react-iiif-vault 1.5.3 → 1.5.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -1,7 +1,7 @@
1
- "use strict";var ka=Object.create;var Yt=Object.defineProperty;var Ma=Object.getOwnPropertyDescriptor;var Ea=Object.getOwnPropertyNames;var Na=Object.getPrototypeOf,Va=Object.prototype.hasOwnProperty;var La=(e,t)=>{for(var n in t)Yt(e,n,{get:t[n],enumerable:!0})},_t=(e,t,n,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of Ea(t))!Va.call(e,r)&&r!==n&&Yt(e,r,{get:()=>t[r],enumerable:!(o=Ma(t,r))||o.enumerable});return e},p=(e,t,n)=>(_t(e,t,"default"),n&&_t(n,t,"default")),j=(e,t,n)=>(n=e!=null?ka(Na(e)):{},_t(t||!e||!e.__esModule?Yt(n,"default",{value:e,enumerable:!0}):n,e)),za=e=>_t(Yt({},"__esModule",{value:!0}),e);var f={};La(f,{AnnotationContext:()=>Ms,AnnotationPageContext:()=>Es,AnnotationStyleProvider:()=>Ts,Auth:()=>eo,AuthProvider:()=>Zn,AuthRContext:()=>Ne,AuthReactContext:()=>Mr,AuthReactContextActions:()=>Er,CanvasAnnotations:()=>ps,CanvasContext:()=>oe,CanvasPanel:()=>F,CanvasStrategyProvider:()=>Mo,CanvasWorldObject:()=>Eo,CollectionContext:()=>Ns,CombinedMetadata:()=>gs,ComplexTimelineProvider:()=>Oo,ContextBridge:()=>ao,ControlsReactContext:()=>Nt,CreateCustomShape:()=>lr,CustomContextBridge:()=>Ur,CustomContextBridgeProvider:()=>Qa,EventsProvider:()=>Ka,Image:()=>ma,ImageService:()=>ws,ImageServiceLoaderContext:()=>ji,InnerViewerProvider:()=>Br,LanguageProvider:()=>rs,LanguageString:()=>zi,LocaleString:()=>te,ManifestContext:()=>qn,ManifestMetadata:()=>ys,MediaPlayerProvider:()=>Ot,Metadata:()=>Wt,PolygonSelector:()=>Is,RangeContext:()=>Wn,ReactEventContext:()=>Ve,ReactVaultContext:()=>ve,Render3DModelStrategy:()=>$o,RenderAccompanyingCanvas:()=>Qo,RenderAnnotationStrategy:()=>Uo,RenderAudioStrategy:()=>Ko,RenderComplexTimelineStrategy:()=>Bo,RenderEmptyStrategy:()=>No,RenderImageStrategy:()=>qo,RenderSvgEditorControls:()=>bs,RenderTextualContentStrategy:()=>Do,RenderVideoStrategy:()=>Go,RenderYouTubeStrategy:()=>Xo,ResourceProvider:()=>$,ResourceReactContext:()=>lt,SelectorControllerProvider:()=>Rs,SequenceThumbnails:()=>xs,SimpleViewerProvider:()=>no,SimpleViewerReactContext:()=>Xe,SingleCanvasThumbnail:()=>er,StrategyReactContext:()=>Et,ThumbnailFallbackImage:()=>We,TranslationProvider:()=>os,TransliterationProvider:()=>is,VaultProvider:()=>we,ViewerPresetContext:()=>re,VirtualAnnotationProvider:()=>uo,VisibleCanvasReactContext:()=>Me,authDetailsForResource:()=>jn,createAuthStateStore:()=>Kn,createProbe:()=>Qn,defaultEmitter:()=>qr,emptyActions:()=>vo,emptyStrategy:()=>So,findAllCanvasesInRange:()=>jt,findFirstCanvasFromRange:()=>Ar,findManifestSelectedRange:()=>Ha,findSelectedRange:()=>$n,flattenAnnotationPageIds:()=>xo,formatTime:()=>hn,get3dStrategy:()=>Ro,getComplexTimelineStrategy:()=>Ao,getDefaultAnnotationStyles:()=>rr,getImageStrategy:()=>wt,getManifestSequence:()=>Gt,getParsedTargetSelector:()=>bt,getRenderingStrategy:()=>Io,getTextualContentStrategy:()=>kt,getVideoStrategy:()=>Mt,getVisibleCanvasesFromCanvasId:()=>Ba,hasAuth:()=>Da,makeAccessServiceRequest:()=>_n,makeAccessTokenRequest:()=>Xt,parseSpecificResource:()=>ja,svgThemes:()=>Sa,unknownResponse:()=>Rt,unsupportedStrategy:()=>E,useAnnotation:()=>xt,useAnnotationPage:()=>ho,useAnnotationPageManager:()=>At,useAnnotationStyles:()=>ar,useAnnotationsAtTime:()=>Vs,useAuthActions:()=>Nr,useAuthService:()=>Vr,useAuthStore:()=>je,useAuthToken:()=>qa,useAuthTokens:()=>Gn,useCanvas:()=>P,useCanvasChoices:()=>Ls,useCanvasClock:()=>zs,useCanvasSequence:()=>Un,useCanvasStartTime:()=>Ht,useCanvasSubset:()=>Os,useClosestLanguage:()=>Hi,useCollection:()=>Hs,useComplexTimeline:()=>cs,useContextBridge:()=>io,useCreateLocaleString:()=>as,useCurrentAuth:()=>Fa,useCustomContextBridge:()=>ro,useDispatch:()=>so,useEventEmitter:()=>yt,useEventListener:()=>Bs,useExistingVault:()=>ke,useExternalCollection:()=>Ds,useExternalManifest:()=>Fn,useExternalResource:()=>mt,useIIIFLanguage:()=>yn,useImage:()=>En,useImageService:()=>dr,useImageServiceLoader:()=>zt,useImageTile:()=>Fs,useIsAuthEnabled:()=>Jn,useLoadImageService:()=>It,useLocaleString:()=>Bi,useManifest:()=>z,useMediaActions:()=>us,useMediaElements:()=>ms,useMediaState:()=>ls,usePaintables:()=>bo,usePaintingAnnotations:()=>Oe,usePolygonHelper:()=>sr,useRange:()=>dt,useRenderControls:()=>_,useRenderingStrategy:()=>wo,useResourceContext:()=>W,useResourceEvents:()=>St,useResources:()=>Co,useSearchService:()=>to,useSelectorController:()=>or,useSelectorEmitter:()=>Ps,useSelectorEvents:()=>nr,useSelectorHelper:()=>As,useSimpleMediaPlayer:()=>Be,useSimpleViewer:()=>ht,useStrategy:()=>V,useStyleHelper:()=>qs,useStyles:()=>ze,useSvgEditor:()=>cr,useThumbnail:()=>he,useTranslations:()=>Lo,useTransliteration:()=>Vo,useVault:()=>T,useVaultEffect:()=>Fo,useVaultSelector:()=>w,useViewerPreset:()=>vt,useVirtualAnnotationPage:()=>co,useVirtualAnnotationPageContext:()=>lo,useVisibleCanvases:()=>Ee});module.exports=za(f);var Ft=require("react");var U=j(require("react"),1),rn=require("@atlas-viewer/atlas"),Xr=require("react-error-boundary");var ee=require("react");var Ye=j(require("react"),1),gr=require("react/jsx-runtime"),Oa={collection:void 0,manifest:void 0,range:void 0,canvas:void 0,annotation:void 0,annotationPage:void 0},lt=Ye.default.createContext(Oa),W=()=>(0,Ye.useContext)(lt);function $({value:e,children:t}){let n=W(),o=(0,Ye.useMemo)(()=>({...n,...e}),[e,n]);return(0,gr.jsx)(lt.Provider,{value:o,children:t})}var Kt=j(require("react"),1),ut=require("@iiif/helpers/vault");var Dn=require("react/jsx-runtime"),ve=Kt.default.createContext({vault:null,setVaultInstance:e=>{}});function we({vault:e,vaultOptions:t,useGlobal:n,resources:o,children:r}){let[a,i]=(0,Kt.useState)(()=>e||(n?(0,ut.globalVault)(t):t?new ut.Vault(t):new ut.Vault));return(0,Dn.jsx)(ve.Provider,{value:{vault:a,setVaultInstance:i},children:(0,Dn.jsx)($,{value:o||{},children:r})})}var Hr=require("react"),Jt=require("react");var hr=require("@iiif/helpers/vault"),yr=require("react");function ke(e){let t=(0,yr.useContext)(ve);return e||(t&&t.vault?t.vault:(0,hr.globalVault)())}var Se=require("react");function mt(e,{noCache:t=!1}={}){let n=typeof e=="string"?e:e.id,o=ke(),[r,a]=(0,Se.useState)(n),[i,s]=(0,Se.useState)(void 0),l=(0,Se.useMemo)(()=>o.get(n,{skipSelfReturn:!0})||void 0,[n,o]),[u,c]=(0,Se.useState)(l);return(0,Se.useEffect)(()=>{(async()=>{try{let d=l&&!t?l:await o.load(n),v=d?d.id||d["@id"]:null;d&&r!==v&&a(v),c(d)}catch(d){s(d)}})()},[n,t]),{isLoaded:!!u,id:r,requestId:n,error:i,resource:u,cached:!!(u&&u===l)}}function Fn(e,t){let{id:n,isLoaded:o,error:r,resource:a,requestId:i,cached:s}=mt(e,t);return{id:n,isLoaded:o,error:r,manifest:a,requestId:i,cached:s}}var vr=require("react/jsx-runtime");function qn({manifest:e,children:t}){return(0,vr.jsx)($,{value:{manifest:e},children:t})}var Sr=require("react/jsx-runtime");function oe({canvas:e,children:t}){return(0,Sr.jsx)($,{value:{canvas:e},children:t})}var Cr=require("react"),br=j(require("react"),1);var xr=require("react"),T=()=>{let{vault:e}=(0,xr.useContext)(ve);if(e===null)throw new Error("Vault not found. Ensure you have your provider set up correctly.");return e};var Qt=require("react");function w(e,t=[]){let n=T(),[o,r]=(0,Qt.useState)(()=>e(n.getState(),n));return(0,Qt.useEffect)(()=>n.subscribe(a=>e(a,n),a=>{r(a)},!1),t),o}var Me=br.default.createContext([]);function Ee(){let e=(0,Cr.useContext)(Me);return w(t=>e.map(n=>t.iiif.entities.Canvas[n]).filter(Boolean),[e])}var Rr=require("react");function z(e={},t=[]){let{id:n,selector:o}=e,r=W(),a=T(),i=n||r.manifest,s=w(l=>i?l.iiif.entities.Manifest[i]:void 0,[i]);return(0,Rr.useMemo)(()=>{if(s)return o?o(s):s},[s,o,...t])}var Pr=require("react/jsx-runtime");function Wn({range:e,children:t}){return(0,Pr.jsx)($,{value:{range:e},children:t})}function Ar(e,t){for(let n of t.items){if(n.type==="Canvas")return n;if(n.type==="SpecificResource")return n.source;if(n.type==="Range"){let o=Ar(e,e.get(n));if(o)return o}}return null}function jt(e,t){let n=[];for(let o of t.items)if(o.type==="SpecificResource"&&o.source?.type==="Canvas"&&(o.source.id.indexOf("#")!==-1?n.push({id:o.source.id.split("#")[0],type:"Canvas"}):n.push(o.source)),o.type==="Range"&&n.push(...jt(e,e.get(o))),o.type==="SpecificResource"){let r=typeof o.source=="string"?o.source:o.source.id;n.push({id:r,type:"Canvas"})}return n}function Ha(e,t,n){for(let o of t.structures){let r=$n(e,e.get(o),n);if(r)return r}return null}function $n(e,t,n){for(let o of t.items){let r=o?.source?.id?.split("#")[0];if(o.type==="SpecificResource"&&o.source===n||o.type==="SpecificResource"&&o.source?.type==="Canvas"&&n===r)return t;if(o.type==="Range"){let a=$n(e,e.get(o),n);if(a)return a}}return null}function Ba(e,t,n,o=!1){let r=t.behavior,a=n?e.get(n):null;if(!a)return[];let i=a.behavior,s=o?!1:r.includes("paged"),l=s?!1:r.includes("continuous"),u=s||l?!1:r.includes("individuals"),c=i.includes("facing-pages"),d=i.includes("non-paged");if(c||d||u||o)return[{id:a.id,type:"Canvas"}];let[v,y]=Gt(e,t);if(l)return v;let x=v.findIndex(g=>g.id===n);if(x===-1)return[];for(let g of y)if(g.includes(x))return g.map(S=>v[S]);return[{id:a.id,type:"Canvas"}]}function Gt(e,t,{disablePaging:n,skipNonPaged:o}={}){let r=t.behavior,a=r.includes("paged"),i=a?!1:r.includes("continuous"),s=a||i?!1:r.includes("individuals"),l=t.type==="Manifest"?t.items:jt(e,t);if(i)return[l,[l.map((x,g)=>g)]];if(s||!a||n)return[l,l.map((x,g)=>[g])];let u=[],c=[],d=()=>{c.length&&(u.push([...c]),c=[])},v=0,y=!1;for(let x=0;x<l.length;x++){let g=e.get(l[x]);if(g.behavior.includes("non-paged")){x===v&&v++,o||(d(),u.push([x]),d());continue}if(x===v||g.behavior.includes("facing-pages")){c.length&&(y=!0),d(),u.push([x]),d();continue}if(c.push(x),y){d(),y=!1;continue}c.length>1&&d()}return c.length&&d(),[l,u]}var ae=require("react");var Tr=require("react");function dt(e={},t=[]){let{id:n,selector:o}=e,r=W(),a=n||r.range,i=w(s=>a?s.iiif.entities.Range[a]:void 0,[a]);return(0,Tr.useMemo)(()=>{if(i)return o?o(i):i},[i,o,...t])}function Un({startCanvas:e,disablePaging:t}){let n=T(),o=z(),r=dt(),[a,i]=(0,ae.useState)(void 0),s=r||o;if(!s)throw new Error("Nothing selected");let[l,u]=(0,ae.useMemo)(()=>Gt(n,s,{disablePaging:t}),[n,s,t]),c=(0,ae.useRef)(u);if(c.current!==u){let S=c.current[a][0],h=u.findIndex(C=>C.includes(S));c.current=u,i(h)}let d=(0,ae.useCallback)(g=>{let S=u.findIndex(h=>h.includes(g));i(S===-1?0:S)},[l,u]),v=(0,ae.useCallback)(g=>{let S=l.findIndex(h=>h.id===g);S!==-1?d(S):i(0)},[l,u]),y=(0,ae.useCallback)(()=>{i(g=>g>=u.length-1?g:g+1)},[u]),x=(0,ae.useCallback)(()=>{i(g=>g<=0?0:g-1)},[u]);return typeof a>"u"&&(e?v(e):i(0)),{visibleItems:u[a]?.map(g=>l[g].id)||[],cursor:a,items:l,sequence:u,hasPrevious:a>0,hasNext:a<u.length-1,setSequenceIndex:i,setCanvasIndex:d,setCanvasId:v,next:y,previous:x}}var ce=require("react"),Qe=require("zustand");var Yn=require("zustand/vanilla");function Da(e){let t=e.service||e.services||[];for(let n of t)if(n.type==="AuthProbeService2")return!0;return!1}function se(e,t,n){let o=t.findIndex(i=>i.service.id===e);if(o===-1)return t;let r=[...t],a=n(r[o]);return a===r[o]?t:(r[o]=a,r)}var Kn=()=>(0,Yn.createStore)((e,t)=>({currentAuth:-1,authItems:[],login:()=>{let n=t().authItems[t().currentAuth];if(!n||n.isPending||n.isLoggedIn)return;if(n.type!=="active")throw new Error("Cannot login to non-active service");let o=n.service.service.find(r=>r.type==="AuthAccessTokenService2");if(!o)throw new Error("Token service not found");e(()=>({authItems:se(n.id,t().authItems,r=>({...r,isPending:!0}))})),_n(n.service).then(()=>{Xt(o).then(r=>{let a=r.expiresIn,i=Date.now()+a*1e3;e(()=>({authItems:se(n.id,t().authItems,s=>({...s,isLoggedIn:!0,isPending:!1,session:{token:r.accessToken,expires:i}}))}))}).catch(r=>{e(()=>({authItems:se(n.id,t().authItems,a=>({...a,isLoggedIn:!1,isPending:!1,error:r.message}))}))})})},logout:()=>{let n=t().authItems[t().currentAuth];if(!n||n.isPending||!n.isLoggedIn)return;if(n.type!=="active")throw new Error("Cannot logout of non-active service");let o=n.service.service.find(i=>i.type==="AuthLogoutService2");if(!o)return;let r=`${o.id}?origin=${Ir()}`,a=window.open(r);e(()=>({authItems:se(n.id,t().authItems,i=>({...i,isLoggedIn:!1,session:null,isPending:!1}))}))},nextAuth:()=>{let n=t().authItems.length,o=t().currentAuth+1;o>=n||e(()=>({currentAuth:o}))},previousAuth:()=>{let n=t().currentAuth-1;n<0||e(()=>({currentAuth:n}))},setAuth:n=>{n!==-1&&(n<0||n>=t().authItems.length)||e(()=>({currentAuth:n}))},addService:(n,o)=>{if(!n.service)return;let r=n.service.find(s=>s.type==="AuthAccessTokenService2"),a=n;if(t().authItems.find(s=>s.service.id===n.id)){e(()=>({authItems:se(n.id,t().authItems,s=>({...s,instances:s.instances+1}))}));return}if(e(()=>({currentAuth:a.profile==="active"?0:t().currentAuth,authItems:[{id:n.id,type:n.profile,service:n,probeId:o,canAuthenticate:!0,instances:1,isPending:!1,isLoggedIn:!1,session:null},...t().authItems]})),n.profile==="external"){if(!r)throw new Error("Token service not found");Xt(r).then(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!0,isPending:!1,session:{token:s.accessToken,expires:s.expiresIn}}))}))}).catch(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!1,isPending:!1,canAuthenticate:!1,error:s.message}))}))})}if(n.profile==="kiosk"){if(!r)throw new Error("Token service not found");e(()=>({authItems:se(n.id,t().authItems,s=>({...s,isPending:!0}))})),_n(a).then(()=>{Xt(r).then(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!0,isPending:!1,session:{token:s.accessToken,expires:s.expiresIn}}))}))}).catch(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!1,isPending:!1,error:s.message}))}))})})}n.profile},removeService:(n,o)=>{let r=t().currentAuth===t().authItems.findIndex(i=>i.service.id===n.id),a=t().currentAuth;if(r){let i=t().authItems.find(l=>l.service.id===n.id);i&&i.instances>1||(a=t().authItems.findIndex(u=>u.service.id!==n.id&&u.instances>0))}e(()=>({authItems:se(n.id,t().authItems,i=>({...i,instances:i.instances-1})),currentAuth:a}))}})),Qn=(e,t)=>(0,Yn.createStore)((n,o)=>({service:e,status:e?"unknown":"success",shouldRedirect:!1,redirectResource:null,shouldSubstitute:!1,substituteResource:null,error:null,errorHeading:null,errorNote:null,shouldDisplayResource:!1,token:t||null,async probe(){if(!o().service)return;let r=o().service?.id;if(!r){n({status:"error",error:"Service ID not found",errorHeading:{en:["Service ID not found"]}});return}n({status:"probing"});let a=o().token;try{let i=await fetch(r,{headers:a?{Authorization:`Bearer ${o().token}`,Accept:"application/json"}:{Accept:"application/json"}}).then(s=>s.json());if(i.status===200)n({status:"success",shouldDisplayResource:!0,error:null,errorHeading:null,errorNote:null,shouldSubstitute:!1,shouldRedirect:!1});else if(i.status<400&&i.status>=300){if(!i.location)throw new Error("Redirect location not found");n({status:"error",shouldDisplayResource:!1,shouldRedirect:!0,redirectResource:i.location||null})}else if(i.status===401)n({status:"error",shouldDisplayResource:!1,shouldRedirect:!1,shouldSubstitute:!!i.substitute,substituteResource:i.substitute||null,error:"Unauthorized",errorHeading:i.heading||{en:["Unauthorized"]},errorNote:i.note||null});else throw new Error("Unknown error")}catch(i){n({status:"error",error:i.message,errorHeading:{en:["Unknown error"]}})}},setToken(r){n({token:r})}}));function jn(e){let t=e.service||e.services||[],n={hasAuth:!1,services:{}};for(let o of t)if(o.type==="AuthProbeService2"){n.services.probe=o,n.hasAuth=!0;let r=o.service.filter(a=>a.type==="AuthAccessService2");r[0]&&(n.services.access=r[0])}return n}async function Xt(e,{strict:t=!0}={}){return new Promise((n,o)=>{let r=Math.random().toString(36).substring(7),a=`${e.id}?messageId=${r}&origin=${window.location.origin}`,i=u=>{let c=u.data;if(c.messageId===r){if(t&&c.type!=="AuthAccessToken2"){s(),o("Invalid response, expected type=AuthAccessToken2");return}if(!c.accessToken){s(),o("Invalid response, expected accessToken");return}s(),n(c)}},s=()=>window.removeEventListener("message",i),l=document.createElement("iframe");l.src=a,l.style.display="none",document.body.appendChild(l),window.addEventListener("message",i)})}function Ir(e){let t=window.location;if(e){let n=document.createElement("a");return n.href=e,n.protocol+"//"+n.hostname+(n.port?":"+n.port:"")}return t.protocol+"//"+t.hostname+(t.port?":"+t.port:"")}async function _n(e){let t=`${e.id}?origin=${Ir()}`,n=window.open(t);if(!n)throw new Error("Failed to open window");return new Promise((o,r)=>{let a=setInterval(()=>{n.closed&&(clearInterval(a),o())},500)})}var Ke=require("react");var wr=require("zustand");function kr(e){let t=(0,Ke.useMemo)(()=>jn(e),[e]),n=Gn(t.services.access?.id),o=(0,Ke.useMemo)(()=>Qn(t.services.probe,n),[t.services.probe]),r=(0,wr.useStore)(o);return(0,Ke.useEffect)(()=>{r.status==="unknown"&&!n&&r.probe()},[t.services.probe,r.status]),(0,Ke.useEffect)(()=>{n&&(r.setToken(n),r.probe())},[n]),[e,r,t.hasAuth]}var ft=require("react/jsx-runtime"),Ne=(0,ce.createContext)(null),Mr=(0,ce.createContext)(null);Mr.displayName="CurrentAuth";var Er=(0,ce.createContext)(null);Er.displayName="AuthActions";function Zn({children:e}){let t=(0,ce.useMemo)(()=>Kn(),[]);return(0,ft.jsx)(Ne.Provider,{value:t,children:e})}function Jn(){return!!(0,ce.useContext)(Ne)}function je(){let e=(0,ce.useContext)(Ne);if(!e)throw new Error("useAuthActions must be used within a AuthProvider");return e}function Nr(){let e=je();return(0,Qe.useStore)(e,n=>({login:n.login,logout:n.logout,nextAuth:n.nextAuth,previousAuth:n.previousAuth,setAuth:n.setAuth,addService:n.addService,removeService:n.removeService}))}function Fa(){let e=je();return(0,Qe.useStore)(e,t=>t)}function Vr(e){let t=je();return(0,Qe.useStore)(t,o=>o.authItems.find(r=>r.service.id===e))}function Gn(e){let t=je();return(0,Qe.useStore)(t,o=>o.authItems.find(r=>r.id===e)?.session?.token)}function qa(e){let t=je();return(0,Qe.useStore)(t,o=>{let r=o.authItems.find(a=>a.service.id===e);return!r||!r.isLoggedIn||!r.session?null:r.session?.token||null})}function Wa(e){let t=Nr(),n=Vr(e.service.id);return(0,ce.useEffect)(()=>(t?.addService(e.service,e.probeId),()=>{t?.removeService(e.service,e.probeId)}),[e.service]),n?(n.error||!n.isLoggedIn,e.children):null}function Xn(){return null}function eo(e){let[t,n,o]=kr(e.resource),r=e.fallbackComponent||Xn,a=e.loadingComponent||Xn,i=e.errorComponent||Xn,s=n.service,l=null;if(!o||!s)return e.children(t);let u=s.service.filter(c=>c.type==="AuthAccessService2");n.status==="error"&&(l=(0,ft.jsx)(i,{resource:e.resource,error:n.error||"",heading:n.errorHeading,note:n.errorNote,extra:e.extra})),(n.status==="unknown"||n.status==="probing")&&(l=(0,ft.jsx)(a,{})),n.status==="success"&&(l=e.children(t));for(let c of u)l=(0,ft.jsx)(Wa,{service:c,probeId:s.id,children:l},c.id);return l}var pt=require("react");var Lr=require("zustand/vanilla"),$a=e=>e.id||e["@id"];function Ua(e){return(Array.isArray(e.service)?e.service:[e.service]).find(n=>n.profile==="http://iiif.io/api/search/0/autocomplete"||n.profile==="http://iiif.io/api/search/1/autocomplete"||n.profile==="AutoCompleteService1")}var zr=e=>{let t;typeof e=="string"?t={"@context":"http://iiif.io/api/search/1/context.json",profile:"http://iiif.io/api/search/1/search","@id":e,id:e,service:[]}:t=e;let n=t?$a(t):void 0,o=null;return(0,Lr.createStore)((r,a)=>({service:t,resources:[],lastQuery:{},loading:!1,error:!1,highlight:null,hasSearch:!!t,hasAutocomplete:t?!!Ua(t):!1,errorMessage:"",search(i,s={}){if(!n)throw new Error("No search service found.");o&&!o.signal.aborted&&o.abort(),o=new AbortController;let l=new URLSearchParams;i.q&&l.set("q",i.q),i.motivation&&l.set("motivation",i.motivation),i.date&&l.set("date",i.date),i.user&&l.set("user",i.user),r({loading:!0}),fetch(`${n}?${l.toString()}`,{signal:o.signal,headers:{"Content-Type":"application/json",Accept:"application/json",...s.headers||{}}}).then(async u=>{if(!o?.signal.aborted)if(u.ok){let c=await u.json();r({resources:c.resources,error:!1,errorMessage:""})}else r({resources:[],error:!0,errorMessage:u.statusText})})},clearSearch(){r({resources:[],error:!1,errorMessage:""})},highlightResult(i){let s=a().resources.find(l=>l["@id"]===i);r({highlight:s})},nextResult(){let i=a().resources,s=a().highlight;if(!s){r({highlight:i[0]||null});return}let l=i.findIndex(u=>u["@id"]===s["@id"]);if(l===-1){r({highlight:i[0]||null});return}r({highlight:i[l+1]||i[0]||null})},previousResult(){let i=a().resources,s=a().highlight;if(!s){r({highlight:i[i.length-1]||null});return}let l=i.findIndex(u=>u["@id"]===s["@id"]);if(l===-1){r({highlight:i[i.length-1]||null});return}if(l===0){r({highlight:i[i.length-1]||null});return}r({highlight:i[l-1]||i[i.length-1]||null})}}))};var _a=require("zustand");function to(){let e=z();return e?e.service.find(t=>t.profile==="SearchService1"||t.profile==="http://iiif.io/api/search/1/search"):void 0}var Zt=require("react/jsx-runtime"),Ge=(0,pt.createContext)(null);Ge.displayName="Search";function Or(e){let t=to();return e.store?(0,Zt.jsx)(Ge.Provider,{value:e.store,children:e.children}):(0,Zt.jsx)(Ya,{service:t,children:e.children})}function Ya({service:e,children:t}){let n=(0,pt.useMemo)(()=>zr(e),[e]);return(0,Zt.jsx)(Ge.Provider,{value:n,children:t})}var G=require("react/jsx-runtime"),gt=()=>{},Xe=(0,Jt.createContext)({setCurrentCanvasId:gt,setCurrentCanvasIndex:gt,nextCanvas:gt,previousCanvas:gt,items:[],sequence:[],setSequenceIndex:gt,currentSequenceIndex:0,hasNext:!1,hasPrevious:!1});function Br(e){let t=z(),{cursor:n,visibleItems:o,next:r,sequence:a,items:i,setCanvasIndex:s,setCanvasId:l,previous:u,setSequenceIndex:c,hasNext:d,hasPrevious:v}=Un({startCanvas:e.startCanvas,disablePaging:e.pagingEnabled===!1}),y=(0,Jt.useMemo)(()=>({sequence:a,items:i,setCurrentCanvasId:l,nextCanvas:r,previousCanvas:u,totalCanvases:i.length,setCurrentCanvasIndex:s,setSequenceIndex:c,currentSequenceIndex:n,hasNext:d,hasPrevious:v}),[a,i,l,r,u,i,s,c,n]);return t?o.length===0?null:(0,G.jsx)(Xe.Provider,{value:y,children:(0,G.jsx)(Me.Provider,{value:o,children:(0,G.jsx)(oe,{canvas:o[0],children:e.children})})}):(console.warn("The manifest passed to the provider is not a valid IIIF manifest."),(0,G.jsx)("div",{children:"Sorry, something went wrong."}))}function no(e){let t=ke(e.vault),n=Fn(e.manifest);if(!n)return console.warn("The manifest passed to the provider is not a valid IIIF manifest."),(0,G.jsx)("div",{children:"Sorry, something went wrong."});if(n.error)return(0,G.jsx)("div",{children:n.error.toString()});if(!n.isLoaded)return(0,G.jsx)("div",{children:"Loading..."});let o=(0,G.jsx)(Br,{...e,children:e.children});return(0,G.jsx)(we,{vault:t,children:(0,G.jsx)(qn,{manifest:n.id,children:(0,G.jsx)(Zn,{children:(0,G.jsx)(Or,{children:e.rangeId?(0,G.jsx)(Wn,{range:e.rangeId,children:o}):o})})})})}function ht(){return(0,Hr.useContext)(Xe)}var Dr=j(require("react"),1),en=require("react"),Fr=j(require("mitt"),1),Wr=require("react/jsx-runtime"),qr=(0,Fr.default)(),Ve=(0,en.createContext)({emitter:qr});Ve.displayName="Events";function yt(){return Dr.default.useContext(Ve).emitter}function Ka({emitter:e,children:t}){return(0,Wr.jsx)(Ve.Provider,{value:(0,en.useMemo)(()=>({emitter:e}),[e]),children:t})}var $r=j(require("react"),1),me=require("react/jsx-runtime"),oo=$r.default.createContext({});function ro(){let e=(0,ee.useContext)(oo),t=Object.keys(e),n={};for(let o of t)e[o].Provider&&(n[o]={value:(0,ee.useContext)(e[o]),Provider:e[o].Provider});return n}function Ur(e){let t=Object.keys(e),n=e.children;for(let o of t){if(o==="children")continue;let{value:r,Provider:a}=e[o];n=(0,me.jsx)(a,{value:r,children:n})}return n}function Qa(e){let t=(0,ee.useContext)(oo),n=(0,ee.useMemo)(()=>({...t,...e.providers}),[e.providers]);return(0,me.jsx)(oo.Provider,{value:n,children:e.children})}function io(){return{VaultContext:(0,ee.useContext)(ve),ResourceContext:(0,ee.useContext)(lt),SimpleViewerReactContext:(0,ee.useContext)(Xe),VisibleCanvasReactContext:(0,ee.useContext)(Me),AuthRContext:(0,ee.useContext)(Ne),SearchReactContext:(0,ee.useContext)(Ge),ReactEventContext:(0,ee.useContext)(Ve)}}function ao(e){return(0,me.jsx)(we,{vault:e.bridge.VaultContext.vault||void 0,resources:e.bridge.ResourceContext,children:(0,me.jsx)(Me.Provider,{value:e.bridge.VisibleCanvasReactContext,children:(0,me.jsx)(Xe.Provider,{value:e.bridge.SimpleViewerReactContext,children:(0,me.jsx)(Ve.Provider,{value:e.bridge.ReactEventContext,children:(0,me.jsx)(Ne.Provider,{value:e.bridge.AuthRContext,children:(0,me.jsx)(Ge.Provider,{value:e.bridge.SearchReactContext,children:e.custom?(0,me.jsx)(Ur,{...e.custom,children:e.children}):e.children})})})})})})}var Ze=require("react");var fe=require("react");var tn=require("@iiif/helpers/vault/actions");var _r=require("react");function so(){let t=T().getStore();return(0,_r.useMemo)(()=>n=>t.dispatch(n),[t])}function Yr(e){return typeof e!="string"&&e&&e.bindToVault}function co(){let e=T(),t=(0,fe.useRef)([]),n=so(),o=(0,fe.useMemo)(()=>`vault://annotation-page/${new Date().getTime()}/${Math.round(Math.random()*1e9).toString(16)}`,[]);(0,fe.useLayoutEffect)(()=>{let s={id:o,type:"AnnotationPage",behavior:[],label:null,thumbnail:[],summary:null,requiredStatement:null,metadata:[],rights:null,provider:[],items:[],seeAlso:[],homepage:[],rendering:[],service:[]};n(tn.entityActions.importEntities({entities:{AnnotationPage:{[s.id]:s}}}))},[o]);let r=w(s=>o&&s.iiif.entities.AnnotationPage[o]||null,[o]),a=(0,fe.useCallback)((s,l)=>{if(o){if(Yr(s)){let d=s;d.__vault||d.bindToVault(e),s=typeof d.source=="string"?d.source:d.source.id,t.current[s]=d}else typeof s!="string"&&(s=s.id);let u=e.get({id:o,type:"AnnotationPage"}),c=e.get({id:s,type:"Annotation"});u&&c&&(u.items.find(d=>d.id===c.id)||n(tn.entityActions.addReference({id:o,type:"AnnotationPage",key:"items",reference:{id:s,type:"Annotation"},index:l})))}},[o]),i=(0,fe.useCallback)(s=>{o&&(Yr(s)?s=typeof s.source=="string"?s.source:s.source.id:typeof s!="string"&&(s=s.id),t.current[s]&&t.current[s].beforeRemove(),e.get({id:o,type:"AnnotationPage"})&&n(tn.entityActions.removeReference({id:o,type:"AnnotationPage",key:"items",reference:{id:s,type:"Annotation"}})))},[o]);return[r,{addAnnotation:a,removeAnnotation:i}]}var Qr=require("react/jsx-runtime"),Kr=(0,Ze.createContext)(null);function lo(){let e=(0,Ze.useContext)(Kr);return[e.fullPage,{addAnnotation:e.addAnnotation,removeAnnotation:e.removeAnnotation}]}function uo({children:e}){let[t,{addAnnotation:n,removeAnnotation:o}]=co();return(0,Qr.jsx)(Kr.Provider,{value:(0,Ze.useMemo)(()=>({fullPage:t,addAnnotation:n,removeAnnotation:o}),[t]),children:e})}var Je=require("react/jsx-runtime");function nn({width:e,style:t,height:n,error:o,resetErrorBoundary:r}){return(0,Je.jsxs)("div",{style:{width:e,height:n,minHeight:500,...t||{},background:"#f9f9f9"},children:[(0,Je.jsx)("h3",{children:"Error occurred"}),(0,Je.jsx)("p",{children:o.message}),(0,Je.jsx)("button",{type:"button",onClick:r,children:"Reset"})]})}var on=require("react"),re=(0,on.createContext)(null);function vt(){return(0,on.useContext)(re)}var Le=require("react"),mo=(0,Le.createContext)(()=>{}),fo=(0,Le.createContext)(()=>{});function D(e,t,n,o,r=[]){let a=(0,Le.useContext)(e==="portal"?fo:mo);(0,Le.useEffect)(()=>(e!=="none"&&a(t,n,o),()=>{a(t,null)}),[t,e,a,...r])}var et=require("react");var jr=require("react");function P(e={},t=[]){let{id:n,selector:o}=e,r=W(),a=n||r.canvas,i=w(s=>a?s.iiif.entities.Canvas[a]:void 0,[a]);return(0,jr.useMemo)(()=>{if(i)return o?o(i):i},[i,o,...t])}var po=(0,et.createContext)(()=>{});function Gr(e){let t=P(),n=(0,et.useContext)(po);(0,et.useEffect)(()=>t&&t.id?(n(t.id,e),()=>n(t.id,-1)):()=>{},[t,e])}var O=require("react/jsx-runtime");function an({children:e,errorFallback:t,outerContainerProps:n={},worldScale:o,...r}){let[a,i]=(0,U.useState)(),s=ro(),l=io(),u=t||nn,[c,d]=(0,U.useState)({}),v=Object.entries(c),[y,x]=(0,U.useState)({}),g=Object.entries(y),[S,h]=(0,U.useState)({}),C=(0,U.useMemo)(()=>o||Math.max(...Object.values(S)),[S]),m=(0,U.useMemo)(()=>({maxOverZoom:C||1,...r.runtimeOptions||{}}),[C,r.runtimeOptions]),b=(0,U.useCallback)((I,R)=>{h(B=>{if(R===-1){let{[I]:_e,...k}=B;return k}return{...B,[I]:R}})},[]),A=(0,U.useCallback)((I,R,B)=>{d(({[I]:_e,...k})=>R?{...k,[I]:{element:R,props:B}}:k)},[]),M=(0,U.useCallback)((I,R,B)=>{x(({[I]:_e,...k})=>R?{...k,[I]:{element:R,props:B}}:k)},[]);return(0,O.jsxs)(Xr.ErrorBoundary,{resetKeys:[],fallbackRender:I=>(0,O.jsx)(u,{...r,...I}),children:[(0,O.jsx)(rn.AtlasAuto,{...r,containerProps:{style:{position:"relative"},...r.containerProps||{}},htmlChildren:(0,O.jsx)(O.Fragment,{children:v.map(([I,{element:R,props:B}])=>(0,O.jsx)(U.default.Fragment,{children:(0,O.jsx)(R,{...B||{}})},I))}),onCreated:I=>{i(I),r.onCreated&&r.onCreated(I)},runtimeOptions:m,children:(0,O.jsx)(re.Provider,{value:a,children:(0,O.jsx)(po.Provider,{value:b,children:(0,O.jsx)(mo.Provider,{value:A,children:(0,O.jsx)(fo.Provider,{value:M,children:(0,O.jsx)(ao,{bridge:l,custom:s,children:(0,O.jsx)(rn.ModeContext.Provider,{value:r.mode||"explore",children:(0,O.jsx)(uo,{children:e})})})})})})})}),(0,O.jsx)("div",{children:g.map(([I,{element:R,props:B}])=>(0,O.jsx)(U.default.Fragment,{children:(0,O.jsx)(R,{...B||{}})},I))})]})}var sn=require("@atlas-viewer/atlas");var go=require("react"),Zr=require("@iiif/helpers/events");function St(e,t){let n=T(),o=(0,go.useMemo)(()=>(0,Zr.createEventsHelper)(n),[n]),r=w(()=>e&&e.id?n.getResourceMeta(e.id,"eventManager"):null,[e]);return(0,go.useMemo)(()=>e?o.getListenersAsProps(e,t):{},[r,e,n,t])}var Jr=require("react"),ei=require("@iiif/helpers/styles");function ze(e,t){let n=T(),o=(0,Jr.useMemo)(()=>(0,ei.createStylesHelper)(n),[n]);return w(()=>{if(!e)return null;let r=o.getAppliedStyles(e.id);return r?t?r[t]:r:void 0},[e,t])}var oi=require("react");var ti=require("react");var ni=require("@iiif/helpers/annotation-targets");function xt(e={},t=[]){let{id:n,selector:o}=e,r=W(),a=T(),i=n||r.annotation,s=w(u=>i?u.iiif.entities.Annotation[i]:void 0,[i]),l=w(u=>s&&s.body?s.body.map(c=>c?c.type==="SpecificResource"?{...c,source:a.get(c)}:c?u.iiif.entities[c.type][c.id]:null:null).filter(Boolean):[],[s]);return(0,ti.useMemo)(()=>{if(!s)return;let u={...s,body:l,target:(0,ni.expandTarget)(s.target,{typeMap:a.getState().iiif.mapping})};return o?o(u):u},[s,o,l,...t])}var ri=require("react/jsx-runtime"),cn=({id:e,style:t,className:n,interactive:o})=>{let r=xt({id:e}),a=ze(r,"atlas"),i=ze(r,"html"),s=St(r,["atlas"]),l=P(),u=(0,oi.useMemo)(()=>(0,sn.mergeStyles)(t,a),[t,a]);return l&&r&&r.target&&r.target.selector&&r.target.selector.type==="BoxSelector"&&r.target.source&&(r.target.source.id===l.id||r.target.source===l.id)?(0,ri.jsx)(sn.RegionHighlight,{id:r.id,isEditing:!0,region:r.target.selector.spatial,style:u,className:i?.className||n,interactive:!!(i?.href||o),href:i?.href||null,title:i?.title||null,hrefTarget:i?.target||null,onClick:()=>{},...s}):null};var ai=require("react");var ii=require("react");function ho(e={},t=[]){let{id:n,selector:o}=e,r=W(),a=n||r.annotationPage,i=w(s=>a?s.iiif.entities.AnnotationPage[a]:void 0,[a]);return(0,ii.useMemo)(()=>{if(i)return o?o(i):i},[i,...t])}var yo=require("react/jsx-runtime"),Ct=({className:e,page:t})=>{let n=ho({id:t.id})||t,o=ze(n,"atlas"),r=ze(n,"html");return w(a=>n.id?a.iiif.entities.AnnotationPage[n.id]:null,[]),(0,yo.jsx)(ai.Fragment,{children:n.items?.map(a=>(0,yo.jsx)(cn,{id:a.id,style:o,className:r?.className||e},a.id))})};var xe=require("react");var nt=require("react");var si=require("@iiif/helpers");function ja(e){return e.type==="SpecificResource"?[e.source,{selector:e.selector}]:[e,{selector:null}]}function bt(e,t){let{selector:n,source:o}=(0,si.expandTarget)(t);if(o.id!==e.id)return[null,o];let r={type:"BoxSelector",spatial:{x:0,y:0,width:Number(e.width),height:Number(e.height)}};return[n?n.type==="TemporalSelector"?{type:"TemporalBoxSelector",temporal:n.temporal,spatial:r.spatial}:n:null,o]}var vo={makeChoice:()=>{}},Rt={type:"unknown"},E=e=>({type:"unknown",reason:e,annotations:{pages:[]}}),So=(e,t)=>({type:"empty",width:e,height:t,annotations:{pages:[]},image:null,images:[]});var Pt=require("react");function Ga(e,t){let n=e?.iiif?.meta[t];return n?n.annotationPageManager:null}function ci(e,t){return w(n=>{let o=[];if(!e)return o;let r=Object.keys(n.iiif.entities.AnnotationPage);for(let a of r)if(!t||t.indexOf(a)!==-1){let i=Ga(n,a);i&&i.views&&i.views[e]&&o.push(a)}return o},[e,t])}function xo({canvas:e,manifest:t,all:n,canvases:o}){let r=[];if(t)for(let a of t.annotations)r.indexOf(a.id)===-1&&r.push(a.id);if(n){if(o&&o.length)for(let a of o)for(let i of a.annotations)r.indexOf(i.id)===-1&&r.push(i.id)}else if(e)for(let a of e.annotations)r.indexOf(a.id)===-1&&r.push(a.id);return r}function Xa(e,t){let n=e?.iiif?.meta[t];return n?n.annotationPageManager:null}function At(e,t={}){let n=T(),o=z(),r=P(),a=Ee(),i=(0,Pt.useMemo)(()=>xo({all:t.all,manifest:o,canvas:r,canvases:a}),[t.all,r,a,o]),s=ci(e,t.all?void 0:i),l=(0,Pt.useCallback)(c=>{e&&n.setMetaValue([c,"annotationPageManager","views"],d=>d&&!d[e]?d:{...d||{},[e]:!1})},[e,n]),u=(0,Pt.useCallback)((c,d={})=>{if(!e)return;let v=n.getState(),y=[];if(d?.deselectOthers){let x=Object.keys(v.iiif.entities.AnnotationPage);for(let g of x){let S=Xa(v,g);S&&S.views&&S.views[e]&&y.push(g)}}for(let x of y)l(x);n.setMetaValue([c,"annotationPageManager","views"],x=>x&&x[e]?x:{...x||{},[e]:!0})},[e,l,n]);return{availablePageIds:i,enabledPageIds:s,setPageEnabled:u,setPageDisabled:l}}function Co(e,t){return w((n,o)=>o.get(e.map(r=>({id:r,type:t}))),[e,t])}var pi=j(require("mitt"),1),gi=require("react"),hi=require("zustand");var ln=j(require("react"),1),li=require("@iiif/helpers/image-service"),Tt=require("zustand"),ui=ln.default.createContext(li.imageServices.store);ui.displayName="ImageServicesHelper";function un(){return(0,ln.useContext)(ui)}function mi(e){let t=un();return(0,Tt.useStore)(t,({loaded:n})=>n[e])}function tt(){let e=un();return(0,Tt.useStore)(e,({loadServiceSync:t})=>t)}function di(){let e=un();return(0,Tt.useStore)(e,({loaded:t})=>t)}function fi(){let e=un();return(0,Tt.useStore)(e,({loadService:t})=>t)}var Za=(0,hi.createStore)((e,t)=>({loaded:{},setLoaded:(n,o="done")=>{e(r=>({loaded:{...r.loaded,[n]:o}}))}})),Ja=(0,pi.default)();Ja.on("loaded",e=>{Za.getState().setLoaded(e.imageServiceId)});function It(){let e=tt(),t=di();return[(0,gi.useCallback)((o,{height:r,width:a})=>o&&e(o,{height:r,width:a},!0),[e]),t]}var He=require("react");function Oe(e={}){let t=xt(),n=P(e.canvasId?{id:e.canvasId}:void 0);return w((o,r)=>{if(!n)return[];if(t&&e.enableSingleAnnotation)return[t];let a=r.get(n.items),i=[];for(let s of a)i.push(...r.get(s.items));return i},[n])}var yi=require("@iiif/helpers/painting-annotations");function bo(e,t=[]){let n=T(),o=(0,He.useMemo)(()=>(0,yi.createPaintingAnnotationsHelper)(n),[]),r=Oe({enableSingleAnnotation:e?.enableSingleAnnotation}),[a,i]=(0,He.useState)(e?.defaultChoices||[]),s=(0,He.useMemo)(()=>o.getPaintables(r,a),[n,r,a,...t]),u={makeChoice:(0,He.useCallback)((c,{deselectOthers:d=!0,deselect:v=!1}={})=>{s.choice&&i(y=>{if(v){let g=y.filter(S=>S!==c);if(g.length===0){let S=s.items[0].resource.id;return S?[S]:[]}return g}if(d)return[c];let x=[...y];if(x.length===0&&s.items.length){let g=s.items[0].resource.id;g&&x.push(g)}return y.indexOf(c)!==-1?y:[...y,c]})},[s.choice])};return[s,u]}var es=["model/gltf-binary"];function Ro(e,t){let n=t.items[0],o=n.resource;return o.format?es.indexOf(o.format)===-1?E(`3D format: ${o.format} is unsupported`):{type:"3d-model",model:o,annotationId:n.annotationId,annotation:n.annotation}:E("Unknown format")}function vi(e,t){let n=t.items,o=n[0];if(n.length===0||!o)return E("No audio");if(!e.duration)return E("No duration on canvas");if(n.length>1)return E("Only one audio source supported");let r=o.resource;return r?"format"in r?{type:"media",media:{annotationId:o.annotationId,annotation:o.annotation,duration:e.duration,url:r.id,type:"Sound",target:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}},format:r.format,selector:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}}},annotations:{pages:[]}}:E("Audio does not have format"):E("Unknown audio")}var Si=require("@iiif/parser/image-3");var Po=require("@iiif/helpers/annotation-targets");function wt(e,t,n){let o=[];for(let r of t.items){let a=r.resource&&r.resource.type==="SpecificResource"?r.resource.source:r.resource;if(!a.id)return E("No resource Identifier");let i;if(a.service){let g=(0,Si.getImageServices)(a);g[0]&&(i=n(g[0],e))}let s={type:"BoxSelector",spatial:{x:0,y:0,width:Number(e.width),height:Number(e.height)}},[l,u]=bt(e,r.target),c=e.id?.split("?")[0]||"";if(!(u.id===e.id||decodeURIComponent(u.id||"")===(e.id||"")||u.id===c||decodeURIComponent(u.id||"")===c))continue;let d=r.resource.width&&r.resource.height?{type:"BoxSelector",spatial:{x:0,y:0,width:r.resource.width,height:r.resource.height}}:void 0,v=r.resource.type==="SpecificResource"?(0,Po.expandTarget)(r.resource):null;if(r.selector){let g=(0,Po.expandTarget)({type:"SpecificResource",source:r.resource,selector:r.selector});g&&(v=g)}let y=v&&v.selector&&(v.selector.type==="BoxSelector"||v.selector.type==="TemporalBoxSelector")?{type:"BoxSelector",spatial:{x:v.selector.spatial.x,y:v.selector.spatial.y,width:v.selector.spatial.width,height:v.selector.spatial.height}}:void 0;i&&!i.id&&(i.id=i["@id"]);let x={id:a.id,type:"Image",annotationId:r.annotationId,annotation:r.annotation,width:Number(l||y?a.width:e.width),height:Number(l||y?a.height:e.height),service:i,sizes:i&&i.sizes?i.sizes:a.width&&a.height?[{width:a.width,height:a.height}]:[],target:l&&l.type!=="PointSelector"?l:s,selector:y||{type:"BoxSelector",spatial:{x:0,y:0,width:Number(e.width),height:Number(e.height)}}};o.push(x)}return{type:"images",image:o[0],images:o,choice:t.choice}}function xi(e,t={},n){let o=e.language||n||"none";switch(e.type){case"TextualBody":{typeof e.value<"u"&&(t[o]=[e.value]);break}case"List":case"Composite":case"Choice":e.items&&e.items.forEach(r=>xi(r,t,o))}return t}function kt(e,t){let n=[];return t.items.forEach(o=>{if(o.resource){let[r]=bt(e,o.target);n.push({type:"Text",annotationId:o.annotationId,annotation:o.annotation,text:xi(o.resource),target:r})}}),{type:"textual-content",items:n}}var mn=require("@iiif/helpers"),ts=/^.*(?:(?:youtu\.be\/|v\/|vi\/|u\/\w\/|embed\/|shorts\/)|(?:(?:watch)?\?vi?=|&vi?=))([^#&?]*).*/;function Mt(e,t,n){let o=t.items.filter(y=>y.type==="video"),r=o[0],a=!1;if(e.duration||(a=!0),o.length>1||!r)return E("Only one video source supported");let i=o[0]?.resource,s=!!(i.service||[]).find(y=>(y.profile||"").includes("youtube.com"));if(!s&&a)return E("Video does not have duration");if(!i)return E("Unknown video");if((!i.format||i.format==="text/html")&&!s)return E("Video does not have format");let l=[],u=n.get(e.annotations||[]);for(let y of u){let x=n.get(y.items||[]);for(let g of x)if((g.motivation?Array.isArray(g.motivation||"")?g.motivation:[g.motivation]:[]).includes("supplementing")){let h=n.get(g.body||[]);for(let C of h){let m=C;if(m.type==="Choice")for(let b of m.items){let A=n.get(b);A.format==="text/vtt"&&l.push({id:A.id,type:"Text",format:"text/vtt",label:A.label,language:A.language})}else m.format==="text/vtt"&&l.push({id:m.id,type:"Text",format:"text/vtt",label:m.label,language:m.language})}}}let c={annotationId:r.annotationId,annotation:r.annotation,duration:e.duration,url:i.id,type:"Video",target:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}},format:i.format,selector:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}}},d=(0,mn.expandTarget)(r.target);d.selector&&d.selector.type==="TemporalBoxSelector"&&(c.target=d.selector);let{selector:v}=(0,mn.parseSelector)(r.selector);if(v===null){let y=c.target.temporal.startTime,g=(c.target.temporal.endTime||e.duration)-y;c.selector={type:"TemporalSelector",temporal:{startTime:0,endTime:g}}}else v.type==="TemporalSelector"&&(c.selector=v);if(s){c.type="VideoYouTube";let y=i.id.match(ts);if(!y[1])return E("Video is not known youtube video");c.youTubeId=y[1]}return{type:"media",media:c,annotations:{pages:[]},captions:l}}function Ao(e,t,n,o){let r={type:"complex-timeline",items:[],keyframes:[],duration:e.duration||0},a={type:"complex-choice",items:[]};function i(u){u.choice&&(u.choice.type==="complex-choice"?a.items.push(...u.choice.items):a.items.push(u.choice))}for(let u of t.items){if(u.type==="image"){let c=wt(e,{choice:null,allChoices:null,types:["image"],items:[u]},n);if(c.type==="images"){i(c),r.items.push(c.image);let d={id:c.image.annotationId,type:"enter",resourceType:"image",time:c.image.target?.temporal?.startTime||0};r.keyframes.push(d);let v={id:c.image.annotationId,type:"exit",resourceType:"image",time:c.image.target?.temporal?.endTime||e.duration||0};r.keyframes.push(v)}}if(u.type==="textualbody"){let c=kt(e,{choice:null,allChoices:null,types:["textualbody"],items:[u]});if(c.type==="textual-content"){i(c);let d=c.items[0];r.items.push(d);let v=d.target,y={id:d.annotationId,type:"enter",resourceType:"text",time:v.temporal?.startTime||0};r.keyframes.push(y);let x={id:d.annotationId,type:"exit",resourceType:"text",time:v.temporal?.endTime||e.duration||0};r.keyframes.push(x)}}if(u.type==="video"){let c=Mt(e,{choice:null,allChoices:null,types:["video"],items:[u]},o);if(c.type==="media"){i(c);let d=c.media;r.items.push(d);let v={id:d.annotationId,type:"enter",resourceType:"video",time:d.target?.temporal?.startTime||0};r.keyframes.push(v);let y={id:d.annotationId,type:"exit",resourceType:"video",time:d.target?.temporal?.endTime||e.duration||0};r.keyframes.push(y)}}}r.keyframes.sort((u,c)=>u.time-c.time);let s=[],l=[];for(let u of r.keyframes){if(u.resourceType==="image"||u.resourceType==="text"){l.push(u);continue}if(u.type==="enter"){s.length===0&&(u.isPrime=!0),s.push(u),l.push(u);continue}if(u.type==="exit"&&(l.push(u),s=s.filter(c=>c.id!==u.id),s.length!==0)){let c=s[0],d={id:c.id,type:"change",isPrime:!0,resourceType:c.resourceType,time:u.time};l.push(d)}}return r.keyframes=l,a.items.length&&(r.choice=a),r}var dn={},To={get(e){return e},setMetaValue([e,t,n],o){let r=To.getResourceMeta(e,t),a=r?r[n]:void 0,i=typeof o=="function"?o(a):o;dn[e]={...dn[e]||{},[t]:{...(dn[e]||{})[t]||{},[n]:i}}},getResourceMeta:(e,t)=>{let n=dn[e];if(n)return t?n[t]:n},async load(e){let t=typeof e=="string"?e:e.id;return fetch(t).then(n=>n.json())},requestStatus(e){}};function Io({canvas:e,paintables:t,supports:n,loadImageService:o,vault:r=To}){if(!e)return Rt;if(t.types.length===0)return n.indexOf("empty")!==-1?So(e.width,e.height):Rt;if(t.types.length!==1)if(t.types.length===2&&t.types.indexOf("text")!==-1)t.types=t.types.filter(i=>i!=="text");else return n.indexOf("complex-timeline")===-1?E("Complex timeline not supported"):Ao(e,t,o,r);let a=t.types[0];return a==="image"?n.indexOf("images")===-1?E("Image not supported"):wt(e,t,o):a==="Model"||a==="model"?n.indexOf("3d-model")===-1?E("3D not supported"):Ro(e,t):a==="textualbody"?n.indexOf("textual-content")===-1?E("Textual content not supported"):kt(e,t):a==="sound"||a==="audio"?n.indexOf("media")===-1?E("Media not supported"):vi(e,t):a==="video"?n.indexOf("media")===-1?E("Media not supported"):Mt(e,t,r):Rt}function wo(e){let t=z(),n=P(),o=T(),r=yt(),a=e?.emitter||r,[i,s]=It(),{enabledPageIds:l}=At(e?.annotationPageManagerId||t?.id||n?.id,{all:!1}),u=Co(l,"AnnotationPage"),c=e?.strategies||["empty","images","media","textual-content","complex-timeline"],[d,v]=bo(e,[s]);(0,nt.useEffect)(()=>{let x=g=>{v.makeChoice(g.choiceId,{deselectOthers:g.deselectOthers,deselect:g.deselect})};return a.on("make-choice",x),()=>{a.off("make-choice",x)}},[]);let y=(0,nt.useMemo)(()=>Io({canvas:n,paintables:d,supports:c,loadImageService:i,vault:o}),[n,d,o,v.makeChoice]);return(0,nt.useEffect)(()=>{let x=d.allChoices,g={canvasId:n?.id,manifestId:t?.id};x&&a.emit("choice-change",{choice:x,partOf:g})},[n?.id,d.allChoices]),(0,nt.useMemo)(()=>y.type==="unknown"?[y,vo]:[{...y,annotations:{pages:u}},v],[y,u])}var fn=require("react"),Et=(0,fn.createContext)(null);Et.displayName="Strategy";function V(){let e=(0,fn.useContext)(Et);if(!e)throw new Error("useStrategy must be used within a StrategyProvider");return e}var Ci=require("@iiif/helpers");var pn=require("react"),Nt=(0,pn.createContext)(null);Nt.displayName="Controls";function _(){let e=(0,pn.useContext)(Nt);if(!e)throw new Error("useStrategy must be used within a StrategyProvider");return e}var ko=require("react/jsx-runtime");function Mo({strategies:e,registerActions:t,defaultChoices:n,onChoiceChange:o,mediaControlsDeps:r,renderMediaControls:a,renderViewerControls:i,viewControlsDeps:s,renderComplexTimelineControls:l,complexTimelineControlsDeps:u,throwOnUnknown:c,children:d}){let v=P(),y=T(),x=(0,xe.useMemo)(()=>(0,Ci.createStylesHelper)(y),[y]),[g,S]=wo({strategies:e||["images"],defaultChoices:n?.map(({id:b})=>b)}),h="choice"in g?g.choice:void 0;if((0,xe.useEffect)(()=>{t&&t(S)},[g.annotations]),(0,xe.useEffect)(()=>{o&&o(h)},[h]),(0,xe.useEffect)(()=>{if(n)for(let b of n)typeof b.opacity<"u"&&x.applyStyles({id:b.id},"atlas",{opacity:b.opacity})},[n]),g.type==="unknown"&&c)throw new Error(g.reason||"Unknown strategy");let C=(0,xe.useMemo)(()=>({renderMediaControls:a,mediaControlsDeps:r||[],renderViewerControls:i,viewControlsDeps:s||[],renderComplexTimelineControls:l,complexTimelineControlsDeps:u||[]}),[r,a,i,s,l,u]),m=(0,xe.useMemo)(()=>({strategy:g,actions:S,choices:"choice"in g?g.choice:[]}),[g,v]);return(0,ko.jsx)(Nt.Provider,{value:C,children:(0,ko.jsx)(Et.Provider,{value:m,children:d})})}var bi=require("react");var Ri=require("react/jsx-runtime");function Eo({x:e=0,y:t=0,keepCanvasScale:n,children:o}){let{strategy:r}=V(),a=P(),i=St(a,["deep-zoom"]),s=(0,bi.useMemo)(()=>n?1:Math.max(1,...r.type==="images"?r.images.map(u=>(u.width||0)/u.target?.spatial.width):[]),[n,r]);Gr(s);let l=r.type==="images"?r.images.length:0;return a?(0,Ri.jsx)("world-object",{height:a.height,width:a.width,x:e,y:t,...i,children:o},`${a.id}/${r.type}/${l}`):null}var Pi=require("react/jsx-runtime");function gn({style:e}){let t=P();return!t||!t.height||!t.width?null:(0,Pi.jsx)("box",{interactive:!1,target:{x:0,y:0,width:Number(t.width),height:Number(t.height)},style:e})}var Ai=require("react/jsx-runtime");function No({backgroundStyle:e,alwaysShowBackground:t}){let{strategy:n}=V();return n.type!=="empty"&&!t?null:(0,Ai.jsx)(gn,{style:e})}var xn=require("react");var wi=j(require("mitt"),1);var L=require("react");function Ti(e){return{isMuted:!1,playRequested:!1,isPlaying:!1,isFinished:!1,volume:100,duration:e}}function ns(e,t){switch(t.type){case"RESET":return t.state;case"FINISHED":return{...e,isFinished:!0,isPlaying:!1,playRequested:!1};case"PLAY_PAUSE":return{...e,isFinished:!1,isPlaying:!e.isPlaying};case"PLAY_REQUESTED":return{...e,isFinished:!1,playRequested:!0};case"PAUSE":return{...e,isPlaying:!1};case"PLAY":return{...e,isFinished:!1,playRequested:!1,isPlaying:!0};case"MUTE":return{...e,isMuted:!0};case"SET_VOLUME":return{...e,volume:t.volume,isMuted:t.volume===0};case"TOGGLE_MUTE":return{...e,isMuted:!e.isMuted};case"UNMUTE":return{...e,isMuted:!1}}return e}function hn(e){let t=Math.round(e);return`${Math.floor(t/60)}:${`${t%60}`.padStart(2,"0")}`}function Be(e){let[t,n]=(0,L.useReducer)(ns,Ti(e.duration));(0,L.useEffect)(()=>{n({type:"RESET",state:Ti(e.duration)})},[e.duration]);let o=(0,L.useRef)(null),r=(0,L.useRef)(null),a=(0,L.useRef)(null),i=(0,L.useRef)(!1),s=(0,L.useCallback)(()=>{r.current&&o.current&&(r.current.innerHTML=hn(o.current.currentTime),a.current&&(a.current.style.width=`${o.current.currentTime/e.duration*100}%`),i.current!==o.current.muted&&(i.current=o.current.muted,n(o.current.muted?{type:"MUTE"}:{type:"UNMUTE"})))},[e.duration]),l=(0,L.useCallback)(()=>{o.current&&(n({type:"PLAY_REQUESTED"}),o.current.play().then(()=>{n({type:"PLAY"})}),s())},[s]),u=(0,L.useCallback)(()=>{o.current&&(o.current.duration>0&&o.current.paused?l():c())},[s]),c=(0,L.useCallback)(()=>{o.current&&(o.current.pause(),n({type:"PAUSE"}),s())},[s]),d=(0,L.useCallback)(()=>{o.current&&(o.current.muted=!o.current.muted,n(o.current.muted?{type:"MUTE"}:{type:"UNMUTE"}))},[]),v=(0,L.useCallback)(()=>{o.current&&(o.current.muted=!0,n({type:"MUTE"}))},[]),y=(0,L.useCallback)(()=>{o.current&&(o.current.muted=!1,n({type:"UNMUTE"}))},[]),x=(0,L.useCallback)(h=>{o.current&&(o.current.muted=!1,o.current.volume=h/100,n({type:"SET_VOLUME",volume:h}))},[]),g=(0,L.useCallback)(h=>{o.current&&(o.current.currentTime=Math.max(0,Math.min(h*e.duration,e.duration)),s())},[]),S=(0,L.useCallback)(h=>{if(o.current){let C=typeof h=="function"?h(o.current.currentTime):h;o.current.currentTime=Math.max(0,Math.min(C,e.duration)),s()}},[]);return(0,L.useEffect)(()=>{let h=setInterval(()=>{s()},350);return()=>clearInterval(h)},[s,e.duration]),(0,L.useEffect)(()=>{let h=()=>{n({type:"FINISHED"})},C=o.current;return C?.addEventListener("ended",h),()=>C?.removeEventListener("ended",h)},[]),[{element:o,currentTime:r,progress:a},t,{play:l,pause:c,playPause:u,mute:v,unmute:y,toggleMute:d,setVolume:x,setDurationPercent:g,setTime:S}]}var ki=require("zustand/vanilla");function Ii({currentKeyFrameIndex:e,keyframes:t,targetTime:n,currentTime:o}){if(o<=n){let r=t.findIndex(s=>s.time>n);if(r===-1)return[e,[]];let a={},i=t.slice(e,r);for(let s of i)s.type==="enter"&&(a[s.id]=s),s.type==="exit"&&(a[s.id]?delete a[s.id]:a[s.id]=s);return[r,Object.values(a)]}return[e,[]]}function Mi({complexTimeline:e,startTime:t=0}){let n=(0,wi.default)(),o={},r={progress:null,currentTime:null},a=0,i=null,s=0,l=null;function u(){let C=S.getState().visibleElements,m=o,b=[],A=Object.keys(m);for(let M of A){let I=m[M],R=C[M];I&&R&&b.push(I)}return b}function c(){return Object.keys(o).map(C=>o[C])}function d(h){r.currentTime&&(r.currentTime.innerHTML=hn(h),r.progress&&(r.progress.style.width=`${h/e.duration*100}%`))}let v=()=>{let h=S.getState(),C=h.currentPrime;if(!C)return;let m=o,b=h.visibleElements,A=Object.keys(m);for(let M of A){let I=m[M],R=b[M];if(I&&M!==C.id&&R){let B=s-R.time*1e3;Math.abs(s-R.time*1e3-I.currentTime*1e3)>300&&(I.currentTime=B/1e3)}}},y=(h=0)=>{let C=h-a,m=S.getState();if(m.isPlaying){let b=m.currentPrime;if(b){let R=o[b.id];R&&(R.paused?s+=C:s=(b.time+R.currentTime)*1e3)}else s+=C;let A=s/1e3;if(A>m.duration){S.getState().setTime(0),S.setState({isPlaying:!1}),x(),d(0);return}d(A);let[M,I]=Ii({currentTime:A,currentKeyFrameIndex:m.nextKeyframeIndex,keyframes:m.complexTimeline.keyframes,targetTime:A});I.length&&m.applyKeyframes(M,I)}a=h,i=requestAnimationFrame(y)},x=()=>{i&&cancelAnimationFrame(i)},g=(h,C)=>{},S=(0,ki.createStore)((h,C)=>({complexTimeline:e,elements:{},visibleElements:{},isBuffering:!1,bufferMap:{},isMuted:!1,playRequested:!1,isPlaying:!1,isFinished:!1,isReady:!1,volume:100,duration:e.duration,clockStartRequests:0,clockStartTime:0,primeTime:0,currentPrime:null,clockRunning:!1,nextKeyframeIndex:0,startClock:()=>{C().clockRunning||(y(),l=setInterval(v,500)),h({clockRunning:!0,clockStartRequests:C().clockStartRequests+1})},applyKeyframes(m,b){let A=C(),M={...A.visibleElements},I=A.currentPrime;for(let R of b)R.type==="enter"&&(M[R.id]=R,n.emit("complex-timeline.enter",{id:R.id})),R.type==="exit"&&(M[R.id]=null,n.emit("complex-timeline.exit",{id:R.id})),R.isPrime&&(I=R);h({nextKeyframeIndex:m,visibleElements:M,currentPrime:I})},stopClock:()=>{let m=C().clockStartRequests;if(m!==0){if(m===1){x(),l&&clearInterval(l),h({clockRunning:!1,clockStartRequests:0});return}h({clockStartRequests:m-1})}},setElement:(m,b)=>{o[m]=b;let A=Object.keys(o),M=C().complexTimeline;g(b,m),M.items.filter(R=>R.type!=="Image"&&R.type!=="Text").every(R=>A.includes(R.annotationId))&&!C().isReady&&(n.emit("complex-timeline.ready",{complexTimeline:M}),h({isReady:!0}))},removeElement:m=>{delete o[m]},mute(){for(let m of c())m.muted=!0;h({isMuted:!0})},unmute(){for(let m of c())m.muted=!1;h({isMuted:!1})},play(){if(!C().isPlaying){for(let b of u())b.play();h({isPlaying:!0})}},pause(){if(C().isPlaying){for(let b of u())b.pause();h({isPlaying:!1})}},playPause(){let m=C();m.isPlaying?m.pause():m.play()},setDurationPercent(m){let A=C().duration*m;C().setTime(A)},setTime(m){let b=C(),A=s/1e3,M=typeof m=="function"?m(A):m,I=b.nextKeyframeIndex;if(A>M){h({visibleElements:{},currentPrime:null});let ct=Object.keys(b.visibleElements);for(let Ut of ct)n.emit("complex-timeline.exit",{id:Ut});A=0,I=0}let[R,B]=Ii({currentTime:A,currentKeyFrameIndex:I,keyframes:b.complexTimeline.keyframes,targetTime:M});b.applyKeyframes(R,B),s=M*1e3;let k=S.getState().visibleElements,ne=o,fr=Object.keys(k);for(let ct of fr){let Ut=k[ct];if(Ut){let pr=ne[ct];pr&&(pr.currentTime=(s-Ut.time*1e3)/1e3)}}d(M)},setVolume(m){for(let b of c())b.volume=Math.min(1,Math.max(0,m/100));h({volume:m})},toggleMute(){let m=C();m.isMuted?(m.unmute(),h({isMuted:!1})):(m.mute(),h({isMuted:!0}))},clearProgressElement(){r.progress=null},setProgressElement(m){r.progress=m},setCurrentTimeElement(m){r.currentTime=m},clearCurrentTimeElement(){r.currentTime=null}}));return n.on("complex-timeline.enter",h=>{let C=S.getState(),m=h.id,b=o[m];b&&C.isPlaying&&b.play()}),n.on("complex-timeline.exit",h=>{let C=S.getState(),m=h.id,b=o[m];b&&(b.currentTime=0,b.pause())}),S.getState().setTime(t),{store:S,emitter:n}}var Ui=require("@atlas-viewer/atlas");var Lt=require("react");var Vt=require("@atlas-viewer/atlas");var ue=j(require("react"),1),le=require("react/jsx-runtime"),Ni=ue.default.createContext("en"),Vi=ue.default.createContext({}),Li=ue.default.createContext(null);function os(e){return(0,le.jsx)(Vi.Provider,{value:e.translations,children:e.children})}function rs(e){return(0,le.jsx)(Ni.Provider,{value:e.language,children:e.children})}function is(e){return(0,le.jsx)(Li.Provider,{value:e.convert,children:e.children})}function Vo(){return ue.default.useContext(Li)}function yn(){return ue.default.useContext(Ni)}function Lo(){return ue.default.useContext(Vi)}function Ei(e){return e.indexOf("-")!==-1?e.slice(0,e.indexOf("-")):e}function zi({as:e,language:t,children:n,viewingDirection:o,...r}){let a=yn();return(0,ue.useMemo)(()=>Ei(a)===Ei(t),[a,t])?e?(0,le.jsx)(e,{...r,children:n}):(0,le.jsx)("span",{...r,children:n}):e?(0,le.jsx)(e,{...r,lang:t,dir:o,children:n}):(0,le.jsx)("span",{...r,lang:t,dir:o,children:n})}function Oi(e,t,n){if(t.length===0)return;if(t.length===1)return t[0];if(t.indexOf(e)!==-1)return e;let o=e.indexOf("-")!==-1?e.slice(0,e.indexOf("-")):null;if(o&&t.indexOf(o)!==-1)return o;for(let r of n)if(t.indexOf(r)!==-1)return r;return t.indexOf("none")!==-1?"none":t.indexOf("@none")!==-1?"@none":t[0]}var Hi=(e,t=[])=>{let n=yn();return(0,ue.useMemo)(()=>{let o=e();return Oi(n,o,[])},[n,...t])};function De(e,t,n,o){return t?n?n(e[t]||t,o||"none"):e[t]||t:""}function Bi(e,t,n=`
2
- `,o={}){let r=Vo(),a=Hi(()=>Object.keys(e||{}),[e]);return[(0,ue.useMemo)(()=>{if(!e)return De(o,t,r)||"";if(typeof e=="string")return De(o,e,r);let i=a?e[a]:void 0;return i?typeof i=="string"?i:i.map(s=>De(o,s,r,a)).join(n):""},[a,t,e]),a]}function as(){let e=yn(),t=Lo(),n=Vo();return function(r,a="",i=`
3
- `,s=t){let l=Object.keys(r||{}),u=Oi(e,l,[]);if(!r)return De(s,a,n)||"";if(typeof r=="string")return De(s,r,n);let c=u?r[u]:void 0;return c?typeof c=="string"?De(s,c,n,u):c.map(d=>De(s,d,n,u)).join(typeof i<"u"?i:`
4
- `):""}}function te({as:e,defaultText:t,enableDangerouslySetInnerHTML:n,children:o,separator:r,...a}){let i=Lo(),[s,l]=Bi(o,t,r,i);return l?(0,le.jsx)(zi,{...a,as:e,language:l,title:n?void 0:s,dangerouslySetInnerHTML:n?{__html:s}:void 0,children:n?void 0:s}):e?(0,le.jsx)(e,{...a,children:s}):(0,le.jsx)("span",{...a,title:n?void 0:s,dangerouslySetInnerHTML:n?{__html:s}:void 0,children:n?void 0:s})}var Di=require("@iiif/parser/image-3");var ie=require("react/jsx-runtime");function ss({resource:e,heading:t,note:n,extra:o}){return o?(0,ie.jsx)(Vt.HTMLPortal,{target:{x:0,y:0,width:o.target?.spatial.width,height:o.target?.spatial.height},backgroundColor:"#333",relative:!0,children:(0,ie.jsx)("div",{style:{display:"flex",alignContent:"center",justifyContent:"center",alignItems:"center",height:"100%",width:"100%",background:"#444",color:"#BBB"},children:(0,ie.jsxs)("div",{children:[(0,ie.jsx)(te,{children:t||"Not authorised"}),n&&(0,ie.jsx)("p",{children:(0,ie.jsx)(te,{children:n})}),(0,ie.jsx)("p",{children:e.id||e["@id"]||"unknown"})]})})}):null}function Fi({image:e,thumbnail:t,crop:n,enableSizes:o,enableThumbnail:r,renderOptions:a}){let i=Jn(),s=(0,Di.getId)(e.service),l=mi(s),u=tt(),c=l?.service;u(e.service,e);let d=c&&l?.status==="done",v=t&&t.type==="fixed"&&t.id&&!t.id.includes("/full/full/")&&!t.id.includes("/max/")?t:void 0;if(d===!1)return null;if(!i){let y=e.service,x=y.width||e.width||0,g=y.height||e.height||0;return(0,ie.jsx)(Vt.TileSet,{enableThumbnail:r,renderOptions:a,tiles:{id:y.id||y["@id"]||"unknown",height:g,width:x,imageService:y,thumbnail:v},enableSizes:o,x:0,y:0,width:e.target?.spatial.width,height:e.target?.spatial.height,crop:n})}return(0,ie.jsx)(eo,{resource:e.service,errorComponent:ss,extra:e,children:y=>{let x=y.width||e.width||0,g=y.height||e.height||0;return(0,ie.jsx)(Vt.TileSet,{enableThumbnail:r,renderOptions:a,tiles:{id:y.id||y["@id"]||"unknown",height:g,width:x,imageService:y,thumbnail:v},enableSizes:o,x:0,y:0,width:e.target?.spatial.width,height:e.target?.spatial.height,crop:n})}},e.id)}var Fe=require("react/jsx-runtime");function Ce({id:e,image:t,thumbnail:n,isStatic:o,x:r=0,y:a=0,children:i,selector:s,onClick:l,enableSizes:u}){let c=(0,Lt.useMemo)(()=>{if(!(!s||s.spatial.x===0&&s.spatial.y===0))return s.spatial},[s]);return(0,Fe.jsx)("world-object",{x:r+t.target.spatial.x,y:a+t.target.spatial.y,width:t.target.spatial.width,height:t.target.spatial.height,onClick:l,children:t.service?(0,Fe.jsxs)(Lt.Fragment,{children:[(0,Fe.jsx)(Fi,{image:t,thumbnail:n,crop:c,enableSizes:u}),i]},"service"):(0,Fe.jsxs)(Lt.Fragment,{children:[(0,Fe.jsx)("world-image",{onClick:l,uri:t.id,target:{x:0,y:0,width:t.target.spatial.width,height:t.target.spatial.height},display:t.width&&t.height?{width:t.width,height:t.height}:void 0,crop:c}),i]},"no-service")},e+(t.service?"server":"no-service"))}var Ho=require("zustand");var vn=require("react"),qi=require("zustand"),Wi=require("react/jsx-runtime"),zo=(0,vn.createContext)(null);zo.displayName="ComplexTimeline";function Oo({children:e,store:t}){return(0,Wi.jsx)(zo.Provider,{value:t,children:e})}function cs(e){let t=(0,vn.useContext)(zo);if(!t)throw new Error("useComplexTimeline must be used within a ComplexTimelineProvider");return(0,qi.useStore)(t,e)}var $i=require("@atlas-viewer/atlas");var pe=require("react/jsx-runtime");function Sn({strategy:e,onClickPaintingAnnotation:t}){return(0,pe.jsx)(pe.Fragment,{children:e.items.map((n,o)=>(0,pe.jsx)(pe.Fragment,{children:(0,pe.jsx)($i.HTMLPortal,{onClick:t?r=>{r.stopPropagation(),t(n.annotationId,n,r)}:void 0,target:n.target?.spatial||void 0,children:(0,pe.jsx)("div",{"data-textual-content":!0,children:(0,pe.jsx)(te,{enableDangerouslySetInnerHTML:!0,children:n.text})})},o)}))})}var ge=require("react/jsx-runtime");function _i({strategy:e,children:t}){let{store:n}=(0,xn.useMemo)(()=>Mi({complexTimeline:e}),[e]),o=(0,Ho.useStore)(n,i=>i.isReady),r=(0,Ho.useStore)(n,i=>i.visibleElements);function a(i){return s=>{s&&n.getState().setElement(i,s)}}return(0,xn.useLayoutEffect)(()=>{if(o){let{startClock:i,stopClock:s}=n.getState();return i(),()=>{s()}}},[e,o]),D("portal","custom-controls",Oo,{store:n,children:t},[o]),(0,ge.jsxs)(ge.Fragment,{children:[e.items.map(i=>i.type!=="Image"||!r[i.annotationId]?null:(0,ge.jsx)(Ce,{image:i,id:i.annotationId},i.id)),e.items.map((i,s)=>i.type!=="Text"||!r[i.annotationId]?null:(0,ge.jsx)(Sn,{strategy:{type:"textual-content",items:[i]}},s)),e.items.map((i,s)=>i.type!=="Video"||!i.target.spatial?null:(0,ge.jsx)(Ui.HTMLPortal,{target:i.target.spatial,children:(0,ge.jsx)("video",{ref:a(i.annotationId),src:i.url,style:{height:"100%",width:"100%",opacity:r[i.annotationId]?1:0}})},s))]})}var Yi=require("react/jsx-runtime");function Bo(){let{strategy:e}=V(),{renderComplexTimelineControls:t}=_();return e.type!=="complex-timeline"?null:(0,Yi.jsx)(_i,{strategy:e,children:t?t(e):null})}var ot=require("react/jsx-runtime");function Do({onClickPaintingAnnotation:e,children:t}){let{strategy:n}=V(),{renderViewerControls:o,viewControlsDeps:r}=_(),a=vt(),i=P();return D(a&&n.type==="textual-content"&&o?"overlay":"none",`canvas-portal-controls-${i?.id}`,re.Provider,o?{value:a||null,children:o(n)}:{},[i,a,n,...r||[]]),n.type!=="textual-content"?null:(0,ot.jsxs)(ot.Fragment,{children:[(0,ot.jsx)(Sn,{strategy:n,onClickPaintingAnnotation:e}),t]})}var be=require("react");var Ki=require("react"),Fo=(e,t=[])=>{let n=T();(0,Ki.useEffect)(()=>{e(n)},[n,...t])};var Cn=j(require("react"),1),Qi=require("@iiif/helpers/image-service"),ji=Cn.default.createContext(new Qi.ImageServiceLoader);function zt(){return(0,Cn.useContext)(ji)}var Gi=require("@iiif/helpers/thumbnail");function he(e,t,{canvasId:n,manifestId:o}={}){let r=T(),a=zt(),i=(0,be.useMemo)(()=>(0,Gi.createThumbnailHelper)(r,{imageServiceLoader:a}),[r,a]),[s,l]=(0,be.useState)(),u=z(o?{id:o}:void 0),c=P(n?{id:n}:void 0),d=c||u,v=(0,be.useRef)(!1);if((0,be.useEffect)(()=>(v.current=!1,()=>{v.current=!0}),[]),!d)throw new Error("Must be called under a manifest or canvas context.");return Fo(y=>{i.getBestThumbnailAtSize(d,e,t).then(x=>{x.best&&!v.current&&l(x.best)})},[d]),s}var rt=require("react/jsx-runtime");function qo({isStatic:e=!1,enableSizes:t=!1,onClickPaintingAnnotation:n,children:o}){let{strategy:r}=V(),{renderViewerControls:a,viewControlsDeps:i}=_(),s=P(),l=vt(),u=he({maxWidth:256,maxHeight:256});return D(l&&r.type==="images"&&a?"overlay":"none",`canvas-portal-controls-${s?.id}`,re.Provider,a?{value:l||null,children:a(r)}:{},[s,l,r,...i||[]]),r.type!=="images"?null:(0,rt.jsxs)(rt.Fragment,{children:[r.images.map((c,d)=>(0,rt.jsx)(Ce,{isStatic:e,image:c,id:c.id,thumbnail:d===0?u:void 0,selector:c.selector,enableSizes:t,onClick:n?v=>{n(c.annotationId,c,v)}:void 0},c.id+d)),o]})}var Re=require("react/jsx-runtime");function Wo({model:e}){return(0,Re.jsxs)(Re.Fragment,{children:[(0,Re.jsx)("style",{children:`
1
+ "use strict";var ka=Object.create;var Yt=Object.defineProperty;var Ma=Object.getOwnPropertyDescriptor;var Ea=Object.getOwnPropertyNames;var Na=Object.getPrototypeOf,Va=Object.prototype.hasOwnProperty;var La=(e,t)=>{for(var n in t)Yt(e,n,{get:t[n],enumerable:!0})},_t=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ea(t))!Va.call(e,o)&&o!==n&&Yt(e,o,{get:()=>t[o],enumerable:!(r=Ma(t,o))||r.enumerable});return e},p=(e,t,n)=>(_t(e,t,"default"),n&&_t(n,t,"default")),j=(e,t,n)=>(n=e!=null?ka(Na(e)):{},_t(t||!e||!e.__esModule?Yt(n,"default",{value:e,enumerable:!0}):n,e)),za=e=>_t(Yt({},"__esModule",{value:!0}),e);var f={};La(f,{AnnotationContext:()=>Ms,AnnotationPageContext:()=>Es,AnnotationStyleProvider:()=>Ts,Auth:()=>er,AuthProvider:()=>Zn,AuthRContext:()=>Ne,AuthReactContext:()=>Mo,AuthReactContextActions:()=>Eo,CanvasAnnotations:()=>ps,CanvasContext:()=>re,CanvasPanel:()=>F,CanvasStrategyProvider:()=>kr,CanvasWorldObject:()=>Mr,CollectionContext:()=>Ns,CombinedMetadata:()=>gs,ComplexTimelineProvider:()=>zr,ContextBridge:()=>ar,ControlsReactContext:()=>Nt,CreateCustomShape:()=>co,CustomContextBridge:()=>Uo,CustomContextBridgeProvider:()=>Qa,EventsProvider:()=>Ka,Image:()=>ma,ImageService:()=>ws,ImageServiceLoaderContext:()=>ji,InnerViewerProvider:()=>Bo,LanguageProvider:()=>os,LanguageString:()=>zi,LocaleString:()=>te,ManifestContext:()=>qn,ManifestMetadata:()=>ys,MediaPlayerProvider:()=>Ot,Metadata:()=>Wt,PolygonSelector:()=>Is,RangeContext:()=>Wn,ReactEventContext:()=>Ve,ReactVaultContext:()=>ve,Render3DModelStrategy:()=>Wr,RenderAccompanyingCanvas:()=>Kr,RenderAnnotationStrategy:()=>$r,RenderAudioStrategy:()=>Yr,RenderComplexTimelineStrategy:()=>Hr,RenderEmptyStrategy:()=>Er,RenderImageStrategy:()=>Fr,RenderSvgEditorControls:()=>bs,RenderTextualContentStrategy:()=>Br,RenderVideoStrategy:()=>jr,RenderYouTubeStrategy:()=>Gr,ResourceProvider:()=>$,ResourceReactContext:()=>lt,SelectorControllerProvider:()=>Rs,SequenceThumbnails:()=>xs,SimpleViewerProvider:()=>nr,SimpleViewerReactContext:()=>Xe,SingleCanvasThumbnail:()=>Jr,StrategyReactContext:()=>Et,ThumbnailFallbackImage:()=>We,TranslationProvider:()=>rs,TransliterationProvider:()=>is,VaultProvider:()=>we,ViewerPresetContext:()=>oe,VirtualAnnotationProvider:()=>ur,VisibleCanvasReactContext:()=>Me,authDetailsForResource:()=>jn,createAuthStateStore:()=>Kn,createProbe:()=>Qn,defaultEmitter:()=>qo,emptyActions:()=>yr,emptyStrategy:()=>vr,findAllCanvasesInRange:()=>jt,findFirstCanvasFromRange:()=>Ao,findManifestSelectedRange:()=>Ha,findSelectedRange:()=>$n,flattenAnnotationPageIds:()=>Sr,formatTime:()=>hn,get3dStrategy:()=>br,getComplexTimelineStrategy:()=>Pr,getDefaultAnnotationStyles:()=>ro,getImageStrategy:()=>wt,getManifestSequence:()=>Gt,getParsedTargetSelector:()=>bt,getRenderingStrategy:()=>Tr,getTextualContentStrategy:()=>kt,getVideoStrategy:()=>Mt,getVisibleCanvasesFromCanvasId:()=>Ba,hasAuth:()=>Da,makeAccessServiceRequest:()=>_n,makeAccessTokenRequest:()=>Xt,parseSpecificResource:()=>ja,svgThemes:()=>Sa,unknownResponse:()=>Rt,unsupportedStrategy:()=>E,useAnnotation:()=>xt,useAnnotationPage:()=>gr,useAnnotationPageManager:()=>At,useAnnotationStyles:()=>io,useAnnotationsAtTime:()=>Vs,useAuthActions:()=>No,useAuthService:()=>Vo,useAuthStore:()=>je,useAuthToken:()=>qa,useAuthTokens:()=>Gn,useCanvas:()=>P,useCanvasChoices:()=>Ls,useCanvasClock:()=>zs,useCanvasSequence:()=>Un,useCanvasStartTime:()=>Ht,useCanvasSubset:()=>Os,useClosestLanguage:()=>Hi,useCollection:()=>Hs,useComplexTimeline:()=>cs,useContextBridge:()=>ir,useCreateLocaleString:()=>as,useCurrentAuth:()=>Fa,useCustomContextBridge:()=>or,useDispatch:()=>sr,useEventEmitter:()=>yt,useEventListener:()=>Bs,useExistingVault:()=>ke,useExternalCollection:()=>Ds,useExternalManifest:()=>Fn,useExternalResource:()=>mt,useIIIFLanguage:()=>yn,useImage:()=>En,useImageService:()=>mo,useImageServiceLoader:()=>zt,useImageTile:()=>Fs,useIsAuthEnabled:()=>Jn,useLoadImageService:()=>It,useLocaleString:()=>Bi,useManifest:()=>z,useMediaActions:()=>us,useMediaElements:()=>ms,useMediaState:()=>ls,usePaintables:()=>Cr,usePaintingAnnotations:()=>Oe,usePolygonHelper:()=>ao,useRange:()=>dt,useRenderControls:()=>_,useRenderingStrategy:()=>Ir,useResourceContext:()=>W,useResourceEvents:()=>St,useResources:()=>xr,useSearchService:()=>tr,useSelectorController:()=>no,useSelectorEmitter:()=>Ps,useSelectorEvents:()=>to,useSelectorHelper:()=>As,useSimpleMediaPlayer:()=>Be,useSimpleViewer:()=>ht,useStrategy:()=>V,useStyleHelper:()=>qs,useStyles:()=>ze,useSvgEditor:()=>so,useThumbnail:()=>he,useTranslations:()=>Vr,useTransliteration:()=>Nr,useVault:()=>T,useVaultEffect:()=>Dr,useVaultSelector:()=>w,useViewerPreset:()=>vt,useVirtualAnnotationPage:()=>cr,useVirtualAnnotationPageContext:()=>lr,useVisibleCanvases:()=>Ee});module.exports=za(f);var Ft=require("react");var U=j(require("react"),1),on=require("@atlas-viewer/atlas"),Xo=require("react-error-boundary");var ee=require("react");var Ye=j(require("react"),1),go=require("react/jsx-runtime"),Oa={collection:void 0,manifest:void 0,range:void 0,canvas:void 0,annotation:void 0,annotationPage:void 0},lt=Ye.default.createContext(Oa),W=()=>(0,Ye.useContext)(lt);function $({value:e,children:t}){let n=W(),r=(0,Ye.useMemo)(()=>({...n,...e}),[e,n]);return(0,go.jsx)(lt.Provider,{value:r,children:t})}var Kt=j(require("react"),1),ut=require("@iiif/helpers/vault");var Dn=require("react/jsx-runtime"),ve=Kt.default.createContext({vault:null,setVaultInstance:e=>{}});function we({vault:e,vaultOptions:t,useGlobal:n,resources:r,children:o}){let[a,i]=(0,Kt.useState)(()=>e||(n?(0,ut.globalVault)(t):t?new ut.Vault(t):new ut.Vault));return(0,Dn.jsx)(ve.Provider,{value:{vault:a,setVaultInstance:i},children:(0,Dn.jsx)($,{value:r||{},children:o})})}var Ho=require("react"),Jt=require("react");var ho=require("@iiif/helpers/vault"),yo=require("react");function ke(e){let t=(0,yo.useContext)(ve);return e||(t&&t.vault?t.vault:(0,ho.globalVault)())}var Se=require("react");function mt(e,{noCache:t=!1}={}){let n=typeof e=="string"?e:e.id,r=ke(),[o,a]=(0,Se.useState)(n),[i,s]=(0,Se.useState)(void 0),l=(0,Se.useMemo)(()=>r.get(n,{skipSelfReturn:!0})||void 0,[n,r]),[u,c]=(0,Se.useState)(l);return(0,Se.useEffect)(()=>{(async()=>{try{let d=l&&!t?l:await r.load(n),v=d?d.id||d["@id"]:null;d&&o!==v&&a(v),c(d)}catch(d){s(d)}})()},[n,t]),{isLoaded:!!u,id:o,requestId:n,error:i,resource:u,cached:!!(u&&u===l)}}function Fn(e,t){let{id:n,isLoaded:r,error:o,resource:a,requestId:i,cached:s}=mt(e,t);return{id:n,isLoaded:r,error:o,manifest:a,requestId:i,cached:s}}var vo=require("react/jsx-runtime");function qn({manifest:e,children:t}){return(0,vo.jsx)($,{value:{manifest:e},children:t})}var So=require("react/jsx-runtime");function re({canvas:e,children:t}){return(0,So.jsx)($,{value:{canvas:e},children:t})}var Co=require("react"),bo=j(require("react"),1);var xo=require("react"),T=()=>{let{vault:e}=(0,xo.useContext)(ve);if(e===null)throw new Error("Vault not found. Ensure you have your provider set up correctly.");return e};var Qt=require("react");function w(e,t=[]){let n=T(),[r,o]=(0,Qt.useState)(()=>e(n.getState(),n));return(0,Qt.useEffect)(()=>n.subscribe(a=>e(a,n),a=>{o(a)},!1),t),r}var Me=bo.default.createContext([]);function Ee(){let e=(0,Co.useContext)(Me);return w(t=>e.map(n=>t.iiif.entities.Canvas[n]).filter(Boolean),[e])}var Ro=require("react");function z(e={},t=[]){let{id:n,selector:r}=e,o=W(),a=T(),i=n||o.manifest,s=w(l=>i?l.iiif.entities.Manifest[i]:void 0,[i]);return(0,Ro.useMemo)(()=>{if(s)return r?r(s):s},[s,r,...t])}var Po=require("react/jsx-runtime");function Wn({range:e,children:t}){return(0,Po.jsx)($,{value:{range:e},children:t})}function Ao(e,t){for(let n of t.items){if(n.type==="Canvas")return n;if(n.type==="SpecificResource")return n.source;if(n.type==="Range"){let r=Ao(e,e.get(n));if(r)return r}}return null}function jt(e,t){let n=[];for(let r of t.items)if(r.type==="SpecificResource"&&r.source?.type==="Canvas"&&(r.source.id.indexOf("#")!==-1?n.push({id:r.source.id.split("#")[0],type:"Canvas"}):n.push(r.source)),r.type==="Range"&&n.push(...jt(e,e.get(r))),r.type==="SpecificResource"){let o=typeof r.source=="string"?r.source:r.source.id;n.push({id:o,type:"Canvas"})}return n}function Ha(e,t,n){for(let r of t.structures){let o=$n(e,e.get(r),n);if(o)return o}return null}function $n(e,t,n){for(let r of t.items){let o=r?.source?.id?.split("#")[0];if(r.type==="SpecificResource"&&r.source===n||r.type==="SpecificResource"&&r.source?.type==="Canvas"&&n===o)return t;if(r.type==="Range"){let a=$n(e,e.get(r),n);if(a)return a}}return null}function Ba(e,t,n,r=!1){let o=t.behavior,a=n?e.get(n):null;if(!a)return[];let i=a.behavior,s=r?!1:o.includes("paged"),l=s?!1:o.includes("continuous"),u=s||l?!1:o.includes("individuals"),c=i.includes("facing-pages"),d=i.includes("non-paged");if(c||d||u||r)return[{id:a.id,type:"Canvas"}];let[v,h]=Gt(e,t);if(l)return v;let x=v.findIndex(g=>g.id===n);if(x===-1)return[];for(let g of h)if(g.includes(x))return g.map(S=>v[S]);return[{id:a.id,type:"Canvas"}]}function Gt(e,t,{disablePaging:n,skipNonPaged:r}={}){let o=t.behavior,a=o.includes("paged"),i=a?!1:o.includes("continuous"),s=a||i?!1:o.includes("individuals"),l=t.type==="Manifest"?t.items:jt(e,t);if(i)return[l,[l.map((x,g)=>g)]];if(s||!a||n)return[l,l.map((x,g)=>[g])];let u=[],c=[],d=()=>{c.length&&(u.push([...c]),c=[])},v=0,h=!1;for(let x=0;x<l.length;x++){let g=e.get(l[x]);if(g.behavior.includes("non-paged")){x===v&&v++,r||(d(),u.push([x]),d());continue}if(x===v||g.behavior.includes("facing-pages")){c.length&&(h=!0),d(),u.push([x]),d();continue}if(c.push(x),h){d(),h=!1;continue}c.length>1&&d()}return c.length&&d(),[l,u]}var ae=require("react");var To=require("react");function dt(e={},t=[]){let{id:n,selector:r}=e,o=W(),a=n||o.range,i=w(s=>a?s.iiif.entities.Range[a]:void 0,[a]);return(0,To.useMemo)(()=>{if(i)return r?r(i):i},[i,r,...t])}function Un({startCanvas:e,disablePaging:t}){let n=T(),r=z(),o=dt(),[a,i]=(0,ae.useState)(void 0),s=o||r;if(!s)throw new Error("Nothing selected");let[l,u]=(0,ae.useMemo)(()=>Gt(n,s,{disablePaging:t}),[n,s,t]),c=(0,ae.useRef)(u);if(c.current!==u){let S=c.current[a][0],y=u.findIndex(C=>C.includes(S));c.current=u,i(y)}let d=(0,ae.useCallback)(g=>{let S=u.findIndex(y=>y.includes(g));i(S===-1?0:S)},[l,u]),v=(0,ae.useCallback)(g=>{let S=l.findIndex(y=>y.id===g);S!==-1?d(S):i(0)},[l,u]),h=(0,ae.useCallback)(()=>{i(g=>g>=u.length-1?g:g+1)},[u]),x=(0,ae.useCallback)(()=>{i(g=>g<=0?0:g-1)},[u]);return typeof a>"u"&&(e?v(e):i(0)),{visibleItems:u[a]?.map(g=>l[g].id)||[],cursor:a,items:l,sequence:u,hasPrevious:a>0,hasNext:a<u.length-1,setSequenceIndex:i,setCanvasIndex:d,setCanvasId:v,next:h,previous:x}}var ce=require("react"),Qe=require("zustand");var Yn=require("zustand/vanilla");function Da(e){let t=e.service||e.services||[];for(let n of t)if(n.type==="AuthProbeService2")return!0;return!1}function se(e,t,n){let r=t.findIndex(i=>i.service.id===e);if(r===-1)return t;let o=[...t],a=n(o[r]);return a===o[r]?t:(o[r]=a,o)}var Kn=()=>(0,Yn.createStore)((e,t)=>({currentAuth:-1,authItems:[],login:()=>{let n=t().authItems[t().currentAuth];if(!n||n.isPending||n.isLoggedIn)return;if(n.type!=="active")throw new Error("Cannot login to non-active service");let r=n.service.service.find(o=>o.type==="AuthAccessTokenService2");if(!r)throw new Error("Token service not found");e(()=>({authItems:se(n.id,t().authItems,o=>({...o,isPending:!0}))})),_n(n.service).then(()=>{Xt(r).then(o=>{let a=o.expiresIn,i=Date.now()+a*1e3;e(()=>({authItems:se(n.id,t().authItems,s=>({...s,isLoggedIn:!0,isPending:!1,session:{token:o.accessToken,expires:i}}))}))}).catch(o=>{e(()=>({authItems:se(n.id,t().authItems,a=>({...a,isLoggedIn:!1,isPending:!1,error:o.message}))}))})})},logout:()=>{let n=t().authItems[t().currentAuth];if(!n||n.isPending||!n.isLoggedIn)return;if(n.type!=="active")throw new Error("Cannot logout of non-active service");let r=n.service.service.find(i=>i.type==="AuthLogoutService2");if(!r)return;let o=`${r.id}?origin=${Io()}`,a=window.open(o);e(()=>({authItems:se(n.id,t().authItems,i=>({...i,isLoggedIn:!1,session:null,isPending:!1}))}))},nextAuth:()=>{let n=t().authItems.length,r=t().currentAuth+1;r>=n||e(()=>({currentAuth:r}))},previousAuth:()=>{let n=t().currentAuth-1;n<0||e(()=>({currentAuth:n}))},setAuth:n=>{n!==-1&&(n<0||n>=t().authItems.length)||e(()=>({currentAuth:n}))},addService:(n,r)=>{if(!n.service)return;let o=n.service.find(s=>s.type==="AuthAccessTokenService2"),a=n;if(t().authItems.find(s=>s.service.id===n.id)){e(()=>({authItems:se(n.id,t().authItems,s=>({...s,instances:s.instances+1}))}));return}if(e(()=>({currentAuth:a.profile==="active"?0:t().currentAuth,authItems:[{id:n.id,type:n.profile,service:n,probeId:r,canAuthenticate:!0,instances:1,isPending:!1,isLoggedIn:!1,session:null},...t().authItems]})),n.profile==="external"){if(!o)throw new Error("Token service not found");Xt(o).then(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!0,isPending:!1,session:{token:s.accessToken,expires:s.expiresIn}}))}))}).catch(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!1,isPending:!1,canAuthenticate:!1,error:s.message}))}))})}if(n.profile==="kiosk"){if(!o)throw new Error("Token service not found");e(()=>({authItems:se(n.id,t().authItems,s=>({...s,isPending:!0}))})),_n(a).then(()=>{Xt(o).then(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!0,isPending:!1,session:{token:s.accessToken,expires:s.expiresIn}}))}))}).catch(s=>{e(()=>({authItems:se(n.id,t().authItems,l=>({...l,isLoggedIn:!1,isPending:!1,error:s.message}))}))})})}n.profile},removeService:(n,r)=>{let o=t().currentAuth===t().authItems.findIndex(i=>i.service.id===n.id),a=t().currentAuth;if(o){let i=t().authItems.find(l=>l.service.id===n.id);i&&i.instances>1||(a=t().authItems.findIndex(u=>u.service.id!==n.id&&u.instances>0))}e(()=>({authItems:se(n.id,t().authItems,i=>({...i,instances:i.instances-1})),currentAuth:a}))}})),Qn=(e,t)=>(0,Yn.createStore)((n,r)=>({service:e,status:e?"unknown":"success",shouldRedirect:!1,redirectResource:null,shouldSubstitute:!1,substituteResource:null,error:null,errorHeading:null,errorNote:null,shouldDisplayResource:!1,token:t||null,async probe(){if(!r().service)return;let o=r().service?.id;if(!o){n({status:"error",error:"Service ID not found",errorHeading:{en:["Service ID not found"]}});return}n({status:"probing"});let a=r().token;try{let i=await fetch(o,{headers:a?{Authorization:`Bearer ${r().token}`,Accept:"application/json"}:{Accept:"application/json"}}).then(s=>s.json());if(i.status===200)n({status:"success",shouldDisplayResource:!0,error:null,errorHeading:null,errorNote:null,shouldSubstitute:!1,shouldRedirect:!1});else if(i.status<400&&i.status>=300){if(!i.location)throw new Error("Redirect location not found");n({status:"error",shouldDisplayResource:!1,shouldRedirect:!0,redirectResource:i.location||null})}else if(i.status===401)n({status:"error",shouldDisplayResource:!1,shouldRedirect:!1,shouldSubstitute:!!i.substitute,substituteResource:i.substitute||null,error:"Unauthorized",errorHeading:i.heading||{en:["Unauthorized"]},errorNote:i.note||null});else throw new Error("Unknown error")}catch(i){n({status:"error",error:i.message,errorHeading:{en:["Unknown error"]}})}},setToken(o){n({token:o})}}));function jn(e){let t=e.service||e.services||[],n={hasAuth:!1,services:{}};for(let r of t)if(r.type==="AuthProbeService2"){n.services.probe=r,n.hasAuth=!0;let o=r.service.filter(a=>a.type==="AuthAccessService2");o[0]&&(n.services.access=o[0])}return n}async function Xt(e,{strict:t=!0}={}){return new Promise((n,r)=>{let o=Math.random().toString(36).substring(7),a=`${e.id}?messageId=${o}&origin=${window.location.origin}`,i=u=>{let c=u.data;if(c.messageId===o){if(t&&c.type!=="AuthAccessToken2"){s(),r("Invalid response, expected type=AuthAccessToken2");return}if(!c.accessToken){s(),r("Invalid response, expected accessToken");return}s(),n(c)}},s=()=>window.removeEventListener("message",i),l=document.createElement("iframe");l.src=a,l.style.display="none",document.body.appendChild(l),window.addEventListener("message",i)})}function Io(e){let t=window.location;if(e){let n=document.createElement("a");return n.href=e,n.protocol+"//"+n.hostname+(n.port?":"+n.port:"")}return t.protocol+"//"+t.hostname+(t.port?":"+t.port:"")}async function _n(e){let t=`${e.id}?origin=${Io()}`,n=window.open(t);if(!n)throw new Error("Failed to open window");return new Promise((r,o)=>{let a=setInterval(()=>{n.closed&&(clearInterval(a),r())},500)})}var Ke=require("react");var wo=require("zustand");function ko(e){let t=(0,Ke.useMemo)(()=>jn(e),[e]),n=Gn(t.services.access?.id),r=(0,Ke.useMemo)(()=>Qn(t.services.probe,n),[t.services.probe]),o=(0,wo.useStore)(r);return(0,Ke.useEffect)(()=>{o.status==="unknown"&&!n&&o.probe()},[t.services.probe,o.status]),(0,Ke.useEffect)(()=>{n&&(o.setToken(n),o.probe())},[n]),[e,o,t.hasAuth]}var ft=require("react/jsx-runtime"),Ne=(0,ce.createContext)(null),Mo=(0,ce.createContext)(null);Mo.displayName="CurrentAuth";var Eo=(0,ce.createContext)(null);Eo.displayName="AuthActions";function Zn({children:e}){let t=(0,ce.useMemo)(()=>Kn(),[]);return(0,ft.jsx)(Ne.Provider,{value:t,children:e})}function Jn(){return!!(0,ce.useContext)(Ne)}function je(){let e=(0,ce.useContext)(Ne);if(!e)throw new Error("useAuthActions must be used within a AuthProvider");return e}function No(){let e=je();return(0,Qe.useStore)(e,n=>({login:n.login,logout:n.logout,nextAuth:n.nextAuth,previousAuth:n.previousAuth,setAuth:n.setAuth,addService:n.addService,removeService:n.removeService}))}function Fa(){let e=je();return(0,Qe.useStore)(e,t=>t)}function Vo(e){let t=je();return(0,Qe.useStore)(t,r=>r.authItems.find(o=>o.service.id===e))}function Gn(e){let t=je();return(0,Qe.useStore)(t,r=>r.authItems.find(o=>o.id===e)?.session?.token)}function qa(e){let t=je();return(0,Qe.useStore)(t,r=>{let o=r.authItems.find(a=>a.service.id===e);return!o||!o.isLoggedIn||!o.session?null:o.session?.token||null})}function Wa(e){let t=No(),n=Vo(e.service.id);return(0,ce.useEffect)(()=>(t?.addService(e.service,e.probeId),()=>{t?.removeService(e.service,e.probeId)}),[e.service]),n?(n.error||!n.isLoggedIn,e.children):null}function Xn(){return null}function er(e){let[t,n,r]=ko(e.resource),o=e.fallbackComponent||Xn,a=e.loadingComponent||Xn,i=e.errorComponent||Xn,s=n.service,l=null;if(!r||!s)return e.children(t);let u=s.service.filter(c=>c.type==="AuthAccessService2");n.status==="error"&&(l=(0,ft.jsx)(i,{resource:e.resource,error:n.error||"",heading:n.errorHeading,note:n.errorNote,extra:e.extra})),(n.status==="unknown"||n.status==="probing")&&(l=(0,ft.jsx)(a,{})),n.status==="success"&&(l=e.children(t));for(let c of u)l=(0,ft.jsx)(Wa,{service:c,probeId:s.id,children:l},c.id);return l}var pt=require("react");var Lo=require("zustand/vanilla"),$a=e=>e.id||e["@id"];function Ua(e){return(Array.isArray(e.service)?e.service:[e.service]).find(n=>n.profile==="http://iiif.io/api/search/0/autocomplete"||n.profile==="http://iiif.io/api/search/1/autocomplete"||n.profile==="AutoCompleteService1")}var zo=e=>{let t;typeof e=="string"?t={"@context":"http://iiif.io/api/search/1/context.json",profile:"http://iiif.io/api/search/1/search","@id":e,id:e,service:[]}:t=e;let n=t?$a(t):void 0,r=null;return(0,Lo.createStore)((o,a)=>({service:t,resources:[],lastQuery:{},loading:!1,error:!1,highlight:null,hasSearch:!!t,hasAutocomplete:t?!!Ua(t):!1,errorMessage:"",search(i,s={}){if(!n)throw new Error("No search service found.");r&&!r.signal.aborted&&r.abort(),r=new AbortController;let l=new URLSearchParams;i.q&&l.set("q",i.q),i.motivation&&l.set("motivation",i.motivation),i.date&&l.set("date",i.date),i.user&&l.set("user",i.user),o({loading:!0}),fetch(`${n}?${l.toString()}`,{signal:r.signal,headers:{"Content-Type":"application/json",Accept:"application/json",...s.headers||{}}}).then(async u=>{if(!r?.signal.aborted)if(u.ok){let c=await u.json();o({resources:c.resources,error:!1,errorMessage:""})}else o({resources:[],error:!0,errorMessage:u.statusText})})},clearSearch(){o({resources:[],error:!1,errorMessage:""})},highlightResult(i){let s=a().resources.find(l=>l["@id"]===i);o({highlight:s})},nextResult(){let i=a().resources,s=a().highlight;if(!s){o({highlight:i[0]||null});return}let l=i.findIndex(u=>u["@id"]===s["@id"]);if(l===-1){o({highlight:i[0]||null});return}o({highlight:i[l+1]||i[0]||null})},previousResult(){let i=a().resources,s=a().highlight;if(!s){o({highlight:i[i.length-1]||null});return}let l=i.findIndex(u=>u["@id"]===s["@id"]);if(l===-1){o({highlight:i[i.length-1]||null});return}if(l===0){o({highlight:i[i.length-1]||null});return}o({highlight:i[l-1]||i[i.length-1]||null})}}))};var _a=require("zustand");function tr(){let e=z();return e?e.service.find(t=>t.profile==="SearchService1"||t.profile==="http://iiif.io/api/search/1/search"):void 0}var Zt=require("react/jsx-runtime"),Ge=(0,pt.createContext)(null);Ge.displayName="Search";function Oo(e){let t=tr();return e.store?(0,Zt.jsx)(Ge.Provider,{value:e.store,children:e.children}):(0,Zt.jsx)(Ya,{service:t,children:e.children})}function Ya({service:e,children:t}){let n=(0,pt.useMemo)(()=>zo(e),[e]);return(0,Zt.jsx)(Ge.Provider,{value:n,children:t})}var G=require("react/jsx-runtime"),gt=()=>{},Xe=(0,Jt.createContext)({setCurrentCanvasId:gt,setCurrentCanvasIndex:gt,nextCanvas:gt,previousCanvas:gt,items:[],sequence:[],setSequenceIndex:gt,currentSequenceIndex:0,hasNext:!1,hasPrevious:!1});function Bo(e){let t=z(),{cursor:n,visibleItems:r,next:o,sequence:a,items:i,setCanvasIndex:s,setCanvasId:l,previous:u,setSequenceIndex:c,hasNext:d,hasPrevious:v}=Un({startCanvas:e.startCanvas,disablePaging:e.pagingEnabled===!1}),h=(0,Jt.useMemo)(()=>({sequence:a,items:i,setCurrentCanvasId:l,nextCanvas:o,previousCanvas:u,totalCanvases:i.length,setCurrentCanvasIndex:s,setSequenceIndex:c,currentSequenceIndex:n,hasNext:d,hasPrevious:v}),[a,i,l,o,u,i,s,c,n]);return t?r.length===0?null:(0,G.jsx)(Xe.Provider,{value:h,children:(0,G.jsx)(Me.Provider,{value:r,children:(0,G.jsx)(re,{canvas:r[0],children:e.children})})}):(console.warn("The manifest passed to the provider is not a valid IIIF manifest."),(0,G.jsx)("div",{children:"Sorry, something went wrong."}))}function nr(e){let t=ke(e.vault),n=Fn(e.manifest);if(!n)return console.warn("The manifest passed to the provider is not a valid IIIF manifest."),(0,G.jsx)("div",{children:"Sorry, something went wrong."});if(n.error)return(0,G.jsx)("div",{children:n.error.toString()});if(!n.isLoaded)return(0,G.jsx)("div",{children:"Loading..."});let r=(0,G.jsx)(Bo,{...e,children:e.children});return(0,G.jsx)(we,{vault:t,children:(0,G.jsx)(qn,{manifest:n.id,children:(0,G.jsx)(Zn,{children:(0,G.jsx)(Oo,{children:e.rangeId?(0,G.jsx)(Wn,{range:e.rangeId,children:r}):r})})})})}function ht(){return(0,Ho.useContext)(Xe)}var Do=j(require("react"),1),en=require("react"),Fo=j(require("mitt"),1),Wo=require("react/jsx-runtime"),qo=(0,Fo.default)(),Ve=(0,en.createContext)({emitter:qo});Ve.displayName="Events";function yt(){return Do.default.useContext(Ve).emitter}function Ka({emitter:e,children:t}){return(0,Wo.jsx)(Ve.Provider,{value:(0,en.useMemo)(()=>({emitter:e}),[e]),children:t})}var $o=j(require("react"),1),me=require("react/jsx-runtime"),rr=$o.default.createContext({});function or(){let e=(0,ee.useContext)(rr),t=Object.keys(e),n={};for(let r of t)e[r].Provider&&(n[r]={value:(0,ee.useContext)(e[r]),Provider:e[r].Provider});return n}function Uo(e){let t=Object.keys(e),n=e.children;for(let r of t){if(r==="children")continue;let{value:o,Provider:a}=e[r];n=(0,me.jsx)(a,{value:o,children:n})}return n}function Qa(e){let t=(0,ee.useContext)(rr),n=(0,ee.useMemo)(()=>({...t,...e.providers}),[e.providers]);return(0,me.jsx)(rr.Provider,{value:n,children:e.children})}function ir(){return{VaultContext:(0,ee.useContext)(ve),ResourceContext:(0,ee.useContext)(lt),SimpleViewerReactContext:(0,ee.useContext)(Xe),VisibleCanvasReactContext:(0,ee.useContext)(Me),AuthRContext:(0,ee.useContext)(Ne),SearchReactContext:(0,ee.useContext)(Ge),ReactEventContext:(0,ee.useContext)(Ve)}}function ar(e){return(0,me.jsx)(we,{vault:e.bridge.VaultContext.vault||void 0,resources:e.bridge.ResourceContext,children:(0,me.jsx)(Me.Provider,{value:e.bridge.VisibleCanvasReactContext,children:(0,me.jsx)(Xe.Provider,{value:e.bridge.SimpleViewerReactContext,children:(0,me.jsx)(Ve.Provider,{value:e.bridge.ReactEventContext,children:(0,me.jsx)(Ne.Provider,{value:e.bridge.AuthRContext,children:(0,me.jsx)(Ge.Provider,{value:e.bridge.SearchReactContext,children:e.custom?(0,me.jsx)(Uo,{...e.custom,children:e.children}):e.children})})})})})})}var Ze=require("react");var fe=require("react");var tn=require("@iiif/helpers/vault/actions");var _o=require("react");function sr(){let t=T().getStore();return(0,_o.useMemo)(()=>n=>t.dispatch(n),[t])}function Yo(e){return typeof e!="string"&&e&&e.bindToVault}function cr(){let e=T(),t=(0,fe.useRef)([]),n=sr(),r=(0,fe.useMemo)(()=>`vault://annotation-page/${new Date().getTime()}/${Math.round(Math.random()*1e9).toString(16)}`,[]);(0,fe.useLayoutEffect)(()=>{let s={id:r,type:"AnnotationPage",behavior:[],label:null,thumbnail:[],summary:null,requiredStatement:null,metadata:[],rights:null,provider:[],items:[],seeAlso:[],homepage:[],rendering:[],service:[]};n(tn.entityActions.importEntities({entities:{AnnotationPage:{[s.id]:s}}}))},[r]);let o=w(s=>r&&s.iiif.entities.AnnotationPage[r]||null,[r]),a=(0,fe.useCallback)((s,l)=>{if(r){if(Yo(s)){let d=s;d.__vault||d.bindToVault(e),s=typeof d.source=="string"?d.source:d.source.id,t.current[s]=d}else typeof s!="string"&&(s=s.id);let u=e.get({id:r,type:"AnnotationPage"}),c=e.get({id:s,type:"Annotation"});u&&c&&(u.items.find(d=>d.id===c.id)||n(tn.entityActions.addReference({id:r,type:"AnnotationPage",key:"items",reference:{id:s,type:"Annotation"},index:l})))}},[r]),i=(0,fe.useCallback)(s=>{r&&(Yo(s)?s=typeof s.source=="string"?s.source:s.source.id:typeof s!="string"&&(s=s.id),t.current[s]&&t.current[s].beforeRemove(),e.get({id:r,type:"AnnotationPage"})&&n(tn.entityActions.removeReference({id:r,type:"AnnotationPage",key:"items",reference:{id:s,type:"Annotation"}})))},[r]);return[o,{addAnnotation:a,removeAnnotation:i}]}var Qo=require("react/jsx-runtime"),Ko=(0,Ze.createContext)(null);function lr(){let e=(0,Ze.useContext)(Ko);return[e.fullPage,{addAnnotation:e.addAnnotation,removeAnnotation:e.removeAnnotation}]}function ur({children:e}){let[t,{addAnnotation:n,removeAnnotation:r}]=cr();return(0,Qo.jsx)(Ko.Provider,{value:(0,Ze.useMemo)(()=>({fullPage:t,addAnnotation:n,removeAnnotation:r}),[t]),children:e})}var Je=require("react/jsx-runtime");function nn({width:e,style:t,height:n,error:r,resetErrorBoundary:o}){return(0,Je.jsxs)("div",{style:{width:e,height:n,minHeight:500,...t||{},background:"#f9f9f9"},children:[(0,Je.jsx)("h3",{children:"Error occurred"}),(0,Je.jsx)("p",{children:r.message}),(0,Je.jsx)("button",{type:"button",onClick:o,children:"Reset"})]})}var rn=require("react"),oe=(0,rn.createContext)(null);function vt(){return(0,rn.useContext)(oe)}var Le=require("react"),mr=(0,Le.createContext)(()=>{}),dr=(0,Le.createContext)(()=>{});function D(e,t,n,r,o=[]){let a=(0,Le.useContext)(e==="portal"?dr:mr);(0,Le.useEffect)(()=>(e!=="none"&&a(t,n,r),()=>{a(t,null)}),[t,e,a,...o])}var et=require("react");var jo=require("react");function P(e={},t=[]){let{id:n,selector:r}=e,o=W(),a=n||o.canvas,i=w(s=>a?s.iiif.entities.Canvas[a]:void 0,[a]);return(0,jo.useMemo)(()=>{if(i)return r?r(i):i},[i,r,...t])}var fr=(0,et.createContext)(()=>{});function Go(e){let t=P(),n=(0,et.useContext)(fr);(0,et.useEffect)(()=>t&&t.id?(n(t.id,e),()=>n(t.id,-1)):()=>{},[t,e])}var O=require("react/jsx-runtime");function an({children:e,errorFallback:t,outerContainerProps:n={},worldScale:r,...o}){let[a,i]=(0,U.useState)(),s=or(),l=ir(),u=t||nn,[c,d]=(0,U.useState)({}),v=Object.entries(c),[h,x]=(0,U.useState)({}),g=Object.entries(h),[S,y]=(0,U.useState)({}),C=(0,U.useMemo)(()=>r||Math.max(...Object.values(S)),[S]),m=(0,U.useMemo)(()=>({maxOverZoom:C||1,...o.runtimeOptions||{}}),[C,o.runtimeOptions]),b=(0,U.useCallback)((I,R)=>{y(B=>{if(R===-1){let{[I]:_e,...k}=B;return k}return{...B,[I]:R}})},[]),A=(0,U.useCallback)((I,R,B)=>{d(({[I]:_e,...k})=>R?{...k,[I]:{element:R,props:B}}:k)},[]),M=(0,U.useCallback)((I,R,B)=>{x(({[I]:_e,...k})=>R?{...k,[I]:{element:R,props:B}}:k)},[]);return(0,O.jsxs)(Xo.ErrorBoundary,{resetKeys:[],fallbackRender:I=>(0,O.jsx)(u,{...o,...I}),children:[(0,O.jsx)(on.AtlasAuto,{...o,containerProps:{style:{position:"relative"},...o.containerProps||{}},htmlChildren:(0,O.jsx)(O.Fragment,{children:v.map(([I,{element:R,props:B}])=>(0,O.jsx)(U.default.Fragment,{children:(0,O.jsx)(R,{...B||{}})},I))}),onCreated:I=>{i(I),o.onCreated&&o.onCreated(I)},runtimeOptions:m,children:(0,O.jsx)(oe.Provider,{value:a,children:(0,O.jsx)(fr.Provider,{value:b,children:(0,O.jsx)(mr.Provider,{value:A,children:(0,O.jsx)(dr.Provider,{value:M,children:(0,O.jsx)(ar,{bridge:l,custom:s,children:(0,O.jsx)(on.ModeContext.Provider,{value:o.mode||"explore",children:(0,O.jsx)(ur,{children:e})})})})})})})}),(0,O.jsx)("div",{children:g.map(([I,{element:R,props:B}])=>(0,O.jsx)(U.default.Fragment,{children:(0,O.jsx)(R,{...B||{}})},I))})]})}var sn=require("@atlas-viewer/atlas");var pr=require("react"),Zo=require("@iiif/helpers/events");function St(e,t){let n=T(),r=(0,pr.useMemo)(()=>(0,Zo.createEventsHelper)(n),[n]),o=w(()=>e&&e.id?n.getResourceMeta(e.id,"eventManager"):null,[e]);return(0,pr.useMemo)(()=>e?r.getListenersAsProps(e,t):{},[o,e,n,t])}var Jo=require("react"),ei=require("@iiif/helpers/styles");function ze(e,t){let n=T(),r=(0,Jo.useMemo)(()=>(0,ei.createStylesHelper)(n),[n]);return w(()=>{if(!e)return null;let o=r.getAppliedStyles(e.id);return o?t?o[t]:o:void 0},[e,t])}var ri=require("react");var ti=require("react");var ni=require("@iiif/helpers/annotation-targets");function xt(e={},t=[]){let{id:n,selector:r}=e,o=W(),a=T(),i=n||o.annotation,s=w(u=>i?u.iiif.entities.Annotation[i]:void 0,[i]),l=w(u=>s&&s.body?s.body.map(c=>c?c.type==="SpecificResource"?{...c,source:a.get(c)}:c?u.iiif.entities[c.type][c.id]:null:null).filter(Boolean):[],[s]);return(0,ti.useMemo)(()=>{if(!s)return;let u={...s,body:l,target:(0,ni.expandTarget)(s.target,{typeMap:a.getState().iiif.mapping})};return r?r(u):u},[s,r,l,...t])}var oi=require("react/jsx-runtime"),cn=({id:e,style:t,className:n,interactive:r})=>{let o=xt({id:e}),a=ze(o,"atlas"),i=ze(o,"html"),s=St(o,["atlas"]),l=P(),u=(0,ri.useMemo)(()=>(0,sn.mergeStyles)(t,a),[t,a]);return l&&o&&o.target&&o.target.selector&&o.target.selector.type==="BoxSelector"&&o.target.source&&(o.target.source.id===l.id||o.target.source===l.id)?(0,oi.jsx)(sn.RegionHighlight,{id:o.id,isEditing:!0,region:o.target.selector.spatial,style:u,className:i?.className||n,interactive:!!(i?.href||r),href:i?.href||null,title:i?.title||null,hrefTarget:i?.target||null,onClick:()=>{},...s}):null};var ai=require("react");var ii=require("react");function gr(e={},t=[]){let{id:n,selector:r}=e,o=W(),a=n||o.annotationPage,i=w(s=>a?s.iiif.entities.AnnotationPage[a]:void 0,[a]);return(0,ii.useMemo)(()=>{if(i)return r?r(i):i},[i,...t])}var hr=require("react/jsx-runtime"),Ct=({className:e,page:t})=>{let n=gr({id:t.id})||t,r=ze(n,"atlas"),o=ze(n,"html");return w(a=>n.id?a.iiif.entities.AnnotationPage[n.id]:null,[]),(0,hr.jsx)(ai.Fragment,{children:n.items?.map(a=>(0,hr.jsx)(cn,{id:a.id,style:r,className:o?.className||e},a.id))})};var xe=require("react");var nt=require("react");var si=require("@iiif/helpers");function ja(e){return e.type==="SpecificResource"?[e.source,{selector:e.selector}]:[e,{selector:null}]}function bt(e,t){let{selector:n,source:r}=(0,si.expandTarget)(t);if(r.id!==e.id)return[null,r];let o={type:"BoxSelector",spatial:{x:0,y:0,width:Number(e.width),height:Number(e.height)}};return[n?n.type==="TemporalSelector"?{type:"TemporalBoxSelector",temporal:n.temporal,spatial:o.spatial}:n:null,r]}var yr={makeChoice:()=>{}},Rt={type:"unknown"},E=e=>({type:"unknown",reason:e,annotations:{pages:[]}}),vr=(e,t)=>({type:"empty",width:e,height:t,annotations:{pages:[]},image:null,images:[]});var Pt=require("react");function Ga(e,t){let n=e?.iiif?.meta[t];return n?n.annotationPageManager:null}function ci(e,t){return w(n=>{let r=[];if(!e)return r;let o=Object.keys(n.iiif.entities.AnnotationPage);for(let a of o)if(!t||t.indexOf(a)!==-1){let i=Ga(n,a);i&&i.views&&i.views[e]&&r.push(a)}return r},[e,t])}function Sr({canvas:e,manifest:t,all:n,canvases:r}){let o=[];if(t)for(let a of t.annotations)o.indexOf(a.id)===-1&&o.push(a.id);if(n){if(r&&r.length)for(let a of r)for(let i of a.annotations)o.indexOf(i.id)===-1&&o.push(i.id)}else if(e)for(let a of e.annotations)o.indexOf(a.id)===-1&&o.push(a.id);return o}function Xa(e,t){let n=e?.iiif?.meta[t];return n?n.annotationPageManager:null}function At(e,t={}){let n=T(),r=z(),o=P(),a=Ee(),i=(0,Pt.useMemo)(()=>Sr({all:t.all,manifest:r,canvas:o,canvases:a}),[t.all,o,a,r]),s=ci(e,t.all?void 0:i),l=(0,Pt.useCallback)(c=>{e&&n.setMetaValue([c,"annotationPageManager","views"],d=>d&&!d[e]?d:{...d||{},[e]:!1})},[e,n]),u=(0,Pt.useCallback)((c,d={})=>{if(!e)return;let v=n.getState(),h=[];if(d?.deselectOthers){let x=Object.keys(v.iiif.entities.AnnotationPage);for(let g of x){let S=Xa(v,g);S&&S.views&&S.views[e]&&h.push(g)}}for(let x of h)l(x);n.setMetaValue([c,"annotationPageManager","views"],x=>x&&x[e]?x:{...x||{},[e]:!0})},[e,l,n]);return{availablePageIds:i,enabledPageIds:s,setPageEnabled:u,setPageDisabled:l}}function xr(e,t){return w((n,r)=>r.get(e.map(o=>({id:o,type:t}))),[e,t])}var pi=j(require("mitt"),1),gi=require("react"),hi=require("zustand");var ln=j(require("react"),1),li=require("@iiif/helpers/image-service"),Tt=require("zustand"),ui=ln.default.createContext(li.imageServices.store);ui.displayName="ImageServicesHelper";function un(){return(0,ln.useContext)(ui)}function mi(e){let t=un();return(0,Tt.useStore)(t,({loaded:n})=>n[e])}function tt(){let e=un();return(0,Tt.useStore)(e,({loadServiceSync:t})=>t)}function di(){let e=un();return(0,Tt.useStore)(e,({loaded:t})=>t)}function fi(){let e=un();return(0,Tt.useStore)(e,({loadService:t})=>t)}var Za=(0,hi.createStore)((e,t)=>({loaded:{},setLoaded:(n,r="done")=>{e(o=>({loaded:{...o.loaded,[n]:r}}))}})),Ja=(0,pi.default)();Ja.on("loaded",e=>{Za.getState().setLoaded(e.imageServiceId)});function It(){let e=tt(),t=di();return[(0,gi.useCallback)((r,{height:o,width:a})=>r&&e(r,{height:o,width:a},!0),[e]),t]}var He=require("react");function Oe(e={}){let t=xt(),n=P(e.canvasId?{id:e.canvasId}:void 0);return w((r,o)=>{if(!n)return[];if(t&&e.enableSingleAnnotation)return[t];let a=o.get(n.items),i=[];for(let s of a)i.push(...o.get(s.items));return i},[n])}var yi=require("@iiif/helpers/painting-annotations");function Cr(e,t=[]){let n=T(),r=(0,He.useMemo)(()=>(0,yi.createPaintingAnnotationsHelper)(n),[]),o=Oe({enableSingleAnnotation:e?.enableSingleAnnotation}),[a,i]=(0,He.useState)(e?.defaultChoices||[]),s=(0,He.useMemo)(()=>r.getPaintables(o,a),[n,o,a,...t]),u={makeChoice:(0,He.useCallback)((c,{deselectOthers:d=!0,deselect:v=!1}={})=>{s.choice&&i(h=>{if(v){let g=h.filter(S=>S!==c);if(g.length===0){let S=s.items[0].resource.id;return S?[S]:[]}return g}if(d)return[c];let x=[...h];if(x.length===0&&s.items.length){let g=s.items[0].resource.id;g&&x.push(g)}return h.indexOf(c)!==-1?h:[...h,c]})},[s.choice])};return[s,u]}var es=["model/gltf-binary"];function br(e,t){let n=t.items[0],r=n.resource;return r.format?es.indexOf(r.format)===-1?E(`3D format: ${r.format} is unsupported`):{type:"3d-model",model:r,annotationId:n.annotationId,annotation:n.annotation}:E("Unknown format")}function vi(e,t){let n=t.items,r=n[0];if(n.length===0||!r)return E("No audio");if(!e.duration)return E("No duration on canvas");if(n.length>1)return E("Only one audio source supported");let o=r.resource;return o?"format"in o?{type:"media",media:{annotationId:r.annotationId,annotation:r.annotation,duration:e.duration,url:o.id,type:"Sound",target:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}},format:o.format,selector:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}}},annotations:{pages:[]}}:E("Audio does not have format"):E("Unknown audio")}var Si=require("@iiif/parser/image-3");var Rr=require("@iiif/helpers/annotation-targets");function wt(e,t,n){let r=[];for(let o of t.items){let a=o.resource&&o.resource.type==="SpecificResource"?o.resource.source:o.resource;if(!a.id)return E("No resource Identifier");let i;if(a.service){let g=(0,Si.getImageServices)(a);g[0]&&(i=n(g[0],e))}let s={type:"BoxSelector",spatial:{x:0,y:0,width:Number(e.width),height:Number(e.height)}},[l,u]=bt(e,o.target),c=e.id?.split("?")[0]||"";if(!(u.id===e.id||decodeURIComponent(u.id||"")===(e.id||"")||u.id===c||decodeURIComponent(u.id||"")===c))continue;let d=o.resource.width&&o.resource.height?{type:"BoxSelector",spatial:{x:0,y:0,width:o.resource.width,height:o.resource.height}}:void 0,v=o.resource.type==="SpecificResource"?(0,Rr.expandTarget)(o.resource):null;if(o.selector){let g=(0,Rr.expandTarget)({type:"SpecificResource",source:o.resource,selector:o.selector});g&&(v=g)}let h=v&&v.selector&&(v.selector.type==="BoxSelector"||v.selector.type==="TemporalBoxSelector")?{type:"BoxSelector",spatial:{x:v.selector.spatial.x,y:v.selector.spatial.y,width:v.selector.spatial.width,height:v.selector.spatial.height}}:void 0;i&&!i.id&&(i.id=i["@id"]);let x={id:a.id,type:"Image",annotationId:o.annotationId,annotation:o.annotation,width:Number(l||h?a.width:e.width),height:Number(l||h?a.height:e.height),service:i,sizes:i&&i.sizes?i.sizes:a.width&&a.height?[{width:a.width,height:a.height}]:[],target:l&&l.type!=="PointSelector"?l:s,selector:h||{type:"BoxSelector",spatial:{x:0,y:0,width:Number(e.width),height:Number(e.height)}}};r.push(x)}return{type:"images",image:r[0],images:r,choice:t.choice}}function xi(e,t={},n){let r=e.language||n||"none";switch(e.type){case"TextualBody":{typeof e.value<"u"&&(t[r]=[e.value]);break}case"List":case"Composite":case"Choice":e.items&&e.items.forEach(o=>xi(o,t,r))}return t}function kt(e,t){let n=[];return t.items.forEach(r=>{if(r.resource){let[o]=bt(e,r.target);n.push({type:"Text",annotationId:r.annotationId,annotation:r.annotation,text:xi(r.resource),target:o})}}),{type:"textual-content",items:n}}var mn=require("@iiif/helpers"),ts=/^.*(?:(?:youtu\.be\/|v\/|vi\/|u\/\w\/|embed\/|shorts\/)|(?:(?:watch)?\?vi?=|&vi?=))([^#&?]*).*/;function Mt(e,t,n){let r=t.items.filter(h=>h.type==="video"),o=r[0],a=!1;if(e.duration||(a=!0),r.length>1||!o)return E("Only one video source supported");let i=r[0]?.resource,s=!!(i.service||[]).find(h=>(h.profile||"").includes("youtube.com"));if(!s&&a)return E("Video does not have duration");if(!i)return E("Unknown video");if((!i.format||i.format==="text/html")&&!s)return E("Video does not have format");let l=[],u=n.get(e.annotations||[]);for(let h of u){let x=n.get(h.items||[]);for(let g of x)if((g.motivation?Array.isArray(g.motivation||"")?g.motivation:[g.motivation]:[]).includes("supplementing")){let y=n.get(g.body||[]);for(let C of y){let m=C;if(m.type==="Choice")for(let b of m.items){let A=n.get(b);A.format==="text/vtt"&&l.push({id:A.id,type:"Text",format:"text/vtt",label:A.label,language:A.language})}else m.format==="text/vtt"&&l.push({id:m.id,type:"Text",format:"text/vtt",label:m.label,language:m.language})}}}let c={annotationId:o.annotationId,annotation:o.annotation,duration:e.duration,url:i.id,type:"Video",target:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}},format:i.format,selector:{type:"TemporalSelector",temporal:{startTime:0,endTime:e.duration}}},d=(0,mn.expandTarget)(o.target);d.selector&&d.selector.type==="TemporalBoxSelector"&&(c.target=d.selector);let{selector:v}=(0,mn.parseSelector)(o.selector);if(v===null){let h=c.target.temporal.startTime,g=(c.target.temporal.endTime||e.duration)-h;c.selector={type:"TemporalSelector",temporal:{startTime:0,endTime:g}}}else v.type==="TemporalSelector"&&(c.selector=v);if(s){c.type="VideoYouTube";let h=i.id.match(ts);if(!h[1])return E("Video is not known youtube video");c.youTubeId=h[1]}return{type:"media",media:c,annotations:{pages:[]},captions:l}}function Pr(e,t,n,r){let o={type:"complex-timeline",items:[],keyframes:[],duration:e.duration||0},a={type:"complex-choice",items:[]};function i(u){u.choice&&(u.choice.type==="complex-choice"?a.items.push(...u.choice.items):a.items.push(u.choice))}for(let u of t.items){if(u.type==="image"){let c=wt(e,{choice:null,allChoices:null,types:["image"],items:[u]},n);if(c.type==="images"){i(c),o.items.push(c.image);let d={id:c.image.annotationId,type:"enter",resourceType:"image",time:c.image.target?.temporal?.startTime||0};o.keyframes.push(d);let v={id:c.image.annotationId,type:"exit",resourceType:"image",time:c.image.target?.temporal?.endTime||e.duration||0};o.keyframes.push(v)}}if(u.type==="textualbody"){let c=kt(e,{choice:null,allChoices:null,types:["textualbody"],items:[u]});if(c.type==="textual-content"){i(c);let d=c.items[0];o.items.push(d);let v=d.target,h={id:d.annotationId,type:"enter",resourceType:"text",time:v.temporal?.startTime||0};o.keyframes.push(h);let x={id:d.annotationId,type:"exit",resourceType:"text",time:v.temporal?.endTime||e.duration||0};o.keyframes.push(x)}}if(u.type==="video"){let c=Mt(e,{choice:null,allChoices:null,types:["video"],items:[u]},r);if(c.type==="media"){i(c);let d=c.media;o.items.push(d);let v={id:d.annotationId,type:"enter",resourceType:"video",time:d.target?.temporal?.startTime||0};o.keyframes.push(v);let h={id:d.annotationId,type:"exit",resourceType:"video",time:d.target?.temporal?.endTime||e.duration||0};o.keyframes.push(h)}}}o.keyframes.sort((u,c)=>u.time-c.time);let s=[],l=[];for(let u of o.keyframes){if(u.resourceType==="image"||u.resourceType==="text"){l.push(u);continue}if(u.type==="enter"){s.length===0&&(u.isPrime=!0),s.push(u),l.push(u);continue}if(u.type==="exit"&&(l.push(u),s=s.filter(c=>c.id!==u.id),s.length!==0)){let c=s[0],d={id:c.id,type:"change",isPrime:!0,resourceType:c.resourceType,time:u.time};l.push(d)}}return o.keyframes=l,a.items.length&&(o.choice=a),o}var dn={},Ar={get(e){return e},setMetaValue([e,t,n],r){let o=Ar.getResourceMeta(e,t),a=o?o[n]:void 0,i=typeof r=="function"?r(a):r;dn[e]={...dn[e]||{},[t]:{...(dn[e]||{})[t]||{},[n]:i}}},getResourceMeta:(e,t)=>{let n=dn[e];if(n)return t?n[t]:n},async load(e){let t=typeof e=="string"?e:e.id;return fetch(t).then(n=>n.json())},requestStatus(e){}};function Tr({canvas:e,paintables:t,supports:n,loadImageService:r,vault:o=Ar}){if(!e)return Rt;if(t.types.length===0)return n.indexOf("empty")!==-1?vr(e.width,e.height):Rt;if(t.types.length!==1)if(t.types.length===2&&t.types.indexOf("text")!==-1)t.types=t.types.filter(i=>i!=="text");else return n.indexOf("complex-timeline")===-1?E("Complex timeline not supported"):Pr(e,t,r,o);let a=t.types[0];return a==="image"?n.indexOf("images")===-1?E("Image not supported"):wt(e,t,r):a==="Model"||a==="model"?n.indexOf("3d-model")===-1?E("3D not supported"):br(e,t):a==="textualbody"?n.indexOf("textual-content")===-1?E("Textual content not supported"):kt(e,t):a==="sound"||a==="audio"?n.indexOf("media")===-1?E("Media not supported"):vi(e,t):a==="video"?n.indexOf("media")===-1?E("Media not supported"):Mt(e,t,o):Rt}function Ir(e){let t=z(),n=P(),r=T(),o=yt(),a=e?.emitter||o,[i,s]=It(),{enabledPageIds:l}=At(e?.annotationPageManagerId||t?.id||n?.id,{all:!1}),u=xr(l,"AnnotationPage"),c=e?.strategies||["empty","images","media","textual-content","complex-timeline"],[d,v]=Cr(e,[s]);(0,nt.useEffect)(()=>{let x=g=>{v.makeChoice(g.choiceId,{deselectOthers:g.deselectOthers,deselect:g.deselect})};return a.on("make-choice",x),()=>{a.off("make-choice",x)}},[]);let h=(0,nt.useMemo)(()=>Tr({canvas:n,paintables:d,supports:c,loadImageService:i,vault:r}),[n,d,r,v.makeChoice]);return(0,nt.useEffect)(()=>{let x=d.allChoices,g={canvasId:n?.id,manifestId:t?.id};x&&a.emit("choice-change",{choice:x,partOf:g})},[n?.id,d.allChoices]),(0,nt.useMemo)(()=>h.type==="unknown"?[h,yr]:[{...h,annotations:{pages:u}},v],[h,u])}var fn=require("react"),Et=(0,fn.createContext)(null);Et.displayName="Strategy";function V(){let e=(0,fn.useContext)(Et);if(!e)throw new Error("useStrategy must be used within a StrategyProvider");return e}var Ci=require("@iiif/helpers");var pn=require("react"),Nt=(0,pn.createContext)(null);Nt.displayName="Controls";function _(){let e=(0,pn.useContext)(Nt);if(!e)throw new Error("useStrategy must be used within a StrategyProvider");return e}var wr=require("react/jsx-runtime");function kr({strategies:e,registerActions:t,defaultChoices:n,onChoiceChange:r,mediaControlsDeps:o,renderMediaControls:a,renderViewerControls:i,viewControlsDeps:s,renderComplexTimelineControls:l,complexTimelineControlsDeps:u,throwOnUnknown:c,children:d}){let v=P(),h=T(),x=(0,xe.useMemo)(()=>(0,Ci.createStylesHelper)(h),[h]),[g,S]=Ir({strategies:e||["images"],defaultChoices:n?.map(({id:b})=>b)}),y="choice"in g?g.choice:void 0;if((0,xe.useEffect)(()=>{t&&t(S)},[g.annotations]),(0,xe.useEffect)(()=>{r&&r(y)},[y]),(0,xe.useEffect)(()=>{if(n)for(let b of n)typeof b.opacity<"u"&&x.applyStyles({id:b.id},"atlas",{opacity:b.opacity})},[n]),g.type==="unknown"&&c)throw new Error(g.reason||"Unknown strategy");let C=(0,xe.useMemo)(()=>({renderMediaControls:a,mediaControlsDeps:o||[],renderViewerControls:i,viewControlsDeps:s||[],renderComplexTimelineControls:l,complexTimelineControlsDeps:u||[]}),[o,a,i,s,l,u]),m=(0,xe.useMemo)(()=>({strategy:g,actions:S,choices:"choice"in g?g.choice:[]}),[g,v]);return(0,wr.jsx)(Nt.Provider,{value:C,children:(0,wr.jsx)(Et.Provider,{value:m,children:d})})}var bi=require("react");var Ri=require("react/jsx-runtime");function Mr({x:e=0,y:t=0,keepCanvasScale:n,children:r}){let{strategy:o}=V(),a=P(),i=St(a,["deep-zoom"]),s=(0,bi.useMemo)(()=>n?1:Math.max(1,...o.type==="images"?o.images.map(u=>(u.width||0)/u.target?.spatial.width):[]),[n,o]);Go(s);let l=o.type==="images"?o.images.length:0;return a?(0,Ri.jsx)("world-object",{height:a.height,width:a.width,x:e,y:t,...i,children:r},`${a.id}/${o.type}/${l}`):null}var Pi=require("react/jsx-runtime");function gn({style:e}){let t=P();return!t||!t.height||!t.width?null:(0,Pi.jsx)("box",{interactive:!1,target:{x:0,y:0,width:Number(t.width),height:Number(t.height)},style:e})}var Ai=require("react/jsx-runtime");function Er({backgroundStyle:e,alwaysShowBackground:t}){let{strategy:n}=V();return n.type!=="empty"&&!t?null:(0,Ai.jsx)(gn,{style:e})}var xn=require("react");var wi=j(require("mitt"),1);var L=require("react");function Ti(e){return{isMuted:!1,playRequested:!1,isPlaying:!1,isFinished:!1,volume:100,duration:e}}function ns(e,t){switch(t.type){case"RESET":return t.state;case"FINISHED":return{...e,isFinished:!0,isPlaying:!1,playRequested:!1};case"PLAY_PAUSE":return{...e,isFinished:!1,isPlaying:!e.isPlaying};case"PLAY_REQUESTED":return{...e,isFinished:!1,playRequested:!0};case"PAUSE":return{...e,isPlaying:!1};case"PLAY":return{...e,isFinished:!1,playRequested:!1,isPlaying:!0};case"MUTE":return{...e,isMuted:!0};case"SET_VOLUME":return{...e,volume:t.volume,isMuted:t.volume===0};case"TOGGLE_MUTE":return{...e,isMuted:!e.isMuted};case"UNMUTE":return{...e,isMuted:!1}}return e}function hn(e){let t=Math.round(e);return`${Math.floor(t/60)}:${`${t%60}`.padStart(2,"0")}`}function Be(e){let[t,n]=(0,L.useReducer)(ns,Ti(e.duration));(0,L.useEffect)(()=>{n({type:"RESET",state:Ti(e.duration)})},[e.duration]);let r=(0,L.useRef)(null),o=(0,L.useRef)(null),a=(0,L.useRef)(null),i=(0,L.useRef)(!1),s=(0,L.useCallback)(()=>{o.current&&r.current&&(o.current.innerHTML=hn(r.current.currentTime),a.current&&(a.current.style.width=`${r.current.currentTime/e.duration*100}%`),i.current!==r.current.muted&&(i.current=r.current.muted,n(r.current.muted?{type:"MUTE"}:{type:"UNMUTE"})))},[e.duration]),l=(0,L.useCallback)(()=>{r.current&&(n({type:"PLAY_REQUESTED"}),r.current.play().then(()=>{n({type:"PLAY"})}),s())},[s]),u=(0,L.useCallback)(()=>{r.current&&(r.current.duration>0&&r.current.paused?l():c())},[s]),c=(0,L.useCallback)(()=>{r.current&&(r.current.pause(),n({type:"PAUSE"}),s())},[s]),d=(0,L.useCallback)(()=>{r.current&&(r.current.muted=!r.current.muted,n(r.current.muted?{type:"MUTE"}:{type:"UNMUTE"}))},[]),v=(0,L.useCallback)(()=>{r.current&&(r.current.muted=!0,n({type:"MUTE"}))},[]),h=(0,L.useCallback)(()=>{r.current&&(r.current.muted=!1,n({type:"UNMUTE"}))},[]),x=(0,L.useCallback)(y=>{r.current&&(r.current.muted=!1,r.current.volume=y/100,n({type:"SET_VOLUME",volume:y}))},[]),g=(0,L.useCallback)(y=>{r.current&&(r.current.currentTime=Math.max(0,Math.min(y*e.duration,e.duration)),s())},[]),S=(0,L.useCallback)(y=>{if(r.current){let C=typeof y=="function"?y(r.current.currentTime):y;r.current.currentTime=Math.max(0,Math.min(C,e.duration)),s()}},[]);return(0,L.useEffect)(()=>{let y=setInterval(()=>{s()},350);return()=>clearInterval(y)},[s,e.duration]),(0,L.useEffect)(()=>{let y=()=>{n({type:"FINISHED"})},C=r.current;return C?.addEventListener("ended",y),()=>C?.removeEventListener("ended",y)},[]),[{element:r,currentTime:o,progress:a},t,{play:l,pause:c,playPause:u,mute:v,unmute:h,toggleMute:d,setVolume:x,setDurationPercent:g,setTime:S}]}var ki=require("zustand/vanilla");function Ii({currentKeyFrameIndex:e,keyframes:t,targetTime:n,currentTime:r}){if(r<=n){let o=t.findIndex(s=>s.time>n);if(o===-1)return[e,[]];let a={},i=t.slice(e,o);for(let s of i)s.type==="enter"&&(a[s.id]=s),s.type==="exit"&&(a[s.id]?delete a[s.id]:a[s.id]=s);return[o,Object.values(a)]}return[e,[]]}function Mi({complexTimeline:e,startTime:t=0}){let n=(0,wi.default)(),r={},o={progress:null,currentTime:null},a=0,i=null,s=0,l=null;function u(){let C=S.getState().visibleElements,m=r,b=[],A=Object.keys(m);for(let M of A){let I=m[M],R=C[M];I&&R&&b.push(I)}return b}function c(){return Object.keys(r).map(C=>r[C])}function d(y){o.currentTime&&(o.currentTime.innerHTML=hn(y),o.progress&&(o.progress.style.width=`${y/e.duration*100}%`))}let v=()=>{let y=S.getState(),C=y.currentPrime;if(!C)return;let m=r,b=y.visibleElements,A=Object.keys(m);for(let M of A){let I=m[M],R=b[M];if(I&&M!==C.id&&R){let B=s-R.time*1e3;Math.abs(s-R.time*1e3-I.currentTime*1e3)>300&&(I.currentTime=B/1e3)}}},h=(y=0)=>{let C=y-a,m=S.getState();if(m.isPlaying){let b=m.currentPrime;if(b){let R=r[b.id];R&&(R.paused?s+=C:s=(b.time+R.currentTime)*1e3)}else s+=C;let A=s/1e3;if(A>m.duration){S.getState().setTime(0),S.setState({isPlaying:!1}),x(),d(0);return}d(A);let[M,I]=Ii({currentTime:A,currentKeyFrameIndex:m.nextKeyframeIndex,keyframes:m.complexTimeline.keyframes,targetTime:A});I.length&&m.applyKeyframes(M,I)}a=y,i=requestAnimationFrame(h)},x=()=>{i&&cancelAnimationFrame(i)},g=(y,C)=>{},S=(0,ki.createStore)((y,C)=>({complexTimeline:e,elements:{},visibleElements:{},isBuffering:!1,bufferMap:{},isMuted:!1,playRequested:!1,isPlaying:!1,isFinished:!1,isReady:!1,volume:100,duration:e.duration,clockStartRequests:0,clockStartTime:0,primeTime:0,currentPrime:null,clockRunning:!1,nextKeyframeIndex:0,startClock:()=>{C().clockRunning||(h(),l=setInterval(v,500)),y({clockRunning:!0,clockStartRequests:C().clockStartRequests+1})},applyKeyframes(m,b){let A=C(),M={...A.visibleElements},I=A.currentPrime;for(let R of b)R.type==="enter"&&(M[R.id]=R,n.emit("complex-timeline.enter",{id:R.id})),R.type==="exit"&&(M[R.id]=null,n.emit("complex-timeline.exit",{id:R.id})),R.isPrime&&(I=R);y({nextKeyframeIndex:m,visibleElements:M,currentPrime:I})},stopClock:()=>{let m=C().clockStartRequests;if(m!==0){if(m===1){x(),l&&clearInterval(l),y({clockRunning:!1,clockStartRequests:0});return}y({clockStartRequests:m-1})}},setElement:(m,b)=>{r[m]=b;let A=Object.keys(r),M=C().complexTimeline;g(b,m),M.items.filter(R=>R.type!=="Image"&&R.type!=="Text").every(R=>A.includes(R.annotationId))&&!C().isReady&&(n.emit("complex-timeline.ready",{complexTimeline:M}),y({isReady:!0}))},removeElement:m=>{delete r[m]},mute(){for(let m of c())m.muted=!0;y({isMuted:!0})},unmute(){for(let m of c())m.muted=!1;y({isMuted:!1})},play(){if(!C().isPlaying){for(let b of u())b.play();y({isPlaying:!0})}},pause(){if(C().isPlaying){for(let b of u())b.pause();y({isPlaying:!1})}},playPause(){let m=C();m.isPlaying?m.pause():m.play()},setDurationPercent(m){let A=C().duration*m;C().setTime(A)},setTime(m){let b=C(),A=s/1e3,M=typeof m=="function"?m(A):m,I=b.nextKeyframeIndex;if(A>M){y({visibleElements:{},currentPrime:null});let ct=Object.keys(b.visibleElements);for(let Ut of ct)n.emit("complex-timeline.exit",{id:Ut});A=0,I=0}let[R,B]=Ii({currentTime:A,currentKeyFrameIndex:I,keyframes:b.complexTimeline.keyframes,targetTime:M});b.applyKeyframes(R,B),s=M*1e3;let k=S.getState().visibleElements,ne=r,fo=Object.keys(k);for(let ct of fo){let Ut=k[ct];if(Ut){let po=ne[ct];po&&(po.currentTime=(s-Ut.time*1e3)/1e3)}}d(M)},setVolume(m){for(let b of c())b.volume=Math.min(1,Math.max(0,m/100));y({volume:m})},toggleMute(){let m=C();m.isMuted?(m.unmute(),y({isMuted:!1})):(m.mute(),y({isMuted:!0}))},clearProgressElement(){o.progress=null},setProgressElement(m){o.progress=m},setCurrentTimeElement(m){o.currentTime=m},clearCurrentTimeElement(){o.currentTime=null}}));return n.on("complex-timeline.enter",y=>{let C=S.getState(),m=y.id,b=r[m];b&&C.isPlaying&&b.play()}),n.on("complex-timeline.exit",y=>{let C=S.getState(),m=y.id,b=r[m];b&&(b.currentTime=0,b.pause())}),S.getState().setTime(t),{store:S,emitter:n}}var Ui=require("@atlas-viewer/atlas");var Lt=require("react");var Vt=require("@atlas-viewer/atlas");var ue=j(require("react"),1),le=require("react/jsx-runtime"),Ni=ue.default.createContext("en"),Vi=ue.default.createContext({}),Li=ue.default.createContext(null);function rs(e){return(0,le.jsx)(Vi.Provider,{value:e.translations,children:e.children})}function os(e){return(0,le.jsx)(Ni.Provider,{value:e.language,children:e.children})}function is(e){return(0,le.jsx)(Li.Provider,{value:e.convert,children:e.children})}function Nr(){return ue.default.useContext(Li)}function yn(){return ue.default.useContext(Ni)}function Vr(){return ue.default.useContext(Vi)}function Ei(e){return e.indexOf("-")!==-1?e.slice(0,e.indexOf("-")):e}function zi({as:e,language:t,children:n,viewingDirection:r,...o}){let a=yn();return(0,ue.useMemo)(()=>Ei(a)===Ei(t),[a,t])?e?(0,le.jsx)(e,{...o,children:n}):(0,le.jsx)("span",{...o,children:n}):e?(0,le.jsx)(e,{...o,lang:t,dir:r,children:n}):(0,le.jsx)("span",{...o,lang:t,dir:r,children:n})}function Oi(e,t,n){if(t.length===0)return;if(t.length===1)return t[0];if(t.indexOf(e)!==-1)return e;let r=e.indexOf("-")!==-1?e.slice(0,e.indexOf("-")):null;if(r&&t.indexOf(r)!==-1)return r;for(let o of n)if(t.indexOf(o)!==-1)return o;return t.indexOf("none")!==-1?"none":t.indexOf("@none")!==-1?"@none":t[0]}var Hi=(e,t=[])=>{let n=yn();return(0,ue.useMemo)(()=>{let r=e();return Oi(n,r,[])},[n,...t])};function De(e,t,n,r){return t?n?n(e[t]||t,r||"none"):e[t]||t:""}function Bi(e,t,n=`
2
+ `,r={}){let o=Nr(),a=Hi(()=>Object.keys(e||{}),[e]);return[(0,ue.useMemo)(()=>{if(!e)return De(r,t,o)||"";if(typeof e=="string")return De(r,e,o);let i=a?e[a]:void 0;return i?typeof i=="string"?i:i.map(s=>De(r,s,o,a)).join(n):""},[a,t,e]),a]}function as(){let e=yn(),t=Vr(),n=Nr();return function(o,a="",i=`
3
+ `,s=t){let l=Object.keys(o||{}),u=Oi(e,l,[]);if(!o)return De(s,a,n)||"";if(typeof o=="string")return De(s,o,n);let c=u?o[u]:void 0;return c?typeof c=="string"?De(s,c,n,u):c.map(d=>De(s,d,n,u)).join(typeof i<"u"?i:`
4
+ `):""}}function te({as:e,defaultText:t,enableDangerouslySetInnerHTML:n,children:r,separator:o,...a}){let i=Vr(),[s,l]=Bi(r,t,o,i);return l?(0,le.jsx)(zi,{...a,as:e,language:l,title:n?void 0:s,dangerouslySetInnerHTML:n?{__html:s}:void 0,children:n?void 0:s}):e?(0,le.jsx)(e,{...a,children:s}):(0,le.jsx)("span",{...a,title:n?void 0:s,dangerouslySetInnerHTML:n?{__html:s}:void 0,children:n?void 0:s})}var Di=require("@iiif/parser/image-3");var ie=require("react/jsx-runtime");function ss({resource:e,heading:t,note:n,extra:r}){return r?(0,ie.jsx)(Vt.HTMLPortal,{target:{x:0,y:0,width:r.target?.spatial.width,height:r.target?.spatial.height},backgroundColor:"#333",relative:!0,children:(0,ie.jsx)("div",{style:{display:"flex",alignContent:"center",justifyContent:"center",alignItems:"center",height:"100%",width:"100%",background:"#444",color:"#BBB"},children:(0,ie.jsxs)("div",{children:[(0,ie.jsx)(te,{children:t||"Not authorised"}),n&&(0,ie.jsx)("p",{children:(0,ie.jsx)(te,{children:n})}),(0,ie.jsx)("p",{children:e.id||e["@id"]||"unknown"})]})})}):null}function Fi({image:e,thumbnail:t,crop:n,enableSizes:r,enableThumbnail:o,renderOptions:a}){let i=Jn(),s=(0,Di.getId)(e.service),l=mi(s),u=tt(),c=l?.service;u(e.service,e);let d=c&&l?.status==="done",v=t&&t.type==="fixed"&&t.id&&!t.id.includes("/full/full/")&&!t.id.includes("/max/")?t:void 0;if(d===!1)return null;if(!i){let h=e.service,x=h.width||e.width||0,g=h.height||e.height||0;return(0,ie.jsx)(Vt.TileSet,{enableThumbnail:o,renderOptions:a,tiles:{id:h.id||h["@id"]||"unknown",height:g,width:x,imageService:h,thumbnail:v},enableSizes:r,x:0,y:0,width:e.target?.spatial.width,height:e.target?.spatial.height,crop:n})}return(0,ie.jsx)(er,{resource:e.service,errorComponent:ss,extra:e,children:h=>{let x=h.width||e.width||0,g=h.height||e.height||0;return(0,ie.jsx)(Vt.TileSet,{enableThumbnail:o,renderOptions:a,tiles:{id:h.id||h["@id"]||"unknown",height:g,width:x,imageService:h,thumbnail:v},enableSizes:r,x:0,y:0,width:e.target?.spatial.width,height:e.target?.spatial.height,crop:n})}},e.id)}var Fe=require("react/jsx-runtime");function Ce({id:e,image:t,thumbnail:n,isStatic:r,x:o=0,y:a=0,children:i,selector:s,onClick:l,enableSizes:u}){let c=(0,Lt.useMemo)(()=>{if(!(!s||s.spatial.x===0&&s.spatial.y===0))return s.spatial},[s]);return(0,Fe.jsx)("world-object",{x:o+t.target.spatial.x,y:a+t.target.spatial.y,width:t.target.spatial.width,height:t.target.spatial.height,onClick:l,children:t.service?(0,Fe.jsxs)(Lt.Fragment,{children:[(0,Fe.jsx)(Fi,{image:t,thumbnail:n,crop:c,enableSizes:u}),i]},"service"):(0,Fe.jsxs)(Lt.Fragment,{children:[(0,Fe.jsx)("world-image",{onClick:l,uri:t.id,target:{x:0,y:0,width:t.target.spatial.width,height:t.target.spatial.height},display:t.width&&t.height?{width:t.width,height:t.height}:void 0,crop:c}),i]},"no-service")},e+(t.service?"server":"no-service"))}var Or=require("zustand");var vn=require("react"),qi=require("zustand"),Wi=require("react/jsx-runtime"),Lr=(0,vn.createContext)(null);Lr.displayName="ComplexTimeline";function zr({children:e,store:t}){return(0,Wi.jsx)(Lr.Provider,{value:t,children:e})}function cs(e){let t=(0,vn.useContext)(Lr);if(!t)throw new Error("useComplexTimeline must be used within a ComplexTimelineProvider");return(0,qi.useStore)(t,e)}var $i=require("@atlas-viewer/atlas");var pe=require("react/jsx-runtime");function Sn({strategy:e,onClickPaintingAnnotation:t}){return(0,pe.jsx)(pe.Fragment,{children:e.items.map((n,r)=>(0,pe.jsx)(pe.Fragment,{children:(0,pe.jsx)($i.HTMLPortal,{onClick:t?o=>{o.stopPropagation(),t(n.annotationId,n,o)}:void 0,target:n.target?.spatial||void 0,children:(0,pe.jsx)("div",{"data-textual-content":!0,children:(0,pe.jsx)(te,{enableDangerouslySetInnerHTML:!0,children:n.text})})},r)}))})}var ge=require("react/jsx-runtime");function _i({strategy:e,children:t}){let{store:n}=(0,xn.useMemo)(()=>Mi({complexTimeline:e}),[e]),r=(0,Or.useStore)(n,i=>i.isReady),o=(0,Or.useStore)(n,i=>i.visibleElements);function a(i){return s=>{s&&n.getState().setElement(i,s)}}return(0,xn.useLayoutEffect)(()=>{if(r){let{startClock:i,stopClock:s}=n.getState();return i(),()=>{s()}}},[e,r]),D("portal","custom-controls",zr,{store:n,children:t},[r]),(0,ge.jsxs)(ge.Fragment,{children:[e.items.map(i=>i.type!=="Image"||!o[i.annotationId]?null:(0,ge.jsx)(Ce,{image:i,id:i.annotationId},i.id)),e.items.map((i,s)=>i.type!=="Text"||!o[i.annotationId]?null:(0,ge.jsx)(Sn,{strategy:{type:"textual-content",items:[i]}},s)),e.items.map((i,s)=>i.type!=="Video"||!i.target.spatial?null:(0,ge.jsx)(Ui.HTMLPortal,{target:i.target.spatial,children:(0,ge.jsx)("video",{ref:a(i.annotationId),src:i.url,style:{height:"100%",width:"100%",opacity:o[i.annotationId]?1:0}})},s))]})}var Yi=require("react/jsx-runtime");function Hr(){let{strategy:e}=V(),{renderComplexTimelineControls:t}=_();return e.type!=="complex-timeline"?null:(0,Yi.jsx)(_i,{strategy:e,children:t?t(e):null})}var rt=require("react/jsx-runtime");function Br({onClickPaintingAnnotation:e,children:t}){let{strategy:n}=V(),{renderViewerControls:r,viewControlsDeps:o}=_(),a=vt(),i=P();return D(a&&n.type==="textual-content"&&r?"overlay":"none",`canvas-portal-controls-${i?.id}`,oe.Provider,r?{value:a||null,children:r(n)}:{},[i,a,n,...o||[]]),n.type!=="textual-content"?null:(0,rt.jsxs)(rt.Fragment,{children:[(0,rt.jsx)(Sn,{strategy:n,onClickPaintingAnnotation:e}),t]})}var be=require("react");var Ki=require("react"),Dr=(e,t=[])=>{let n=T();(0,Ki.useEffect)(()=>{e(n)},[n,...t])};var Cn=j(require("react"),1),Qi=require("@iiif/helpers/image-service"),ji=Cn.default.createContext(new Qi.ImageServiceLoader);function zt(){return(0,Cn.useContext)(ji)}var Gi=require("@iiif/helpers/thumbnail");function he(e,t,{canvasId:n,manifestId:r}={}){let o=T(),a=zt(),i=(0,be.useMemo)(()=>(0,Gi.createThumbnailHelper)(o,{imageServiceLoader:a}),[o,a]),[s,l]=(0,be.useState)(),u=z(r?{id:r}:void 0),c=P(n?{id:n}:void 0),d=c||u,v=(0,be.useRef)(!1);if((0,be.useEffect)(()=>(v.current=!1,()=>{v.current=!0}),[]),!d)throw new Error("Must be called under a manifest or canvas context.");return Dr(h=>{i.getBestThumbnailAtSize(d,e,t).then(x=>{x.best&&!v.current&&l(x.best)})},[d]),s}var ot=require("react/jsx-runtime");function Fr({isStatic:e=!1,enableSizes:t=!1,onClickPaintingAnnotation:n,children:r}){let{strategy:o}=V(),{renderViewerControls:a,viewControlsDeps:i}=_(),s=P(),l=vt(),u=he({maxWidth:256,maxHeight:256});return D(l&&o.type==="images"&&a?"overlay":"none",`canvas-portal-controls-${s?.id}`,oe.Provider,a?{value:l||null,children:a(o)}:{},[s,l,o,...i||[]]),o.type!=="images"?null:(0,ot.jsxs)(ot.Fragment,{children:[o.images.map((c,d)=>(0,ot.jsx)(Ce,{isStatic:e,image:c,id:c.id,thumbnail:d===0?u:void 0,selector:c.selector,enableSizes:t,onClick:n?v=>{n(c.annotationId,c,v)}:void 0},c.id+d)),r]})}var Re=require("react/jsx-runtime");function qr({model:e}){return(0,Re.jsxs)(Re.Fragment,{children:[(0,Re.jsx)("style",{children:`
5
5
  .model-container {
6
6
  position: absolute;
7
7
  top: 0;
@@ -14,7 +14,7 @@
14
14
  justify-content: center;
15
15
  pointer-events: visible;
16
16
  }
17
- `}),(0,Re.jsx)("div",{className:"model-container",children:(0,Re.jsx)("model-viewer",{"interaction-prompt":"none",style:{width:"100%",height:"100%"},"camera-controls":"","ar-status":"not-presenting",src:e.id})})]})}function bn({model:e,name:t}){return D("overlay",`model-${t}`,Wo,{model:e},[e]),null}var Xi=require("react/jsx-runtime");function $o(){let{strategy:e}=V();return e.type!=="3d-model"?null:(0,Xi.jsx)(bn,{model:e.model})}var qe=require("react/jsx-runtime");function Uo({children:e}){let{strategy:t}=V(),[n]=lo();return t.type!=="images"?null:(0,qe.jsxs)(qe.Fragment,{children:[n?(0,qe.jsx)(Ct,{page:n}):null,t.annotations&&t.annotations.pages?t.annotations.pages.map(o=>(0,qe.jsx)(Ct,{page:o},o.id)):null,e]})}var Pe=require("react"),Rn=require("react/jsx-runtime"),Zi=(0,Pe.createContext)(null),Ji=(0,Pe.createContext)(null),ea=(0,Pe.createContext)(null);function ls(){let e=(0,Pe.useContext)(Zi);if(!e)throw new Error("Ctx not found");return e}function us(){let e=(0,Pe.useContext)(Ji);if(!e)throw new Error("Ctx not found");return e}function ms(){let e=(0,Pe.useContext)(ea);if(!e)throw new Error("Ctx not found");return e}function Ot({actions:e,state:t,children:n,currentTime:o,progress:r,element:a}){return(0,Rn.jsx)(ea.Provider,{value:{currentTime:o,progress:r,element:a},children:(0,Rn.jsx)(Ji.Provider,{value:e,children:(0,Rn.jsx)(Zi.Provider,{value:t,children:n})})})}var ta=require("react");var na=require("@iiif/helpers");function Ht(){let e=z(),t=P();return(0,ta.useMemo)(()=>{if(!e||!t||!e.start)return null;let n=(0,na.expandTarget)(e.start);return!n||n.source.id!==t.id||!n||!n.selector||n.selector.type!=="TemporalSelector"?null:n.selector.temporal},[e,t])}var An=require("react/jsx-runtime");function _o({media:e,startTime:t,children:n}){let[{element:o,currentTime:r,progress:a},i,s]=Be({duration:e.duration}),l=t?`${e.url}#t=${t}`:e.url;return(0,An.jsxs)(Ot,{state:i,actions:s,currentTime:r,progress:a,element:o,children:[(0,An.jsx)("audio",{ref:o,src:l}),n]})}function Pn({media:e,mediaControlsDeps:t,audioCopmonent:n=_o,children:o}){let r=Ht();return D("portal","audio",n,{media:e,startTime:r?r.startTime:null,children:o},[e,r,...t||[]]),null}var Yo=require("react/jsx-runtime");function We({x:e=0,y:t=0}){let n=P(),o=he({maxWidth:256,maxHeight:256});return!n||!o||o.type!=="fixed"?null:(0,Yo.jsx)("world-object",{height:n.height,width:n.width,x:e,y:t,children:(0,Yo.jsx)("world-image",{uri:o.id,target:{x:0,y:0,width:n.width,height:n.height},display:o.width&&o.height?{width:o.width,height:o.height}:void 0,crop:void 0})})}var $e=require("react/jsx-runtime");function Ko({as:e}){let{strategy:t}=V(),{renderMediaControls:n,mediaControlsDeps:o}=_();return t.type!=="media"||t.media.type!=="Sound"?null:(0,$e.jsx)($e.Fragment,{children:(0,$e.jsxs)(Pn,{media:t.media,mediaControlsDeps:o,audioCopmonent:e,children:[(0,$e.jsx)(We,{}),n?n(t):null]},t.media.url)})}var ye=require("react/jsx-runtime");function Qo(){let{strategy:e}=V(),{renderViewerControls:t,viewControlsDeps:n}=_(),o=P(),r=o?.accompanyingCanvas,a=o?.placeholderCanvas;return(0,ye.jsxs)(ye.Fragment,{children:[e.type==="media"&&e.media.type==="Sound"&&r?(0,ye.jsx)(oe,{canvas:r.id,children:(0,ye.jsx)(Ue,{renderViewerControls:t,viewControlsDeps:n})}):null,e.type==="media"&&e.media.type==="Sound"&&a&&!r?(0,ye.jsx)(oe,{canvas:a.id,children:(0,ye.jsx)(Ue,{renderViewerControls:t,viewControlsDeps:n})}):null]})}var Bt=require("react/jsx-runtime");function jo({element:e,media:t,startTime:n,playPause:o,poster:r}){let a="div",i=n?`${t.url}#t=${n}`:t.url;return(0,Bt.jsxs)(a,{className:"video-container",part:"video-container",onClick:o,children:[(0,Bt.jsx)("style",{children:`
17
+ `}),(0,Re.jsx)("div",{className:"model-container",children:(0,Re.jsx)("model-viewer",{"interaction-prompt":"none",style:{width:"100%",height:"100%"},"camera-controls":"","ar-status":"not-presenting",src:e.id})})]})}function bn({model:e,name:t}){return D("overlay",`model-${t}`,qr,{model:e},[e]),null}var Xi=require("react/jsx-runtime");function Wr(){let{strategy:e}=V();return e.type!=="3d-model"?null:(0,Xi.jsx)(bn,{model:e.model})}var qe=require("react/jsx-runtime");function $r({children:e}){let{strategy:t}=V(),[n]=lr();return t.type!=="images"?null:(0,qe.jsxs)(qe.Fragment,{children:[n?(0,qe.jsx)(Ct,{page:n}):null,t.annotations&&t.annotations.pages?t.annotations.pages.map(r=>(0,qe.jsx)(Ct,{page:r},r.id)):null,e]})}var Pe=require("react"),Rn=require("react/jsx-runtime"),Zi=(0,Pe.createContext)(null),Ji=(0,Pe.createContext)(null),ea=(0,Pe.createContext)(null);function ls(){let e=(0,Pe.useContext)(Zi);if(!e)throw new Error("Ctx not found");return e}function us(){let e=(0,Pe.useContext)(Ji);if(!e)throw new Error("Ctx not found");return e}function ms(){let e=(0,Pe.useContext)(ea);if(!e)throw new Error("Ctx not found");return e}function Ot({actions:e,state:t,children:n,currentTime:r,progress:o,element:a}){return(0,Rn.jsx)(ea.Provider,{value:{currentTime:r,progress:o,element:a},children:(0,Rn.jsx)(Ji.Provider,{value:e,children:(0,Rn.jsx)(Zi.Provider,{value:t,children:n})})})}var ta=require("react");var na=require("@iiif/helpers");function Ht(){let e=z(),t=P();return(0,ta.useMemo)(()=>{if(!e||!t||!e.start)return null;let n=(0,na.expandTarget)(e.start);return!n||n.source.id!==t.id||!n||!n.selector||n.selector.type!=="TemporalSelector"?null:n.selector.temporal},[e,t])}var An=require("react/jsx-runtime");function Ur({media:e,startTime:t,children:n}){let[{element:r,currentTime:o,progress:a},i,s]=Be({duration:e.duration}),l=t?`${e.url}#t=${t}`:e.url;return(0,An.jsxs)(Ot,{state:i,actions:s,currentTime:o,progress:a,element:r,children:[(0,An.jsx)("audio",{ref:r,src:l}),n]},e.url)}function Pn({media:e,mediaControlsDeps:t,audioCopmonent:n=Ur,children:r}){let o=Ht();return D("portal","audio",n,{media:e,startTime:o?o.startTime:null,children:r},[e,o,...t||[]]),null}var _r=require("react/jsx-runtime");function We({x:e=0,y:t=0}){let n=P(),r=he({maxWidth:256,maxHeight:256});return!n||!r||r.type!=="fixed"?null:(0,_r.jsx)("world-object",{height:n.height,width:n.width,x:e,y:t,children:(0,_r.jsx)("world-image",{uri:r.id,target:{x:0,y:0,width:n.width,height:n.height},display:r.width&&r.height?{width:r.width,height:r.height}:void 0,crop:void 0})})}var $e=require("react/jsx-runtime");function Yr({as:e}){let{strategy:t}=V(),{renderMediaControls:n,mediaControlsDeps:r}=_();return t.type!=="media"||t.media.type!=="Sound"?null:(0,$e.jsx)($e.Fragment,{children:(0,$e.jsxs)(Pn,{media:t.media,mediaControlsDeps:r,audioCopmonent:e,children:[(0,$e.jsx)(We,{}),n?n(t):null]},t.media.url)})}var ye=require("react/jsx-runtime");function Kr(){let{strategy:e}=V(),{renderViewerControls:t,viewControlsDeps:n}=_(),r=P(),o=r?.accompanyingCanvas,a=r?.placeholderCanvas;return(0,ye.jsxs)(ye.Fragment,{children:[e.type==="media"&&e.media.type==="Sound"&&o?(0,ye.jsx)(re,{canvas:o.id,children:(0,ye.jsx)(Ue,{renderViewerControls:t,viewControlsDeps:n})}):null,e.type==="media"&&e.media.type==="Sound"&&a&&!o?(0,ye.jsx)(re,{canvas:a.id,children:(0,ye.jsx)(Ue,{renderViewerControls:t,viewControlsDeps:n})}):null]})}var Bt=require("react/jsx-runtime");function Qr({element:e,media:t,startTime:n,playPause:r,poster:o}){let a="div",i=n?`${t.url}#t=${n}`:t.url;return(0,Bt.jsxs)(a,{className:"video-container",part:"video-container",onClick:r,children:[(0,Bt.jsx)("style",{children:`
18
18
  .video-container {
19
19
  position: absolute;
20
20
  top: 0;
@@ -27,7 +27,7 @@
27
27
  justify-content: center;
28
28
  pointer-events: visible;
29
29
  }
30
- `}),(0,Bt.jsx)("video",{poster:r,ref:e,src:i,style:{width:"100%",objectFit:"contain"}})]})}function Tn({media:e,mediaControlsDeps:t,children:n,videoComponent:o=jo,captions:r}){let a=P(),i=Ht(),s=a&&a.placeholderCanvas&&a.placeholderCanvas.id||void 0,l=he({},!1,{canvasId:s}),[{element:u,currentTime:c,progress:d},v,y]=Be({duration:e.duration});return D("overlay","video-element",o,{element:u,media:e,playPause:y.playPause,poster:l?.id,canvas:a,startTime:i?i.startTime:null,captions:r},[l]),D("portal","custom-controls",Ot,{state:v,actions:y,currentTime:c,progress:d,element:u,children:n},[c,v,e,...t||[]]),null}var In=require("react/jsx-runtime");function Go({as:e}){let{strategy:t}=V(),{renderMediaControls:n,mediaControlsDeps:o}=_();return t.type!=="media"||t.media.type!=="Video"?null:(0,In.jsxs)(Tn,{captions:t.captions,media:t.media,mediaControlsDeps:o,videoComponent:e,children:[(0,In.jsx)(We,{}),n?n(t):null]},t.media.url)}var oa=require("react"),Dt=require("react/jsx-runtime");function ds({element:e,media:t,playPause:n}){let o=(0,oa.useRef)(null);return t.youTubeId?(0,Dt.jsxs)("div",{className:"video-container",part:"video-container",onClick:n,children:[(0,Dt.jsx)("style",{children:`
30
+ `}),(0,Bt.jsx)("video",{poster:o,ref:e,src:i,style:{width:"100%",objectFit:"contain"}})]})}function Tn({media:e,mediaControlsDeps:t,children:n,videoComponent:r=Qr,captions:o}){let a=P(),i=Ht(),s=a&&a.placeholderCanvas&&a.placeholderCanvas.id||void 0,l=he({},!1,{canvasId:s}),[{element:u,currentTime:c,progress:d},v,h]=Be({duration:e.duration});return D("overlay","video-element",r,{element:u,media:e,playPause:h.playPause,poster:l?.id,canvas:a,startTime:i?i.startTime:null,captions:o},[l]),D("portal","custom-controls",Ot,{state:v,actions:h,currentTime:c,progress:d,element:u,children:n},[c,v,e,...t||[]]),null}var In=require("react/jsx-runtime");function jr({as:e}){let{strategy:t}=V(),{renderMediaControls:n,mediaControlsDeps:r}=_();return t.type!=="media"||t.media.type!=="Video"?null:(0,In.jsxs)(Tn,{captions:t.captions,media:t.media,mediaControlsDeps:r,videoComponent:e,children:[(0,In.jsx)(We,{}),n?n(t):null]},t.media.url)}var ra=require("react"),Dt=require("react/jsx-runtime");function ds({element:e,media:t,playPause:n}){let r=(0,ra.useRef)(null);return t.youTubeId?(0,Dt.jsxs)("div",{className:"video-container",part:"video-container",onClick:n,children:[(0,Dt.jsx)("style",{children:`
31
31
  .video-container {
32
32
  position: absolute;
33
33
  top: 0;
@@ -45,4 +45,4 @@
45
45
  width: 100%;
46
46
  object-fit: contain;
47
47
  }
48
- `}),(0,Dt.jsx)("iframe",{className:"video-yt",ref:o,src:`https://www.youtube.com/embed/${t.youTubeId}?enablejsapi=1&origin=${window.location.host}`,referrerPolicy:"no-referrer",sandbox:"allow-scripts allow-same-origin allow-presentation"})]}):null}function ra({media:e,mediaControlsDeps:t,children:n}){let[{element:o,currentTime:r,progress:a},i,s]=Be({duration:e.duration});return D("overlay","video-element",ds,{element:o,media:e,playPause:s.playPause}),null}var wn=require("react/jsx-runtime");function Xo(){let{strategy:e}=V(),{renderMediaControls:t,mediaControlsDeps:n}=_();return e.type!=="media"||e.media.type!=="VideoYouTube"?null:(0,wn.jsxs)(ra,{media:e.media,mediaControlsDeps:n,children:[(0,wn.jsx)(We,{}),t?t(e):null]})}var X=require("react/jsx-runtime");function Ue({x:e,y:t,onChoiceChange:n,registerActions:o,defaultChoices:r,isStatic:a,renderViewerControls:i,renderMediaControls:s,renderComplexTimelineControls:l,complexTimelineControlsDeps:u,viewControlsDeps:c,mediaControlsDeps:d,strategies:v,throwOnUnknown:y,backgroundStyle:x,alwaysShowBackground:g,keepCanvasScale:S=!1,enableSizes:h=!1,enableYouTube:C=!0,onClickPaintingAnnotation:m,components:b={},children:A}){return(0,X.jsxs)(Mo,{throwOnUnknown:y,onChoiceChange:n,registerActions:o,strategies:v,defaultChoices:r,mediaControlsDeps:d,renderMediaControls:s,renderViewerControls:i,renderComplexTimelineControls:l,complexTimelineControlsDeps:u,viewControlsDeps:c,children:[(0,X.jsxs)(Eo,{keepCanvasScale:S,x:e,y:t,children:[(0,X.jsx)(No,{alwaysShowBackground:g,backgroundStyle:x}),(0,X.jsx)(Bo,{}),(0,X.jsx)(Do,{}),(0,X.jsx)(qo,{isStatic:a,enableSizes:h,onClickPaintingAnnotation:m}),(0,X.jsx)(Uo,{}),(0,X.jsx)($o,{}),(0,X.jsx)(Ko,{as:b.Audio}),(0,X.jsx)(Go,{as:b.Video}),C?(0,X.jsx)(Xo,{}):null,A]}),(0,X.jsx)(Qo,{})]})}var Zo=require("react/jsx-runtime");function ia(e){let t=P();return!t||!t.placeholderCanvas?null:(0,Zo.jsx)(oe,{canvas:t.placeholderCanvas.id,children:(0,Zo.jsx)(Ue,{renderViewerControls:e.renderViewerControls})})}var Y=require("react/jsx-runtime"),fs=(0,Ft.forwardRef)(function(t,n){let o=z(),r=Ee(),a=ht(),{ViewerControls:i,MediaControls:s,ComplexTimelineControls:l}=t.components||{};if((0,Ft.useImperativeHandle)(n,()=>a,[a]),!o)return(0,Y.jsx)("div",{});let u=0;return(0,Y.jsxs)(Y.Fragment,{children:[t.header,(0,Y.jsx)(F.Viewer,{height:t.height,mode:t.mode,renderPreset:t.renderPreset,runtimeOptions:t.runtimeOptions,children:r.map((c,d)=>{let v=u;return u+=c.width+(t.spacing||0),(0,Y.jsx)(oe,{canvas:c.id,children:(0,Y.jsx)(F.RenderCanvas,{strategies:["3d-model","media","images","empty","textual-content","complex-timeline"],renderViewerControls:d===0&&i?()=>(0,Y.jsx)(i,{}):void 0,renderMediaControls:d===0&&s?()=>(0,Y.jsx)(s,{}):void 0,renderComplexTimelineControls:d===0&&l?()=>(0,Y.jsx)(l,{}):void 0,x:v,...t.canvasProps||{},children:t.annotations},c.id)},c.id)})},t.reuseAtlas?"":a.currentSequenceIndex),t.children]})}),F=(0,Ft.forwardRef)(function({children:t,height:n,annotations:o,canvasProps:r,spacing:a,header:i,components:s,mode:l,reuseAtlas:u,renderPreset:c,runtimeOptions:d,...v},y){let x=ke();return(0,Y.jsx)(we,{vault:x,children:(0,Y.jsx)(no,{...v,children:(0,Y.jsx)(fs,{ref:y,height:n,components:s,spacing:a,canvasProps:r,annotations:o,header:i,mode:l,reuseAtlas:u,renderPreset:c,runtimeOptions:d,children:t})})})});F.RenderImage=Ce;F.RenderCanvas=Ue;F.RenderAnnotationPage=Ct;F.RenderAnnotation=cn;F.Viewer=an;F.CanvasBackground=gn;F.Audio=Pn;F.Video=Tn;F.Model=bn;F.AudioHTML=_o;F.VideoHTML=jo;F.ModelHTML=Wo;F.PlaceholderCanvas=ia;var aa=require("@atlas-viewer/atlas");var kn=require("react"),qt=require("react/jsx-runtime"),ps=(0,kn.forwardRef)(function({canvasId:t},n){let o=(0,aa.useCanvas)(),r=At(t||o?.id),a=T();return(0,kn.useImperativeHandle)(n,()=>r,[t,o]),!o||r.enabledPageIds.length===0?null:(0,qt.jsx)(qt.Fragment,{children:r.enabledPageIds.map(i=>(0,qt.jsx)(F.RenderAnnotationPage,{page:a.get(i)},i))})});var ca=require("react");var sa=require("react");var H=require("react/jsx-runtime");function Wt({metadata:e=[],config:t,labelWidth:n=16,showEmptyMessage:o=!0,allowHtml:r,emptyFallback:a,classes:i={},emptyMessage:s="No metadata available",emptyValueFallback:l="No value",emptyLabelFallback:u="",separator:c,tableFooter:d,tableHeader:v}){let y=(0,sa.useMemo)(()=>{let g=(t||[]).reduce((h,C)=>[...h,...C.keys],[]),S={};for(let h of e){let C=h&&h.label?Object.values(h.label):[];for(let m of C)if(m&&m.length&&(g.indexOf(`metadata.${m[0]}`)!==-1||g.length===0)&&h){let b=`metadata.${m[0]}`;S[b]=S[b]?S[b]:[],S[b].push(h);break}}return S},[t,e]);return Object.keys(y).length===0&&o?(0,H.jsx)(H.Fragment,{children:a})||(0,H.jsx)("div",{className:i.empty,children:s}):t&&t.length?(0,H.jsxs)("table",{className:i.container,children:[v,(0,H.jsx)("tbody",{children:t.map((g,S)=>{let h=[];for(let C of g.keys)for(let m of y[C]||[])h.push((0,H.jsx)(te,{enableDangerouslySetInnerHTML:r,defaultText:l,separator:c,children:m.value},S+"__"+C));return h.length===0?null:(0,H.jsxs)("tr",{className:i.row,children:[(0,H.jsx)("td",{className:i.label,style:n?{minWidth:n}:{},children:(0,H.jsx)(te,{enableDangerouslySetInnerHTML:r,separator:c,defaultText:u,children:g.label})}),(0,H.jsx)("td",{className:i.value,children:h})]},S)})}),d]}):(0,H.jsxs)("table",{className:i.container,children:[v,(0,H.jsx)("tbody",{children:e&&e.length?e.map((g,S)=>g?(0,H.jsxs)("tr",{className:i.row,children:[(0,H.jsx)("td",{className:i.label,style:n?{minWidth:n}:{},children:(0,H.jsx)(te,{enableDangerouslySetInnerHTML:r,defaultText:l,separator:c,children:g.label})}),(0,H.jsx)("td",{className:i.value,children:(0,H.jsx)(te,{enableDangerouslySetInnerHTML:r,defaultText:l,separator:c,children:g.value})})]},S):null):null}),d]})}var la=require("react/jsx-runtime");function gs(e){let t=z(),n=P(),o=dt(),r=(0,ca.useMemo)(()=>{let a=t?.metadata||[],i=n?.metadata||[],s=o?.metadata||[];return[...a,...i,...s]},[t,n,o]);return(0,la.jsx)(Wt,{metadata:r,...e})}var Nn=require("react");var Mn=require("@iiif/parser/image-3"),ua=require("react");function En(e,t={},n=[]){return(0,ua.useMemo)(()=>{if(!e)return null;let o=t.quality;e&&e.extraQualities&&t.quality&&(e.extraQualities.includes(t.quality)||(o="default"));let r=(0,Mn.createImageServiceRequest)(e);return(0,Mn.imageServiceRequestToString)({identifier:r.identifier,server:r.server,scheme:r.scheme,type:"image",size:{max:!t.size?.width&&!t.size?.height,confined:!1,upscaled:!1,...t.size||{}},format:t.format||"jpg",region:t.region||{full:!0},rotation:t?.rotation?Number.isInteger(t.rotation)?{angle:t.rotation}:t.rotation:{angle:0},quality:o||"default",prefix:r.prefix,originalPath:r.originalPath})},[...n])}var $t=require("react/jsx-runtime");function hs(e){let t=typeof e.src=="string"?e.src:e.src.id,n=zt(),[o,r]=(0,Nn.useState)(!1),a;if(t){let s=n.loadServiceSync({id:t});s&&(a=s)}!a&&!o&&n.loadService({id:t}).then(()=>{r(!0)});let i=En(a,{size:e.size,selector:e.region,rotation:e.rotation,format:e.format,region:e.region,quality:e.quality},[o,e.src,e.size,e.region,e.rotation,e.format,e.region,e.quality]);return(0,Nn.useEffect)(()=>()=>{r(!1)},[t]),i?(0,$t.jsx)("img",{src:i,alt:e.alt,className:e.className,style:e.style}):(0,$t.jsx)(ma,{...e,fetchImageService:!1})}function ma(e){if(e.fetchImageService)return(0,$t.jsx)(hs,{...e});let t=typeof e.src=="string"?{id:e.src,profile:"level0"}:e.src,n=En(t,{size:e.size,selector:e.region,rotation:e.rotation,format:e.format,region:e.region,quality:e.quality},[e.src,e.size,e.region,e.rotation,e.format,e.region,e.quality]);return n?(0,$t.jsx)("img",{src:n,alt:e.alt,className:e.className,style:e.style}):null}var da=require("react/jsx-runtime");function ys(e){let t=z();return(0,da.jsx)(Wt,{metadata:t?.metadata||[],...e})}var Vn=require("react");var Jo=j(require("react-lazy-load-image-component"),1);var fa=require("@iiif/helpers/i18n"),Z=require("react/jsx-runtime"),{LazyLoadComponent:vs}=Jo||Jo.default;function er(e){let{size:t,visible:n,classes:o,canvasId:r,figure:a}=e,i=t?.width||128,s=t?.height||t?.width||128,l=(0,Z.jsx)(Ss,{...e}),u=(0,Z.jsx)(vs,{threshold:300,style:{height:s,width:i},visibleByDefault:n,children:r?(0,Z.jsx)(oe,{canvas:r,children:l}):l});return a?(0,Z.jsx)("figure",{className:o?.figure,children:u}):u}function Ss({fallback:e,size:t,classes:n,showLabel:o,alt:r,dereference:a=!1}){let i=P(),s=t?.width||128,l=t?.height||t?.width||128,u=r||(0,fa.getValue)(i?.label)||"",c=he({width:s,height:l,allowUnsafe:!0},a);return!c||c.type!=="fixed"?(0,Z.jsx)(Z.Fragment,{children:e}):(0,Z.jsxs)(Z.Fragment,{children:[(0,Z.jsx)("div",{className:n?.imageWrapper,children:(0,Z.jsx)("img",{className:n?.img,src:c.id,alt:u})}),o?(0,Z.jsx)(te,{as:"figcaption",className:n?.label,children:i?.label}):null]})}var it=require("react/jsx-runtime");function xs({scrollBehaviour:e,dereference:t,flat:n,size:o,classes:r={},showLabel:a,figure:i,fallback:s}){let l=(0,Vn.useRef)(null),{items:u,sequence:c,currentSequenceIndex:d,setSequenceIndex:v}=ht(),y={row:r.selected?.row||r.row,item:r.selected?.item||r.item,figure:r.selected?.figure||r.figure,img:r.selected?.img||r.img,label:r.selected?.label||r.label,imageWrapper:r.selected?.imageWrapper||r.imageWrapper};(0,Vn.useLayoutEffect)(()=>{if(!l.current)return;let g=l.current.querySelector("[data-selected=true]");g&&g.scrollIntoView({behavior:e||"instant",block:"nearest",inline:"center"})},[d]);let x=[];for(let g of c){let S=[],h=c[d]===g;for(let C of g){let m=u[C];S.push((0,it.jsx)("div",{className:h?y.item:r.item,children:(0,it.jsx)(er,{classes:h?y:r,canvasId:m.id,size:o,dereference:t,showLabel:a,figure:i,placeholder:(0,it.jsx)("div",{style:{height:128,width:128}}),fallback:s})},C))}if(n){x.push(S);continue}x.push((0,it.jsx)("div",{onClick:C=>{v(c.indexOf(g))},"data-selected":h,className:h?y.row:r.row,children:S},g.join("-")))}return(0,it.jsx)("div",{ref:l,className:r.container,children:x})}var K=require("react/jsx-runtime"),Cs={draw:!0,polygon:!0,line:!0,lineBox:!0,square:!0,triangle:!0,hexagon:!0,circle:!0,delete:!0};function bs({helper:e,showShapes:t,state:n,enabled:o=Cs,classNames:r={},icons:a={}}){return(0,K.jsxs)(K.Fragment,{children:[t?(0,K.jsxs)(K.Fragment,{children:[o.draw&&(0,K.jsx)("button",{className:r.button,onClick:()=>{e.stamps.clear(),e.draw.enable()},"data-active":!n.lineMode&&!n.selectedStamp&&t&&n.drawMode,children:a.DrawIcon||"Draw"}),o.polygon&&(0,K.jsx)("button",{className:r.button,"data-active":!n.lineMode&&!n.selectedStamp&&t&&!n.drawMode,onClick:()=>{e.stamps.clear(),e.draw.disable(),e.modes.disableLineBoxMode(),e.modes.disableLineMode()},children:a.PolygonIcon||"Polygon"}),o.line&&(0,K.jsx)("button",{className:r.button,"data-active":n.lineMode&&!n.lineBoxMode,onClick:()=>{e.modes.enableLineMode()},children:a.LineIcon||"Line"}),o.lineBox&&(0,K.jsx)("button",{className:r.button,"data-active":n.lineBoxMode,onClick:()=>{e.modes.enableLineBoxMode()},children:a.LineBoxIcon||"LineBox"}),o.square&&(0,K.jsx)("button",{className:r.button,"data-active":n.selectedStamp?.id==="square",onClick:()=>{e.stamps.square()},children:a.SquareIcon||"Square"}),o.triangle&&(0,K.jsx)("button",{className:r.button,"data-active":n.selectedStamp?.id==="triangle",onClick:()=>{e.stamps.triangle()},children:a.TriangleIcon||"Triangle"}),o.hexagon&&(0,K.jsx)("button",{className:r.button,"data-active":n.selectedStamp?.id==="hexagon",onClick:()=>{e.stamps.hexagon()},children:a.HexagonIcon||"Hexagon"})]}):null,n.showBoundingBox&&o.delete&&(0,K.jsx)("button",{className:r.button,onClick:()=>e.key.down("Backspace"),children:a.DeleteForeverIcon||"Delete"})]})}var q=require("react"),tr=j(require("mitt"),1),pa=require("react/jsx-runtime"),Ln=(0,q.createContext)((0,tr.default)());Ln.displayName="SelectorHelper";function Rs({children:e}){return(0,pa.jsx)(Ln.Provider,{value:(0,q.useMemo)(()=>(0,tr.default)(),[]),children:e})}function Ps(){return(0,q.useContext)(Ln)}function nr(e){let t=or(),[n,o]=(0,q.useState)(!1);(0,q.useEffect)(()=>t.withSelector(e).on("highlight",()=>{o(!0)}),[t,e]),(0,q.useEffect)(()=>t.withSelector(e).on("clear-highlight",()=>{o(!1)}),[t,e]);let r=(0,q.useCallback)(i=>{t.emit("click",{selectorId:e,event:i})},[e,t]),a=(0,q.useCallback)(i=>{t.emit("hover",{selectorId:e,event:i})},[e,t]);return{controller:t,onClick:r,onHover:a,isHighlighted:n}}function or(){let e=(0,q.useContext)(Ln);return(0,q.useMemo)(()=>({withSelector(t){return{on(n,o){let r=a=>{a&&a.selectorId===t&&o(a)};return e.on(n,r),()=>{e.off(n,r)}},emit(n,o){e.emit(n,{...o,selectorId:t})}}},on(t,n){return e.on(t,n),()=>{e.off(t,n)}},emit(t,n){e.emit(t,n)}}),[e])}function As(){let e=or();return(0,q.useMemo)(()=>({withSelector(t){return{highlight(){e.emit("highlight",{selectorId:t})},clearHighlight(){e.emit("clear-highlight",{selectorId:t})},zoomTo(){e.emit("zoom-to",{selectorId:t})},addEventListener(n,o){return e.emit("event-listener",{selectorId:t,name:n,callback:o}),()=>{e.emit("remove-event-listener",{selectorId:t,name:n,callback:o})}},getImagePreview(){return new Promise((n,o)=>{e.emit("image-preview-request",{selectorId:t,resolve:n,reject:o})})},on(n,o){return e.withSelector(t).on(n,o)}}},highlight(t){e.emit("highlight",{selectorId:t})},clearHighlight(t){e.emit("clear-highlight",{selectorId:t})},zoomTo(t){e.emit("zoom-to",{selectorId:t})},addEventListener(t,n,o){return e.emit("event-listener",{selectorId:t,name:n,callback:o}),()=>{e.emit("remove-event-listener",{selectorId:t,name:n,callback:o})}},getImagePreview(t){return new Promise((n,o)=>{e.emit("image-preview-request",{selectorId:t,resolve:n,reject:o})})},on(t,n){return e.on(t,n)}}),[e])}var at=require("react"),ga=require("react/jsx-runtime");function rr(){return{default:{backgroundColor:"rgba(0,0,0,0)",borderWidth:"2px",borderColor:"rgba(252,0,98, .5)"},highlighted:{backgroundColor:"rgba(75, 103, 225, 0.4)",borderWidth:"1px",borderColor:"rgba(75,103,225,0.99)"},hidden:{borderWidth:"0px",borderColor:"rgba(0,0,0,0)",backgroundColor:"rgba(0,0,0,0)",hidden:!0}}}var ir=(0,at.createContext)(rr());ir.displayName="AnnotationStyle";function ar(){return(0,at.useContext)(ir)}function Ts({theme:e,children:t}){let n=(0,at.useMemo)(()=>e||rr(),[e]);return(0,ga.jsx)(ir.Provider,{value:n,children:t})}var On=require("@atlas-viewer/atlas");var Q=require("react");var st=require("react"),ha=require("polygon-editor");function sr(e,t,n){let[o,r]=(0,st.useState)({}),a=(0,st.useMemo)(()=>(0,ha.createHelper)(e,n),[]);return(0,st.useEffect)(()=>(a.clock.start(t,r),()=>{a.clock.stop()}),[]),{state:o,helper:a}}var ya=require("polygon-editor"),N=require("react/jsx-runtime"),Ae=(0,ya.createSvgHelpers)();function cr(e,t){let{image:n,currentShape:o,onChange:r,hideShapeLines:a}=e,i=(0,Q.useRef)(),s=(0,Q.useRef)(),l=(0,Q.useRef)(),u=(0,Q.useRef)(),c=(0,Q.useRef)(),d=(0,Q.useRef)(),v=(0,Q.useRef)(),y=(0,Q.useRef)(),[x,g]=(0,Q.useState)(null),[S,h]=(0,Q.useState)(!1),{helper:C,state:m}=sr(o,(k,ne)=>{Ae.updateTransitionBoundingBox(s.current,k,ne),Ae.updateBoundingBoxPolygon(i.current,k,ne),Ae.updateTransitionShape(d.current,k,ne),Ae.updateClosestLinePointTransform(u.current,k,ne),Ae.updateSelectBox(l.current,k,ne),Ae.updatePointLine(v.current,k,ne),Ae.updateDrawPreview(c.current,k,ne,3),Ae.updateLineBox(y.current,k),g(k.transitionDirection),h(k.transitionRotate)},r);(0,Q.useEffect)(()=>{C.setShape(o||null)},t),(0,Q.useEffect)(()=>{let k=()=>{C.modifiers.reset()};return document.addEventListener("mouseleave",k),()=>{document.removeEventListener("mouseleave",k)}},[]);let b=(0,N.jsxs)(N.Fragment,{children:[(0,N.jsx)("marker",{id:"dot",viewBox:"0 0 10 10",refX:"5",refY:"5",markerWidth:"5",markerHeight:"5",children:(0,N.jsx)("circle",{cx:"5",cy:"5",r:"4",className:"marker"})}),(0,N.jsx)("marker",{id:"selected",viewBox:"0 0 10 10",refX:"5",refY:"5",markerWidth:"5",markerHeight:"5",children:(0,N.jsx)("circle",{cx:"5",cy:"5",r:"4",fill:"#FAFF00"})}),(0,N.jsx)("marker",{id:"resizer",viewBox:"0 0 10 10",refX:"5",refY:"5",markerWidth:"5",markerHeight:"5",children:(0,N.jsx)("rect",{width:"10",height:"10",stroke:"#FF0DCB",fill:"#fff",strokeWidth:2})})]}),A=o?o.open?"polyline":"polygon":null,M=!m.showBoundingBox&&m.closestPoint!==null&&m.actionIntentType==="select-point",I=m.actionIntentType==="add-open-point",R=m.transitionIntentType==="split-line",B=m.transitioning&&m.selectedStamp&&m.transitionIntentType==="stamp-shape",_e=o&&A?(0,N.jsxs)(N.Fragment,{children:[(0,N.jsx)(A,{fill:!m.transitioning&&m.showBoundingBox?"rgba(255, 0, 0, .5)":"none",strokeWidth:B?0:2,stroke:a?"transparent":"#000",points:o.points.map(k=>k.join(",")).join(" "),vectorEffect:"non-scaling-stroke",markerStart:m.showBoundingBox?void 0:"url(#dot)",markerMid:m.showBoundingBox?void 0:"url(#dot)",markerEnd:m.showBoundingBox?void 0:"url(#dot)",style:{pointerEvents:"none"}}),m.lineBoxMode&&m.actionIntentType==="close-line-box"?(0,N.jsx)("polygon",{fill:"rgba(255, 0, 0, .4)",ref:y,stroke:"#000",strokeWidth:2,vectorEffect:"non-scaling-stroke"}):null,m.transitionIntentType==="draw-shape"&&m.transitioning?(0,N.jsx)("polyline",{ref:c,fill:"none",stroke:"rgba(255, 0, 0, .5)",strokeWidth:2,vectorEffect:"non-scaling-stroke"}):null,!m.showBoundingBox&&m.selectedPoints&&m.selectedPoints.length?(0,N.jsx)("polyline",{strokeWidth:2,vectorEffect:"non-scaling-stroke",stroke:"transparent",markerStart:"url(#selected)",markerMid:"url(#selected)",markerEnd:"url(#selected)",fill:"transparent",points:o.points.filter((k,ne)=>m.selectedPoints?.includes(ne)).map(k=>k.join(",")).join(" ")}):null,M&&m.closestPoint!==null&&o.points[m.closestPoint]?(0,N.jsx)("polyline",{strokeWidth:2,vectorEffect:"non-scaling-stroke",stroke:"transparent",markerStart:"url(#selected)",markerMid:"url(#selected)",markerEnd:"url(#selected)",fill:"transparent",points:`${o.points[m.closestPoint][0]},${o.points[m.closestPoint][1]}`}):null,!m.transitioning&&(m.actionIntentType==="add-open-point"||m.actionIntentType==="close-shape"||m.actionIntentType==="close-shape-line")?(0,N.jsx)("polyline",{stroke:"#000",ref:v,strokeWidth:m.actionIntentType==="close-shape"?2:1,vectorEffect:"non-scaling-stroke"}):null,m.hasClosestLine&&(!m.transitionIntentType||m.transitionIntentType==="split-line")?(0,N.jsx)("g",{ref:u,children:(0,N.jsx)("polyline",{style:{opacity:.5},markerStart:"url(#dot)",points:"0,0 10,10",vectorEffect:"non-scaling-stroke",fill:"transparent",strokeWidth:2})}):null,m.transitioning?(0,N.jsx)(A,{ref:d,fill:o.open?"none":"rgba(255, 0, 0, .5)",stroke:"rgba(255, 0, 0, .5)",strokeWidth:o.open?2:0}):null,m.transitioning&&m.transitionIntentType==="select-multiple-points"?(0,N.jsx)("rect",{ref:l,fill:"rgba(255, 255, 255, .3)",strokeWidth:1,stroke:"rgba(0,0,0,.2)",vectorEffect:"non-scaling-stroke"}):null,m.showBoundingBox?null:(0,N.jsx)("g",{name:"controls",children:!1}),m.showBoundingBox&&!B?(0,N.jsx)("polygon",{ref:i,strokeWidth:2,stroke:"#FF0DCB",fill:"none",markerStart:"url(#resizer)",markerMid:"url(#resizer)",markerEnd:"url(#resizer)",vectorEffect:"non-scaling-stroke"}):null]}):null;return{helper:C,state:m,isAddingPoint:I,isSplitting:R,isStamping:B,isHoveringPoint:M,transitionDirection:x,transitionRotate:S,defs:b,editor:_e}}var zn=require("react"),va=require("react-dom"),J=require("react/jsx-runtime"),Sa=[{name:"Default",outer:{borderWidth:4,borderColor:"rgba(255, 255, 255, .4)"},inner:{borderWidth:2,borderColor:"#000"}},{name:"High contrast",outer:{borderWidth:3,borderColor:"#fff"},inner:{borderWidth:1,borderColor:"#000"}},{name:"Lightsaber",outer:{borderWidth:"4",borderColor:"rgba(56,68,255,0.64)"},inner:{borderWidth:"2",borderColor:"#fff"}},{name:"Bright",outer:{borderWidth:"6",borderColor:"#25d527"},inner:{borderWidth:"3",borderColor:"#a916ff"}},{name:"pink",outer:{borderWidth:"4",borderColor:"#ff00ff"},inner:{borderWidth:"2",borderColor:"#ffffff"}},{name:"fine (dark)",outer:{borderWidth:"1",borderColor:"#000000"},inner:{}},{name:"fine (light)",outer:{borderWidth:"1",borderColor:"#FFF"},inner:{}}];function lr(e){let t=e.theme||Sa[0],n=(0,On.useAtlas)(),{image:o}=e,{helper:r,defs:a,editor:i,state:s,transitionDirection:l,isSplitting:u,transitionRotate:c,isHoveringPoint:d,isAddingPoint:v,isStamping:y}=cr({currentShape:e.shape||null,onChange:e.updateShape,image:e.image,hideShapeLines:!0},[]),x=m=>{r.pointer([[~~m.atlas.x,~~m.atlas.y]])};(0,zn.useEffect)(()=>{let m=b=>{r.key.up(b.key)};return document.addEventListener("keyup",m),()=>{document.removeEventListener("keyup",m)}},[]),(0,zn.useEffect)(()=>{let m=b=>{r.key.down(b.key)};return document.addEventListener("keydown",m),()=>{document.removeEventListener("keydown",m)}},[]),(0,zn.useEffect)(()=>{let m=[];return l&&m.push(`atlas-cursor-${l}`),s.actionIntentType==="cut-line"&&s.modifiers?.Shift&&m.push("atlas-cursor-cut"),(d||s.transitionIntentType==="move-shape"||s.transitionIntentType==="move-point")&&m.push("atlas-cursor-move"),v&&m.push("atlas-cursor-crosshair"),u&&m.push("atlas-cursor-copy"),c&&m.push("atlas-cursor-rotate"),s.transitionIntentType==="draw-shape"&&m.push("atlas-cursor-draw"),n?.canvas&&n.canvas.classList.add(...m),()=>{n?.canvas&&n.canvas.classList.remove(...m)}},[n?.canvas,v,d,u,s.modifiers?.Shift,s.actionIntentType,s.transitionIntentType,l,c]);let g=e.shape&&e.shape?.points.length===0,S=e.renderControls?e.renderControls(r,s,g):null,h=document.getElementById(e.controlsHtmlId||"atlas-controls"),C="shape";return(0,J.jsx)(J.Fragment,{children:(0,J.jsxs)("world-object",{height:o.height,width:o.width,onMouseMove:x,onMouseDown:r.pointerDown,onMouseUp:r.pointerUp,onMouseLeave:r.blur,children:[e.shape?(0,J.jsxs)(J.Fragment,{children:[(0,J.jsx)(C,{open:e.shape.open,points:e.shape.points,relativeStyle:!0,style:y?{}:t.outer}),(0,J.jsx)(C,{open:e.shape.open,points:e.shape.points,relativeStyle:!0,style:y?{}:t.inner})]}):null,(0,J.jsxs)(On.HTMLPortal,{relative:!0,interactive:!1,children:[(0,J.jsx)("div",{style:{position:"absolute",top:0,right:0,left:0,bottom:0},children:(0,J.jsxs)("svg",{width:"100%",height:"100%",viewBox:`0 0 ${o.width} ${o.height}`,tabIndex:-1,children:[(0,J.jsx)("defs",{children:a}),i]})}),h?(0,va.createPortal)(S,h,"controls"):null]})]})})}var ur=require("react/jsx-runtime");function Is(e){let t=P(),n=e.annotationBucket,o=e.readOnly,r=e.id,{onClick:a,isHighlighted:i}=nr(e.id),s=ar(),l=i?s.highlighted:s[n||"hidden"]||s.hidden;if(!t)return null;if(o){let u="shape",c=e.polygon,d=c.open;return c?(0,ur.jsx)(u,{id:`shape-${r}`,points:c.points,open:d,onClick:a,relativeStyle:!0,target:{x:0,y:0,width:t.width,height:t.height},style:l}):null}return(0,ur.jsx)(lr,{image:t,shape:e.polygon||{id:e.id,open:!0,points:[]},updateShape:e.updatePolygon,theme:e.theme,controlsHtmlId:e.controlsHtmlId,renderControls:e.renderControls})}var Hn=require("react"),xa=require("react-error-boundary");var Te=require("react/jsx-runtime");function ws({src:e,errorFallback:t,interactive:n,skipSizes:o,children:r,renderViewerControls:a,viewControlsDeps:i,fluid:s,x:l,y:u,...c}){let[d,v]=(0,Hn.useState)(),y=t||nn,[x,g]=It(),S=(0,Hn.useMemo)(()=>{let C=g[e]?.status,m=x({id:e},{});return m?.height&&m.width&&C!=="loading"?{id:e,width:m.width,height:m.height,service:m,type:"Image",selector:{type:"BoxSelector",spatial:{x:0,y:0,width:m.width,height:m.height}},target:{type:"BoxSelector",spatial:{x:0,y:0,width:m.width,height:m.height}}}:null},[x,e,g]);if(D(d&&a?"overlay":"none",`canvas-portal-controls-${e}`,re.Provider,a&&S?{value:d||null,children:a({image:S,images:[S],type:"images"})}:{},[e,S,d,...i||[]]),!S||!S.height||!S.width)return null;let h=s?void 0:c.homePosition?c.homePosition.width/c.homePosition.height:S.width/S.height;return console.log("here",h),(0,Te.jsx)(xa.ErrorBoundary,{resetKeys:[],fallbackRender:C=>(0,Te.jsx)(y,{...c,...C}),children:(0,Te.jsx)(an,{...c,aspectRatio:h,containerProps:{style:{position:"relative"},...c.containerProps||{}},onCreated:C=>{v(C),c.onCreated&&c.onCreated(C)},children:(0,Te.jsxs)(re.Provider,{value:d,children:[(0,Te.jsx)(Ce,{image:S,id:S.id,isStatic:!n,x:l,y:u},S.id),(0,Te.jsx)(ks,{viewerPreset:d,renderViewerControls:a,image:S,src:e,viewControlsDeps:i}),r]})})})}function ks({viewerPreset:e,renderViewerControls:t,image:n,src:o,viewControlsDeps:r}){return D(e&&t?"overlay":"none",`canvas-portal-controls-${o}`,re.Provider,t&&n?{value:e||null,children:t({image:n,images:[n],type:"images"})}:{},[o,e,...r||[]]),null}var Ca=require("react/jsx-runtime");function Ms({annotation:e,children:t}){return(0,Ca.jsx)($,{value:{annotation:e},children:t})}var ba=require("react/jsx-runtime");function Es({annotationPage:e,children:t}){return(0,ba.jsx)($,{value:{annotationPage:e},children:t})}var Ra=require("react/jsx-runtime");function Ns({collection:e,children:t}){return(0,Ra.jsx)($,{value:{collection:e},children:t})}function Vs(e,t={}){return Oe(t)}var Pa=require("@atlas-viewer/atlas"),Ie=require("react");function Ls({canvasId:e}={}){let t=(0,Pa.useCanvas)(),n=Ee(),o=(0,Ie.useMemo)(()=>e?[e]:t?[t.id]:n.map(u=>u.id),[e,t,n]),[r,a]=(0,Ie.useState)({}),i=yt();(0,Ie.useEffect)(()=>{let u=c=>{let d=c.partOf.canvasId;d&&a(v=>({...v,[d]:c.choice}))};return i.on("choice-change",u),()=>{i.off("choice-change",u)}},[]);let s=(0,Ie.useMemo)(()=>{let u=[];for(let c of o){let d=r[c];d&&u.push({canvasId:c,choice:d})}return u},[o,r]),l=(0,Ie.useMemo)(()=>({makeChoice:(u,c)=>{i.emit("make-choice",{choiceId:u,...c})}}),[i]);return{choices:s,actions:l}}function zs(e,t=!1){}function Os(e){let n=W().manifest,o=e?e.map(r=>typeof r=="string"?r:r?.id):[];return w(r=>{let a=n?r.iiif.entities.Manifest[n]:void 0,i=a?.items||[];if(typeof e>"u")return i;let s=[];for(let l of a?.items||[])o.indexOf(l.id)!==-1&&s.push(l);return s},[o.join("/")])}var Aa=require("react");function Hs(e,t=[]){let{id:n,selector:o}=e,r=W(),a=n||r.collection,i=w(s=>a?s.iiif.entities.Collection[a]:void 0,[a]);return(0,Aa.useMemo)(()=>{if(i)return o?o(i):i},[i,o,...t])}var Bn=require("react"),Ta=require("@iiif/helpers/events");function Bs(e,t,n,o,r=[]){let a=T(),i=(0,Bn.useMemo)(()=>(0,Ta.createEventsHelper)(a),[a]);(0,Bn.useEffect)(()=>{let s=e;return s?(i.addEventListener(s,t,n,o),()=>{i.removeEventListener(s,t,n)}):()=>{}},[i,e,t,...r])}function Ds(e,t){let{id:n,isLoaded:o,error:r,resource:a,requestId:i,cached:s}=mt(e,t);return{id:n,isLoaded:o,error:r,manifest:a,requestId:i,cached:s}}var mr=require("@iiif/parser/image-3");var de=require("react");function dr({cacheKey:e}={}){let t=P(),n=Oe(),o=T(),r=tt(),a=fi(),[i,s]=(0,de.useState)(void 0),[l,u]=(0,de.useState)(!1),[c,d]=(0,de.useState)("idle"),[v,y]=(0,de.useState)(void 0),x=t?t.id:"undefined",g=(0,de.useMemo)(()=>{try{if(t&&n.length){let h=n[0],C=o.get(h.body[0]),b=(0,mr.getImageServices)(C)[0];return b&&r(b,{width:b.width||t.width,height:b.height||t.height},!0)||void 0}}catch(h){console.error(h)}},[x,e,t]),S=c==="success"&&i?i:g;return(0,de.useEffect)(()=>{(async()=>{try{if(t&&n.length){let h=n[0],C=o.get(h.body[0]),b=(0,mr.getImageServices)(C)[0];if(!b)return;u(!0),d("loading");try{let A=await a(b,{width:b.width||t.width,height:b.height||t.height})||void 0;s(A),d("success"),u(!1)}catch(A){d("error"),y(A)}}}catch(h){d("error"),y(h)}})()},[x,e]),(0,de.useMemo)(()=>({data:S,isFetching:l,status:c,error:v}),[S,l,c,v])}function Fs(){let e=dr();return{isLoading:e.isFetching,tile:e.data?{id:e.data.id||e.data["@id"],width:e.data.width,height:e.data.height,imageService:e.data,thumbnail:void 0}:null}}var Ia=require("@iiif/helpers/styles"),wa=require("react");function qs(){let e=T();return(0,wa.useMemo)(()=>(0,Ia.createStylesHelper)(e),[e])}p(f,require("@iiif/helpers/annotation-targets"),module.exports);
48
+ `}),(0,Dt.jsx)("iframe",{className:"video-yt",ref:r,src:`https://www.youtube.com/embed/${t.youTubeId}?enablejsapi=1&origin=${window.location.host}`,referrerPolicy:"no-referrer",sandbox:"allow-scripts allow-same-origin allow-presentation"})]}):null}function oa({media:e,mediaControlsDeps:t,children:n}){let[{element:r,currentTime:o,progress:a},i,s]=Be({duration:e.duration});return D("overlay","video-element",ds,{element:r,media:e,playPause:s.playPause}),null}var wn=require("react/jsx-runtime");function Gr(){let{strategy:e}=V(),{renderMediaControls:t,mediaControlsDeps:n}=_();return e.type!=="media"||e.media.type!=="VideoYouTube"?null:(0,wn.jsxs)(oa,{media:e.media,mediaControlsDeps:n,children:[(0,wn.jsx)(We,{}),t?t(e):null]})}var X=require("react/jsx-runtime");function Ue({x:e,y:t,onChoiceChange:n,registerActions:r,defaultChoices:o,isStatic:a,renderViewerControls:i,renderMediaControls:s,renderComplexTimelineControls:l,complexTimelineControlsDeps:u,viewControlsDeps:c,mediaControlsDeps:d,strategies:v,throwOnUnknown:h,backgroundStyle:x,alwaysShowBackground:g,keepCanvasScale:S=!1,enableSizes:y=!1,enableYouTube:C=!0,onClickPaintingAnnotation:m,components:b={},children:A}){return(0,X.jsxs)(kr,{throwOnUnknown:h,onChoiceChange:n,registerActions:r,strategies:v,defaultChoices:o,mediaControlsDeps:d,renderMediaControls:s,renderViewerControls:i,renderComplexTimelineControls:l,complexTimelineControlsDeps:u,viewControlsDeps:c,children:[(0,X.jsxs)(Mr,{keepCanvasScale:S,x:e,y:t,children:[(0,X.jsx)(Er,{alwaysShowBackground:g,backgroundStyle:x}),(0,X.jsx)(Hr,{}),(0,X.jsx)(Br,{}),(0,X.jsx)(Fr,{isStatic:a,enableSizes:y,onClickPaintingAnnotation:m}),(0,X.jsx)($r,{}),(0,X.jsx)(Wr,{}),(0,X.jsx)(Yr,{as:b.Audio}),(0,X.jsx)(jr,{as:b.Video}),C?(0,X.jsx)(Gr,{}):null,A]}),(0,X.jsx)(Kr,{})]})}var Xr=require("react/jsx-runtime");function ia(e){let t=P();return!t||!t.placeholderCanvas?null:(0,Xr.jsx)(re,{canvas:t.placeholderCanvas.id,children:(0,Xr.jsx)(Ue,{renderViewerControls:e.renderViewerControls})})}var Y=require("react/jsx-runtime"),fs=(0,Ft.forwardRef)(function(t,n){let r=z(),o=Ee(),a=ht(),{ViewerControls:i,MediaControls:s,ComplexTimelineControls:l}=t.components||{};if((0,Ft.useImperativeHandle)(n,()=>a,[a]),!r)return(0,Y.jsx)("div",{});let u=0;return(0,Y.jsxs)(Y.Fragment,{children:[t.header,(0,Y.jsx)(F.Viewer,{height:t.height,mode:t.mode,renderPreset:t.renderPreset,runtimeOptions:t.runtimeOptions,children:o.map((c,d)=>{let v=u;return u+=c.width+(t.spacing||0),(0,Y.jsx)(re,{canvas:c.id,children:(0,Y.jsx)(F.RenderCanvas,{strategies:["3d-model","media","images","empty","textual-content","complex-timeline"],renderViewerControls:d===0&&i?()=>(0,Y.jsx)(i,{}):void 0,renderMediaControls:d===0&&s?()=>(0,Y.jsx)(s,{}):void 0,renderComplexTimelineControls:d===0&&l?()=>(0,Y.jsx)(l,{}):void 0,x:v,...t.canvasProps||{},children:t.annotations},c.id)},c.id)})},t.reuseAtlas?"":a.currentSequenceIndex),t.children]})}),F=(0,Ft.forwardRef)(function({children:t,height:n,annotations:r,canvasProps:o,spacing:a,header:i,components:s,mode:l,reuseAtlas:u,renderPreset:c,runtimeOptions:d,...v},h){let x=ke();return(0,Y.jsx)(we,{vault:x,children:(0,Y.jsx)(nr,{...v,children:(0,Y.jsx)(fs,{ref:h,height:n,components:s,spacing:a,canvasProps:o,annotations:r,header:i,mode:l,reuseAtlas:u,renderPreset:c,runtimeOptions:d,children:t})})})});F.RenderImage=Ce;F.RenderCanvas=Ue;F.RenderAnnotationPage=Ct;F.RenderAnnotation=cn;F.Viewer=an;F.CanvasBackground=gn;F.Audio=Pn;F.Video=Tn;F.Model=bn;F.AudioHTML=Ur;F.VideoHTML=Qr;F.ModelHTML=qr;F.PlaceholderCanvas=ia;var aa=require("@atlas-viewer/atlas");var kn=require("react"),qt=require("react/jsx-runtime"),ps=(0,kn.forwardRef)(function({canvasId:t},n){let r=(0,aa.useCanvas)(),o=At(t||r?.id),a=T();return(0,kn.useImperativeHandle)(n,()=>o,[t,r]),!r||o.enabledPageIds.length===0?null:(0,qt.jsx)(qt.Fragment,{children:o.enabledPageIds.map(i=>(0,qt.jsx)(F.RenderAnnotationPage,{page:a.get(i)},i))})});var ca=require("react");var sa=require("react");var H=require("react/jsx-runtime");function Wt({metadata:e=[],config:t,labelWidth:n=16,showEmptyMessage:r=!0,allowHtml:o,emptyFallback:a,classes:i={},emptyMessage:s="No metadata available",emptyValueFallback:l="No value",emptyLabelFallback:u="",separator:c,tableFooter:d,tableHeader:v}){let h=(0,sa.useMemo)(()=>{let g=(t||[]).reduce((y,C)=>[...y,...C.keys],[]),S={};for(let y of e){let C=y&&y.label?Object.values(y.label):[];for(let m of C)if(m&&m.length&&(g.indexOf(`metadata.${m[0]}`)!==-1||g.length===0)&&y){let b=`metadata.${m[0]}`;S[b]=S[b]?S[b]:[],S[b].push(y);break}}return S},[t,e]);return Object.keys(h).length===0&&r?(0,H.jsx)(H.Fragment,{children:a})||(0,H.jsx)("div",{className:i.empty,children:s}):t&&t.length?(0,H.jsxs)("table",{className:i.container,children:[v,(0,H.jsx)("tbody",{children:t.map((g,S)=>{let y=[];for(let C of g.keys)for(let m of h[C]||[])y.push((0,H.jsx)(te,{enableDangerouslySetInnerHTML:o,defaultText:l,separator:c,children:m.value},S+"__"+C));return y.length===0?null:(0,H.jsxs)("tr",{className:i.row,children:[(0,H.jsx)("td",{className:i.label,style:n?{minWidth:n}:{},children:(0,H.jsx)(te,{enableDangerouslySetInnerHTML:o,separator:c,defaultText:u,children:g.label})}),(0,H.jsx)("td",{className:i.value,children:y})]},S)})}),d]}):(0,H.jsxs)("table",{className:i.container,children:[v,(0,H.jsx)("tbody",{children:e&&e.length?e.map((g,S)=>g?(0,H.jsxs)("tr",{className:i.row,children:[(0,H.jsx)("td",{className:i.label,style:n?{minWidth:n}:{},children:(0,H.jsx)(te,{enableDangerouslySetInnerHTML:o,defaultText:l,separator:c,children:g.label})}),(0,H.jsx)("td",{className:i.value,children:(0,H.jsx)(te,{enableDangerouslySetInnerHTML:o,defaultText:l,separator:c,children:g.value})})]},S):null):null}),d]})}var la=require("react/jsx-runtime");function gs(e){let t=z(),n=P(),r=dt(),o=(0,ca.useMemo)(()=>{let a=t?.metadata||[],i=n?.metadata||[],s=r?.metadata||[];return[...a,...i,...s]},[t,n,r]);return(0,la.jsx)(Wt,{metadata:o,...e})}var Nn=require("react");var Mn=require("@iiif/parser/image-3"),ua=require("react");function En(e,t={},n=[]){return(0,ua.useMemo)(()=>{if(!e)return null;let r=t.quality;e&&e.extraQualities&&t.quality&&(e.extraQualities.includes(t.quality)||(r="default"));let o=(0,Mn.createImageServiceRequest)(e);return(0,Mn.imageServiceRequestToString)({identifier:o.identifier,server:o.server,scheme:o.scheme,type:"image",size:{max:!t.size?.width&&!t.size?.height,confined:!1,upscaled:!1,...t.size||{}},format:t.format||"jpg",region:t.region||{full:!0},rotation:t?.rotation?Number.isInteger(t.rotation)?{angle:t.rotation}:t.rotation:{angle:0},quality:r||"default",prefix:o.prefix,originalPath:o.originalPath})},[...n])}var $t=require("react/jsx-runtime");function hs(e){let t=typeof e.src=="string"?e.src:e.src.id,n=zt(),[r,o]=(0,Nn.useState)(!1),a;if(t){let s=n.loadServiceSync({id:t});s&&(a=s)}!a&&!r&&n.loadService({id:t}).then(()=>{o(!0)});let i=En(a,{size:e.size,selector:e.region,rotation:e.rotation,format:e.format,region:e.region,quality:e.quality},[r,e.src,e.size,e.region,e.rotation,e.format,e.region,e.quality]);return(0,Nn.useEffect)(()=>()=>{o(!1)},[t]),i?(0,$t.jsx)("img",{src:i,alt:e.alt,className:e.className,style:e.style}):(0,$t.jsx)(ma,{...e,fetchImageService:!1})}function ma(e){if(e.fetchImageService)return(0,$t.jsx)(hs,{...e});let t=typeof e.src=="string"?{id:e.src,profile:"level0"}:e.src,n=En(t,{size:e.size,selector:e.region,rotation:e.rotation,format:e.format,region:e.region,quality:e.quality},[e.src,e.size,e.region,e.rotation,e.format,e.region,e.quality]);return n?(0,$t.jsx)("img",{src:n,alt:e.alt,className:e.className,style:e.style}):null}var da=require("react/jsx-runtime");function ys(e){let t=z();return(0,da.jsx)(Wt,{metadata:t?.metadata||[],...e})}var Vn=require("react");var Zr=j(require("react-lazy-load-image-component"),1);var fa=require("@iiif/helpers/i18n"),Z=require("react/jsx-runtime"),{LazyLoadComponent:vs}=Zr||Zr.default;function Jr(e){let{size:t,visible:n,classes:r,canvasId:o,figure:a}=e,i=t?.width||128,s=t?.height||t?.width||128,l=(0,Z.jsx)(Ss,{...e}),u=(0,Z.jsx)(vs,{threshold:300,style:{height:s,width:i},visibleByDefault:n,children:o?(0,Z.jsx)(re,{canvas:o,children:l}):l});return a?(0,Z.jsx)("figure",{className:r?.figure,children:u}):u}function Ss({fallback:e,size:t,classes:n,showLabel:r,alt:o,dereference:a=!1}){let i=P(),s=t?.width||128,l=t?.height||t?.width||128,u=o||(0,fa.getValue)(i?.label)||"",c=he({width:s,height:l,allowUnsafe:!0},a);return!c||c.type!=="fixed"?(0,Z.jsx)(Z.Fragment,{children:e}):(0,Z.jsxs)(Z.Fragment,{children:[(0,Z.jsx)("div",{className:n?.imageWrapper,children:(0,Z.jsx)("img",{className:n?.img,src:c.id,alt:u})}),r?(0,Z.jsx)(te,{as:"figcaption",className:n?.label,children:i?.label}):null]})}var it=require("react/jsx-runtime");function xs({scrollBehaviour:e,dereference:t,flat:n,size:r,classes:o={},showLabel:a,figure:i,fallback:s}){let l=(0,Vn.useRef)(null),{items:u,sequence:c,currentSequenceIndex:d,setSequenceIndex:v}=ht(),h={row:o.selected?.row||o.row,item:o.selected?.item||o.item,figure:o.selected?.figure||o.figure,img:o.selected?.img||o.img,label:o.selected?.label||o.label,imageWrapper:o.selected?.imageWrapper||o.imageWrapper};(0,Vn.useLayoutEffect)(()=>{if(!l.current)return;let g=l.current.querySelector("[data-selected=true]");g&&g.scrollIntoView({behavior:e||"instant",block:"nearest",inline:"center"})},[d]);let x=[];for(let g of c){let S=[],y=c[d]===g;for(let C of g){let m=u[C];S.push((0,it.jsx)("div",{className:y?h.item:o.item,children:(0,it.jsx)(Jr,{classes:y?h:o,canvasId:m.id,size:r,dereference:t,showLabel:a,figure:i,placeholder:(0,it.jsx)("div",{style:{height:128,width:128}}),fallback:s})},C))}if(n){x.push(S);continue}x.push((0,it.jsx)("div",{onClick:C=>{v(c.indexOf(g))},"data-selected":y,className:y?h.row:o.row,children:S},g.join("-")))}return(0,it.jsx)("div",{ref:l,className:o.container,children:x})}var K=require("react/jsx-runtime"),Cs={draw:!0,polygon:!0,line:!0,lineBox:!0,square:!0,triangle:!0,hexagon:!0,circle:!0,delete:!0};function bs({helper:e,showShapes:t,state:n,enabled:r=Cs,classNames:o={},icons:a={}}){return(0,K.jsxs)(K.Fragment,{children:[t?(0,K.jsxs)(K.Fragment,{children:[r.draw&&(0,K.jsx)("button",{className:o.button,onClick:()=>{e.stamps.clear(),e.draw.enable()},"data-active":!n.lineMode&&!n.selectedStamp&&t&&n.drawMode,children:a.DrawIcon||"Draw"}),r.polygon&&(0,K.jsx)("button",{className:o.button,"data-active":!n.lineMode&&!n.selectedStamp&&t&&!n.drawMode,onClick:()=>{e.stamps.clear(),e.draw.disable(),e.modes.disableLineBoxMode(),e.modes.disableLineMode()},children:a.PolygonIcon||"Polygon"}),r.line&&(0,K.jsx)("button",{className:o.button,"data-active":n.lineMode&&!n.lineBoxMode,onClick:()=>{e.modes.enableLineMode()},children:a.LineIcon||"Line"}),r.lineBox&&(0,K.jsx)("button",{className:o.button,"data-active":n.lineBoxMode,onClick:()=>{e.modes.enableLineBoxMode()},children:a.LineBoxIcon||"LineBox"}),r.square&&(0,K.jsx)("button",{className:o.button,"data-active":n.selectedStamp?.id==="square",onClick:()=>{e.stamps.square()},children:a.SquareIcon||"Square"}),r.triangle&&(0,K.jsx)("button",{className:o.button,"data-active":n.selectedStamp?.id==="triangle",onClick:()=>{e.stamps.triangle()},children:a.TriangleIcon||"Triangle"}),r.hexagon&&(0,K.jsx)("button",{className:o.button,"data-active":n.selectedStamp?.id==="hexagon",onClick:()=>{e.stamps.hexagon()},children:a.HexagonIcon||"Hexagon"})]}):null,n.showBoundingBox&&r.delete&&(0,K.jsx)("button",{className:o.button,onClick:()=>e.key.down("Backspace"),children:a.DeleteForeverIcon||"Delete"})]})}var q=require("react"),eo=j(require("mitt"),1),pa=require("react/jsx-runtime"),Ln=(0,q.createContext)((0,eo.default)());Ln.displayName="SelectorHelper";function Rs({children:e}){return(0,pa.jsx)(Ln.Provider,{value:(0,q.useMemo)(()=>(0,eo.default)(),[]),children:e})}function Ps(){return(0,q.useContext)(Ln)}function to(e){let t=no(),[n,r]=(0,q.useState)(!1);(0,q.useEffect)(()=>t.withSelector(e).on("highlight",()=>{r(!0)}),[t,e]),(0,q.useEffect)(()=>t.withSelector(e).on("clear-highlight",()=>{r(!1)}),[t,e]);let o=(0,q.useCallback)(i=>{t.emit("click",{selectorId:e,event:i})},[e,t]),a=(0,q.useCallback)(i=>{t.emit("hover",{selectorId:e,event:i})},[e,t]);return{controller:t,onClick:o,onHover:a,isHighlighted:n}}function no(){let e=(0,q.useContext)(Ln);return(0,q.useMemo)(()=>({withSelector(t){return{on(n,r){let o=a=>{a&&a.selectorId===t&&r(a)};return e.on(n,o),()=>{e.off(n,o)}},emit(n,r){e.emit(n,{...r,selectorId:t})}}},on(t,n){return e.on(t,n),()=>{e.off(t,n)}},emit(t,n){e.emit(t,n)}}),[e])}function As(){let e=no();return(0,q.useMemo)(()=>({withSelector(t){return{highlight(){e.emit("highlight",{selectorId:t})},clearHighlight(){e.emit("clear-highlight",{selectorId:t})},zoomTo(){e.emit("zoom-to",{selectorId:t})},addEventListener(n,r){return e.emit("event-listener",{selectorId:t,name:n,callback:r}),()=>{e.emit("remove-event-listener",{selectorId:t,name:n,callback:r})}},getImagePreview(){return new Promise((n,r)=>{e.emit("image-preview-request",{selectorId:t,resolve:n,reject:r})})},on(n,r){return e.withSelector(t).on(n,r)}}},highlight(t){e.emit("highlight",{selectorId:t})},clearHighlight(t){e.emit("clear-highlight",{selectorId:t})},zoomTo(t){e.emit("zoom-to",{selectorId:t})},addEventListener(t,n,r){return e.emit("event-listener",{selectorId:t,name:n,callback:r}),()=>{e.emit("remove-event-listener",{selectorId:t,name:n,callback:r})}},getImagePreview(t){return new Promise((n,r)=>{e.emit("image-preview-request",{selectorId:t,resolve:n,reject:r})})},on(t,n){return e.on(t,n)}}),[e])}var at=require("react"),ga=require("react/jsx-runtime");function ro(){return{default:{backgroundColor:"rgba(0,0,0,0)",borderWidth:"2px",borderColor:"rgba(252,0,98, .5)"},highlighted:{backgroundColor:"rgba(75, 103, 225, 0.4)",borderWidth:"1px",borderColor:"rgba(75,103,225,0.99)"},hidden:{borderWidth:"0px",borderColor:"rgba(0,0,0,0)",backgroundColor:"rgba(0,0,0,0)",hidden:!0}}}var oo=(0,at.createContext)(ro());oo.displayName="AnnotationStyle";function io(){return(0,at.useContext)(oo)}function Ts({theme:e,children:t}){let n=(0,at.useMemo)(()=>e||ro(),[e]);return(0,ga.jsx)(oo.Provider,{value:n,children:t})}var On=require("@atlas-viewer/atlas");var Q=require("react");var st=require("react"),ha=require("polygon-editor");function ao(e,t,n){let[r,o]=(0,st.useState)({}),a=(0,st.useMemo)(()=>(0,ha.createHelper)(e,n),[]);return(0,st.useEffect)(()=>(a.clock.start(t,o),()=>{a.clock.stop()}),[]),{state:r,helper:a}}var ya=require("polygon-editor"),N=require("react/jsx-runtime"),Ae=(0,ya.createSvgHelpers)();function so(e,t){let{image:n,currentShape:r,onChange:o,hideShapeLines:a}=e,i=(0,Q.useRef)(),s=(0,Q.useRef)(),l=(0,Q.useRef)(),u=(0,Q.useRef)(),c=(0,Q.useRef)(),d=(0,Q.useRef)(),v=(0,Q.useRef)(),h=(0,Q.useRef)(),[x,g]=(0,Q.useState)(null),[S,y]=(0,Q.useState)(!1),{helper:C,state:m}=ao(r,(k,ne)=>{Ae.updateTransitionBoundingBox(s.current,k,ne),Ae.updateBoundingBoxPolygon(i.current,k,ne),Ae.updateTransitionShape(d.current,k,ne),Ae.updateClosestLinePointTransform(u.current,k,ne),Ae.updateSelectBox(l.current,k,ne),Ae.updatePointLine(v.current,k,ne),Ae.updateDrawPreview(c.current,k,ne,3),Ae.updateLineBox(h.current,k),g(k.transitionDirection),y(k.transitionRotate)},o);(0,Q.useEffect)(()=>{C.setShape(r||null)},t),(0,Q.useEffect)(()=>{let k=()=>{C.modifiers.reset()};return document.addEventListener("mouseleave",k),()=>{document.removeEventListener("mouseleave",k)}},[]);let b=(0,N.jsxs)(N.Fragment,{children:[(0,N.jsx)("marker",{id:"dot",viewBox:"0 0 10 10",refX:"5",refY:"5",markerWidth:"5",markerHeight:"5",children:(0,N.jsx)("circle",{cx:"5",cy:"5",r:"4",className:"marker"})}),(0,N.jsx)("marker",{id:"selected",viewBox:"0 0 10 10",refX:"5",refY:"5",markerWidth:"5",markerHeight:"5",children:(0,N.jsx)("circle",{cx:"5",cy:"5",r:"4",fill:"#FAFF00"})}),(0,N.jsx)("marker",{id:"resizer",viewBox:"0 0 10 10",refX:"5",refY:"5",markerWidth:"5",markerHeight:"5",children:(0,N.jsx)("rect",{width:"10",height:"10",stroke:"#FF0DCB",fill:"#fff",strokeWidth:2})})]}),A=r?r.open?"polyline":"polygon":null,M=!m.showBoundingBox&&m.closestPoint!==null&&m.actionIntentType==="select-point",I=m.actionIntentType==="add-open-point",R=m.transitionIntentType==="split-line",B=m.transitioning&&m.selectedStamp&&m.transitionIntentType==="stamp-shape",_e=r&&A?(0,N.jsxs)(N.Fragment,{children:[(0,N.jsx)(A,{fill:!m.transitioning&&m.showBoundingBox?"rgba(255, 0, 0, .5)":"none",strokeWidth:B?0:2,stroke:a?"transparent":"#000",points:r.points.map(k=>k.join(",")).join(" "),vectorEffect:"non-scaling-stroke",markerStart:m.showBoundingBox?void 0:"url(#dot)",markerMid:m.showBoundingBox?void 0:"url(#dot)",markerEnd:m.showBoundingBox?void 0:"url(#dot)",style:{pointerEvents:"none"}}),m.lineBoxMode&&m.actionIntentType==="close-line-box"?(0,N.jsx)("polygon",{fill:"rgba(255, 0, 0, .4)",ref:h,stroke:"#000",strokeWidth:2,vectorEffect:"non-scaling-stroke"}):null,m.transitionIntentType==="draw-shape"&&m.transitioning?(0,N.jsx)("polyline",{ref:c,fill:"none",stroke:"rgba(255, 0, 0, .5)",strokeWidth:2,vectorEffect:"non-scaling-stroke"}):null,!m.showBoundingBox&&m.selectedPoints&&m.selectedPoints.length?(0,N.jsx)("polyline",{strokeWidth:2,vectorEffect:"non-scaling-stroke",stroke:"transparent",markerStart:"url(#selected)",markerMid:"url(#selected)",markerEnd:"url(#selected)",fill:"transparent",points:r.points.filter((k,ne)=>m.selectedPoints?.includes(ne)).map(k=>k.join(",")).join(" ")}):null,M&&m.closestPoint!==null&&r.points[m.closestPoint]?(0,N.jsx)("polyline",{strokeWidth:2,vectorEffect:"non-scaling-stroke",stroke:"transparent",markerStart:"url(#selected)",markerMid:"url(#selected)",markerEnd:"url(#selected)",fill:"transparent",points:`${r.points[m.closestPoint][0]},${r.points[m.closestPoint][1]}`}):null,!m.transitioning&&(m.actionIntentType==="add-open-point"||m.actionIntentType==="close-shape"||m.actionIntentType==="close-shape-line")?(0,N.jsx)("polyline",{stroke:"#000",ref:v,strokeWidth:m.actionIntentType==="close-shape"?2:1,vectorEffect:"non-scaling-stroke"}):null,m.hasClosestLine&&(!m.transitionIntentType||m.transitionIntentType==="split-line")?(0,N.jsx)("g",{ref:u,children:(0,N.jsx)("polyline",{style:{opacity:.5},markerStart:"url(#dot)",points:"0,0 10,10",vectorEffect:"non-scaling-stroke",fill:"transparent",strokeWidth:2})}):null,m.transitioning?(0,N.jsx)(A,{ref:d,fill:r.open?"none":"rgba(255, 0, 0, .5)",stroke:"rgba(255, 0, 0, .5)",strokeWidth:r.open?2:0}):null,m.transitioning&&m.transitionIntentType==="select-multiple-points"?(0,N.jsx)("rect",{ref:l,fill:"rgba(255, 255, 255, .3)",strokeWidth:1,stroke:"rgba(0,0,0,.2)",vectorEffect:"non-scaling-stroke"}):null,m.showBoundingBox?null:(0,N.jsx)("g",{name:"controls",children:!1}),m.showBoundingBox&&!B?(0,N.jsx)("polygon",{ref:i,strokeWidth:2,stroke:"#FF0DCB",fill:"none",markerStart:"url(#resizer)",markerMid:"url(#resizer)",markerEnd:"url(#resizer)",vectorEffect:"non-scaling-stroke"}):null]}):null;return{helper:C,state:m,isAddingPoint:I,isSplitting:R,isStamping:B,isHoveringPoint:M,transitionDirection:x,transitionRotate:S,defs:b,editor:_e}}var zn=require("react"),va=require("react-dom"),J=require("react/jsx-runtime"),Sa=[{name:"Default",outer:{borderWidth:4,borderColor:"rgba(255, 255, 255, .4)"},inner:{borderWidth:2,borderColor:"#000"}},{name:"High contrast",outer:{borderWidth:3,borderColor:"#fff"},inner:{borderWidth:1,borderColor:"#000"}},{name:"Lightsaber",outer:{borderWidth:"4",borderColor:"rgba(56,68,255,0.64)"},inner:{borderWidth:"2",borderColor:"#fff"}},{name:"Bright",outer:{borderWidth:"6",borderColor:"#25d527"},inner:{borderWidth:"3",borderColor:"#a916ff"}},{name:"pink",outer:{borderWidth:"4",borderColor:"#ff00ff"},inner:{borderWidth:"2",borderColor:"#ffffff"}},{name:"fine (dark)",outer:{borderWidth:"1",borderColor:"#000000"},inner:{}},{name:"fine (light)",outer:{borderWidth:"1",borderColor:"#FFF"},inner:{}}];function co(e){let t=e.theme||Sa[0],n=(0,On.useAtlas)(),{image:r}=e,{helper:o,defs:a,editor:i,state:s,transitionDirection:l,isSplitting:u,transitionRotate:c,isHoveringPoint:d,isAddingPoint:v,isStamping:h}=so({currentShape:e.shape||null,onChange:e.updateShape,image:e.image,hideShapeLines:!0},[]),x=m=>{o.pointer([[~~m.atlas.x,~~m.atlas.y]])};(0,zn.useEffect)(()=>{let m=b=>{o.key.up(b.key)};return document.addEventListener("keyup",m),()=>{document.removeEventListener("keyup",m)}},[]),(0,zn.useEffect)(()=>{let m=b=>{o.key.down(b.key)};return document.addEventListener("keydown",m),()=>{document.removeEventListener("keydown",m)}},[]),(0,zn.useEffect)(()=>{let m=[];return l&&m.push(`atlas-cursor-${l}`),s.actionIntentType==="cut-line"&&s.modifiers?.Shift&&m.push("atlas-cursor-cut"),(d||s.transitionIntentType==="move-shape"||s.transitionIntentType==="move-point")&&m.push("atlas-cursor-move"),v&&m.push("atlas-cursor-crosshair"),u&&m.push("atlas-cursor-copy"),c&&m.push("atlas-cursor-rotate"),s.transitionIntentType==="draw-shape"&&m.push("atlas-cursor-draw"),n?.canvas&&n.canvas.classList.add(...m),()=>{n?.canvas&&n.canvas.classList.remove(...m)}},[n?.canvas,v,d,u,s.modifiers?.Shift,s.actionIntentType,s.transitionIntentType,l,c]);let g=e.shape&&e.shape?.points.length===0,S=e.renderControls?e.renderControls(o,s,g):null,y=document.getElementById(e.controlsHtmlId||"atlas-controls"),C="shape";return(0,J.jsx)(J.Fragment,{children:(0,J.jsxs)("world-object",{height:r.height,width:r.width,onMouseMove:x,onMouseDown:o.pointerDown,onMouseUp:o.pointerUp,onMouseLeave:o.blur,children:[e.shape?(0,J.jsxs)(J.Fragment,{children:[(0,J.jsx)(C,{open:e.shape.open,points:e.shape.points,relativeStyle:!0,style:h?{}:t.outer}),(0,J.jsx)(C,{open:e.shape.open,points:e.shape.points,relativeStyle:!0,style:h?{}:t.inner})]}):null,(0,J.jsxs)(On.HTMLPortal,{relative:!0,interactive:!1,children:[(0,J.jsx)("div",{style:{position:"absolute",top:0,right:0,left:0,bottom:0},children:(0,J.jsxs)("svg",{width:"100%",height:"100%",viewBox:`0 0 ${r.width} ${r.height}`,tabIndex:-1,children:[(0,J.jsx)("defs",{children:a}),i]})}),y?(0,va.createPortal)(S,y,"controls"):null]})]})})}var lo=require("react/jsx-runtime");function Is(e){let t=P(),n=e.annotationBucket,r=e.readOnly,o=e.id,{onClick:a,isHighlighted:i}=to(e.id),s=io(),l=i?s.highlighted:s[n||"hidden"]||s.hidden;if(!t)return null;if(r){let u="shape",c=e.polygon,d=c.open;return c?(0,lo.jsx)(u,{id:`shape-${o}`,points:c.points,open:d,onClick:a,relativeStyle:!0,target:{x:0,y:0,width:t.width,height:t.height},style:l}):null}return(0,lo.jsx)(co,{image:t,shape:e.polygon||{id:e.id,open:!0,points:[]},updateShape:e.updatePolygon,theme:e.theme,controlsHtmlId:e.controlsHtmlId,renderControls:e.renderControls})}var Hn=require("react"),xa=require("react-error-boundary");var Te=require("react/jsx-runtime");function ws({src:e,errorFallback:t,interactive:n,skipSizes:r,children:o,renderViewerControls:a,viewControlsDeps:i,fluid:s,x:l,y:u,...c}){let[d,v]=(0,Hn.useState)(),h=t||nn,[x,g]=It(),S=(0,Hn.useMemo)(()=>{let C=g[e]?.status,m=x({id:e},{});return m?.height&&m.width&&C!=="loading"?{id:e,width:m.width,height:m.height,service:m,type:"Image",selector:{type:"BoxSelector",spatial:{x:0,y:0,width:m.width,height:m.height}},target:{type:"BoxSelector",spatial:{x:0,y:0,width:m.width,height:m.height}}}:null},[x,e,g]);if(D(d&&a?"overlay":"none",`canvas-portal-controls-${e}`,oe.Provider,a&&S?{value:d||null,children:a({image:S,images:[S],type:"images"})}:{},[e,S,d,...i||[]]),!S||!S.height||!S.width)return null;let y=s?void 0:c.homePosition?c.homePosition.width/c.homePosition.height:S.width/S.height;return(0,Te.jsx)(xa.ErrorBoundary,{resetKeys:[],fallbackRender:C=>(0,Te.jsx)(h,{...c,...C}),children:(0,Te.jsx)(an,{...c,aspectRatio:y,containerProps:{style:{position:"relative"},...c.containerProps||{}},onCreated:C=>{v(C),c.onCreated&&c.onCreated(C)},children:(0,Te.jsxs)(oe.Provider,{value:d,children:[(0,Te.jsx)(Ce,{image:S,id:S.id,isStatic:!n,x:l,y:u},S.id),(0,Te.jsx)(ks,{viewerPreset:d,renderViewerControls:a,image:S,src:e,viewControlsDeps:i}),o]})})})}function ks({viewerPreset:e,renderViewerControls:t,image:n,src:r,viewControlsDeps:o}){return D(e&&t?"overlay":"none",`canvas-portal-controls-${r}`,oe.Provider,t&&n?{value:e||null,children:t({image:n,images:[n],type:"images"})}:{},[r,e,...o||[]]),null}var Ca=require("react/jsx-runtime");function Ms({annotation:e,children:t}){return(0,Ca.jsx)($,{value:{annotation:e},children:t})}var ba=require("react/jsx-runtime");function Es({annotationPage:e,children:t}){return(0,ba.jsx)($,{value:{annotationPage:e},children:t})}var Ra=require("react/jsx-runtime");function Ns({collection:e,children:t}){return(0,Ra.jsx)($,{value:{collection:e},children:t})}function Vs(e,t={}){return Oe(t)}var Pa=require("@atlas-viewer/atlas"),Ie=require("react");function Ls({canvasId:e}={}){let t=(0,Pa.useCanvas)(),n=Ee(),r=(0,Ie.useMemo)(()=>e?[e]:t?[t.id]:n.map(u=>u.id),[e,t,n]),[o,a]=(0,Ie.useState)({}),i=yt();(0,Ie.useEffect)(()=>{let u=c=>{let d=c.partOf.canvasId;d&&a(v=>({...v,[d]:c.choice}))};return i.on("choice-change",u),()=>{i.off("choice-change",u)}},[]);let s=(0,Ie.useMemo)(()=>{let u=[];for(let c of r){let d=o[c];d&&u.push({canvasId:c,choice:d})}return u},[r,o]),l=(0,Ie.useMemo)(()=>({makeChoice:(u,c)=>{i.emit("make-choice",{choiceId:u,...c})}}),[i]);return{choices:s,actions:l}}function zs(e,t=!1){}function Os(e){let n=W().manifest,r=e?e.map(o=>typeof o=="string"?o:o?.id):[];return w(o=>{let a=n?o.iiif.entities.Manifest[n]:void 0,i=a?.items||[];if(typeof e>"u")return i;let s=[];for(let l of a?.items||[])r.indexOf(l.id)!==-1&&s.push(l);return s},[r.join("/")])}var Aa=require("react");function Hs(e,t=[]){let{id:n,selector:r}=e,o=W(),a=n||o.collection,i=w(s=>a?s.iiif.entities.Collection[a]:void 0,[a]);return(0,Aa.useMemo)(()=>{if(i)return r?r(i):i},[i,r,...t])}var Bn=require("react"),Ta=require("@iiif/helpers/events");function Bs(e,t,n,r,o=[]){let a=T(),i=(0,Bn.useMemo)(()=>(0,Ta.createEventsHelper)(a),[a]);(0,Bn.useEffect)(()=>{let s=e;return s?(i.addEventListener(s,t,n,r),()=>{i.removeEventListener(s,t,n)}):()=>{}},[i,e,t,...o])}function Ds(e,t){let{id:n,isLoaded:r,error:o,resource:a,requestId:i,cached:s}=mt(e,t);return{id:n,isLoaded:r,error:o,manifest:a,requestId:i,cached:s}}var uo=require("@iiif/parser/image-3");var de=require("react");function mo({cacheKey:e}={}){let t=P(),n=Oe(),r=T(),o=tt(),a=fi(),[i,s]=(0,de.useState)(void 0),[l,u]=(0,de.useState)(!1),[c,d]=(0,de.useState)("idle"),[v,h]=(0,de.useState)(void 0),x=t?t.id:"undefined",g=(0,de.useMemo)(()=>{try{if(t&&n.length){let y=n[0],C=r.get(y.body[0]),b=(0,uo.getImageServices)(C)[0];return b&&o(b,{width:b.width||t.width,height:b.height||t.height},!0)||void 0}}catch(y){console.error(y)}},[x,e,t]),S=c==="success"&&i?i:g;return(0,de.useEffect)(()=>{(async()=>{try{if(t&&n.length){let y=n[0],C=r.get(y.body[0]),b=(0,uo.getImageServices)(C)[0];if(!b)return;u(!0),d("loading");try{let A=await a(b,{width:b.width||t.width,height:b.height||t.height})||void 0;s(A),d("success"),u(!1)}catch(A){d("error"),h(A)}}}catch(y){d("error"),h(y)}})()},[x,e]),(0,de.useMemo)(()=>({data:S,isFetching:l,status:c,error:v}),[S,l,c,v])}function Fs(){let e=mo();return{isLoading:e.isFetching,tile:e.data?{id:e.data.id||e.data["@id"],width:e.data.width,height:e.data.height,imageService:e.data,thumbnail:void 0}:null}}var Ia=require("@iiif/helpers/styles"),wa=require("react");function qs(){let e=T();return(0,wa.useMemo)(()=>(0,Ia.createStylesHelper)(e),[e])}p(f,require("@iiif/helpers/annotation-targets"),module.exports);