@shijiu/jsview-vue 0.9.426 → 0.9.502

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.
Files changed (63) hide show
  1. package/dom/bin/jsview-browser-debug-dom.min.js +1 -1
  2. package/dom/bin/jsview-dom.min.js +1 -1
  3. package/dom/jsv-browser-debug-dom.js_1 +8 -0
  4. package/dom/jsv-dom.js_1 +6 -0
  5. package/dom/jsv-forge-define.js_1 +6 -0
  6. package/dom/target_core_revision.js +3 -3
  7. package/package.json +1 -1
  8. package/patches/node_modules/@vue/cli-service/lib/config/assets.js +1 -1
  9. package/patches/node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js +4 -1
  10. package/samples/ColorSpace/App.vue +4 -4
  11. package/samples/DemoHomepage/router.js +17 -2
  12. package/samples/FilterDemo/App.vue +121 -0
  13. package/samples/GridDemo/App.vue +183 -0
  14. package/samples/GridDemo/ButtonBlock.vue +111 -0
  15. package/samples/GridDemo/FocusItem.vue +56 -0
  16. package/samples/GridDemo/Item.vue +101 -0
  17. package/samples/NinePatchDemo/App.vue +146 -0
  18. package/samples/NinePatchDemo/Item.vue +70 -0
  19. package/samples/NinePatchDemo/assets/border.png +0 -0
  20. package/samples/TouchSample/App.vue +137 -0
  21. package/samples/TouchSample/Item.vue +101 -0
  22. package/samples/TouchSample/MetroWidgetHorizontal.vue +144 -0
  23. package/samples/TouchSample/MetroWidgetVertical.vue +144 -0
  24. package/samples/TouchSample/TouchContainerHorizontal.vue +159 -0
  25. package/samples/TouchSample/TouchContainerVertical.vue +159 -0
  26. package/samples/TouchSample/data.js +81 -0
  27. package/samples/{ColorSpace → assets}/bmpDemo.bmp +0 -0
  28. package/samples/{ColorSpace → assets}/jpegDemo.jpeg +0 -0
  29. package/samples/{ColorSpace → assets}/pngDemo.png +0 -0
  30. package/samples/{ColorSpace → assets}/pngNoAlphaDemo.png +0 -0
  31. package/samples/assets/webpDemo.webp +0 -0
  32. package/scripts/jsview-jsmap-serve.js +63 -0
  33. package/scripts/jsview-post-build.js +50 -3
  34. package/scripts/jsview-post-install.js +22 -0
  35. package/utils/JsViewEngineWidget/JsvFocusBlock.vue +7 -5
  36. package/utils/JsViewEngineWidget/JsvFocusManager.js +5 -0
  37. package/utils/JsViewEngineWidget/MetroWidget/ItemView.vue +7 -14
  38. package/utils/JsViewEngineWidget/MetroWidget/MetroWidget.vue +214 -89
  39. package/utils/JsViewEngineWidget/MetroWidget/RootView.vue +4 -3
  40. package/utils/JsViewEngineWidget/SimpleWidget/SimpleWidget.vue +2 -0
  41. package/utils/JsViewEngineWidget/TemplateParser.js +8 -6
  42. package/utils/JsViewPlugin/JsvPlayer/GetVersion.js +20 -0
  43. package/utils/JsViewPlugin/JsvPlayer/JsvMedia.js +220 -85
  44. package/utils/JsViewPlugin/JsvPlayer/JsvPlayer.vue +43 -14
  45. package/utils/JsViewPlugin/JsvPlayer/JsvPlayerBrowser.vue +25 -12
  46. package/utils/JsViewPlugin/JsvPlayer/index.js +4 -0
  47. package/utils/JsViewPlugin/JsvPlayer/version.js +19 -0
  48. package/utils/JsViewVueTools/DebugTool.js +24 -0
  49. package/utils/JsViewVueTools/NinePatchHelper.js +44 -0
  50. package/utils/JsViewVueTools/TypeCheckAndSet.js +27 -0
  51. package/utils/JsViewVueWidget/BrowserDebugWidget/BrowserQrcode.vue +19 -8
  52. package/utils/JsViewVueWidget/BrowserDebugWidget/JsvApic/BrowserApic.vue +1 -1
  53. package/utils/JsViewVueWidget/JsvApic/JsvApic.vue +2 -2
  54. package/utils/JsViewVueWidget/JsvFilterView.vue +73 -0
  55. package/utils/JsViewVueWidget/JsvGrid.vue +573 -0
  56. package/utils/JsViewVueWidget/JsvInput/JsvInput.vue +7 -0
  57. package/utils/JsViewVueWidget/JsvNinePatch.vue +2 -2
  58. package/utils/JsViewVueWidget/JsvQrcode/JsvQrcode.vue +12 -3
  59. package/utils/JsViewVueWidget/JsvSpray/JsvSpray.vue +1 -1
  60. package/utils/JsViewVueWidget/JsvTextureAnim/CommonType.js +8 -0
  61. package/utils/JsViewVueWidget/JsvTextureAnim/JsvTextureAnim.vue +171 -38
  62. package/utils/JsViewVueWidget/JsvTextureAnim/index.js +3 -2
  63. package/utils/JsViewVueWidget/JsvTouchContainer.vue +184 -0
@@ -1 +1 @@
1
- /* eslint-disable */ 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("./")||!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)+"/"}let e=window.JsView.Dom.__MainPath;t=t.startsWith("./")?e+t.substring(2):e+t}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):"";if(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:"",this.host.startsWith("[")){let t=this.host.indexOf("]");this.hostname=this.host.substring(0,t+1),t=this.host.substring(t+1).indexOf(":"),this.port=t>1?this.host.substring(t+1):""}else{let t=this.host.indexOf(":");this.hostname=t>0?this.host.substring(0,t):this.host,this.port=t>1?this.host.substring(t+1):""}}replace(t){this.href=t}}window.JsView&&window.JsView.registerUriConverter?.((t=>new e(t,!1).href));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 d extends i{}d.Type={FOCUS:"focus",BLUR:"blur"};class c 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 p{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 g{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.jsvLazyPrevInheritedClassNames=null,this.jsvLazyClassNames=null,this.jsvLazyInheritedClassNames=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?(t==y.PROP.ANIMATION?e=v.ConvertAnimation(e):t==y.PROP.TRANSITION&&(e=v.ConvertTransition(e)),e):(e=this.jsvGetClassPropValue(this.jsvLazyInheritedClassNames,this.jsvLazyClassAttributes,t),e?(t==y.PROP.ANIMATION?e=v.ConvertAnimation(e):t==y.PROP.TRANSITION&&(e=v.ConvertTransition(e)),e):void 0)}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,s){if(e.indexOf("JsvStyle_")<0){s?(this.jsvLazyPrevInheritedClassNames=this.jsvLazyInheritedClassNames,this.jsvLazyInheritedClassNames=e.split(" ")):(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(t,e,s){h.D("jsvGetChangedClassTypes() classNames="+t);let i={};if(e){w.RemoveRefStyle(this);const t=this.jsvGetClassDeclarations(e,s);for(const e of Object.keys(t)){i[y.JsvGetStyleType(e)]=!0}e=null}if(t){const e=this.jsvGetClassDeclarations(t,s);for(const[t,s]of Object.entries(e)){i[y.JsvGetStyleType(t)]=!0,"string"==typeof s&&s.startsWith("var(--")&&w.AppendRefStyle(s,this,t)}}return i}jsvSetChangedListener(t){this.jsvLazySyncCache.setOnSyncCallback((e=>{if(e.hasOwnProperty(y.TYPE.CLASS_NAME)){let t=this.jsvUpdateChangedClasses(this.jsvLazyClassNames,this.jsvLazyPrevClassNames,this.jsvLazyClassAttributes);Object.assign(e,t),t=this.jsvUpdateChangedClasses(this.jsvLazyInheritedClassNames,this.jsvLazyPrevInheritedClassNames,this.jsvLazyClassAttributes),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 p(e);case y.PROP.BORDERIMAGE:return new g(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 j{static getHandlers(t){const e=j.reactEventHandlers(t);return e||(t._vei?t._vei:{})}static reactEventHandlers(t){return null==f&&j._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 m extends u{constructor(e){super(u.ELEMENT_NODE),this.parentElement=null,this.tagName=this.jsvGetTagName(),this.tagName===m.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,scopedAttributes:[]},this.jsvLazySyncCache=new o("element"),this.instantSwapCallback=null,this.eventHandlers=null,this.jsvInheritClassDepth=null,this.jsvHasInheritClassChildren=!1}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 m&&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]=e,t.startsWith("data-v-")?this._jsvAppendScopedAttribute(t,0):"class"===t?this._jsvSetClassNames(e,0):"jsv-inherit-class"===t?this._jsvSetInheritClassDepth(parseInt(e)):t.startsWith(m.ATTRIBUTE.JSVPREFIX)?(t=t.replace(/-/g,"_"),this.jsvLazySyncCache.setCacheProperty(t,e)):window.JsView||"id"!==t||this.jsvMainView.Element&&(this.jsvMainView.Element.id=e))}removeAttribute(t){this[t]=void 0,t.startsWith(m.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 d(d.Type.BLUR);e.target=t,document.dispatchEvent(e)}let e=new d(d.Type.FOCUS);document.dispatchEvent(e)}jsvInsertChild(t,e){if(t.parentElement=this,t.nodeType===u.ELEMENT_NODE&&t.tagName!==m.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),(t.jsvInheritClassDepth>0||t.jsvHasInheritClassChildren)&&(this.jsvHasInheritClassChildren=!0)}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=j.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)}let i=this.style.visibility;"NONE"==this.style.display&&(i="HIDDEN"),this.jsvMaskView.SetVisibility(i);let n=null;null!==s&&window.JsView?n={x:s.x,y:s.y,width:s.width,height:s.height}:this.style.clipPath?n={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&&(n={x:0,y:0,width:this.style.width,height:this.style.height}),n?this.jsvMaskView.SetClipRect(n.x,n.y,n.width,n.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.scopedAttributes);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 c("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 c("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 m);)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}_jsvAppendScopedAttribute(t,e){if(0!=e&&this.jsvInheritClassDepth!=e||(this.jsvStore.scopedAttributes.push(t),this.style.jsvAppendClassAttribute(t)),this.jsvHasInheritClassChildren){e=this.jsvInheritClassDepth==e?1:e+1;for(const s of this.childNodes)s.jsvInheritClassDepth<=0&&0==s.jsvHasInheritClassChildren||s instanceof m&&(s.jsvStore.scopedAttributes.includes(t)||s._jsvAppendScopedAttribute(t,e))}}_jsvSetClassNames(t,e){if(0!=e&&this.jsvInheritClassDepth!=e||this.style.jsvApplyClasses(t,this.jsvInheritClassDepth==e),this.jsvHasInheritClassChildren){e=this.jsvInheritClassDepth==e?1:e+1;for(const s of this.childNodes)s.jsvInheritClassDepth<=0&&0==s.jsvHasInheritClassChildren||s instanceof m&&s._jsvSetClassNames(t,e)}}_jsvSetInheritClassDepth(t){if(t<=0)return;this.jsvInheritClassDepth=t;let e=this;for(let s=0;s<t&&(e=e.parentNode,e);s++);if(e){for(const s of e.jsvStore.scopedAttributes)this._jsvAppendScopedAttribute(s,t);this._jsvSetClassNames(e.class,t)}}}m.TAG={DIV:"DIV",IMAGE:"IMAGE",LINK:"LINK",STYLE:"STYLE",AUDIO:"AUDIO",VIDEO:"VIDEO",ANCHOR:"A",SVG:"SVG",FDIV:"FDIV",AUDIOTRACK:"AUDIOTRACK"},m.ATTRIBUTE={SRC:"src",JSVPREFIX:"jsv"};class S extends m{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 m.TAG.ANCHOR}}class T extends m{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}}T.HOOKS={Audio:Audio,Video:window._ExtVideo,OffscreenVideo:window._ExtOVP},T.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 T.PROP){let e=T.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?T.prototype[s]=e:Object.defineProperty(T.prototype,s,e)}}class O extends T{constructor(t){super(t),this.jsvOverrideMedia=!1,console.log("AudioElement.constructor()",this)}jsvGetTagName(){return m.TAG.AUDIO}jsvInit(){this.jsvOverrideMedia||(this.jsvMedia=new T.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 C{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){C._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){C._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 E=new C;class R extends m{constructor(){super(),this.jsvContentView=null,this.jsvRefedImgTex=null,this.jsvTextLatexEnable=!1,this.jsvEmoji=!1,this.jsvTextAlignMinWidth=NaN,this.jsvEmptyRect=null}jsvGetTagName(){return m.TAG.DIV}get textContent(){return this.jsvStore.textContent}set textContent(e){(e||this.jsvStore.textContent)&&(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=E.getTempPack(s);n||(n=t.sTextStyleCache.StyleToPack(e),E.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,d=0,c={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,c.str=o;let v=s.GetTextWidth(c),p=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(p,{x:d,y:0,width:v,height:this.style.height}),d+=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=E.getPersistPack(e);if(!s){let i=R._jsvStyleToPackData(this.style);s=t.sTextStyleCache.StyleToPack(i),E.putPersistPack(e,s)}return s}return null}static _jsvStyleToPackData(t){let e={textColor:t.color?t.color:"#000000",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.borderImageWidth,s=this.style.borderImage.slice,i=Math.floor(t.width*e.top/s.top),n=Math.floor(t.height*e.left/s.left);this.jsvMaskView.SetImageDspSize(i,n);let r=this.style.borderImageOutset?this.style.borderImageOutset:v.ConvertRect();this.jsvMaskView.SetPadding({start:r.left,width:Math.max(0,i-r.left-r.right)},{start:r.top,width:Math.max(0,n-r.top-r.bottom)}),this.jsvMaskView.SetRepeat([{start:e.left,width:Math.max(0,i-2*e.left)}],[{start:e.top,width:Math.max(0,n-2*e.top)}]),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 I{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(P.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 P 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._OnCustomerEvent=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 I(!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}setOnCustomerEvent(t){this._OnCustomerEvent=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)}OnCustomerEvent(t){return!!this._OnCustomerEvent&&this._OnCustomerEvent(t)}bubbleCustomerEvent(t){this.BubbleCustomerEvent(t)}dispatchKeyDown(t){return this.DispatchKeyDown(t)}DispatchKeyDown(t){return P.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(),A()),t instanceof P)){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 P.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()}}P.sFocusMemos=[],P.sLastFocus=null,P.sRootPageNode=null;let A=()=>{let t=P.sFocusMemos.length;if(t>0){let e=P.sFocusMemos;P.sFocusMemos=[];for(let s=0;s<t;s++)e[s].obj.Focus(e[s].bcf)}},N=1;class M extends m{constructor(){super(),this.FocusNodeRef=new P(""+N++),this.HubRef=void 0}jsvGetTagName(){return m.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 I(!1,e);this.HubRef=t,this.FocusNodeRef.setHub(t),this.FocusNodeRef.setBranchName(e)}}jsvGetHub(){return this.HubRef}}class x{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 V{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 m{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 x||t instanceof V)&&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 m{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 m.TAG.IMAGE}setAttribute(t,e){this.jsvTakeTextureAttribute(t,e)?console.assert(!this._ImageInLoading,`set ${t} after src`):(super.setAttribute(t,e),t===m.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(m.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 m.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 m{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 H extends m{constructor(t){super(t),this.textContent=null}jsvGetTagName(){return m.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 G extends m{}class B extends T{constructor(t){super(t),console.log("VideoElement.constructor()",this),this._EventCache=[],this._UseTexture=!1,this._StartTime=0}jsvGetTagName(){return m.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 m.applyObjectFitCommon(this,t,this.jsvMediaView)}jsvInit(){console.log("VideoElement jsvInit"),this._UseTexture?this.jsvMedia=new T.HOOKS.OffscreenVideo:this.jsvMedia=new T.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(),A()}}class Y extends O{constructor(t){super(t),console.log("AudioElement.constructor()",this)}jsvGetTagName(){return m.TAG.AUDIOTRACK}jsvInit(){this.jsvMedia=new T.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.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 M;case X.DIV_ELEMENT:return new R;case X.IMG_ELEMENT:case X.FIMG_ELEMENT:return new D;case X.STYLE_ELEMENT:return new H;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 x:window.originDocument.createElement(X.LINK_ELEMENT);case X.SCRIPT_ELEMENT:return window.JsView?new V:window.originDocument.createElement(X.SCRIPT_ELEMENT);case X.ANCHOR_ELEMENT:return new S;case X.SVG_ELEMENT:return new SVGElement;default:return 0!==t.indexOf("jsv")||window.JsView?(console.warn("Document.createElement() unknown name="+t),new G(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)}set cookie(t){window.__JsvCookies.setCookie(t)}get cookie(){return window.__JsvCookies.getCookie()}}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 m{jsvGetTagName(){return m.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=m;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};
1
+ /* eslint-disable */ 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("./")||!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)+"/"}let e=window.JsView.Dom.__MainPath;t=t.startsWith("./")?e+t.substring(2):e+t}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):"";if(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:"",this.host.startsWith("[")){let t=this.host.indexOf("]");this.hostname=this.host.substring(0,t+1),t=this.host.substring(t+1).indexOf(":"),this.port=t>1?this.host.substring(t+1):""}else{let t=this.host.indexOf(":");this.hostname=t>0?this.host.substring(0,t):this.host,this.port=t>1?this.host.substring(t+1):""}}replace(t){this.href=t}}window.JsView&&window.JsView.registerUriConverter?.((t=>new e(t,!1).href));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){for(let e=t.childNodes.length-1;e>=0;e--)t.removeChild(t.childNodes[e]);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 d extends i{}d.Type={FOCUS:"focus",BLUR:"blur"};class c 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 p{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 g{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.jsvLazyPrevInheritedClassNames=null,this.jsvLazyClassNames=null,this.jsvLazyInheritedClassNames=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?(t==y.PROP.ANIMATION?e=v.ConvertAnimation(e):t==y.PROP.TRANSITION&&(e=v.ConvertTransition(e)),e):(e=this.jsvGetClassPropValue(this.jsvLazyInheritedClassNames,this.jsvLazyClassAttributes,t),e?(t==y.PROP.ANIMATION?e=v.ConvertAnimation(e):t==y.PROP.TRANSITION&&(e=v.ConvertTransition(e)),e):void 0)}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,s){if(e.indexOf("JsvStyle_")<0){s?(this.jsvLazyPrevInheritedClassNames=this.jsvLazyInheritedClassNames,this.jsvLazyInheritedClassNames=e.split(" ")):(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(t,e,s){h.D("jsvGetChangedClassTypes() classNames="+t);let i={};if(e){w.RemoveRefStyle(this);const t=this.jsvGetClassDeclarations(e,s);for(const e of Object.keys(t)){i[y.JsvGetStyleType(e)]=!0}e=null}if(t){const e=this.jsvGetClassDeclarations(t,s);for(const[t,s]of Object.entries(e)){i[y.JsvGetStyleType(t)]=!0,"string"==typeof s&&s.startsWith("var(--")&&w.AppendRefStyle(s,this,t)}}return i}jsvSetChangedListener(t){let e=null;t&&(e=e=>{if(e.hasOwnProperty(y.TYPE.CLASS_NAME)){let t=this.jsvUpdateChangedClasses(this.jsvLazyClassNames,this.jsvLazyPrevClassNames,this.jsvLazyClassAttributes);Object.assign(e,t),t=this.jsvUpdateChangedClasses(this.jsvLazyInheritedClassNames,this.jsvLazyPrevInheritedClassNames,this.jsvLazyClassAttributes),Object.assign(e,t),e[y.TYPE.CLASS_NAME]=void 0}t(e)}),this.jsvLazySyncCache.setOnSyncCallback(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 p(e);case y.PROP.BORDERIMAGE:return new g(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 j{static getHandlers(t){const e=j.reactEventHandlers(t);return e||(t._vei?t._vei:{})}static reactEventHandlers(t){return null==f&&j._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 m extends u{constructor(e){super(u.ELEMENT_NODE),this.parentElement=null,this.tagName=this.jsvGetTagName(),this.tagName===m.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,scopedAttributes:[]},this.jsvLazySyncCache=new o("element"),this.instantSwapCallback=null,this.eventHandlers=null,this.jsvInheritClassDepth=null,this.jsvHasInheritClassChildren=!1}appendChild(t){super.appendChild(t),this.jsvInsertChild(t,null)}removeChild(t){this.jsvRemoveChild(t),super.removeChild(t)}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]=e,t.startsWith("data-v-")?this._jsvAppendScopedAttribute(t,0):"class"===t?this._jsvSetClassNames(e,0):"jsv-inherit-class"===t?this._jsvSetInheritClassDepth(parseInt(e)):t.startsWith(m.ATTRIBUTE.JSVPREFIX)?(t=t.replace(/-/g,"_"),this.jsvLazySyncCache.setCacheProperty(t,e)):window.JsView||"id"!==t||this.jsvMainView.Element&&(this.jsvMainView.Element.id=e))}removeAttribute(t){this[t]=void 0,t.startsWith(m.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 d(d.Type.BLUR);e.target=t,document.dispatchEvent(e)}let e=new d(d.Type.FOCUS);document.dispatchEvent(e)}jsvInsertChild(t,e){if(t.parentElement=this,t.nodeType===u.ELEMENT_NODE&&t.tagName!==m.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),(t.jsvInheritClassDepth>0||t.jsvHasInheritClassChildren)&&(this.jsvHasInheritClassChildren=!0)}else t.nodeType===u.TEXT_NODE&&(this.textContent=t.textContent)}jsvRemoveChild(t){t.parentElement=null,t.jsvLazySyncCache=null,t.style?.jsvSetChangedListener(null),t.style?.jsvDestory(),t.jsvAnimation?.Cancel(),t.jsvAnimation=null,t instanceof m&&this.jsvMainView.RemoveView(t.jsvMaskView)}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=j.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)}let i=this.style.visibility;"NONE"==this.style.display&&(i="HIDDEN"),this.jsvMaskView.SetVisibility(i);let n=null;null!==s&&window.JsView?n={x:s.x,y:s.y,width:s.width,height:s.height}:this.style.clipPath?n={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&&(n={x:0,y:0,width:this.style.width,height:this.style.height}),n?this.jsvMaskView.SetClipRect(n.x,n.y,n.width,n.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.scopedAttributes);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 c("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 c("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 m);)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}_jsvAppendScopedAttribute(t,e){if(0!=e&&this.jsvInheritClassDepth!=e||(this.jsvStore.scopedAttributes.push(t),this.style.jsvAppendClassAttribute(t)),this.jsvHasInheritClassChildren){e=this.jsvInheritClassDepth==e?1:e+1;for(const s of this.childNodes)s.jsvInheritClassDepth<=0&&0==s.jsvHasInheritClassChildren||s instanceof m&&(s.jsvStore.scopedAttributes.includes(t)||s._jsvAppendScopedAttribute(t,e))}}_jsvSetClassNames(t,e){if(0!=e&&this.jsvInheritClassDepth!=e||this.style.jsvApplyClasses(t,this.jsvInheritClassDepth==e),this.jsvHasInheritClassChildren){e=this.jsvInheritClassDepth==e?1:e+1;for(const s of this.childNodes)s.jsvInheritClassDepth<=0&&0==s.jsvHasInheritClassChildren||s instanceof m&&s._jsvSetClassNames(t,e)}}_jsvSetInheritClassDepth(t){if(t<=0)return;this.jsvInheritClassDepth=t;let e=this;for(let s=0;s<t&&(e=e.parentNode,e);s++);if(e){for(const s of e.jsvStore.scopedAttributes)this._jsvAppendScopedAttribute(s,t);this._jsvSetClassNames(e.class,t)}}}m.TAG={DIV:"DIV",IMAGE:"IMAGE",LINK:"LINK",STYLE:"STYLE",AUDIO:"AUDIO",VIDEO:"VIDEO",ANCHOR:"A",SVG:"SVG",FDIV:"FDIV",AUDIOTRACK:"AUDIOTRACK"},m.ATTRIBUTE={SRC:"src",JSVPREFIX:"jsv"};class S extends m{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 m.TAG.ANCHOR}}class T extends m{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}}T.HOOKS={Audio:Audio,Video:window._ExtVideo,OffscreenVideo:window._ExtOVP},T.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 T.PROP){let e=T.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?T.prototype[s]=e:Object.defineProperty(T.prototype,s,e)}}class C extends T{constructor(t){super(t),this.jsvOverrideMedia=!1,console.log("AudioElement.constructor()",this)}jsvGetTagName(){return m.TAG.AUDIO}jsvInit(){this.jsvOverrideMedia||(this.jsvMedia=new T.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 O{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){O._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){O._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 E=new O;class R extends m{constructor(){super(),this.jsvContentView=null,this.jsvRefedImgTex=null,this.jsvTextLatexEnable=!1,this.jsvEmoji=!1,this.jsvTextAlignMinWidth=NaN,this.jsvEmptyRect=null}jsvGetTagName(){return m.TAG.DIV}get textContent(){return this.jsvStore.textContent}set textContent(e){(e||this.jsvStore.textContent)&&(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=E.getTempPack(s);n||(n=t.sTextStyleCache.StyleToPack(e),E.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,d=0,c={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,c.str=o;let v=s.GetTextWidth(c),p=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(p,{x:d,y:0,width:v,height:this.style.height}),d+=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=E.getPersistPack(e);if(!s){let i=R._jsvStyleToPackData(this.style);s=t.sTextStyleCache.StyleToPack(i),E.putPersistPack(e,s)}return s}return null}static _jsvStyleToPackData(t){let e={textColor:t.color?t.color:"#000000",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.borderImageWidth,s=this.style.borderImage.slice,i=Math.floor(t.width*e.top/s.top),n=Math.floor(t.height*e.left/s.left);this.jsvMaskView.SetImageDspSize(i,n);let r=this.style.borderImageOutset?this.style.borderImageOutset:v.ConvertRect();this.jsvMaskView.SetPadding({start:r.left,width:Math.max(0,i-r.left-r.right)},{start:r.top,width:Math.max(0,n-r.top-r.bottom)}),this.jsvMaskView.SetRepeat([{start:e.left,width:Math.max(0,i-2*e.left)}],[{start:e.top,width:Math.max(0,n-2*e.top)}]),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 I{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(P.sLastFocus)}getCurrentFocusStack(){const t=[];if(this.RouterDelegate.ref){let e=this.RouterDelegate.ref.getCurrentFocusNode();for(;e&&e instanceof P&&e.RouterDelegate.ref===this.RouterDelegate.ref;)t.push({name:e.BranchName}),e=e.GetParentPage()}else console.error("getCurrentFocusStack failed: router delegate is null.");return t}}class b{constructor(t,e){this._IsTemp=!!t,this._ChildMap={},this._FocusNameBeforeMount=null,this._FocusNodeName=null,this.NameSpace=e}getCurrentFocusNode(){return this._ChildMap[this._FocusNodeName]}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._FocusNameBeforeMount==t&&(this._FocusNameBeforeMount=null,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):(this._FocusNameBeforeMount=t,!1)}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 P 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._OnCustomerEvent=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 I(!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}setOnCustomerEvent(t){this._OnCustomerEvent=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)}OnCustomerEvent(t){return!!this._OnCustomerEvent&&this._OnCustomerEvent(t)}bubbleCustomerEvent(t){this.BubbleCustomerEvent(t)}dispatchKeyDown(t){return this.DispatchKeyDown(t)}DispatchKeyDown(t){return P.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(),A()),t instanceof P)){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 P.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()}}P.sFocusMemos=[],P.sLastFocus=null,P.sRootPageNode=null;let A=()=>{let t=P.sFocusMemos.length;if(t>0){let e=P.sFocusMemos;P.sFocusMemos=[];for(let s=0;s<t;s++)e[s].obj.Focus(e[s].bcf)}},N=1;class M extends m{constructor(){super(),this.FocusNodeRef=new P(""+N++),this.HubRef=void 0}jsvGetTagName(){return m.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 I(!1,e);this.HubRef=t,this.FocusNodeRef.setHub(t),this.FocusNodeRef.setBranchName(e)}}jsvGetHub(){return this.HubRef}}class x extends m{constructor(t){super(t),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 V extends m{constructor(t){super(t),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 m{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 x||t instanceof V)&&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 m{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 m.TAG.IMAGE}setAttribute(t,e){this.jsvTakeTextureAttribute(t,e)?console.assert(!this._ImageInLoading,`set ${t} after src`):(super.setAttribute(t,e),t===m.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(m.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 0!=this.jsvStore.textureWidth&&0!=this.jsvStore.textureHeight||console.warn("warning: size 0 not support object fit, src="+this.src),m.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 m{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 H extends m{constructor(t){super(t),this.textContent=null}jsvGetTagName(){return m.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 G extends m{}class B extends T{constructor(t){super(t),console.log("VideoElement.constructor()",this),this._EventCache=[],this._UseTexture=!1,this._StartTime=0}jsvGetTagName(){return m.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 m.applyObjectFitCommon(this,t,this.jsvMediaView)}jsvInit(){console.log("VideoElement jsvInit"),this._UseTexture?this.jsvMedia=new T.HOOKS.OffscreenVideo:this.jsvMedia=new T.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 W 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 K 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(),A()}}class Y extends C{constructor(t){super(t),console.log("AudioElement.constructor()",this)}jsvGetTagName(){return m.TAG.AUDIOTRACK}jsvInit(){this.jsvMedia=new T.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.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 M;case X.DIV_ELEMENT:return new R;case X.IMG_ELEMENT:case X.FIMG_ELEMENT:return new D;case X.STYLE_ELEMENT:return new H;case X.AUDIO_ELEMENT:return new C;case X.AUDIOTRACK_ELEMENT:return new Y;case X.VIDEO_ELEMENT:return new B;case X.LINK_ELEMENT:return window.JsView?new x:window.originDocument.createElement(X.LINK_ELEMENT);case X.SCRIPT_ELEMENT:return window.JsView?new V:window.originDocument.createElement(X.SCRIPT_ELEMENT);case X.ANCHOR_ELEMENT:return new S;case X.SVG_ELEMENT:return new SVGElement;default:return window.JsView?(console.warn("Document.createElement() unknown name="+t),new G(t)):new F(t.startsWith("jsv")?t:"jsve-"+t)}}createTextNode(t){return new W(t)}createEvent(t){return new i(t)}createComment(t){return new K(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)}set cookie(t){window.__JsvCookies.setCookie(t)}get cookie(){return window.__JsvCookies.getCookie()}}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 m{jsvGetTagName(){return m.TAG.LINK}}if(window.JsvCode={Dom:{StyleSheets:{}}},window.Audio=C,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=m;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};
@@ -0,0 +1,8 @@
1
+ import "./browser-root-style.css"
2
+
3
+ // Release entry
4
+ // export * from "./bin/jsview-browser-debug-dom.min"
5
+
6
+ // Debug entry
7
+ // TODO: 进行编译(yarn build)时,需要关闭掉此require
8
+ export * from "../deps/jsview-dom/src/dom-browser-hook"
@@ -0,0 +1,6 @@
1
+ // Release entry
2
+ // export * from "./bin/jsview-dom.min"
3
+
4
+ // Debug entry
5
+ // TODO: 进行编译(yarn build)时,需要关闭掉此require
6
+ export * from "../deps/jsview-dom/src/dom-wrapper"
@@ -0,0 +1,6 @@
1
+ // Release entry
2
+ // export * from "./bin/jsview-forge-define.min"
3
+
4
+ // Debug entry
5
+ // TODO: 进行编译(yarn build)时,需要关闭掉此require
6
+ export * from "../deps/jsview-dom/src/forge"
@@ -3,10 +3,10 @@
3
3
  */
4
4
 
5
5
  const TargetRevision = {
6
- "CoreRevision": 811031,
7
- "JseRevision": "1.0.779",
6
+ "CoreRevision": 811078,
7
+ "JseRevision": "1.0.791",
8
8
  "JseUrl":
9
- "http://cdn.release.qcast.cn/forge_js/master/JsViewES6_react_r779.jsv.456af8f1.js"
9
+ "http://cdn.release.qcast.cn/forge_js/master/JsViewES6_react_r791.jsv.907a1ff3.js"
10
10
  };
11
11
 
12
12
  // 不要用export default,update-env脚本不能解析
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@shijiu/jsview-vue",
3
- "version": "0.9.426",
3
+ "version": "0.9.502",
4
4
  "bin": {
5
5
  "jsview-post-build": "./scripts/jsview-post-build.js",
6
6
  "jsview-post-install": "./scripts/jsview-post-install.js",
@@ -3,7 +3,7 @@ module.exports = (api, options) => {
3
3
  const getAssetPath = require('../util/getAssetPath')
4
4
  const getVueMajor = require('../util/getVueMajor')
5
5
 
6
- const inlineLimit = 4096
6
+ const inlineLimit = -1
7
7
 
8
8
  const vueMajor = getVueMajor(api.getCwd())
9
9
  const supportsEsModuleAsset = (vueMajor !== 2)
@@ -5679,7 +5679,10 @@ function resolveAsset(type, name, warnMissing = true, maybeSelfReference = false
5679
5679
  return Component;
5680
5680
  }
5681
5681
  if ((process.env.NODE_ENV !== 'production') && warnMissing && !res) {
5682
- warn(`Failed to resolve ${type.slice(0, -1)}: ${name}`);
5682
+ // QCode Modify, 避免掉jsv自定义 element的报错问题
5683
+ if (!name.startsWith("jsve-")) {
5684
+ warn(`Failed to resolve ${type.slice(0, -1)}: ${name}`);
5685
+ }
5683
5686
  }
5684
5687
  return res;
5685
5688
  }
@@ -1,9 +1,9 @@
1
1
  <script>
2
2
  import { Vue } from "vue-class-component";
3
- import jpegDemo from "./jpegDemo.jpeg";
4
- import pngDemo from "./pngDemo.png";
5
- import pngNoAlphaDemo from "./pngNoAlphaDemo.png";
6
- import bmpDemo from "./bmpDemo.bmp";
3
+ import jpegDemo from "../assets/jpegDemo.jpeg";
4
+ import pngDemo from "../assets/pngDemo.png";
5
+ import pngNoAlphaDemo from "../assets/pngNoAlphaDemo.png";
6
+ import bmpDemo from "../assets/bmpDemo.bmp";
7
7
 
8
8
  class App extends Vue {
9
9
  constructor(props) {
@@ -8,6 +8,16 @@ const routeList = [
8
8
  path: "/",
9
9
  component: () => import("./views/Homepage"),
10
10
  },
11
+ {
12
+ name: "快速刷新的表格布局组件",
13
+ path: "/feature/GridDemo",
14
+ component: () => import("jsview/samples/GridDemo/App"),
15
+ },
16
+ {
17
+ name: ".9图焦点框漂移",
18
+ path: "/feature/NinePatchDemo",
19
+ component: () => import("jsview/samples/NinePatchDemo/App"),
20
+ },
11
21
  {
12
22
  name: "基础示例合集",
13
23
  path: "/feature/Basic",
@@ -113,7 +123,7 @@ const routeList = [
113
123
  component: () => import("jsview/samples/SpriteImage/App"),
114
124
  },
115
125
  {
116
- name: "文字滚动",
126
+ name: "文字滚动(标题跑马灯)",
117
127
  path: "/feature/Marquee",
118
128
  component: () => import("jsview/samples/Marquee/App"),
119
129
  },
@@ -137,7 +147,12 @@ const routeList = [
137
147
  path: "/feature/TextureAnimation",
138
148
  component: () => import("jsview/samples/TextureAnimation/App"),
139
149
  },
140
-
150
+ {
151
+ name: "公祭日黑白效果",
152
+ path: "/feature/GrayDown",
153
+ component: () => import("jsview/samples/FilterDemo/App"),
154
+ },
155
+
141
156
  // 场景实例
142
157
  {
143
158
  name: "直播间(TBD)",
@@ -0,0 +1,121 @@
1
+ <!--
2
+ * @Author: ChenChanghua
3
+ * @Date: 2022-04-20 21:05:26
4
+ * @LastEditors: ChenChanghua
5
+ * @LastEditTime: 2022-04-29 15:23:14
6
+ * @Description: file content
7
+ -->
8
+ <script>
9
+ import { ref } from "vue";
10
+ import { jJsvRuntimeBridge } from "jsview/utils/JsViewVueTools/JsvRuntimeBridge";
11
+ import JsvFilterView from "jsview/utils/JsViewVueWidget/JsvFilterView";
12
+ import sample from "../assets/jpegDemo.jpeg";
13
+ import webpSample from "../assets/webpDemo.webp";
14
+
15
+ export default {
16
+ components: {
17
+ JsvFilterView,
18
+ },
19
+ setup() {
20
+ return {
21
+ viewId: -1,
22
+ sample,
23
+ webpSample,
24
+ enableFilter: ref(true),
25
+ };
26
+ },
27
+ methods: {
28
+ _onKeyDown(ev) {
29
+ if (ev.keyCode == 8 || ev.keyCode == 27 || ev.keyCode == 10000) {
30
+ this.$router?.go(-1); // 有router时,是从DemoHomepage进入,回退
31
+ } else {
32
+ if (ev.keyCode == 13) {
33
+ this.enableFilter = !this.enableFilter;
34
+ this.$refs.filter1?.enableFilter(this.enableFilter);
35
+ this.$refs.filter2?.enableFilter(this.enableFilter);
36
+ }
37
+ }
38
+ return true;
39
+ },
40
+ },
41
+ mounted() {
42
+ jJsvRuntimeBridge.notifyPageLoaded();
43
+ },
44
+ };
45
+ </script>
46
+
47
+ <template>
48
+ <jsv-focus-block
49
+ autoFocus
50
+ :onAction="{
51
+ onKeyDown: _onKeyDown,
52
+ }"
53
+ :style="{
54
+ width: 1920,
55
+ height: 1080,
56
+ backgroundColor: '#007788',
57
+ }"
58
+ >
59
+ <jsv-filter-view :width="400" :height="400" ref="filter1">
60
+ <div
61
+ :style="{
62
+ left: 0,
63
+ top: 0,
64
+ width: 300,
65
+ height: 300,
66
+ backgroundImage: `url(${sample})`,
67
+ }"
68
+ ></div>
69
+ </jsv-filter-view>
70
+ <div
71
+ :style="{
72
+ left: 400,
73
+ top: 0,
74
+ width: 300,
75
+ height: 300,
76
+ backgroundImage: `url(${sample})`,
77
+ }"
78
+ ></div>
79
+
80
+ <jsv-filter-view :top="350" :width="400" :height="400" ref="filter2">
81
+ <div
82
+ :style="{
83
+ width: 300,
84
+ height: 300,
85
+ backgroundImage: `url(${webpSample})`,
86
+ }"
87
+ ></div>
88
+ </jsv-filter-view>
89
+ <div
90
+ :style="{
91
+ left: 400,
92
+ top: 350,
93
+ width: 300,
94
+ height: 300,
95
+ backgroundImage: `url(${webpSample})`,
96
+ }"
97
+ ></div>
98
+ </jsv-focus-block>
99
+ <div
100
+ :style="{
101
+ left: 800,
102
+ width: 400,
103
+ height: 200,
104
+ color: '#FFFFFF',
105
+ fontSize: '30px',
106
+ }"
107
+ >
108
+ 按OK键关闭/开启滤镜
109
+ </div>
110
+ </template>
111
+
112
+ <style scoped>
113
+ @keyframes rotate {
114
+ from {
115
+ transform: rotate3d(0, 0, 1, 0);
116
+ }
117
+ to {
118
+ transform: rotate3d(0, 0, 1, 360deg);
119
+ }
120
+ }
121
+ </style>