UNPKG

@stencil/react-output-target

Version:

React output target for @stencil/core components.

6 lines (5 loc) 11.7 kB
"use strict";var _=Object.create;var C=Object.defineProperty;var F=Object.getOwnPropertyDescriptor;var N=Object.getOwnPropertyNames;var W=Object.getPrototypeOf,D=Object.prototype.hasOwnProperty;var q=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of N(t))!D.call(e,o)&&o!==r&&C(e,o,{get:()=>t[o],enumerable:!(n=F(t,o))||n.enumerable});return e};var T=(e,t,r)=>(r=e!=null?_(W(e)):{},q(t||!e||!e.__esModule?C(r,"default",{value:e,enumerable:!0}):r,e));Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("react"),v=require("./create-component-DUNPnWI2.cjs");var G={animationIterationCount:1,aspectRatio:1,borderImageOutset:1,borderImageSlice:1,borderImageWidth:1,boxFlex:1,boxFlexGroup:1,boxOrdinalGroup:1,columnCount:1,columns:1,flex:1,flexGrow:1,flexPositive:1,flexShrink:1,flexNegative:1,flexOrder:1,gridRow:1,gridRowEnd:1,gridRowSpan:1,gridRowStart:1,gridColumn:1,gridColumnEnd:1,gridColumnSpan:1,gridColumnStart:1,msGridRow:1,msGridRowSpan:1,msGridColumn:1,msGridColumnSpan:1,fontWeight:1,lineHeight:1,opacity:1,order:1,orphans:1,scale:1,tabSize:1,widows:1,zIndex:1,zoom:1,WebkitLineClamp:1,fillOpacity:1,floodOpacity:1,stopOpacity:1,strokeDasharray:1,strokeDashoffset:1,strokeMiterlimit:1,strokeOpacity:1,strokeWidth:1},E="px",B=e=>typeof e=="number"||typeof e=="string";function V(e){return e.replace(/[A-Z]/g,t=>`-${t.toLowerCase()}`)}function X(e,t,r=E){if(typeof t!="string"&&typeof t!="number")throw new Error("Invalid input: value of 'cssProperties' must be string or number.");const n=G[e]===1;if(typeof t=="string"||t===0||n)return`${t}`;const o=(typeof r=="string"?r:r[e])||E;return`${t}${o}`}function Y(e,t){if(typeof e!="object"||e===null)throw new TypeError(`[stringifyStyleDeclaration]: Expected 'styleDeclaration' to be a non-null object, but received ${e} (type:${typeof e}).`);const r=t!=null&&t.important?"!important":"";return Object.entries(e).filter(([n,o])=>B(o)).map(([n,o])=>`${V(n)}:${X(n,o,t==null?void 0:t.unit)}${r};`).join("")}function K(e,t=!1){if(typeof e!="object"||e===null)throw new TypeError(`[stringifyCSSProperties]: Expected 'cssProperties' to be a non-null object, but received ${e} (type:${typeof e}).`);return Y(e,typeof t=="boolean"?{important:t}:t)}const Z={acceptCharset:"accept-charset",accessKey:"accesskey",allowFullScreen:"allowfullscreen",autoCapitalize:"autocapitalize",autoComplete:"autocomplete",autoCorrect:"autocorrect",autoFocus:"autofocus",autoPlay:"autoplay",autoSave:"autosave",cellPadding:"cellpadding",cellSpacing:"cellspacing",charSet:"charset",className:"class",classID:"classid",colSpan:"colspan",contentEditable:"contenteditable",contextMenu:"contextmenu",controlsList:"controlslist",crossOrigin:"crossorigin",dangerouslySetInnerHTML:"dangerouslysetinnerhtml",dateTime:"datetime",defaultChecked:"defaultchecked",defaultValue:"defaultvalue",disablePictureInPicture:"disablepictureinpicture",disableRemotePlayback:"disableremoteplayback",encType:"enctype",enterKeyHint:"enterkeyhint",fetchPriority:"fetchpriority",htmlFor:"for",formMethod:"formmethod",formAction:"formaction",formEncType:"formenctype",formNoValidate:"formnovalidate",formTarget:"formtarget",frameBorder:"frameborder",hrefLang:"hreflang",httpEquiv:"http-equiv",imageSizes:"imagesizes",imageSrcSet:"imagesrcset",inputMode:"inputmode",itemID:"itemid",itemProp:"itemprop",itemRef:"itemref",itemScope:"itemscope",itemType:"itemtype",keyParams:"keyparams",keyType:"keytype",marginWidth:"marginwidth",marginHeight:"marginheight",maxLength:"maxlength",mediaGroup:"mediagroup",noModule:"nomodule",noValidate:"novalidate",playsInline:"playsinline",radioGroup:"radiogroup",readOnly:"readonly",referrerPolicy:"referrerpolicy",rowSpan:"rowspan",spellCheck:"spellcheck",srcDoc:"srcdoc",srcLang:"srclang",srcSet:"srcset",tabIndex:"tabindex",useMap:"usemap",accentHeight:"accent-height",alignmentBaseline:"alignment-baseline",arabicForm:"arabic-form",attributeName:"attributename",attributeType:"attributetype",autoReverse:"autoreverse",baseFrequency:"basefrequency",baselineShift:"baseline-shift",baseProfile:"baseprofile",calcMode:"calcmode",capHeight:"cap-height",clipPath:"clip-path",clipPathUnits:"clippathunits",clipRule:"clip-rule",colorInterpolation:"color-interpolation",colorInterpolationFilters:"color-interpolation-filters",colorProfile:"color-profile",colorRendering:"color-rendering",contentScriptType:"contentscripttype",contentStyleType:"contentstyletype",diffuseConstant:"diffuseconstant",dominantBaseline:"dominant-baseline",enableBackground:"enable-background",externalResourcesRequired:"externalresourcesrequired",fillOpacity:"fill-opacity",fillRule:"fill-rule",filterRes:"filterres",filterUnits:"filterunits",floodOpacity:"flood-opacity",floodColor:"flood-color",fontFamily:"font-family",fontSize:"font-size",fontSizeAdjust:"font-size-adjust",fontStretch:"font-stretch",fontStyle:"font-style",fontVariant:"font-variant",fontWeight:"font-weight",glyphName:"glyph-name",glyphOrientationHorizontal:"glyph-orientation-horizontal",glyphOrientationVertical:"glyph-orientation-vertical",gradientTransform:"gradienttransform",gradientUnits:"gradientunits",horizAdvX:"horiz-adv-x",horizOriginX:"horiz-origin-x",imageRendering:"image-rendering",kernelMatrix:"kernelmatrix",kernelUnitLength:"kernelunitlength",keyPoints:"keypoints",keySplines:"keysplines",keyTimes:"keytimes",lengthAdjust:"lengthadjust",letterSpacing:"letter-spacing",lightingColor:"lighting-color",limitingConeAngle:"limitingconeangle",markerEnd:"marker-end",markerHeight:"markerheight",markerMid:"marker-mid",markerStart:"marker-start",markerUnits:"markerunits",markerWidth:"markerwidth",maskContentUnits:"maskcontentunits",maskUnits:"maskunits",numOctaves:"numoctaves",overlinePosition:"overline-position",overlineThickness:"overline-thickness",paintOrder:"paint-order",panose1:"panose-1",pathLength:"pathlength",patternContentUnits:"patterncontentunits",patternTransform:"patterntransform",patternUnits:"patternunits",pointerEvents:"pointer-events",pointsAtX:"pointsatx",pointsAtY:"pointsaty",pointsAtZ:"pointsatz",preserveAlpha:"preservealpha",preserveAspectRatio:"preserveaspectratio",primitiveUnits:"primitiveunits",refX:"refx",refY:"refy",renderingIntent:"rendering-intent",repeatCount:"repeatcount",repeatDur:"repeatdur",requiredExtensions:"requiredextensions",requiredFeatures:"requiredfeatures",shapeRendering:"shape-rendering",slot:"slot",specularConstant:"specularconstant",specularExponent:"specularexponent",spreadMethod:"spreadmethod",startOffset:"startoffset",stdDeviation:"stddeviation",stitchTiles:"stitchtiles",stopColor:"stop-color",stopOpacity:"stop-opacity",strikethroughPosition:"strikethrough-position",strikethroughThickness:"strikethrough-thickness",strokeDasharray:"stroke-dasharray",strokeDashoffset:"stroke-dashoffset",strokeLinecap:"stroke-linecap",strokeLinejoin:"stroke-linejoin",strokeMiterlimit:"stroke-miterlimit",strokeWidth:"stroke-width",strokeOpacity:"stroke-opacity",suppressContentEditableWarning:"suppresscontenteditablewarning",suppressHydrationWarning:"suppresshydrationwarning",surfaceScale:"surfacescale",systemLanguage:"systemlanguage",tableValues:"tablevalues",targetX:"targetx",targetY:"targety",textAnchor:"text-anchor",textDecoration:"text-decoration",textLength:"textlength",textRendering:"text-rendering",transformOrigin:"transform-origin",underlinePosition:"underline-position",underlineThickness:"underline-thickness",unicodeBidi:"unicode-bidi",unicodeRange:"unicode-range",unitsPerEm:"units-per-em",vectorEffect:"vector-effect",vertAdvY:"vert-adv-y",vertOriginX:"vert-origin-x",vertOriginY:"vert-origin-y",wordSpacing:"word-spacing",writingMode:"writing-mode",xChannelSelector:"xchannelselector",xHeight:"x-height",xlinkActuate:"xlink:actuate",xlinkArcrole:"xlink:arcrole",xlinkHref:"xlink:href",xlinkRole:"xlink:role",xlinkShow:"xlink:show",xlinkTitle:"xlink:title",xlinkType:"xlink:type",xmlBase:"xml:base",xmlLang:"xml:lang",xmlnsXlink:"xmlns:xlink",yChannelSelector:"ychannelselector",zoomAndPan:"zoomandpan"},J="[react-output-target]",u=e=>typeof e=="string"||typeof e=="number"||typeof e=="boolean",y=e=>e==null,z=e=>Array.isArray(e),Q=e=>!!e&&/^\s*class\s+/.test(e.toString()),ee=e=>!!e&&typeof e=="object"&&"_payload"in e,te=e=>async({children:t,...r}={})=>{if(!("process"in globalThis)||typeof window<"u")throw new Error("`createComponentForServerSideRendering` can only be run on the server");let n="";for(const[a,i]of Object.entries(r)){if(typeof i=="boolean"&&i===!1)continue;let l=u(i)?`"${i}"`:typeof i!="function"?e.serializeProperty(i):void 0;if(a==="style"&&typeof i=="object"&&i&&(l=`"${K(i)}"`),!l)continue;const d=Z[a]||e.properties[a]||a;n+=` ${d}=${l}`}let o="";const p=e.transformTag?e.transformTag(e.tagName):e.tagName,S=`<${p}${n} suppressHydrationWarning="true">`,P=console.error;try{process.env.STENCIL_SSR_DEBUG||(console.error=()=>{});const a=await h(t),{renderToString:i}=await import("react-dom/server");o=i(a).replace(/\n\s+/g,"")}catch(a){if(process.env.STENCIL_SSR_DEBUG){const i=a instanceof Error?a:new Error("Unknown error");console.warn(`${J} Failed to serialize light DOM for ${S.slice(0,-1)} />: ${i.message} - this may impact the hydration of the component`)}}finally{console.error=P}const R=`${S}${o}</${p}>`,{html:f,styles:b}=await e.renderToString(R,{fullDocument:!1,serializeShadowRoot:e.serializeShadowRoot??"declarative-shadow-dom",prettyHtml:!0});if(!f)throw new Error("No HTML returned from renderToString");const c=f.split(` `),O="<!--r.1-->",x=c[1].includes('shadowrootmode="open"'),$=c[1].includes("shadowrootdelegatesfocus");let w;x&&(w=c.slice(2,c.lastIndexOf(" </template>")).join(` `).trim());const{default:L}=await import("html-react-parser"),M=L,H=()=>M(f,{transform(a,i){if("name"in i&&(i.name===p||i.name===e.tagName)){const l=a.props,d=`${p}`;if(!x){const{children:ne,...I}=l||{},j=c.slice(1,-1).join(` `).trim().replace(new RegExp("(?<=>)\\s+(?=<)","g"),"").replace(/\n\s+/g,""),A=b.length>0&&b.map((m,U)=>s.createElement("style",{href:`stencil-${m.id||e.tagName}`,key:m.id||U,id:m.id,precedence:"stencil",suppressHydrationWarning:!0,dangerouslySetInnerHTML:{__html:m.content||""}}));return s.createElement(s.Fragment,null,A,s.createElement(d,{...I,suppressHydrationWarning:!0,dangerouslySetInnerHTML:{__html:j}}))}return s.createElement(d,{...l,suppressHydrationWarning:!0},s.createElement("template",{shadowrootmode:"open",...$?{shadowrootdelegatesfocus:""}:{},suppressHydrationWarning:!0,dangerouslySetInnerHTML:{__html:O+w}}),t)}}});return s.createElement(H,null)};async function h(e){return u(e)||y(e)?e:(z(e)||(e=[e]),Promise.all(Array.from(e).map(async t=>{if(u(t)||y(t))return t;if(z(t))return h(t);if(!s.isValidElement(t))return t;const{type:r,props:n}=t;return{...t,props:{...n,children:await h(n.children)},type:await k(r,n)}})))}const k=async(e,t)=>{let r=null;if(typeof e=="string")return e;if(Q(e)){const n=new e(t);r=n.render?n.render():n}else if(ee(e)){const n=e._payload,{default:o}=n._status===-1?await n._result():n._result;r=await k(o,t)}else typeof e!="object"&&(r=await e(t));return!y(r)&&!u(r)&&typeof r=="object"&&r!==null&&"type"in r&&(r=await k(r.type,t)),r};let g=null;const re=e=>{if(typeof window<"u"){if(e.clientModule)return e.clientModule;if(v.createComponent)return v.createComponent({tagName:e.tagName,properties:e.properties})}return async t=>{let r=!1;g||(g=await e.hydrateModule,r=!0);const n=g;if(e.getTagTransformer&&r){const o=e.getTagTransformer();o&&n.setTagTransformer(o)}return e.transformTag=n.transformTag,te({renderToString:n.renderToString,serializeProperty:n.serializeProperty,...e})(t)}};exports.createComponent=re; //# sourceMappingURL=ssr.cjs.map