From 91742979806ca23e2784d6d3290186632ce62fca Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Fri, 6 Dec 2019 11:48:17 +0800 Subject: [PATCH] update .gitignore --- .gitignore | 3 + app/src/main/assets/demo/.gitignore | 2 +- app/src/main/assets/demo/AnimatorDemo.js | 225 -- .../main/assets/demo/ComplicatedAnimations.js | 239 -- app/src/main/assets/demo/ComplicatedDemo.js | 78 - app/src/main/assets/demo/Counter.js | 128 - app/src/main/assets/demo/EffectsDemo.js | 392 -- app/src/main/assets/demo/FlowLayoutDemo.js | 53 - app/src/main/assets/demo/ImageDemo.js | 139 - app/src/main/assets/demo/LayoutDemo.js | 464 --- app/src/main/assets/demo/ListDemo.js | 155 - app/src/main/assets/demo/ModalDemo.js | 174 - app/src/main/assets/demo/NavbarDemo.js | 124 - app/src/main/assets/demo/NavigatorDemo.js | 80 - app/src/main/assets/demo/NetworkDemo.js | 72 - app/src/main/assets/demo/PopoverDemo.js | 84 - app/src/main/assets/demo/RefreshableDemo.js | 132 - app/src/main/assets/demo/ScrollerDemo.js | 57 - app/src/main/assets/demo/SliderDemo.js | 81 - app/src/main/assets/demo/Snake.js | 341 -- app/src/main/assets/demo/StorageDemo.js | 119 - doric/src/main/assets/bundle/.gitignore | 2 +- doric/src/main/assets/bundle/doric-lib.js | 1921 --------- doric/src/main/assets/bundle/doric-sandbox.js | 1474 ------- doric/src/main/assets/bundle/doric-vm.js | 3450 ----------------- 25 files changed, 5 insertions(+), 9984 deletions(-) delete mode 100644 app/src/main/assets/demo/AnimatorDemo.js delete mode 100644 app/src/main/assets/demo/ComplicatedAnimations.js delete mode 100644 app/src/main/assets/demo/ComplicatedDemo.js delete mode 100644 app/src/main/assets/demo/Counter.js delete mode 100644 app/src/main/assets/demo/EffectsDemo.js delete mode 100644 app/src/main/assets/demo/FlowLayoutDemo.js delete mode 100644 app/src/main/assets/demo/ImageDemo.js delete mode 100644 app/src/main/assets/demo/LayoutDemo.js delete mode 100644 app/src/main/assets/demo/ListDemo.js delete mode 100644 app/src/main/assets/demo/ModalDemo.js delete mode 100644 app/src/main/assets/demo/NavbarDemo.js delete mode 100644 app/src/main/assets/demo/NavigatorDemo.js delete mode 100644 app/src/main/assets/demo/NetworkDemo.js delete mode 100644 app/src/main/assets/demo/PopoverDemo.js delete mode 100644 app/src/main/assets/demo/RefreshableDemo.js delete mode 100644 app/src/main/assets/demo/ScrollerDemo.js delete mode 100644 app/src/main/assets/demo/SliderDemo.js delete mode 100644 app/src/main/assets/demo/Snake.js delete mode 100644 app/src/main/assets/demo/StorageDemo.js delete mode 100644 doric/src/main/assets/bundle/doric-lib.js delete mode 100644 doric/src/main/assets/bundle/doric-sandbox.js delete mode 100644 doric/src/main/assets/bundle/doric-vm.js diff --git a/.gitignore b/.gitignore index 0df7064d..d432ee46 100644 --- a/.gitignore +++ b/.gitignore @@ -6,3 +6,6 @@ /build /captures .externalNativeBuild +.project +.classpath +.settings/ \ No newline at end of file diff --git a/app/src/main/assets/demo/.gitignore b/app/src/main/assets/demo/.gitignore index b35172a3..4c43fe68 100644 --- a/app/src/main/assets/demo/.gitignore +++ b/app/src/main/assets/demo/.gitignore @@ -1 +1 @@ - *.js \ No newline at end of file +*.js \ No newline at end of file diff --git a/app/src/main/assets/demo/AnimatorDemo.js b/app/src/main/assets/demo/AnimatorDemo.js deleted file mode 100644 index 3de47ef1..00000000 --- a/app/src/main/assets/demo/AnimatorDemo.js +++ /dev/null @@ -1,225 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function box(idx = 0) { - return (new doric.Stack).also(it => { - it.width = it.height = 20; - it.backgroundColor = colors[idx || 0]; - }); -} -function title(str) { - return doric.text({ - text: str, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -function thisLabel(str) { - return doric.text({ - text: str, - width: 60, - height: 50, - backgroundColor: colors[0], - textSize: 15, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - }); -} -let AnimatorDemo = class AnimatorDemo extends doric.Panel { - build(rootView) { - const view = box(2); - view.onClick = () => { - doric.modal(context).toast('Clicked'); - }; - const view2 = box(3); - let idx = 0; - doric.vlayout([ - title("Animator Demo"), - doric.vlayout([ - doric.hlayout([ - thisLabel('Reset').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - view.width = view.height = 20; - view.x = view.y = 0; - view.rotation = 0; - view.backgroundColor = colors[2]; - view.corners = 0; - view.scaleX = 1; - view.scaleY = 1; - view.translationX = 0; - view.translationY = 0; - view.rotation = 0; - }, - duration: 1500, - }).then(() => { - doric.modal(context).toast('Fininshed'); - }).catch(e => { - doric.modal(context).toast(`${e}`); - }); - } - }), - ]).apply({ space: 10 }), - doric.hlayout([ - thisLabel('X').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - view.x = view.x || 0; - view.x += 100; - view2.x += 50; - }, - duration: 1000, - }); - } - }), - thisLabel('Y').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - view.y = view.y || 0; - view.y += 100; - view2.y += 50; - }, - duration: 1000, - }); - } - }), - thisLabel('Width').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - view.width += 100; - }, - duration: 1000, - }); - } - }), - thisLabel('Height').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - view.height += 100; - }, - duration: 1000, - }); - } - }), - ]).apply({ space: 10 }), - doric.hlayout([ - thisLabel('BgColor').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - view.backgroundColor = colors[(idx++) % colors.length]; - }, - duration: 1000, - }); - } - }), - thisLabel('Rotation').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - if (view.rotation) { - view.rotation += 0.5; - } - else { - view.rotation = 0.5; - } - }, - duration: 1000, - }); - } - }), - thisLabel('Corner').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - if (typeof view.corners === 'number') { - view.corners += 10; - } - else { - view.corners = 10; - } - }, - duration: 1000, - }); - } - }), - ]).apply({ space: 10 }), - doric.hlayout([ - thisLabel('scaleX').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - if (view.scaleX) { - view.scaleX += 0.1; - } - else { - view.scaleX = 1.1; - } - }, - duration: 1000, - }); - } - }), - thisLabel('scaleY').apply({ - onClick: () => { - doric.animate(this)({ - animations: () => { - if (view.scaleY) { - view.scaleY += 0.1; - } - else { - view.scaleY = 1.1; - } - }, - duration: 1000, - }); - } - }), - ]).apply({ space: 10 }), - ]).apply({ space: 10 }), - doric.stack([ - view, - ]).apply({ - layoutConfig: doric.layoutConfig().atmost(), - backgroundColor: colors[1].alpha(0.3 * 255), - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost(), - gravity: doric.gravity().center(), - space: 10, - }).in(rootView); - } -}; -AnimatorDemo = __decorate([ - Entry -], AnimatorDemo); -//# sourceMappingURL=AnimatorDemo.js.map diff --git a/app/src/main/assets/demo/ComplicatedAnimations.js b/app/src/main/assets/demo/ComplicatedAnimations.js deleted file mode 100644 index 5ad02e61..00000000 --- a/app/src/main/assets/demo/ComplicatedAnimations.js +++ /dev/null @@ -1,239 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function box(idx = 0) { - return (new doric.Stack).also(it => { - it.width = it.height = 20; - it.backgroundColor = colors[idx || 0]; - }); -} -function title(str) { - return doric.text({ - text: str, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -function thisLabel(str) { - return doric.text({ - text: str, - width: 80, - height: 30, - backgroundColor: colors[0], - textSize: 10, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - }); -} -let AnimationDemo = class AnimationDemo extends doric.Panel { - build(rootView) { - const view = box(2); - const view2 = box(3); - view.onClick = () => { - doric.modal(context).toast('Clicked'); - }; - doric.vlayout([ - title("Complicated Animation"), - doric.vlayout([ - doric.hlayout([ - thisLabel('reset').apply({ - onClick: () => { - const rotation = new doric.RotationAnimation; - rotation.duration = 1000; - rotation.fromRotation = view.rotation || 0; - rotation.toRotation = 0; - const translation = new doric.TranslationAnimation; - translation.duration = 1000; - translation.fromTranslationX = view.translationX || 0; - translation.toTranslationX = 0; - translation.fromTranslationY = view.translationY || 0; - translation.toTranslationY = 0; - const scale = new doric.ScaleAnimation; - scale.duration = 1000; - scale.fromScaleX = view.scaleX || 1; - scale.toScaleX = 1; - scale.fromScaleY = view.scaleY || 1; - scale.toScaleY = 1; - const animationSet = new doric.AnimationSet; - animationSet.addAnimation(rotation); - animationSet.addAnimation(translation); - animationSet.addAnimation(scale); - view.doAnimation(context, animationSet).then(() => { - doric.modal(context).toast('Resetd'); - }); - } - }), - ]).apply({ space: 10 }), - doric.hlayout([ - thisLabel('TranslationX').apply({ - onClick: () => { - const animation = new doric.TranslationAnimation; - animation.duration = 1000; - animation.fromTranslationX = view.translationX || 0; - animation.toTranslationX = animation.fromTranslationX + 100; - animation.fromTranslationY = view.translationY || 0; - animation.toTranslationY = view.translationY || 0; - view.doAnimation(context, animation); - } - }), - thisLabel('TranslationY').apply({ - onClick: () => { - const animation = new doric.TranslationAnimation; - animation.duration = 1000; - animation.fromTranslationX = view.translationX || 0; - animation.toTranslationX = view.translationX || 0; - animation.fromTranslationY = view.translationY || 0; - animation.toTranslationY = animation.fromTranslationY + 100; - view.doAnimation(context, animation); - } - }), - thisLabel('ScaleX').apply({ - onClick: () => { - const animation = new doric.ScaleAnimation; - animation.duration = 1000; - animation.fromScaleX = view.scaleX || 1; - animation.toScaleX = animation.fromScaleX + 1; - view.doAnimation(context, animation); - } - }), - thisLabel('ScaleY').apply({ - onClick: () => { - const animation = new doric.ScaleAnimation; - animation.duration = 1000; - animation.fromScaleY = view.scaleY || 1; - animation.toScaleY = animation.fromScaleY + 1; - view.doAnimation(context, animation); - } - }), - thisLabel('rotation').apply({ - onClick: () => { - const animation = new doric.RotationAnimation; - animation.duration = 1000; - animation.fromRotation = view.rotation || 0; - animation.toRotation = animation.fromRotation + 0.25; - view.doAnimation(context, animation); - } - }), - ]).apply({ space: 10 }), - doric.hlayout([ - thisLabel('group').apply({ - onClick: () => { - const rotation = new doric.RotationAnimation; - rotation.duration = 1000; - rotation.fromRotation = 0; - rotation.toRotation = 4; - const translation = new doric.TranslationAnimation; - translation.duration = 1000; - translation.fromTranslationX = view.translationX || 0; - translation.toTranslationX = 100; - const animationSet = new doric.AnimationSet; - animationSet.addAnimation(rotation); - animationSet.addAnimation(translation); - view.doAnimation(context, animationSet); - } - }), - ]).apply({ space: 10 }), - doric.hlayout([ - thisLabel('Default').apply({ - onClick: () => { - const translation = new doric.TranslationAnimation; - translation.duration = 3000; - translation.fromTranslationX = 0; - translation.toTranslationX = 300; - translation.timingFunction = doric.TimingFunction.Default; - view.doAnimation(context, translation); - } - }), - thisLabel('Linear').apply({ - onClick: () => { - const translation = new doric.TranslationAnimation; - translation.duration = 3000; - translation.fromTranslationX = 0; - translation.toTranslationX = 300; - translation.timingFunction = doric.TimingFunction.Linear; - view.doAnimation(context, translation); - } - }), - thisLabel('EaseIn').apply({ - onClick: () => { - const translation = new doric.TranslationAnimation; - translation.duration = 3000; - translation.fromTranslationX = 0; - translation.toTranslationX = 300; - translation.timingFunction = doric.TimingFunction.EaseIn; - view.doAnimation(context, translation); - } - }), - thisLabel('EaseOut').apply({ - onClick: () => { - const translation = new doric.TranslationAnimation; - translation.duration = 3000; - translation.fromTranslationX = 0; - translation.toTranslationX = 300; - translation.timingFunction = doric.TimingFunction.EaseOut; - view.doAnimation(context, translation); - } - }), - thisLabel('EaseInEaseOut').apply({ - onClick: () => { - const translation = new doric.TranslationAnimation; - translation.duration = 3000; - translation.fromTranslationX = 0; - translation.toTranslationX = 300; - translation.timingFunction = doric.TimingFunction.EaseInEaseOut; - view.doAnimation(context, translation); - } - }), - ]).apply({ space: 10 }), - ]).apply({ space: 10 }), - doric.stack([ - view.also(v => { - v.x = 20; - v.y = 0; - v.width = 30; - v.left = 15; - }), - view2.also(v => { - v.x = v.y = 20; - v.y = 40; - v.scaleX = 1.5; - }) - ]).apply({ - layoutConfig: doric.layoutConfig().atmost(), - backgroundColor: colors[1].alpha(0.3 * 255), - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost(), - gravity: doric.gravity().center(), - space: 10, - }).in(rootView); - } -}; -AnimationDemo = __decorate([ - Entry -], AnimationDemo); -//# sourceMappingURL=ComplicatedAnimations.js.map diff --git a/app/src/main/assets/demo/ComplicatedDemo.js b/app/src/main/assets/demo/ComplicatedDemo.js deleted file mode 100644 index 0231c4fe..00000000 --- a/app/src/main/assets/demo/ComplicatedDemo.js +++ /dev/null @@ -1,78 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let MyDemo = class MyDemo extends doric.Panel { - build(root) { - let refreshed; - let headerImage; - doric.stack([ - refreshed = doric.refreshable({ - onRefresh: () => { - refreshed.setRefreshing(context, false); - }, - header: doric.pullable(doric.stack([]).apply({ - backgroundColor: doric.Color.RED, - layoutConfig: doric.layoutConfig().exactly(), - width: 100, - height: 30, - }), { - startAnimation: () => { - }, - stopAnimation: () => { - }, - setPullingDistance: (distance) => { - headerImage.scaleX = headerImage.scaleY = (headerImage.height + distance * 2) / headerImage.height; - }, - }), - content: doric.list({ - itemCount: 20, - renderItem: (idx) => { - return doric.listItem(doric.text({ - text: `Item :${idx}`, - layoutConfig: doric.layoutConfig().exactly(), - width: root.width, - height: 50, - textColor: doric.Color.WHITE, - backgroundColor: colors[idx % colors.length], - })); - } - }).apply({}), - }).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).also(v => { - v.top = 200; - }), - headerImage = doric.image({ - imageUrl: "https://img.zcool.cn/community/01e75b5da933daa801209e1ffa4649.jpg@1280w_1l_2o_100sh.jpg", - layoutConfig: doric.layoutConfig().exactly(), - width: root.width, - height: 200, - scaleType: doric.ScaleType.ScaleAspectFill, - }), - ]).in(root); - } -}; -MyDemo = __decorate([ - Entry -], MyDemo); -//# sourceMappingURL=ComplicatedDemo.js.map diff --git a/app/src/main/assets/demo/Counter.js b/app/src/main/assets/demo/Counter.js deleted file mode 100644 index f23ec473..00000000 --- a/app/src/main/assets/demo/Counter.js +++ /dev/null @@ -1,128 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class CounterView extends doric.ViewHolder { - build(root) { - root.addChild(doric.vlayout([ - doric.text({ - textSize: 40, - layoutConfig: { - alignment: doric.Gravity.Center, - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }, - }).also(it => { this.number = it; }), - doric.text({ - text: "点击计数", - textSize: 20, - border: { - width: 1, - color: doric.Color.parse('#000000'), - }, - corners: 5, - layoutConfig: { - alignment: doric.Gravity.Center, - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }, - padding: { - left: 10, - right: 10, - top: 10, - bottom: 10, - }, - shadow: { - color: doric.Color.parse("#00ff00"), - opacity: 0.5, - radius: 20, - offsetX: 10, - offsetY: 10, - } - }).also(it => { this.counter = it; }), - ]).also(it => { - it.width = 200; - it.height = 200; - it.space = 20; - it.gravity = doric.Gravity.Center; - it.layoutConfig = { - alignment: doric.Gravity.Center - }; - it.border = { - width: 1, - color: doric.Color.parse("#000000"), - }; - it.shadow = { - color: doric.Color.parse("#ffff00"), - opacity: 0.5, - radius: 20, - offsetX: 10, - offsetY: 10, - }; - it.corners = 20; - it.backgroundColor = doric.Color.parse('#ff00ff'); - })); - root.addChild((new doric.Image).also(iv => { - iv.imageUrl = "https://misc.aotu.io/ONE-SUNDAY/SteamEngine.png"; - iv.layoutConfig = { - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }; - })); - } - bind(state) { - this.number.text = `${state.count}`; - } - setCounter(v) { - this.counter.onClick = v; - } -} -class CounterVM extends doric.ViewModel { - onAttached(s, vh) { - vh.counter.onClick = () => { - this.updateState(state => { - state.count++; - }); - }; - } -} -let MyPage = class MyPage extends doric.VMPanel { - getViewHolderClass() { - return CounterView; - } - getViewModelClass() { - return CounterVM; - } - getState() { - return { - count: 0 - }; - } - log() { - doric.log("Hello.HEGO"); - doric.logw("Hello.HEGO"); - doric.loge("Hello.HEGO"); - context.modal.toast('This is a toast.').then((r) => { - doric.loge(r); - }); - } -}; -__decorate([ - doric.NativeCall, - __metadata("design:type", Function), - __metadata("design:paramtypes", []), - __metadata("design:returntype", void 0) -], MyPage.prototype, "log", null); -MyPage = __decorate([ - Entry -], MyPage); -//# sourceMappingURL=Counter.js.map diff --git a/app/src/main/assets/demo/EffectsDemo.js b/app/src/main/assets/demo/EffectsDemo.js deleted file mode 100644 index 1634cfd8..00000000 --- a/app/src/main/assets/demo/EffectsDemo.js +++ /dev/null @@ -1,392 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -function box(idx = 0) { - return (new doric.Stack).also(it => { - it.width = it.height = 20; - it.backgroundColor = colors[idx || 0]; - }); -} -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} -let EffectsDemo = class EffectsDemo extends doric.Panel { - build(rootView) { - doric.scroller(doric.vlayout([ - doric.hlayout([ - doric.vlayout([ - label("Origin view"), - box().apply({ - width: 100, - height: 100 - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Border"), - box().apply({ - width: 100, - height: 100, - border: { - width: 5, - color: colors[3] - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Corner"), - box().apply({ - width: 100, - height: 100, - corners: 10, - layoutConfig: doric.layoutConfig().exactly().m({ - bottom: 10 - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Shadow"), - box().apply({ - width: 100, - height: 100, - shadow: { - opacity: 1, - color: colors[1], - offsetX: 3, - offsetY: 3, - radius: 5, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - bottom: 10 - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - ]).apply({ space: 20 }), - doric.hlayout([ - doric.vlayout([ - label("Border,Corner"), - box().apply({ - width: 100, - height: 100, - border: { - width: 5, - color: colors[3] - }, - corners: 10, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Border,Shadow"), - box().apply({ - width: 100, - height: 100, - border: { - width: 5, - color: colors[3] - }, - shadow: { - opacity: 1, - color: colors[1], - offsetX: 3, - offsetY: 3, - radius: 5, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - bottom: 10 - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Corner,Shadow"), - box().apply({ - width: 100, - height: 100, - corners: 10, - shadow: { - opacity: 1, - color: colors[1], - offsetX: 3, - offsetY: 3, - radius: 5, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - bottom: 10 - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Border,Corner,Shadow"), - box().apply({ - width: 100, - height: 100, - border: { - width: 5, - color: colors[3] - }, - corners: 10, - shadow: { - opacity: 1, - color: colors[1], - offsetX: 3, - offsetY: 3, - radius: 5, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - ]).apply({ space: 20 }), - doric.hlayout([ - doric.vlayout([ - label("Shadow"), - box().apply({ - width: 100, - height: 100, - corners: 50, - shadow: { - opacity: 1, - color: colors[1], - offsetX: 0, - offsetY: 0, - radius: 10, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 10, - right: 10, - bottom: 10, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Shadow,offset"), - box().apply({ - width: 100, - height: 100, - corners: 50, - shadow: { - opacity: 1, - color: colors[1], - offsetX: 5, - offsetY: 5, - radius: 5, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 10, - right: 10, - bottom: 10, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Shadow,opacity"), - box().apply({ - width: 100, - height: 100, - corners: 50, - shadow: { - opacity: 0.5, - color: colors[1], - offsetX: 5, - offsetY: 5, - radius: 5, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 10, - right: 10, - bottom: 10, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Shadow,color"), - box().apply({ - width: 100, - height: 100, - corners: 50, - shadow: { - opacity: 1, - color: colors[2], - offsetX: 5, - offsetY: 5, - radius: 5, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 10, - right: 10, - bottom: 10, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - ]).apply({ space: 20 }), - doric.hlayout([ - doric.vlayout([ - label("Corner round"), - box().apply({ - width: 100, - height: 100, - corners: 50, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Corner left top"), - box().apply({ - width: 100, - height: 100, - corners: { - leftTop: 50, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Corner right top"), - box().apply({ - width: 100, - height: 100, - corners: { - rightTop: 50, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Corner left bottom"), - box().apply({ - width: 100, - height: 100, - corners: { - leftBottom: 50, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - doric.vlayout([ - label("Corner right bottom"), - box().apply({ - width: 100, - height: 100, - corners: { - rightBottom: 50, - }, - layoutConfig: doric.layoutConfig().exactly().m({ - left: 5, - right: 5, - bottom: 5, - }) - }), - ]).apply({ - gravity: doric.Gravity.Center, - space: 10, - }), - ]).apply({ space: 20 }), - ]).also(it => { - it.space = 20; - })).also(it => { - it.layoutConfig = doric.layoutConfig().atmost(); - }).in(rootView); - } -}; -EffectsDemo = __decorate([ - Entry -], EffectsDemo); -//# sourceMappingURL=EffectsDemo.js.map diff --git a/app/src/main/assets/demo/FlowLayoutDemo.js b/app/src/main/assets/demo/FlowLayoutDemo.js deleted file mode 100644 index e6f17af0..00000000 --- a/app/src/main/assets/demo/FlowLayoutDemo.js +++ /dev/null @@ -1,53 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let FlowDemo = class FlowDemo extends doric.Panel { - build(rootView) { - doric.flowlayout({ - layoutConfig: doric.layoutConfig().atmost(), - itemCount: 500, - columnCount: 3, - columnSpace: 10, - rowSpace: 10, - renderItem: (idx) => { - return new doric.FlowLayoutItem().apply({ - backgroundColor: colors[idx % colors.length], - height: 50 + (idx % 3) * 20, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - }).also(it => { - it.addChild(doric.text({ - text: `${idx}`, - textColor: doric.Color.WHITE, - textSize: 20, - layoutConfig: doric.layoutConfig().wrap().a(doric.Gravity.Center) - })); - }); - }, - }) - .in(rootView); - } -}; -FlowDemo = __decorate([ - Entry -], FlowDemo); -//# sourceMappingURL=FlowLayoutDemo.js.map diff --git a/app/src/main/assets/demo/ImageDemo.js b/app/src/main/assets/demo/ImageDemo.js deleted file mode 100644 index 4c2a65e6..00000000 --- a/app/src/main/assets/demo/ImageDemo.js +++ /dev/null @@ -1,139 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} - -const img_base64 = ''; - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -const imageUrl = 'https://img.zcool.cn/community/01e75b5da933daa801209e1ffa4649.jpg@1280w_1l_2o_100sh.jpg'; -let ImageDemo = class ImageDemo extends doric.Panel { - build(rootView) { - let imageView; - doric.scroller(doric.vlayout([ - doric.text({ - text: "Image Demo", - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[5], - textAlignment: doric.gravity().center(), - height: 50, - }), - label('Gif'), - doric.image({ - imageUrl: "https://misc.aotu.io/ONE-SUNDAY/world-cup_2014_42.gif", - scaleType: doric.ScaleType.ScaleToFill, - loadCallback: function (ret) { - doric.log('this'); - doric.log('loadCallback', ret); - } - }), - label('APNG'), - doric.image({ - imageUrl: "https://misc.aotu.io/ONE-SUNDAY/world_cup_2014_42.png", - loadCallback: (ret) => { - } - }), - label('Animated WebP'), - doric.image({ - imageUrl: "https://p.upyun.com/demo/webp/webp/animated-gif-0.webp", - loadCallback: (ret) => { - } - }), - label('WebP'), - imageView = doric.image({ - imageUrl: "https://p.upyun.com/demo/webp/webp/jpg-0.webp", - loadCallback: (ret) => { - if (ret) { - imageView.width = ret.width; - imageView.height = ret.height; - } - } - }), - label('ScaleToFill'), - doric.image({ - imageUrl, - width: 300, - height: 300, - border: { - width: 2, - color: doric.Color.GRAY, - }, - scaleType: doric.ScaleType.ScaleToFill, - layoutConfig: doric.layoutConfig().exactly(), - loadCallback: (ret) => { - } - }), - label('ScaleAspectFit'), - doric.image({ - imageUrl, - width: 300, - height: 300, - border: { - width: 2, - color: doric.Color.GRAY, - }, - scaleType: doric.ScaleType.ScaleAspectFit, - layoutConfig: doric.layoutConfig().exactly(), - }), - label('ScaleAspectFill'), - doric.image({ - imageUrl, - width: 300, - height: 300, - border: { - width: 2, - color: doric.Color.GRAY, - }, - scaleType: doric.ScaleType.ScaleAspectFill, - layoutConfig: doric.layoutConfig().exactly(), - }), - label('ImageBase64'), - doric.image({ - imageBase64: img_base64, - width: 300, - height: 300, - border: { - width: 2, - color: doric.Color.GRAY, - }, - scaleType: doric.ScaleType.ScaleAspectFill, - layoutConfig: doric.layoutConfig().exactly(), - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.gravity().center(), - space: 10, - })).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).in(rootView); - } -}; -ImageDemo = __decorate([ - Entry -], ImageDemo); -//# sourceMappingURL=ImageDemo.js.map diff --git a/app/src/main/assets/demo/LayoutDemo.js b/app/src/main/assets/demo/LayoutDemo.js deleted file mode 100644 index 70948147..00000000 --- a/app/src/main/assets/demo/LayoutDemo.js +++ /dev/null @@ -1,464 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -const colors = [ - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -]; -function box(idx = 0) { - return (new doric.Stack).also(it => { - it.width = it.height = 20; - it.backgroundColor = doric.Color.parse(colors[idx || 0]); - }); -} -function boxStr(str, idx = 0) { - return (new doric.Text).also(it => { - it.width = it.height = 20; - it.text = str; - it.textColor = doric.Color.parse('#ffffff'); - it.backgroundColor = doric.Color.parse(colors[idx || 0]); - }); -} -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} -let LayoutDemo = class LayoutDemo extends doric.Panel { - build(rootView) { - doric.scroller(doric.hlayout([ - doric.vlayout([ - label("Horizontal Layout(Align to Top)"), - doric.hlayout([ - box().apply({ - height: 20 - }), - box().apply({ - height: 40 - }), - box().apply({ - height: 60 - }), - box().apply({ - height: 40 - }), - box().apply({ - height: 20 - }), - ]).also(it => { - it.space = 20; - }), - label("Horizontal Layout(Align to Bottom)"), - doric.hlayout([ - box().apply({ - height: 20 - }), - box().apply({ - height: 40 - }), - box().apply({ - height: 60 - }), - box().apply({ - height: 40 - }), - box().apply({ - height: 20 - }), - ]).also(it => { - it.space = 20; - it.gravity = doric.gravity().bottom(); - }), - label("Horizontal Layout(Align to Center)"), - doric.hlayout([ - box().apply({ - height: 20 - }), - box().apply({ - height: 40 - }), - box().apply({ - height: 60 - }), - box().apply({ - height: 40 - }), - box().apply({ - height: 20 - }), - ]).also(it => { - it.space = 20; - it.gravity = doric.gravity().center(); - }), - label("Horizontal Layout(Weight)"), - doric.hlayout([ - boxStr('weight=1', 3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - box(2), - box(4), - ]).apply({ - width: 200, - height: 30, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.hlayout([ - box(3), - boxStr('weight=1', 2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - box(4), - ]).apply({ - width: 200, - height: 30, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.hlayout([ - box(3), - box(2), - boxStr('weight=1', 4).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - ]).apply({ - width: 200, - height: 30, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.hlayout([ - boxStr('weight=1', 3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - boxStr('weight=1', 2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - box(4), - ]).apply({ - width: 200, - height: 30, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.hlayout([ - boxStr('weight=1', 3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - boxStr('weight=1', 2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - boxStr('weight=1', 4).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - ]).apply({ - width: 200, - height: 30, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - ]).also(it => { - it.space = 20; - it.gravity = doric.gravity().center(); - }), - doric.vlayout([ - label("Vertical Layout(Algin to Left)"), - doric.vlayout([ - box(1).apply({ - width: 20 - }), - box(1).apply({ - width: 40 - }), - box(1).apply({ - width: 60 - }), - box(1).apply({ - width: 40 - }), - box(1).apply({ - width: 20 - }), - ]).apply({ - space: 20 - }), - label("Vertical Layout(Algin to Right)"), - doric.vlayout([ - box(1).apply({ - width: 20 - }), - box(1).apply({ - width: 40 - }), - box(1).apply({ - width: 60 - }), - box(1).apply({ - width: 40 - }), - box(1).apply({ - width: 20 - }), - ]).apply({ - space: 20, - gravity: doric.gravity().right(), - }), - label("Vertical Layout(Algin to Center)"), - doric.vlayout([ - box(1).apply({ - width: 20 - }), - box(1).apply({ - width: 40 - }), - box(1).apply({ - width: 60 - }), - box(1).apply({ - width: 40 - }), - box(1).apply({ - width: 20 - }), - ]).apply({ - space: 20, - gravity: doric.gravity().center(), - }), - label("Vertical Layout(Weight)"), - doric.hlayout([ - doric.vlayout([ - boxStr('weight=1', 3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - }, - }), - box(2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - } - }), - box(4).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - } - }), - ]).apply({ - width: 100, - height: 200, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.vlayout([ - box(3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - }), - boxStr('weight=1', 2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - box(4).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - } - }), - ]).apply({ - width: 100, - height: 200, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.vlayout([ - box(3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - }), - box(2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - }), - boxStr('weight=1', 4).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - ]).apply({ - width: 100, - height: 200, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.vlayout([ - boxStr('weight=1', 3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - }, - }), - boxStr('weight=1', 2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - box(4).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - } - }), - ]).apply({ - width: 100, - height: 200, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - doric.vlayout([ - boxStr('weight=1', 3).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - }, - }), - boxStr('weight=1', 2).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - boxStr('weight=1', 4).apply({ - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - weight: 1, - } - }), - ]).apply({ - width: 100, - height: 200, - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - backgroundColor: doric.Color.parse('#eeeeee'), - gravity: doric.gravity().center(), - }), - ]).also(it => { - it.space = 20; - }), - ]).also(it => { - it.space = 20; - it.gravity = doric.gravity().left(); - }) - ]).also(it => { - it.space = 20; - })).also(it => { - it.layoutConfig = doric.layoutConfig().atmost(); - }) - .in(rootView); - } -}; -LayoutDemo = __decorate([ - Entry -], LayoutDemo); -//# sourceMappingURL=LayoutDemo.js.map diff --git a/app/src/main/assets/demo/ListDemo.js b/app/src/main/assets/demo/ListDemo.js deleted file mode 100644 index 3ce0af64..00000000 --- a/app/src/main/assets/demo/ListDemo.js +++ /dev/null @@ -1,155 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const icon_refresh = ''; -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function rotatedArrow() { - let refreshImage; - return doric.pullable(doric.stack([ - doric.image({ - layoutConfig: doric.layoutConfig().exactly().m({ top: 50, bottom: 10, }), - width: 30, - height: 30, - imageBase64: icon_refresh, - }).also(v => refreshImage = v), - ]), { - startAnimation: () => { - doric.log('startAnimation'); - }, - stopAnimation: () => { - doric.log('stopAnimation'); - }, - setPullingDistance: (distance) => { - refreshImage.rotation = distance / 30; - }, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let ListPanel = class ListPanel extends doric.Panel { - build(rootView) { - let refreshView; - let offset = Math.ceil(Math.random() * colors.length); - doric.vlayout([ - doric.text({ - text: "ListDemo", - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - textSize: 30, - textColor: doric.Color.parse("#535c68"), - backgroundColor: doric.Color.parse("#dff9fb"), - textAlignment: doric.gravity().center(), - height: 50, - }), - refreshView = doric.refreshable({ - onRefresh: () => { - refreshView.setRefreshing(context, false).then(() => { - refreshView.content.also(it => { - it.reset(); - offset = Math.ceil(Math.random() * colors.length); - it.itemCount = 40; - it.renderItem = (idx) => { - let counter; - return doric.listItem(doric.hlayout([ - doric.text({ - layoutConfig: { - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.EXACTLY, - alignment: doric.gravity().center(), - }, - text: `Cell At Line ${idx}`, - textAlignment: doric.gravity().center(), - textColor: doric.Color.parse("#ffffff"), - textSize: 20, - height: 50, - }), - doric.text({ - textColor: doric.Color.parse("#ffffff"), - textSize: 20, - text: "", - }).also(it => { - counter = it; - it.layoutConfig = { - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - margin: { - left: 10, - } - }; - }) - ]).also(it => { - it.layoutConfig = { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - margin: { - bottom: 2, - } - }; - it.gravity = doric.gravity().center(); - it.backgroundColor = colors[(idx + offset) % colors.length]; - let clicked = 0; - it.onClick = () => { - counter.text = `Item Clicked ${++clicked}`; - }; - })).also(it => { - it.layoutConfig = { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }; - it.onClick = () => { - doric.log(`Click item at ${idx}`); - it.height += 10; - it.nativeChannel(context, "getWidth")().then(resolve => { - doric.log(`resolve,${resolve}`); - }, reject => { - doric.log(`reject,${reject}`); - }); - }; - }); - }; - }); - }); - }, - header: rotatedArrow(), - content: doric.list({ - itemCount: 0, - renderItem: () => new doric.ListItem, - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.AT_MOST, - }, - }), - }), - ]).also(it => { - it.layoutConfig = { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.AT_MOST, - }; - it.backgroundColor = doric.Color.WHITE; - }).in(rootView); - refreshView.backgroundColor = doric.Color.YELLOW; - } -}; -ListPanel = __decorate([ - Entry -], ListPanel); -//# sourceMappingURL=ListDemo.js.map diff --git a/app/src/main/assets/demo/ModalDemo.js b/app/src/main/assets/demo/ModalDemo.js deleted file mode 100644 index 1867c92b..00000000 --- a/app/src/main/assets/demo/ModalDemo.js +++ /dev/null @@ -1,174 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let ModalDemo = class ModalDemo extends doric.Panel { - build(rootView) { - doric.scroller(doric.vlayout([ - doric.text({ - text: "Modal", - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.Gravity.Center, - height: 50, - }), - label('toast on bottom'), - label('Click me').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.modal(context).toast('This is a toast.'); - } - }), - label('toast on top'), - label('Click me').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.modal(context).toast('This is a toast.', doric.Gravity.Top); - } - }), - label('toast on center'), - label('Click me').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.modal(context).toast('This is a toast.', doric.Gravity.Center); - } - }), - doric.text({ - text: "Alert", - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[2], - textAlignment: doric.Gravity.Center, - height: 50, - }), - label('Click me').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.modal(context).alert({ - msg: 'This is alert.', - title: 'Alert title', - okLabel: "OkLabel" - }).then(e => { - doric.modal(context).toast('Clicked OK.'); - }); - } - }), - doric.text({ - text: "Confirm", - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[3], - textAlignment: doric.Gravity.Center, - height: 50, - }), - label('Click me').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.modal(context).confirm({ - msg: 'This is Confirm.', - title: 'Confirm title', - okLabel: "OkLabel", - cancelLabel: 'CancelLabel', - }).then(() => { - doric.modal(context).toast('Clicked OK.'); - }, () => { - doric.modal(context).toast('Clicked Cancel.'); - }); - } - }), - doric.text({ - text: "Prompt", - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[4], - textAlignment: doric.Gravity.Center, - height: 50, - }), - label('Click me').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.modal(context).prompt({ - msg: 'This is Prompt.', - title: 'Prompt title', - okLabel: "OkLabel", - cancelLabel: 'CancelLabel', - }).then(e => { - doric.modal(context).toast(`Clicked OK.Input:${e}`); - }, e => { - doric.modal(context).toast(`Clicked Cancel.Input:${e}`); - }); - } - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.Gravity.Center, - space: 10, - })).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).in(rootView); - } -}; -ModalDemo = __decorate([ - Entry -], ModalDemo); -//# sourceMappingURL=ModalDemo.js.map diff --git a/app/src/main/assets/demo/NavbarDemo.js b/app/src/main/assets/demo/NavbarDemo.js deleted file mode 100644 index ba825f57..00000000 --- a/app/src/main/assets/demo/NavbarDemo.js +++ /dev/null @@ -1,124 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} -function title(str) { - return doric.text({ - text: str, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let NavbarDemo = class NavbarDemo extends doric.Panel { - build(rootView) { - doric.scroller(doric.vlayout([ - title("Navbar Demo"), - label('isHidden').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.navbar(context).isHidden().then(e => doric.modal(context).alert(`Navbar isHidden:${e}`)).catch(e => { - doric.modal(context).alert(e); - }); - } - }), - label('setHidden').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.navbar(context).isHidden() - .then(e => doric.navbar(context).setHidden(!e)) - .catch(e => { - doric.modal(context).alert(e); - }); - } - }), - label('setTitle').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.navbar(context).setTitle('Setted Title') - .catch(e => { - doric.modal(context).alert(e); - }); - } - }), - label('setBgColor').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.navbar(context).setBgColor(doric.Color.YELLOW) - .catch(e => { - doric.modal(context).alert(e); - }); - } - }), - label('Pop').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.navigator(context).pop(); - } - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.gravity().center(), - space: 10, - })).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).in(rootView); - } -}; -NavbarDemo = __decorate([ - Entry -], NavbarDemo); -//# sourceMappingURL=NavbarDemo.js.map diff --git a/app/src/main/assets/demo/NavigatorDemo.js b/app/src/main/assets/demo/NavigatorDemo.js deleted file mode 100644 index e4e81769..00000000 --- a/app/src/main/assets/demo/NavigatorDemo.js +++ /dev/null @@ -1,80 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let NaivgatorDemo = class NaivgatorDemo extends doric.Panel { - build(root) { - doric.scroller(doric.vlayout([ - doric.text({ - text: "Navigator Demo", - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }), - ...[ - 'NavbarDemo', - 'Counter', 'EffectsDemo', 'ImageDemo', 'LayoutDemo', - 'ListDemo', 'ModalDemo', 'NavigatorDemo', - 'NetworkDemo', 'ScrollerDemo', 'SliderDemo', 'Snake', 'StorageDemo' - ].map(e => label(e).apply({ - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly().w(doric.LayoutSpec.AT_MOST), - onClick: () => { - doric.navigator(context).push(`assets://demo/${e}.js`, `${e}.js`); - }, - })), - label('POP').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.navigator(context).pop(); - }, - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.gravity().center(), - space: 10, - })).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).in(root); - } -}; -NaivgatorDemo = __decorate([ - Entry -], NaivgatorDemo); -//# sourceMappingURL=NavigatorDemo.js.map diff --git a/app/src/main/assets/demo/NetworkDemo.js b/app/src/main/assets/demo/NetworkDemo.js deleted file mode 100644 index 2f08e178..00000000 --- a/app/src/main/assets/demo/NetworkDemo.js +++ /dev/null @@ -1,72 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} -function title(str) { - return doric.text({ - text: str, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let NetworkDemo = class NetworkDemo extends doric.Panel { - build(rootView) { - doric.scroller(doric.vlayout([ - title("Network Demo"), - label('Click me').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.network(context).get('https://m.baidu.com').then(e => { - doric.modal(context).alert(JSON.stringify(e)); - }).catch(e => { - doric.modal(context).toast('Catched:' + JSON.stringify(e)); - }); - } - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.gravity().center(), - space: 10, - })).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).in(rootView); - } -}; -NetworkDemo = __decorate([ - Entry -], NetworkDemo); -//# sourceMappingURL=NetworkDemo.js.map diff --git a/app/src/main/assets/demo/PopoverDemo.js b/app/src/main/assets/demo/PopoverDemo.js deleted file mode 100644 index bdd41e81..00000000 --- a/app/src/main/assets/demo/PopoverDemo.js +++ /dev/null @@ -1,84 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} -function title(str) { - return doric.text({ - text: str, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let PopoverDemo = class PopoverDemo extends doric.Panel { - build(rootView) { - doric.scroller(doric.vlayout([ - title("Popover Demo"), - label('Popover').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.popover(context).show(doric.text({ - width: 200, - height: 50, - backgroundColor: colors[0], - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly().a(doric.Gravity.Center), - text: "This is PopOver Window", - }).also(v => { - let idx = 0; - v.onClick = () => { - v.backgroundColor = colors[(++idx) % colors.length]; - }; - doric.modal(context).toast('Dismissed after 3 seconds'); - setTimeout(() => { - doric.popover(context).dismiss(); - }, 3000); - })); - } - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.gravity().center(), - space: 10, - })).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).in(rootView); - } -}; -PopoverDemo = __decorate([ - Entry -], PopoverDemo); -//# sourceMappingURL=PopoverDemo.js.map diff --git a/app/src/main/assets/demo/RefreshableDemo.js b/app/src/main/assets/demo/RefreshableDemo.js deleted file mode 100644 index 715edd99..00000000 --- a/app/src/main/assets/demo/RefreshableDemo.js +++ /dev/null @@ -1,132 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const icon_refresh = ''; -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} -function title(str) { - return doric.text({ - text: str, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let RefreshableDemo = class RefreshableDemo extends doric.Panel { - build(rootView) { - let refreshImage; - let refreshView = doric.refreshable({ - layoutConfig: doric.layoutConfig().atmost(), - onRefresh: () => { - doric.log('onRefresh'); - setTimeout(() => { - refreshView.setRefreshing(context, false); - }, 5000); - }, - header: doric.pullable(doric.stack([ - doric.image({ - layoutConfig: doric.layoutConfig().exactly().m({ top: 50, bottom: 10, }), - width: 30, - height: 30, - imageBase64: icon_refresh, - }).also(v => { - refreshImage = v; - }), - ]), { - startAnimation: () => { - doric.log('startAnimation'); - }, - stopAnimation: () => { - doric.log('stopAnimation'); - }, - setPullingDistance: (distance) => { - refreshImage.rotation = distance / 30; - }, - }), - content: (doric.vlayout([ - title("Refreshable Demo"), - label('start Refresh').apply({ - width: 300, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - refreshView.setRefreshing(context, true); - } - }), - label('stop Refresh').apply({ - width: 300, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - refreshView.setRefreshing(context, false); - } - }), - label('Enable Refresh').apply({ - width: 300, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - refreshView.setRefreshable(context, true); - } - }), - label('Disable Refresh').apply({ - width: 300, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - refreshView.setRefreshable(context, false); - } - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.gravity().centerX(), - space: 10, - })) - }).apply({ - backgroundColor: doric.Color.YELLOW - }).in(rootView); - } -}; -RefreshableDemo = __decorate([ - Entry -], RefreshableDemo); -//# sourceMappingURL=RefreshableDemo.js.map diff --git a/app/src/main/assets/demo/ScrollerDemo.js b/app/src/main/assets/demo/ScrollerDemo.js deleted file mode 100644 index 0a5d6974..00000000 --- a/app/src/main/assets/demo/ScrollerDemo.js +++ /dev/null @@ -1,57 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -let ScrollerPanel = class ScrollerPanel extends doric.Panel { - build(rootView) { - doric.scroller(doric.vlayout([ - doric.scroller(doric.vlayout(new Array(100).fill(1).map(e => label('Scroll Content')))).apply({ - layoutConfig: doric.layoutConfig().exactly(), - width: 300, - height: 500, - backgroundColor: doric.Color.RED, - }), - doric.scroller(doric.vlayout(new Array(100).fill(1).map(e => label('Scroll Content')))).apply({ - layoutConfig: doric.layoutConfig().exactly(), - width: 300, - height: 500, - backgroundColor: doric.Color.BLUE, - }) - ])) - .apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.EXACTLY), - height: 500, - backgroundColor: doric.Color.YELLOW, - }) - .in(rootView); - } -}; -ScrollerPanel = __decorate([ - Entry -], ScrollerPanel); -//# sourceMappingURL=ScrollerDemo.js.map diff --git a/app/src/main/assets/demo/SliderDemo.js b/app/src/main/assets/demo/SliderDemo.js deleted file mode 100644 index f1000643..00000000 --- a/app/src/main/assets/demo/SliderDemo.js +++ /dev/null @@ -1,81 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -const imageUrls = [ - 'http://b.hiphotos.baidu.com/image/pic/item/908fa0ec08fa513db777cf78376d55fbb3fbd9b3.jpg', - 'http://f.hiphotos.baidu.com/image/pic/item/0e2442a7d933c8956c0e8eeadb1373f08202002a.jpg', - 'http://f.hiphotos.baidu.com/image/pic/item/b151f8198618367aa7f3cc7424738bd4b31ce525.jpg', - 'http://b.hiphotos.baidu.com/image/pic/item/0eb30f2442a7d9337119f7dba74bd11372f001e0.jpg', - 'http://a.hiphotos.baidu.com/image/h%3D300/sign=b38f3fc35b0fd9f9bf175369152cd42b/9a504fc2d5628535bdaac29e9aef76c6a6ef63c2.jpg', - 'http://h.hiphotos.baidu.com/image/pic/item/810a19d8bc3eb1354c94a704ac1ea8d3fd1f4439.jpg', - 'http://calonye.com/wp-content/uploads/2015/08/0-wx_fmtgiftpwebpwxfrom5wx_lazy1-9.gif', - 'http://hbimg.b0.upaiyun.com/ca29ea125b7f2d580f573e48eb594b1ef509757f34a08-m0hK45_fw658', - 'https://misc.aotu.io/ONE-SUNDAY/SteamEngine.png', -]; -let SliderPanel = class SliderPanel extends doric.Panel { - build(rootView) { - rootView.addChild(doric.vlayout([ - doric.text({ - text: "Gallery", - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }), - doric.slider({ - itemCount: 100, - renderPage: (idx) => { - return doric.slideItem(doric.image({ - imageUrl: imageUrls[idx % imageUrls.length], - scaleType: doric.ScaleType.ScaleAspectFit, - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST).h(doric.LayoutSpec.AT_MOST).a(doric.gravity().center()), - })).also(it => { - let start = idx; - it.onClick = () => { - it.backgroundColor = (colors[++start % colors.length]); - }; - }); - }, - layoutConfig: { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - weight: 1, - }, - }), - ]).also(it => { - it.layoutConfig = { - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.AT_MOST, - }; - })); - } -}; -SliderPanel = __decorate([ - Entry -], SliderPanel); -//# sourceMappingURL=SliderDemo.js.map diff --git a/app/src/main/assets/demo/Snake.js b/app/src/main/assets/demo/Snake.js deleted file mode 100644 index 423de1ea..00000000 --- a/app/src/main/assets/demo/Snake.js +++ /dev/null @@ -1,341 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var Direction; -(function (Direction) { - Direction[Direction["left"] = 0] = "left"; - Direction[Direction["right"] = 1] = "right"; - Direction[Direction["up"] = 2] = "up"; - Direction[Direction["down"] = 3] = "down"; -})(Direction || (Direction = {})); -var State; -(function (State) { - State[State["idel"] = 0] = "idel"; - State[State["run"] = 1] = "run"; - State[State["fail"] = 2] = "fail"; -})(State || (State = {})); -class SnakeModel { - constructor(w, h) { - this.state = State.idel; - this.direction = Direction.right; - this.food = { x: -1, y: -1 }; - this.head = { - x: 0, - y: 0, - }; - this.width = w; - this.height = h; - } - refreshFood() { - this.food.x = Math.floor(Math.random() * (this.width - 1)); - this.food.y = Math.floor(Math.random() * (this.height - 1)); - } - get tail() { - let node = this.head; - while (node.next !== undefined) { - node = node.next; - } - return node; - } - get score() { - let node = this.head; - let n = 0; - while (node.next !== undefined) { - n++; - node = node.next; - } - return n; - } - forward(node) { - switch (this.direction) { - case Direction.left: - node.x -= 1; - break; - case Direction.right: - node.x += 1; - break; - case Direction.up: - node.y -= 1; - break; - case Direction.down: - node.y += 1; - break; - } - } - step() { - if (this.state !== State.run) { - return; - } - let tail = this.tail; - while (tail.prev != undefined) { - tail.x = tail.prev.x; - tail.y = tail.prev.y; - tail = tail.prev; - } - this.forward(this.head); - if (this.head.x < 0 || this.head.x >= this.width - || this.head.y < 0 || this.head.y >= this.height) { - //If out of bound - doric.loge('out of bound'); - this.state = State.fail; - } - else if (this.head.x == this.food.x && this.head.y == this.food.y) { - //If eat food - let head = { x: this.food.x, y: this.food.y }; - doric.log('eat food', head); - this.forward(head); - this.head.prev = head; - head.next = this.head; - this.head = head; - this.refreshFood(); - } - if (this.crashAtSelf()) { - //If crash at self - doric.loge('crash at self'); - this.state = State.fail; - } - } - crashAtSelf() { - let cur = this.head.next; - while (cur !== undefined) { - if (cur.x == this.head.x && cur.y == this.head.y) { - return true; - } - cur = cur.next; - } - return false; - } - reset() { - this.direction = Direction.right; - this.state = State.run; - this.head.x = 0; - this.head.y = 0; - this.head.next = undefined; - this.refreshFood(); - } -} -class SnakeView extends doric.ViewHolder { - build(root) { - root.backgroundColor = doric.Color.parse('#000000'); - doric.vlayout([ - doric.text({ - text: "Snake", - textSize: 20, - textColor: doric.Color.parse("#ffffff"), - layoutConfig: { - alignment: new doric.Gravity().centerX(), - margin: { - top: 20 - }, - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }, - }), - (new doric.Stack).also(panel => { - panel.backgroundColor = doric.Color.parse('#00ff00'); - this.panel = panel; - }), - doric.hlayout([ - doric.text({ - text: "Start", - textSize: 30, - textColor: doric.Color.parse("#ffffff"), - layoutConfig: { - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }, - }).also(it => this.start = it), - ]).also(it => { - it.layoutConfig = { - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }; - }), - doric.vlayout([ - doric.hlayout([ - doric.text({ - width: 50, - height: 50, - text: "↑", - textSize: 30, - textAlignment: new doric.Gravity().center(), - backgroundColor: doric.Color.parse('#ffff00'), - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - }).also(it => this.up = it) - ]).also(it => { - it.layoutConfig = { - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }; - }), - doric.hlayout([ - doric.text({ - width: 50, - height: 50, - text: "←", - textSize: 30, - textAlignment: new doric.Gravity().center(), - backgroundColor: doric.Color.parse('#ffff00'), - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - }).also(it => this.left = it), - doric.text({ - width: 50, - height: 50, - text: "↓", - textSize: 30, - textAlignment: new doric.Gravity().center(), - backgroundColor: doric.Color.parse('#ffff00'), - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - }).also(it => this.down = it), - doric.text({ - width: 50, - height: 50, - text: "→", - textSize: 30, - textAlignment: new doric.Gravity().center(), - backgroundColor: doric.Color.parse('#ffff00'), - layoutConfig: { - widthSpec: doric.LayoutSpec.EXACTLY, - heightSpec: doric.LayoutSpec.EXACTLY, - }, - }).also(it => this.right = it), - ]).also(it => { - it.layoutConfig = { - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }; - it.space = 10; - }), - ]).also(controlArea => { - controlArea.gravity = new doric.Gravity().centerX(); - controlArea.space = 10; - controlArea.layoutConfig = { - alignment: new doric.Gravity().centerX(), - widthSpec: doric.LayoutSpec.WRAP_CONTENT, - heightSpec: doric.LayoutSpec.WRAP_CONTENT, - }; - }), - ]).also(it => { - it.space = 20; - it.layoutConfig = { - alignment: new doric.Gravity().centerX().top(), - widthSpec: doric.LayoutSpec.AT_MOST, - heightSpec: doric.LayoutSpec.AT_MOST, - }; - it.gravity = new doric.Gravity().centerX(); - }).in(root); - } - bind(state) { - doric.log('build', state); - this.panel.width = state.width * 10; - this.panel.height = state.height * 10; - let node = state.head; - let nodes = []; - while (node != undefined) { - nodes.push(node); - node = node.next; - } - nodes.push(state.food); - nodes.forEach((e, index) => { - let item = this.panel.children[index]; - if (item === undefined) { - item = new doric.Stack; - item.width = item.height = 10; - item.corners = 5; - item.shadow = { - color: doric.Color.GRAY, - opacity: 1, - radius: 3, - offsetX: 3, - offsetY: 3, - }; - this.panel.addChild(item); - } - if (index === nodes.length - 1) { - item.backgroundColor = doric.Color.parse('#ffff00'); - } - else { - item.backgroundColor = doric.Color.parse('#ff0000'); - } - item.x = e.x * 10; - item.y = e.y * 10; - }); - if (nodes.length < this.panel.children.length) { - this.panel.children.length = nodes.length; - } - } -} -class SnakeVM extends doric.ViewModel { - constructor() { - super(...arguments); - this.start = () => { - if (this.timerId !== undefined) { - clearInterval(this.timerId); - } - this.updateState(it => it.reset()); - this.timerId = setInterval(() => { - this.updateState(it => it.step()); - if (this.getState().state === State.fail) { - doric.loge('Game Over'); - this.stop(); - } - }, 500); - }; - this.stop = () => { - if (this.timerId !== undefined) { - clearInterval(this.timerId); - this.timerId = undefined; - } - }; - this.left = () => { - this.updateState(it => it.direction = Direction.left); - }; - this.right = () => { - this.updateState(it => it.direction = Direction.right); - }; - this.up = () => { - this.updateState(it => it.direction = Direction.up); - }; - this.down = () => { - this.updateState(it => it.direction = Direction.down); - }; - } - onAttached(state, v) { - doric.takeNonNull(v.start)(it => it.onClick = this.start); - doric.takeNonNull(v.left)(it => it.onClick = this.left); - doric.takeNonNull(v.right)(it => it.onClick = this.right); - doric.takeNonNull(v.up)(it => it.onClick = this.up); - doric.takeNonNull(v.down)(it => it.onClick = this.down); - } -} -let SnakePanel = class SnakePanel extends doric.VMPanel { - getViewModelClass() { - return SnakeVM; - } - getState() { - return new SnakeModel(35, 35); - } - getViewHolderClass() { - return SnakeView; - } -}; -SnakePanel = __decorate([ - Entry -], SnakePanel); -//# sourceMappingURL=Snake.js.map diff --git a/app/src/main/assets/demo/StorageDemo.js b/app/src/main/assets/demo/StorageDemo.js deleted file mode 100644 index d8d36a17..00000000 --- a/app/src/main/assets/demo/StorageDemo.js +++ /dev/null @@ -1,119 +0,0 @@ -'use strict'; - -var doric = require('doric'); - -const colors = [ - "#70a1ff", - "#7bed9f", - "#ff6b81", - "#a4b0be", - "#f0932b", - "#eb4d4b", - "#6ab04c", - "#e056fd", - "#686de0", - "#30336b", -].map(e => doric.Color.parse(e)); -function label(str) { - return doric.text({ - text: str, - textSize: 16, - }); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -const storedKey = 'StoredKey'; -const zone = 'StorageDemo'; -let StorageDemo = class StorageDemo extends doric.Panel { - update() { - doric.storage(context).getItem(storedKey, zone).then(e => { - this.stored.text = e || ""; - doric.log('Called in then'); - }); - } - build(root) { - doric.scroller(doric.vlayout([ - doric.text({ - text: "Storage Demo", - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 30, - textColor: doric.Color.WHITE, - backgroundColor: colors[1], - textAlignment: doric.gravity().center(), - height: 50, - }), - label('Stored'), - doric.text({ - layoutConfig: doric.layoutConfig().w(doric.LayoutSpec.AT_MOST), - textSize: 20, - textColor: doric.Color.WHITE, - backgroundColor: colors[3], - textAlignment: doric.gravity().center(), - height: 50, - }).also(it => this.stored = it), - label('store a value').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.storage(context).getItem(storedKey, zone).then(e => { - doric.modal(context).prompt({ - text: e, - title: "Please input text to store", - defaultText: "Default Value", - }).then(text => { - doric.storage(context).setItem(storedKey, text, zone).then(() => { - this.update(); - }); - }); - }); - }, - }), - label('remove value').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.storage(context).remove(storedKey, zone).then(e => { - this.update(); - }); - }, - }), - label('clear values').apply({ - width: 200, - height: 50, - backgroundColor: colors[0], - textSize: 30, - textColor: doric.Color.WHITE, - layoutConfig: doric.layoutConfig().exactly(), - onClick: () => { - doric.storage(context).clear(zone).then(e => { - this.update(); - }); - }, - }), - ]).apply({ - layoutConfig: doric.layoutConfig().atmost().h(doric.LayoutSpec.WRAP_CONTENT), - gravity: doric.gravity().center(), - space: 10, - })).apply({ - layoutConfig: doric.layoutConfig().atmost(), - }).in(root); - this.update(); - } -}; -StorageDemo = __decorate([ - Entry -], StorageDemo); -//# sourceMappingURL=StorageDemo.js.map diff --git a/doric/src/main/assets/bundle/.gitignore b/doric/src/main/assets/bundle/.gitignore index b35172a3..4c43fe68 100644 --- a/doric/src/main/assets/bundle/.gitignore +++ b/doric/src/main/assets/bundle/.gitignore @@ -1 +1 @@ - *.js \ No newline at end of file +*.js \ No newline at end of file diff --git a/doric/src/main/assets/bundle/doric-lib.js b/doric/src/main/assets/bundle/doric-lib.js deleted file mode 100644 index ba705c3b..00000000 --- a/doric/src/main/assets/bundle/doric-lib.js +++ /dev/null @@ -1,1921 +0,0 @@ -'use strict'; - -Object.defineProperty(exports, '__esModule', { value: true }); - -function obj2Model(obj) { - if (obj instanceof Array) { - return obj.map(e => obj2Model(e)); - } - else if (obj instanceof Object) { - if (Reflect.has(obj, 'toModel') && Reflect.get(obj, 'toModel') instanceof Function) { - obj = Reflect.apply(Reflect.get(obj, 'toModel'), obj, []); - return obj; - } - else { - for (let key in obj) { - const val = Reflect.get(obj, key); - Reflect.set(obj, key, obj2Model(val)); - } - return obj; - } - } - else { - return obj; - } -} -class Mutable { - constructor(v) { - this.binders = new Set; - this.get = () => { - return this.val; - }; - this.set = (v) => { - this.val = v; - this.binders.forEach(e => { - Reflect.apply(e, undefined, [this.val]); - }); - }; - this.val = v; - } - bind(binder) { - this.binders.add(binder); - Reflect.apply(binder, undefined, [this.val]); - } - static of(v) { - return new Mutable(v); - } -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -let __uniqueId__ = 0; -function uniqueId(prefix) { - return `__${prefix}_${__uniqueId__++}__`; -} - -function toString(message) { - if (message instanceof Function) { - return message.toString(); - } - else if (message instanceof Object) { - try { - return JSON.stringify(message); - } - catch (e) { - return message.toString(); - } - } - else if (message === undefined) { - return "undefined"; - } - else { - return message.toString(); - } -} -function log(...args) { - let out = ""; - for (let i = 0; i < arguments.length; i++) { - if (i > 0) { - out += ','; - } - out += toString(arguments[i]); - } - nativeLog('d', out); -} -function loge(...message) { - let out = ""; - for (let i = 0; i < arguments.length; i++) { - if (i > 0) { - out += ','; - } - out += toString(arguments[i]); - } - nativeLog('e', out); -} -function logw(...message) { - let out = ""; - for (let i = 0; i < arguments.length; i++) { - if (i > 0) { - out += ','; - } - out += toString(arguments[i]); - } - nativeLog('w', out); -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -function Property(target, propKey) { - Reflect.defineMetadata(propKey, true, target); -} -class View { - constructor() { - this.width = 0; - this.height = 0; - this.x = 0; - this.y = 0; - this.viewId = uniqueId('ViewId'); - this.callbacks = new Map; - /** Anchor end*/ - this.__dirty_props__ = {}; - this.nativeViewModel = { - id: this.viewId, - type: this.constructor.name, - props: this.__dirty_props__, - }; - return new Proxy(this, { - get: (target, p, receiver) => { - return Reflect.get(target, p, receiver); - }, - set: (target, p, v, receiver) => { - const oldV = Reflect.get(target, p, receiver); - const ret = Reflect.set(target, p, v, receiver); - if (Reflect.getMetadata(p, target) && oldV !== v) { - receiver.onPropertyChanged(p.toString(), oldV, v); - } - return ret; - } - }); - } - callback2Id(f) { - const id = uniqueId('Function'); - this.callbacks.set(id, f); - return id; - } - id2Callback(id) { - let f = this.callbacks.get(id); - if (f === undefined) { - f = Reflect.get(this, id); - } - return f; - } - /** Anchor start*/ - get left() { - return this.x; - } - set left(v) { - this.x = v; - } - get right() { - return this.x + this.width; - } - set right(v) { - this.x = v - this.width; - } - get top() { - return this.y; - } - set top(v) { - this.y = v; - } - get bottom() { - return this.y + this.height; - } - set bottom(v) { - this.y = v - this.height; - } - get centerX() { - return this.x + this.width / 2; - } - get centerY() { - return this.y + this.height / 2; - } - set centerX(v) { - this.x = v - this.width / 2; - } - set centerY(v) { - this.y = v - this.height / 2; - } - get dirtyProps() { - return this.__dirty_props__; - } - onPropertyChanged(propKey, oldV, newV) { - if (newV instanceof Function) { - newV = this.callback2Id(newV); - } - else { - newV = obj2Model(newV); - } - this.__dirty_props__[propKey] = newV; - } - clean() { - for (const key in this.__dirty_props__) { - if (Reflect.has(this.__dirty_props__, key)) { - Reflect.deleteProperty(this.__dirty_props__, key); - } - } - } - isDirty() { - return Reflect.ownKeys(this.__dirty_props__).length !== 0; - } - responseCallback(id, ...args) { - const f = this.id2Callback(id); - if (f instanceof Function) { - const argumentsList = []; - for (let i = 1; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - return Reflect.apply(f, this, argumentsList); - } - else { - loge(`Cannot find callback:${id} for ${JSON.stringify(this.toModel())}`); - } - } - toModel() { - return this.nativeViewModel; - } - let(block) { - block(this); - } - also(block) { - block(this); - return this; - } - apply(config) { - for (let key in config) { - Reflect.set(this, key, Reflect.get(config, key, config), this); - } - return this; - } - in(group) { - group.addChild(this); - return this; - } - nativeChannel(context, name) { - let thisView = this; - return function (args = undefined) { - const func = context.shader.command; - const viewIds = []; - while (thisView != undefined) { - viewIds.push(thisView.viewId); - thisView = thisView.superview; - } - const params = { - viewIds: viewIds.reverse(), - name, - args, - }; - return Reflect.apply(func, undefined, [params]); - }; - } - getWidth(context) { - return this.nativeChannel(context, 'getWidth')(); - } - getHeight(context) { - return this.nativeChannel(context, 'getHeight')(); - } - /**----------transform----------*/ - doAnimation(context, animation) { - return this.nativeChannel(context, "doAnimation")(animation.toModel()).then((args) => { - for (let key in args) { - Reflect.set(this, key, Reflect.get(args, key, args), this); - Reflect.deleteProperty(this.__dirty_props__, key); - } - }); - } -} -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "width", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "height", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "x", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "y", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "backgroundColor", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "corners", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "border", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "shadow", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "alpha", void 0); -__decorate([ - Property, - __metadata("design:type", Boolean) -], View.prototype, "hidden", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "viewId", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "padding", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "layoutConfig", void 0); -__decorate([ - Property, - __metadata("design:type", Function) -], View.prototype, "onClick", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "translationX", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "translationY", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "scaleX", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "scaleY", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "pivotX", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "pivotY", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "rotation", void 0); -class Superview extends View { - subviewById(id) { - for (let v of this.allSubviews()) { - if (v.viewId === id) { - return v; - } - } - } - isDirty() { - if (super.isDirty()) { - return true; - } - else { - for (const v of this.allSubviews()) { - if (v.isDirty()) { - return true; - } - } - } - return false; - } - clean() { - for (let v of this.allSubviews()) { - v.clean(); - } - super.clean(); - } - toModel() { - const subviews = []; - for (let v of this.allSubviews()) { - v.superview = this; - if (v.isDirty()) { - subviews.push(v.toModel()); - } - } - this.dirtyProps.subviews = subviews; - return super.toModel(); - } -} -class Group extends Superview { - constructor() { - super(...arguments); - this.children = new Proxy([], { - set: (target, index, value) => { - const ret = Reflect.set(target, index, value); - // Let getDirty return true - this.dirtyProps.children = this.children.map(e => e.viewId); - return ret; - } - }); - } - allSubviews() { - return this.children; - } - addChild(view) { - this.children.push(view); - } -} - -const SPECIFIED = 1; -const START = 1 << 1; -const END = 1 << 2; -const SHIFT_X = 0; -const SHIFT_Y = 4; -const LEFT = (START | SPECIFIED) << SHIFT_X; -const RIGHT = (END | SPECIFIED) << SHIFT_X; -const TOP = (START | SPECIFIED) << SHIFT_Y; -const BOTTOM = (END | SPECIFIED) << SHIFT_Y; -const CENTER_X = SPECIFIED << SHIFT_X; -const CENTER_Y = SPECIFIED << SHIFT_Y; -const CENTER = CENTER_X | CENTER_Y; -class Gravity { - constructor() { - this.val = 0; - } - left() { - const val = this.val | LEFT; - const ret = new Gravity; - ret.val = val; - return ret; - } - right() { - const val = this.val | RIGHT; - const ret = new Gravity; - ret.val = val; - return ret; - } - top() { - const val = this.val | TOP; - const ret = new Gravity; - ret.val = val; - return ret; - } - bottom() { - const val = this.val | BOTTOM; - const ret = new Gravity; - ret.val = val; - return ret; - } - center() { - const val = this.val | CENTER; - const ret = new Gravity; - ret.val = val; - return ret; - } - centerX() { - const val = this.val | CENTER_X; - const ret = new Gravity; - ret.val = val; - return ret; - } - centerY() { - const val = this.val | CENTER_Y; - const ret = new Gravity; - ret.val = val; - return ret; - } - toModel() { - return this.val; - } -} -Gravity.origin = new Gravity; -Gravity.Center = Gravity.origin.center(); -Gravity.Left = Gravity.origin.left(); -Gravity.Right = Gravity.origin.right(); -Gravity.Top = Gravity.origin.top(); -Gravity.Bottom = Gravity.origin.bottom(); -function gravity() { - return new Gravity; -} - -(function (LayoutSpec) { - LayoutSpec[LayoutSpec["EXACTLY"] = 0] = "EXACTLY"; - LayoutSpec[LayoutSpec["WRAP_CONTENT"] = 1] = "WRAP_CONTENT"; - LayoutSpec[LayoutSpec["AT_MOST"] = 2] = "AT_MOST"; -})(exports.LayoutSpec || (exports.LayoutSpec = {})); -class LayoutConfigImpl { - wrap() { - this.widthSpec = exports.LayoutSpec.WRAP_CONTENT; - this.heightSpec = exports.LayoutSpec.WRAP_CONTENT; - return this; - } - atmost() { - this.widthSpec = exports.LayoutSpec.AT_MOST; - this.heightSpec = exports.LayoutSpec.AT_MOST; - return this; - } - exactly() { - this.widthSpec = exports.LayoutSpec.EXACTLY; - this.heightSpec = exports.LayoutSpec.EXACTLY; - return this; - } - w(w) { - this.widthSpec = w; - return this; - } - h(h) { - this.heightSpec = h; - return this; - } - m(m) { - this.margin = m; - return this; - } - a(a) { - this.alignment = a; - return this; - } - wg(w) { - this.weight = w; - return this; - } - toModel() { - return { - widthSpec: this.widthSpec, - heightSpec: this.heightSpec, - margin: this.margin, - alignment: this.alignment ? this.alignment.toModel() : undefined, - weight: this.weight, - }; - } -} -function layoutConfig() { - return new LayoutConfigImpl; -} - -var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$1 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class Stack extends Group { -} -class Root extends Stack { -} -class LinearLayout extends Group { -} -__decorate$1([ - Property, - __metadata$1("design:type", Number) -], LinearLayout.prototype, "space", void 0); -__decorate$1([ - Property, - __metadata$1("design:type", Gravity) -], LinearLayout.prototype, "gravity", void 0); -class VLayout extends LinearLayout { -} -class HLayout extends LinearLayout { -} -function stack(views) { - const ret = new Stack; - ret.layoutConfig = layoutConfig().wrap(); - for (let v of views) { - ret.addChild(v); - } - return ret; -} -function hlayout(views) { - const ret = new HLayout; - ret.layoutConfig = layoutConfig().wrap(); - for (let v of views) { - ret.addChild(v); - } - return ret; -} -function vlayout(views) { - const ret = new VLayout; - ret.layoutConfig = layoutConfig().wrap(); - for (let v of views) { - ret.addChild(v); - } - return ret; -} - -var __decorate$2 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$2 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -function NativeCall(target, propertyKey, descriptor) { - const originVal = descriptor.value; - descriptor.value = function () { - const ret = Reflect.apply(originVal, this, arguments); - return ret; - }; - return descriptor; -} -class Panel { - constructor() { - this.__root__ = new Root; - this.headviews = new Map; - } - onCreate() { } - onDestroy() { } - onShow() { } - onHidden() { } - addHeadView(v) { - this.headviews.set(v.viewId, v); - } - allHeadViews() { - return this.headviews.values(); - } - removeHeadView(v) { - if (v instanceof View) { - this.headviews.delete(v.viewId); - } - else { - this.headviews.delete(v); - } - } - clearHeadViews() { - this.headviews.clear(); - } - getRootView() { - return this.__root__; - } - getInitData() { - return this.__data__; - } - __init__(frame, data) { - this.__data__ = data; - this.__root__.width = frame.width; - this.__root__.height = frame.height; - this.__root__.children.length = 0; - this.build(this.__root__); - } - __onCreate__() { - this.onCreate(); - } - __onDestroy__() { - this.onDestroy(); - } - __onShow__() { - this.onShow(); - } - __onHidden__() { - this.onHidden(); - } - __build__() { - this.build(this.__root__); - } - __response__(viewIds, callbackId) { - const v = this.retrospectView(viewIds); - if (v === undefined) { - loge(`Cannot find view for ${viewIds}`); - } - else { - const argumentsList = [callbackId]; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - return Reflect.apply(v.responseCallback, v, argumentsList); - } - } - retrospectView(ids) { - return ids.reduce((acc, cur) => { - if (acc === undefined) { - if (cur === this.__root__.viewId) { - return this.__root__; - } - return this.headviews.get(cur); - } - else { - if (Reflect.has(acc, "subviewById")) { - return Reflect.apply(Reflect.get(acc, "subviewById"), acc, [cur]); - } - return acc; - } - }, undefined); - } - nativeRender(model) { - if (this.context) { - this.context.shader.render(model); - } - } - hookBeforeNativeCall() { - this.__root__.clean(); - for (let v of this.headviews.values()) { - v.clean(); - } - } - hookAfterNativeCall() { - //Here insert a native call to ensure the promise is resolved done. - nativeEmpty(); - if (this.__root__.isDirty()) { - const model = this.__root__.toModel(); - this.nativeRender(model); - } - for (let v of this.headviews.values()) { - if (v.isDirty()) { - const model = v.toModel(); - this.nativeRender(model); - } - } - } -} -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", [Object, Object]), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__init__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onCreate__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onDestroy__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onShow__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onHidden__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__build__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", [Array, String]), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__response__", null); - -(function (RepeatMode) { - RepeatMode[RepeatMode["RESTART"] = 1] = "RESTART"; - RepeatMode[RepeatMode["REVERSE"] = 2] = "REVERSE"; -})(exports.RepeatMode || (exports.RepeatMode = {})); -(function (FillMode) { - /** - * The receiver is removed from the presentation when the animation is completed. - */ - FillMode[FillMode["Removed"] = 0] = "Removed"; - /** - * The receiver remains visible in its final state when the animation is completed. - */ - FillMode[FillMode["Forward"] = 1] = "Forward"; - /** - * The receiver clamps values before zero to zero when the animation is completed. - */ - FillMode[FillMode["Backward"] = 2] = "Backward"; - /** - * The receiver clamps values at both ends of the object’s time space - */ - FillMode[FillMode["Both"] = 3] = "Both"; -})(exports.FillMode || (exports.FillMode = {})); -(function (TimingFunction) { - /** - * The system default timing function. Use this function to ensure that the timing of your animations matches that of most system animations. - */ - TimingFunction[TimingFunction["Default"] = 0] = "Default"; - /** - * Linear pacing, which causes an animation to occur evenly over its duration. - */ - TimingFunction[TimingFunction["Linear"] = 1] = "Linear"; - /** - * Ease-in pacing, which causes an animation to begin slowly and then speed up as it progresses. - */ - TimingFunction[TimingFunction["EaseIn"] = 2] = "EaseIn"; - /** - * Ease-out pacing, which causes an animation to begin quickly and then slow as it progresses. - */ - TimingFunction[TimingFunction["EaseOut"] = 3] = "EaseOut"; - /** - * Ease-in-ease-out pacing, which causes an animation to begin slowly, accelerate through the middle of its duration, and then slow again before completing. - */ - TimingFunction[TimingFunction["EaseInEaseOut"] = 4] = "EaseInEaseOut"; -})(exports.TimingFunction || (exports.TimingFunction = {})); -class Animation { - constructor() { - this.changeables = new Map; - this.duration = 0; - this.fillMode = exports.FillMode.Forward; - } - toModel() { - const changeables = []; - for (let e of this.changeables.values()) { - changeables.push({ - key: e.key, - fromValue: e.fromValue, - toValue: e.toValue, - }); - } - return { - type: this.constructor.name, - delay: this.delay, - duration: this.duration, - changeables, - repeatCount: this.repeatCount, - repeatMode: this.repeatMode, - fillMode: this.fillMode, - timingFunction: this.timingFunction - }; - } -} -class ScaleAnimation extends Animation { - constructor() { - super(); - this.scaleXChangeable = { - key: "scaleX", - fromValue: 1, - toValue: 1, - }; - this.scaleYChangeable = { - key: "scaleY", - fromValue: 1, - toValue: 1, - }; - this.changeables.set("scaleX", this.scaleXChangeable); - this.changeables.set("scaleY", this.scaleYChangeable); - } - set fromScaleX(v) { - this.scaleXChangeable.fromValue = v; - } - get fromScaleX() { - return this.scaleXChangeable.fromValue; - } - set toScaleX(v) { - this.scaleXChangeable.toValue = v; - } - get toScaleX() { - return this.scaleXChangeable.toValue; - } - set fromScaleY(v) { - this.scaleYChangeable.fromValue = v; - } - get fromScaleY() { - return this.scaleYChangeable.fromValue; - } - set toScaleY(v) { - this.scaleYChangeable.toValue = v; - } - get toScaleY() { - return this.scaleYChangeable.toValue; - } -} -class TranslationAnimation extends Animation { - constructor() { - super(); - this.translationXChangeable = { - key: "translationX", - fromValue: 1, - toValue: 1, - }; - this.translationYChangeable = { - key: "translationY", - fromValue: 1, - toValue: 1, - }; - this.changeables.set("translationX", this.translationXChangeable); - this.changeables.set("translationY", this.translationYChangeable); - } - set fromTranslationX(v) { - this.translationXChangeable.fromValue = v; - } - get fromTranslationX() { - return this.translationXChangeable.fromValue; - } - set toTranslationX(v) { - this.translationXChangeable.toValue = v; - } - get toTranslationX() { - return this.translationXChangeable.toValue; - } - set fromTranslationY(v) { - this.translationYChangeable.fromValue = v; - } - get fromTranslationY() { - return this.translationYChangeable.fromValue; - } - set toTranslationY(v) { - this.translationYChangeable.toValue = v; - } - get toTranslationY() { - return this.translationYChangeable.toValue; - } -} -class RotationAnimation extends Animation { - constructor() { - super(); - this.rotationChaneable = { - key: "rotation", - fromValue: 1, - toValue: 1, - }; - this.changeables.set("rotation", this.rotationChaneable); - } - set fromRotation(v) { - this.rotationChaneable.fromValue = v; - } - get fromRotation() { - return this.rotationChaneable.fromValue; - } - set toRotation(v) { - this.rotationChaneable.toValue = v; - } - get toRotation() { - return this.rotationChaneable.toValue; - } -} -class AnimationSet { - constructor() { - this.animations = []; - this._duration = 0; - } - addAnimation(anim) { - this.animations.push(anim); - } - get duration() { - return this._duration; - } - set duration(v) { - this._duration = v; - this.animations.forEach(e => e.duration = v); - } - toModel() { - return { - animations: this.animations.map(e => { - return e.toModel(); - }), - delay: this.delay, - }; - } -} - -/** - * Store color as format AARRGGBB or RRGGBB - */ -class Color { - constructor(v) { - this._value = 0; - this._value = v | 0x0; - } - static parse(str) { - if (!str.startsWith("#")) { - throw new Error(`Parse color error with ${str}`); - } - const val = parseInt(str.substr(1), 16); - if (str.length === 7) { - return new Color(val | 0xff000000); - } - else if (str.length === 9) { - return new Color(val); - } - else { - throw new Error(`Parse color error with ${str}`); - } - } - static safeParse(str, defVal = Color.TRANSPARENT) { - let color = defVal; - try { - color = Color.parse(str); - } - catch (e) { - } - finally { - return color; - } - } - alpha(v) { - return new Color((this._value & 0xffffff) | ((v & 0xff) << 24)); - } - toModel() { - return this._value; - } -} -Color.BLACK = new Color(0xFF000000); -Color.DKGRAY = new Color(0xFF444444); -Color.GRAY = new Color(0xFF888888); -Color.LTGRAY = new Color(0xFFCCCCCC); -Color.WHITE = new Color(0xFFFFFFFF); -Color.RED = new Color(0xFFFF0000); -Color.GREEN = new Color(0xFF00FF00); -Color.BLUE = new Color(0xFF0000FF); -Color.YELLOW = new Color(0xFFFFFF00); -Color.CYAN = new Color(0xFF00FFFF); -Color.MAGENTA = new Color(0xFFFF00FF); -Color.TRANSPARENT = new Color(0); -(function (GradientOrientation) { - /** draw the gradient from the top to the bottom */ - GradientOrientation[GradientOrientation["TOP_BOTTOM"] = 0] = "TOP_BOTTOM"; - /** draw the gradient from the top-right to the bottom-left */ - GradientOrientation[GradientOrientation["TR_BL"] = 1] = "TR_BL"; - /** draw the gradient from the right to the left */ - GradientOrientation[GradientOrientation["RIGHT_LEFT"] = 2] = "RIGHT_LEFT"; - /** draw the gradient from the bottom-right to the top-left */ - GradientOrientation[GradientOrientation["BR_TL"] = 3] = "BR_TL"; - /** draw the gradient from the bottom to the top */ - GradientOrientation[GradientOrientation["BOTTOM_TOP"] = 4] = "BOTTOM_TOP"; - /** draw the gradient from the bottom-left to the top-right */ - GradientOrientation[GradientOrientation["BL_TR"] = 5] = "BL_TR"; - /** draw the gradient from the left to the right */ - GradientOrientation[GradientOrientation["LEFT_RIGHT"] = 6] = "LEFT_RIGHT"; - /** draw the gradient from the top-left to the bottom-right */ - GradientOrientation[GradientOrientation["TL_BR"] = 7] = "TL_BR"; -})(exports.GradientOrientation || (exports.GradientOrientation = {})); - -var __decorate$3 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$3 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class Text extends View { -} -__decorate$3([ - Property, - __metadata$3("design:type", String) -], Text.prototype, "text", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Color) -], Text.prototype, "textColor", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Number) -], Text.prototype, "textSize", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Number) -], Text.prototype, "maxLines", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Gravity) -], Text.prototype, "textAlignment", void 0); -function text(config) { - const ret = new Text; - ret.layoutConfig = layoutConfig().wrap(); - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} - -var __decorate$4 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$4 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -(function (ScaleType) { - ScaleType[ScaleType["ScaleToFill"] = 0] = "ScaleToFill"; - ScaleType[ScaleType["ScaleAspectFit"] = 1] = "ScaleAspectFit"; - ScaleType[ScaleType["ScaleAspectFill"] = 2] = "ScaleAspectFill"; -})(exports.ScaleType || (exports.ScaleType = {})); -class Image extends View { -} -__decorate$4([ - Property, - __metadata$4("design:type", String) -], Image.prototype, "imageUrl", void 0); -__decorate$4([ - Property, - __metadata$4("design:type", String) -], Image.prototype, "imageBase64", void 0); -__decorate$4([ - Property, - __metadata$4("design:type", Number) -], Image.prototype, "scaleType", void 0); -__decorate$4([ - Property, - __metadata$4("design:type", Function) -], Image.prototype, "loadCallback", void 0); -function image(config) { - const ret = new Image; - ret.layoutConfig = layoutConfig().wrap(); - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var __decorate$5 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$5 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class ListItem extends Stack { -} -__decorate$5([ - Property, - __metadata$5("design:type", String) -], ListItem.prototype, "identifier", void 0); -class List extends Superview { - constructor() { - super(...arguments); - this.cachedViews = new Map; - this.ignoreDirtyCallOnce = false; - this.itemCount = 0; - this.batchCount = 15; - } - allSubviews() { - return this.cachedViews.values(); - } - reset() { - this.cachedViews.clear(); - this.itemCount = 0; - } - getItem(itemIdx) { - let view = this.cachedViews.get(`${itemIdx}`); - if (view === undefined) { - view = this.renderItem(itemIdx); - view.superview = this; - this.cachedViews.set(`${itemIdx}`, view); - } - return view; - } - isDirty() { - if (this.ignoreDirtyCallOnce) { - this.ignoreDirtyCallOnce = false; - //Ignore the dirty call once. - return false; - } - return super.isDirty(); - } - renderBunchedItems(start, length) { - this.ignoreDirtyCallOnce = true; - return new Array(Math.min(length, this.itemCount - start)).fill(0).map((_, idx) => { - const listItem = this.getItem(start + idx); - return listItem.toModel(); - }); - } -} -__decorate$5([ - Property, - __metadata$5("design:type", Object) -], List.prototype, "itemCount", void 0); -__decorate$5([ - Property, - __metadata$5("design:type", Function) -], List.prototype, "renderItem", void 0); -__decorate$5([ - Property, - __metadata$5("design:type", Object) -], List.prototype, "batchCount", void 0); -function list(config) { - const ret = new List; - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} -function listItem(item) { - return (new ListItem).also((it) => { - it.layoutConfig = layoutConfig().wrap(); - it.addChild(item); - }); -} - -var __decorate$6 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$6 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class SlideItem extends Stack { -} -__decorate$6([ - Property, - __metadata$6("design:type", String) -], SlideItem.prototype, "identifier", void 0); -class Slider extends Superview { - constructor() { - super(...arguments); - this.cachedViews = new Map; - this.ignoreDirtyCallOnce = false; - this.itemCount = 0; - this.batchCount = 3; - } - allSubviews() { - return this.cachedViews.values(); - } - getItem(itemIdx) { - let view = this.cachedViews.get(`${itemIdx}`); - if (view === undefined) { - view = this.renderPage(itemIdx); - view.superview = this; - this.cachedViews.set(`${itemIdx}`, view); - } - return view; - } - isDirty() { - if (this.ignoreDirtyCallOnce) { - this.ignoreDirtyCallOnce = false; - //Ignore the dirty call once. - return false; - } - return super.isDirty(); - } - renderBunchedItems(start, length) { - this.ignoreDirtyCallOnce = true; - return new Array(Math.min(length, this.itemCount - start)).fill(0).map((_, idx) => { - const slideItem = this.getItem(start + idx); - return slideItem.toModel(); - }); - } -} -__decorate$6([ - Property, - __metadata$6("design:type", Object) -], Slider.prototype, "itemCount", void 0); -__decorate$6([ - Property, - __metadata$6("design:type", Function) -], Slider.prototype, "renderPage", void 0); -__decorate$6([ - Property, - __metadata$6("design:type", Object) -], Slider.prototype, "batchCount", void 0); -function slideItem(item) { - return (new SlideItem).also((it) => { - it.layoutConfig = layoutConfig().wrap(); - it.addChild(item); - }); -} -function slider(config) { - const ret = new Slider; - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function scroller(content) { - return (new Scroller).also(v => { - v.layoutConfig = layoutConfig().wrap(); - v.content = content; - }); -} -class Scroller extends Superview { - allSubviews() { - return [this.content]; - } - toModel() { - this.dirtyProps.content = this.content.viewId; - return super.toModel(); - } -} - -var __decorate$7 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$7 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class Refreshable extends Superview { - allSubviews() { - const ret = [this.content]; - if (this.header) { - ret.push(this.header); - } - return ret; - } - setRefreshable(context, refreshable) { - return this.nativeChannel(context, 'setRefreshable')(refreshable); - } - setRefreshing(context, refreshing) { - return this.nativeChannel(context, 'setRefreshing')(refreshing); - } - isRefreshable(context) { - return this.nativeChannel(context, 'isRefreshable')(); - } - isRefreshing(context) { - return this.nativeChannel(context, 'isRefreshing')(); - } - toModel() { - this.dirtyProps.content = this.content.viewId; - this.dirtyProps.header = (this.header || {}).viewId; - return super.toModel(); - } -} -__decorate$7([ - Property, - __metadata$7("design:type", Function) -], Refreshable.prototype, "onRefresh", void 0); -function refreshable(config) { - const ret = new Refreshable; - ret.layoutConfig = layoutConfig().wrap(); - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} -function pullable(v, config) { - Reflect.set(v, 'startAnimation', config.startAnimation); - Reflect.set(v, 'stopAnimation', config.stopAnimation); - Reflect.set(v, 'setPullingDistance', config.setPullingDistance); - return v; -} - -var __decorate$8 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$8 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class FlowLayoutItem extends Stack { -} -__decorate$8([ - Property, - __metadata$8("design:type", String) -], FlowLayoutItem.prototype, "identifier", void 0); -class FlowLayout extends Superview { - constructor() { - super(...arguments); - this.cachedViews = new Map; - this.ignoreDirtyCallOnce = false; - this.columnCount = 2; - this.itemCount = 0; - this.batchCount = 15; - } - allSubviews() { - return this.cachedViews.values(); - } - reset() { - this.cachedViews.clear(); - this.itemCount = 0; - } - getItem(itemIdx) { - let view = this.cachedViews.get(`${itemIdx}`); - if (view === undefined) { - view = this.renderItem(itemIdx); - view.superview = this; - this.cachedViews.set(`${itemIdx}`, view); - } - return view; - } - isDirty() { - if (this.ignoreDirtyCallOnce) { - this.ignoreDirtyCallOnce = false; - //Ignore the dirty call once. - return false; - } - return super.isDirty(); - } - renderBunchedItems(start, length) { - this.ignoreDirtyCallOnce = true; - return new Array(Math.min(length, this.itemCount - start)).fill(0).map((_, idx) => { - const listItem = this.getItem(start + idx); - return listItem.toModel(); - }); - } -} -__decorate$8([ - Property, - __metadata$8("design:type", Object) -], FlowLayout.prototype, "columnCount", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Number) -], FlowLayout.prototype, "columnSpace", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Number) -], FlowLayout.prototype, "rowSpace", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Object) -], FlowLayout.prototype, "itemCount", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Function) -], FlowLayout.prototype, "renderItem", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Object) -], FlowLayout.prototype, "batchCount", void 0); -function flowlayout(config) { - const ret = new FlowLayout; - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} -function flowItem(item) { - return (new FlowLayoutItem).also((it) => { - it.layoutConfig = layoutConfig().wrap(); - it.addChild(item); - }); -} - -function modal(context) { - return { - toast: (msg, gravity = Gravity.Bottom) => { - context.modal.toast({ - msg, - gravity: gravity.toModel(), - }); - }, - alert: (arg) => { - if (typeof arg === 'string') { - return context.modal.alert({ msg: arg }); - } - else { - return context.modal.alert(arg); - } - }, - confirm: (arg) => { - if (typeof arg === 'string') { - return context.modal.confirm({ msg: arg }); - } - else { - return context.modal.confirm(arg); - } - }, - prompt: (arg) => { - return context.modal.prompt(arg); - }, - }; -} - -function navbar(context) { - const entity = context.entity; - return { - isHidden: () => { - return context.navbar.isHidden(); - }, - setHidden: (hidden) => { - return context.navbar.setHidden({ - hidden, - }); - }, - setTitle: (title) => { - return context.navbar.setTitle({ - title, - }); - }, - setBgColor: (color) => { - return context.navbar.setBgColor({ - color: color.toModel(), - }); - }, - }; -} - -function navigator(context) { - return { - push: (scheme, alias, animated = true) => { - return context.navigator.push({ - scheme, alias, animated - }); - }, - pop: (animated = true) => { - return context.navigator.pop({ animated }); - }, - }; -} - -function transformRequest(request) { - let url = request.url || ""; - if (request.params !== undefined) { - const queryStrings = []; - for (let key in request.params) { - queryStrings.push(`${key}=${encodeURIComponent(request.params[key])}`); - } - request.url = `${request.url}${url.indexOf('?') >= 0 ? '&' : '?'}${queryStrings.join('&')}`; - } - if (typeof request.data === 'object') { - request.data = JSON.stringify(request.data); - } - return request; -} -function network(context) { - return { - request: (config) => { - return context.network.request(transformRequest(config)); - }, - get: (url, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "get"; - return context.network.request(transformRequest(finalConfig)); - }, - post: (url, data, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "post"; - if (data !== undefined) { - finalConfig.data = data; - } - return context.network.request(transformRequest(finalConfig)); - }, - put: (url, data, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "put"; - if (data !== undefined) { - finalConfig.data = data; - } - return context.network.request(transformRequest(finalConfig)); - }, - delete: (url, data, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "delete"; - return context.network.request(transformRequest(finalConfig)); - }, - }; -} - -function storage(context) { - return { - setItem: (key, value, zone) => { - return context.storage.setItem({ key, value, zone }); - }, - getItem: (key, zone) => { - return context.storage.getItem({ key, zone }); - }, - remove: (key, zone) => { - return context.storage.remove({ key, zone }); - }, - clear: (zone) => { - return context.storage.clear({ zone }); - }, - }; -} - -function popover(context) { - const entity = context.entity; - let panel = undefined; - if (entity instanceof Panel) { - panel = entity; - } - return { - show: (view) => { - if (panel) { - panel.addHeadView(view); - } - return context.popover.show(view.toModel()); - }, - dismiss: (view = undefined) => { - if (panel) { - if (view) { - panel.removeHeadView(view); - } - else { - panel.clearHeadViews(); - } - } - return context.popover.dismiss(view ? { id: view.viewId } : undefined); - }, - }; -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function take(target) { - return (block) => { - block(target); - }; -} -function takeNonNull(target) { - return (block) => { - if (target !== undefined) { - return block(target); - } - }; -} -function takeNull(target) { - return (block) => { - if (target === undefined) { - return block(); - } - }; -} -function takeLet(target) { - return (block) => { - return block(target); - }; -} -function takeAlso(target) { - return (block) => { - block(target); - return target; - }; -} -function takeIf(target) { - return (predicate) => { - return predicate(target) ? target : undefined; - }; -} -function takeUnless(target) { - return (predicate) => { - return predicate(target) ? undefined : target; - }; -} -function repeat(action) { - return (times) => { - for (let i = 0; i < times; i++) { - action(i); - } - }; -} - -/** - * Only supports x,y,width,height,corner(just for four corners),rotation,bgColor, - * @param panel @see Panel - */ -function animate(panel) { - return (args) => { - return takeLet(panel.context.animate)(it => { - return it.submit().then(() => { - args.animations(); - return takeLet(panel.getRootView())(root => { - if (root.isDirty()) { - const model = root.toModel(); - model.duration = args.duration; - const ret = it.animateRender(model); - root.clean(); - return ret; - } - for (let v of panel.allHeadViews()) { - if (v.isDirty()) { - const model = v.toModel(); - const ret = it.animateRender(model); - it.clean(); - return ret; - } - } - throw new Error('Cannot find any animated elements'); - }); - }); - }); - }; -} - -class Observable { - constructor(provider, clz) { - this.observers = new Set; - this.provider = provider; - this.clz = clz; - } - addObserver(observer) { - this.observers.add(observer); - } - removeObserver(observer) { - this.observers.delete(observer); - } - update(updater) { - const oldV = this.provider.acquire(this.clz); - const newV = updater(oldV); - if (newV !== undefined) { - this.provider.provide(newV); - } - for (let observer of this.observers) { - observer(newV); - } - } -} -class Provider { - constructor() { - this.provision = new Map; - this.observableMap = new Map; - } - provide(obj) { - this.provision.set(obj.constructor, obj); - } - acquire(clz) { - const ret = this.provision.get(clz); - return ret; - } - remove(clz) { - this.provision.delete(clz); - } - clear() { - this.provision.clear(); - } - observe(clz) { - let observable = this.observableMap.get(clz); - if (observable === undefined) { - observable = new Observable(this, clz); - this.observableMap.set(clz, observable); - } - return observable; - } -} - -class ViewHolder { -} -class ViewModel { - constructor(obj, v) { - this.state = obj; - this.viewHolder = v; - } - getState() { - return this.state; - } - updateState(setter) { - setter(this.state); - this.viewHolder.bind(this.state); - } - attach(view) { - this.viewHolder.build(view); - this.viewHolder.bind(this.state); - this.onAttached(this.state, this.viewHolder); - } -} -class VMPanel extends Panel { - getViewModel() { - return this.vm; - } - build(root) { - this.vh = new (this.getViewHolderClass()); - this.vm = new (this.getViewModelClass())(this.getState(), this.vh); - this.vm.attach(root); - } -} - -exports.AnimationSet = AnimationSet; -exports.BOTTOM = BOTTOM; -exports.CENTER = CENTER; -exports.CENTER_X = CENTER_X; -exports.CENTER_Y = CENTER_Y; -exports.Color = Color; -exports.FlowLayout = FlowLayout; -exports.FlowLayoutItem = FlowLayoutItem; -exports.Gravity = Gravity; -exports.Group = Group; -exports.HLayout = HLayout; -exports.Image = Image; -exports.LEFT = LEFT; -exports.LayoutConfigImpl = LayoutConfigImpl; -exports.List = List; -exports.ListItem = ListItem; -exports.Mutable = Mutable; -exports.NativeCall = NativeCall; -exports.Observable = Observable; -exports.Panel = Panel; -exports.Property = Property; -exports.Provider = Provider; -exports.RIGHT = RIGHT; -exports.Refreshable = Refreshable; -exports.Root = Root; -exports.RotationAnimation = RotationAnimation; -exports.ScaleAnimation = ScaleAnimation; -exports.Scroller = Scroller; -exports.SlideItem = SlideItem; -exports.Slider = Slider; -exports.Stack = Stack; -exports.Superview = Superview; -exports.TOP = TOP; -exports.Text = Text; -exports.TranslationAnimation = TranslationAnimation; -exports.VLayout = VLayout; -exports.VMPanel = VMPanel; -exports.View = View; -exports.ViewHolder = ViewHolder; -exports.ViewModel = ViewModel; -exports.animate = animate; -exports.flowItem = flowItem; -exports.flowlayout = flowlayout; -exports.gravity = gravity; -exports.hlayout = hlayout; -exports.image = image; -exports.layoutConfig = layoutConfig; -exports.list = list; -exports.listItem = listItem; -exports.log = log; -exports.loge = loge; -exports.logw = logw; -exports.modal = modal; -exports.navbar = navbar; -exports.navigator = navigator; -exports.network = network; -exports.obj2Model = obj2Model; -exports.popover = popover; -exports.pullable = pullable; -exports.refreshable = refreshable; -exports.repeat = repeat; -exports.scroller = scroller; -exports.slideItem = slideItem; -exports.slider = slider; -exports.stack = stack; -exports.storage = storage; -exports.take = take; -exports.takeAlso = takeAlso; -exports.takeIf = takeIf; -exports.takeLet = takeLet; -exports.takeNonNull = takeNonNull; -exports.takeNull = takeNull; -exports.takeUnless = takeUnless; -exports.text = text; -exports.uniqueId = uniqueId; -exports.vlayout = vlayout; diff --git a/doric/src/main/assets/bundle/doric-sandbox.js b/doric/src/main/assets/bundle/doric-sandbox.js deleted file mode 100644 index 0dfe650b..00000000 --- a/doric/src/main/assets/bundle/doric-sandbox.js +++ /dev/null @@ -1,1474 +0,0 @@ -var doric = (function (exports) { - 'use strict'; - - /* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - let __uniqueId__ = 0; - function uniqueId(prefix) { - return `__${prefix}_${__uniqueId__++}__`; - } - - function toString(message) { - if (message instanceof Function) { - return message.toString(); - } - else if (message instanceof Object) { - try { - return JSON.stringify(message); - } - catch (e) { - return message.toString(); - } - } - else if (message === undefined) { - return "undefined"; - } - else { - return message.toString(); - } - } - function loge(...message) { - let out = ""; - for (let i = 0; i < arguments.length; i++) { - if (i > 0) { - out += ','; - } - out += toString(arguments[i]); - } - nativeLog('e', out); - } - - /*! ***************************************************************************** - Copyright (C) Microsoft. All rights reserved. - Licensed under the Apache License, Version 2.0 (the "License"); you may not use - this file except in compliance with the License. You may obtain a copy of the - License at http://www.apache.org/licenses/LICENSE-2.0 - - THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY - KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED - WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, - MERCHANTABLITY OR NON-INFRINGEMENT. - - See the Apache Version 2.0 License for specific language governing permissions - and limitations under the License. - ***************************************************************************** */ - var Reflect$1; - (function (Reflect) { - // Metadata Proposal - // https://rbuckton.github.io/reflect-metadata/ - (function (factory) { - var root = typeof global === "object" ? global : - typeof self === "object" ? self : - typeof this === "object" ? this : - Function("return this;")(); - var exporter = makeExporter(Reflect); - if (typeof root.Reflect === "undefined") { - root.Reflect = Reflect; - } - else { - exporter = makeExporter(root.Reflect, exporter); - } - factory(exporter); - function makeExporter(target, previous) { - return function (key, value) { - if (typeof target[key] !== "function") { - Object.defineProperty(target, key, { configurable: true, writable: true, value: value }); - } - if (previous) - previous(key, value); - }; - } - })(function (exporter) { - var hasOwn = Object.prototype.hasOwnProperty; - // feature test for Symbol support - var supportsSymbol = typeof Symbol === "function"; - var toPrimitiveSymbol = supportsSymbol && typeof Symbol.toPrimitive !== "undefined" ? Symbol.toPrimitive : "@@toPrimitive"; - var iteratorSymbol = supportsSymbol && typeof Symbol.iterator !== "undefined" ? Symbol.iterator : "@@iterator"; - var supportsCreate = typeof Object.create === "function"; // feature test for Object.create support - var supportsProto = { __proto__: [] } instanceof Array; // feature test for __proto__ support - var downLevel = !supportsCreate && !supportsProto; - var HashMap = { - // create an object in dictionary mode (a.k.a. "slow" mode in v8) - create: supportsCreate - ? function () { return MakeDictionary(Object.create(null)); } - : supportsProto - ? function () { return MakeDictionary({ __proto__: null }); } - : function () { return MakeDictionary({}); }, - has: downLevel - ? function (map, key) { return hasOwn.call(map, key); } - : function (map, key) { return key in map; }, - get: downLevel - ? function (map, key) { return hasOwn.call(map, key) ? map[key] : undefined; } - : function (map, key) { return map[key]; }, - }; - // Load global or shim versions of Map, Set, and WeakMap - var functionPrototype = Object.getPrototypeOf(Function); - var usePolyfill = typeof process === "object" && process.env && process.env["REFLECT_METADATA_USE_MAP_POLYFILL"] === "true"; - var _Map = !usePolyfill && typeof Map === "function" && typeof Map.prototype.entries === "function" ? Map : CreateMapPolyfill(); - var _Set = !usePolyfill && typeof Set === "function" && typeof Set.prototype.entries === "function" ? Set : CreateSetPolyfill(); - var _WeakMap = !usePolyfill && typeof WeakMap === "function" ? WeakMap : CreateWeakMapPolyfill(); - // [[Metadata]] internal slot - // https://rbuckton.github.io/reflect-metadata/#ordinary-object-internal-methods-and-internal-slots - var Metadata = new _WeakMap(); - /** - * Applies a set of decorators to a property of a target object. - * @param decorators An array of decorators. - * @param target The target object. - * @param propertyKey (Optional) The property key to decorate. - * @param attributes (Optional) The property descriptor for the target key. - * @remarks Decorators are applied in reverse order. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * Example = Reflect.decorate(decoratorsArray, Example); - * - * // property (on constructor) - * Reflect.decorate(decoratorsArray, Example, "staticProperty"); - * - * // property (on prototype) - * Reflect.decorate(decoratorsArray, Example.prototype, "property"); - * - * // method (on constructor) - * Object.defineProperty(Example, "staticMethod", - * Reflect.decorate(decoratorsArray, Example, "staticMethod", - * Object.getOwnPropertyDescriptor(Example, "staticMethod"))); - * - * // method (on prototype) - * Object.defineProperty(Example.prototype, "method", - * Reflect.decorate(decoratorsArray, Example.prototype, "method", - * Object.getOwnPropertyDescriptor(Example.prototype, "method"))); - * - */ - function decorate(decorators, target, propertyKey, attributes) { - if (!IsUndefined(propertyKey)) { - if (!IsArray(decorators)) - throw new TypeError(); - if (!IsObject(target)) - throw new TypeError(); - if (!IsObject(attributes) && !IsUndefined(attributes) && !IsNull(attributes)) - throw new TypeError(); - if (IsNull(attributes)) - attributes = undefined; - propertyKey = ToPropertyKey(propertyKey); - return DecorateProperty(decorators, target, propertyKey, attributes); - } - else { - if (!IsArray(decorators)) - throw new TypeError(); - if (!IsConstructor(target)) - throw new TypeError(); - return DecorateConstructor(decorators, target); - } - } - exporter("decorate", decorate); - // 4.1.2 Reflect.metadata(metadataKey, metadataValue) - // https://rbuckton.github.io/reflect-metadata/#reflect.metadata - /** - * A default metadata decorator factory that can be used on a class, class member, or parameter. - * @param metadataKey The key for the metadata entry. - * @param metadataValue The value for the metadata entry. - * @returns A decorator function. - * @remarks - * If `metadataKey` is already defined for the target and target key, the - * metadataValue for that key will be overwritten. - * @example - * - * // constructor - * @Reflect.metadata(key, value) - * class Example { - * } - * - * // property (on constructor, TypeScript only) - * class Example { - * @Reflect.metadata(key, value) - * static staticProperty; - * } - * - * // property (on prototype, TypeScript only) - * class Example { - * @Reflect.metadata(key, value) - * property; - * } - * - * // method (on constructor) - * class Example { - * @Reflect.metadata(key, value) - * static staticMethod() { } - * } - * - * // method (on prototype) - * class Example { - * @Reflect.metadata(key, value) - * method() { } - * } - * - */ - function metadata(metadataKey, metadataValue) { - function decorator(target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey) && !IsPropertyKey(propertyKey)) - throw new TypeError(); - OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey); - } - return decorator; - } - exporter("metadata", metadata); - /** - * Define a unique metadata entry on the target. - * @param metadataKey A key used to store and retrieve metadata. - * @param metadataValue A value that contains attached metadata. - * @param target The target object on which to define metadata. - * @param propertyKey (Optional) The property key for the target. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * Reflect.defineMetadata("custom:annotation", options, Example); - * - * // property (on constructor) - * Reflect.defineMetadata("custom:annotation", options, Example, "staticProperty"); - * - * // property (on prototype) - * Reflect.defineMetadata("custom:annotation", options, Example.prototype, "property"); - * - * // method (on constructor) - * Reflect.defineMetadata("custom:annotation", options, Example, "staticMethod"); - * - * // method (on prototype) - * Reflect.defineMetadata("custom:annotation", options, Example.prototype, "method"); - * - * // decorator factory as metadata-producing annotation. - * function MyAnnotation(options): Decorator { - * return (target, key?) => Reflect.defineMetadata("custom:annotation", options, target, key); - * } - * - */ - function defineMetadata(metadataKey, metadataValue, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey); - } - exporter("defineMetadata", defineMetadata); - /** - * Gets a value indicating whether the target object or its prototype chain has the provided metadata key defined. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns `true` if the metadata key was defined on the target object or its prototype chain; otherwise, `false`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.hasMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.hasMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.hasMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.hasMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.hasMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function hasMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryHasMetadata(metadataKey, target, propertyKey); - } - exporter("hasMetadata", hasMetadata); - /** - * Gets a value indicating whether the target object has the provided metadata key defined. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns `true` if the metadata key was defined on the target object; otherwise, `false`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.hasOwnMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.hasOwnMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.hasOwnMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.hasOwnMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.hasOwnMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function hasOwnMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryHasOwnMetadata(metadataKey, target, propertyKey); - } - exporter("hasOwnMetadata", hasOwnMetadata); - /** - * Gets the metadata value for the provided metadata key on the target object or its prototype chain. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns The metadata value for the metadata key if found; otherwise, `undefined`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.getMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function getMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryGetMetadata(metadataKey, target, propertyKey); - } - exporter("getMetadata", getMetadata); - /** - * Gets the metadata value for the provided metadata key on the target object. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns The metadata value for the metadata key if found; otherwise, `undefined`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getOwnMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.getOwnMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getOwnMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getOwnMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getOwnMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function getOwnMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryGetOwnMetadata(metadataKey, target, propertyKey); - } - exporter("getOwnMetadata", getOwnMetadata); - /** - * Gets the metadata keys defined on the target object or its prototype chain. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns An array of unique metadata keys. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getMetadataKeys(Example); - * - * // property (on constructor) - * result = Reflect.getMetadataKeys(Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getMetadataKeys(Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getMetadataKeys(Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getMetadataKeys(Example.prototype, "method"); - * - */ - function getMetadataKeys(target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryMetadataKeys(target, propertyKey); - } - exporter("getMetadataKeys", getMetadataKeys); - /** - * Gets the unique metadata keys defined on the target object. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns An array of unique metadata keys. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getOwnMetadataKeys(Example); - * - * // property (on constructor) - * result = Reflect.getOwnMetadataKeys(Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getOwnMetadataKeys(Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getOwnMetadataKeys(Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getOwnMetadataKeys(Example.prototype, "method"); - * - */ - function getOwnMetadataKeys(target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryOwnMetadataKeys(target, propertyKey); - } - exporter("getOwnMetadataKeys", getOwnMetadataKeys); - /** - * Deletes the metadata entry from the target object with the provided key. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns `true` if the metadata entry was found and deleted; otherwise, false. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.deleteMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.deleteMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.deleteMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.deleteMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.deleteMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function deleteMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - var metadataMap = GetOrCreateMetadataMap(target, propertyKey, /*Create*/ false); - if (IsUndefined(metadataMap)) - return false; - if (!metadataMap.delete(metadataKey)) - return false; - if (metadataMap.size > 0) - return true; - var targetMetadata = Metadata.get(target); - targetMetadata.delete(propertyKey); - if (targetMetadata.size > 0) - return true; - Metadata.delete(target); - return true; - } - exporter("deleteMetadata", deleteMetadata); - function DecorateConstructor(decorators, target) { - for (var i = decorators.length - 1; i >= 0; --i) { - var decorator = decorators[i]; - var decorated = decorator(target); - if (!IsUndefined(decorated) && !IsNull(decorated)) { - if (!IsConstructor(decorated)) - throw new TypeError(); - target = decorated; - } - } - return target; - } - function DecorateProperty(decorators, target, propertyKey, descriptor) { - for (var i = decorators.length - 1; i >= 0; --i) { - var decorator = decorators[i]; - var decorated = decorator(target, propertyKey, descriptor); - if (!IsUndefined(decorated) && !IsNull(decorated)) { - if (!IsObject(decorated)) - throw new TypeError(); - descriptor = decorated; - } - } - return descriptor; - } - function GetOrCreateMetadataMap(O, P, Create) { - var targetMetadata = Metadata.get(O); - if (IsUndefined(targetMetadata)) { - if (!Create) - return undefined; - targetMetadata = new _Map(); - Metadata.set(O, targetMetadata); - } - var metadataMap = targetMetadata.get(P); - if (IsUndefined(metadataMap)) { - if (!Create) - return undefined; - metadataMap = new _Map(); - targetMetadata.set(P, metadataMap); - } - return metadataMap; - } - // 3.1.1.1 OrdinaryHasMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinaryhasmetadata - function OrdinaryHasMetadata(MetadataKey, O, P) { - var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P); - if (hasOwn) - return true; - var parent = OrdinaryGetPrototypeOf(O); - if (!IsNull(parent)) - return OrdinaryHasMetadata(MetadataKey, parent, P); - return false; - } - // 3.1.2.1 OrdinaryHasOwnMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinaryhasownmetadata - function OrdinaryHasOwnMetadata(MetadataKey, O, P) { - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false); - if (IsUndefined(metadataMap)) - return false; - return ToBoolean(metadataMap.has(MetadataKey)); - } - // 3.1.3.1 OrdinaryGetMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarygetmetadata - function OrdinaryGetMetadata(MetadataKey, O, P) { - var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P); - if (hasOwn) - return OrdinaryGetOwnMetadata(MetadataKey, O, P); - var parent = OrdinaryGetPrototypeOf(O); - if (!IsNull(parent)) - return OrdinaryGetMetadata(MetadataKey, parent, P); - return undefined; - } - // 3.1.4.1 OrdinaryGetOwnMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarygetownmetadata - function OrdinaryGetOwnMetadata(MetadataKey, O, P) { - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false); - if (IsUndefined(metadataMap)) - return undefined; - return metadataMap.get(MetadataKey); - } - // 3.1.5.1 OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarydefineownmetadata - function OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) { - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ true); - metadataMap.set(MetadataKey, MetadataValue); - } - // 3.1.6.1 OrdinaryMetadataKeys(O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarymetadatakeys - function OrdinaryMetadataKeys(O, P) { - var ownKeys = OrdinaryOwnMetadataKeys(O, P); - var parent = OrdinaryGetPrototypeOf(O); - if (parent === null) - return ownKeys; - var parentKeys = OrdinaryMetadataKeys(parent, P); - if (parentKeys.length <= 0) - return ownKeys; - if (ownKeys.length <= 0) - return parentKeys; - var set = new _Set(); - var keys = []; - for (var _i = 0, ownKeys_1 = ownKeys; _i < ownKeys_1.length; _i++) { - var key = ownKeys_1[_i]; - var hasKey = set.has(key); - if (!hasKey) { - set.add(key); - keys.push(key); - } - } - for (var _a = 0, parentKeys_1 = parentKeys; _a < parentKeys_1.length; _a++) { - var key = parentKeys_1[_a]; - var hasKey = set.has(key); - if (!hasKey) { - set.add(key); - keys.push(key); - } - } - return keys; - } - // 3.1.7.1 OrdinaryOwnMetadataKeys(O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinaryownmetadatakeys - function OrdinaryOwnMetadataKeys(O, P) { - var keys = []; - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false); - if (IsUndefined(metadataMap)) - return keys; - var keysObj = metadataMap.keys(); - var iterator = GetIterator(keysObj); - var k = 0; - while (true) { - var next = IteratorStep(iterator); - if (!next) { - keys.length = k; - return keys; - } - var nextValue = IteratorValue(next); - try { - keys[k] = nextValue; - } - catch (e) { - try { - IteratorClose(iterator); - } - finally { - throw e; - } - } - k++; - } - } - // 6 ECMAScript Data Typ0es and Values - // https://tc39.github.io/ecma262/#sec-ecmascript-data-types-and-values - function Type(x) { - if (x === null) - return 1 /* Null */; - switch (typeof x) { - case "undefined": return 0 /* Undefined */; - case "boolean": return 2 /* Boolean */; - case "string": return 3 /* String */; - case "symbol": return 4 /* Symbol */; - case "number": return 5 /* Number */; - case "object": return x === null ? 1 /* Null */ : 6 /* Object */; - default: return 6 /* Object */; - } - } - // 6.1.1 The Undefined Type - // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-undefined-type - function IsUndefined(x) { - return x === undefined; - } - // 6.1.2 The Null Type - // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-null-type - function IsNull(x) { - return x === null; - } - // 6.1.5 The Symbol Type - // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-symbol-type - function IsSymbol(x) { - return typeof x === "symbol"; - } - // 6.1.7 The Object Type - // https://tc39.github.io/ecma262/#sec-object-type - function IsObject(x) { - return typeof x === "object" ? x !== null : typeof x === "function"; - } - // 7.1 Type Conversion - // https://tc39.github.io/ecma262/#sec-type-conversion - // 7.1.1 ToPrimitive(input [, PreferredType]) - // https://tc39.github.io/ecma262/#sec-toprimitive - function ToPrimitive(input, PreferredType) { - switch (Type(input)) { - case 0 /* Undefined */: return input; - case 1 /* Null */: return input; - case 2 /* Boolean */: return input; - case 3 /* String */: return input; - case 4 /* Symbol */: return input; - case 5 /* Number */: return input; - } - var hint = PreferredType === 3 /* String */ ? "string" : PreferredType === 5 /* Number */ ? "number" : "default"; - var exoticToPrim = GetMethod(input, toPrimitiveSymbol); - if (exoticToPrim !== undefined) { - var result = exoticToPrim.call(input, hint); - if (IsObject(result)) - throw new TypeError(); - return result; - } - return OrdinaryToPrimitive(input, hint === "default" ? "number" : hint); - } - // 7.1.1.1 OrdinaryToPrimitive(O, hint) - // https://tc39.github.io/ecma262/#sec-ordinarytoprimitive - function OrdinaryToPrimitive(O, hint) { - if (hint === "string") { - var toString_1 = O.toString; - if (IsCallable(toString_1)) { - var result = toString_1.call(O); - if (!IsObject(result)) - return result; - } - var valueOf = O.valueOf; - if (IsCallable(valueOf)) { - var result = valueOf.call(O); - if (!IsObject(result)) - return result; - } - } - else { - var valueOf = O.valueOf; - if (IsCallable(valueOf)) { - var result = valueOf.call(O); - if (!IsObject(result)) - return result; - } - var toString_2 = O.toString; - if (IsCallable(toString_2)) { - var result = toString_2.call(O); - if (!IsObject(result)) - return result; - } - } - throw new TypeError(); - } - // 7.1.2 ToBoolean(argument) - // https://tc39.github.io/ecma262/2016/#sec-toboolean - function ToBoolean(argument) { - return !!argument; - } - // 7.1.12 ToString(argument) - // https://tc39.github.io/ecma262/#sec-tostring - function ToString(argument) { - return "" + argument; - } - // 7.1.14 ToPropertyKey(argument) - // https://tc39.github.io/ecma262/#sec-topropertykey - function ToPropertyKey(argument) { - var key = ToPrimitive(argument, 3 /* String */); - if (IsSymbol(key)) - return key; - return ToString(key); - } - // 7.2 Testing and Comparison Operations - // https://tc39.github.io/ecma262/#sec-testing-and-comparison-operations - // 7.2.2 IsArray(argument) - // https://tc39.github.io/ecma262/#sec-isarray - function IsArray(argument) { - return Array.isArray - ? Array.isArray(argument) - : argument instanceof Object - ? argument instanceof Array - : Object.prototype.toString.call(argument) === "[object Array]"; - } - // 7.2.3 IsCallable(argument) - // https://tc39.github.io/ecma262/#sec-iscallable - function IsCallable(argument) { - // NOTE: This is an approximation as we cannot check for [[Call]] internal method. - return typeof argument === "function"; - } - // 7.2.4 IsConstructor(argument) - // https://tc39.github.io/ecma262/#sec-isconstructor - function IsConstructor(argument) { - // NOTE: This is an approximation as we cannot check for [[Construct]] internal method. - return typeof argument === "function"; - } - // 7.2.7 IsPropertyKey(argument) - // https://tc39.github.io/ecma262/#sec-ispropertykey - function IsPropertyKey(argument) { - switch (Type(argument)) { - case 3 /* String */: return true; - case 4 /* Symbol */: return true; - default: return false; - } - } - // 7.3 Operations on Objects - // https://tc39.github.io/ecma262/#sec-operations-on-objects - // 7.3.9 GetMethod(V, P) - // https://tc39.github.io/ecma262/#sec-getmethod - function GetMethod(V, P) { - var func = V[P]; - if (func === undefined || func === null) - return undefined; - if (!IsCallable(func)) - throw new TypeError(); - return func; - } - // 7.4 Operations on Iterator Objects - // https://tc39.github.io/ecma262/#sec-operations-on-iterator-objects - function GetIterator(obj) { - var method = GetMethod(obj, iteratorSymbol); - if (!IsCallable(method)) - throw new TypeError(); // from Call - var iterator = method.call(obj); - if (!IsObject(iterator)) - throw new TypeError(); - return iterator; - } - // 7.4.4 IteratorValue(iterResult) - // https://tc39.github.io/ecma262/2016/#sec-iteratorvalue - function IteratorValue(iterResult) { - return iterResult.value; - } - // 7.4.5 IteratorStep(iterator) - // https://tc39.github.io/ecma262/#sec-iteratorstep - function IteratorStep(iterator) { - var result = iterator.next(); - return result.done ? false : result; - } - // 7.4.6 IteratorClose(iterator, completion) - // https://tc39.github.io/ecma262/#sec-iteratorclose - function IteratorClose(iterator) { - var f = iterator["return"]; - if (f) - f.call(iterator); - } - // 9.1 Ordinary Object Internal Methods and Internal Slots - // https://tc39.github.io/ecma262/#sec-ordinary-object-internal-methods-and-internal-slots - // 9.1.1.1 OrdinaryGetPrototypeOf(O) - // https://tc39.github.io/ecma262/#sec-ordinarygetprototypeof - function OrdinaryGetPrototypeOf(O) { - var proto = Object.getPrototypeOf(O); - if (typeof O !== "function" || O === functionPrototype) - return proto; - // TypeScript doesn't set __proto__ in ES5, as it's non-standard. - // Try to determine the superclass constructor. Compatible implementations - // must either set __proto__ on a subclass constructor to the superclass constructor, - // or ensure each class has a valid `constructor` property on its prototype that - // points back to the constructor. - // If this is not the same as Function.[[Prototype]], then this is definately inherited. - // This is the case when in ES6 or when using __proto__ in a compatible browser. - if (proto !== functionPrototype) - return proto; - // If the super prototype is Object.prototype, null, or undefined, then we cannot determine the heritage. - var prototype = O.prototype; - var prototypeProto = prototype && Object.getPrototypeOf(prototype); - if (prototypeProto == null || prototypeProto === Object.prototype) - return proto; - // If the constructor was not a function, then we cannot determine the heritage. - var constructor = prototypeProto.constructor; - if (typeof constructor !== "function") - return proto; - // If we have some kind of self-reference, then we cannot determine the heritage. - if (constructor === O) - return proto; - // we have a pretty good guess at the heritage. - return constructor; - } - // naive Map shim - function CreateMapPolyfill() { - var cacheSentinel = {}; - var arraySentinel = []; - var MapIterator = /** @class */ (function () { - function MapIterator(keys, values, selector) { - this._index = 0; - this._keys = keys; - this._values = values; - this._selector = selector; - } - MapIterator.prototype["@@iterator"] = function () { return this; }; - MapIterator.prototype[iteratorSymbol] = function () { return this; }; - MapIterator.prototype.next = function () { - var index = this._index; - if (index >= 0 && index < this._keys.length) { - var result = this._selector(this._keys[index], this._values[index]); - if (index + 1 >= this._keys.length) { - this._index = -1; - this._keys = arraySentinel; - this._values = arraySentinel; - } - else { - this._index++; - } - return { value: result, done: false }; - } - return { value: undefined, done: true }; - }; - MapIterator.prototype.throw = function (error) { - if (this._index >= 0) { - this._index = -1; - this._keys = arraySentinel; - this._values = arraySentinel; - } - throw error; - }; - MapIterator.prototype.return = function (value) { - if (this._index >= 0) { - this._index = -1; - this._keys = arraySentinel; - this._values = arraySentinel; - } - return { value: value, done: true }; - }; - return MapIterator; - }()); - return /** @class */ (function () { - function Map() { - this._keys = []; - this._values = []; - this._cacheKey = cacheSentinel; - this._cacheIndex = -2; - } - Object.defineProperty(Map.prototype, "size", { - get: function () { return this._keys.length; }, - enumerable: true, - configurable: true - }); - Map.prototype.has = function (key) { return this._find(key, /*insert*/ false) >= 0; }; - Map.prototype.get = function (key) { - var index = this._find(key, /*insert*/ false); - return index >= 0 ? this._values[index] : undefined; - }; - Map.prototype.set = function (key, value) { - var index = this._find(key, /*insert*/ true); - this._values[index] = value; - return this; - }; - Map.prototype.delete = function (key) { - var index = this._find(key, /*insert*/ false); - if (index >= 0) { - var size = this._keys.length; - for (var i = index + 1; i < size; i++) { - this._keys[i - 1] = this._keys[i]; - this._values[i - 1] = this._values[i]; - } - this._keys.length--; - this._values.length--; - if (key === this._cacheKey) { - this._cacheKey = cacheSentinel; - this._cacheIndex = -2; - } - return true; - } - return false; - }; - Map.prototype.clear = function () { - this._keys.length = 0; - this._values.length = 0; - this._cacheKey = cacheSentinel; - this._cacheIndex = -2; - }; - Map.prototype.keys = function () { return new MapIterator(this._keys, this._values, getKey); }; - Map.prototype.values = function () { return new MapIterator(this._keys, this._values, getValue); }; - Map.prototype.entries = function () { return new MapIterator(this._keys, this._values, getEntry); }; - Map.prototype["@@iterator"] = function () { return this.entries(); }; - Map.prototype[iteratorSymbol] = function () { return this.entries(); }; - Map.prototype._find = function (key, insert) { - if (this._cacheKey !== key) { - this._cacheIndex = this._keys.indexOf(this._cacheKey = key); - } - if (this._cacheIndex < 0 && insert) { - this._cacheIndex = this._keys.length; - this._keys.push(key); - this._values.push(undefined); - } - return this._cacheIndex; - }; - return Map; - }()); - function getKey(key, _) { - return key; - } - function getValue(_, value) { - return value; - } - function getEntry(key, value) { - return [key, value]; - } - } - // naive Set shim - function CreateSetPolyfill() { - return /** @class */ (function () { - function Set() { - this._map = new _Map(); - } - Object.defineProperty(Set.prototype, "size", { - get: function () { return this._map.size; }, - enumerable: true, - configurable: true - }); - Set.prototype.has = function (value) { return this._map.has(value); }; - Set.prototype.add = function (value) { return this._map.set(value, value), this; }; - Set.prototype.delete = function (value) { return this._map.delete(value); }; - Set.prototype.clear = function () { this._map.clear(); }; - Set.prototype.keys = function () { return this._map.keys(); }; - Set.prototype.values = function () { return this._map.values(); }; - Set.prototype.entries = function () { return this._map.entries(); }; - Set.prototype["@@iterator"] = function () { return this.keys(); }; - Set.prototype[iteratorSymbol] = function () { return this.keys(); }; - return Set; - }()); - } - // naive WeakMap shim - function CreateWeakMapPolyfill() { - var UUID_SIZE = 16; - var keys = HashMap.create(); - var rootKey = CreateUniqueKey(); - return /** @class */ (function () { - function WeakMap() { - this._key = CreateUniqueKey(); - } - WeakMap.prototype.has = function (target) { - var table = GetOrCreateWeakMapTable(target, /*create*/ false); - return table !== undefined ? HashMap.has(table, this._key) : false; - }; - WeakMap.prototype.get = function (target) { - var table = GetOrCreateWeakMapTable(target, /*create*/ false); - return table !== undefined ? HashMap.get(table, this._key) : undefined; - }; - WeakMap.prototype.set = function (target, value) { - var table = GetOrCreateWeakMapTable(target, /*create*/ true); - table[this._key] = value; - return this; - }; - WeakMap.prototype.delete = function (target) { - var table = GetOrCreateWeakMapTable(target, /*create*/ false); - return table !== undefined ? delete table[this._key] : false; - }; - WeakMap.prototype.clear = function () { - // NOTE: not a real clear, just makes the previous data unreachable - this._key = CreateUniqueKey(); - }; - return WeakMap; - }()); - function CreateUniqueKey() { - var key; - do - key = "@@WeakMap@@" + CreateUUID(); - while (HashMap.has(keys, key)); - keys[key] = true; - return key; - } - function GetOrCreateWeakMapTable(target, create) { - if (!hasOwn.call(target, rootKey)) { - if (!create) - return undefined; - Object.defineProperty(target, rootKey, { value: HashMap.create() }); - } - return target[rootKey]; - } - function FillRandomBytes(buffer, size) { - for (var i = 0; i < size; ++i) - buffer[i] = Math.random() * 0xff | 0; - return buffer; - } - function GenRandomBytes(size) { - if (typeof Uint8Array === "function") { - if (typeof crypto !== "undefined") - return crypto.getRandomValues(new Uint8Array(size)); - if (typeof msCrypto !== "undefined") - return msCrypto.getRandomValues(new Uint8Array(size)); - return FillRandomBytes(new Uint8Array(size), size); - } - return FillRandomBytes(new Array(size), size); - } - function CreateUUID() { - var data = GenRandomBytes(UUID_SIZE); - // mark as random - RFC 4122 § 4.4 - data[6] = data[6] & 0x4f | 0x40; - data[8] = data[8] & 0xbf | 0x80; - var result = ""; - for (var offset = 0; offset < UUID_SIZE; ++offset) { - var byte = data[offset]; - if (offset === 4 || offset === 6 || offset === 8) - result += "-"; - if (byte < 16) - result += "0"; - result += byte.toString(16).toLowerCase(); - } - return result; - } - } - // uses a heuristic used by v8 and chakra to force an object into dictionary mode. - function MakeDictionary(obj) { - obj.__ = undefined; - delete obj.__; - return obj; - } - }); - })(Reflect$1 || (Reflect$1 = {})); - - /* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - function hookBeforeNativeCall(context) { - if (context) { - Reflect.defineMetadata('__doric_context__', context, global$1); - context.hookBeforeNativeCall(); - } - } - function hookAfterNativeCall(context) { - if (context) { - context.hookAfterNativeCall(); - } - } - function getContext() { - return Reflect.getMetadata('__doric_context__', global$1); - } - function setContext(context) { - Reflect.defineMetadata('__doric_context__', context, global$1); - } - function jsCallResolve(contextId, callbackId, args) { - const context = gContexts.get(contextId); - if (context === undefined) { - loge(`Cannot find context for context id:${contextId}`); - return; - } - const callback = context.callbacks.get(callbackId); - if (callback === undefined) { - loge(`Cannot find call for context id:${contextId},callback id:${callbackId}`); - return; - } - const argumentsList = []; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - hookBeforeNativeCall(context); - Reflect.apply(callback.resolve, context, argumentsList); - hookAfterNativeCall(context); - } - function jsCallReject(contextId, callbackId, args) { - const context = gContexts.get(contextId); - if (context === undefined) { - loge(`Cannot find context for context id:${contextId}`); - return; - } - const callback = context.callbacks.get(callbackId); - if (callback === undefined) { - loge(`Cannot find call for context id:${contextId},callback id:${callbackId}`); - return; - } - const argumentsList = []; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - hookBeforeNativeCall(context); - Reflect.apply(callback.reject, context.entity, argumentsList); - hookAfterNativeCall(context); - } - class Context { - constructor(id) { - this.callbacks = new Map; - this.id = id; - return new Proxy(this, { - get: (target, p) => { - if (Reflect.has(target, p)) { - return Reflect.get(target, p); - } - else { - const namespace = p; - return new Proxy({}, { - get: (target, p) => { - if (Reflect.has(target, p)) { - return Reflect.get(target, p); - } - else { - const context = this; - return function () { - const args = []; - args.push(namespace); - args.push(p); - for (let arg of arguments) { - args.push(arg); - } - return Reflect.apply(context.callNative, context, args); - }; - } - } - }); - } - } - }); - } - hookBeforeNativeCall() { - if (this.entity && Reflect.has(this.entity, 'hookBeforeNativeCall')) { - Reflect.apply(Reflect.get(this.entity, 'hookBeforeNativeCall'), this.entity, []); - } - } - hookAfterNativeCall() { - if (this.entity && Reflect.has(this.entity, 'hookAfterNativeCall')) { - Reflect.apply(Reflect.get(this.entity, 'hookAfterNativeCall'), this.entity, []); - } - } - callNative(namespace, method, args) { - const callbackId = uniqueId('callback'); - nativeBridge(this.id, namespace, method, callbackId, args); - return new Promise((resolve, reject) => { - this.callbacks.set(callbackId, { - resolve, - reject, - }); - }); - } - register(instance) { - this.entity = instance; - } - } - const gContexts = new Map; - const gModules = new Map; - function jsObtainContext(id) { - if (gContexts.has(id)) { - const context = gContexts.get(id); - setContext(context); - return context; - } - else { - const context = new Context(id); - gContexts.set(id, context); - setContext(context); - return context; - } - } - function jsReleaseContext(id) { - const context = gContexts.get(id); - if (context) { - timerInfos.forEach((v, k) => { - if (v.context === context) { - if (global$1.nativeClearTimer === undefined) { - return Reflect.apply(_clearTimeout, undefined, arguments); - } - timerInfos.delete(k); - nativeClearTimer(k); - } - }); - } - gContexts.delete(id); - } - function __require__(name) { - if (gModules.has(name)) { - return gModules.get(name); - } - else { - if (nativeRequire(name)) { - return gModules.get(name); - } - else { - return undefined; - } - } - } - function jsRegisterModule(name, moduleObject) { - gModules.set(name, moduleObject); - } - function jsCallEntityMethod(contextId, methodName, args) { - const context = gContexts.get(contextId); - if (context === undefined) { - loge(`Cannot find context for context id:${contextId}`); - return; - } - if (context.entity === undefined) { - loge(`Cannot find holder for context id:${contextId}`); - return; - } - if (Reflect.has(context.entity, methodName)) { - const argumentsList = []; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - hookBeforeNativeCall(context); - const ret = Reflect.apply(Reflect.get(context.entity, methodName), context.entity, argumentsList); - hookAfterNativeCall(context); - return ret; - } - else { - loge(`Cannot find method for context id:${contextId},method name is:${methodName}`); - } - } - function jsObtainEntry(contextId) { - const context = jsObtainContext(contextId); - return (constructor) => { - const ret = class extends constructor { - constructor() { - super(...arguments); - this.context = context; - } - }; - if (context) { - context.register(new ret); - } - return ret; - }; - } - const global$1 = Function('return this')(); - let __timerId__ = 0; - const timerInfos = new Map; - const _setTimeout = global$1.setTimeout; - const _setInterval = global$1.setInterval; - const _clearTimeout = global$1.clearTimeout; - const _clearInterval = global$1.clearInterval; - global$1.setTimeout = function (handler, timeout, ...args) { - if (global$1.nativeSetTimer === undefined) { - return Reflect.apply(_setTimeout, undefined, arguments); - } - const id = __timerId__++; - timerInfos.set(id, { - callback: () => { - Reflect.apply(handler, undefined, args); - timerInfos.delete(id); - }, - context: getContext(), - }); - nativeSetTimer(id, timeout || 0, false); - return id; - }; - global$1.setInterval = function (handler, timeout, ...args) { - if (global$1.nativeSetTimer === undefined) { - return Reflect.apply(_setInterval, undefined, arguments); - } - const id = __timerId__++; - timerInfos.set(id, { - callback: () => { - Reflect.apply(handler, undefined, args); - }, - context: getContext(), - }); - nativeSetTimer(id, timeout || 0, true); - return id; - }; - global$1.clearTimeout = function (timerId) { - if (global$1.nativeClearTimer === undefined) { - return Reflect.apply(_clearTimeout, undefined, arguments); - } - timerInfos.delete(timerId); - nativeClearTimer(timerId); - }; - global$1.clearInterval = function (timerId) { - if (global$1.nativeClearTimer === undefined) { - return Reflect.apply(_clearInterval, undefined, arguments); - } - timerInfos.delete(timerId); - nativeClearTimer(timerId); - }; - function jsCallbackTimer(timerId) { - const timerInfo = timerInfos.get(timerId); - if (timerInfo === undefined) { - return; - } - if (timerInfo.callback instanceof Function) { - hookBeforeNativeCall(timerInfo.context); - Reflect.apply(timerInfo.callback, timerInfo.context, []); - hookAfterNativeCall(timerInfo.context); - } - } - - exports.Context = Context; - exports.__require__ = __require__; - exports.jsCallEntityMethod = jsCallEntityMethod; - exports.jsCallReject = jsCallReject; - exports.jsCallResolve = jsCallResolve; - exports.jsCallbackTimer = jsCallbackTimer; - exports.jsObtainContext = jsObtainContext; - exports.jsObtainEntry = jsObtainEntry; - exports.jsRegisterModule = jsRegisterModule; - exports.jsReleaseContext = jsReleaseContext; - - return exports; - -}({})); diff --git a/doric/src/main/assets/bundle/doric-vm.js b/doric/src/main/assets/bundle/doric-vm.js deleted file mode 100644 index 684bfde0..00000000 --- a/doric/src/main/assets/bundle/doric-vm.js +++ /dev/null @@ -1,3450 +0,0 @@ -'use strict'; - -Object.defineProperty(exports, '__esModule', { value: true }); - -var WebSocket = require('ws'); - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -let __uniqueId__ = 0; -function uniqueId(prefix) { - return `__${prefix}_${__uniqueId__++}__`; -} - -function toString(message) { - if (message instanceof Function) { - return message.toString(); - } - else if (message instanceof Object) { - try { - return JSON.stringify(message); - } - catch (e) { - return message.toString(); - } - } - else if (message === undefined) { - return "undefined"; - } - else { - return message.toString(); - } -} -function log(...args) { - let out = ""; - for (let i = 0; i < arguments.length; i++) { - if (i > 0) { - out += ','; - } - out += toString(arguments[i]); - } - nativeLog('d', out); -} -function loge(...message) { - let out = ""; - for (let i = 0; i < arguments.length; i++) { - if (i > 0) { - out += ','; - } - out += toString(arguments[i]); - } - nativeLog('e', out); -} -function logw(...message) { - let out = ""; - for (let i = 0; i < arguments.length; i++) { - if (i > 0) { - out += ','; - } - out += toString(arguments[i]); - } - nativeLog('w', out); -} - -/*! ***************************************************************************** -Copyright (C) Microsoft. All rights reserved. -Licensed under the Apache License, Version 2.0 (the "License"); you may not use -this file except in compliance with the License. You may obtain a copy of the -License at http://www.apache.org/licenses/LICENSE-2.0 - -THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY -KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED -WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, -MERCHANTABLITY OR NON-INFRINGEMENT. - -See the Apache Version 2.0 License for specific language governing permissions -and limitations under the License. -***************************************************************************** */ -var Reflect$1; -(function (Reflect) { - // Metadata Proposal - // https://rbuckton.github.io/reflect-metadata/ - (function (factory) { - var root = typeof global === "object" ? global : - typeof self === "object" ? self : - typeof this === "object" ? this : - Function("return this;")(); - var exporter = makeExporter(Reflect); - if (typeof root.Reflect === "undefined") { - root.Reflect = Reflect; - } - else { - exporter = makeExporter(root.Reflect, exporter); - } - factory(exporter); - function makeExporter(target, previous) { - return function (key, value) { - if (typeof target[key] !== "function") { - Object.defineProperty(target, key, { configurable: true, writable: true, value: value }); - } - if (previous) - previous(key, value); - }; - } - })(function (exporter) { - var hasOwn = Object.prototype.hasOwnProperty; - // feature test for Symbol support - var supportsSymbol = typeof Symbol === "function"; - var toPrimitiveSymbol = supportsSymbol && typeof Symbol.toPrimitive !== "undefined" ? Symbol.toPrimitive : "@@toPrimitive"; - var iteratorSymbol = supportsSymbol && typeof Symbol.iterator !== "undefined" ? Symbol.iterator : "@@iterator"; - var supportsCreate = typeof Object.create === "function"; // feature test for Object.create support - var supportsProto = { __proto__: [] } instanceof Array; // feature test for __proto__ support - var downLevel = !supportsCreate && !supportsProto; - var HashMap = { - // create an object in dictionary mode (a.k.a. "slow" mode in v8) - create: supportsCreate - ? function () { return MakeDictionary(Object.create(null)); } - : supportsProto - ? function () { return MakeDictionary({ __proto__: null }); } - : function () { return MakeDictionary({}); }, - has: downLevel - ? function (map, key) { return hasOwn.call(map, key); } - : function (map, key) { return key in map; }, - get: downLevel - ? function (map, key) { return hasOwn.call(map, key) ? map[key] : undefined; } - : function (map, key) { return map[key]; }, - }; - // Load global or shim versions of Map, Set, and WeakMap - var functionPrototype = Object.getPrototypeOf(Function); - var usePolyfill = typeof process === "object" && process.env && process.env["REFLECT_METADATA_USE_MAP_POLYFILL"] === "true"; - var _Map = !usePolyfill && typeof Map === "function" && typeof Map.prototype.entries === "function" ? Map : CreateMapPolyfill(); - var _Set = !usePolyfill && typeof Set === "function" && typeof Set.prototype.entries === "function" ? Set : CreateSetPolyfill(); - var _WeakMap = !usePolyfill && typeof WeakMap === "function" ? WeakMap : CreateWeakMapPolyfill(); - // [[Metadata]] internal slot - // https://rbuckton.github.io/reflect-metadata/#ordinary-object-internal-methods-and-internal-slots - var Metadata = new _WeakMap(); - /** - * Applies a set of decorators to a property of a target object. - * @param decorators An array of decorators. - * @param target The target object. - * @param propertyKey (Optional) The property key to decorate. - * @param attributes (Optional) The property descriptor for the target key. - * @remarks Decorators are applied in reverse order. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * Example = Reflect.decorate(decoratorsArray, Example); - * - * // property (on constructor) - * Reflect.decorate(decoratorsArray, Example, "staticProperty"); - * - * // property (on prototype) - * Reflect.decorate(decoratorsArray, Example.prototype, "property"); - * - * // method (on constructor) - * Object.defineProperty(Example, "staticMethod", - * Reflect.decorate(decoratorsArray, Example, "staticMethod", - * Object.getOwnPropertyDescriptor(Example, "staticMethod"))); - * - * // method (on prototype) - * Object.defineProperty(Example.prototype, "method", - * Reflect.decorate(decoratorsArray, Example.prototype, "method", - * Object.getOwnPropertyDescriptor(Example.prototype, "method"))); - * - */ - function decorate(decorators, target, propertyKey, attributes) { - if (!IsUndefined(propertyKey)) { - if (!IsArray(decorators)) - throw new TypeError(); - if (!IsObject(target)) - throw new TypeError(); - if (!IsObject(attributes) && !IsUndefined(attributes) && !IsNull(attributes)) - throw new TypeError(); - if (IsNull(attributes)) - attributes = undefined; - propertyKey = ToPropertyKey(propertyKey); - return DecorateProperty(decorators, target, propertyKey, attributes); - } - else { - if (!IsArray(decorators)) - throw new TypeError(); - if (!IsConstructor(target)) - throw new TypeError(); - return DecorateConstructor(decorators, target); - } - } - exporter("decorate", decorate); - // 4.1.2 Reflect.metadata(metadataKey, metadataValue) - // https://rbuckton.github.io/reflect-metadata/#reflect.metadata - /** - * A default metadata decorator factory that can be used on a class, class member, or parameter. - * @param metadataKey The key for the metadata entry. - * @param metadataValue The value for the metadata entry. - * @returns A decorator function. - * @remarks - * If `metadataKey` is already defined for the target and target key, the - * metadataValue for that key will be overwritten. - * @example - * - * // constructor - * @Reflect.metadata(key, value) - * class Example { - * } - * - * // property (on constructor, TypeScript only) - * class Example { - * @Reflect.metadata(key, value) - * static staticProperty; - * } - * - * // property (on prototype, TypeScript only) - * class Example { - * @Reflect.metadata(key, value) - * property; - * } - * - * // method (on constructor) - * class Example { - * @Reflect.metadata(key, value) - * static staticMethod() { } - * } - * - * // method (on prototype) - * class Example { - * @Reflect.metadata(key, value) - * method() { } - * } - * - */ - function metadata(metadataKey, metadataValue) { - function decorator(target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey) && !IsPropertyKey(propertyKey)) - throw new TypeError(); - OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey); - } - return decorator; - } - exporter("metadata", metadata); - /** - * Define a unique metadata entry on the target. - * @param metadataKey A key used to store and retrieve metadata. - * @param metadataValue A value that contains attached metadata. - * @param target The target object on which to define metadata. - * @param propertyKey (Optional) The property key for the target. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * Reflect.defineMetadata("custom:annotation", options, Example); - * - * // property (on constructor) - * Reflect.defineMetadata("custom:annotation", options, Example, "staticProperty"); - * - * // property (on prototype) - * Reflect.defineMetadata("custom:annotation", options, Example.prototype, "property"); - * - * // method (on constructor) - * Reflect.defineMetadata("custom:annotation", options, Example, "staticMethod"); - * - * // method (on prototype) - * Reflect.defineMetadata("custom:annotation", options, Example.prototype, "method"); - * - * // decorator factory as metadata-producing annotation. - * function MyAnnotation(options): Decorator { - * return (target, key?) => Reflect.defineMetadata("custom:annotation", options, target, key); - * } - * - */ - function defineMetadata(metadataKey, metadataValue, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey); - } - exporter("defineMetadata", defineMetadata); - /** - * Gets a value indicating whether the target object or its prototype chain has the provided metadata key defined. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns `true` if the metadata key was defined on the target object or its prototype chain; otherwise, `false`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.hasMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.hasMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.hasMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.hasMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.hasMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function hasMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryHasMetadata(metadataKey, target, propertyKey); - } - exporter("hasMetadata", hasMetadata); - /** - * Gets a value indicating whether the target object has the provided metadata key defined. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns `true` if the metadata key was defined on the target object; otherwise, `false`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.hasOwnMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.hasOwnMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.hasOwnMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.hasOwnMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.hasOwnMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function hasOwnMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryHasOwnMetadata(metadataKey, target, propertyKey); - } - exporter("hasOwnMetadata", hasOwnMetadata); - /** - * Gets the metadata value for the provided metadata key on the target object or its prototype chain. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns The metadata value for the metadata key if found; otherwise, `undefined`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.getMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function getMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryGetMetadata(metadataKey, target, propertyKey); - } - exporter("getMetadata", getMetadata); - /** - * Gets the metadata value for the provided metadata key on the target object. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns The metadata value for the metadata key if found; otherwise, `undefined`. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getOwnMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.getOwnMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getOwnMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getOwnMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getOwnMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function getOwnMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryGetOwnMetadata(metadataKey, target, propertyKey); - } - exporter("getOwnMetadata", getOwnMetadata); - /** - * Gets the metadata keys defined on the target object or its prototype chain. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns An array of unique metadata keys. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getMetadataKeys(Example); - * - * // property (on constructor) - * result = Reflect.getMetadataKeys(Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getMetadataKeys(Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getMetadataKeys(Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getMetadataKeys(Example.prototype, "method"); - * - */ - function getMetadataKeys(target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryMetadataKeys(target, propertyKey); - } - exporter("getMetadataKeys", getMetadataKeys); - /** - * Gets the unique metadata keys defined on the target object. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns An array of unique metadata keys. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.getOwnMetadataKeys(Example); - * - * // property (on constructor) - * result = Reflect.getOwnMetadataKeys(Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.getOwnMetadataKeys(Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.getOwnMetadataKeys(Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.getOwnMetadataKeys(Example.prototype, "method"); - * - */ - function getOwnMetadataKeys(target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - return OrdinaryOwnMetadataKeys(target, propertyKey); - } - exporter("getOwnMetadataKeys", getOwnMetadataKeys); - /** - * Deletes the metadata entry from the target object with the provided key. - * @param metadataKey A key used to store and retrieve metadata. - * @param target The target object on which the metadata is defined. - * @param propertyKey (Optional) The property key for the target. - * @returns `true` if the metadata entry was found and deleted; otherwise, false. - * @example - * - * class Example { - * // property declarations are not part of ES6, though they are valid in TypeScript: - * // static staticProperty; - * // property; - * - * constructor(p) { } - * static staticMethod(p) { } - * method(p) { } - * } - * - * // constructor - * result = Reflect.deleteMetadata("custom:annotation", Example); - * - * // property (on constructor) - * result = Reflect.deleteMetadata("custom:annotation", Example, "staticProperty"); - * - * // property (on prototype) - * result = Reflect.deleteMetadata("custom:annotation", Example.prototype, "property"); - * - * // method (on constructor) - * result = Reflect.deleteMetadata("custom:annotation", Example, "staticMethod"); - * - * // method (on prototype) - * result = Reflect.deleteMetadata("custom:annotation", Example.prototype, "method"); - * - */ - function deleteMetadata(metadataKey, target, propertyKey) { - if (!IsObject(target)) - throw new TypeError(); - if (!IsUndefined(propertyKey)) - propertyKey = ToPropertyKey(propertyKey); - var metadataMap = GetOrCreateMetadataMap(target, propertyKey, /*Create*/ false); - if (IsUndefined(metadataMap)) - return false; - if (!metadataMap.delete(metadataKey)) - return false; - if (metadataMap.size > 0) - return true; - var targetMetadata = Metadata.get(target); - targetMetadata.delete(propertyKey); - if (targetMetadata.size > 0) - return true; - Metadata.delete(target); - return true; - } - exporter("deleteMetadata", deleteMetadata); - function DecorateConstructor(decorators, target) { - for (var i = decorators.length - 1; i >= 0; --i) { - var decorator = decorators[i]; - var decorated = decorator(target); - if (!IsUndefined(decorated) && !IsNull(decorated)) { - if (!IsConstructor(decorated)) - throw new TypeError(); - target = decorated; - } - } - return target; - } - function DecorateProperty(decorators, target, propertyKey, descriptor) { - for (var i = decorators.length - 1; i >= 0; --i) { - var decorator = decorators[i]; - var decorated = decorator(target, propertyKey, descriptor); - if (!IsUndefined(decorated) && !IsNull(decorated)) { - if (!IsObject(decorated)) - throw new TypeError(); - descriptor = decorated; - } - } - return descriptor; - } - function GetOrCreateMetadataMap(O, P, Create) { - var targetMetadata = Metadata.get(O); - if (IsUndefined(targetMetadata)) { - if (!Create) - return undefined; - targetMetadata = new _Map(); - Metadata.set(O, targetMetadata); - } - var metadataMap = targetMetadata.get(P); - if (IsUndefined(metadataMap)) { - if (!Create) - return undefined; - metadataMap = new _Map(); - targetMetadata.set(P, metadataMap); - } - return metadataMap; - } - // 3.1.1.1 OrdinaryHasMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinaryhasmetadata - function OrdinaryHasMetadata(MetadataKey, O, P) { - var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P); - if (hasOwn) - return true; - var parent = OrdinaryGetPrototypeOf(O); - if (!IsNull(parent)) - return OrdinaryHasMetadata(MetadataKey, parent, P); - return false; - } - // 3.1.2.1 OrdinaryHasOwnMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinaryhasownmetadata - function OrdinaryHasOwnMetadata(MetadataKey, O, P) { - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false); - if (IsUndefined(metadataMap)) - return false; - return ToBoolean(metadataMap.has(MetadataKey)); - } - // 3.1.3.1 OrdinaryGetMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarygetmetadata - function OrdinaryGetMetadata(MetadataKey, O, P) { - var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P); - if (hasOwn) - return OrdinaryGetOwnMetadata(MetadataKey, O, P); - var parent = OrdinaryGetPrototypeOf(O); - if (!IsNull(parent)) - return OrdinaryGetMetadata(MetadataKey, parent, P); - return undefined; - } - // 3.1.4.1 OrdinaryGetOwnMetadata(MetadataKey, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarygetownmetadata - function OrdinaryGetOwnMetadata(MetadataKey, O, P) { - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false); - if (IsUndefined(metadataMap)) - return undefined; - return metadataMap.get(MetadataKey); - } - // 3.1.5.1 OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarydefineownmetadata - function OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) { - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ true); - metadataMap.set(MetadataKey, MetadataValue); - } - // 3.1.6.1 OrdinaryMetadataKeys(O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinarymetadatakeys - function OrdinaryMetadataKeys(O, P) { - var ownKeys = OrdinaryOwnMetadataKeys(O, P); - var parent = OrdinaryGetPrototypeOf(O); - if (parent === null) - return ownKeys; - var parentKeys = OrdinaryMetadataKeys(parent, P); - if (parentKeys.length <= 0) - return ownKeys; - if (ownKeys.length <= 0) - return parentKeys; - var set = new _Set(); - var keys = []; - for (var _i = 0, ownKeys_1 = ownKeys; _i < ownKeys_1.length; _i++) { - var key = ownKeys_1[_i]; - var hasKey = set.has(key); - if (!hasKey) { - set.add(key); - keys.push(key); - } - } - for (var _a = 0, parentKeys_1 = parentKeys; _a < parentKeys_1.length; _a++) { - var key = parentKeys_1[_a]; - var hasKey = set.has(key); - if (!hasKey) { - set.add(key); - keys.push(key); - } - } - return keys; - } - // 3.1.7.1 OrdinaryOwnMetadataKeys(O, P) - // https://rbuckton.github.io/reflect-metadata/#ordinaryownmetadatakeys - function OrdinaryOwnMetadataKeys(O, P) { - var keys = []; - var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false); - if (IsUndefined(metadataMap)) - return keys; - var keysObj = metadataMap.keys(); - var iterator = GetIterator(keysObj); - var k = 0; - while (true) { - var next = IteratorStep(iterator); - if (!next) { - keys.length = k; - return keys; - } - var nextValue = IteratorValue(next); - try { - keys[k] = nextValue; - } - catch (e) { - try { - IteratorClose(iterator); - } - finally { - throw e; - } - } - k++; - } - } - // 6 ECMAScript Data Typ0es and Values - // https://tc39.github.io/ecma262/#sec-ecmascript-data-types-and-values - function Type(x) { - if (x === null) - return 1 /* Null */; - switch (typeof x) { - case "undefined": return 0 /* Undefined */; - case "boolean": return 2 /* Boolean */; - case "string": return 3 /* String */; - case "symbol": return 4 /* Symbol */; - case "number": return 5 /* Number */; - case "object": return x === null ? 1 /* Null */ : 6 /* Object */; - default: return 6 /* Object */; - } - } - // 6.1.1 The Undefined Type - // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-undefined-type - function IsUndefined(x) { - return x === undefined; - } - // 6.1.2 The Null Type - // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-null-type - function IsNull(x) { - return x === null; - } - // 6.1.5 The Symbol Type - // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-symbol-type - function IsSymbol(x) { - return typeof x === "symbol"; - } - // 6.1.7 The Object Type - // https://tc39.github.io/ecma262/#sec-object-type - function IsObject(x) { - return typeof x === "object" ? x !== null : typeof x === "function"; - } - // 7.1 Type Conversion - // https://tc39.github.io/ecma262/#sec-type-conversion - // 7.1.1 ToPrimitive(input [, PreferredType]) - // https://tc39.github.io/ecma262/#sec-toprimitive - function ToPrimitive(input, PreferredType) { - switch (Type(input)) { - case 0 /* Undefined */: return input; - case 1 /* Null */: return input; - case 2 /* Boolean */: return input; - case 3 /* String */: return input; - case 4 /* Symbol */: return input; - case 5 /* Number */: return input; - } - var hint = PreferredType === 3 /* String */ ? "string" : PreferredType === 5 /* Number */ ? "number" : "default"; - var exoticToPrim = GetMethod(input, toPrimitiveSymbol); - if (exoticToPrim !== undefined) { - var result = exoticToPrim.call(input, hint); - if (IsObject(result)) - throw new TypeError(); - return result; - } - return OrdinaryToPrimitive(input, hint === "default" ? "number" : hint); - } - // 7.1.1.1 OrdinaryToPrimitive(O, hint) - // https://tc39.github.io/ecma262/#sec-ordinarytoprimitive - function OrdinaryToPrimitive(O, hint) { - if (hint === "string") { - var toString_1 = O.toString; - if (IsCallable(toString_1)) { - var result = toString_1.call(O); - if (!IsObject(result)) - return result; - } - var valueOf = O.valueOf; - if (IsCallable(valueOf)) { - var result = valueOf.call(O); - if (!IsObject(result)) - return result; - } - } - else { - var valueOf = O.valueOf; - if (IsCallable(valueOf)) { - var result = valueOf.call(O); - if (!IsObject(result)) - return result; - } - var toString_2 = O.toString; - if (IsCallable(toString_2)) { - var result = toString_2.call(O); - if (!IsObject(result)) - return result; - } - } - throw new TypeError(); - } - // 7.1.2 ToBoolean(argument) - // https://tc39.github.io/ecma262/2016/#sec-toboolean - function ToBoolean(argument) { - return !!argument; - } - // 7.1.12 ToString(argument) - // https://tc39.github.io/ecma262/#sec-tostring - function ToString(argument) { - return "" + argument; - } - // 7.1.14 ToPropertyKey(argument) - // https://tc39.github.io/ecma262/#sec-topropertykey - function ToPropertyKey(argument) { - var key = ToPrimitive(argument, 3 /* String */); - if (IsSymbol(key)) - return key; - return ToString(key); - } - // 7.2 Testing and Comparison Operations - // https://tc39.github.io/ecma262/#sec-testing-and-comparison-operations - // 7.2.2 IsArray(argument) - // https://tc39.github.io/ecma262/#sec-isarray - function IsArray(argument) { - return Array.isArray - ? Array.isArray(argument) - : argument instanceof Object - ? argument instanceof Array - : Object.prototype.toString.call(argument) === "[object Array]"; - } - // 7.2.3 IsCallable(argument) - // https://tc39.github.io/ecma262/#sec-iscallable - function IsCallable(argument) { - // NOTE: This is an approximation as we cannot check for [[Call]] internal method. - return typeof argument === "function"; - } - // 7.2.4 IsConstructor(argument) - // https://tc39.github.io/ecma262/#sec-isconstructor - function IsConstructor(argument) { - // NOTE: This is an approximation as we cannot check for [[Construct]] internal method. - return typeof argument === "function"; - } - // 7.2.7 IsPropertyKey(argument) - // https://tc39.github.io/ecma262/#sec-ispropertykey - function IsPropertyKey(argument) { - switch (Type(argument)) { - case 3 /* String */: return true; - case 4 /* Symbol */: return true; - default: return false; - } - } - // 7.3 Operations on Objects - // https://tc39.github.io/ecma262/#sec-operations-on-objects - // 7.3.9 GetMethod(V, P) - // https://tc39.github.io/ecma262/#sec-getmethod - function GetMethod(V, P) { - var func = V[P]; - if (func === undefined || func === null) - return undefined; - if (!IsCallable(func)) - throw new TypeError(); - return func; - } - // 7.4 Operations on Iterator Objects - // https://tc39.github.io/ecma262/#sec-operations-on-iterator-objects - function GetIterator(obj) { - var method = GetMethod(obj, iteratorSymbol); - if (!IsCallable(method)) - throw new TypeError(); // from Call - var iterator = method.call(obj); - if (!IsObject(iterator)) - throw new TypeError(); - return iterator; - } - // 7.4.4 IteratorValue(iterResult) - // https://tc39.github.io/ecma262/2016/#sec-iteratorvalue - function IteratorValue(iterResult) { - return iterResult.value; - } - // 7.4.5 IteratorStep(iterator) - // https://tc39.github.io/ecma262/#sec-iteratorstep - function IteratorStep(iterator) { - var result = iterator.next(); - return result.done ? false : result; - } - // 7.4.6 IteratorClose(iterator, completion) - // https://tc39.github.io/ecma262/#sec-iteratorclose - function IteratorClose(iterator) { - var f = iterator["return"]; - if (f) - f.call(iterator); - } - // 9.1 Ordinary Object Internal Methods and Internal Slots - // https://tc39.github.io/ecma262/#sec-ordinary-object-internal-methods-and-internal-slots - // 9.1.1.1 OrdinaryGetPrototypeOf(O) - // https://tc39.github.io/ecma262/#sec-ordinarygetprototypeof - function OrdinaryGetPrototypeOf(O) { - var proto = Object.getPrototypeOf(O); - if (typeof O !== "function" || O === functionPrototype) - return proto; - // TypeScript doesn't set __proto__ in ES5, as it's non-standard. - // Try to determine the superclass constructor. Compatible implementations - // must either set __proto__ on a subclass constructor to the superclass constructor, - // or ensure each class has a valid `constructor` property on its prototype that - // points back to the constructor. - // If this is not the same as Function.[[Prototype]], then this is definately inherited. - // This is the case when in ES6 or when using __proto__ in a compatible browser. - if (proto !== functionPrototype) - return proto; - // If the super prototype is Object.prototype, null, or undefined, then we cannot determine the heritage. - var prototype = O.prototype; - var prototypeProto = prototype && Object.getPrototypeOf(prototype); - if (prototypeProto == null || prototypeProto === Object.prototype) - return proto; - // If the constructor was not a function, then we cannot determine the heritage. - var constructor = prototypeProto.constructor; - if (typeof constructor !== "function") - return proto; - // If we have some kind of self-reference, then we cannot determine the heritage. - if (constructor === O) - return proto; - // we have a pretty good guess at the heritage. - return constructor; - } - // naive Map shim - function CreateMapPolyfill() { - var cacheSentinel = {}; - var arraySentinel = []; - var MapIterator = /** @class */ (function () { - function MapIterator(keys, values, selector) { - this._index = 0; - this._keys = keys; - this._values = values; - this._selector = selector; - } - MapIterator.prototype["@@iterator"] = function () { return this; }; - MapIterator.prototype[iteratorSymbol] = function () { return this; }; - MapIterator.prototype.next = function () { - var index = this._index; - if (index >= 0 && index < this._keys.length) { - var result = this._selector(this._keys[index], this._values[index]); - if (index + 1 >= this._keys.length) { - this._index = -1; - this._keys = arraySentinel; - this._values = arraySentinel; - } - else { - this._index++; - } - return { value: result, done: false }; - } - return { value: undefined, done: true }; - }; - MapIterator.prototype.throw = function (error) { - if (this._index >= 0) { - this._index = -1; - this._keys = arraySentinel; - this._values = arraySentinel; - } - throw error; - }; - MapIterator.prototype.return = function (value) { - if (this._index >= 0) { - this._index = -1; - this._keys = arraySentinel; - this._values = arraySentinel; - } - return { value: value, done: true }; - }; - return MapIterator; - }()); - return /** @class */ (function () { - function Map() { - this._keys = []; - this._values = []; - this._cacheKey = cacheSentinel; - this._cacheIndex = -2; - } - Object.defineProperty(Map.prototype, "size", { - get: function () { return this._keys.length; }, - enumerable: true, - configurable: true - }); - Map.prototype.has = function (key) { return this._find(key, /*insert*/ false) >= 0; }; - Map.prototype.get = function (key) { - var index = this._find(key, /*insert*/ false); - return index >= 0 ? this._values[index] : undefined; - }; - Map.prototype.set = function (key, value) { - var index = this._find(key, /*insert*/ true); - this._values[index] = value; - return this; - }; - Map.prototype.delete = function (key) { - var index = this._find(key, /*insert*/ false); - if (index >= 0) { - var size = this._keys.length; - for (var i = index + 1; i < size; i++) { - this._keys[i - 1] = this._keys[i]; - this._values[i - 1] = this._values[i]; - } - this._keys.length--; - this._values.length--; - if (key === this._cacheKey) { - this._cacheKey = cacheSentinel; - this._cacheIndex = -2; - } - return true; - } - return false; - }; - Map.prototype.clear = function () { - this._keys.length = 0; - this._values.length = 0; - this._cacheKey = cacheSentinel; - this._cacheIndex = -2; - }; - Map.prototype.keys = function () { return new MapIterator(this._keys, this._values, getKey); }; - Map.prototype.values = function () { return new MapIterator(this._keys, this._values, getValue); }; - Map.prototype.entries = function () { return new MapIterator(this._keys, this._values, getEntry); }; - Map.prototype["@@iterator"] = function () { return this.entries(); }; - Map.prototype[iteratorSymbol] = function () { return this.entries(); }; - Map.prototype._find = function (key, insert) { - if (this._cacheKey !== key) { - this._cacheIndex = this._keys.indexOf(this._cacheKey = key); - } - if (this._cacheIndex < 0 && insert) { - this._cacheIndex = this._keys.length; - this._keys.push(key); - this._values.push(undefined); - } - return this._cacheIndex; - }; - return Map; - }()); - function getKey(key, _) { - return key; - } - function getValue(_, value) { - return value; - } - function getEntry(key, value) { - return [key, value]; - } - } - // naive Set shim - function CreateSetPolyfill() { - return /** @class */ (function () { - function Set() { - this._map = new _Map(); - } - Object.defineProperty(Set.prototype, "size", { - get: function () { return this._map.size; }, - enumerable: true, - configurable: true - }); - Set.prototype.has = function (value) { return this._map.has(value); }; - Set.prototype.add = function (value) { return this._map.set(value, value), this; }; - Set.prototype.delete = function (value) { return this._map.delete(value); }; - Set.prototype.clear = function () { this._map.clear(); }; - Set.prototype.keys = function () { return this._map.keys(); }; - Set.prototype.values = function () { return this._map.values(); }; - Set.prototype.entries = function () { return this._map.entries(); }; - Set.prototype["@@iterator"] = function () { return this.keys(); }; - Set.prototype[iteratorSymbol] = function () { return this.keys(); }; - return Set; - }()); - } - // naive WeakMap shim - function CreateWeakMapPolyfill() { - var UUID_SIZE = 16; - var keys = HashMap.create(); - var rootKey = CreateUniqueKey(); - return /** @class */ (function () { - function WeakMap() { - this._key = CreateUniqueKey(); - } - WeakMap.prototype.has = function (target) { - var table = GetOrCreateWeakMapTable(target, /*create*/ false); - return table !== undefined ? HashMap.has(table, this._key) : false; - }; - WeakMap.prototype.get = function (target) { - var table = GetOrCreateWeakMapTable(target, /*create*/ false); - return table !== undefined ? HashMap.get(table, this._key) : undefined; - }; - WeakMap.prototype.set = function (target, value) { - var table = GetOrCreateWeakMapTable(target, /*create*/ true); - table[this._key] = value; - return this; - }; - WeakMap.prototype.delete = function (target) { - var table = GetOrCreateWeakMapTable(target, /*create*/ false); - return table !== undefined ? delete table[this._key] : false; - }; - WeakMap.prototype.clear = function () { - // NOTE: not a real clear, just makes the previous data unreachable - this._key = CreateUniqueKey(); - }; - return WeakMap; - }()); - function CreateUniqueKey() { - var key; - do - key = "@@WeakMap@@" + CreateUUID(); - while (HashMap.has(keys, key)); - keys[key] = true; - return key; - } - function GetOrCreateWeakMapTable(target, create) { - if (!hasOwn.call(target, rootKey)) { - if (!create) - return undefined; - Object.defineProperty(target, rootKey, { value: HashMap.create() }); - } - return target[rootKey]; - } - function FillRandomBytes(buffer, size) { - for (var i = 0; i < size; ++i) - buffer[i] = Math.random() * 0xff | 0; - return buffer; - } - function GenRandomBytes(size) { - if (typeof Uint8Array === "function") { - if (typeof crypto !== "undefined") - return crypto.getRandomValues(new Uint8Array(size)); - if (typeof msCrypto !== "undefined") - return msCrypto.getRandomValues(new Uint8Array(size)); - return FillRandomBytes(new Uint8Array(size), size); - } - return FillRandomBytes(new Array(size), size); - } - function CreateUUID() { - var data = GenRandomBytes(UUID_SIZE); - // mark as random - RFC 4122 § 4.4 - data[6] = data[6] & 0x4f | 0x40; - data[8] = data[8] & 0xbf | 0x80; - var result = ""; - for (var offset = 0; offset < UUID_SIZE; ++offset) { - var byte = data[offset]; - if (offset === 4 || offset === 6 || offset === 8) - result += "-"; - if (byte < 16) - result += "0"; - result += byte.toString(16).toLowerCase(); - } - return result; - } - } - // uses a heuristic used by v8 and chakra to force an object into dictionary mode. - function MakeDictionary(obj) { - obj.__ = undefined; - delete obj.__; - return obj; - } - }); -})(Reflect$1 || (Reflect$1 = {})); - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function hookBeforeNativeCall(context) { - if (context) { - Reflect.defineMetadata('__doric_context__', context, global$1); - context.hookBeforeNativeCall(); - } -} -function hookAfterNativeCall(context) { - if (context) { - context.hookAfterNativeCall(); - } -} -function getContext() { - return Reflect.getMetadata('__doric_context__', global$1); -} -function setContext(context) { - Reflect.defineMetadata('__doric_context__', context, global$1); -} -function jsCallResolve(contextId, callbackId, args) { - const context = gContexts.get(contextId); - if (context === undefined) { - loge(`Cannot find context for context id:${contextId}`); - return; - } - const callback = context.callbacks.get(callbackId); - if (callback === undefined) { - loge(`Cannot find call for context id:${contextId},callback id:${callbackId}`); - return; - } - const argumentsList = []; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - hookBeforeNativeCall(context); - Reflect.apply(callback.resolve, context, argumentsList); - hookAfterNativeCall(context); -} -function jsCallReject(contextId, callbackId, args) { - const context = gContexts.get(contextId); - if (context === undefined) { - loge(`Cannot find context for context id:${contextId}`); - return; - } - const callback = context.callbacks.get(callbackId); - if (callback === undefined) { - loge(`Cannot find call for context id:${contextId},callback id:${callbackId}`); - return; - } - const argumentsList = []; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - hookBeforeNativeCall(context); - Reflect.apply(callback.reject, context.entity, argumentsList); - hookAfterNativeCall(context); -} -class Context { - constructor(id) { - this.callbacks = new Map; - this.id = id; - return new Proxy(this, { - get: (target, p) => { - if (Reflect.has(target, p)) { - return Reflect.get(target, p); - } - else { - const namespace = p; - return new Proxy({}, { - get: (target, p) => { - if (Reflect.has(target, p)) { - return Reflect.get(target, p); - } - else { - const context = this; - return function () { - const args = []; - args.push(namespace); - args.push(p); - for (let arg of arguments) { - args.push(arg); - } - return Reflect.apply(context.callNative, context, args); - }; - } - } - }); - } - } - }); - } - hookBeforeNativeCall() { - if (this.entity && Reflect.has(this.entity, 'hookBeforeNativeCall')) { - Reflect.apply(Reflect.get(this.entity, 'hookBeforeNativeCall'), this.entity, []); - } - } - hookAfterNativeCall() { - if (this.entity && Reflect.has(this.entity, 'hookAfterNativeCall')) { - Reflect.apply(Reflect.get(this.entity, 'hookAfterNativeCall'), this.entity, []); - } - } - callNative(namespace, method, args) { - const callbackId = uniqueId('callback'); - nativeBridge(this.id, namespace, method, callbackId, args); - return new Promise((resolve, reject) => { - this.callbacks.set(callbackId, { - resolve, - reject, - }); - }); - } - register(instance) { - this.entity = instance; - } -} -const gContexts = new Map; -const gModules = new Map; -function jsObtainContext(id) { - if (gContexts.has(id)) { - const context = gContexts.get(id); - setContext(context); - return context; - } - else { - const context = new Context(id); - gContexts.set(id, context); - setContext(context); - return context; - } -} -function jsReleaseContext(id) { - const context = gContexts.get(id); - if (context) { - timerInfos.forEach((v, k) => { - if (v.context === context) { - if (global$1.nativeClearTimer === undefined) { - return Reflect.apply(_clearTimeout, undefined, arguments); - } - timerInfos.delete(k); - nativeClearTimer(k); - } - }); - } - gContexts.delete(id); -} -function __require__(name) { - if (gModules.has(name)) { - return gModules.get(name); - } - else { - if (nativeRequire(name)) { - return gModules.get(name); - } - else { - return undefined; - } - } -} -function jsRegisterModule(name, moduleObject) { - gModules.set(name, moduleObject); -} -function jsCallEntityMethod(contextId, methodName, args) { - const context = gContexts.get(contextId); - if (context === undefined) { - loge(`Cannot find context for context id:${contextId}`); - return; - } - if (context.entity === undefined) { - loge(`Cannot find holder for context id:${contextId}`); - return; - } - if (Reflect.has(context.entity, methodName)) { - const argumentsList = []; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - hookBeforeNativeCall(context); - const ret = Reflect.apply(Reflect.get(context.entity, methodName), context.entity, argumentsList); - hookAfterNativeCall(context); - return ret; - } - else { - loge(`Cannot find method for context id:${contextId},method name is:${methodName}`); - } -} -function jsObtainEntry(contextId) { - const context = jsObtainContext(contextId); - return (constructor) => { - const ret = class extends constructor { - constructor() { - super(...arguments); - this.context = context; - } - }; - if (context) { - context.register(new ret); - } - return ret; - }; -} -const global$1 = Function('return this')(); -let __timerId__ = 0; -const timerInfos = new Map; -const _setTimeout = global$1.setTimeout; -const _setInterval = global$1.setInterval; -const _clearTimeout = global$1.clearTimeout; -const _clearInterval = global$1.clearInterval; -global$1.setTimeout = function (handler, timeout, ...args) { - if (global$1.nativeSetTimer === undefined) { - return Reflect.apply(_setTimeout, undefined, arguments); - } - const id = __timerId__++; - timerInfos.set(id, { - callback: () => { - Reflect.apply(handler, undefined, args); - timerInfos.delete(id); - }, - context: getContext(), - }); - nativeSetTimer(id, timeout || 0, false); - return id; -}; -global$1.setInterval = function (handler, timeout, ...args) { - if (global$1.nativeSetTimer === undefined) { - return Reflect.apply(_setInterval, undefined, arguments); - } - const id = __timerId__++; - timerInfos.set(id, { - callback: () => { - Reflect.apply(handler, undefined, args); - }, - context: getContext(), - }); - nativeSetTimer(id, timeout || 0, true); - return id; -}; -global$1.clearTimeout = function (timerId) { - if (global$1.nativeClearTimer === undefined) { - return Reflect.apply(_clearTimeout, undefined, arguments); - } - timerInfos.delete(timerId); - nativeClearTimer(timerId); -}; -global$1.clearInterval = function (timerId) { - if (global$1.nativeClearTimer === undefined) { - return Reflect.apply(_clearInterval, undefined, arguments); - } - timerInfos.delete(timerId); - nativeClearTimer(timerId); -}; -function jsCallbackTimer(timerId) { - const timerInfo = timerInfos.get(timerId); - if (timerInfo === undefined) { - return; - } - if (timerInfo.callback instanceof Function) { - hookBeforeNativeCall(timerInfo.context); - Reflect.apply(timerInfo.callback, timerInfo.context, []); - hookAfterNativeCall(timerInfo.context); - } -} - -var doric = /*#__PURE__*/Object.freeze({ - __proto__: null, - jsCallResolve: jsCallResolve, - jsCallReject: jsCallReject, - Context: Context, - jsObtainContext: jsObtainContext, - jsReleaseContext: jsReleaseContext, - __require__: __require__, - jsRegisterModule: jsRegisterModule, - jsCallEntityMethod: jsCallEntityMethod, - jsObtainEntry: jsObtainEntry, - jsCallbackTimer: jsCallbackTimer -}); - -function obj2Model(obj) { - if (obj instanceof Array) { - return obj.map(e => obj2Model(e)); - } - else if (obj instanceof Object) { - if (Reflect.has(obj, 'toModel') && Reflect.get(obj, 'toModel') instanceof Function) { - obj = Reflect.apply(Reflect.get(obj, 'toModel'), obj, []); - return obj; - } - else { - for (let key in obj) { - const val = Reflect.get(obj, key); - Reflect.set(obj, key, obj2Model(val)); - } - return obj; - } - } - else { - return obj; - } -} -class Mutable { - constructor(v) { - this.binders = new Set; - this.get = () => { - return this.val; - }; - this.set = (v) => { - this.val = v; - this.binders.forEach(e => { - Reflect.apply(e, undefined, [this.val]); - }); - }; - this.val = v; - } - bind(binder) { - this.binders.add(binder); - Reflect.apply(binder, undefined, [this.val]); - } - static of(v) { - return new Mutable(v); - } -} - -var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -function Property(target, propKey) { - Reflect.defineMetadata(propKey, true, target); -} -class View { - constructor() { - this.width = 0; - this.height = 0; - this.x = 0; - this.y = 0; - this.viewId = uniqueId('ViewId'); - this.callbacks = new Map; - /** Anchor end*/ - this.__dirty_props__ = {}; - this.nativeViewModel = { - id: this.viewId, - type: this.constructor.name, - props: this.__dirty_props__, - }; - return new Proxy(this, { - get: (target, p, receiver) => { - return Reflect.get(target, p, receiver); - }, - set: (target, p, v, receiver) => { - const oldV = Reflect.get(target, p, receiver); - const ret = Reflect.set(target, p, v, receiver); - if (Reflect.getMetadata(p, target) && oldV !== v) { - receiver.onPropertyChanged(p.toString(), oldV, v); - } - return ret; - } - }); - } - callback2Id(f) { - const id = uniqueId('Function'); - this.callbacks.set(id, f); - return id; - } - id2Callback(id) { - let f = this.callbacks.get(id); - if (f === undefined) { - f = Reflect.get(this, id); - } - return f; - } - /** Anchor start*/ - get left() { - return this.x; - } - set left(v) { - this.x = v; - } - get right() { - return this.x + this.width; - } - set right(v) { - this.x = v - this.width; - } - get top() { - return this.y; - } - set top(v) { - this.y = v; - } - get bottom() { - return this.y + this.height; - } - set bottom(v) { - this.y = v - this.height; - } - get centerX() { - return this.x + this.width / 2; - } - get centerY() { - return this.y + this.height / 2; - } - set centerX(v) { - this.x = v - this.width / 2; - } - set centerY(v) { - this.y = v - this.height / 2; - } - get dirtyProps() { - return this.__dirty_props__; - } - onPropertyChanged(propKey, oldV, newV) { - if (newV instanceof Function) { - newV = this.callback2Id(newV); - } - else { - newV = obj2Model(newV); - } - this.__dirty_props__[propKey] = newV; - } - clean() { - for (const key in this.__dirty_props__) { - if (Reflect.has(this.__dirty_props__, key)) { - Reflect.deleteProperty(this.__dirty_props__, key); - } - } - } - isDirty() { - return Reflect.ownKeys(this.__dirty_props__).length !== 0; - } - responseCallback(id, ...args) { - const f = this.id2Callback(id); - if (f instanceof Function) { - const argumentsList = []; - for (let i = 1; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - return Reflect.apply(f, this, argumentsList); - } - else { - loge(`Cannot find callback:${id} for ${JSON.stringify(this.toModel())}`); - } - } - toModel() { - return this.nativeViewModel; - } - let(block) { - block(this); - } - also(block) { - block(this); - return this; - } - apply(config) { - for (let key in config) { - Reflect.set(this, key, Reflect.get(config, key, config), this); - } - return this; - } - in(group) { - group.addChild(this); - return this; - } - nativeChannel(context, name) { - let thisView = this; - return function (args = undefined) { - const func = context.shader.command; - const viewIds = []; - while (thisView != undefined) { - viewIds.push(thisView.viewId); - thisView = thisView.superview; - } - const params = { - viewIds: viewIds.reverse(), - name, - args, - }; - return Reflect.apply(func, undefined, [params]); - }; - } - getWidth(context) { - return this.nativeChannel(context, 'getWidth')(); - } - getHeight(context) { - return this.nativeChannel(context, 'getHeight')(); - } - /**----------transform----------*/ - doAnimation(context, animation) { - return this.nativeChannel(context, "doAnimation")(animation.toModel()).then((args) => { - for (let key in args) { - Reflect.set(this, key, Reflect.get(args, key, args), this); - Reflect.deleteProperty(this.__dirty_props__, key); - } - }); - } -} -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "width", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "height", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "x", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "y", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "backgroundColor", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "corners", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "border", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "shadow", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "alpha", void 0); -__decorate([ - Property, - __metadata("design:type", Boolean) -], View.prototype, "hidden", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "viewId", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "padding", void 0); -__decorate([ - Property, - __metadata("design:type", Object) -], View.prototype, "layoutConfig", void 0); -__decorate([ - Property, - __metadata("design:type", Function) -], View.prototype, "onClick", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "translationX", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "translationY", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "scaleX", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "scaleY", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "pivotX", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "pivotY", void 0); -__decorate([ - Property, - __metadata("design:type", Number) -], View.prototype, "rotation", void 0); -class Superview extends View { - subviewById(id) { - for (let v of this.allSubviews()) { - if (v.viewId === id) { - return v; - } - } - } - isDirty() { - if (super.isDirty()) { - return true; - } - else { - for (const v of this.allSubviews()) { - if (v.isDirty()) { - return true; - } - } - } - return false; - } - clean() { - for (let v of this.allSubviews()) { - v.clean(); - } - super.clean(); - } - toModel() { - const subviews = []; - for (let v of this.allSubviews()) { - v.superview = this; - if (v.isDirty()) { - subviews.push(v.toModel()); - } - } - this.dirtyProps.subviews = subviews; - return super.toModel(); - } -} -class Group extends Superview { - constructor() { - super(...arguments); - this.children = new Proxy([], { - set: (target, index, value) => { - const ret = Reflect.set(target, index, value); - // Let getDirty return true - this.dirtyProps.children = this.children.map(e => e.viewId); - return ret; - } - }); - } - allSubviews() { - return this.children; - } - addChild(view) { - this.children.push(view); - } -} - -const SPECIFIED = 1; -const START = 1 << 1; -const END = 1 << 2; -const SHIFT_X = 0; -const SHIFT_Y = 4; -const LEFT = (START | SPECIFIED) << SHIFT_X; -const RIGHT = (END | SPECIFIED) << SHIFT_X; -const TOP = (START | SPECIFIED) << SHIFT_Y; -const BOTTOM = (END | SPECIFIED) << SHIFT_Y; -const CENTER_X = SPECIFIED << SHIFT_X; -const CENTER_Y = SPECIFIED << SHIFT_Y; -const CENTER = CENTER_X | CENTER_Y; -class Gravity { - constructor() { - this.val = 0; - } - left() { - const val = this.val | LEFT; - const ret = new Gravity; - ret.val = val; - return ret; - } - right() { - const val = this.val | RIGHT; - const ret = new Gravity; - ret.val = val; - return ret; - } - top() { - const val = this.val | TOP; - const ret = new Gravity; - ret.val = val; - return ret; - } - bottom() { - const val = this.val | BOTTOM; - const ret = new Gravity; - ret.val = val; - return ret; - } - center() { - const val = this.val | CENTER; - const ret = new Gravity; - ret.val = val; - return ret; - } - centerX() { - const val = this.val | CENTER_X; - const ret = new Gravity; - ret.val = val; - return ret; - } - centerY() { - const val = this.val | CENTER_Y; - const ret = new Gravity; - ret.val = val; - return ret; - } - toModel() { - return this.val; - } -} -Gravity.origin = new Gravity; -Gravity.Center = Gravity.origin.center(); -Gravity.Left = Gravity.origin.left(); -Gravity.Right = Gravity.origin.right(); -Gravity.Top = Gravity.origin.top(); -Gravity.Bottom = Gravity.origin.bottom(); -function gravity() { - return new Gravity; -} - -(function (LayoutSpec) { - LayoutSpec[LayoutSpec["EXACTLY"] = 0] = "EXACTLY"; - LayoutSpec[LayoutSpec["WRAP_CONTENT"] = 1] = "WRAP_CONTENT"; - LayoutSpec[LayoutSpec["AT_MOST"] = 2] = "AT_MOST"; -})(exports.LayoutSpec || (exports.LayoutSpec = {})); -class LayoutConfigImpl { - wrap() { - this.widthSpec = exports.LayoutSpec.WRAP_CONTENT; - this.heightSpec = exports.LayoutSpec.WRAP_CONTENT; - return this; - } - atmost() { - this.widthSpec = exports.LayoutSpec.AT_MOST; - this.heightSpec = exports.LayoutSpec.AT_MOST; - return this; - } - exactly() { - this.widthSpec = exports.LayoutSpec.EXACTLY; - this.heightSpec = exports.LayoutSpec.EXACTLY; - return this; - } - w(w) { - this.widthSpec = w; - return this; - } - h(h) { - this.heightSpec = h; - return this; - } - m(m) { - this.margin = m; - return this; - } - a(a) { - this.alignment = a; - return this; - } - wg(w) { - this.weight = w; - return this; - } - toModel() { - return { - widthSpec: this.widthSpec, - heightSpec: this.heightSpec, - margin: this.margin, - alignment: this.alignment ? this.alignment.toModel() : undefined, - weight: this.weight, - }; - } -} -function layoutConfig() { - return new LayoutConfigImpl; -} - -var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$1 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class Stack extends Group { -} -class Root extends Stack { -} -class LinearLayout extends Group { -} -__decorate$1([ - Property, - __metadata$1("design:type", Number) -], LinearLayout.prototype, "space", void 0); -__decorate$1([ - Property, - __metadata$1("design:type", Gravity) -], LinearLayout.prototype, "gravity", void 0); -class VLayout extends LinearLayout { -} -class HLayout extends LinearLayout { -} -function stack(views) { - const ret = new Stack; - ret.layoutConfig = layoutConfig().wrap(); - for (let v of views) { - ret.addChild(v); - } - return ret; -} -function hlayout(views) { - const ret = new HLayout; - ret.layoutConfig = layoutConfig().wrap(); - for (let v of views) { - ret.addChild(v); - } - return ret; -} -function vlayout(views) { - const ret = new VLayout; - ret.layoutConfig = layoutConfig().wrap(); - for (let v of views) { - ret.addChild(v); - } - return ret; -} - -var __decorate$2 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$2 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -function NativeCall(target, propertyKey, descriptor) { - const originVal = descriptor.value; - descriptor.value = function () { - const ret = Reflect.apply(originVal, this, arguments); - return ret; - }; - return descriptor; -} -class Panel { - constructor() { - this.__root__ = new Root; - this.headviews = new Map; - } - onCreate() { } - onDestroy() { } - onShow() { } - onHidden() { } - addHeadView(v) { - this.headviews.set(v.viewId, v); - } - allHeadViews() { - return this.headviews.values(); - } - removeHeadView(v) { - if (v instanceof View) { - this.headviews.delete(v.viewId); - } - else { - this.headviews.delete(v); - } - } - clearHeadViews() { - this.headviews.clear(); - } - getRootView() { - return this.__root__; - } - getInitData() { - return this.__data__; - } - __init__(frame, data) { - this.__data__ = data; - this.__root__.width = frame.width; - this.__root__.height = frame.height; - this.__root__.children.length = 0; - this.build(this.__root__); - } - __onCreate__() { - this.onCreate(); - } - __onDestroy__() { - this.onDestroy(); - } - __onShow__() { - this.onShow(); - } - __onHidden__() { - this.onHidden(); - } - __build__() { - this.build(this.__root__); - } - __response__(viewIds, callbackId) { - const v = this.retrospectView(viewIds); - if (v === undefined) { - loge(`Cannot find view for ${viewIds}`); - } - else { - const argumentsList = [callbackId]; - for (let i = 2; i < arguments.length; i++) { - argumentsList.push(arguments[i]); - } - return Reflect.apply(v.responseCallback, v, argumentsList); - } - } - retrospectView(ids) { - return ids.reduce((acc, cur) => { - if (acc === undefined) { - if (cur === this.__root__.viewId) { - return this.__root__; - } - return this.headviews.get(cur); - } - else { - if (Reflect.has(acc, "subviewById")) { - return Reflect.apply(Reflect.get(acc, "subviewById"), acc, [cur]); - } - return acc; - } - }, undefined); - } - nativeRender(model) { - if (this.context) { - this.context.shader.render(model); - } - } - hookBeforeNativeCall() { - this.__root__.clean(); - for (let v of this.headviews.values()) { - v.clean(); - } - } - hookAfterNativeCall() { - //Here insert a native call to ensure the promise is resolved done. - nativeEmpty(); - if (this.__root__.isDirty()) { - const model = this.__root__.toModel(); - this.nativeRender(model); - } - for (let v of this.headviews.values()) { - if (v.isDirty()) { - const model = v.toModel(); - this.nativeRender(model); - } - } - } -} -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", [Object, Object]), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__init__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onCreate__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onDestroy__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onShow__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__onHidden__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", []), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__build__", null); -__decorate$2([ - NativeCall, - __metadata$2("design:type", Function), - __metadata$2("design:paramtypes", [Array, String]), - __metadata$2("design:returntype", void 0) -], Panel.prototype, "__response__", null); - -(function (RepeatMode) { - RepeatMode[RepeatMode["RESTART"] = 1] = "RESTART"; - RepeatMode[RepeatMode["REVERSE"] = 2] = "REVERSE"; -})(exports.RepeatMode || (exports.RepeatMode = {})); -(function (FillMode) { - /** - * The receiver is removed from the presentation when the animation is completed. - */ - FillMode[FillMode["Removed"] = 0] = "Removed"; - /** - * The receiver remains visible in its final state when the animation is completed. - */ - FillMode[FillMode["Forward"] = 1] = "Forward"; - /** - * The receiver clamps values before zero to zero when the animation is completed. - */ - FillMode[FillMode["Backward"] = 2] = "Backward"; - /** - * The receiver clamps values at both ends of the object’s time space - */ - FillMode[FillMode["Both"] = 3] = "Both"; -})(exports.FillMode || (exports.FillMode = {})); -(function (TimingFunction) { - /** - * The system default timing function. Use this function to ensure that the timing of your animations matches that of most system animations. - */ - TimingFunction[TimingFunction["Default"] = 0] = "Default"; - /** - * Linear pacing, which causes an animation to occur evenly over its duration. - */ - TimingFunction[TimingFunction["Linear"] = 1] = "Linear"; - /** - * Ease-in pacing, which causes an animation to begin slowly and then speed up as it progresses. - */ - TimingFunction[TimingFunction["EaseIn"] = 2] = "EaseIn"; - /** - * Ease-out pacing, which causes an animation to begin quickly and then slow as it progresses. - */ - TimingFunction[TimingFunction["EaseOut"] = 3] = "EaseOut"; - /** - * Ease-in-ease-out pacing, which causes an animation to begin slowly, accelerate through the middle of its duration, and then slow again before completing. - */ - TimingFunction[TimingFunction["EaseInEaseOut"] = 4] = "EaseInEaseOut"; -})(exports.TimingFunction || (exports.TimingFunction = {})); -class Animation { - constructor() { - this.changeables = new Map; - this.duration = 0; - this.fillMode = exports.FillMode.Forward; - } - toModel() { - const changeables = []; - for (let e of this.changeables.values()) { - changeables.push({ - key: e.key, - fromValue: e.fromValue, - toValue: e.toValue, - }); - } - return { - type: this.constructor.name, - delay: this.delay, - duration: this.duration, - changeables, - repeatCount: this.repeatCount, - repeatMode: this.repeatMode, - fillMode: this.fillMode, - timingFunction: this.timingFunction - }; - } -} -class ScaleAnimation extends Animation { - constructor() { - super(); - this.scaleXChangeable = { - key: "scaleX", - fromValue: 1, - toValue: 1, - }; - this.scaleYChangeable = { - key: "scaleY", - fromValue: 1, - toValue: 1, - }; - this.changeables.set("scaleX", this.scaleXChangeable); - this.changeables.set("scaleY", this.scaleYChangeable); - } - set fromScaleX(v) { - this.scaleXChangeable.fromValue = v; - } - get fromScaleX() { - return this.scaleXChangeable.fromValue; - } - set toScaleX(v) { - this.scaleXChangeable.toValue = v; - } - get toScaleX() { - return this.scaleXChangeable.toValue; - } - set fromScaleY(v) { - this.scaleYChangeable.fromValue = v; - } - get fromScaleY() { - return this.scaleYChangeable.fromValue; - } - set toScaleY(v) { - this.scaleYChangeable.toValue = v; - } - get toScaleY() { - return this.scaleYChangeable.toValue; - } -} -class TranslationAnimation extends Animation { - constructor() { - super(); - this.translationXChangeable = { - key: "translationX", - fromValue: 1, - toValue: 1, - }; - this.translationYChangeable = { - key: "translationY", - fromValue: 1, - toValue: 1, - }; - this.changeables.set("translationX", this.translationXChangeable); - this.changeables.set("translationY", this.translationYChangeable); - } - set fromTranslationX(v) { - this.translationXChangeable.fromValue = v; - } - get fromTranslationX() { - return this.translationXChangeable.fromValue; - } - set toTranslationX(v) { - this.translationXChangeable.toValue = v; - } - get toTranslationX() { - return this.translationXChangeable.toValue; - } - set fromTranslationY(v) { - this.translationYChangeable.fromValue = v; - } - get fromTranslationY() { - return this.translationYChangeable.fromValue; - } - set toTranslationY(v) { - this.translationYChangeable.toValue = v; - } - get toTranslationY() { - return this.translationYChangeable.toValue; - } -} -class RotationAnimation extends Animation { - constructor() { - super(); - this.rotationChaneable = { - key: "rotation", - fromValue: 1, - toValue: 1, - }; - this.changeables.set("rotation", this.rotationChaneable); - } - set fromRotation(v) { - this.rotationChaneable.fromValue = v; - } - get fromRotation() { - return this.rotationChaneable.fromValue; - } - set toRotation(v) { - this.rotationChaneable.toValue = v; - } - get toRotation() { - return this.rotationChaneable.toValue; - } -} -class AnimationSet { - constructor() { - this.animations = []; - this._duration = 0; - } - addAnimation(anim) { - this.animations.push(anim); - } - get duration() { - return this._duration; - } - set duration(v) { - this._duration = v; - this.animations.forEach(e => e.duration = v); - } - toModel() { - return { - animations: this.animations.map(e => { - return e.toModel(); - }), - delay: this.delay, - }; - } -} - -/** - * Store color as format AARRGGBB or RRGGBB - */ -class Color { - constructor(v) { - this._value = 0; - this._value = v | 0x0; - } - static parse(str) { - if (!str.startsWith("#")) { - throw new Error(`Parse color error with ${str}`); - } - const val = parseInt(str.substr(1), 16); - if (str.length === 7) { - return new Color(val | 0xff000000); - } - else if (str.length === 9) { - return new Color(val); - } - else { - throw new Error(`Parse color error with ${str}`); - } - } - static safeParse(str, defVal = Color.TRANSPARENT) { - let color = defVal; - try { - color = Color.parse(str); - } - catch (e) { - } - finally { - return color; - } - } - alpha(v) { - return new Color((this._value & 0xffffff) | ((v & 0xff) << 24)); - } - toModel() { - return this._value; - } -} -Color.BLACK = new Color(0xFF000000); -Color.DKGRAY = new Color(0xFF444444); -Color.GRAY = new Color(0xFF888888); -Color.LTGRAY = new Color(0xFFCCCCCC); -Color.WHITE = new Color(0xFFFFFFFF); -Color.RED = new Color(0xFFFF0000); -Color.GREEN = new Color(0xFF00FF00); -Color.BLUE = new Color(0xFF0000FF); -Color.YELLOW = new Color(0xFFFFFF00); -Color.CYAN = new Color(0xFF00FFFF); -Color.MAGENTA = new Color(0xFFFF00FF); -Color.TRANSPARENT = new Color(0); -(function (GradientOrientation) { - /** draw the gradient from the top to the bottom */ - GradientOrientation[GradientOrientation["TOP_BOTTOM"] = 0] = "TOP_BOTTOM"; - /** draw the gradient from the top-right to the bottom-left */ - GradientOrientation[GradientOrientation["TR_BL"] = 1] = "TR_BL"; - /** draw the gradient from the right to the left */ - GradientOrientation[GradientOrientation["RIGHT_LEFT"] = 2] = "RIGHT_LEFT"; - /** draw the gradient from the bottom-right to the top-left */ - GradientOrientation[GradientOrientation["BR_TL"] = 3] = "BR_TL"; - /** draw the gradient from the bottom to the top */ - GradientOrientation[GradientOrientation["BOTTOM_TOP"] = 4] = "BOTTOM_TOP"; - /** draw the gradient from the bottom-left to the top-right */ - GradientOrientation[GradientOrientation["BL_TR"] = 5] = "BL_TR"; - /** draw the gradient from the left to the right */ - GradientOrientation[GradientOrientation["LEFT_RIGHT"] = 6] = "LEFT_RIGHT"; - /** draw the gradient from the top-left to the bottom-right */ - GradientOrientation[GradientOrientation["TL_BR"] = 7] = "TL_BR"; -})(exports.GradientOrientation || (exports.GradientOrientation = {})); - -var __decorate$3 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$3 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class Text extends View { -} -__decorate$3([ - Property, - __metadata$3("design:type", String) -], Text.prototype, "text", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Color) -], Text.prototype, "textColor", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Number) -], Text.prototype, "textSize", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Number) -], Text.prototype, "maxLines", void 0); -__decorate$3([ - Property, - __metadata$3("design:type", Gravity) -], Text.prototype, "textAlignment", void 0); -function text(config) { - const ret = new Text; - ret.layoutConfig = layoutConfig().wrap(); - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} - -var __decorate$4 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$4 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -(function (ScaleType) { - ScaleType[ScaleType["ScaleToFill"] = 0] = "ScaleToFill"; - ScaleType[ScaleType["ScaleAspectFit"] = 1] = "ScaleAspectFit"; - ScaleType[ScaleType["ScaleAspectFill"] = 2] = "ScaleAspectFill"; -})(exports.ScaleType || (exports.ScaleType = {})); -class Image extends View { -} -__decorate$4([ - Property, - __metadata$4("design:type", String) -], Image.prototype, "imageUrl", void 0); -__decorate$4([ - Property, - __metadata$4("design:type", String) -], Image.prototype, "imageBase64", void 0); -__decorate$4([ - Property, - __metadata$4("design:type", Number) -], Image.prototype, "scaleType", void 0); -__decorate$4([ - Property, - __metadata$4("design:type", Function) -], Image.prototype, "loadCallback", void 0); -function image(config) { - const ret = new Image; - ret.layoutConfig = layoutConfig().wrap(); - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var __decorate$5 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$5 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class ListItem extends Stack { -} -__decorate$5([ - Property, - __metadata$5("design:type", String) -], ListItem.prototype, "identifier", void 0); -class List extends Superview { - constructor() { - super(...arguments); - this.cachedViews = new Map; - this.ignoreDirtyCallOnce = false; - this.itemCount = 0; - this.batchCount = 15; - } - allSubviews() { - return this.cachedViews.values(); - } - reset() { - this.cachedViews.clear(); - this.itemCount = 0; - } - getItem(itemIdx) { - let view = this.cachedViews.get(`${itemIdx}`); - if (view === undefined) { - view = this.renderItem(itemIdx); - view.superview = this; - this.cachedViews.set(`${itemIdx}`, view); - } - return view; - } - isDirty() { - if (this.ignoreDirtyCallOnce) { - this.ignoreDirtyCallOnce = false; - //Ignore the dirty call once. - return false; - } - return super.isDirty(); - } - renderBunchedItems(start, length) { - this.ignoreDirtyCallOnce = true; - return new Array(Math.min(length, this.itemCount - start)).fill(0).map((_, idx) => { - const listItem = this.getItem(start + idx); - return listItem.toModel(); - }); - } -} -__decorate$5([ - Property, - __metadata$5("design:type", Object) -], List.prototype, "itemCount", void 0); -__decorate$5([ - Property, - __metadata$5("design:type", Function) -], List.prototype, "renderItem", void 0); -__decorate$5([ - Property, - __metadata$5("design:type", Object) -], List.prototype, "batchCount", void 0); -function list(config) { - const ret = new List; - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} -function listItem(item) { - return (new ListItem).also((it) => { - it.layoutConfig = layoutConfig().wrap(); - it.addChild(item); - }); -} - -var __decorate$6 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$6 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class SlideItem extends Stack { -} -__decorate$6([ - Property, - __metadata$6("design:type", String) -], SlideItem.prototype, "identifier", void 0); -class Slider extends Superview { - constructor() { - super(...arguments); - this.cachedViews = new Map; - this.ignoreDirtyCallOnce = false; - this.itemCount = 0; - this.batchCount = 3; - } - allSubviews() { - return this.cachedViews.values(); - } - getItem(itemIdx) { - let view = this.cachedViews.get(`${itemIdx}`); - if (view === undefined) { - view = this.renderPage(itemIdx); - view.superview = this; - this.cachedViews.set(`${itemIdx}`, view); - } - return view; - } - isDirty() { - if (this.ignoreDirtyCallOnce) { - this.ignoreDirtyCallOnce = false; - //Ignore the dirty call once. - return false; - } - return super.isDirty(); - } - renderBunchedItems(start, length) { - this.ignoreDirtyCallOnce = true; - return new Array(Math.min(length, this.itemCount - start)).fill(0).map((_, idx) => { - const slideItem = this.getItem(start + idx); - return slideItem.toModel(); - }); - } -} -__decorate$6([ - Property, - __metadata$6("design:type", Object) -], Slider.prototype, "itemCount", void 0); -__decorate$6([ - Property, - __metadata$6("design:type", Function) -], Slider.prototype, "renderPage", void 0); -__decorate$6([ - Property, - __metadata$6("design:type", Object) -], Slider.prototype, "batchCount", void 0); -function slideItem(item) { - return (new SlideItem).also((it) => { - it.layoutConfig = layoutConfig().wrap(); - it.addChild(item); - }); -} -function slider(config) { - const ret = new Slider; - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function scroller(content) { - return (new Scroller).also(v => { - v.layoutConfig = layoutConfig().wrap(); - v.content = content; - }); -} -class Scroller extends Superview { - allSubviews() { - return [this.content]; - } - toModel() { - this.dirtyProps.content = this.content.viewId; - return super.toModel(); - } -} - -var __decorate$7 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$7 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class Refreshable extends Superview { - allSubviews() { - const ret = [this.content]; - if (this.header) { - ret.push(this.header); - } - return ret; - } - setRefreshable(context, refreshable) { - return this.nativeChannel(context, 'setRefreshable')(refreshable); - } - setRefreshing(context, refreshing) { - return this.nativeChannel(context, 'setRefreshing')(refreshing); - } - isRefreshable(context) { - return this.nativeChannel(context, 'isRefreshable')(); - } - isRefreshing(context) { - return this.nativeChannel(context, 'isRefreshing')(); - } - toModel() { - this.dirtyProps.content = this.content.viewId; - this.dirtyProps.header = (this.header || {}).viewId; - return super.toModel(); - } -} -__decorate$7([ - Property, - __metadata$7("design:type", Function) -], Refreshable.prototype, "onRefresh", void 0); -function refreshable(config) { - const ret = new Refreshable; - ret.layoutConfig = layoutConfig().wrap(); - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} -function pullable(v, config) { - Reflect.set(v, 'startAnimation', config.startAnimation); - Reflect.set(v, 'stopAnimation', config.stopAnimation); - Reflect.set(v, 'setPullingDistance', config.setPullingDistance); - return v; -} - -var __decorate$8 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -}; -var __metadata$8 = (undefined && undefined.__metadata) || function (k, v) { - if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); -}; -class FlowLayoutItem extends Stack { -} -__decorate$8([ - Property, - __metadata$8("design:type", String) -], FlowLayoutItem.prototype, "identifier", void 0); -class FlowLayout extends Superview { - constructor() { - super(...arguments); - this.cachedViews = new Map; - this.ignoreDirtyCallOnce = false; - this.columnCount = 2; - this.itemCount = 0; - this.batchCount = 15; - } - allSubviews() { - return this.cachedViews.values(); - } - reset() { - this.cachedViews.clear(); - this.itemCount = 0; - } - getItem(itemIdx) { - let view = this.cachedViews.get(`${itemIdx}`); - if (view === undefined) { - view = this.renderItem(itemIdx); - view.superview = this; - this.cachedViews.set(`${itemIdx}`, view); - } - return view; - } - isDirty() { - if (this.ignoreDirtyCallOnce) { - this.ignoreDirtyCallOnce = false; - //Ignore the dirty call once. - return false; - } - return super.isDirty(); - } - renderBunchedItems(start, length) { - this.ignoreDirtyCallOnce = true; - return new Array(Math.min(length, this.itemCount - start)).fill(0).map((_, idx) => { - const listItem = this.getItem(start + idx); - return listItem.toModel(); - }); - } -} -__decorate$8([ - Property, - __metadata$8("design:type", Object) -], FlowLayout.prototype, "columnCount", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Number) -], FlowLayout.prototype, "columnSpace", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Number) -], FlowLayout.prototype, "rowSpace", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Object) -], FlowLayout.prototype, "itemCount", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Function) -], FlowLayout.prototype, "renderItem", void 0); -__decorate$8([ - Property, - __metadata$8("design:type", Object) -], FlowLayout.prototype, "batchCount", void 0); -function flowlayout(config) { - const ret = new FlowLayout; - for (let key in config) { - Reflect.set(ret, key, Reflect.get(config, key, config), ret); - } - return ret; -} -function flowItem(item) { - return (new FlowLayoutItem).also((it) => { - it.layoutConfig = layoutConfig().wrap(); - it.addChild(item); - }); -} - -function modal(context) { - return { - toast: (msg, gravity = Gravity.Bottom) => { - context.modal.toast({ - msg, - gravity: gravity.toModel(), - }); - }, - alert: (arg) => { - if (typeof arg === 'string') { - return context.modal.alert({ msg: arg }); - } - else { - return context.modal.alert(arg); - } - }, - confirm: (arg) => { - if (typeof arg === 'string') { - return context.modal.confirm({ msg: arg }); - } - else { - return context.modal.confirm(arg); - } - }, - prompt: (arg) => { - return context.modal.prompt(arg); - }, - }; -} - -function navbar(context) { - const entity = context.entity; - return { - isHidden: () => { - return context.navbar.isHidden(); - }, - setHidden: (hidden) => { - return context.navbar.setHidden({ - hidden, - }); - }, - setTitle: (title) => { - return context.navbar.setTitle({ - title, - }); - }, - setBgColor: (color) => { - return context.navbar.setBgColor({ - color: color.toModel(), - }); - }, - }; -} - -function navigator(context) { - return { - push: (scheme, alias, animated = true) => { - return context.navigator.push({ - scheme, alias, animated - }); - }, - pop: (animated = true) => { - return context.navigator.pop({ animated }); - }, - }; -} - -function transformRequest(request) { - let url = request.url || ""; - if (request.params !== undefined) { - const queryStrings = []; - for (let key in request.params) { - queryStrings.push(`${key}=${encodeURIComponent(request.params[key])}`); - } - request.url = `${request.url}${url.indexOf('?') >= 0 ? '&' : '?'}${queryStrings.join('&')}`; - } - if (typeof request.data === 'object') { - request.data = JSON.stringify(request.data); - } - return request; -} -function network(context) { - return { - request: (config) => { - return context.network.request(transformRequest(config)); - }, - get: (url, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "get"; - return context.network.request(transformRequest(finalConfig)); - }, - post: (url, data, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "post"; - if (data !== undefined) { - finalConfig.data = data; - } - return context.network.request(transformRequest(finalConfig)); - }, - put: (url, data, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "put"; - if (data !== undefined) { - finalConfig.data = data; - } - return context.network.request(transformRequest(finalConfig)); - }, - delete: (url, data, config) => { - let finalConfig = config; - if (finalConfig === undefined) { - finalConfig = {}; - } - finalConfig.url = url; - finalConfig.method = "delete"; - return context.network.request(transformRequest(finalConfig)); - }, - }; -} - -function storage(context) { - return { - setItem: (key, value, zone) => { - return context.storage.setItem({ key, value, zone }); - }, - getItem: (key, zone) => { - return context.storage.getItem({ key, zone }); - }, - remove: (key, zone) => { - return context.storage.remove({ key, zone }); - }, - clear: (zone) => { - return context.storage.clear({ zone }); - }, - }; -} - -function popover(context) { - const entity = context.entity; - let panel = undefined; - if (entity instanceof Panel) { - panel = entity; - } - return { - show: (view) => { - if (panel) { - panel.addHeadView(view); - } - return context.popover.show(view.toModel()); - }, - dismiss: (view = undefined) => { - if (panel) { - if (view) { - panel.removeHeadView(view); - } - else { - panel.clearHeadViews(); - } - } - return context.popover.dismiss(view ? { id: view.viewId } : undefined); - }, - }; -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function take(target) { - return (block) => { - block(target); - }; -} -function takeNonNull(target) { - return (block) => { - if (target !== undefined) { - return block(target); - } - }; -} -function takeNull(target) { - return (block) => { - if (target === undefined) { - return block(); - } - }; -} -function takeLet(target) { - return (block) => { - return block(target); - }; -} -function takeAlso(target) { - return (block) => { - block(target); - return target; - }; -} -function takeIf(target) { - return (predicate) => { - return predicate(target) ? target : undefined; - }; -} -function takeUnless(target) { - return (predicate) => { - return predicate(target) ? undefined : target; - }; -} -function repeat(action) { - return (times) => { - for (let i = 0; i < times; i++) { - action(i); - } - }; -} - -/** - * Only supports x,y,width,height,corner(just for four corners),rotation,bgColor, - * @param panel @see Panel - */ -function animate(panel) { - return (args) => { - return takeLet(panel.context.animate)(it => { - return it.submit().then(() => { - args.animations(); - return takeLet(panel.getRootView())(root => { - if (root.isDirty()) { - const model = root.toModel(); - model.duration = args.duration; - const ret = it.animateRender(model); - root.clean(); - return ret; - } - for (let v of panel.allHeadViews()) { - if (v.isDirty()) { - const model = v.toModel(); - const ret = it.animateRender(model); - it.clean(); - return ret; - } - } - throw new Error('Cannot find any animated elements'); - }); - }); - }); - }; -} - -class Observable { - constructor(provider, clz) { - this.observers = new Set; - this.provider = provider; - this.clz = clz; - } - addObserver(observer) { - this.observers.add(observer); - } - removeObserver(observer) { - this.observers.delete(observer); - } - update(updater) { - const oldV = this.provider.acquire(this.clz); - const newV = updater(oldV); - if (newV !== undefined) { - this.provider.provide(newV); - } - for (let observer of this.observers) { - observer(newV); - } - } -} -class Provider { - constructor() { - this.provision = new Map; - this.observableMap = new Map; - } - provide(obj) { - this.provision.set(obj.constructor, obj); - } - acquire(clz) { - const ret = this.provision.get(clz); - return ret; - } - remove(clz) { - this.provision.delete(clz); - } - clear() { - this.provision.clear(); - } - observe(clz) { - let observable = this.observableMap.get(clz); - if (observable === undefined) { - observable = new Observable(this, clz); - this.observableMap.set(clz, observable); - } - return observable; - } -} - -class ViewHolder { -} -class ViewModel { - constructor(obj, v) { - this.state = obj; - this.viewHolder = v; - } - getState() { - return this.state; - } - updateState(setter) { - setter(this.state); - this.viewHolder.bind(this.state); - } - attach(view) { - this.viewHolder.build(view); - this.viewHolder.bind(this.state); - this.onAttached(this.state, this.viewHolder); - } -} -class VMPanel extends Panel { - getViewModel() { - return this.vm; - } - build(root) { - this.vh = new (this.getViewHolderClass()); - this.vm = new (this.getViewModelClass())(this.getState(), this.vh); - this.vm.attach(root); - } -} - -/* - * Copyright [2019] [Doric.Pub] - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -const WebSocketClient = require('ws'); -const fs = require('fs'); -let context = process.cwd() + '/build/context'; -const contextId = fs.readFileSync(context, { encoding: 'utf8' }); -console.log(contextId); -let global$2 = new Function('return this')(); -global$2.doric = doric; -global$2.context = jsObtainContext(contextId); -global$2.Entry = jsObtainEntry(contextId); -// dev kit client -const devClient = new WebSocketClient('ws://localhost:7777'); -devClient.on('open', function open() { - console.log('dev kit connected on 7777'); -}); -devClient.on('message', function incoming(data) { - console.log(data); -}); -devClient.on('error', function incoming(error) { - console.log(error); -}); -// debug server -const debugServer = new WebSocket.Server({ port: 2080 }); -debugServer.on('connection', function connection(ws) { - console.log('connected'); - ws.on('message', function incoming(message) { - let messageObject = JSON.parse(message); - switch (messageObject.cmd) { - case "injectGlobalJSFunction": - console.log(messageObject.name); - Reflect.set(global$2, messageObject.name, function () { - let args = [].slice.call(arguments); - console.log("==============================="); - console.log(args); - console.log("==============================="); - ws.send(JSON.stringify({ - cmd: 'injectGlobalJSFunction', - name: messageObject.name, - arguments: args - })); - }); - break; - case "invokeMethod": - console.log(messageObject.objectName); - console.log(messageObject.functionName); - let args = []; - for (let i = 0; i < messageObject.javaValues.length; i++) { - let javaValue = messageObject.javaValues[i]; - if (javaValue.type === 0) { - args.push(null); - } - else if (javaValue.type === 1) { - args.push(parseFloat(javaValue.value)); - } - else if (javaValue.type === 2) { - args.push((javaValue.value == 'true')); - } - else if (javaValue.type === 3) { - args.push(javaValue.value.toString()); - } - else if (javaValue.type === 4) { - args.push(JSON.parse(javaValue.value)); - } - else if (javaValue.type === 5) { - args.push(JSON.parse(javaValue.value)); - } - } - console.log(args); - console.log(messageObject.hashKey); - let object = Reflect.get(global$2, messageObject.objectName); - let method = Reflect.get(object, messageObject.functionName); - let result = Reflect.apply(method, undefined, args); - console.log(result); - ws.send(JSON.stringify({ - cmd: 'invokeMethod', - result: result - })); - break; - } - }); -}); -debugServer.on('listening', function connection(ws) { - console.log('debugger server started on 2080'); -}); -global$2.injectGlobal = (objName, obj) => { - Reflect.set(global$2, objName, JSON.parse(obj)); -}; -global$2.sendToNative = () => { -}; -global$2.receiveFromNative = () => { -}; - -exports.AnimationSet = AnimationSet; -exports.BOTTOM = BOTTOM; -exports.CENTER = CENTER; -exports.CENTER_X = CENTER_X; -exports.CENTER_Y = CENTER_Y; -exports.Color = Color; -exports.FlowLayout = FlowLayout; -exports.FlowLayoutItem = FlowLayoutItem; -exports.Gravity = Gravity; -exports.Group = Group; -exports.HLayout = HLayout; -exports.Image = Image; -exports.LEFT = LEFT; -exports.LayoutConfigImpl = LayoutConfigImpl; -exports.List = List; -exports.ListItem = ListItem; -exports.Mutable = Mutable; -exports.NativeCall = NativeCall; -exports.Observable = Observable; -exports.Panel = Panel; -exports.Property = Property; -exports.Provider = Provider; -exports.RIGHT = RIGHT; -exports.Refreshable = Refreshable; -exports.Root = Root; -exports.RotationAnimation = RotationAnimation; -exports.ScaleAnimation = ScaleAnimation; -exports.Scroller = Scroller; -exports.SlideItem = SlideItem; -exports.Slider = Slider; -exports.Stack = Stack; -exports.Superview = Superview; -exports.TOP = TOP; -exports.Text = Text; -exports.TranslationAnimation = TranslationAnimation; -exports.VLayout = VLayout; -exports.VMPanel = VMPanel; -exports.View = View; -exports.ViewHolder = ViewHolder; -exports.ViewModel = ViewModel; -exports.animate = animate; -exports.flowItem = flowItem; -exports.flowlayout = flowlayout; -exports.gravity = gravity; -exports.hlayout = hlayout; -exports.image = image; -exports.layoutConfig = layoutConfig; -exports.list = list; -exports.listItem = listItem; -exports.log = log; -exports.loge = loge; -exports.logw = logw; -exports.modal = modal; -exports.navbar = navbar; -exports.navigator = navigator; -exports.network = network; -exports.obj2Model = obj2Model; -exports.popover = popover; -exports.pullable = pullable; -exports.refreshable = refreshable; -exports.repeat = repeat; -exports.scroller = scroller; -exports.slideItem = slideItem; -exports.slider = slider; -exports.stack = stack; -exports.storage = storage; -exports.take = take; -exports.takeAlso = takeAlso; -exports.takeIf = takeIf; -exports.takeLet = takeLet; -exports.takeNonNull = takeNonNull; -exports.takeNull = takeNull; -exports.takeUnless = takeUnless; -exports.text = text; -exports.uniqueId = uniqueId; -exports.vlayout = vlayout;