From fbeb910c1ab843bd842e7c3f82fdbf6a7bcaa334 Mon Sep 17 00:00:00 2001 From: pengfeizhou Date: Wed, 4 Dec 2019 13:46:09 +0800 Subject: [PATCH 01/35] Add Readme --- README.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 00000000..c5fb175e --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +# Doric Demos \ No newline at end of file From 8a6ae585bba5d34a166dae1f624b1a32b84e8286 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 4 Dec 2019 14:07:14 +0800 Subject: [PATCH 02/35] add project files from main project --- index.ts | 21 ++ package-lock.json | 268 ++++++++++++++++++++ package.json | 21 ++ rollup.config.js | 23 ++ src/AnimatorDemo.ts | 185 ++++++++++++++ src/ComplicatedAnimations.ts | 202 +++++++++++++++ src/ComplicatedDemo.ts | 49 ++++ src/Counter.ts | 121 +++++++++ src/EffectsDemo.ts | 367 ++++++++++++++++++++++++++++ src/FlowLayoutDemo.ts | 41 ++++ src/ImageDemo.ts | 109 +++++++++ src/LayoutDemo.ts | 460 +++++++++++++++++++++++++++++++++++ src/ListDemo.ts | 114 +++++++++ src/ModalDemo.ts | 150 ++++++++++++ src/NavbarDemo.ts | 84 +++++++ src/NavigatorDemo.ts | 52 ++++ src/NetworkDemo.ts | 34 +++ src/PopoverDemo.ts | 44 ++++ src/RefreshableDemo.ts | 95 ++++++++ src/ScrollerDemo.ts | 34 +++ src/SliderDemo.ts | 58 +++++ src/Snake.ts | 369 ++++++++++++++++++++++++++++ src/StorageDemo.ts | 93 +++++++ src/image_base64.ts | 2 + src/utils.ts | 72 ++++++ tsconfig.json | 61 +++++ 26 files changed, 3129 insertions(+) create mode 100644 index.ts create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 rollup.config.js create mode 100644 src/AnimatorDemo.ts create mode 100644 src/ComplicatedAnimations.ts create mode 100644 src/ComplicatedDemo.ts create mode 100644 src/Counter.ts create mode 100644 src/EffectsDemo.ts create mode 100644 src/FlowLayoutDemo.ts create mode 100644 src/ImageDemo.ts create mode 100644 src/LayoutDemo.ts create mode 100644 src/ListDemo.ts create mode 100644 src/ModalDemo.ts create mode 100644 src/NavbarDemo.ts create mode 100644 src/NavigatorDemo.ts create mode 100644 src/NetworkDemo.ts create mode 100644 src/PopoverDemo.ts create mode 100644 src/RefreshableDemo.ts create mode 100644 src/ScrollerDemo.ts create mode 100644 src/SliderDemo.ts create mode 100644 src/Snake.ts create mode 100644 src/StorageDemo.ts create mode 100644 src/image_base64.ts create mode 100644 src/utils.ts create mode 100644 tsconfig.json diff --git a/index.ts b/index.ts new file mode 100644 index 00000000..bd7e494d --- /dev/null +++ b/index.ts @@ -0,0 +1,21 @@ +export default [ + 'src/Counter', + 'src/Snake', + 'src/ListDemo', + 'src/ScrollerDemo', + 'src/SliderDemo', + 'src/LayoutDemo', + 'src/EffectsDemo', + 'src/ImageDemo', + 'src/ModalDemo', + 'src/NetworkDemo', + 'src/StorageDemo', + 'src/NavigatorDemo', + 'src/NavbarDemo', + 'src/RefreshableDemo', + 'src/FlowLayoutDemo', + 'src/PopoverDemo', + 'src/AnimatorDemo', + 'src/ComplicatedAnimations', + 'src/ComplicatedDemo', +] \ No newline at end of file diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 00000000..ed538db2 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,268 @@ +{ + "name": "demo", + "version": "0.1.0", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@types/estree": { + "version": "0.0.39", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", + "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==" + }, + "@types/node": { + "version": "12.12.7", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.7.tgz", + "integrity": "sha512-E6Zn0rffhgd130zbCbAr/JdXfXkoOUFAKNs/rF8qnafSJ8KYaA/j3oz7dcwal+lYjLA7xvdd5J4wdYpCTlP8+w==" + }, + "@types/resolve": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", + "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", + "requires": { + "@types/node": "*" + } + }, + "acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" + }, + "builtin-modules": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", + "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" + }, + "doric": { + "version": "file:../js-framework", + "requires": { + "@types/ws": "^6.0.3", + "reflect-metadata": "^0.1.13", + "rollup": "^1.27.2", + "rollup-plugin-node-resolve": "^5.2.0", + "tslib": "^1.10.0", + "typescript": "^3.7.2", + "ws": "^7.2.0" + }, + "dependencies": { + "@types/estree": { + "version": "0.0.39", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", + "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==" + }, + "@types/node": { + "version": "12.12.7", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.7.tgz", + "integrity": "sha512-E6Zn0rffhgd130zbCbAr/JdXfXkoOUFAKNs/rF8qnafSJ8KYaA/j3oz7dcwal+lYjLA7xvdd5J4wdYpCTlP8+w==" + }, + "@types/resolve": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", + "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", + "requires": { + "@types/node": "*" + } + }, + "@types/ws": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/@types/ws/-/ws-6.0.3.tgz", + "integrity": "sha512-yBTM0P05Tx9iXGq00BbJPo37ox68R5vaGTXivs6RGh/BQ6QP5zqZDGWdAO6JbRE/iR1l80xeGAwCQS2nMV9S/w==", + "requires": { + "@types/node": "*" + } + }, + "acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" + }, + "builtin-modules": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", + "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" + }, + "estree-walker": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", + "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" + }, + "is-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", + "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + }, + "reflect-metadata": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", + "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" + }, + "resolve": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", + "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "rollup": { + "version": "1.26.5", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.26.5.tgz", + "integrity": "sha512-c6Pv0yWzjYNpy2DIhLFUnyP6e1UTGownr4IfpJcPY/k186RJjpaGGPRwKQ62KCauctG6dgtHt88pw1EGrPRkuA==", + "requires": { + "@types/estree": "*", + "@types/node": "*", + "acorn": "^7.1.0" + } + }, + "rollup-plugin-node-resolve": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", + "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", + "requires": { + "@types/resolve": "0.0.8", + "builtin-modules": "^3.1.0", + "is-module": "^1.0.0", + "resolve": "^1.11.1", + "rollup-pluginutils": "^2.8.1" + } + }, + "rollup-pluginutils": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", + "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", + "requires": { + "estree-walker": "^0.6.1" + } + }, + "tslib": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", + "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" + }, + "typescript": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.2.tgz", + "integrity": "sha512-ml7V7JfiN2Xwvcer+XAf2csGO1bPBdRbFCkYBczNZggrBZ9c7G3riSUeJmqEU5uOtXNPMhE3n+R4FA/3YOAWOQ==" + }, + "ws": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", + "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", + "requires": { + "async-limiter": "^1.0.0" + } + } + } + }, + "estree-walker": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", + "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" + }, + "is-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", + "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" + }, + "is-reference": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-1.1.4.tgz", + "integrity": "sha512-uJA/CDPO3Tao3GTrxYn6AwkM4nUPJiGGYu5+cB8qbC7WGFlrKZbiRo7SFKxUAEpFUfiHofWCXBUNhvYJMh+6zw==", + "requires": { + "@types/estree": "0.0.39" + } + }, + "magic-string": { + "version": "0.25.4", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.4.tgz", + "integrity": "sha512-oycWO9nEVAP2RVPbIoDoA4Y7LFIJ3xRYov93gAyJhZkET1tNuB0u7uWkZS2LpBWTJUWnmau/To8ECWRC+jKNfw==", + "requires": { + "sourcemap-codec": "^1.4.4" + } + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + }, + "reflect-metadata": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", + "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" + }, + "resolve": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", + "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "rollup": { + "version": "1.27.2", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.2.tgz", + "integrity": "sha512-sD3iyd0zlvgK1S3MmICi6F/Y+R/QWY5XxzsTGN4pAd+nCasDUizmAhgq2hdh1t2eLux974NHU2TW41fhuGPv+Q==", + "requires": { + "@types/estree": "*", + "@types/node": "*", + "acorn": "^7.1.0" + } + }, + "rollup-plugin-commonjs": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/rollup-plugin-commonjs/-/rollup-plugin-commonjs-10.1.0.tgz", + "integrity": "sha512-jlXbjZSQg8EIeAAvepNwhJj++qJWNJw1Cl0YnOqKtP5Djx+fFGkp3WRh+W0ASCaFG5w1jhmzDxgu3SJuVxPF4Q==", + "requires": { + "estree-walker": "^0.6.1", + "is-reference": "^1.1.2", + "magic-string": "^0.25.2", + "resolve": "^1.11.0", + "rollup-pluginutils": "^2.8.1" + } + }, + "rollup-plugin-node-resolve": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", + "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", + "requires": { + "@types/resolve": "0.0.8", + "builtin-modules": "^3.1.0", + "is-module": "^1.0.0", + "resolve": "^1.11.1", + "rollup-pluginutils": "^2.8.1" + } + }, + "rollup-pluginutils": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", + "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", + "requires": { + "estree-walker": "^0.6.1" + } + }, + "sourcemap-codec": { + "version": "1.4.6", + "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.6.tgz", + "integrity": "sha512-1ZooVLYFxC448piVLBbtOxFcXwnymH9oUF8nRd3CuYDVvkRBxRl6pB4Mtas5a4drtL+E8LDgFkQNcgIw6tc8Hg==" + }, + "tslib": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", + "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" + }, + "typescript": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.2.tgz", + "integrity": "sha512-ml7V7JfiN2Xwvcer+XAf2csGO1bPBdRbFCkYBczNZggrBZ9c7G3riSUeJmqEU5uOtXNPMhE3n+R4FA/3YOAWOQ==" + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 00000000..7c36fcc3 --- /dev/null +++ b/package.json @@ -0,0 +1,21 @@ +{ + "name": "demo", + "version": "0.1.0", + "main": "index.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1", + "build": "tsc -p .&& rollup -c", + "dev": "tsc -w -p . & rollup -c -w", + "clean": "rm -rf build && rm -rf bundle" + }, + "license": "Apache-2.0", + "dependencies": { + "doric": "file:../js-framework", + "reflect-metadata": "^0.1.13", + "rollup": "^1.27.2", + "rollup-plugin-commonjs": "^10.1.0", + "rollup-plugin-node-resolve": "^5.2.0", + "tslib": "^1.10.0", + "typescript": "^3.7.2" + } +} diff --git a/rollup.config.js b/rollup.config.js new file mode 100644 index 00000000..3e5b5b75 --- /dev/null +++ b/rollup.config.js @@ -0,0 +1,23 @@ +import resolve from 'rollup-plugin-node-resolve' +import commonjs from 'rollup-plugin-commonjs' +import bundles from './build/index' + +export default bundles.map(bundle => { + return { + input: `build/${bundle}.js`, + output: { + format: "cjs", + file: `bundle/${bundle}.js`, + sourcemap: true, + }, + plugins: [ + resolve({ mainFields: ["jsnext"] }), + commonjs() + ], + external: ['reflect-metadata', 'doric'], + onwarn: function (warning) { + if (warning.code === 'THIS_IS_UNDEFINED') { return; } + console.warn(warning.message); + } + } +}) \ No newline at end of file diff --git a/src/AnimatorDemo.ts b/src/AnimatorDemo.ts new file mode 100644 index 00000000..185acd51 --- /dev/null +++ b/src/AnimatorDemo.ts @@ -0,0 +1,185 @@ +import { animate, Group, Panel, gravity, Color, AnimationSet, vlayout, scroller, layoutConfig, IVLayout, modal, IText, network, View, stack, IHLayout, hlayout, IView, text, TranslationAnimation, ScaleAnimation, RotationAnimation, FillMode } from "doric"; +import { title, colors, box } from "./utils"; + +function thisLabel(str: string) { + return text({ + text: str, + width: 60, + height: 50, + backgroundColor: colors[0], + textSize: 15, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + }) +} + +@Entry +class AnimatorDemo extends Panel { + build(rootView: Group): void { + const view = box(2) + view.onClick = () => { + modal(context).toast('Clicked') + } + const view2 = box(3) + let idx = 0 + vlayout([ + title("Animator Demo"), + vlayout( + [ + hlayout([ + thisLabel('Reset').apply({ + onClick: () => { + 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(() => { + modal(context).toast('Fininshed') + }).catch(e => { + modal(context).toast(`${e}`) + }) + } + }), + ]).apply({ space: 10 } as IHLayout), + hlayout([ + thisLabel('X').apply({ + onClick: () => { + animate(this)({ + animations: () => { + view.x = view.x || 0 + view.x += 100 + view2.x += 50 + }, + duration: 1000, + }) + } + }), + thisLabel('Y').apply({ + onClick: () => { + animate(this)({ + animations: () => { + view.y = view.y || 0 + view.y += 100 + view2.y += 50 + }, + duration: 1000, + }) + } + }), + thisLabel('Width').apply({ + onClick: () => { + animate(this)({ + animations: () => { + view.width += 100 + }, + duration: 1000, + }) + } + }), + thisLabel('Height').apply({ + onClick: () => { + animate(this)({ + animations: () => { + view.height += 100 + }, + duration: 1000, + }) + } + }), + ]).apply({ space: 10 } as IHLayout), + hlayout([ + thisLabel('BgColor').apply({ + onClick: () => { + animate(this)({ + animations: () => { + view.backgroundColor = colors[(idx++) % colors.length] + }, + duration: 1000, + }); + } + }), + thisLabel('Rotation').apply({ + onClick: () => { + animate(this)({ + animations: () => { + if (view.rotation) { + view.rotation += 0.5 + } else { + view.rotation = 0.5 + } + }, + duration: 1000, + }); + } + }), + thisLabel('Corner').apply({ + onClick: () => { + animate(this)({ + animations: () => { + if (typeof view.corners === 'number') { + view.corners += 10 + } else { + view.corners = 10 + } + }, + duration: 1000, + }); + } + }), + ]).apply({ space: 10 } as IHLayout), + + hlayout([ + thisLabel('scaleX').apply({ + onClick: () => { + animate(this)({ + animations: () => { + if (view.scaleX) { + view.scaleX += 0.1 + } else { + view.scaleX = 1.1 + } + }, + duration: 1000, + }); + } + }), + thisLabel('scaleY').apply({ + onClick: () => { + animate(this)({ + animations: () => { + if (view.scaleY) { + view.scaleY += 0.1 + } else { + view.scaleY = 1.1 + } + }, + duration: 1000, + }); + } + }), + ]).apply({ space: 10 } as IHLayout), + ] + ).apply({ space: 10 } as IVLayout), + stack([ + view, + ]).apply({ + layoutConfig: layoutConfig().atmost(), + backgroundColor: colors[1].alpha(0.3 * 255), + }), + ]).apply({ + layoutConfig: layoutConfig().atmost(), + gravity: gravity().center(), + space: 10, + } as IVLayout).in(rootView) + } +} \ No newline at end of file diff --git a/src/ComplicatedAnimations.ts b/src/ComplicatedAnimations.ts new file mode 100644 index 00000000..bc477830 --- /dev/null +++ b/src/ComplicatedAnimations.ts @@ -0,0 +1,202 @@ +import { animate, Group, Panel, gravity, Color, AnimationSet, vlayout, scroller, layoutConfig, IVLayout, modal, IText, network, View, stack, IHLayout, hlayout, IView, text, TranslationAnimation, ScaleAnimation, RotationAnimation, FillMode, TimingFunction } from "doric"; +import { title, colors, box } from "./utils"; + +function thisLabel(str: string) { + return text({ + text: str, + width: 80, + height: 30, + backgroundColor: colors[0], + textSize: 10, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + }) +} + +@Entry +class AnimationDemo extends Panel { + build(rootView: Group): void { + const view = box(2) + const view2 = box(3) + view.onClick = () => { + modal(context).toast('Clicked') + } + vlayout([ + title("Complicated Animation"), + vlayout( + [ + hlayout([ + thisLabel('reset').apply({ + onClick: () => { + const rotation = new RotationAnimation + rotation.duration = 1000 + rotation.fromRotation = view.rotation || 0 + rotation.toRotation = 0 + const translation = new TranslationAnimation + translation.duration = 1000 + translation.fromTranslationX = view.translationX || 0 + translation.toTranslationX = 0 + translation.fromTranslationY = view.translationY || 0 + translation.toTranslationY = 0 + const scale = new ScaleAnimation + scale.duration = 1000 + scale.fromScaleX = view.scaleX || 1 + scale.toScaleX = 1 + scale.fromScaleY = view.scaleY || 1 + scale.toScaleY = 1 + const animationSet = new AnimationSet + animationSet.addAnimation(rotation) + animationSet.addAnimation(translation) + animationSet.addAnimation(scale) + view.doAnimation(context, animationSet).then(() => { + modal(context).toast('Resetd') + }) + } + }), + ]).apply({ space: 10 } as IHLayout), + hlayout([ + thisLabel('TranslationX').apply({ + onClick: () => { + const animation = new 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 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 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 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 RotationAnimation + animation.duration = 1000 + animation.fromRotation = view.rotation || 0 + animation.toRotation = animation.fromRotation + 0.25 + view.doAnimation(context, animation) + } + }), + ]).apply({ space: 10 } as IHLayout), + hlayout([ + thisLabel('group').apply({ + onClick: () => { + const rotation = new RotationAnimation + rotation.duration = 1000 + rotation.fromRotation = 0 + rotation.toRotation = 4 + const translation = new TranslationAnimation + translation.duration = 1000 + translation.fromTranslationX = view.translationX || 0 + translation.toTranslationX = 100 + const animationSet = new AnimationSet + animationSet.addAnimation(rotation) + animationSet.addAnimation(translation) + view.doAnimation(context, animationSet) + } + }), + ]).apply({ space: 10 } as IHLayout), + hlayout([ + thisLabel('Default').apply({ + onClick: () => { + const translation = new TranslationAnimation + translation.duration = 3000 + translation.fromTranslationX = 0 + translation.toTranslationX = 300 + translation.timingFunction = TimingFunction.Default + view.doAnimation(context, translation) + } + }), + thisLabel('Linear').apply({ + onClick: () => { + const translation = new TranslationAnimation + translation.duration = 3000 + translation.fromTranslationX = 0 + translation.toTranslationX = 300 + translation.timingFunction = TimingFunction.Linear + view.doAnimation(context, translation) + } + }), + thisLabel('EaseIn').apply({ + onClick: () => { + const translation = new TranslationAnimation + translation.duration = 3000 + translation.fromTranslationX = 0 + translation.toTranslationX = 300 + translation.timingFunction = TimingFunction.EaseIn + view.doAnimation(context, translation) + } + }), + thisLabel('EaseOut').apply({ + onClick: () => { + const translation = new TranslationAnimation + translation.duration = 3000 + translation.fromTranslationX = 0 + translation.toTranslationX = 300 + translation.timingFunction = TimingFunction.EaseOut + view.doAnimation(context, translation) + } + }), + thisLabel('EaseInEaseOut').apply({ + onClick: () => { + const translation = new TranslationAnimation + translation.duration = 3000 + translation.fromTranslationX = 0 + translation.toTranslationX = 300 + translation.timingFunction = TimingFunction.EaseInEaseOut + view.doAnimation(context, translation) + } + }), + ]).apply({ space: 10 } as IHLayout), + ] + ).apply({ space: 10 } as IVLayout), + 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: layoutConfig().atmost(), + backgroundColor: colors[1].alpha(0.3 * 255), + }), + ]).apply({ + layoutConfig: layoutConfig().atmost(), + gravity: gravity().center(), + space: 10, + } as IVLayout).in(rootView) + } +} \ No newline at end of file diff --git a/src/ComplicatedDemo.ts b/src/ComplicatedDemo.ts new file mode 100644 index 00000000..c4c4db2f --- /dev/null +++ b/src/ComplicatedDemo.ts @@ -0,0 +1,49 @@ +import { Panel, Group, vlayout, image, layoutConfig, ScaleType, refreshable, Color, pullable, stack, Image, Refreshable, TranslationAnimation, loge, log } from "doric"; +import { title, icon_refresh } from "./utils"; + +@Entry +class MyDemo extends Panel { + build(root: Group) { + let refreshed: Refreshable + let headerImage: Image + stack([ + refreshed = refreshable({ + onRefresh: () => { + refreshed.setRefreshing(context, false) + }, + header: pullable(context, + stack([]).apply({ + backgroundColor: Color.RED, + layoutConfig: layoutConfig().exactly(), + width: 100, + height: 30, + }), + { + startAnimation: () => { + }, + stopAnimation: () => { + }, + setPullingDistance: (distance: number) => { + headerImage.scaleX = headerImage.scaleY = (headerImage.height + distance * 2) / headerImage.height + log(`Header Image scaleY:${headerImage.scaleY},height:${headerImage.height},distance:${distance}`) + }, + }), + content: vlayout([]).apply({ + backgroundColor: Color.YELLOW, + }), + }).apply({ + layoutConfig: layoutConfig().atmost(), + }).also(v => { + v.top = 200 + }), + + headerImage = image({ + imageUrl: "https://img.zcool.cn/community/01e75b5da933daa801209e1ffa4649.jpg@1280w_1l_2o_100sh.jpg", + layoutConfig: layoutConfig().exactly(), + width: root.width, + height: 200, + scaleType: ScaleType.ScaleAspectFill, + }), + ]).in(root) + } +} \ No newline at end of file diff --git a/src/Counter.ts b/src/Counter.ts new file mode 100644 index 00000000..3b152919 --- /dev/null +++ b/src/Counter.ts @@ -0,0 +1,121 @@ +import { text, vlayout, Image, ViewHolder, VMPanel, ViewModel, Gravity, NativeCall, Text, Color, log, logw, loge, Group, LayoutSpec, } from "doric" + +interface CountModel { + count: number +} + +class CounterView extends ViewHolder { + + number!: Text + counter!: Text + build(root: Group) { + root.addChild(vlayout([ + text({ + textSize: 40, + layoutConfig: { + alignment: Gravity.Center, + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + }, + }).also(it => { this.number = it }), + text({ + text: "点击计数", + textSize: 20, + border: { + width: 1, + color: Color.parse('#000000'), + }, + corners: 5, + layoutConfig: { + alignment: Gravity.Center, + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + }, + shadow: { + color: 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 = Gravity.Center + it.layoutConfig = { + alignment: Gravity.Center + } + it.border = { + width: 1, + color: Color.parse("#000000"), + } + it.shadow = { + color: Color.parse("#ffff00"), + opacity: 0.5, + radius: 20, + offsetX: 10, + offsetY: 10, + } + it.corners = 20 + it.backgroundColor = Color.parse('#ff00ff') + })) + + root.addChild((new Image).also(iv => { + iv.imageUrl = "https://misc.aotu.io/ONE-SUNDAY/SteamEngine.png" + iv.layoutConfig = { + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + } + })) + } + + bind(state: CountModel) { + this.number.text = `${state.count}` + } + + setCounter(v: Function) { + this.counter.onClick = v + } +} + +class CounterVM extends ViewModel { + onAttached(s: CountModel, vh: CounterView): void { + vh.counter.onClick = () => { + this.updateState(state => { + state.count++ + }) + } + } +} + +@Entry +class MyPage extends VMPanel{ + + + getViewHolderClass() { + return CounterView + } + + getViewModelClass() { + return CounterVM + } + + getState(): CountModel { + return { + count: 0 + } + } + + + @NativeCall + log() { + log("Hello.HEGO") + logw("Hello.HEGO") + loge("Hello.HEGO") + context.modal.toast('This is a toast.').then((r) => { + loge(r) + }) + } +} \ No newline at end of file diff --git a/src/EffectsDemo.ts b/src/EffectsDemo.ts new file mode 100644 index 00000000..126d6728 --- /dev/null +++ b/src/EffectsDemo.ts @@ -0,0 +1,367 @@ + +import { Group, Panel, Text, text, gravity, Color, Stack, LayoutSpec, vlayout, hlayout, scroller, IVLayout, IHLayout, layoutConfig, Gravity } from "doric"; +import { colors } from "./utils"; + + +function box(idx = 0) { + return (new Stack).also(it => { + it.width = it.height = 20 + it.backgroundColor = colors[idx || 0] + }) +} + +function boxStr(str: string, idx = 0) { + return (new Text).also(it => { + it.width = it.height = 20 + it.text = str + it.textColor = Color.WHITE + it.backgroundColor = colors[idx || 0] + }) +} + +function label(str: string) { + return text({ + text: str, + textSize: 16, + }) +} + +@Entry +class EffectsDemo extends Panel { + build(rootView: Group) { + scroller( + vlayout([ + hlayout([ + vlayout([ + label("Origin view"), + box().apply({ + width: 100, + height: 100 + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + vlayout([ + label("Border"), + box().apply({ + width: 100, + height: 100, + border: { + width: 5, + color: colors[3] + }, + layoutConfig: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + vlayout([ + label("Corner"), + box().apply({ + width: 100, + height: 100, + corners: 10, + layoutConfig: layoutConfig().exactly().m({ + bottom: 10 + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + vlayout([ + label("Shadow"), + box().apply({ + width: 100, + height: 100, + shadow: { + opacity: 1, + color: colors[1], + offsetX: 3, + offsetY: 3, + radius: 5, + }, + layoutConfig: layoutConfig().exactly().m({ + bottom: 10 + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + ]).apply({ space: 20 } as IHLayout), + hlayout([ + vlayout([ + label("Border,Corner"), + box().apply({ + width: 100, + height: 100, + border: { + width: 5, + color: colors[3] + }, + corners: 10, + layoutConfig: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + 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: layoutConfig().exactly().m({ + bottom: 10 + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + 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: layoutConfig().exactly().m({ + bottom: 10 + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + 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: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + ]).apply({ space: 20 } as IHLayout), + hlayout([ + vlayout([ + label("Shadow"), + box().apply({ + width: 100, + height: 100, + corners: 50, + shadow: { + opacity: 1, + color: colors[1], + offsetX: 0, + offsetY: 0, + radius: 10, + }, + layoutConfig: layoutConfig().exactly().m({ + left: 10, + right: 10, + bottom: 10, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + 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: layoutConfig().exactly().m({ + left: 10, + right: 10, + bottom: 10, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + 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: layoutConfig().exactly().m({ + left: 10, + right: 10, + bottom: 10, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + 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: layoutConfig().exactly().m({ + left: 10, + right: 10, + bottom: 10, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + ]).apply({ space: 20 } as IHLayout), + hlayout([ + vlayout([ + label("Corner round"), + box().apply({ + width: 100, + height: 100, + corners: 50, + layoutConfig: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + vlayout([ + label("Corner left top"), + box().apply({ + width: 100, + height: 100, + corners: { + leftTop: 50, + }, + layoutConfig: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + vlayout([ + label("Corner right top"), + box().apply({ + width: 100, + height: 100, + corners: { + rightTop: 50, + }, + layoutConfig: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + vlayout([ + label("Corner left bottom"), + box().apply({ + width: 100, + height: 100, + corners: { + leftBottom: 50, + }, + layoutConfig: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + vlayout([ + label("Corner right bottom"), + box().apply({ + width: 100, + height: 100, + corners: { + rightBottom: 50, + }, + layoutConfig: layoutConfig().exactly().m({ + left: 5, + right: 5, + bottom: 5, + }) + }),]).apply({ + gravity: Gravity.Center, + space: 10, + } as IVLayout), + ]).apply({ space: 20 } as IHLayout), + ]).also(it => { + it.space = 20 + }), + ).also(it => { + it.layoutConfig = layoutConfig().atmost() + }).in(rootView) + } +} \ No newline at end of file diff --git a/src/FlowLayoutDemo.ts b/src/FlowLayoutDemo.ts new file mode 100644 index 00000000..f668cc08 --- /dev/null +++ b/src/FlowLayoutDemo.ts @@ -0,0 +1,41 @@ +import { Group, Panel, flowlayout, layoutConfig, FlowLayoutItem, text, Color, IFlowLayout, LayoutSpec, Gravity } from "doric"; +import { colors, label } from "./utils"; + +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', +] +@Entry +class FlowDemo extends Panel { + build(rootView: Group): void { + flowlayout({ + layoutConfig: layoutConfig().atmost(), + itemCount: 500, + columnCount: 3, + columnSpace: 10, + rowSpace: 10, + renderItem: (idx) => { + return new FlowLayoutItem().apply({ + backgroundColor: colors[idx % colors.length], + height: 50 + (idx % 3) * 20, + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + }).also(it => { + it.addChild(text({ + text: `${idx}`, + textColor: Color.WHITE, + textSize: 20, + layoutConfig: layoutConfig().wrap().a(Gravity.Center) + })) + }) + }, + }) + .in(rootView) + } +} \ No newline at end of file diff --git a/src/ImageDemo.ts b/src/ImageDemo.ts new file mode 100644 index 00000000..357a8e22 --- /dev/null +++ b/src/ImageDemo.ts @@ -0,0 +1,109 @@ +import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, scroller, layoutConfig, image, IView, IVLayout, ScaleType, Image } from "doric"; +import { colors, label } from "./utils"; +import { img_base64 } from "./image_base64"; +const imageUrl = 'https://img.zcool.cn/community/01e75b5da933daa801209e1ffa4649.jpg@1280w_1l_2o_100sh.jpg' + +@Entry +class ImageDemo extends Panel { + build(rootView: Group): void { + let imageView: Image + scroller(vlayout([ + text({ + text: "Image Demo", + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[5], + textAlignment: gravity().center(), + height: 50, + }), + label('Gif'), + image({ + imageUrl: "https://misc.aotu.io/ONE-SUNDAY/world-cup_2014_42.gif", + scaleType: ScaleType.ScaleToFill, + loadCallback: function (ret) { + log('this') + log('loadCallback', ret) + } + }), + label('APNG'), + image({ + imageUrl: "https://misc.aotu.io/ONE-SUNDAY/world_cup_2014_42.png", + loadCallback: (ret) => { + } + }), + label('Animated WebP'), + image({ + imageUrl: "https://p.upyun.com/demo/webp/webp/animated-gif-0.webp", + loadCallback: (ret) => { + } + }), + label('WebP'), + imageView = 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'), + image({ + imageUrl, + width: 300, + height: 300, + border: { + width: 2, + color: Color.GRAY, + }, + scaleType: ScaleType.ScaleToFill, + layoutConfig: layoutConfig().exactly(), + loadCallback: (ret) => { + } + }), + label('ScaleAspectFit'), + image({ + imageUrl, + width: 300, + height: 300, + border: { + width: 2, + color: Color.GRAY, + }, + scaleType: ScaleType.ScaleAspectFit, + layoutConfig: layoutConfig().exactly(), + }), + label('ScaleAspectFill'), + image({ + imageUrl, + width: 300, + height: 300, + border: { + width: 2, + color: Color.GRAY, + }, + scaleType: ScaleType.ScaleAspectFill, + layoutConfig: layoutConfig().exactly(), + }), + label('ImageBase64'), + image({ + imageBase64: img_base64, + width: 300, + height: 300, + border: { + width: 2, + color: Color.GRAY, + }, + scaleType: ScaleType.ScaleAspectFill, + layoutConfig: layoutConfig().exactly(), + }), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: gravity().center(), + space: 10, + } as IVLayout)).apply({ + layoutConfig: layoutConfig().atmost(), + }).in(rootView) + } +} \ No newline at end of file diff --git a/src/LayoutDemo.ts b/src/LayoutDemo.ts new file mode 100644 index 00000000..b4762dbb --- /dev/null +++ b/src/LayoutDemo.ts @@ -0,0 +1,460 @@ + +import { Group, Panel, Text, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, slider, slideItem, scroller, IVLayout, IHLayout, layoutConfig } from "doric"; +import { O_TRUNC } from "constants"; + +const colors = [ + "#f0932b", + "#eb4d4b", + "#6ab04c", + "#e056fd", + "#686de0", + "#30336b", +] + +function box(idx = 0) { + return (new Stack).also(it => { + it.width = it.height = 20 + it.backgroundColor = Color.parse(colors[idx || 0]) + }) +} +function boxStr(str: string, idx = 0) { + return (new Text).also(it => { + it.width = it.height = 20 + it.text = str + it.textColor = Color.parse('#ffffff') + it.backgroundColor = Color.parse(colors[idx || 0]) + }) +} +function label(str: string) { + return text({ + text: str, + textSize: 16, + }) +} +@Entry +class LayoutDemo extends Panel { + build(rootView: Group) { + scroller( + hlayout([ + vlayout([ + label("Horizontal Layout(Align to Top)"), + 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)"), + 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 = gravity().bottom() + }), + label("Horizontal Layout(Align to Center)"), + 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 = gravity().center() + }), + label("Horizontal Layout(Weight)"), + hlayout([ + boxStr('weight=1', 3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + box(2), + box(4), + ]).apply({ + width: 200, + height: 30, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IHLayout), + hlayout([ + box(3), + boxStr('weight=1', 2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + box(4), + ]).apply({ + width: 200, + height: 30, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IHLayout), + hlayout([ + box(3), + box(2), + boxStr('weight=1', 4).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + ]).apply({ + width: 200, + height: 30, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IHLayout), + hlayout([ + boxStr('weight=1', 3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + boxStr('weight=1', 2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + box(4), + ]).apply({ + width: 200, + height: 30, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IHLayout), + hlayout([ + boxStr('weight=1', 3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + boxStr('weight=1', 2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + boxStr('weight=1', 4).apply({ + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + ]).apply({ + width: 200, + height: 30, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IHLayout), + ]).also(it => { + it.space = 20 + it.gravity = gravity().center() + }), + vlayout([ + label("Vertical Layout(Algin to Left)"), + 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 + } as IVLayout), + label("Vertical Layout(Algin to Right)"), + 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: gravity().right(), + } as IVLayout), + label("Vertical Layout(Algin to Center)"), + 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: gravity().center(), + } as IVLayout), + label("Vertical Layout(Weight)"), + hlayout([ + + vlayout([ + boxStr('weight=1', 3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + }, + }), + box(2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + } + }), + box(4).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + } + }), + ]).apply({ + width: 100, + height: 200, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IVLayout), + vlayout([ + box(3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + }, + }), + boxStr('weight=1', 2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + box(4).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + } + }), + ]).apply({ + width: 100, + height: 200, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IVLayout), + vlayout([ + box(3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + }, + }), + box(2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + }, + }), + boxStr('weight=1', 4).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + ]).apply({ + width: 100, + height: 200, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IVLayout), + vlayout([ + boxStr('weight=1', 3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + }, + }), + boxStr('weight=1', 2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + box(4).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + } + }), + ]).apply({ + width: 100, + height: 200, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IVLayout), + vlayout([ + boxStr('weight=1', 3).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + }, + }), + boxStr('weight=1', 2).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + boxStr('weight=1', 4).apply({ + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + weight: 1, + } + }), + ]).apply({ + width: 100, + height: 200, + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + backgroundColor: Color.parse('#eeeeee'), + gravity: gravity().center(), + } as IVLayout), + ]).also(it => { + it.space = 20 + }), + + ]).also(it => { + it.space = 20 + it.gravity = gravity().left() + }) + ]).also(it => { + it.space = 20 + }), + ).also(it => { + it.layoutConfig = layoutConfig().atmost() + }) + .in(rootView) + } +} \ No newline at end of file diff --git a/src/ListDemo.ts b/src/ListDemo.ts new file mode 100644 index 00000000..ebd5c186 --- /dev/null +++ b/src/ListDemo.ts @@ -0,0 +1,114 @@ +import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, refreshable, Refreshable, ListItem } from "doric"; +import { rotatedArrow, colors } from "./utils"; +@Entry +class ListPanel extends Panel { + build(rootView: Group): void { + let refreshView: Refreshable + let offset = Math.ceil(Math.random() * colors.length) + vlayout([ + text({ + text: "ListDemo", + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + }, + textSize: 30, + textColor: Color.parse("#535c68"), + backgroundColor: Color.parse("#dff9fb"), + textAlignment: gravity().center(), + height: 50, + }), + refreshView = refreshable({ + onRefresh: () => { + refreshView.setRefreshing(context, false).then(() => { + (refreshView.content as List).also(it => { + it.reset() + offset = Math.ceil(Math.random() * colors.length) + it.itemCount = 40 + it.renderItem = (idx: number) => { + let counter!: Text + return listItem( + hlayout([ + text({ + layoutConfig: { + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.EXACTLY, + alignment: gravity().center(), + }, + text: `Cell At Line ${idx}`, + textAlignment: gravity().center(), + textColor: Color.parse("#ffffff"), + textSize: 20, + height: 50, + }), + text({ + textColor: Color.parse("#ffffff"), + textSize: 20, + text: "", + }).also(it => { + counter = it + it.layoutConfig = { + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + margin: { + left: 10, + } + } + }) + ]).also(it => { + it.layoutConfig = { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.WRAP_CONTENT, + margin: { + bottom: 2, + } + } + it.gravity = gravity().center() + it.backgroundColor = colors[(idx + offset) % colors.length] + let clicked = 0 + it.onClick = () => { + counter.text = `Item Clicked ${++clicked}` + } + }) + ).also(it => { + it.layoutConfig = { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.WRAP_CONTENT, + } + it.onClick = () => { + log(`Click item at ${idx}`) + it.height += 10 + it.nativeChannel(context, "getWidth")().then( + resolve => { + log(`resolve,${resolve}`) + }, + reject => { + log(`reject,${reject}`) + }) + } + }) + } + }) + }) + }, + header: rotatedArrow(context), + content: list({ + itemCount: 0, + renderItem: () => new ListItem, + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.AT_MOST, + }, + }), + }), + + ]).also(it => { + it.layoutConfig = { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.AT_MOST, + } + it.backgroundColor = Color.WHITE + }).in(rootView) + refreshView.backgroundColor = Color.YELLOW + } +} \ No newline at end of file diff --git a/src/ModalDemo.ts b/src/ModalDemo.ts new file mode 100644 index 00000000..2086e1b0 --- /dev/null +++ b/src/ModalDemo.ts @@ -0,0 +1,150 @@ +import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, scroller, layoutConfig, image, IView, IVLayout, ScaleType, IText, modal } from "doric"; +import { colors, label } from "./utils"; + +@Entry +class ModalDemo extends Panel { + build(rootView: Group): void { + scroller(vlayout([ + text({ + text: "Modal", + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[1], + textAlignment: Gravity.Center, + height: 50, + }), + label('toast on bottom'), + label('Click me').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + modal(context).toast('This is a toast.') + } + } as IText), + label('toast on top'), + label('Click me').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + modal(context).toast('This is a toast.', Gravity.Top) + } + } as IText), + + label('toast on center'), + label('Click me').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + modal(context).toast('This is a toast.', Gravity.Center) + } + } as IText), + text({ + text: "Alert", + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[2], + textAlignment: Gravity.Center, + height: 50, + }), + label('Click me').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + modal(context).alert({ + msg: 'This is alert.', + title: 'Alert title', + okLabel: "OkLabel" + }).then(e => { + modal(context).toast('Clicked OK.') + }) + } + } as IText), + text({ + text: "Confirm", + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[3], + textAlignment: Gravity.Center, + height: 50, + }), + label('Click me').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + modal(context).confirm({ + msg: 'This is Confirm.', + title: 'Confirm title', + okLabel: "OkLabel", + cancelLabel: 'CancelLabel', + }).then( + () => { + modal(context).toast('Clicked OK.') + }, + () => { + modal(context).toast('Clicked Cancel.') + }) + } + } as IText), + text({ + text: "Prompt", + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[4], + textAlignment: Gravity.Center, + height: 50, + }), + label('Click me').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + modal(context).prompt({ + msg: 'This is Prompt.', + title: 'Prompt title', + okLabel: "OkLabel", + cancelLabel: 'CancelLabel', + }).then( + e => { + modal(context).toast(`Clicked OK.Input:${e}`) + }, + e => { + modal(context).toast(`Clicked Cancel.Input:${e}`) + }) + } + } as IText), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: Gravity.Center, + space: 10, + } as IVLayout)).apply({ + layoutConfig: layoutConfig().atmost(), + }).in(rootView) + } +} \ No newline at end of file diff --git a/src/NavbarDemo.ts b/src/NavbarDemo.ts new file mode 100644 index 00000000..43b743ca --- /dev/null +++ b/src/NavbarDemo.ts @@ -0,0 +1,84 @@ +import { Group, Panel, navbar, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, scroller, layoutConfig, image, IView, IVLayout, ScaleType, modal, IText, network, navigator } from "doric"; +import { title, label, colors } from "./utils"; + +@Entry +class NavbarDemo extends Panel { + build(rootView: Group): void { + scroller(vlayout([ + title("Navbar Demo"), + label('isHidden').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + navbar(context).isHidden().then(e => modal(context).alert(`Navbar isHidden:${e}`)).catch(e => { + modal(context).alert(e) + }) + } + } as IText), + label('setHidden').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + navbar(context).isHidden() + .then(e => navbar(context).setHidden(!e)) + .catch(e => { + modal(context).alert(e) + }) + } + } as IText), + label('setTitle').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + navbar(context).setTitle('Setted Title') + .catch(e => { + modal(context).alert(e) + }) + } + } as IText), + label('setBgColor').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + navbar(context).setBgColor(Color.YELLOW) + .catch(e => { + modal(context).alert(e) + }) + } + } as IText), + label('Pop').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + navigator(context).pop() + } + } as IText), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: gravity().center(), + space: 10, + } as IVLayout)).apply({ + layoutConfig: layoutConfig().atmost(), + }).in(rootView) + } +} \ No newline at end of file diff --git a/src/NavigatorDemo.ts b/src/NavigatorDemo.ts new file mode 100644 index 00000000..03796ef5 --- /dev/null +++ b/src/NavigatorDemo.ts @@ -0,0 +1,52 @@ +import { Panel, scroller, vlayout, text, layoutConfig, LayoutSpec, Color, gravity, IVLayout, Group, IText, navigator } from "doric"; +import { colors, label } from "./utils"; +@Entry +class NaivgatorDemo extends Panel { + build(root: Group) { + scroller(vlayout([ + text({ + text: "Navigator Demo", + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[1], + textAlignment: 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: Color.WHITE, + layoutConfig: layoutConfig().exactly().w(LayoutSpec.AT_MOST), + onClick: () => { + navigator(context).push(`assets://demo/${e}.js`, `${e}.js`) + }, + } as IText) + ), + label('POP').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + navigator(context).pop() + }, + } as IText), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: gravity().center(), + space: 10, + } as IVLayout)).apply({ + layoutConfig: layoutConfig().atmost(), + }).in(root) + } + +} \ No newline at end of file diff --git a/src/NetworkDemo.ts b/src/NetworkDemo.ts new file mode 100644 index 00000000..851b5704 --- /dev/null +++ b/src/NetworkDemo.ts @@ -0,0 +1,34 @@ +import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, scroller, layoutConfig, image, IView, IVLayout, ScaleType, modal, IText, network } from "doric"; +import { title, label, colors } from "./utils"; + +@Entry +class NetworkDemo extends Panel { + build(rootView: Group): void { + scroller(vlayout([ + title("Network Demo"), + label('Click me').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + network(context).get('https://m.baidu.com').then( + e => { + modal(context).alert(JSON.stringify(e)) + } + ).catch(e => { + modal(context).toast('Catched:' + JSON.stringify(e)) + }) + } + } as IText), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: gravity().center(), + space: 10, + } as IVLayout)).apply({ + layoutConfig: layoutConfig().atmost(), + }).in(rootView) + } +} \ No newline at end of file diff --git a/src/PopoverDemo.ts b/src/PopoverDemo.ts new file mode 100644 index 00000000..fd0e4f99 --- /dev/null +++ b/src/PopoverDemo.ts @@ -0,0 +1,44 @@ +import { Group, Panel, popover, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, scroller, layoutConfig, image, IView, IVLayout, ScaleType, modal, IText, network } from "doric"; +import { title, label, colors } from "./utils"; + +@Entry +class PopoverDemo extends Panel { + build(rootView: Group): void { + scroller(vlayout([ + title("Popover Demo"), + label('Popover').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + popover(context).show(text({ + width: 200, + height: 50, + backgroundColor: colors[0], + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly().a(Gravity.Center), + text: "This is PopOver Window", + }).also(v => { + let idx = 0 + v.onClick = () => { + v.backgroundColor = colors[(++idx) % colors.length] + } + modal(context).toast('Dismissed after 3 seconds') + setTimeout(() => { + popover(context).dismiss() + }, 3000) + })) + } + } as IText), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: gravity().center(), + space: 10, + } as IVLayout)).apply({ + layoutConfig: layoutConfig().atmost(), + }).in(rootView) + } +} \ No newline at end of file diff --git a/src/RefreshableDemo.ts b/src/RefreshableDemo.ts new file mode 100644 index 00000000..b91c7e02 --- /dev/null +++ b/src/RefreshableDemo.ts @@ -0,0 +1,95 @@ +import { refreshable, Group, Panel, pullable, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, scroller, layoutConfig, image, IView, IVLayout, ScaleType, modal, IText, network, navigator, stack, Image } from "doric"; +import { title, label, colors, icon_refresh } from "./utils"; + +@Entry +class RefreshableDemo extends Panel { + build(rootView: Group): void { + let refreshImage: Image + let refreshView = refreshable({ + layoutConfig: layoutConfig().atmost(), + onRefresh: () => { + log('onRefresh') + setTimeout(() => { + refreshView.setRefreshing(context, false) + }, 5000) + }, + header: pullable(context, + stack([ + image({ + layoutConfig: layoutConfig().exactly().m({ top: 50, bottom: 10, }), + width: 30, + height: 30, + imageBase64: icon_refresh, + }).also(v => { + refreshImage = v + }), + ]), + { + startAnimation: () => { + log('startAnimation') + }, + stopAnimation: () => { + log('stopAnimation') + }, + setPullingDistance: (distance: number) => { + refreshImage.rotation = distance / 30 + }, + }), + content: (vlayout([ + title("Refreshable Demo"), + label('start Refresh').apply({ + width: 300, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + refreshView.setRefreshing(context, true) + } + } as IText), + label('stop Refresh').apply({ + width: 300, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + refreshView.setRefreshing(context, false) + } + } as IText), + + label('Enable Refresh').apply({ + width: 300, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + refreshView.setRefreshable(context, true) + } + } as IText), + + label('Disable Refresh').apply({ + width: 300, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + refreshView.setRefreshable(context, false) + } + } as IText), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: gravity().centerX(), + space: 10, + } as IVLayout)) + }).apply({ + backgroundColor: Color.YELLOW + }).in(rootView) + } +} \ No newline at end of file diff --git a/src/ScrollerDemo.ts b/src/ScrollerDemo.ts new file mode 100644 index 00000000..9870d3d1 --- /dev/null +++ b/src/ScrollerDemo.ts @@ -0,0 +1,34 @@ +import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, scroller, layoutConfig } from "doric"; +import { label } from "./utils"; + +@Entry +class ScrollerPanel extends Panel { + build(rootView: Group): void { + scroller( + vlayout([ + scroller( + vlayout(new Array(100).fill(1).map(e => label('Scroll Content'))) + ).apply({ + layoutConfig: layoutConfig().exactly(), + width: 300, + height: 500, + backgroundColor: Color.RED, + }), + scroller( + vlayout(new Array(100).fill(1).map(e => label('Scroll Content'))) + ).apply({ + layoutConfig: layoutConfig().exactly(), + width: 300, + height: 500, + backgroundColor: Color.BLUE, + }) + ]) + ) + .apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY), + height: 500, + backgroundColor: Color.YELLOW, + }) + .in(rootView) + } +} \ No newline at end of file diff --git a/src/SliderDemo.ts b/src/SliderDemo.ts new file mode 100644 index 00000000..6ab55c38 --- /dev/null +++ b/src/SliderDemo.ts @@ -0,0 +1,58 @@ +import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, slider, slideItem, image, layoutConfig, ScaleType } from "doric"; +import { colors } from "./utils"; + +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', +] +@Entry +class SliderPanel extends Panel { + build(rootView: Group): void { + rootView.addChild(vlayout([ + text({ + text: "Gallery", + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.EXACTLY, + }, + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[1], + textAlignment: gravity().center(), + height: 50, + }), + slider({ + itemCount: 100, + renderPage: (idx) => { + return slideItem(image({ + imageUrl: imageUrls[idx % imageUrls.length], + scaleType: ScaleType.ScaleAspectFit, + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST).h(LayoutSpec.AT_MOST).a(gravity().center()), + })).also(it => { + let start = idx + it.onClick = () => { + it.backgroundColor = (colors[++start % colors.length]) + } + }) + }, + layoutConfig: { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.WRAP_CONTENT, + weight: 1, + }, + }), + ]).also(it => { + it.layoutConfig = { + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.AT_MOST, + } + })) + } +} \ No newline at end of file diff --git a/src/Snake.ts b/src/Snake.ts new file mode 100644 index 00000000..05bcba33 --- /dev/null +++ b/src/Snake.ts @@ -0,0 +1,369 @@ +import { text, loge, log, ViewHolder, Stack, ViewModel, Gravity, Text, Color, HLayout, VLayout, Group, VMPanel, LayoutSpec, vlayout, hlayout, takeNonNull, stack } from "doric"; + +type SnakeNode = { + x: number + y: number + prev?: SnakeNode + next?: SnakeNode +} + + +enum Direction { + left = 0, + right = 1, + up = 2, + down = 3, +} + +enum State { + idel, + run, + fail, +} + +class SnakeModel { + state = State.idel + direction = Direction.right + + width: number + height: number + + constructor(w: number, h: number) { + this.width = w + this.height = h + } + food = { x: -1, y: -1 } + + head: SnakeNode = { + x: 0, + y: 0, + } + + 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: SnakeNode) { + 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 + 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: SnakeNode = { x: this.food.x, y: this.food.y } + 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 + 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 ViewHolder { + + panel!: Stack + start?: Text + up?: Text + down?: Text + left?: Text + right?: Text + + build(root: Group): void { + root.backgroundColor = Color.parse('#000000') + vlayout([ + text({ + text: "Snake", + textSize: 20, + textColor: Color.parse("#ffffff"), + layoutConfig: { + alignment: new Gravity().centerX(), + margin: { + top: 20 + }, + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + }, + }), + (new Stack).also(panel => { + panel.backgroundColor = Color.parse('#00ff00') + this.panel = panel + }), + hlayout([ + text({ + text: "Start", + textSize: 30, + textColor: Color.parse("#ffffff"), + layoutConfig: { + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + }, + }).also(it => this.start = it), + ]).also(it => { + it.layoutConfig = { + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + } + }), + + vlayout([ + hlayout([ + text({ + width: 50, + height: 50, + text: "↑", + textSize: 30, + textAlignment: new Gravity().center(), + backgroundColor: Color.parse('#ffff00'), + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + }).also(it => this.up = it) + ]).also(it => { + it.layoutConfig = { + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + } + }), + hlayout([ + text({ + width: 50, + height: 50, + text: "←", + textSize: 30, + textAlignment: new Gravity().center(), + backgroundColor: Color.parse('#ffff00'), + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + }).also(it => this.left = it), + text({ + width: 50, + height: 50, + text: "↓", + textSize: 30, + textAlignment: new Gravity().center(), + backgroundColor: Color.parse('#ffff00'), + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + }).also(it => this.down = it), + text({ + width: 50, + height: 50, + text: "→", + textSize: 30, + textAlignment: new Gravity().center(), + backgroundColor: Color.parse('#ffff00'), + layoutConfig: { + widthSpec: LayoutSpec.EXACTLY, + heightSpec: LayoutSpec.EXACTLY, + }, + }).also(it => this.right = it), + ]).also(it => { + it.layoutConfig = { + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + } + it.space = 10 + }), + ]).also(controlArea => { + controlArea.gravity = new Gravity().centerX() + controlArea.space = 10 + controlArea.layoutConfig = { + alignment: new Gravity().centerX(), + widthSpec: LayoutSpec.WRAP_CONTENT, + heightSpec: LayoutSpec.WRAP_CONTENT, + } + }), + ]).also(it => { + it.space = 20 + it.layoutConfig = { + alignment: new Gravity().centerX().top(), + widthSpec: LayoutSpec.AT_MOST, + heightSpec: LayoutSpec.AT_MOST, + } + it.gravity = new Gravity().centerX() + }).in(root) + } + + bind(state: SnakeModel): void { + log('build', state) + this.panel.width = state.width * 10 + this.panel.height = state.height * 10 + let node: SnakeNode | undefined = state.head + let nodes: SnakeNode[] = [] + 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 Stack + item.width = item.height = 10 + item.corners = 5 + item.shadow = { + color: Color.GRAY, + opacity: 1, + radius: 3, + offsetX: 3, + offsetY: 3, + } + this.panel.addChild(item) + } + if (index === nodes.length - 1) { + item.backgroundColor = Color.parse('#ffff00') + } else { + item.backgroundColor = 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 ViewModel{ + timerId?: any + + 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) { + loge('Game Over') + this.stop() + } + }, 500) + } + + stop = () => { + if (this.timerId !== undefined) { + clearInterval(this.timerId) + this.timerId = undefined + } + } + + left = () => { + this.updateState(it => it.direction = Direction.left) + } + + right = () => { + this.updateState(it => it.direction = Direction.right) + } + + up = () => { + this.updateState(it => it.direction = Direction.up) + } + + down = () => { + this.updateState(it => it.direction = Direction.down) + } + + onAttached(state: SnakeModel, v: SnakeView): void { + takeNonNull(v.start)(it => it.onClick = this.start) + takeNonNull(v.left)(it => it.onClick = this.left) + takeNonNull(v.right)(it => it.onClick = this.right) + takeNonNull(v.up)(it => it.onClick = this.up) + takeNonNull(v.down)(it => it.onClick = this.down) + } + +} +@Entry +class SnakePanel extends VMPanel{ + getViewModelClass() { + return SnakeVM + } + getState(): SnakeModel { + return new SnakeModel(35, 35) + } + getViewHolderClass() { + return SnakeView + } +} \ No newline at end of file diff --git a/src/StorageDemo.ts b/src/StorageDemo.ts new file mode 100644 index 00000000..f13db93b --- /dev/null +++ b/src/StorageDemo.ts @@ -0,0 +1,93 @@ +import { storage, Panel, scroller, vlayout, text, layoutConfig, LayoutSpec, Color, gravity, IVLayout, Group, IText, modal, Text, log, loge } from "doric"; +import { colors, label } from "./utils"; +const storedKey = 'StoredKey' +const zone = 'StorageDemo' +@Entry +class StorageDemo extends Panel { + stored!: Text + + update() { + storage(context).getItem(storedKey, zone).then(e => { + this.stored.text = e || "" + log('Called in then') + }) + } + + build(root: Group) { + scroller(vlayout([ + text({ + text: "Storage Demo", + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[1], + textAlignment: gravity().center(), + height: 50, + }), + label('Stored'), + text({ + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 20, + textColor: Color.WHITE, + backgroundColor: colors[3], + textAlignment: gravity().center(), + height: 50, + }).also(it => this.stored = it), + label('store a value').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + storage(context).getItem(storedKey, zone).then(e => { + modal(context).prompt({ + text: e, + title: "Please input text to store", + defaultText: "Default Value", + }).then(text => { + storage(context).setItem(storedKey, text, zone).then(() => { + this.update() + }) + }) + }) + }, + } as IText), + label('remove value').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + storage(context).remove(storedKey, zone).then(e => { + this.update() + }) + }, + } as IText), + label('clear values').apply({ + width: 200, + height: 50, + backgroundColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + onClick: () => { + storage(context).clear(zone).then(e => { + this.update() + }) + }, + } as IText), + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + gravity: gravity().center(), + space: 10, + } as IVLayout)).apply({ + layoutConfig: layoutConfig().atmost(), + }).in(root) + this.update() + } + +} \ No newline at end of file diff --git a/src/image_base64.ts b/src/image_base64.ts new file mode 100644 index 00000000..9eb105a6 --- /dev/null +++ b/src/image_base64.ts @@ -0,0 +1,2 @@ +export const img_base64 = + '' \ No newline at end of file diff --git a/src/utils.ts b/src/utils.ts new file mode 100644 index 00000000..9e7e7610 --- /dev/null +++ b/src/utils.ts @@ -0,0 +1,72 @@ +import { Color, text, Stack, Text, layoutConfig, LayoutSpec, gravity, pullable, stack, image, Image, BridgeContext, log } from "doric"; +export const icon_refresh = '' + +export const colors = [ + "#70a1ff", + "#7bed9f", + "#ff6b81", + "#a4b0be", + "#f0932b", + "#eb4d4b", + "#6ab04c", + "#e056fd", + "#686de0", + "#30336b", +].map(e => Color.parse(e)) + +export function label(str: string) { + return text({ + text: str, + textSize: 16, + }) +} + +export function box(idx = 0) { + return (new Stack).also(it => { + it.width = it.height = 20 + it.backgroundColor = colors[idx || 0] + }) +} +export function boxStr(str: string, idx = 0) { + return (new Text).also(it => { + it.width = it.height = 20 + it.text = str + it.textColor = Color.WHITE + it.backgroundColor = colors[idx || 0] + }) +} + +export function title(str: string) { + return text({ + text: str, + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[1], + textAlignment: gravity().center(), + height: 50, + }) +} + +export function rotatedArrow(context: BridgeContext) { + let refreshImage: Image + return pullable(context, + stack([ + image({ + layoutConfig: layoutConfig().exactly().m({ top: 50, bottom: 10, }), + width: 30, + height: 30, + imageBase64: icon_refresh, + }).also(v => refreshImage = v), + ]), { + startAnimation: () => { + log('startAnimation') + }, + stopAnimation: () => { + log('stopAnimation') + }, + setPullingDistance: (distance: number) => { + refreshImage.rotation = distance / 30 + }, + }) +} \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 00000000..8a7c268d --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,61 @@ +{ + "compilerOptions": { + /* Basic Options */ + // "incremental": true, /* Enable incremental compilation */ + "target": "ES2015", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'. */ + "module": "es2015", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */ + "lib": [], /* Specify library files to be included in the compilation. */ + // "allowJs": true, /* Allow javascript files to be compiled. */ + // "checkJs": true, /* Report errors in .js files. */ + // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ + // "declaration": true, /* Generates corresponding '.d.ts' file. */ + // "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */ + "sourceMap": true, /* Generates corresponding '.map' file. */ + // "outFile": "./", /* Concatenate and emit output to single file. */ + "outDir": "build/", /* Redirect output structure to the directory. */ + // "rootDir": "./", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */ + // "composite": true, /* Enable project compilation */ + // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ + // "removeComments": true, /* Do not emit comments to output. */ + // "noEmit": true, /* Do not emit outputs. */ + // "importHelpers": true, /* Import emit helpers from 'tslib'. */ + // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ + // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ + /* Strict Type-Checking Options */ + "strict": true, /* Enable all strict type-checking options. */ + // "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */ + // "strictNullChecks": true, /* Enable strict null checks. */ + // "strictFunctionTypes": true, /* Enable strict checking of function types. */ + // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ + // "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */ + // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ + // "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */ + /* Additional Checks */ + // "noUnusedLocals": true, /* Report errors on unused locals. */ + // "noUnusedParameters": true, /* Report errors on unused parameters. */ + // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ + // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ + /* Module Resolution Options */ + "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ + // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ + // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ + // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ + // "typeRoots": [], /* List of folders to include type definitions from. */ + // "types": [], /* Type declaration files to be included in compilation. */ + // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ + "esModuleInterop": true, /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */ + // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ + // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ + /* Source Map Options */ + // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ + // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ + // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ + // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ + /* Experimental Options */ + "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ + "emitDecoratorMetadata": true /* Enables experimental support for emitting type metadata for decorators. */ + }, + "include": [ + "**/*.ts", + ] +} \ No newline at end of file From 8ee86f93175068c7d9a4e8b8c56d4f6aaace63d8 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 4 Dec 2019 14:09:20 +0800 Subject: [PATCH 03/35] add ignored files --- .gitignore | 3 +++ .vscode/launch.json | 24 ++++++++++++++++++++++++ .vscode/tasks.json | 28 ++++++++++++++++++++++++++++ 3 files changed, 55 insertions(+) create mode 100644 .gitignore create mode 100644 .vscode/launch.json create mode 100644 .vscode/tasks.json diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..692a327e --- /dev/null +++ b/.gitignore @@ -0,0 +1,3 @@ +node_modules/ +build/ +bundle/ \ No newline at end of file diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 00000000..39c84064 --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,24 @@ +{ + // Use IntelliSense to learn about possible attributes. + // Hover to view descriptions of existing attributes. + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 + "version": "0.2.0", + "configurations": [ + { + "type": "node", + "request": "launch", + "name": "Debug TS", + "program": "${workspaceFolder}/${relativeFile}", + "preLaunchTask": "Doric Build", + "sourceMaps": true, + "serverReadyAction": { + "pattern": "listening on port ([0-9]+)", + "uriFormat": "http://localhost:%s", + "action": "openExternally" + }, + "outFiles": [ + "${workspaceFolder}/bundle/**/*.js" + ] + } + ] +} \ No newline at end of file diff --git a/.vscode/tasks.json b/.vscode/tasks.json new file mode 100644 index 00000000..d51f6710 --- /dev/null +++ b/.vscode/tasks.json @@ -0,0 +1,28 @@ +{ + // See https://go.microsoft.com/fwlink/?LinkId=733558 + // for the documentation about the tasks.json format + "version": "2.0.0", + "tasks": [ + { + "label": "Doric Build", + "type": "shell", + "command": "doric build", + "group": "build", + "problemMatcher": [] + }, + { + "label": "Doric Clean", + "type": "shell", + "command": "doric clean", + "group": "build", + "problemMatcher": [] + }, + { + "label": "Doric Dev", + "type": "shell", + "command": "doric dev", + "group": "build", + "problemMatcher": [] + } + ] +} \ No newline at end of file From f79399310450405353f0ebff046af2d84cf6ffd9 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 4 Dec 2019 14:27:39 +0800 Subject: [PATCH 04/35] feat:update file path --- package-lock.json | 121 +--------------------------------------------- package.json | 2 +- 2 files changed, 2 insertions(+), 121 deletions(-) diff --git a/package-lock.json b/package-lock.json index ed538db2..40075af9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -33,7 +33,7 @@ "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" }, "doric": { - "version": "file:../js-framework", + "version": "file:../doric-js", "requires": { "@types/ws": "^6.0.3", "reflect-metadata": "^0.1.13", @@ -42,125 +42,6 @@ "tslib": "^1.10.0", "typescript": "^3.7.2", "ws": "^7.2.0" - }, - "dependencies": { - "@types/estree": { - "version": "0.0.39", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", - "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==" - }, - "@types/node": { - "version": "12.12.7", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.7.tgz", - "integrity": "sha512-E6Zn0rffhgd130zbCbAr/JdXfXkoOUFAKNs/rF8qnafSJ8KYaA/j3oz7dcwal+lYjLA7xvdd5J4wdYpCTlP8+w==" - }, - "@types/resolve": { - "version": "0.0.8", - "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", - "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", - "requires": { - "@types/node": "*" - } - }, - "@types/ws": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/@types/ws/-/ws-6.0.3.tgz", - "integrity": "sha512-yBTM0P05Tx9iXGq00BbJPo37ox68R5vaGTXivs6RGh/BQ6QP5zqZDGWdAO6JbRE/iR1l80xeGAwCQS2nMV9S/w==", - "requires": { - "@types/node": "*" - } - }, - "acorn": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", - "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" - }, - "async-limiter": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", - "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" - }, - "builtin-modules": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", - "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" - }, - "estree-walker": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", - "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" - }, - "is-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", - "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" - }, - "path-parse": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", - "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" - }, - "reflect-metadata": { - "version": "0.1.13", - "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", - "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" - }, - "resolve": { - "version": "1.12.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", - "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", - "requires": { - "path-parse": "^1.0.6" - } - }, - "rollup": { - "version": "1.26.5", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.26.5.tgz", - "integrity": "sha512-c6Pv0yWzjYNpy2DIhLFUnyP6e1UTGownr4IfpJcPY/k186RJjpaGGPRwKQ62KCauctG6dgtHt88pw1EGrPRkuA==", - "requires": { - "@types/estree": "*", - "@types/node": "*", - "acorn": "^7.1.0" - } - }, - "rollup-plugin-node-resolve": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", - "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", - "requires": { - "@types/resolve": "0.0.8", - "builtin-modules": "^3.1.0", - "is-module": "^1.0.0", - "resolve": "^1.11.1", - "rollup-pluginutils": "^2.8.1" - } - }, - "rollup-pluginutils": { - "version": "2.8.2", - "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", - "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", - "requires": { - "estree-walker": "^0.6.1" - } - }, - "tslib": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", - "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" - }, - "typescript": { - "version": "3.7.2", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.2.tgz", - "integrity": "sha512-ml7V7JfiN2Xwvcer+XAf2csGO1bPBdRbFCkYBczNZggrBZ9c7G3riSUeJmqEU5uOtXNPMhE3n+R4FA/3YOAWOQ==" - }, - "ws": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", - "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", - "requires": { - "async-limiter": "^1.0.0" - } - } } }, "estree-walker": { diff --git a/package.json b/package.json index 7c36fcc3..5cbba9e2 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,7 @@ }, "license": "Apache-2.0", "dependencies": { - "doric": "file:../js-framework", + "doric": "file:../doric-js", "reflect-metadata": "^0.1.13", "rollup": "^1.27.2", "rollup-plugin-commonjs": "^10.1.0", From 4a8aaebbc745bfe825149e08d8a7f9a820fef68a Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 4 Dec 2019 16:24:28 +0800 Subject: [PATCH 05/35] add license --- LICENSE | 201 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 201 insertions(+) create mode 100644 LICENSE diff --git a/LICENSE b/LICENSE new file mode 100644 index 00000000..97846020 --- /dev/null +++ b/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + 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. From 8712a0d401b762e1bc42053b3719a256ee57940f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E5=8A=B2=E9=B9=8F?= Date: Wed, 4 Dec 2019 17:04:30 +0800 Subject: [PATCH 06/35] update rollup & typescript --- package-lock.json | 162 ++++++++++++++++++++++++++++++++++++++++------ package.json | 4 +- 2 files changed, 146 insertions(+), 20 deletions(-) diff --git a/package-lock.json b/package-lock.json index 40075af9..f1d3a996 100644 --- a/package-lock.json +++ b/package-lock.json @@ -5,14 +5,14 @@ "requires": true, "dependencies": { "@types/estree": { - "version": "0.0.39", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", - "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==" + "version": "0.0.40", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", + "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" }, "@types/node": { - "version": "12.12.7", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.7.tgz", - "integrity": "sha512-E6Zn0rffhgd130zbCbAr/JdXfXkoOUFAKNs/rF8qnafSJ8KYaA/j3oz7dcwal+lYjLA7xvdd5J4wdYpCTlP8+w==" + "version": "12.12.14", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.14.tgz", + "integrity": "sha512-u/SJDyXwuihpwjXy7hOOghagLEV1KdAST6syfnOk6QZAMzZuWZqXy5aYYZbh8Jdpd4escVFP0MvftHNDb9pruA==" }, "@types/resolve": { "version": "0.0.8", @@ -35,13 +35,132 @@ "doric": { "version": "file:../doric-js", "requires": { - "@types/ws": "^6.0.3", + "@types/ws": "^6.0.4", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.2", + "rollup": "^1.27.8", "rollup-plugin-node-resolve": "^5.2.0", "tslib": "^1.10.0", - "typescript": "^3.7.2", + "typescript": "^3.7.3", "ws": "^7.2.0" + }, + "dependencies": { + "@types/estree": { + "version": "0.0.40", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", + "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" + }, + "@types/node": { + "version": "12.12.14", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.14.tgz", + "integrity": "sha512-u/SJDyXwuihpwjXy7hOOghagLEV1KdAST6syfnOk6QZAMzZuWZqXy5aYYZbh8Jdpd4escVFP0MvftHNDb9pruA==" + }, + "@types/resolve": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", + "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", + "requires": { + "@types/node": "*" + } + }, + "@types/ws": { + "version": "6.0.4", + "resolved": "https://registry.npmjs.org/@types/ws/-/ws-6.0.4.tgz", + "integrity": "sha512-PpPrX7SZW9re6+Ha8ojZG4Se8AZXgf0GK6zmfqEuCsY49LFDNXO3SByp44X3dFEqtB73lkCDAdUazhAjVPiNwg==", + "requires": { + "@types/node": "*" + } + }, + "acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" + }, + "builtin-modules": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", + "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" + }, + "estree-walker": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", + "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" + }, + "is-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", + "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + }, + "reflect-metadata": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", + "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" + }, + "resolve": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", + "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "rollup": { + "version": "1.27.8", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.8.tgz", + "integrity": "sha512-EVoEV5rAWl+5clnGznt1KY8PeVkzVQh/R0d2s3gHEkN7gfoyC4JmvIVuCtPbYE8NM5Ep/g+nAmvKXBjzaqTsHA==", + "requires": { + "@types/estree": "*", + "@types/node": "*", + "acorn": "^7.1.0" + } + }, + "rollup-plugin-node-resolve": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", + "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", + "requires": { + "@types/resolve": "0.0.8", + "builtin-modules": "^3.1.0", + "is-module": "^1.0.0", + "resolve": "^1.11.1", + "rollup-pluginutils": "^2.8.1" + } + }, + "rollup-pluginutils": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", + "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", + "requires": { + "estree-walker": "^0.6.1" + } + }, + "tslib": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", + "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" + }, + "typescript": { + "version": "3.7.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.3.tgz", + "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==" + }, + "ws": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", + "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", + "requires": { + "async-limiter": "^1.0.0" + } + } } }, "estree-walker": { @@ -60,6 +179,13 @@ "integrity": "sha512-uJA/CDPO3Tao3GTrxYn6AwkM4nUPJiGGYu5+cB8qbC7WGFlrKZbiRo7SFKxUAEpFUfiHofWCXBUNhvYJMh+6zw==", "requires": { "@types/estree": "0.0.39" + }, + "dependencies": { + "@types/estree": { + "version": "0.0.39", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", + "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==" + } } }, "magic-string": { @@ -81,17 +207,17 @@ "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" }, "resolve": { - "version": "1.12.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", - "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", + "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", "requires": { "path-parse": "^1.0.6" } }, "rollup": { - "version": "1.27.2", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.2.tgz", - "integrity": "sha512-sD3iyd0zlvgK1S3MmICi6F/Y+R/QWY5XxzsTGN4pAd+nCasDUizmAhgq2hdh1t2eLux974NHU2TW41fhuGPv+Q==", + "version": "1.27.8", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.8.tgz", + "integrity": "sha512-EVoEV5rAWl+5clnGznt1KY8PeVkzVQh/R0d2s3gHEkN7gfoyC4JmvIVuCtPbYE8NM5Ep/g+nAmvKXBjzaqTsHA==", "requires": { "@types/estree": "*", "@types/node": "*", @@ -141,9 +267,9 @@ "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" }, "typescript": { - "version": "3.7.2", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.2.tgz", - "integrity": "sha512-ml7V7JfiN2Xwvcer+XAf2csGO1bPBdRbFCkYBczNZggrBZ9c7G3riSUeJmqEU5uOtXNPMhE3n+R4FA/3YOAWOQ==" + "version": "3.7.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.3.tgz", + "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==" } } } diff --git a/package.json b/package.json index 5cbba9e2..6ec581e9 100644 --- a/package.json +++ b/package.json @@ -12,10 +12,10 @@ "dependencies": { "doric": "file:../doric-js", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.2", + "rollup": "^1.27.8", "rollup-plugin-commonjs": "^10.1.0", "rollup-plugin-node-resolve": "^5.2.0", "tslib": "^1.10.0", - "typescript": "^3.7.2" + "typescript": "^3.7.3" } } From 82c338bf76c9f9159cddc8dd4beb6ea90f57900c Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 4 Dec 2019 18:15:41 +0800 Subject: [PATCH 07/35] feat:sync lost changes --- src/ComplicatedDemo.ts | 22 ++++++++++++++++------ src/Counter.ts | 6 ++++++ src/ListDemo.ts | 2 +- src/RefreshableDemo.ts | 2 +- src/utils.ts | 4 ++-- 5 files changed, 26 insertions(+), 10 deletions(-) diff --git a/src/ComplicatedDemo.ts b/src/ComplicatedDemo.ts index c4c4db2f..203f2878 100644 --- a/src/ComplicatedDemo.ts +++ b/src/ComplicatedDemo.ts @@ -1,5 +1,5 @@ -import { Panel, Group, vlayout, image, layoutConfig, ScaleType, refreshable, Color, pullable, stack, Image, Refreshable, TranslationAnimation, loge, log } from "doric"; -import { title, icon_refresh } from "./utils"; +import { Panel, Group, vlayout, image, layoutConfig, ScaleType, refreshable, Color, pullable, stack, Image, Refreshable, TranslationAnimation, loge, log, list, listItem, text } from "doric"; +import { title, icon_refresh, colors } from "./utils"; @Entry class MyDemo extends Panel { @@ -11,7 +11,7 @@ class MyDemo extends Panel { onRefresh: () => { refreshed.setRefreshing(context, false) }, - header: pullable(context, + header: pullable( stack([]).apply({ backgroundColor: Color.RED, layoutConfig: layoutConfig().exactly(), @@ -25,11 +25,21 @@ class MyDemo extends Panel { }, setPullingDistance: (distance: number) => { headerImage.scaleX = headerImage.scaleY = (headerImage.height + distance * 2) / headerImage.height - log(`Header Image scaleY:${headerImage.scaleY},height:${headerImage.height},distance:${distance}`) }, }), - content: vlayout([]).apply({ - backgroundColor: Color.YELLOW, + content: list({ + itemCount: 20, + renderItem: (idx) => { + return listItem(text({ + text: `Item :${idx}`, + layoutConfig: layoutConfig().exactly(), + width: root.width, + height: 50, + textColor: Color.WHITE, + backgroundColor: colors[idx % colors.length], + })) + } + }).apply({ }), }).apply({ layoutConfig: layoutConfig().atmost(), diff --git a/src/Counter.ts b/src/Counter.ts index 3b152919..32f4f5e5 100644 --- a/src/Counter.ts +++ b/src/Counter.ts @@ -31,6 +31,12 @@ class CounterView extends ViewHolder { widthSpec: LayoutSpec.WRAP_CONTENT, heightSpec: LayoutSpec.WRAP_CONTENT, }, + padding: { + left: 10, + right: 10, + top: 10, + bottom: 10, + }, shadow: { color: Color.parse("#00ff00"), opacity: 0.5, diff --git a/src/ListDemo.ts b/src/ListDemo.ts index ebd5c186..bd416a0f 100644 --- a/src/ListDemo.ts +++ b/src/ListDemo.ts @@ -91,7 +91,7 @@ class ListPanel extends Panel { }) }) }, - header: rotatedArrow(context), + header: rotatedArrow(), content: list({ itemCount: 0, renderItem: () => new ListItem, diff --git a/src/RefreshableDemo.ts b/src/RefreshableDemo.ts index b91c7e02..3d9d30c8 100644 --- a/src/RefreshableDemo.ts +++ b/src/RefreshableDemo.ts @@ -13,7 +13,7 @@ class RefreshableDemo extends Panel { refreshView.setRefreshing(context, false) }, 5000) }, - header: pullable(context, + header: pullable( stack([ image({ layoutConfig: layoutConfig().exactly().m({ top: 50, bottom: 10, }), diff --git a/src/utils.ts b/src/utils.ts index 9e7e7610..c8d98f37 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -48,9 +48,9 @@ export function title(str: string) { }) } -export function rotatedArrow(context: BridgeContext) { +export function rotatedArrow() { let refreshImage: Image - return pullable(context, + return pullable( stack([ image({ layoutConfig: layoutConfig().exactly().m({ top: 50, bottom: 10, }), From 64a703b83bccfaaeacba399ef37550662deb9d91 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 4 Dec 2019 18:17:12 +0800 Subject: [PATCH 08/35] update package-lock.json --- package-lock.json | 125 ++-------------------------------------------- 1 file changed, 3 insertions(+), 122 deletions(-) diff --git a/package-lock.json b/package-lock.json index f1d3a996..569d975d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -35,132 +35,13 @@ "doric": { "version": "file:../doric-js", "requires": { - "@types/ws": "^6.0.4", + "@types/ws": "^6.0.3", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.8", + "rollup": "^1.27.2", "rollup-plugin-node-resolve": "^5.2.0", "tslib": "^1.10.0", - "typescript": "^3.7.3", + "typescript": "^3.7.2", "ws": "^7.2.0" - }, - "dependencies": { - "@types/estree": { - "version": "0.0.40", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", - "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" - }, - "@types/node": { - "version": "12.12.14", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.14.tgz", - "integrity": "sha512-u/SJDyXwuihpwjXy7hOOghagLEV1KdAST6syfnOk6QZAMzZuWZqXy5aYYZbh8Jdpd4escVFP0MvftHNDb9pruA==" - }, - "@types/resolve": { - "version": "0.0.8", - "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", - "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", - "requires": { - "@types/node": "*" - } - }, - "@types/ws": { - "version": "6.0.4", - "resolved": "https://registry.npmjs.org/@types/ws/-/ws-6.0.4.tgz", - "integrity": "sha512-PpPrX7SZW9re6+Ha8ojZG4Se8AZXgf0GK6zmfqEuCsY49LFDNXO3SByp44X3dFEqtB73lkCDAdUazhAjVPiNwg==", - "requires": { - "@types/node": "*" - } - }, - "acorn": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", - "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" - }, - "async-limiter": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", - "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" - }, - "builtin-modules": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", - "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" - }, - "estree-walker": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", - "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" - }, - "is-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", - "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" - }, - "path-parse": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", - "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" - }, - "reflect-metadata": { - "version": "0.1.13", - "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", - "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" - }, - "resolve": { - "version": "1.13.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", - "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", - "requires": { - "path-parse": "^1.0.6" - } - }, - "rollup": { - "version": "1.27.8", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.8.tgz", - "integrity": "sha512-EVoEV5rAWl+5clnGznt1KY8PeVkzVQh/R0d2s3gHEkN7gfoyC4JmvIVuCtPbYE8NM5Ep/g+nAmvKXBjzaqTsHA==", - "requires": { - "@types/estree": "*", - "@types/node": "*", - "acorn": "^7.1.0" - } - }, - "rollup-plugin-node-resolve": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", - "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", - "requires": { - "@types/resolve": "0.0.8", - "builtin-modules": "^3.1.0", - "is-module": "^1.0.0", - "resolve": "^1.11.1", - "rollup-pluginutils": "^2.8.1" - } - }, - "rollup-pluginutils": { - "version": "2.8.2", - "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", - "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", - "requires": { - "estree-walker": "^0.6.1" - } - }, - "tslib": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", - "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" - }, - "typescript": { - "version": "3.7.3", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.3.tgz", - "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==" - }, - "ws": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", - "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", - "requires": { - "async-limiter": "^1.0.0" - } - } } }, "estree-walker": { From 540177f77ae404136ac7d1df1b457c6238aea59a Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Fri, 6 Dec 2019 11:41:51 +0800 Subject: [PATCH 09/35] update demo --- src/Counter.ts | 17 +++++------------ src/Snake.ts | 8 +++++--- 2 files changed, 10 insertions(+), 15 deletions(-) diff --git a/src/Counter.ts b/src/Counter.ts index 32f4f5e5..76f4852e 100644 --- a/src/Counter.ts +++ b/src/Counter.ts @@ -3,9 +3,7 @@ import { text, vlayout, Image, ViewHolder, VMPanel, ViewModel, Gravity, NativeCa interface CountModel { count: number } - -class CounterView extends ViewHolder { - +class CounterView extends ViewHolder { number!: Text counter!: Text build(root: Group) { @@ -76,24 +74,19 @@ class CounterView extends ViewHolder { } })) } - - bind(state: CountModel) { - this.number.text = `${state.count}` - } - - setCounter(v: Function) { - this.counter.onClick = v - } } class CounterVM extends ViewModel { - onAttached(s: CountModel, vh: CounterView): void { + onAttached(s: CountModel, vh: CounterView) { vh.counter.onClick = () => { this.updateState(state => { state.count++ }) } } + onBind(s: CountModel, vh: CounterView) { + vh.number.text = `${s.count}` + } } @Entry diff --git a/src/Snake.ts b/src/Snake.ts index 05bcba33..962835c4 100644 --- a/src/Snake.ts +++ b/src/Snake.ts @@ -134,7 +134,7 @@ class SnakeModel { } } -class SnakeView extends ViewHolder { +class SnakeView extends ViewHolder { panel!: Stack start?: Text @@ -346,14 +346,16 @@ class SnakeVM extends ViewModel{ this.updateState(it => it.direction = Direction.down) } - onAttached(state: SnakeModel, v: SnakeView): void { + onAttached(state: SnakeModel, v: SnakeView) { takeNonNull(v.start)(it => it.onClick = this.start) takeNonNull(v.left)(it => it.onClick = this.left) takeNonNull(v.right)(it => it.onClick = this.right) takeNonNull(v.up)(it => it.onClick = this.up) takeNonNull(v.down)(it => it.onClick = this.down) } - + onBind(state: SnakeModel, v: SnakeView) { + v.bind(state) + } } @Entry class SnakePanel extends VMPanel{ From 7d83431d6841014b5eadca95fd950b57378c03f5 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Sat, 7 Dec 2019 15:50:37 +0800 Subject: [PATCH 10/35] add input and stick demo --- index.ts | 2 + src/InputDemo.ts | 47 ++++++++++++++++++ src/StickDemo.ts | 124 +++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 173 insertions(+) create mode 100644 src/InputDemo.ts create mode 100644 src/StickDemo.ts diff --git a/index.ts b/index.ts index bd7e494d..2fbf2642 100644 --- a/index.ts +++ b/index.ts @@ -18,4 +18,6 @@ export default [ 'src/AnimatorDemo', 'src/ComplicatedAnimations', 'src/ComplicatedDemo', + 'src/InputDemo', + 'src/StickDemo' ] \ No newline at end of file diff --git a/src/InputDemo.ts b/src/InputDemo.ts new file mode 100644 index 00000000..e1222045 --- /dev/null +++ b/src/InputDemo.ts @@ -0,0 +1,47 @@ +import { Panel, Group, scroller, vlayout, layoutConfig, LayoutSpec, Input, Gravity, log } from "doric"; +import { title, colors } from "./utils"; +@Entry +class InputDemo extends Panel { + build(root: Group) { + scroller( + vlayout([ + title("Input Demo"), + (new Input).also(it => { + it.layoutConfig = layoutConfig().exactly().h(LayoutSpec.WRAP_CONTENT) + it.width = 300 + it.multiline = false + it.hintText = "HintText" + it.textAlignment = Gravity.Left + it.onTextChange = (s) => { + log(`onTextChange:${s}`) + } + it.onFocusChange = (f) => { + log(`onFocusChange:${f}`) + } + }), + (new Input).also(it => { + it.layoutConfig = layoutConfig().wrap() + it.hintText = "HintText" + it.hintTextColor = colors[2] + it.textAlignment = Gravity.Left + it.textColor = colors[3] + it.onTextChange = (s) => { + log(`onTextChange:${s}`) + } + it.onFocusChange = (f) => { + log(`onFocusChange:${f}`) + } + it.backgroundColor = colors[1].alpha(0.3) + }), + ]) + .also(it => { + it.space = 10 + it.layoutConfig = layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT) + })) + .apply({ + layoutConfig: layoutConfig().atmost() + }) + .in(root) + } + +} \ No newline at end of file diff --git a/src/StickDemo.ts b/src/StickDemo.ts new file mode 100644 index 00000000..433609ae --- /dev/null +++ b/src/StickDemo.ts @@ -0,0 +1,124 @@ +import { Panel, Group, scroller, vlayout, layoutConfig, LayoutSpec, Input, Gravity, log, stack, hlayout, text, IHLayout, CENTER, slider, slideItem, modal, Slider, Text, Color, View, Stack, animate, flowlayout, FlowLayoutItem, NestedSlider } from "doric"; +import { title, colors } from "./utils"; + +function tab(idx: number, title: string, sliderView: Slider) { + return text({ + text: title, + layoutConfig: layoutConfig().exactly().wg(1), + height: 41, + onClick: () => { + sliderView.slidePage(context, 0, true) + }, + }) +} + +@Entry +class StickDemo extends Panel { + private tabs!: Text[] + private indicator!: View + private sliderView!: NestedSlider + build(root: Group) { + this.indicator = new Stack + this.indicator.backgroundColor = colors[0] + this.indicator.width = 20 + this.indicator.height = 2 + + scroller( + vlayout([ + stack([]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY), + height: 200, + backgroundColor: colors[0], + }), + stack([ + hlayout([ + ...this.tabs = [0, 1, 2].map(idx => { + return text({ + text: `Tab ${idx}`, + layoutConfig: layoutConfig().exactly().wg(1), + height: 41, + onClick: () => { + this.sliderView.slidePage(context, idx, true) + }, + }) + }) + ]).apply({ + layoutConfig: layoutConfig().atmost(), + gravity: Gravity.Center, + } as IHLayout), + this.indicator, + ]).apply({ + layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY), + height: 57, + }), + + (new NestedSlider).also(v => { + this.sliderView = v; + v.onPageSlided = (idx) => { + this.refreshTabs(idx) + } + [0, 1, 2].map(idx => { + return flowlayout({ + layoutConfig: layoutConfig().exactly(), + width: root.width, + height: root.height - 57, + itemCount: 100, + columnCount: 2, + columnSpace: 10, + rowSpace: 10, + renderItem: (itemIdx) => { + return new FlowLayoutItem().apply({ + backgroundColor: colors[itemIdx % colors.length], + height: 50, + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + }).also(it => { + it.addChild(text({ + text: `In Page ${idx},${itemIdx}`, + textColor: Color.WHITE, + textSize: 20, + layoutConfig: layoutConfig().wrap().a(Gravity.Center) + }).also(v => { + v.onClick = () => { + v.text = "Clicked" + } + })) + }) + }, + }) + }).forEach(e => { + v.addSlideItem(e) + }) + }).apply({ + layoutConfig: layoutConfig().exactly(), + width: root.width, + height: root.height - 57, + }), + ]) + .also(it => { + it.layoutConfig = layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT) + })) + .apply({ + layoutConfig: layoutConfig().atmost() + }) + .in(root) + this.indicator.centerX = this.getRootView().width / this.tabs.length / 2 + this.refreshTabs(0) + } + + refreshTabs(page: number) { + this.tabs.forEach((e, idx) => { + if (idx == page) { + e.textColor = colors[0] + } else { + e.textColor = Color.BLACK + } + }) + this.indicator.layoutConfig = layoutConfig().exactly().a(Gravity.Bottom).m({ bottom: 13 }) + animate(this)({ + animations: () => { + this.indicator.centerX = this.getRootView().width / this.tabs.length * (page + 0.5) + }, + duration: 300, + }) + } +} \ No newline at end of file From 59acec65951101472b2cbed46b275265ada15bad Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Mon, 9 Dec 2019 20:34:28 +0800 Subject: [PATCH 11/35] feat:navigator add extra --- src/NavigatorDemo.ts | 12 ++++++++++-- src/StickDemo.ts | 11 +++++++++-- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/src/NavigatorDemo.ts b/src/NavigatorDemo.ts index 03796ef5..b5ae7eca 100644 --- a/src/NavigatorDemo.ts +++ b/src/NavigatorDemo.ts @@ -1,8 +1,11 @@ -import { Panel, scroller, vlayout, text, layoutConfig, LayoutSpec, Color, gravity, IVLayout, Group, IText, navigator } from "doric"; +import { Panel, scroller, vlayout, text, layoutConfig, LayoutSpec, Color, gravity, IVLayout, Group, IText, navigator, modal } from "doric"; import { colors, label } from "./utils"; @Entry class NaivgatorDemo extends Panel { build(root: Group) { + if (this.getInitData()) { + modal(context).alert(`Init Data :${JSON.stringify(this.getInitData())}`) + } scroller(vlayout([ text({ text: "Navigator Demo", @@ -25,7 +28,12 @@ class NaivgatorDemo extends Panel { textColor: Color.WHITE, layoutConfig: layoutConfig().exactly().w(LayoutSpec.AT_MOST), onClick: () => { - navigator(context).push(`assets://demo/${e}.js`, `${e}.js`) + navigator(context).push(`assets://demo/${e}.js`, { + alias: `${e}.js`, + extra: { + from: "navigatorDemo" + }, + }) }, } as IText) ), diff --git a/src/StickDemo.ts b/src/StickDemo.ts index 433609ae..43d9b3b6 100644 --- a/src/StickDemo.ts +++ b/src/StickDemo.ts @@ -1,4 +1,4 @@ -import { Panel, Group, scroller, vlayout, layoutConfig, LayoutSpec, Input, Gravity, log, stack, hlayout, text, IHLayout, CENTER, slider, slideItem, modal, Slider, Text, Color, View, Stack, animate, flowlayout, FlowLayoutItem, NestedSlider } from "doric"; +import { Panel, Group, scroller, vlayout, image, layoutConfig, LayoutSpec, Input, Gravity, log, stack, hlayout, text, IHLayout, CENTER, slider, slideItem, modal, Slider, Text, Color, View, Stack, animate, flowlayout, FlowLayoutItem, NestedSlider, ScaleType } from "doric"; import { title, colors } from "./utils"; function tab(idx: number, title: string, sliderView: Slider) { @@ -25,7 +25,14 @@ class StickDemo extends Panel { scroller( vlayout([ - stack([]).apply({ + stack([ + image({ + layoutConfig: layoutConfig().atmost(), + imageUrl: "https://p.upyun.com/demo/webp/webp/jpg-0.webp", + scaleType: ScaleType.ScaleAspectFill, + }), + + ]).apply({ layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY), height: 200, backgroundColor: colors[0], From ecd40b9641b14f9761f2b3446f445439b4347bca Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 10 Dec 2019 20:32:17 +0800 Subject: [PATCH 12/35] feat:add list onLoadMore --- src/ListDemo.ts | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/src/ListDemo.ts b/src/ListDemo.ts index bd416a0f..b5ec9ee4 100644 --- a/src/ListDemo.ts +++ b/src/ListDemo.ts @@ -1,4 +1,4 @@ -import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, refreshable, Refreshable, ListItem } from "doric"; +import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, refreshable, Refreshable, ListItem, layoutConfig } from "doric"; import { rotatedArrow, colors } from "./utils"; @Entry class ListPanel extends Panel { @@ -25,6 +25,17 @@ class ListPanel extends Panel { it.reset() offset = Math.ceil(Math.random() * colors.length) it.itemCount = 40 + it.loadMore = true + it.onLoadMore = () => { + setTimeout(() => { + it.itemCount += 10 + }, 1000) + } + it.loadMoreView = listItem(text({ + text: "Loading", + layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY).a(Gravity.Center), + height: 50, + })) it.renderItem = (idx: number) => { let counter!: Text return listItem( From 83d8da4b9ce9e9cabf248b236285fc9a982fc2e8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E5=8A=B2=E9=B9=8F?= Date: Thu, 12 Dec 2019 11:59:46 +0800 Subject: [PATCH 13/35] update dependency --- package-lock.json | 137 +++++++++++++++++++++++++++++++++++++++++++--- package.json | 2 +- 2 files changed, 129 insertions(+), 10 deletions(-) diff --git a/package-lock.json b/package-lock.json index 569d975d..29b2b4d5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,9 +10,9 @@ "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" }, "@types/node": { - "version": "12.12.14", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.14.tgz", - "integrity": "sha512-u/SJDyXwuihpwjXy7hOOghagLEV1KdAST6syfnOk6QZAMzZuWZqXy5aYYZbh8Jdpd4escVFP0MvftHNDb9pruA==" + "version": "12.12.17", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.17.tgz", + "integrity": "sha512-Is+l3mcHvs47sKy+afn2O1rV4ldZFU7W8101cNlOd+MRbjM4Onida8jSZnJdTe/0Pcf25g9BNIUsuugmE6puHA==" }, "@types/resolve": { "version": "0.0.8", @@ -35,13 +35,132 @@ "doric": { "version": "file:../doric-js", "requires": { - "@types/ws": "^6.0.3", + "@types/ws": "^6.0.4", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.2", + "rollup": "^1.27.10", "rollup-plugin-node-resolve": "^5.2.0", "tslib": "^1.10.0", - "typescript": "^3.7.2", + "typescript": "^3.7.3", "ws": "^7.2.0" + }, + "dependencies": { + "@types/estree": { + "version": "0.0.40", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", + "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" + }, + "@types/node": { + "version": "12.12.17", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.17.tgz", + "integrity": "sha512-Is+l3mcHvs47sKy+afn2O1rV4ldZFU7W8101cNlOd+MRbjM4Onida8jSZnJdTe/0Pcf25g9BNIUsuugmE6puHA==" + }, + "@types/resolve": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", + "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", + "requires": { + "@types/node": "*" + } + }, + "@types/ws": { + "version": "6.0.4", + "resolved": "https://registry.npmjs.org/@types/ws/-/ws-6.0.4.tgz", + "integrity": "sha512-PpPrX7SZW9re6+Ha8ojZG4Se8AZXgf0GK6zmfqEuCsY49LFDNXO3SByp44X3dFEqtB73lkCDAdUazhAjVPiNwg==", + "requires": { + "@types/node": "*" + } + }, + "acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" + }, + "builtin-modules": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", + "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" + }, + "estree-walker": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", + "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" + }, + "is-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", + "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + }, + "reflect-metadata": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", + "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" + }, + "resolve": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", + "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "rollup": { + "version": "1.27.10", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.10.tgz", + "integrity": "sha512-5PjBSKney8zLu7tTn/y4iVBL3OyK+G9rA/wfkcY78bZ9kAMtgNqb8nOfR5KpoDYyt8Vs5o2o8DyDjf9RpwYbAg==", + "requires": { + "@types/estree": "*", + "@types/node": "*", + "acorn": "^7.1.0" + } + }, + "rollup-plugin-node-resolve": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", + "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", + "requires": { + "@types/resolve": "0.0.8", + "builtin-modules": "^3.1.0", + "is-module": "^1.0.0", + "resolve": "^1.11.1", + "rollup-pluginutils": "^2.8.1" + } + }, + "rollup-pluginutils": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", + "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", + "requires": { + "estree-walker": "^0.6.1" + } + }, + "tslib": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", + "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" + }, + "typescript": { + "version": "3.7.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.3.tgz", + "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==" + }, + "ws": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", + "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", + "requires": { + "async-limiter": "^1.0.0" + } + } } }, "estree-walker": { @@ -96,9 +215,9 @@ } }, "rollup": { - "version": "1.27.8", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.8.tgz", - "integrity": "sha512-EVoEV5rAWl+5clnGznt1KY8PeVkzVQh/R0d2s3gHEkN7gfoyC4JmvIVuCtPbYE8NM5Ep/g+nAmvKXBjzaqTsHA==", + "version": "1.27.10", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.10.tgz", + "integrity": "sha512-5PjBSKney8zLu7tTn/y4iVBL3OyK+G9rA/wfkcY78bZ9kAMtgNqb8nOfR5KpoDYyt8Vs5o2o8DyDjf9RpwYbAg==", "requires": { "@types/estree": "*", "@types/node": "*", diff --git a/package.json b/package.json index 6ec581e9..4bfba784 100644 --- a/package.json +++ b/package.json @@ -12,7 +12,7 @@ "dependencies": { "doric": "file:../doric-js", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.8", + "rollup": "^1.27.10", "rollup-plugin-commonjs": "^10.1.0", "rollup-plugin-node-resolve": "^5.2.0", "tslib": "^1.10.0", From 4569e6416a8e58820c78a9a3248a925375018dce Mon Sep 17 00:00:00 2001 From: yao <294149113@qq.com> Date: Thu, 12 Dec 2019 16:57:00 +0800 Subject: [PATCH 14/35] add image Blur --- src/ImageDemo.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/src/ImageDemo.ts b/src/ImageDemo.ts index 357a8e22..c1ca6830 100644 --- a/src/ImageDemo.ts +++ b/src/ImageDemo.ts @@ -53,6 +53,7 @@ class ImageDemo extends Panel { imageUrl, width: 300, height: 300, + isBlur: true, border: { width: 2, color: Color.GRAY, From 0be742d167b449e7ad685c431e9ae3760058934c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E5=8A=B2=E9=B9=8F?= Date: Fri, 13 Dec 2019 14:33:24 +0800 Subject: [PATCH 15/35] flow layout demo load more --- src/FlowLayoutDemo.ts | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/src/FlowLayoutDemo.ts b/src/FlowLayoutDemo.ts index f668cc08..5bc11e37 100644 --- a/src/FlowLayoutDemo.ts +++ b/src/FlowLayoutDemo.ts @@ -17,7 +17,7 @@ class FlowDemo extends Panel { build(rootView: Group): void { flowlayout({ layoutConfig: layoutConfig().atmost(), - itemCount: 500, + itemCount: 100, columnCount: 3, columnSpace: 10, rowSpace: 10, @@ -35,6 +35,25 @@ class FlowDemo extends Panel { })) }) }, + }).also(it => { + it.loadMore = true + it.onLoadMore = () => { + setTimeout(() => { + it.itemCount += 20 + }, 1000) + } + it.loadMoreView = new FlowLayoutItem().apply({ + backgroundColor: colors[500 % colors.length], + height: 50, + layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + }).also(it => { + it.addChild(text({ + text: 'load more', + textColor: Color.WHITE, + textSize: 20, + layoutConfig: layoutConfig().wrap().a(Gravity.Center) + })) + }) }) .in(rootView) } From b238485894915508b20af815c136b691fd1966a4 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Sat, 14 Dec 2019 11:30:56 +0800 Subject: [PATCH 16/35] feat:update demo --- src/AnimatorDemo.ts | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/src/AnimatorDemo.ts b/src/AnimatorDemo.ts index 185acd51..723c9776 100644 --- a/src/AnimatorDemo.ts +++ b/src/AnimatorDemo.ts @@ -29,7 +29,7 @@ class AnimatorDemo extends Panel { hlayout([ thisLabel('Reset').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { view.width = view.height = 20 view.x = view.y = 0 @@ -54,7 +54,7 @@ class AnimatorDemo extends Panel { hlayout([ thisLabel('X').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { view.x = view.x || 0 view.x += 100 @@ -66,7 +66,7 @@ class AnimatorDemo extends Panel { }), thisLabel('Y').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { view.y = view.y || 0 view.y += 100 @@ -78,7 +78,7 @@ class AnimatorDemo extends Panel { }), thisLabel('Width').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { view.width += 100 }, @@ -88,7 +88,7 @@ class AnimatorDemo extends Panel { }), thisLabel('Height').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { view.height += 100 }, @@ -100,7 +100,7 @@ class AnimatorDemo extends Panel { hlayout([ thisLabel('BgColor').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { view.backgroundColor = colors[(idx++) % colors.length] }, @@ -110,7 +110,7 @@ class AnimatorDemo extends Panel { }), thisLabel('Rotation').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { if (view.rotation) { view.rotation += 0.5 @@ -124,7 +124,7 @@ class AnimatorDemo extends Panel { }), thisLabel('Corner').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { if (typeof view.corners === 'number') { view.corners += 10 @@ -141,7 +141,7 @@ class AnimatorDemo extends Panel { hlayout([ thisLabel('scaleX').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { if (view.scaleX) { view.scaleX += 0.1 @@ -155,7 +155,7 @@ class AnimatorDemo extends Panel { }), thisLabel('scaleY').apply({ onClick: () => { - animate(this)({ + animate(context)({ animations: () => { if (view.scaleY) { view.scaleY += 0.1 From 74ee52ed09a8df23d279de945a23613fa2f34fed Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Sat, 14 Dec 2019 14:20:05 +0800 Subject: [PATCH 17/35] update demo --- package-lock.json | 119 ---------------------------------------------- src/StickDemo.ts | 2 +- 2 files changed, 1 insertion(+), 120 deletions(-) diff --git a/package-lock.json b/package-lock.json index 29b2b4d5..7ffbe636 100644 --- a/package-lock.json +++ b/package-lock.json @@ -42,125 +42,6 @@ "tslib": "^1.10.0", "typescript": "^3.7.3", "ws": "^7.2.0" - }, - "dependencies": { - "@types/estree": { - "version": "0.0.40", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", - "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" - }, - "@types/node": { - "version": "12.12.17", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.17.tgz", - "integrity": "sha512-Is+l3mcHvs47sKy+afn2O1rV4ldZFU7W8101cNlOd+MRbjM4Onida8jSZnJdTe/0Pcf25g9BNIUsuugmE6puHA==" - }, - "@types/resolve": { - "version": "0.0.8", - "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", - "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", - "requires": { - "@types/node": "*" - } - }, - "@types/ws": { - "version": "6.0.4", - "resolved": "https://registry.npmjs.org/@types/ws/-/ws-6.0.4.tgz", - "integrity": "sha512-PpPrX7SZW9re6+Ha8ojZG4Se8AZXgf0GK6zmfqEuCsY49LFDNXO3SByp44X3dFEqtB73lkCDAdUazhAjVPiNwg==", - "requires": { - "@types/node": "*" - } - }, - "acorn": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", - "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" - }, - "async-limiter": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", - "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" - }, - "builtin-modules": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", - "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" - }, - "estree-walker": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", - "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" - }, - "is-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", - "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" - }, - "path-parse": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", - "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" - }, - "reflect-metadata": { - "version": "0.1.13", - "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", - "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" - }, - "resolve": { - "version": "1.13.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", - "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", - "requires": { - "path-parse": "^1.0.6" - } - }, - "rollup": { - "version": "1.27.10", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.10.tgz", - "integrity": "sha512-5PjBSKney8zLu7tTn/y4iVBL3OyK+G9rA/wfkcY78bZ9kAMtgNqb8nOfR5KpoDYyt8Vs5o2o8DyDjf9RpwYbAg==", - "requires": { - "@types/estree": "*", - "@types/node": "*", - "acorn": "^7.1.0" - } - }, - "rollup-plugin-node-resolve": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", - "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", - "requires": { - "@types/resolve": "0.0.8", - "builtin-modules": "^3.1.0", - "is-module": "^1.0.0", - "resolve": "^1.11.1", - "rollup-pluginutils": "^2.8.1" - } - }, - "rollup-pluginutils": { - "version": "2.8.2", - "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", - "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", - "requires": { - "estree-walker": "^0.6.1" - } - }, - "tslib": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", - "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" - }, - "typescript": { - "version": "3.7.3", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.3.tgz", - "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==" - }, - "ws": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", - "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", - "requires": { - "async-limiter": "^1.0.0" - } - } } }, "estree-walker": { diff --git a/src/StickDemo.ts b/src/StickDemo.ts index 43d9b3b6..3f74e083 100644 --- a/src/StickDemo.ts +++ b/src/StickDemo.ts @@ -121,7 +121,7 @@ class StickDemo extends Panel { } }) this.indicator.layoutConfig = layoutConfig().exactly().a(Gravity.Bottom).m({ bottom: 13 }) - animate(this)({ + animate(context)({ animations: () => { this.indicator.centerX = this.getRootView().width / this.tabs.length * (page + 0.5) }, From 02dc70270175d78a1f389e4c877e37ddbd63bf61 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E5=8A=B2=E9=B9=8F?= Date: Sat, 14 Dec 2019 15:36:52 +0800 Subject: [PATCH 18/35] update deps --- package-lock.json | 125 ++++++++++++++++++++++++++++++++++++++++++++-- package.json | 2 +- 2 files changed, 123 insertions(+), 4 deletions(-) diff --git a/package-lock.json b/package-lock.json index 7ffbe636..b074ffed 100644 --- a/package-lock.json +++ b/package-lock.json @@ -42,6 +42,125 @@ "tslib": "^1.10.0", "typescript": "^3.7.3", "ws": "^7.2.0" + }, + "dependencies": { + "@types/estree": { + "version": "0.0.40", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", + "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" + }, + "@types/node": { + "version": "12.12.17", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.17.tgz", + "integrity": "sha512-Is+l3mcHvs47sKy+afn2O1rV4ldZFU7W8101cNlOd+MRbjM4Onida8jSZnJdTe/0Pcf25g9BNIUsuugmE6puHA==" + }, + "@types/resolve": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", + "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", + "requires": { + "@types/node": "*" + } + }, + "@types/ws": { + "version": "6.0.4", + "resolved": "https://registry.npmjs.org/@types/ws/-/ws-6.0.4.tgz", + "integrity": "sha512-PpPrX7SZW9re6+Ha8ojZG4Se8AZXgf0GK6zmfqEuCsY49LFDNXO3SByp44X3dFEqtB73lkCDAdUazhAjVPiNwg==", + "requires": { + "@types/node": "*" + } + }, + "acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" + }, + "builtin-modules": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", + "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==" + }, + "estree-walker": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", + "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==" + }, + "is-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", + "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + }, + "reflect-metadata": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", + "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" + }, + "resolve": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", + "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "rollup": { + "version": "1.27.12", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.12.tgz", + "integrity": "sha512-51iR7n6NQfdQJlRrIktaGmkdt395A8Vue7CdnlrK6UhY9DY2GaKsTdljWeXisJuZh+w90Gz8VFNh5X+yxP20oQ==", + "requires": { + "@types/estree": "*", + "@types/node": "*", + "acorn": "^7.1.0" + } + }, + "rollup-plugin-node-resolve": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", + "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", + "requires": { + "@types/resolve": "0.0.8", + "builtin-modules": "^3.1.0", + "is-module": "^1.0.0", + "resolve": "^1.11.1", + "rollup-pluginutils": "^2.8.1" + } + }, + "rollup-pluginutils": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", + "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", + "requires": { + "estree-walker": "^0.6.1" + } + }, + "tslib": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", + "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" + }, + "typescript": { + "version": "3.7.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.3.tgz", + "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==" + }, + "ws": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", + "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", + "requires": { + "async-limiter": "^1.0.0" + } + } } }, "estree-walker": { @@ -96,9 +215,9 @@ } }, "rollup": { - "version": "1.27.10", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.10.tgz", - "integrity": "sha512-5PjBSKney8zLu7tTn/y4iVBL3OyK+G9rA/wfkcY78bZ9kAMtgNqb8nOfR5KpoDYyt8Vs5o2o8DyDjf9RpwYbAg==", + "version": "1.27.12", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.12.tgz", + "integrity": "sha512-51iR7n6NQfdQJlRrIktaGmkdt395A8Vue7CdnlrK6UhY9DY2GaKsTdljWeXisJuZh+w90Gz8VFNh5X+yxP20oQ==", "requires": { "@types/estree": "*", "@types/node": "*", diff --git a/package.json b/package.json index 4bfba784..c8f9338a 100644 --- a/package.json +++ b/package.json @@ -12,7 +12,7 @@ "dependencies": { "doric": "file:../doric-js", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.10", + "rollup": "^1.27.12", "rollup-plugin-commonjs": "^10.1.0", "rollup-plugin-node-resolve": "^5.2.0", "tslib": "^1.10.0", From 02615bc17e52421ad103797c7209c9c852b5a552 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Sat, 14 Dec 2019 16:32:04 +0800 Subject: [PATCH 19/35] update demo --- src/AnimatorDemo.ts | 6 +- src/ComplicatedAnimations.ts | 6 +- src/ComplicatedDemo.ts | 8 +-- src/Counter.ts | 12 ++-- src/EffectsDemo.ts | 34 ++++----- src/FlowLayoutDemo.ts | 10 +-- src/ImageDemo.ts | 14 ++-- src/InputDemo.ts | 8 +-- src/LayoutDemo.ts | 134 +++++++++++++++++------------------ src/ListDemo.ts | 30 ++++---- src/ModalDemo.ts | 24 +++---- src/NavbarDemo.ts | 14 ++-- src/NavigatorDemo.ts | 10 +-- src/NetworkDemo.ts | 6 +- src/PopoverDemo.ts | 8 +-- src/RefreshableDemo.ts | 14 ++-- src/ScrollerDemo.ts | 6 +- src/SliderDemo.ts | 14 ++-- src/Snake.ts | 44 ++++++------ src/StickDemo.ts | 26 +++---- src/StorageDemo.ts | 14 ++-- src/utils.ts | 4 +- 22 files changed, 223 insertions(+), 223 deletions(-) diff --git a/src/AnimatorDemo.ts b/src/AnimatorDemo.ts index 723c9776..d5335d0c 100644 --- a/src/AnimatorDemo.ts +++ b/src/AnimatorDemo.ts @@ -9,7 +9,7 @@ function thisLabel(str: string) { backgroundColor: colors[0], textSize: 15, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), }) } @@ -173,11 +173,11 @@ class AnimatorDemo extends Panel { stack([ view, ]).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), backgroundColor: colors[1].alpha(0.3 * 255), }), ]).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), gravity: gravity().center(), space: 10, } as IVLayout).in(rootView) diff --git a/src/ComplicatedAnimations.ts b/src/ComplicatedAnimations.ts index bc477830..bf437b59 100644 --- a/src/ComplicatedAnimations.ts +++ b/src/ComplicatedAnimations.ts @@ -9,7 +9,7 @@ function thisLabel(str: string) { backgroundColor: colors[0], textSize: 10, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), }) } @@ -190,11 +190,11 @@ class AnimationDemo extends Panel { v.scaleX = 1.5 }) ]).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), backgroundColor: colors[1].alpha(0.3 * 255), }), ]).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), gravity: gravity().center(), space: 10, } as IVLayout).in(rootView) diff --git a/src/ComplicatedDemo.ts b/src/ComplicatedDemo.ts index 203f2878..e5620aaf 100644 --- a/src/ComplicatedDemo.ts +++ b/src/ComplicatedDemo.ts @@ -14,7 +14,7 @@ class MyDemo extends Panel { header: pullable( stack([]).apply({ backgroundColor: Color.RED, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), width: 100, height: 30, }), @@ -32,7 +32,7 @@ class MyDemo extends Panel { renderItem: (idx) => { return listItem(text({ text: `Item :${idx}`, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), width: root.width, height: 50, textColor: Color.WHITE, @@ -42,14 +42,14 @@ class MyDemo extends Panel { }).apply({ }), }).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).also(v => { v.top = 200 }), headerImage = image({ imageUrl: "https://img.zcool.cn/community/01e75b5da933daa801209e1ffa4649.jpg@1280w_1l_2o_100sh.jpg", - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), width: root.width, height: 200, scaleType: ScaleType.ScaleAspectFill, diff --git a/src/Counter.ts b/src/Counter.ts index 76f4852e..96e9876e 100644 --- a/src/Counter.ts +++ b/src/Counter.ts @@ -12,8 +12,8 @@ class CounterView extends ViewHolder { textSize: 40, layoutConfig: { alignment: Gravity.Center, - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, }, }).also(it => { this.number = it }), text({ @@ -26,8 +26,8 @@ class CounterView extends ViewHolder { corners: 5, layoutConfig: { alignment: Gravity.Center, - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, }, padding: { left: 10, @@ -69,8 +69,8 @@ class CounterView extends ViewHolder { root.addChild((new Image).also(iv => { iv.imageUrl = "https://misc.aotu.io/ONE-SUNDAY/SteamEngine.png" iv.layoutConfig = { - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, } })) } diff --git a/src/EffectsDemo.ts b/src/EffectsDemo.ts index 126d6728..1914e360 100644 --- a/src/EffectsDemo.ts +++ b/src/EffectsDemo.ts @@ -50,7 +50,7 @@ class EffectsDemo extends Panel { width: 5, color: colors[3] }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -65,7 +65,7 @@ class EffectsDemo extends Panel { width: 100, height: 100, corners: 10, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ bottom: 10 }) }),]).apply({ @@ -84,7 +84,7 @@ class EffectsDemo extends Panel { offsetY: 3, radius: 5, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ bottom: 10 }) }),]).apply({ @@ -103,7 +103,7 @@ class EffectsDemo extends Panel { color: colors[3] }, corners: 10, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -128,7 +128,7 @@ class EffectsDemo extends Panel { offsetY: 3, radius: 5, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ bottom: 10 }) }),]).apply({ @@ -148,7 +148,7 @@ class EffectsDemo extends Panel { offsetY: 3, radius: 5, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ bottom: 10 }) }),]).apply({ @@ -172,7 +172,7 @@ class EffectsDemo extends Panel { offsetY: 3, radius: 5, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -196,7 +196,7 @@ class EffectsDemo extends Panel { offsetY: 0, radius: 10, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 10, right: 10, bottom: 10, @@ -218,7 +218,7 @@ class EffectsDemo extends Panel { offsetY: 5, radius: 5, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 10, right: 10, bottom: 10, @@ -240,7 +240,7 @@ class EffectsDemo extends Panel { offsetY: 5, radius: 5, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 10, right: 10, bottom: 10, @@ -262,7 +262,7 @@ class EffectsDemo extends Panel { offsetY: 5, radius: 5, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 10, right: 10, bottom: 10, @@ -279,7 +279,7 @@ class EffectsDemo extends Panel { width: 100, height: 100, corners: 50, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -296,7 +296,7 @@ class EffectsDemo extends Panel { corners: { leftTop: 50, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -313,7 +313,7 @@ class EffectsDemo extends Panel { corners: { rightTop: 50, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -330,7 +330,7 @@ class EffectsDemo extends Panel { corners: { leftBottom: 50, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -347,7 +347,7 @@ class EffectsDemo extends Panel { corners: { rightBottom: 50, }, - layoutConfig: layoutConfig().exactly().m({ + layoutConfig: layoutConfig().just().configMargin({ left: 5, right: 5, bottom: 5, @@ -361,7 +361,7 @@ class EffectsDemo extends Panel { it.space = 20 }), ).also(it => { - it.layoutConfig = layoutConfig().atmost() + it.layoutConfig = layoutConfig().most() }).in(rootView) } } \ No newline at end of file diff --git a/src/FlowLayoutDemo.ts b/src/FlowLayoutDemo.ts index 5bc11e37..25b6415b 100644 --- a/src/FlowLayoutDemo.ts +++ b/src/FlowLayoutDemo.ts @@ -16,7 +16,7 @@ const imageUrls = [ class FlowDemo extends Panel { build(rootView: Group): void { flowlayout({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), itemCount: 100, columnCount: 3, columnSpace: 10, @@ -25,13 +25,13 @@ class FlowDemo extends Panel { return new FlowLayoutItem().apply({ backgroundColor: colors[idx % colors.length], height: 50 + (idx % 3) * 20, - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), }).also(it => { it.addChild(text({ text: `${idx}`, textColor: Color.WHITE, textSize: 20, - layoutConfig: layoutConfig().wrap().a(Gravity.Center) + layoutConfig: layoutConfig().fit().configAligmnet(Gravity.Center) })) }) }, @@ -45,13 +45,13 @@ class FlowDemo extends Panel { it.loadMoreView = new FlowLayoutItem().apply({ backgroundColor: colors[500 % colors.length], height: 50, - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), }).also(it => { it.addChild(text({ text: 'load more', textColor: Color.WHITE, textSize: 20, - layoutConfig: layoutConfig().wrap().a(Gravity.Center) + layoutConfig: layoutConfig().fit().configAligmnet(Gravity.Center) })) }) }) diff --git a/src/ImageDemo.ts b/src/ImageDemo.ts index c1ca6830..513f5d6b 100644 --- a/src/ImageDemo.ts +++ b/src/ImageDemo.ts @@ -10,7 +10,7 @@ class ImageDemo extends Panel { scroller(vlayout([ text({ text: "Image Demo", - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[5], @@ -59,7 +59,7 @@ class ImageDemo extends Panel { color: Color.GRAY, }, scaleType: ScaleType.ScaleToFill, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), loadCallback: (ret) => { } }), @@ -73,7 +73,7 @@ class ImageDemo extends Panel { color: Color.GRAY, }, scaleType: ScaleType.ScaleAspectFit, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), }), label('ScaleAspectFill'), image({ @@ -85,7 +85,7 @@ class ImageDemo extends Panel { color: Color.GRAY, }, scaleType: ScaleType.ScaleAspectFill, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), }), label('ImageBase64'), image({ @@ -97,14 +97,14 @@ class ImageDemo extends Panel { color: Color.GRAY, }, scaleType: ScaleType.ScaleAspectFill, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), }), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: gravity().center(), space: 10, } as IVLayout)).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).in(rootView) } } \ No newline at end of file diff --git a/src/InputDemo.ts b/src/InputDemo.ts index e1222045..8b52c831 100644 --- a/src/InputDemo.ts +++ b/src/InputDemo.ts @@ -7,7 +7,7 @@ class InputDemo extends Panel { vlayout([ title("Input Demo"), (new Input).also(it => { - it.layoutConfig = layoutConfig().exactly().h(LayoutSpec.WRAP_CONTENT) + it.layoutConfig = layoutConfig().just().configHeight(LayoutSpec.FIT) it.width = 300 it.multiline = false it.hintText = "HintText" @@ -20,7 +20,7 @@ class InputDemo extends Panel { } }), (new Input).also(it => { - it.layoutConfig = layoutConfig().wrap() + it.layoutConfig = layoutConfig().fit() it.hintText = "HintText" it.hintTextColor = colors[2] it.textAlignment = Gravity.Left @@ -36,10 +36,10 @@ class InputDemo extends Panel { ]) .also(it => { it.space = 10 - it.layoutConfig = layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT) + it.layoutConfig = layoutConfig().most().configHeight(LayoutSpec.FIT) })) .apply({ - layoutConfig: layoutConfig().atmost() + layoutConfig: layoutConfig().most() }) .in(root) } diff --git a/src/LayoutDemo.ts b/src/LayoutDemo.ts index b4762dbb..6a08b068 100644 --- a/src/LayoutDemo.ts +++ b/src/LayoutDemo.ts @@ -103,8 +103,8 @@ class LayoutDemo extends Panel { hlayout([ boxStr('weight=1', 3).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), @@ -114,8 +114,8 @@ class LayoutDemo extends Panel { width: 200, height: 30, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -124,8 +124,8 @@ class LayoutDemo extends Panel { box(3), boxStr('weight=1', 2).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), @@ -134,8 +134,8 @@ class LayoutDemo extends Panel { width: 200, height: 30, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -145,8 +145,8 @@ class LayoutDemo extends Panel { box(2), boxStr('weight=1', 4).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), @@ -154,8 +154,8 @@ class LayoutDemo extends Panel { width: 200, height: 30, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -163,15 +163,15 @@ class LayoutDemo extends Panel { hlayout([ boxStr('weight=1', 3).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), boxStr('weight=1', 2).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), @@ -180,8 +180,8 @@ class LayoutDemo extends Panel { width: 200, height: 30, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -189,22 +189,22 @@ class LayoutDemo extends Panel { hlayout([ boxStr('weight=1', 3).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), boxStr('weight=1', 2).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), boxStr('weight=1', 4).apply({ layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), @@ -212,8 +212,8 @@ class LayoutDemo extends Panel { width: 200, height: 30, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -291,29 +291,29 @@ class LayoutDemo extends Panel { vlayout([ boxStr('weight=1', 3).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, }, }), box(2).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, } }), box(4).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, } }), ]).apply({ width: 100, height: 200, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -321,29 +321,29 @@ class LayoutDemo extends Panel { vlayout([ box(3).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, }, }), boxStr('weight=1', 2).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), box(4).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, } }), ]).apply({ width: 100, height: 200, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -351,20 +351,20 @@ class LayoutDemo extends Panel { vlayout([ box(3).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, }, }), box(2).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, }, }), boxStr('weight=1', 4).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), @@ -372,8 +372,8 @@ class LayoutDemo extends Panel { width: 100, height: 200, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -381,30 +381,30 @@ class LayoutDemo extends Panel { vlayout([ boxStr('weight=1', 3).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, }, }), boxStr('weight=1', 2).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), box(4).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, } }), ]).apply({ width: 100, height: 200, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -412,22 +412,22 @@ class LayoutDemo extends Panel { vlayout([ boxStr('weight=1', 3).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, }, }), boxStr('weight=1', 2).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), boxStr('weight=1', 4).apply({ layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, weight: 1, } }), @@ -435,8 +435,8 @@ class LayoutDemo extends Panel { width: 100, height: 200, layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, backgroundColor: Color.parse('#eeeeee'), gravity: gravity().center(), @@ -453,7 +453,7 @@ class LayoutDemo extends Panel { it.space = 20 }), ).also(it => { - it.layoutConfig = layoutConfig().atmost() + it.layoutConfig = layoutConfig().most() }) .in(rootView) } diff --git a/src/ListDemo.ts b/src/ListDemo.ts index b5ec9ee4..71d4066c 100644 --- a/src/ListDemo.ts +++ b/src/ListDemo.ts @@ -9,8 +9,8 @@ class ListPanel extends Panel { text({ text: "ListDemo", layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, }, textSize: 30, textColor: Color.parse("#535c68"), @@ -33,7 +33,7 @@ class ListPanel extends Panel { } it.loadMoreView = listItem(text({ text: "Loading", - layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY).a(Gravity.Center), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.JUST).configAligmnet(Gravity.Center), height: 50, })) it.renderItem = (idx: number) => { @@ -42,8 +42,8 @@ class ListPanel extends Panel { hlayout([ text({ layoutConfig: { - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.JUST, alignment: gravity().center(), }, text: `Cell At Line ${idx}`, @@ -59,8 +59,8 @@ class ListPanel extends Panel { }).also(it => { counter = it it.layoutConfig = { - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, margin: { left: 10, } @@ -68,8 +68,8 @@ class ListPanel extends Panel { }) ]).also(it => { it.layoutConfig = { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.FIT, margin: { bottom: 2, } @@ -83,8 +83,8 @@ class ListPanel extends Panel { }) ).also(it => { it.layoutConfig = { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.FIT, } it.onClick = () => { log(`Click item at ${idx}`) @@ -107,16 +107,16 @@ class ListPanel extends Panel { itemCount: 0, renderItem: () => new ListItem, layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.AT_MOST, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.MOST, }, }), }), ]).also(it => { it.layoutConfig = { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.AT_MOST, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.MOST, } it.backgroundColor = Color.WHITE }).in(rootView) diff --git a/src/ModalDemo.ts b/src/ModalDemo.ts index 2086e1b0..f4756080 100644 --- a/src/ModalDemo.ts +++ b/src/ModalDemo.ts @@ -7,7 +7,7 @@ class ModalDemo extends Panel { scroller(vlayout([ text({ text: "Modal", - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[1], @@ -21,7 +21,7 @@ class ModalDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { modal(context).toast('This is a toast.') } @@ -33,7 +33,7 @@ class ModalDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { modal(context).toast('This is a toast.', Gravity.Top) } @@ -46,14 +46,14 @@ class ModalDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { modal(context).toast('This is a toast.', Gravity.Center) } } as IText), text({ text: "Alert", - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[2], @@ -66,7 +66,7 @@ class ModalDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { modal(context).alert({ msg: 'This is alert.', @@ -79,7 +79,7 @@ class ModalDemo extends Panel { } as IText), text({ text: "Confirm", - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[3], @@ -92,7 +92,7 @@ class ModalDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { modal(context).confirm({ msg: 'This is Confirm.', @@ -110,7 +110,7 @@ class ModalDemo extends Panel { } as IText), text({ text: "Prompt", - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[4], @@ -123,7 +123,7 @@ class ModalDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { modal(context).prompt({ msg: 'This is Prompt.', @@ -140,11 +140,11 @@ class ModalDemo extends Panel { } } as IText), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: Gravity.Center, space: 10, } as IVLayout)).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).in(rootView) } } \ No newline at end of file diff --git a/src/NavbarDemo.ts b/src/NavbarDemo.ts index 43b743ca..b88fdc7e 100644 --- a/src/NavbarDemo.ts +++ b/src/NavbarDemo.ts @@ -12,7 +12,7 @@ class NavbarDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { navbar(context).isHidden().then(e => modal(context).alert(`Navbar isHidden:${e}`)).catch(e => { modal(context).alert(e) @@ -25,7 +25,7 @@ class NavbarDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { navbar(context).isHidden() .then(e => navbar(context).setHidden(!e)) @@ -40,7 +40,7 @@ class NavbarDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { navbar(context).setTitle('Setted Title') .catch(e => { @@ -54,7 +54,7 @@ class NavbarDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { navbar(context).setBgColor(Color.YELLOW) .catch(e => { @@ -68,17 +68,17 @@ class NavbarDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { navigator(context).pop() } } as IText), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: gravity().center(), space: 10, } as IVLayout)).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).in(rootView) } } \ No newline at end of file diff --git a/src/NavigatorDemo.ts b/src/NavigatorDemo.ts index b5ae7eca..3190be23 100644 --- a/src/NavigatorDemo.ts +++ b/src/NavigatorDemo.ts @@ -9,7 +9,7 @@ class NaivgatorDemo extends Panel { scroller(vlayout([ text({ text: "Navigator Demo", - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[1], @@ -26,7 +26,7 @@ class NaivgatorDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().just().configWidth(LayoutSpec.MOST), onClick: () => { navigator(context).push(`assets://demo/${e}.js`, { alias: `${e}.js`, @@ -43,17 +43,17 @@ class NaivgatorDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { navigator(context).pop() }, } as IText), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: gravity().center(), space: 10, } as IVLayout)).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).in(root) } diff --git a/src/NetworkDemo.ts b/src/NetworkDemo.ts index 851b5704..1515415a 100644 --- a/src/NetworkDemo.ts +++ b/src/NetworkDemo.ts @@ -12,7 +12,7 @@ class NetworkDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { network(context).get('https://m.baidu.com').then( e => { @@ -24,11 +24,11 @@ class NetworkDemo extends Panel { } } as IText), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: gravity().center(), space: 10, } as IVLayout)).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).in(rootView) } } \ No newline at end of file diff --git a/src/PopoverDemo.ts b/src/PopoverDemo.ts index fd0e4f99..8782578b 100644 --- a/src/PopoverDemo.ts +++ b/src/PopoverDemo.ts @@ -12,14 +12,14 @@ class PopoverDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { popover(context).show(text({ width: 200, height: 50, backgroundColor: colors[0], textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly().a(Gravity.Center), + layoutConfig: layoutConfig().just().configAligmnet(Gravity.Center), text: "This is PopOver Window", }).also(v => { let idx = 0 @@ -34,11 +34,11 @@ class PopoverDemo extends Panel { } } as IText), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: gravity().center(), space: 10, } as IVLayout)).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).in(rootView) } } \ No newline at end of file diff --git a/src/RefreshableDemo.ts b/src/RefreshableDemo.ts index 3d9d30c8..a9e012c8 100644 --- a/src/RefreshableDemo.ts +++ b/src/RefreshableDemo.ts @@ -6,7 +6,7 @@ class RefreshableDemo extends Panel { build(rootView: Group): void { let refreshImage: Image let refreshView = refreshable({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), onRefresh: () => { log('onRefresh') setTimeout(() => { @@ -16,7 +16,7 @@ class RefreshableDemo extends Panel { header: pullable( stack([ image({ - layoutConfig: layoutConfig().exactly().m({ top: 50, bottom: 10, }), + layoutConfig: layoutConfig().just().configMargin({ top: 50, bottom: 10, }), width: 30, height: 30, imageBase64: icon_refresh, @@ -43,7 +43,7 @@ class RefreshableDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { refreshView.setRefreshing(context, true) } @@ -54,7 +54,7 @@ class RefreshableDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { refreshView.setRefreshing(context, false) } @@ -66,7 +66,7 @@ class RefreshableDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { refreshView.setRefreshable(context, true) } @@ -78,13 +78,13 @@ class RefreshableDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { refreshView.setRefreshable(context, false) } } as IText), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: gravity().centerX(), space: 10, } as IVLayout)) diff --git a/src/ScrollerDemo.ts b/src/ScrollerDemo.ts index 9870d3d1..0f7a949d 100644 --- a/src/ScrollerDemo.ts +++ b/src/ScrollerDemo.ts @@ -9,7 +9,7 @@ class ScrollerPanel extends Panel { scroller( vlayout(new Array(100).fill(1).map(e => label('Scroll Content'))) ).apply({ - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), width: 300, height: 500, backgroundColor: Color.RED, @@ -17,7 +17,7 @@ class ScrollerPanel extends Panel { scroller( vlayout(new Array(100).fill(1).map(e => label('Scroll Content'))) ).apply({ - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), width: 300, height: 500, backgroundColor: Color.BLUE, @@ -25,7 +25,7 @@ class ScrollerPanel extends Panel { ]) ) .apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.JUST), height: 500, backgroundColor: Color.YELLOW, }) diff --git a/src/SliderDemo.ts b/src/SliderDemo.ts index 6ab55c38..100ab458 100644 --- a/src/SliderDemo.ts +++ b/src/SliderDemo.ts @@ -19,8 +19,8 @@ class SliderPanel extends Panel { text({ text: "Gallery", layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.JUST, }, textSize: 30, textColor: Color.WHITE, @@ -34,7 +34,7 @@ class SliderPanel extends Panel { return slideItem(image({ imageUrl: imageUrls[idx % imageUrls.length], scaleType: ScaleType.ScaleAspectFit, - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST).h(LayoutSpec.AT_MOST).a(gravity().center()), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST).configHeight(LayoutSpec.MOST).configAligmnet(gravity().center()), })).also(it => { let start = idx it.onClick = () => { @@ -43,15 +43,15 @@ class SliderPanel extends Panel { }) }, layoutConfig: { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.FIT, weight: 1, }, }), ]).also(it => { it.layoutConfig = { - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.AT_MOST, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.MOST, } })) } diff --git a/src/Snake.ts b/src/Snake.ts index 962835c4..1998f217 100644 --- a/src/Snake.ts +++ b/src/Snake.ts @@ -155,8 +155,8 @@ class SnakeView extends ViewHolder { margin: { top: 20 }, - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, }, }), (new Stack).also(panel => { @@ -169,14 +169,14 @@ class SnakeView extends ViewHolder { textSize: 30, textColor: Color.parse("#ffffff"), layoutConfig: { - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, }, }).also(it => this.start = it), ]).also(it => { it.layoutConfig = { - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, } }), @@ -190,14 +190,14 @@ class SnakeView extends ViewHolder { textAlignment: new Gravity().center(), backgroundColor: Color.parse('#ffff00'), layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, }).also(it => this.up = it) ]).also(it => { it.layoutConfig = { - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, } }), hlayout([ @@ -209,8 +209,8 @@ class SnakeView extends ViewHolder { textAlignment: new Gravity().center(), backgroundColor: Color.parse('#ffff00'), layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, }).also(it => this.left = it), text({ @@ -221,8 +221,8 @@ class SnakeView extends ViewHolder { textAlignment: new Gravity().center(), backgroundColor: Color.parse('#ffff00'), layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, }).also(it => this.down = it), text({ @@ -233,14 +233,14 @@ class SnakeView extends ViewHolder { textAlignment: new Gravity().center(), backgroundColor: Color.parse('#ffff00'), layoutConfig: { - widthSpec: LayoutSpec.EXACTLY, - heightSpec: LayoutSpec.EXACTLY, + widthSpec: LayoutSpec.JUST, + heightSpec: LayoutSpec.JUST, }, }).also(it => this.right = it), ]).also(it => { it.layoutConfig = { - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, } it.space = 10 }), @@ -249,16 +249,16 @@ class SnakeView extends ViewHolder { controlArea.space = 10 controlArea.layoutConfig = { alignment: new Gravity().centerX(), - widthSpec: LayoutSpec.WRAP_CONTENT, - heightSpec: LayoutSpec.WRAP_CONTENT, + widthSpec: LayoutSpec.FIT, + heightSpec: LayoutSpec.FIT, } }), ]).also(it => { it.space = 20 it.layoutConfig = { alignment: new Gravity().centerX().top(), - widthSpec: LayoutSpec.AT_MOST, - heightSpec: LayoutSpec.AT_MOST, + widthSpec: LayoutSpec.MOST, + heightSpec: LayoutSpec.MOST, } it.gravity = new Gravity().centerX() }).in(root) diff --git a/src/StickDemo.ts b/src/StickDemo.ts index 3f74e083..3fc1b14c 100644 --- a/src/StickDemo.ts +++ b/src/StickDemo.ts @@ -4,7 +4,7 @@ import { title, colors } from "./utils"; function tab(idx: number, title: string, sliderView: Slider) { return text({ text: title, - layoutConfig: layoutConfig().exactly().wg(1), + layoutConfig: layoutConfig().just().configWeight(1), height: 41, onClick: () => { sliderView.slidePage(context, 0, true) @@ -27,13 +27,13 @@ class StickDemo extends Panel { vlayout([ stack([ image({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), imageUrl: "https://p.upyun.com/demo/webp/webp/jpg-0.webp", scaleType: ScaleType.ScaleAspectFill, }), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.JUST), height: 200, backgroundColor: colors[0], }), @@ -42,7 +42,7 @@ class StickDemo extends Panel { ...this.tabs = [0, 1, 2].map(idx => { return text({ text: `Tab ${idx}`, - layoutConfig: layoutConfig().exactly().wg(1), + layoutConfig: layoutConfig().just().configWeight(1), height: 41, onClick: () => { this.sliderView.slidePage(context, idx, true) @@ -50,12 +50,12 @@ class StickDemo extends Panel { }) }) ]).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), gravity: Gravity.Center, } as IHLayout), this.indicator, ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.EXACTLY), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.JUST), height: 57, }), @@ -66,7 +66,7 @@ class StickDemo extends Panel { } [0, 1, 2].map(idx => { return flowlayout({ - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), width: root.width, height: root.height - 57, itemCount: 100, @@ -77,13 +77,13 @@ class StickDemo extends Panel { return new FlowLayoutItem().apply({ backgroundColor: colors[itemIdx % colors.length], height: 50, - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.JUST), }).also(it => { it.addChild(text({ text: `In Page ${idx},${itemIdx}`, textColor: Color.WHITE, textSize: 20, - layoutConfig: layoutConfig().wrap().a(Gravity.Center) + layoutConfig: layoutConfig().fit().configAligmnet(Gravity.Center) }).also(v => { v.onClick = () => { v.text = "Clicked" @@ -96,16 +96,16 @@ class StickDemo extends Panel { v.addSlideItem(e) }) }).apply({ - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), width: root.width, height: root.height - 57, }), ]) .also(it => { - it.layoutConfig = layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT) + it.layoutConfig = layoutConfig().most().configHeight(LayoutSpec.FIT) })) .apply({ - layoutConfig: layoutConfig().atmost() + layoutConfig: layoutConfig().most() }) .in(root) this.indicator.centerX = this.getRootView().width / this.tabs.length / 2 @@ -120,7 +120,7 @@ class StickDemo extends Panel { e.textColor = Color.BLACK } }) - this.indicator.layoutConfig = layoutConfig().exactly().a(Gravity.Bottom).m({ bottom: 13 }) + this.indicator.layoutConfig = layoutConfig().just().configAligmnet(Gravity.Bottom).configMargin({ bottom: 13 }) animate(context)({ animations: () => { this.indicator.centerX = this.getRootView().width / this.tabs.length * (page + 0.5) diff --git a/src/StorageDemo.ts b/src/StorageDemo.ts index f13db93b..fa814397 100644 --- a/src/StorageDemo.ts +++ b/src/StorageDemo.ts @@ -17,7 +17,7 @@ class StorageDemo extends Panel { scroller(vlayout([ text({ text: "Storage Demo", - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[1], @@ -26,7 +26,7 @@ class StorageDemo extends Panel { }), label('Stored'), text({ - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 20, textColor: Color.WHITE, backgroundColor: colors[3], @@ -39,7 +39,7 @@ class StorageDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { storage(context).getItem(storedKey, zone).then(e => { modal(context).prompt({ @@ -60,7 +60,7 @@ class StorageDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { storage(context).remove(storedKey, zone).then(e => { this.update() @@ -73,7 +73,7 @@ class StorageDemo extends Panel { backgroundColor: colors[0], textSize: 30, textColor: Color.WHITE, - layoutConfig: layoutConfig().exactly(), + layoutConfig: layoutConfig().just(), onClick: () => { storage(context).clear(zone).then(e => { this.update() @@ -81,11 +81,11 @@ class StorageDemo extends Panel { }, } as IText), ]).apply({ - layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.FIT), gravity: gravity().center(), space: 10, } as IVLayout)).apply({ - layoutConfig: layoutConfig().atmost(), + layoutConfig: layoutConfig().most(), }).in(root) this.update() } diff --git a/src/utils.ts b/src/utils.ts index c8d98f37..96e1847d 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -39,7 +39,7 @@ export function boxStr(str: string, idx = 0) { export function title(str: string) { return text({ text: str, - layoutConfig: layoutConfig().w(LayoutSpec.AT_MOST), + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), textSize: 30, textColor: Color.WHITE, backgroundColor: colors[1], @@ -53,7 +53,7 @@ export function rotatedArrow() { return pullable( stack([ image({ - layoutConfig: layoutConfig().exactly().m({ top: 50, bottom: 10, }), + layoutConfig: layoutConfig().just().configMargin({ top: 50, bottom: 10, }), width: 30, height: 30, imageBase64: icon_refresh, From a459e0440da0219119484eb32fda512bcea084fc Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Mon, 16 Dec 2019 14:08:30 +0800 Subject: [PATCH 20/35] add Gobang --- index.ts | 3 +- src/Gobang.ts | 184 ++++++++++++++++++++++++++++++++++++++++++++++ src/LayoutDemo.ts | 1 - 3 files changed, 186 insertions(+), 2 deletions(-) create mode 100644 src/Gobang.ts diff --git a/index.ts b/index.ts index 2fbf2642..fade3a4a 100644 --- a/index.ts +++ b/index.ts @@ -19,5 +19,6 @@ export default [ 'src/ComplicatedAnimations', 'src/ComplicatedDemo', 'src/InputDemo', - 'src/StickDemo' + 'src/StickDemo', + 'src/Gobang', ] \ No newline at end of file diff --git a/src/Gobang.ts b/src/Gobang.ts new file mode 100644 index 00000000..9f93fb47 --- /dev/null +++ b/src/Gobang.ts @@ -0,0 +1,184 @@ +import { Stack, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller } from "doric"; +import { title } from "./utils"; + + +const lineColor = Color.BLACK +function columLine() { + return (new Stack).apply({ + layoutConfig: layoutConfig().most().configWidth(LayoutSpec.JUST), + width: 1, + backgroundColor: lineColor, + }) +} + +function rowLine() { + return (new Stack).apply({ + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.JUST), + height: 1, + backgroundColor: lineColor, + }) +} + +function pointer(size: number) { + return (new Stack).apply({ + layoutConfig: layoutConfig().just(), + width: size, + height: size, + }) +} + +const count = 13 +enum State { + Unspecified, + BLACK, + WHITE, +} + +interface GoBangState { + count: number + gap: number + role: "white" | "black" + matrix: Map +} + +class GoBangVH extends ViewHolder { + pieces!: Stack + root!: Group + gap = 0 + onPieceDown?: (x: number, y: number) => void + build(root: Group): void { + this.root = root + } + actualBuild(state: GoBangState): void { + const boardSize = state.gap * (state.count - 1) + const gap = state.gap + const borderWidth = gap + let hintText: Text + this.gap = state.gap + scroller( + vlayout([ + title("GoBang"), + stack([ + stack([ + ...(new Array(count - 2)).fill(0).map((_, idx) => { + return columLine().also(v => { + v.left = (idx + 1) * gap + }) + } + ), + ...(new Array(count - 2)).fill(0).map((_, idx) => { + return rowLine().also(v => { + v.top = (idx + 1) * gap + }) + } + ), + ]) + .apply({ + layoutConfig: layoutConfig().just() + .configMargin({ top: borderWidth, left: borderWidth }), + width: boardSize, + height: boardSize, + border: { + width: 1, + color: lineColor, + }, + }), + + ...(new Array(count * count)).fill(0).map((_, idx) => { + const row = Math.floor(idx / count) + const colum = idx % count + return pointer(gap).also(v => { + v.top = (row - 0.5) * gap + borderWidth + v.left = (colum - 0.5) * gap + borderWidth + v.onClick = () => { + hintText.text = `row:${row},colum:${colum}` + if (this.onPieceDown) { + this.onPieceDown(colum, row) + } + } + }) + }), + this.pieces = (new Stack).apply({ + layoutConfig: layoutConfig().most(), + }), + ]).apply({ + layoutConfig: layoutConfig().just(), + width: boardSize + 2 * borderWidth, + height: boardSize + 2 * borderWidth, + backgroundColor: Color.parse("#E6B080"), + }), + hintText = title('Hint'), + ]) + .apply({ + layoutConfig: layoutConfig().fit(), + backgroundColor: Color.parse('#ecf0f1'), + } as IVLayout) + ).in(this.root) + } + + addPiece(pos: number, role: "black" | "white") { + const x = Math.floor(pos / count) + const y = pos % count + const piece = (new Stack).also(v => { + v.width = v.height = 30 + v.corners = 15 + v.backgroundColor = role === 'black' ? Color.BLACK : Color.WHITE + }) + piece.centerX = (x + 1) * this.gap + piece.centerY = (y + 1) * this.gap + this.pieces.addChild(piece) + } +} + +class GoBangVM extends ViewModel{ + onAttached(state: GoBangState, vh: GoBangVH) { + vh.actualBuild(state) + vh.onPieceDown = (x, y) => { + this.updateState(it => { + if (it.role === 'black') { + it.matrix.set(x * count + y, State.BLACK) + it.role = 'white' + } else { + it.matrix.set(x * count + y, State.WHITE) + it.role = 'black' + } + }) + } + } + + onBind(state: GoBangState, vh: GoBangVH) { + vh.pieces.children.length = 0 + for (let e of state.matrix.keys()) { + const v = state.matrix.get(e) + if (v === State.BLACK) { + vh.addPiece(e, 'black') + } + switch (v) { + case State.BLACK: + vh.addPiece(e, 'black') + break + case State.WHITE: + vh.addPiece(e, 'white') + break + } + } + } +} + +@Entry +class Gobang extends VMPanel { + getViewModelClass() { + return GoBangVM + } + getState(): GoBangState { + return { + count, + gap: 40, + role: "black", + matrix: new Map + } + } + getViewHolderClass() { + return GoBangVH + } +} \ No newline at end of file diff --git a/src/LayoutDemo.ts b/src/LayoutDemo.ts index 6a08b068..79027d39 100644 --- a/src/LayoutDemo.ts +++ b/src/LayoutDemo.ts @@ -1,6 +1,5 @@ import { Group, Panel, Text, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, slider, slideItem, scroller, IVLayout, IHLayout, layoutConfig } from "doric"; -import { O_TRUNC } from "constants"; const colors = [ "#f0932b", From 1b7952d1ae6bf8313577d11d397b1e94e1449198 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Mon, 16 Dec 2019 14:40:10 +0800 Subject: [PATCH 21/35] feat:adjust anchor style --- src/Gobang.ts | 93 ++++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 81 insertions(+), 12 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 9f93fb47..296745bf 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -1,5 +1,5 @@ -import { Stack, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller } from "doric"; -import { title } from "./utils"; +import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull } from "doric"; +import { colors } from "./utils"; const lineColor = Color.BLACK @@ -39,13 +39,17 @@ interface GoBangState { gap: number role: "white" | "black" matrix: Map + anchor?: { x: number, y: number } } class GoBangVH extends ViewHolder { pieces!: Stack root!: Group gap = 0 + currentRole!: Text + result!: Text onPieceDown?: (x: number, y: number) => void + onAnchorDown?: (x: number, y: number) => void build(root: Group): void { this.root = root } @@ -53,11 +57,18 @@ class GoBangVH extends ViewHolder { const boardSize = state.gap * (state.count - 1) const gap = state.gap const borderWidth = gap - let hintText: Text this.gap = state.gap scroller( vlayout([ - title("GoBang"), + text({ + text: "五子棋", + layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST), + textSize: 30, + textColor: Color.WHITE, + backgroundColor: colors[0], + textAlignment: gravity().center(), + height: 50, + }), stack([ stack([ ...(new Array(count - 2)).fill(0).map((_, idx) => { @@ -91,9 +102,8 @@ class GoBangVH extends ViewHolder { v.top = (row - 0.5) * gap + borderWidth v.left = (colum - 0.5) * gap + borderWidth v.onClick = () => { - hintText.text = `row:${row},colum:${colum}` - if (this.onPieceDown) { - this.onPieceDown(colum, row) + if (this.onAnchorDown) { + this.onAnchorDown(colum, row) } } }) @@ -107,7 +117,26 @@ class GoBangVH extends ViewHolder { height: boardSize + 2 * borderWidth, backgroundColor: Color.parse("#E6B080"), }), - hintText = title('Hint'), + hlayout([ + this.currentRole = text({ + text: "当前:", + textSize: 20, + textColor: Color.WHITE, + layoutConfig: layoutConfig().just().configWeight(1), + height: 50, + backgroundColor: colors[1], + }), + this.result = text({ + text: "获胜方:", + textSize: 20, + textColor: Color.WHITE, + layoutConfig: layoutConfig().just().configWeight(1), + height: 50, + backgroundColor: colors[2], + }), + ]).apply({ + layoutConfig: layoutConfig().fit().configWidth(LayoutSpec.MOST), + } as IHLayout), ]) .apply({ layoutConfig: layoutConfig().fit(), @@ -120,7 +149,7 @@ class GoBangVH extends ViewHolder { const x = Math.floor(pos / count) const y = pos % count const piece = (new Stack).also(v => { - v.width = v.height = 30 + v.width = v.height = this.gap v.corners = 15 v.backgroundColor = role === 'black' ? Color.BLACK : Color.WHITE }) @@ -128,20 +157,56 @@ class GoBangVH extends ViewHolder { piece.centerY = (y + 1) * this.gap this.pieces.addChild(piece) } + + addAnchor(x: number, y: number) { + const piece = (new Stack).also(v => { + v.width = v.height = 30 + v.border = { + color: Color.RED, + width: 1, + } + }) + piece.centerX = (x + 1) * this.gap + piece.centerY = (y + 1) * this.gap + piece.onClick = () => { + if (this.onPieceDown) { + this.onPieceDown(x, y) + } + } + this.pieces.addChild(piece) + } } class GoBangVM extends ViewModel{ onAttached(state: GoBangState, vh: GoBangVH) { vh.actualBuild(state) + vh.onAnchorDown = (x, y) => { + const pos = x * count + y + if (state.matrix.get(pos) == State.BLACK + || state.matrix.get(pos) == State.WHITE) { + modal(context).toast('This position had been token.') + return + } + this.updateState(it => { + it.anchor = { x, y } + }) + } vh.onPieceDown = (x, y) => { + const pos = x * count + y + if (state.matrix.get(pos) == State.BLACK + || state.matrix.get(pos) == State.WHITE) { + modal(context).toast('This position had been token.') + return + } this.updateState(it => { if (it.role === 'black') { - it.matrix.set(x * count + y, State.BLACK) + it.matrix.set(pos, State.BLACK) it.role = 'white' } else { - it.matrix.set(x * count + y, State.WHITE) + it.matrix.set(pos, State.WHITE) it.role = 'black' } + it.anchor = undefined }) } } @@ -162,6 +227,10 @@ class GoBangVM extends ViewModel{ break } } + takeNonNull(state.anchor)(it => { + vh.addAnchor(it.x, it.y) + }) + vh.currentRole.text = `当前: ${(state.role === 'black') ? "黑方" : "白方"}` } } @@ -173,7 +242,7 @@ class Gobang extends VMPanel { getState(): GoBangState { return { count, - gap: 40, + gap: this.getRootView().width / 14, role: "black", matrix: new Map } From 3b43a2bd8d8564245ce54e5eecfa303514b6c94f Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Mon, 16 Dec 2019 15:39:29 +0800 Subject: [PATCH 22/35] feat:update ui --- src/Gobang.ts | 160 ++++++++++++++++++++++---------------------------- 1 file changed, 70 insertions(+), 90 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 296745bf..3ff7c65a 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -1,4 +1,4 @@ -import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull } from "doric"; +import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull, View } from "doric"; import { colors } from "./utils"; @@ -39,17 +39,16 @@ interface GoBangState { gap: number role: "white" | "black" matrix: Map - anchor?: { x: number, y: number } + anchor?: number } class GoBangVH extends ViewHolder { - pieces!: Stack root!: Group gap = 0 currentRole!: Text result!: Text - onPieceDown?: (x: number, y: number) => void - onAnchorDown?: (x: number, y: number) => void + targetZone: View[] = [] + build(root: Group): void { this.root = root } @@ -75,14 +74,12 @@ class GoBangVH extends ViewHolder { return columLine().also(v => { v.left = (idx + 1) * gap }) - } - ), + }), ...(new Array(count - 2)).fill(0).map((_, idx) => { return rowLine().also(v => { v.top = (idx + 1) * gap }) - } - ), + }), ]) .apply({ layoutConfig: layoutConfig().just() @@ -94,23 +91,14 @@ class GoBangVH extends ViewHolder { color: lineColor, }, }), - - ...(new Array(count * count)).fill(0).map((_, idx) => { + ...this.targetZone = (new Array(count * count)).fill(0).map((_, idx) => { const row = Math.floor(idx / count) const colum = idx % count return pointer(gap).also(v => { v.top = (row - 0.5) * gap + borderWidth v.left = (colum - 0.5) * gap + borderWidth - v.onClick = () => { - if (this.onAnchorDown) { - this.onAnchorDown(colum, row) - } - } }) }), - this.pieces = (new Stack).apply({ - layoutConfig: layoutConfig().most(), - }), ]).apply({ layoutConfig: layoutConfig().just(), width: boardSize + 2 * borderWidth, @@ -144,91 +132,83 @@ class GoBangVH extends ViewHolder { } as IVLayout) ).in(this.root) } - - addPiece(pos: number, role: "black" | "white") { - const x = Math.floor(pos / count) - const y = pos % count - const piece = (new Stack).also(v => { - v.width = v.height = this.gap - v.corners = 15 - v.backgroundColor = role === 'black' ? Color.BLACK : Color.WHITE - }) - piece.centerX = (x + 1) * this.gap - piece.centerY = (y + 1) * this.gap - this.pieces.addChild(piece) - } - - addAnchor(x: number, y: number) { - const piece = (new Stack).also(v => { - v.width = v.height = 30 - v.border = { - color: Color.RED, - width: 1, - } - }) - piece.centerX = (x + 1) * this.gap - piece.centerY = (y + 1) * this.gap - piece.onClick = () => { - if (this.onPieceDown) { - this.onPieceDown(x, y) - } - } - this.pieces.addChild(piece) - } } class GoBangVM extends ViewModel{ onAttached(state: GoBangState, vh: GoBangVH) { vh.actualBuild(state) - vh.onAnchorDown = (x, y) => { - const pos = x * count + y - if (state.matrix.get(pos) == State.BLACK - || state.matrix.get(pos) == State.WHITE) { - modal(context).toast('This position had been token.') - return - } - this.updateState(it => { - it.anchor = { x, y } - }) - } - vh.onPieceDown = (x, y) => { - const pos = x * count + y - if (state.matrix.get(pos) == State.BLACK - || state.matrix.get(pos) == State.WHITE) { - modal(context).toast('This position had been token.') - return - } - this.updateState(it => { - if (it.role === 'black') { - it.matrix.set(pos, State.BLACK) - it.role = 'white' - } else { - it.matrix.set(pos, State.WHITE) - it.role = 'black' + vh.targetZone.forEach((e, idx) => { + e.onClick = () => { + const zoneState = state.matrix.get(idx) + if (zoneState === State.BLACK || zoneState === State.WHITE) { + modal(context).toast('This position had been token.') + return } - it.anchor = undefined - }) - } + if (state.anchor === undefined || state.anchor != idx) { + this.updateState(it => { + it.anchor = idx + }) + } else { + this.updateState(it => { + if (it.role === 'black') { + it.matrix.set(idx, State.BLACK) + it.role = 'white' + } else { + it.matrix.set(idx, State.WHITE) + it.role = 'black' + } + it.anchor = undefined + }) + } + } + }) } onBind(state: GoBangState, vh: GoBangVH) { - vh.pieces.children.length = 0 - for (let e of state.matrix.keys()) { - const v = state.matrix.get(e) - if (v === State.BLACK) { - vh.addPiece(e, 'black') - } - switch (v) { + vh.targetZone.forEach((v, idx) => { + const zoneState = state.matrix.get(idx) + switch (zoneState) { case State.BLACK: - vh.addPiece(e, 'black') + v.also(it => { + it.backgroundColor = Color.BLACK + it.corners = state.gap / 2 + it.border = { + color: Color.TRANSPARENT, + width: 0, + } + }) break case State.WHITE: - vh.addPiece(e, 'white') + v.also(it => { + it.backgroundColor = Color.WHITE + it.corners = state.gap / 2 + it.border = { + color: Color.TRANSPARENT, + width: 0, + } + }) + break + default: + v.also(it => { + it.backgroundColor = Color.TRANSPARENT + it.corners = 0 + it.border = { + color: Color.TRANSPARENT, + width: 0, + } + }) break } - } - takeNonNull(state.anchor)(it => { - vh.addAnchor(it.x, it.y) + if (state.anchor === idx) { + v.also(it => { + it.backgroundColor = Color.RED.alpha(0.1) + it.corners = 0 + it.border = { + color: Color.RED, + width: 1, + } + }) + } }) vh.currentRole.text = `当前: ${(state.role === 'black') ? "黑方" : "白方"}` } From 641bad072d28686d78237af400375234ecc45d5b Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Mon, 16 Dec 2019 16:38:53 +0800 Subject: [PATCH 23/35] add gobang roles --- src/Gobang.ts | 117 +++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 116 insertions(+), 1 deletion(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 3ff7c65a..10e8f6cc 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -1,4 +1,4 @@ -import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull, View } from "doric"; +import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull, View, log } from "doric"; import { colors } from "./utils"; @@ -158,6 +158,18 @@ class GoBangVM extends ViewModel{ it.role = 'black' } it.anchor = undefined + if (this.checkResult(idx)) { + modal(context).alert({ + title: "游戏结束", + msg: `恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`, + }).then(() => { + this.updateState(s => { + s.matrix.clear() + s.role = 'black' + }) + }) + } + }) } } @@ -212,6 +224,109 @@ class GoBangVM extends ViewModel{ }) vh.currentRole.text = `当前: ${(state.role === 'black') ? "黑方" : "白方"}` } + + checkResult(pos: number) { + const matrix = this.getState().matrix + const state = matrix.get(pos) + const y = Math.floor(pos / count) + const x = pos % count + const getState = (x: number, y: number) => matrix.get(y * count + x) + ///Horitonzal + { + let left = x + while (left >= 1) { + if (getState(left - 1, y) === state) { + left -= 1 + } else { + break + } + } + let right = x + while (right <= count - 2) { + if (getState(right + 1, y) === state) { + right += 1 + } else { + break + } + } + if (right - left >= 4) { + return true + } + } + ///Vertical + { + let top = y + while (top >= 1) { + if (getState(x, top - 1) === state) { + top -= 1 + } else { + break + } + } + let bottom = y + while (bottom <= count - 2) { + if (getState(x, bottom + 1) === state) { + bottom += 1 + } else { + break + } + } + if (bottom - top >= 4) { + return true + } + } + + ///LT-RB + { + let startX = x, startY = y + while (startX >= 1 && startY >= 1) { + if (getState(startX - 1, startY - 1) === state) { + startX -= 1 + startY -= 1 + } else { + break + } + } + let endX = x, endY = y + while (endX <= count - 2 && endY <= count - 2) { + if (getState(endX + 1, endY + 1) === state) { + endX += 1 + endY += 1 + } else { + break + } + } + if (endX - startX >= 4) { + return true + } + } + + ///LB-RT + { + let startX = x, startY = y + while (startX >= 1 && startY <= count + 2) { + if (getState(startX - 1, startY + 1) === state) { + startX -= 1 + startY += 1 + } else { + break + } + } + let endX = x, endY = y + while (endX <= count - 2 && endY >= 1) { + if (getState(endX + 1, endY - 1) === state) { + endX += 1 + endY -= 1 + } else { + break + } + } + if (endX - startX >= 4) { + return true + } + } + return false + } } @Entry From faaf8fd99d69041b2d22423477e8c60793d1ce47 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Mon, 16 Dec 2019 17:06:42 +0800 Subject: [PATCH 24/35] add game mode --- src/Gobang.ts | 74 ++++++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 68 insertions(+), 6 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 10e8f6cc..2309ef93 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -1,4 +1,4 @@ -import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull, View, log } from "doric"; +import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull, View, log, popover } from "doric"; import { colors } from "./utils"; @@ -33,6 +33,11 @@ enum State { BLACK, WHITE, } +enum GameMode { + P2P, + P2C, + C2P, +} interface GoBangState { count: number @@ -40,6 +45,8 @@ interface GoBangState { role: "white" | "black" matrix: Map anchor?: number + gameMode: GameMode + reset: () => void } class GoBangVH extends ViewHolder { @@ -48,7 +55,7 @@ class GoBangVH extends ViewHolder { currentRole!: Text result!: Text targetZone: View[] = [] - + gameMode!: Text build(root: Group): void { this.root = root } @@ -105,6 +112,15 @@ class GoBangVH extends ViewHolder { height: boardSize + 2 * borderWidth, backgroundColor: Color.parse("#E6B080"), }), + + this.gameMode = text({ + text: "游戏模式", + textSize: 20, + textColor: Color.WHITE, + layoutConfig: layoutConfig().most().configHeight(LayoutSpec.JUST), + height: 50, + backgroundColor: colors[3], + }), hlayout([ this.currentRole = text({ text: "当前:", @@ -164,16 +180,55 @@ class GoBangVM extends ViewModel{ msg: `恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`, }).then(() => { this.updateState(s => { - s.matrix.clear() - s.role = 'black' + s.reset() }) }) } - }) } } }) + vh.gameMode.onClick = () => { + popover(context).show(vlayout([ + ...[ + { + label: "黑方:人 白方:人", + mode: GameMode.P2P, + }, + { + label: "黑方:人 白方:机", + mode: GameMode.P2C, + }, + { + label: "黑方:机 白方:人", + mode: GameMode.C2P, + }, + ].map((e) => text({ + text: e.label, + textSize: 20, + textColor: Color.WHITE, + layoutConfig: layoutConfig().just(), + height: 50, + width: 300, + backgroundColor: (state.gameMode === e.mode) ? Color.parse('#636e72') : Color.parse('#b2bec3'), + onClick: () => { + this.updateState(s => { + s.gameMode = e.mode + s.reset() + }) + popover(context).dismiss() + }, + })) + ]) + .apply({ + layoutConfig: layoutConfig().most(), + onClick: () => { + popover(context).dismiss() + }, + gravity: Gravity.Center, + } as IVLayout) + ) + } } onBind(state: GoBangState, vh: GoBangVH) { @@ -223,6 +278,7 @@ class GoBangVM extends ViewModel{ } }) vh.currentRole.text = `当前: ${(state.role === 'black') ? "黑方" : "白方"}` + vh.gameMode.text = `游戏模式: 黑方 ${state.gameMode === GameMode.C2P ? "机" : "人"} 白方 ${state.gameMode === GameMode.P2C ? "机" : "人"}` } checkResult(pos: number) { @@ -339,7 +395,13 @@ class Gobang extends VMPanel { count, gap: this.getRootView().width / 14, role: "black", - matrix: new Map + matrix: new Map, + gameMode: GameMode.P2P, + reset: function () { + this.matrix.clear() + this.role = "black" + this.anchor = undefined + } } } getViewHolderClass() { From 84ea697eb2eb82a8206b9d7c9c2c6150cba9a007 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Mon, 16 Dec 2019 17:28:50 +0800 Subject: [PATCH 25/35] current support random play --- src/Gobang.ts | 35 +++++++++++++++++++++++++++-------- 1 file changed, 27 insertions(+), 8 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 2309ef93..341b9f50 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -46,7 +46,6 @@ interface GoBangState { matrix: Map anchor?: number gameMode: GameMode - reset: () => void } class GoBangVH extends ViewHolder { @@ -180,9 +179,15 @@ class GoBangVM extends ViewModel{ msg: `恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`, }).then(() => { this.updateState(s => { - s.reset() + this.reset(s) }) }) + } else { + if (it.role === 'black' && it.gameMode === GameMode.C2P) { + this.computeNextStep(it) + } else if (it.role === 'white' && it.gameMode === GameMode.P2C) { + this.computeNextStep(it) + } } }) } @@ -214,7 +219,7 @@ class GoBangVM extends ViewModel{ onClick: () => { this.updateState(s => { s.gameMode = e.mode - s.reset() + this.reset(s) }) popover(context).dismiss() }, @@ -231,6 +236,25 @@ class GoBangVM extends ViewModel{ } } + computeNextStep(it: GoBangState) { + let x = 0, y = 0 + do { + x = Math.floor(Math.random() * count) + y = Math.floor(Math.random() * count) + } while (it.matrix.get(x * count + y) === State.Unspecified) + this.updateState(state => { + state.matrix.set(x * count + y, state.role === 'black' ? State.BLACK : State.WHITE) + state.role = state.role === 'black' ? 'white' : 'black' + }) + } + reset(it: GoBangState) { + it.matrix.clear() + it.role = "black" + it.anchor = undefined + if (it.gameMode === GameMode.C2P) { + this.computeNextStep(it) + } + } onBind(state: GoBangState, vh: GoBangVH) { vh.targetZone.forEach((v, idx) => { const zoneState = state.matrix.get(idx) @@ -397,11 +421,6 @@ class Gobang extends VMPanel { role: "black", matrix: new Map, gameMode: GameMode.P2P, - reset: function () { - this.matrix.clear() - this.role = "black" - this.anchor = undefined - } } } getViewHolderClass() { From 4a5cb1739f1493df4b301b6ac95f58c0a966bcdd Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 17 Dec 2019 15:45:00 +0800 Subject: [PATCH 26/35] add ai --- src/Gobang.ts | 185 ++++++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 172 insertions(+), 13 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 341b9f50..2a17f43c 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -1,7 +1,152 @@ import { Stack, hlayout, Group, Color, stack, layoutConfig, LayoutSpec, vlayout, IVLayout, Text, ViewHolder, ViewModel, VMPanel, scroller, modal, text, gravity, Gravity, IHLayout, takeNonNull, View, log, popover } from "doric"; import { colors } from "./utils"; +enum State { + Unspecified, + BLACK, + WHITE, +} +const count = 13 + + +class AIComputer { + wins: Array>> = new Array(count).fill(0).map(_ => new Array(count).fill(0).map(_ => [])); + winCount = 0 + blackWins: number[] + whiteWins: number[] + constructor() { + for (let y = 0; y < count; y++) { + for (let x = 0; x < count - 4; x++) { + for (let k = 0; k < 5; k++) { + this.wins[x + k][y][this.winCount] = true; + } + this.winCount++; + } + } + + for (let x = 0; x < count; x++) { + for (let y = 0; y < count - 4; y++) { + for (let k = 0; k < 5; k++) { + this.wins[x][y + k][this.winCount] = true; + } + this.winCount++; + } + } + + for (let x = 0; x < count - 4; x++) { + for (let y = 0; y < count - 4; y++) { + for (let k = 0; k < 5; k++) { + this.wins[x + k][y + k][this.winCount] = true; + } + this.winCount++; + } + } + + for (let x = 0; x < count - 4; x++) { + for (let y = count - 1; y > 3; y--) { + for (let k = 0; k < 5; k++) { + this.wins[x + k][y - k][this.winCount] = true; + } + this.winCount++; + } + } + this.blackWins = new Array(this.winCount).fill(0) + this.whiteWins = new Array(this.winCount).fill(0) + } + + + oneStep(idx: number, role: State.BLACK | State.WHITE) { + const { x, y } = this.index2Position(idx) + for (let loop = 0; loop < this.winCount; loop++) { + if (this.wins[x][y][loop]) { + if (role === State.BLACK) { + this.blackWins[loop] += 1 + } else { + this.whiteWins[loop] += 1 + } + } + } + } + + index2Position(idx: number) { + const x = idx % count + const y = Math.floor(idx / count) + return { x, y } + } + + compute(matrix: State[], role: State.BLACK | State.WHITE) { + const myScore = new Array(matrix.length).fill(0) + const rivalScore = new Array(matrix.length).fill(0) + const myWins = role === State.BLACK ? this.blackWins : this.whiteWins + const rivalWins = role === State.BLACK ? this.whiteWins : this.blackWins + let max = 0 + let retIdx = 0 + matrix.forEach((state, idx) => { + if (state != State.Unspecified) { + return + } + const { x, y } = this.index2Position(idx) + for (let loop = 0; loop < this.winCount; loop++) { + if (this.wins[x][y][loop]) { + switch (rivalWins[loop]) { + case 1: + rivalScore[idx] += 200 + break + case 2: + rivalScore[idx] += 400 + break + case 3: + rivalScore[idx] += 2000 + break + case 4: + rivalScore[idx] += 10000 + break + default: + break + } + + switch (myWins[loop]) { + case 1: + myScore[idx] += 220 + break + case 2: + myScore[idx] += 420 + break + case 3: + myScore[idx] += 2200 + break + case 4: + myScore[idx] += 20000 + break + default: + break + } + } + } + if (rivalScore[idx] > max) { + max = rivalScore[idx]; + retIdx = idx + } else if (rivalScore[idx] == max) { + if (myScore[idx] > myScore[retIdx]) { + retIdx = idx + } + } + + if (myScore[idx] > max) { + max = myScore[idx] + retIdx = idx + } else if (myScore[idx] == max) { + if (rivalScore[idx] > rivalScore[retIdx]) { + retIdx = idx + } + } + + + }) + return retIdx + } +} const lineColor = Color.BLACK function columLine() { return (new Stack).apply({ @@ -26,13 +171,6 @@ function pointer(size: number) { height: size, }) } - -const count = 13 -enum State { - Unspecified, - BLACK, - WHITE, -} enum GameMode { P2P, P2C, @@ -150,6 +288,7 @@ class GoBangVH extends ViewHolder { } class GoBangVM extends ViewModel{ + computer!: AIComputer onAttached(state: GoBangState, vh: GoBangVH) { vh.actualBuild(state) vh.targetZone.forEach((e, idx) => { @@ -168,9 +307,15 @@ class GoBangVM extends ViewModel{ if (it.role === 'black') { it.matrix.set(idx, State.BLACK) it.role = 'white' + if (this.computer) { + this.computer.oneStep(idx, State.BLACK) + } } else { it.matrix.set(idx, State.WHITE) it.role = 'black' + if (this.computer) { + this.computer.oneStep(idx, State.WHITE) + } } it.anchor = undefined if (this.checkResult(idx)) { @@ -235,22 +380,36 @@ class GoBangVM extends ViewModel{ ) } } - computeNextStep(it: GoBangState) { - let x = 0, y = 0 + const tempMatrix: State[] = new Array(count * count).fill(0).map((_, idx) => { + return it.matrix.get(idx) || State.Unspecified + }) + let idx = 0 do { - x = Math.floor(Math.random() * count) - y = Math.floor(Math.random() * count) - } while (it.matrix.get(x * count + y) === State.Unspecified) + idx = this.computer.compute(tempMatrix, it.role === 'black' ? State.BLACK : State.WHITE) + } while (it.matrix.get(idx) === State.Unspecified) + this.computer.oneStep(idx, it.role === 'black' ? State.BLACK : State.WHITE) this.updateState(state => { - state.matrix.set(x * count + y, state.role === 'black' ? State.BLACK : State.WHITE) + state.matrix.set(idx, state.role === 'black' ? State.BLACK : State.WHITE) state.role = state.role === 'black' ? 'white' : 'black' }) + if (this.checkResult(idx)) { + modal(context).alert({ + title: "游戏结束", + msg: `恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`, + }).then(() => { + this.updateState(s => { + this.reset(s) + }) + }) + } } + reset(it: GoBangState) { it.matrix.clear() it.role = "black" it.anchor = undefined + this.computer = new AIComputer if (it.gameMode === GameMode.C2P) { this.computeNextStep(it) } From d7a95b5958e477a59b50e61913196c7f74a249ad Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 17 Dec 2019 16:02:14 +0800 Subject: [PATCH 27/35] update ai --- src/Gobang.ts | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 2a17f43c..ab916106 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -11,7 +11,7 @@ const count = 13 class AIComputer { - wins: Array>> = new Array(count).fill(0).map(_ => new Array(count).fill(0).map(_ => [])); + wins: Array>> = new Array(count).fill(0).map(_ => new Array(count).fill(0).map(_ => [])) winCount = 0 blackWins: number[] whiteWins: number[] @@ -411,7 +411,10 @@ class GoBangVM extends ViewModel{ it.anchor = undefined this.computer = new AIComputer if (it.gameMode === GameMode.C2P) { - this.computeNextStep(it) + const idx = Math.floor(Math.random() * count) * count + Math.floor(Math.random() * count) + this.computer.oneStep(idx, State.BLACK) + it.matrix.set(idx, State.BLACK) + it.role = 'white' } } onBind(state: GoBangState, vh: GoBangVH) { From 2850f2a4368e83e5c1c80b3c29fc792c42d5e0c4 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 17 Dec 2019 16:39:59 +0800 Subject: [PATCH 28/35] upgrade ai --- src/Gobang.ts | 177 +++++++++++++++++++++++++++++--------------------- 1 file changed, 103 insertions(+), 74 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index ab916106..70a87b1f 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -11,15 +11,19 @@ const count = 13 class AIComputer { - wins: Array>> = new Array(count).fill(0).map(_ => new Array(count).fill(0).map(_ => [])) + wins: Array> = [] winCount = 0 - blackWins: number[] - whiteWins: number[] - constructor() { + matrix: Map + constructor(matrix: Map) { + this.matrix = matrix for (let y = 0; y < count; y++) { for (let x = 0; x < count - 4; x++) { + this.wins.push([]) for (let k = 0; k < 5; k++) { - this.wins[x + k][y][this.winCount] = true; + this.wins[this.winCount].push({ + x: x + k, + y, + }) } this.winCount++; } @@ -27,8 +31,12 @@ class AIComputer { for (let x = 0; x < count; x++) { for (let y = 0; y < count - 4; y++) { + this.wins.push([]) for (let k = 0; k < 5; k++) { - this.wins[x][y + k][this.winCount] = true; + this.wins[this.winCount].push({ + x, + y: y + k, + }) } this.winCount++; } @@ -36,8 +44,12 @@ class AIComputer { for (let x = 0; x < count - 4; x++) { for (let y = 0; y < count - 4; y++) { + this.wins.push([]) for (let k = 0; k < 5; k++) { - this.wins[x + k][y + k][this.winCount] = true; + this.wins[this.winCount].push({ + x: x + k, + y: y + k, + }) } this.winCount++; } @@ -45,28 +57,16 @@ class AIComputer { for (let x = 0; x < count - 4; x++) { for (let y = count - 1; y > 3; y--) { + this.wins.push([]) for (let k = 0; k < 5; k++) { - this.wins[x + k][y - k][this.winCount] = true; + this.wins[this.winCount].push({ + x: x + k, + y: y - k, + }) } this.winCount++; } } - this.blackWins = new Array(this.winCount).fill(0) - this.whiteWins = new Array(this.winCount).fill(0) - } - - - oneStep(idx: number, role: State.BLACK | State.WHITE) { - const { x, y } = this.index2Position(idx) - for (let loop = 0; loop < this.winCount; loop++) { - if (this.wins[x][y][loop]) { - if (role === State.BLACK) { - this.blackWins[loop] += 1 - } else { - this.whiteWins[loop] += 1 - } - } - } } index2Position(idx: number) { @@ -74,6 +74,41 @@ class AIComputer { const y = Math.floor(idx / count) return { x, y } } + get blackWins() { + return this.wins.map((win) => { + let idx = 0 + for (let e of win) { + switch (this.matrix.get(e.x + e.y * count)) { + case State.BLACK: + idx++ + break + case State.WHITE: + return 0 + default: + break + } + } + return idx + }) + } + + get whiteWins() { + return this.wins.map((win) => { + let count = 0 + for (let e of win) { + switch (this.matrix.get(e.x + e.y * count)) { + case State.WHITE: + count++ + break + case State.BLACK: + return 0 + default: + break + } + } + return count + }) + } compute(matrix: State[], role: State.BLACK | State.WHITE) { const myScore = new Array(matrix.length).fill(0) @@ -86,44 +121,44 @@ class AIComputer { if (state != State.Unspecified) { return } - const { x, y } = this.index2Position(idx) - for (let loop = 0; loop < this.winCount; loop++) { - if (this.wins[x][y][loop]) { - switch (rivalWins[loop]) { - case 1: - rivalScore[idx] += 200 - break - case 2: - rivalScore[idx] += 400 - break - case 3: - rivalScore[idx] += 2000 - break - case 4: - rivalScore[idx] += 10000 - break - default: - break - } - - switch (myWins[loop]) { - case 1: - myScore[idx] += 220 - break - case 2: - myScore[idx] += 420 - break - case 3: - myScore[idx] += 2200 - break - case 4: - myScore[idx] += 20000 - break - default: - break - } + this.wins.forEach((e, winIdx) => { + if (e.filter(e => (e.x + e.y * count) === idx).length === 0) { + return } - } + switch (rivalWins[winIdx]) { + case 1: + rivalScore[idx] += 200 + break + case 2: + rivalScore[idx] += 400 + break + case 3: + rivalScore[idx] += 2000 + break + case 4: + rivalScore[idx] += 10000 + break + default: + break + } + + switch (myWins[winIdx]) { + case 1: + myScore[idx] += 220 + break + case 2: + myScore[idx] += 420 + break + case 3: + myScore[idx] += 2200 + break + case 4: + myScore[idx] += 20000 + break + default: + break + } + }) if (rivalScore[idx] > max) { max = rivalScore[idx]; retIdx = idx @@ -141,8 +176,6 @@ class AIComputer { retIdx = idx } } - - }) return retIdx } @@ -307,15 +340,9 @@ class GoBangVM extends ViewModel{ if (it.role === 'black') { it.matrix.set(idx, State.BLACK) it.role = 'white' - if (this.computer) { - this.computer.oneStep(idx, State.BLACK) - } } else { it.matrix.set(idx, State.WHITE) it.role = 'black' - if (this.computer) { - this.computer.oneStep(idx, State.WHITE) - } } it.anchor = undefined if (this.checkResult(idx)) { @@ -329,9 +356,13 @@ class GoBangVM extends ViewModel{ }) } else { if (it.role === 'black' && it.gameMode === GameMode.C2P) { - this.computeNextStep(it) + setTimeout(() => { + this.computeNextStep(it) + }, 0) } else if (it.role === 'white' && it.gameMode === GameMode.P2C) { - this.computeNextStep(it) + setTimeout(() => { + this.computeNextStep(it) + }, 0) } } }) @@ -388,7 +419,6 @@ class GoBangVM extends ViewModel{ do { idx = this.computer.compute(tempMatrix, it.role === 'black' ? State.BLACK : State.WHITE) } while (it.matrix.get(idx) === State.Unspecified) - this.computer.oneStep(idx, it.role === 'black' ? State.BLACK : State.WHITE) this.updateState(state => { state.matrix.set(idx, state.role === 'black' ? State.BLACK : State.WHITE) state.role = state.role === 'black' ? 'white' : 'black' @@ -409,10 +439,9 @@ class GoBangVM extends ViewModel{ it.matrix.clear() it.role = "black" it.anchor = undefined - this.computer = new AIComputer + this.computer = new AIComputer(it.matrix) if (it.gameMode === GameMode.C2P) { const idx = Math.floor(Math.random() * count) * count + Math.floor(Math.random() * count) - this.computer.oneStep(idx, State.BLACK) it.matrix.set(idx, State.BLACK) it.role = 'white' } From 78d1b5d929e0e355cc46610fa4f9dd06dd406294 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 17 Dec 2019 16:52:43 +0800 Subject: [PATCH 29/35] fix ai --- src/Gobang.ts | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 70a87b1f..fcf528c3 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -69,11 +69,6 @@ class AIComputer { } } - index2Position(idx: number) { - const x = idx % count - const y = Math.floor(idx / count) - return { x, y } - } get blackWins() { return this.wins.map((win) => { let idx = 0 @@ -94,11 +89,11 @@ class AIComputer { get whiteWins() { return this.wins.map((win) => { - let count = 0 + let idx = 0 for (let e of win) { switch (this.matrix.get(e.x + e.y * count)) { case State.WHITE: - count++ + idx++ break case State.BLACK: return 0 @@ -106,7 +101,7 @@ class AIComputer { break } } - return count + return idx }) } @@ -323,6 +318,9 @@ class GoBangVH extends ViewHolder { class GoBangVM extends ViewModel{ computer!: AIComputer onAttached(state: GoBangState, vh: GoBangVH) { + if (!this.computer) { + this.computer = new AIComputer(state.matrix) + } vh.actualBuild(state) vh.targetZone.forEach((e, idx) => { e.onClick = () => { @@ -611,7 +609,7 @@ class Gobang extends VMPanel { gap: this.getRootView().width / 14, role: "black", matrix: new Map, - gameMode: GameMode.P2P, + gameMode: GameMode.P2C, } } getViewHolderClass() { From 81da004341da6c4d17216fc7a15c658c97ce7088 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 17 Dec 2019 17:01:21 +0800 Subject: [PATCH 30/35] update ai --- src/Gobang.ts | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index fcf528c3..ca89403b 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -122,13 +122,13 @@ class AIComputer { } switch (rivalWins[winIdx]) { case 1: - rivalScore[idx] += 200 + rivalScore[idx] += 1 break case 2: - rivalScore[idx] += 400 + rivalScore[idx] += 10 break case 3: - rivalScore[idx] += 2000 + rivalScore[idx] += 100 break case 4: rivalScore[idx] += 10000 @@ -139,13 +139,13 @@ class AIComputer { switch (myWins[winIdx]) { case 1: - myScore[idx] += 220 + myScore[idx] += 2 break case 2: - myScore[idx] += 420 + myScore[idx] += 20 break case 3: - myScore[idx] += 2200 + myScore[idx] += 200 break case 4: myScore[idx] += 20000 From 723636c90278d3603c5c3610c5e13448227ce66c Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 17 Dec 2019 17:29:36 +0800 Subject: [PATCH 31/35] feat:optimize --- src/Gobang.ts | 69 +++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 50 insertions(+), 19 deletions(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index ca89403b..6d6b38f1 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -212,6 +212,7 @@ interface GoBangState { matrix: Map anchor?: number gameMode: GameMode + gameState: "blackWin" | "whiteWin" | "idle" } class GoBangVH extends ViewHolder { @@ -324,6 +325,9 @@ class GoBangVM extends ViewModel{ vh.actualBuild(state) vh.targetZone.forEach((e, idx) => { e.onClick = () => { + if (state.gameState !== 'idle') { + return + } const zoneState = state.matrix.get(idx) if (zoneState === State.BLACK || zoneState === State.WHITE) { modal(context).toast('This position had been token.') @@ -344,14 +348,8 @@ class GoBangVM extends ViewModel{ } it.anchor = undefined if (this.checkResult(idx)) { - modal(context).alert({ - title: "游戏结束", - msg: `恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`, - }).then(() => { - this.updateState(s => { - this.reset(s) - }) - }) + modal(context).toast(`恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`) + it.gameState = it.role === 'white' ? 'blackWin' : 'whiteWin' } else { if (it.role === 'black' && it.gameMode === GameMode.C2P) { setTimeout(() => { @@ -408,6 +406,30 @@ class GoBangVM extends ViewModel{ } as IVLayout) ) } + vh.result.onClick = () => { + switch (state.gameState) { + case "idle": + this.updateState(state => { + this.reset(state) + }) + break + case "blackWin": + case "whiteWin": + break + } + } + vh.currentRole.onClick = () => { + switch (state.gameState) { + case "idle": + break + case "blackWin": + case "whiteWin": + this.updateState(state => { + this.reset(state) + }) + break + } + } } computeNextStep(it: GoBangState) { const tempMatrix: State[] = new Array(count * count).fill(0).map((_, idx) => { @@ -420,21 +442,16 @@ class GoBangVM extends ViewModel{ this.updateState(state => { state.matrix.set(idx, state.role === 'black' ? State.BLACK : State.WHITE) state.role = state.role === 'black' ? 'white' : 'black' + if (this.checkResult(idx)) { + modal(context).toast(`恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`) + it.gameState = it.role === 'white' ? 'blackWin' : 'whiteWin' + } }) - if (this.checkResult(idx)) { - modal(context).alert({ - title: "游戏结束", - msg: `恭喜获胜方${it.role === 'white' ? "黑方" : "白方"}`, - }).then(() => { - this.updateState(s => { - this.reset(s) - }) - }) - } } reset(it: GoBangState) { it.matrix.clear() + it.gameState = 'idle' it.role = "black" it.anchor = undefined this.computer = new AIComputer(it.matrix) @@ -490,8 +507,21 @@ class GoBangVM extends ViewModel{ }) } }) - vh.currentRole.text = `当前: ${(state.role === 'black') ? "黑方" : "白方"}` vh.gameMode.text = `游戏模式: 黑方 ${state.gameMode === GameMode.C2P ? "机" : "人"} 白方 ${state.gameMode === GameMode.P2C ? "机" : "人"}` + switch (state.gameState) { + case "idle": + vh.result.text = "重新开始" + vh.currentRole.text = `当前: ${(state.role === 'black') ? "黑方" : "白方"}` + break + case "blackWin": + vh.result.text = "黑方获胜" + vh.currentRole.text = "重新开始" + break + case "whiteWin": + vh.result.text = "白方获胜" + vh.currentRole.text = "重新开始" + break + } } checkResult(pos: number) { @@ -610,6 +640,7 @@ class Gobang extends VMPanel { role: "black", matrix: new Map, gameMode: GameMode.P2C, + gameState: "idle" } } getViewHolderClass() { From 2ccb2193d0bb0eb220fdbf2564461544856ca8e6 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Tue, 17 Dec 2019 17:50:51 +0800 Subject: [PATCH 32/35] feat:add assistant --- src/Gobang.ts | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) diff --git a/src/Gobang.ts b/src/Gobang.ts index 6d6b38f1..d1563c32 100644 --- a/src/Gobang.ts +++ b/src/Gobang.ts @@ -222,6 +222,7 @@ class GoBangVH extends ViewHolder { result!: Text targetZone: View[] = [] gameMode!: Text + assistant!: Text build(root: Group): void { this.root = root } @@ -285,7 +286,7 @@ class GoBangVH extends ViewHolder { textColor: Color.WHITE, layoutConfig: layoutConfig().most().configHeight(LayoutSpec.JUST), height: 50, - backgroundColor: colors[3], + backgroundColor: colors[8], }), hlayout([ this.currentRole = text({ @@ -307,6 +308,14 @@ class GoBangVH extends ViewHolder { ]).apply({ layoutConfig: layoutConfig().fit().configWidth(LayoutSpec.MOST), } as IHLayout), + this.assistant = text({ + text: "提示", + textSize: 20, + textColor: Color.WHITE, + layoutConfig: layoutConfig().just().configWidth(LayoutSpec.MOST), + height: 50, + backgroundColor: colors[3], + }), ]) .apply({ layoutConfig: layoutConfig().fit(), @@ -430,6 +439,25 @@ class GoBangVM extends ViewModel{ break } } + vh.assistant.onClick = () => { + const it = this.getState() + if (it.gameState !== 'idle') { + return + } + this.computeNextStep(it) + if (it.gameState !== 'idle') { + return + } + if (it.role === 'black' && it.gameMode === GameMode.C2P) { + setTimeout(() => { + this.computeNextStep(it) + }, 0) + } else if (it.role === 'white' && it.gameMode === GameMode.P2C) { + setTimeout(() => { + this.computeNextStep(it) + }, 0) + } + } } computeNextStep(it: GoBangState) { const tempMatrix: State[] = new Array(count * count).fill(0).map((_, idx) => { From 4a8769684c1df71633ff4693ca2363ebdf217128 Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 18 Dec 2019 15:28:32 +0800 Subject: [PATCH 33/35] update rollup config --- index.ts | 19 +------------ rollup.config.js | 69 ++++++++++++++++++++++++++++++++++++------------ 2 files changed, 53 insertions(+), 35 deletions(-) diff --git a/index.ts b/index.ts index fade3a4a..5f778ea2 100644 --- a/index.ts +++ b/index.ts @@ -1,24 +1,7 @@ export default [ 'src/Counter', 'src/Snake', - 'src/ListDemo', - 'src/ScrollerDemo', - 'src/SliderDemo', - 'src/LayoutDemo', - 'src/EffectsDemo', - 'src/ImageDemo', - 'src/ModalDemo', - 'src/NetworkDemo', - 'src/StorageDemo', - 'src/NavigatorDemo', - 'src/NavbarDemo', - 'src/RefreshableDemo', - 'src/FlowLayoutDemo', - 'src/PopoverDemo', - 'src/AnimatorDemo', 'src/ComplicatedAnimations', - 'src/ComplicatedDemo', - 'src/InputDemo', - 'src/StickDemo', + 'src/.*Demo', 'src/Gobang', ] \ No newline at end of file diff --git a/rollup.config.js b/rollup.config.js index 3e5b5b75..85dd2275 100644 --- a/rollup.config.js +++ b/rollup.config.js @@ -1,23 +1,58 @@ import resolve from 'rollup-plugin-node-resolve' import commonjs from 'rollup-plugin-commonjs' import bundles from './build/index' +import fs from 'fs' +import path from 'path' -export default bundles.map(bundle => { - return { - input: `build/${bundle}.js`, - output: { - format: "cjs", - file: `bundle/${bundle}.js`, - sourcemap: true, - }, - plugins: [ - resolve({ mainFields: ["jsnext"] }), - commonjs() - ], - external: ['reflect-metadata', 'doric'], - onwarn: function (warning) { - if (warning.code === 'THIS_IS_UNDEFINED') { return; } - console.warn(warning.message); +function readDirs(dirPath, files) { + if (fs.statSync(dirPath).isDirectory()) { + fs.readdirSync(dirPath).forEach(e => { + readDirs(path.join(dirPath, e), files) + }) + } else { + for (let bundle of bundles) { + if (dirPath.match(new RegExp(`^${bundle}`))) { + files.push(dirPath) + } } } -}) \ No newline at end of file +} + + +const dirs = fs.readdirSync('.') + .filter(e => { + for (let bundle of bundles) { + if (bundle.match(new RegExp(`^${e}/`))) { + return true + } + } + return false + }) + +const allFiles = [] + +dirs.forEach(e => { + readDirs(e, allFiles) +}) + +export default allFiles + .map(e => e.replace('.ts', '')) + .map(bundle => { + return { + input: `build/${bundle}.js`, + output: { + format: "cjs", + file: `bundle/${bundle}.js`, + sourcemap: true, + }, + plugins: [ + resolve({ mainFields: ["jsnext"] }), + commonjs() + ], + external: ['reflect-metadata', 'doric'], + onwarn: function (warning) { + if (warning.code === 'THIS_IS_UNDEFINED') { return; } + console.warn(warning.message); + } + } + }) \ No newline at end of file From c76274b76255560e051270f6a803ec822be8605f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E5=8A=B2=E9=B9=8F?= Date: Fri, 20 Dec 2019 11:19:30 +0800 Subject: [PATCH 34/35] update rollup & rollup plugin node resolve --- package-lock.json | 128 +++++++++++++++++++++++----------------------- package.json | 4 +- rollup.config.js | 2 +- 3 files changed, 67 insertions(+), 67 deletions(-) diff --git a/package-lock.json b/package-lock.json index b074ffed..36c4f6a8 100644 --- a/package-lock.json +++ b/package-lock.json @@ -4,15 +4,35 @@ "lockfileVersion": 1, "requires": true, "dependencies": { + "@rollup/plugin-node-resolve": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-6.0.0.tgz", + "integrity": "sha512-GqWz1CfXOsqpeVMcoM315+O7zMxpRsmhWyhJoxLFHVSp9S64/u02i7len/FnbTNbmgYs+sZyilasijH8UiuboQ==", + "requires": { + "@rollup/pluginutils": "^3.0.0", + "@types/resolve": "0.0.8", + "builtin-modules": "^3.1.0", + "is-module": "^1.0.0", + "resolve": "^1.11.1" + } + }, + "@rollup/pluginutils": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.0.0.tgz", + "integrity": "sha512-qBbGQQaUUiId/lBU9VMeYlVLOoRNvz1fV8HWY5tiGDpI2gdPZHbmOfCjzSdXPhdq3XOfyWvXEBlIPbnM3+9ogQ==", + "requires": { + "estree-walker": "^0.6.1" + } + }, "@types/estree": { "version": "0.0.40", "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" }, "@types/node": { - "version": "12.12.17", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.17.tgz", - "integrity": "sha512-Is+l3mcHvs47sKy+afn2O1rV4ldZFU7W8101cNlOd+MRbjM4Onida8jSZnJdTe/0Pcf25g9BNIUsuugmE6puHA==" + "version": "12.12.21", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.21.tgz", + "integrity": "sha512-8sRGhbpU+ck1n0PGAUgVrWrWdjSW2aqNeyC15W88GRsMpSwzv6RJGlLhE7s2RhVSOdyDmxbqlWSeThq4/7xqlA==" }, "@types/resolve": { "version": "0.0.8", @@ -35,24 +55,44 @@ "doric": { "version": "file:../doric-js", "requires": { + "@rollup/plugin-node-resolve": "^6.0.0", "@types/ws": "^6.0.4", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.10", - "rollup-plugin-node-resolve": "^5.2.0", + "rollup": "^1.27.13", "tslib": "^1.10.0", "typescript": "^3.7.3", - "ws": "^7.2.0" + "ws": "^7.2.1" }, "dependencies": { + "@rollup/plugin-node-resolve": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-6.0.0.tgz", + "integrity": "sha512-GqWz1CfXOsqpeVMcoM315+O7zMxpRsmhWyhJoxLFHVSp9S64/u02i7len/FnbTNbmgYs+sZyilasijH8UiuboQ==", + "requires": { + "@rollup/pluginutils": "^3.0.0", + "@types/resolve": "0.0.8", + "builtin-modules": "^3.1.0", + "is-module": "^1.0.0", + "resolve": "^1.11.1" + } + }, + "@rollup/pluginutils": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.0.0.tgz", + "integrity": "sha512-qBbGQQaUUiId/lBU9VMeYlVLOoRNvz1fV8HWY5tiGDpI2gdPZHbmOfCjzSdXPhdq3XOfyWvXEBlIPbnM3+9ogQ==", + "requires": { + "estree-walker": "^0.6.1" + } + }, "@types/estree": { "version": "0.0.40", "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.40.tgz", "integrity": "sha512-p3KZgMto/JyxosKGmnLDJ/dG5wf+qTRMUjHJcspC2oQKa4jP7mz+tv0ND56lLBu3ojHlhzY33Ol+khLyNmilkA==" }, "@types/node": { - "version": "12.12.17", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.17.tgz", - "integrity": "sha512-Is+l3mcHvs47sKy+afn2O1rV4ldZFU7W8101cNlOd+MRbjM4Onida8jSZnJdTe/0Pcf25g9BNIUsuugmE6puHA==" + "version": "12.12.21", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.21.tgz", + "integrity": "sha512-8sRGhbpU+ck1n0PGAUgVrWrWdjSW2aqNeyC15W88GRsMpSwzv6RJGlLhE7s2RhVSOdyDmxbqlWSeThq4/7xqlA==" }, "@types/resolve": { "version": "0.0.8", @@ -75,11 +115,6 @@ "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" }, - "async-limiter": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", - "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" - }, "builtin-modules": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", @@ -106,43 +141,23 @@ "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" }, "resolve": { - "version": "1.13.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", - "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.14.1.tgz", + "integrity": "sha512-fn5Wobh4cxbLzuHaE+nphztHy43/b++4M6SsGFC2gB8uYwf0C8LcarfCz1un7UTW8OFQg9iNjZ4xpcFVGebDPg==", "requires": { "path-parse": "^1.0.6" } }, "rollup": { - "version": "1.27.12", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.12.tgz", - "integrity": "sha512-51iR7n6NQfdQJlRrIktaGmkdt395A8Vue7CdnlrK6UhY9DY2GaKsTdljWeXisJuZh+w90Gz8VFNh5X+yxP20oQ==", + "version": "1.27.13", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.13.tgz", + "integrity": "sha512-hDi7M07MpmNSDE8YVwGVFA8L7n8jTLJ4lG65nMAijAyqBe//rtu4JdxjUBE7JqXfdpqxqDTbCDys9WcqdpsQvw==", "requires": { "@types/estree": "*", "@types/node": "*", "acorn": "^7.1.0" } }, - "rollup-plugin-node-resolve": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", - "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", - "requires": { - "@types/resolve": "0.0.8", - "builtin-modules": "^3.1.0", - "is-module": "^1.0.0", - "resolve": "^1.11.1", - "rollup-pluginutils": "^2.8.1" - } - }, - "rollup-pluginutils": { - "version": "2.8.2", - "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", - "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", - "requires": { - "estree-walker": "^0.6.1" - } - }, "tslib": { "version": "1.10.0", "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", @@ -154,12 +169,9 @@ "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==" }, "ws": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.0.tgz", - "integrity": "sha512-+SqNqFbwTm/0DC18KYzIsMTnEWpLwJsiasW/O17la4iDRRIO9uaHbvKiAS3AHgTiuuWerK/brj4O6MYZkei9xg==", - "requires": { - "async-limiter": "^1.0.0" - } + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.1.tgz", + "integrity": "sha512-sucePNSafamSKoOqoNfBd8V0StlkzJKL2ZAhGQinCfNQ+oacw+Pk7lcdAElecBF2VkLNZRiIb5Oi1Q5lVUVt2A==" } } }, @@ -207,17 +219,17 @@ "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" }, "resolve": { - "version": "1.13.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", - "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.14.1.tgz", + "integrity": "sha512-fn5Wobh4cxbLzuHaE+nphztHy43/b++4M6SsGFC2gB8uYwf0C8LcarfCz1un7UTW8OFQg9iNjZ4xpcFVGebDPg==", "requires": { "path-parse": "^1.0.6" } }, "rollup": { - "version": "1.27.12", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.12.tgz", - "integrity": "sha512-51iR7n6NQfdQJlRrIktaGmkdt395A8Vue7CdnlrK6UhY9DY2GaKsTdljWeXisJuZh+w90Gz8VFNh5X+yxP20oQ==", + "version": "1.27.13", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.27.13.tgz", + "integrity": "sha512-hDi7M07MpmNSDE8YVwGVFA8L7n8jTLJ4lG65nMAijAyqBe//rtu4JdxjUBE7JqXfdpqxqDTbCDys9WcqdpsQvw==", "requires": { "@types/estree": "*", "@types/node": "*", @@ -236,18 +248,6 @@ "rollup-pluginutils": "^2.8.1" } }, - "rollup-plugin-node-resolve": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-5.2.0.tgz", - "integrity": "sha512-jUlyaDXts7TW2CqQ4GaO5VJ4PwwaV8VUGA7+km3n6k6xtOEacf61u0VXwN80phY/evMcaS+9eIeJ9MOyDxt5Zw==", - "requires": { - "@types/resolve": "0.0.8", - "builtin-modules": "^3.1.0", - "is-module": "^1.0.0", - "resolve": "^1.11.1", - "rollup-pluginutils": "^2.8.1" - } - }, "rollup-pluginutils": { "version": "2.8.2", "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", diff --git a/package.json b/package.json index c8f9338a..46e11717 100644 --- a/package.json +++ b/package.json @@ -12,9 +12,9 @@ "dependencies": { "doric": "file:../doric-js", "reflect-metadata": "^0.1.13", - "rollup": "^1.27.12", + "rollup": "^1.27.13", "rollup-plugin-commonjs": "^10.1.0", - "rollup-plugin-node-resolve": "^5.2.0", + "@rollup/plugin-node-resolve": "^6.0.0", "tslib": "^1.10.0", "typescript": "^3.7.3" } diff --git a/rollup.config.js b/rollup.config.js index 85dd2275..cc4cd96d 100644 --- a/rollup.config.js +++ b/rollup.config.js @@ -1,4 +1,4 @@ -import resolve from 'rollup-plugin-node-resolve' +import resolve from '@rollup/plugin-node-resolve' import commonjs from 'rollup-plugin-commonjs' import bundles from './build/index' import fs from 'fs' From 5fcba0a28bce0aea0900988c22dfdde30704b44e Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Sat, 21 Dec 2019 22:07:15 +0800 Subject: [PATCH 35/35] rename dir --- .gitignore => doric-demo/.gitignore | 0 {.vscode => doric-demo/.vscode}/launch.json | 0 {.vscode => doric-demo/.vscode}/tasks.json | 0 LICENSE => doric-demo/LICENSE | 0 README.md => doric-demo/README.md | 0 index.ts => doric-demo/index.ts | 0 package-lock.json => doric-demo/package-lock.json | 0 package.json => doric-demo/package.json | 0 rollup.config.js => doric-demo/rollup.config.js | 0 {src => doric-demo/src}/AnimatorDemo.ts | 0 {src => doric-demo/src}/ComplicatedAnimations.ts | 0 {src => doric-demo/src}/ComplicatedDemo.ts | 0 {src => doric-demo/src}/Counter.ts | 0 {src => doric-demo/src}/EffectsDemo.ts | 0 {src => doric-demo/src}/FlowLayoutDemo.ts | 0 {src => doric-demo/src}/Gobang.ts | 0 {src => doric-demo/src}/ImageDemo.ts | 0 {src => doric-demo/src}/InputDemo.ts | 0 {src => doric-demo/src}/LayoutDemo.ts | 0 {src => doric-demo/src}/ListDemo.ts | 0 {src => doric-demo/src}/ModalDemo.ts | 0 {src => doric-demo/src}/NavbarDemo.ts | 0 {src => doric-demo/src}/NavigatorDemo.ts | 0 {src => doric-demo/src}/NetworkDemo.ts | 0 {src => doric-demo/src}/PopoverDemo.ts | 0 {src => doric-demo/src}/RefreshableDemo.ts | 0 {src => doric-demo/src}/ScrollerDemo.ts | 0 {src => doric-demo/src}/SliderDemo.ts | 0 {src => doric-demo/src}/Snake.ts | 0 {src => doric-demo/src}/StickDemo.ts | 0 {src => doric-demo/src}/StorageDemo.ts | 0 {src => doric-demo/src}/image_base64.ts | 0 {src => doric-demo/src}/utils.ts | 0 tsconfig.json => doric-demo/tsconfig.json | 0 34 files changed, 0 insertions(+), 0 deletions(-) rename .gitignore => doric-demo/.gitignore (100%) rename {.vscode => doric-demo/.vscode}/launch.json (100%) rename {.vscode => doric-demo/.vscode}/tasks.json (100%) rename LICENSE => doric-demo/LICENSE (100%) rename README.md => doric-demo/README.md (100%) rename index.ts => doric-demo/index.ts (100%) rename package-lock.json => doric-demo/package-lock.json (100%) rename package.json => doric-demo/package.json (100%) rename rollup.config.js => doric-demo/rollup.config.js (100%) rename {src => doric-demo/src}/AnimatorDemo.ts (100%) rename {src => doric-demo/src}/ComplicatedAnimations.ts (100%) rename {src => doric-demo/src}/ComplicatedDemo.ts (100%) rename {src => doric-demo/src}/Counter.ts (100%) rename {src => doric-demo/src}/EffectsDemo.ts (100%) rename {src => doric-demo/src}/FlowLayoutDemo.ts (100%) rename {src => doric-demo/src}/Gobang.ts (100%) rename {src => doric-demo/src}/ImageDemo.ts (100%) rename {src => doric-demo/src}/InputDemo.ts (100%) rename {src => doric-demo/src}/LayoutDemo.ts (100%) rename {src => doric-demo/src}/ListDemo.ts (100%) rename {src => doric-demo/src}/ModalDemo.ts (100%) rename {src => doric-demo/src}/NavbarDemo.ts (100%) rename {src => doric-demo/src}/NavigatorDemo.ts (100%) rename {src => doric-demo/src}/NetworkDemo.ts (100%) rename {src => doric-demo/src}/PopoverDemo.ts (100%) rename {src => doric-demo/src}/RefreshableDemo.ts (100%) rename {src => doric-demo/src}/ScrollerDemo.ts (100%) rename {src => doric-demo/src}/SliderDemo.ts (100%) rename {src => doric-demo/src}/Snake.ts (100%) rename {src => doric-demo/src}/StickDemo.ts (100%) rename {src => doric-demo/src}/StorageDemo.ts (100%) rename {src => doric-demo/src}/image_base64.ts (100%) rename {src => doric-demo/src}/utils.ts (100%) rename tsconfig.json => doric-demo/tsconfig.json (100%) diff --git a/.gitignore b/doric-demo/.gitignore similarity index 100% rename from .gitignore rename to doric-demo/.gitignore diff --git a/.vscode/launch.json b/doric-demo/.vscode/launch.json similarity index 100% rename from .vscode/launch.json rename to doric-demo/.vscode/launch.json diff --git a/.vscode/tasks.json b/doric-demo/.vscode/tasks.json similarity index 100% rename from .vscode/tasks.json rename to doric-demo/.vscode/tasks.json diff --git a/LICENSE b/doric-demo/LICENSE similarity index 100% rename from LICENSE rename to doric-demo/LICENSE diff --git a/README.md b/doric-demo/README.md similarity index 100% rename from README.md rename to doric-demo/README.md diff --git a/index.ts b/doric-demo/index.ts similarity index 100% rename from index.ts rename to doric-demo/index.ts diff --git a/package-lock.json b/doric-demo/package-lock.json similarity index 100% rename from package-lock.json rename to doric-demo/package-lock.json diff --git a/package.json b/doric-demo/package.json similarity index 100% rename from package.json rename to doric-demo/package.json diff --git a/rollup.config.js b/doric-demo/rollup.config.js similarity index 100% rename from rollup.config.js rename to doric-demo/rollup.config.js diff --git a/src/AnimatorDemo.ts b/doric-demo/src/AnimatorDemo.ts similarity index 100% rename from src/AnimatorDemo.ts rename to doric-demo/src/AnimatorDemo.ts diff --git a/src/ComplicatedAnimations.ts b/doric-demo/src/ComplicatedAnimations.ts similarity index 100% rename from src/ComplicatedAnimations.ts rename to doric-demo/src/ComplicatedAnimations.ts diff --git a/src/ComplicatedDemo.ts b/doric-demo/src/ComplicatedDemo.ts similarity index 100% rename from src/ComplicatedDemo.ts rename to doric-demo/src/ComplicatedDemo.ts diff --git a/src/Counter.ts b/doric-demo/src/Counter.ts similarity index 100% rename from src/Counter.ts rename to doric-demo/src/Counter.ts diff --git a/src/EffectsDemo.ts b/doric-demo/src/EffectsDemo.ts similarity index 100% rename from src/EffectsDemo.ts rename to doric-demo/src/EffectsDemo.ts diff --git a/src/FlowLayoutDemo.ts b/doric-demo/src/FlowLayoutDemo.ts similarity index 100% rename from src/FlowLayoutDemo.ts rename to doric-demo/src/FlowLayoutDemo.ts diff --git a/src/Gobang.ts b/doric-demo/src/Gobang.ts similarity index 100% rename from src/Gobang.ts rename to doric-demo/src/Gobang.ts diff --git a/src/ImageDemo.ts b/doric-demo/src/ImageDemo.ts similarity index 100% rename from src/ImageDemo.ts rename to doric-demo/src/ImageDemo.ts diff --git a/src/InputDemo.ts b/doric-demo/src/InputDemo.ts similarity index 100% rename from src/InputDemo.ts rename to doric-demo/src/InputDemo.ts diff --git a/src/LayoutDemo.ts b/doric-demo/src/LayoutDemo.ts similarity index 100% rename from src/LayoutDemo.ts rename to doric-demo/src/LayoutDemo.ts diff --git a/src/ListDemo.ts b/doric-demo/src/ListDemo.ts similarity index 100% rename from src/ListDemo.ts rename to doric-demo/src/ListDemo.ts diff --git a/src/ModalDemo.ts b/doric-demo/src/ModalDemo.ts similarity index 100% rename from src/ModalDemo.ts rename to doric-demo/src/ModalDemo.ts diff --git a/src/NavbarDemo.ts b/doric-demo/src/NavbarDemo.ts similarity index 100% rename from src/NavbarDemo.ts rename to doric-demo/src/NavbarDemo.ts diff --git a/src/NavigatorDemo.ts b/doric-demo/src/NavigatorDemo.ts similarity index 100% rename from src/NavigatorDemo.ts rename to doric-demo/src/NavigatorDemo.ts diff --git a/src/NetworkDemo.ts b/doric-demo/src/NetworkDemo.ts similarity index 100% rename from src/NetworkDemo.ts rename to doric-demo/src/NetworkDemo.ts diff --git a/src/PopoverDemo.ts b/doric-demo/src/PopoverDemo.ts similarity index 100% rename from src/PopoverDemo.ts rename to doric-demo/src/PopoverDemo.ts diff --git a/src/RefreshableDemo.ts b/doric-demo/src/RefreshableDemo.ts similarity index 100% rename from src/RefreshableDemo.ts rename to doric-demo/src/RefreshableDemo.ts diff --git a/src/ScrollerDemo.ts b/doric-demo/src/ScrollerDemo.ts similarity index 100% rename from src/ScrollerDemo.ts rename to doric-demo/src/ScrollerDemo.ts diff --git a/src/SliderDemo.ts b/doric-demo/src/SliderDemo.ts similarity index 100% rename from src/SliderDemo.ts rename to doric-demo/src/SliderDemo.ts diff --git a/src/Snake.ts b/doric-demo/src/Snake.ts similarity index 100% rename from src/Snake.ts rename to doric-demo/src/Snake.ts diff --git a/src/StickDemo.ts b/doric-demo/src/StickDemo.ts similarity index 100% rename from src/StickDemo.ts rename to doric-demo/src/StickDemo.ts diff --git a/src/StorageDemo.ts b/doric-demo/src/StorageDemo.ts similarity index 100% rename from src/StorageDemo.ts rename to doric-demo/src/StorageDemo.ts diff --git a/src/image_base64.ts b/doric-demo/src/image_base64.ts similarity index 100% rename from src/image_base64.ts rename to doric-demo/src/image_base64.ts diff --git a/src/utils.ts b/doric-demo/src/utils.ts similarity index 100% rename from src/utils.ts rename to doric-demo/src/utils.ts diff --git a/tsconfig.json b/doric-demo/tsconfig.json similarity index 100% rename from tsconfig.json rename to doric-demo/tsconfig.json