@lpdjs/firestore-repo-service 2.2.9-beta.0 → 2.2.9-beta.2
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/history/index.cjs +1 -1
- package/dist/history/index.cjs.map +1 -1
- package/dist/history/index.js +1 -1
- package/dist/history/index.js.map +1 -1
- package/dist/index.cjs +3 -3
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/servers/admin/index.cjs +33 -33
- package/dist/servers/admin/index.cjs.map +1 -1
- package/dist/servers/admin/index.js +33 -33
- package/dist/servers/admin/index.js.map +1 -1
- package/dist/servers/index.cjs +4 -4
- package/dist/servers/index.cjs.map +1 -1
- package/dist/servers/index.js +4 -4
- package/dist/servers/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
'use strict';var jsxRuntime=require('hono/jsx/jsx-runtime'),zod=require('zod'),server=require('hono/jsx/dom/server');var It=Object.defineProperty;var Ae=(e,t)=>()=>(e&&(t=e(e=0)),t);var Pt=(e,t)=>{for(var n in t)It(e,n,{get:t[n],enumerable:true});};function B(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 J(e){let t=e;if(t._zod?.def?.innerType)return t._zod.def.innerType;if(t._def?.innerType)return t._def.innerType}function tt(e){let t=e;if(t._zod?.def?.element)return t._zod.def.element;if(t._def?.type)return t._def.type}function nt(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 Y(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 xe(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 we(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 Ce(e){let t=e;return Array.isArray(t._zod?.def?.values)?t._zod.def.values[0]:t._def?.value}function rt(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,Ee=Ae(()=>{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 dt({val:e}){return jsxRuntime.jsx("span",{class:"text-sm text-base-content/80 font-mono tabular-nums whitespace-nowrap",children:e.toLocaleString()})}function jt({message:e}){return jsxRuntime.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:jsxRuntime.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",class:"size-3.5",children:jsxRuntime.jsx("path",{d:"M12 2 1 22h22L12 2zm0 6 7.5 13h-15L12 8zm-1 4v4h2v-4h-2zm0 5v2h2v-2h-2z"})})})}function be({val:e,mismatch:t}){let n=Mt(e);return t?jsxRuntime.jsxs("span",{class:"inline-flex items-start gap-0.5",children:[n,jsxRuntime.jsx(jt,{message:t})]}):n}function Mt(e){if(e==null)return jsxRuntime.jsx("span",{class:"opacity-30 italic text-xs",children:"\u2014"});if(typeof e=="boolean")return e?jsxRuntime.jsx("span",{class:"badge badge-success badge-sm",children:"true"}):jsxRuntime.jsx("span",{class:"badge badge-error badge-sm",children:"false"});if(e instanceof Date)return jsxRuntime.jsx(dt,{val:e});if(typeof e=="object"&&e!==null&&typeof e.toDate=="function")return jsxRuntime.jsx(dt,{val:e.toDate()});if(typeof e=="number")return jsxRuntime.jsx("span",{class:"text-sm font-mono tabular-nums",children:String(e)});if(Array.isArray(e))return e.length===0?jsxRuntime.jsx("span",{class:"text-xs text-base-content/30",children:"[]"}):jsxRuntime.jsxs("ul",{class:"list-none p-0 m-0 space-y-0.5 text-xs",children:[e.slice(0,8).map((n,r)=>jsxRuntime.jsx("li",{class:"break-all",children:typeof n=="object"?JSON.stringify(n):String(n)},r)),e.length>8&&jsxRuntime.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?jsxRuntime.jsx("span",{class:"text-xs text-base-content/30",children:"{}"}):jsxRuntime.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])=>jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("dt",{class:"text-base-content/50 font-semibold whitespace-nowrap",children:r}),jsxRuntime.jsx("dd",{class:"break-all",children:String(a??"")})]})),n.length>8&&jsxRuntime.jsxs("dt",{class:"col-span-2 text-base-content/40 italic",children:["+",n.length-8," more\u2026"]})]})}let t=String(e);return jsxRuntime.jsx("span",{class:"text-sm break-all",children:t})}var Te=Ae(()=>{});function ye(e){if(!e)return "unknown";let t=Pe(e);switch(B(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 Pe(e){let t=B(e);if(t==="ZodOptional"||t==="ZodNullable"||t==="ZodDefault"){let n=J(e);return n?Pe(n):e}return e}function ge(e,t){if(!e)return;let n=t.split("."),r=e;for(let a of n){if(!r)return;let s=Pe(r);if(B(s)!=="ZodObject")return;r=Y(s)[a];}return r}function qt(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 ke(e,t){if(e==="unknown")return null;let n=qt(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 ze=Ae(()=>{Ee();});var pt={};Pt(pt,{PanelMany:()=>Vt,PanelOne:()=>Ht,RightPanel:()=>De});function Ht({doc:e,repoName:t,basePath:n,schema:r,columns:a}){if(!e)return jsxRuntime.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=ut(r,a);return jsxRuntime.jsxs("div",{class:"space-y-4",children:[jsxRuntime.jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxRuntime.jsxs("div",{class:"text-xs text-base-content/60",children:[jsxRuntime.jsx("span",{class:"font-mono",children:t}),jsxRuntime.jsx("span",{class:"opacity-50",children:" \xB7 "}),jsxRuntime.jsx("span",{class:"font-mono break-all",children:s})]}),jsxRuntime.jsx("a",{href:o,class:"btn btn-sm btn-primary",children:"Edit \u2192"})]}),jsxRuntime.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 u=e[l],m=d[l],N=m?ke(m,u):null;return jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("dt",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide pt-0.5",children:l}),jsxRuntime.jsx("dd",{class:"min-w-0",children:jsxRuntime.jsx(be,{val:u,mismatch:N})})]})})})]})}function Vt({docs:e,repoName:t,basePath:n,fk:r,fv:a,columns:s,schema:o,pagination:d}){let l=`${n}/${t}?fv_${r}=${encodeURIComponent(a)}`,u=ut(o,s);return jsxRuntime.jsxs("div",{class:"space-y-4",children:[jsxRuntime.jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxRuntime.jsxs("div",{class:"text-xs text-base-content/60",children:[jsxRuntime.jsx("span",{class:"font-mono",children:t}),jsxRuntime.jsx("span",{class:"opacity-50",children:" where "}),jsxRuntime.jsx("span",{class:"font-mono",children:r}),jsxRuntime.jsx("span",{class:"opacity-50",children:" = "}),jsxRuntime.jsx("span",{class:"font-mono break-all",children:a}),jsxRuntime.jsx("span",{class:"opacity-50",children:" \xB7 "}),jsxRuntime.jsxs("span",{children:[e.length," doc",e.length!==1?"s":""]})]}),jsxRuntime.jsx("a",{href:l,class:"btn btn-sm btn-outline",children:"Full view \u2192"})]}),jsxRuntime.jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100",children:jsxRuntime.jsxs("table",{class:"table table-xs w-full",children:[jsxRuntime.jsx("thead",{children:jsxRuntime.jsxs("tr",{class:"bg-base-200/50",children:[s.map((m,N)=>jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:m},N)),jsxRuntime.jsx("th",{})]})}),jsxRuntime.jsx("tbody",{children:e.length===0?jsxRuntime.jsx("tr",{children:jsxRuntime.jsx("td",{colspan:s.length+1,class:"text-center py-10 text-base-content/40",children:"No related documents"})}):e.map((m,N)=>{let w=String(m.docId??m.id??""),S=`${n}/${t}/${encodeURIComponent(w)}/edit`;return jsxRuntime.jsxs("tr",{class:"hover",children:[s.map((E,j)=>{let M=m[E],b=u[E],p=b?ke(b,M):null;return jsxRuntime.jsx("td",{class:"align-top py-1.5",children:jsxRuntime.jsx(be,{val:M,mismatch:p})},j)}),jsxRuntime.jsx("td",{class:"text-right py-1.5",children:jsxRuntime.jsx("a",{href:S,class:"btn btn-xs btn-ghost",children:"Edit"})})]},N)})})]})}),(d.hasPrev||d.hasNext)&&jsxRuntime.jsxs("div",{class:"flex justify-center items-center gap-2",children:[d.hasPrev?jsxRuntime.jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"prev","data-cursor":d.prevCursor,children:"\u2190 Previous"}):jsxRuntime.jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"\u2190 Previous"}),d.hasNext?jsxRuntime.jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"next","data-cursor":d.nextCursor,children:"Next \u2192"}):jsxRuntime.jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"Next \u2192"})]})]})}function ut(e,t){if(!e)return {};let n={};for(let r of t)n[r]=ye(ge(e,r));return n}var De,Fe=Ae(()=>{Te();ze();De=({basePath:e=""})=>jsxRuntime.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:[jsxRuntime.jsx("div",{class:"absolute inset-0 bg-black/30 opacity-0 transition-opacity duration-200 pointer-events-auto","data-frs-panel-backdrop":true}),jsxRuntime.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:[jsxRuntime.jsxs("header",{class:"flex items-center justify-between px-5 py-3 border-b border-base-300 bg-base-200/40 shrink-0",children:[jsxRuntime.jsx("h2",{class:"font-semibold text-base truncate","data-frs-panel-title":true,children:"Relation"}),jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-ghost btn-circle","data-frs-panel-close":true,"aria-label":"Close panel",children:"\u2715"})]}),jsxRuntime.jsx("div",{class:"flex-1 overflow-auto p-5 text-sm","data-frs-panel-body":true,children:jsxRuntime.jsx("div",{class:"flex items-center justify-center py-12 text-base-content/40",children:jsxRuntime.jsx("span",{class:"loading loading-spinner loading-md"})})})]})]});});Ee();Ee();function Dt(e){return e.replace(/([A-Z])/g," $1").replace(/_/g," ").replace(/^\s/,"").replace(/^./,t=>t.toUpperCase())}function at(e){let t=e,n=true,r=false,a;for(;;){let s=B(t);if(s==="ZodOptional")n=false,t=J(t);else if(s==="ZodNullable")n=false,r=true,t=J(t);else if(s==="ZodDefault")n=false,a=nt(t),t=J(t);else break}return {inner:t,required:n,nullable:r,defaultValue:a}}function ee(e,t=""){if(B(e)==="ZodObject"){let r=Y(e);return Object.entries(r).map(([a,s])=>st(t?`${t}.${a}`:a,a,s))}return [st(t||"value",t||"value",e)]}function st(e,t,n){let{inner:r,required:a,nullable:s,defaultValue:o}=at(n),d=B(r),l=Dt(t.split(".").pop()??t);switch(d){case "ZodString":{let u=rt(r),m=u.includes("email"),N=u.includes("url");return {name:e,label:l,type:"text",required:a,nullable:s,defaultValue:o,hint:m?"email":N?"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 u=xe(r);return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:u}}case "ZodNativeEnum":{let u=we(r),m=Object.values(u).filter(N=>typeof N=="string");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:m}}case "ZodLiteral":{let u=String(Ce(r)??"");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:[u]}}case "ZodObject":{let u=ee(r,e);return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,nested:u,hint:"JSON object"}}case "ZodArray":{let u=tt(r);if(!u)return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON array"};let{inner:m}=at(u),N=B(m),w,S,E;switch(N){case "ZodString":w="text";break;case "ZodNumber":case "ZodBigInt":w="number";break;case "ZodBoolean":w="checkbox";break;case "ZodDate":w="datetime-local";break;case "ZodEnum":w="select",S=xe(m);break;case "ZodNativeEnum":w="select",S=Object.values(we(m)).filter(j=>typeof j=="string");break;case "ZodObject":w="object",E=ee(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:w,arrayElementOptions:S,arrayElementFields:E}}default:return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON"}}}function lt(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
|
+
'use strict';var jsxRuntime=require('hono/jsx/jsx-runtime'),zod=require('zod'),server=require('hono/jsx/dom/server');var It=Object.defineProperty;var Ae=(e,t)=>()=>(e&&(t=e(e=0)),t);var Pt=(e,t)=>{for(var n in t)It(e,n,{get:t[n],enumerable:true});};function M(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 J(e){let t=e;if(t._zod?.def?.innerType)return t._zod.def.innerType;if(t._def?.innerType)return t._def.innerType}function tt(e){let t=e;if(t._zod?.def?.element)return t._zod.def.element;if(t._def?.type)return t._def.type}function nt(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 Y(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 xe(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 we(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 Ce(e){let t=e;return Array.isArray(t._zod?.def?.values)?t._zod.def.values[0]:t._def?.value}function rt(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,Ee=Ae(()=>{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 pt({val:e}){return jsxRuntime.jsx("span",{class:"text-sm text-base-content/80 font-mono tabular-nums whitespace-nowrap",children:e.toLocaleString()})}function Jt({message:e}){return jsxRuntime.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:jsxRuntime.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",class:"size-3.5",children:jsxRuntime.jsx("path",{d:"M12 2 1 22h22L12 2zm0 6 7.5 13h-15L12 8zm-1 4v4h2v-4h-2zm0 5v2h2v-2h-2z"})})})}function be({val:e,mismatch:t}){let n=Kt(e);return t?jsxRuntime.jsxs("span",{class:"inline-flex items-start gap-0.5",children:[n,jsxRuntime.jsx(Jt,{message:t})]}):n}function Kt(e){if(e==null)return jsxRuntime.jsx("span",{class:"opacity-30 italic text-xs",children:"\u2014"});if(typeof e=="boolean")return e?jsxRuntime.jsx("span",{class:"badge badge-success badge-sm",children:"true"}):jsxRuntime.jsx("span",{class:"badge badge-error badge-sm",children:"false"});if(e instanceof Date)return jsxRuntime.jsx(pt,{val:e});if(typeof e=="object"&&e!==null&&typeof e.toDate=="function")return jsxRuntime.jsx(pt,{val:e.toDate()});if(typeof e=="number")return jsxRuntime.jsx("span",{class:"text-sm font-mono tabular-nums",children:String(e)});if(Array.isArray(e))return e.length===0?jsxRuntime.jsx("span",{class:"text-xs text-base-content/30",children:"[]"}):jsxRuntime.jsxs("ul",{class:"list-none p-0 m-0 space-y-0.5 text-xs",children:[e.slice(0,8).map((n,r)=>jsxRuntime.jsx("li",{class:"break-all",children:typeof n=="object"?JSON.stringify(n):String(n)},r)),e.length>8&&jsxRuntime.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?jsxRuntime.jsx("span",{class:"text-xs text-base-content/30",children:"{}"}):jsxRuntime.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])=>jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("dt",{class:"text-base-content/50 font-semibold whitespace-nowrap",children:r}),jsxRuntime.jsx("dd",{class:"break-all",children:String(a??"")})]})),n.length>8&&jsxRuntime.jsxs("dt",{class:"col-span-2 text-base-content/40 italic",children:["+",n.length-8," more\u2026"]})]})}let t=String(e);return jsxRuntime.jsx("span",{class:"text-sm break-all",children:t})}var _e=Ae(()=>{});function ye(e){if(!e)return "unknown";let t=Be(e);switch(M(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 Be(e){let t=M(e);if(t==="ZodOptional"||t==="ZodNullable"||t==="ZodDefault"){let n=J(e);return n?Be(n):e}return e}function ge(e,t){if(!e)return;let n=t.split("."),r=e;for(let a of n){if(!r)return;let s=Be(r);if(M(s)!=="ZodObject")return;r=Y(s)[a];}return r}function Xt(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 ke(e,t){if(e==="unknown")return null;let n=Xt(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 Me=Ae(()=>{Ee();});var bt={};Pt(bt,{PanelMany:()=>en,PanelOne:()=>Yt,RightPanel:()=>Le});function Yt({doc:e,repoName:t,basePath:n,schema:r,columns:a}){if(!e)return jsxRuntime.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=mt(r,a);return jsxRuntime.jsxs("div",{class:"space-y-4",children:[jsxRuntime.jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxRuntime.jsxs("div",{class:"text-xs text-base-content/60",children:[jsxRuntime.jsx("span",{class:"font-mono",children:t}),jsxRuntime.jsx("span",{class:"opacity-50",children:" \xB7 "}),jsxRuntime.jsx("span",{class:"font-mono break-all",children:s})]}),jsxRuntime.jsx("a",{href:o,class:"btn btn-sm btn-primary",children:"Edit \u2192"})]}),jsxRuntime.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 u=e[l],m=d[l],N=m?ke(m,u):null;return jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("dt",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide pt-0.5",children:l}),jsxRuntime.jsx("dd",{class:"min-w-0",children:jsxRuntime.jsx(be,{val:u,mismatch:N})})]})})})]})}function en({docs:e,repoName:t,basePath:n,fk:r,fv:a,columns:s,schema:o,pagination:d}){let l=`${n}/${t}?fv_${r}=${encodeURIComponent(a)}`,u=mt(o,s);return jsxRuntime.jsxs("div",{class:"space-y-4",children:[jsxRuntime.jsxs("div",{class:"flex items-center justify-between gap-2",children:[jsxRuntime.jsxs("div",{class:"text-xs text-base-content/60",children:[jsxRuntime.jsx("span",{class:"font-mono",children:t}),jsxRuntime.jsx("span",{class:"opacity-50",children:" where "}),jsxRuntime.jsx("span",{class:"font-mono",children:r}),jsxRuntime.jsx("span",{class:"opacity-50",children:" = "}),jsxRuntime.jsx("span",{class:"font-mono break-all",children:a}),jsxRuntime.jsx("span",{class:"opacity-50",children:" \xB7 "}),jsxRuntime.jsxs("span",{children:[e.length," doc",e.length!==1?"s":""]})]}),jsxRuntime.jsx("a",{href:l,class:"btn btn-sm btn-outline",children:"Full view \u2192"})]}),jsxRuntime.jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100",children:jsxRuntime.jsxs("table",{class:"table table-xs w-full",children:[jsxRuntime.jsx("thead",{children:jsxRuntime.jsxs("tr",{class:"bg-base-200/50",children:[s.map((m,N)=>jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:m},N)),jsxRuntime.jsx("th",{})]})}),jsxRuntime.jsx("tbody",{children:e.length===0?jsxRuntime.jsx("tr",{children:jsxRuntime.jsx("td",{colspan:s.length+1,class:"text-center py-10 text-base-content/40",children:"No related documents"})}):e.map((m,N)=>{let w=String(m.docId??m.id??""),S=`${n}/${t}/${encodeURIComponent(w)}/edit`;return jsxRuntime.jsxs("tr",{class:"hover",children:[s.map((E,j)=>{let B=m[E],b=u[E],f=b?ke(b,B):null;return jsxRuntime.jsx("td",{class:"align-top py-1.5",children:jsxRuntime.jsx(be,{val:B,mismatch:f})},j)}),jsxRuntime.jsx("td",{class:"text-right py-1.5",children:jsxRuntime.jsx("a",{href:S,class:"btn btn-xs btn-ghost",children:"Edit"})})]},N)})})]})}),(d.hasPrev||d.hasNext)&&jsxRuntime.jsxs("div",{class:"flex justify-center items-center gap-2",children:[d.hasPrev?jsxRuntime.jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"prev","data-cursor":d.prevCursor,children:"\u2190 Previous"}):jsxRuntime.jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"\u2190 Previous"}),d.hasNext?jsxRuntime.jsx("button",{type:"button",class:"btn btn-xs btn-outline","data-frs-panel-page":"next","data-cursor":d.nextCursor,children:"Next \u2192"}):jsxRuntime.jsx("button",{class:"btn btn-xs btn-outline",disabled:true,children:"Next \u2192"})]})]})}function mt(e,t){if(!e)return {};let n={};for(let r of t)n[r]=ye(ge(e,r));return n}var Le,Ue=Ae(()=>{_e();Me();Le=({basePath:e=""})=>jsxRuntime.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:[jsxRuntime.jsx("div",{class:"absolute inset-0 bg-black/30 opacity-0 transition-opacity duration-200 pointer-events-auto","data-frs-panel-backdrop":true}),jsxRuntime.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:[jsxRuntime.jsxs("header",{class:"flex items-center justify-between px-5 py-3 border-b border-base-300 bg-base-200/40 shrink-0",children:[jsxRuntime.jsx("h2",{class:"font-semibold text-base truncate","data-frs-panel-title":true,children:"Relation"}),jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-ghost btn-circle","data-frs-panel-close":true,"aria-label":"Close panel",children:"\u2715"})]}),jsxRuntime.jsx("div",{class:"flex-1 overflow-auto p-5 text-sm","data-frs-panel-body":true,children:jsxRuntime.jsx("div",{class:"flex items-center justify-center py-12 text-base-content/40",children:jsxRuntime.jsx("span",{class:"loading loading-spinner loading-md"})})})]})]});});Ee();Ee();function Dt(e){return e.replace(/([A-Z])/g," $1").replace(/_/g," ").replace(/^\s/,"").replace(/^./,t=>t.toUpperCase())}function at(e){let t=e,n=true,r=false,a;for(;;){let s=M(t);if(s==="ZodOptional")n=false,t=J(t);else if(s==="ZodNullable")n=false,r=true,t=J(t);else if(s==="ZodDefault")n=false,a=nt(t),t=J(t);else break}return {inner:t,required:n,nullable:r,defaultValue:a}}function ee(e,t=""){if(M(e)==="ZodObject"){let r=Y(e);return Object.entries(r).map(([a,s])=>st(t?`${t}.${a}`:a,a,s))}return [st(t||"value",t||"value",e)]}function st(e,t,n){let{inner:r,required:a,nullable:s,defaultValue:o}=at(n),d=M(r),l=Dt(t.split(".").pop()??t);switch(d){case "ZodString":{let u=rt(r),m=u.includes("email"),N=u.includes("url");return {name:e,label:l,type:"text",required:a,nullable:s,defaultValue:o,hint:m?"email":N?"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 u=xe(r);return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:u}}case "ZodNativeEnum":{let u=we(r),m=Object.values(u).filter(N=>typeof N=="string");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:m}}case "ZodLiteral":{let u=String(Ce(r)??"");return {name:e,label:l,type:"select",required:a,nullable:s,defaultValue:o,options:[u]}}case "ZodObject":{let u=ee(r,e);return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,nested:u,hint:"JSON object"}}case "ZodArray":{let u=tt(r);if(!u)return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON array"};let{inner:m}=at(u),N=M(m),w,S,E;switch(N){case "ZodString":w="text";break;case "ZodNumber":case "ZodBigInt":w="number";break;case "ZodBoolean":w="checkbox";break;case "ZodDate":w="datetime-local";break;case "ZodEnum":w="select",S=xe(m);break;case "ZodNativeEnum":w="select",S=Object.values(we(m)).filter(j=>typeof j=="string");break;case "ZodObject":w="object",E=ee(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:w,arrayElementOptions:S,arrayElementFields:E}}default:return {name:e,label:l,type:"textarea",required:a,nullable:s,defaultValue:o,hint:"JSON"}}}function lt(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":""}
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
<div class="form-control mb-3 ${n}">
|
|
15
15
|
<label for="${r}" class="label pb-1">
|
|
16
16
|
<span class="label-text font-medium">
|
|
17
|
-
${
|
|
17
|
+
${$(e.label)}
|
|
18
18
|
<span class="text-base-content/40 text-xs ml-1">(nullable)</span>
|
|
19
19
|
</span>
|
|
20
20
|
</label>
|
|
@@ -28,41 +28,41 @@
|
|
|
28
28
|
<label class="label cursor-pointer justify-start gap-3">
|
|
29
29
|
<input type="checkbox" id="${r}" name="${a}" value="true"${d==="true"?" checked":""} class="checkbox checkbox-primary checkbox-sm">
|
|
30
30
|
<span class="label-text font-medium">
|
|
31
|
-
${
|
|
31
|
+
${$(e.label)}${e.required?' <span class="text-error">*</span>':""}
|
|
32
32
|
</span>
|
|
33
33
|
</label>
|
|
34
34
|
</div>`;case "select":u=`<select id="${r}" name="${a}"${s}${o?' disabled style="opacity:0.35"':""} class="select select-bordered select-sm w-full">
|
|
35
35
|
${e.required&&!e.nullable?"":'<option value="">\u2014 optional \u2014</option>'}
|
|
36
|
-
${(e.options??[]).map(m=>`<option value="${
|
|
36
|
+
${(e.options??[]).map(m=>`<option value="${$(m)}"${d===m?" selected":""}>${$(m)}</option>`).join(`
|
|
37
37
|
`)}
|
|
38
38
|
</select>`;break;case "textarea":if(e.arrayElementType)return Ft(e,t);if(e.nested&&e.nested.length>0){let m=e.nested.map(N=>lt(N,t+1)).join(`
|
|
39
39
|
`);return `
|
|
40
40
|
<fieldset class="fieldset border border-base-300 rounded-box p-3 mb-3 ${n}">
|
|
41
41
|
<legend class="fieldset-legend text-xs font-semibold text-base-content/60 px-1">
|
|
42
|
-
${
|
|
42
|
+
${$(e.label)}${e.required?' <span class="text-error">*</span>':""}
|
|
43
43
|
</legend>
|
|
44
44
|
${m}
|
|
45
45
|
</fieldset>`}u=`<textarea id="${r}" name="${a}"${s} rows="3"${o?' disabled style="opacity:0.35"':""}
|
|
46
46
|
data-json
|
|
47
47
|
class="textarea textarea-bordered textarea-sm w-full font-mono text-xs"
|
|
48
|
-
placeholder="${
|
|
49
|
-
value="${
|
|
48
|
+
placeholder="${$(e.hint??"JSON")}">${$(d)}</textarea>`;break;default:u=`<input type="${e.type}" id="${r}" name="${a}"${s}${o?' disabled style="opacity:0.35"':""}
|
|
49
|
+
value="${$(d)}"
|
|
50
50
|
class="input input-bordered input-sm w-full"${e.hint==="email"?' autocomplete="email"':e.hint==="url"?' autocomplete="url"':""}>`;}return `
|
|
51
51
|
<div class="form-control mb-3 ${n}">
|
|
52
52
|
<label for="${r}" class="label pb-1">
|
|
53
53
|
<span class="label-text font-medium">
|
|
54
|
-
${
|
|
55
|
-
${e.hint?`<span class="text-base-content/40 text-xs ml-1">(${
|
|
54
|
+
${$(e.label)}${e.required?' <span class="text-error">*</span>':""}
|
|
55
|
+
${e.hint?`<span class="text-base-content/40 text-xs ml-1">(${$(e.hint)})</span>`:""}
|
|
56
56
|
</span>
|
|
57
57
|
</label>
|
|
58
58
|
<div class="flex items-center gap-2">
|
|
59
59
|
<div class="flex-1 min-w-0">${u}</div>
|
|
60
60
|
${l}
|
|
61
61
|
</div>
|
|
62
|
-
</div>`}function
|
|
62
|
+
</div>`}function $(e){return e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'")}function Ft(e,t){let n=t>0?`ml-${t*4}`:"",r=`field_${e.name.replace(/\./g,"__")}`,a=e.defaultValue==="__null__",s=e.arrayElementType==="object",o=[];if(e.defaultValue!=null&&e.defaultValue!==""&&e.defaultValue!=="__null__")try{o=JSON.parse(String(e.defaultValue));}catch{}Array.isArray(o)||(o=[]);let d=s?o.map(m=>it(e,m??{})).join(`
|
|
63
63
|
`):o.map(m=>ot(e,m)).join(`
|
|
64
64
|
`),l=s?it(e,{}):ot(e,""),u=e.nullable?`<span class="flex items-center gap-1 mt-2">
|
|
65
|
-
<input type="hidden" id="${r}__isnull" name="${
|
|
65
|
+
<input type="hidden" id="${r}__isnull" name="${$(e.name)}__isnull" value="${a?"1":""}">
|
|
66
66
|
<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">
|
|
67
67
|
<input type="checkbox" class="checkbox checkbox-xs" ${a?"checked":""}
|
|
68
68
|
onchange="(function(cb){
|
|
@@ -76,11 +76,11 @@
|
|
|
76
76
|
</label>
|
|
77
77
|
</span>`:"";return `
|
|
78
78
|
<fieldset class="fieldset border border-base-300 rounded-box p-3 mb-3 ${n}"
|
|
79
|
-
data-frs-array="${
|
|
79
|
+
data-frs-array="${$(e.name)}" data-frs-array-type="${$(e.arrayElementType??"text")}">
|
|
80
80
|
<legend class="fieldset-legend text-xs font-semibold text-base-content/60 px-1">
|
|
81
|
-
${
|
|
81
|
+
${$(e.label)}${e.required?' <span class="text-error">*</span>':""}
|
|
82
82
|
</legend>
|
|
83
|
-
<input type="hidden" id="${r}" name="${
|
|
83
|
+
<input type="hidden" id="${r}" name="${$(e.name)}" value="${$(JSON.stringify(o))}"${a?" disabled":""}>
|
|
84
84
|
<div data-frs-array-items${a?' style="opacity:0.35"':""}>
|
|
85
85
|
${d}
|
|
86
86
|
</div>
|
|
@@ -89,11 +89,11 @@
|
|
|
89
89
|
${u}
|
|
90
90
|
</fieldset>`}function ot(e,t){let n=t!=null?String(t):"",r;switch(e.arrayElementType){case "select":r=`<select data-frs-val class="select select-bordered select-sm flex-1">
|
|
91
91
|
<option value="">\u2014</option>
|
|
92
|
-
${(e.arrayElementOptions??[]).map(a=>`<option value="${
|
|
92
|
+
${(e.arrayElementOptions??[]).map(a=>`<option value="${$(a)}"${n===a?" selected":""}>${$(a)}</option>`).join("")}
|
|
93
93
|
</select>`;break;case "checkbox":r=`<label class="flex items-center gap-2 flex-1 cursor-pointer">
|
|
94
94
|
<input type="checkbox" data-frs-val class="checkbox checkbox-sm checkbox-primary"${n==="true"?" checked":""}>
|
|
95
95
|
<span class="text-sm">true</span>
|
|
96
|
-
</label>`;break;case "number":r=`<input type="number" data-frs-val value="${
|
|
96
|
+
</label>`;break;case "number":r=`<input type="number" data-frs-val value="${$(n)}" class="input input-bordered input-sm flex-1">`;break;case "datetime-local":r=`<input type="datetime-local" data-frs-val value="${$(n)}" class="input input-bordered input-sm flex-1">`;break;default:r=`<input type="text" data-frs-val value="${$(n)}" class="input input-bordered input-sm flex-1">`;}return `<div class="flex items-center gap-2 mb-2" data-frs-array-item>
|
|
97
97
|
${r}
|
|
98
98
|
<button type="button" class="btn btn-xs btn-ghost text-error" data-frs-array-rm>×</button>
|
|
99
99
|
</div>`}function it(e,t){return `<div class="border border-base-200 rounded p-3 mb-2" data-frs-array-item>
|
|
@@ -102,38 +102,38 @@
|
|
|
102
102
|
</div>
|
|
103
103
|
${(e.arrayElementFields??[]).map(a=>{let s=t[a.name],o=s==null?"":typeof s=="object"?JSON.stringify(s):String(s);switch(a.type){case "checkbox":return `<div class="form-control mb-2">
|
|
104
104
|
<label class="label cursor-pointer justify-start gap-3">
|
|
105
|
-
<input type="checkbox" data-frs-key="${
|
|
106
|
-
<span class="label-text text-sm">${
|
|
105
|
+
<input type="checkbox" data-frs-key="${$(a.name)}" class="checkbox checkbox-sm checkbox-primary"${o==="true"?" checked":""}>
|
|
106
|
+
<span class="label-text text-sm">${$(a.label)}</span>
|
|
107
107
|
</label>
|
|
108
108
|
</div>`;case "select":return `<div class="form-control mb-2">
|
|
109
|
-
<label class="label pb-1"><span class="label-text text-sm">${
|
|
110
|
-
<select data-frs-key="${
|
|
109
|
+
<label class="label pb-1"><span class="label-text text-sm">${$(a.label)}</span></label>
|
|
110
|
+
<select data-frs-key="${$(a.name)}" class="select select-bordered select-sm w-full">
|
|
111
111
|
${a.required?"":'<option value="">\u2014</option>'}
|
|
112
|
-
${(a.options??[]).map(d=>`<option value="${
|
|
112
|
+
${(a.options??[]).map(d=>`<option value="${$(d)}"${o===d?" selected":""}>${$(d)}</option>`).join("")}
|
|
113
113
|
</select>
|
|
114
114
|
</div>`;case "number":return `<div class="form-control mb-2">
|
|
115
|
-
<label class="label pb-1"><span class="label-text text-sm">${
|
|
116
|
-
<input type="number" data-frs-key="${
|
|
115
|
+
<label class="label pb-1"><span class="label-text text-sm">${$(a.label)}</span></label>
|
|
116
|
+
<input type="number" data-frs-key="${$(a.name)}" value="${$(o)}" class="input input-bordered input-sm w-full">
|
|
117
117
|
</div>`;case "datetime-local":return `<div class="form-control mb-2">
|
|
118
|
-
<label class="label pb-1"><span class="label-text text-sm">${
|
|
119
|
-
<input type="datetime-local" data-frs-key="${
|
|
118
|
+
<label class="label pb-1"><span class="label-text text-sm">${$(a.label)}</span></label>
|
|
119
|
+
<input type="datetime-local" data-frs-key="${$(a.name)}" value="${$(o)}" class="input input-bordered input-sm w-full">
|
|
120
120
|
</div>`;case "textarea":return `<div class="form-control mb-2">
|
|
121
|
-
<label class="label pb-1"><span class="label-text text-sm">${
|
|
122
|
-
<textarea data-frs-key="${
|
|
121
|
+
<label class="label pb-1"><span class="label-text text-sm">${$(a.label)}</span></label>
|
|
122
|
+
<textarea data-frs-key="${$(a.name)}" rows="2" class="textarea textarea-bordered textarea-sm w-full font-mono text-xs" placeholder="JSON">${$(o)}</textarea>
|
|
123
123
|
</div>`;default:return `<div class="form-control mb-2">
|
|
124
|
-
<label class="label pb-1"><span class="label-text text-sm">${
|
|
125
|
-
<input type="text" data-frs-key="${
|
|
124
|
+
<label class="label pb-1"><span class="label-text text-sm">${$(a.label)}</span></label>
|
|
125
|
+
<input type="text" data-frs-key="${$(a.name)}" value="${$(o)}" class="input input-bordered input-sm w-full">
|
|
126
126
|
</div>`}}).join(`
|
|
127
127
|
`)}
|
|
128
128
|
</div>`}function ie(e,t,n,r="Save"){let a=e.map(s=>lt(s)).join(`
|
|
129
129
|
`);return `
|
|
130
|
-
<form action="${
|
|
130
|
+
<form action="${$(t)}" method="${n}" novalidate data-frs-form>
|
|
131
131
|
${a}
|
|
132
132
|
<div class="flex gap-2 mt-4 pt-4 border-t border-base-200">
|
|
133
|
-
<button type="submit" class="btn btn-primary btn-sm">${
|
|
133
|
+
<button type="submit" class="btn btn-primary btn-sm">${$(r)}</button>
|
|
134
134
|
<button type="button" class="btn btn-ghost btn-sm" onclick="history.back()">Cancel</button>
|
|
135
135
|
</div>
|
|
136
|
-
</form>`}Te();var
|
|
136
|
+
</form>`}var jt=new Set(["<","<=",">",">=","!="]),Bt=new Set(["array-contains","array-contains-any"]);function Pe(e){return e==="desc"?"DESCENDING":"ASCENDING"}function Mt(e){let t=e.split("/").filter(Boolean);return t[t.length-1]??e}function Lt(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(Bt.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(jt.has(l.op)){if(o.has(l.field))continue;o.add(l.field);let u=a?.field===l.field?Pe(a.dir):"ASCENDING";s.push({fieldPath:l.field,order:u});}if(a&&!o.has(a.field)&&s.push({fieldPath:a.field,order:Pe(a.dir)}),s.length===1&&n)return Ht(e,t,s[0]);let d=a&&s.some(l=>l.fieldPath===a.field)?Pe(a.dir):"ASCENDING";return s.push({fieldPath:"__name__",order:d}),Ut(e,t,n,s)}function Ut(e,t,n,r,a="(default)"){let s=`projects/${e}/databases/${a}/collectionGroups/${t}/indexes/_`,o=[...Fe(1,s),...Te(2,n?2:1)];for(let u of r)o.push(...dt(3,ct(u)));let d=a==="(default)"?"-default-":a,l=encodeURIComponent(ut(o));return `https://console.firebase.google.com/project/${e}/firestore/databases/${d}/indexes?create_composite=${l}`}function qt(e){return e.match(/https:\/\/console\.firebase\.google\.com[^\s)"]*/)?.[0]}function ze(e){let t=[],n=e>>>0;for(;n>=128;)t.push(n&127|128),n>>>=7;return t.push(n&127),t}function De(e,t){return e<<3|t}function Fe(e,t){let n=Array.from(new TextEncoder().encode(t));return [De(e,2),...ze(n.length),...n]}function Te(e,t){return [De(e,0),...ze(t)]}function dt(e,t){return [De(e,2),...ze(t.length),...t]}function ct(e){let t=[...Fe(1,e.fieldPath)];return e.arrayConfig==="CONTAINS"?t.push(...Te(3,1)):t.push(...Te(2,e.order==="DESCENDING"?2:1)),t}function ut(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 Ht(e,t,n,r="(default)"){let a=`projects/${e}/databases/${r}/collectionGroups/${t}/fields/${n.fieldPath}`,s=[...Fe(1,a),...Te(2,2),...dt(3,ct(n))],o=r==="(default)"?"-default-":r,d=encodeURIComponent(ut(s));return `https://console.firebase.google.com/project/${e}/firestore/databases/${o}/indexes/automatic?create_exemption=${d}`}function Vt(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 le(e){let t=e;return t?t.code===9?true:typeof t.message=="string"?t.message.includes("requires an index"):false:false}function je(e,t){let n=e??{},r=le(e),a;if(r&&(a=n.message?qt(n.message):void 0,!a)){let s=Vt(t.ref);if(s){let o=Mt(t.path);a=Lt(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}}_e();var ft=`// \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
137
|
function frsGetBasePath() {
|
|
138
138
|
var root = document.querySelector("[data-frs-panel-root]");
|
|
139
139
|
var bp = root && root.getAttribute("data-frs-base-path");
|
|
@@ -1042,6 +1042,6 @@ function initColumnReorder(table) {
|
|
|
1042
1042
|
});
|
|
1043
1043
|
});
|
|
1044
1044
|
}
|
|
1045
|
-
`;function _e(){return jsxRuntime.jsx("script",{dangerouslySetInnerHTML:{__html:ct}})}Fe();function re(e){return "<!DOCTYPE html>"+server.renderToString(e)}var Gt=["corporate","silk","dark"],Wt=()=>jsxRuntime.jsxs("div",{class:"dropdown dropdown-end","data-frs-theme-switcher":true,children:[jsxRuntime.jsxs("button",{type:"button",tabIndex:0,class:"btn btn-sm btn-ghost text-neutral-content gap-1.5","aria-label":"Switch theme",children:[jsxRuntime.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:[jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"4"}),jsxRuntime.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"})]}),jsxRuntime.jsx("span",{class:"text-xs hidden sm:inline","data-frs-theme-current":true,children:"Theme"})]}),jsxRuntime.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:Gt.map(e=>jsxRuntime.jsx("li",{children:jsxRuntime.jsxs("button",{type:"button","data-frs-theme":e,class:"capitalize justify-between",children:[jsxRuntime.jsx("span",{children:e}),jsxRuntime.jsx("span",{class:"hidden text-primary","data-frs-theme-check":e,children:"\u2713"})]})},e))})]}),ae=({opts:e,children:t})=>{let{title:n,breadcrumb:r,flash:a,basePath:s="/"}=e;return jsxRuntime.jsxs("html",{lang:"en","data-theme":"corporate",children:[jsxRuntime.jsxs("head",{children:[jsxRuntime.jsx("meta",{charset:"UTF-8"}),jsxRuntime.jsx("meta",{name:"viewport",content:"width=device-width, initial-scale=1"}),jsxRuntime.jsxs("title",{children:[n," \u2014 FRS Admin"]}),jsxRuntime.jsx("script",{dangerouslySetInnerHTML:{__html:"(function(){try{var t=localStorage.getItem('frs-admin-theme');if(t){document.documentElement.setAttribute('data-theme',t);}}catch(_){}})();"}}),jsxRuntime.jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/themes.css",rel:"stylesheet",type:"text/css"}),jsxRuntime.jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/daisyui.css",rel:"stylesheet",type:"text/css"}),jsxRuntime.jsx("script",{src:"https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"})]}),jsxRuntime.jsxs("body",{class:"bg-base-200/50 min-h-screen flex flex-col",children:[jsxRuntime.jsxs("div",{class:"navbar bg-neutral text-neutral-content shadow-sm sticky top-0 z-50 px-6",children:[jsxRuntime.jsx("div",{class:"flex-1",children:jsxRuntime.jsx("a",{href:s,class:"font-bold text-lg tracking-tight hover:opacity-80 transition-opacity",children:"FRS Admin"})}),jsxRuntime.jsx("div",{class:"flex-none",children:jsxRuntime.jsx(Wt,{})})]}),jsxRuntime.jsxs("main",{class:"px-6 py-8 w-full flex-1",children:[r&&r.length>0&&jsxRuntime.jsx("div",{class:"text-sm breadcrumbs mb-4",children:jsxRuntime.jsx("ul",{children:r.map((o,d)=>o.href?jsxRuntime.jsx("li",{children:jsxRuntime.jsx("a",{href:o.href,children:o.label})},d):jsxRuntime.jsx("li",{class:"text-base-content/60",children:o.label},d))})}),jsxRuntime.jsx("h1",{class:"text-2xl font-bold mb-6",children:n}),a&&jsxRuntime.jsxs("div",{role:"alert",class:`alert ${a.type==="success"?"alert-success":a.type==="warning"?"alert-warning":"alert-error"} mb-6`,children:[jsxRuntime.jsx("span",{class:"flex-1",children:a.message}),a.action&&jsxRuntime.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]}),jsxRuntime.jsx(De,{basePath:s}),jsxRuntime.jsx(_e,{})]})]})};function je(e,t){return re(jsxRuntime.jsx(ae,{opts:t,children:jsxRuntime.jsx("div",{dangerouslySetInnerHTML:{__html:e}})}))}function Me(e,t){return re(jsxRuntime.jsx(ae,{opts:{title:"Repositories",basePath:t},children:e.length===0?jsxRuntime.jsxs("div",{class:"text-center py-20 text-base-content/50",children:[jsxRuntime.jsx("p",{class:"text-lg font-medium mb-1",children:"No repositories configured"}),jsxRuntime.jsx("p",{class:"text-sm",children:"Add a repository to your FRS config to get started."})]}):jsxRuntime.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=>jsxRuntime.jsx("a",{href:`${t}/${n.name}`,class:"card bg-base-100 border border-base-300 hover:shadow-md no-underline transition-shadow",children:jsxRuntime.jsxs("div",{class:"card-body p-5",children:[jsxRuntime.jsx("h2",{class:"card-title text-sm font-semibold",children:n.name}),jsxRuntime.jsx("p",{class:"text-xs text-base-content/50 font-mono",children:n.path})]})},n.name))})}))}var mt=[{value:"==",label:"="},{value:"!=",label:"\u2260"},{value:"in",label:"in"},{value:"not-in",label:"not in"}],Qt=[{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"}],Xt=[{value:"array-contains",label:"contains"},{value:"array-contains-any",label:"contains any"}];function Yt(e){switch(e){case "ZodNumber":case "ZodBigInt":case "ZodDate":return Qt;case "ZodBoolean":return mt;case "ZodArray":return Xt;default:return mt}}var se="__null__";function en(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="${se}"]');if(!o){o=document.createElement('option');o.value='${se}';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='${se}';i.readOnly=true;}i.style.opacity='0.55';}else{i.style.opacity='';if(i.tagName==='SELECT'){var o2=i.querySelector('option[value="${se}"][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!=='${se}')?i.dataset._prev:'';}}})(this)`}function tn(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 Se({inputId:e,active:t}){return jsxRuntime.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:[jsxRuntime.jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",checked:t,onchange:en(e)}),jsxRuntime.jsx("span",{children:"\u2205"})]})}function nn({col:e,active:t}){let n=t?.value??"",r=n===se,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(u=>u.trim()).filter(Boolean)),l=`eg_${e.name.replace(/\./g,"__")}`;return jsxRuntime.jsxs("div",{class:"flex flex-wrap items-center gap-1 w-full",children:[jsxRuntime.jsx("input",{type:"hidden",id:a,name:`fv_${e.name}`,value:n}),e.enumValues.map(u=>jsxRuntime.jsxs("label",{class:"flex items-center gap-1 text-xs border border-base-300 rounded px-2 cursor-pointer hover:bg-base-200",children:[jsxRuntime.jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",value:u,checked:d.has(u),"data-enum-group":l,onchange:tn(a,l)}),jsxRuntime.jsx("span",{children:u})]},u))]})}return jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsxRuntime.jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),e.enumValues.map(d=>jsxRuntime.jsx("option",{value:d,selected:n===d,children:d},d)),e.nullable&&jsxRuntime.jsx("option",{value:se,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsxRuntime.jsx(Se,{inputId:a,active:r})]})}if(e.zodType==="ZodBoolean")return jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsxRuntime.jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),jsxRuntime.jsx("option",{value:"true",selected:n==="true",children:"true"}),jsxRuntime.jsx("option",{value:"false",selected:n==="false",children:"false"}),e.nullable&&jsxRuntime.jsx("option",{value:se,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsxRuntime.jsx(Se,{inputId:a,active:r})]});if(e.zodType==="ZodArray"){let d=t?.op==="array-contains-any";return jsxRuntime.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"?jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.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&&jsxRuntime.jsx(Se,{inputId:a,active:r})]}):e.zodType==="ZodDate"?jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.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&&jsxRuntime.jsx(Se,{inputId:a,active:r})]}):jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.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&&jsxRuntime.jsx(Se,{inputId:a,active:r})]})}function Be({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 jsxRuntime.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:[jsxRuntime.jsxs("summary",{class:"collapse-title text-sm font-medium py-2 min-h-0",children:["Filters",s&&jsxRuntime.jsxs("span",{class:"badge badge-primary badge-sm ml-2",children:[n.length," active"]})]}),jsxRuntime.jsx("div",{class:"collapse-content pb-4 pt-2",children:jsxRuntime.jsxs("form",{method:"get",action:e,children:[jsxRuntime.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 u=Yt(l.zodType),m=a[l.name],N=m?.op??u[0].value;return jsxRuntime.jsxs("div",{class:"flex flex-col gap-1.5",children:[jsxRuntime.jsx("label",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:l.name}),jsxRuntime.jsxs("div",{class:"flex gap-1.5",children:[u.length>1?jsxRuntime.jsx("select",{name:`fo_${l.name}`,class:"select select-sm select-bordered w-20 shrink-0",children:u.map(w=>jsxRuntime.jsx("option",{value:w.value,selected:w.value===N,children:w.label},w.value))}):jsxRuntime.jsx("input",{type:"hidden",name:`fo_${l.name}`,value:u[0].value}),jsxRuntime.jsx(nn,{col:l,active:m})]})]},l.name)})}),jsxRuntime.jsxs("div",{class:"flex flex-wrap gap-2 mt-4 pt-3 border-t border-base-200 items-center",children:[jsxRuntime.jsx("button",{type:"submit",class:"btn btn-sm btn-primary",children:"Apply"}),s&&jsxRuntime.jsx("a",{href:e,class:"btn btn-sm btn-ghost",children:"Clear"}),o&&jsxRuntime.jsxs("span",{class:"text-xs text-warning ml-auto flex items-center gap-1",children:[jsxRuntime.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:jsxRuntime.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 Le(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 re(jsxRuntime.jsx(ae,{opts:{title:o,breadcrumb:d,basePath:a,flash:s},children:jsxRuntime.jsx("div",{class:"card bg-base-100 border border-base-300",children:jsxRuntime.jsx("div",{class:"card-body p-6",children:jsxRuntime.jsx("div",{dangerouslySetInnerHTML:{__html:t}})})})}))}Te();ze();function Ue(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 bt(e,t,n,r,a){let s=Ue(e,r,a);return s.set("cursor",t),s.set("dir",n),`?${s.toString()}`}function rn(e,t,n,r){let a=Ue(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 an(e,t,n){return `?${Ue(t,n,e).toString()}`}function qe(e,t,n,r,a,s,o=[],d=[],l=false,u=[],m,N,w,S,E,j,M,b=false){let p=`${r}/${e}`,x=`${p}/create`,i={};if(M)for(let v of n)i[v]=ye(ge(M,v));let c=(j??[]).filter(v=>{let R=i[v]??ye(ge(M,v));return R==="string"||R==="number"||R==="bigint"||R==="boolean"||R==="enum"||R==="literal"}),f=c.length>0,h=l,T=h||f,_=c.map(v=>{let R=ge(M,v),k=ye(R),$=o.find(D=>D.name===v);return {name:v,type:k,enumValues:$?.enumValues??null,nullable:$?.nullable??false}});return re(jsxRuntime.jsxs(ae,{opts:{title:e,breadcrumb:[{label:"Repositories",href:r},{label:e}],basePath:r,flash:s},children:[o.length>0&&jsxRuntime.jsx(Be,{action:p,columnMeta:o,activeFilters:d,isGroup:S}),w&&jsxRuntime.jsxs("div",{role:"alert",class:`alert ${w.type==="index"?"alert-warning":"alert-error"} mb-6 shadow-sm`,children:[jsxRuntime.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:w.type==="index"?jsxRuntime.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"}):jsxRuntime.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"})}),jsxRuntime.jsxs("div",{class:"flex-1",children:[jsxRuntime.jsx("h3",{class:"font-bold",children:w.type==="index"?"Composite index required":"Query failed"}),jsxRuntime.jsx("div",{class:"text-sm",children:w.message})]}),w.indexUrl&&jsxRuntime.jsx("a",{href:w.indexUrl,target:"_blank",rel:"noopener noreferrer",class:"btn btn-sm btn-outline",children:"Create Index \u2192"})]}),jsxRuntime.jsxs("div",{class:"flex flex-wrap justify-between items-center mb-4 gap-3","data-frs-toolbar":true,children:[jsxRuntime.jsxs("div",{class:"flex items-center gap-3",children:[jsxRuntime.jsxs("span",{class:"text-sm text-base-content/60",children:[t.length,typeof E=="number"&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[" ","of ",jsxRuntime.jsx("span",{class:"font-semibold text-base-content/80",children:E})]})," ","document",(typeof E=="number"?E:t.length)!==1&&"s"]}),jsxRuntime.jsxs("div",{class:"flex items-center gap-1.5 text-sm text-base-content/60",children:[jsxRuntime.jsx("span",{children:"Rows"}),jsxRuntime.jsx("div",{class:"join",children:[10,25,50,100].map(v=>jsxRuntime.jsx("a",{href:an(v,d,m),class:`join-item btn btn-xs ${N===v?"btn-active btn-primary":"btn-outline"}`,children:v},v))})]})]}),jsxRuntime.jsx("a",{href:x,class:"btn btn-primary btn-sm",children:"+ New"})]}),T&&jsxRuntime.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 E=="number"?String(E):"","data-frs-page-size":String(N??t.length),"data-frs-allow-delete":h?"1":"0","data-frs-allow-update":f?"1":"0","data-frs-fields":JSON.stringify(_),"data-frs-filters":JSON.stringify(d),children:[jsxRuntime.jsxs("div",{class:"flex-1 text-sm",children:[jsxRuntime.jsx("span",{"data-frs-bulk-summary":true,children:"0 selected"}),typeof E=="number"&&E>t.length&&jsxRuntime.jsxs("button",{type:"button",class:"ml-3 link link-primary text-sm hidden","data-frs-bulk-select-all":true,children:["Select all ",E," matching documents"]}),jsxRuntime.jsxs("span",{class:"hidden ml-3 italic","data-frs-bulk-all-active":true,children:["All ",E??"?"," matching documents are selected."," ",jsxRuntime.jsx("button",{type:"button",class:"link","data-frs-bulk-clear":true,children:"Clear selection"})]})]}),jsxRuntime.jsxs("div",{class:"flex gap-2",children:[f&&jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-outline","data-frs-bulk-action":"update",children:"Update field\u2026"}),h&&jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-error btn-outline","data-frs-bulk-action":"delete",children:"Delete"})]})]}),jsxRuntime.jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100","data-frs-table-wrap":true,children:jsxRuntime.jsxs("table",{class:"table table-sm w-full","data-frs-table":true,"data-frs-repo":e,"data-frs-colcount":n.length,children:[jsxRuntime.jsx("thead",{children:jsxRuntime.jsxs("tr",{class:"bg-base-200/50",children:[T&&jsxRuntime.jsx("th",{class:"w-8",children:jsxRuntime.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,R)=>{let k=m?.field===v,$=k?m.dir==="asc"?" \u25B2":" \u25BC":"";return jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:jsxRuntime.jsxs("a",{href:rn(v,m,d,N),class:`hover:text-base-content inline-flex items-center gap-0.5${k?" text-primary font-bold":""}`,children:[v,$]})},R)}),u.map((v,R)=>jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:v.column},`rel-${R}`)),jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide text-right",children:"Actions"})]})}),jsxRuntime.jsx("tbody",{children:t.length===0?jsxRuntime.jsx("tr",{children:jsxRuntime.jsx("td",{colspan:n.length+u.length+1+(T?1:0),class:"text-center py-16 text-base-content/40",children:"No documents found"})}):t.map((v,R)=>{let k=String(v.docId??v.id??""),$=`${r}/${e}/${encodeURIComponent(k)}/edit`,D=`${r}/${e}/${encodeURIComponent(k)}/delete`;return jsxRuntime.jsxs("tr",{class:"hover","data-frs-row-id":k,children:[T&&jsxRuntime.jsx("td",{class:"align-middle py-2",children:jsxRuntime.jsx("input",{type:"checkbox",class:"checkbox checkbox-xs checkbox-primary","data-frs-select-row":true,value:k,"aria-label":`Select ${k}`})}),n.map((P,G)=>{let C=v[P],y=i[P],L=y?ke(y,C):null;return jsxRuntime.jsx("td",{class:"align-top py-2",children:jsxRuntime.jsx(be,{val:C,mismatch:L})},G)}),u.map((P,G)=>{let C=v[P.key];if(C==null||C==="")return jsxRuntime.jsx("td",{class:"py-2"},`rel-${G}`);let y=P.type==="one"?`${r}/${P.targetRepo}/${encodeURIComponent(String(C))}/edit`:`${r}/${P.targetRepo}?fv_${P.targetKey}=${encodeURIComponent(String(C))}`;return jsxRuntime.jsx("td",{class:"align-middle py-2",children:jsxRuntime.jsx("a",{href:y,class:"btn btn-xs btn-ghost btn-outline","data-frs-relation":true,"data-frs-rel-type":P.type,"data-frs-rel-repo":P.targetRepo,"data-frs-rel-fk":P.targetKey,"data-frs-rel-val":String(C),"data-frs-rel-label":P.column,children:P.column})},`rel-${G}`)}),jsxRuntime.jsx("td",{class:"align-middle text-right whitespace-nowrap py-2",children:jsxRuntime.jsxs("div",{class:"flex gap-1 justify-end",children:[jsxRuntime.jsx("a",{href:$,class:"btn btn-xs btn-outline",children:"Edit"}),b&&jsxRuntime.jsx("a",{href:`${r}/${e}/${encodeURIComponent(k)}/history`,class:"btn btn-xs btn-outline",title:"View change history",children:"History"}),l&&jsxRuntime.jsx("form",{method:"post",action:D,onsubmit:"return confirm('Delete this document?')",children:jsxRuntime.jsx("button",{type:"submit",class:"btn btn-xs btn-error btn-outline",children:"Delete"})})]})})]},R)})})]})}),(a.hasPrev||a.hasNext)&&jsxRuntime.jsxs("div",{class:"flex flex-col items-center mt-6 gap-2",children:[jsxRuntime.jsxs("div",{class:"flex justify-center items-center gap-2",children:[a.hasPrev?jsxRuntime.jsx("a",{href:bt(d,a.prevCursor,"prev",m,N),class:"btn btn-sm btn-outline",children:"\u2190 Previous"}):jsxRuntime.jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"\u2190 Previous"}),a.hasNext?jsxRuntime.jsx("a",{href:bt(d,a.nextCursor,"next",m,N),class:"btn btn-sm btn-outline",children:"Next \u2192"}):jsxRuntime.jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"Next \u2192"})]}),typeof E=="number"&&jsxRuntime.jsxs("div",{class:"text-xs text-base-content/50",children:[E," total document",E!==1?"s":"",d.length>0?" matching filters":""]})]}),T&&f&&jsxRuntime.jsxs("dialog",{id:"frs-bulk-update-modal",class:"modal",children:[jsxRuntime.jsxs("div",{class:"modal-box",children:[jsxRuntime.jsx("h3",{class:"font-bold text-lg mb-3",children:"Bulk update field"}),jsxRuntime.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."}),jsxRuntime.jsxs("form",{method:"dialog","data-frs-bulk-update-form":true,children:[jsxRuntime.jsxs("label",{class:"form-control w-full mb-3",children:[jsxRuntime.jsx("div",{class:"label",children:jsxRuntime.jsx("span",{class:"label-text text-xs uppercase tracking-wide",children:"Field"})}),jsxRuntime.jsxs("select",{class:"select select-bordered select-sm w-full",name:"field",required:true,"data-frs-bulk-field-select":true,children:[jsxRuntime.jsx("option",{value:"",children:"\u2014 Select a field \u2014"}),c.map(v=>jsxRuntime.jsx("option",{value:v,children:v},v))]})]}),jsxRuntime.jsx("div",{class:"mb-4","data-frs-bulk-value-container":true}),jsxRuntime.jsxs("div",{class:"modal-action",children:[jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-ghost","data-frs-bulk-update-cancel":true,children:"Cancel"}),jsxRuntime.jsx("button",{type:"submit",class:"btn btn-sm btn-primary","data-frs-bulk-update-submit":true,children:"Apply"})]})]})]}),jsxRuntime.jsx("form",{method:"dialog",class:"modal-backdrop",children:jsxRuntime.jsx("button",{children:"close"})})]})]}))}function Ze(e,t){return je(e,t)}function yt(e,t){return Me(e,t)}function gt(e,t,n,r,a,s,o,d,l,u,m,N,w,S,E,j,M,b){return qe(e,t,n,r,a,s,o,d,l,u,m,N,w,S,E,j,M,b)}function de(e,t,n,r,a,s){return Le(e,t,n,r,a,s)}var on=new Set(["<","<=",">",">=","!="]),ln=new Set(["array-contains","array-contains-any"]);function He(e){return e==="desc"?"DESCENDING":"ASCENDING"}function dn(e){let t=e.split("/").filter(Boolean);return t[t.length-1]??e}function cn(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(ln.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(on.has(l.op)){if(o.has(l.field))continue;o.add(l.field);let u=a?.field===l.field?He(a.dir):"ASCENDING";s.push({fieldPath:l.field,order:u});}if(a&&!o.has(a.field)&&s.push({fieldPath:a.field,order:He(a.dir)}),s.length===1&&n)return fn(e,t,s[0]);let d=a&&s.some(l=>l.fieldPath===a.field)?He(a.dir):"ASCENDING";return s.push({fieldPath:"__name__",order:d}),un(e,t,n,s)}function un(e,t,n,r,a="(default)"){let s=`projects/${e}/databases/${a}/collectionGroups/${t}/indexes/_`,o=[...Ke(1,s),...Ne(2,n?2:1)];for(let u of r)o.push(...ht(3,vt(u)));let d=a==="(default)"?"-default-":a,l=encodeURIComponent(xt(o));return `https://console.firebase.google.com/project/${e}/firestore/databases/${d}/indexes?create_composite=${l}`}function pn(e){return e.match(/https:\/\/console\.firebase\.google\.com[^\s)"]*/)?.[0]}function Ve(e){let t=[],n=e>>>0;for(;n>=128;)t.push(n&127|128),n>>>=7;return t.push(n&127),t}function Je(e,t){return e<<3|t}function Ke(e,t){let n=Array.from(new TextEncoder().encode(t));return [Je(e,2),...Ve(n.length),...n]}function Ne(e,t){return [Je(e,0),...Ve(t)]}function ht(e,t){return [Je(e,2),...Ve(t.length),...t]}function vt(e){let t=[...Ke(1,e.fieldPath)];return e.arrayConfig==="CONTAINS"?t.push(...Ne(3,1)):t.push(...Ne(2,e.order==="DESCENDING"?2:1)),t}function xt(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 fn(e,t,n,r="(default)"){let a=`projects/${e}/databases/${r}/collectionGroups/${t}/fields/${n.fieldPath}`,s=[...Ke(1,a),...Ne(2,2),...ht(3,vt(n))],o=r==="(default)"?"-default-":r,d=encodeURIComponent(xt(s));return `https://console.firebase.google.com/project/${e}/firestore/databases/${o}/indexes/automatic?create_exemption=${d}`}function mn(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 ce(e){let t=e;return t?t.code===9?true:typeof t.message=="string"?t.message.includes("requires an index"):false:false}function Ge(e,t){let n=e??{},r=ce(e),a;if(r&&(a=n.message?pn(n.message):void 0,!a)){let s=mn(t.ref);if(s){let o=dn(t.path);a=cn(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 wt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function yn(){let e="";for(let t=0;t<20;t++)e+=wt.charAt(Math.floor(Math.random()*wt.length));return e}function Ie(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 he(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 We(e,t,n){let r=e.documentKey??"docId",a=Ge(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 Z(e,t,n=200){e.status(n).set("Content-Type","text/html; charset=utf-8").send(t);}function Qe(e,t){e.status(302).set("Location",t).send("");}function Xe(e,t){let n=t.shape,r={};for(let[a,s]of Object.entries(n)){let o=et(s);if(o==="ZodObject"){if(e[a+"__isnull"]==="1"){r[a]=null;continue}let u={},m=false;for(let[S,E]of Object.entries(e))S.startsWith(`${a}.`)&&(u[S.slice(a.length+1)]=E,m=true);if(m){let S=s;for(;;){let E=B(S);if(E==="ZodOptional"||E==="ZodNullable"||E==="ZodDefault")S=J(S);else break}r[a]=Xe(u,S);continue}let N=e[a],w=Array.isArray(N)?N[N.length-1]:N;if(w)try{r[a]=JSON.parse(w);}catch{r[a]=w;}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 kt(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 et(e){let t=e;for(;;){let n=B(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=J(t);else return n}}function gn(e){let t=e;for(;;){let n=B(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=J(t);else return t}}function Rt(e){let t=e;for(;;){let n=B(t);if(n==="ZodOptional"||n==="ZodNullable")return true;if(n==="ZodDefault"){t=J(t);continue}return false}}function $t(e){let t=gn(e),n=B(t);if(n==="ZodEnum"){let r=xe(t);return r.length>0?r:void 0}if(n==="ZodNativeEnum"){let r=we(t),a=Object.values(r).filter(s=>typeof s=="string");return a.length>0?a:void 0}if(n==="ZodLiteral"){let r=Ce(t);return typeof r=="string"?[r]:void 0}}function At(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 u=B(d);if(u==="ZodOptional"||u==="ZodNullable"||u==="ZodDefault")d=J(d);else break}let l=B(d);if(l==="ZodObject"&&typeof o=="object"&&o!==null&&!Array.isArray(o)){let u=At(o,d,s);Object.assign(r,u);}else if(l==="ZodDate"){let u=kt(o);u!==null&&(r[s]=u);}else if(typeof o=="object"&&o!==null&&!Array.isArray(o)&&("_seconds"in o||typeof o.toDate=="function")){let u=kt(o);r[s]=u??JSON.stringify(o,null,2);}else typeof o=="object"?r[s]=JSON.stringify(o,null,2):r[s]=String(o);}return r}function Ye(e,t){return e.map(n=>({...n,defaultValue:t[n.name]??n.defaultValue,nested:n.nested?Ye(n.nested,t):void 0}))}function hn(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}`]??"==",u=n.has(l)?l:"==";r.push({field:o,op:u,value:d});}return r}function St(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 Ct(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=et(o);if(d==="ZodObject"){let l=o;for(;;){let m=B(l);if(m==="ZodOptional"||m==="ZodNullable"||m==="ZodDefault")l=J(l);else break}let u=Y(l);r.push(...Ct(Object.keys(u),l,s));}else r.push({name:s,zodType:d,nullable:Rt(o),enumValues:$t(o)});}return r}function vn(e,t){let n=t.split("."),r=e;for(let a of n){for(;;){let o=B(r);if(o==="ZodOptional"||o==="ZodNullable"||o==="ZodDefault")r=J(r);else break}let s=Y(r);if(!(a in s))return null;r=s[a];}return r}function ue(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=B(d);if(l==="ZodOptional"||l==="ZodNullable"||l==="ZodDefault")d=J(d);else break}if(B(d)!=="ZodObject"){a[s]=e.shape[s];continue}a[s]=ue(d,o);}return zod.z.object(a)}function te(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 Et(e,t){let n=(b,p)=>{let x=te(b,t),i=Object.values(e).map(c=>({name:c.name,path:c.path}));Z(p,yt(i,x));},r=async(b,p)=>{let x=b.params.repoName;if(!x){Z(p,"Bad request",400);return}let i=e[x];if(!i){Z(p,"Repository not found",404);return}let c=i.pageSize??25,f=b.query??{},h=f.cursor,T=f.dir==="prev"?"prev":"next",_=f.ob??"",v=f.od==="desc"?"desc":"asc",R=_?{field:_,dir:v}:void 0,k=parseInt(f.ps??""),$=Number.isFinite(k)&&k>0?Math.min(k,200):c,D=i.listColumns??Object.keys(i.schema.shape),P=i.documentKey??"docId",G=[P,...D.filter(H=>H!==P)],C=i.filterableFields?(()=>{let H=[];for(let X of i.filterableFields)(X.includes(".")||D.includes(X))&&H.push(X);return H})():D,y=(()=>{let H=[];for(let X of C)if(X.includes(".")){let fe=vn(i.schema,X);H.push({name:X,zodType:fe?et(fe):"ZodString",nullable:fe?Rt(fe):false,enumValues:fe?$t(fe):void 0});}else H.push(...Ct([X],i.schema));return H})(),L=new Set(y.map(H=>H.name)),oe=hn(f,L),ne=St(oe),ve;if(h)try{let H=i.repo.ref;typeof H.doc=="function"&&(ve=await H.doc(h).get());}catch{}let[V,$e]=await Promise.all([i.repo.query.paginate({pageSize:$,cursor:ve,direction:T,...ne.length>0?{where:ne}:{},...R?{orderBy:[{field:R.field,direction:R.dir}]}:{}}).catch(H=>({queryError:Ge(H,{ref:i.repo.ref,path:i.path,isGroup:!!i.isGroup,filters:oe,sort:R})})),i.repo.aggregate.count(ne.length>0?{where:ne}:{}).catch(()=>{})]),pe="queryError"in V,Tt=pe?[]:V.data,_t=pe?"":V.nextCursor?.id??"",Ot=pe?"":V.prevCursor?.id??"",Zt=pe?V.queryError:void 0,Nt=te(b,t);Z(p,gt(i.name,Tt,G,Nt,{hasPrev:pe?false:V.hasPrevPage,hasNext:pe?false:V.hasNextPage,prevCursor:Ot,nextCursor:_t},void 0,y,oe,i.allowDelete??false,i.relationalMeta,R,$,Zt,i.isGroup,$e,i.mutableFields,i.schema,i.historyEnabled));},a=(b,p)=>{let x=b.params.repoName;if(!x){Z(p,"Bad request",400);return}let i=e[x];if(!i){Z(p,"Repository not found",404);return}let c=te(b,t),f=ue(i.schema,i.createFields),h=ee(f),T=`${c}/${i.name}/create`,_=ie(h,T,"POST","Create document");Z(p,de(i.name,_,"create",null,c));},s=async(b,p)=>{let x=b.params.repoName;if(!x){Z(p,"Bad request",400);return}let i=e[x];if(!i){Z(p,"Repository not found",404);return}let c=te(b,t),f=b.body??{},h=Xe(f,i.schema),T=ue(i.schema,i.createFields),_=T.safeParse(h);if(!_.success){let v=ee(T),R=`${c}/${i.name}/create`,k=ie(v,R,"POST","Create document"),$=_.error.issues.map(D=>`${D.path.join(".")}: ${D.message}`).join(", ");Z(p,de(i.name,k,"create",null,c,{type:"error",message:`Validation error: ${$}`}),422);return}try{if(i.isGroup&&i.parentKeys&&i.parentKeys.length>0){let v={..._.data};i.createdKey&&(v[i.createdKey]=new Date);let R=i.parentKeys.filter(P=>!v[P]);if(R.length>0)throw new Error(`Missing parent key(s) for subcollection create: ${R.join(", ")}`);let k=i.parentKeys.map(P=>v[P]),$=i.documentKey??"docId",D=v[$]||yn();await i.repo.set(...k,D,v);}else await i.repo.create(_.data);Qe(p,`${c}/${i.name}?flash=created`);}catch(v){let R=ue(i.schema,i.createFields),k=ee(R),$=`${c}/${i.name}/create`,D=ie(k,$,"POST","Create document");Z(p,de(i.name,D,"create",null,c,{type:"error",message:`Save error: ${v.message}`}),500);}},o=async(b,p)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(p,"Bad request",400);return}let c=e[x];if(!c){Z(p,"Repository not found",404);return}let f=te(b,t),h=null;try{h=await he(c,i);}catch($){let D=We(c,i,$),P=ce($)?424:500;Z(p,Ze("",{title:`Edit ${c.name} / ${i}`,basePath:f,breadcrumb:[{label:"Repositories",href:f},{label:c.name,href:`${f}/${c.name}`},{label:`Edit ${i}`}],flash:D}),P);return}if(!h){Z(p,"Document not found",404);return}let T=At(h,c.schema),_=ue(c.schema,c.mutableFields),v=Ye(ee(_),T),R=`${f}/${c.name}/${encodeURIComponent(i)}/edit`,k=ie(v,R,"POST","Save changes");Z(p,de(c.name,k,"edit",i,f));},d=async(b,p)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(p,"Bad request",400);return}let c=e[x];if(!c){Z(p,"Repository not found",404);return}let f=te(b,t),h=b.body??{},T=Xe(h,c.schema),_=ue(c.schema,c.mutableFields),R=_.partial().safeParse(T);if(!R.success){let k=Object.fromEntries(Object.entries(h).map(([C,y])=>[C,Array.isArray(y)?y.join(","):y??""])),$=Ye(ee(_),k),D=`${f}/${c.name}/${encodeURIComponent(i)}/edit`,P=ie($,D,"POST","Save changes"),G=R.error.issues.map(C=>`${C.path.join(".")}: ${C.message}`).join(", ");Z(p,de(c.name,P,"edit",i,f,{type:"error",message:`Validation error: ${G}`}),422);return}try{let k=await he(c,i),$=(k&&Ie(k,c.pathKey))??[i];await c.repo.update(...$,R.data),Qe(p,`${f}/${c.name}?flash=updated`);}catch(k){let $=ue(c.schema,c.mutableFields),D=ee($),P=`${f}/${c.name}/${encodeURIComponent(i)}/edit`,G=ie(D,P,"POST","Save changes"),C=ce(k)?We(c,i,k):{type:"error",message:`Save error: ${k.message}`},y=ce(k)?424:500;Z(p,de(c.name,G,"edit",i,f,C),y);}},l=async(b,p)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(p,"Bad request",400);return}let c=e[x];if(!c){Z(p,"Repository not found",404);return}if(!c.allowDelete){Z(p,"Delete is not allowed for this repository",403);return}let f=te(b,t);try{let h=await he(c,i),T=(h&&Ie(h,c.pathKey))??[i];await c.repo.delete(...T),Qe(p,`${f}/${c.name}?flash=deleted`);}catch(h){let T=ce(h)?We(c,i,h):{type:"error",message:`Delete error: ${h.message}`},_=ce(h)?424:500;Z(p,Ze("",{title:`Delete ${c.name} / ${i}`,basePath:f,breadcrumb:[{label:"Repositories",href:f},{label:c.name,href:`${f}/${c.name}`},{label:`Delete ${i}`}],flash:T}),_);}},u=async(b,p)=>{let x=b.params.repoName;if(!x){Z(p,"Bad request",400);return}let i=e[x];if(!i){Z(p,"Repository not found",404);return}let c=te(b,t),f=b.query,h=f?.type==="many"?"many":"one",T=Math.max(1,Math.min(100,Number(f?.ps??25)||25)),_=i.listColumns??Object.keys(Y(i.schema)),{PanelOne:v,PanelMany:R}=await Promise.resolve().then(()=>(Fe(),pt)),{renderToString:k}=await import('hono/jsx/dom/server');if(h==="one"){let y=String(f?.id??"");if(!y){Z(p,"<div class='p-6 text-error'>Missing id parameter.</div>",400);return}try{let L=await he(i,y),oe=k(v({doc:L,repoName:i.name,basePath:c,schema:i.schema,columns:_}));Z(p,oe);}catch(L){Z(p,`<div class='p-6 text-error text-sm'>Error: ${L.message}</div>`,500);}return}let $=String(f?.fk??""),D=String(f?.fv??"");if(!$||!D){Z(p,"<div class='p-6 text-error'>Missing fk/fv parameters.</div>",400);return}let P=f?.cursor??"",G=f?.dir==="prev"?"prev":"next",C;if(P)try{let y=i.repo.ref;typeof y.doc=="function"&&(C=await y.doc(P).get());}catch{}try{let y=await i.repo.query.paginate({pageSize:T,cursor:C,direction:G,where:[[$,"==",xn(D)]]}),L=k(R({docs:y.data,repoName:i.name,basePath:c,fk:$,fv:D,columns:_,schema:i.schema,pagination:{hasPrev:y.hasPrevPage,hasNext:y.hasNextPage,prevCursor:y.prevCursor?.id??"",nextCursor:y.nextCursor?.id??"",pageSize:T}}));Z(p,L);}catch(y){Z(p,`<div class='p-6 text-error text-sm'>Error: ${y.message}</div>`,500);}},m=async(b,p)=>{let x=[];for(let i of p){let c;if(b.isGroup||b.parentKeys?.length){let f=await he(b,i);c=f?Ie(f,b.pathKey):void 0;}c||(c=[i]);try{let f=b.repo.documentRef(...c);f&&x.push(f);}catch{}}return x},N=async(b,p)=>{let x=St(p),i=b.documentKey??"docId",c=[],f;for(;;){let h=await b.repo.query.paginate({pageSize:500,cursor:f,direction:"next",...x.length>0?{where:x}:{}});for(let T of h.data){let _=String(T[i]??T.id??"");_&&c.push(_);}if(!h.hasNextPage||!h.nextCursor)break;f=h.nextCursor;}return c},w=async(b,p)=>{let x=b.params.repoName;if(!x){W(p,{error:"Bad request"},400);return}let i=e[x];if(!i){W(p,{error:"Repository not found"},404);return}if(!i.allowDelete){W(p,{error:"Delete is not allowed for this repository"},403);return}let c=b.body??{};try{let f=await E(i,c);if(f.length===0){W(p,{deleted:0});return}let h=await m(i,f);for(let T=0;T<h.length;T+=500)await i.repo.bulk.delete(h.slice(T,T+500));W(p,{deleted:h.length});}catch(f){W(p,{error:f.message},500);}},S=async(b,p)=>{let x=b.params.repoName;if(!x){W(p,{error:"Bad request"},400);return}let i=e[x];if(!i){W(p,{error:"Repository not found"},404);return}let c=b.body??{},f=String(c.field??"");if(!f){W(p,{error:"Missing 'field'"},400);return}if(!i.mutableFields||!i.mutableFields.includes(f)){W(p,{error:`Field '${f}' is not bulk-updatable`},403);return}let h=i.schema.shape?.[f],T=c.value;if(h){let _=h.safeParse(c.value);if(!_.success){W(p,{error:`Invalid value for '${f}': ${_.error.message}`},400);return}T=_.data;}try{let _=await E(i,c);if(_.length===0){W(p,{updated:0});return}let R=(await m(i,_)).map(k=>({docRef:k,data:{[f]:T}}));for(let k=0;k<R.length;k+=500)await i.repo.bulk.update(R.slice(k,k+500));W(p,{updated:R.length});}catch(_){W(p,{error:_.message},500);}};async function E(b,p){if(p.selectAll){let x=j(p.filters,b);return await N(b,x)}return Array.isArray(p.ids)?p.ids.filter(x=>typeof x=="string"&&!!x):[]}function j(b,p){if(!Array.isArray(b))return [];let x=new Set((p.filterableFields??Object.keys(Y(p.schema))).map(f=>String(f))),i=new Set(["==","!=","<","<=",">",">=","in","not-in","array-contains","array-contains-any"]),c=[];for(let f of b)f&&typeof f=="object"&&typeof f.field=="string"&&x.has(f.field)&&typeof f.value=="string"&&i.has(String(f.op))&&c.push({field:f.field,op:f.op,value:f.value});return c}return {handleDashboard:n,handleList:r,handleCreateForm:a,handleCreateSubmit:s,handleEditForm:o,handleEditSubmit:d,handleDelete:l,handlePanel:u,handleBulkDelete:w,handleBulkUpdate:S,handleHistory:async(b,p)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(p,"Bad request",400);return}let c=e[x];if(!c){Z(p,"Repository not found",404);return}if(!c.historyEnabled||!c.repo.history){Z(p,"History not enabled for this repository",404);return}let f=te(b,t),h=c.historySubcollection??"history",T=[i];try{let y=await he(c,i),L=y?Ie(y,c.pathKey):void 0;L&&L.length>0&&(T=L);}catch{}let _=parseInt(String(b.query?.limit??"")),v=Number.isFinite(_)&&_>0?Math.min(_,500):100,R=[],k;try{R=await c.repo.history.list(...T,{limit:v});}catch(y){k=y.message;}let $=y=>String(y??"").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,"""),D=y=>{if(y===void 0)return '<span class="opacity-40">undefined</span>';if(y===null)return '<span class="opacity-40">null</span>';if(typeof y=="object")try{return `<code class="text-xs">${$(JSON.stringify(y))}</code>`}catch{return $(String(y))}return $(String(y))},P=y=>y?typeof y.toDate=="function"?y.toDate().toISOString():y instanceof Date?y.toISOString():$(String(y)):"",G=y=>`<span class="badge badge-sm ${y==="create"?"badge-success":y==="delete"?"badge-error":"badge-info"}">${$(y)}</span>`,C="";if(C+='<div class="flex items-center justify-between mb-4">',C+=`<h1 class="text-2xl font-semibold">History \u2014 ${$(c.name)} / ${$(i)}</h1>`,C+=`<a href="${f}/${c.name}/${encodeURIComponent(i)}/edit" class="btn btn-sm btn-outline">\u2190 Back to edit</a>`,C+="</div>",C+=`<p class="text-sm text-base-content/60 mb-4">Subcollection: <code>${$(h)}</code> \xB7 Showing up to ${v} entries.</p>`,k)C+=`<div class="alert alert-error mb-4">${$(k)}</div>`;else if(R.length===0)C+='<div class="alert">No history entries found.</div>';else {C+='<div class="overflow-x-auto"><table class="table table-zebra table-sm">',C+="<thead><tr><th>When</th><th>Op</th><th>User</th><th>Reason / Comment</th><th>Changes</th></tr></thead><tbody>";for(let y of R){let L=y.meta??{},oe=[L.reason,L.comment].filter(V=>V!=null&&V!=="").map(V=>$(String(V))).join(" \u2014 "),ne="",ve=Object.keys(y.changes??{});ve.length===0?ne='<span class="opacity-40">\u2014</span>':ne='<ul class="space-y-1">'+ve.map(V=>{let $e=y.changes[V];return `<li><strong>${$(V)}</strong>: ${D($e.oldValue)} \u2192 ${D($e.newValue)}</li>`}).join("")+"</ul>",C+="<tr>",C+=`<td class="whitespace-nowrap text-xs font-mono">${$(P(y.historySetAt))}</td>`,C+=`<td>${G(y.operation??"update")}</td>`,C+=`<td class="text-xs">${$(L.userEmail??L.userId??"")}</td>`,C+=`<td class="text-xs">${oe}</td>`,C+=`<td>${ne}</td>`,C+="</tr>";}C+="</tbody></table></div>";}Z(p,Ze(C,{title:`History \u2014 ${c.name} / ${i}`,basePath:f,breadcrumb:[{label:"Repositories",href:f},{label:c.name,href:`${f}/${c.name}`},{label:`History ${i}`}]}));}}}function W(e,t,n=200){e.status(n).set("Content-Type","application/json; charset=utf-8").send(JSON.stringify(t));}function xn(e){return e==="true"?true:e==="false"?false:e!==""&&!isNaN(Number(e))?Number(e):e}function wn(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 kn(e){let t=e.path??e.url??"/",n=t.indexOf("?");return n===-1?t:t.slice(0,n)}var Re=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}=wn(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=kn(t),s=null,o={};for(let u of this.routes){if(u.method!==r)continue;let m=a.match(u.pattern);if(m){s=u,o={},u.paramNames.forEach((N,w)=>{o[N]=decodeURIComponent(m[w+1]??"");});break}}let d=Object.assign(t,{params:o}),l=s?s.handler:this.notFoundHandler;try{await this.runMiddlewareChain(d,n,l);}catch(u){this.errorHandler(u,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 Sn(e){return typeof e.rawBody=="string"?e.rawBody:Buffer.isBuffer(e.rawBody)?e.rawBody.toString("utf8"):""}function Rn(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 Ar(e){let{basePath:t="/",repos:n,parseBody:r=true,auth:a,middleware:s=[],httpsOptions:o}=e,d=t==="/"?"":t.replace(/\/$/,""),l={};for(let[w,S]of Object.entries(n)){let E=S.schema??S.repo.schema??null;if(!E)throw new Error(`[createAdminServer] Repository "${w}" has no Zod schema. Either use createRepositoryConfig(schema)(config) or pass schema: explicitly.`);let j,M,b;if(S.fieldsConfig){let i=S.fieldsConfig;j=[],M=[],b=[];for(let[c,f]of Object.entries(i))for(let h of f)h==="filterable"?j.push(c):h==="mutable"?M.push(c):h==="create"&&b.push(c);j.length===0&&(j=void 0),M.length===0&&(M=void 0),b.length===0&&(b=void 0);}let p=(()=>{let i=S.repo._parentKeys;return i&&i.length>0?i:void 0})();if(p&&b)for(let i of p)b.includes(i)||b.push(i);let x={name:w,path:S.path,repo:S.repo,schema:E,documentKey:S.documentKey??"docId",pathKey:S.repo._pathKey??void 0,isGroup:!!S.repo._isGroup,parentKeys:p,createdKey:S.repo._createdKey??void 0,listColumns:S.listColumns,pageSize:S.pageSize,filterableFields:j,mutableFields:M,createFields:b,allowDelete:S.allowDelete??false,historyEnabled:!!S.repo.history,historySubcollection:(S.repo.history&&S.repo._historySubcollection)??void 0,relationalMeta:(()=>{if(!S.relationalFields||S.relationalFields.length===0)return;let i=S.repo.relationalKeys??{},c=[];for(let f of S.relationalFields){let h=i[f.key];h&&c.push({key:f.key,column:f.column,targetRepo:String(h.repo),targetKey:String(h.key),type:h.type});}return c.length>0?c:void 0})()};l[w]=x;}let u=Et(l,d),m=new Re;if(r&&m.use(async(w,S,E)=>{let j=w,M=String(j.headers?.["content-type"]??"");if(M.includes("application/x-www-form-urlencoded")){let b=await Sn(j);w.body=Rn(b);}else if(M.includes("application/json")&&typeof j.body=="string")try{w.body=JSON.parse(j.body);}catch{}await E();}),a)if(typeof a=="function")m.use(a);else {let w=a.realm??"Admin",S="Basic "+Buffer.from(`${a.username}:${a.password}`).toString("base64");m.use((E,j,M)=>{if((E.headers?.authorization??"")!==S){j.status(401).set("WWW-Authenticate",`Basic realm="${w}"`).set("Content-Type","text/plain").send("Unauthorized");return}M();});}for(let w of s)m.use(w);m.get(`${d}/`,u.handleDashboard),m.get(`${d}`,u.handleDashboard),m.get(`${d}/:repoName/_panel`,u.handlePanel),m.post(`${d}/:repoName/_bulk/delete`,u.handleBulkDelete),m.post(`${d}/:repoName/_bulk/update`,u.handleBulkUpdate),m.get(`${d}/:repoName`,u.handleList),m.get(`${d}/:repoName/create`,u.handleCreateForm),m.post(`${d}/:repoName/create`,u.handleCreateSubmit),m.get(`${d}/:repoName/:id/edit`,u.handleEditForm),m.post(`${d}/:repoName/:id/edit`,u.handleEditSubmit),m.get(`${d}/:repoName/:id/history`,u.handleHistory),m.post(`${d}/:repoName/:id/delete`,u.handleDelete);let N=async(w,S)=>{await m.handle(w,S);};return o&&(N.httpsOptions=o),N}
|
|
1045
|
+
`;function Oe(){return jsxRuntime.jsx("script",{dangerouslySetInnerHTML:{__html:ft}})}Ue();function re(e){return "<!DOCTYPE html>"+server.renderToString(e)}var rn=["corporate","silk","dark"],an=()=>jsxRuntime.jsxs("div",{class:"dropdown dropdown-end","data-frs-theme-switcher":true,children:[jsxRuntime.jsxs("button",{type:"button",tabIndex:0,class:"btn btn-sm btn-ghost text-neutral-content gap-1.5","aria-label":"Switch theme",children:[jsxRuntime.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:[jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"4"}),jsxRuntime.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"})]}),jsxRuntime.jsx("span",{class:"text-xs hidden sm:inline","data-frs-theme-current":true,children:"Theme"})]}),jsxRuntime.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:rn.map(e=>jsxRuntime.jsx("li",{children:jsxRuntime.jsxs("button",{type:"button","data-frs-theme":e,class:"capitalize justify-between",children:[jsxRuntime.jsx("span",{children:e}),jsxRuntime.jsx("span",{class:"hidden text-primary","data-frs-theme-check":e,children:"\u2713"})]})},e))})]}),ae=({opts:e,children:t})=>{let{title:n,breadcrumb:r,flash:a,basePath:s="/"}=e;return jsxRuntime.jsxs("html",{lang:"en","data-theme":"corporate",children:[jsxRuntime.jsxs("head",{children:[jsxRuntime.jsx("meta",{charset:"UTF-8"}),jsxRuntime.jsx("meta",{name:"viewport",content:"width=device-width, initial-scale=1"}),jsxRuntime.jsxs("title",{children:[n," \u2014 FRS Admin"]}),jsxRuntime.jsx("script",{dangerouslySetInnerHTML:{__html:"(function(){try{var t=localStorage.getItem('frs-admin-theme');if(t){document.documentElement.setAttribute('data-theme',t);}}catch(_){}})();"}}),jsxRuntime.jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/themes.css",rel:"stylesheet",type:"text/css"}),jsxRuntime.jsx("link",{href:"https://cdn.jsdelivr.net/npm/daisyui@5/daisyui.css",rel:"stylesheet",type:"text/css"}),jsxRuntime.jsx("script",{src:"https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"})]}),jsxRuntime.jsxs("body",{class:"bg-base-200/50 min-h-screen flex flex-col",children:[jsxRuntime.jsxs("div",{class:"navbar bg-neutral text-neutral-content shadow-sm sticky top-0 z-50 px-6",children:[jsxRuntime.jsx("div",{class:"flex-1",children:jsxRuntime.jsx("a",{href:s,class:"font-bold text-lg tracking-tight hover:opacity-80 transition-opacity",children:"FRS Admin"})}),jsxRuntime.jsx("div",{class:"flex-none",children:jsxRuntime.jsx(an,{})})]}),jsxRuntime.jsxs("main",{class:"px-6 py-8 w-full flex-1",children:[r&&r.length>0&&jsxRuntime.jsx("div",{class:"text-sm breadcrumbs mb-4",children:jsxRuntime.jsx("ul",{children:r.map((o,d)=>o.href?jsxRuntime.jsx("li",{children:jsxRuntime.jsx("a",{href:o.href,children:o.label})},d):jsxRuntime.jsx("li",{class:"text-base-content/60",children:o.label},d))})}),jsxRuntime.jsx("h1",{class:"text-2xl font-bold mb-6",children:n}),a&&jsxRuntime.jsxs("div",{role:"alert",class:`alert ${a.type==="success"?"alert-success":a.type==="warning"?"alert-warning":"alert-error"} mb-6`,children:[jsxRuntime.jsx("span",{class:"flex-1",children:a.message}),a.action&&jsxRuntime.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]}),jsxRuntime.jsx(Le,{basePath:s}),jsxRuntime.jsx(Oe,{})]})]})};function qe(e,t){return re(jsxRuntime.jsx(ae,{opts:t,children:jsxRuntime.jsx("div",{dangerouslySetInnerHTML:{__html:e}})}))}function He(e,t){return re(jsxRuntime.jsx(ae,{opts:{title:"Repositories",basePath:t},children:e.length===0?jsxRuntime.jsxs("div",{class:"text-center py-20 text-base-content/50",children:[jsxRuntime.jsx("p",{class:"text-lg font-medium mb-1",children:"No repositories configured"}),jsxRuntime.jsx("p",{class:"text-sm",children:"Add a repository to your FRS config to get started."})]}):jsxRuntime.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=>jsxRuntime.jsx("a",{href:`${t}/${n.name}`,class:"card bg-base-100 border border-base-300 hover:shadow-md no-underline transition-shadow",children:jsxRuntime.jsxs("div",{class:"card-body p-5",children:[jsxRuntime.jsx("h2",{class:"card-title text-sm font-semibold",children:n.name}),jsxRuntime.jsx("p",{class:"text-xs text-base-content/50 font-mono",children:n.path})]})},n.name))})}))}var gt=[{value:"==",label:"="},{value:"!=",label:"\u2260"},{value:"in",label:"in"},{value:"not-in",label:"not in"}],sn=[{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"}],on=[{value:"array-contains",label:"contains"},{value:"array-contains-any",label:"contains any"}];function ln(e){switch(e){case "ZodNumber":case "ZodBigInt":case "ZodDate":return sn;case "ZodBoolean":return gt;case "ZodArray":return on;default:return gt}}var se="__null__";function dn(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="${se}"]');if(!o){o=document.createElement('option');o.value='${se}';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='${se}';i.readOnly=true;}i.style.opacity='0.55';}else{i.style.opacity='';if(i.tagName==='SELECT'){var o2=i.querySelector('option[value="${se}"][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!=='${se}')?i.dataset._prev:'';}}})(this)`}function cn(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 Se({inputId:e,active:t}){return jsxRuntime.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:[jsxRuntime.jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",checked:t,onchange:dn(e)}),jsxRuntime.jsx("span",{children:"\u2205"})]})}function un({col:e,active:t}){let n=t?.value??"",r=n===se,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(u=>u.trim()).filter(Boolean)),l=`eg_${e.name.replace(/\./g,"__")}`;return jsxRuntime.jsxs("div",{class:"flex flex-wrap items-center gap-1 w-full",children:[jsxRuntime.jsx("input",{type:"hidden",id:a,name:`fv_${e.name}`,value:n}),e.enumValues.map(u=>jsxRuntime.jsxs("label",{class:"flex items-center gap-1 text-xs border border-base-300 rounded px-2 cursor-pointer hover:bg-base-200",children:[jsxRuntime.jsx("input",{type:"checkbox",class:"checkbox checkbox-xs",value:u,checked:d.has(u),"data-enum-group":l,onchange:cn(a,l)}),jsxRuntime.jsx("span",{children:u})]},u))]})}return jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsxRuntime.jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),e.enumValues.map(d=>jsxRuntime.jsx("option",{value:d,selected:n===d,children:d},d)),e.nullable&&jsxRuntime.jsx("option",{value:se,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsxRuntime.jsx(Se,{inputId:a,active:r})]})}if(e.zodType==="ZodBoolean")return jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.jsxs("select",{id:a,name:`fv_${e.name}`,class:"select select-sm select-bordered w-full",style:r?"opacity:0.55":void 0,children:[jsxRuntime.jsx("option",{value:"",selected:n===""&&!r,children:"\u2014"}),jsxRuntime.jsx("option",{value:"true",selected:n==="true",children:"true"}),jsxRuntime.jsx("option",{value:"false",selected:n==="false",children:"false"}),e.nullable&&jsxRuntime.jsx("option",{value:se,"data-_auto":"1",selected:r,children:"\u2205 null"})]}),e.nullable&&jsxRuntime.jsx(Se,{inputId:a,active:r})]});if(e.zodType==="ZodArray"){let d=t?.op==="array-contains-any";return jsxRuntime.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"?jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.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||void 0,style:r?"opacity:0.55":void 0,"data-_type":r?"number":void 0}),e.nullable&&jsxRuntime.jsx(Se,{inputId:a,active:r})]}):e.zodType==="ZodDate"?jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.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||void 0,style:r?"opacity:0.55":void 0,"data-_type":r?"datetime-local":void 0}),e.nullable&&jsxRuntime.jsx(Se,{inputId:a,active:r})]}):jsxRuntime.jsxs("div",{class:"flex items-center gap-1 w-full",children:[jsxRuntime.jsx("input",{id:a,type:"text",name:`fv_${e.name}`,value:n,placeholder:"value",class:"input input-sm input-bordered w-full",readOnly:r||void 0,style:r?"opacity:0.55":void 0}),e.nullable&&jsxRuntime.jsx(Se,{inputId:a,active:r})]})}function Ve({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 jsxRuntime.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:[jsxRuntime.jsxs("summary",{class:"collapse-title text-sm font-medium py-2 min-h-0",children:["Filters",s&&jsxRuntime.jsxs("span",{class:"badge badge-primary badge-sm ml-2",children:[n.length," active"]})]}),jsxRuntime.jsx("div",{class:"collapse-content pb-4 pt-2",children:jsxRuntime.jsxs("form",{method:"get",action:e,children:[jsxRuntime.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 u=ln(l.zodType),m=a[l.name],N=m?.op??u[0].value;return jsxRuntime.jsxs("div",{class:"flex flex-col gap-1.5",children:[jsxRuntime.jsx("label",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:l.name}),jsxRuntime.jsxs("div",{class:"flex gap-1.5",children:[u.length>1?jsxRuntime.jsx("select",{name:`fo_${l.name}`,class:"select select-sm select-bordered w-20 shrink-0",children:u.map(w=>jsxRuntime.jsx("option",{value:w.value,selected:w.value===N,children:w.label},w.value))}):jsxRuntime.jsx("input",{type:"hidden",name:`fo_${l.name}`,value:u[0].value}),jsxRuntime.jsx(un,{col:l,active:m})]})]},l.name)})}),jsxRuntime.jsxs("div",{class:"flex flex-wrap gap-2 mt-4 pt-3 border-t border-base-200 items-center",children:[jsxRuntime.jsx("button",{type:"submit",class:"btn btn-sm btn-primary",children:"Apply"}),s&&jsxRuntime.jsx("a",{href:e,class:"btn btn-sm btn-ghost",children:"Clear"}),o&&jsxRuntime.jsxs("span",{class:"text-xs text-warning ml-auto flex items-center gap-1",children:[jsxRuntime.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:jsxRuntime.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 Je(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 re(jsxRuntime.jsx(ae,{opts:{title:o,breadcrumb:d,basePath:a,flash:s},children:jsxRuntime.jsx("div",{class:"card bg-base-100 border border-base-300",children:jsxRuntime.jsx("div",{class:"card-body p-6",children:jsxRuntime.jsx("div",{dangerouslySetInnerHTML:{__html:t}})})})}))}_e();Me();function Ke(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 ht(e,t,n,r,a){let s=Ke(e,r,a);return s.set("cursor",t),s.set("dir",n),`?${s.toString()}`}function pn(e,t,n,r){let a=Ke(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 fn(e,t,n){return `?${Ke(t,n,e).toString()}`}function Ge(e,t,n,r,a,s,o=[],d=[],l=false,u=[],m,N,w,S,E,j,B,b=false){let f=`${r}/${e}`,x=`${f}/create`,i={};if(B)for(let v of n)i[v]=ye(ge(B,v));let c=(j??[]).filter(v=>{let R=i[v]??ye(ge(B,v));return R==="string"||R==="number"||R==="bigint"||R==="boolean"||R==="enum"||R==="literal"}),p=c.length>0,h=l,T=h||p,_=c.map(v=>{let R=ge(B,v),k=ye(R),A=o.find(D=>D.name===v);return {name:v,type:k,enumValues:A?.enumValues??null,nullable:A?.nullable??false}});return re(jsxRuntime.jsxs(ae,{opts:{title:e,breadcrumb:[{label:"Repositories",href:r},{label:e}],basePath:r,flash:s},children:[o.length>0&&jsxRuntime.jsx(Ve,{action:f,columnMeta:o,activeFilters:d,isGroup:S}),w&&jsxRuntime.jsxs("div",{role:"alert",class:`alert ${w.type==="index"?"alert-warning":"alert-error"} mb-6 shadow-sm`,children:[jsxRuntime.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:w.type==="index"?jsxRuntime.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"}):jsxRuntime.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"})}),jsxRuntime.jsxs("div",{class:"flex-1",children:[jsxRuntime.jsx("h3",{class:"font-bold",children:w.type==="index"?"Composite index required":"Query failed"}),jsxRuntime.jsx("div",{class:"text-sm",children:w.message})]}),w.indexUrl&&jsxRuntime.jsx("a",{href:w.indexUrl,target:"_blank",rel:"noopener noreferrer",class:"btn btn-sm btn-outline",children:"Create Index \u2192"})]}),jsxRuntime.jsxs("div",{class:"flex flex-wrap justify-between items-center mb-4 gap-3","data-frs-toolbar":true,children:[jsxRuntime.jsxs("div",{class:"flex items-center gap-3",children:[jsxRuntime.jsxs("span",{class:"text-sm text-base-content/60",children:[t.length,typeof E=="number"&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[" ","of ",jsxRuntime.jsx("span",{class:"font-semibold text-base-content/80",children:E})]})," ","document",(typeof E=="number"?E:t.length)!==1&&"s"]}),jsxRuntime.jsxs("div",{class:"flex items-center gap-1.5 text-sm text-base-content/60",children:[jsxRuntime.jsx("span",{children:"Rows"}),jsxRuntime.jsx("div",{class:"join",children:[10,25,50,100].map(v=>jsxRuntime.jsx("a",{href:fn(v,d,m),class:`join-item btn btn-xs ${N===v?"btn-active btn-primary":"btn-outline"}`,children:v},v))})]})]}),jsxRuntime.jsx("a",{href:x,class:"btn btn-primary btn-sm",children:"+ New"})]}),T&&jsxRuntime.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 E=="number"?String(E):"","data-frs-page-size":String(N??t.length),"data-frs-allow-delete":h?"1":"0","data-frs-allow-update":p?"1":"0","data-frs-fields":JSON.stringify(_),"data-frs-filters":JSON.stringify(d),children:[jsxRuntime.jsxs("div",{class:"flex-1 text-sm",children:[jsxRuntime.jsx("span",{"data-frs-bulk-summary":true,children:"0 selected"}),typeof E=="number"&&E>t.length&&jsxRuntime.jsxs("button",{type:"button",class:"ml-3 link link-primary text-sm hidden","data-frs-bulk-select-all":true,children:["Select all ",E," matching documents"]}),jsxRuntime.jsxs("span",{class:"hidden ml-3 italic","data-frs-bulk-all-active":true,children:["All ",E??"?"," matching documents are selected."," ",jsxRuntime.jsx("button",{type:"button",class:"link","data-frs-bulk-clear":true,children:"Clear selection"})]})]}),jsxRuntime.jsxs("div",{class:"flex gap-2",children:[p&&jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-outline","data-frs-bulk-action":"update",children:"Update field\u2026"}),h&&jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-error btn-outline","data-frs-bulk-action":"delete",children:"Delete"})]})]}),jsxRuntime.jsx("div",{class:"overflow-x-auto rounded-box border border-base-300 bg-base-100","data-frs-table-wrap":true,children:jsxRuntime.jsxs("table",{class:"table table-sm w-full","data-frs-table":true,"data-frs-repo":e,"data-frs-colcount":n.length,children:[jsxRuntime.jsx("thead",{children:jsxRuntime.jsxs("tr",{class:"bg-base-200/50",children:[T&&jsxRuntime.jsx("th",{class:"w-8",children:jsxRuntime.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,R)=>{let k=m?.field===v,A=k?m.dir==="asc"?" \u25B2":" \u25BC":"";return jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:jsxRuntime.jsxs("a",{href:pn(v,m,d,N),class:`hover:text-base-content inline-flex items-center gap-0.5${k?" text-primary font-bold":""}`,children:[v,A]})},R)}),u.map((v,R)=>jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide",children:v.column},`rel-${R}`)),jsxRuntime.jsx("th",{class:"text-xs font-semibold text-base-content/60 uppercase tracking-wide text-right",children:"Actions"})]})}),jsxRuntime.jsx("tbody",{children:t.length===0?jsxRuntime.jsx("tr",{children:jsxRuntime.jsx("td",{colspan:n.length+u.length+1+(T?1:0),class:"text-center py-16 text-base-content/40",children:"No documents found"})}):t.map((v,R)=>{let k=String(v.docId??v.id??""),A=`${r}/${e}/${encodeURIComponent(k)}/edit`,D=`${r}/${e}/${encodeURIComponent(k)}/delete`;return jsxRuntime.jsxs("tr",{class:"hover","data-frs-row-id":k,children:[T&&jsxRuntime.jsx("td",{class:"align-middle py-2",children:jsxRuntime.jsx("input",{type:"checkbox",class:"checkbox checkbox-xs checkbox-primary","data-frs-select-row":true,value:k,"aria-label":`Select ${k}`})}),n.map((P,G)=>{let C=v[P],y=i[P],L=y?ke(y,C):null;return jsxRuntime.jsx("td",{class:"align-top py-2",children:jsxRuntime.jsx(be,{val:C,mismatch:L})},G)}),u.map((P,G)=>{let C=v[P.key];if(C==null||C==="")return jsxRuntime.jsx("td",{class:"py-2"},`rel-${G}`);let y=P.type==="one"?`${r}/${P.targetRepo}/${encodeURIComponent(String(C))}/edit`:`${r}/${P.targetRepo}?fv_${P.targetKey}=${encodeURIComponent(String(C))}`;return jsxRuntime.jsx("td",{class:"align-middle py-2",children:jsxRuntime.jsx("a",{href:y,class:"btn btn-xs btn-ghost btn-outline","data-frs-relation":true,"data-frs-rel-type":P.type,"data-frs-rel-repo":P.targetRepo,"data-frs-rel-fk":P.targetKey,"data-frs-rel-val":String(C),"data-frs-rel-label":P.column,children:P.column})},`rel-${G}`)}),jsxRuntime.jsx("td",{class:"align-middle text-right whitespace-nowrap py-2",children:jsxRuntime.jsxs("div",{class:"flex gap-1 justify-end",children:[jsxRuntime.jsx("a",{href:A,class:"btn btn-xs btn-outline",children:"Edit"}),b&&jsxRuntime.jsx("a",{href:`${r}/${e}/${encodeURIComponent(k)}/history`,class:"btn btn-xs btn-outline",title:"View change history",children:"History"}),l&&jsxRuntime.jsx("form",{method:"post",action:D,onsubmit:"return confirm('Delete this document?')",children:jsxRuntime.jsx("button",{type:"submit",class:"btn btn-xs btn-error btn-outline",children:"Delete"})})]})})]},R)})})]})}),(a.hasPrev||a.hasNext)&&jsxRuntime.jsxs("div",{class:"flex flex-col items-center mt-6 gap-2",children:[jsxRuntime.jsxs("div",{class:"flex justify-center items-center gap-2",children:[a.hasPrev?jsxRuntime.jsx("a",{href:ht(d,a.prevCursor,"prev",m,N),class:"btn btn-sm btn-outline",children:"\u2190 Previous"}):jsxRuntime.jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"\u2190 Previous"}),a.hasNext?jsxRuntime.jsx("a",{href:ht(d,a.nextCursor,"next",m,N),class:"btn btn-sm btn-outline",children:"Next \u2192"}):jsxRuntime.jsx("button",{class:"btn btn-sm btn-outline",disabled:true,children:"Next \u2192"})]}),typeof E=="number"&&jsxRuntime.jsxs("div",{class:"text-xs text-base-content/50",children:[E," total document",E!==1?"s":"",d.length>0?" matching filters":""]})]}),T&&p&&jsxRuntime.jsxs("dialog",{id:"frs-bulk-update-modal",class:"modal",children:[jsxRuntime.jsxs("div",{class:"modal-box",children:[jsxRuntime.jsx("h3",{class:"font-bold text-lg mb-3",children:"Bulk update field"}),jsxRuntime.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."}),jsxRuntime.jsxs("form",{method:"dialog","data-frs-bulk-update-form":true,children:[jsxRuntime.jsxs("label",{class:"form-control w-full mb-3",children:[jsxRuntime.jsx("div",{class:"label",children:jsxRuntime.jsx("span",{class:"label-text text-xs uppercase tracking-wide",children:"Field"})}),jsxRuntime.jsxs("select",{class:"select select-bordered select-sm w-full",name:"field",required:true,"data-frs-bulk-field-select":true,children:[jsxRuntime.jsx("option",{value:"",children:"\u2014 Select a field \u2014"}),c.map(v=>jsxRuntime.jsx("option",{value:v,children:v},v))]})]}),jsxRuntime.jsx("div",{class:"mb-4","data-frs-bulk-value-container":true}),jsxRuntime.jsxs("div",{class:"modal-action",children:[jsxRuntime.jsx("button",{type:"button",class:"btn btn-sm btn-ghost","data-frs-bulk-update-cancel":true,children:"Cancel"}),jsxRuntime.jsx("button",{type:"submit",class:"btn btn-sm btn-primary","data-frs-bulk-update-submit":true,children:"Apply"})]})]})]}),jsxRuntime.jsx("form",{method:"dialog",class:"modal-backdrop",children:jsxRuntime.jsx("button",{children:"close"})})]})]}))}function Ne(e,t){return qe(e,t)}function vt(e,t){return He(e,t)}function xt(e,t,n,r,a,s,o,d,l,u,m,N,w,S,E,j,B,b){return Ge(e,t,n,r,a,s,o,d,l,u,m,N,w,S,E,j,B,b)}function ce(e,t,n,r,a,s){return Je(e,t,n,r,a,s)}var wt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";function yn(){let e="";for(let t=0;t<20;t++)e+=wt.charAt(Math.floor(Math.random()*wt.length));return e}function Ie(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 he(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 We(e,t,n){let r=e.documentKey??"docId",a=je(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 Z(e,t,n=200){e.status(n).set("Content-Type","text/html; charset=utf-8").send(t);}function Qe(e,t){e.status(302).set("Location",t).send("");}function Xe(e,t){let n=t.shape,r={};for(let[a,s]of Object.entries(n)){let o=et(s);if(o==="ZodObject"){if(e[a+"__isnull"]==="1"){r[a]=null;continue}let u={},m=false;for(let[S,E]of Object.entries(e))S.startsWith(`${a}.`)&&(u[S.slice(a.length+1)]=E,m=true);if(m){let S=s;for(;;){let E=M(S);if(E==="ZodOptional"||E==="ZodNullable"||E==="ZodDefault")S=J(S);else break}r[a]=Xe(u,S);continue}let N=e[a],w=Array.isArray(N)?N[N.length-1]:N;if(w)try{r[a]=JSON.parse(w);}catch{r[a]=w;}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 kt(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 et(e){let t=e;for(;;){let n=M(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=J(t);else return n}}function gn(e){let t=e;for(;;){let n=M(t);if(n==="ZodOptional"||n==="ZodNullable"||n==="ZodDefault")t=J(t);else return t}}function Rt(e){let t=e;for(;;){let n=M(t);if(n==="ZodOptional"||n==="ZodNullable")return true;if(n==="ZodDefault"){t=J(t);continue}return false}}function $t(e){let t=gn(e),n=M(t);if(n==="ZodEnum"){let r=xe(t);return r.length>0?r:void 0}if(n==="ZodNativeEnum"){let r=we(t),a=Object.values(r).filter(s=>typeof s=="string");return a.length>0?a:void 0}if(n==="ZodLiteral"){let r=Ce(t);return typeof r=="string"?[r]:void 0}}function At(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 u=M(d);if(u==="ZodOptional"||u==="ZodNullable"||u==="ZodDefault")d=J(d);else break}let l=M(d);if(l==="ZodObject"&&typeof o=="object"&&o!==null&&!Array.isArray(o)){let u=At(o,d,s);Object.assign(r,u);}else if(l==="ZodDate"){let u=kt(o);u!==null&&(r[s]=u);}else if(typeof o=="object"&&o!==null&&!Array.isArray(o)&&("_seconds"in o||typeof o.toDate=="function")){let u=kt(o);r[s]=u??JSON.stringify(o,null,2);}else typeof o=="object"?r[s]=JSON.stringify(o,null,2):r[s]=String(o);}return r}function Ye(e,t){return e.map(n=>({...n,defaultValue:t[n.name]??n.defaultValue,nested:n.nested?Ye(n.nested,t):void 0}))}function hn(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}`]??"==",u=n.has(l)?l:"==";r.push({field:o,op:u,value:d});}return r}function St(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 Ct(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=et(o);if(d==="ZodObject"){let l=o;for(;;){let m=M(l);if(m==="ZodOptional"||m==="ZodNullable"||m==="ZodDefault")l=J(l);else break}let u=Y(l);r.push(...Ct(Object.keys(u),l,s));}else r.push({name:s,zodType:d,nullable:Rt(o),enumValues:$t(o)});}return r}function vn(e,t){let n=t.split("."),r=e;for(let a of n){for(;;){let o=M(r);if(o==="ZodOptional"||o==="ZodNullable"||o==="ZodDefault")r=J(r);else break}let s=Y(r);if(!(a in s))return null;r=s[a];}return r}function ue(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=M(d);if(l==="ZodOptional"||l==="ZodNullable"||l==="ZodDefault")d=J(d);else break}if(M(d)!=="ZodObject"){a[s]=e.shape[s];continue}a[s]=ue(d,o);}return zod.z.object(a)}function te(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 Et(e,t){let n=(b,f)=>{let x=te(b,t),i=Object.values(e).map(c=>({name:c.name,path:c.path}));Z(f,vt(i,x));},r=async(b,f)=>{let x=b.params.repoName;if(!x){Z(f,"Bad request",400);return}let i=e[x];if(!i){Z(f,"Repository not found",404);return}let c=i.pageSize??25,p=b.query??{},h=p.cursor,T=p.dir==="prev"?"prev":"next",_=p.ob??"",v=p.od==="desc"?"desc":"asc",R=_?{field:_,dir:v}:void 0,k=parseInt(p.ps??""),A=Number.isFinite(k)&&k>0?Math.min(k,200):c,D=i.listColumns??Object.keys(i.schema.shape),P=i.documentKey??"docId",G=[P,...D.filter(H=>H!==P)],C=i.filterableFields?(()=>{let H=[];for(let X of i.filterableFields)(X.includes(".")||D.includes(X))&&H.push(X);return H})():D,y=(()=>{let H=[];for(let X of C)if(X.includes(".")){let fe=vn(i.schema,X);H.push({name:X,zodType:fe?et(fe):"ZodString",nullable:fe?Rt(fe):false,enumValues:fe?$t(fe):void 0});}else H.push(...Ct([X],i.schema));return H})(),L=new Set(y.map(H=>H.name)),oe=hn(p,L),ne=St(oe),ve;if(h)try{let H=i.repo.ref;typeof H.doc=="function"&&(ve=await H.doc(h).get());}catch{}let[V,$e]=await Promise.all([i.repo.query.paginate({pageSize:A,cursor:ve,direction:T,...ne.length>0?{where:ne}:{},...R?{orderBy:[{field:R.field,direction:R.dir}]}:{}}).catch(H=>({queryError:je(H,{ref:i.repo.ref,path:i.path,isGroup:!!i.isGroup,filters:oe,sort:R})})),i.repo.aggregate.count(ne.length>0?{where:ne}:{}).catch(()=>{})]),pe="queryError"in V,Tt=pe?[]:V.data,_t=pe?"":V.nextCursor?.id??"",Ot=pe?"":V.prevCursor?.id??"",Zt=pe?V.queryError:void 0,Nt=te(b,t);Z(f,xt(i.name,Tt,G,Nt,{hasPrev:pe?false:V.hasPrevPage,hasNext:pe?false:V.hasNextPage,prevCursor:Ot,nextCursor:_t},void 0,y,oe,i.allowDelete??false,i.relationalMeta,R,A,Zt,i.isGroup,$e,i.mutableFields,i.schema,i.historyEnabled));},a=(b,f)=>{let x=b.params.repoName;if(!x){Z(f,"Bad request",400);return}let i=e[x];if(!i){Z(f,"Repository not found",404);return}let c=te(b,t),p=ue(i.schema,i.createFields),h=ee(p),T=`${c}/${i.name}/create`,_=ie(h,T,"POST","Create document");Z(f,ce(i.name,_,"create",null,c));},s=async(b,f)=>{let x=b.params.repoName;if(!x){Z(f,"Bad request",400);return}let i=e[x];if(!i){Z(f,"Repository not found",404);return}let c=te(b,t),p=b.body??{},h=Xe(p,i.schema),T=ue(i.schema,i.createFields),_=T.safeParse(h);if(!_.success){let v=ee(T),R=`${c}/${i.name}/create`,k=ie(v,R,"POST","Create document"),A=_.error.issues.map(D=>`${D.path.join(".")}: ${D.message}`).join(", ");Z(f,ce(i.name,k,"create",null,c,{type:"error",message:`Validation error: ${A}`}),422);return}try{if(i.isGroup&&i.parentKeys&&i.parentKeys.length>0){let v={..._.data};i.createdKey&&(v[i.createdKey]=new Date);let R=i.parentKeys.filter(P=>!v[P]);if(R.length>0)throw new Error(`Missing parent key(s) for subcollection create: ${R.join(", ")}`);let k=i.parentKeys.map(P=>v[P]),A=i.documentKey??"docId",D=v[A]||yn();await i.repo.set(...k,D,v);}else await i.repo.create(_.data);Qe(f,`${c}/${i.name}?flash=created`);}catch(v){let R=ue(i.schema,i.createFields),k=ee(R),A=`${c}/${i.name}/create`,D=ie(k,A,"POST","Create document");Z(f,ce(i.name,D,"create",null,c,{type:"error",message:`Save error: ${v.message}`}),500);}},o=async(b,f)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(f,"Bad request",400);return}let c=e[x];if(!c){Z(f,"Repository not found",404);return}let p=te(b,t),h=null;try{h=await he(c,i);}catch(A){let D=We(c,i,A),P=le(A)?424:500;Z(f,Ne("",{title:`Edit ${c.name} / ${i}`,basePath:p,breadcrumb:[{label:"Repositories",href:p},{label:c.name,href:`${p}/${c.name}`},{label:`Edit ${i}`}],flash:D}),P);return}if(!h){Z(f,"Document not found",404);return}let T=At(h,c.schema),_=ue(c.schema,c.mutableFields),v=Ye(ee(_),T),R=`${p}/${c.name}/${encodeURIComponent(i)}/edit`,k=ie(v,R,"POST","Save changes");Z(f,ce(c.name,k,"edit",i,p));},d=async(b,f)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(f,"Bad request",400);return}let c=e[x];if(!c){Z(f,"Repository not found",404);return}let p=te(b,t),h=b.body??{},T=Xe(h,c.schema),_=ue(c.schema,c.mutableFields),R=_.partial().safeParse(T);if(!R.success){let k=Object.fromEntries(Object.entries(h).map(([C,y])=>[C,Array.isArray(y)?y.join(","):y??""])),A=Ye(ee(_),k),D=`${p}/${c.name}/${encodeURIComponent(i)}/edit`,P=ie(A,D,"POST","Save changes"),G=R.error.issues.map(C=>`${C.path.join(".")}: ${C.message}`).join(", ");Z(f,ce(c.name,P,"edit",i,p,{type:"error",message:`Validation error: ${G}`}),422);return}try{let k=await he(c,i),A=(k&&Ie(k,c.pathKey))??[i];await c.repo.update(...A,R.data),Qe(f,`${p}/${c.name}?flash=updated`);}catch(k){let A=ue(c.schema,c.mutableFields),D=ee(A),P=`${p}/${c.name}/${encodeURIComponent(i)}/edit`,G=ie(D,P,"POST","Save changes"),C=le(k)?We(c,i,k):{type:"error",message:`Save error: ${k.message}`},y=le(k)?424:500;Z(f,ce(c.name,G,"edit",i,p,C),y);}},l=async(b,f)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(f,"Bad request",400);return}let c=e[x];if(!c){Z(f,"Repository not found",404);return}if(!c.allowDelete){Z(f,"Delete is not allowed for this repository",403);return}let p=te(b,t);try{let h=await he(c,i),T=(h&&Ie(h,c.pathKey))??[i];await c.repo.delete(...T),Qe(f,`${p}/${c.name}?flash=deleted`);}catch(h){let T=le(h)?We(c,i,h):{type:"error",message:`Delete error: ${h.message}`},_=le(h)?424:500;Z(f,Ne("",{title:`Delete ${c.name} / ${i}`,basePath:p,breadcrumb:[{label:"Repositories",href:p},{label:c.name,href:`${p}/${c.name}`},{label:`Delete ${i}`}],flash:T}),_);}},u=async(b,f)=>{let x=b.params.repoName;if(!x){Z(f,"Bad request",400);return}let i=e[x];if(!i){Z(f,"Repository not found",404);return}let c=te(b,t),p=b.query,h=p?.type==="many"?"many":"one",T=Math.max(1,Math.min(100,Number(p?.ps??25)||25)),_=i.listColumns??Object.keys(Y(i.schema)),{PanelOne:v,PanelMany:R}=await Promise.resolve().then(()=>(Ue(),bt)),{renderToString:k}=await import('hono/jsx/dom/server');if(h==="one"){let y=String(p?.id??"");if(!y){Z(f,"<div class='p-6 text-error'>Missing id parameter.</div>",400);return}try{let L=await he(i,y),oe=k(v({doc:L,repoName:i.name,basePath:c,schema:i.schema,columns:_}));Z(f,oe);}catch(L){Z(f,`<div class='p-6 text-error text-sm'>Error: ${L.message}</div>`,500);}return}let A=String(p?.fk??""),D=String(p?.fv??"");if(!A||!D){Z(f,"<div class='p-6 text-error'>Missing fk/fv parameters.</div>",400);return}let P=p?.cursor??"",G=p?.dir==="prev"?"prev":"next",C;if(P)try{let y=i.repo.ref;typeof y.doc=="function"&&(C=await y.doc(P).get());}catch{}try{let y=await i.repo.query.paginate({pageSize:T,cursor:C,direction:G,where:[[A,"==",xn(D)]]}),L=k(R({docs:y.data,repoName:i.name,basePath:c,fk:A,fv:D,columns:_,schema:i.schema,pagination:{hasPrev:y.hasPrevPage,hasNext:y.hasNextPage,prevCursor:y.prevCursor?.id??"",nextCursor:y.nextCursor?.id??"",pageSize:T}}));Z(f,L);}catch(y){Z(f,`<div class='p-6 text-error text-sm'>Error: ${y.message}</div>`,500);}},m=async(b,f)=>{let x=[];for(let i of f){let c;if(b.isGroup||b.parentKeys?.length){let p=await he(b,i);c=p?Ie(p,b.pathKey):void 0;}c||(c=[i]);try{let p=b.repo.documentRef(...c);p&&x.push(p);}catch{}}return x},N=async(b,f)=>{let x=St(f),i=b.documentKey??"docId",c=[],p;for(;;){let h=await b.repo.query.paginate({pageSize:500,cursor:p,direction:"next",...x.length>0?{where:x}:{}});for(let T of h.data){let _=String(T[i]??T.id??"");_&&c.push(_);}if(!h.hasNextPage||!h.nextCursor)break;p=h.nextCursor;}return c},w=async(b,f)=>{let x=b.params.repoName;if(!x){W(f,{error:"Bad request"},400);return}let i=e[x];if(!i){W(f,{error:"Repository not found"},404);return}if(!i.allowDelete){W(f,{error:"Delete is not allowed for this repository"},403);return}let c=b.body??{};try{let p=await E(i,c);if(p.length===0){W(f,{deleted:0});return}let h=await m(i,p);for(let T=0;T<h.length;T+=500)await i.repo.bulk.delete(h.slice(T,T+500));W(f,{deleted:h.length});}catch(p){W(f,{error:p.message},500);}},S=async(b,f)=>{let x=b.params.repoName;if(!x){W(f,{error:"Bad request"},400);return}let i=e[x];if(!i){W(f,{error:"Repository not found"},404);return}let c=b.body??{},p=String(c.field??"");if(!p){W(f,{error:"Missing 'field'"},400);return}if(!i.mutableFields||!i.mutableFields.includes(p)){W(f,{error:`Field '${p}' is not bulk-updatable`},403);return}let h=i.schema.shape?.[p],T=c.value;if(h){let _=h.safeParse(c.value);if(!_.success){W(f,{error:`Invalid value for '${p}': ${_.error.message}`},400);return}T=_.data;}try{let _=await E(i,c);if(_.length===0){W(f,{updated:0});return}let R=(await m(i,_)).map(k=>({docRef:k,data:{[p]:T}}));for(let k=0;k<R.length;k+=500)await i.repo.bulk.update(R.slice(k,k+500));W(f,{updated:R.length});}catch(_){W(f,{error:_.message},500);}};async function E(b,f){if(f.selectAll){let x=j(f.filters,b);return await N(b,x)}return Array.isArray(f.ids)?f.ids.filter(x=>typeof x=="string"&&!!x):[]}function j(b,f){if(!Array.isArray(b))return [];let x=new Set((f.filterableFields??Object.keys(Y(f.schema))).map(p=>String(p))),i=new Set(["==","!=","<","<=",">",">=","in","not-in","array-contains","array-contains-any"]),c=[];for(let p of b)p&&typeof p=="object"&&typeof p.field=="string"&&x.has(p.field)&&typeof p.value=="string"&&i.has(String(p.op))&&c.push({field:p.field,op:p.op,value:p.value});return c}return {handleDashboard:n,handleList:r,handleCreateForm:a,handleCreateSubmit:s,handleEditForm:o,handleEditSubmit:d,handleDelete:l,handlePanel:u,handleBulkDelete:w,handleBulkUpdate:S,handleHistory:async(b,f)=>{let x=b.params.repoName,i=b.params.id;if(!x||!i){Z(f,"Bad request",400);return}let c=e[x];if(!c){Z(f,"Repository not found",404);return}if(!c.historyEnabled||!c.repo.history){Z(f,"History not enabled for this repository",404);return}let p=te(b,t),h=c.historySubcollection??"history",T=[i];try{let y=await he(c,i),L=y?Ie(y,c.pathKey):void 0;L&&L.length>0&&(T=L);}catch{}let _=parseInt(String(b.query?.limit??"")),v=Number.isFinite(_)&&_>0?Math.min(_,500):100,R=[],k;try{R=await c.repo.history.list(...T,{limit:v});}catch(y){k=y.message;}let A=y=>String(y??"").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,"""),D=y=>{if(y===void 0)return '<span class="opacity-40">undefined</span>';if(y===null)return '<span class="opacity-40">null</span>';if(typeof y=="object")try{return `<code class="text-xs">${A(JSON.stringify(y))}</code>`}catch{return A(String(y))}return A(String(y))},P=y=>y?typeof y.toDate=="function"?y.toDate().toISOString():y instanceof Date?y.toISOString():A(String(y)):"",G=y=>`<span class="badge badge-sm ${y==="create"?"badge-success":y==="delete"?"badge-error":"badge-info"}">${A(y)}</span>`,C="";if(C+='<div class="flex items-center justify-between mb-4">',C+=`<a href="${p}/${c.name}/${encodeURIComponent(i)}/edit" class="btn btn-sm btn-outline">\u2190 Back to edit</a>`,C+=`<a href="${p}/${c.name}" class="btn btn-sm btn-outline">\u2190 Back to list</a>`,C+="</div>",C+=`<p class="text-sm text-base-content/60 mb-4">Subcollection: <code>${A(h)}</code> \xB7 Showing up to ${v} entries.</p>`,k)C+=`<div class="alert alert-error mb-4">${A(k)}</div>`;else if(R.length===0)C+='<div class="alert">No history entries found.</div>';else {C+='<div class="overflow-x-auto"><table class="table table-zebra table-sm">',C+="<thead><tr><th>When</th><th>Op</th><th>User</th><th>Reason / Comment</th><th>Changes</th></tr></thead><tbody>";for(let y of R){let L=y.meta??{},oe=[L.reason,L.comment].filter(V=>V!=null&&V!=="").map(V=>A(String(V))).join(" \u2014 "),ne="",ve=Object.keys(y.changes??{});ve.length===0?ne='<span class="opacity-40">\u2014</span>':ne='<ul class="space-y-1">'+ve.map(V=>{let $e=y.changes[V];return `<li><strong>${A(V)}</strong>: ${D($e.oldValue)} \u2192 ${D($e.newValue)}</li>`}).join("")+"</ul>",C+="<tr>",C+=`<td class="whitespace-nowrap text-xs font-mono">${A(P(y.historySetAt))}</td>`,C+=`<td>${G(y.operation??"update")}</td>`,C+=`<td class="text-xs">${A(L.userEmail??L.userId??"")}</td>`,C+=`<td class="text-xs">${oe}</td>`,C+=`<td>${ne}</td>`,C+="</tr>";}C+="</tbody></table></div>";}Z(f,Ne(C,{title:`History \u2014 ${c.name} / ${i}`,basePath:p,breadcrumb:[{label:"Repositories",href:p},{label:c.name,href:`${p}/${c.name}`},{label:`History ${i}`}]}));}}}function W(e,t,n=200){e.status(n).set("Content-Type","application/json; charset=utf-8").send(JSON.stringify(t));}function xn(e){return e==="true"?true:e==="false"?false:e!==""&&!isNaN(Number(e))?Number(e):e}function wn(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 kn(e){let t=e.path??e.url??"/",n=t.indexOf("?");return n===-1?t:t.slice(0,n)}var Re=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}=wn(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=kn(t),s=null,o={};for(let u of this.routes){if(u.method!==r)continue;let m=a.match(u.pattern);if(m){s=u,o={},u.paramNames.forEach((N,w)=>{o[N]=decodeURIComponent(m[w+1]??"");});break}}let d=Object.assign(t,{params:o}),l=s?s.handler:this.notFoundHandler;try{await this.runMiddlewareChain(d,n,l);}catch(u){this.errorHandler(u,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 Sn(e){return typeof e.rawBody=="string"?e.rawBody:Buffer.isBuffer(e.rawBody)?e.rawBody.toString("utf8"):""}function Rn(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 Ar(e){let{basePath:t="/",repos:n,parseBody:r=true,auth:a,middleware:s=[],httpsOptions:o}=e,d=t==="/"?"":t.replace(/\/$/,""),l={};for(let[w,S]of Object.entries(n)){let E=S.schema??S.repo.schema??null;if(!E)throw new Error(`[createAdminServer] Repository "${w}" has no Zod schema. Either use createRepositoryConfig(schema)(config) or pass schema: explicitly.`);let j,B,b;if(S.fieldsConfig){let i=S.fieldsConfig;j=[],B=[],b=[];for(let[c,p]of Object.entries(i))for(let h of p)h==="filterable"?j.push(c):h==="mutable"?B.push(c):h==="create"&&b.push(c);j.length===0&&(j=void 0),B.length===0&&(B=void 0),b.length===0&&(b=void 0);}let f=(()=>{let i=S.repo._parentKeys;return i&&i.length>0?i:void 0})();if(f&&b)for(let i of f)b.includes(i)||b.push(i);let x={name:w,path:S.path,repo:S.repo,schema:E,documentKey:S.documentKey??"docId",pathKey:S.repo._pathKey??void 0,isGroup:!!S.repo._isGroup,parentKeys:f,createdKey:S.repo._createdKey??void 0,listColumns:S.listColumns,pageSize:S.pageSize,filterableFields:j,mutableFields:B,createFields:b,allowDelete:S.allowDelete??false,historyEnabled:!!S.repo.history,historySubcollection:(S.repo.history&&S.repo._historySubcollection)??void 0,relationalMeta:(()=>{if(!S.relationalFields||S.relationalFields.length===0)return;let i=S.repo.relationalKeys??{},c=[];for(let p of S.relationalFields){let h=i[p.key];h&&c.push({key:p.key,column:p.column,targetRepo:String(h.repo),targetKey:String(h.key),type:h.type});}return c.length>0?c:void 0})()};l[w]=x;}let u=Et(l,d),m=new Re;if(r&&m.use(async(w,S,E)=>{let j=w,B=String(j.headers?.["content-type"]??"");if(B.includes("application/x-www-form-urlencoded")){let b=await Sn(j);w.body=Rn(b);}else if(B.includes("application/json")&&typeof j.body=="string")try{w.body=JSON.parse(j.body);}catch{}await E();}),a)if(typeof a=="function")m.use(a);else {let w=a.realm??"Admin",S="Basic "+Buffer.from(`${a.username}:${a.password}`).toString("base64");m.use((E,j,B)=>{if((E.headers?.authorization??"")!==S){j.status(401).set("WWW-Authenticate",`Basic realm="${w}"`).set("Content-Type","text/plain").send("Unauthorized");return}B();});}for(let w of s)m.use(w);m.get(`${d}/`,u.handleDashboard),m.get(`${d}`,u.handleDashboard),m.get(`${d}/:repoName/_panel`,u.handlePanel),m.post(`${d}/:repoName/_bulk/delete`,u.handleBulkDelete),m.post(`${d}/:repoName/_bulk/update`,u.handleBulkUpdate),m.get(`${d}/:repoName`,u.handleList),m.get(`${d}/:repoName/create`,u.handleCreateForm),m.post(`${d}/:repoName/create`,u.handleCreateSubmit),m.get(`${d}/:repoName/:id/edit`,u.handleEditForm),m.post(`${d}/:repoName/:id/edit`,u.handleEditSubmit),m.get(`${d}/:repoName/:id/history`,u.handleHistory),m.post(`${d}/:repoName/:id/delete`,u.handleDelete);let N=async(w,S)=>{await m.handle(w,S);};return o&&(N.httpsOptions=o),N}
|
|
1046
1046
|
exports.MiniRouter=Re;exports.createAdminServer=Ar;//# sourceMappingURL=index.cjs.map
|
|
1047
1047
|
//# sourceMappingURL=index.cjs.map
|