@lpdjs/firestore-repo-service 2.2.6 → 2.2.8
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/{create-servers-DmggzSb3.d.cts → create-servers-BGtAS0oG.d.cts} +3 -3
- package/dist/{create-servers-D4-NGpKm.d.ts → create-servers-DMszgNtg.d.ts} +3 -3
- package/dist/history/index.cjs +2 -0
- package/dist/history/index.cjs.map +1 -0
- package/dist/history/index.d.cts +126 -0
- package/dist/history/index.d.ts +126 -0
- package/dist/history/index.js +2 -0
- package/dist/history/index.js.map +1 -0
- package/dist/{index-Cvip2Sgt.d.ts → index-BSZP0Gz9.d.ts} +3 -3
- package/dist/{index-DpD4DEqH.d.cts → index-D7oj3Pft.d.cts} +3 -3
- package/dist/index.cjs +120 -102
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +21 -12
- package/dist/index.d.ts +21 -12
- package/dist/index.js +120 -102
- package/dist/index.js.map +1 -1
- package/dist/{openapi-B3P2F8op.d.ts → openapi-BdqIkSjO.d.ts} +1 -1
- package/dist/{openapi-UJJ1aCFk.d.cts → openapi-lY43PZXy.d.cts} +1 -1
- package/dist/read-DfXXxhO4.d.cts +230 -0
- package/dist/read-DfXXxhO4.d.ts +230 -0
- package/dist/servers/admin/index.cjs +31 -13
- package/dist/servers/admin/index.cjs.map +1 -1
- package/dist/servers/admin/index.d.cts +4 -2
- package/dist/servers/admin/index.d.ts +4 -2
- package/dist/servers/admin/index.js +31 -13
- package/dist/servers/admin/index.js.map +1 -1
- package/dist/servers/crud/index.d.cts +6 -4
- package/dist/servers/crud/index.d.ts +6 -4
- package/dist/servers/index.cjs +33 -15
- package/dist/servers/index.cjs.map +1 -1
- package/dist/servers/index.d.cts +6 -5
- package/dist/servers/index.d.ts +6 -5
- package/dist/servers/index.js +33 -15
- package/dist/servers/index.js.map +1 -1
- package/dist/{types-Z9Qy8Xmx.d.ts → types-BESS89Fu.d.cts} +30 -12
- package/dist/{types-Z9Qy8Xmx.d.cts → types-BVUFVcpl.d.ts} +30 -12
- package/package.json +17 -1
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import 'zod';
|
|
2
2
|
import 'firebase-functions/v2/https';
|
|
3
|
-
import '../../types-
|
|
4
|
-
export { A as AdminRepoConfig, a as AdminRepoEntry, b as AdminServerOptions, B as BasicAuthConfig, c as Middleware, M as MiniRouter, d as RepoRegistry, e as RouteHandler, f as createAdminServer } from '../../index-
|
|
3
|
+
import '../../types-BESS89Fu.cjs';
|
|
4
|
+
export { A as AdminRepoConfig, a as AdminRepoEntry, b as AdminServerOptions, B as BasicAuthConfig, c as Middleware, M as MiniRouter, d as RepoRegistry, e as RouteHandler, f as createAdminServer } from '../../index-D7oj3Pft.cjs';
|
|
5
|
+
import '../../read-DfXXxhO4.cjs';
|
|
5
6
|
import 'firebase-admin/firestore';
|
|
7
|
+
import 'firebase-functions/v2/firestore';
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import 'zod';
|
|
2
2
|
import 'firebase-functions/v2/https';
|
|
3
|
-
import '../../types-
|
|
4
|
-
export { A as AdminRepoConfig, a as AdminRepoEntry, b as AdminServerOptions, B as BasicAuthConfig, c as Middleware, M as MiniRouter, d as RepoRegistry, e as RouteHandler, f as createAdminServer } from '../../index-
|
|
3
|
+
import '../../types-BVUFVcpl.js';
|
|
4
|
+
export { A as AdminRepoConfig, a as AdminRepoEntry, b as AdminServerOptions, B as BasicAuthConfig, c as Middleware, M as MiniRouter, d as RepoRegistry, e as RouteHandler, f as createAdminServer } from '../../index-BSZP0Gz9.js';
|
|
5
|
+
import '../../read-DfXXxhO4.js';
|
|
5
6
|
import 'firebase-admin/firestore';
|
|
7
|
+
import 'firebase-functions/v2/firestore';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {jsx,jsxs,Fragment}from'hono/jsx/jsx-runtime';import {z}from'zod';import {renderToString}from'hono/jsx/dom/server';var Nt=Object.defineProperty;var Se=(e,t)=>()=>(e&&(t=e(e=0)),t);var It=(e,t)=>{for(var n in t)Nt(e,n,{get:t[n],enumerable:true});};function j(e){let t=e,n=t._zod?.def?.type;if(n)return zt[n]??`Zod${n.charAt(0).toUpperCase()}${n.slice(1)}`;let r=t._def?.typeName;return r||""}function q(e){let t=e;if(t._zod?.def?.innerType)return t._zod.def.innerType;if(t._def?.innerType)return t._def.innerType}function Ye(e){let t=e;if(t._zod?.def?.element)return t._zod.def.element;if(t._def?.type)return t._def.type}function et(e){let t=e;if(t._zod?.def?.defaultValue!==void 0)return t._zod.def.defaultValue;let n=t._def?.defaultValue;return typeof n=="function"?n():n}function Q(e){let t=e;return t.shape&&typeof t.shape=="object"?t.shape:t._zod?.def?.shape&&typeof t._zod.def.shape=="object"?t._zod.def.shape:t._def?.shape?typeof t._def.shape=="function"?t._def.shape():t._def.shape:{}}function ye(e){let t=e;return Array.isArray(t.options)?t.options:t._zod?.def?.entries?Object.values(t._zod.def.entries):Array.isArray(t._def?.values)?t._def.values:[]}function ge(e){let t=e;return t._zod?.def?.entries?t._zod.def.entries:t.enum&&typeof t.enum=="object"?t.enum:t._def?.values&&typeof t._def.values=="object"?t._def.values:{}}function Re(e){let t=e;return Array.isArray(t._zod?.def?.values)?t._zod.def.values[0]:t._def?.value}function tt(e){let t=e,n=[],r=t._zod?.def?.checks;if(Array.isArray(r)){for(let s of r)s.format&&n.push(s.format);if(n.length>0)return n}let a=t._def?.checks;if(Array.isArray(a))for(let s of a)s.kind&&n.push(s.kind);return n}var zt,$e=Se(()=>{zt={string:"ZodString",number:"ZodNumber",bigint:"ZodBigInt",boolean:"ZodBoolean",date:"ZodDate",enum:"ZodEnum",nativeEnum:"ZodNativeEnum",literal:"ZodLiteral",object:"ZodObject",array:"ZodArray",optional:"ZodOptional",nullable:"ZodNullable",default:"ZodDefault",coerce:"ZodCoerce",union:"ZodUnion",undefined:"ZodUndefined",unknown:"ZodUnknown",any:"ZodAny",record:"ZodRecord"};});function it({val:e}){return jsx("span",{class:"text-sm text-base-content/80 font-mono tabular-nums whitespace-nowrap",children:e.toLocaleString()})}function Ft({message:e}){return jsx("span",{class:"tooltip tooltip-warning tooltip-right inline-flex align-middle ml-1 text-warning","data-tip":e,role:"img","aria-label":e,children:jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",class:"size-3.5",children:jsx("path",{d:"M12 2 1 22h22L12 2zm0 6 7.5 13h-15L12 8zm-1 4v4h2v-4h-2zm0 5v2h2v-2h-2z"})})})}function pe({val:e,mismatch:t}){let n=jt(e);return t?jsxs("span",{class:"inline-flex items-start gap-0.5",children:[n,jsx(Ft,{message:t})]}):n}function jt(e){if(e==null)return jsx("span",{class:"opacity-30 italic text-xs",children:"\u2014"});if(typeof e=="boolean")return e?jsx("span",{class:"badge badge-success badge-sm",children:"true"}):jsx("span",{class:"badge badge-error badge-sm",children:"false"});if(e instanceof Date)return jsx(it,{val:e});if(typeof e=="object"&&e!==null&&typeof e.toDate=="function")return jsx(it,{val:e.toDate()});if(typeof e=="number")return jsx("span",{class:"text-sm font-mono tabular-nums",children:String(e)});if(Array.isArray(e))return e.length===0?jsx("span",{class:"text-xs text-base-content/30",children:"[]"}):jsxs("ul",{class:"list-none p-0 m-0 space-y-0.5 text-xs",children:[e.slice(0,8).map((n,r)=>jsx("li",{class:"break-all",children:typeof n=="object"?JSON.stringify(n):String(n)},r)),e.length>8&&jsxs("li",{class:"text-base-content/40 italic",children:["+",e.length-8," more\u2026"]})]});if(typeof e=="object"&&e!==null){let n=Object.entries(e);return n.length===0?jsx("span",{class:"text-xs text-base-content/30",children:"{}"}):jsxs("dl",{class:"grid grid-cols-[auto_1fr] gap-x-2 gap-y-0.5 text-xs m-0",children:[n.slice(0,8).map(([r,a])=>jsxs(Fragment,{children:[jsx("dt",{class:"text-base-content/50 font-semibold whitespace-nowrap",children:r}),jsx("dd",{class:"break-all",children:String(a??"")})]})),n.length>8&&jsxs("dt",{class:"col-span-2 text-base-content/40 italic",children:["+",n.length-8," more\u2026"]})]})}let t=String(e);return jsx("span",{class:"text-sm break-all",children:t})}var Ae=Se(()=>{});function fe(e){if(!e)return "unknown";let t=_e(e);switch(j(t)){case "ZodString":return "string";case "ZodNumber":return "number";case "ZodBigInt":return "bigint";case "ZodBoolean":return "boolean";case "ZodDate":return "date";case "ZodArray":return "array";case "ZodObject":case "ZodRecord":return "object";case "ZodEnum":case "ZodNativeEnum":return "enum";case "ZodLiteral":return "literal";default:return "unknown"}}function _e(e){let t=j(e);if(t==="ZodOptional"||t==="ZodNullable"||t==="ZodDefault"){let n=q(e);return n?_e(n):e}return e}function me(e,t){if(!e)return;let n=t.split("."),r=e;for(let a of n){if(!r)return;let s=_e(r);if(j(s)!=="ZodObject")return;r=Q(s)[a];}return r}function Ut(e){return e==null?"null":e instanceof Date?"date":Array.isArray(e)?"array":typeof e=="string"?"string":typeof e=="boolean"?"boolean":typeof e=="bigint"?"bigint":typeof e=="number"?"number":typeof e=="object"?typeof e.toDate=="function"?"date":"object":"unknown"}function he(e,t){if(e==="unknown")return null;let n=Ut(t);return n==="null"?null:e==="enum"||e==="literal"?n==="string"||n==="number"?null:`Expected ${e} (string/number), got ${n}`:e===n||e==="number"&&n==="bigint"||e==="bigint"&&n==="number"?null:`Expected ${e}, got ${n}`}var Oe=Se(()=>{$e();});var ct={};It(ct,{PanelMany:()=>Ht,PanelOne:()=>qt,RightPanel:()=>Ze});function qt({doc:e,repoName:t,basePath:n,schema:r,columns:a}){if(!e)return jsx("div",{class:"text-center py-12 text-base-content/50",children:"Document not found."});let s=String(e.docId??e.id??""),o=`${n}/${t}/${encodeURIComponent(s)}/edit`,d=dt(r,a);return jsxs("div",{class:"space-y-4",children:[jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxs("div",{class:"text-xs text-base-content/60",children:[jsx("span",{class:"font-mono",children:t}),jsx("span",{class:"opacity-50",children:" \xB7 "}),jsx("span",{class:"font-mono break-all",children:s})]}),jsx("a",{href:o,class:"btn btn-sm btn-primary",children:"Edit \u2192"})]}),jsx("dl",{class:"grid grid-cols-[max-content_1fr] gap-x-4 gap-y-2 border border-base-300 rounded-box p-4 bg-base-100",children:a.map(l=>{let p=e[l],m=d[l],E=m?he(m,p):null;return jsxs(Fragment,{children:[jsx("dt",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide pt-0.5",children:l}),jsx("dd",{class:"min-w-0",children:jsx(pe,{val:p,mismatch:E})})]})})})]})}function Ht({docs:e,repoName:t,basePath:n,fk:r,fv:a,columns:s,schema:o,pagination:d}){let l=`${n}/${t}?fv_${r}=${encodeURIComponent(a)}`,p=dt(o,s);return jsxs("div",{class:"space-y-4",children:[jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxs("div",{class:"text-xs text-base-content/60",children:[jsx("span",{class:"font-mono",children:t}),jsx("span",{class:"opacity-50",children:" where "}),jsx("span",{class:"font-mono",children:r}),jsx("span",{class:"opacity-50",children:" = "}),jsx("span",{class:"font-mono break-all",children:a}),jsx("span",{class:"opacity-50",children:" \xB7 "}),jsxs("span",{children:[e.length," doc",e.length!==1?"s":""]})]}),jsx("a",{href:l,class:"btn btn-sm btn-outline",children:"Full view \u2192"})]}),jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100",children:jsxs("table",{class:"table table-xs w-full",children:[jsx("thead",{children:jsxs("tr",{class:"bg-base-200/50",children:[s.map((m,E)=>jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:m},E)),jsx("th",{})]})}),jsx("tbody",{children:e.length===0?jsx("tr",{children:jsx("td",{colspan:s.length+1,class:"text-center py-10 text-base-content/40",children:"No related documents"})}):e.map((m,E)=>{let h=String(m.docId??m.id??""),w=`${n}/${t}/${encodeURIComponent(h)}/edit`;return jsxs("tr",{class:"hover",children:[s.map((A,F)=>{let b=m[A],c=p[A],g=c?he(c,b):null;return jsx("td",{class:"align-top py-1.5",children:jsx(pe,{val:b,mismatch:g})},F)}),jsx("td",{class:"text-right py-1.5",children:jsx("a",{href:w,class:"btn btn-xs btn-ghost",children:"Edit"})})]},E)})})]})}),(d.hasPrev||d.hasNext)&&jsxs("div",{class:"flex justify-center items-center gap-2",children:[d.hasPrev?jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"prev","data-cursor":d.prevCursor,children:"\u2190 Previous"}):jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"\u2190 Previous"}),d.hasNext?jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"next","data-cursor":d.nextCursor,children:"Next \u2192"}):jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"Next \u2192"})]})]})}function dt(e,t){if(!e)return {};let n={};for(let r of t)n[r]=fe(me(e,r));return n}var Ze,Ne=Se(()=>{Ae();Oe();Ze=()=>jsxs("div",{class:"fixed inset-0 z-[100] hidden pointer-events-none","data-frs-panel-root":true,"aria-hidden":"true",children:[jsx("div",{class:"absolute inset-0 bg-black/30 opacity-0 transition-opacity duration-200 pointer-events-auto","data-frs-panel-backdrop":true}),jsxs("aside",{class:"absolute top-0 right-0 h-full w-full md:w-1/2 bg-base-100 shadow-2xl border-l border-base-300 translate-x-full transition-transform duration-200 pointer-events-auto flex flex-col","data-frs-panel":true,role:"dialog","aria-label":"Relation preview",children:[jsxs("header",{class:"flex items-center justify-between px-5 py-3 border-b border-base-300 bg-base-200/40 shrink-0",children:[jsx("h2",{class:"font-semibold text-base truncate","data-frs-panel-title":true,children:"Relation"}),jsx("button",{type:"button",class:"btn btn-sm btn-ghost btn-circle","data-frs-panel-close":true,"aria-label":"Close panel",children:"\u2715"})]}),jsx("div",{class:"flex-1 overflow-auto p-5 text-sm","data-frs-panel-body":true,children:jsx("div",{class:"flex items-center justify-center py-12 text-base-content/40",children:jsx("span",{class:"loading loading-spinner loading-md"})})})]})]});});$e();$e();function Pt(e){return e.replace(/([A-Z])/g," $1").replace(/_/g," ").replace(/^\s/,"").replace(/^./,t=>t.toUpperCase())}function nt(e){let t=e,n=true,r=false,a;for(;;){let s=j(t);if(s==="ZodOptional")n=false,t=q(t);else if(s==="ZodNullable")n=false,r=true,t=q(t);else if(s==="ZodDefault")n=false,a=et(t),t=q(t);else break}return {inner:t,required:n,nullable:r,defaultValue:a}}function X(e,t=""){if(j(e)==="ZodObject"){let r=Q(e);return Object.entries(r).map(([a,s])=>rt(t?`${t}.${a}`:a,a,s))}return [rt(t||"value",t||"value",e)]}function rt(e,t,n){let{inner:r,required:a,nullable:s,defaultValue:o}=nt(n),d=j(r),l=Pt(t.split(".").pop()??t);switch(d){case "ZodString":{let p=tt(r),m=p.includes("email"),E=p.includes("url");return {name:e,label:l,type:"text",required:a,nullable:s,defaultValue:o,hint:m?"email":E?"url":void 0}}case "ZodNumber":case "ZodBigInt":return {name:e,label:l,type:"number",required:a,nullable:s,defaultValue:o};case "ZodBoolean":return {name:e,label:l,type:"checkbox",required:a,nullable:s,defaultValue:o};case "ZodDate":case "ZodCoerce":return {name:e,label:l,type:"datetime-local",required:a,nullable:s,defaultValue:o};case "ZodEnum":{let p=ye(r);return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:p}}case "ZodNativeEnum":{let p=ge(r),m=Object.values(p).filter(E=>typeof E=="string");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:m}}case "ZodLiteral":{let p=String(Re(r)??"");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:[p]}}case "ZodObject":{let p=X(r,e);return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,nested:p,hint:"JSON object"}}case "ZodArray":{let p=Ye(r);if(!p)return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON array"};let{inner:m}=nt(p),E=j(m),h,w,A;switch(E){case "ZodString":h="text";break;case "ZodNumber":case "ZodBigInt":h="number";break;case "ZodBoolean":h="checkbox";break;case "ZodDate":h="datetime-local";break;case "ZodEnum":h="select",w=ye(m);break;case "ZodNativeEnum":h="select",w=Object.values(ge(m)).filter(F=>typeof F=="string");break;case "ZodObject":h="object",A=X(m);break;default:return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON array"}}return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,arrayElementType:h,arrayElementOptions:w,arrayElementFields:A}}default:return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON"}}}function ot(e,t=0){let n=t>0?`ml-${t*4}`:"",r=`field_${e.name.replace(/\./g,"__")}`,a=e.name,s=e.required?" required":"",o=e.defaultValue==="__null__",d=!o&&e.defaultValue!=null?String(e.defaultValue):"",l=e.nullable&&e.type!=="checkbox"?`<span class="flex items-center gap-1 shrink-0">
|
|
1
|
+
import {jsx,jsxs,Fragment}from'hono/jsx/jsx-runtime';import {z}from'zod';import {renderToString}from'hono/jsx/dom/server';var Nt=Object.defineProperty;var Se=(e,t)=>()=>(e&&(t=e(e=0)),t);var It=(e,t)=>{for(var n in t)Nt(e,n,{get:t[n],enumerable:true});};function j(e){let t=e,n=t._zod?.def?.type;if(n)return Pt[n]??`Zod${n.charAt(0).toUpperCase()}${n.slice(1)}`;let r=t._def?.typeName;return r||""}function q(e){let t=e;if(t._zod?.def?.innerType)return t._zod.def.innerType;if(t._def?.innerType)return t._def.innerType}function Ye(e){let t=e;if(t._zod?.def?.element)return t._zod.def.element;if(t._def?.type)return t._def.type}function et(e){let t=e;if(t._zod?.def?.defaultValue!==void 0)return t._zod.def.defaultValue;let n=t._def?.defaultValue;return typeof n=="function"?n():n}function Q(e){let t=e;return t.shape&&typeof t.shape=="object"?t.shape:t._zod?.def?.shape&&typeof t._zod.def.shape=="object"?t._zod.def.shape:t._def?.shape?typeof t._def.shape=="function"?t._def.shape():t._def.shape:{}}function ye(e){let t=e;return Array.isArray(t.options)?t.options:t._zod?.def?.entries?Object.values(t._zod.def.entries):Array.isArray(t._def?.values)?t._def.values:[]}function ge(e){let t=e;return t._zod?.def?.entries?t._zod.def.entries:t.enum&&typeof t.enum=="object"?t.enum:t._def?.values&&typeof t._def.values=="object"?t._def.values:{}}function Re(e){let t=e;return Array.isArray(t._zod?.def?.values)?t._zod.def.values[0]:t._def?.value}function tt(e){let t=e,n=[],r=t._zod?.def?.checks;if(Array.isArray(r)){for(let s of r)s.format&&n.push(s.format);if(n.length>0)return n}let a=t._def?.checks;if(Array.isArray(a))for(let s of a)s.kind&&n.push(s.kind);return n}var Pt,$e=Se(()=>{Pt={string:"ZodString",number:"ZodNumber",bigint:"ZodBigInt",boolean:"ZodBoolean",date:"ZodDate",enum:"ZodEnum",nativeEnum:"ZodNativeEnum",literal:"ZodLiteral",object:"ZodObject",array:"ZodArray",optional:"ZodOptional",nullable:"ZodNullable",default:"ZodDefault",coerce:"ZodCoerce",union:"ZodUnion",undefined:"ZodUndefined",unknown:"ZodUnknown",any:"ZodAny",record:"ZodRecord"};});function it({val:e}){return jsx("span",{class:"text-sm text-base-content/80 font-mono tabular-nums whitespace-nowrap",children:e.toLocaleString()})}function Ft({message:e}){return jsx("span",{class:"tooltip tooltip-warning tooltip-right inline-flex align-middle ml-1 text-warning","data-tip":e,role:"img","aria-label":e,children:jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",class:"size-3.5",children:jsx("path",{d:"M12 2 1 22h22L12 2zm0 6 7.5 13h-15L12 8zm-1 4v4h2v-4h-2zm0 5v2h2v-2h-2z"})})})}function pe({val:e,mismatch:t}){let n=jt(e);return t?jsxs("span",{class:"inline-flex items-start gap-0.5",children:[n,jsx(Ft,{message:t})]}):n}function jt(e){if(e==null)return jsx("span",{class:"opacity-30 italic text-xs",children:"\u2014"});if(typeof e=="boolean")return e?jsx("span",{class:"badge badge-success badge-sm",children:"true"}):jsx("span",{class:"badge badge-error badge-sm",children:"false"});if(e instanceof Date)return jsx(it,{val:e});if(typeof e=="object"&&e!==null&&typeof e.toDate=="function")return jsx(it,{val:e.toDate()});if(typeof e=="number")return jsx("span",{class:"text-sm font-mono tabular-nums",children:String(e)});if(Array.isArray(e))return e.length===0?jsx("span",{class:"text-xs text-base-content/30",children:"[]"}):jsxs("ul",{class:"list-none p-0 m-0 space-y-0.5 text-xs",children:[e.slice(0,8).map((n,r)=>jsx("li",{class:"break-all",children:typeof n=="object"?JSON.stringify(n):String(n)},r)),e.length>8&&jsxs("li",{class:"text-base-content/40 italic",children:["+",e.length-8," more\u2026"]})]});if(typeof e=="object"&&e!==null){let n=Object.entries(e);return n.length===0?jsx("span",{class:"text-xs text-base-content/30",children:"{}"}):jsxs("dl",{class:"grid grid-cols-[auto_1fr] gap-x-2 gap-y-0.5 text-xs m-0",children:[n.slice(0,8).map(([r,a])=>jsxs(Fragment,{children:[jsx("dt",{class:"text-base-content/50 font-semibold whitespace-nowrap",children:r}),jsx("dd",{class:"break-all",children:String(a??"")})]})),n.length>8&&jsxs("dt",{class:"col-span-2 text-base-content/40 italic",children:["+",n.length-8," more\u2026"]})]})}let t=String(e);return jsx("span",{class:"text-sm break-all",children:t})}var Ae=Se(()=>{});function fe(e){if(!e)return "unknown";let t=_e(e);switch(j(t)){case "ZodString":return "string";case "ZodNumber":return "number";case "ZodBigInt":return "bigint";case "ZodBoolean":return "boolean";case "ZodDate":return "date";case "ZodArray":return "array";case "ZodObject":case "ZodRecord":return "object";case "ZodEnum":case "ZodNativeEnum":return "enum";case "ZodLiteral":return "literal";default:return "unknown"}}function _e(e){let t=j(e);if(t==="ZodOptional"||t==="ZodNullable"||t==="ZodDefault"){let n=q(e);return n?_e(n):e}return e}function me(e,t){if(!e)return;let n=t.split("."),r=e;for(let a of n){if(!r)return;let s=_e(r);if(j(s)!=="ZodObject")return;r=Q(s)[a];}return r}function Ut(e){return e==null?"null":e instanceof Date?"date":Array.isArray(e)?"array":typeof e=="string"?"string":typeof e=="boolean"?"boolean":typeof e=="bigint"?"bigint":typeof e=="number"?"number":typeof e=="object"?typeof e.toDate=="function"?"date":"object":"unknown"}function he(e,t){if(e==="unknown")return null;let n=Ut(t);return n==="null"?null:e==="enum"||e==="literal"?n==="string"||n==="number"?null:`Expected ${e} (string/number), got ${n}`:e===n||e==="number"&&n==="bigint"||e==="bigint"&&n==="number"?null:`Expected ${e}, got ${n}`}var Oe=Se(()=>{$e();});var ct={};It(ct,{PanelMany:()=>Ht,PanelOne:()=>qt,RightPanel:()=>Ze});function qt({doc:e,repoName:t,basePath:n,schema:r,columns:a}){if(!e)return jsx("div",{class:"text-center py-12 text-base-content/50",children:"Document not found."});let s=String(e.docId??e.id??""),o=`${n}/${t}/${encodeURIComponent(s)}/edit`,d=dt(r,a);return jsxs("div",{class:"space-y-4",children:[jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxs("div",{class:"text-xs text-base-content/60",children:[jsx("span",{class:"font-mono",children:t}),jsx("span",{class:"opacity-50",children:" \xB7 "}),jsx("span",{class:"font-mono break-all",children:s})]}),jsx("a",{href:o,class:"btn btn-sm btn-primary",children:"Edit \u2192"})]}),jsx("dl",{class:"grid grid-cols-[max-content_1fr] gap-x-4 gap-y-2 border border-base-300 rounded-box p-4 bg-base-100",children:a.map(l=>{let p=e[l],m=d[l],E=m?he(m,p):null;return jsxs(Fragment,{children:[jsx("dt",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide pt-0.5",children:l}),jsx("dd",{class:"min-w-0",children:jsx(pe,{val:p,mismatch:E})})]})})})]})}function Ht({docs:e,repoName:t,basePath:n,fk:r,fv:a,columns:s,schema:o,pagination:d}){let l=`${n}/${t}?fv_${r}=${encodeURIComponent(a)}`,p=dt(o,s);return jsxs("div",{class:"space-y-4",children:[jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxs("div",{class:"text-xs text-base-content/60",children:[jsx("span",{class:"font-mono",children:t}),jsx("span",{class:"opacity-50",children:" where "}),jsx("span",{class:"font-mono",children:r}),jsx("span",{class:"opacity-50",children:" = "}),jsx("span",{class:"font-mono break-all",children:a}),jsx("span",{class:"opacity-50",children:" \xB7 "}),jsxs("span",{children:[e.length," doc",e.length!==1?"s":""]})]}),jsx("a",{href:l,class:"btn btn-sm btn-outline",children:"Full view \u2192"})]}),jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100",children:jsxs("table",{class:"table table-xs w-full",children:[jsx("thead",{children:jsxs("tr",{class:"bg-base-200/50",children:[s.map((m,E)=>jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:m},E)),jsx("th",{})]})}),jsx("tbody",{children:e.length===0?jsx("tr",{children:jsx("td",{colspan:s.length+1,class:"text-center py-10 text-base-content/40",children:"No related documents"})}):e.map((m,E)=>{let h=String(m.docId??m.id??""),w=`${n}/${t}/${encodeURIComponent(h)}/edit`;return jsxs("tr",{class:"hover",children:[s.map((A,F)=>{let b=m[A],c=p[A],g=c?he(c,b):null;return jsx("td",{class:"align-top py-1.5",children:jsx(pe,{val:b,mismatch:g})},F)}),jsx("td",{class:"text-right py-1.5",children:jsx("a",{href:w,class:"btn btn-xs btn-ghost",children:"Edit"})})]},E)})})]})}),(d.hasPrev||d.hasNext)&&jsxs("div",{class:"flex justify-center items-center gap-2",children:[d.hasPrev?jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"prev","data-cursor":d.prevCursor,children:"\u2190 Previous"}):jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"\u2190 Previous"}),d.hasNext?jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"next","data-cursor":d.nextCursor,children:"Next \u2192"}):jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"Next \u2192"})]})]})}function dt(e,t){if(!e)return {};let n={};for(let r of t)n[r]=fe(me(e,r));return n}var Ze,Ne=Se(()=>{Ae();Oe();Ze=({basePath:e=""})=>jsxs("div",{class:"fixed inset-0 z-[100] hidden pointer-events-none","data-frs-panel-root":true,"data-frs-base-path":e,"aria-hidden":"true",children:[jsx("div",{class:"absolute inset-0 bg-black/30 opacity-0 transition-opacity duration-200 pointer-events-auto","data-frs-panel-backdrop":true}),jsxs("aside",{class:"absolute top-0 right-0 h-full w-full md:w-1/2 bg-base-100 shadow-2xl border-l border-base-300 translate-x-full transition-transform duration-200 pointer-events-auto flex flex-col","data-frs-panel":true,role:"dialog","aria-label":"Relation preview",children:[jsxs("header",{class:"flex items-center justify-between px-5 py-3 border-b border-base-300 bg-base-200/40 shrink-0",children:[jsx("h2",{class:"font-semibold text-base truncate","data-frs-panel-title":true,children:"Relation"}),jsx("button",{type:"button",class:"btn btn-sm btn-ghost btn-circle","data-frs-panel-close":true,"aria-label":"Close panel",children:"\u2715"})]}),jsx("div",{class:"flex-1 overflow-auto p-5 text-sm","data-frs-panel-body":true,children:jsx("div",{class:"flex items-center justify-center py-12 text-base-content/40",children:jsx("span",{class:"loading loading-spinner loading-md"})})})]})]});});$e();$e();function zt(e){return e.replace(/([A-Z])/g," $1").replace(/_/g," ").replace(/^\s/,"").replace(/^./,t=>t.toUpperCase())}function nt(e){let t=e,n=true,r=false,a;for(;;){let s=j(t);if(s==="ZodOptional")n=false,t=q(t);else if(s==="ZodNullable")n=false,r=true,t=q(t);else if(s==="ZodDefault")n=false,a=et(t),t=q(t);else break}return {inner:t,required:n,nullable:r,defaultValue:a}}function X(e,t=""){if(j(e)==="ZodObject"){let r=Q(e);return Object.entries(r).map(([a,s])=>rt(t?`${t}.${a}`:a,a,s))}return [rt(t||"value",t||"value",e)]}function rt(e,t,n){let{inner:r,required:a,nullable:s,defaultValue:o}=nt(n),d=j(r),l=zt(t.split(".").pop()??t);switch(d){case "ZodString":{let p=tt(r),m=p.includes("email"),E=p.includes("url");return {name:e,label:l,type:"text",required:a,nullable:s,defaultValue:o,hint:m?"email":E?"url":void 0}}case "ZodNumber":case "ZodBigInt":return {name:e,label:l,type:"number",required:a,nullable:s,defaultValue:o};case "ZodBoolean":return {name:e,label:l,type:"checkbox",required:a,nullable:s,defaultValue:o};case "ZodDate":case "ZodCoerce":return {name:e,label:l,type:"datetime-local",required:a,nullable:s,defaultValue:o};case "ZodEnum":{let p=ye(r);return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:p}}case "ZodNativeEnum":{let p=ge(r),m=Object.values(p).filter(E=>typeof E=="string");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:m}}case "ZodLiteral":{let p=String(Re(r)??"");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:[p]}}case "ZodObject":{let p=X(r,e);return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,nested:p,hint:"JSON object"}}case "ZodArray":{let p=Ye(r);if(!p)return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON array"};let{inner:m}=nt(p),E=j(m),h,w,A;switch(E){case "ZodString":h="text";break;case "ZodNumber":case "ZodBigInt":h="number";break;case "ZodBoolean":h="checkbox";break;case "ZodDate":h="datetime-local";break;case "ZodEnum":h="select",w=ye(m);break;case "ZodNativeEnum":h="select",w=Object.values(ge(m)).filter(F=>typeof F=="string");break;case "ZodObject":h="object",A=X(m);break;default:return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON array"}}return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,arrayElementType:h,arrayElementOptions:w,arrayElementFields:A}}default:return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON"}}}function ot(e,t=0){let n=t>0?`ml-${t*4}`:"",r=`field_${e.name.replace(/\./g,"__")}`,a=e.name,s=e.required?" required":"",o=e.defaultValue==="__null__",d=!o&&e.defaultValue!=null?String(e.defaultValue):"",l=e.nullable&&e.type!=="checkbox"?`<span class="flex items-center gap-1 shrink-0">
|
|
2
2
|
<input type="hidden" id="${r}__isnull" name="${a}__isnull" value="${o?"1":""}">
|
|
3
3
|
<label class="flex items-center gap-1 cursor-pointer select-none text-xs text-base-content/40 hover:text-base-content/70 border border-base-300 rounded px-2 py-1">
|
|
4
4
|
<input type="checkbox" class="checkbox checkbox-xs" ${o?"checked":""}
|
|
@@ -133,7 +133,15 @@ import {jsx,jsxs,Fragment}from'hono/jsx/jsx-runtime';import {z}from'zod';import
|
|
|
133
133
|
<button type="submit" class="btn btn-primary btn-sm">${R(r)}</button>
|
|
134
134
|
<button type="button" class="btn btn-ghost btn-sm" onclick="history.back()">Cancel</button>
|
|
135
135
|
</div>
|
|
136
|
-
</form>`}Ae();var lt=`// \u2500\u2500
|
|
136
|
+
</form>`}Ae();var lt=`// \u2500\u2500 Shared helpers \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500
|
|
137
|
+
function frsGetBasePath() {
|
|
138
|
+
var root = document.querySelector("[data-frs-panel-root]");
|
|
139
|
+
var bp = root && root.getAttribute("data-frs-base-path");
|
|
140
|
+
if (typeof bp === "string") return bp.replace(/\\/$/, "");
|
|
141
|
+
return window.location.pathname.replace(/\\/[^/]*\\/?$/, "");
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
// \u2500\u2500 Right panel (relations preview) \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500
|
|
137
145
|
(function () {
|
|
138
146
|
function panelEls() {
|
|
139
147
|
return {
|
|
@@ -151,7 +159,11 @@ import {jsx,jsxs,Fragment}from'hono/jsx/jsx-runtime';import {z}from'zod';import
|
|
|
151
159
|
els.root.setAttribute("aria-hidden", "false");
|
|
152
160
|
requestAnimationFrame(function () {
|
|
153
161
|
if (els.backdrop) els.backdrop.style.opacity = "1";
|
|
154
|
-
if (els.panel)
|
|
162
|
+
if (els.panel) {
|
|
163
|
+
els.panel.classList.remove("translate-x-full");
|
|
164
|
+
els.panel.style.transform = "translateX(0)";
|
|
165
|
+
els.panel.style.translate = "0 0";
|
|
166
|
+
}
|
|
155
167
|
});
|
|
156
168
|
if (els.title) els.title.textContent = label || "Relation";
|
|
157
169
|
if (els.body) {
|
|
@@ -163,17 +175,18 @@ import {jsx,jsxs,Fragment}from'hono/jsx/jsx-runtime';import {z}from'zod';import
|
|
|
163
175
|
var els = panelEls();
|
|
164
176
|
if (!els.root || !els.panel) return;
|
|
165
177
|
if (els.backdrop) els.backdrop.style.opacity = "0";
|
|
166
|
-
if (els.panel)
|
|
178
|
+
if (els.panel) {
|
|
179
|
+
els.panel.style.transform = "translateX(100%)";
|
|
180
|
+
els.panel.style.translate = "100% 0";
|
|
181
|
+
els.panel.classList.add("translate-x-full");
|
|
182
|
+
}
|
|
167
183
|
setTimeout(function () {
|
|
168
184
|
els.root.classList.add("hidden");
|
|
169
185
|
els.root.setAttribute("aria-hidden", "true");
|
|
170
186
|
}, 200);
|
|
171
187
|
}
|
|
172
|
-
function
|
|
173
|
-
|
|
174
|
-
// We can't know basePath without context, so we derive it from the current URL up to the repoName segment.
|
|
175
|
-
// Caller passes the absolute fragment URL via data attribute; we just need the prefix here.
|
|
176
|
-
return window.location.pathname.replace(/\\/[^/]*\\/?$/, "");
|
|
188
|
+
function getBasePath() {
|
|
189
|
+
return frsGetBasePath();
|
|
177
190
|
}
|
|
178
191
|
function fetchPanel(url, label) {
|
|
179
192
|
openPanel(label);
|
|
@@ -204,7 +217,7 @@ import {jsx,jsxs,Fragment}from'hono/jsx/jsx-runtime';import {z}from'zod';import
|
|
|
204
217
|
var fk = trigger.getAttribute("data-frs-rel-fk");
|
|
205
218
|
var val = trigger.getAttribute("data-frs-rel-val");
|
|
206
219
|
var label = trigger.getAttribute("data-frs-rel-label") || "Relation";
|
|
207
|
-
var bp =
|
|
220
|
+
var bp = getBasePath();
|
|
208
221
|
var url;
|
|
209
222
|
if (type === "one") {
|
|
210
223
|
url =
|
|
@@ -395,7 +408,7 @@ import {jsx,jsxs,Fragment}from'hono/jsx/jsx-runtime';import {z}from'zod';import
|
|
|
395
408
|
var b = bar();
|
|
396
409
|
if (!b) return null;
|
|
397
410
|
var repo = b.getAttribute("data-frs-repo");
|
|
398
|
-
var bp =
|
|
411
|
+
var bp = frsGetBasePath();
|
|
399
412
|
return bp + "/" + encodeURIComponent(repo) + "/_bulk/" + action;
|
|
400
413
|
}
|
|
401
414
|
|
|
@@ -835,7 +848,12 @@ function initColumnVisibility(table) {
|
|
|
835
848
|
if (dataThs.length === 0) return;
|
|
836
849
|
|
|
837
850
|
var wrap = table.closest("[data-frs-table-wrap]");
|
|
838
|
-
var toolbar =
|
|
851
|
+
var toolbar =
|
|
852
|
+
(wrap &&
|
|
853
|
+
(wrap.parentElement
|
|
854
|
+
? wrap.parentElement.querySelector("[data-frs-toolbar]")
|
|
855
|
+
: null)) ||
|
|
856
|
+
(wrap && wrap.previousElementSibling);
|
|
839
857
|
if (!toolbar) return;
|
|
840
858
|
|
|
841
859
|
var repo = table.getAttribute("data-frs-repo") || "default";
|
|
@@ -1024,6 +1042,6 @@ function initColumnReorder(table) {
|
|
|
1024
1042
|
});
|
|
1025
1043
|
});
|
|
1026
1044
|
}
|
|
1027
|
-
`;function Ce(){return jsx("script",{dangerouslySetInnerHTML:{__html:lt}})}Ne();function Y(e){return "<!DOCTYPE html>"+renderToString(e)}var Kt=["corporate","silk","dark"],Gt=()=>jsxs("div",{class:"dropdown dropdown-end","data-frs-theme-switcher":true,children:[jsxs("button",{type:"button",tabIndex:0,class:"btn btn-sm btn-ghost text-neutral-content gap-1.5","aria-label":"Switch theme",children:[jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2",class:"size-4",children:[jsx("circle",{cx:"12",cy:"12",r:"4"}),jsx("path",{d:"M12 2v2M12 20v2M4.93 4.93l1.41 1.41M17.66 17.66l1.41 1.41M2 12h2M20 12h2M4.93 19.07l1.41-1.41M17.66 6.34l1.41-1.41"})]}),jsx("span",{class:"text-xs hidden sm:inline","data-frs-theme-current":true,children:"Theme"})]}),jsx("ul",{tabIndex:0,class:"dropdown-content menu menu-sm bg-base-100 text-base-content rounded-box z-50 mt-2 w-40 p-1 shadow-lg border border-base-300",children:Kt.map(e=>jsx("li",{children:jsxs("button",{type:"button","data-frs-theme":e,class:"capitalize justify-between",children:[jsx("span",{children:e}),jsx("span",{class:"hidden text-primary","data-frs-theme-check":e,children:"\u2713"})]})},e))})]}),ee=({opts:e,children:t})=>{let{title:n,breadcrumb:r,flash:a,basePath:s="/"}=e;return jsxs("html",{lang:"en","data-theme":"corporate",children:[jsxs("head",{children:[jsx("meta",{charset:"UTF-8"}),jsx("meta",{name:"viewport",content:"width=device-width, initial-scale=1"}),jsxs("title",{children:[n," \u2014 FRS Admin"]}),jsx("script",{dangerouslySetInnerHTML:{__html:"(function(){try{var t=localStorage.getItem('frs-admin-theme');if(t){document.documentElement.setAttribute('data-theme',t);}}catch(_){}})();"}}),jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/themes.css",rel:"stylesheet",type:"text/css"}),jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/daisyui.css",rel:"stylesheet",type:"text/css"}),jsx("script",{src:"https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"})]}),jsxs("body",{class:"bg-base-200/50 min-h-screen flex flex-col",children:[jsxs("div",{class:"navbar bg-neutral text-neutral-content shadow-sm sticky top-0 z-50 px-6",children:[jsx("div",{class:"flex-1",children:jsx("a",{href:s,class:"font-bold text-lg tracking-tight hover:opacity-80 transition-opacity",children:"FRS Admin"})}),jsx("div",{class:"flex-none",children:jsx(Gt,{})})]}),jsxs("main",{class:"px-6 py-8 w-full flex-1",children:[r&&r.length>0&&jsx("div",{class:"text-sm breadcrumbs mb-4",children:jsx("ul",{children:r.map((o,d)=>o.href?jsx("li",{children:jsx("a",{href:o.href,children:o.label})},d):jsx("li",{class:"text-base-content/60",children:o.label},d))})}),jsx("h1",{class:"text-2xl font-bold mb-6",children:n}),a&&jsxs("div",{role:"alert",class:`alert ${a.type==="success"?"alert-success":a.type==="warning"?"alert-warning":"alert-error"} mb-6`,children:[jsx("span",{class:"flex-1",children:a.message}),a.action&&jsx("a",{href:a.action.href,...a.action.external?{target:"_blank",rel:"noopener noreferrer"}:{},class:"btn btn-sm btn-outline",children:a.action.label})]}),t]}),jsx(Ze,{}),jsx(Ce,{})]})]})};function Ie(e,t){return Y(jsx(ee,{opts:t,children:jsx("div",{dangerouslySetInnerHTML:{__html:e}})}))}function ze(e,t){return Y(jsx(ee,{opts:{title:"Repositories",basePath:t},children:e.length===0?jsxs("div",{class:"text-center py-20 text-base-content/50",children:[jsx("p",{class:"text-lg font-medium mb-1",children:"No repositories configured"}),jsx("p",{class:"text-sm",children:"Add a repository to your FRS config to get started."})]}):jsx("div",{class:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-4",children:e.map(n=>jsx("a",{href:`${t}/${n.name}`,class:"card bg-base-100 border border-base-300 hover:shadow-md no-underline transition-shadow",children:jsxs("div",{class:"card-body p-5",children:[jsx("h2",{class:"card-title text-sm font-semibold",children:n.name}),jsx("p",{class:"text-xs text-base-content/50 font-mono",children:n.path})]})},n.name))})}))}var pt=[{value:"==",label:"="},{value:"!=",label:"\u2260"},{value:"in",label:"in"},{value:"not-in",label:"not in"}],Wt=[{value:"==",label:"="},{value:"!=",label:"\u2260"},{value:"<",label:"<"},{value:"<=",label:"\u2264"},{value:">",label:">"},{value:">=",label:"\u2265"},{value:"in",label:"in"},{value:"not-in",label:"not in"}],Qt=[{value:"array-contains",label:"contains"},{value:"array-contains-any",label:"contains any"}];function Xt(e){switch(e){case "ZodNumber":case "ZodBigInt":case "ZodDate":return Wt;case "ZodBoolean":return pt;case "ZodArray":return Qt;default:return pt}}var te="__null__";function Yt(e){return `(function(cb){var i=document.getElementById('${e}');if(!i)return;if(cb.checked){i.dataset._prev=i.value;if(i.tagName==='SELECT'){var o=i.querySelector('option[value="${te}"]');if(!o){o=document.createElement('option');o.value='${te}';o.textContent='\u2205 null';o.dataset._auto='1';i.appendChild(o);}o.selected=true;}else{if(i.type==='number'||i.type==='datetime-local'){i.dataset._type=i.type;i.type='text';}i.value='${te}';i.readOnly=true;}i.style.opacity='0.55';}else{i.style.opacity='';if(i.tagName==='SELECT'){var o2=i.querySelector('option[value="${te}"][data-_auto="1"]');if(o2)o2.remove();var prev=i.dataset._prev||'';for(var k=0;k<i.options.length;k++)i.options[k].selected=(i.options[k].value===prev);}else{if(i.dataset._type){i.type=i.dataset._type;delete i.dataset._type;}i.readOnly=false;i.value=(i.dataset._prev&&i.dataset._prev!=='${te}')?i.dataset._prev:'';}}})(this)`}function en(e,t){return `(function(){var h=document.getElementById('${e}');var boxes=document.querySelectorAll('input[data-enum-group="${t}"]');h.value=Array.from(boxes).filter(function(b){return b.checked;}).map(function(b){return b.value;}).join(',');})()`}function ve({inputId:e,active:t}){return jsxs("label",{class:"flex items-center gap-1 cursor-pointer select-none text-xs text-base-content/60 hover:text-base-content border border-base-300 rounded-md px-1.5 py-1 shrink-0 leading-none h-8",title:"Filter where field IS NULL",children:[jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",checked:t,onchange:Yt(e)}),jsx("span",{children:"\u2205"})]})}function tn({col:e,active:t}){let n=t?.value??"",r=n===te,a=`fv_input_${e.name.replace(/\./g,"__")}`,s=t?.op,o=s==="in"||s==="not-in";if(e.enumValues&&e.enumValues.length>0){if(o){let d=new Set(n.split(",").map(p=>p.trim()).filter(Boolean)),l=`eg_${e.name.replace(/\./g,"__")}`;return jsxs("div",{class:"flex flex-wrap items-center gap-1 w-full",children:[jsx("input",{type:"hidden",id:a,name:`fv_${e.name}`,value:n}),e.enumValues.map(p=>jsxs("label",{class:"flex items-center gap-1 text-xs border border-base-300 rounded px-2 cursor-pointer hover:bg-base-200",children:[jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",value:p,checked:d.has(p),"data-enum-group":l,onchange:en(a,l)}),jsx("span",{children:p})]},p))]})}return jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),e.enumValues.map(d=>jsx("option",{value:d,selected:n===d,children:d},d)),e.nullable&&jsx("option",{value:te,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsx(ve,{inputId:a,active:r})]})}if(e.zodType==="ZodBoolean")return jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),jsx("option",{value:"true",selected:n==="true",children:"true"}),jsx("option",{value:"false",selected:n==="false",children:"false"}),e.nullable&&jsx("option",{value:te,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsx(ve,{inputId:a,active:r})]});if(e.zodType==="ZodArray"){let d=t?.op==="array-contains-any";return jsx("input",{id:a,type:"text",name:`fv_${e.name}`,value:n,placeholder:d?"val1, val2, \u2026":"value",class:"input input-sm input-bordered w-full"})}return e.zodType==="ZodNumber"||e.zodType==="ZodBigInt"?jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsx("input",{id:a,type:r?"text":"number",name:`fv_${e.name}`,value:n,placeholder:"value",class:"input input-sm input-bordered w-full",readOnly:r,style:r?"opacity:0.55":void 0,"data-_type":r?"number":void 0}),e.nullable&&jsx(ve,{inputId:a,active:r})]}):e.zodType==="ZodDate"?jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsx("input",{id:a,type:r?"text":"datetime-local",name:`fv_${e.name}`,value:n,class:"input input-sm input-bordered w-full",readOnly:r,style:r?"opacity:0.55":void 0,"data-_type":r?"datetime-local":void 0}),e.nullable&&jsx(ve,{inputId:a,active:r})]}):jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsx("input",{id:a,type:"text",name:`fv_${e.name}`,value:n,placeholder:"value",class:"input input-sm input-bordered w-full",readOnly:r,style:r?"opacity:0.55":void 0}),e.nullable&&jsx(ve,{inputId:a,active:r})]})}function Pe({action:e,columnMeta:t,activeFilters:n,isGroup:r}){let a=Object.fromEntries(n.map(l=>[l.field,l])),s=n.length>0,o=n.length>=2||r&&s,d=t.filter(l=>l.zodType!=="ZodObject"&&l.zodType!=="ZodRecord");return jsxs("details",{class:"collapse collapse-arrow bg-base-100 border border-base-300 rounded-box mb-6 shadow-sm",open:s?true:void 0,children:[jsxs("summary",{class:"collapse-title text-sm font-medium py-2 min-h-0",children:["Filters",s&&jsxs("span",{class:"badge badge-primary badge-sm ml-2",children:[n.length," active"]})]}),jsx("div",{class:"collapse-content pb-4 pt-2",children:jsxs("form",{method:"get",action:e,children:[jsx("div",{class:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-4",children:d.map(l=>{let p=Xt(l.zodType),m=a[l.name],E=m?.op??p[0].value;return jsxs("div",{class:"flex flex-col gap-1.5",children:[jsx("label",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:l.name}),jsxs("div",{class:"flex gap-1.5",children:[p.length>1?jsx("select",{name:`fo_${l.name}`,class:"select select-sm select-bordered w-20 shrink-0",children:p.map(h=>jsx("option",{value:h.value,selected:h.value===E,children:h.label},h.value))}):jsx("input",{type:"hidden",name:`fo_${l.name}`,value:p[0].value}),jsx(tn,{col:l,active:m})]})]},l.name)})}),jsxs("div",{class:"flex flex-wrap gap-2 mt-4 pt-3 border-t border-base-200 items-center",children:[jsx("button",{type:"submit",class:"btn btn-sm btn-primary",children:"Apply"}),s&&jsx("a",{href:e,class:"btn btn-sm btn-ghost",children:"Clear"}),o&&jsxs("span",{class:"text-xs text-warning ml-auto flex items-center gap-1",children:[jsx("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:jsx("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"})}),r?"Collection group queries require a composite index":"Multiple filters may require a composite index"]})]})]})})]})}function De(e,t,n,r,a,s){let o=n==="create"?`Create ${e}`:`Edit ${e} / ${r??""}`,d=n==="create"?[{label:"Repositories",href:a},{label:e,href:`${a}/${e}`},{label:"New document"}]:[{label:"Repositories",href:a},{label:e,href:`${a}/${e}`},{label:`Edit ${r??""}`}];return Y(jsx(ee,{opts:{title:o,breadcrumb:d,basePath:a,flash:s},children:jsx("div",{class:"card bg-base-100 border border-base-300",children:jsx("div",{class:"card-body p-6",children:jsx("div",{dangerouslySetInnerHTML:{__html:t}})})})}))}Ae();Oe();function Fe(e,t,n){let r=new URLSearchParams;for(let a of e)r.set(`fv_${a.field}`,a.value),r.set(`fo_${a.field}`,a.op);return t&&(r.set("ob",t.field),r.set("od",t.dir)),n&&r.set("ps",String(n)),r}function ft(e,t,n,r,a){let s=Fe(e,r,a);return s.set("cursor",t),s.set("dir",n),`?${s.toString()}`}function nn(e,t,n,r){let a=Fe(n,void 0,r);return t?.field===e?t.dir==="asc"&&(a.set("ob",e),a.set("od","desc")):(a.set("ob",e),a.set("od","asc")),`?${a.toString()}`}function rn(e,t,n){return `?${Fe(t,n,e).toString()}`}function je(e,t,n,r,a,s,o=[],d=[],l=false,p=[],m,E,h,w,A,F,b){let c=`${r}/${e}`,g=`${c}/create`,i={};if(b)for(let v of n)i[v]=fe(me(b,v));let u=(F??[]).filter(v=>{let $=i[v]??fe(me(b,v));return $==="string"||$==="number"||$==="bigint"||$==="boolean"||$==="enum"||$==="literal"}),f=u.length>0,x=l,k=x||f,T=u.map(v=>{let $=me(b,v),S=fe($),I=o.find(D=>D.name===v);return {name:v,type:S,enumValues:I?.enumValues??null,nullable:I?.nullable??false}});return Y(jsxs(ee,{opts:{title:e,breadcrumb:[{label:"Repositories",href:r},{label:e}],basePath:r,flash:s},children:[o.length>0&&jsx(Pe,{action:c,columnMeta:o,activeFilters:d,isGroup:w}),h&&jsxs("div",{role:"alert",class:`alert ${h.type==="index"?"alert-warning":"alert-error"} mb-6 shadow-sm`,children:[jsx("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 shrink-0 stroke-current",fill:"none",viewBox:"0 0 24 24",children:h.type==="index"?jsx("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"}):jsx("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M10 14l2-2m0 0l2-2m-2 2l-2-2m2 2l2 2m7-2a9 9 0 11-18 0 9 9 0 0118 0z"})}),jsxs("div",{class:"flex-1",children:[jsx("h3",{class:"font-bold",children:h.type==="index"?"Composite index required":"Query failed"}),jsx("div",{class:"text-sm",children:h.message})]}),h.indexUrl&&jsx("a",{href:h.indexUrl,target:"_blank",rel:"noopener noreferrer",class:"btn btn-sm btn-outline",children:"Create Index \u2192"})]}),jsxs("div",{class:"flex flex-wrap justify-between items-center mb-4 gap-3",children:[jsxs("div",{class:"flex items-center gap-3",children:[jsxs("span",{class:"text-sm text-base-content/60",children:[t.length,typeof A=="number"&&jsxs(Fragment,{children:[" ","of ",jsx("span",{class:"font-semibold text-base-content/80",children:A})]})," ","document",(typeof A=="number"?A:t.length)!==1&&"s"]}),jsxs("div",{class:"flex items-center gap-1.5 text-sm text-base-content/60",children:[jsx("span",{children:"Rows"}),jsx("div",{class:"join",children:[10,25,50,100].map(v=>jsx("a",{href:rn(v,d,m),class:`join-item btn btn-xs ${E===v?"btn-active btn-primary":"btn-outline"}`,children:v},v))})]})]}),jsx("a",{href:g,class:"btn btn-primary btn-sm",children:"+ New"})]}),k&&jsxs("div",{class:"hidden mb-3 alert alert-info py-2 px-3","data-frs-bulk-bar":true,"data-frs-repo":e,"data-frs-total":typeof A=="number"?String(A):"","data-frs-page-size":String(E??t.length),"data-frs-allow-delete":x?"1":"0","data-frs-allow-update":f?"1":"0","data-frs-fields":JSON.stringify(T),"data-frs-filters":JSON.stringify(d),children:[jsxs("div",{class:"flex-1 text-sm",children:[jsx("span",{"data-frs-bulk-summary":true,children:"0 selected"}),typeof A=="number"&&A>t.length&&jsxs("button",{type:"button",class:"ml-3 link link-primary text-sm hidden","data-frs-bulk-select-all":true,children:["Select all ",A," matching documents"]}),jsxs("span",{class:"hidden ml-3 italic","data-frs-bulk-all-active":true,children:["All ",A??"?"," matching documents are selected."," ",jsx("button",{type:"button",class:"link","data-frs-bulk-clear":true,children:"Clear selection"})]})]}),jsxs("div",{class:"flex gap-2",children:[f&&jsx("button",{type:"button",class:"btn btn-sm btn-outline","data-frs-bulk-action":"update",children:"Update field\u2026"}),x&&jsx("button",{type:"button",class:"btn btn-sm btn-error btn-outline","data-frs-bulk-action":"delete",children:"Delete"})]})]}),jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100","data-frs-table-wrap":true,children:jsxs("table",{class:"table table-sm w-full","data-frs-table":true,"data-frs-repo":e,"data-frs-colcount":n.length,children:[jsx("thead",{children:jsxs("tr",{class:"bg-base-200/50",children:[k&&jsx("th",{class:"w-8",children:jsx("input",{type:"checkbox",class:"checkbox checkbox-xs checkbox-primary","data-frs-select-page":true,"aria-label":"Select all on this page"})}),[...n].map((v,$)=>{let S=m?.field===v,I=S?m.dir==="asc"?" \u25B2":" \u25BC":"";return jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:jsxs("a",{href:nn(v,m,d,E),class:`hover:text-base-content inline-flex items-center gap-0.5${S?" text-primary font-bold":""}`,children:[v,I]})},$)}),p.map((v,$)=>jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:v.column},`rel-${$}`)),jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide text-right",children:"Actions"})]})}),jsx("tbody",{children:t.length===0?jsx("tr",{children:jsx("td",{colspan:n.length+p.length+1+(k?1:0),class:"text-center py-16 text-base-content/40",children:"No documents found"})}):t.map((v,$)=>{let S=String(v.docId??v.id??""),I=`${r}/${e}/${encodeURIComponent(S)}/edit`,D=`${r}/${e}/${encodeURIComponent(S)}/delete`;return jsxs("tr",{class:"hover","data-frs-row-id":S,children:[k&&jsx("td",{class:"align-middle py-2",children:jsx("input",{type:"checkbox",class:"checkbox checkbox-xs checkbox-primary","data-frs-select-row":true,value:S,"aria-label":`Select ${S}`})}),n.map((Z,J)=>{let M=v[Z],z=i[Z],G=z?he(z,M):null;return jsx("td",{class:"align-top py-2",children:jsx(pe,{val:M,mismatch:G})},J)}),p.map((Z,J)=>{let M=v[Z.key];if(M==null||M==="")return jsx("td",{class:"py-2"},`rel-${J}`);let z=Z.type==="one"?`${r}/${Z.targetRepo}/${encodeURIComponent(String(M))}/edit`:`${r}/${Z.targetRepo}?fv_${Z.targetKey}=${encodeURIComponent(String(M))}`;return jsx("td",{class:"align-middle py-2",children:jsx("a",{href:z,class:"btn btn-xs btn-ghost btn-outline","data-frs-relation":true,"data-frs-rel-type":Z.type,"data-frs-rel-repo":Z.targetRepo,"data-frs-rel-fk":Z.targetKey,"data-frs-rel-val":String(M),"data-frs-rel-label":Z.column,children:Z.column})},`rel-${J}`)}),jsx("td",{class:"align-middle text-right whitespace-nowrap py-2",children:jsxs("div",{class:"flex gap-1 justify-end",children:[jsx("a",{href:I,class:"btn btn-xs btn-outline",children:"Edit"}),l&&jsx("form",{method:"post",action:D,onsubmit:"return confirm('Delete this document?')",children:jsx("button",{type:"submit",class:"btn btn-xs btn-error btn-outline",children:"Delete"})})]})})]},$)})})]})}),(a.hasPrev||a.hasNext)&&jsxs("div",{class:"flex flex-col items-center mt-6 gap-2",children:[jsxs("div",{class:"flex justify-center items-center gap-2",children:[a.hasPrev?jsx("a",{href:ft(d,a.prevCursor,"prev",m,E),class:"btn btn-sm btn-outline",children:"\u2190 Previous"}):jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"\u2190 Previous"}),a.hasNext?jsx("a",{href:ft(d,a.nextCursor,"next",m,E),class:"btn btn-sm btn-outline",children:"Next \u2192"}):jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"Next \u2192"})]}),typeof A=="number"&&jsxs("div",{class:"text-xs text-base-content/50",children:[A," total document",A!==1?"s":"",d.length>0?" matching filters":""]})]}),k&&f&&jsxs("dialog",{id:"frs-bulk-update-modal",class:"modal",children:[jsxs("div",{class:"modal-box",children:[jsx("h3",{class:"font-bold text-lg mb-3",children:"Bulk update field"}),jsx("p",{class:"text-sm text-base-content/60 mb-4","data-frs-bulk-update-summary":true,children:"Update one field on the selected documents."}),jsxs("form",{method:"dialog","data-frs-bulk-update-form":true,children:[jsxs("label",{class:"form-control w-full mb-3",children:[jsx("div",{class:"label",children:jsx("span",{class:"label-text text-xs uppercase tracking-wide",children:"Field"})}),jsxs("select",{class:"select select-bordered select-sm w-full",name:"field",required:true,"data-frs-bulk-field-select":true,children:[jsx("option",{value:"",children:"\u2014 Select a field \u2014"}),u.map(v=>jsx("option",{value:v,children:v},v))]})]}),jsx("div",{class:"mb-4","data-frs-bulk-value-container":true}),jsxs("div",{class:"modal-action",children:[jsx("button",{type:"button",class:"btn btn-sm btn-ghost","data-frs-bulk-update-cancel":true,children:"Cancel"}),jsx("button",{type:"submit",class:"btn btn-sm btn-primary","data-frs-bulk-update-submit":true,children:"Apply"})]})]})]}),jsx("form",{method:"dialog",class:"modal-backdrop",children:jsx("button",{children:"close"})})]})]}))}function Me(e,t){return Ie(e,t)}function mt(e,t){return ze(e,t)}function bt(e,t,n,r,a,s,o,d,l,p,m,E,h,w,A,F,b){return je(e,t,n,r,a,s,o,d,l,p,m,E,h,w,A,F,b)}function oe(e,t,n,r,a,s){return De(e,t,n,r,a,s)}var sn=new Set(["<","<=",">",">=","!="]),on=new Set(["array-contains","array-contains-any"]);function Be(e){return e==="desc"?"DESCENDING":"ASCENDING"}function ln(e){let t=e.split("/").filter(Boolean);return t[t.length-1]??e}function dn(e,t,n,r,a){let s=[],o=new Set;for(let l of r)if(l.op==="=="||l.op==="in"||l.op==="not-in"){if(o.has(l.field))continue;o.add(l.field),s.push({fieldPath:l.field,order:"ASCENDING"});}for(let l of r)if(on.has(l.op)){if(o.has(l.field))continue;o.add(l.field),s.push({fieldPath:l.field,arrayConfig:"CONTAINS"});}for(let l of r)if(sn.has(l.op)){if(o.has(l.field))continue;o.add(l.field);let p=a?.field===l.field?Be(a.dir):"ASCENDING";s.push({fieldPath:l.field,order:p});}if(a&&!o.has(a.field)&&s.push({fieldPath:a.field,order:Be(a.dir)}),s.length===1&&n)return pn(e,t,s[0]);let d=a&&s.some(l=>l.fieldPath===a.field)?Be(a.dir):"ASCENDING";return s.push({fieldPath:"__name__",order:d}),cn(e,t,n,s)}function cn(e,t,n,r,a="(default)"){let s=`projects/${e}/databases/${a}/collectionGroups/${t}/indexes/_`,o=[...qe(1,s),...Te(2,n?2:1)];for(let p of r)o.push(...yt(3,gt(p)));let d=a==="(default)"?"-default-":a,l=encodeURIComponent(ht(o));return `https://console.firebase.google.com/project/${e}/firestore/databases/${d}/indexes?create_composite=${l}`}function un(e){return e.match(/https:\/\/console\.firebase\.google\.com[^\s)"]*/)?.[0]}function Le(e){let t=[],n=e>>>0;for(;n>=128;)t.push(n&127|128),n>>>=7;return t.push(n&127),t}function Ue(e,t){return e<<3|t}function qe(e,t){let n=Array.from(new TextEncoder().encode(t));return [Ue(e,2),...Le(n.length),...n]}function Te(e,t){return [Ue(e,0),...Le(t)]}function yt(e,t){return [Ue(e,2),...Le(t.length),...t]}function gt(e){let t=[...qe(1,e.fieldPath)];return e.arrayConfig==="CONTAINS"?t.push(...Te(3,1)):t.push(...Te(2,e.order==="DESCENDING"?2:1)),t}function ht(e){let t=String.fromCharCode(...e),n;if(typeof Buffer<"u")n=Buffer.from(e).toString("base64");else if(typeof btoa<"u")n=btoa(t);else throw new Error("No base64 encoder available");return n.replace(/=+$/,"")}function pn(e,t,n,r="(default)"){let a=`projects/${e}/databases/${r}/collectionGroups/${t}/fields/${n.fieldPath}`,s=[...qe(1,a),...Te(2,2),...yt(3,gt(n))],o=r==="(default)"?"-default-":r,d=encodeURIComponent(ht(s));return `https://console.firebase.google.com/project/${e}/firestore/databases/${o}/indexes/automatic?create_exemption=${d}`}function fn(e){let t=e,n=[t?.firestore?.projectId,t?.firestore?.app?.options?.projectId,t?.firestore?._settings?.projectId,t?.firestore?.databaseId?.projectId,t?._firestore?.projectId];for(let a of n)if(typeof a=="string"&&a.length>0)return a;return process.env.GCLOUD_PROJECT||process.env.GOOGLE_CLOUD_PROJECT||process.env.FIREBASE_PROJECT_ID||void 0}function ie(e){let t=e;return t?t.code===9?true:typeof t.message=="string"?t.message.includes("requires an index"):false:false}function He(e,t){let n=e??{},r=ie(e),a;if(r&&(a=n.message?un(n.message):void 0,!a)){let s=fn(t.ref);if(s){let o=ln(t.path);a=dn(s,o,t.isGroup,t.filters,t.sort);}}return {type:r?"index":"error",message:r?"This query requires a composite index that does not exist yet.":n.message??"Query failed",indexUrl:a}}var vt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function bn(){let e="";for(let t=0;t<20;t++)e+=vt.charAt(Math.floor(Math.random()*vt.length));return e}function Ve(e,t){if(!t)return;let n=e[t];if(typeof n!="string"||!n)return;let r=n.split("/").filter(Boolean),a=[];for(let s=1;s<r.length;s+=2)a.push(r[s]);return a.length>0?a:void 0}async function xe(e,t){let n=e.documentKey??"docId",r=`by${n.charAt(0).toUpperCase()}${n.slice(1)}`;if(typeof e.repo.get[r]=="function")try{let s=await e.repo.get[r](t);if(s)return s}catch{}return (await e.repo.query.by({where:[[n,"==",t]],limit:1}))[0]??null}function Je(e,t,n){let r=e.documentKey??"docId",a=He(n,{ref:e.repo.ref,path:e.path,isGroup:!!e.isGroup,filters:[{field:r,op:"==",value:t}]});return a.type==="index"?{type:"warning",message:"Loading this document requires a composite index that does not exist yet.",...a.indexUrl?{action:{href:a.indexUrl,label:"Create Index \u2192",external:true}}:{}}:{type:"error",message:a.message}}function O(e,t,n=200){e.status(n).set("Content-Type","text/html; charset=utf-8").send(t);}function Ke(e,t){e.status(302).set("Location",t).send("");}function Ge(e,t){let n=t.shape,r={};for(let[a,s]of Object.entries(n)){let o=Qe(s);if(o==="ZodObject"){if(e[a+"__isnull"]==="1"){r[a]=null;continue}let p={},m=false;for(let[w,A]of Object.entries(e))w.startsWith(`${a}.`)&&(p[w.slice(a.length+1)]=A,m=true);if(m){let w=s;for(;;){let A=j(w);if(A==="ZodOptional"||A==="ZodNullable"||A==="ZodDefault")w=q(w);else break}r[a]=Ge(p,w);continue}let E=e[a],h=Array.isArray(E)?E[E.length-1]:E;if(h)try{r[a]=JSON.parse(h);}catch{r[a]=h;}continue}let d=e[a],l=Array.isArray(d)?d[d.length-1]:d;if(e[a+"__isnull"]==="1"){r[a]=null;continue}if(l===void 0||l===""){o==="ZodBoolean"&&(r[a]=false);continue}switch(o){case "ZodBoolean":l==="__null__"?r[a]=null:r[a]=l==="true"||l==="on"||l==="1";break;case "ZodNumber":case "ZodBigInt":r[a]=Number(l);break;case "ZodDate":r[a]=new Date(l);break;case "ZodArray":try{r[a]=JSON.parse(l);}catch{r[a]=l;}break;default:if(l.startsWith("{")||l.startsWith("["))try{r[a]=JSON.parse(l);break}catch{}r[a]=l;}}return r}function xt(e){let t=null;if(e instanceof Date)t=e;else if(typeof e=="object"&&e!==null&&typeof e.toDate=="function")t=e.toDate();else if(typeof e=="object"&&e!==null&&"_seconds"in e&&"_nanoseconds"in e)t=new Date(e._seconds*1e3+Math.floor(e._nanoseconds/1e6));else if(typeof e=="string"||typeof e=="number"){let r=new Date(e);isNaN(r.getTime())||(t=r);}if(!t||isNaN(t.getTime()))return null;let n=r=>String(r).padStart(2,"0");return `${t.getFullYear()}-${n(t.getMonth()+1)}-${n(t.getDate())}T${n(t.getHours())}:${n(t.getMinutes())}`}function Qe(e){let t=e;for(;;){let n=j(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=q(t);else return n}}function yn(e){let t=e;for(;;){let n=j(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=q(t);else return t}}function kt(e){let t=e;for(;;){let n=j(t);if(n==="ZodOptional"||n==="ZodNullable")return true;if(n==="ZodDefault"){t=q(t);continue}return false}}function St(e){let t=yn(e),n=j(t);if(n==="ZodEnum"){let r=ye(t);return r.length>0?r:void 0}if(n==="ZodNativeEnum"){let r=ge(t),a=Object.values(r).filter(s=>typeof s=="string");return a.length>0?a:void 0}if(n==="ZodLiteral"){let r=Re(t);return typeof r=="string"?[r]:void 0}}function Rt(e,t,n=""){let r={};for(let a of Object.keys(t.shape)){let s=n?`${n}.${a}`:a,o=e[a];if(o===null){r[s]="__null__";continue}if(o===void 0)continue;let d=t.shape[a];for(;;){let p=j(d);if(p==="ZodOptional"||p==="ZodNullable"||p==="ZodDefault")d=q(d);else break}let l=j(d);if(l==="ZodObject"&&typeof o=="object"&&o!==null&&!Array.isArray(o)){let p=Rt(o,d,s);Object.assign(r,p);}else if(l==="ZodDate"){let p=xt(o);p!==null&&(r[s]=p);}else if(typeof o=="object"&&o!==null&&!Array.isArray(o)&&("_seconds"in o||typeof o.toDate=="function")){let p=xt(o);r[s]=p??JSON.stringify(o,null,2);}else typeof o=="object"?r[s]=JSON.stringify(o,null,2):r[s]=String(o);}return r}function We(e,t){return e.map(n=>({...n,defaultValue:t[n.name]??n.defaultValue,nested:n.nested?We(n.nested,t):void 0}))}function gn(e,t){let n=new Set(["==","!=","<","<=",">",">=","in","not-in","array-contains","array-contains-any"]),r=[];for(let[a,s]of Object.entries(e)){if(!a.startsWith("fv_"))continue;let o=a.slice(3);if(!t.has(o))continue;let d=(s??"").trim();if(!d)continue;let l=e[`fo_${o}`]??"==",p=n.has(l)?l:"==";r.push({field:o,op:p,value:d});}return r}function wt(e){let t="__null__",n=r=>r===t?null:r==="true"?true:r==="false"?false:r!==""&&!isNaN(Number(r))?Number(r):r;return e.map(r=>{if(r.op==="array-contains-any"||r.op==="in"||r.op==="not-in"){let a=r.value.split(",").map(s=>s.trim()).filter(s=>s!==""&&s!==t).map(s=>n(s));return [r.field,r.op,a]}return [r.field,r.op,n(r.value)]})}function $t(e,t,n=""){let r=[];for(let a of e){let s=n?`${n}.${a}`:a,o=t.shape[a];if(!o){r.push({name:s,zodType:"ZodString"});continue}let d=Qe(o);if(d==="ZodObject"){let l=o;for(;;){let m=j(l);if(m==="ZodOptional"||m==="ZodNullable"||m==="ZodDefault")l=q(l);else break}let p=Q(l);r.push(...$t(Object.keys(p),l,s));}else r.push({name:s,zodType:d,nullable:kt(o),enumValues:St(o)});}return r}function hn(e,t){let n=t.split("."),r=e;for(let a of n){for(;;){let o=j(r);if(o==="ZodOptional"||o==="ZodNullable"||o==="ZodDefault")r=q(r);else break}let s=Q(r);if(!(a in s))return null;r=s[a];}return r}function le(e,t){if(!t||t.length===0)return e;let n=[],r=new Map;for(let s of t){let o=s.indexOf(".");if(o===-1)n.push(s);else {let d=s.slice(0,o),l=s.slice(o+1);r.has(d)||r.set(d,[]),r.get(d).push(l);}}let a={};for(let s of n)s in e.shape&&(a[s]=e.shape[s]);for(let[s,o]of r){if(!(s in e.shape))continue;let d=e.shape[s];for(;;){let l=j(d);if(l==="ZodOptional"||l==="ZodNullable"||l==="ZodDefault")d=q(d);else break}if(j(d)!=="ZodObject"){a[s]=e.shape[s];continue}a[s]=le(d,o);}return z.object(a)}function ne(e,t){let n=t==="/"?"":t.replace(/\/$/,"");if(process.env.FUNCTIONS_EMULATOR==="true"){let s=process.env.GCLOUD_PROJECT??process.env.GOOGLE_CLOUD_PROJECT??"demo-project",o=process.env.FUNCTION_REGION??"us-central1",d=(process.env.FUNCTION_TARGET??"").replace(/\./g,"-");return `/${s}/${o}/${d}${n}`}let r=process.env.K_SERVICE,a=e.hostname??e.headers?.host??"";return r&&a.includes("cloudfunctions.net")?`/${r.toLowerCase()}${n}`:n}function At(e,t){let n=(b,c)=>{let g=ne(b,t),i=Object.values(e).map(u=>({name:u.name,path:u.path}));O(c,mt(i,g));},r=async(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=i.pageSize??25,f=b.query??{},x=f.cursor,k=f.dir==="prev"?"prev":"next",T=f.ob??"",v=f.od==="desc"?"desc":"asc",$=T?{field:T,dir:v}:void 0,S=parseInt(f.ps??""),I=Number.isFinite(S)&&S>0?Math.min(S,200):u,D=i.listColumns??Object.keys(i.schema.shape),Z=i.documentKey??"docId",J=[Z,...D.filter(U=>U!==Z)],M=i.filterableFields?(()=>{let U=[];for(let W of i.filterableFields)(W.includes(".")||D.includes(W))&&U.push(W);return U})():D,z=(()=>{let U=[];for(let W of M)if(W.includes(".")){let ce=hn(i.schema,W);U.push({name:W,zodType:ce?Qe(ce):"ZodString",nullable:ce?kt(ce):false,enumValues:ce?St(ce):void 0});}else U.push(...$t([W],i.schema));return U})(),G=new Set(z.map(U=>U.name)),be=gn(f,G),ke=wt(be),Xe;if(x)try{let U=i.repo.ref;typeof U.doc=="function"&&(Xe=await U.doc(x).get());}catch{}let[re,Ct]=await Promise.all([i.repo.query.paginate({pageSize:I,cursor:Xe,direction:k,...ke.length>0?{where:ke}:{},...$?{orderBy:[{field:$.field,direction:$.dir}]}:{}}).catch(U=>({queryError:He(U,{ref:i.repo.ref,path:i.path,isGroup:!!i.isGroup,filters:be,sort:$})})),i.repo.aggregate.count(ke.length>0?{where:ke}:{}).catch(()=>{})]),de="queryError"in re,Et=de?[]:re.data,Tt=de?"":re.nextCursor?.id??"",_t=de?"":re.prevCursor?.id??"",Ot=de?re.queryError:void 0,Zt=ne(b,t);O(c,bt(i.name,Et,J,Zt,{hasPrev:de?false:re.hasPrevPage,hasNext:de?false:re.hasNextPage,prevCursor:_t,nextCursor:Tt},void 0,z,be,i.allowDelete??false,i.relationalMeta,$,I,Ot,i.isGroup,Ct,i.mutableFields,i.schema));},a=(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=ne(b,t),f=le(i.schema,i.createFields),x=X(f),k=`${u}/${i.name}/create`,T=ae(x,k,"POST","Create document");O(c,oe(i.name,T,"create",null,u));},s=async(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=ne(b,t),f=b.body??{},x=Ge(f,i.schema),k=le(i.schema,i.createFields),T=k.safeParse(x);if(!T.success){let v=X(k),$=`${u}/${i.name}/create`,S=ae(v,$,"POST","Create document"),I=T.error.issues.map(D=>`${D.path.join(".")}: ${D.message}`).join(", ");O(c,oe(i.name,S,"create",null,u,{type:"error",message:`Validation error: ${I}`}),422);return}try{if(i.isGroup&&i.parentKeys&&i.parentKeys.length>0){let v={...T.data};i.createdKey&&(v[i.createdKey]=new Date);let $=i.parentKeys.filter(Z=>!v[Z]);if($.length>0)throw new Error(`Missing parent key(s) for subcollection create: ${$.join(", ")}`);let S=i.parentKeys.map(Z=>v[Z]),I=i.documentKey??"docId",D=v[I]||bn();await i.repo.set(...S,D,v);}else await i.repo.create(T.data);Ke(c,`${u}/${i.name}?flash=created`);}catch(v){let $=le(i.schema,i.createFields),S=X($),I=`${u}/${i.name}/create`,D=ae(S,I,"POST","Create document");O(c,oe(i.name,D,"create",null,u,{type:"error",message:`Save error: ${v.message}`}),500);}},o=async(b,c)=>{let g=b.params.repoName,i=b.params.id;if(!g||!i){O(c,"Bad request",400);return}let u=e[g];if(!u){O(c,"Repository not found",404);return}let f=ne(b,t),x=null;try{x=await xe(u,i);}catch(I){let D=Je(u,i,I),Z=ie(I)?424:500;O(c,Me("",{title:`Edit ${u.name} / ${i}`,basePath:f,breadcrumb:[{label:"Repositories",href:f},{label:u.name,href:`${f}/${u.name}`},{label:`Edit ${i}`}],flash:D}),Z);return}if(!x){O(c,"Document not found",404);return}let k=Rt(x,u.schema),T=le(u.schema,u.mutableFields),v=We(X(T),k),$=`${f}/${u.name}/${encodeURIComponent(i)}/edit`,S=ae(v,$,"POST","Save changes");O(c,oe(u.name,S,"edit",i,f));},d=async(b,c)=>{let g=b.params.repoName,i=b.params.id;if(!g||!i){O(c,"Bad request",400);return}let u=e[g];if(!u){O(c,"Repository not found",404);return}let f=ne(b,t),x=b.body??{},k=Ge(x,u.schema),T=le(u.schema,u.mutableFields),$=T.partial().safeParse(k);if(!$.success){let S=Object.fromEntries(Object.entries(x).map(([M,z])=>[M,Array.isArray(z)?z.join(","):z??""])),I=We(X(T),S),D=`${f}/${u.name}/${encodeURIComponent(i)}/edit`,Z=ae(I,D,"POST","Save changes"),J=$.error.issues.map(M=>`${M.path.join(".")}: ${M.message}`).join(", ");O(c,oe(u.name,Z,"edit",i,f,{type:"error",message:`Validation error: ${J}`}),422);return}try{let S=await xe(u,i),I=(S&&Ve(S,u.pathKey))??[i];await u.repo.update(...I,$.data),Ke(c,`${f}/${u.name}?flash=updated`);}catch(S){let I=le(u.schema,u.mutableFields),D=X(I),Z=`${f}/${u.name}/${encodeURIComponent(i)}/edit`,J=ae(D,Z,"POST","Save changes"),M=ie(S)?Je(u,i,S):{type:"error",message:`Save error: ${S.message}`},z=ie(S)?424:500;O(c,oe(u.name,J,"edit",i,f,M),z);}},l=async(b,c)=>{let g=b.params.repoName,i=b.params.id;if(!g||!i){O(c,"Bad request",400);return}let u=e[g];if(!u){O(c,"Repository not found",404);return}if(!u.allowDelete){O(c,"Delete is not allowed for this repository",403);return}let f=ne(b,t);try{let x=await xe(u,i),k=(x&&Ve(x,u.pathKey))??[i];await u.repo.delete(...k),Ke(c,`${f}/${u.name}?flash=deleted`);}catch(x){let k=ie(x)?Je(u,i,x):{type:"error",message:`Delete error: ${x.message}`},T=ie(x)?424:500;O(c,Me("",{title:`Delete ${u.name} / ${i}`,basePath:f,breadcrumb:[{label:"Repositories",href:f},{label:u.name,href:`${f}/${u.name}`},{label:`Delete ${i}`}],flash:k}),T);}},p=async(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=ne(b,t),f=b.query,x=f?.type==="many"?"many":"one",k=Math.max(1,Math.min(100,Number(f?.ps??25)||25)),T=i.listColumns??Object.keys(Q(i.schema)),{PanelOne:v,PanelMany:$}=await Promise.resolve().then(()=>(Ne(),ct)),{renderToString:S}=await import('hono/jsx/dom/server');if(x==="one"){let z=String(f?.id??"");if(!z){O(c,"<div class='p-6 text-error'>Missing id parameter.</div>",400);return}try{let G=await xe(i,z),be=S(v({doc:G,repoName:i.name,basePath:u,schema:i.schema,columns:T}));O(c,be);}catch(G){O(c,`<div class='p-6 text-error text-sm'>Error: ${G.message}</div>`,500);}return}let I=String(f?.fk??""),D=String(f?.fv??"");if(!I||!D){O(c,"<div class='p-6 text-error'>Missing fk/fv parameters.</div>",400);return}let Z=f?.cursor??"",J=f?.dir==="prev"?"prev":"next",M;if(Z)try{let z=i.repo.ref;typeof z.doc=="function"&&(M=await z.doc(Z).get());}catch{}try{let z=await i.repo.query.paginate({pageSize:k,cursor:M,direction:J,where:[[I,"==",vn(D)]]}),G=S($({docs:z.data,repoName:i.name,basePath:u,fk:I,fv:D,columns:T,schema:i.schema,pagination:{hasPrev:z.hasPrevPage,hasNext:z.hasNextPage,prevCursor:z.prevCursor?.id??"",nextCursor:z.nextCursor?.id??"",pageSize:k}}));O(c,G);}catch(z){O(c,`<div class='p-6 text-error text-sm'>Error: ${z.message}</div>`,500);}},m=async(b,c)=>{let g=[];for(let i of c){let u;if(b.isGroup||b.parentKeys?.length){let f=await xe(b,i);u=f?Ve(f,b.pathKey):void 0;}u||(u=[i]);try{let f=b.repo.documentRef(...u);f&&g.push(f);}catch{}}return g},E=async(b,c)=>{let g=wt(c),i=b.documentKey??"docId",u=[],f;for(;;){let x=await b.repo.query.paginate({pageSize:500,cursor:f,direction:"next",...g.length>0?{where:g}:{}});for(let k of x.data){let T=String(k[i]??k.id??"");T&&u.push(T);}if(!x.hasNextPage||!x.nextCursor)break;f=x.nextCursor;}return u},h=async(b,c)=>{let g=b.params.repoName;if(!g){V(c,{error:"Bad request"},400);return}let i=e[g];if(!i){V(c,{error:"Repository not found"},404);return}if(!i.allowDelete){V(c,{error:"Delete is not allowed for this repository"},403);return}let u=b.body??{};try{let f=await A(i,u);if(f.length===0){V(c,{deleted:0});return}let x=await m(i,f);for(let k=0;k<x.length;k+=500)await i.repo.bulk.delete(x.slice(k,k+500));V(c,{deleted:x.length});}catch(f){V(c,{error:f.message},500);}},w=async(b,c)=>{let g=b.params.repoName;if(!g){V(c,{error:"Bad request"},400);return}let i=e[g];if(!i){V(c,{error:"Repository not found"},404);return}let u=b.body??{},f=String(u.field??"");if(!f){V(c,{error:"Missing 'field'"},400);return}if(!i.mutableFields||!i.mutableFields.includes(f)){V(c,{error:`Field '${f}' is not bulk-updatable`},403);return}let x=i.schema.shape?.[f],k=u.value;if(x){let T=x.safeParse(u.value);if(!T.success){V(c,{error:`Invalid value for '${f}': ${T.error.message}`},400);return}k=T.data;}try{let T=await A(i,u);if(T.length===0){V(c,{updated:0});return}let $=(await m(i,T)).map(S=>({docRef:S,data:{[f]:k}}));for(let S=0;S<$.length;S+=500)await i.repo.bulk.update($.slice(S,S+500));V(c,{updated:$.length});}catch(T){V(c,{error:T.message},500);}};async function A(b,c){if(c.selectAll){let g=F(c.filters,b);return await E(b,g)}return Array.isArray(c.ids)?c.ids.filter(g=>typeof g=="string"&&!!g):[]}function F(b,c){if(!Array.isArray(b))return [];let g=new Set((c.filterableFields??Object.keys(Q(c.schema))).map(f=>String(f))),i=new Set(["==","!=","<","<=",">",">=","in","not-in","array-contains","array-contains-any"]),u=[];for(let f of b)f&&typeof f=="object"&&typeof f.field=="string"&&g.has(f.field)&&typeof f.value=="string"&&i.has(String(f.op))&&u.push({field:f.field,op:f.op,value:f.value});return u}return {handleDashboard:n,handleList:r,handleCreateForm:a,handleCreateSubmit:s,handleEditForm:o,handleEditSubmit:d,handleDelete:l,handlePanel:p,handleBulkDelete:h,handleBulkUpdate:w}}function V(e,t,n=200){e.status(n).set("Content-Type","application/json; charset=utf-8").send(JSON.stringify(t));}function vn(e){return e==="true"?true:e==="false"?false:e!==""&&!isNaN(Number(e))?Number(e):e}function xn(e){let t=[],n=e.replace(/[.*+?^${}()|[\]\\]/g,r=>r===":"?r:`\\${r}`).replace(/:([a-zA-Z_][a-zA-Z0-9_]*)/g,(r,a)=>(t.push(a),"([^/]+)"));return {pattern:new RegExp(`^${n}$`),paramNames:t}}function wn(e){let t=e.path??e.url??"/",n=t.indexOf("?");return n===-1?t:t.slice(0,n)}var we=class{constructor(){this.routes=[];this.middlewares=[];this.notFoundHandler=(t,n)=>{n.status(404).send("Not Found");};this.errorHandler=(t,n,r)=>{console.error("[MiniRouter]",t),r.status(500).send("Internal Server Error");};}use(t){return this.middlewares.push(t),this}get(t,n){return this.addRoute("GET",t,n)}post(t,n){return this.addRoute("POST",t,n)}put(t,n){return this.addRoute("PUT",t,n)}patch(t,n){return this.addRoute("PATCH",t,n)}delete(t,n){return this.addRoute("DELETE",t,n)}onNotFound(t){return this.notFoundHandler=t,this}onError(t){return this.errorHandler=t,this}addRoute(t,n,r){let{pattern:a,paramNames:s}=xn(n);return this.routes.push({method:t.toUpperCase(),pattern:a,paramNames:s,handler:r}),this}async handle(t,n){let r=(t.method??"GET").toUpperCase(),a=wn(t),s=null,o={};for(let p of this.routes){if(p.method!==r)continue;let m=a.match(p.pattern);if(m){s=p,o={},p.paramNames.forEach((E,h)=>{o[E]=decodeURIComponent(m[h+1]??"");});break}}let d=Object.assign(t,{params:o}),l=s?s.handler:this.notFoundHandler;try{await this.runMiddlewareChain(d,n,l);}catch(p){this.errorHandler(p,t,n);}}async runMiddlewareChain(t,n,r){let a=0,s=async()=>{if(a<this.middlewares.length){let o=this.middlewares[a++];await o(t,n,s);}else await r(t,n);};await s();}};async function kn(e){return typeof e.rawBody=="string"?e.rawBody:Buffer.isBuffer(e.rawBody)?e.rawBody.toString("utf8"):""}function Sn(e){let t={};if(!e)return t;for(let n of e.split("&")){let r=n.indexOf("=");if(r===-1)continue;let a=decodeURIComponent(n.slice(0,r).replace(/\+/g," ")),s=decodeURIComponent(n.slice(r+1).replace(/\+/g," ")),o=t[a];o===void 0?t[a]=s:Array.isArray(o)?o.push(s):t[a]=[o,s];}return t}function $r(e){let{basePath:t="/",repos:n,parseBody:r=true,auth:a,middleware:s=[],httpsOptions:o}=e,d=t==="/"?"":t.replace(/\/$/,""),l={};for(let[h,w]of Object.entries(n)){let A=w.schema??w.repo.schema??null;if(!A)throw new Error(`[createAdminServer] Repository "${h}" has no Zod schema. Either use createRepositoryConfig(schema)(config) or pass schema: explicitly.`);let F,b,c;if(w.fieldsConfig){let u=w.fieldsConfig;F=[],b=[],c=[];for(let[f,x]of Object.entries(u))for(let k of x)k==="filterable"?F.push(f):k==="mutable"?b.push(f):k==="create"&&c.push(f);F.length===0&&(F=void 0),b.length===0&&(b=void 0),c.length===0&&(c=void 0);}let g=(()=>{let u=w.repo._parentKeys;return u&&u.length>0?u:void 0})();if(g&&c)for(let u of g)c.includes(u)||c.push(u);let i={name:h,path:w.path,repo:w.repo,schema:A,documentKey:w.documentKey??"docId",pathKey:w.repo._pathKey??void 0,isGroup:!!w.repo._isGroup,parentKeys:g,createdKey:w.repo._createdKey??void 0,listColumns:w.listColumns,pageSize:w.pageSize,filterableFields:F,mutableFields:b,createFields:c,allowDelete:w.allowDelete??false,relationalMeta:(()=>{if(!w.relationalFields||w.relationalFields.length===0)return;let u=w.repo.relationalKeys??{},f=[];for(let x of w.relationalFields){let k=u[x.key];k&&f.push({key:x.key,column:x.column,targetRepo:String(k.repo),targetKey:String(k.key),type:k.type});}return f.length>0?f:void 0})()};l[h]=i;}let p=At(l,d),m=new we;if(r&&m.use(async(h,w,A)=>{let F=h,b=String(F.headers?.["content-type"]??"");if(b.includes("application/x-www-form-urlencoded")){let c=await kn(F);h.body=Sn(c);}else if(b.includes("application/json")&&typeof F.body=="string")try{h.body=JSON.parse(F.body);}catch{}await A();}),a)if(typeof a=="function")m.use(a);else {let h=a.realm??"Admin",w="Basic "+Buffer.from(`${a.username}:${a.password}`).toString("base64");m.use((A,F,b)=>{if((A.headers?.authorization??"")!==w){F.status(401).set("WWW-Authenticate",`Basic realm="${h}"`).set("Content-Type","text/plain").send("Unauthorized");return}b();});}for(let h of s)m.use(h);m.get(`${d}/`,p.handleDashboard),m.get(`${d}`,p.handleDashboard),m.get(`${d}/:repoName/_panel`,p.handlePanel),m.post(`${d}/:repoName/_bulk/delete`,p.handleBulkDelete),m.post(`${d}/:repoName/_bulk/update`,p.handleBulkUpdate),m.get(`${d}/:repoName`,p.handleList),m.get(`${d}/:repoName/create`,p.handleCreateForm),m.post(`${d}/:repoName/create`,p.handleCreateSubmit),m.get(`${d}/:repoName/:id/edit`,p.handleEditForm),m.post(`${d}/:repoName/:id/edit`,p.handleEditSubmit),m.post(`${d}/:repoName/:id/delete`,p.handleDelete);let E=async(h,w)=>{await m.handle(h,w);};return o&&(E.httpsOptions=o),E}
|
|
1045
|
+
`;function Ce(){return jsx("script",{dangerouslySetInnerHTML:{__html:lt}})}Ne();function Y(e){return "<!DOCTYPE html>"+renderToString(e)}var Kt=["corporate","silk","dark"],Gt=()=>jsxs("div",{class:"dropdown dropdown-end","data-frs-theme-switcher":true,children:[jsxs("button",{type:"button",tabIndex:0,class:"btn btn-sm btn-ghost text-neutral-content gap-1.5","aria-label":"Switch theme",children:[jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2",class:"size-4",children:[jsx("circle",{cx:"12",cy:"12",r:"4"}),jsx("path",{d:"M12 2v2M12 20v2M4.93 4.93l1.41 1.41M17.66 17.66l1.41 1.41M2 12h2M20 12h2M4.93 19.07l1.41-1.41M17.66 6.34l1.41-1.41"})]}),jsx("span",{class:"text-xs hidden sm:inline","data-frs-theme-current":true,children:"Theme"})]}),jsx("ul",{tabIndex:0,class:"dropdown-content menu menu-sm bg-base-100 text-base-content rounded-box z-50 mt-2 w-40 p-1 shadow-lg border border-base-300",children:Kt.map(e=>jsx("li",{children:jsxs("button",{type:"button","data-frs-theme":e,class:"capitalize justify-between",children:[jsx("span",{children:e}),jsx("span",{class:"hidden text-primary","data-frs-theme-check":e,children:"\u2713"})]})},e))})]}),ee=({opts:e,children:t})=>{let{title:n,breadcrumb:r,flash:a,basePath:s="/"}=e;return jsxs("html",{lang:"en","data-theme":"corporate",children:[jsxs("head",{children:[jsx("meta",{charset:"UTF-8"}),jsx("meta",{name:"viewport",content:"width=device-width, initial-scale=1"}),jsxs("title",{children:[n," \u2014 FRS Admin"]}),jsx("script",{dangerouslySetInnerHTML:{__html:"(function(){try{var t=localStorage.getItem('frs-admin-theme');if(t){document.documentElement.setAttribute('data-theme',t);}}catch(_){}})();"}}),jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/themes.css",rel:"stylesheet",type:"text/css"}),jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/daisyui.css",rel:"stylesheet",type:"text/css"}),jsx("script",{src:"https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"})]}),jsxs("body",{class:"bg-base-200/50 min-h-screen flex flex-col",children:[jsxs("div",{class:"navbar bg-neutral text-neutral-content shadow-sm sticky top-0 z-50 px-6",children:[jsx("div",{class:"flex-1",children:jsx("a",{href:s,class:"font-bold text-lg tracking-tight hover:opacity-80 transition-opacity",children:"FRS Admin"})}),jsx("div",{class:"flex-none",children:jsx(Gt,{})})]}),jsxs("main",{class:"px-6 py-8 w-full flex-1",children:[r&&r.length>0&&jsx("div",{class:"text-sm breadcrumbs mb-4",children:jsx("ul",{children:r.map((o,d)=>o.href?jsx("li",{children:jsx("a",{href:o.href,children:o.label})},d):jsx("li",{class:"text-base-content/60",children:o.label},d))})}),jsx("h1",{class:"text-2xl font-bold mb-6",children:n}),a&&jsxs("div",{role:"alert",class:`alert ${a.type==="success"?"alert-success":a.type==="warning"?"alert-warning":"alert-error"} mb-6`,children:[jsx("span",{class:"flex-1",children:a.message}),a.action&&jsx("a",{href:a.action.href,...a.action.external?{target:"_blank",rel:"noopener noreferrer"}:{},class:"btn btn-sm btn-outline",children:a.action.label})]}),t]}),jsx(Ze,{basePath:s}),jsx(Ce,{})]})]})};function Ie(e,t){return Y(jsx(ee,{opts:t,children:jsx("div",{dangerouslySetInnerHTML:{__html:e}})}))}function Pe(e,t){return Y(jsx(ee,{opts:{title:"Repositories",basePath:t},children:e.length===0?jsxs("div",{class:"text-center py-20 text-base-content/50",children:[jsx("p",{class:"text-lg font-medium mb-1",children:"No repositories configured"}),jsx("p",{class:"text-sm",children:"Add a repository to your FRS config to get started."})]}):jsx("div",{class:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-4",children:e.map(n=>jsx("a",{href:`${t}/${n.name}`,class:"card bg-base-100 border border-base-300 hover:shadow-md no-underline transition-shadow",children:jsxs("div",{class:"card-body p-5",children:[jsx("h2",{class:"card-title text-sm font-semibold",children:n.name}),jsx("p",{class:"text-xs text-base-content/50 font-mono",children:n.path})]})},n.name))})}))}var pt=[{value:"==",label:"="},{value:"!=",label:"\u2260"},{value:"in",label:"in"},{value:"not-in",label:"not in"}],Wt=[{value:"==",label:"="},{value:"!=",label:"\u2260"},{value:"<",label:"<"},{value:"<=",label:"\u2264"},{value:">",label:">"},{value:">=",label:"\u2265"},{value:"in",label:"in"},{value:"not-in",label:"not in"}],Qt=[{value:"array-contains",label:"contains"},{value:"array-contains-any",label:"contains any"}];function Xt(e){switch(e){case "ZodNumber":case "ZodBigInt":case "ZodDate":return Wt;case "ZodBoolean":return pt;case "ZodArray":return Qt;default:return pt}}var te="__null__";function Yt(e){return `(function(cb){var i=document.getElementById('${e}');if(!i)return;if(cb.checked){i.dataset._prev=i.value;if(i.tagName==='SELECT'){var o=i.querySelector('option[value="${te}"]');if(!o){o=document.createElement('option');o.value='${te}';o.textContent='\u2205 null';o.dataset._auto='1';i.appendChild(o);}o.selected=true;}else{if(i.type==='number'||i.type==='datetime-local'){i.dataset._type=i.type;i.type='text';}i.value='${te}';i.readOnly=true;}i.style.opacity='0.55';}else{i.style.opacity='';if(i.tagName==='SELECT'){var o2=i.querySelector('option[value="${te}"][data-_auto="1"]');if(o2)o2.remove();var prev=i.dataset._prev||'';for(var k=0;k<i.options.length;k++)i.options[k].selected=(i.options[k].value===prev);}else{if(i.dataset._type){i.type=i.dataset._type;delete i.dataset._type;}i.readOnly=false;i.value=(i.dataset._prev&&i.dataset._prev!=='${te}')?i.dataset._prev:'';}}})(this)`}function en(e,t){return `(function(){var h=document.getElementById('${e}');var boxes=document.querySelectorAll('input[data-enum-group="${t}"]');h.value=Array.from(boxes).filter(function(b){return b.checked;}).map(function(b){return b.value;}).join(',');})()`}function ve({inputId:e,active:t}){return jsxs("label",{class:"flex items-center gap-1 cursor-pointer select-none text-xs text-base-content/60 hover:text-base-content border border-base-300 rounded-md px-1.5 py-1 shrink-0 leading-none h-8",title:"Filter where field IS NULL",children:[jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",checked:t,onchange:Yt(e)}),jsx("span",{children:"\u2205"})]})}function tn({col:e,active:t}){let n=t?.value??"",r=n===te,a=`fv_input_${e.name.replace(/\./g,"__")}`,s=t?.op,o=s==="in"||s==="not-in";if(e.enumValues&&e.enumValues.length>0){if(o){let d=new Set(n.split(",").map(p=>p.trim()).filter(Boolean)),l=`eg_${e.name.replace(/\./g,"__")}`;return jsxs("div",{class:"flex flex-wrap items-center gap-1 w-full",children:[jsx("input",{type:"hidden",id:a,name:`fv_${e.name}`,value:n}),e.enumValues.map(p=>jsxs("label",{class:"flex items-center gap-1 text-xs border border-base-300 rounded px-2 cursor-pointer hover:bg-base-200",children:[jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",value:p,checked:d.has(p),"data-enum-group":l,onchange:en(a,l)}),jsx("span",{children:p})]},p))]})}return jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),e.enumValues.map(d=>jsx("option",{value:d,selected:n===d,children:d},d)),e.nullable&&jsx("option",{value:te,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsx(ve,{inputId:a,active:r})]})}if(e.zodType==="ZodBoolean")return jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),jsx("option",{value:"true",selected:n==="true",children:"true"}),jsx("option",{value:"false",selected:n==="false",children:"false"}),e.nullable&&jsx("option",{value:te,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsx(ve,{inputId:a,active:r})]});if(e.zodType==="ZodArray"){let d=t?.op==="array-contains-any";return jsx("input",{id:a,type:"text",name:`fv_${e.name}`,value:n,placeholder:d?"val1, val2, \u2026":"value",class:"input input-sm input-bordered w-full"})}return e.zodType==="ZodNumber"||e.zodType==="ZodBigInt"?jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsx("input",{id:a,type:r?"text":"number",name:`fv_${e.name}`,value:n,placeholder:"value",class:"input input-sm input-bordered w-full",readOnly:r,style:r?"opacity:0.55":void 0,"data-_type":r?"number":void 0}),e.nullable&&jsx(ve,{inputId:a,active:r})]}):e.zodType==="ZodDate"?jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsx("input",{id:a,type:r?"text":"datetime-local",name:`fv_${e.name}`,value:n,class:"input input-sm input-bordered w-full",readOnly:r,style:r?"opacity:0.55":void 0,"data-_type":r?"datetime-local":void 0}),e.nullable&&jsx(ve,{inputId:a,active:r})]}):jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsx("input",{id:a,type:"text",name:`fv_${e.name}`,value:n,placeholder:"value",class:"input input-sm input-bordered w-full",readOnly:r,style:r?"opacity:0.55":void 0}),e.nullable&&jsx(ve,{inputId:a,active:r})]})}function ze({action:e,columnMeta:t,activeFilters:n,isGroup:r}){let a=Object.fromEntries(n.map(l=>[l.field,l])),s=n.length>0,o=n.length>=2||r&&s,d=t.filter(l=>l.zodType!=="ZodObject"&&l.zodType!=="ZodRecord");return jsxs("details",{class:"collapse collapse-arrow bg-base-100 border border-base-300 rounded-box mb-6 shadow-sm",open:s?true:void 0,children:[jsxs("summary",{class:"collapse-title text-sm font-medium py-2 min-h-0",children:["Filters",s&&jsxs("span",{class:"badge badge-primary badge-sm ml-2",children:[n.length," active"]})]}),jsx("div",{class:"collapse-content pb-4 pt-2",children:jsxs("form",{method:"get",action:e,children:[jsx("div",{class:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-4",children:d.map(l=>{let p=Xt(l.zodType),m=a[l.name],E=m?.op??p[0].value;return jsxs("div",{class:"flex flex-col gap-1.5",children:[jsx("label",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:l.name}),jsxs("div",{class:"flex gap-1.5",children:[p.length>1?jsx("select",{name:`fo_${l.name}`,class:"select select-sm select-bordered w-20 shrink-0",children:p.map(h=>jsx("option",{value:h.value,selected:h.value===E,children:h.label},h.value))}):jsx("input",{type:"hidden",name:`fo_${l.name}`,value:p[0].value}),jsx(tn,{col:l,active:m})]})]},l.name)})}),jsxs("div",{class:"flex flex-wrap gap-2 mt-4 pt-3 border-t border-base-200 items-center",children:[jsx("button",{type:"submit",class:"btn btn-sm btn-primary",children:"Apply"}),s&&jsx("a",{href:e,class:"btn btn-sm btn-ghost",children:"Clear"}),o&&jsxs("span",{class:"text-xs text-warning ml-auto flex items-center gap-1",children:[jsx("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:jsx("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"})}),r?"Collection group queries require a composite index":"Multiple filters may require a composite index"]})]})]})})]})}function De(e,t,n,r,a,s){let o=n==="create"?`Create ${e}`:`Edit ${e} / ${r??""}`,d=n==="create"?[{label:"Repositories",href:a},{label:e,href:`${a}/${e}`},{label:"New document"}]:[{label:"Repositories",href:a},{label:e,href:`${a}/${e}`},{label:`Edit ${r??""}`}];return Y(jsx(ee,{opts:{title:o,breadcrumb:d,basePath:a,flash:s},children:jsx("div",{class:"card bg-base-100 border border-base-300",children:jsx("div",{class:"card-body p-6",children:jsx("div",{dangerouslySetInnerHTML:{__html:t}})})})}))}Ae();Oe();function Fe(e,t,n){let r=new URLSearchParams;for(let a of e)r.set(`fv_${a.field}`,a.value),r.set(`fo_${a.field}`,a.op);return t&&(r.set("ob",t.field),r.set("od",t.dir)),n&&r.set("ps",String(n)),r}function ft(e,t,n,r,a){let s=Fe(e,r,a);return s.set("cursor",t),s.set("dir",n),`?${s.toString()}`}function nn(e,t,n,r){let a=Fe(n,void 0,r);return t?.field===e?t.dir==="asc"&&(a.set("ob",e),a.set("od","desc")):(a.set("ob",e),a.set("od","asc")),`?${a.toString()}`}function rn(e,t,n){return `?${Fe(t,n,e).toString()}`}function je(e,t,n,r,a,s,o=[],d=[],l=false,p=[],m,E,h,w,A,F,b){let c=`${r}/${e}`,g=`${c}/create`,i={};if(b)for(let v of n)i[v]=fe(me(b,v));let u=(F??[]).filter(v=>{let $=i[v]??fe(me(b,v));return $==="string"||$==="number"||$==="bigint"||$==="boolean"||$==="enum"||$==="literal"}),f=u.length>0,x=l,k=x||f,T=u.map(v=>{let $=me(b,v),S=fe($),I=o.find(D=>D.name===v);return {name:v,type:S,enumValues:I?.enumValues??null,nullable:I?.nullable??false}});return Y(jsxs(ee,{opts:{title:e,breadcrumb:[{label:"Repositories",href:r},{label:e}],basePath:r,flash:s},children:[o.length>0&&jsx(ze,{action:c,columnMeta:o,activeFilters:d,isGroup:w}),h&&jsxs("div",{role:"alert",class:`alert ${h.type==="index"?"alert-warning":"alert-error"} mb-6 shadow-sm`,children:[jsx("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-6 w-6 shrink-0 stroke-current",fill:"none",viewBox:"0 0 24 24",children:h.type==="index"?jsx("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"}):jsx("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M10 14l2-2m0 0l2-2m-2 2l-2-2m2 2l2 2m7-2a9 9 0 11-18 0 9 9 0 0118 0z"})}),jsxs("div",{class:"flex-1",children:[jsx("h3",{class:"font-bold",children:h.type==="index"?"Composite index required":"Query failed"}),jsx("div",{class:"text-sm",children:h.message})]}),h.indexUrl&&jsx("a",{href:h.indexUrl,target:"_blank",rel:"noopener noreferrer",class:"btn btn-sm btn-outline",children:"Create Index \u2192"})]}),jsxs("div",{class:"flex flex-wrap justify-between items-center mb-4 gap-3","data-frs-toolbar":true,children:[jsxs("div",{class:"flex items-center gap-3",children:[jsxs("span",{class:"text-sm text-base-content/60",children:[t.length,typeof A=="number"&&jsxs(Fragment,{children:[" ","of ",jsx("span",{class:"font-semibold text-base-content/80",children:A})]})," ","document",(typeof A=="number"?A:t.length)!==1&&"s"]}),jsxs("div",{class:"flex items-center gap-1.5 text-sm text-base-content/60",children:[jsx("span",{children:"Rows"}),jsx("div",{class:"join",children:[10,25,50,100].map(v=>jsx("a",{href:rn(v,d,m),class:`join-item btn btn-xs ${E===v?"btn-active btn-primary":"btn-outline"}`,children:v},v))})]})]}),jsx("a",{href:g,class:"btn btn-primary btn-sm",children:"+ New"})]}),k&&jsxs("div",{class:"hidden mb-3 alert alert-info py-2 px-3","data-frs-bulk-bar":true,"data-frs-repo":e,"data-frs-total":typeof A=="number"?String(A):"","data-frs-page-size":String(E??t.length),"data-frs-allow-delete":x?"1":"0","data-frs-allow-update":f?"1":"0","data-frs-fields":JSON.stringify(T),"data-frs-filters":JSON.stringify(d),children:[jsxs("div",{class:"flex-1 text-sm",children:[jsx("span",{"data-frs-bulk-summary":true,children:"0 selected"}),typeof A=="number"&&A>t.length&&jsxs("button",{type:"button",class:"ml-3 link link-primary text-sm hidden","data-frs-bulk-select-all":true,children:["Select all ",A," matching documents"]}),jsxs("span",{class:"hidden ml-3 italic","data-frs-bulk-all-active":true,children:["All ",A??"?"," matching documents are selected."," ",jsx("button",{type:"button",class:"link","data-frs-bulk-clear":true,children:"Clear selection"})]})]}),jsxs("div",{class:"flex gap-2",children:[f&&jsx("button",{type:"button",class:"btn btn-sm btn-outline","data-frs-bulk-action":"update",children:"Update field\u2026"}),x&&jsx("button",{type:"button",class:"btn btn-sm btn-error btn-outline","data-frs-bulk-action":"delete",children:"Delete"})]})]}),jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100","data-frs-table-wrap":true,children:jsxs("table",{class:"table table-sm w-full","data-frs-table":true,"data-frs-repo":e,"data-frs-colcount":n.length,children:[jsx("thead",{children:jsxs("tr",{class:"bg-base-200/50",children:[k&&jsx("th",{class:"w-8",children:jsx("input",{type:"checkbox",class:"checkbox checkbox-xs checkbox-primary","data-frs-select-page":true,"aria-label":"Select all on this page"})}),[...n].map((v,$)=>{let S=m?.field===v,I=S?m.dir==="asc"?" \u25B2":" \u25BC":"";return jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:jsxs("a",{href:nn(v,m,d,E),class:`hover:text-base-content inline-flex items-center gap-0.5${S?" text-primary font-bold":""}`,children:[v,I]})},$)}),p.map((v,$)=>jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:v.column},`rel-${$}`)),jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide text-right",children:"Actions"})]})}),jsx("tbody",{children:t.length===0?jsx("tr",{children:jsx("td",{colspan:n.length+p.length+1+(k?1:0),class:"text-center py-16 text-base-content/40",children:"No documents found"})}):t.map((v,$)=>{let S=String(v.docId??v.id??""),I=`${r}/${e}/${encodeURIComponent(S)}/edit`,D=`${r}/${e}/${encodeURIComponent(S)}/delete`;return jsxs("tr",{class:"hover","data-frs-row-id":S,children:[k&&jsx("td",{class:"align-middle py-2",children:jsx("input",{type:"checkbox",class:"checkbox checkbox-xs checkbox-primary","data-frs-select-row":true,value:S,"aria-label":`Select ${S}`})}),n.map((Z,J)=>{let M=v[Z],P=i[Z],G=P?he(P,M):null;return jsx("td",{class:"align-top py-2",children:jsx(pe,{val:M,mismatch:G})},J)}),p.map((Z,J)=>{let M=v[Z.key];if(M==null||M==="")return jsx("td",{class:"py-2"},`rel-${J}`);let P=Z.type==="one"?`${r}/${Z.targetRepo}/${encodeURIComponent(String(M))}/edit`:`${r}/${Z.targetRepo}?fv_${Z.targetKey}=${encodeURIComponent(String(M))}`;return jsx("td",{class:"align-middle py-2",children:jsx("a",{href:P,class:"btn btn-xs btn-ghost btn-outline","data-frs-relation":true,"data-frs-rel-type":Z.type,"data-frs-rel-repo":Z.targetRepo,"data-frs-rel-fk":Z.targetKey,"data-frs-rel-val":String(M),"data-frs-rel-label":Z.column,children:Z.column})},`rel-${J}`)}),jsx("td",{class:"align-middle text-right whitespace-nowrap py-2",children:jsxs("div",{class:"flex gap-1 justify-end",children:[jsx("a",{href:I,class:"btn btn-xs btn-outline",children:"Edit"}),l&&jsx("form",{method:"post",action:D,onsubmit:"return confirm('Delete this document?')",children:jsx("button",{type:"submit",class:"btn btn-xs btn-error btn-outline",children:"Delete"})})]})})]},$)})})]})}),(a.hasPrev||a.hasNext)&&jsxs("div",{class:"flex flex-col items-center mt-6 gap-2",children:[jsxs("div",{class:"flex justify-center items-center gap-2",children:[a.hasPrev?jsx("a",{href:ft(d,a.prevCursor,"prev",m,E),class:"btn btn-sm btn-outline",children:"\u2190 Previous"}):jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"\u2190 Previous"}),a.hasNext?jsx("a",{href:ft(d,a.nextCursor,"next",m,E),class:"btn btn-sm btn-outline",children:"Next \u2192"}):jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"Next \u2192"})]}),typeof A=="number"&&jsxs("div",{class:"text-xs text-base-content/50",children:[A," total document",A!==1?"s":"",d.length>0?" matching filters":""]})]}),k&&f&&jsxs("dialog",{id:"frs-bulk-update-modal",class:"modal",children:[jsxs("div",{class:"modal-box",children:[jsx("h3",{class:"font-bold text-lg mb-3",children:"Bulk update field"}),jsx("p",{class:"text-sm text-base-content/60 mb-4","data-frs-bulk-update-summary":true,children:"Update one field on the selected documents."}),jsxs("form",{method:"dialog","data-frs-bulk-update-form":true,children:[jsxs("label",{class:"form-control w-full mb-3",children:[jsx("div",{class:"label",children:jsx("span",{class:"label-text text-xs uppercase tracking-wide",children:"Field"})}),jsxs("select",{class:"select select-bordered select-sm w-full",name:"field",required:true,"data-frs-bulk-field-select":true,children:[jsx("option",{value:"",children:"\u2014 Select a field \u2014"}),u.map(v=>jsx("option",{value:v,children:v},v))]})]}),jsx("div",{class:"mb-4","data-frs-bulk-value-container":true}),jsxs("div",{class:"modal-action",children:[jsx("button",{type:"button",class:"btn btn-sm btn-ghost","data-frs-bulk-update-cancel":true,children:"Cancel"}),jsx("button",{type:"submit",class:"btn btn-sm btn-primary","data-frs-bulk-update-submit":true,children:"Apply"})]})]})]}),jsx("form",{method:"dialog",class:"modal-backdrop",children:jsx("button",{children:"close"})})]})]}))}function Me(e,t){return Ie(e,t)}function mt(e,t){return Pe(e,t)}function bt(e,t,n,r,a,s,o,d,l,p,m,E,h,w,A,F,b){return je(e,t,n,r,a,s,o,d,l,p,m,E,h,w,A,F,b)}function oe(e,t,n,r,a,s){return De(e,t,n,r,a,s)}var sn=new Set(["<","<=",">",">=","!="]),on=new Set(["array-contains","array-contains-any"]);function Be(e){return e==="desc"?"DESCENDING":"ASCENDING"}function ln(e){let t=e.split("/").filter(Boolean);return t[t.length-1]??e}function dn(e,t,n,r,a){let s=[],o=new Set;for(let l of r)if(l.op==="=="||l.op==="in"||l.op==="not-in"){if(o.has(l.field))continue;o.add(l.field),s.push({fieldPath:l.field,order:"ASCENDING"});}for(let l of r)if(on.has(l.op)){if(o.has(l.field))continue;o.add(l.field),s.push({fieldPath:l.field,arrayConfig:"CONTAINS"});}for(let l of r)if(sn.has(l.op)){if(o.has(l.field))continue;o.add(l.field);let p=a?.field===l.field?Be(a.dir):"ASCENDING";s.push({fieldPath:l.field,order:p});}if(a&&!o.has(a.field)&&s.push({fieldPath:a.field,order:Be(a.dir)}),s.length===1&&n)return pn(e,t,s[0]);let d=a&&s.some(l=>l.fieldPath===a.field)?Be(a.dir):"ASCENDING";return s.push({fieldPath:"__name__",order:d}),cn(e,t,n,s)}function cn(e,t,n,r,a="(default)"){let s=`projects/${e}/databases/${a}/collectionGroups/${t}/indexes/_`,o=[...qe(1,s),...Te(2,n?2:1)];for(let p of r)o.push(...yt(3,gt(p)));let d=a==="(default)"?"-default-":a,l=encodeURIComponent(ht(o));return `https://console.firebase.google.com/project/${e}/firestore/databases/${d}/indexes?create_composite=${l}`}function un(e){return e.match(/https:\/\/console\.firebase\.google\.com[^\s)"]*/)?.[0]}function Le(e){let t=[],n=e>>>0;for(;n>=128;)t.push(n&127|128),n>>>=7;return t.push(n&127),t}function Ue(e,t){return e<<3|t}function qe(e,t){let n=Array.from(new TextEncoder().encode(t));return [Ue(e,2),...Le(n.length),...n]}function Te(e,t){return [Ue(e,0),...Le(t)]}function yt(e,t){return [Ue(e,2),...Le(t.length),...t]}function gt(e){let t=[...qe(1,e.fieldPath)];return e.arrayConfig==="CONTAINS"?t.push(...Te(3,1)):t.push(...Te(2,e.order==="DESCENDING"?2:1)),t}function ht(e){let t=String.fromCharCode(...e),n;if(typeof Buffer<"u")n=Buffer.from(e).toString("base64");else if(typeof btoa<"u")n=btoa(t);else throw new Error("No base64 encoder available");return n.replace(/=+$/,"")}function pn(e,t,n,r="(default)"){let a=`projects/${e}/databases/${r}/collectionGroups/${t}/fields/${n.fieldPath}`,s=[...qe(1,a),...Te(2,2),...yt(3,gt(n))],o=r==="(default)"?"-default-":r,d=encodeURIComponent(ht(s));return `https://console.firebase.google.com/project/${e}/firestore/databases/${o}/indexes/automatic?create_exemption=${d}`}function fn(e){let t=e,n=[t?.firestore?.projectId,t?.firestore?.app?.options?.projectId,t?.firestore?._settings?.projectId,t?.firestore?.databaseId?.projectId,t?._firestore?.projectId];for(let a of n)if(typeof a=="string"&&a.length>0)return a;return process.env.GCLOUD_PROJECT||process.env.GOOGLE_CLOUD_PROJECT||process.env.FIREBASE_PROJECT_ID||void 0}function ie(e){let t=e;return t?t.code===9?true:typeof t.message=="string"?t.message.includes("requires an index"):false:false}function He(e,t){let n=e??{},r=ie(e),a;if(r&&(a=n.message?un(n.message):void 0,!a)){let s=fn(t.ref);if(s){let o=ln(t.path);a=dn(s,o,t.isGroup,t.filters,t.sort);}}return {type:r?"index":"error",message:r?"This query requires a composite index that does not exist yet.":n.message??"Query failed",indexUrl:a}}var vt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function bn(){let e="";for(let t=0;t<20;t++)e+=vt.charAt(Math.floor(Math.random()*vt.length));return e}function Ve(e,t){if(!t)return;let n=e[t];if(typeof n!="string"||!n)return;let r=n.split("/").filter(Boolean),a=[];for(let s=1;s<r.length;s+=2)a.push(r[s]);return a.length>0?a:void 0}async function xe(e,t){let n=e.documentKey??"docId",r=`by${n.charAt(0).toUpperCase()}${n.slice(1)}`;if(typeof e.repo.get[r]=="function")try{let s=await e.repo.get[r](t);if(s)return s}catch{}return (await e.repo.query.by({where:[[n,"==",t]],limit:1}))[0]??null}function Je(e,t,n){let r=e.documentKey??"docId",a=He(n,{ref:e.repo.ref,path:e.path,isGroup:!!e.isGroup,filters:[{field:r,op:"==",value:t}]});return a.type==="index"?{type:"warning",message:"Loading this document requires a composite index that does not exist yet.",...a.indexUrl?{action:{href:a.indexUrl,label:"Create Index \u2192",external:true}}:{}}:{type:"error",message:a.message}}function O(e,t,n=200){e.status(n).set("Content-Type","text/html; charset=utf-8").send(t);}function Ke(e,t){e.status(302).set("Location",t).send("");}function Ge(e,t){let n=t.shape,r={};for(let[a,s]of Object.entries(n)){let o=Qe(s);if(o==="ZodObject"){if(e[a+"__isnull"]==="1"){r[a]=null;continue}let p={},m=false;for(let[w,A]of Object.entries(e))w.startsWith(`${a}.`)&&(p[w.slice(a.length+1)]=A,m=true);if(m){let w=s;for(;;){let A=j(w);if(A==="ZodOptional"||A==="ZodNullable"||A==="ZodDefault")w=q(w);else break}r[a]=Ge(p,w);continue}let E=e[a],h=Array.isArray(E)?E[E.length-1]:E;if(h)try{r[a]=JSON.parse(h);}catch{r[a]=h;}continue}let d=e[a],l=Array.isArray(d)?d[d.length-1]:d;if(e[a+"__isnull"]==="1"){r[a]=null;continue}if(l===void 0||l===""){o==="ZodBoolean"&&(r[a]=false);continue}switch(o){case "ZodBoolean":l==="__null__"?r[a]=null:r[a]=l==="true"||l==="on"||l==="1";break;case "ZodNumber":case "ZodBigInt":r[a]=Number(l);break;case "ZodDate":r[a]=new Date(l);break;case "ZodArray":try{r[a]=JSON.parse(l);}catch{r[a]=l;}break;default:if(l.startsWith("{")||l.startsWith("["))try{r[a]=JSON.parse(l);break}catch{}r[a]=l;}}return r}function xt(e){let t=null;if(e instanceof Date)t=e;else if(typeof e=="object"&&e!==null&&typeof e.toDate=="function")t=e.toDate();else if(typeof e=="object"&&e!==null&&"_seconds"in e&&"_nanoseconds"in e)t=new Date(e._seconds*1e3+Math.floor(e._nanoseconds/1e6));else if(typeof e=="string"||typeof e=="number"){let r=new Date(e);isNaN(r.getTime())||(t=r);}if(!t||isNaN(t.getTime()))return null;let n=r=>String(r).padStart(2,"0");return `${t.getFullYear()}-${n(t.getMonth()+1)}-${n(t.getDate())}T${n(t.getHours())}:${n(t.getMinutes())}`}function Qe(e){let t=e;for(;;){let n=j(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=q(t);else return n}}function yn(e){let t=e;for(;;){let n=j(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=q(t);else return t}}function kt(e){let t=e;for(;;){let n=j(t);if(n==="ZodOptional"||n==="ZodNullable")return true;if(n==="ZodDefault"){t=q(t);continue}return false}}function St(e){let t=yn(e),n=j(t);if(n==="ZodEnum"){let r=ye(t);return r.length>0?r:void 0}if(n==="ZodNativeEnum"){let r=ge(t),a=Object.values(r).filter(s=>typeof s=="string");return a.length>0?a:void 0}if(n==="ZodLiteral"){let r=Re(t);return typeof r=="string"?[r]:void 0}}function Rt(e,t,n=""){let r={};for(let a of Object.keys(t.shape)){let s=n?`${n}.${a}`:a,o=e[a];if(o===null){r[s]="__null__";continue}if(o===void 0)continue;let d=t.shape[a];for(;;){let p=j(d);if(p==="ZodOptional"||p==="ZodNullable"||p==="ZodDefault")d=q(d);else break}let l=j(d);if(l==="ZodObject"&&typeof o=="object"&&o!==null&&!Array.isArray(o)){let p=Rt(o,d,s);Object.assign(r,p);}else if(l==="ZodDate"){let p=xt(o);p!==null&&(r[s]=p);}else if(typeof o=="object"&&o!==null&&!Array.isArray(o)&&("_seconds"in o||typeof o.toDate=="function")){let p=xt(o);r[s]=p??JSON.stringify(o,null,2);}else typeof o=="object"?r[s]=JSON.stringify(o,null,2):r[s]=String(o);}return r}function We(e,t){return e.map(n=>({...n,defaultValue:t[n.name]??n.defaultValue,nested:n.nested?We(n.nested,t):void 0}))}function gn(e,t){let n=new Set(["==","!=","<","<=",">",">=","in","not-in","array-contains","array-contains-any"]),r=[];for(let[a,s]of Object.entries(e)){if(!a.startsWith("fv_"))continue;let o=a.slice(3);if(!t.has(o))continue;let d=(s??"").trim();if(!d)continue;let l=e[`fo_${o}`]??"==",p=n.has(l)?l:"==";r.push({field:o,op:p,value:d});}return r}function wt(e){let t="__null__",n=r=>r===t?null:r==="true"?true:r==="false"?false:r!==""&&!isNaN(Number(r))?Number(r):r;return e.map(r=>{if(r.op==="array-contains-any"||r.op==="in"||r.op==="not-in"){let a=r.value.split(",").map(s=>s.trim()).filter(s=>s!==""&&s!==t).map(s=>n(s));return [r.field,r.op,a]}return [r.field,r.op,n(r.value)]})}function $t(e,t,n=""){let r=[];for(let a of e){let s=n?`${n}.${a}`:a,o=t.shape[a];if(!o){r.push({name:s,zodType:"ZodString"});continue}let d=Qe(o);if(d==="ZodObject"){let l=o;for(;;){let m=j(l);if(m==="ZodOptional"||m==="ZodNullable"||m==="ZodDefault")l=q(l);else break}let p=Q(l);r.push(...$t(Object.keys(p),l,s));}else r.push({name:s,zodType:d,nullable:kt(o),enumValues:St(o)});}return r}function hn(e,t){let n=t.split("."),r=e;for(let a of n){for(;;){let o=j(r);if(o==="ZodOptional"||o==="ZodNullable"||o==="ZodDefault")r=q(r);else break}let s=Q(r);if(!(a in s))return null;r=s[a];}return r}function le(e,t){if(!t||t.length===0)return e;let n=[],r=new Map;for(let s of t){let o=s.indexOf(".");if(o===-1)n.push(s);else {let d=s.slice(0,o),l=s.slice(o+1);r.has(d)||r.set(d,[]),r.get(d).push(l);}}let a={};for(let s of n)s in e.shape&&(a[s]=e.shape[s]);for(let[s,o]of r){if(!(s in e.shape))continue;let d=e.shape[s];for(;;){let l=j(d);if(l==="ZodOptional"||l==="ZodNullable"||l==="ZodDefault")d=q(d);else break}if(j(d)!=="ZodObject"){a[s]=e.shape[s];continue}a[s]=le(d,o);}return z.object(a)}function ne(e,t){let n=t==="/"?"":t.replace(/\/$/,"");if(process.env.FUNCTIONS_EMULATOR==="true"){let s=process.env.GCLOUD_PROJECT??process.env.GOOGLE_CLOUD_PROJECT??"demo-project",o=process.env.FUNCTION_REGION??"us-central1",d=(process.env.FUNCTION_TARGET??"").replace(/\./g,"-");return `/${s}/${o}/${d}${n}`}let r=process.env.K_SERVICE,a=e.hostname??e.headers?.host??"";return r&&a.includes("cloudfunctions.net")?`/${r.toLowerCase()}${n}`:n}function At(e,t){let n=(b,c)=>{let g=ne(b,t),i=Object.values(e).map(u=>({name:u.name,path:u.path}));O(c,mt(i,g));},r=async(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=i.pageSize??25,f=b.query??{},x=f.cursor,k=f.dir==="prev"?"prev":"next",T=f.ob??"",v=f.od==="desc"?"desc":"asc",$=T?{field:T,dir:v}:void 0,S=parseInt(f.ps??""),I=Number.isFinite(S)&&S>0?Math.min(S,200):u,D=i.listColumns??Object.keys(i.schema.shape),Z=i.documentKey??"docId",J=[Z,...D.filter(U=>U!==Z)],M=i.filterableFields?(()=>{let U=[];for(let W of i.filterableFields)(W.includes(".")||D.includes(W))&&U.push(W);return U})():D,P=(()=>{let U=[];for(let W of M)if(W.includes(".")){let ce=hn(i.schema,W);U.push({name:W,zodType:ce?Qe(ce):"ZodString",nullable:ce?kt(ce):false,enumValues:ce?St(ce):void 0});}else U.push(...$t([W],i.schema));return U})(),G=new Set(P.map(U=>U.name)),be=gn(f,G),ke=wt(be),Xe;if(x)try{let U=i.repo.ref;typeof U.doc=="function"&&(Xe=await U.doc(x).get());}catch{}let[re,Ct]=await Promise.all([i.repo.query.paginate({pageSize:I,cursor:Xe,direction:k,...ke.length>0?{where:ke}:{},...$?{orderBy:[{field:$.field,direction:$.dir}]}:{}}).catch(U=>({queryError:He(U,{ref:i.repo.ref,path:i.path,isGroup:!!i.isGroup,filters:be,sort:$})})),i.repo.aggregate.count(ke.length>0?{where:ke}:{}).catch(()=>{})]),de="queryError"in re,Et=de?[]:re.data,Tt=de?"":re.nextCursor?.id??"",_t=de?"":re.prevCursor?.id??"",Ot=de?re.queryError:void 0,Zt=ne(b,t);O(c,bt(i.name,Et,J,Zt,{hasPrev:de?false:re.hasPrevPage,hasNext:de?false:re.hasNextPage,prevCursor:_t,nextCursor:Tt},void 0,P,be,i.allowDelete??false,i.relationalMeta,$,I,Ot,i.isGroup,Ct,i.mutableFields,i.schema));},a=(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=ne(b,t),f=le(i.schema,i.createFields),x=X(f),k=`${u}/${i.name}/create`,T=ae(x,k,"POST","Create document");O(c,oe(i.name,T,"create",null,u));},s=async(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=ne(b,t),f=b.body??{},x=Ge(f,i.schema),k=le(i.schema,i.createFields),T=k.safeParse(x);if(!T.success){let v=X(k),$=`${u}/${i.name}/create`,S=ae(v,$,"POST","Create document"),I=T.error.issues.map(D=>`${D.path.join(".")}: ${D.message}`).join(", ");O(c,oe(i.name,S,"create",null,u,{type:"error",message:`Validation error: ${I}`}),422);return}try{if(i.isGroup&&i.parentKeys&&i.parentKeys.length>0){let v={...T.data};i.createdKey&&(v[i.createdKey]=new Date);let $=i.parentKeys.filter(Z=>!v[Z]);if($.length>0)throw new Error(`Missing parent key(s) for subcollection create: ${$.join(", ")}`);let S=i.parentKeys.map(Z=>v[Z]),I=i.documentKey??"docId",D=v[I]||bn();await i.repo.set(...S,D,v);}else await i.repo.create(T.data);Ke(c,`${u}/${i.name}?flash=created`);}catch(v){let $=le(i.schema,i.createFields),S=X($),I=`${u}/${i.name}/create`,D=ae(S,I,"POST","Create document");O(c,oe(i.name,D,"create",null,u,{type:"error",message:`Save error: ${v.message}`}),500);}},o=async(b,c)=>{let g=b.params.repoName,i=b.params.id;if(!g||!i){O(c,"Bad request",400);return}let u=e[g];if(!u){O(c,"Repository not found",404);return}let f=ne(b,t),x=null;try{x=await xe(u,i);}catch(I){let D=Je(u,i,I),Z=ie(I)?424:500;O(c,Me("",{title:`Edit ${u.name} / ${i}`,basePath:f,breadcrumb:[{label:"Repositories",href:f},{label:u.name,href:`${f}/${u.name}`},{label:`Edit ${i}`}],flash:D}),Z);return}if(!x){O(c,"Document not found",404);return}let k=Rt(x,u.schema),T=le(u.schema,u.mutableFields),v=We(X(T),k),$=`${f}/${u.name}/${encodeURIComponent(i)}/edit`,S=ae(v,$,"POST","Save changes");O(c,oe(u.name,S,"edit",i,f));},d=async(b,c)=>{let g=b.params.repoName,i=b.params.id;if(!g||!i){O(c,"Bad request",400);return}let u=e[g];if(!u){O(c,"Repository not found",404);return}let f=ne(b,t),x=b.body??{},k=Ge(x,u.schema),T=le(u.schema,u.mutableFields),$=T.partial().safeParse(k);if(!$.success){let S=Object.fromEntries(Object.entries(x).map(([M,P])=>[M,Array.isArray(P)?P.join(","):P??""])),I=We(X(T),S),D=`${f}/${u.name}/${encodeURIComponent(i)}/edit`,Z=ae(I,D,"POST","Save changes"),J=$.error.issues.map(M=>`${M.path.join(".")}: ${M.message}`).join(", ");O(c,oe(u.name,Z,"edit",i,f,{type:"error",message:`Validation error: ${J}`}),422);return}try{let S=await xe(u,i),I=(S&&Ve(S,u.pathKey))??[i];await u.repo.update(...I,$.data),Ke(c,`${f}/${u.name}?flash=updated`);}catch(S){let I=le(u.schema,u.mutableFields),D=X(I),Z=`${f}/${u.name}/${encodeURIComponent(i)}/edit`,J=ae(D,Z,"POST","Save changes"),M=ie(S)?Je(u,i,S):{type:"error",message:`Save error: ${S.message}`},P=ie(S)?424:500;O(c,oe(u.name,J,"edit",i,f,M),P);}},l=async(b,c)=>{let g=b.params.repoName,i=b.params.id;if(!g||!i){O(c,"Bad request",400);return}let u=e[g];if(!u){O(c,"Repository not found",404);return}if(!u.allowDelete){O(c,"Delete is not allowed for this repository",403);return}let f=ne(b,t);try{let x=await xe(u,i),k=(x&&Ve(x,u.pathKey))??[i];await u.repo.delete(...k),Ke(c,`${f}/${u.name}?flash=deleted`);}catch(x){let k=ie(x)?Je(u,i,x):{type:"error",message:`Delete error: ${x.message}`},T=ie(x)?424:500;O(c,Me("",{title:`Delete ${u.name} / ${i}`,basePath:f,breadcrumb:[{label:"Repositories",href:f},{label:u.name,href:`${f}/${u.name}`},{label:`Delete ${i}`}],flash:k}),T);}},p=async(b,c)=>{let g=b.params.repoName;if(!g){O(c,"Bad request",400);return}let i=e[g];if(!i){O(c,"Repository not found",404);return}let u=ne(b,t),f=b.query,x=f?.type==="many"?"many":"one",k=Math.max(1,Math.min(100,Number(f?.ps??25)||25)),T=i.listColumns??Object.keys(Q(i.schema)),{PanelOne:v,PanelMany:$}=await Promise.resolve().then(()=>(Ne(),ct)),{renderToString:S}=await import('hono/jsx/dom/server');if(x==="one"){let P=String(f?.id??"");if(!P){O(c,"<div class='p-6 text-error'>Missing id parameter.</div>",400);return}try{let G=await xe(i,P),be=S(v({doc:G,repoName:i.name,basePath:u,schema:i.schema,columns:T}));O(c,be);}catch(G){O(c,`<div class='p-6 text-error text-sm'>Error: ${G.message}</div>`,500);}return}let I=String(f?.fk??""),D=String(f?.fv??"");if(!I||!D){O(c,"<div class='p-6 text-error'>Missing fk/fv parameters.</div>",400);return}let Z=f?.cursor??"",J=f?.dir==="prev"?"prev":"next",M;if(Z)try{let P=i.repo.ref;typeof P.doc=="function"&&(M=await P.doc(Z).get());}catch{}try{let P=await i.repo.query.paginate({pageSize:k,cursor:M,direction:J,where:[[I,"==",vn(D)]]}),G=S($({docs:P.data,repoName:i.name,basePath:u,fk:I,fv:D,columns:T,schema:i.schema,pagination:{hasPrev:P.hasPrevPage,hasNext:P.hasNextPage,prevCursor:P.prevCursor?.id??"",nextCursor:P.nextCursor?.id??"",pageSize:k}}));O(c,G);}catch(P){O(c,`<div class='p-6 text-error text-sm'>Error: ${P.message}</div>`,500);}},m=async(b,c)=>{let g=[];for(let i of c){let u;if(b.isGroup||b.parentKeys?.length){let f=await xe(b,i);u=f?Ve(f,b.pathKey):void 0;}u||(u=[i]);try{let f=b.repo.documentRef(...u);f&&g.push(f);}catch{}}return g},E=async(b,c)=>{let g=wt(c),i=b.documentKey??"docId",u=[],f;for(;;){let x=await b.repo.query.paginate({pageSize:500,cursor:f,direction:"next",...g.length>0?{where:g}:{}});for(let k of x.data){let T=String(k[i]??k.id??"");T&&u.push(T);}if(!x.hasNextPage||!x.nextCursor)break;f=x.nextCursor;}return u},h=async(b,c)=>{let g=b.params.repoName;if(!g){V(c,{error:"Bad request"},400);return}let i=e[g];if(!i){V(c,{error:"Repository not found"},404);return}if(!i.allowDelete){V(c,{error:"Delete is not allowed for this repository"},403);return}let u=b.body??{};try{let f=await A(i,u);if(f.length===0){V(c,{deleted:0});return}let x=await m(i,f);for(let k=0;k<x.length;k+=500)await i.repo.bulk.delete(x.slice(k,k+500));V(c,{deleted:x.length});}catch(f){V(c,{error:f.message},500);}},w=async(b,c)=>{let g=b.params.repoName;if(!g){V(c,{error:"Bad request"},400);return}let i=e[g];if(!i){V(c,{error:"Repository not found"},404);return}let u=b.body??{},f=String(u.field??"");if(!f){V(c,{error:"Missing 'field'"},400);return}if(!i.mutableFields||!i.mutableFields.includes(f)){V(c,{error:`Field '${f}' is not bulk-updatable`},403);return}let x=i.schema.shape?.[f],k=u.value;if(x){let T=x.safeParse(u.value);if(!T.success){V(c,{error:`Invalid value for '${f}': ${T.error.message}`},400);return}k=T.data;}try{let T=await A(i,u);if(T.length===0){V(c,{updated:0});return}let $=(await m(i,T)).map(S=>({docRef:S,data:{[f]:k}}));for(let S=0;S<$.length;S+=500)await i.repo.bulk.update($.slice(S,S+500));V(c,{updated:$.length});}catch(T){V(c,{error:T.message},500);}};async function A(b,c){if(c.selectAll){let g=F(c.filters,b);return await E(b,g)}return Array.isArray(c.ids)?c.ids.filter(g=>typeof g=="string"&&!!g):[]}function F(b,c){if(!Array.isArray(b))return [];let g=new Set((c.filterableFields??Object.keys(Q(c.schema))).map(f=>String(f))),i=new Set(["==","!=","<","<=",">",">=","in","not-in","array-contains","array-contains-any"]),u=[];for(let f of b)f&&typeof f=="object"&&typeof f.field=="string"&&g.has(f.field)&&typeof f.value=="string"&&i.has(String(f.op))&&u.push({field:f.field,op:f.op,value:f.value});return u}return {handleDashboard:n,handleList:r,handleCreateForm:a,handleCreateSubmit:s,handleEditForm:o,handleEditSubmit:d,handleDelete:l,handlePanel:p,handleBulkDelete:h,handleBulkUpdate:w}}function V(e,t,n=200){e.status(n).set("Content-Type","application/json; charset=utf-8").send(JSON.stringify(t));}function vn(e){return e==="true"?true:e==="false"?false:e!==""&&!isNaN(Number(e))?Number(e):e}function xn(e){let t=[],n=e.replace(/[.*+?^${}()|[\]\\]/g,r=>r===":"?r:`\\${r}`).replace(/:([a-zA-Z_][a-zA-Z0-9_]*)/g,(r,a)=>(t.push(a),"([^/]+)"));return {pattern:new RegExp(`^${n}$`),paramNames:t}}function wn(e){let t=e.path??e.url??"/",n=t.indexOf("?");return n===-1?t:t.slice(0,n)}var we=class{constructor(){this.routes=[];this.middlewares=[];this.notFoundHandler=(t,n)=>{n.status(404).send("Not Found");};this.errorHandler=(t,n,r)=>{console.error("[MiniRouter]",t),r.status(500).send("Internal Server Error");};}use(t){return this.middlewares.push(t),this}get(t,n){return this.addRoute("GET",t,n)}post(t,n){return this.addRoute("POST",t,n)}put(t,n){return this.addRoute("PUT",t,n)}patch(t,n){return this.addRoute("PATCH",t,n)}delete(t,n){return this.addRoute("DELETE",t,n)}onNotFound(t){return this.notFoundHandler=t,this}onError(t){return this.errorHandler=t,this}addRoute(t,n,r){let{pattern:a,paramNames:s}=xn(n);return this.routes.push({method:t.toUpperCase(),pattern:a,paramNames:s,handler:r}),this}async handle(t,n){let r=(t.method??"GET").toUpperCase(),a=wn(t),s=null,o={};for(let p of this.routes){if(p.method!==r)continue;let m=a.match(p.pattern);if(m){s=p,o={},p.paramNames.forEach((E,h)=>{o[E]=decodeURIComponent(m[h+1]??"");});break}}let d=Object.assign(t,{params:o}),l=s?s.handler:this.notFoundHandler;try{await this.runMiddlewareChain(d,n,l);}catch(p){this.errorHandler(p,t,n);}}async runMiddlewareChain(t,n,r){let a=0,s=async()=>{if(a<this.middlewares.length){let o=this.middlewares[a++];await o(t,n,s);}else await r(t,n);};await s();}};async function kn(e){return typeof e.rawBody=="string"?e.rawBody:Buffer.isBuffer(e.rawBody)?e.rawBody.toString("utf8"):""}function Sn(e){let t={};if(!e)return t;for(let n of e.split("&")){let r=n.indexOf("=");if(r===-1)continue;let a=decodeURIComponent(n.slice(0,r).replace(/\+/g," ")),s=decodeURIComponent(n.slice(r+1).replace(/\+/g," ")),o=t[a];o===void 0?t[a]=s:Array.isArray(o)?o.push(s):t[a]=[o,s];}return t}function $r(e){let{basePath:t="/",repos:n,parseBody:r=true,auth:a,middleware:s=[],httpsOptions:o}=e,d=t==="/"?"":t.replace(/\/$/,""),l={};for(let[h,w]of Object.entries(n)){let A=w.schema??w.repo.schema??null;if(!A)throw new Error(`[createAdminServer] Repository "${h}" has no Zod schema. Either use createRepositoryConfig(schema)(config) or pass schema: explicitly.`);let F,b,c;if(w.fieldsConfig){let u=w.fieldsConfig;F=[],b=[],c=[];for(let[f,x]of Object.entries(u))for(let k of x)k==="filterable"?F.push(f):k==="mutable"?b.push(f):k==="create"&&c.push(f);F.length===0&&(F=void 0),b.length===0&&(b=void 0),c.length===0&&(c=void 0);}let g=(()=>{let u=w.repo._parentKeys;return u&&u.length>0?u:void 0})();if(g&&c)for(let u of g)c.includes(u)||c.push(u);let i={name:h,path:w.path,repo:w.repo,schema:A,documentKey:w.documentKey??"docId",pathKey:w.repo._pathKey??void 0,isGroup:!!w.repo._isGroup,parentKeys:g,createdKey:w.repo._createdKey??void 0,listColumns:w.listColumns,pageSize:w.pageSize,filterableFields:F,mutableFields:b,createFields:c,allowDelete:w.allowDelete??false,relationalMeta:(()=>{if(!w.relationalFields||w.relationalFields.length===0)return;let u=w.repo.relationalKeys??{},f=[];for(let x of w.relationalFields){let k=u[x.key];k&&f.push({key:x.key,column:x.column,targetRepo:String(k.repo),targetKey:String(k.key),type:k.type});}return f.length>0?f:void 0})()};l[h]=i;}let p=At(l,d),m=new we;if(r&&m.use(async(h,w,A)=>{let F=h,b=String(F.headers?.["content-type"]??"");if(b.includes("application/x-www-form-urlencoded")){let c=await kn(F);h.body=Sn(c);}else if(b.includes("application/json")&&typeof F.body=="string")try{h.body=JSON.parse(F.body);}catch{}await A();}),a)if(typeof a=="function")m.use(a);else {let h=a.realm??"Admin",w="Basic "+Buffer.from(`${a.username}:${a.password}`).toString("base64");m.use((A,F,b)=>{if((A.headers?.authorization??"")!==w){F.status(401).set("WWW-Authenticate",`Basic realm="${h}"`).set("Content-Type","text/plain").send("Unauthorized");return}b();});}for(let h of s)m.use(h);m.get(`${d}/`,p.handleDashboard),m.get(`${d}`,p.handleDashboard),m.get(`${d}/:repoName/_panel`,p.handlePanel),m.post(`${d}/:repoName/_bulk/delete`,p.handleBulkDelete),m.post(`${d}/:repoName/_bulk/update`,p.handleBulkUpdate),m.get(`${d}/:repoName`,p.handleList),m.get(`${d}/:repoName/create`,p.handleCreateForm),m.post(`${d}/:repoName/create`,p.handleCreateSubmit),m.get(`${d}/:repoName/:id/edit`,p.handleEditForm),m.post(`${d}/:repoName/:id/edit`,p.handleEditSubmit),m.post(`${d}/:repoName/:id/delete`,p.handleDelete);let E=async(h,w)=>{await m.handle(h,w);};return o&&(E.httpsOptions=o),E}
|
|
1028
1046
|
export{we as MiniRouter,$r as createAdminServer};//# sourceMappingURL=index.js.map
|
|
1029
1047
|
//# sourceMappingURL=index.js.map
|