satori 0.0.15 → 0.0.18

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/README.md CHANGED
@@ -146,24 +146,26 @@ The image will be resized to the current font-size (both width and height), so i
146
146
  | `object-fit` | `contain`, `cover`, `none` |
147
147
  | `opacity` | Supported |
148
148
  | `background-color` | Supported |
149
- | `background-image` | Support `linear-gradient`, `url` |
149
+ | `background-image` | Support `linear-gradient`, `radial-gradient`, `url` |
150
150
  | `word-break` | Supported |
151
151
  | `text-shadow` | Supported |
152
152
  | `text-transform` | Support `lowercase`, `uppercase`, `capitalize` |
153
153
  | `background-position` | Supported |
154
154
  | `background-size` | Support two-value size string such as `10px 20%` |
155
- | `background-clip` | TBD |
156
- | `background-repeat` | TBD |
157
- | `background-origin` | TBD |
158
- | `text-decoration` | TBD |
159
- | `line-height` | TBD |
160
- | `white-space` | TBD |
155
+ | `white-space` | Support `normal`, `pre`, `pre-wrap` and `nowrap` |
156
+ | `text-overflow` | Support `clip` and `ellipsis` |
157
+ | `text-decoration` | Support line types `underline` and `line-through`, and styles `dotted`, `dashed`, `solid` |
158
+ | `line-height` | Supported |
159
+ | `background-clip` | Support `border-box` and `text` |
160
+ | `background-repeat` | Supported |
161
161
 
162
162
  Note:
163
163
 
164
164
  1. Three-dimensional transforms are not supported.
165
165
  2. There is no `z-index` support in SVG. Elements that come later in the document will be painted on top.
166
166
  3. `box-sizing` is set to `border-box` for all elements.
167
+ 4. `calc` isn't supported.
168
+ 5. `overflow: hidden` and `transform` can't be used together.
167
169
 
168
170
  ## Contribute
169
171
 
package/dist/esm/index.js CHANGED
@@ -1,3 +1,5 @@
1
- var ie=Object.defineProperty,ze=Object.defineProperties,He=Object.getOwnPropertyDescriptor,Ve=Object.getOwnPropertyDescriptors,Je=Object.getOwnPropertyNames,Le=Object.getOwnPropertySymbols;var Ae=Object.prototype.hasOwnProperty,je=Object.prototype.propertyIsEnumerable;var we=(e,r,t)=>r in e?ie(e,r,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[r]=t,Y=(e,r)=>{for(var t in r||(r={}))Ae.call(r,t)&&we(e,t,r[t]);if(Le)for(var t of Le(r))je.call(r,t)&&we(e,t,r[t]);return e},ve=(e,r)=>ze(e,Ve(r)),Ke=e=>ie(e,"__esModule",{value:!0});var Ce=(e,r)=>()=>(e&&(r=e(e=0)),r);var qe=(e,r)=>{for(var t in r)ie(e,t,{get:r[t],enumerable:!0})},Ze=(e,r,t,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of Je(r))!Ae.call(e,s)&&(t||s!=="default")&&ie(e,s,{get:()=>r[s],enumerable:!(o=He(r,s))||o.enumerable});return e};var Qe=(e=>(r,t)=>e&&e.get(r)||(t=Ze(Ke({}),r,1),e&&e.set(r,t),t))(typeof WeakMap!="undefined"?new WeakMap:0);var u=Ce(()=>{});var Fe={};qe(Fe,{default:()=>tt});import*as et from"yoga-layout-prebuilt";var tt,Oe=Ce(()=>{u();tt=et});u();u();u();var ae;{let e=(Oe(),Qe(Fe));e.default?ae=e.default:ae=e}function rt(e){ae=e}function U(){return ae}u();u();function ue(e){let r=typeof e;return!(r==="number"||r==="bigint"||r==="string"||r==="boolean")}function Ne(e){return/^class\s/.test(Function.prototype.toString.call(e))}function Q(e,r){return[e[0]*r[0]+e[2]*r[1],e[1]*r[0]+e[3]*r[1],e[0]*r[2]+e[2]*r[3],e[1]*r[2]+e[3]*r[3],e[0]*r[4]+e[2]*r[5]+e[4],e[1]*r[4]+e[3]*r[5]+e[5]]}function k(e,r,t){let o=r[e];return typeof o=="undefined"?t:o}u();u();var ke={p:{display:"block",marginTop:"1em",marginBottom:"1em"},div:{display:"block"},blockquote:{display:"block",marginTop:"1em",marginBottom:"1em",marginLeft:40,marginRight:40},center:{display:"block",textAlign:"center"},hr:{display:"block",marginTop:"0.5em",marginBottom:"0.5em",marginLeft:"auto",marginRight:"auto",borderWidth:1,borderStyle:"inset"},h1:{display:"block",fontSize:"2em",marginTop:"0.67em",marginBottom:"0.67em",marginLeft:0,marginRight:0,fontWeight:"bold"},h2:{display:"block",fontSize:"1.5em",marginTop:"0.83em",marginBottom:"0.83em",marginLeft:0,marginRight:0,fontWeight:"bold"},h3:{display:"block",fontSize:"1.17em",marginTop:"1em",marginBottom:"1em",marginLeft:0,marginRight:0,fontWeight:"bold"},h4:{display:"block",marginTop:"1.33em",marginBottom:"1.33em",marginLeft:0,marginRight:0,fontWeight:"bold"},h5:{display:"block",fontSize:"0.83em",marginTop:"1.67em",marginBottom:"1.67em",marginLeft:0,marginRight:0,fontWeight:"bold"},h6:{display:"block",fontSize:"0.67em",marginTop:"2.33em",marginBottom:"2.33em",marginLeft:0,marginRight:0,fontWeight:"bold"},u:{textDecoration:"underline"},strong:{fontWeight:"bold"},b:{fontWeight:"bold"},i:{fontStyle:"italic"},em:{fontStyle:"italic"},code:{fontFamily:"monospace"},kbd:{fontFamily:"monospace"},pre:{display:"block",fontFamily:"monospace",whiteSpace:"pre",marginTop:"1em",marginBottom:"1em"},mark:{backgroundColor:"yellow",color:"black"},big:{fontSize:"larger"},small:{fontSize:"smaller"},s:{textDecoration:"line-through"}};u();var nt=new Set(["color","font","fontFamily","fontSize","fontStyle","fontWeight","lineHeight","textAlign","textTransform","whiteSpace","letterSpacing","transform","wordBreak","textShadowOffset","textShadowColor","textShadowRadius","opacity"]);function ce(e){let r={};for(let t in e)nt.has(t)&&(r[t]=e[t]);return r}u();import{getPropertyName as Pe,getStylesForProperty as st}from"css-to-react-native";import De from"parse-css-dimension";import{parseElementStyle as ft}from"css-background-parser";u();import ot from"postcss-value-parser";import it from"parse-css-dimension";function at(e,r){try{let t=new it(e);switch(t.unit){case"px":return{absolute:t.value};case"em":return{absolute:t.value*r};case"rem":return{absolute:t.value*16};case"%":return{relative:t.value};default:return{}}}catch{return{}}}function me(e,r,t){switch(e){case"top":return{yRelative:0};case"left":return{xRelative:0};case"right":return{xRelative:100};case"bottom":return{yRelative:100};case"center":return{};default:let o=at(e,r);return o.absolute?{[t?"xAbsolute":"yAbsolute"]:o.absolute}:o.relative?{[t?"xRelative":"yRelative"]:o.relative}:{}}}function pe(e,r){if(typeof e=="number")return{xAbsolute:e};let t;try{t=ot(e).nodes.filter(o=>o.type==="word").map(o=>o.value)}catch{return{}}return t.length===1?me(t[0],r,!0):t.length===2?((t[0]==="top"||t[0]==="bottom"||t[1]==="left"||t[1]==="right")&&t.reverse(),Y(Y({},me(t[0],r,!0)),me(t[1],r,!1))):{}}var lt=new Set(["flex","flexGrow","flexShrink","flexBasis","fontWeight","lineHeight","opacity","scale","scaleX","scaleY"]),We=[1,0,0,1,0,0];function ut(e,r){return typeof r=="number"?lt.has(e)?String(r):r+"px":r}function Ge(e,r){if(typeof e=="number")return e;try{let t=new De(e);if(t.type==="length")switch(t.unit){case"em":return t.value*r;case"rem":return t.value*16;default:return t.value}else if(t.type==="angle")switch(t.unit){case"deg":return t.value;case"rad":return t.value*180/Math.PI;default:return t.value}}catch{}}function se(e,r){let t=[];for(let i in e){let n=Pe(i);t.push([n,ut(n,e[i])])}let o=t.reduce((i,n)=>{let a=Pe(n[0]),f=n[1];return Object.assign(i,st(a,f,!0))},{});if(o.backgroundImage){let{backgrounds:i}=ft(o);o.backgroundImage=i}let s=o.fontSize||r.fontSize;if(typeof s=="string")try{let i=new De(s);switch(i.unit){case"em":s=i.value*r.fontSize;break;case"rem":s=i.value*16;break}}catch{s=16}typeof o.fontSize!="undefined"&&(o.fontSize=s),o.transformOrigin&&(o.transformOrigin=pe(o.transformOrigin,s));for(let i in o){let n=o[i];if(typeof n=="string"){let a=Ge(n,s);typeof a!="undefined"&&(o[i]=a),n=o[i]}if(i==="opacity"&&(n=o[i]=n*r.opacity),i==="transform"){let a=[...We],f=n;for(let m of f){let y=Object.keys(m)[0],d=m[y],p=typeof d=="string"?Ge(d,s):d,g=[...We];switch(y){case"translateX":g[4]=p;break;case"translateY":g[5]=p;break;case"scaleX":g[0]=p;break;case"scaleY":g[3]=p;break;case"rotate":let c=p*Math.PI/180,x=Math.cos(c),_=Math.sin(c);g[0]=x,g[1]=_,g[2]=-_,g[3]=x;break;case"skewX":g[2]=Math.tan(p*Math.PI/180);break;case"skewY":g[1]=Math.tan(p*Math.PI/180);break}a=Q(g,a)}o.transform=a}}return o}function de(e,r,t,o,s){let i=U(),n=Y(Y(Y({},t),se(ke[r],t)),se(o,t));if(r==="img"){let a=parseInt(s.width),m=parseInt(s.height)/a;n.width||(n.width=a),n.height||(n.height=m*n.width)}return e.setDisplay(k(n.display,{flex:i.DISPLAY_FLEX,none:i.DISPLAY_NONE},i.DISPLAY_FLEX)),e.setAlignContent(k(n.alignContent,{stretch:i.ALIGN_STRETCH,center:i.ALIGN_CENTER,"flex-start":i.ALIGN_FLEX_START,"flex-end":i.ALIGN_FLEX_END,"space-between":i.ALIGN_SPACE_BETWEEN,"space-around":i.ALIGN_SPACE_AROUND,baseline:i.ALIGN_BASELINE,normal:i.ALIGN_AUTO},i.ALIGN_AUTO)),e.setAlignItems(k(n.alignItems,{stretch:i.ALIGN_STRETCH,center:i.ALIGN_CENTER,"flex-start":i.ALIGN_FLEX_START,"flex-end":i.ALIGN_FLEX_END,baseline:i.ALIGN_BASELINE,normal:i.ALIGN_AUTO},i.ALIGN_FLEX_START)),e.setAlignSelf(k(n.alignSelf,{stretch:i.ALIGN_STRETCH,center:i.ALIGN_CENTER,"flex-start":i.ALIGN_FLEX_START,"flex-end":i.ALIGN_FLEX_END,baseline:i.ALIGN_BASELINE,normal:i.ALIGN_AUTO},i.ALIGN_AUTO)),e.setJustifyContent(k(n.justifyContent,{center:i.JUSTIFY_CENTER,"flex-start":i.JUSTIFY_FLEX_START,"flex-end":i.JUSTIFY_FLEX_END,"space-between":i.JUSTIFY_SPACE_BETWEEN,"space-around":i.JUSTIFY_SPACE_AROUND},i.JUSTIFY_FLEX_START)),e.setFlexDirection(k(n.flexDirection,{row:i.FLEX_DIRECTION_ROW,column:i.FLEX_DIRECTION_COLUMN,"row-reverse":i.FLEX_DIRECTION_ROW_REVERSE,"column-reverse":i.FLEX_DIRECTION_COLUMN_REVERSE},i.FLEX_DIRECTION_ROW)),e.setFlexWrap(k(n.flexWrap,{wrap:i.WRAP_WRAP,nowrap:i.WRAP_NO_WRAP,"wrap-reverse":i.WRAP_WRAP_REVERSE},i.WRAP_WRAP)),typeof n.flexBasis!="undefined"&&e.setFlexBasis(n.flexBasis),e.setFlexGrow(typeof n.flexGrow=="undefined"?0:n.flexGrow),e.setFlexShrink(typeof n.flexShrink=="undefined"?1:n.flexShrink),typeof n.maxHeight!="undefined"&&e.setMaxHeight(n.maxHeight),typeof n.maxWidth!="undefined"&&e.setMaxWidth(n.maxWidth),typeof n.minHeight!="undefined"&&e.setMinHeight(n.minHeight),typeof n.minWidth!="undefined"&&e.setMinWidth(n.minWidth),e.setOverflow(k(n.overflow,{visible:i.OVERFLOW_VISIBLE,hidden:i.OVERFLOW_HIDDEN},i.OVERFLOW_VISIBLE)),e.setMargin(i.EDGE_TOP,n.marginTop||0),e.setMargin(i.EDGE_BOTTOM,n.marginBottom||0),e.setMargin(i.EDGE_LEFT,n.marginLeft||0),e.setMargin(i.EDGE_RIGHT,n.marginRight||0),e.setBorder(i.EDGE_TOP,n.borderWidth||0),e.setBorder(i.EDGE_BOTTOM,n.borderWidth||0),e.setBorder(i.EDGE_LEFT,n.borderWidth||0),e.setBorder(i.EDGE_RIGHT,n.borderWidth||0),e.setPadding(i.EDGE_TOP,n.paddingTop||0),e.setPadding(i.EDGE_BOTTOM,n.paddingBottom||0),e.setPadding(i.EDGE_LEFT,n.paddingLeft||0),e.setPadding(i.EDGE_RIGHT,n.paddingRight||0),e.setPositionType(k(n.position,{absolute:i.POSITION_TYPE_ABSOLUTE,relative:i.POSITION_TYPE_RELATIVE},i.POSITION_TYPE_RELATIVE)),typeof n.top!="undefined"&&e.setPosition(i.EDGE_TOP,n.top),typeof n.bottom!="undefined"&&e.setPosition(i.EDGE_BOTTOM,n.bottom),typeof n.left!="undefined"&&e.setPosition(i.EDGE_LEFT,n.left),typeof n.right!="undefined"&&e.setPosition(i.EDGE_RIGHT,n.right),typeof n.height!="undefined"?e.setHeight(n.height):e.setHeightAuto(),typeof n.width!="undefined"?e.setWidth(n.width):e.setWidthAuto(),[n,ce(n)]}u();import{LineBreaker as ct}from"css-line-break";import{splitGraphemes as mt}from"text-segmentation";u();u();function te({left:e,top:r,width:t,height:o},s,i,n){var f,m,y,d;let a;if(i)a=s;else{let p=(m=n==null?void 0:n.xAbsolute)!=null?m:((f=n==null?void 0:n.xRelative)!=null?f:50)*t/100,g=(d=n==null?void 0:n.yAbsolute)!=null?d:((y=n==null?void 0:n.yRelative)!=null?y:50)*o/100,c=e+p,x=r+g;a=Q([1,0,0,1,c,x],Q(s,[1,0,0,1,-c,-x])),s.__parent&&(a=Q(s.__parent,a)),s.splice(0,6,...a)}return`matrix(${a.map(p=>p.toFixed(2)).join(",")})`}function Me({left:e,top:r,width:t,height:o,isInheritingTransform:s},i){let n="",a=1;return i.transform&&(n=te({left:e,top:r,width:t,height:o},i.transform,s,i.transformOrigin)),i.opacity&&(a=+i.opacity),{matrix:n,opacity:a}}function ge({id:e,content:r,filter:t,left:o,top:s,width:i,height:n,matrix:a,opacity:f,image:m,debug:y},d){let p="";return y&&(p=`<rect x="${o}" y="${s}" width="${i}" height="0.5" fill="transparent" stroke="#575eff" stroke-width="1" ${a?`transform="${a}"`:""}></rect>`),m?`${t?`${t}<g filter="url(#satori_s-${e})">`:""}<image href="${m}" x="${o}" y="${s}" width="${i}" height="${n}" ${a?`transform="${a}"`:""} ${f!==1?`opacity="${f}"`:""}></image>${t?"</g>":""}${p}`:`${t?`${t}<g filter="url(#satori_s-${e})">`:""}<text x="${o}" y="${s}" width="${i}" height="${n}" fill="${d.color}" font-weight="${d.fontWeight}" font-style="${d.fontStyle}" font-size="${d.fontSize}" font-family="${d.fontFamily}" ${d.letterSpacing?`letter-spacing="${d.letterSpacing}"`:""} ${a?`transform="${a}"`:""} ${f!==1?`opacity="${f}"`:""}>${r}</text>${t?"</g>":""}${p}`}u();function q({id:e,width:r,height:t},o){if(!o.shadowColor||!o.shadowOffset||typeof o.shadowRadius=="undefined")return"";let s=o.shadowRadius*o.shadowRadius/4,i=Math.min(o.shadowOffset.width-s,0),n=Math.max(o.shadowOffset.width+s+r,r),a=Math.min(o.shadowOffset.height-s,0),f=Math.max(o.shadowOffset.height+s+t,t);return`<defs><filter id="satori_s-${e}" x="${i/r*100}%" y="${a/t*100}%" width="${(n-i)/r*100}%" height="${(f-a)/t*100}%"><feDropShadow dx="${o.shadowOffset.width}" dy="${o.shadowOffset.height}" stdDeviation="${o.shadowRadius/2}" flood-color="${o.shadowColor}" flood-opacity="1"/></filter></defs>`}var re=void 0,be=typeof Intl!="undefined"&&"Segmenter"in Intl,pt=be?new Intl.Segmenter(re,{granularity:"word"}):null,dt=be?new Intl.Segmenter(re,{granularity:"grapheme"}):null,gt=[32,160,4961,65792,65793,4153,4241],ht=e=>{let r=ct(e,{lineBreak:"strict",wordBreak:"normal"}),t=[],o;for(;!(o=r.next()).done;)if(o.value){let s=o.value.slice(),i=[].map.call(s,a=>a.codePointAt(0)),n="";i.forEach(a=>{gt.includes(a)?(n.length&&t.push(n),t.push(String.fromCodePoint(a)),n=""):n+=String.fromCodePoint(a)}),n.length&&t.push(n)}return t};function he(e,r){return be?r==="word"?[...pt.segment(e)].map(t=>t.segment):[...dt.segment(e)].map(t=>t.segment):r==="word"?ht(e):mt(e)}function*ye(e,r){let t=U(),{parentStyle:o,parent:s,font:i,id:n,isInheritingTransform:a,debug:f,embedFont:m,graphemeImages:y}=r;o.textTransform==="uppercase"?e=e.toLocaleUpperCase(re):o.textTransform==="lowercase"?e=e.toLocaleLowerCase(re):o.textTransform==="capitalize"&&(e=he(e,"word").map($=>he($,"grapheme").map((L,W)=>W===0?L.toLocaleUpperCase(re):L).join("")).join(""));let d=k(o.wordBreak,{normal:"word","break-all":"grapheme","break-word":"grapheme","keep-all":"word"},"word"),p=he(e,d),g=t.Node.create();g.setAlignItems(t.ALIGN_BASELINE),o.textAlign==="left"?g.setJustifyContent(t.JUSTIFY_FLEX_START):o.textAlign==="center"?g.setJustifyContent(t.JUSTIFY_CENTER):o.textAlign==="right"?g.setJustifyContent(t.JUSTIFY_FLEX_END):o.textAlign==="justify"&&g.setJustifyContent(t.JUSTIFY_SPACE_BETWEEN),s.insertChild(g,s.getChildCount());let c=i.getFont(o),x=c.ascender/c.unitsPerEm*o.fontSize,_=-(c.descender/c.unitsPerEm)*o.fontSize,h=(x+_)*1.2,{textAlign:E}=o,v=[],M=[],F=[];g.setMeasureFunc($=>{let L=[],W="",G=0,j="",A=0,Z=0,ee=-1;v=[],M=[0];for(let B=0;B<p.length;B++){let D=p[B];if([" ",`
2
- `," ","\u3000"].includes(D))W+=D,G=i.measure(c,W,o),F[B]=null;else{let K=y&&y[D]?o.fontSize:i.measure(c,D,o);A||(W="",G=0);let _e=G||",.!?:-@)>]}%#".indexOf(D[0])<0,Ie=!A||!!G;_e&&A+G+K>$?(v.push(A),L.push(j),j=D,A=K,M.push(1),ee=-1):(j+=W+D,A+=G+K,Ie&&M[M.length-1]++),W="",G=0,Ie&&ee++,Z=Math.max(Z,A),F[B]={y:L.length*h,x:A-K,width:K,line:L.length,lineIndex:ee}}}return A&&(L.push(j),v.push(A)),L.length>1&&(Z=$),{width:Z,height:L.length*h}});let[X,z]=yield,H="";o.position==="absolute"&&g.calculateLayout();let{left:V,top:O,width:C,height:P}=g.getComputedLayout(),w=X+V,N=z+O,{matrix:J,opacity:l}=Me({left:V,top:O,width:C,height:P,isInheritingTransform:a},o),b="";o.textShadowOffset&&(b=q({width:C,height:P,id:n},{shadowColor:o.textShadowColor,shadowOffset:o.textShadowOffset,shadowRadius:o.textShadowRadius}));let S="";for(let $=0;$<p.length;$++){if(!F[$])continue;let L=p[$],W=null,G=null,j=F[$].y,A=F[$].x,Z=F[$].width,ee=h,B=C-v[F[$].line];if(E==="right"||E==="end")A+=B;else if(E==="center")A+=B/2;else if(E==="justify"){let D=F[$].line;if(D<v.length-1){let K=M[D];A+=(K>1?B/(K-1):0)*F[$].lineIndex}}y&&y[L]?G=y[L]:m?W=i.getSVG(c,L,ve(Y({},o),{left:w+A,top:N+j,letterSpacing:o.letterSpacing})):j+=x,W?S+=W+" ":H+=ge({content:L,filter:b,id:n,left:w+A,top:N+j,width:Z,height:ee,matrix:J,opacity:l,image:G,debug:f},o)}if(S){let $="";f&&($=`<rect x="${w}" y="${N}" width="${C}" height="${P}" fill="transparent" stroke="#575eff" stroke-width="1" ${J?`transform="${J}"`:""}></rect>`),H+=`${b?`${b}<g filter="url(#satori_s-${n})">`:""}<path fill="${o.color}" ${J?`transform="${J}"`:""} ${l!==1?`opacity="${l}"`:""} d="${S}"></path>${b?"</g>":""}${$}`}return H}u();u();import bt from"parse-css-dimension";u();var xe=xe||{};xe.parse=function(){var e={linearGradient:/^(\-(webkit|o|ms|moz)\-)?(linear\-gradient)/i,repeatingLinearGradient:/^(\-(webkit|o|ms|moz)\-)?(repeating\-linear\-gradient)/i,radialGradient:/^(\-(webkit|o|ms|moz)\-)?(radial\-gradient)/i,repeatingRadialGradient:/^(\-(webkit|o|ms|moz)\-)?(repeating\-radial\-gradient)/i,sideOrCorner:/^to (left (top|bottom)|right (top|bottom)|top (left|right)|bottom (left|right)|left|right|top|bottom)/i,extentKeywords:/^(closest\-side|closest\-corner|farthest\-side|farthest\-corner|contain|cover)/,positionKeywords:/^(left|center|right|top|bottom)/i,pixelValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))px/,percentageValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))\%/,emValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))em/,angleValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))deg/,startCall:/^\(/,endCall:/^\)/,comma:/^,/,hexColor:/^\#([0-9a-fA-F]+)/,literalColor:/^([a-zA-Z]+)/,rgbColor:/^rgb/i,rgbaColor:/^rgba/i,number:/^(([0-9]*\.[0-9]+)|([0-9]+\.?))/},r="";function t(l){var b=new Error(r+": "+l);throw b.source=r,b}function o(){var l=s();return r.length>0&&t("Invalid input not EOF"),l}function s(){return E(i)}function i(){return n("linear-gradient",e.linearGradient,f)||n("repeating-linear-gradient",e.repeatingLinearGradient,f)||n("radial-gradient",e.radialGradient,d)||n("repeating-radial-gradient",e.repeatingRadialGradient,d)}function n(l,b,S){return a(b,function($){var L=S();return L&&(N(e.comma)||t("Missing comma before color stops")),{type:l,orientation:L,colorStops:E(v)}})}function a(l,b){var S=N(l);if(S){N(e.startCall)||t("Missing (");var $=b(S);return N(e.endCall)||t("Missing )"),$}}function f(){return m()||y()}function m(){return w("directional",e.sideOrCorner,1)}function y(){return w("angular",e.angleValue,1)}function d(){var l,b=p(),S;return b&&(l=[],l.push(b),S=r,N(e.comma)&&(b=p(),b?l.push(b):r=S)),l}function p(){var l=g()||c();if(l)l.at=_();else{var b=x();if(b){l=b;var S=_();S&&(l.at=S)}else{var $=I();$&&(l={type:"default-radial",at:$})}}return l}function g(){var l=w("shape",/^(circle)/i,0);return l&&(l.style=P()||x()),l}function c(){var l=w("shape",/^(ellipse)/i,0);return l&&(l.style=O()||x()),l}function x(){return w("extent-keyword",e.extentKeywords,1)}function _(){if(w("position",/^at/,0)){var l=I();return l||t("Missing positioning value"),l}}function I(){var l=h();if(l.x||l.y)return{type:"position",value:l}}function h(){return{x:O(),y:O()}}function E(l){var b=l(),S=[];if(b)for(S.push(b);N(e.comma);)b=l(),b?S.push(b):t("One extra comma");return S}function v(){var l=M();return l||t("Expected color definition"),l.length=O(),l}function M(){return X()||H()||z()||F()}function F(){return w("literal",e.literalColor,0)}function X(){return w("hex",e.hexColor,1)}function z(){return a(e.rgbColor,function(){return{type:"rgb",value:E(V)}})}function H(){return a(e.rgbaColor,function(){return{type:"rgba",value:E(V)}})}function V(){return N(e.number)[1]}function O(){return w("%",e.percentageValue,1)||C()||P()}function C(){return w("position-keyword",e.positionKeywords,1)}function P(){return w("px",e.pixelValue,1)||w("em",e.emValue,1)}function w(l,b,S){var $=N(b);if($)return{type:l,value:$[S]}}function N(l){var b,S;return S=/^[\n\r\t\s]+/.exec(r),S&&J(S[0].length),b=l.exec(r),b&&J(b[0].length),b}function J(l){r=r.substr(l)}return function(l){return r=l.toString(),o()}}();var Be=xe;function yt(e){return e.type==="literal"?e.value:e.type==="hex"?`#${e.value}`:e.type==="rgb"?`rgb(${e.value.join(",")})`:e.type==="rgba"?`rgba(${e.value.join(",")})`:"transparent"}function xt(e,r){return typeof e=="string"&&e.endsWith("%")?r*parseFloat(e)/100:+e}function Ye(e,{x:r,y:t,defaultX:o,defaultY:s}){return(e?e.split(" ").map(i=>{try{let n=new bt(i);return n.type==="length"?n.value:n.value+n.unit}catch{return null}}).filter(i=>i!==null):[o,s]).map((i,n)=>xt(i,[r,t][n]))}function $e({id:e,width:r,height:t},{image:o,size:s,position:i}){let n=Ye(s,{x:r,y:t,defaultX:r,defaultY:t}),a=Ye(i,{x:r,y:t,defaultX:0,defaultY:0});if(o.startsWith("linear-gradient(")){let f=Be.parse(o)[0],m,y,d,p;if(f.orientation.type==="directional")[m,y,d,p]={top:[0,1,0,0],bottom:[0,0,0,1],left:[1,0,0,0],right:[0,0,1,0]}[f.orientation.value];else if(f.orientation.type==="angular"){let h=+f.orientation.value/180*Math.PI-Math.PI/2,E=Math.cos(h),v=Math.sin(h);m=0,y=0,d=E,p=v,d<0&&(m-=d,d=0),p<0&&(y-=p,p=0)}let g=r,c=[];for(let h of f.colorStops){let E=yt(h);if(!c.length&&(c.push({offset:0,color:E}),typeof h.length=="undefined"||h.length.value==="0"))continue;let v=typeof h.length=="undefined"?void 0:h.length.type==="%"?h.length.value/100:h.length.value/g;c.push({offset:v,color:E})}c.length||c.push({offset:0,color:"transparent"});let x=c[c.length-1];x.offset!==1&&(typeof x.offset=="undefined"?x.offset=1:c.push({offset:1,color:x.color}));let _=0,I=1;for(let h=0;h<c.length;h++)if(typeof c[h].offset=="undefined"){for(I<h&&(I=h);typeof c[I].offset=="undefined";)I++;c[h].offset=(c[I].offset-c[_].offset)/(I-_)*(h-_)+c[_].offset}else _=h;return[`satori_bi${e}`,`<linearGradient id="satori_bi${e}" x1="${m}" y1="${y}" x2="${d}" y2="${p}">${c.map(h=>`<stop offset="${h.offset*100}%" stop-color="${h.color}"/>`).join("")}</linearGradient>`]}if(o.startsWith("url(")){let f=o.slice(4,-1);return[`satori_bi${e}`,`<pattern id="satori_bi${e}" patternContentUnits="userSpaceOnUse" patternUnits="userSpaceOnUse" x="${a[0]}" y="${a[1]}" width="${n[0]}" height="${n[1]}"><image href="${f}" x="0" y="0" width="${n[0]}" height="${n[1]}"/></pattern>`]}}u();function fe(e,r,t){return t<e+r&&(t/2<e&&t/2<r?e=r=t/2:t/2<e?e=t-r:t/2<r&&(r=t-e)),[e,r]}function ne({left:e,top:r,width:t,height:o},s){let{borderTopLeftRadius:i,borderTopRightRadius:n,borderBottomLeftRadius:a,borderBottomRightRadius:f}=s;return i=Math.min(i||0,t,o),n=Math.min(n||0,t,o),a=Math.min(a||0,t,o),f=Math.min(f||0,t,o),!i&&!n&&!a&&!f?"":([i,n]=fe(i,n,t),[i,a]=fe(i,a,o),[n,f]=fe(n,f,o),[a,f]=fe(a,f,t),`M${e+i},${r} h${t-i-n} a${n},${n} 0 0 1 ${n},${n} v${o-n-f} a${f},${f} 0 0 1 ${-f},${f} h${f+a-t} a${a},${a} 0 0 1 ${-a},${-a} v${a+i-o} a${i},${i} 0 0 1 ${i},${-i}`)}function Ee({id:e,left:r,top:t,width:o,height:s,isInheritingTransform:i,debug:n},a){if(a.display==="none")return"";let f="rect",m="transparent",y=0,d="",p="",g=[],c=1,x="";if(a.backgroundColor&&g.push(a.backgroundColor),a.borderWidth&&(y=a.borderWidth,m=a.borderColor),a.opacity&&(c=+a.opacity),a.transform&&(d=te({left:r,top:t,width:o,height:s},a.transform,i,a.transformOrigin)),a.backgroundImage){let h=a.backgroundImage.map((E,v)=>$e({id:e+"_"+v,width:o,height:s},E)).filter(Boolean);for(let E of h)p+=E[1],g.push(`url(#${E[0]})`)}let _=ne({left:r,top:t,width:o,height:s},a);_&&(f="path");let I=q({width:o,height:s,id:e},a);return g.length||g.push("transparent"),n&&(x=`<rect x="${r}" y="${t}" width="${o}" height="${s}" fill="transparent" stroke="#ff5757" stroke-width="1" ${d?`transform="${d}"`:""}></rect>`),`${p?`<defs>${p}</defs>`:""}${I?`${I}<g filter="url(#satori_s-${e})">`:""}${c!==1?`<g opacity="${c}">`:""}${g.map((h,E)=>h==="transparent"&&!(E===g.length-1&&y)?"":`<${f} x="${r}" y="${t}" width="${o}" height="${s}" fill="${h}" ${E===g.length-1&&y?`stroke="${m}" stroke-width="${y}"`:""} ${_?`d="${_}"`:""} ${d?`transform="${d}"`:""}></${f}>`).join("")}${c!==1?"</g>":""}${I?"</g>":""}${x}`}u();function Se({id:e,left:r,top:t,width:o,height:s,src:i,debug:n},a){if(a.display==="none")return"";let f="",m=1,y=a.objectFit==="contain"?"xMidYMid":a.objectFit==="cover"?"xMidYMid slice":"none",d=ne({left:r,top:t,width:o,height:s},a);d&&(f=`<clipPath id="satori_c-${e}"><path x="${r}" y="${t}" width="${o}" height="${s}" d="${d}"></path></clipPath>`),a.opacity&&(m=+a.opacity);let p=q({width:o,height:s,id:e},a);return`${p}${p?`<g filter="url(#satori_s-${e})">`:""}${f}<image href="${i}" x="${r}" y="${t}" width="${o}" height="${s}" preserveAspectRatio="${y}" ${f?`clip-path="url(#satori_c-${e})"`:""} ${m!==1?`opacity="${m}"`:""}></image>${p?"</g>":""}`}function*oe(e,r){let t=U(),{id:o,inheritedStyle:s,parent:i,font:n,debug:a,embedFont:f=!0,graphemeImages:m}=r;if(e===null||typeof e=="undefined")return yield,"";if(!ue(e)||typeof e.type=="function"){let C;if(!ue(e))C=ye(String(e),r);else{if(Ne(e.type))throw new Error("Class component is not supported.");C=oe(e.type(e.props),r)}C.next();let P=yield;return C.next(P).value}let{type:y,props:d}=e,{style:p,children:g}=d,c=t.Node.create();i.insertChild(c,i.getChildCount());let[x,_]=de(c,y,s,p,d),I=x.transform===s.transform;I||(x.transform.__parent=s.transform);let h=typeof g=="undefined"?[]:[].concat(g),E=[],v=0;for(let C of h){let P=oe(C,{id:o*h.length+ ++v,parentStyle:x,inheritedStyle:_,isInheritingTransform:!0,parent:c,font:n,embedFont:f,debug:a,graphemeImages:m});P.next(),E.push(P)}let[M,F]=yield;x.position==="absolute"&&c.calculateLayout();let{left:X,top:z,width:H,height:V}=c.getComputedLayout();X+=M,z+=F;let O="";y==="img"?O=Se({id:o,left:X,top:z,width:H,height:V,src:d.src,isInheritingTransform:I,debug:a},x):O=Ee({id:o,left:X,top:z,width:H,height:V,isInheritingTransform:I,debug:a},x);for(let C of E)O+=C.next([X,z]).value;return O}u();import Ue from"@shuding/opentype.js";var le=class{constructor(r){this.fonts=new Map;for(let t of r){let o=t.data,s="buffer"in o?Ue.parse(o.buffer.slice(o.byteOffset,o.byteOffset+o.byteLength)):Ue.parse(o);this.defaultFont||(this.defaultFont=s),this.fonts.has(t.name)||this.fonts.set(t.name,[]),this.fonts.get(t.name).push([s,t.weight,t.style])}}get({name:r,weight:t,style:o}){if(!this.fonts.has(r))return this.defaultFont;t==="normal"&&(t=400),t==="bold"&&(t=700);let s=[...this.fonts.get(r)];return s.sort(([i,n,a],[f,m,y])=>{if(n!==m)return n?!m||n===t?-1:m===t?1:t===400&&n===500||t===500&&n===400?-1:t===400&&m===500||t===500&&m===400?1:t<400?n<t&&m<t?m-n:n<t?-1:m<t?1:n-m:t<n&&t<m?n-m:t<n?-1:t<m?1:m-n:1;if(a!==y){if(a===o)return-1;if(y===o)return 1}return-1}),s[0][0]}getFont({fontFamily:r,fontWeight:t=400,fontStyle:o="normal"}){return this.get({name:r,weight:t,style:o})}measure(r,t,{fontSize:o,letterSpacing:s=0}){return r.getAdvanceWidth(t,o,{letterSpacing:s/o})}getSVG(r,t,{fontSize:o,top:s,left:i,letterSpacing:n=0}){return s+=r.ascender/r.unitsPerEm*o,r.getPath(t,i,s,o,{letterSpacing:n/o}).toPathData(1)}};u();function Re({width:e,height:r,content:t},o){return`<svg width="${e}" height="${r}" viewBox="0 0 ${e} ${r}" xmlns="http://www.w3.org/2000/svg">${t}</svg>`}var Te=new WeakMap;function Xe(e,r){let t=U();if(!t)throw new Error("Satori is not initialized.");let o;Te.has(r.fonts)?o=Te.get(r.fonts):Te.set(r.fonts,o=new le(r.fonts));let s=t.Node.create();s.setWidth(r.width),s.setHeight(r.height),s.setFlexDirection(t.FLEX_DIRECTION_ROW),s.setFlexWrap(t.WRAP_WRAP),s.setAlignContent(t.ALIGN_AUTO),s.setAlignItems(t.ALIGN_FLEX_START),s.setJustifyContent(t.JUSTIFY_FLEX_START);let i=oe(e,{id:1,parentStyle:{},inheritedStyle:{fontSize:16,fontWeight:"normal",fontFamily:"serif",fontStyle:"normal",lineHeight:1.2,color:"black",opacity:1},parent:s,font:o,embedFont:r.embedFont,debug:r.debug,graphemeImages:r.graphemeImages});i.next(),s.calculateLayout(r.width,r.height,t.DIRECTION_LTR);let n=i.next([0,0]).value;return Re({width:r.width,height:r.height,content:n})}export{Xe as default,rt as init};
1
+ var xt=Object.defineProperty,St=Object.defineProperties;var _t=Object.getOwnPropertyDescriptors;var rt=Object.getOwnPropertySymbols;var Et=Object.prototype.hasOwnProperty,Rt=Object.prototype.propertyIsEnumerable;var nt=(t,r,e)=>r in t?xt(t,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):t[r]=e,D=(t,r)=>{for(var e in r||(r={}))Et.call(r,e)&&nt(t,e,r[e]);if(rt)for(var e of rt(r))Rt.call(r,e)&&nt(t,e,r[e]);return t},te=(t,r)=>St(t,_t(r));import*as Tt from"yoga-layout-prebuilt";var it=Tt;var ve;ve=it.default;function wt(t){ve=t}function Q(){return ve}import{LineBreaker as It}from"css-line-break";import{splitGraphemes as Lt}from"text-segmentation";function ke(t){let r=typeof t;return!(r==="number"||r==="bigint"||r==="string"||r==="boolean")}function ot(t){return/^class\s/.test(Function.prototype.toString.call(t))}function fe(t,r){return[t[0]*r[0]+t[2]*r[1],t[1]*r[0]+t[3]*r[1],t[0]*r[2]+t[2]*r[3],t[1]*r[2]+t[3]*r[3],t[0]*r[4]+t[2]*r[5]+t[4],t[1]*r[4]+t[3]*r[5]+t[5]]}function H(t,r,e){let o=r[t];return typeof o=="undefined"?e:o}var at=void 0,Ae=typeof Intl!="undefined"&&"Segmenter"in Intl&&process.env.NODE_ENV!=="test",Ct=Ae?new Intl.Segmenter(at,{granularity:"word"}):null,vt=Ae?new Intl.Segmenter(at,{granularity:"grapheme"}):null,de=[32,160,4961,65792,65793,4153,4241,10].map(t=>String.fromCodePoint(t)),kt=t=>{let r=It(t,{lineBreak:"strict",wordBreak:"normal"}),e=[],o;for(;!(o=r.next()).done;)if(o.value){let a=o.value.slice(),i="";for(let n=0;n<a.length;n++){let s=a[n];de.includes(s)?(i.length&&e.push(i),e.push(s),i=""):i+=s}i.length&&e.push(i)}return e};function ce(t,r){return Ae?r==="word"?[...Ct.segment(t)].map(e=>e.segment):[...vt.segment(t)].map(e=>e.segment):r==="word"?kt(t):Lt(t)}function y(t,r,e){let o="";for(let[a,i]of Object.entries(r))typeof i!="undefined"&&(o+=` ${a}="${i}"`);return e?`<${t}${o}>${e}</${t}>`:`<${t}${o}/>`}var st={p:{display:"block",marginTop:"1em",marginBottom:"1em"},div:{display:"block"},blockquote:{display:"block",marginTop:"1em",marginBottom:"1em",marginLeft:40,marginRight:40},center:{display:"block",textAlign:"center"},hr:{display:"block",marginTop:"0.5em",marginBottom:"0.5em",marginLeft:"auto",marginRight:"auto",borderWidth:1,borderStyle:"inset"},h1:{display:"block",fontSize:"2em",marginTop:"0.67em",marginBottom:"0.67em",marginLeft:0,marginRight:0,fontWeight:"bold"},h2:{display:"block",fontSize:"1.5em",marginTop:"0.83em",marginBottom:"0.83em",marginLeft:0,marginRight:0,fontWeight:"bold"},h3:{display:"block",fontSize:"1.17em",marginTop:"1em",marginBottom:"1em",marginLeft:0,marginRight:0,fontWeight:"bold"},h4:{display:"block",marginTop:"1.33em",marginBottom:"1.33em",marginLeft:0,marginRight:0,fontWeight:"bold"},h5:{display:"block",fontSize:"0.83em",marginTop:"1.67em",marginBottom:"1.67em",marginLeft:0,marginRight:0,fontWeight:"bold"},h6:{display:"block",fontSize:"0.67em",marginTop:"2.33em",marginBottom:"2.33em",marginLeft:0,marginRight:0,fontWeight:"bold"},u:{textDecoration:"underline"},strong:{fontWeight:"bold"},b:{fontWeight:"bold"},i:{fontStyle:"italic"},em:{fontStyle:"italic"},code:{fontFamily:"monospace"},kbd:{fontFamily:"monospace"},pre:{display:"block",fontFamily:"monospace",whiteSpace:"pre",marginTop:"1em",marginBottom:"1em"},mark:{backgroundColor:"yellow",color:"black"},big:{fontSize:"larger"},small:{fontSize:"smaller"},s:{textDecoration:"line-through"}};var At=new Set(["color","font","fontFamily","fontSize","fontStyle","fontWeight","letterSpacing","lineHeight","textAlign","textTransform","textShadowOffset","textShadowColor","textShadowRadius","textDecorationLine","textDecorationStyle","textDecorationColor","whiteSpace","transform","wordBreak","opacity","_viewportWidth","_viewportHeight","_inheritedClipPathId","_inheritedBackgroundClipTextPath"]);function Pe(t){let r={};for(let e in t)At.has(e)&&(r[e]=t[e]);return r}import{getPropertyName as Ft,getStylesForProperty as $t}from"css-to-react-native";import ut from"parse-css-dimension";import{parseElementStyle as Nt}from"css-background-parser";import Pt from"postcss-value-parser";import Wt from"parse-css-dimension";function Ot(t,r){try{let e=new Wt(t);switch(e.unit){case"px":return{absolute:e.value};case"em":return{absolute:e.value*r};case"rem":return{absolute:e.value*16};case"%":return{relative:e.value};default:return{}}}catch{return{}}}function We(t,r,e){switch(t){case"top":return{yRelative:0};case"left":return{xRelative:0};case"right":return{xRelative:100};case"bottom":return{yRelative:100};case"center":return{};default:let o=Ot(t,r);return o.absolute?{[e?"xAbsolute":"yAbsolute"]:o.absolute}:o.relative?{[e?"xRelative":"yRelative"]:o.relative}:{}}}function Oe(t,r){if(typeof t=="number")return{xAbsolute:t};let e;try{e=Pt(t).nodes.filter(o=>o.type==="word").map(o=>o.value)}catch{return{}}return e.length===1?We(e[0],r,!0):e.length===2?((e[0]==="top"||e[0]==="bottom"||e[1]==="left"||e[1]==="right")&&e.reverse(),D(D({},We(e[0],r,!0)),We(e[1],r,!1))):{}}var Mt=new Set(["flex","flexGrow","flexShrink","flexBasis","fontWeight","lineHeight","opacity","scale","scaleX","scaleY"]),Gt=new Set(["lineHeight"]),ft=[1,0,0,1,0,0];function Dt(t,r,e,o){return t==="border"&&!e.includes(r.borderColor)?r.borderColor=o:t==="textDecoration"&&!e.includes(r.textDecorationColor)&&(r.textDecorationColor=o),r}function lt(t,r){return typeof r=="number"?Mt.has(t)?Gt.has(t)?r:String(r):r+"px":r}function Fe(t,r,e,{percentage:o}={percentage:!1}){if(typeof t=="number")return t;try{let a=new ut(t);if(a.type==="length")switch(a.unit){case"em":return a.value*r;case"rem":return a.value*16;case"vw":return~~(a.value*e._viewportWidth/100);case"vh":return~~(a.value*e._viewportHeight/100);default:return a.value}else if(a.type==="angle")switch(a.unit){case"deg":return a.value;case"rad":return a.value*180/Math.PI;default:return a.value}else if(a.type==="percentage"&&o)return a.value/100*r}catch{}}function Ee(t,r){let e={};for(let a in t){if(a.startsWith("_")){e[a]=t[a];continue}let i=Ft(a);Object.assign(e,i==="lineHeight"?{lineHeight:lt(i,t[a])}:Dt(i,$t(i,lt(i,t[a]),!0),t[a],t.color||r.color))}if(e.backgroundImage){let{backgrounds:a}=Nt(e);e.backgroundImage=a}let o=e.fontSize||r.fontSize;if(typeof o=="string")try{let a=new ut(o);switch(a.unit){case"em":o=a.value*r.fontSize;break;case"rem":o=a.value*16;break}}catch{o=16}typeof e.fontSize!="undefined"&&(e.fontSize=o),e.transformOrigin&&(e.transformOrigin=Oe(e.transformOrigin,o));for(let a in e){let i=e[a];if(a==="lineHeight")typeof i=="string"&&(i=e[a]=Fe(i,o,r,{percentage:!0})/o);else if(typeof i=="string"){let n=Fe(i,o,r);typeof n!="undefined"&&(e[a]=n),i=e[a]}if(a==="opacity"&&(i=e[a]=i*r.opacity),a==="transform"){let n=[...ft],s=i;for(let f of s){let p=Object.keys(f)[0],g=f[p],u=typeof g=="string"?Fe(g,o,r):g,m=[...ft];switch(p){case"translateX":m[4]=u;break;case"translateY":m[5]=u;break;case"scale":m[0]=u,m[3]=u;break;case"scaleX":m[0]=u;break;case"scaleY":m[3]=u;break;case"rotate":let h=u*Math.PI/180,d=Math.cos(h),c=Math.sin(h);m[0]=d,m[1]=c,m[2]=-c,m[3]=d;break;case"skewX":m[2]=Math.tan(u*Math.PI/180);break;case"skewY":m[1]=Math.tan(u*Math.PI/180);break}n=fe(m,n)}e.transform=n}}return e}function $e(t,r,e,o,a){let i=Q(),n=D(D(D({},e),Ee(st[r],e)),Ee(o,e));if(r==="img"){let s=parseInt(a.width),p=parseInt(a.height)/s;n.width||(n.width=s),n.height||(n.height=p*n.width)}return t.setDisplay(H(n.display,{flex:i.DISPLAY_FLEX,none:i.DISPLAY_NONE},i.DISPLAY_FLEX)),t.setAlignContent(H(n.alignContent,{stretch:i.ALIGN_STRETCH,center:i.ALIGN_CENTER,"flex-start":i.ALIGN_FLEX_START,"flex-end":i.ALIGN_FLEX_END,"space-between":i.ALIGN_SPACE_BETWEEN,"space-around":i.ALIGN_SPACE_AROUND,baseline:i.ALIGN_BASELINE,normal:i.ALIGN_AUTO},i.ALIGN_AUTO)),t.setAlignItems(H(n.alignItems,{stretch:i.ALIGN_STRETCH,center:i.ALIGN_CENTER,"flex-start":i.ALIGN_FLEX_START,"flex-end":i.ALIGN_FLEX_END,baseline:i.ALIGN_BASELINE,normal:i.ALIGN_AUTO},i.ALIGN_FLEX_START)),t.setAlignSelf(H(n.alignSelf,{stretch:i.ALIGN_STRETCH,center:i.ALIGN_CENTER,"flex-start":i.ALIGN_FLEX_START,"flex-end":i.ALIGN_FLEX_END,baseline:i.ALIGN_BASELINE,normal:i.ALIGN_AUTO},i.ALIGN_AUTO)),t.setJustifyContent(H(n.justifyContent,{center:i.JUSTIFY_CENTER,"flex-start":i.JUSTIFY_FLEX_START,"flex-end":i.JUSTIFY_FLEX_END,"space-between":i.JUSTIFY_SPACE_BETWEEN,"space-around":i.JUSTIFY_SPACE_AROUND},i.JUSTIFY_FLEX_START)),t.setFlexDirection(H(n.flexDirection,{row:i.FLEX_DIRECTION_ROW,column:i.FLEX_DIRECTION_COLUMN,"row-reverse":i.FLEX_DIRECTION_ROW_REVERSE,"column-reverse":i.FLEX_DIRECTION_COLUMN_REVERSE},i.FLEX_DIRECTION_ROW)),t.setFlexWrap(H(n.flexWrap,{wrap:i.WRAP_WRAP,nowrap:i.WRAP_NO_WRAP,"wrap-reverse":i.WRAP_WRAP_REVERSE},i.WRAP_WRAP)),typeof n.flexBasis!="undefined"&&t.setFlexBasis(n.flexBasis),t.setFlexGrow(typeof n.flexGrow=="undefined"?0:n.flexGrow),t.setFlexShrink(typeof n.flexShrink=="undefined"?0:n.flexShrink),typeof n.maxHeight!="undefined"&&t.setMaxHeight(n.maxHeight),typeof n.maxWidth!="undefined"&&t.setMaxWidth(n.maxWidth),typeof n.minHeight!="undefined"&&t.setMinHeight(n.minHeight),typeof n.minWidth!="undefined"&&t.setMinWidth(n.minWidth),t.setOverflow(H(n.overflow,{visible:i.OVERFLOW_VISIBLE,hidden:i.OVERFLOW_HIDDEN},i.OVERFLOW_VISIBLE)),t.setMargin(i.EDGE_TOP,n.marginTop||0),t.setMargin(i.EDGE_BOTTOM,n.marginBottom||0),t.setMargin(i.EDGE_LEFT,n.marginLeft||0),t.setMargin(i.EDGE_RIGHT,n.marginRight||0),t.setBorder(i.EDGE_TOP,n.borderWidth||0),t.setBorder(i.EDGE_BOTTOM,n.borderWidth||0),t.setBorder(i.EDGE_LEFT,n.borderWidth||0),t.setBorder(i.EDGE_RIGHT,n.borderWidth||0),t.setPadding(i.EDGE_TOP,n.paddingTop||0),t.setPadding(i.EDGE_BOTTOM,n.paddingBottom||0),t.setPadding(i.EDGE_LEFT,n.paddingLeft||0),t.setPadding(i.EDGE_RIGHT,n.paddingRight||0),t.setPositionType(H(n.position,{absolute:i.POSITION_TYPE_ABSOLUTE,relative:i.POSITION_TYPE_RELATIVE},i.POSITION_TYPE_RELATIVE)),typeof n.top!="undefined"&&t.setPosition(i.EDGE_TOP,n.top),typeof n.bottom!="undefined"&&t.setPosition(i.EDGE_BOTTOM,n.bottom),typeof n.left!="undefined"&&t.setPosition(i.EDGE_LEFT,n.left),typeof n.right!="undefined"&&t.setPosition(i.EDGE_RIGHT,n.right),typeof n.height!="undefined"?t.setHeight(n.height):t.setHeightAuto(),typeof n.width!="undefined"?t.setWidth(n.width):t.setWidthAuto(),[n,Pe(n)]}function re({left:t,top:r,width:e,height:o},a,i,n){var f,p,g,u;let s;if(i)s=a;else{let m=(p=n==null?void 0:n.xAbsolute)!=null?p:((f=n==null?void 0:n.xRelative)!=null?f:50)*e/100,h=(u=n==null?void 0:n.yAbsolute)!=null?u:((g=n==null?void 0:n.yRelative)!=null?g:50)*o/100,d=t+m,c=r+h;s=fe([1,0,0,1,d,c],fe(a,[1,0,0,1,-d,-c])),a.__parent&&(s=fe(a.__parent,s)),a.splice(0,6,...s)}return`matrix(${s.map(m=>m.toFixed(2)).join(",")})`}function dt({left:t,top:r,width:e,height:o,isInheritingTransform:a},i){let n="",s=1;return i.transform&&(n=re({left:t,top:r,width:e,height:o},i.transform,a,i.transformOrigin)),i.opacity&&(s=+i.opacity),{matrix:n,opacity:s}}function Ne({id:t,content:r,filter:e,left:o,top:a,width:i,height:n,matrix:s,opacity:f,image:p,clipPathId:g,debug:u,shape:m,decorationShape:h},d){let c="";if(u&&(c=y("rect",{x:o,y:a,width:i,height:.5,fill:"transparent",stroke:"#575eff","stroke-width":1,transform:s||void 0,"clip-path":g?`url(#${g})`:void 0})),p){let x={href:p,x:o,y:a,width:i,height:n,transform:s||void 0,"clip-path":g?`url(#${g})`:void 0};return[(e?`${e}<g filter="url(#satori_s-${t})">`:"")+y("image",te(D({},x),{opacity:f!==1?f:void 0}))+(h||"")+(e?"</g>":"")+c,""]}let R={x:o,y:a,width:i,height:n,"font-weight":d.fontWeight,"font-style":d.fontStyle,"font-size":d.fontSize,"font-family":d.fontFamily,"letter-spacing":d.letterSpacing||void 0,transform:s||void 0,"clip-path":g?`url(#${g})`:void 0};return[(e?`${e}<g filter="url(#satori_s-${t})">`:"")+y("text",te(D({},R),{fill:d.color,opacity:f!==1?f:void 0}),r)+(h||"")+(e?"</g>":"")+c,m?y("text",R,r):""]}function ne({id:t,width:r,height:e},o){if(!o.shadowColor||!o.shadowOffset||typeof o.shadowRadius=="undefined")return"";let a=o.shadowRadius*o.shadowRadius/4,i=Math.min(o.shadowOffset.width-a,0),n=Math.max(o.shadowOffset.width+a+r,r),s=Math.min(o.shadowOffset.height-a,0),f=Math.max(o.shadowOffset.height+a+e,e);return`<defs><filter id="satori_s-${t}" x="${i/r*100}%" y="${s/e*100}%" width="${(n-i)/r*100}%" height="${(f-s)/e*100}%"><feDropShadow dx="${o.shadowOffset.width}" dy="${o.shadowOffset.height}" stdDeviation="${o.shadowRadius/2}" flood-color="${o.shadowColor}" flood-opacity="1"/></filter></defs>`}function Me({width:t,left:r,top:e,ascender:o,clipPathId:a},i){let{textDecorationColor:n,textDecorationStyle:s,textDecorationLine:f,fontSize:p}=i;if(!f||f==="none")return"";let g=Math.max(1,p*.1),u=f==="line-through"?e+o*.75:f==="underline"?e+o*1.25:e,m=s==="dashed"?`${g*1.2} ${g*2}`:s==="dotted"?`0 ${g*2}`:void 0;return y("line",{x1:r,y1:u,x2:r+t,y2:u,stroke:n,"stroke-width":g,"stroke-dasharray":m,"stroke-linecap":s==="dotted"?"round":"square","clip-path":a?`url(#${a})`:void 0})}var Ge=void 0;function*De(t,r){var Qe;let e=Q(),{parentStyle:o,inheritedStyle:a,parent:i,font:n,id:s,isInheritingTransform:f,debug:p,embedFont:g,graphemeImages:u}=r;o.textTransform==="uppercase"?t=t.toLocaleUpperCase(Ge):o.textTransform==="lowercase"?t=t.toLocaleLowerCase(Ge):o.textTransform==="capitalize"&&(t=ce(t,"word").map(_=>ce(_,"grapheme").map((E,N)=>N===0?E.toLocaleUpperCase(Ge):E).join("")).join(""));let m=H(o.wordBreak,{normal:"word","break-all":"grapheme","break-word":"grapheme","keep-all":"word"},"word"),h=ce(t,m),d=e.Node.create();d.setAlignItems(e.ALIGN_BASELINE),o.textAlign==="left"?d.setJustifyContent(e.JUSTIFY_FLEX_START):o.textAlign==="center"?d.setJustifyContent(e.JUSTIFY_CENTER):o.textAlign==="right"?d.setJustifyContent(e.JUSTIFY_FLEX_END):o.textAlign==="justify"&&d.setJustifyContent(e.JUSTIFY_SPACE_BETWEEN),i.insertChild(d,i.getChildCount());let{textAlign:c,textOverflow:R,whiteSpace:x,lineHeight:Y,_inheritedBackgroundClipTextPath:L}=o,O=n.getFont(o),F=o.fontSize,P=O.ascender/O.unitsPerEm*F,v=-(O.descender/O.unitsPerEm)*F,C=P+v,M=Y/1.2*F-C,W=C*Y/1.2,j=(o.fontSize-C)/2,G=[],U=[],S=[],$=new Map,z=_=>{if($.has(_))return $.get(_);let E=n.measure(O,_,o);return $.set(_,E),E},l=0,b="",T=0;for(let _ of h){let E=!1,N=u&&u[_];x==="pre"?E=_[0]===`
2
+ `:x!=="nowrap"&&(N||de.includes(_[0]))&&(E=!0),E?(x==="nowrap"?T+=z(b)+o.fontSize:(l=Math.max(l,z(b)),N&&(l=Math.max(l,o.fontSize))),b=""):(!de.includes(_[0])||!b)&&(b+=_===`
3
+ `?" ":_)}l=Math.max(l,z(b)+T);let X=i.getMinWidth(),ie=i.getMaxWidth(),gt=i.getWidth();isNaN(gt.value)&&(isNaN(X.value)||X.unit===1&&X.value>l)&&(isNaN(ie.value)||ie.unit===1&&(l=Math.min(l,ie.value)),i.setMinWidth(l)),typeof o.flexShrink=="undefined"&&i.setFlexShrink(1);let je=["pre-wrap","pre"].includes(x);d.setMeasureFunc(_=>{let E=0,N="",V=0,B=0,K=0,q=-1;G=[],U=[0];for(let Z=0;Z<h.length;Z++){let k=h[Z];if(!je&&de.includes(k[0]))N||(N=" "),V=z(N),S[Z]=null;else{let ae=je&&k===`
4
+ `,A=ae?0:u&&u[k]?o.fontSize:z(k);B||(N="",V=0);let J=V||",.!?:-@)>]}%#".indexOf(k[0])<0,se=!B||!!V;ae||Z&&J&&B+V+A>_&&x!=="nowrap"&&x!=="pre"?(G.push(B),E++,B=A,U.push(1),q=-1,ae||(K=Math.max(K,_))):(B+=V+A,se&&U[U.length-1]++),N="",V=0,se&&q++,K=Math.max(K,B),S[Z]={y:E*W-j,x:B-A,width:A,line:E,lineIndex:q}}}return B&&(E++,G.push(B)),{width:K,height:E*W}});let[ht,bt]=yield,we="",ge="",oe=a._inheritedClipPathId,{left:Ke,top:qe,width:le,height:Ie}=d.getComputedLayout(),Le=i.getComputedWidth()-i.getComputedPadding(e.EDGE_LEFT)-i.getComputedPadding(e.EDGE_RIGHT)-i.getComputedBorder(e.EDGE_LEFT)-i.getComputedBorder(e.EDGE_RIGHT),he=ht+Ke,be=bt+qe,{matrix:ee,opacity:ye}=dt({left:Ke,top:qe,width:le,height:Ie,isInheritingTransform:f},o),ue="";o.textShadowOffset&&(ue=ne({width:le,height:Ie,id:s},{shadowColor:o.textShadowColor,shadowOffset:o.textShadowOffset,shadowRadius:o.textShadowRadius}));let xe="",Se="",Ce=-1,Ze=R==="ellipsis"?z("\u2026"):0,yt=R==="ellipsis"?z(" "):0,_e={};for(let _=0;_<h.length;_++){if(!S[_])continue;let E=S[_],N=h[_],V=null,B=u?u[N]:null,K=E.y,q=E.x,Z=E.width,k=E.line;if(k===Ce)continue;let ae=!1;if(G.length>1){let A=le-G[k];if(c==="right"||c==="end")q+=A;else if(c==="center")q+=A/2;else if(c==="justify"&&k<G.length-1){let J=U[k];q+=(J>1?A/(J-1):0)*E.lineIndex,ae=!0}}if(_e[k]||(_e[k]=[q,ae?le:G[k]]),R==="ellipsis"&&G[k]>Le&&E.x+Z+Ze+yt>Le){let A=ce(N,"grapheme"),J="",se=0;for(let et of A){let tt=E.x+z(J+et);if(J&&tt+Ze>Le)break;J+=et,se=tt}N=J+"\u2026",Ce=k,_e[k][1]=se}if(B?K+=j:g?V=n.getSVG(O,N,te(D({},o),{left:he+q,top:be+K+P+M/2,letterSpacing:o.letterSpacing})):K+=P+M/2,o.textDecorationLine&&(k!==((Qe=S[_+1])==null?void 0:Qe.line)||Ce===k)){let A=_e[k];A&&!A[2]&&(xe+=Me({left:he+A[0],top:be+W*+k,width:A[1],ascender:P+M/2,clipPathId:oe},o),A[2]=1)}if(V)Se+=V+" ";else{let[A,J]=Ne({content:N,filter:ue,id:s,left:he+q,top:be+K,width:Z,height:W,matrix:ee,opacity:ye,image:B,clipPathId:oe,debug:p,shape:!!L,decorationShape:xe},o);we+=A,ge+=J,xe=""}}if(Se){let _="";p&&(_=y("rect",{x:he,y:be,width:le,height:Ie,fill:"transparent",stroke:"#575eff","stroke-width":1,transform:ee||void 0,"clip-path":oe?`url(#${oe})`:void 0}));let E=o.color!=="transparent"&&ye!==0?y("path",{fill:o.color,d:Se,transform:ee||void 0,opacity:ye!==1?ye:void 0,"clip-path":oe?`url(#${oe})`:void 0}):"";L&&(ge=y("path",{d:Se,transform:ee||void 0})),we+=(ue?`${ue}<g filter="url(#satori_s-${s})">`:"")+E+xe+(ue?"</g>":"")+_}return ge&&(o._inheritedBackgroundClipTextPath.value+=ge),we}import Bt from"parse-css-dimension";var Be=Be||{};Be.parse=function(){var t={linearGradient:/^(\-(webkit|o|ms|moz)\-)?(linear\-gradient)/i,repeatingLinearGradient:/^(\-(webkit|o|ms|moz)\-)?(repeating\-linear\-gradient)/i,radialGradient:/^(\-(webkit|o|ms|moz)\-)?(radial\-gradient)/i,repeatingRadialGradient:/^(\-(webkit|o|ms|moz)\-)?(repeating\-radial\-gradient)/i,sideOrCorner:/^to (left (top|bottom)|right (top|bottom)|top (left|right)|bottom (left|right)|left|right|top|bottom)/i,extentKeywords:/^(closest\-side|closest\-corner|farthest\-side|farthest\-corner|contain|cover)/,positionKeywords:/^(left|center|right|top|bottom)/i,pixelValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))px/,percentageValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))\%/,emValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))em/,angleValue:/^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))deg/,startCall:/^\(/,endCall:/^\)/,comma:/^,/,hexColor:/^\#([0-9a-fA-F]+)/,literalColor:/^([a-zA-Z]+)/,rgbColor:/^rgb/i,rgbaColor:/^rgba/i,number:/^(([0-9]*\.[0-9]+)|([0-9]+\.?))/},r="";function e(l){var b=new Error(r+": "+l);throw b.source=r,b}function o(){var l=a();return r.length>0&&e("Invalid input not EOF"),l}function a(){return L(i)}function i(){return n("linear-gradient",t.linearGradient,f)||n("repeating-linear-gradient",t.repeatingLinearGradient,f)||n("radial-gradient",t.radialGradient,u)||n("repeating-radial-gradient",t.repeatingRadialGradient,u)}function n(l,b,T){return s(b,function(X){var ie=T();return ie&&($(t.comma)||e("Missing comma before color stops")),{type:l,orientation:ie,colorStops:L(O)}})}function s(l,b){var T=$(l);if(T){$(t.startCall)||e("Missing (");var X=b(T);return $(t.endCall)||e("Missing )"),X}}function f(){return p()||g()}function p(){return S("directional",t.sideOrCorner,1)}function g(){return S("angular",t.angleValue,1)}function u(){var l,b=m(),T;return b&&(l=[],l.push(b),T=r,$(t.comma)&&(b=m(),b?l.push(b):r=T)),l}function m(){var l=h()||d();if(l)l.at=R();else{var b=c();if(b){l=b;var T=R();T&&(l.at=T)}else{var X=x();X&&(l={type:"default-radial",at:X})}}return l}function h(){var l=S("shape",/^(circle)/i,0);return l&&(l.style=U()||c()),l}function d(){var l=S("shape",/^(ellipse)/i,0);return l&&(l.style=j()||c()),l}function c(){return S("extent-keyword",t.extentKeywords,1)}function R(){if(S("position",/^at/,0)){var l=x();return l||e("Missing positioning value"),l}}function x(){var l=Y();if(l.x||l.y)return{type:"position",value:l}}function Y(){return{x:j(),y:j()}}function L(l){var b=l(),T=[];if(b)for(T.push(b);$(t.comma);)b=l(),b?T.push(b):e("One extra comma");return T}function O(){var l=F();return l||e("Expected color definition"),l.length=j(),l}function F(){return v()||M()||C()||P()}function P(){return S("literal",t.literalColor,0)}function v(){return S("hex",t.hexColor,1)}function C(){return s(t.rgbColor,function(){return{type:"rgb",value:L(W)}})}function M(){return s(t.rgbaColor,function(){return{type:"rgba",value:L(W)}})}function W(){return $(t.number)[1]}function j(){return S("%",t.percentageValue,1)||G()||U()}function G(){return S("position-keyword",t.positionKeywords,1)}function U(){return S("px",t.pixelValue,1)||S("em",t.emValue,1)}function S(l,b,T){var X=$(b);if(X)return{type:l,value:X[T]}}function $(l){var b,T;return T=/^[\n\r\t\s]+/.exec(r),T&&z(T[0].length),b=l.exec(r),b&&z(b[0].length),b}function z(l){r=r.substr(l)}return function(l){return r=l.toString(),o()}}();var Ye=Be;function Yt(t){return t.type==="literal"?t.value:t.type==="hex"?`#${t.value}`:t.type==="rgb"?`rgb(${t.value.join(",")})`:t.type==="rgba"?`rgba(${t.value.join(",")})`:"transparent"}function Xt(t,r){return typeof t=="string"&&t.endsWith("%")?r*parseFloat(t)/100:+t}function ct(t,{x:r,y:e,defaultX:o,defaultY:a}){return(t?t.split(" ").map(i=>{try{let n=new Bt(i);return n.type==="length"||n.type==="number"?n.value:n.value+n.unit}catch{return null}}).filter(i=>i!==null):[o,a]).map((i,n)=>Xt(i,[r,e][n]))}function mt(t,r){let e=[];for(let n of r){let s=Yt(n);if(!e.length&&(e.push({offset:0,color:s}),typeof n.length=="undefined"||n.length.value==="0"))continue;let f=typeof n.length=="undefined"?void 0:n.length.type==="%"?n.length.value/100:n.length.value/t;e.push({offset:f,color:s})}e.length||e.push({offset:0,color:"transparent"});let o=e[e.length-1];o.offset!==1&&(typeof o.offset=="undefined"?o.offset=1:e.push({offset:1,color:o.color}));let a=0,i=1;for(let n=0;n<e.length;n++)if(typeof e[n].offset=="undefined"){for(i<n&&(i=n);typeof e[i].offset=="undefined";)i++;e[n].offset=(e[i].offset-e[a].offset)/(i-a)*(n-a)+e[a].offset}else a=n;return e}function Xe({id:t,width:r,height:e},{image:o,size:a,position:i,repeat:n}){let s=n==="repeat-x"||n==="repeat",f=n==="repeat-y"||n==="repeat",p=ct(a,{x:r,y:e,defaultX:r,defaultY:e}),g=ct(i,{x:r,y:e,defaultX:0,defaultY:0});if(o.startsWith("linear-gradient(")){let u=Ye.parse(o)[0],m,h,d,c;if(u.orientation.type==="directional")[m,h,d,c]={top:[0,1,0,0],bottom:[0,0,0,1],left:[1,0,0,0],right:[0,0,1,0]}[u.orientation.value];else if(u.orientation.type==="angular"){let x=+u.orientation.value/180*Math.PI-Math.PI/2,Y=Math.cos(x),L=Math.sin(x);m=0,h=0,d=Y,c=L,d<0&&(m-=d,d=0),c<0&&(h-=c,c=0)}let R=mt(r,u.colorStops);return[`satori_bi${t}`,`<linearGradient id="satori_bi${t}" x1="${m}" y1="${h}" x2="${d}" y2="${c}">${R.map(x=>`<stop offset="${x.offset*100}%" stop-color="${x.color}"/>`).join("")}</linearGradient>`]}if(o.startsWith("radial-gradient(")){let u=Ye.parse(o)[0],m=u.orientation[0],[h,d]=p,c="circle",R=h/2,x=d/2;if(m.type==="shape"){if(c=m.value,m.at)if(m.at.type==="position")R=m.at.value.x.value,x=m.at.value.y.value;else throw new Error("orientation.at.type not implemented: "+m.at.type)}else throw new Error("orientation.type not implemented: "+m.type);let Y=mt(r,u.colorStops),L=`satori_radial_${t}`,O=`satori_pattern_${t}`,F={},P=Math.max(Math.abs(h-R),Math.abs(R)),v=Math.max(Math.abs(d-x),Math.abs(x));if(c==="circle")F.r=Math.sqrt(P*P+v*v);else if(c==="ellipse"){let W=v!==0?P/v:1;F.ry=Math.sqrt(P*P+v*v*W*W)/W,F.rx=F.ry*W}let C=y("pattern",{id:O,x:g[0],y:g[1],width:s?h:"100%",height:f?d:"100%",patternUnits:"userSpaceOnUse"},y("radialGradient",{id:L},Y.map(W=>y("stop",{offset:W.offset,"stop-color":W.color})).join(""))+y(c,te(D({cx:R,cy:x,width:h,height:d},F),{fill:`url(#${L})`})));return[O,C]}if(o.startsWith("url(")){let u=o.slice(4,-1);return[`satori_bi${t}`,y("pattern",{id:`satori_bi${t}`,patternContentUnits:"userSpaceOnUse",patternUnits:"userSpaceOnUse",x:g[0],y:g[1],width:s?p[0]:"100%",height:f?p[1]:"100%"},y("image",{x:0,y:0,width:p[0],height:p[1],href:u}))]}}function Re(t,r,e){return e<t+r&&(e/2<t&&e/2<r?t=r=e/2:e/2<t?t=e-r:e/2<r&&(r=e-t)),[t,r]}function me({left:t,top:r,width:e,height:o},a){let{borderTopLeftRadius:i,borderTopRightRadius:n,borderBottomLeftRadius:s,borderBottomRightRadius:f}=a;return i=Math.min(i||0,e,o),n=Math.min(n||0,e,o),s=Math.min(s||0,e,o),f=Math.min(f||0,e,o),!i&&!n&&!s&&!f?"":([i,n]=Re(i,n,e),[i,s]=Re(i,s,o),[n,f]=Re(n,f,o),[s,f]=Re(s,f,e),`M${t+i},${r} h${e-i-n} a${n},${n} 0 0 1 ${n},${n} v${o-n-f} a${f},${f} 0 0 1 ${-f},${f} h${f+s-e} a${s},${s} 0 0 1 ${-s},${-s} v${s+i-o} a${i},${i} 0 0 1 ${i},${-i}`)}function He({left:t,top:r,width:e,height:o,path:a,id:i},n){return n.overflow!=="hidden"?"":a?y("clipPath",{id:`satori_cp-${i}`,"clip-path":n._inheritedClipPathId?`url(#${n._inheritedClipPathId})`:void 0},y("path",{x:t,y:r,width:e,height:o,d:a})):y("clipPath",{id:`satori_cp-${i}`,"clip-path":n._inheritedClipPathId?`url(#${n._inheritedClipPathId})`:void 0},y("rect",{x:t,y:r,width:e,height:o}))}function Ue({id:t,left:r,top:e,width:o,height:a,isInheritingTransform:i,debug:n},s){if(s.display==="none")return"";let f="rect",p="transparent",g=0,u="",m="",h=[],d=1,c="";s.backgroundColor&&h.push(s.backgroundColor),s.borderWidth&&(g=s.borderWidth,p=s.borderColor),s.opacity&&(d=+s.opacity),s.transform&&(u=re({left:r,top:e,width:o,height:a},s.transform,i,s.transformOrigin));let R="";if(s.backgroundImage){let v=s.backgroundImage.map((C,M)=>Xe({id:t+"_"+M,width:o,height:a},C)).filter(Boolean);for(let C of v)h.push(`url(#${C[0]})`),m+=C[1],C[2]&&(R+=C[2])}let x=me({left:r,top:e,width:o,height:a},s);x&&(f="path");let Y=He({left:r,top:e,width:o,height:a,path:x,id:t},s),L=s._inheritedClipPathId,O=ne({width:o,height:a,id:t},s);n&&(c=y("rect",{x:r,y:e,width:o,height:a,fill:"transparent",stroke:"#ff5757","stroke-width":1,transform:u||void 0,"clip-path":L?`url(#${L})`:void 0})),h.length||h.push("transparent");let{backgroundClip:F}=s,P=h.map((v,C)=>{if(v==="transparent"&&!(C===h.length-1&&g))return"";let M=C===h.length-1&&g&&F!=="text";return y(f,{x:r,y:e,width:o,height:a,fill:v,stroke:M?p:void 0,"stroke-width":M?g:void 0,d:x||void 0,transform:u||void 0,"clip-path":F==="text"?`url(#satori_bct-${t})`:L?`url(#${L})`:void 0})}).join("");return F==="text"&&g&&(P=y(f,{x:r,y:e,width:o,height:a,fill:"transparent",stroke:p,"stroke-width":g,d:x||void 0,transform:u||void 0,"clip-path":L?`url(#${L})`:void 0})+P),(m?`<defs>${m}</defs>`:"")+Y+(O?`${O}<g filter="url(#satori_s-${t})">`:"")+(d!==1?`<g opacity="${d}">`:"")+(R||P)+(d!==1?"</g>":"")+(O?"</g>":"")+c}function ze({id:t,left:r,top:e,width:o,height:a,src:i,debug:n,isInheritingTransform:s},f){if(f.display==="none")return"";let p="",g=1,u="",m=f.objectFit==="contain"?"xMidYMid":f.objectFit==="cover"?"xMidYMid slice":"none",h=me({left:r,top:e,width:o,height:a},f),d=f._inheritedClipPathId;h&&(p=y("clipPath",{id:`satori_c-${t}`,"clip-path":d?`url(#${d})`:void 0},y("path",{x:r,y:e,width:o,height:a,d:h}))),f.opacity&&(g=+f.opacity);let c=ne({width:o,height:a,id:t},f);return f.transform&&(u=re({left:r,top:e,width:o,height:a},f.transform,s,f.transformOrigin)),c+(c?`<g filter="url(#satori_s-${t})">`:"")+p+y("image",{x:r,y:e,width:o,height:a,href:i,preserveAspectRatio:m,transform:u||void 0,"clip-path":p?`url(#satori_c-${t})`:d?`url(#${d})`:void 0})+(c?"</g>":"")}function*pe(t,r){let e=Q(),{id:o,inheritedStyle:a,parent:i,font:n,debug:s,embedFont:f=!0,graphemeImages:p}=r;if(t===null||typeof t=="undefined")return yield,"";if(!ke(t)||typeof t.type=="function"){let S;if(!ke(t))S=De(String(t),r);else{if(ot(t.type))throw new Error("Class component is not supported.");S=pe(t.type(t.props),r)}S.next();let $=yield;return S.next($).value}let{type:g,props:u}=t,{style:m,children:h}=u,d=e.Node.create();i.insertChild(d,i.getChildCount());let[c,R]=$e(d,g,a,m,u),x=c.transform===a.transform;if(x||(c.transform.__parent=a.transform),c.overflow==="hidden"&&(R._inheritedClipPathId=`satori_cp-${o}`),c.backgroundClip==="text"){let S={value:""};R._inheritedBackgroundClipTextPath=S,c._inheritedBackgroundClipTextPath=S}let Y=typeof h=="undefined"?[]:[].concat(h),L=[],O=0;for(let S of Y){let $=pe(S,{id:o+"-"+O++,parentStyle:c,inheritedStyle:R,isInheritingTransform:!0,parent:d,font:n,embedFont:f,debug:s,graphemeImages:p});$.next(),L.push($)}let[F,P]=yield;c.position==="absolute"&&d.calculateLayout();let{left:v,top:C,width:M,height:W}=d.getComputedLayout();v+=F,C+=P;let j="",G="",U="";g==="img"?G=ze({id:o,left:v,top:C,width:M,height:W,src:u.src,isInheritingTransform:x,debug:s},c):G=Ue({id:o,left:v,top:C,width:M,height:W,isInheritingTransform:x,debug:s},c);for(let S of L)j+=S.next([v,C]).value;return c._inheritedBackgroundClipTextPath&&(U+=y("clipPath",{id:`satori_bct-${o}`,"clip-path":c._inheritedClipPathId?`url(#${c._inheritedClipPathId})`:void 0},c._inheritedBackgroundClipTextPath.value)),U+G+j}import Ht from"@shuding/opentype.js";var Te=class{constructor(r){this.fonts=new Map;for(let e of r){let o=e.data,a=Ht.parse("buffer"in o?o.buffer.slice(o.byteOffset,o.byteOffset+o.byteLength):o,{lowMemory:!0});this.defaultFont||(this.defaultFont=a),this.fonts.has(e.name)||this.fonts.set(e.name,[]),this.fonts.get(e.name).push([a,e.weight,e.style])}}get({name:r,weight:e,style:o}){if(!this.fonts.has(r))return this.defaultFont;e==="normal"&&(e=400),e==="bold"&&(e=700);let a=[...this.fonts.get(r)];return a.sort(([i,n,s],[f,p,g])=>{if(n!==p)return n?!p||n===e?-1:p===e?1:e===400&&n===500||e===500&&n===400?-1:e===400&&p===500||e===500&&p===400?1:e<400?n<e&&p<e?p-n:n<e?-1:p<e?1:n-p:e<n&&e<p?n-p:e<n?-1:e<p?1:p-n:1;if(s!==g){if(s===o)return-1;if(g===o)return 1}return-1}),a[0][0]}getFont({fontFamily:r,fontWeight:e=400,fontStyle:o="normal"}){return this.get({name:r,weight:e,style:o})}measure(r,e,{fontSize:o,letterSpacing:a=0}){return r.getAdvanceWidth(e,o,{letterSpacing:a/o})}getSVG(r,e,{fontSize:o,top:a,left:i,letterSpacing:n=0}){return r.getPath(e,i,a,o,{letterSpacing:n/o}).toPathData(1)}};function Ve({width:t,height:r,content:e}){return y("svg",{width:t,height:r,viewBox:`0 0 ${t} ${r}`,xmlns:"http://www.w3.org/2000/svg"},e)}var Je=new WeakMap;function pt(t,r){let e=Q();if(!e)throw new Error("Satori is not initialized.");let o;Je.has(r.fonts)?o=Je.get(r.fonts):Je.set(r.fonts,o=new Te(r.fonts));let a=e.Node.create();a.setWidth(r.width),a.setHeight(r.height),a.setFlexDirection(e.FLEX_DIRECTION_ROW),a.setFlexWrap(e.WRAP_WRAP),a.setAlignContent(e.ALIGN_AUTO),a.setAlignItems(e.ALIGN_FLEX_START),a.setJustifyContent(e.JUSTIFY_FLEX_START),a.setOverflow(e.OVERFLOW_HIDDEN);let i=pe(t,{id:"id",parentStyle:{},inheritedStyle:{fontSize:16,fontWeight:"normal",fontFamily:"serif",fontStyle:"normal",lineHeight:1.2,color:"black",opacity:1,whiteSpace:"normal",_viewportWidth:r.width,_viewportHeight:r.height},parent:a,font:o,embedFont:r.embedFont,debug:r.debug,graphemeImages:r.graphemeImages});i.next(),a.calculateLayout(r.width,r.height,e.DIRECTION_LTR);let n=i.next([0,0]).value;return a.freeRecursive(),Ve({width:r.width,height:r.height,content:n})}export{pt as default,wt as init};
3
5
  //# sourceMappingURL=index.js.map