satori 0.0.14-beta.0 → 0.0.14
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 +4 -2
- package/dist/esm/index.js +2 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/index.wasm.js +2 -2
- package/dist/esm/index.wasm.js.map +1 -1
- package/package.json +7 -5
package/README.md
CHANGED
|
@@ -88,6 +88,8 @@ satori(
|
|
|
88
88
|
)
|
|
89
89
|
```
|
|
90
90
|
|
|
91
|
+
When using `background-image`, the image will be stretched to fit the element by default if you don't specify the size.
|
|
92
|
+
|
|
91
93
|
If you want to render the generated SVG to another image format such as PNG, it would be better to use base64 encoded image data directly as `props.src` so no extra I/O is needed.
|
|
92
94
|
|
|
93
95
|
#### Emojis
|
|
@@ -147,9 +149,9 @@ The image will be resized to the current font-size (both width and height), so i
|
|
|
147
149
|
| `word-break` | Supported |
|
|
148
150
|
| `text-shadow` | Supported |
|
|
149
151
|
| `text-transform` | Support `lowercase`, `uppercase`, `capitalize` |
|
|
152
|
+
| `background-position` | Supported |
|
|
153
|
+
| `background-size` | Support two-value size string such as `10px 20%` |
|
|
150
154
|
| `background-clip` | TBD |
|
|
151
|
-
| `background-size` | TBD |
|
|
152
|
-
| `background-position` | TBD |
|
|
153
155
|
| `background-repeat` | TBD |
|
|
154
156
|
| `background-origin` | TBD |
|
|
155
157
|
| `text-decoration` | TBD |
|
package/dist/esm/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
var at=Object.defineProperty,zt=Object.defineProperties,Ut=Object.getOwnPropertyDescriptor,Xt=Object.getOwnPropertyDescriptors,Ht=Object.getOwnPropertyNames,Tt=Object.getOwnPropertySymbols;var Lt=Object.prototype.hasOwnProperty,Vt=Object.prototype.propertyIsEnumerable;var It=(t,r,e)=>r in t?at(t,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):t[r]=e,Z=(t,r)=>{for(var e in r||(r={}))Lt.call(r,e)&&It(t,e,r[e]);if(Tt)for(var e of Tt(r))Vt.call(r,e)&&It(t,e,r[e]);return t},wt=(t,r)=>zt(t,Xt(r)),Jt=t=>at(t,"__esModule",{value:!0});var At=(t,r)=>()=>(t&&(r=t(t=0)),r);var jt=(t,r)=>{for(var e in r)at(t,e,{get:r[e],enumerable:!0})},Kt=(t,r,e,i)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of Ht(r))!Lt.call(t,s)&&(e||s!=="default")&&at(t,s,{get:()=>r[s],enumerable:!(i=Ut(r,s))||i.enumerable});return t};var qt=(t=>(r,e)=>t&&t.get(r)||(e=Kt(Jt({}),r,1),t&&t.set(r,e),e))(typeof WeakMap!="undefined"?new WeakMap:0);var d=At(()=>{});var Ct={};jt(Ct,{default:()=>Qt});import*as Zt from"yoga-layout-prebuilt";var Qt,Ft=At(()=>{d();Qt=Zt});d();d();d();var st;{let t=(Ft(),qt(Ct));t.default?st=t.default:st=t}function te(t){st=t}function B(){return st}d();d();function ct(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 Q(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 F(t,r,e){let i=r[t];return typeof i=="undefined"?e:i}d();d();var Nt={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"}};d();var ee=new Set(["color","font","fontFamily","fontSize","fontStyle","fontWeight","lineHeight","textAlign","textTransform","whiteSpace","letterSpacing","transform","wordBreak","textShadowOffset","textShadowColor","textShadowRadius","opacity"]);function mt(t){let r={};for(let e in t)ee.has(e)&&(r[e]=t[e]);return r}d();import{getPropertyName as vt,getStylesForProperty as re}from"css-to-react-native";import Gt from"parse-css-dimension";import{parseElementStyle as ne}from"css-background-parser";var oe=new Set(["flex","flexGrow","flexShrink","flexBasis","fontWeight","lineHeight","opacity","scale","scaleX","scaleY"]),kt=[1,0,0,1,0,0];function ie(t,r){return typeof r=="number"?oe.has(t)?String(r):r+"px":r}function Wt(t,r){if(typeof t=="number")return t;try{let e=new Gt(t);if(e.type==="length")switch(e.unit){case"em":return e.value*r;case"rem":return e.value*16;default:return e.value}else if(e.type==="angle")switch(e.unit){case"deg":return e.value;case"rad":return e.value*180/Math.PI;default:return e.value}}catch{}}function ft(t,r){let e=[];for(let o in t){let n=vt(o);e.push([n,ie(n,t[o])])}let i=e.reduce((o,n)=>{let a=vt(n[0]),c=n[1];return Object.assign(o,re(a,c,!0))},{});if(i.backgroundImage){let{backgrounds:o}=ne(i);i.backgroundImage=o}let s=i.fontSize||r.fontSize;if(typeof s=="string")try{let o=new Gt(s);switch(o.unit){case"em":s=o.value*r.fontSize;break;case"rem":s=o.value*16;break}}catch{s=16}typeof i.fontSize!="undefined"&&(i.fontSize=s);for(let o in i){let n=i[o];if(typeof n=="string"){let a=Wt(n,s);typeof a!="undefined"&&(i[o]=a),n=i[o]}if(o==="opacity"&&(n=i[o]=n*r.opacity),o==="transform"){let a=[...kt],c=n;for(let l of c){let p=Object.keys(l)[0],h=l[p],g=typeof h=="string"?Wt(h,s):h,f=[...kt];switch(p){case"translateX":f[4]=g;break;case"translateY":f[5]=g;break;case"scaleX":f[0]=g;break;case"scaleY":f[3]=g;break;case"rotate":let y=g*Math.PI/180,x=Math.cos(y),I=Math.sin(y);f[0]=x,f[1]=I,f[2]=-I,f[3]=x;break;case"skewX":f[2]=Math.tan(g*Math.PI/180);break;case"skewY":f[1]=Math.tan(g*Math.PI/180);break}a=Q(f,a)}i.transform=a}}return i}function dt(t,r,e,i,s){let o=B(),n=Z(Z(Z({},e),ft(Nt[r],e)),ft(i,e));if(r==="img"){let a=parseInt(s.width),l=parseInt(s.height)/a;n.width||(n.width=a),n.height||(n.height=l*n.width)}return t.setDisplay(F(n.display,{flex:o.DISPLAY_FLEX,none:o.DISPLAY_NONE},o.DISPLAY_FLEX)),t.setAlignContent(F(n.alignContent,{stretch:o.ALIGN_STRETCH,center:o.ALIGN_CENTER,"flex-start":o.ALIGN_FLEX_START,"flex-end":o.ALIGN_FLEX_END,"space-between":o.ALIGN_SPACE_BETWEEN,"space-around":o.ALIGN_SPACE_AROUND,baseline:o.ALIGN_BASELINE,normal:o.ALIGN_AUTO},o.ALIGN_AUTO)),t.setAlignItems(F(n.alignItems,{stretch:o.ALIGN_STRETCH,center:o.ALIGN_CENTER,"flex-start":o.ALIGN_FLEX_START,"flex-end":o.ALIGN_FLEX_END,baseline:o.ALIGN_BASELINE,normal:o.ALIGN_AUTO},o.ALIGN_FLEX_START)),t.setAlignSelf(F(n.alignSelf,{stretch:o.ALIGN_STRETCH,center:o.ALIGN_CENTER,"flex-start":o.ALIGN_FLEX_START,"flex-end":o.ALIGN_FLEX_END,baseline:o.ALIGN_BASELINE,normal:o.ALIGN_AUTO},o.ALIGN_AUTO)),t.setJustifyContent(F(n.justifyContent,{center:o.JUSTIFY_CENTER,"flex-start":o.JUSTIFY_FLEX_START,"flex-end":o.JUSTIFY_FLEX_END,"space-between":o.JUSTIFY_SPACE_BETWEEN,"space-around":o.JUSTIFY_SPACE_AROUND},o.JUSTIFY_FLEX_START)),t.setFlexDirection(F(n.flexDirection,{row:o.FLEX_DIRECTION_ROW,column:o.FLEX_DIRECTION_COLUMN,"row-reverse":o.FLEX_DIRECTION_ROW_REVERSE,"column-reverse":o.FLEX_DIRECTION_COLUMN_REVERSE},o.FLEX_DIRECTION_ROW)),t.setFlexWrap(F(n.flexWrap,{wrap:o.WRAP_WRAP,nowrap:o.WRAP_NO_WRAP,"wrap-reverse":o.WRAP_WRAP_REVERSE},o.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"?1: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(F(n.overflow,{visible:o.OVERFLOW_VISIBLE,hidden:o.OVERFLOW_HIDDEN},o.OVERFLOW_VISIBLE)),t.setMargin(o.EDGE_TOP,n.marginTop||0),t.setMargin(o.EDGE_BOTTOM,n.marginBottom||0),t.setMargin(o.EDGE_LEFT,n.marginLeft||0),t.setMargin(o.EDGE_RIGHT,n.marginRight||0),t.setBorder(o.EDGE_TOP,n.borderWidth||0),t.setBorder(o.EDGE_BOTTOM,n.borderWidth||0),t.setBorder(o.EDGE_LEFT,n.borderWidth||0),t.setBorder(o.EDGE_RIGHT,n.borderWidth||0),t.setPadding(o.EDGE_TOP,n.paddingTop||0),t.setPadding(o.EDGE_BOTTOM,n.paddingBottom||0),t.setPadding(o.EDGE_LEFT,n.paddingLeft||0),t.setPadding(o.EDGE_RIGHT,n.paddingRight||0),t.setPositionType(F(n.position,{absolute:o.POSITION_TYPE_ABSOLUTE,relative:o.POSITION_TYPE_RELATIVE},o.POSITION_TYPE_RELATIVE)),typeof n.top!="undefined"&&t.setPosition(o.EDGE_TOP,n.top),typeof n.bottom!="undefined"&&t.setPosition(o.EDGE_BOTTOM,n.bottom),typeof n.left!="undefined"&&t.setPosition(o.EDGE_LEFT,n.left),typeof n.right!="undefined"&&t.setPosition(o.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,mt(n)]}d();import{LineBreaker as ae}from"css-line-break";import{splitGraphemes as se}from"text-segmentation";d();d();function et({left:t,top:r,width:e,height:i},s,o){let n;if(o)n=s;else{let a=t+e/2,c=r+i/2;n=Q([1,0,0,1,a,c],Q(s,[1,0,0,1,-a,-c])),s.__parent&&(n=Q(s.__parent,n)),s.splice(0,6,...n)}return`matrix(${n.map(a=>a.toFixed(2)).join(",")})`}function Pt({left:t,top:r,width:e,height:i,isInheritingTransform:s},o){let n="",a=1,c="";return o.transform&&(n=et({left:t,top:r,width:e,height:i},o.transform,s)),o.opacity&&(a=+o.opacity),{matrix:n,opacity:a}}function gt({id:t,content:r,filter:e,left:i,top:s,width:o,height:n,matrix:a,opacity:c,path:l,image:p,debug:h},g){let f="";return h&&(f=`<rect x="${i}" y="${s}" width="${o}" height="${l===null?.5:n}" fill="transparent" stroke="#575eff" stroke-width="1" ${a?`transform="${a}"`:""}></rect>`),p?`${e?`${e}<g filter="url(#satori_s-${t})">`:""}<image href="${p}" x="${i}" y="${s}" width="${o}" height="${n}" ${a?`transform="${a}"`:""} ${c!==1?`opacity="${c}"`:""}></image>${e?"</g>":""}${f}`:l===null?`${e?`${e}<g filter="url(#satori_s-${t})">`:""}<text x="${i}" y="${s}" width="${o}" height="${n}" fill="${g.color}" font-weight="${g.fontWeight}" font-style="${g.fontStyle}" font-size="${g.fontSize}" font-family="${g.fontFamily}" ${g.letterSpacing?`letter-spacing="${g.letterSpacing}"`:""} ${a?`transform="${a}"`:""} ${c!==1?`opacity="${c}"`:""}>${r}</text>${e?"</g>":""}${f}`:`${e?`${e}<g filter="url(#satori_s-${t})">`:""}<path fill="${g.color}" ${a?`transform="${a}"`:""} ${c!==1?`opacity="${c}"`:""} d="${l}"></path>${e?"</g>":""}${f}`}d();function j({id:t,width:r,height:e},i){if(!i.shadowColor||!i.shadowOffset||typeof i.shadowRadius=="undefined")return"";let s=i.shadowRadius*i.shadowRadius/4,o=Math.min(i.shadowOffset.width-s,0),n=Math.max(i.shadowOffset.width+s+r,r),a=Math.min(i.shadowOffset.height-s,0),c=Math.max(i.shadowOffset.height+s+e,e);return`<defs><filter id="satori_s-${t}" x="${o/r*100}%" y="${a/e*100}%" width="${(n-o)/r*100}%" height="${(c-a)/e*100}%"><feDropShadow dx="${i.shadowOffset.width}" dy="${i.shadowOffset.height}" stdDeviation="${i.shadowRadius/2}" flood-color="${i.shadowColor}" flood-opacity="1"/></filter></defs>`}var rt="en",ht=typeof Intl!="undefined"&&"Segmenter"in Intl,fe=ht?new Intl.Segmenter(rt,{granularity:"word"}):null,le=ht?new Intl.Segmenter(rt,{granularity:"grapheme"}):null,ue=[32,160,4961,65792,65793,4153,4241],ce=t=>{let r=ae(t,{lineBreak:"strict",wordBreak:"normal"}),e=[],i;for(;!(i=r.next()).done;)if(i.value){let s=i.value.slice(),o=[].map.call(s,a=>a.codePointAt(0)),n="";o.forEach(a=>{ue.includes(a)?(n.length&&e.push(n),e.push(String.fromCodePoint(a)),n=""):n+=String.fromCodePoint(a)}),n.length&&e.push(n)}return e};function pt(t,r){return ht?r==="word"?[...fe.segment(t)].map(e=>e.segment):[...le.segment(t)].map(e=>e.segment):r==="word"?ce(t):se(t)}function*bt(t,r){let e=B(),{parentStyle:i,parent:s,font:o,id:n,isInheritingTransform:a,debug:c,embedFont:l,graphemeImages:p}=r;i.textTransform==="uppercase"?t=t.toLocaleUpperCase(rt):i.textTransform==="lowercase"?t=t.toLocaleLowerCase(rt):i.textTransform==="capitalize"&&(t=pt(t,"word").map(m=>pt(m,"grapheme").map((b,R)=>R===0?b.toLocaleUpperCase(rt):b).join("")).join(""));let h=F(i.wordBreak,{normal:"word","break-all":"grapheme","break-word":"grapheme","keep-all":"word"},"word"),g=pt(t,h),f=e.Node.create();f.setAlignItems(e.ALIGN_BASELINE),i.textAlign==="left"?f.setJustifyContent(e.JUSTIFY_FLEX_START):i.textAlign==="center"?f.setJustifyContent(e.JUSTIFY_CENTER):i.textAlign==="right"?f.setJustifyContent(e.JUSTIFY_FLEX_END):i.textAlign==="justify"&&f.setJustifyContent(e.JUSTIFY_SPACE_BETWEEN),s.insertChild(f,s.getChildCount());let y=o.getFont(i),x=y.ascender/y.unitsPerEm*i.fontSize,I=-(y.descender/y.unitsPerEm)*i.fontSize,L=(x+I)*1.2,{textAlign:$}=i,N=[],P=[],w=[];f.setMeasureFunc((m,b,R,K)=>{let W=[],k="",G=0,V="",T=0,J=0,q=-1;N=[],P=[0];for(let U=0;U<g.length;U++){let X=g[U];if([" ",`
|
|
2
|
-
`," ","\u3000"].includes(X))k+=X,G=o.measure(y,k,i),w[U]=null;else{let tt=p&&p[X]?i.fontSize:o.measure(y,X,i);T||(k="",G=0);let Yt=G||",.!?:-@)>]}%#".indexOf(X[0])<0,Rt=!T||!!G;Yt&&T+G+tt>m?(N.push(T),W.push(V),V=X,T=tt,P.push(1),q=-1):(V+=k+X,T+=G+tt,Rt&&P[P.length-1]++),k="",G=0,Rt&&q++,J=Math.max(J,T),w[U]={y:W.length*L,x:T-tt,width:tt,line:W.length,lineIndex:q}}}return T&&(W.push(V),N.push(T)),W.length>1&&(J=m),{width:J,height:W.length*L}});let[D,Y]=yield,H="";i.position==="absolute"&&f.calculateLayout();let{left:z,top:C,width:A,height:M}=f.getComputedLayout(),_=D+z,v=Y+C,{matrix:it,opacity:u}=Pt({left:z,top:C,width:A,height:M,isInheritingTransform:a},i);for(let m=0;m<g.length;m++){if(!w[m])continue;let b=g[m],R=null,K=null,W=w[m].y,k=w[m].x,G=w[m].width,V=L,T=A-N[w[m].line];if($==="right"||$==="end")k+=T;else if($==="center")k+=T/2;else if($==="justify"){let q=w[m].line;if(q<N.length-1){let U=P[q];k+=(U>1?T/(U-1):0)*w[m].lineIndex}}p&&p[b]?K=p[b]:l?R=o.getSVG(y,b,wt(Z({},i),{left:_+k,top:v+W,letterSpacing:i.letterSpacing})):W+=x;let J="";i.textShadowOffset&&(J=j({width:G,height:V,id:n},{shadowColor:i.textShadowColor,shadowOffset:i.textShadowOffset,shadowRadius:i.textShadowRadius})),H+=gt({content:b,filter:J,id:n,left:_+k,top:v+W,width:G,height:V,matrix:it,opacity:u,path:R,image:K,debug:c},i)}return H}d();d();d();var yt=yt||{};yt.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(u){var m=new Error(r+": "+u);throw m.source=r,m}function i(){var u=s();return r.length>0&&e("Invalid input not EOF"),u}function s(){return $(o)}function o(){return n("linear-gradient",t.linearGradient,c)||n("repeating-linear-gradient",t.repeatingLinearGradient,c)||n("radial-gradient",t.radialGradient,h)||n("repeating-radial-gradient",t.repeatingRadialGradient,h)}function n(u,m,b){return a(m,function(R){var K=b();return K&&(v(t.comma)||e("Missing comma before color stops")),{type:u,orientation:K,colorStops:$(N)}})}function a(u,m){var b=v(u);if(b){v(t.startCall)||e("Missing (");var R=m(b);return v(t.endCall)||e("Missing )"),R}}function c(){return l()||p()}function l(){return _("directional",t.sideOrCorner,1)}function p(){return _("angular",t.angleValue,1)}function h(){var u,m=g(),b;return m&&(u=[],u.push(m),b=r,v(t.comma)&&(m=g(),m?u.push(m):r=b)),u}function g(){var u=f()||y();if(u)u.at=I();else{var m=x();if(m){u=m;var b=I();b&&(u.at=b)}else{var R=O();R&&(u={type:"default-radial",at:R})}}return u}function f(){var u=_("shape",/^(circle)/i,0);return u&&(u.style=M()||x()),u}function y(){var u=_("shape",/^(ellipse)/i,0);return u&&(u.style=C()||x()),u}function x(){return _("extent-keyword",t.extentKeywords,1)}function I(){if(_("position",/^at/,0)){var u=O();return u||e("Missing positioning value"),u}}function O(){var u=L();if(u.x||u.y)return{type:"position",value:u}}function L(){return{x:C(),y:C()}}function $(u){var m=u(),b=[];if(m)for(b.push(m);v(t.comma);)m=u(),m?b.push(m):e("One extra comma");return b}function N(){var u=P();return u||e("Expected color definition"),u.length=C(),u}function P(){return D()||H()||Y()||w()}function w(){return _("literal",t.literalColor,0)}function D(){return _("hex",t.hexColor,1)}function Y(){return a(t.rgbColor,function(){return{type:"rgb",value:$(z)}})}function H(){return a(t.rgbaColor,function(){return{type:"rgba",value:$(z)}})}function z(){return v(t.number)[1]}function C(){return _("%",t.percentageValue,1)||A()||M()}function A(){return _("position-keyword",t.positionKeywords,1)}function M(){return _("px",t.pixelValue,1)||_("em",t.emValue,1)}function _(u,m,b){var R=v(m);if(R)return{type:u,value:R[b]}}function v(u){var m,b;return b=/^[\n\r\t\s]+/.exec(r),b&&it(b[0].length),m=u.exec(r),m&&it(m[0].length),m}function it(u){r=r.substr(u)}return function(u){return r=u.toString(),i()}}();var Mt=yt;function me(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({id:t,width:r},{image:e}){if(e.startsWith("linear-gradient(")){let i=Mt.parse(e)[0],s,o,n,a;if(i.orientation.type==="directional")[s,o,n,a]={top:[0,1,0,0],bottom:[0,0,0,1],left:[1,0,0,0],right:[0,0,1,0]}[i.orientation.value];else if(i.orientation.type==="angular"){let f=+i.orientation.value/180*Math.PI-Math.PI/2,y=Math.cos(f),x=Math.sin(f);s=0,o=0,n=y,a=x,n<0&&(s-=n,n=0),a<0&&(o-=a,a=0)}let c=r,l=[];for(let f of i.colorStops){let y=me(f);if(!l.length&&(l.push({offset:0,color:y}),typeof f.length=="undefined"||f.length.value==="0"))continue;let x=typeof f.length=="undefined"?void 0:f.length.type==="%"?f.length.value/100:f.length.value/c;l.push({offset:x,color:y})}l.length||l.push({offset:0,color:"transparent"});let p=l[l.length-1];p.offset!==1&&(typeof p.offset=="undefined"?p.offset=1:l.push({offset:1,color:p.color}));let h=0,g=1;for(let f=0;f<l.length;f++)if(typeof l[f].offset=="undefined"){for(g<f&&(g=f);typeof l[g].offset=="undefined";)g++;l[f].offset=(l[g].offset-l[h].offset)/(g-h)*(f-h)+l[h].offset}else h=f;return[`satori_bi${t}`,`<linearGradient id="satori_bi${t}" x1="${s}" y1="${o}" x2="${n}" y2="${a}">${l.map(f=>`<stop offset="${f.offset*100}%" stop-color="${f.color}"/>`).join("")}</linearGradient>`]}if(e.startsWith("url(")){let i=e.slice(4,-1);return[`satori_bi${t}`,`<pattern id="satori_bi${t}" patternContentUnits="objectBoundingBox" width="1" height="1"><image href="${i}" x="0" y="0" width="1" height="1"/></pattern>`]}}d();function lt(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 nt({left:t,top:r,width:e,height:i},s){let{borderTopLeftRadius:o,borderTopRightRadius:n,borderBottomLeftRadius:a,borderBottomRightRadius:c}=s;return o=Math.min(o||0,e,i),n=Math.min(n||0,e,i),a=Math.min(a||0,e,i),c=Math.min(c||0,e,i),!o&&!n&&!a&&!c?"":([o,n]=lt(o,n,e),[o,a]=lt(o,a,i),[n,c]=lt(n,c,i),[a,c]=lt(a,c,e),`M${t+o},${r} h${e-o-n} a${n},${n} 0 0 1 ${n},${n} v${i-n-c} a${c},${c} 0 0 1 ${-c},${c} h${c+a-e} a${a},${a} 0 0 1 ${-a},${-a} v${a+o-i} a${o},${o} 0 0 1 ${o},${-o}`)}function $t({id:t,left:r,top:e,width:i,height:s,isInheritingTransform:o,debug:n},a){if(a.display==="none")return"";let c="rect",l="transparent",p=0,h="",g="",f=[],y=1,x="";if(a.backgroundColor&&f.push(a.backgroundColor),a.borderWidth&&(p=a.borderWidth,l=a.borderColor),a.opacity&&(y=+a.opacity),a.transform&&(h=et({left:r,top:e,width:i,height:s},a.transform,o)),a.backgroundImage){let L=a.backgroundImage.map(($,N)=>xt({id:t+"_"+N,width:i,height:s},$)).filter(Boolean);for(let $ of L)g+=$[1],f.push(`url(#${$[0]})`)}let I=nt({left:r,top:e,width:i,height:s},a);I&&(c="path");let O=j({width:i,height:s,id:t},a);return f.length||f.push("transparent"),n&&(x=`<rect x="${r}" y="${e}" width="${i}" height="${s}" fill="transparent" stroke="#ff5757" stroke-width="1" ${h?`transform="${h}"`:""}></rect>`),`${g?`<defs>${g}</defs>`:""}${O?`${O}<g filter="url(#satori_s-${t})">`:""}${y!==1?`<g opacity="${y}">`:""}${f.map((L,$)=>L==="transparent"&&!($===f.length-1&&p)?"":`<${c} x="${r}" y="${e}" width="${i}" height="${s}" fill="${L}" ${$===f.length-1&&p?`stroke="${l}" stroke-width="${p}"`:""} ${I?`d="${I}"`:""} ${h?`transform="${h}"`:""}></${c}>`).join("")}${y!==1?"</g>":""}${O?"</g>":""}${x}`}d();function Et({id:t,left:r,top:e,width:i,height:s,src:o,debug:n},a){if(a.display==="none")return"";let c="",l=1,p=a.objectFit==="contain"?"xMidYMid":a.objectFit==="cover"?"xMidYMid slice":"none",h=nt({left:r,top:e,width:i,height:s},a);h&&(c=`<clipPath id="satori_c-${t}"><path x="${r}" y="${e}" width="${i}" height="${s}" d="${h}"></path></clipPath>`),a.opacity&&(l=+a.opacity);let g=j({width:i,height:s,id:t},a);return`${g}${g?`<g filter="url(#satori_s-${t})">`:""}${c}<image href="${o}" x="${r}" y="${e}" width="${i}" height="${s}" preserveAspectRatio="${p}" ${c?`clip-path="url(#satori_c-${t})"`:""} ${l!==1?`opacity="${l}"`:""}></image>${g?"</g>":""}`}function*ot(t,r){let e=B(),{id:i,inheritedStyle:s,parent:o,font:n,debug:a,embedFont:c=!0,graphemeImages:l}=r;if(t===null||typeof t=="undefined")return yield,"";if(!ct(t)||typeof t.type=="function"){let A;if(!ct(t))A=bt(String(t),r);else{if(Ot(t.type))throw new Error("Class component is not supported.");A=ot(t.type(t.props),r)}A.next();let M=yield;return A.next(M).value}let{type:p,props:h}=t,{style:g,children:f}=h,y=e.Node.create();o.insertChild(y,o.getChildCount());let[x,I]=dt(y,p,s,g,h),O=x.transform===s.transform;O||(x.transform.__parent=s.transform);let L=typeof f=="undefined"?[]:[].concat(f),$=[],N=0;for(let A of L){let M=ot(A,{id:i*L.length+ ++N,parentStyle:x,inheritedStyle:I,isInheritingTransform:!0,parent:y,font:n,embedFont:c,debug:a,graphemeImages:l});M.next(),$.push(M)}let[P,w]=yield;x.position==="absolute"&&y.calculateLayout();let{left:D,top:Y,width:H,height:z}=y.getComputedLayout();D+=P,Y+=w;let C="";p==="img"?C=Et({id:i,left:D,top:Y,width:H,height:z,src:h.src,isInheritingTransform:O,debug:a},x):C=$t({id:i,left:D,top:Y,width:H,height:z,isInheritingTransform:O,debug:a},x);for(let A of $)C+=A.next([D,Y]).value;return C}d();import Bt from"opentype.js";var ut=class{constructor(r){this.fonts=new Map;for(let e of r){let i=e.data,s="buffer"in i?Bt.parse(i.buffer.slice(i.byteOffset,i.byteOffset+i.byteLength)):Bt.parse(i);this.defaultFont||(this.defaultFont=s),this.fonts.has(e.name)||this.fonts.set(e.name,[]),this.fonts.get(e.name).push([s,e.weight,e.style])}}get({name:r,weight:e,style:i}){if(!this.fonts.has(r))return this.defaultFont;e==="normal"&&(e=400),e==="bold"&&(e=700);let s=[...this.fonts.get(r)];return s.sort(([o,n,a],[c,l,p])=>{if(n!==l)return n?!l||n===e?-1:l===e?1:e===400&&n===500||e===500&&n===400?-1:e===400&&l===500||e===500&&l===400?1:e<400?n<e&&l<e?l-n:n<e?-1:l<e?1:n-l:e<n&&e<l?n-l:e<n?-1:e<l?1:l-n:1;if(a!==p){if(a===i)return-1;if(p===i)return 1}return-1}),s[0][0]}getFont({fontFamily:r,fontWeight:e=400,fontStyle:i="normal"}){return this.get({name:r,weight:e,style:i})}measure(r,e,{fontSize:i,letterSpacing:s=0}){return r.getAdvanceWidth(e,i,{letterSpacing:s/i})}getSVG(r,e,{fontSize:i,top:s,left:o,letterSpacing:n=0}){return s+=r.ascender/r.unitsPerEm*i,r.getPath(e,o,s,i,{letterSpacing:n/i}).toPathData(2)}};d();function St({width:t,height:r,content:e},i){return`<svg width="${t}" height="${r}" viewBox="0 0 ${t} ${r}" xmlns="http://www.w3.org/2000/svg">${e}</svg>`}var _t=new WeakMap;function Dt(t,r){let e=B();if(!e)throw new Error("Satori is not initialized.");let i;_t.has(r.fonts)?i=_t.get(r.fonts):_t.set(r.fonts,i=new ut(r.fonts));let s=e.Node.create();s.setWidth(r.width),s.setHeight(r.height),s.setFlexDirection(e.FLEX_DIRECTION_ROW),s.setFlexWrap(e.WRAP_WRAP),s.setAlignContent(e.ALIGN_AUTO),s.setAlignItems(e.ALIGN_FLEX_START),s.setJustifyContent(e.JUSTIFY_FLEX_START);let o=ot(t,{id:1,parentStyle:{},inheritedStyle:{fontSize:16,fontWeight:"normal",fontFamily:"serif",fontStyle:"normal",lineHeight:1.2,color:"black",opacity:1},parent:s,font:i,embedFont:r.embedFont,debug:r.debug,graphemeImages:r.graphemeImages});o.next(),s.calculateLayout(r.width,r.height,e.DIRECTION_LTR);let n=o.next([0,0]).value;return St({width:r.width,height:r.height,content:n})}export{Dt as default,te as init};
|
|
1
|
+
var it=Object.defineProperty,Ut=Object.defineProperties,zt=Object.getOwnPropertyDescriptor,Xt=Object.getOwnPropertyDescriptors,Ht=Object.getOwnPropertyNames,Tt=Object.getOwnPropertySymbols;var Lt=Object.prototype.hasOwnProperty,Vt=Object.prototype.propertyIsEnumerable;var It=(t,r,e)=>r in t?it(t,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):t[r]=e,Z=(t,r)=>{for(var e in r||(r={}))Lt.call(r,e)&&It(t,e,r[e]);if(Tt)for(var e of Tt(r))Vt.call(r,e)&&It(t,e,r[e]);return t},wt=(t,r)=>Ut(t,Xt(r)),Jt=t=>it(t,"__esModule",{value:!0});var At=(t,r)=>()=>(t&&(r=t(t=0)),r);var jt=(t,r)=>{for(var e in r)it(t,e,{get:r[e],enumerable:!0})},Kt=(t,r,e,i)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of Ht(r))!Lt.call(t,s)&&(e||s!=="default")&&it(t,s,{get:()=>r[s],enumerable:!(i=zt(r,s))||i.enumerable});return t};var qt=(t=>(r,e)=>t&&t.get(r)||(e=Kt(Jt({}),r,1),t&&t.set(r,e),e))(typeof WeakMap!="undefined"?new WeakMap:0);var u=At(()=>{});var Ct={};jt(Ct,{default:()=>Qt});import*as Zt from"yoga-layout-prebuilt";var Qt,Ft=At(()=>{u();Qt=Zt});u();u();u();var at;{let t=(Ft(),qt(Ct));t.default?at=t.default:at=t}function te(t){at=t}function Y(){return at}u();u();function ut(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 Q(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 v(t,r,e){let i=r[t];return typeof i=="undefined"?e:i}u();u();var Nt={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 ee=new Set(["color","font","fontFamily","fontSize","fontStyle","fontWeight","lineHeight","textAlign","textTransform","whiteSpace","letterSpacing","transform","wordBreak","textShadowOffset","textShadowColor","textShadowRadius","opacity"]);function ct(t){let r={};for(let e in t)ee.has(e)&&(r[e]=t[e]);return r}u();import{getPropertyName as kt,getStylesForProperty as re}from"css-to-react-native";import Gt from"parse-css-dimension";import{parseElementStyle as ne}from"css-background-parser";var oe=new Set(["flex","flexGrow","flexShrink","flexBasis","fontWeight","lineHeight","opacity","scale","scaleX","scaleY"]),vt=[1,0,0,1,0,0];function ie(t,r){return typeof r=="number"?oe.has(t)?String(r):r+"px":r}function Wt(t,r){if(typeof t=="number")return t;try{let e=new Gt(t);if(e.type==="length")switch(e.unit){case"em":return e.value*r;case"rem":return e.value*16;default:return e.value}else if(e.type==="angle")switch(e.unit){case"deg":return e.value;case"rad":return e.value*180/Math.PI;default:return e.value}}catch{}}function st(t,r){let e=[];for(let o in t){let n=kt(o);e.push([n,ie(n,t[o])])}let i=e.reduce((o,n)=>{let a=kt(n[0]),f=n[1];return Object.assign(o,re(a,f,!0))},{});if(i.backgroundImage){let{backgrounds:o}=ne(i);i.backgroundImage=o}let s=i.fontSize||r.fontSize;if(typeof s=="string")try{let o=new Gt(s);switch(o.unit){case"em":s=o.value*r.fontSize;break;case"rem":s=o.value*16;break}}catch{s=16}typeof i.fontSize!="undefined"&&(i.fontSize=s);for(let o in i){let n=i[o];if(typeof n=="string"){let a=Wt(n,s);typeof a!="undefined"&&(i[o]=a),n=i[o]}if(o==="opacity"&&(n=i[o]=n*r.opacity),o==="transform"){let a=[...vt],f=n;for(let m of f){let y=Object.keys(m)[0],p=m[y],d=typeof p=="string"?Wt(p,s):p,g=[...vt];switch(y){case"translateX":g[4]=d;break;case"translateY":g[5]=d;break;case"scaleX":g[0]=d;break;case"scaleY":g[3]=d;break;case"rotate":let c=d*Math.PI/180,E=Math.cos(c),T=Math.sin(c);g[0]=E,g[1]=T,g[2]=-T,g[3]=E;break;case"skewX":g[2]=Math.tan(d*Math.PI/180);break;case"skewY":g[1]=Math.tan(d*Math.PI/180);break}a=Q(g,a)}i.transform=a}}return i}function mt(t,r,e,i,s){let o=Y(),n=Z(Z(Z({},e),st(Nt[r],e)),st(i,e));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 t.setDisplay(v(n.display,{flex:o.DISPLAY_FLEX,none:o.DISPLAY_NONE},o.DISPLAY_FLEX)),t.setAlignContent(v(n.alignContent,{stretch:o.ALIGN_STRETCH,center:o.ALIGN_CENTER,"flex-start":o.ALIGN_FLEX_START,"flex-end":o.ALIGN_FLEX_END,"space-between":o.ALIGN_SPACE_BETWEEN,"space-around":o.ALIGN_SPACE_AROUND,baseline:o.ALIGN_BASELINE,normal:o.ALIGN_AUTO},o.ALIGN_AUTO)),t.setAlignItems(v(n.alignItems,{stretch:o.ALIGN_STRETCH,center:o.ALIGN_CENTER,"flex-start":o.ALIGN_FLEX_START,"flex-end":o.ALIGN_FLEX_END,baseline:o.ALIGN_BASELINE,normal:o.ALIGN_AUTO},o.ALIGN_FLEX_START)),t.setAlignSelf(v(n.alignSelf,{stretch:o.ALIGN_STRETCH,center:o.ALIGN_CENTER,"flex-start":o.ALIGN_FLEX_START,"flex-end":o.ALIGN_FLEX_END,baseline:o.ALIGN_BASELINE,normal:o.ALIGN_AUTO},o.ALIGN_AUTO)),t.setJustifyContent(v(n.justifyContent,{center:o.JUSTIFY_CENTER,"flex-start":o.JUSTIFY_FLEX_START,"flex-end":o.JUSTIFY_FLEX_END,"space-between":o.JUSTIFY_SPACE_BETWEEN,"space-around":o.JUSTIFY_SPACE_AROUND},o.JUSTIFY_FLEX_START)),t.setFlexDirection(v(n.flexDirection,{row:o.FLEX_DIRECTION_ROW,column:o.FLEX_DIRECTION_COLUMN,"row-reverse":o.FLEX_DIRECTION_ROW_REVERSE,"column-reverse":o.FLEX_DIRECTION_COLUMN_REVERSE},o.FLEX_DIRECTION_ROW)),t.setFlexWrap(v(n.flexWrap,{wrap:o.WRAP_WRAP,nowrap:o.WRAP_NO_WRAP,"wrap-reverse":o.WRAP_WRAP_REVERSE},o.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"?1: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(v(n.overflow,{visible:o.OVERFLOW_VISIBLE,hidden:o.OVERFLOW_HIDDEN},o.OVERFLOW_VISIBLE)),t.setMargin(o.EDGE_TOP,n.marginTop||0),t.setMargin(o.EDGE_BOTTOM,n.marginBottom||0),t.setMargin(o.EDGE_LEFT,n.marginLeft||0),t.setMargin(o.EDGE_RIGHT,n.marginRight||0),t.setBorder(o.EDGE_TOP,n.borderWidth||0),t.setBorder(o.EDGE_BOTTOM,n.borderWidth||0),t.setBorder(o.EDGE_LEFT,n.borderWidth||0),t.setBorder(o.EDGE_RIGHT,n.borderWidth||0),t.setPadding(o.EDGE_TOP,n.paddingTop||0),t.setPadding(o.EDGE_BOTTOM,n.paddingBottom||0),t.setPadding(o.EDGE_LEFT,n.paddingLeft||0),t.setPadding(o.EDGE_RIGHT,n.paddingRight||0),t.setPositionType(v(n.position,{absolute:o.POSITION_TYPE_ABSOLUTE,relative:o.POSITION_TYPE_RELATIVE},o.POSITION_TYPE_RELATIVE)),typeof n.top!="undefined"&&t.setPosition(o.EDGE_TOP,n.top),typeof n.bottom!="undefined"&&t.setPosition(o.EDGE_BOTTOM,n.bottom),typeof n.left!="undefined"&&t.setPosition(o.EDGE_LEFT,n.left),typeof n.right!="undefined"&&t.setPosition(o.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,ct(n)]}u();import{LineBreaker as ae}from"css-line-break";import{splitGraphemes as se}from"text-segmentation";u();u();function et({left:t,top:r,width:e,height:i},s,o){let n;if(o)n=s;else{let a=t+e/2,f=r+i/2;n=Q([1,0,0,1,a,f],Q(s,[1,0,0,1,-a,-f])),s.__parent&&(n=Q(s.__parent,n)),s.splice(0,6,...n)}return`matrix(${n.map(a=>a.toFixed(2)).join(",")})`}function Pt({left:t,top:r,width:e,height:i,isInheritingTransform:s},o){let n="",a=1;return o.transform&&(n=et({left:t,top:r,width:e,height:i},o.transform,s)),o.opacity&&(a=+o.opacity),{matrix:n,opacity:a}}function pt({id:t,content:r,filter:e,left:i,top:s,width:o,height:n,matrix:a,opacity:f,image:m,debug:y},p){let d="";return y&&(d=`<rect x="${i}" y="${s}" width="${o}" height="0.5" fill="transparent" stroke="#575eff" stroke-width="1" ${a?`transform="${a}"`:""}></rect>`),m?`${e?`${e}<g filter="url(#satori_s-${t})">`:""}<image href="${m}" x="${i}" y="${s}" width="${o}" height="${n}" ${a?`transform="${a}"`:""} ${f!==1?`opacity="${f}"`:""}></image>${e?"</g>":""}${d}`:`${e?`${e}<g filter="url(#satori_s-${t})">`:""}<text x="${i}" y="${s}" width="${o}" height="${n}" fill="${p.color}" font-weight="${p.fontWeight}" font-style="${p.fontStyle}" font-size="${p.fontSize}" font-family="${p.fontFamily}" ${p.letterSpacing?`letter-spacing="${p.letterSpacing}"`:""} ${a?`transform="${a}"`:""} ${f!==1?`opacity="${f}"`:""}>${r}</text>${e?"</g>":""}${d}`}u();function K({id:t,width:r,height:e},i){if(!i.shadowColor||!i.shadowOffset||typeof i.shadowRadius=="undefined")return"";let s=i.shadowRadius*i.shadowRadius/4,o=Math.min(i.shadowOffset.width-s,0),n=Math.max(i.shadowOffset.width+s+r,r),a=Math.min(i.shadowOffset.height-s,0),f=Math.max(i.shadowOffset.height+s+e,e);return`<defs><filter id="satori_s-${t}" x="${o/r*100}%" y="${a/e*100}%" width="${(n-o)/r*100}%" height="${(f-a)/e*100}%"><feDropShadow dx="${i.shadowOffset.width}" dy="${i.shadowOffset.height}" stdDeviation="${i.shadowRadius/2}" flood-color="${i.shadowColor}" flood-opacity="1"/></filter></defs>`}var rt=void 0,gt=typeof Intl!="undefined"&&"Segmenter"in Intl,fe=gt?new Intl.Segmenter(rt,{granularity:"word"}):null,le=gt?new Intl.Segmenter(rt,{granularity:"grapheme"}):null,ue=[32,160,4961,65792,65793,4153,4241],ce=t=>{let r=ae(t,{lineBreak:"strict",wordBreak:"normal"}),e=[],i;for(;!(i=r.next()).done;)if(i.value){let s=i.value.slice(),o=[].map.call(s,a=>a.codePointAt(0)),n="";o.forEach(a=>{ue.includes(a)?(n.length&&e.push(n),e.push(String.fromCodePoint(a)),n=""):n+=String.fromCodePoint(a)}),n.length&&e.push(n)}return e};function dt(t,r){return gt?r==="word"?[...fe.segment(t)].map(e=>e.segment):[...le.segment(t)].map(e=>e.segment):r==="word"?ce(t):se(t)}function*ht(t,r){let e=Y(),{parentStyle:i,parent:s,font:o,id:n,isInheritingTransform:a,debug:f,embedFont:m,graphemeImages:y}=r;i.textTransform==="uppercase"?t=t.toLocaleUpperCase(rt):i.textTransform==="lowercase"?t=t.toLocaleLowerCase(rt):i.textTransform==="capitalize"&&(t=dt(t,"word").map(x=>dt(x,"grapheme").map((L,G)=>G===0?L.toLocaleUpperCase(rt):L).join("")).join(""));let p=v(i.wordBreak,{normal:"word","break-all":"grapheme","break-word":"grapheme","keep-all":"word"},"word"),d=dt(t,p),g=e.Node.create();g.setAlignItems(e.ALIGN_BASELINE),i.textAlign==="left"?g.setJustifyContent(e.JUSTIFY_FLEX_START):i.textAlign==="center"?g.setJustifyContent(e.JUSTIFY_CENTER):i.textAlign==="right"?g.setJustifyContent(e.JUSTIFY_FLEX_END):i.textAlign==="justify"&&g.setJustifyContent(e.JUSTIFY_SPACE_BETWEEN),s.insertChild(g,s.getChildCount());let c=o.getFont(i),E=c.ascender/c.unitsPerEm*i.fontSize,T=-(c.descender/c.unitsPerEm)*i.fontSize,h=(E+T)*1.2,{textAlign:$}=i,C=[],M=[],O=[];g.setMeasureFunc(x=>{let L=[],G="",P=0,J="",A=0,q=0,tt=-1;C=[],M=[0];for(let B=0;B<d.length;B++){let D=d[B];if([" ",`
|
|
2
|
+
`," ","\u3000"].includes(D))G+=D,P=o.measure(c,G,i),O[B]=null;else{let j=y&&y[D]?i.fontSize:o.measure(c,D,i);A||(G="",P=0);let _t=P||",.!?:-@)>]}%#".indexOf(D[0])<0,Rt=!A||!!P;_t&&A+P+j>x?(C.push(A),L.push(J),J=D,A=j,M.push(1),tt=-1):(J+=G+D,A+=P+j,Rt&&M[M.length-1]++),G="",P=0,Rt&&tt++,q=Math.max(q,A),O[B]={y:L.length*h,x:A-j,width:j,line:L.length,lineIndex:tt}}}return A&&(L.push(J),C.push(A)),L.length>1&&(q=x),{width:q,height:L.length*h}});let[U,z]=yield,X="";i.position==="absolute"&&g.calculateLayout();let{left:H,top:N,width:F,height:W}=g.getComputedLayout(),w=U+H,k=z+N,{matrix:V,opacity:l}=Pt({left:H,top:N,width:F,height:W,isInheritingTransform:a},i),b="";i.textShadowOffset&&(b=K({width:F,height:W,id:n},{shadowColor:i.textShadowColor,shadowOffset:i.textShadowOffset,shadowRadius:i.textShadowRadius}));let S="";for(let x=0;x<d.length;x++){if(!O[x])continue;let L=d[x],G=null,P=null,J=O[x].y,A=O[x].x,q=O[x].width,tt=h,B=F-C[O[x].line];if($==="right"||$==="end")A+=B;else if($==="center")A+=B/2;else if($==="justify"){let D=O[x].line;if(D<C.length-1){let j=M[D];A+=(j>1?B/(j-1):0)*O[x].lineIndex}}y&&y[L]?P=y[L]:m?G=o.getSVG(c,L,wt(Z({},i),{left:w+A,top:k+J,letterSpacing:i.letterSpacing})):J+=E,G?S+=G+" ":X+=pt({content:L,filter:b,id:n,left:w+A,top:k+J,width:q,height:tt,matrix:V,opacity:l,image:P,debug:f},i)}if(S){let x="";f&&(x=`<rect x="${w}" y="${k}" width="${F}" height="${W}" fill="transparent" stroke="#575eff" stroke-width="1" ${V?`transform="${V}"`:""}></rect>`),X+=`${b?`${b}<g filter="url(#satori_s-${n})">`:""}<path fill="${i.color}" ${V?`transform="${V}"`:""} ${l!==1?`opacity="${l}"`:""} d="${S}"></path>${b?"</g>":""}${x}`}return X}u();u();import me from"parse-css-dimension";u();var bt=bt||{};bt.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 i(){var l=s();return r.length>0&&e("Invalid input not EOF"),l}function s(){return $(o)}function o(){return n("linear-gradient",t.linearGradient,f)||n("repeating-linear-gradient",t.repeatingLinearGradient,f)||n("radial-gradient",t.radialGradient,p)||n("repeating-radial-gradient",t.repeatingRadialGradient,p)}function n(l,b,S){return a(b,function(x){var L=S();return L&&(k(t.comma)||e("Missing comma before color stops")),{type:l,orientation:L,colorStops:$(C)}})}function a(l,b){var S=k(l);if(S){k(t.startCall)||e("Missing (");var x=b(S);return k(t.endCall)||e("Missing )"),x}}function f(){return m()||y()}function m(){return w("directional",t.sideOrCorner,1)}function y(){return w("angular",t.angleValue,1)}function p(){var l,b=d(),S;return b&&(l=[],l.push(b),S=r,k(t.comma)&&(b=d(),b?l.push(b):r=S)),l}function d(){var l=g()||c();if(l)l.at=T();else{var b=E();if(b){l=b;var S=T();S&&(l.at=S)}else{var x=I();x&&(l={type:"default-radial",at:x})}}return l}function g(){var l=w("shape",/^(circle)/i,0);return l&&(l.style=W()||E()),l}function c(){var l=w("shape",/^(ellipse)/i,0);return l&&(l.style=N()||E()),l}function E(){return w("extent-keyword",t.extentKeywords,1)}function T(){if(w("position",/^at/,0)){var l=I();return l||e("Missing positioning value"),l}}function I(){var l=h();if(l.x||l.y)return{type:"position",value:l}}function h(){return{x:N(),y:N()}}function $(l){var b=l(),S=[];if(b)for(S.push(b);k(t.comma);)b=l(),b?S.push(b):e("One extra comma");return S}function C(){var l=M();return l||e("Expected color definition"),l.length=N(),l}function M(){return U()||X()||z()||O()}function O(){return w("literal",t.literalColor,0)}function U(){return w("hex",t.hexColor,1)}function z(){return a(t.rgbColor,function(){return{type:"rgb",value:$(H)}})}function X(){return a(t.rgbaColor,function(){return{type:"rgba",value:$(H)}})}function H(){return k(t.number)[1]}function N(){return w("%",t.percentageValue,1)||F()||W()}function F(){return w("position-keyword",t.positionKeywords,1)}function W(){return w("px",t.pixelValue,1)||w("em",t.emValue,1)}function w(l,b,S){var x=k(b);if(x)return{type:l,value:x[S]}}function k(l){var b,S;return S=/^[\n\r\t\s]+/.exec(r),S&&V(S[0].length),b=l.exec(r),b&&V(b[0].length),b}function V(l){r=r.substr(l)}return function(l){return r=l.toString(),i()}}();var Dt=bt;function pe(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 de(t,r){return typeof t=="string"&&t.endsWith("%")?r*parseFloat(t)/100:+t}function Mt(t,{x:r,y:e,defaultX:i,defaultY:s}){return(t?t.split(" ").map(o=>{try{let n=new me(o);return n.type==="length"?n.value:n.value+n.unit}catch{return null}}).filter(o=>o!==null):[i,s]).map((o,n)=>de(o,[r,e][n]))}function yt({id:t,width:r,height:e},{image:i,size:s,position:o}){let n=Mt(s,{x:r,y:e,defaultX:r,defaultY:e}),a=Mt(o,{x:r,y:e,defaultX:0,defaultY:0});if(i.startsWith("linear-gradient(")){let f=Dt.parse(i)[0],m,y,p,d;if(f.orientation.type==="directional")[m,y,p,d]={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,$=Math.cos(h),C=Math.sin(h);m=0,y=0,p=$,d=C,p<0&&(m-=p,p=0),d<0&&(y-=d,d=0)}let g=r,c=[];for(let h of f.colorStops){let $=pe(h);if(!c.length&&(c.push({offset:0,color:$}),typeof h.length=="undefined"||h.length.value==="0"))continue;let C=typeof h.length=="undefined"?void 0:h.length.type==="%"?h.length.value/100:h.length.value/g;c.push({offset:C,color:$})}c.length||c.push({offset:0,color:"transparent"});let E=c[c.length-1];E.offset!==1&&(typeof E.offset=="undefined"?E.offset=1:c.push({offset:1,color:E.color}));let T=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[T].offset)/(I-T)*(h-T)+c[T].offset}else T=h;return[`satori_bi${t}`,`<linearGradient id="satori_bi${t}" x1="${m}" y1="${y}" x2="${p}" y2="${d}">${c.map(h=>`<stop offset="${h.offset*100}%" stop-color="${h.color}"/>`).join("")}</linearGradient>`]}if(i.startsWith("url(")){let f=i.slice(4,-1);return[`satori_bi${t}`,`<pattern id="satori_bi${t}" 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 ft(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 nt({left:t,top:r,width:e,height:i},s){let{borderTopLeftRadius:o,borderTopRightRadius:n,borderBottomLeftRadius:a,borderBottomRightRadius:f}=s;return o=Math.min(o||0,e,i),n=Math.min(n||0,e,i),a=Math.min(a||0,e,i),f=Math.min(f||0,e,i),!o&&!n&&!a&&!f?"":([o,n]=ft(o,n,e),[o,a]=ft(o,a,i),[n,f]=ft(n,f,i),[a,f]=ft(a,f,e),`M${t+o},${r} h${e-o-n} a${n},${n} 0 0 1 ${n},${n} v${i-n-f} a${f},${f} 0 0 1 ${-f},${f} h${f+a-e} a${a},${a} 0 0 1 ${-a},${-a} v${a+o-i} a${o},${o} 0 0 1 ${o},${-o}`)}function xt({id:t,left:r,top:e,width:i,height:s,isInheritingTransform:o,debug:n},a){if(a.display==="none")return"";let f="rect",m="transparent",y=0,p="",d="",g=[],c=1,E="";if(a.backgroundColor&&g.push(a.backgroundColor),a.borderWidth&&(y=a.borderWidth,m=a.borderColor),a.opacity&&(c=+a.opacity),a.transform&&(p=et({left:r,top:e,width:i,height:s},a.transform,o)),a.backgroundImage){let h=a.backgroundImage.map(($,C)=>yt({id:t+"_"+C,width:i,height:s},$)).filter(Boolean);for(let $ of h)d+=$[1],g.push(`url(#${$[0]})`)}let T=nt({left:r,top:e,width:i,height:s},a);T&&(f="path");let I=K({width:i,height:s,id:t},a);return g.length||g.push("transparent"),n&&(E=`<rect x="${r}" y="${e}" width="${i}" height="${s}" fill="transparent" stroke="#ff5757" stroke-width="1" ${p?`transform="${p}"`:""}></rect>`),`${d?`<defs>${d}</defs>`:""}${I?`${I}<g filter="url(#satori_s-${t})">`:""}${c!==1?`<g opacity="${c}">`:""}${g.map((h,$)=>h==="transparent"&&!($===g.length-1&&y)?"":`<${f} x="${r}" y="${e}" width="${i}" height="${s}" fill="${h}" ${$===g.length-1&&y?`stroke="${m}" stroke-width="${y}"`:""} ${T?`d="${T}"`:""} ${p?`transform="${p}"`:""}></${f}>`).join("")}${c!==1?"</g>":""}${I?"</g>":""}${E}`}u();function $t({id:t,left:r,top:e,width:i,height:s,src:o,debug:n},a){if(a.display==="none")return"";let f="",m=1,y=a.objectFit==="contain"?"xMidYMid":a.objectFit==="cover"?"xMidYMid slice":"none",p=nt({left:r,top:e,width:i,height:s},a);p&&(f=`<clipPath id="satori_c-${t}"><path x="${r}" y="${e}" width="${i}" height="${s}" d="${p}"></path></clipPath>`),a.opacity&&(m=+a.opacity);let d=K({width:i,height:s,id:t},a);return`${d}${d?`<g filter="url(#satori_s-${t})">`:""}${f}<image href="${o}" x="${r}" y="${e}" width="${i}" height="${s}" preserveAspectRatio="${y}" ${f?`clip-path="url(#satori_c-${t})"`:""} ${m!==1?`opacity="${m}"`:""}></image>${d?"</g>":""}`}function*ot(t,r){let e=Y(),{id:i,inheritedStyle:s,parent:o,font:n,debug:a,embedFont:f=!0,graphemeImages:m}=r;if(t===null||typeof t=="undefined")return yield,"";if(!ut(t)||typeof t.type=="function"){let F;if(!ut(t))F=ht(String(t),r);else{if(Ot(t.type))throw new Error("Class component is not supported.");F=ot(t.type(t.props),r)}F.next();let W=yield;return F.next(W).value}let{type:y,props:p}=t,{style:d,children:g}=p,c=e.Node.create();o.insertChild(c,o.getChildCount());let[E,T]=mt(c,y,s,d,p),I=E.transform===s.transform;I||(E.transform.__parent=s.transform);let h=typeof g=="undefined"?[]:[].concat(g),$=[],C=0;for(let F of h){let W=ot(F,{id:i*h.length+ ++C,parentStyle:E,inheritedStyle:T,isInheritingTransform:!0,parent:c,font:n,embedFont:f,debug:a,graphemeImages:m});W.next(),$.push(W)}let[M,O]=yield;E.position==="absolute"&&c.calculateLayout();let{left:U,top:z,width:X,height:H}=c.getComputedLayout();U+=M,z+=O;let N="";y==="img"?N=$t({id:i,left:U,top:z,width:X,height:H,src:p.src,isInheritingTransform:I,debug:a},E):N=xt({id:i,left:U,top:z,width:X,height:H,isInheritingTransform:I,debug:a},E);for(let F of $)N+=F.next([U,z]).value;return N}u();import Bt from"@shuding/opentype.js";var lt=class{constructor(r){this.fonts=new Map;for(let e of r){let i=e.data,s="buffer"in i?Bt.parse(i.buffer.slice(i.byteOffset,i.byteOffset+i.byteLength)):Bt.parse(i);this.defaultFont||(this.defaultFont=s),this.fonts.has(e.name)||this.fonts.set(e.name,[]),this.fonts.get(e.name).push([s,e.weight,e.style])}}get({name:r,weight:e,style:i}){if(!this.fonts.has(r))return this.defaultFont;e==="normal"&&(e=400),e==="bold"&&(e=700);let s=[...this.fonts.get(r)];return s.sort(([o,n,a],[f,m,y])=>{if(n!==m)return n?!m||n===e?-1:m===e?1:e===400&&n===500||e===500&&n===400?-1:e===400&&m===500||e===500&&m===400?1:e<400?n<e&&m<e?m-n:n<e?-1:m<e?1:n-m:e<n&&e<m?n-m:e<n?-1:e<m?1:m-n:1;if(a!==y){if(a===i)return-1;if(y===i)return 1}return-1}),s[0][0]}getFont({fontFamily:r,fontWeight:e=400,fontStyle:i="normal"}){return this.get({name:r,weight:e,style:i})}measure(r,e,{fontSize:i,letterSpacing:s=0}){return r.getAdvanceWidth(e,i,{letterSpacing:s/i})}getSVG(r,e,{fontSize:i,top:s,left:o,letterSpacing:n=0}){return s+=r.ascender/r.unitsPerEm*i,r.getPath(e,o,s,i,{letterSpacing:n/i}).toPathData(1)}};u();function Et({width:t,height:r,content:e},i){return`<svg width="${t}" height="${r}" viewBox="0 0 ${t} ${r}" xmlns="http://www.w3.org/2000/svg">${e}</svg>`}var St=new WeakMap;function Yt(t,r){let e=Y();if(!e)throw new Error("Satori is not initialized.");let i;St.has(r.fonts)?i=St.get(r.fonts):St.set(r.fonts,i=new lt(r.fonts));let s=e.Node.create();s.setWidth(r.width),s.setHeight(r.height),s.setFlexDirection(e.FLEX_DIRECTION_ROW),s.setFlexWrap(e.WRAP_WRAP),s.setAlignContent(e.ALIGN_AUTO),s.setAlignItems(e.ALIGN_FLEX_START),s.setJustifyContent(e.JUSTIFY_FLEX_START);let o=ot(t,{id:1,parentStyle:{},inheritedStyle:{fontSize:16,fontWeight:"normal",fontFamily:"serif",fontStyle:"normal",lineHeight:1.2,color:"black",opacity:1},parent:s,font:i,embedFont:r.embedFont,debug:r.debug,graphemeImages:r.graphemeImages});o.next(),s.calculateLayout(r.width,r.height,e.DIRECTION_LTR);let n=o.next([0,0]).value;return Et({width:r.width,height:r.height,content:n})}export{Yt as default,te as init};
|
|
3
3
|
//# sourceMappingURL=index.js.map
|