resuma 1.0.2

Resuma — resumable SSR Rust web framework: zero hydration, islands, server actions, Flow (Axum).
1
2
function m(t){let e=new Map;for(let r of t){let n=j(r.id);e.set(n,U(n,r.value))}return e}function j(t){return typeof t=="string"?t:typeof t=="number"?`s${t}`:`s${t[0]}`}function U(t,e){let r=e,n=new Set,o={id:t,get value(){return r},set value(a){o.set(a)},set(a){Object.is(a,r)||(r=a,n.forEach(i=>i(r)))},update(a){let i=a(r);i!==void 0?o.set(i):n.forEach(s=>s(r))},subscribe(a){return n.add(a),()=>n.delete(a)}};return o}var G="RESUMA-DYN";function p(t,e){t.querySelectorAll(G.toLowerCase()).forEach(n=>{let o=n.getAttribute("data-r-signal");if(!o)return;let a=e.get(o);a&&a.subscribe(i=>{n.textContent=M(i)})})}function h(t,e){t.querySelectorAll("[data-r-bind]").forEach(n=>R(n,e)),V(t,e)}function V(t,e){let r=document.createTreeWalker(t,NodeFilter.SHOW_ELEMENT),n=r.currentNode;for(;n;)n instanceof HTMLElement&&R(n,e),n=r.nextNode()}function R(t,e){for(let r of Array.from(t.attributes)){let n=r.name;if(!n.startsWith("data-r-bind:"))continue;let o=n.slice(12),[a,i="{}"]=r.value.split("|"),s=e.get(a);if(!s)continue;let c=l=>{let u=i.replace("{}",M(l));t.setAttribute(o,u)};c(s.value),s.subscribe(c)}}function M(t){if(t==null)return"";if(typeof t=="string")return t;if(typeof t=="number"||typeof t=="boolean")return String(t);try{return JSON.stringify(t)}catch{return String(t)}}var J="resuma-island";function w(t,e){t.querySelectorAll(J).forEach(n=>{let o=n.getAttribute("data-r-chunk");if(!o)return;if((n.getAttribute("data-r-load")??"eager")==="visible"&&"IntersectionObserver"in window){new IntersectionObserver((s,c)=>{for(let l of s)l.isIntersecting&&(c.unobserve(l.target),A(n,o,e))},{rootMargin:"100px"}).observe(n);return}A(n,o,e)})}async function A(t,e,r){let n=t.getAttribute("data-r-props")??"{}",o={};try{o=JSON.parse(n)}catch{}await K(e,o,t,r)}async function K(t,e,r,n){try{let o=await import(`/_resuma/island-chunk/${t}.js`);typeof o.resume=="function"&&o.resume(e,n,r)}catch(o){console.debug("[resuma] island chunk unavailable, staying static",t,o)}}var _=new Map;async function x(t,e){if(e){let s=_.get(e);return s||(s=L(e),_.set(e,s)),s}let[r,n]=t.split("#"),o=window.__resuma;if(r==="__page__"){let s=o.handlers[r]?.[n];if(s)return L(s)}let a=o.loaded.get(r);a||(a=await import(`/_resuma/handler/${r}.js`),o.loaded.set(r,a));let i=a[n];if(!i)throw new Error(`[resuma] handler ${n} not found in chunk ${r}`);return i}function L(t){let e=t.trim(),n=e.startsWith("(")||e.startsWith("function")||e.startsWith("async")?`return (${t});`:`return (async (event, state, __resuma) => { ${t} });`;return new Function(n)()}var C="resuma-root",b="resuma-state",v=new Map,y=new Set;async function X(t){if(!(!t||v.has(t)||y.has(t))&&!(t.startsWith("http")&&!t.startsWith(location.origin))){y.add(t);try{let e=await fetch(t,{headers:{Accept:"text/html"},credentials:"same-origin"});e.ok&&v.set(t,await e.text())}catch{}finally{y.delete(t)}}}var E=null;function H(t){E=t}function k(){return document.getElementById(C)??document.body}function Y(t){if(!t?.textContent)return{signals:[],handlers:{},islands:[],actions:[]};try{return JSON.parse(t.textContent)}catch(e){return console.error("[resuma] failed to parse state payload",e),{signals:[],handlers:{},islands:[],actions:[]}}}function z(t,e){if(t===e)return!0;let r="http://resuma.local",n=new URL(t,r),o=new URL(e,r);if(n.search)return n.pathname+n.search===o.pathname+o.search;if(n.pathname===o.pathname)return!0;if(n.pathname!=="/"&&o.pathname.startsWith(n.pathname)){let a=o.pathname.charCodeAt(n.pathname.length);return a===void 0||a===47}return!1}function I(t){document.querySelectorAll("a[data-r-nav]").forEach(e=>{let r=e.getAttribute("href");if(!r)return;let n=e.getAttribute("data-r-active-class");if(!n)return;let o=(e.getAttribute("data-r-base-class")??e.className).split(/\s+/).filter(a=>a&&a!==n).join(" ");e.setAttribute("data-r-base-class",o),e.className=z(r,t)?`${o} ${n}`.trim():o})}function S(){if(!window.__resuma){window.location.reload();return}if(E){E(),I(location.pathname+location.search);return}let t=Y(document.getElementById(b)),e=m(t.signals),r={};for(let[i,s]of e)r[i]=s;let n=window.__resuma,o={state:r,signals:e,handlers:t.handlers,contexts:t.contexts??{},loaded:n.loaded??new Map,action:n.action,safeAction:n.safeAction,refreshIsland:n.refreshIsland,context:i=>o.contexts[i],navigate:g,buildUrl:P,invalidate:Z};window.__resuma=o;let a=k();p(a,e),h(a,e),w(a,e),I(location.pathname+location.search)}function Q(){let t=k(),e=t.querySelector("[autofocus]")??t.querySelector("h1, [role='heading'], main")??t;e.hasAttribute("tabindex")||e.setAttribute("tabindex","-1");try{e.focus({preventScroll:!0})}catch{e.focus()}}function P(t,e){let r=new URL(t,location.origin);if(e)for(let[n,o]of Object.entries(e))o!=null&&o!==""&&r.searchParams.set(n,o);return r.pathname+r.search}async function Z(t,e){let r=t?.split("?")[0]??location.pathname,n=String(Date.now());await g(P(r,{...e,_r:n}))}async function g(t,e=!0){try{let r=v.get(t);if(r)v.delete(t);else{let s=await fetch(t,{headers:{Accept:"text/html"},credentials:"same-origin"});if(!s.ok){window.location.href=t;return}r=await s.text()}let n=new DOMParser().parseFromString(r,"text/html"),o=n.getElementById(C),a=n.getElementById(b);if(!o||!a?.textContent){window.location.href=t;return}k().innerHTML=o.innerHTML;let i=document.getElementById(b);i&&(i.textContent=a.textContent),n.title&&(document.title=n.title),e&&history.pushState({resumaNav:!0},"",t),S(),e&&window.scrollTo(0,0),Q(),document.dispatchEvent(new CustomEvent("resuma:navigate",{detail:{href:t}}))}catch(r){console.error("[resuma] navigation failed",r),window.location.href=t}}function T(t){t.startsWith("/")&&!t.startsWith("//")?g(t):window.location.assign(t)}function tt(t,e){if(e.defaultPrevented||e.button!==0||e.metaKey||e.ctrlKey||e.shiftKey||e.altKey||t.target&&t.target!=="_self")return!1;let r=t.getAttribute("href");if(!r||r.startsWith("#")||r.startsWith("javascript:"))return!1;if(r.startsWith("http://")||r.startsWith("https://"))try{return new URL(r).origin===location.origin}catch{return!1}return!0}function N(){document.addEventListener("mouseenter",t=>{let e=t.target;if(!(e instanceof Element))return;let n=e.closest("a[data-r-nav]")?.getAttribute("href");n&&X(n)},!0),document.addEventListener("click",t=>{let e=t.target;if(!(e instanceof Element))return;let r=e.closest("a[data-r-nav]");if(!r||!tt(r,t))return;let n=r.getAttribute("href");n&&(t.preventDefault(),g(n))}),window.addEventListener("popstate",()=>{g(location.pathname+location.search,!1)})}var et="resuma-state",nt="resuma-root",rt="data-r-on:",ot="data-r-cap:",at="data-r-inline:",d=()=>document.getElementById(nt)??document.body;function F(){let t=document.getElementById(et);if(!t||!t.textContent)return{signals:[],handlers:{},islands:[],actions:[]};try{return JSON.parse(t.textContent)}catch(e){return console.error("[resuma] failed to parse state payload",e),{signals:[],handlers:{},islands:[],actions:[]}}}function st(){return F().csrf_token??""}function q(t={}){let e={...t},r=st();return r&&(e["x-resuma-csrf"]=r),e}function O(){H($),$(),ct(),gt(),N()}function $(){let t=F(),e=m(t.signals),r={};for(let[o,a]of e)r[o]=a;let n={state:r,signals:e,handlers:t.handlers,contexts:t.contexts??{},loaded:new Map,action:W,safeAction:vt,refreshIsland:yt,context:o=>n.contexts[o]};window.__resuma=n,p(d(),e),h(d(),e),w(d(),e),mt(d()),pt(d()),ht(d()),wt(t.visible_tasks??{},r)}var it=["click","input","change","submit","focus","blur","keydown","keyup","keypress","mousedown","mouseup","mousemove","mouseenter","mouseleave","pointerdown","pointerup","pointermove","touchstart","touchend","scroll","wheel","dragstart","dragend","drop","load"];function ct(){for(let t of it)document.addEventListener(t,ut,!0)}function lt(t){let e=t.target;return e instanceof Element?e:e instanceof Text?e.parentElement:null}async function ut(t){let e=lt(t);if(!e)return;let r=rt+t.type,n=ot+t.type,o=at+t.type;for(;e&&e!==document.body;){e.getAttribute(`data-r-prevent:${t.type}`)!==null&&t.preventDefault(),e.getAttribute(`data-r-stop:${t.type}`)!==null&&t.stopPropagation();let s=e.getAttribute(r);if(s){let c=(e.getAttribute(n)??"").split(",").map(u=>u.trim()).filter(Boolean),l=e.getAttribute(o);try{let u=await x(s,l),f=dt(c),D=window.__resuma;await u(t,f,D)}catch(u){console.error("[resuma] handler error",u)}return}e=e.parentElement}}function dt(t){let e=window.__resuma;if(!t.length)return e.state;let r={};for(let n of t){let[o,a]=n.split(":"),i=a??o,s=e.signals.get(i);s&&(r[o]=s)}return Object.assign(Object.create(e.state),r)}function gt(){document.addEventListener("submit",async t=>{if(!(t.target instanceof HTMLFormElement))return;let e=t.target;if(!e.getAttribute("data-r-submit"))return;t.preventDefault();let r=e.getAttribute("data-r-submit"),n=new FormData(e),o={};n.forEach((i,s)=>{o[s]=String(i)});let a=new URLSearchParams(o);try{let i=await fetch(e.action||`/_resuma/submit/${encodeURIComponent(r)}`,{method:"POST",credentials:"same-origin",headers:q({"content-type":"application/x-www-form-urlencoded",accept:"application/json"}),body:a.toString()}),s=await i.json();if(!i.ok||s.ok===!1){ft(e,s.field_errors??{}),(i.status>=500||!s.field_errors)&&console.error("[resuma] submit error",s.error??`submit ${r} failed`);return}if(B(e),s.redirect){T(s.redirect);return}console.info("[resuma] submit ok",s.value)}catch(i){console.error("[resuma] submit error",i)}},!0)}function ft(t,e){B(t);for(let[r,n]of Object.entries(e)){let o=t.querySelector(`[name="${r}"]`);if(!o)continue;let a=document.createElement("span");a.className="resuma-field-error",a.setAttribute("data-r-field-error",r),a.textContent=n,o.insertAdjacentElement("afterend",a)}}function B(t){t.querySelectorAll("[data-r-field-error]").forEach(e=>e.remove())}function mt(t){t.querySelectorAll("template[data-r-stream-chunk]").forEach(e=>{let r=e.getAttribute("data-r-stream-chunk");if(!r)return;let n=t.querySelector(`template[data-r-stream="${r}"]`);if(!n||!n.parentElement)return;let o=e.innerHTML,a=document.createRange().createContextualFragment(o);n.replaceWith(a),e.remove()})}function pt(t){t.querySelectorAll("template[data-r-portal]").forEach(e=>{if(e.closest("[data-r-show-if]")?.hidden)return;let n=e.getAttribute("data-r-portal");if(!n)return;let o=document.getElementById(n)??document.querySelector(`[data-r-portal-target="${n}"]`);o&&o.appendChild(e.content.cloneNode(!0))})}function ht(t){"startViewTransition"in document&&t.querySelectorAll("[data-r-vt]").forEach(e=>{e.addEventListener("click",r=>{let n=r.target?.closest("a[href]");if(!n||n.getAttribute("target")==="_blank")return;let o=n.getAttribute("href");if(!o||o.startsWith("#")||o.startsWith("javascript:"))return;r.preventDefault();let a=()=>{window.location.href=o};document.startViewTransition?.(a)})})}function wt(t,e){let r=Object.entries(t);if(!r.length)return;let n=(i,s)=>{try{let c=s.trim(),l=new Function("state","__resuma",`return (${c})(state, __resuma);`);Promise.resolve(l(e,window.__resuma))}catch(c){console.error("[resuma] visible task",i,c)}},o=new Set(r.map(([i])=>i)),a=(i,s)=>{o.has(i)&&(o.delete(i),n(i,s))};for(let[i,s]of r)a(i,s);if("IntersectionObserver"in window){let i=new IntersectionObserver((s,c)=>{for(let l of s){if(!l.isIntersecting)continue;let u=l.target.dataset.rVisibleTask,f=u?t[u]:void 0;u&&f&&a(u,f),c.unobserve(l.target)}},{rootMargin:"50px"});for(let[s]of r){let c=document.createElement("span");c.dataset.rVisibleTask=s,c.style.cssText="position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;overflow:hidden",d().appendChild(c),i.observe(c)}}else for(let[i,s]of r)n(i,s)}async function vt(t,e){try{return{ok:!0,value:await W(t,e)}}catch(r){return{ok:!1,error:r instanceof Error?r.message:String(r)}}}async function W(t,e){let r=await fetch(`/_resuma/action/${encodeURIComponent(t)}`,{method:"POST",credentials:"same-origin",headers:q({"content-type":"application/json"}),body:JSON.stringify({args:e})});if(!r.ok)throw new Error(`[resuma] action ${t} failed: ${r.status}`);let n=await r.json();if(n.ok===!1)throw new Error(n.error??"action failed");return n.redirect&&T(n.redirect),n.value}async function yt(t){let e=await fetch(`/_resuma/island/${encodeURIComponent(t)}`);if(!e.ok)return;let r=await e.text(),n=document.querySelector(`resuma-island[data-r-instance="${t}"]`);n&&(n.outerHTML=r),S()}document.readyState==="loading"?document.addEventListener("DOMContentLoaded",O,{once:!0}):O();
//# sourceMappingURL=runtime.js.map