@shijiu/jsview-vue 0.9.270 → 0.9.276

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.
@@ -1 +1 @@
1
- void 0===window.Forge&&(window.Forge={});var e=window.Forge;class t{constructor(e,t){if(this.href="",this.origin="",this.protocol="",this.host="",this.hostname="",this.port="",this.pathname="",this.search="",this.hash="",!e)return;if(!0===e.startsWith("url")){let t=e.indexOf("(")+1,s=e.lastIndexOf(")");if("undefined"===(e=e.substring(t,s).trim())||"null"===e||0===e.length)return}if(!0===e.startsWith("data:"))return void(this.href=e);let s=e.indexOf("://");if(!(s<0||s>10)||e.startsWith("./")||e.startsWith("/")||(e="./"+e),!0===e.startsWith("/"))e=document.location.origin+e;else if(!0===e.startsWith("./")&&void 0!==window.JsView&&void 0!==window.JsView.Dom.JsSubPath){if(void 0===window.JsView.Dom.__MainPath||"undefined"===window.JsView.Dom.__MainPathRef||window.JsView.Dom.__MainPathRef!==document.location.href){window.JsView.Dom.JsSubPath.startsWith("/")||(window.JsView.Dom.JsSubPath="/"+window.JsView.Dom.JsSubPath),window.JsView.Dom.JsSubPath.endsWith("/")||(window.JsView.Dom.JsSubPath=window.JsView.Dom.JsSubPath+"/"),window.JsView.Dom.__MainPathRef=document.location.href;let e=document.location.pathname.lastIndexOf(window.JsView.Dom.JsSubPath);window.JsView.Dom.__MainPath=document.location.origin+document.location.pathname.substring(0,e)}e=window.JsView.Dom.__MainPath+e.substring(1)}if(this.href=e,!t)return;let i=this.href,n=i.indexOf("#");n>0&&(this.hash=i.substring(n),i=i.substring(0,n));let r=i.indexOf("?");r>1&&(this.search=i.substring(r),i=i.substring(0,r));let o=i,a=o.indexOf("://");this.protocol=a>0?o.substring(0,a+1):"";let l=a>1?o.substring(a+3):"";a=l.indexOf("/"),this.host=a>0?l.substring(0,a):"",this.pathname=a>1?l.substring(a):"",this.origin=a>0?this.protocol+"//"+this.host:"",a=this.host.indexOf(":"),this.hostname=a>0?this.host.substring(0,a):this.host,this.port=a>1?this.host.substring(a+1):""}replace(e){this.href=e}}class s{static SetBackgroundColor(t,i,n){const r=s.TextureManager.GetColorTexture(i);let o;n&&(o=new e.ViewRoundCornerMask(n.topLeft,n.topRight,n.bottomLeft,n.bottomRight));const a=new e.TextureSetting(r,o);t.ResetTexture(a)}static SetBackgroundImage(i,n,r,o,a,l){if("string"==typeof n&&(n=new t(n)),n instanceof t==!1)throw Error("Bad Argument.",n);let h;if(h=n.href.endsWith("gif")||n.href.endsWith("webp")?s.TextureManager.GetGifImage(n.href,!1,null):s.TextureManager.GetImage2(n.href,!1,a,l||e.ColorSpace.RGBA_8888),h){let t;r&&(t=new e.ViewRoundCornerMask(r.topLeft,r.topRight,r.bottomLeft,r.bottomRight));const s=new e.ExternalTextureSetting(h,t);if(i.ResetTexture(s),o){let e=h.RegisterLoadImageCallback(null,(function(){o({width:h.Width,height:h.Height})}));i.RegisterDetachCallback((()=>{h.UnregisterLoadImageCallback(e)}))}}}static SetMaskedBackgroundImage(i,n,r,o){if("string"==typeof n&&(n=new t(n)),n instanceof t==!1)throw Error("Bad Argument.",n);if("string"==typeof r&&(r=new t(r)),r instanceof t==!1)throw Error("Bad Argument(MaskURL).",r);const a=s.TextureManager.GetImage2(n.href,!1,null,o||e.ColorSpace.RGBA_8888);if(a){const t=s.TextureManager.GetImage2(r.href,!1,null,e.ColorSpace.RGBA_8888),n=new e.ExternalTextureSetting(a,new e.ViewTextureMask(t));i.ResetTexture(n)}}static SetVideoTexture(t,i,n){const r=s.TextureManager.GetColorTexture(i);let o;n&&(o=new e.ViewRoundCornerMask(n.topLeft,n.topRight,n.bottomLeft,n.bottomRight));const a=new e.TextureSetting(r,o);t.ResetTexture(a)}static GetTextWidth(t){return t.str||(t.str=""),t.font||(t.font=e.TextUtils._sDefaultFont),t.size||(t.size=e.TextUtils._sDefaultFontSize),"italic"!==t.italic&&(t.italic=""),"bold"!==t.bold&&(t.bold=""),window.PlatformUtils.GetTextWidth(t)}static RequestSwap(){e.sRenderBridge.RequestSwap()}static SetImgTexSize(e,t){let i={size:t,refNum:0};s.TextureInfo.Cache[e.Source]=i}static RefImgTexSize(e,t){let i=s.TextureInfo.Cache[e.Source];i?(i.refNum>0?i.refNum++:i.refNum=1,t(i.size)):e.RegisterLoadImageCallback(null,(function(){const i={width:e.Width,height:e.Height};t(i);let n=s.TextureInfo.Cache[e.Source];if(n)n.refNum>0?n.refNum++:n.refNum=1;else{let t={size:i,refNum:1};s.TextureInfo.Cache[e.Source]=t}}))}static UnrefImgTexSize(e){if(!e)return;let t=s.TextureInfo.Cache[e.Source];t&&(t.refNum--,t.refNum<=0&&s.TextureInfo.Unused.add(e.Source))}static ClearUnusedTexSize(){for(let e of s.TextureInfo.Unused){let t=s.TextureInfo.Cache[e];t.refNum<-2?(delete s.TextureInfo.Cache[e],s.TextureInfo.Unused.delete(e)):t.refNum<=0?t.refNum--:s.TextureInfo.Unused.delete(e)}}}s.TextureInfo={Cache:{},Unused:new Set},s.TextureManager=null,s.RootView=null,s.RootActivity=null,s.HaltKeyEvent=!1;class i{constructor(e){this.target=null,this.timeStamp=Date.now(),this.type=e}initEvent(e,t,s){this.type=e}}class n extends i{constructor(e){super(e),this.keyCode=-1,this.key=-1,this.repeat=0}static JsvGetKeyFromCode(e){return new Map([[n.KeyCode.Enter,n.Key.Enter],[n.KeyCode.ArrowUp,n.Key.ArrowUp],[n.KeyCode.ArrowDown,n.Key.ArrowDown],[n.KeyCode.ArrowLeft,n.Key.ArrowLeft],[n.KeyCode.ArrowRight,n.Key.ArrowRight]])[e]}}n.Type={KEYDOWN:"keydown",KEYUP:"keyup"},n.Key={Enter:"Enter",ArrowUp:"ArrowUp",ArrowDown:"ArrowDown",ArrowLeft:"ArrowLeft",ArrowRight:"ArrowRight"},n.KeyCode={Enter:13,ArrowUp:38,ArrowDown:40,ArrowLeft:37,ArrowRight:39};let r={cnt:0};class o{constructor(e){this.type=e,this.cachedValues=null,this.onSyncCallback=null}setOnSyncCallback(e){this.onSyncCallback=e,this.syncLastCaches(!0)}setCacheProperty(e,t){this.cachedValues||(this.cachedValues={}),this.cachedValues[e]=t,this.syncLastCaches(!1),s.RequestSwap()}syncLastCaches(e){let t=o.LastModified[this.type];if((e||t!==this)&&(o.LastModified[this.type]=this,t&&t.cachedValues&&"function"==typeof t.onSyncCallback)){let e=t.cachedValues;t.cachedValues=null,t.onSyncCallback(e)}}static SyncAllCachedProperty(){for(let e of Object.values(o.LastModified))e.syncLastCaches(!0);r.cnt=(r.cnt+1)%65535}}o.LastModified={};class a{constructor(t){this.activity=new e.ReactActivity("JsViewForgeActivity",t,this.OnKeyDown.bind(this),this.OnKeyUp.bind(this)),this._Init()}_Init(){console.log("JsViewForgeActivity.OnCreate()."),s.TextureManager=this.activity.GetTextureManager(),s.RootView=new e.LayoutView,s.RootActivity=this.activity,document.jsvUpdateRootElement(s.RootView);let t=null;e.DesignMap&&(t=e.DesignMap());let i=t?t.width:1280,n=Math.floor(9*i/16);this.activity.SetContentView(s.RootView,{x:0,y:0,width:i,height:n}),e.sRenderBridge.AddWillSwapListener("forgeSwap",(()=>{o.SyncAllCachedProperty(),s.ClearUnusedTexSize()})),window.JsView.Dom.Render()}OnKeyDown(e){if(s.HaltKeyEvent){let t=new n(n.Type.KEYDOWN);return t.keyCode=e.keyCode,t.repeat=e.repeat,document.dispatchEvent(t),!0}return!1}OnKeyUp(e){if(s.HaltKeyEvent){let t=new n(n.Type.KEYUP);return t.keyCode=e.keyCode,t.key=n.JsvGetKeyFromCode(t.keyCode),t.repeat=e.repeat,document.dispatchEvent(t),!0}return!1}}class l{constructor(t){this._ActivityManager=t;let s=new a(t);t.RegisterActivity(s.activity),t.StartActivity(new e.Intent("JsViewForgeActivity"))}}window.JsView&&(window.JsView.Dom={DesignMap:null,Render:null,Extension:s,UrlRef:t},window.JsView.React=window.JsView.Dom);class h{static SetLevel(e){switch(h.E=h.W=h.I=h.D=function(){},e){case h.Level.Verbose:h.V=console.debug.bind(console);case h.Level.Debug:h.D=console.debug.bind(console);case h.Level.Info:h.I=console.info.bind(console)}}static Throw(...e){throw console.error(...e),[...e]}}h.E=console.error.bind(console),h.W=console.warn.bind(console),h.I=console.info.bind(console),h.D=function(){},h.V=function(){},h.Level={Error:0,Warning:1,Info:2,Debug:3,Verbose:4};class u{constructor(e){this.ownerDocument=window.document,this.nodeType=e,this.parentNode=void 0,this.childNodes=[],this.jsvEventListener=void 0,this.jsvChildChangedCallback=void 0}jsvGetTagName(){return"Unknown"}appendChild(e){this.childNodes.push(e),e.parentNode=this,this.jsvChildChangedCallback?.()}removeChild(e){let t=this.childNodes.indexOf(e);t<0&&h.Throw("Failed to call Node.removeChild(), node not found. node=",e),this.childNodes.splice(t,1),e.parentNode=void 0,this.jsvChildChangedCallback?.()}insertBefore(e,t){let s=this.childNodes.length;void 0===t?h.Throw("TypeError: Failed to execute 'insertBefore' on 'Node': 2 arguments required, but only 1 present."):null!==t&&(s=this.childNodes.indexOf(t)),s<0&&h.Throw("Failed to call Node.insertBefore(), before node not found. beforeNode=",t),this.childNodes.splice(s,0,e),e.parentNode=this,this.jsvChildChangedCallback?.()}get previousSibling(){const e=this.parentNode.childNodes;let t=e.indexOf(this);return t<0&&h.Throw("Failed to call Node.previousSibling(), this node not found. this=",this),e[t-1]}get nextSibling(){const e=this.parentNode.childNodes;let t=e.indexOf(this);return t<0&&h.Throw("Failed to call Node.nextSibling(), this node not found. this=",this),e[t+1]}addEventListener(e,t,s){this.jsvEventListener||(this.jsvEventListener={});let i=this.jsvEventListener[e];i||(i=new Set,this.jsvEventListener[e]=i),i.add(t)}removeEventListener(e,t,s){if(!this.jsvEventListener)return;let i=this.jsvEventListener[e];i&&(i.delete(t),i.size<=0&&this.jsvEventListener.hasOwnProperty(e)&&delete this.jsvEventListener[e],0===Object.values(this.jsvEventListener).length&&(this.jsvEventListener=void 0))}dispatchEvent(e){if(!this.jsvEventListener)return void console.warn("Node.dispatchEvent() Ignore to dispatch event: "+e.type+". No event added.");let t=this.jsvEventListener[e.type];if(t){e.target||(e.target=document.activeElement);for(let s of t)s(e)}else console.warn("Node.dispatchEvent() Ignore to dispatch event: "+e.type+". No listener added.")}jsvObserveChildChanged(e){this.jsvChildChangedCallback=e}}u.ELEMENT_NODE=1,u.TEXT_NODE=3,u.COMMENT_NODE=8,u.DOCUMENT_NODE=9,u.NOLAYOUT_NODE=10;class c extends i{}c.Type={FOCUS:"focus",BLUR:"blur"};class d extends i{stopPropagation(){}}class v{static ConvertInt(e){return e?"number"==typeof e?Math.floor(e):"string"==typeof e?parseInt(e):e:e}static ConvertFloat(e){if(!e)return e;if("string"!=typeof e)return e;return parseFloat(e)}static ConvertPx(e){if(!e)return e;if("string"!=typeof e)return e;if("0"===e)return 0;if(e.endsWith("px")){return parseInt(e)}return e}static ConvertRect(e){let t=v.SplitString(e," "),s={top:t.length>0?parseInt(t[0]):0,right:t.length>1?parseInt(t[1]):null,bottom:t.length>2?parseInt(t[2]):null,left:t.length>3?parseInt(t[3]):null};return s.right=s.right||0===s.right?s.right:s.top,s.bottom=s.bottom||0===s.bottom?s.bottom:s.top,s.left=s.left||0===s.left?s.left:s.right,s}static ConvertCorner(e){let t=v.SplitString(e," "),s={topLeft:t.length>0?parseInt(t[0]):0,topRight:t.length>1?parseInt(t[1]):null,bottomRight:t.length>2?parseInt(t[2]):null,bottomLeft:t.length>3?parseInt(t[3]):null};return s.topRight=s.topRight||0===s.topRight?s.topRight:s.topLeft,s.bottomRight=s.bottomRight||0===s.bottomRight?s.bottomRight:s.topLeft,s.bottomLeft=s.bottomLeft||0===s.bottomLeft?s.bottomLeft:s.bottomRight,s}static ConvertSize(e){let t=v.SplitString(e," "),s={width:t.length>0?parseInt(t[0]):0,height:t.length>1?parseInt(t[1]):null};return s.height=s.height||0===s.height?s.height:s.width,s}static ConvertAnimation(e){if(null===e||0===e.length)return null;let t=e.indexOf("cubic-bezier"),s=[];if(t>=0){let i=e.indexOf(")"),n=e.substring(t,i+1),r=v.SplitString(e,n);for(let e of r){let t=v.SplitString(e," ");s=s.concat(t)}s.push(n)}else s=v.SplitString(e," ");let i=null,n=0,r=1,o=e.includes("alternate");for(let e=2;e<s.length;e++){if("infinite"===s[e]){r=-1;continue}let t=v.ConvertTimeMs(s[e]);!1===isNaN(t)?n=t:(t=parseFloat(s[e]),!1===isNaN(t)?r=t:i=s[e])}let a=s.length>1?v.ConvertTimeMs(s[1]):0;return{name:s.length>0?s[0]:"",duration:a,timingFunction:v.ConvertEasing(i,a),delay:n,iterationCount:r,direction:o,originStr:e}}static ConvertTransition(e){if(null==e||0==e.length)return null;let t={},s=new Array,i=e.split(",");for(let e=0;e<i.length;e++)if(i[e].indexOf("(")>=0){let t=e;for(;t<i.length&&i[t].indexOf(")")<0;)t++;let n="";for(let s=e;s<=t;s++)s!=e&&(n+=","),n+=i[s];e=t,s=s.concat(n)}else s=s.concat(i[e]);for(let e of s){let s=v.ConvertAnimation(e);if(t[s.name]=s,"all"==s.name){let e=new Array("opacity","left","top","width","height","transform");for(let i of e)t[i]=s}}return t}static ConvertTimeMs(e){e||(e="");let t=NaN;return(e=e.trim()).endsWith("ms")?t=1:e.endsWith("s")&&(t=1e3),t*=parseFloat(e),t}static ConvertEasing(t,s){let i=e.Easing.Circular.InOut;if(!t)return i;if(t.includes("ease"))i=t.includes("-in-out")?e.Easing.Circular.InOut:t.includes("-out")?e.Easing.Circular.Out:t.includes("-in")?e.Easing.Circular.In:e.Easing.Circular.InOut;else if(t.includes("linear"))i=null;else if(t.includes("cubic-bezier")){let n=v.ConvertBezier(t);i=new e.BezierEasing(n.x1,n.y1,n.x2,n.y2,s)}else if(t.includes("steps")){let s=v.ConvertSteps(t);i=new e.StepsEasing(s.steps,s.type)}return i}static ConvertBezier(e){let t=e.indexOf("(");t>=0&&(e=e.substring(t+1));let s=v.SplitString(e,",");return{x1:s.length>0?parseFloat(s[0]):0,y1:s.length>1?parseFloat(s[1]):0,x2:s.length>2?parseFloat(s[2]):0,y2:s.length>3?parseFloat(s[3]):0}}static ConvertSteps(e){let t=e.indexOf("(");t>=0&&(e=e.substring(t+1));let s=v.SplitString(e,",");return{steps:s.length>0?parseInt(s[0]):1,type:s.length>1?s[1].includes("start")?0:1:0}}static ConvertOverflow(e,t){return e&&!e.includes("visible")?t.HIDDEN:t.VISIBLE}static ConvertObjectFit(e,t){return"symbol"==typeof e?e:(e||(e=""),e.includes("fill")?t.FILL:e.includes("contain")?t.CONTAIN:e.includes("cover")?t.COVER:e.includes("none")?t.NONE:e.includes("scale-down")?t.SCALEDOWN:t.CONTAIN)}static SplitString(e,t){e||(e="");let s=e.trim().split(t);if(" "!==t)return s;let i=[];for(let e of s)e&&i.push(e);return i}}class g{constructor(e){if(this.top=null,this.right=null,this.bottom=null,this.left=null,!e||!1===e.startsWith("inset"))return void console.error("Inset.Parse() InvalidArgs: value=",e);let t=e.indexOf("(")+1,s=e.substring(t),i=v.ConvertRect(s);this.top=i.top,this.right=i.right,this.bottom=i.bottom,this.left=i.left}}class p{constructor(e){if(this.source=null,this.slice=null,this.repeat=null,this.outset=null,this.width=null,!e)return void console.error("BorderImage.constructor() InvalidArgs: value=",e);let s=e.indexOf(")")+1,i=e.substring(0,s),n=e.substring(s);this.source=new t(i),this.slice=v.ConvertRect(n)}}class w{constructor(){this.refStyleObject=new Map,this.value=void 0}static AppendRefStyle(e,t,s){let i=w.jsvGetStyleVar(e);i.refStyleObject.has(t)||i.refStyleObject.set(t,[]),i.refStyleObject.get(t).push(s)}static RemoveRefStyle(e){for(const t of w.VariableMap.values())for(const s of t.refStyleObject.keys())s==e&&t.refStyleObject.delete(e)}static UpdateValue(e,t){let s=w.jsvGetStyleVar(e);s.value=t;for(const[e,t]of s.refStyleObject)for(const s of t)e.jsvSetClassProperty(s)}static GetValue(e){return w.jsvGetStyleVar(e).value}static jsvGetStyleVar(e){e.startsWith("--")&&(e=`var(${e})`),w.VariableMap.has(e)||w.VariableMap.set(e,new w);return w.VariableMap.get(e)}}w.VariableMap=new Map;class y{constructor(){this.jsvStore={},this.jsvLazySyncCache=new o("style"),this.jsvLockedProps={},this.jsvNamedClassArray=null,this.jsvCustomStyles={},this.jsvLazyPrevClassNames=null,this.jsvLazyClassNames=null,this.jsvLazyClassAttributes=null}setProperty(e,t){"function"==typeof document.jsvCheckStyleFormat&&document.jsvCheckStyleFormat(e,t),this.jsvLockedProps[e]=!0,t=y.JsvConvertPropValue(e,t),this.jsvUpdateProperty(e,t)}getPropertyValue(e){if(void 0!==this.jsvStore[e])return this.jsvStore[e];let t=this.jsvGetClassPropValue(this.jsvLazyClassNames,this.jsvLazyClassAttributes,e);return t=y.JsvConvertPropValue(e,t),t}jsvDestory(){w.RemoveRefStyle(this)}jsvUpdateProperty(e,t){let s=this.jsvSetPropertySilently(e,t);s&&this.jsvLazySyncCache.setCacheProperty(s,!0)}jsvSetPropertySilently(e,t){if(e.startsWith("--"))return void w.UpdateValue(e,t);if("string"==typeof t&&t.startsWith("var(--"))return void w.AppendRefStyle(t,this,e);if("animation"===e){if(this.jsvStore[e]?.originStr===t?.originStr)return null}else if(this.jsvStore[e]===t)return null;return this.jsvStore[e]=t,y.JsvGetStyleType(e)}jsvApplyClasses(t){if(t.indexOf("JsvStyle_")<0){this.jsvLazyPrevClassNames=this.jsvLazyClassNames,this.jsvLazyClassNames=t.split(" ");const e=y.TYPE.CLASS_NAME;this.jsvLazySyncCache.setCacheProperty(e,!0)}else if(t){let s=t.split(" "),i={};this.jsvNamedClassArray=new Array(s.length);let n=0;for(let t of s){let s=null;if(e.ReactUtils.StyleClassMap.hasOwnProperty(t)){s=e.ReactUtils.StyleClassMap[t];let n=s.getAttach();if(null==n){let e=s.getStyles();n={altStyles:{},hasTextMajorStyle:0,textPackAttr:null};for(let t in e)n.altStyles[t]=y.JsvConvertPropValue(t,e[t]);s.updateAttach(n)}"text"===s.classType()&&(n.hasTextMajorStyle=2,null===n.textPackAttr&&(n.textPackAttr={textLineAlign:s.getLineAlign(),textVerticalAlign:s.getVerticalAlign()}),this.jsvCustomStyles.textLineAlign=n.textPackAttr.textLineAlign,this.jsvCustomStyles.textVerticalAlign=n.textPackAttr.textVerticalAlign),Object.assign(i,n.altStyles)}else console.error("Error: className not found");this.jsvNamedClassArray[n]=s,n++}for(let e in i)this.jsvLockedProps[e]||this.jsvUpdateProperty(e,i[e])}}jsvAppendClassAttribute(e){this.jsvLazyClassAttributes||(this.jsvLazyClassAttributes=new Set),this.jsvLazyClassAttributes.add(e);const t=y.TYPE.CLASS_NAME;this.jsvLazySyncCache.setCacheProperty(t,!0)}jsvSetClassProperty(e){let t=y.JsvGetStyleType(e);t&&this.jsvLazySyncCache.setCacheProperty(t,!0)}jsvGetClassPropValue(e,t,s){if(!e)return;const i=(e,t,s,i)=>{for(let n=t.length-1;n>=0;n--){let r=t[n];if(s&&(r+="["+s+"]"),!e.hasOwnProperty(r))continue;const o=e[r];if(!o.hasOwnProperty(i))continue;let a=o[i];return"string"==typeof a&&a.startsWith("var(--")&&(a=w.GetValue(a)),a}},n=window.JsvCode.Dom.StyleSheets;for(const r of t??[]){const t=i(n,e,r,s);if(t)return t}return i(n,e,null,s)}jsvGetClassDeclarations(e,t){if(!e)return;const s=(e,t,s)=>{let i={};for(let n=0;n<t.length;n++){let r=t[n];if(s&&(r+="["+s+"]"),!e.hasOwnProperty(r))continue;const o=e[r];Object.assign(i,o)}return i},i=window.JsvCode.Dom.StyleSheets;let n=s(i,e,null);for(const r of t??[]){const t=s(i,e,r);Object.assign(n,t)}return n}jsvUpdateChangedClasses(){h.D("jsvGetChangedClassTypes() classNames="+this.jsvLazyClassNames);let e={};if(this.jsvLazyPrevClassNames){w.RemoveRefStyle(this);const t=this.jsvGetClassDeclarations(this.jsvLazyPrevClassNames,this.jsvLazyClassAttributes);for(const s of Object.keys(t)){e[y.JsvGetStyleType(s)]=!0}this.jsvLazyPrevClassNames=null}if(this.jsvLazyClassNames){const t=this.jsvGetClassDeclarations(this.jsvLazyClassNames,this.jsvLazyClassAttributes);for(const[s,i]of Object.entries(t)){e[y.JsvGetStyleType(s)]=!0,"string"==typeof i&&i.startsWith("var(--")&&w.AppendRefStyle(i,this,s)}}return e}jsvSetChangedListener(e){this.jsvLazySyncCache.setOnSyncCallback((t=>{if(t.hasOwnProperty(y.TYPE.CLASS_NAME)){const e=this.jsvUpdateChangedClasses();Object.assign(t,e),t[y.TYPE.CLASS_NAME]=void 0}e(t)}))}static JsvContainsTextMajor(e){for(let t of y.TextClassMajorStyles)if(e.hasOwnProperty(t))return!0;return!1}static JsvGetStyleType(e){switch(e){case y.PROP.LEFT:case y.PROP.RIGHT:case y.PROP.TOP:case y.PROP.BOTTOM:case y.PROP.ZINDEX:return y.TYPE.LAYOUT_POS;case y.PROP.TRANSFORM:case y.PROP.TRANSFORMORIGIN:return y.TYPE.TRANSFORM;case y.PROP.WIDTH:case y.PROP.HEIGHT:case y.PROP.VISIBILITY:case y.PROP.DISPLAY:case y.PROP.CLIPPATH:case y.PROP.OVERFLOW:case y.PROP.OBJECTFIT:case y.PROP.PERSPECTIVE:case y.PROP.PERSPECTIVEORIGIN:case y.PROP.BACKFACEVISIBILITY:case y.PROP.TRANSFORMSTYLE:case y.PROP.JSVVIDEOROTATION:return y.TYPE.LAYOUT_SIZE;case y.PROP.BACKGROUNDCOLOR:case y.PROP.BACKGROUNDIMAGE:case y.PROP.BORDERRADIUS:return y.TYPE.BACKGROUND;case y.PROP.COLOR:case y.PROP.LINEHEIGHT:case y.PROP.WHITESPACE:case y.PROP.FONTFAMILY:case y.PROP.FONTSIZE:case y.PROP.FONTSTYLE:case y.PROP.FONTWEIGHT:case y.PROP.TEXTALIGN:case y.PROP.TEXTSHADOW:case y.PROP.TEXTOVERFLOW:case y.PROP.WEBKITTEXTSTROKE:return y.TYPE.FOREGROUND;case y.PROP.BORDERIMAGE:case y.PROP.BORDERIMAGEWIDTH:case y.PROP.BORDERIMAGEOUTSET:return y.TYPE.BORDER;case y.PROP.ANIMATION:return y.TYPE.ANIMATION;case y.PROP.TRANSITION:return y.TYPE.TRANSITION;case y.PROP.OPACITY:break;default:return console.warn("Unknown style type for: "+e),null}}static JsvConvertPropValue(e,t){if(void 0===t)return t;if(e.startsWith("--")||t?.startsWith?.("var(--"))return t;switch(e){case y.PROP.TOP:case y.PROP.BOTTOM:case y.PROP.LEFT:case y.PROP.RIGHT:case y.PROP.WIDTH:case y.PROP.HEIGHT:case y.PROP.JSVVIDEOROTATION:return v.ConvertInt(t);case y.PROP.VISIBILITY:case y.PROP.DISPLAY:return t.toUpperCase();case y.PROP.OVERFLOW:return v.ConvertOverflow(t,y.Overflow);case y.PROP.OBJECTFIT:return v.ConvertObjectFit(t,y.ObjectFit);case y.PROP.TRANSFORM:case y.PROP.TRANSFORMORIGIN:return t;case y.PROP.CLIPPATH:return new g(t);case y.PROP.BORDERIMAGE:return new p(t);case y.PROP.BORDERIMAGEWIDTH:case y.PROP.BORDERIMAGEOUTSET:return v.ConvertRect(t);case y.PROP.BORDERRADIUS:return v.ConvertCorner(t);case y.PROP.ANIMATION:return v.ConvertAnimation(t);case y.PROP.TRANSITION:return v.ConvertTransition(t);case y.PROP.OPACITY:return v.ConvertFloat(t);default:return v.ConvertPx(t)}}}y.Overflow={HIDDEN:Symbol("hidden"),VISIBLE:Symbol("visible")},y.ObjectFit={FILL:Symbol("fill"),CONTAIN:Symbol("contain"),COVER:Symbol("cover"),NONE:Symbol("none"),SCALEDOWN:Symbol("scale-down")},y.TextClassMajorStyles=new Set(["textOverflow","wordWrap","textShadow","color","fontFamily","fontStyle","fontWeight","textAlign","WebkitTextStroke"]),y.TYPE={LAYOUT_POS:"layout-position",LAYOUT_SIZE:"layout-size",FOREGROUND:"foreground",BACKGROUND:"background",BORDER:"border",ANIMATION:"animation",TRANSFORM:"transform",TRANSITION:"transition",CLASS_NAME:"class-name"},y.PROP={TOP:"top",BOTTOM:"bottom",LEFT:"left",RIGHT:"right",WIDTH:"width",HEIGHT:"height",VISIBILITY:"visibility",DISPLAY:"display",BACKFACEVISIBILITY:"backfaceVisibility",CLIPPATH:"clipPath",OVERFLOW:"overflow",OBJECTFIT:"objectFit",TRANSFORM:"transform",TRANSFORMORIGIN:"transformOrigin",PERSPECTIVE:"perspective",PERSPECTIVEORIGIN:"perspectiveOrigin",ZINDEX:"zIndex",TRANSFORMSTYLE:"transformStyle",BACKGROUNDCOLOR:"backgroundColor",BACKGROUNDIMAGE:"backgroundImage",BORDERRADIUS:"borderRadius",COLOR:"color",LINEHEIGHT:"lineHeight",WHITESPACE:"whiteSpace",FONTFAMILY:"fontFamily",FONTSIZE:"fontSize",FONTSTYLE:"fontStyle",FONTWEIGHT:"fontWeight",TEXTALIGN:"textAlign",TEXTSHADOW:"textShadow",TEXTOVERFLOW:"textOverflow",WEBKITTEXTSTROKE:"WebkitTextStroke",BORDERIMAGE:"borderImage",BORDERIMAGEWIDTH:"borderImageWidth",BORDERIMAGEOUTSET:"borderImageOutset",ANIMATION:"animation",TRANSITION:"transition",OPACITY:"opacity",JSVVIDEOROTATION:"JsvVideoRotation"};for(let e in y.PROP){let t=y.PROP[e];Object.defineProperty(y.prototype,t,{set:function(e){this.setProperty(t,e)},get:function(){return this.getPropertyValue(t)}})}let f=null;class m{static getHandlers(e){const t=m.reactEventHandlers(e);return t||(e._vei?e._vei:{})}static reactEventHandlers(e){return null==f&&m._getReactToken(e),e["__reactEventHandlers$"+f]}static _getReactToken(e){for(let t in e)if(t.indexOf("__reactEventHandlers")>=0||t.indexOf("__reactInternalInstance")>=0){let e=t.indexOf("$");f=t.substring(e+1);break}}}class j extends u{constructor(t){super(u.ELEMENT_NODE),this.parentElement=null,this.tagName=this.jsvGetTagName(),this.tagName===j.TAG.STYLE?(this.style=null,this.jsvMainView=null,this.jsvMaskView=null):(this.style=new y,this.jsvMainView=new e.LayoutView,this.jsvMaskView=null),this.jsvAnimation=null,this.jsvStore={transition:null,transitionTmp:null,textContent:null,textStylePack:null,clientWidth:NaN,clientHeight:NaN,textureWidth:NaN,textureHeight:NaN,scopedData:[]},this.jsvLazySyncCache=new o("element"),this.instantSwapCallback=null,this.eventHandlers=null}appendChild(e){super.appendChild(e),this.jsvInsertChild(e,null)}removeChild(e){if(e.childNodes)for(const t of e.childNodes)e.removeChild(t);e.style?.jsvDestory(),super.removeChild(e),e.parentElement=null,e instanceof j&&this.jsvMainView.RemoveView(e.jsvMaskView)}insertBefore(e,t){super.insertBefore(e,t),this.jsvInsertChild(e,t)}get childElementCount(){return this.childNodes.length}get firstElementChild(){return this.childNodes.length>0?this.childNodes[0]:null}get lastElementChild(){const e=this.childNodes.length;return e>0?this.childNodes[e-1]:null}set className(e){this.setAttribute("class",e)}setAttribute(e,t){e&&(this[e],this[e]=t,e.startsWith("data-v-")?(this.jsvStore.scopedData.push(e),this.style.jsvAppendClassAttribute(e)):"class"===e?this.style.jsvApplyClasses(t):e.startsWith(j.ATTRIBUTE.JSVPREFIX)&&(e=e.replace(/-/g,"_"),this.jsvLazySyncCache.setCacheProperty(e,t)))}removeAttribute(e){this[e]=void 0,e.startsWith(j.ATTRIBUTE.JSVPREFIX)&&this.jsvLazySyncCache.setCacheProperty(e,void 0)}getAttribute(e){return this[e]}hasAttribute(e){return console.log("Element.hasAttribute() name="+e),!!this[e]}get clientWidth(){return isNaN(this.jsvStore.clientWidth)?this.style.width:this.jsvStore.clientWidth}get clientHeight(){return isNaN(this.jsvStore.clientHeight)?this.style.height:this.jsvStore.clientHeight}focus(){console.log("Element.focus()"),document.activeElement&&document.activeElement.onfocus();let e=document.activeElement;if(document.activeElement=this,e){let t=new c(c.Type.BLUR);t.target=e,document.dispatchEvent(t)}let t=new c(c.Type.FOCUS);document.dispatchEvent(t)}jsvInsertChild(e,t){if(e.parentElement=this,e.nodeType===u.ELEMENT_NODE&&e.tagName!==j.TAG.STYLE){if(!1===document.jsvIsReady)return void console.warn("Element.appendChild() Failed to append child to Forge. jsvIsReady="+document.jsvIsReady);e.jsvOnLoadForgeView(),e.style.jsvSetChangedListener(e.jsvOnStyleChanged.bind(e)),t=this.jsvBackwardFindForgeView(t);let s=e.jsvMaskView.GetLayoutParams();this.jsvMainView.InsertView(e.jsvMaskView,t?t.jsvMaskView:null,s)}else e.nodeType===u.TEXT_NODE&&(this.textContent=e.textContent)}jsvOnLoadForgeView(){if(this.style.clipPath||this.style.overflow||this.style.objectFit){if(this.jsvMaskView)throw Error("Jsview: jsvMaskView is conflicting.");this.jsvMaskView=new e.ClipView}else this.jsvMaskView||(this.jsvMaskView=this.jsvMainView);this.jsvMaskView!==this.jsvMainView&&this.jsvMaskView.AddView(this.jsvMainView);let t=this.jsvCallbackOnUnloadForgeView();t&&this.jsvMainView.RegisterDetachCallback(t),this.jsvLazySyncCache.setOnSyncCallback((e=>{this.jsvSetElementProp(e)}))}jsvSetElementProp(e){this.jsvMainView&&this.jsvMainView.SetElementProp(e,s.RootActivity)}jsvCallbackOnUnloadForgeView(){return null}jsvOnStyleChanged(e){let t=!!e[y.TYPE.LAYOUT_SIZE],s=!1;e[y.TYPE.LAYOUT_POS]&&(t||(this.jsvFlushViewLayout(),s=!0)),e[y.TYPE.LAYOUT_SIZE]&&(this.jsvFlushViewLayout(),s=!0),e[y.TYPE.TRANSFORM]&&!s&&(this.jsvMaskView.ResetCssTransform(this.style.transform,this.style.transformOrigin),this.jsvFlushViewTransition(),s=!0),e[y.TYPE.BACKGROUND]&&this.jsvFlushViewBackground(),e[y.TYPE.ANIMATION]&&this.jsvFlushViewAnimation(),e[y.TYPE.TRANSITION]&&!s&&this.jsvFlushViewTransition(),this.jsvFlushEventHandlers()}jsvFlushEventHandlers(){null===this.eventHandlers&&(this.eventHandlers=m.getHandlers(this),this.eventHandlers&&this.eventHandlers.onClick&&this.jsvMainView&&this.jsvMainView.EnableDivTouch(this,null))}jsvApplyObjectFit(e){return null}jsvFlushViewLayout(){if((this.style.clipPath||this.style.overflow||this.style.objectFit)&&!this.jsvMaskView)return void console.error("Element.jsvFlushViewLayout() InvalidOpt: clippath=",this.style.clipPath);const t={x:isNaN(this.style.left)?0:this.style.left,y:isNaN(this.style.top)?0:this.style.top,width:isNaN(this.style.width)?0:this.style.width,height:isNaN(this.style.height)?0:this.style.height};let s=null;if(this.style.objectFit&&(s=this.jsvApplyObjectFit(t),this.style.objectFit===y.ObjectFit.FILL&&(s=null)),this.jsvMaskView.ResetCssTransform(this.style.transform,this.style.transformOrigin),this.style.perspective&&this.style.perspective>0){let e=this.style.perspectiveOrigin?this.style.perspectiveOrigin:null;this.jsvMainView.SetPerspective(this.style.perspective,e)}if(this.style.backfaceVisibility&&this.jsvMainView.SetBackfaceVisibility("visible"==this.style.backfaceVisibility),this.style.transformStyle&&this.jsvMainView.SetTransformStyle(this.style.transformStyle),this.jsvMaskView.ResetLayoutParams({x:t.x,y:t.y,width:this.clientWidth,height:this.clientHeight}),this.jsvMaskView!==this.jsvMainView){const e={x:0,y:0,width:this.jsvMaskView.LayoutParams.Width,height:this.jsvMaskView.LayoutParams.Height};this.jsvMainView.ResetLayoutParams(e)}this.jsvMaskView.SetVisibility(this.style.visibility);let i=null;null!==s&&window.JsView?i={x:s.x,y:s.y,width:s.width,height:s.height}:this.style.clipPath?i={x:this.style.clipPath.left,y:this.style.clipPath.top,width:this.jsvMaskView.LayoutParams.Width-this.style.clipPath.left-this.style.clipPath.right,height:this.jsvMaskView.LayoutParams.Height-this.style.clipPath.top-this.style.clipPath.bottom}:this.style.overflow===y.Overflow.HIDDEN&&null===this.jsvStore.textContent&&(i={x:0,y:0,width:this.style.width,height:this.style.height}),i?this.jsvMaskView.SetClipRect(i.x,i.y,i.width,i.height,!0):this.jsvMaskView instanceof e.ClipView&&this.jsvMaskView.SetClipRect(0,0,0,0,!1),void 0!==this.style.zIndex&&null!==this.style.zIndex&&this.jsvMaskView.SetZIndex(this.style.zIndex),this.jsvFlushViewTransition()}jsvFlushViewBackground(){this.style.backgroundColor&&(this.jsvStore.textureWidth=NaN,this.jsvStore.textureHeight=NaN,s.SetBackgroundColor(this.jsvMainView,this.style.backgroundColor,this.style.borderRadius)),this.style.backgroundImage&&(this.jsvStore.textureWidth=NaN,this.jsvStore.textureHeight=NaN,s.SetBackgroundImage(this.jsvMainView,this.style.backgroundImage,this.style.borderRadius))}jsvFlushViewAnimation(){if(this.jsvAnimation&&this.jsvAnimation.Cancel(),!this.style.animation)return;let t=document.jsvGetKeyFrames(this.style.animation.name,this.jsvStore.scopedData);this.jsvAnimation=new e.CssKeyframeAnimation(t,this.style.animation.duration,this.style.animation.timingFunction,this.style.width?this.style.width:this.clientWidth,this.style.height),this.jsvAnimation.EnableDelay(this.style.animation.delay).SetRepeat(this.style.animation.iterationCount),"forwards"===this.style.animationFillMode&&this.jsvAnimation.Enable(e.AnimationEnable.KeepTransform);var s=this;let i=new e.AnimationListener;i.OnEnd((t=>{if(s.jsvAnimation=null,t){if(s.eventHandlers&&s.eventHandlers.onAnimationEnd){let e;e=new d("animationend"),e.target=s,s.eventHandlers.onAnimationEnd(e)}null==s.instantSwapCallback&&(s.instantSwapCallback=e.sRenderBridge.InstantPerformSwap.bind(e.sRenderBridge)),Promise.resolve().then(s.instantSwapCallback)}})),this.jsvAnimation.Enable(e.AnimationEnable.ReleaseAfterEndCallback),this.jsvAnimation.SetAnimationListener(i),this.jsvMaskView.StartAnimation(this.jsvAnimation)}jsvFlushViewTransition(){if(this.style.animation)return;if(null!=this.jsvStore.transitionTmp&&this.jsvStore.transitionTmp.syncTimes!=r.cnt&&-1!=this.jsvStore.transitionTmp.syncTimes){let e=this.jsvStore.transition;this.jsvStore.transition=this.jsvStore.transitionTmp,this.jsvStore.transitionTmp=e,null!=this.jsvStore.transitionTmp&&(this.jsvStore.transitionTmp.syncTimes=-1)}if(this.style.transition){if(this.jsvStore.transition){if(!this._JsvBuildTransition())return}}else this.jsvAnimation&&(this.jsvAnimation.Cancel(),this.jsvAnimation=null);let e=this.jsvStore.transitionTmp;e||(e={left:0,top:0,width:0,height:0,opacity:1,transform:null,syncTimes:-1}),e.left=this.style.left,e.top=this.style.top,e.width=this.style.width,e.height=this.style.height,e.opacity=this.style.opacity,e.transform=this.style.transform,e.syncTimes=r.cnt,this.jsvStore.transitionTmp=e}_JsvBuildTransition(){let t=[];for(let e in this.style.transition){let s=this.jsvStore.transition[e],i=this.style[e];if(s===i)continue;let n=this.style.transition[e],r={name:e,dur:n.duration,tf:null,dly:n.delay,from:s||"",to:i};"transform"===e&&(r.origin=this.style.transformOrigin?this.style.transformOrigin:"center center"),n.timingFunction&&(r.tf=n.timingFunction.Package()),t.push(r)}if(t.length<=0)return!1;var s=this;let i=new e.AnimationListener;return i.OnEnd((t=>{if(s.jsvAnimation=null,t){if(s.eventHandlers&&s.eventHandlers.onTransitionEnd){let e=new d("transitionend");e.target=s,s.eventHandlers.onTransitionEnd(e)}null==s.instantSwapCallback&&(s.instantSwapCallback=e.sRenderBridge.InstantPerformSwap.bind(e.sRenderBridge)),Promise.resolve().then(s.instantSwapCallback)}})),this.jsvAnimation=new e.CssTransitionAnimation(t),this.jsvAnimation.SetAnimationListener(i),this.jsvMaskView.StartAnimation(this.jsvAnimation),!0}jsvBackwardFindForgeView(e){let t=e;for(;t&&!(t instanceof j);)t=t.nextSibling;return t}static applyObjectFitCommon(e,t,s){if(s&&!isNaN(e.jsvStore.textureWidth)&&!isNaN(e.jsvStore.textureHeight)){const i=e.style.objectFit,n=s.ApplyObjectFit(t.width,t.height,e.jsvStore.textureWidth,e.jsvStore.textureHeight,i,y.ObjectFit);return 0!==t.width&&0!==t.height||0===t.width&&0===t.height||(e.jsvStore.clientWidth=Math.max(t.width,n.width),e.jsvStore.clientHeight=Math.max(t.height,n.height)),n}return null}}j.TAG={DIV:"DIV",IMAGE:"IMAGE",LINK:"LINK",STYLE:"STYLE",AUDIO:"AUDIO",VIDEO:"VIDEO",ANCHOR:"A",SVG:"SVG",FDIV:"FDIV",AUDIOTRACK:"AUDIOTRACK"},j.ATTRIBUTE={SRC:"src",JSVPREFIX:"jsv"};class T extends j{constructor(){super(),console.warn("Warnig: <a> is fake in JsView system"),this.href="",this.protocol="",this.host="",this.search="",this.hash="",this.hostname="",this.port="",this.pathname=""}jsvGetTagName(){return j.TAG.ANCHOR}}class O extends j{constructor(e){super(),this.jsvMediaView=null,this.jsvMedia=null,this.onVisibilityChange=this.onVisibilityChange.bind(this),this.stopByOnHide=!1,this.playBackground=!1,e&&(this.srcValue=e)}addEventListener(e,t,s){e=e.replace(/-/g,""),super.addEventListener(e,t,s),this.jsvAddMediaListener(e)}jsvOnLoaded(){}set src(e){if(e&&"about:null"!==e&&"about:blank"!==e){e=new t(e).href}this.jsvMedia||this.jsvInit(),e!==this.jsvMedia.src&&(this.jsvMedia.src=e,this.srcValue=e)}jsvOnLoadForgeView(){console.log("MediaElement jsvOnLoadForgeView"),super.jsvOnLoadForgeView(),this.jsvMedia||this.jsvInit(),this.registerOnVisibilityChange()}jsvInit(){let e=this.jsvEventListener;if(e)for(var t in e.keys)this.jsvAddMediaListener(t)}jsvCallbackOnUnloadForgeView(){return this.jsvOnUnloadForgeView.bind(this)}jsvOnUnloadForgeView(){console.log("MediaElement jsvOnUnloadForgeView"),this.unregisterOnVisibilityChange(),this.jsvMediaView&&(this.jsvMediaView=null),this.jsvRelease()}jsvRelease(){this.jsvMedia&&(this.jsvMedia.pause(),this.jsvMedia.unload&&this.jsvMedia.unload(),this.jsvMedia.releaseResource&&(this.jsvMedia.releaseResource(),this.jsvMedia.onPlatformDestroy())),this.jsvEventListener=void 0}jsvAddMediaListener(e){}onJsViewHide(){this.jsvMedia&&(this.jsvMedia.paused||(this.stopByOnHide=!0),this.jsvMedia.unload())}onJsViewShow(){this.jsvMedia||this.jsvInit(),this.jsvMedia.src=this.srcValue,this.stopByOnHide&&(this.stopByOnHide=!1,this.jsvMedia.play())}onVisibilityChange(e){this.playBackground||("show"===e.status?this.onJsViewShow():"hide"===e.status&&this.onJsViewHide())}registerOnVisibilityChange(){window.JsView&&window.JsView.onVisibilityChange(this.onVisibilityChange)}unregisterOnVisibilityChange(){window.JsView&&window.JsView.removeEventCallback(this.onVisibilityChange)}setAttribute(e,t){"jsv_play_background"!==e?super.setAttribute(e,t):this.playBackground="true"===t}}O.HOOKS={Audio:Audio,Video:window._ExtVideo,OffscreenVideo:window._ExtOVP},O.PROP={SetOnly:["autoplay","loop","timeupdateless"],GetOnly:["duration","paused"],SetAndGet:["currentTime","muted","playbackRate","preload","volume"],Function:["load","pause","play","unload"]};for(let e in O.PROP){let t=O.PROP[e];for(let s of t){let t={};"SetOnly"!==e&&"SetAndGet"!==e||(t.set=function(e){this.jsvMedia||this.jsvInit(),this.jsvMedia[s]=e}),"GetOnly"!==e&&"SetAndGet"!==e||(t.get=function(){return this.jsvMedia||this.jsvInit(),this.jsvMedia[s]}),"Function"===e&&(t=function(...e){return this.jsvMedia||this.jsvInit(),this.jsvMedia[s]?this.jsvMedia[s](...e):null}),t instanceof Function?O.prototype[s]=t:Object.defineProperty(O.prototype,s,t)}}class S extends O{constructor(e){super(e),this.jsvOverrideMedia=!1,console.log("AudioElement.constructor()",this)}jsvGetTagName(){return j.TAG.AUDIO}jsvInit(){this.jsvOverrideMedia||(this.jsvMedia=new O.HOOKS.Audio),super.jsvInit(),this.jsvOnLoaded()}jsvOnLoaded(){this.jsvMediaView=new e.LayoutView,this.jsvMainView.AddView(this.jsvMediaView)}jsvAddMediaListener(e){this.jsvMedia||this.jsvInit(),this.jsvMedia.addEventListener(e,(()=>{let t=new i(e);t.target=this,this.dispatchEvent(t)}))}jsvRelease(){super.jsvRelease(),this.jsvMedia=null}setAttribute(e,t){super.setAttribute(e,t)}}class E{constructor(){this._PersistMap=new Map,this._PersistMax=300,this._PersistIdx=0,this._PersistTrackList=new Array(this._PersistMax),this._TempMap=new Map,this._TempMax=50,this._TempIdx=0,this._TempTrackList=new Array(this._TempMax)}getPersistPack(e){return this._PersistMap.get(e)}putPersistPack(e,t){E._putPack(this._PersistMap,this._PersistTrackList,this._PersistIdx,e,t),this._PersistIdx=(this._PersistIdx+1)%this._PersistMax}getTempPack(e){return this._TempMap.get(e)}putTempPack(e,t){E._putPack(this._TempMap,this._TempTrackList,this._TempIdx,e,t),this._TempIdx=(this._TempIdx+1)%this._TempMax}static _putPack(e,t,s,i,n){let r=t[s];r&&(e.delete(r),t[s]=i),e.set(i,n)}}let C=new E;class R extends j{constructor(){super(),this.jsvContentView=null,this.jsvRefedImgTex=null,this.jsvTextLatexEnable=!1,this.jsvEmoji=!1,this.jsvTextAlignMinWidth=NaN}jsvGetTagName(){return j.TAG.DIV}get textContent(){return this.jsvStore.textContent}set textContent(t){this.jsvStore.textContent=t,this.jsvStore.clientWidth=NaN,this.jsvContentView||(this.jsvContentView=new e.LayoutView,this.jsvMainView.AddView(this.jsvContentView)),this.parentElement&&this.jsvFlushViewForeground()}get clientWidth(){const e=this.style.width;if(e||0===e)return e;if(this.jsvStore.textContent){if(!isNaN(this.jsvStore.clientWidth))return this.jsvStore.clientWidth;const e={str:this.jsvStore.textContent,font:this.style.fontFamily,size:this.style.fontSize,italic:this.style.fontStyle,bold:this.style.fontWeight};return this.jsvStore.clientWidth=s.GetTextWidth(e),this.jsvStore.clientWidth}return super.clientWidth}jsvOnLoadForgeView(){this.style.borderImage&&(this.jsvMaskView=new e.NinePatchView),super.jsvOnLoadForgeView()}jsvCallbackOnUnloadForgeView(){return this.jsvOnUnloadForgeView.bind(this)}jsvOnUnloadForgeView(){s.UnrefImgTexSize(this.jsvRefedImgTex),this.jsvRefedImgTex=null}jsvOnStyleChanged(e){super.jsvOnStyleChanged(e),this.jsvStore.textStylePack=null;let t=!!e[y.TYPE.FOREGROUND];e[y.TYPE.LAYOUT_SIZE]&&(t||this.jsvFlushViewForeground()),e[y.TYPE.FOREGROUND]&&this.jsvFlushViewForeground(),e[y.TYPE.BORDER]&&this.jsvFlushViewBorder()}jsvFlushViewForeground(){if(this.jsvContentView&&(this.jsvContentView.ClearViews(),this.jsvStore.textContent)){let e=void 0===this.style.height||0==this.style.height,t=e?(e,t)=>{this.jsvStore.clientHeight=e.height}:null,s=this.jsvBuildTextView(t);e&&s.EnableAutoHeight(),this.jsvContentView.AddView(s)}}jsvBuildTextView(t){let i=this.jsvStore.textStylePack;if(null===i&&(i=this._jsvGetClassNameCache()),null===i){this.style.jsvCustomStyles.textLineAlign||(this.style.jsvCustomStyles.textLineAlign=this.style.lineHeight?"middle":"top"),this.style.jsvCustomStyles.textVerticalAlign||(this.style.jsvCustomStyles.textVerticalAlign="top");let t=R._jsvStyleToPackData(this.style),s=JSON.stringify(t),n=C.getTempPack(s);n||(n=e.sTextStyleCache.StyleToPack(t),C.putTempPack(s,n)),i=n}this.jsvStore.textStylePack=i;let n=this.style.lineHeight?parseInt(this.style.lineHeight):this.style.fontSize?1.3*this.style.fontSize:14,r=this.style.width;return void 0===r&&(r=this.clientWidth),this.jsvTextAlignMinWidth&&r<this.jsvTextAlignMinWidth&&(r=this.jsvTextAlignMinWidth),e.sTextUtils.BuildTextView(s.TextureManager,this.jsvStore.textContent,i,t,{width:r,height:this.style.height},this.style.fontSize,n,!0,this.jsvTextLatexEnable,this.jsvEmoji)}_jsvGetClassNameCache(){if(null===this.style.jsvNamedClassArray)return null;if(y.JsvContainsTextMajor(this.style.jsvLockedProps))return null;let t="";for(let e of this.style.jsvNamedClassArray){let s=e.getAttach();0===s.hasTextMajorStyle&&(y.JsvContainsTextMajor(e.getStyles())?s.hasTextMajorStyle=2:s.hasTextMajorStyle=1),2===s.hasTextMajorStyle&&(t+=e.getName())}if(t.length>0){let s=C.getPersistPack(t);if(!s){let i=R._jsvStyleToPackData(this.style);s=e.sTextStyleCache.StyleToPack(i),C.putPersistPack(t,s)}return s}return null}static _jsvStyleToPackData(e){let t={textColor:e.color,font:e.fontFamily,italic:"italic"===e.fontStyle,bold:"bold"===e.fontWeight,hAlign:e.textAlign?e.textAlign:"left",vAlign:e.jsvCustomStyles.textLineAlign?e.jsvCustomStyles.textLineAlign:"middle",vAreaAlign:e.jsvCustomStyles.textVerticalAlign?e.jsvCustomStyles.textVerticalAlign:"top",textOverflow:e.textOverflow?e.textOverflow:"clip",wordWrap:"break-word"===e.wordWrap?"break_word":"normal"};"nowrap"===e.whiteSpace&&(t.wordWrap="none");let s=e.textShadow?e.textShadow.split(" "):void 0;s&&(t.shadow={shadowOffsetX:parseInt(s[0]),shadowOffsetY:parseInt(s[1]),shadowBlur:parseFloat(s[2]),shadowColor:s[3]});let i=e.WebkitTextStroke?e.WebkitTextStroke.split(" "):void 0;return i&&(t.stroke={strokeWidth:parseInt(i[0]),strokeColor:i[1]}),t}jsvFlushViewBorder(){if(this.jsvMaskView)if(this.style.clipPath)console.error("BorderImage is conflicting with ClipPath.");else if(this.style.borderImage){if(!(this.jsvMaskView instanceof e.NinePatchView))return void console.error("Error: style.borderImage NOT support dynamic adding");let t=v.ConvertPx(this.getAttribute("jsv-borderimage-width")),i=v.ConvertPx(this.getAttribute("jsv-borderimage-height"));if(s.UnrefImgTexSize(this.jsvRefedImgTex),!this.jsvRefedImgTex||this.jsvRefedImgTex.Source!==this.style.borderImage.source.href){let n=t&&i?{width:t,height:i}:null;if(!this.style.borderImage.source.href)return void this.jsvMaskView.ResetTexture(null);this.jsvRefedImgTex=s.TextureManager.GetImage2(this.style.borderImage.source.href,!1,n,e.ColorSpace.RGBA_8888)}t&&i&&(console.log("Custom cache image size with: "+t+"/"+i),s.SetImgTexSize(this.jsvRefedImgTex,{width:t,height:i}));const n=new e.ExternalTextureSetting(this.jsvRefedImgTex);this.jsvMaskView.ResetTexture(n),this.jsvMaskView.WaitTextureToResize(!0),s.RefImgTexSize(this.jsvRefedImgTex,function(e){if(!this.jsvMaskView)return void console.log("Found border view gone");let t=this.style.borderImageOutset?this.style.borderImageOutset:v.ConvertRect();this.jsvMaskView.SetPadding({start:t.left,width:e.width-t.left-t.right},{start:t.top,width:e.height-t.top-t.bottom});let s=this.style.borderImage.slice;this.jsvMaskView.SetRepeat([{start:s.left,width:e.width-s.left-s.right}],[{start:s.top,width:e.height-s.top-s.bottom}]),this.jsvMaskView.WaitTextureToResize(!1)}.bind(this))}}setAttribute(e,t){this.jsvTakeTextAttribute(e,t)||super.setAttribute(e,t)}jsvTakeTextAttribute(e,t){return"jsv_text_vertical_align"===e?(this.style.jsvCustomStyles.textVerticalAlign=t,!0):"jsv_text_latex_enable"===e?(this.jsvTextLatexEnable="true"===t,!0):"jsv_text_align_minwidth"===e?(this.jsvTextAlignMinWidth=parseInt(t),!0):"jsv_text_emoji"===e&&(this.jsvEmoji="true"===t,!0)}}class P{constructor(e,t){this.RouterDelegate={ref:null},e||(this.RouterDelegate.ref=new b(!1,t))}getNodeByName(e){return this.RouterDelegate.ref.getNodeByName(e)}focusByNameBeforeMount(e,t){return this.RouterDelegate.ref.focusBeforeMount(e,t)}printFocusList(){for(let e in this.RouterDelegate.ref._ChildMap)console.log(`branchName[${e}] ${e===this.RouterDelegate.ref._FocusNodeName?"focused":""}`,this.RouterDelegate.ref._ChildMap[e])}printGlobalLastFocus(){console.log("FocusNode:"),console.log(A.sLastFocus)}}class b{constructor(e,t){this._IsTemp=!!e,this._ChildMap={},this._FocusNodeName=null,this.NameSpace=t}getNodeByName(e,t){let s=e.split(".");return this._FindRouterSearchBase(s,t)._GetNodeFromPathArray(s,e)}_FindRouterSearchBase(e,t){if(0==e[0].length){let t,s;for(let e in this._ChildMap){t=this._ChildMap[e];break}do{s=t,t=t.GetParentPage()}while(null!=t);return e.splice(0,1),s.RouterDelegate.ref}return t&&t.AsHub&&t.GetParentPage()?t.GetParentPage().RouterDelegate.ref:this}_GetNodeFromPathArray(e,t){let s=0,i=this;for(;s<e.length-1;){let n=!1;for(let t in i._ChildMap){let r=i._ChildMap[t].RouterDelegate.ref;if(r!=i&&r.NameSpace==e[s]){i=r,s++,n=!0;break}}if(!n)return void console.error(`Error: no found subpath fname=${t}`)}let n=e[s];return i._ChildMap.hasOwnProperty(n)?i._ChildMap[n]:void console.error(`Error: no found fname=${t}`)}add(e,t){e.indexOf(".")>=0?console.error("ERROR: FDiv name can not contains '.'"):this._ChildMap.hasOwnProperty(e)&&this._ChildMap[e]!==t?console.error(`ERROR: FDiv router branch name duplicated:[${e}]`):(this._ChildMap[e]=t,this._FocusNodeName==e&&t.Focus())}remove(e,t){let s=this._ChildMap[e];s&&s==t&&delete this._ChildMap[e]}rename(e,t){if(!this._ChildMap.hasOwnProperty(e))return void console.error(`ERROR: alter name failed ${e}->${t}`);let s=this._ChildMap[e];delete this._ChildMap[e],this.add(t,s),this._FocusNodeName==e&&(this._FocusNodeName=t)}focusBeforeMount(e,t){if(e.indexOf(".")>=0)return console.error("ERROR: not support name with namespace"),!1;let s=this._ChildMap[e];return this._FocusNodeName=e,!!s&&(s.Focus(!t),!0)}focus(e,t){let s=this.focusBeforeMount(e,t);return s||console.log("No found branch:"+e),s}forEach(e){for(let t in this._ChildMap)e(this._ChildMap[t],t,this._ChildMap)}printNodes(){console.log(this._ChildMap)}}class A extends e.PageBase{constructor(e){super(e),this._OnKeyDown=null,this._OnKeyUp=null,this._OnFocus=null,this._OnBlur=null,this._DispatchKeyDown=null,this._DispatchKeyUp=null,this._DKeyDownProxy=void 0,this._DKeyUpProxy=void 0,this._Mounted=!1,this.BranchName=e,this.AsHub=!1,this.InterfaceHub=null,this.RouterDelegate={ref:null},this._TmpRouter=null,this._OriginDispatchKeyDown=this._OriginDispatchKeyDown.bind(this),this._OriginDispatchKeyUp=this._OriginDispatchKeyUp.bind(this),this._AutoShow=!1}updateMountState(){this._Mounted=!0;let e=this.SubPages;for(let t in e)e[t].updateMountState()}getHub(){return this.InterfaceHub||(this.InterfaceHub=new P(!0),this.InterfaceHub.RouterDelegate=this.RouterDelegate),this.InterfaceHub}setHub(e){this.RouterDelegate.ref?console.error("Error: hub is already setted."):(this.RouterDelegate.ref=e.RouterDelegate.ref,this.AsHub=!0)}_UseParentRouter(e){this.RouterDelegate=e,this.InterfaceHub&&(this.InterfaceHub.RouterDelegate=e)}routerAdd(e,t){t.RouterDelegate.ref||t._UseParentRouter(this.RouterDelegate),this.RouterDelegate.ref||(this.RouterDelegate.ref=new b(!0)),this.RouterDelegate.ref.add(e,t)}routerRenameChild(e,t){this.RouterDelegate.ref.rename(e,t)}printFocusList(){this.RouterDelegate.ref?this.RouterDelegate.ref.printFocusList():console.error("Error: no router")}routerUnbind(){let e;this.AsHub?this.GetParentPage()&&(e=this.GetParentPage().RouterDelegate.ref):e=this.RouterDelegate.ref,e&&e.remove(this.BranchName,this)}setBranchName(e){if(e===this.BranchName)return;let t=this.BranchName;this.BranchName=e,this.PageName=e,this._ParentPage&&this._ParentPage.routerRenameChild(t,e)}setOnKeyDown(e){this._OnKeyDown=e}setOnKeyUp(e){this._OnKeyUp=e}setOnFocus(e){this._OnFocus=e}setOnBlur(e){this._OnBlur=e}setDispatchKeyUp(e){this._DispatchKeyUp=e}setDispatchKeyDown(e){this._DispatchKeyDown=e}setDispatchKeyProxy(e,t){this._DKeyDownProxy=e,this._DKeyUpProxy=t}requestFocus(e){let t=this.RouterDelegate.ref;return this.AsHub&&this.GetParentPage()&&(t=this.GetParentPage().RouterDelegate.ref),t?t.focus(this.BranchName,e):(console.error("error: lost router"),!1)}OnKeyDown(e){return!!this._OnKeyDown&&this._OnKeyDown(e)}OnKeyUp(e){return!!this._OnKeyUp&&this._OnKeyUp(e)}dispatchKeyDown(e){return this.DispatchKeyDown(e)}DispatchKeyDown(e){return A.sLastFocus=this,this._DKeyDownProxy?this._DKeyDownProxy(e,this._OriginDispatchKeyDown):this._OriginDispatchKeyDown(e)}_OriginDispatchKeyDown(e){let t=!1;return this._DispatchKeyDown&&(t=this._DispatchKeyDown(e)),!!t||super.DispatchKeyDown(e)}dispatchKeyUp(e){return this.DispatchKeyUp(e)}DispatchKeyUp(e){return this.__DKeyUpProxy?this.__DKeyUpProxy(e,this._OriginDispatchKeyUp):this._OriginDispatchKeyUp(e)}_OriginDispatchKeyUp(e){let t=!1;return this._DispatchKeyUp&&(t=this._DispatchKeyUp(e)),!!t||super.DispatchKeyUp(e)}attachToActivity(e,t){this.AttachToActivity(e,t)}AttachToActivity(e,t){super.SetParent(e,t)}setParent(e){this.SetParent(e)}SetParent(e){if(null!=e&&(super.SetParent(e,null),this._ParentPage._Mounted&&(this.updateMountState(),I()),e instanceof A)){if(this.RouterDelegate.ref&&this.RouterDelegate.ref._IsTemp){let t=this.RouterDelegate.ref;this.RouterDelegate.ref=null,t.forEach(((t,s)=>{e.routerAdd(s,t)}))}e.routerAdd(this.BranchName,this)}}focus(e){this.Focus(e)}Focus(e){if(!this._Mounted)return A.sFocusMemos.push({obj:this,bcf:e}),void console.log("page base tree not build, cache focus");super.Focus(e)}OnFocus(){this._OnFocus&&this._OnFocus()}OnBlur(){this._OnBlur&&this._OnBlur()}onUnMount(){let e=this.GetParentPage();e&&e.RemoveSubPage(this),this.ClearSubPages(),this.routerUnbind()}getName(){let e=this,t=[this.RouterDelegate.ref.NameSpace];this.AsHub||t.push(this.BranchName);let s=this.RouterDelegate.ref;do{if(e=e.GetParentPage(),"__AppRoot__"==t[0])break;e&&e.RouterDelegate.ref!=s&&(s=e.RouterDelegate.ref,t.unshift(s.NameSpace))}while(e);return"__AppRoot__"==t[0]?t[0]="":console.error("ERROR: missing app root"),t.join(".")}getNodeByName(e){return this.RouterDelegate.ref.getNodeByName(e,this)}printFocusNodeList(){this.getHub().printFocusList()}printGlobalLastFocus(){this.getHub().printGlobalLastFocus()}}A.sFocusMemos=[],A.sLastFocus=null,A.sRootPageNode=null;let I=()=>{let e=A.sFocusMemos.length;if(e>0){let t=A.sFocusMemos;A.sFocusMemos=[];for(let s=0;s<e;s++)t[s].obj.Focus(t[s].bcf)}},M=1;class V extends j{constructor(){super(),this.FocusNodeRef=new A(""+M++),this.HubRef=void 0}jsvGetTagName(){return j.TAG.FDIV}setAttribute(e,t){if(e)if("fname"===e)t&&this.FocusNodeRef.setBranchName(t);else if("new-namespace"===e&&""!==t&&!this.HubRef){let e=new P(!1,t);this.HubRef=e,this.FocusNodeRef.setHub(e),this.FocusNodeRef.setBranchName(t)}}jsvGetHub(){return this.HubRef}}class N{constructor(){this.src=null,this.onerror=null,this.onload=null}setAttribute(e,t){console.log("LinkElement.setAttribute() name="+e+", value=",t),this[e]=t}jsvLoadResource(){let e=!1,s=null;if(null!=this.href){var i=new t(this.href);console.log("Ignore to load link from url="+i.href),e=!0}else console.warn("Failed to load link, href is not exists."),s="NoSrc";this.jsvOnLoadResult(e,s)}jsvOnLoadResult(e,t){if(console.log("jsvOnLoadResult isSuccess:"+e+", errCode:"+t),e){if(this.onload){let e=new i("load");this.onload(e)}}else this.onerror&&this.onerror({type:"jsvErr_"+t,target:this})}}class x{constructor(){this.src=null,this.onerror=null,this.onload=null,this.charset=null,this.timeout=120}setAttribute(e,t){console.log("ScriptElement.setAttribute() name="+e+", value=",t),this[e]=t}jsvLoadResource(){if(null!=this.src){var e=new t(this.src);console.log("load script with url="+e.href);var s=this;window.JsView.runJsWithUrl(e.href,!1,((e,t)=>{s.jsvOnLoadResult(e,t)}))}}jsvOnLoadResult(e,t){if(console.log("onLoadResult "+e+" "+t),e){if(this.onload){let e=new i("load");this.onload(e)}}else this.onerror&&this.onerror({type:"jsvErr_"+t,target:this})}}class L extends j{constructor(){super(),console.log("Document header construct")}appendChild(e){"HTMLScriptElement"==e.constructor.name||"HTMLStyleElement"==e.constructor.name||"HTMLLinkElement"==e.constructor.name?window.originDocument.headAppendChild(e):super.appendChild(e),(e instanceof N||e instanceof x)&&e.jsvLoadResource()}removeChild(e){"HTMLScriptElement"==e.constructor.name||"HTMLStyleElement"==e.constructor.name||"HTMLLinkElement"==e.constructor.name?window.originDocument.headRemoveChild(e):super.removeChild(e)}}class D extends i{constructor(e){super("load")}}class _ extends j{constructor(t){super(t),this.jsvImageView=new e.LayoutView(null,"img"),this.jsvMainView.AddView(this.jsvImageView),this._ImageInLoading=!1,this.jsvColorSpace=e.ColorSpace.RGBA_8888,this.jsvScaleDownTex=null,this._HasUserOnLoad=!1,this._OnLoadSeq=1}jsvGetTagName(){return j.TAG.IMAGE}setAttribute(e,t){this.jsvTakeTextureAttribute(e,t)?console.assert(!this._ImageInLoading,`set ${e} after src`):(super.setAttribute(e,t),e===j.ATTRIBUTE.SRC&&(this._ImageInLoading=!0,this.jsvStore.textureWidth=NaN,this.jsvStore.textureHeight=NaN,this.jsvDrawImage()))}jsvSetElementProp(e){this.jsvImageView.SetElementProp(e,s.RootActivity)}jsvCallbackOnUnloadForgeView(){return()=>{if(this._HasUserOnLoad){let e=this.jsvImageView?.TextureSetting?.Texture;e&&e.DisableBackgroundLoad(this)}}}jsvFlushEventHandlers(){if(super.jsvFlushEventHandlers(),this.eventHandlers.onLoad){let e=this.jsvImageView?.TextureSetting?.Texture;e&&(this._HasUserOnLoad=!0,e.EnableBackgroundLoad(this))}else if(this._HasUserOnLoad){let e=this.jsvImageView?.TextureSetting?.Texture;e&&e.DisableBackgroundLoad(this),this._HasUserOnLoad=!1}}jsvTakeTextureAttribute(e,t){return"jsv_img_color_space"==e||"jsvImgColorSpace"==e||"jsv-img-color-space"==e?(this.jsvColorSpace=t,!0):("jsv_img_scaledown_tex"==e||"jsvImgScaledownTex"==e||"jsv-img-scaledown-tex"==e)&&(""!==t&&void 0!==t||(t="true"),this.jsvScaleDownTex=t,!0)}jsvFlushViewLayout(){this._ImageInLoading?(this.jsvImageView.WaitTextureToResize(!0),this.jsvImageView.ResetLayoutParams({x:0,y:0,width:this.style.width,height:this.style.height})):this.jsvImageView.WaitTextureToResize(!1),super.jsvFlushViewLayout()}jsvFlushViewBackground(){this.jsvDrawImage();this.getAttribute(j.ATTRIBUTE.SRC)}jsvOnLoaded(e){if(console.log("ImageElement.jsvOnLoaded() imageSize="+JSON.stringify(e)),this._ImageInLoading=!1,this.jsvStore.textureWidth=e.width,this.jsvStore.textureHeight=e.height,this.style.jsvLazySyncCache.setCacheProperty(y.TYPE.LAYOUT_SIZE,!0),this._HasUserOnLoad){let e=new D;e.target=this,document.dispatchEvent(e)}}jsvOnLoadForgeView(){this.style.objectFit||this.style.jsvSetPropertySilently("objectFit",y.ObjectFit.FILL),super.jsvOnLoadForgeView()}jsvApplyObjectFit(e){return j.applyObjectFitCommon(this,e,this.jsvImageView)}jsvDrawImage(){if(!this.src)return;let e=null;"true"===this.jsvScaleDownTex&&(this.style&&this.style.width?e={width:this.style.width,height:0}:console.error("set jsvScaleDownTex while style.width is not set")),this._OnLoadSeq++;let t=this._OnLoadSeq;s.SetBackgroundImage(this.jsvImageView,this.src,this.style.borderRadius,(e=>{t===this._OnLoadSeq&&this.jsvOnLoaded(e)}),e,this.jsvColorSpace)}}class F extends j{constructor(t){super(),this.jsvMainView=new e.JsvElementView(t)}get textContent(){return this.jsvMainView.textContent}set textContent(e){this.jsvMainView.textContent=e}setAttribute(e,t){super.setAttribute(e,t),this.jsvMainView.setAttribute(e,t)}removeAttribute(e){super.removeAttribute(e),this.jsvMainView.removeAttribute(e)}getAttribute(e){return this.jsvMainView.getAttribute(e)}hasAttribute(e){return this.jsvMainView.hasAttribute(e)}jsvOnStyleChanged(e){super.jsvOnStyleChanged(e)}}class k{constructor(e){let t=e.indexOf(k.KeyFramesFlag)+k.KeyFramesFlag.length,s=e.indexOf("{"),i=e.substring(t,s);this.name=i.trim(),this.cssText=e}}k.KeyFramesFlag="@keyframes";class U{constructor(e){this.jsvCssRules=null,this.jsvTextContent=e}get cssRules(){if(this.jsvCssRules)return this.jsvCssRules;this.jsvCssRules=new Array;if(this.jsvTextContent.indexOf(k.KeyFramesFlag)<0)return this.jsvCssRules;var e=this.jsvTextContent.split(k.KeyFramesFlag);for(let t in e)0!=t&&this.insertRule(k.KeyFramesFlag+e[t]);return this.jsvCssRules}insertRule(e,t){if(void 0===t&&(t=this.jsvCssRules.length),e.indexOf(k.KeyFramesFlag)<0)throw Error("StyleSheet.insertRule() Rule is not supported except keyframes.");let s=new k(e);this.jsvCssRules.splice(t,0,s)}deleteRule(e){this.jsvCssRules.splice(e,1)}}class G extends j{constructor(e){super(e),this.textContent=null}jsvGetTagName(){return j.TAG.STYLE}appendChild(e){super.appendChild(e);let t=new U(e.textContent);document.jsvAppendStyleSheet(t)}removeChild(e){throw super.removeChild(e),Error("Failed to removeChild, unimplement!.")}}class H extends j{}class B extends O{constructor(e){super(e),console.log("VideoElement.constructor()",this),this._EventCache=[],this._UseTexture=!1,this._StartTime=0}jsvGetTagName(){return j.TAG.VIDEO}setAttribute(e,t){("jsv-media-usetexture"!==e||"true"!==t&&!0!==t&&""!==t)&&("jsv_media_usetexture"!==e||"true"!==t)?super.setAttribute(e,t):this._UseTexture=!0}removeAttribute(e){if("jsv-media-usetexture"===e||"jsv_media_usetexture"===e)return this._UseTexture=!1,void console.log("removeAttribute jsv_media_usetexture");super.removeAttribute(e)}jsvFlushViewLayout(){super.jsvFlushViewLayout();let e=this.style.JsvVideoRotation;isNaN(e)&&(e=0),this.style.objectFit!=y.ObjectFit.CONTAIN&&this.style.objectFit!=y.ObjectFit.FILL&&(console.error("Video rotation is not valid on objectFit="+this.objectFit),e=0),this.jsvMedia&&this.jsvMedia.setRotation(e,this.style.width,this.style.height,this.style.objectFit==y.ObjectFit.FILL)}jsvAddMediaListener(e){this.jsvMedia?this.jsvMedia.addEventListener(e,(()=>{let t=new i(e);t.target=this,this.dispatchEvent(t)})):this._EventCache.push(e)}jsvFlushVideoView(){this.jsvMediaView&&(this.jsvStore.textureWidth=this.jsvMedia.videoWidth,this.jsvStore.textureHeight=this.jsvMedia.videoHeight,this.style.jsvLazySyncCache.setCacheProperty(y.TYPE.LAYOUT_SIZE,!0))}jsvApplyObjectFit(e){return j.applyObjectFitCommon(this,e,this.jsvMediaView)}jsvInit(){console.log("VideoElement jsvInit"),this._UseTexture?this.jsvMedia=new O.HOOKS.OffscreenVideo:this.jsvMedia=new O.HOOKS.Video,this._EventCache.length>0&&(this._EventCache.map((e=>{this.jsvAddMediaListener(e)})),this._EventCache=[]),this.addEventListener("load",this.jsvOnLoaded.bind(this)),super.jsvInit()}jsvRelease(){super.jsvRelease(),this.jsvMedia=null}jsvOnLoaded(){if(!this.jsvMediaView){let t;if(this._UseTexture){this.jsvMediaView=new e.LayoutView;let i,n=s.TextureManager.GetOffScreenMediaTexture(this.jsvMedia),r=this.style.borderRadius;r&&(i=new e.ViewRoundCornerMask(r.topLeft,r.topRight,r.bottomLeft,r.bottomRight)),t=new e.TextureSetting(n,i)}else{this.jsvMediaView=new e.VideoView(this.jsvMedia);let i=s.TextureManager.GetColorTexture("rgba(0,0,0,0)");t=new e.TextureSetting(i,null,null,!1)}this.jsvMainView.AddView(this.jsvMediaView),this.jsvMediaView.ResetTexture(t)}this.jsvFlushVideoView()}jsvOnLoadForgeView(){this.style.objectFit||this.style.jsvSetPropertySilently("objectFit",y.ObjectFit.CONTAIN),super.jsvOnLoadForgeView()}onJsViewHide(){this._StartTime=this.jsvMedia.currentTime,super.onJsViewHide(),this.jsvMedia.setState("autoPlay",!1,"boolean")}onJsViewShow(){this.jsvMedia||this.jsvInit(),this.jsvMedia.src=this.srcValue,this.jsvMedia.startTime=Math.max(this._StartTime-1,0),this._StartTime=0,this.stopByOnHide&&(this.stopByOnHide=!1,this.jsvMedia.play())}}B.PROP={SetOnly:[],GetOnly:["videoHeight","videoWidth"],SetAndGet:["height","poster","width"]};for(let e in B.PROP){let t=B.PROP[e];for(let s of t){let t={};"SetOnly"!==e&&"SetAndGet"!==e||(t.set=function(e){this.media[s]=e}),"GetOnly"!==e&&"SetAndGet"!==e||(t.get=function(){return this.media[s]}),B.prototype[s]=t}}B.EVENTS=["oncanplay","oncanplaythrough","ondurationchange","onended","onerror","onload","onloadedmetadata","onloadstart","onpause","onplay","onplaying","onprogress","onseeking","onseeked","onstalled","ontimeupdate"];class K extends u{constructor(e){super(u.TEXT_NODE),this.textContent=e}get nodeValue(){return this.textContent}set nodeValue(e){this.textContent=e,this.parentNode&&(this.parentNode.textContent=this.textContent)}}class W extends u{constructor(e){super(u.COMMENT_NODE),this.textContent=e}}let J={};class z{constructor(e,t,s){this._Element=s,J.hasOwnProperty(e)&&console.error(`Warn: FDivRoot duplicate name=${e}`),J[e]=this,this._DoInit(t)}_DoInit(e){let t=this._Element.FocusNodeRef;if(this._Element.setAttribute("new-namespace","__AppRoot__"),e&&t.setDispatchKeyProxy(e.keyDown,e.keyUp),window.JsView){let e=window.JsView.ForgeExt;t.attachToActivity(e.RootActivity,e.RootView)}else window.addEventListener("keydown",(e=>{var s=document.activeElement.tagName;s&&"input"===s.toLowerCase()||(t.dispatchKeyDown(e),e.preventDefault&&e.preventDefault())})),window.addEventListener("keyup",(e=>{var s=document.activeElement.tagName;s&&"input"===s.toLowerCase()||(t.dispatchKeyUp(e),e.preventDefault&&e.preventDefault())}))}getElement(){return this._Element}getHub(){return this._Element.jsvGetHub()}onMounted(){this._Element.FocusNodeRef.updateMountState(),I()}}class Y extends S{constructor(e){super(e),console.log("AudioElement.constructor()",this)}jsvGetTagName(){return j.TAG.AUDIOTRACK}jsvInit(){this.jsvMedia=new O.HOOKS.Audio("AudioTrack"),this.jsvOverrideMedia=!0,super.jsvInit()}}class X extends u{constructor(){console.log("Document.constructor()"),super(u.DOCUMENT_NODE),this.location=window.location,this.rootElement=new R,this.rootElement.ownerDocument=this,this.rootElement.id="root",this.activeElement=this.rootElement,this.head=new L,this.cookie="",this.styleSheets=new Array,this.jsvIsReady=!1}createElement(e){switch(e){case X.FDIV_ELEMENT:return new V;case X.DIV_ELEMENT:return new R;case X.IMG_ELEMENT:case X.FIMG_ELEMENT:return new _;case X.STYLE_ELEMENT:return new G;case X.AUDIO_ELEMENT:return new S;case X.AUDIOTRACK_ELEMENT:return new Y;case X.VIDEO_ELEMENT:return new B;case X.LINK_ELEMENT:return window.JsView?new N:window.originDocument.createElement(X.LINK_ELEMENT);case X.SCRIPT_ELEMENT:return window.JsView?new x:window.originDocument.createElement(X.SCRIPT_ELEMENT);case X.ANCHOR_ELEMENT:return new T;case X.SVG_ELEMENT:return new SVGElement;default:return 0!==e.indexOf("jsv")||window.JsView?(console.warn("Document.createElement() unknown name="+e),new H(e)):new F(e)}}createTextNode(e){return new K(e)}createEvent(e){return new i(e)}createComment(e){return new W(e)}getElementById(e){if("root"===e||"app"===e)return this.rootElement;throw Error("Document.getElementById() id="+e+" is UNIMPLEMENTED.")}getElementsByTagName(e){if("head"===e.toLowerCase())return window.JsView?[this.head]:window.originDocument.getElementsByTagName(e);if("link"===e.toLowerCase()||"script"===e.toLowerCase()||"style"===e.toLowerCase())return[];throw Error("Document.getElementsByTagName() name="+e+" is UNIMPLEMENTED.")}querySelector(e){if("root"===e||"#app"===e)return this.rootElement;if("head"===e)return this.head;if("base"===e)return null;if(e.startsWith("style[")&&e.endsWith("]"))return null;throw Error("Document.querySelector() selectors="+e+" is UNIMPLEMENTED.")}jsvAppendStyleSheet(e){document.styleSheets.push(e)}jsvGetKeyFrames(e,t){if(window.JsvCode.Dom.StyleSheets){const s=window.JsvCode.Dom.StyleSheets;for(const i of t){const t=s[`${e}-${i.replace("data-v-","")}`];if(t)return t}const i=s[e];if(i)return i}for(let t of this.styleSheets)for(let s of t.cssRules)if(s.name==e)return s.cssText;let s="@keyframes ",i=s+e;for(let e of this.styleSheets){let t=e.jsvTextContent,n=t.indexOf(i);if(n<0)continue;let r=t.indexOf("-keyframes",n+1),o=t.indexOf(s,n+1);o<0&&(o=t.length),r>0&&r<o&&(o=r);let a=t.substring(n,o);return e.insertRule(a,0),a}return null}jsvUpdateRootElement(e){console.log("Document.jsvUpdateRootElement() this.jsvIsReady = true"),this.rootElement.jsvMainView=e,this.jsvIsReady=!0}jsvInitFDivRoot(e,t,s){if(!s){let e=document.createElement("fdiv");this.rootElement.appendChild(e),this.rootElement=e,s=this.rootElement}return new z(e,t,s)}jsvGetFDivRoot(e){return function(e){return J[e]}(e)}}X.ANCHOR_ELEMENT="a",X.AUDIO_ELEMENT="audio",X.DIV_ELEMENT="div",X.IMG_ELEMENT="img",X.LINK_ELEMENT="link",X.SCRIPT_ELEMENT="script",X.STYLE_ELEMENT="style",X.SVG_ELEMENT="svg",X.VIDEO_ELEMENT="video",X.FIMG_ELEMENT="fimg",X.FDIV_ELEMENT="fdiv",X.AUDIOTRACK_ELEMENT="audiotrack";class $ extends j{jsvGetTagName(){return j.TAG.LINK}}if(window.JsvCode={Dom:{StyleSheets:{}}},window.Audio=S,window.Video=B,window.MutationObserver=class{constructor(e){this.callback=e}observe(e,t){if(!(e instanceof u))throw Error("TypeError: Failed to execute 'observe' on 'MutationObserver': parameter 1 is not of type JsView's 'Node'");for(const e of Object.keys(t))"childList"==e||console.warn("JsView: only childList config is supported! ignore "+e);t.childList&&e.jsvObserveChildChanged((()=>{this.callback?.()}))}disconnect(){this.callback=void 0}},window.JsView){console.log("Declare Dom Proxy."),global.SVGElement=$,global.Element=j;let e=new t(window.JsView.getAppUrl(),!0);window.location.applyUrlInfo?window.location.applyUrlInfo(e):window.location=e,window.addEventListener=function(e,t){},window.document=new X,window.history={},window.navigator={userAgent:"jsview-runtime"},window.HTMLIFrameElement=function(){}}h.I("Using JsView Runtime");export{X as Document,s as ForgeExtension,L as HeadElement,l as JsViewForgeApp,o as JsvLazySyncCache,h as Log,r as gSyncTimesCounter};
1
+ void 0===window.Forge&&(window.Forge={});var t=window.Forge;class e{constructor(t,e){if(this.href="",this.origin="",this.protocol="",this.host="",this.hostname="",this.port="",this.pathname="",this.search="",this.hash="",!t)return;if(!0===t.startsWith("url")){let e=t.indexOf("(")+1,s=t.lastIndexOf(")");if("undefined"===(t=t.substring(e,s).trim())||"null"===t||0===t.length)return}if(!0===t.startsWith("data:"))return void(this.href=t);let s=t.indexOf("://");if(!(s<0||s>10)||t.startsWith("./")||t.startsWith("/")||(t="./"+t),!0===t.startsWith("/"))t=document.location.origin+t;else if(!0===t.startsWith("./")&&void 0!==window.JsView&&void 0!==window.JsView.Dom.JsSubPath){if(void 0===window.JsView.Dom.__MainPath||"undefined"===window.JsView.Dom.__MainPathRef||window.JsView.Dom.__MainPathRef!==document.location.href){window.JsView.Dom.JsSubPath.startsWith("/")||(window.JsView.Dom.JsSubPath="/"+window.JsView.Dom.JsSubPath),window.JsView.Dom.JsSubPath.endsWith("/")||(window.JsView.Dom.JsSubPath=window.JsView.Dom.JsSubPath+"/"),window.JsView.Dom.__MainPathRef=document.location.href;let t=document.location.pathname.lastIndexOf(window.JsView.Dom.JsSubPath);window.JsView.Dom.__MainPath=document.location.origin+document.location.pathname.substring(0,t)}t=window.JsView.Dom.__MainPath+t.substring(1)}if(this.href=t,!e)return;let i=this.href,n=i.indexOf("#");n>0&&(this.hash=i.substring(n),i=i.substring(0,n));let r=i.indexOf("?");r>1&&(this.search=i.substring(r),i=i.substring(0,r));let o=i,a=o.indexOf("://");this.protocol=a>0?o.substring(0,a+1):"";let l=a>1?o.substring(a+3):"";a=l.indexOf("/"),this.host=a>0?l.substring(0,a):"",this.pathname=a>1?l.substring(a):"",this.origin=a>0?this.protocol+"//"+this.host:"",a=this.host.indexOf(":"),this.hostname=a>0?this.host.substring(0,a):this.host,this.port=a>1?this.host.substring(a+1):""}replace(t){this.href=t}}class s{static SetBackgroundColor(e,i,n){const r=s.TextureManager.GetColorTexture(i);let o;n&&(o=new t.ViewRoundCornerMask(n.topLeft,n.topRight,n.bottomLeft,n.bottomRight));const a=new t.TextureSetting(r,o);e.ResetTexture(a)}static SetBackgroundImage(i,n,r,o,a,l){if("string"==typeof n&&(n=new e(n)),n instanceof e==!1)throw Error("Bad Argument.",n);let h;if(h=n.href.endsWith("gif")||n.href.endsWith("webp")?s.TextureManager.GetGifImage(n.href,!1,null):s.TextureManager.GetImage2(n.href,!1,a,l||t.ColorSpace.RGBA_8888),h){let e;r&&(e=new t.ViewRoundCornerMask(r.topLeft,r.topRight,r.bottomLeft,r.bottomRight));const s=new t.ExternalTextureSetting(h,e);if(i.ResetTexture(s),o){let t=h.RegisterLoadImageCallback(null,(function(){o({width:h.Width,height:h.Height})}));i.RegisterDetachCallback((()=>{h.UnregisterLoadImageCallback(t)}))}}}static SetMaskedBackgroundImage(i,n,r,o){if("string"==typeof n&&(n=new e(n)),n instanceof e==!1)throw Error("Bad Argument.",n);if("string"==typeof r&&(r=new e(r)),r instanceof e==!1)throw Error("Bad Argument(MaskURL).",r);const a=s.TextureManager.GetImage2(n.href,!1,null,o||t.ColorSpace.RGBA_8888);if(a){const e=s.TextureManager.GetImage2(r.href,!1,null,t.ColorSpace.RGBA_8888),n=new t.ExternalTextureSetting(a,new t.ViewTextureMask(e));i.ResetTexture(n)}}static SetVideoTexture(e,i,n){const r=s.TextureManager.GetColorTexture(i);let o;n&&(o=new t.ViewRoundCornerMask(n.topLeft,n.topRight,n.bottomLeft,n.bottomRight));const a=new t.TextureSetting(r,o);e.ResetTexture(a)}static GetTextWidth(e){return e.str||(e.str=""),e.font||(e.font=t.TextUtils._sDefaultFont),e.size||(e.size=t.TextUtils._sDefaultFontSize),"italic"!==e.italic&&(e.italic=""),"bold"!==e.bold&&(e.bold=""),window.PlatformUtils.GetTextWidth(e)}static RequestSwap(){t.sRenderBridge.RequestSwap()}static SetImgTexSize(t,e){let i={size:e,refNum:0};s.TextureInfo.Cache[t.Source]=i}static RefImgTexSize(t,e){let i=s.TextureInfo.Cache[t.Source];i?(i.refNum>0?i.refNum++:i.refNum=1,e(i.size)):t.RegisterLoadImageCallback(null,(function(){const i={width:t.Width,height:t.Height};e(i);let n=s.TextureInfo.Cache[t.Source];if(n)n.refNum>0?n.refNum++:n.refNum=1;else{let e={size:i,refNum:1};s.TextureInfo.Cache[t.Source]=e}}))}static UnrefImgTexSize(t){if(!t)return;let e=s.TextureInfo.Cache[t.Source];e&&(e.refNum--,e.refNum<=0&&s.TextureInfo.Unused.add(t.Source))}static ClearUnusedTexSize(){for(let t of s.TextureInfo.Unused){let e=s.TextureInfo.Cache[t];e.refNum<-2?(delete s.TextureInfo.Cache[t],s.TextureInfo.Unused.delete(t)):e.refNum<=0?e.refNum--:s.TextureInfo.Unused.delete(t)}}}s.TextureInfo={Cache:{},Unused:new Set},s.TextureManager=null,s.RootView=null,s.RootActivity=null,s.HaltKeyEvent=!1;class i{constructor(t){this.target=null,this.timeStamp=Date.now(),this.type=t}initEvent(t,e,s){this.type=t}}class n extends i{constructor(t){super(t),this.keyCode=-1,this.key=-1,this.repeat=0}static JsvGetKeyFromCode(t){return new Map([[n.KeyCode.Enter,n.Key.Enter],[n.KeyCode.ArrowUp,n.Key.ArrowUp],[n.KeyCode.ArrowDown,n.Key.ArrowDown],[n.KeyCode.ArrowLeft,n.Key.ArrowLeft],[n.KeyCode.ArrowRight,n.Key.ArrowRight]])[t]}}n.Type={KEYDOWN:"keydown",KEYUP:"keyup"},n.Key={Enter:"Enter",ArrowUp:"ArrowUp",ArrowDown:"ArrowDown",ArrowLeft:"ArrowLeft",ArrowRight:"ArrowRight"},n.KeyCode={Enter:13,ArrowUp:38,ArrowDown:40,ArrowLeft:37,ArrowRight:39};let r={cnt:0};class o{constructor(t){this.type=t,this.cachedValues=null,this.onSyncCallback=null}setOnSyncCallback(t){this.onSyncCallback=t,this.syncLastCaches(!0)}setCacheProperty(t,e){this.cachedValues||(this.cachedValues={}),this.cachedValues[t]=e,this.syncLastCaches(!1),s.RequestSwap()}syncLastCaches(t){let e=o.LastModified[this.type];if((t||e!==this)&&(o.LastModified[this.type]=this,e&&e.cachedValues&&"function"==typeof e.onSyncCallback)){let t=e.cachedValues;e.cachedValues=null,e.onSyncCallback(t)}}static SyncAllCachedProperty(){for(let t of Object.values(o.LastModified))t.syncLastCaches(!0);r.cnt=(r.cnt+1)%65535}}o.LastModified={};class a{constructor(e){this.activity=new t.ReactActivity("JsViewForgeActivity",e,this.OnKeyDown.bind(this),this.OnKeyUp.bind(this)),this._Init()}_Init(){console.log("JsViewForgeActivity.OnCreate()."),s.TextureManager=this.activity.GetTextureManager(),s.RootView=new t.LayoutView,s.RootActivity=this.activity,document.jsvUpdateRootElement(s.RootView);let e=null;t.DesignMap&&(e=t.DesignMap());let i=e?e.width:1280,n=Math.floor(9*i/16);this.activity.SetContentView(s.RootView,{x:0,y:0,width:i,height:n}),t.sRenderBridge.AddWillSwapListener("forgeSwap",(()=>{o.SyncAllCachedProperty(),s.ClearUnusedTexSize()})),window.JsView.Dom.Render()}OnKeyDown(t){if(s.HaltKeyEvent){let e=new n(n.Type.KEYDOWN);return e.keyCode=t.keyCode,e.repeat=t.repeat,document.dispatchEvent(e),!0}return!1}OnKeyUp(t){if(s.HaltKeyEvent){let e=new n(n.Type.KEYUP);return e.keyCode=t.keyCode,e.key=n.JsvGetKeyFromCode(e.keyCode),e.repeat=t.repeat,document.dispatchEvent(e),!0}return!1}}class l{constructor(e){this._ActivityManager=e;let s=new a(e);e.RegisterActivity(s.activity),e.StartActivity(new t.Intent("JsViewForgeActivity"))}}window.JsView&&(window.JsView.Dom={DesignMap:null,Render:null,Extension:s,UrlRef:e},window.JsView.React=window.JsView.Dom);class h{static SetLevel(t){switch(h.E=h.W=h.I=h.D=function(){},t){case h.Level.Verbose:h.V=console.debug.bind(console);case h.Level.Debug:h.D=console.debug.bind(console);case h.Level.Info:h.I=console.info.bind(console)}}static Throw(...t){throw console.error(...t),[...t]}}h.E=console.error.bind(console),h.W=console.warn.bind(console),h.I=console.info.bind(console),h.D=function(){},h.V=function(){},h.Level={Error:0,Warning:1,Info:2,Debug:3,Verbose:4};class u{constructor(t){this.ownerDocument=window.document,this.nodeType=t,this.parentNode=void 0,this.childNodes=[],this.jsvEventListener=void 0,this.jsvChildChangedCallback=void 0}jsvGetTagName(){return"Unknown"}appendChild(t){this.childNodes.push(t),t.parentNode=this,this.jsvChildChangedCallback?.()}removeChild(t){let e=this.childNodes.indexOf(t);e<0&&h.Throw("Failed to call Node.removeChild(), node not found. node=",t),this.childNodes.splice(e,1),t.parentNode=void 0,this.jsvChildChangedCallback?.()}insertBefore(t,e){let s=this.childNodes.length;void 0===e?h.Throw("TypeError: Failed to execute 'insertBefore' on 'Node': 2 arguments required, but only 1 present."):null!==e&&(s=this.childNodes.indexOf(e)),s<0&&h.Throw("Failed to call Node.insertBefore(), before node not found. beforeNode=",e),this.childNodes.splice(s,0,t),t.parentNode=this,this.jsvChildChangedCallback?.()}get previousSibling(){const t=this.parentNode.childNodes;let e=t.indexOf(this);return e<0&&h.Throw("Failed to call Node.previousSibling(), this node not found. this=",this),t[e-1]}get nextSibling(){const t=this.parentNode.childNodes;let e=t.indexOf(this);return e<0&&h.Throw("Failed to call Node.nextSibling(), this node not found. this=",this),t[e+1]}addEventListener(t,e,s){this.jsvEventListener||(this.jsvEventListener={});let i=this.jsvEventListener[t];i||(i=new Set,this.jsvEventListener[t]=i),i.add(e)}removeEventListener(t,e,s){if(!this.jsvEventListener)return;let i=this.jsvEventListener[t];i&&(i.delete(e),i.size<=0&&this.jsvEventListener.hasOwnProperty(t)&&delete this.jsvEventListener[t],0===Object.values(this.jsvEventListener).length&&(this.jsvEventListener=void 0))}dispatchEvent(t){if(!this.jsvEventListener)return void console.warn("Node.dispatchEvent() Ignore to dispatch event: "+t.type+". No event added.");let e=this.jsvEventListener[t.type];if(e){t.target||(t.target=document.activeElement);for(let s of e)s(t)}else console.warn("Node.dispatchEvent() Ignore to dispatch event: "+t.type+". No listener added.")}jsvObserveChildChanged(t){this.jsvChildChangedCallback=t}}u.ELEMENT_NODE=1,u.TEXT_NODE=3,u.COMMENT_NODE=8,u.DOCUMENT_NODE=9,u.NOLAYOUT_NODE=10;class c extends i{}c.Type={FOCUS:"focus",BLUR:"blur"};class d extends i{stopPropagation(){}}class v{static ConvertInt(t){return t?"number"==typeof t?Math.floor(t):"string"==typeof t?parseInt(t):t:t}static ConvertFloat(t){if(!t)return t;if("string"!=typeof t)return t;return parseFloat(t)}static ConvertPx(t){if(!t)return t;if("string"!=typeof t)return t;if("0"===t)return 0;if(t.endsWith("px")){return parseInt(t)}return t}static ConvertRect(t){let e=v.SplitString(t," "),s={top:e.length>0?parseInt(e[0]):0,right:e.length>1?parseInt(e[1]):null,bottom:e.length>2?parseInt(e[2]):null,left:e.length>3?parseInt(e[3]):null};return s.right=s.right||0===s.right?s.right:s.top,s.bottom=s.bottom||0===s.bottom?s.bottom:s.top,s.left=s.left||0===s.left?s.left:s.right,s}static ConvertCorner(t){let e=v.SplitString(t," "),s={topLeft:e.length>0?parseInt(e[0]):0,topRight:e.length>1?parseInt(e[1]):null,bottomRight:e.length>2?parseInt(e[2]):null,bottomLeft:e.length>3?parseInt(e[3]):null};return s.topRight=s.topRight||0===s.topRight?s.topRight:s.topLeft,s.bottomRight=s.bottomRight||0===s.bottomRight?s.bottomRight:s.topLeft,s.bottomLeft=s.bottomLeft||0===s.bottomLeft?s.bottomLeft:s.bottomRight,s}static ConvertSize(t){let e=v.SplitString(t," "),s={width:e.length>0?parseInt(e[0]):0,height:e.length>1?parseInt(e[1]):null};return s.height=s.height||0===s.height?s.height:s.width,s}static ConvertAnimation(t){if(null===t||0===t.length)return null;let e=t.indexOf("cubic-bezier"),s=[];if(e>=0){let i=t.indexOf(")"),n=t.substring(e,i+1),r=v.SplitString(t,n);for(let t of r){let e=v.SplitString(t," ");s=s.concat(e)}s.push(n)}else s=v.SplitString(t," ");let i=null,n=0,r=1,o=t.includes("alternate");for(let t=2;t<s.length;t++){if("infinite"===s[t]){r=-1;continue}let e=v.ConvertTimeMs(s[t]);!1===isNaN(e)?n=e:(e=parseFloat(s[t]),!1===isNaN(e)?r=e:i=s[t])}let a=s.length>1?v.ConvertTimeMs(s[1]):0;return{name:s.length>0?s[0]:"",duration:a,timingFunction:v.ConvertEasing(i,a),delay:n,iterationCount:r,direction:o,originStr:t}}static ConvertTransition(t){if(null==t||0==t.length)return null;let e={},s=new Array,i=t.split(",");for(let t=0;t<i.length;t++)if(i[t].indexOf("(")>=0){let e=t;for(;e<i.length&&i[e].indexOf(")")<0;)e++;let n="";for(let s=t;s<=e;s++)s!=t&&(n+=","),n+=i[s];t=e,s=s.concat(n)}else s=s.concat(i[t]);for(let t of s){let s=v.ConvertAnimation(t);if(e[s.name]=s,"all"==s.name){let t=new Array("opacity","left","top","width","height","transform");for(let i of t)e[i]=s}}return e}static ConvertTimeMs(t){t||(t="");let e=NaN;return(t=t.trim()).endsWith("ms")?e=1:t.endsWith("s")&&(e=1e3),e*=parseFloat(t),e}static ConvertEasing(e,s){let i=t.Easing.Circular.InOut;if(!e)return i;if(e.includes("ease"))i=e.includes("-in-out")?t.Easing.Circular.InOut:e.includes("-out")?t.Easing.Circular.Out:e.includes("-in")?t.Easing.Circular.In:t.Easing.Circular.InOut;else if(e.includes("linear"))i=null;else if(e.includes("cubic-bezier")){let n=v.ConvertBezier(e);i=new t.BezierEasing(n.x1,n.y1,n.x2,n.y2,s)}else if(e.includes("steps")){let s=v.ConvertSteps(e);i=new t.StepsEasing(s.steps,s.type)}return i}static ConvertBezier(t){let e=t.indexOf("(");e>=0&&(t=t.substring(e+1));let s=v.SplitString(t,",");return{x1:s.length>0?parseFloat(s[0]):0,y1:s.length>1?parseFloat(s[1]):0,x2:s.length>2?parseFloat(s[2]):0,y2:s.length>3?parseFloat(s[3]):0}}static ConvertSteps(t){let e=t.indexOf("(");e>=0&&(t=t.substring(e+1));let s=v.SplitString(t,",");return{steps:s.length>0?parseInt(s[0]):1,type:s.length>1?s[1].includes("start")?0:1:0}}static ConvertOverflow(t,e){return t&&!t.includes("visible")?e.HIDDEN:e.VISIBLE}static ConvertObjectFit(t,e){return"symbol"==typeof t?t:(t||(t=""),t.includes("fill")?e.FILL:t.includes("contain")?e.CONTAIN:t.includes("cover")?e.COVER:t.includes("none")?e.NONE:t.includes("scale-down")?e.SCALEDOWN:e.CONTAIN)}static SplitString(t,e){t||(t="");let s=t.trim().split(e);if(" "!==e)return s;let i=[];for(let t of s)t&&i.push(t);return i}}class g{constructor(t){if(this.top=null,this.right=null,this.bottom=null,this.left=null,!t||!1===t.startsWith("inset"))return void console.error("Inset.Parse() InvalidArgs: value=",t);let e=t.indexOf("(")+1,s=t.substring(e),i=v.ConvertRect(s);this.top=i.top,this.right=i.right,this.bottom=i.bottom,this.left=i.left}}class p{constructor(t){if(this.source=null,this.slice=null,this.repeat=null,this.outset=null,this.width=null,!t)return void console.error("BorderImage.constructor() InvalidArgs: value=",t);let s=t.indexOf(")")+1,i=t.substring(0,s),n=t.substring(s);this.source=new e(i),this.slice=v.ConvertRect(n)}}class w{constructor(){this.refStyleObject=new Map,this.value=void 0}static AppendRefStyle(t,e,s){let i=w.jsvGetStyleVar(t);i.refStyleObject.has(e)||i.refStyleObject.set(e,[]),i.refStyleObject.get(e).push(s)}static RemoveRefStyle(t){for(const e of w.VariableMap.values())for(const s of e.refStyleObject.keys())s==t&&e.refStyleObject.delete(t)}static UpdateValue(t,e){let s=w.jsvGetStyleVar(t);s.value=e;for(const[t,e]of s.refStyleObject)for(const s of e)t.jsvSetClassProperty(s)}static GetValue(t){return w.jsvGetStyleVar(t).value}static jsvGetStyleVar(t){t.startsWith("--")&&(t=`var(${t})`),w.VariableMap.has(t)||w.VariableMap.set(t,new w);return w.VariableMap.get(t)}}w.VariableMap=new Map;class y{constructor(){this.jsvStore={},this.jsvLazySyncCache=new o("style"),this.jsvLockedProps={},this.jsvNamedClassArray=null,this.jsvCustomStyles={},this.jsvLazyPrevClassNames=null,this.jsvLazyClassNames=null,this.jsvLazyClassAttributes=null}setProperty(t,e){"function"==typeof document.jsvCheckStyleFormat&&document.jsvCheckStyleFormat(t,e),this.jsvLockedProps[t]=!0,e=y.JsvConvertPropValue(t,e),this.jsvUpdateProperty(t,e)}getPropertyValue(t){if(void 0!==this.jsvStore[t])return this.jsvStore[t];let e=this.jsvGetClassPropValue(this.jsvLazyClassNames,this.jsvLazyClassAttributes,t);return e=y.JsvConvertPropValue(t,e),e}jsvDestory(){w.RemoveRefStyle(this)}jsvUpdateProperty(t,e){let s=this.jsvSetPropertySilently(t,e);s&&this.jsvLazySyncCache.setCacheProperty(s,!0)}jsvSetPropertySilently(t,e){if(t.startsWith("--"))return void w.UpdateValue(t,e);if("string"==typeof e&&e.startsWith("var(--"))return void w.AppendRefStyle(e,this,t);if("animation"===t){if(this.jsvStore[t]?.originStr===e?.originStr)return null}else if(this.jsvStore[t]===e)return null;return this.jsvStore[t]=e,y.JsvGetStyleType(t)}jsvApplyClasses(e){if(e.indexOf("JsvStyle_")<0){this.jsvLazyPrevClassNames=this.jsvLazyClassNames,this.jsvLazyClassNames=e.split(" ");const t=y.TYPE.CLASS_NAME;this.jsvLazySyncCache.setCacheProperty(t,!0)}else if(e){let s=e.split(" "),i={};this.jsvNamedClassArray=new Array(s.length);let n=0;for(let e of s){let s=null;if(t.ReactUtils.StyleClassMap.hasOwnProperty(e)){s=t.ReactUtils.StyleClassMap[e];let n=s.getAttach();if(null==n){let t=s.getStyles();n={altStyles:{},hasTextMajorStyle:0,textPackAttr:null};for(let e in t)n.altStyles[e]=y.JsvConvertPropValue(e,t[e]);s.updateAttach(n)}"text"===s.classType()&&(n.hasTextMajorStyle=2,null===n.textPackAttr&&(n.textPackAttr={textLineAlign:s.getLineAlign(),textVerticalAlign:s.getVerticalAlign()}),this.jsvCustomStyles.textLineAlign=n.textPackAttr.textLineAlign,this.jsvCustomStyles.textVerticalAlign=n.textPackAttr.textVerticalAlign),Object.assign(i,n.altStyles)}else console.error("Error: className not found");this.jsvNamedClassArray[n]=s,n++}for(let t in i)this.jsvLockedProps[t]||this.jsvUpdateProperty(t,i[t])}}jsvAppendClassAttribute(t){this.jsvLazyClassAttributes||(this.jsvLazyClassAttributes=new Set),this.jsvLazyClassAttributes.add(t);const e=y.TYPE.CLASS_NAME;this.jsvLazySyncCache.setCacheProperty(e,!0)}jsvSetClassProperty(t){let e=y.JsvGetStyleType(t);e&&this.jsvLazySyncCache.setCacheProperty(e,!0)}jsvGetClassPropValue(t,e,s){if(!t)return;const i=(t,e,s,i)=>{for(let n=e.length-1;n>=0;n--){let r=e[n];if(s&&(r+="["+s+"]"),!t.hasOwnProperty(r))continue;const o=t[r];if(!o.hasOwnProperty(i))continue;let a=o[i];return"string"==typeof a&&a.startsWith("var(--")&&(a=w.GetValue(a)),a}},n=window.JsvCode.Dom.StyleSheets;for(const r of e??[]){const e=i(n,t,r,s);if(e)return e}return i(n,t,null,s)}jsvGetClassDeclarations(t,e){if(!t)return;const s=(t,e,s)=>{let i={};for(let n=0;n<e.length;n++){let r=e[n];if(s&&(r+="["+s+"]"),!t.hasOwnProperty(r))continue;const o=t[r];Object.assign(i,o)}return i},i=window.JsvCode.Dom.StyleSheets;let n=s(i,t,null);for(const r of e??[]){const e=s(i,t,r);Object.assign(n,e)}return n}jsvUpdateChangedClasses(){h.D("jsvGetChangedClassTypes() classNames="+this.jsvLazyClassNames);let t={};if(this.jsvLazyPrevClassNames){w.RemoveRefStyle(this);const e=this.jsvGetClassDeclarations(this.jsvLazyPrevClassNames,this.jsvLazyClassAttributes);for(const s of Object.keys(e)){t[y.JsvGetStyleType(s)]=!0}this.jsvLazyPrevClassNames=null}if(this.jsvLazyClassNames){const e=this.jsvGetClassDeclarations(this.jsvLazyClassNames,this.jsvLazyClassAttributes);for(const[s,i]of Object.entries(e)){t[y.JsvGetStyleType(s)]=!0,"string"==typeof i&&i.startsWith("var(--")&&w.AppendRefStyle(i,this,s)}}return t}jsvSetChangedListener(t){this.jsvLazySyncCache.setOnSyncCallback((e=>{if(e.hasOwnProperty(y.TYPE.CLASS_NAME)){const t=this.jsvUpdateChangedClasses();Object.assign(e,t),e[y.TYPE.CLASS_NAME]=void 0}t(e)}))}static JsvContainsTextMajor(t){for(let e of y.TextClassMajorStyles)if(t.hasOwnProperty(e))return!0;return!1}static JsvGetStyleType(t){switch(t){case y.PROP.LEFT:case y.PROP.RIGHT:case y.PROP.TOP:case y.PROP.BOTTOM:case y.PROP.ZINDEX:return y.TYPE.LAYOUT_POS;case y.PROP.TRANSFORM:case y.PROP.TRANSFORMORIGIN:return y.TYPE.TRANSFORM;case y.PROP.WIDTH:case y.PROP.HEIGHT:case y.PROP.VISIBILITY:case y.PROP.DISPLAY:case y.PROP.CLIPPATH:case y.PROP.OVERFLOW:case y.PROP.OBJECTFIT:case y.PROP.PERSPECTIVE:case y.PROP.PERSPECTIVEORIGIN:case y.PROP.BACKFACEVISIBILITY:case y.PROP.TRANSFORMSTYLE:case y.PROP.JSVVIDEOROTATION:return y.TYPE.LAYOUT_SIZE;case y.PROP.BACKGROUNDCOLOR:case y.PROP.BACKGROUNDIMAGE:case y.PROP.BORDERRADIUS:return y.TYPE.BACKGROUND;case y.PROP.COLOR:case y.PROP.LINEHEIGHT:case y.PROP.WHITESPACE:case y.PROP.FONTFAMILY:case y.PROP.FONTSIZE:case y.PROP.FONTSTYLE:case y.PROP.FONTWEIGHT:case y.PROP.TEXTALIGN:case y.PROP.TEXTSHADOW:case y.PROP.TEXTOVERFLOW:case y.PROP.WEBKITTEXTSTROKE:return y.TYPE.FOREGROUND;case y.PROP.BORDERIMAGE:case y.PROP.BORDERIMAGEWIDTH:case y.PROP.BORDERIMAGEOUTSET:return y.TYPE.BORDER;case y.PROP.ANIMATION:return y.TYPE.ANIMATION;case y.PROP.TRANSITION:return y.TYPE.TRANSITION;case y.PROP.OPACITY:break;default:return console.warn("Unknown style type for: "+t),null}}static JsvConvertPropValue(t,e){if(void 0===e)return e;if(t.startsWith("--")||e?.startsWith?.("var(--"))return e;switch(t){case y.PROP.TOP:case y.PROP.BOTTOM:case y.PROP.LEFT:case y.PROP.RIGHT:case y.PROP.WIDTH:case y.PROP.HEIGHT:case y.PROP.JSVVIDEOROTATION:return v.ConvertInt(e);case y.PROP.VISIBILITY:case y.PROP.DISPLAY:return e.toUpperCase();case y.PROP.OVERFLOW:return v.ConvertOverflow(e,y.Overflow);case y.PROP.OBJECTFIT:return v.ConvertObjectFit(e,y.ObjectFit);case y.PROP.TRANSFORM:case y.PROP.TRANSFORMORIGIN:return e;case y.PROP.CLIPPATH:return new g(e);case y.PROP.BORDERIMAGE:return new p(e);case y.PROP.BORDERIMAGEWIDTH:case y.PROP.BORDERIMAGEOUTSET:return v.ConvertRect(e);case y.PROP.BORDERRADIUS:return v.ConvertCorner(e);case y.PROP.ANIMATION:return v.ConvertAnimation(e);case y.PROP.TRANSITION:return v.ConvertTransition(e);case y.PROP.OPACITY:return v.ConvertFloat(e);default:return v.ConvertPx(e)}}}y.Overflow={HIDDEN:Symbol("hidden"),VISIBLE:Symbol("visible")},y.ObjectFit={FILL:Symbol("fill"),CONTAIN:Symbol("contain"),COVER:Symbol("cover"),NONE:Symbol("none"),SCALEDOWN:Symbol("scale-down")},y.TextClassMajorStyles=new Set(["textOverflow","wordWrap","textShadow","color","fontFamily","fontStyle","fontWeight","textAlign","WebkitTextStroke"]),y.TYPE={LAYOUT_POS:"layout-position",LAYOUT_SIZE:"layout-size",FOREGROUND:"foreground",BACKGROUND:"background",BORDER:"border",ANIMATION:"animation",TRANSFORM:"transform",TRANSITION:"transition",CLASS_NAME:"class-name"},y.PROP={TOP:"top",BOTTOM:"bottom",LEFT:"left",RIGHT:"right",WIDTH:"width",HEIGHT:"height",VISIBILITY:"visibility",DISPLAY:"display",BACKFACEVISIBILITY:"backfaceVisibility",CLIPPATH:"clipPath",OVERFLOW:"overflow",OBJECTFIT:"objectFit",TRANSFORM:"transform",TRANSFORMORIGIN:"transformOrigin",PERSPECTIVE:"perspective",PERSPECTIVEORIGIN:"perspectiveOrigin",ZINDEX:"zIndex",TRANSFORMSTYLE:"transformStyle",BACKGROUNDCOLOR:"backgroundColor",BACKGROUNDIMAGE:"backgroundImage",BORDERRADIUS:"borderRadius",COLOR:"color",LINEHEIGHT:"lineHeight",WHITESPACE:"whiteSpace",FONTFAMILY:"fontFamily",FONTSIZE:"fontSize",FONTSTYLE:"fontStyle",FONTWEIGHT:"fontWeight",TEXTALIGN:"textAlign",TEXTSHADOW:"textShadow",TEXTOVERFLOW:"textOverflow",WEBKITTEXTSTROKE:"WebkitTextStroke",BORDERIMAGE:"borderImage",BORDERIMAGEWIDTH:"borderImageWidth",BORDERIMAGEOUTSET:"borderImageOutset",ANIMATION:"animation",TRANSITION:"transition",OPACITY:"opacity",JSVVIDEOROTATION:"JsvVideoRotation"};for(let t in y.PROP){let e=y.PROP[t];Object.defineProperty(y.prototype,e,{set:function(t){this.setProperty(e,t)},get:function(){return this.getPropertyValue(e)}})}let f=null;class m{static getHandlers(t){const e=m.reactEventHandlers(t);return e||(t._vei?t._vei:{})}static reactEventHandlers(t){return null==f&&m._getReactToken(t),t["__reactEventHandlers$"+f]}static _getReactToken(t){for(let e in t)if(e.indexOf("__reactEventHandlers")>=0||e.indexOf("__reactInternalInstance")>=0){let t=e.indexOf("$");f=e.substring(t+1);break}}}class j extends u{constructor(e){super(u.ELEMENT_NODE),this.parentElement=null,this.tagName=this.jsvGetTagName(),this.tagName===j.TAG.STYLE?(this.style=null,this.jsvMainView=null,this.jsvMaskView=null):(this.style=new y,this.jsvMainView=new t.LayoutView,this.jsvMaskView=null),this.jsvAnimation=null,this.jsvStore={transition:null,transitionTmp:null,textContent:null,textStylePack:null,clientWidth:NaN,clientHeight:NaN,textureWidth:NaN,textureHeight:NaN,scopedData:[]},this.jsvLazySyncCache=new o("element"),this.instantSwapCallback=null,this.eventHandlers=null}appendChild(t){super.appendChild(t),this.jsvInsertChild(t,null)}removeChild(t){if(t.childNodes)for(const e of t.childNodes)t.removeChild(e);t.style?.jsvDestory(),super.removeChild(t),t.parentElement=null,t instanceof j&&this.jsvMainView.RemoveView(t.jsvMaskView)}insertBefore(t,e){super.insertBefore(t,e),this.jsvInsertChild(t,e)}get childElementCount(){return this.childNodes.length}get firstElementChild(){return this.childNodes.length>0?this.childNodes[0]:null}get lastElementChild(){const t=this.childNodes.length;return t>0?this.childNodes[t-1]:null}set className(t){this.setAttribute("class",t)}setAttribute(t,e){t&&(this[t],this[t]=e,t.startsWith("data-v-")?(this.jsvStore.scopedData.push(t),this.style.jsvAppendClassAttribute(t)):"class"===t?this.style.jsvApplyClasses(e):t.startsWith(j.ATTRIBUTE.JSVPREFIX)&&(t=t.replace(/-/g,"_"),this.jsvLazySyncCache.setCacheProperty(t,e)))}removeAttribute(t){this[t]=void 0,t.startsWith(j.ATTRIBUTE.JSVPREFIX)&&this.jsvLazySyncCache.setCacheProperty(t,void 0)}getAttribute(t){return this[t]}hasAttribute(t){return console.log("Element.hasAttribute() name="+t),!!this[t]}get clientWidth(){return isNaN(this.jsvStore.clientWidth)?this.style.width:this.jsvStore.clientWidth}get clientHeight(){return isNaN(this.jsvStore.clientHeight)?this.style.height:this.jsvStore.clientHeight}focus(){console.log("Element.focus()"),document.activeElement&&document.activeElement.onfocus();let t=document.activeElement;if(document.activeElement=this,t){let e=new c(c.Type.BLUR);e.target=t,document.dispatchEvent(e)}let e=new c(c.Type.FOCUS);document.dispatchEvent(e)}jsvInsertChild(t,e){if(t.parentElement=this,t.nodeType===u.ELEMENT_NODE&&t.tagName!==j.TAG.STYLE){if(!1===document.jsvIsReady)return void console.warn("Element.appendChild() Failed to append child to Forge. jsvIsReady="+document.jsvIsReady);t.jsvOnLoadForgeView(),t.style.jsvSetChangedListener(t.jsvOnStyleChanged.bind(t)),e=this.jsvBackwardFindForgeView(e);let s=t.jsvMaskView.GetLayoutParams();this.jsvMainView.InsertView(t.jsvMaskView,e?e.jsvMaskView:null,s)}else t.nodeType===u.TEXT_NODE&&(this.textContent=t.textContent)}jsvOnLoadForgeView(){if(this.style.clipPath||this.style.overflow||this.style.objectFit){if(this.jsvMaskView)throw Error("Jsview: jsvMaskView is conflicting.");this.jsvMaskView=new t.ClipView}else this.jsvMaskView||(this.jsvMaskView=this.jsvMainView);this.jsvMaskView!==this.jsvMainView&&this.jsvMaskView.AddView(this.jsvMainView);let e=this.jsvCallbackOnUnloadForgeView();e&&this.jsvMainView.RegisterDetachCallback(e),this.jsvLazySyncCache.setOnSyncCallback((t=>{this.jsvSetElementProp(t)}))}jsvSetElementProp(t){this.jsvMainView&&this.jsvMainView.SetElementProp(t,s.RootActivity)}jsvCallbackOnUnloadForgeView(){return null}jsvOnStyleChanged(t){let e=!!t[y.TYPE.LAYOUT_SIZE],s=!1;t[y.TYPE.LAYOUT_POS]&&(e||(this.jsvFlushViewLayout(),s=!0)),t[y.TYPE.LAYOUT_SIZE]&&(this.jsvFlushViewLayout(),s=!0),t[y.TYPE.TRANSFORM]&&!s&&(this.jsvMaskView.ResetCssTransform(this.style.transform,this.style.transformOrigin),this.jsvFlushViewTransition(),s=!0),t[y.TYPE.BACKGROUND]&&this.jsvFlushViewBackground(),t[y.TYPE.ANIMATION]&&this.jsvFlushViewAnimation(),t[y.TYPE.TRANSITION]&&!s&&this.jsvFlushViewTransition(),this.jsvFlushEventHandlers()}jsvFlushEventHandlers(){null===this.eventHandlers&&(this.eventHandlers=m.getHandlers(this),this.eventHandlers&&this.eventHandlers.onClick&&this.jsvMainView&&this.jsvMainView.EnableDivTouch(this,null))}jsvApplyObjectFit(t){return null}jsvFlushViewLayout(){if((this.style.clipPath||this.style.overflow||this.style.objectFit)&&!this.jsvMaskView)return void console.error("Element.jsvFlushViewLayout() InvalidOpt: clippath=",this.style.clipPath);const e={x:isNaN(this.style.left)?0:this.style.left,y:isNaN(this.style.top)?0:this.style.top,width:isNaN(this.style.width)?0:this.style.width,height:isNaN(this.style.height)?0:this.style.height};let s=null;if(this.style.objectFit&&(s=this.jsvApplyObjectFit(e),this.style.objectFit===y.ObjectFit.FILL&&(s=null)),this.jsvMaskView.ResetCssTransform(this.style.transform,this.style.transformOrigin),this.style.perspective&&this.style.perspective>0){let t=this.style.perspectiveOrigin?this.style.perspectiveOrigin:null;this.jsvMainView.SetPerspective(this.style.perspective,t)}if(this.style.backfaceVisibility&&this.jsvMainView.SetBackfaceVisibility("visible"==this.style.backfaceVisibility),this.style.transformStyle&&this.jsvMainView.SetTransformStyle(this.style.transformStyle),this.jsvMaskView.ResetLayoutParams({x:e.x,y:e.y,width:this.clientWidth,height:this.clientHeight}),this.jsvMaskView!==this.jsvMainView){const t={x:0,y:0,width:this.jsvMaskView.LayoutParams.Width,height:this.jsvMaskView.LayoutParams.Height};this.jsvMainView.ResetLayoutParams(t)}this.jsvMaskView.SetVisibility(this.style.visibility);let i=null;null!==s&&window.JsView?i={x:s.x,y:s.y,width:s.width,height:s.height}:this.style.clipPath?i={x:this.style.clipPath.left,y:this.style.clipPath.top,width:this.jsvMaskView.LayoutParams.Width-this.style.clipPath.left-this.style.clipPath.right,height:this.jsvMaskView.LayoutParams.Height-this.style.clipPath.top-this.style.clipPath.bottom}:this.style.overflow===y.Overflow.HIDDEN&&null===this.jsvStore.textContent&&(i={x:0,y:0,width:this.style.width,height:this.style.height}),i?this.jsvMaskView.SetClipRect(i.x,i.y,i.width,i.height,!0):this.jsvMaskView instanceof t.ClipView&&this.jsvMaskView.SetClipRect(0,0,0,0,!1),void 0!==this.style.zIndex&&null!==this.style.zIndex&&this.jsvMaskView.SetZIndex(this.style.zIndex),this.jsvFlushViewTransition()}jsvFlushViewBackground(){this.style.backgroundColor&&(this.jsvStore.textureWidth=NaN,this.jsvStore.textureHeight=NaN,s.SetBackgroundColor(this.jsvMainView,this.style.backgroundColor,this.style.borderRadius)),this.style.backgroundImage&&(this.jsvStore.textureWidth=NaN,this.jsvStore.textureHeight=NaN,s.SetBackgroundImage(this.jsvMainView,this.style.backgroundImage,this.style.borderRadius))}jsvFlushViewAnimation(){if(this.jsvAnimation&&this.jsvAnimation.Cancel(),!this.style.animation)return;let e=document.jsvGetKeyFrames(this.style.animation.name,this.jsvStore.scopedData);this.jsvAnimation=new t.CssKeyframeAnimation(e,this.style.animation.duration,this.style.animation.timingFunction,this.style.width?this.style.width:this.clientWidth,this.style.height),this.jsvAnimation.EnableDelay(this.style.animation.delay).SetRepeat(this.style.animation.iterationCount),"forwards"===this.style.animationFillMode&&this.jsvAnimation.Enable(t.AnimationEnable.KeepTransform);var s=this;let i=new t.AnimationListener;i.OnEnd((e=>{if(s.jsvAnimation=null,e){if(s.eventHandlers&&s.eventHandlers.onAnimationEnd){let t;t=new d("animationend"),t.target=s,s.eventHandlers.onAnimationEnd(t)}null==s.instantSwapCallback&&(s.instantSwapCallback=t.sRenderBridge.InstantPerformSwap.bind(t.sRenderBridge)),Promise.resolve().then(s.instantSwapCallback)}})),this.jsvAnimation.Enable(t.AnimationEnable.ReleaseAfterEndCallback),this.jsvAnimation.SetAnimationListener(i),this.jsvMaskView.StartAnimation(this.jsvAnimation)}jsvFlushViewTransition(){if(this.style.animation)return;if(null!=this.jsvStore.transitionTmp&&this.jsvStore.transitionTmp.syncTimes!=r.cnt&&-1!=this.jsvStore.transitionTmp.syncTimes){let t=this.jsvStore.transition;this.jsvStore.transition=this.jsvStore.transitionTmp,this.jsvStore.transitionTmp=t,null!=this.jsvStore.transitionTmp&&(this.jsvStore.transitionTmp.syncTimes=-1)}if(this.style.transition){if(this.jsvStore.transition){if(!this._JsvBuildTransition())return}}else this.jsvAnimation&&(this.jsvAnimation.Cancel(),this.jsvAnimation=null);let t=this.jsvStore.transitionTmp;t||(t={left:0,top:0,width:0,height:0,opacity:1,transform:null,syncTimes:-1}),t.left=this.style.left,t.top=this.style.top,t.width=this.style.width,t.height=this.style.height,t.opacity=this.style.opacity,t.transform=this.style.transform,t.syncTimes=r.cnt,this.jsvStore.transitionTmp=t}_JsvBuildTransition(){let e=[];for(let t in this.style.transition){let s=this.jsvStore.transition[t],i=this.style[t];if(s===i)continue;let n=this.style.transition[t],r={name:t,dur:n.duration,tf:null,dly:n.delay,from:s||"",to:i};"transform"===t&&(r.origin=this.style.transformOrigin?this.style.transformOrigin:"center center"),n.timingFunction&&(r.tf=n.timingFunction.Package()),e.push(r)}if(e.length<=0)return!1;var s=this;let i=new t.AnimationListener;return i.OnEnd((e=>{if(s.jsvAnimation=null,e){if(s.eventHandlers&&s.eventHandlers.onTransitionEnd){let t=new d("transitionend");t.target=s,s.eventHandlers.onTransitionEnd(t)}null==s.instantSwapCallback&&(s.instantSwapCallback=t.sRenderBridge.InstantPerformSwap.bind(t.sRenderBridge)),Promise.resolve().then(s.instantSwapCallback)}})),this.jsvAnimation=new t.CssTransitionAnimation(e),this.jsvAnimation.SetAnimationListener(i),this.jsvMaskView.StartAnimation(this.jsvAnimation),!0}jsvBackwardFindForgeView(t){let e=t;for(;e&&!(e instanceof j);)e=e.nextSibling;return e}static applyObjectFitCommon(t,e,s){if(s&&!isNaN(t.jsvStore.textureWidth)&&!isNaN(t.jsvStore.textureHeight)){const i=t.style.objectFit,n=s.ApplyObjectFit(e.width,e.height,t.jsvStore.textureWidth,t.jsvStore.textureHeight,i,y.ObjectFit);return 0!==e.width&&0!==e.height||0===e.width&&0===e.height||(t.jsvStore.clientWidth=Math.max(e.width,n.width),t.jsvStore.clientHeight=Math.max(e.height,n.height)),n}return null}}j.TAG={DIV:"DIV",IMAGE:"IMAGE",LINK:"LINK",STYLE:"STYLE",AUDIO:"AUDIO",VIDEO:"VIDEO",ANCHOR:"A",SVG:"SVG",FDIV:"FDIV",AUDIOTRACK:"AUDIOTRACK"},j.ATTRIBUTE={SRC:"src",JSVPREFIX:"jsv"};class T extends j{constructor(){super(),console.warn("Warnig: <a> is fake in JsView system"),this.href="",this.protocol="",this.host="",this.search="",this.hash="",this.hostname="",this.port="",this.pathname=""}jsvGetTagName(){return j.TAG.ANCHOR}}class S extends j{constructor(t){super(),this.jsvMediaView=null,this.jsvMedia=null,this.onVisibilityChange=this.onVisibilityChange.bind(this),this.stopByOnHide=!1,this.playBackground=!1,t&&(this.srcValue=t)}addEventListener(t,e,s){t=t.replace(/-/g,""),super.addEventListener(t,e,s),this.jsvAddMediaListener(t)}jsvOnLoaded(){}set src(t){if(t&&"about:null"!==t&&"about:blank"!==t){t=new e(t).href}this.jsvMedia||this.jsvInit(),t!==this.jsvMedia.src&&(this.jsvMedia.src=t,this.srcValue=t)}jsvOnLoadForgeView(){console.log("MediaElement jsvOnLoadForgeView"),super.jsvOnLoadForgeView(),this.jsvMedia||this.jsvInit(),this.registerOnVisibilityChange()}jsvInit(){let t=this.jsvEventListener;if(t)for(var e in t.keys)this.jsvAddMediaListener(e);Promise.resolve().then((()=>{this.jsvMedia&&this.jsvMedia.confirmInitSetup?.()}))}jsvCallbackOnUnloadForgeView(){return this.jsvOnUnloadForgeView.bind(this)}jsvOnUnloadForgeView(){console.log("MediaElement jsvOnUnloadForgeView"),this.unregisterOnVisibilityChange(),this.jsvMediaView&&(this.jsvMediaView=null),this.jsvRelease()}jsvRelease(){this.jsvMedia&&(this.jsvMedia.pause(),this.jsvMedia.unload&&this.jsvMedia.unload(),this.jsvMedia.releaseResource&&(this.jsvMedia.releaseResource(),this.jsvMedia.onPlatformDestroy())),this.jsvEventListener=void 0}jsvAddMediaListener(t){}onJsViewHide(){this.jsvMedia&&(this.jsvMedia.paused||(this.stopByOnHide=!0),this.jsvMedia.unload())}onJsViewShow(){this.jsvMedia||this.jsvInit(),this.jsvMedia.src=this.srcValue,this.stopByOnHide&&(this.stopByOnHide=!1,this.jsvMedia.play())}onVisibilityChange(t){this.playBackground||("show"===t.status?this.onJsViewShow():"hide"===t.status&&this.onJsViewHide())}registerOnVisibilityChange(){window.JsView&&window.JsView.onVisibilityChange(this.onVisibilityChange)}unregisterOnVisibilityChange(){window.JsView&&window.JsView.removeEventCallback(this.onVisibilityChange)}setAttribute(t,e){"jsv_play_background"!==t?super.setAttribute(t,e):this.playBackground="true"===e}}S.HOOKS={Audio:Audio,Video:window._ExtVideo,OffscreenVideo:window._ExtOVP},S.PROP={SetOnly:["autoplay","loop","timeupdateless","predownload"],GetOnly:["duration","paused"],SetAndGet:["currentTime","muted","playbackRate","preload","volume"],Function:["load","pause","play","unload","confirmInitSetup"]};for(let t in S.PROP){let e=S.PROP[t];for(let s of e){let e={};"SetOnly"!==t&&"SetAndGet"!==t||(e.set=function(t){this.jsvMedia||this.jsvInit(),this.jsvMedia[s]=t}),"GetOnly"!==t&&"SetAndGet"!==t||(e.get=function(){return this.jsvMedia||this.jsvInit(),this.jsvMedia[s]}),"Function"===t&&(e=function(...t){return this.jsvMedia||this.jsvInit(),this.jsvMedia[s]?this.jsvMedia[s](...t):null}),e instanceof Function?S.prototype[s]=e:Object.defineProperty(S.prototype,s,e)}}class O extends S{constructor(t){super(t),this.jsvOverrideMedia=!1,console.log("AudioElement.constructor()",this)}jsvGetTagName(){return j.TAG.AUDIO}jsvInit(){this.jsvOverrideMedia||(this.jsvMedia=new S.HOOKS.Audio),super.jsvInit(),this.jsvOnLoaded()}jsvOnLoaded(){this.jsvMediaView=new t.LayoutView,this.jsvMainView.AddView(this.jsvMediaView)}jsvAddMediaListener(t){this.jsvMedia||this.jsvInit(),this.jsvMedia.addEventListener(t,(()=>{let e=new i(t);e.target=this,this.dispatchEvent(e)}))}jsvRelease(){super.jsvRelease(),this.jsvMedia=null}setAttribute(t,e){if("data-jsv-audio-predownload"==t)return this.jsvMedia||this.jsvInit(),void(this.jsvMedia.predownload=!0);super.setAttribute(t,e)}}class E{constructor(){this._PersistMap=new Map,this._PersistMax=300,this._PersistIdx=0,this._PersistTrackList=new Array(this._PersistMax),this._TempMap=new Map,this._TempMax=50,this._TempIdx=0,this._TempTrackList=new Array(this._TempMax)}getPersistPack(t){return this._PersistMap.get(t)}putPersistPack(t,e){E._putPack(this._PersistMap,this._PersistTrackList,this._PersistIdx,t,e),this._PersistIdx=(this._PersistIdx+1)%this._PersistMax}getTempPack(t){return this._TempMap.get(t)}putTempPack(t,e){E._putPack(this._TempMap,this._TempTrackList,this._TempIdx,t,e),this._TempIdx=(this._TempIdx+1)%this._TempMax}static _putPack(t,e,s,i,n){let r=e[s];r&&(t.delete(r),e[s]=i),t.set(i,n)}}let C=new E;class R extends j{constructor(){super(),this.jsvContentView=null,this.jsvRefedImgTex=null,this.jsvTextLatexEnable=!1,this.jsvEmoji=!1,this.jsvTextAlignMinWidth=NaN,this.jsvEmptyRect=null}jsvGetTagName(){return j.TAG.DIV}get textContent(){return this.jsvStore.textContent}set textContent(e){this.jsvStore.textContent=e,this.jsvStore.clientWidth=NaN,this.jsvContentView||(this.jsvContentView=new t.LayoutView,this.jsvMainView.AddView(this.jsvContentView)),this.parentElement&&this.jsvFlushViewForeground()}get clientWidth(){const t=this.style.width;if(t||0===t)return t;if(this.jsvStore.textContent){if(!isNaN(this.jsvStore.clientWidth))return this.jsvStore.clientWidth;const t={str:this.jsvStore.textContent,font:this.style.fontFamily,size:this.style.fontSize,italic:this.style.fontStyle,bold:this.style.fontWeight};return this.jsvStore.clientWidth=s.GetTextWidth(t),this.jsvStore.clientWidth}return super.clientWidth}jsvOnLoadForgeView(){this.style.borderImage&&(this.jsvMaskView=new t.NinePatchView),super.jsvOnLoadForgeView()}jsvCallbackOnUnloadForgeView(){return this.jsvOnUnloadForgeView.bind(this)}jsvOnUnloadForgeView(){s.UnrefImgTexSize(this.jsvRefedImgTex),this.jsvRefedImgTex=null}jsvOnStyleChanged(t){super.jsvOnStyleChanged(t),this.jsvStore.textStylePack=null;let e=!!t[y.TYPE.FOREGROUND];t[y.TYPE.LAYOUT_SIZE]&&(e||this.jsvFlushViewForeground()),t[y.TYPE.FOREGROUND]&&this.jsvFlushViewForeground(),t[y.TYPE.BORDER]&&this.jsvFlushViewBorder()}jsvFlushViewForeground(){if(this.jsvContentView&&(this.jsvContentView.ClearViews(),this.jsvStore.textContent)){let t=void 0===this.style.height||0==this.style.height,e=t?(t,e)=>{this.jsvStore.clientHeight=t.height}:null,s=this.jsvBuildTextView(e);t&&s.EnableAutoHeight(),this.jsvContentView.AddView(s)}}jsvBuildTextView(e){let i=this.jsvStore.textStylePack;if(null===i&&(i=this._jsvGetClassNameCache()),null===i){this.style.jsvCustomStyles.textLineAlign||(this.style.jsvCustomStyles.textLineAlign=this.style.lineHeight?"middle":"top"),this.style.jsvCustomStyles.textVerticalAlign||(this.style.jsvCustomStyles.textVerticalAlign="top");let e=R._jsvStyleToPackData(this.style),s=JSON.stringify(e),n=C.getTempPack(s);n||(n=t.sTextStyleCache.StyleToPack(e),C.putTempPack(s,n)),i=n}this.jsvStore.textStylePack=i;let n=this.style.lineHeight?parseInt(this.style.lineHeight):this.style.fontSize?1.3*this.style.fontSize:14,r=this.style.width,o=!1;if(void 0===r&&(r=this.clientWidth,o=!0),this.jsvTextAlignMinWidth&&r<this.jsvTextAlignMinWidth&&(r=this.jsvTextAlignMinWidth),r>3e3){if(!o)return console.error(`text too long. str=${this.jsvStore.textContent}`),null;console.log(`text too long, start to break down. width(${r})`);let a=new t.LayoutView,l=Math.floor(2048/this.style.fontSize),h=this.jsvStore.textContent.length,u=0,c=0,d={str:null,font:this.style.fontFamily,size:this.style.fontSize,italic:this.style.fontStyle,bold:this.style.fontWeight};for(;h>0;){let r=l<h?l:h,o=this.jsvStore.textContent.substr(u,r);u+=r,d.str=o;let v=s.GetTextWidth(d),g=t.sTextUtils.BuildTextView(s.TextureManager,o,i,0===u?e:null,{width:v,height:this.style.height},this.style.fontSize,n,!0,this.jsvTextLatexEnable,this.jsvEmoji,this.jsvEmptyRect);a.AddView(g,{x:c,y:0,width:v,height:this.style.height}),c+=v,h-=r}return a}return t.sTextUtils.BuildTextView(s.TextureManager,this.jsvStore.textContent,i,e,{width:r,height:this.style.height},this.style.fontSize,n,!0,this.jsvTextLatexEnable,this.jsvEmoji,this.jsvEmptyRect)}_jsvGetClassNameCache(){if(null===this.style.jsvNamedClassArray)return null;if(y.JsvContainsTextMajor(this.style.jsvLockedProps))return null;let e="";for(let t of this.style.jsvNamedClassArray){let s=t.getAttach();0===s.hasTextMajorStyle&&(y.JsvContainsTextMajor(t.getStyles())?s.hasTextMajorStyle=2:s.hasTextMajorStyle=1),2===s.hasTextMajorStyle&&(e+=t.getName())}if(e.length>0){let s=C.getPersistPack(e);if(!s){let i=R._jsvStyleToPackData(this.style);s=t.sTextStyleCache.StyleToPack(i),C.putPersistPack(e,s)}return s}return null}static _jsvStyleToPackData(t){let e={textColor:t.color?t.color:"0x000000",font:t.fontFamily,italic:"italic"===t.fontStyle,bold:"bold"===t.fontWeight,hAlign:t.textAlign?t.textAlign:"left",vAlign:t.jsvCustomStyles.textLineAlign?t.jsvCustomStyles.textLineAlign:"middle",vAreaAlign:t.jsvCustomStyles.textVerticalAlign?t.jsvCustomStyles.textVerticalAlign:"top",textOverflow:t.textOverflow?t.textOverflow:"clip",wordWrap:"break-word"===t.wordWrap?"break_word":"normal"};"nowrap"===t.whiteSpace&&(e.wordWrap="none");let s=t.textShadow?t.textShadow.split(" "):void 0;s&&(e.shadow={shadowOffsetX:parseInt(s[0]),shadowOffsetY:parseInt(s[1]),shadowBlur:parseFloat(s[2]),shadowColor:s[3]});let i=t.WebkitTextStroke?t.WebkitTextStroke.split(" "):void 0;return i&&(e.stroke={strokeWidth:parseInt(i[0]),strokeColor:i[1]}),e}jsvFlushViewBorder(){if(this.jsvMaskView)if(this.style.clipPath)console.error("BorderImage is conflicting with ClipPath.");else if(this.style.borderImage){if(!(this.jsvMaskView instanceof t.NinePatchView))return void console.error("Error: style.borderImage NOT support dynamic adding");let e=v.ConvertPx(this.getAttribute("jsv-borderimage-width")),i=v.ConvertPx(this.getAttribute("jsv-borderimage-height"));if(s.UnrefImgTexSize(this.jsvRefedImgTex),!this.jsvRefedImgTex||this.jsvRefedImgTex.Source!==this.style.borderImage.source.href){let n=e&&i?{width:e,height:i}:null;if(!this.style.borderImage.source.href)return void this.jsvMaskView.ResetTexture(null);this.jsvRefedImgTex=s.TextureManager.GetImage2(this.style.borderImage.source.href,!1,n,t.ColorSpace.RGBA_8888)}e&&i&&(console.log("Custom cache image size with: "+e+"/"+i),s.SetImgTexSize(this.jsvRefedImgTex,{width:e,height:i}));const n=new t.ExternalTextureSetting(this.jsvRefedImgTex);this.jsvMaskView.ResetTexture(n),this.jsvMaskView.WaitTextureToResize(!0),s.RefImgTexSize(this.jsvRefedImgTex,function(t){if(!this.jsvMaskView)return void console.log("Found border view gone");let e=this.style.borderImageOutset?this.style.borderImageOutset:v.ConvertRect();this.jsvMaskView.SetPadding({start:e.left,width:t.width-e.left-e.right},{start:e.top,width:t.height-e.top-e.bottom});let s=this.style.borderImage.slice;this.jsvMaskView.SetRepeat([{start:s.left,width:t.width-s.left-s.right}],[{start:s.top,width:t.height-s.top-s.bottom}]),this.jsvMaskView.WaitTextureToResize(!1)}.bind(this))}}setAttribute(t,e){this.jsvTakeTextAttribute(t,e)||super.setAttribute(t,e)}jsvTakeTextAttribute(t,e){return"jsv_text_vertical_align"===t?(this.style.jsvCustomStyles.textVerticalAlign=e,!0):"jsv_text_latex_enable"===t?(this.jsvTextLatexEnable="true"===e,!0):"jsv_text_align_minwidth"===t?(this.jsvTextAlignMinWidth=parseInt(e),!0):"jsv_text_emoji"===t?(this.jsvEmoji="true"===e,!0):("jsv_text_empty_rect"===t&&(this.jsvEmptyRect=JSON.parse(e)),!1)}}class P{constructor(t,e){this.RouterDelegate={ref:null},t||(this.RouterDelegate.ref=new b(!1,e))}getNodeByName(t){return this.RouterDelegate.ref.getNodeByName(t)}focusByNameBeforeMount(t,e){return this.RouterDelegate.ref.focusBeforeMount(t,e)}printFocusList(){for(let t in this.RouterDelegate.ref._ChildMap)console.log(`branchName[${t}] ${t===this.RouterDelegate.ref._FocusNodeName?"focused":""}`,this.RouterDelegate.ref._ChildMap[t])}printGlobalLastFocus(){console.log("FocusNode:"),console.log(A.sLastFocus)}}class b{constructor(t,e){this._IsTemp=!!t,this._ChildMap={},this._FocusNodeName=null,this.NameSpace=e}getNodeByName(t,e){let s=t.split(".");return this._FindRouterSearchBase(s,e)._GetNodeFromPathArray(s,t)}_FindRouterSearchBase(t,e){if(0==t[0].length){let e,s;for(let t in this._ChildMap){e=this._ChildMap[t];break}do{s=e,e=e.GetParentPage()}while(null!=e);return t.splice(0,1),s.RouterDelegate.ref}return e&&e.AsHub&&e.GetParentPage()?e.GetParentPage().RouterDelegate.ref:this}_GetNodeFromPathArray(t,e){let s=0,i=this;for(;s<t.length-1;){let n=!1;for(let e in i._ChildMap){let r=i._ChildMap[e].RouterDelegate.ref;if(r!=i&&r.NameSpace==t[s]){i=r,s++,n=!0;break}}if(!n)return void console.error(`Error: no found subpath fname=${e}`)}let n=t[s];return i._ChildMap.hasOwnProperty(n)?i._ChildMap[n]:void console.error(`Error: no found fname=${e}`)}add(t,e){t.indexOf(".")>=0?console.error("ERROR: FDiv name can not contains '.'"):this._ChildMap.hasOwnProperty(t)&&this._ChildMap[t]!==e?console.error(`ERROR: FDiv router branch name duplicated:[${t}]`):(this._ChildMap[t]=e,this._FocusNodeName==t&&e.Focus())}remove(t,e){let s=this._ChildMap[t];s&&s==e&&delete this._ChildMap[t]}rename(t,e){if(!this._ChildMap.hasOwnProperty(t))return void console.error(`ERROR: alter name failed ${t}->${e}`);let s=this._ChildMap[t];delete this._ChildMap[t],this.add(e,s),this._FocusNodeName==t&&(this._FocusNodeName=e)}focusBeforeMount(t,e){if(t.indexOf(".")>=0)return console.error("ERROR: not support name with namespace"),!1;let s=this._ChildMap[t];return this._FocusNodeName=t,!!s&&(s.Focus(!e),!0)}focus(t,e){let s=this.focusBeforeMount(t,e);return s||console.log("No found branch:"+t),s}forEach(t){for(let e in this._ChildMap)t(this._ChildMap[e],e,this._ChildMap)}printNodes(){console.log(this._ChildMap)}}class A extends t.PageBase{constructor(t){super(t),this._OnKeyDown=null,this._OnKeyUp=null,this._OnFocus=null,this._OnBlur=null,this._DispatchKeyDown=null,this._DispatchKeyUp=null,this._DKeyDownProxy=void 0,this._DKeyUpProxy=void 0,this._Mounted=!1,this.BranchName=t,this.AsHub=!1,this.InterfaceHub=null,this.RouterDelegate={ref:null},this._TmpRouter=null,this._OriginDispatchKeyDown=this._OriginDispatchKeyDown.bind(this),this._OriginDispatchKeyUp=this._OriginDispatchKeyUp.bind(this),this._AutoShow=!1}updateMountState(){this._Mounted=!0;let t=this.SubPages;for(let e in t)t[e].updateMountState()}getHub(){return this.InterfaceHub||(this.InterfaceHub=new P(!0),this.InterfaceHub.RouterDelegate=this.RouterDelegate),this.InterfaceHub}setHub(t){this.RouterDelegate.ref?console.error("Error: hub is already setted."):(this.RouterDelegate.ref=t.RouterDelegate.ref,this.AsHub=!0)}_UseParentRouter(t){this.RouterDelegate=t,this.InterfaceHub&&(this.InterfaceHub.RouterDelegate=t)}routerAdd(t,e){e.RouterDelegate.ref||e._UseParentRouter(this.RouterDelegate),this.RouterDelegate.ref||(this.RouterDelegate.ref=new b(!0)),this.RouterDelegate.ref.add(t,e)}routerRenameChild(t,e){this.RouterDelegate.ref.rename(t,e)}printFocusList(){this.RouterDelegate.ref?this.RouterDelegate.ref.printFocusList():console.error("Error: no router")}routerUnbind(){let t;this.AsHub?this.GetParentPage()&&(t=this.GetParentPage().RouterDelegate.ref):t=this.RouterDelegate.ref,t&&t.remove(this.BranchName,this)}setBranchName(t){if(t===this.BranchName)return;let e=this.BranchName;this.BranchName=t,this.PageName=t,this._ParentPage&&this._ParentPage.routerRenameChild(e,t)}setOnKeyDown(t){this._OnKeyDown=t}setOnKeyUp(t){this._OnKeyUp=t}setOnFocus(t){this._OnFocus=t}setOnBlur(t){this._OnBlur=t}setDispatchKeyUp(t){this._DispatchKeyUp=t}setDispatchKeyDown(t){this._DispatchKeyDown=t}setDispatchKeyProxy(t,e){this._DKeyDownProxy=t,this._DKeyUpProxy=e}requestFocus(t){let e=this.RouterDelegate.ref;return this.AsHub&&this.GetParentPage()&&(e=this.GetParentPage().RouterDelegate.ref),e?e.focus(this.BranchName,t):(console.error("error: lost router"),!1)}OnKeyDown(t){return!!this._OnKeyDown&&this._OnKeyDown(t)}OnKeyUp(t){return!!this._OnKeyUp&&this._OnKeyUp(t)}dispatchKeyDown(t){return this.DispatchKeyDown(t)}DispatchKeyDown(t){return A.sLastFocus=this,this._DKeyDownProxy?this._DKeyDownProxy(t,this._OriginDispatchKeyDown):this._OriginDispatchKeyDown(t)}_OriginDispatchKeyDown(t){let e=!1;return this._DispatchKeyDown&&(e=this._DispatchKeyDown(t)),!!e||super.DispatchKeyDown(t)}dispatchKeyUp(t){return this.DispatchKeyUp(t)}DispatchKeyUp(t){return this.__DKeyUpProxy?this.__DKeyUpProxy(t,this._OriginDispatchKeyUp):this._OriginDispatchKeyUp(t)}_OriginDispatchKeyUp(t){let e=!1;return this._DispatchKeyUp&&(e=this._DispatchKeyUp(t)),!!e||super.DispatchKeyUp(t)}attachToActivity(t,e){this.AttachToActivity(t,e)}AttachToActivity(t,e){super.SetParent(t,e)}setParent(t){this.SetParent(t)}SetParent(t){if(null!=t&&(super.SetParent(t,null),this._ParentPage._Mounted&&(this.updateMountState(),I()),t instanceof A)){if(this.RouterDelegate.ref&&this.RouterDelegate.ref._IsTemp){let e=this.RouterDelegate.ref;this.RouterDelegate.ref=null,e.forEach(((e,s)=>{t.routerAdd(s,e)}))}t.routerAdd(this.BranchName,this)}}focus(t){this.Focus(t)}Focus(t){if(!this._Mounted)return A.sFocusMemos.push({obj:this,bcf:t}),void console.log("page base tree not build, cache focus");super.Focus(t)}OnFocus(){this._OnFocus&&this._OnFocus()}OnBlur(){this._OnBlur&&this._OnBlur()}onUnMount(){let t=this.GetParentPage();t&&t.RemoveSubPage(this),this.ClearSubPages(),this.routerUnbind()}getName(){let t=this,e=[this.RouterDelegate.ref.NameSpace];this.AsHub||e.push(this.BranchName);let s=this.RouterDelegate.ref;do{if(t=t.GetParentPage(),"__AppRoot__"==e[0])break;t&&t.RouterDelegate.ref!=s&&(s=t.RouterDelegate.ref,e.unshift(s.NameSpace))}while(t);return"__AppRoot__"==e[0]?e[0]="":console.error("ERROR: missing app root"),e.join(".")}getNodeByName(t){return this.RouterDelegate.ref.getNodeByName(t,this)}printFocusNodeList(){this.getHub().printFocusList()}printGlobalLastFocus(){this.getHub().printGlobalLastFocus()}}A.sFocusMemos=[],A.sLastFocus=null,A.sRootPageNode=null;let I=()=>{let t=A.sFocusMemos.length;if(t>0){let e=A.sFocusMemos;A.sFocusMemos=[];for(let s=0;s<t;s++)e[s].obj.Focus(e[s].bcf)}},M=1;class x extends j{constructor(){super(),this.FocusNodeRef=new A(""+M++),this.HubRef=void 0}jsvGetTagName(){return j.TAG.FDIV}setAttribute(t,e){if(t)if("fname"===t)e&&this.FocusNodeRef.setBranchName(e);else if("new-namespace"===t&&""!==e&&!this.HubRef){let t=new P(!1,e);this.HubRef=t,this.FocusNodeRef.setHub(t),this.FocusNodeRef.setBranchName(e)}}jsvGetHub(){return this.HubRef}}class V{constructor(){this.src=null,this.onerror=null,this.onload=null}setAttribute(t,e){console.log("LinkElement.setAttribute() name="+t+", value=",e),this[t]=e}jsvLoadResource(){let t=!1,s=null;if(null!=this.href){var i=new e(this.href);console.log("Ignore to load link from url="+i.href),t=!0}else console.warn("Failed to load link, href is not exists."),s="NoSrc";this.jsvOnLoadResult(t,s)}jsvOnLoadResult(t,e){if(console.log("jsvOnLoadResult isSuccess:"+t+", errCode:"+e),t){if(this.onload){let t=new i("load");this.onload(t)}}else this.onerror&&this.onerror({type:"jsvErr_"+e,target:this})}}class N{constructor(){this.src=null,this.onerror=null,this.onload=null,this.charset=null,this.timeout=120}setAttribute(t,e){console.log("ScriptElement.setAttribute() name="+t+", value=",e),this[t]=e}jsvLoadResource(){if(null!=this.src){var t=new e(this.src);console.log("load script with url="+t.href);var s=this;window.JsView.runJsWithUrl(t.href,!1,((t,e)=>{s.jsvOnLoadResult(t,e)}))}}jsvOnLoadResult(t,e){if(console.log("onLoadResult "+t+" "+e),t){if(this.onload){let t=new i("load");this.onload(t)}}else this.onerror&&this.onerror({type:"jsvErr_"+e,target:this})}}class L extends j{constructor(){super(),console.log("Document header construct")}appendChild(t){"HTMLScriptElement"==t.constructor.name||"HTMLStyleElement"==t.constructor.name||"HTMLLinkElement"==t.constructor.name?window.originDocument.headAppendChild(t):super.appendChild(t),(t instanceof V||t instanceof N)&&t.jsvLoadResource()}removeChild(t){"HTMLScriptElement"==t.constructor.name||"HTMLStyleElement"==t.constructor.name||"HTMLLinkElement"==t.constructor.name?window.originDocument.headRemoveChild(t):super.removeChild(t)}}class _ extends i{constructor(t){super("load")}}class D extends j{constructor(e){super(e),this.jsvImageView=new t.LayoutView(null,"img"),this.jsvMainView.AddView(this.jsvImageView),this._ImageInLoading=!1,this.jsvColorSpace=t.ColorSpace.RGBA_8888,this.jsvScaleDownTex=null,this._HasUserOnLoad=!1,this._OnLoadSeq=1}jsvGetTagName(){return j.TAG.IMAGE}setAttribute(t,e){this.jsvTakeTextureAttribute(t,e)?console.assert(!this._ImageInLoading,`set ${t} after src`):(super.setAttribute(t,e),t===j.ATTRIBUTE.SRC&&(this._ImageInLoading=!0,this.jsvStore.textureWidth=NaN,this.jsvStore.textureHeight=NaN,this.jsvDrawImage()))}jsvSetElementProp(t){this.jsvImageView.SetElementProp(t,s.RootActivity)}jsvCallbackOnUnloadForgeView(){return()=>{if(this._HasUserOnLoad){let t=this.jsvImageView?.TextureSetting?.Texture;t&&t.DisableBackgroundLoad(this)}}}jsvFlushEventHandlers(){if(super.jsvFlushEventHandlers(),this.eventHandlers.onLoad){let t=this.jsvImageView?.TextureSetting?.Texture;t&&(this._HasUserOnLoad=!0,t.EnableBackgroundLoad(this))}else if(this._HasUserOnLoad){let t=this.jsvImageView?.TextureSetting?.Texture;t&&t.DisableBackgroundLoad(this),this._HasUserOnLoad=!1}}jsvTakeTextureAttribute(t,e){return"jsv_img_color_space"==t||"jsvImgColorSpace"==t||"jsv-img-color-space"==t?(this.jsvColorSpace=e,!0):("jsv_img_scaledown_tex"==t||"jsvImgScaledownTex"==t||"jsv-img-scaledown-tex"==t)&&(""!==e&&void 0!==e||(e="true"),this.jsvScaleDownTex=e,!0)}jsvFlushViewLayout(){this._ImageInLoading?(this.jsvImageView.WaitTextureToResize(!0),this.jsvImageView.ResetLayoutParams({x:0,y:0,width:this.style.width,height:this.style.height})):this.jsvImageView.WaitTextureToResize(!1),super.jsvFlushViewLayout()}jsvFlushViewBackground(){this.jsvDrawImage();this.getAttribute(j.ATTRIBUTE.SRC)}jsvOnLoaded(t){if(console.log("ImageElement.jsvOnLoaded() imageSize="+JSON.stringify(t)),this._ImageInLoading=!1,this.jsvStore.textureWidth=t.width,this.jsvStore.textureHeight=t.height,this.style.jsvLazySyncCache.setCacheProperty(y.TYPE.LAYOUT_SIZE,!0),this._HasUserOnLoad){let t=new _;t.target=this,document.dispatchEvent(t)}}jsvOnLoadForgeView(){this.style.objectFit||this.style.jsvSetPropertySilently("objectFit",y.ObjectFit.FILL),super.jsvOnLoadForgeView()}jsvApplyObjectFit(t){return j.applyObjectFitCommon(this,t,this.jsvImageView)}jsvDrawImage(){if(!this.src)return;let t=null;"true"===this.jsvScaleDownTex&&(this.style&&this.style.width?t={width:this.style.width,height:0}:console.error("set jsvScaleDownTex while style.width is not set")),this._OnLoadSeq++;let e=this._OnLoadSeq;s.SetBackgroundImage(this.jsvImageView,this.src,this.style.borderRadius,(t=>{e===this._OnLoadSeq&&this.jsvOnLoaded(t)}),t,this.jsvColorSpace)}}class F extends j{constructor(e){super(),this.jsvMainView=new t.JsvElementView(e)}get textContent(){return this.jsvMainView.textContent}set textContent(t){this.jsvMainView.textContent=t}setAttribute(t,e){super.setAttribute(t,e),this.jsvMainView.setAttribute(t,e)}removeAttribute(t){super.removeAttribute(t),this.jsvMainView.removeAttribute(t)}getAttribute(t){return this.jsvMainView.getAttribute(t)}hasAttribute(t){return this.jsvMainView.hasAttribute(t)}jsvOnStyleChanged(t){super.jsvOnStyleChanged(t)}}class k{constructor(t){let e=t.indexOf(k.KeyFramesFlag)+k.KeyFramesFlag.length,s=t.indexOf("{"),i=t.substring(e,s);this.name=i.trim(),this.cssText=t}}k.KeyFramesFlag="@keyframes";class U{constructor(t){this.jsvCssRules=null,this.jsvTextContent=t}get cssRules(){if(this.jsvCssRules)return this.jsvCssRules;this.jsvCssRules=new Array;if(this.jsvTextContent.indexOf(k.KeyFramesFlag)<0)return this.jsvCssRules;var t=this.jsvTextContent.split(k.KeyFramesFlag);for(let e in t)0!=e&&this.insertRule(k.KeyFramesFlag+t[e]);return this.jsvCssRules}insertRule(t,e){if(void 0===e&&(e=this.jsvCssRules.length),t.indexOf(k.KeyFramesFlag)<0)throw Error("StyleSheet.insertRule() Rule is not supported except keyframes.");let s=new k(t);this.jsvCssRules.splice(e,0,s)}deleteRule(t){this.jsvCssRules.splice(t,1)}}class G extends j{constructor(t){super(t),this.textContent=null}jsvGetTagName(){return j.TAG.STYLE}appendChild(t){super.appendChild(t);let e=new U(t.textContent);document.jsvAppendStyleSheet(e)}removeChild(t){throw super.removeChild(t),Error("Failed to removeChild, unimplement!.")}}class H extends j{}class B extends S{constructor(t){super(t),console.log("VideoElement.constructor()",this),this._EventCache=[],this._UseTexture=!1,this._StartTime=0}jsvGetTagName(){return j.TAG.VIDEO}setAttribute(t,e){("jsv-media-usetexture"!==t||"true"!==e&&!0!==e&&""!==e)&&("jsv_media_usetexture"!==t||"true"!==e)?super.setAttribute(t,e):this._UseTexture=!0}removeAttribute(t){if("jsv-media-usetexture"===t||"jsv_media_usetexture"===t)return this._UseTexture=!1,void console.log("removeAttribute jsv_media_usetexture");super.removeAttribute(t)}jsvFlushViewLayout(){super.jsvFlushViewLayout();let t=this.style.JsvVideoRotation;isNaN(t)&&(t=0),this.style.objectFit&&this.style.objectFit!=y.ObjectFit.CONTAIN&&this.style.objectFit!=y.ObjectFit.FILL&&(console.error("Video rotation is not valid on objectFit=",this.style.objectFit),t=0),this.jsvMedia&&this.jsvMedia.setRotation?.(t,this.style.width,this.style.height,this.style.objectFit==y.ObjectFit.FILL)}jsvAddMediaListener(t){this.jsvMedia?this.jsvMedia.addEventListener(t,(()=>{let e=new i(t);e.target=this,this.dispatchEvent(e)})):this._EventCache.push(t)}jsvFlushVideoView(){this.jsvMediaView&&(this.jsvStore.textureWidth=this.jsvMedia.videoWidth,this.jsvStore.textureHeight=this.jsvMedia.videoHeight,this.style.jsvLazySyncCache.setCacheProperty(y.TYPE.LAYOUT_SIZE,!0))}jsvApplyObjectFit(t){return j.applyObjectFitCommon(this,t,this.jsvMediaView)}jsvInit(){console.log("VideoElement jsvInit"),this._UseTexture?this.jsvMedia=new S.HOOKS.OffscreenVideo:this.jsvMedia=new S.HOOKS.Video,this._EventCache.length>0&&(this._EventCache.map((t=>{this.jsvAddMediaListener(t)})),this._EventCache=[]),this.addEventListener("load",this.jsvOnLoaded.bind(this)),super.jsvInit()}jsvRelease(){super.jsvRelease(),this.jsvMedia=null}jsvOnLoaded(){if(!this.jsvMediaView){let e;if(this._UseTexture){this.jsvMediaView=new t.LayoutView;let i,n=s.TextureManager.GetOffScreenMediaTexture(this.jsvMedia),r=this.style.borderRadius;r&&(i=new t.ViewRoundCornerMask(r.topLeft,r.topRight,r.bottomLeft,r.bottomRight)),e=new t.TextureSetting(n,i)}else{this.jsvMediaView=new t.VideoView(this.jsvMedia);let i=s.TextureManager.GetColorTexture("rgba(0,0,0,0)");e=new t.TextureSetting(i,null,null,!1)}this.jsvMainView.AddView(this.jsvMediaView),this.jsvMediaView.ResetTexture(e)}this.jsvFlushVideoView()}jsvOnLoadForgeView(){this.style.objectFit||this.style.jsvSetPropertySilently("objectFit",y.ObjectFit.CONTAIN),super.jsvOnLoadForgeView()}onJsViewHide(){this._StartTime=this.jsvMedia.currentTime,super.onJsViewHide(),this.jsvMedia.setState("autoPlay",!1,"boolean")}onJsViewShow(){this.jsvMedia||this.jsvInit(),this.jsvMedia.src=this.srcValue,this.jsvMedia.startTime=Math.max(this._StartTime-1,0),this._StartTime=0,this.stopByOnHide&&(this.stopByOnHide=!1,this.jsvMedia.play())}}B.PROP={SetOnly:[],GetOnly:["videoHeight","videoWidth"],SetAndGet:["height","poster","width"]};for(let t in B.PROP){let e=B.PROP[t];for(let s of e){let e={};"SetOnly"!==t&&"SetAndGet"!==t||(e.set=function(t){this.media[s]=t}),"GetOnly"!==t&&"SetAndGet"!==t||(e.get=function(){return this.media[s]}),B.prototype[s]=e}}B.EVENTS=["oncanplay","oncanplaythrough","ondurationchange","onended","onerror","onload","onloadedmetadata","onloadstart","onpause","onplay","onplaying","onprogress","onseeking","onseeked","onstalled","ontimeupdate"];class K extends u{constructor(t){super(u.TEXT_NODE),this.textContent=t}get nodeValue(){return this.textContent}set nodeValue(t){this.textContent=t,this.parentNode&&(this.parentNode.textContent=this.textContent)}}class W extends u{constructor(t){super(u.COMMENT_NODE),this.textContent=t}}let J={};class z{constructor(t,e,s){this._Element=s,J.hasOwnProperty(t)&&console.error(`Warn: FDivRoot duplicate name=${t}`),J[t]=this,this._DoInit(e)}_DoInit(t){let e=this._Element.FocusNodeRef;if(this._Element.setAttribute("new-namespace","__AppRoot__"),t&&e.setDispatchKeyProxy(t.keyDown,t.keyUp),window.JsView){let t=window.JsView.ForgeExt;e.attachToActivity(t.RootActivity,t.RootView)}else window.addEventListener("keydown",(t=>{var s=document.activeElement.tagName;s&&"input"===s.toLowerCase()||(e.dispatchKeyDown(t),t.preventDefault&&t.preventDefault())})),window.addEventListener("keyup",(t=>{var s=document.activeElement.tagName;s&&"input"===s.toLowerCase()||(e.dispatchKeyUp(t),t.preventDefault&&t.preventDefault())}))}getElement(){return this._Element}getHub(){return this._Element.jsvGetHub()}onMounted(){this._Element.FocusNodeRef.updateMountState(),I()}}class Y extends O{constructor(t){super(t),console.log("AudioElement.constructor()",this)}jsvGetTagName(){return j.TAG.AUDIOTRACK}jsvInit(){this.jsvMedia=new S.HOOKS.Audio("AudioTrack"),this.jsvOverrideMedia=!0,super.jsvInit()}}class X extends u{constructor(){console.log("Document.constructor()"),super(u.DOCUMENT_NODE),this.location=window.location,this.rootElement=new R,this.rootElement.ownerDocument=this,this.rootElement.id="root",this.activeElement=this.rootElement,this.head=new L,this.cookie="",this.styleSheets=new Array,window.JsView&&this.styleSheets.push(new U("@keyframes jsv-basic-slot {}")),this.jsvIsReady=!1}createElement(t){switch(t){case X.FDIV_ELEMENT:return new x;case X.DIV_ELEMENT:return new R;case X.IMG_ELEMENT:case X.FIMG_ELEMENT:return new D;case X.STYLE_ELEMENT:return new G;case X.AUDIO_ELEMENT:return new O;case X.AUDIOTRACK_ELEMENT:return new Y;case X.VIDEO_ELEMENT:return new B;case X.LINK_ELEMENT:return window.JsView?new V:window.originDocument.createElement(X.LINK_ELEMENT);case X.SCRIPT_ELEMENT:return window.JsView?new N:window.originDocument.createElement(X.SCRIPT_ELEMENT);case X.ANCHOR_ELEMENT:return new T;case X.SVG_ELEMENT:return new SVGElement;default:return 0!==t.indexOf("jsv")||window.JsView?(console.warn("Document.createElement() unknown name="+t),new H(t)):new F(t)}}createTextNode(t){return new K(t)}createEvent(t){return new i(t)}createComment(t){return new W(t)}getElementById(t){if("root"===t||"app"===t)return this.rootElement;throw Error("Document.getElementById() id="+t+" is UNIMPLEMENTED.")}getElementsByTagName(t){if("head"===t.toLowerCase())return window.JsView?[this.head]:window.originDocument.getElementsByTagName(t);if("link"===t.toLowerCase()||"script"===t.toLowerCase()||"style"===t.toLowerCase())return[];throw Error("Document.getElementsByTagName() name="+t+" is UNIMPLEMENTED.")}querySelector(t){if("root"===t||"#app"===t)return this.rootElement;if("head"===t)return this.head;if("base"===t)return null;if(t.startsWith("style[")&&t.endsWith("]"))return null;throw Error("Document.querySelector() selectors="+t+" is UNIMPLEMENTED.")}jsvAppendStyleSheet(t){document.styleSheets.push(t)}jsvGetKeyFrames(t,e){if(window.JsvCode.Dom.StyleSheets){const s=window.JsvCode.Dom.StyleSheets;for(const i of e){const e=s[`${t}-${i.replace("data-v-","")}`];if(e)return e}const i=s[t];if(i)return i}for(let e of this.styleSheets)for(let s of e.cssRules)if(s.name==t)return s.cssText;let s="@keyframes ",i=s+t;for(let t of this.styleSheets){let e=t.jsvTextContent,n=e.indexOf(i);if(n<0)continue;let r=e.indexOf("-keyframes",n+1),o=e.indexOf(s,n+1);o<0&&(o=e.length),r>0&&r<o&&(o=r);let a=e.substring(n,o);return t.insertRule(a,0),a}return null}jsvUpdateRootElement(t){console.log("Document.jsvUpdateRootElement() this.jsvIsReady = true"),this.rootElement.jsvMainView=t,this.jsvIsReady=!0}jsvInitFDivRoot(t,e,s){if(!s){let t=document.createElement("fdiv");this.rootElement.appendChild(t),this.rootElement=t,s=this.rootElement}return new z(t,e,s)}jsvGetFDivRoot(t){return function(t){return J[t]}(t)}}X.ANCHOR_ELEMENT="a",X.AUDIO_ELEMENT="audio",X.DIV_ELEMENT="div",X.IMG_ELEMENT="img",X.LINK_ELEMENT="link",X.SCRIPT_ELEMENT="script",X.STYLE_ELEMENT="style",X.SVG_ELEMENT="svg",X.VIDEO_ELEMENT="video",X.FIMG_ELEMENT="fimg",X.FDIV_ELEMENT="fdiv",X.AUDIOTRACK_ELEMENT="audiotrack";class $ extends j{jsvGetTagName(){return j.TAG.LINK}}if(window.JsvCode={Dom:{StyleSheets:{}}},window.Audio=O,window.Video=B,window.MutationObserver=class{constructor(t){this.callback=t}observe(t,e){if(!(t instanceof u))throw Error("TypeError: Failed to execute 'observe' on 'MutationObserver': parameter 1 is not of type JsView's 'Node'");for(const t of Object.keys(e))"childList"==t||console.warn("JsView: only childList config is supported! ignore "+t);e.childList&&t.jsvObserveChildChanged((()=>{this.callback?.()}))}disconnect(){this.callback=void 0}},window.JsView){console.log("Declare Dom Proxy."),global.SVGElement=$,global.Element=j;let t=new e(window.JsView.getAppUrl(),!0);window.location.applyUrlInfo?window.location.applyUrlInfo(t):window.location=t,window.addEventListener=function(t,e){},window.document=new X,window.history={},window.navigator={userAgent:"jsview-runtime"},window.HTMLIFrameElement=function(){}}h.I("Using JsView Runtime");export{X as Document,s as ForgeExtension,L as HeadElement,l as JsViewForgeApp,o as JsvLazySyncCache,h as Log,r as gSyncTimesCounter};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@shijiu/jsview-vue",
3
- "version": "0.9.270",
3
+ "version": "0.9.276",
4
4
  "bin": {
5
5
  "jsview-post-build": "./scripts/jsview-post-build.js",
6
6
  "jsview-post-install": "./scripts/jsview-post-install.js",
@@ -7,7 +7,6 @@ Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
8
  const compilerSfc = require("./compiler-sfc.cjs");
9
9
 
10
- var findCacheDir = _interopDefaultLegacy(require("find-cache-dir"));
11
10
  var fs = _interopDefaultLegacy(require('fs'));
12
11
  var hash = _interopDefaultLegacy(require('hash-sum'));
13
12
  var path = _interopDefaultLegacy(require('path'));
@@ -19,6 +18,7 @@ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'defau
19
18
 
20
19
  const adaptPath = (path.posix || path);
21
20
 
21
+ var nodeModulesDir = path.resolve(process.cwd(), 'node_modules')
22
22
  var cachedCssStyles = {}
23
23
 
24
24
  function ensureSfcDescriptor(descriptor) {
@@ -107,7 +107,7 @@ function compileCssToJs(sfc, options) {
107
107
  // styleCodeContainer.add(styleCode);
108
108
 
109
109
  checkSelectors(node, styleInfo.styleFilePath, styleInfo.styleSelectors); // 检测selector是否已经处理过
110
- styleImportContainer += `\nimport "${styleInfo.styleJsFilePath}";`
110
+ styleImportContainer += `\nimport "${path.relative(nodeModulesDir, styleInfo.styleJsFilePath)}";`
111
111
  } else if(node.name === "keyframes") {
112
112
  const styleFilePath = node.source.input.file;
113
113
  const styleSelectors = new Set([node.params]);
@@ -151,7 +151,7 @@ function checkSelectors(node, styleFilePath, styleSelectors) {
151
151
  const cachedSelectors = cachedCssStyles[cachedFilePath];
152
152
  for(let selector of cachedSelectors) {
153
153
  if(styleSelectors.has(selector)) { // 发现重复的selector
154
- let errMsg = "JsView Error: Multi defined CSS selector '" + selector + "' from " + node.source.input.file + ".\n";
154
+ let errMsg = "JsView Warn: Multi defined CSS selector '" + selector + "' from " + node.source.input.file + ".\n";
155
155
  errMsg += "It has been defined in " + cachedFilePath + ".\n";
156
156
  check(false, node.source.input.css, errMsg);
157
157
  }
@@ -219,9 +219,10 @@ function compileAndSaveImportedNode(styleFilePath, styleNodes) {
219
219
  })
220
220
 
221
221
  // 保存到js文件并import到script中
222
- const cacheDir = findCacheDir({
223
- name: 'jsview-dom', create: true
224
- });
222
+ const cacheDir = path.resolve(nodeModulesDir, '@shijiu', '.cache')
223
+ if (!fs.existsSync(cacheDir)) {
224
+ fs.mkdirSync(cacheDir);
225
+ }
225
226
  const styleJsFileName = adaptPath.basename(styleFilePath) + `.${hash(styleFilePath)}.js`;
226
227
  const styleJsFilePath = adaptPath.join(cacheDir, styleJsFileName);
227
228
 
@@ -11,24 +11,31 @@
11
11
  </div>
12
12
  </template>
13
13
 
14
- <script setup>
15
- /* eslint-disable no-unused-vars */
16
- import { defineProps } from "vue";
14
+ <script>
17
15
 
18
- const name = 'TitleBlock';
19
- const props = defineProps({
20
- title: String,
21
- index: Number,
22
- itemSides: Object
23
- })
16
+ export default {
17
+ props: {
18
+ title: String,
19
+ index: Number,
20
+ itemSides: Object,
21
+ },
22
+ computed: {
23
+ blockOpacity() {
24
+ return (((this.index) % 2 === 0) ? 0.2 : 0.5);
25
+ }
26
+ },
27
+ data() {
28
+ return {
29
+ titleStyle: {
30
+ lineHeight: 18,
31
+ width: this.itemSides.width, height: 18,
32
+ backgroundColor: 'rgba(0,0,255,0.7)',
33
+ }
34
+ }
35
+ }
24
36
 
25
- const blockOpacity = (((props.index) % 2 === 0) ? 0.2 : 0.5);
37
+ }
26
38
 
27
- const titleStyle = {
28
- lineHeight: 18,
29
- width: props.itemSides.width, height: 18,
30
- backgroundColor: 'rgba(0,0,255,0.7)',
31
- };
32
39
  </script>
33
40
 
34
41
  <style>
@@ -7,14 +7,12 @@
7
7
  </div>
8
8
  </template>
9
9
 
10
- <script setup>
11
- /* eslint-disable no-unused-vars */
12
- import { defineProps } from "vue";
13
-
14
- const name = 'Title';
15
- const props = defineProps({
16
- itemSides: Object
17
- })
10
+ <script>
11
+ export default {
12
+ props: {
13
+ itemSides: Object
14
+ }
15
+ }
18
16
  </script>
19
17
 
20
18
  <style>
@@ -28,41 +28,53 @@
28
28
 
29
29
  </template>
30
30
 
31
- <script setup>
31
+ <script>
32
32
  /* eslint-disable no-unused-vars */
33
- import { defineProps, reactive, onMounted, onBeforeUnmount } from "vue";
33
+ import { reactive } from "vue";
34
34
  import ContentBlock from '../ContentBlock';
35
35
  import AnimKeyframeBasic from './AnimKeyframeBasic';
36
36
  import AnimKeyframeComposite from './AnimKeyframeComposite';
37
37
  import AnimTransition from './AnimTransition';
38
38
 
39
- const name = 'DivGroup2';
40
- const props = defineProps({
41
- contentClass: String,
42
- itemSides: Object
43
- })
44
-
45
- const state = reactive({
46
- timeCount: 20
47
- })
48
- var timerId = -1;
49
-
50
- onMounted(() => {
51
- timerId = setInterval(() => {
52
- // console.log('change timeCount: ' + timeCount);
53
- state.timeCount = (state.timeCount + 5);
39
+ export default {
40
+ props: {
41
+ contentClass: String,
42
+ itemSides: Object
43
+ },
44
+ components: {
45
+ ContentBlock,
46
+ AnimKeyframeBasic,
47
+ AnimKeyframeComposite,
48
+ AnimTransition,
49
+ },
50
+ computed: {
51
+ contentBlockProps() {
52
+ return {
53
+ colIndex: 0,
54
+ itemSides: this.itemSides
55
+ }
56
+ }
57
+ },
58
+ data() {
59
+ return {
60
+ timerId: -1,
61
+ state: reactive({
62
+ timeCount: 20
63
+ })
64
+ }
65
+ },
66
+ mounted() {
67
+ this.timerId = setInterval(() => {
68
+ // console.log('change timeCount: ' + timeCount);
69
+ this.state.timeCount = (this.state.timeCount + 5);
54
70
  }, 2000);
55
- });
56
-
57
- onBeforeUnmount(() => {
58
- if (timerId >= 0) {
59
- window.clearInterval(timerId);
71
+ },
72
+ beforeUnmount() {
73
+ if (this.timerId >= 0) {
74
+ window.clearInterval(this.timerId);
60
75
  }
61
- timerId = -1;
62
- });
76
+ this.timerId = -1;
77
+ }
78
+ }
63
79
 
64
- const contentBlockProps = {
65
- colIndex: 0,
66
- itemSides: props.itemSides
67
- };
68
80
  </script>
@@ -24,25 +24,31 @@
24
24
  </div>
25
25
  </template>
26
26
 
27
- <script setup>
28
- /* eslint-disable no-unused-vars */
29
- const blockSize = {
30
- width: 70,
31
- height: 70,
32
- };
33
-
34
- const titleStyle = {
35
- width: 60, height: 20,
36
- textAlign: 'center',
37
- lineHeight: 20
38
- };
39
-
40
- const itemStyle = {
41
- top: 20,
42
- width: 50, height: 50,
43
- backgroundColor: 'rgba(255, 0, 0, 1)'
44
- };
45
-
27
+ <script>
28
+ export default {
29
+ computed: {
30
+ blockSize() {
31
+ return {
32
+ width: 70,
33
+ height: 70,
34
+ }
35
+ },
36
+ titleStyle() {
37
+ return {
38
+ width: 60, height: 20,
39
+ textAlign: 'center',
40
+ lineHeight: 20
41
+ }
42
+ },
43
+ itemStyle() {
44
+ return {
45
+ top: 20,
46
+ width: 50, height: 50,
47
+ backgroundColor: 'rgba(255, 0, 0, 1)'
48
+ }
49
+ },
50
+ }
51
+ }
46
52
  </script>
47
53
 
48
54
  <style>