diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/.gitignore b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..d2ff20141ceed86d87c0ea5d99481973005bab2b --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/.gitignore @@ -0,0 +1,12 @@ +/node_modules +/oh_modules +/local.properties +/.idea +**/build +/.hvigor +.cxx +/.clangd +/.clang-format +/.clang-tidy +**/.test +/.appanalyzer \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/app.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/app.json5 new file mode 100644 index 0000000000000000000000000000000000000000..99f5c793567ac51163307cd3456cc32e96709090 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/app.json5 @@ -0,0 +1,10 @@ +{ + "app": { + "bundleName": "com.example.basiccomponent", + "vendor": "example", + "versionCode": 1000000, + "versionName": "1.0.0", + "icon": "$media:layered_image", + "label": "$string:app_name" + } +} diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/element/string.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..c4d5c75d193f03ae174e82185b275d68e77019e1 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "app_name", + "value": "basicComponent" + } + ] +} diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/background.png b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/background.png new file mode 100644 index 0000000000000000000000000000000000000000..923f2b3f27e915d6871871deea0420eb45ce102f Binary files /dev/null and b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/background.png differ diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/foreground.png b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/foreground.png new file mode 100644 index 0000000000000000000000000000000000000000..eb9427585b36d14b12477435b6419d1f07b3e0bb Binary files /dev/null and b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/foreground.png differ diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/layered_image.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/layered_image.json new file mode 100644 index 0000000000000000000000000000000000000000..fb49920440fb4d246c82f9ada275e26123a2136a --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/AppScope/resources/base/media/layered_image.json @@ -0,0 +1,7 @@ +{ + "layered-image": + { + "background" : "$media:background", + "foreground" : "$media:foreground" + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/build-profile.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/build-profile.json5 new file mode 100644 index 0000000000000000000000000000000000000000..6523d992ff1c87b2b54ceebb6562cbd006fe6d8f --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/build-profile.json5 @@ -0,0 +1,42 @@ +{ + "app": { + "signingConfigs": [], + "products": [ + { + "name": "default", + "signingConfig": "default", + "targetSdkVersion": "6.0.0(20)", + "compatibleSdkVersion": "6.0.0(20)", + "runtimeOS": "HarmonyOS", + "buildOption": { + "strictMode": { + "caseSensitiveCheck": true, + "useNormalizedOHMUrl": true + } + } + } + ], + "buildModeSet": [ + { + "name": "debug", + }, + { + "name": "release" + } + ] + }, + "modules": [ + { + "name": "entry", + "srcPath": "./entry", + "targets": [ + { + "name": "default", + "applyToProducts": [ + "default" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/code-linter.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/code-linter.json5 new file mode 100644 index 0000000000000000000000000000000000000000..073990fa45394e1f8e85d85418ee60a8953f9b99 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/code-linter.json5 @@ -0,0 +1,32 @@ +{ + "files": [ + "**/*.ets" + ], + "ignore": [ + "**/src/ohosTest/**/*", + "**/src/test/**/*", + "**/src/mock/**/*", + "**/node_modules/**/*", + "**/oh_modules/**/*", + "**/build/**/*", + "**/.preview/**/*" + ], + "ruleSet": [ + "plugin:@performance/recommended", + "plugin:@typescript-eslint/recommended" + ], + "rules": { + "@security/no-unsafe-aes": "error", + "@security/no-unsafe-hash": "error", + "@security/no-unsafe-mac": "warn", + "@security/no-unsafe-dh": "error", + "@security/no-unsafe-dsa": "error", + "@security/no-unsafe-ecdsa": "error", + "@security/no-unsafe-rsa-encrypt": "error", + "@security/no-unsafe-rsa-sign": "error", + "@security/no-unsafe-rsa-key": "error", + "@security/no-unsafe-dsa-key": "error", + "@security/no-unsafe-dh-key": "error", + "@security/no-unsafe-3des": "error" + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/.gitignore b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..e2713a2779c5a3e0eb879efe6115455592caeea5 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/.gitignore @@ -0,0 +1,6 @@ +/node_modules +/oh_modules +/.preview +/build +/.cxx +/.test \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/build-profile.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/build-profile.json5 new file mode 100644 index 0000000000000000000000000000000000000000..dfb34f7b9ee6d4be47467380bc43fb8019f98e17 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/build-profile.json5 @@ -0,0 +1,28 @@ +{ + "apiType": "stageMode", + "buildOption": { + }, + "buildOptionSet": [ + { + "name": "release", + "arkOptions": { + "obfuscation": { + "ruleOptions": { + "enable": false, + "files": [ + "./obfuscation-rules.txt" + ] + } + } + } + }, + ], + "targets": [ + { + "name": "default" + }, + { + "name": "ohosTest", + } + ] +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/hvigorfile.ts b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/hvigorfile.ts new file mode 100644 index 0000000000000000000000000000000000000000..b0e3a1ab98a91bc918d6404b2413111a5011f14a --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/hvigorfile.ts @@ -0,0 +1,6 @@ +import { hapTasks } from '@ohos/hvigor-ohos-plugin'; + +export default { + system: hapTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ + plugins: [] /* Custom plugin to extend the functionality of Hvigor. */ +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/obfuscation-rules.txt b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/obfuscation-rules.txt new file mode 100644 index 0000000000000000000000000000000000000000..272efb6ca3f240859091bbbfc7c5802d52793b0b --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/obfuscation-rules.txt @@ -0,0 +1,23 @@ +# Define project specific obfuscation rules here. +# You can include the obfuscation configuration files in the current module's build-profile.json5. +# +# For more details, see +# https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/source-obfuscation-V5 + +# Obfuscation options: +# -disable-obfuscation: disable all obfuscations +# -enable-property-obfuscation: obfuscate the property names +# -enable-toplevel-obfuscation: obfuscate the names in the global scope +# -compact: remove unnecessary blank spaces and all line feeds +# -remove-log: remove all console.* statements +# -print-namecache: print the name cache that contains the mapping from the old names to new names +# -apply-namecache: reuse the given cache file + +# Keep options: +# -keep-property-name: specifies property names that you want to keep +# -keep-global-name: specifies names that you want to keep in the global scope + +-enable-property-obfuscation +-enable-toplevel-obfuscation +-enable-filename-obfuscation +-enable-export-obfuscation \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/oh-package.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/oh-package.json5 new file mode 100644 index 0000000000000000000000000000000000000000..2959d78c50285f912adb2cdff9f613df9a503b44 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/oh-package.json5 @@ -0,0 +1,10 @@ +{ + "name": "entry", + "version": "1.0.0", + "description": "Please describe the basic information.", + "main": "", + "author": "", + "license": "", + "dependencies": {} +} + diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/entryability/EntryAbility.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/entryability/EntryAbility.ets new file mode 100644 index 0000000000000000000000000000000000000000..b12b706076bc833e0f1c073e99881ef3b3a84004 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/entryability/EntryAbility.ets @@ -0,0 +1,44 @@ +import { AbilityConstant, ConfigurationConstant, UIAbility, Want } from '@kit.AbilityKit'; +import { hilog } from '@kit.PerformanceAnalysisKit'; +import { window } from '@kit.ArkUI'; + +const DOMAIN = 0x0000; + +export default class EntryAbility extends UIAbility { + onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void { + this.context.getApplicationContext().setColorMode(ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET); + hilog.info(DOMAIN, 'testTag', '%{public}s', 'Ability onCreate'); + } + + onDestroy(): void { + hilog.info(DOMAIN, 'testTag', '%{public}s', 'Ability onDestroy'); + } + + onWindowStageCreate(windowStage: window.WindowStage): void { + // Main window is created, set main page for this ability + hilog.info(DOMAIN, 'testTag', '%{public}s', 'Ability onWindowStageCreate'); + + windowStage.loadContent('pages/Index', (err) => { + if (err.code) { + hilog.error(DOMAIN, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err)); + return; + } + hilog.info(DOMAIN, 'testTag', 'Succeeded in loading the content.'); + }); + } + + onWindowStageDestroy(): void { + // Main window is destroyed, release UI related resources + hilog.info(DOMAIN, 'testTag', '%{public}s', 'Ability onWindowStageDestroy'); + } + + onForeground(): void { + // Ability has brought to foreground + hilog.info(DOMAIN, 'testTag', '%{public}s', 'Ability onForeground'); + } + + onBackground(): void { + // Ability has back to background + hilog.info(DOMAIN, 'testTag', '%{public}s', 'Ability onBackground'); + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/entrybackupability/EntryBackupAbility.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/entrybackupability/EntryBackupAbility.ets new file mode 100644 index 0000000000000000000000000000000000000000..fae19f9dd53d2857e2843539cbedf5bee4a34b5a --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/entrybackupability/EntryBackupAbility.ets @@ -0,0 +1,16 @@ +import { hilog } from '@kit.PerformanceAnalysisKit'; +import { BackupExtensionAbility, BundleVersion } from '@kit.CoreFileKit'; + +const DOMAIN = 0x0000; + +export default class EntryBackupAbility extends BackupExtensionAbility { + async onBackup() { + hilog.info(DOMAIN, 'testTag', 'onBackup ok'); + await Promise.resolve(); + } + + async onRestore(bundleVersion: BundleVersion) { + hilog.info(DOMAIN, 'testTag', 'onRestore ok %{public}s', JSON.stringify(bundleVersion)); + await Promise.resolve(); + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/BlankDemo.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/BlankDemo.ets new file mode 100644 index 0000000000000000000000000000000000000000..2ab345ede4822c71cc6c49433a73418819383728 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/BlankDemo.ets @@ -0,0 +1,25 @@ +@Entry +@Component +struct BlankDemo { + onPageShow(){ + console.log("[blank] page show called") + } + build() { + Column({ space: 20 }) { + // Blank父组件不设置宽度时,Blank失效,可以通过设置min最小宽度填充固定宽度 + Row() { + Text('Bluetooth').fontSize(18) + Blank().color(Color.Yellow).key("blank") + Toggle({ type: ToggleType.Switch }).margin({ top: 14, bottom: 14, left: 6, right: 6 }) + }.backgroundColor(0xFFFFFF).borderRadius(15).padding({ left: 12 }) + + Row() { + Text('Bluetooth').fontSize(18) + // 设置最小宽度为160 + Blank('160').color(Color.Yellow) + Toggle({ type: ToggleType.Switch }).margin({ top: 14, bottom: 14, left: 6, right: 6 }) + }.backgroundColor(0xFFFFFF).borderRadius(15).padding({ left: 12 }) + + }.backgroundColor(0xEFEFEF).padding(20).width('100%') + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/ButtonOneDemo.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/ButtonOneDemo.ets new file mode 100644 index 0000000000000000000000000000000000000000..e7f2c13ca651e3c2797dd22c20a337c1fe60e6ca --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/ButtonOneDemo.ets @@ -0,0 +1,79 @@ +@Entry +@Component +struct ButtonOne { + onPageShow(){ + console.log("[button] page show called") + } + build() { + Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Start, justifyContent: FlexAlign.SpaceBetween }) { + Text('Common button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Ok', { type: ButtonType.Normal, stateEffect: true }).borderRadius(8).backgroundColor(0x317aff).width(90).key('button') + Button({ type: ButtonType.Normal, stateEffect: true }) { + Row() { + // 图片建议通过$r创建Resource对象引入 + Image($r('app.media.icon')).width(20).height(20).margin({ left: 12 }) + Text('loading').fontSize(12).fontColor(0xffffff).margin({ left: 5, right: 12 }) + }.alignItems(VerticalAlign.Center) + }.borderRadius(8).backgroundColor(0x317aff).width(90) + Button('Disable', { type: ButtonType.Normal, stateEffect: false }).opacity(0.5) + .borderRadius(8).backgroundColor(0x317aff).width(90) + } + + Text(' Capsule button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Ok', { type: ButtonType.Capsule, stateEffect: true }).backgroundColor(0x317aff).width(90) + Button({ type: ButtonType.Capsule, stateEffect: true }) { + Row() { + Image($r('app.media.icon')).width(20).height(20).margin({ left: 12 }) + Text('loading').fontSize(12).fontColor(0xffffff).margin({ left: 5, right: 12 }) + }.alignItems(VerticalAlign.Center).width(90) + }.backgroundColor(0x317aff) + .onClick((event: ClickEvent) => { + AlertDialog.show({ message: 'The login is successful' }) + }) + Button('Disable', { type: ButtonType.Capsule, stateEffect: false }).opacity(0.5) + .backgroundColor(0x317aff).width(90) + } + Text('Circle button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, wrap: FlexWrap.Wrap }) { + Button({ type: ButtonType.Circle, stateEffect: true }) { + Image($r('app.media.icon')).width(20).height(20) + }.width(55).height(55).backgroundColor(0x317aff) + Button({ type: ButtonType.Circle, stateEffect: true }) { + Image($r('app.media.icon')).width(30).height(30) + }.width(55).height(55).margin({ left: 20 }).backgroundColor(0xF55A42) + } + Text('Normal size button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Emphasized', { buttonStyle: ButtonStyleMode.EMPHASIZED }); + Button('Normal', { buttonStyle: ButtonStyleMode.NORMAL }); + Button('Textual', { buttonStyle: ButtonStyleMode.TEXTUAL }); + } + Text('Small size button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Emphasized', { controlSize: ControlSize.SMALL, buttonStyle: ButtonStyleMode.EMPHASIZED }); + Button('Normal', { controlSize: ControlSize.SMALL, buttonStyle: ButtonStyleMode.NORMAL }); + Button('Textual', { controlSize: ControlSize.SMALL, buttonStyle: ButtonStyleMode.TEXTUAL }); + } + Text('Small size button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Emphasized').controlSize(ControlSize.SMALL).buttonStyle(ButtonStyleMode.EMPHASIZED); + Button('Normal').controlSize(ControlSize.SMALL).buttonStyle(ButtonStyleMode.NORMAL); + Button('Textual').controlSize(ControlSize.SMALL).buttonStyle(ButtonStyleMode.TEXTUAL); + } + Text('Role is Normal button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Emphasized', { buttonStyle: ButtonStyleMode.EMPHASIZED, role: ButtonRole.NORMAL }); + Button('Normal', { buttonStyle: ButtonStyleMode.NORMAL, role: ButtonRole.NORMAL }); + Button('Textual', { buttonStyle: ButtonStyleMode.TEXTUAL, role: ButtonRole.NORMAL }); + } + Text('Role is Error button').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Emphasized', { buttonStyle: ButtonStyleMode.EMPHASIZED, role: ButtonRole.ERROR}); + Button('Normal', { buttonStyle: ButtonStyleMode.NORMAL, role: ButtonRole.ERROR }); + Button('Textual', { buttonStyle: ButtonStyleMode.TEXTUAL, role: ButtonRole.ERROR }); + } + }.height(750).padding({ left: 35, right: 35, top: 35 }) + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/ButtonTwoDemo.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/ButtonTwoDemo.ets new file mode 100644 index 0000000000000000000000000000000000000000..d2d01310dde01d979311cb358f77e5ae72df6f92 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/ButtonTwoDemo.ets @@ -0,0 +1,107 @@ +class MyButtonStyle implements ContentModifier { + x: number = 0; + y: number = 0; + selectedColor: Color = Color.Black; + + constructor(x: number, y: number, ColorType: Color) { + this.x = x; + this.y = y; + this.selectedColor = ColorType; + } + + applyContent(): WrappedBuilder<[ButtonConfiguration]> { + return wrapBuilder(buildButton1); + } +} + +@Builder +function buildButton1(config: ButtonConfiguration) { + Column({ space: 30 }) { + Text(config.enabled ? "enabled true" : "enabled false") + Text('圆圈状态' + (config.pressed ? "( 按压 )" : "( 非按压 )")) + Text('点击位置x坐标:' + (config.enabled ? (config.contentModifier as MyButtonStyle).x : "0")) + Text('点击位置y坐标:' + (config.enabled ? (config.contentModifier as MyButtonStyle).y : "0")) + Circle({ width: 50, height: 50 }) + .fill(config.pressed ? (config.contentModifier as MyButtonStyle).selectedColor : Color.Black) + .gesture( + TapGesture({ count: 1 }).onAction((event: GestureEvent) => { + config.triggerClick(event.fingerList[0].localX, event.fingerList[0].localY) + })).opacity(config.enabled ? 1 : 0.1) + } +} + +@Entry +@Component +struct ButtonTwo { + @State buttonEnabled: boolean = true; + @State positionX: number = 0; + @State positionY: number = 0; + @State state: boolean[] = [true, false]; + @State index: number = 0; + @State txt: string = 'overflowTextOverlengthTextOverflow.Clip'; + @State widthShortSize: number = 210; + build() { + Column() { + Button(this.txt) + .width(this.widthShortSize) + .height(100) + .backgroundColor(0x317aff) + .labelStyle({ overflow: TextOverflow.Clip, + maxLines: 1, + minFontSize: 20, + maxFontSize: 20, + font: { + size: 20, + weight: FontWeight.Bolder, + family: 'cursive', + style: FontStyle.Italic + } + }) + .fontSize(40).key('button') + Button('OK') + .contentModifier(new MyButtonStyle(this.positionX, this.positionY, Color.Red)) + .onClick((event) => { + console.info('change' + JSON.stringify(event)); + this.positionX = event.displayX; + this.positionY = event.displayY; + }).enabled(this.buttonEnabled) + Row() { + Toggle({ type: ToggleType.Switch, isOn: true }).onChange((value: boolean) => { + if (value) { + this.buttonEnabled = true; + } else { + this.buttonEnabled = false; + } + }).margin({ left: -80 }) + } + Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Start, justifyContent: FlexAlign.SpaceBetween }) { + Text('Rounded rectangle button with rounded corners by default.').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Rounded rectangle') + .type(ButtonType.ROUNDED_RECTANGLE) + .backgroundColor(0x317aff) + .controlSize(ControlSize.NORMAL) + .width(180) + } + Text('Rounded rectangle button configured with a borderRadius of 5.').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Rounded rectangle') + .type(ButtonType.ROUNDED_RECTANGLE) + .backgroundColor(0x317aff) + .controlSize(ControlSize.NORMAL) + .width(180) + .borderRadius(5) + } + Text('Rounded rectangle button configured extra long text.').fontSize(9).fontColor(0xCCCCCC) + Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) { + Button('Rounded rectangle Rounded rectangle Rounded rectangle Rounded rectangle') + .type(ButtonType.ROUNDED_RECTANGLE) + .backgroundColor(0x317aff) + .width(180) + //.buttonStyle(ButtonStyleMode.NORMAL) + .labelStyle({overflow:TextOverflow.Ellipsis, maxLines:3, minFontSize: 0}) + } + }.height(400).padding({ left: 35, right: 35, top: 35 }) + }.height('100%').width('100%').justifyContent(FlexAlign.Center) + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/CalendarPickerDemo.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/CalendarPickerDemo.ets new file mode 100644 index 0000000000000000000000000000000000000000..78886db31b4b9aca5b38cd4c06a2bc3d675f1a85 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/CalendarPickerDemo.ets @@ -0,0 +1,29 @@ +@Entry +@Component +struct CalendarPickerExample { + private selectedDate: Date = new Date('2025-01-15'); + private startDate: Date = new Date('2025-01-05'); + private endDate: Date = new Date('2025-01-25'); + build() { + Column() { + Column() { + CalendarPicker({ hintRadius: 10, selected: this.selectedDate }) + .edgeAlign(CalendarAlign.END) + .textStyle({ color: "#ff182431", font: { size: 20, weight: FontWeight.Normal } }) + .margin(10) + .onChange((value) => { + console.info("CalendarPicker onChange:" + JSON.stringify(value)); + }) + }.alignItems(HorizontalAlign.End).width("100%") + + Text('日历日期选择器').fontSize(30) + CalendarPicker({ hintRadius: 10, selected: this.selectedDate, start: this.startDate, end: this.endDate }) + .edgeAlign(CalendarAlign.END) + .textStyle({ color: "#ff182431", font: { size: 20, weight: FontWeight.Normal } }) + .margin(10) + .onChange((value) => { + console.info("CalendarPicker onChange:" + JSON.stringify(value)); + }).key("CalendarPicker") + }.width('100%').margin({ top: 350 }) + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/Index.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/Index.ets new file mode 100644 index 0000000000000000000000000000000000000000..41c9a3ec6c61fcebdae8793fae5c006d771b367b --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/ets/pages/Index.ets @@ -0,0 +1,43 @@ +import { Core, ExpectExtend, DataDriver, beforeAll, describe } from "@ohos/hypium" +import testsuite from '../../../test/List.test' + +@Entry +@Component +struct Index { + aboutToAppear() { + console.info("start run testcase!!!!") + const core:Core = Core.getInstance() + const expectExtend: ExpectExtend = new ExpectExtend({ + 'id': 'extend' + }) + core.addService('expect', expectExtend) + core.addService('dataDriver', new DataDriver('')) + core.init() + console.info('testsuite()---->') + beforeExec(); + core.execute() + console.info('core.execute()---->') + testsuite(); + } + + build() { + Flex({ + direction: FlexDirection.Column, + alignItems: ItemAlign.Center, + justifyContent: FlexAlign.Center + }) { + Text('base component') + .fontSize(50) + .fontWeight(FontWeight.Bold) + } + .width('100%') + .height('100%') + } +} + +function beforeExec() { + describe('beforeExec', () => { + beforeAll(async () => { + }); + }) +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/module.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/module.json5 new file mode 100644 index 0000000000000000000000000000000000000000..5aa1f1236dd8ccc74a8e8671bebca557c2edaa1d --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/module.json5 @@ -0,0 +1,50 @@ +{ + "module": { + "name": "entry", + "type": "entry", + "description": "$string:module_desc", + "mainElement": "EntryAbility", + "deviceTypes": [ + "phone" + ], + "deliveryWithInstall": true, + "installationFree": false, + "pages": "$profile:main_pages", + "abilities": [ + { + "name": "EntryAbility", + "srcEntry": "./ets/entryability/EntryAbility.ets", + "description": "$string:EntryAbility_desc", + "icon": "$media:layered_image", + "label": "$string:EntryAbility_label", + "startWindowIcon": "$media:startIcon", + "startWindowBackground": "$color:start_window_background", + "exported": true, + "skills": [ + { + "entities": [ + "entity.system.home" + ], + "actions": [ + "ohos.want.action.home" + ] + } + ] + } + ], + "extensionAbilities": [ + { + "name": "EntryBackupAbility", + "srcEntry": "./ets/entrybackupability/EntryBackupAbility.ets", + "type": "backup", + "exported": false, + "metadata": [ + { + "name": "ohos.extension.backup", + "resource": "$profile:backup_config" + } + ], + } + ] + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/color.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/color.json new file mode 100644 index 0000000000000000000000000000000000000000..d66f9a7d4ac61fb8d215239ab3620b7bcd77bf33 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/color.json @@ -0,0 +1,8 @@ +{ + "color": [ + { + "name": "start_window_background", + "value": "#FFFFFF" + } + ] +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/float.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/float.json new file mode 100644 index 0000000000000000000000000000000000000000..5f0600c7083c3ac3776dcc13ce3e3f03c378fc6d --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/float.json @@ -0,0 +1,8 @@ +{ + "float": [ + { + "name": "page_text_font_size", + "value": "50fp" + } + ] +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/string.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..f94595515a99e0c828807e243494f57f09251930 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/element/string.json @@ -0,0 +1,16 @@ +{ + "string": [ + { + "name": "module_desc", + "value": "module description" + }, + { + "name": "EntryAbility_desc", + "value": "description" + }, + { + "name": "EntryAbility_label", + "value": "label" + } + ] +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/background.png b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/background.png new file mode 100644 index 0000000000000000000000000000000000000000..923f2b3f27e915d6871871deea0420eb45ce102f Binary files /dev/null and b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/background.png differ diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/foreground.png b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/foreground.png new file mode 100644 index 0000000000000000000000000000000000000000..97014d3e10e5ff511409c378cd4255713aecd85f Binary files /dev/null and b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/foreground.png differ diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/icon.png b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/icon.png differ diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/layered_image.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/layered_image.json new file mode 100644 index 0000000000000000000000000000000000000000..fb49920440fb4d246c82f9ada275e26123a2136a --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/layered_image.json @@ -0,0 +1,7 @@ +{ + "layered-image": + { + "background" : "$media:background", + "foreground" : "$media:foreground" + } +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/startIcon.png b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/startIcon.png new file mode 100644 index 0000000000000000000000000000000000000000..205ad8b5a8a42e8762fbe4899b8e5e31ce822b8b Binary files /dev/null and b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/media/startIcon.png differ diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/profile/backup_config.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/profile/backup_config.json new file mode 100644 index 0000000000000000000000000000000000000000..d742c2f96e7dd0f406f499941f3147345e998f95 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/profile/backup_config.json @@ -0,0 +1,3 @@ +{ + "allowToBackupRestore": true +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/profile/main_pages.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/profile/main_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..20c50fc22b1bc6aaa9b59425bca9544e4ffb2a6a --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/base/profile/main_pages.json @@ -0,0 +1,9 @@ +{ + "src": [ + "pages/Index", + "pages/BlankDemo", + "pages/ButtonOneDemo", + "pages/ButtonTwoDemo", + "pages/CalendarPickerDemo" + ] +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/dark/element/color.json b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/dark/element/color.json new file mode 100644 index 0000000000000000000000000000000000000000..438d5bc43bb23c59c210d586b96635a72da5b64a --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/main/resources/dark/element/color.json @@ -0,0 +1,8 @@ +{ + "color": [ + { + "name": "start_window_background", + "value": "#000000" + } + ] +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/mock/mock-config.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/mock/mock-config.json5 new file mode 100644 index 0000000000000000000000000000000000000000..7a73a41bfdf76d6f793007240d80983a52f15f97 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/mock/mock-config.json5 @@ -0,0 +1,2 @@ +{ +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/ets/test/Ability.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/ets/test/Ability.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..85c78f67579d6e31b5f5aeea463e216b9b141048 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/ets/test/Ability.test.ets @@ -0,0 +1,35 @@ +import { hilog } from '@kit.PerformanceAnalysisKit'; +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium'; + +export default function abilityTest() { + describe('ActsAbilityTest', () => { + // Defines a test suite. Two parameters are supported: test suite name and test suite function. + beforeAll(() => { + // Presets an action, which is performed only once before all test cases of the test suite start. + // This API supports only one parameter: preset action function. + }) + beforeEach(() => { + // Presets an action, which is performed before each unit test case starts. + // The number of execution times is the same as the number of test cases defined by **it**. + // This API supports only one parameter: preset action function. + }) + afterEach(() => { + // Presets a clear action, which is performed after each unit test case ends. + // The number of execution times is the same as the number of test cases defined by **it**. + // This API supports only one parameter: clear action function. + }) + afterAll(() => { + // Presets a clear action, which is performed after all test cases of the test suite end. + // This API supports only one parameter: clear action function. + }) + it('assertContain', 0, () => { + // Defines a test case. This API supports three parameters: test case name, filter parameter, and test case function. + hilog.info(0x0000, 'testTag', '%{public}s', 'it begin'); + let a = 'abc'; + let b = 'b'; + // Defines a variety of assertion methods, which are used to declare expected boolean conditions. + expect(a).assertContain(b); + expect(a).assertEqual(a); + }) + }) +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/ets/test/List.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/ets/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..794c7dc4ed66bd98fa3865e07922906e2fcef545 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/ets/test/List.test.ets @@ -0,0 +1,5 @@ +import abilityTest from './Ability.test'; + +export default function testsuite() { + abilityTest(); +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/module.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/module.json5 new file mode 100644 index 0000000000000000000000000000000000000000..fb0d7837fd30b732c6a09b25ae2401679275291c --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/ohosTest/module.json5 @@ -0,0 +1,11 @@ +{ + "module": { + "name": "entry_test", + "type": "feature", + "deviceTypes": [ + "phone" + ], + "deliveryWithInstall": true, + "installationFree": false + } +} diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/BlankUnit.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/BlankUnit.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..e7f54daf9451133d9eb1a2b433897346d489f888 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/BlankUnit.test.ets @@ -0,0 +1,41 @@ +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium" +import router from '@ohos.router'; +import Utils from './Unit.test'; + +export default function blankJsunit() { + describe('blankTest', () => { + beforeEach(async (done:Function) => { + console.info("blank beforeEach start"); + let options: router.RouterOptions = { + url: 'pages/Blank', + }; + try { + router.clear(); + let pages = router.getState(); + console.info("get blank state pages:" + JSON.stringify(pages)); + if (!("blank" == pages.name)) { + console.info("get blank state pages.name:" + JSON.stringify(pages.name)); + let result = await router.push(options); + await Utils.sleep(2000); + console.info("push blank page result:" + JSON.stringify(result)); + } + } catch (err) { + console.error("push blank page error:" + err); + } + done(); + }); + afterEach(async () => { + await Utils.sleep(2000); + console.info("blank after each called"); + }); + it('testBlank001', 0, async (done: Function) => { + await Utils.sleep(3000); + let strJson = getInspectorByKey('blank'); + let obj:object = JSON.parse(strJson); + console.info("[testBlank001] component obj is: " + JSON.stringify(obj)); + expect(JSON.parse(strJson).$attrs.min).assertEqual('0.00vp'); + done(); + }); + }) +} + diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/ButtonOneUnit.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/ButtonOneUnit.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..fa049b9cab85934e281630c2e9940e7666940ca6 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/ButtonOneUnit.test.ets @@ -0,0 +1,40 @@ +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium" +import router from '@ohos.router'; +import Utils from './Unit.test'; + +export default function buttonOneJsunit() { + describe('buttonTest', () => { + beforeEach(async (done:Function) => { + console.info("button beforeEach start"); + let options: router.RouterOptions = { + url: 'pages/ButtonOne', + }; + try { + router.clear(); + let pages = router.getState(); + console.info("get button state pages:" + JSON.stringify(pages)); + if (!("button" == pages.name)) { + console.info("get button state pages.name:" + JSON.stringify(pages.name)); + let result = await router.push(options); + await Utils.sleep(2000); + console.info("push button page result:" + JSON.stringify(result)); + } + } catch (err) { + console.error("push button page error:" + err); + } + done(); + }); + afterEach(async () => { + await Utils.sleep(2000); + console.info("button after each called"); + }); + it('testButton001', 0, async (done:Function) => { + await Utils.sleep(3000); + let strJson = getInspectorByKey('button'); + let obj:object = JSON.parse(strJson); + console.info("[testButton001] component obj is: " + JSON.stringify(obj)); + expect(JSON.parse(strJson).$attrs.sepia).assertEqual(0); + done(); + }); + }) +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/ButtonTwoUnit.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/ButtonTwoUnit.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..2c644b045b8a64ce5520d1106dc02a3d0506b66b --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/ButtonTwoUnit.test.ets @@ -0,0 +1,40 @@ +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium" +import router from '@ohos.router'; +import Utils from './Unit.test'; + +export default function buttonOneJsunit() { + describe('buttonTest', () => { + beforeEach(async (done:Function) => { + console.info("button beforeEach start"); + let options: router.RouterOptions = { + url: 'pages/ButtonTwo', + }; + try { + router.clear(); + let pages = router.getState(); + console.info("get button state pages:" + JSON.stringify(pages)); + if (!("button" == pages.name)) { + console.info("get button state pages.name:" + JSON.stringify(pages.name)); + let result = await router.push(options); + await Utils.sleep(2000); + console.info("push button page result:" + JSON.stringify(result)); + } + } catch (err) { + console.error("push button page error:" + err); + } + done(); + }); + afterEach(async () => { + await Utils.sleep(2000); + console.info("button after each called"); + }); + it('testButton001', 0, async (done:Function) => { + await Utils.sleep(3000); + let strJson = getInspectorByKey('button'); + let obj:object = JSON.parse(strJson); + console.info("[testButton001] component obj is: " + JSON.stringify(obj)); + expect(JSON.parse(strJson).$attrs.sepia).assertEqual(0); + done(); + }); + }) +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/CalendarPickerUnit.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/CalendarPickerUnit.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..4fe6e05e22374db73708f080947a743bb9931df4 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/CalendarPickerUnit.test.ets @@ -0,0 +1,40 @@ +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium" +import router from '@ohos.router'; +import Utils from './Unit.test'; + +export default function calendarPickerJsunit() { + describe('checkboxGroupTest', () => { + beforeEach(async (done:Function) => { + console.info("calendarPicker beforeEach start"); + let options: router.RouterOptions = { + url: 'pages/CalendarPicker', + }; + try { + router.clear(); + let pages = router.getState(); + console.info("get calendarPicker state pages:" + JSON.stringify(pages)); + if (!("calendarPicker" == pages.name)) { + console.info("get calendarPicker state pages.name:" + JSON.stringify(pages.name)); + let result = await router.push(options); + await Utils.sleep(2000); + console.info("push calendarPicker page result:" + JSON.stringify(result)); + } + } catch (err) { + console.error("push calendarPicker page error:" + err); + } + done(); + }); + afterEach(async () => { + await Utils.sleep(2000); + console.info("calendarPicker after each called"); + }); + it('testcalendarPicker001', 0, async (done:Function) => { + await Utils.sleep(3000); + let strJson = getInspectorByKey('calendarPicker'); + let obj:object = JSON.parse(strJson); + console.info("[testcalendarPicker001] component obj is: " + JSON.stringify(obj)); + expect(JSON.parse(strJson).$attrs.sepia).assertEqual(0); + done(); + }); + }) +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/List.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..28be211bf29b760d31909dd1c2ad27b93746ee5a --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/List.test.ets @@ -0,0 +1,11 @@ +import blankJsunit from './BlankUnit.test'; +import buttonOneJsunit from './ButtonOneUnit.test' +import buttonTwoJsunit from './ButtonTwoUnit.test'; +import calendarPickerJsunit from './CalendarPickerUnit.test'; + +export default function testsuite() { + blankJsunit(); + buttonOneJsunit(); + buttonTwoJsunit() + calendarPickerJsunit() +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/LocalUnit.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/LocalUnit.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..165fc1615ee8618b4cb6a622f144a9a707eee99f --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/LocalUnit.test.ets @@ -0,0 +1,33 @@ +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium'; + +export default function localUnitTest() { + describe('localUnitTest', () => { + // Defines a test suite. Two parameters are supported: test suite name and test suite function. + beforeAll(() => { + // Presets an action, which is performed only once before all test cases of the test suite start. + // This API supports only one parameter: preset action function. + }); + beforeEach(() => { + // Presets an action, which is performed before each unit test case starts. + // The number of execution times is the same as the number of test cases defined by **it**. + // This API supports only one parameter: preset action function. + }); + afterEach(() => { + // Presets a clear action, which is performed after each unit test case ends. + // The number of execution times is the same as the number of test cases defined by **it**. + // This API supports only one parameter: clear action function. + }); + afterAll(() => { + // Presets a clear action, which is performed after all test cases of the test suite end. + // This API supports only one parameter: clear action function. + }); + it('assertContain', 0, () => { + // Defines a test case. This API supports three parameters: test case name, filter parameter, and test case function. + let a = 'abc'; + let b = 'b'; + // Defines a variety of assertion methods, which are used to declare expected boolean conditions. + expect(a).assertContain(b); + expect(a).assertEqual(a); + }); + }); +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/Unit.test.ets b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/Unit.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..dfcd5767a3540a5bbc9d22bdcb8c4c2a3c2f0f8d --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/entry/src/test/Unit.test.ets @@ -0,0 +1,125 @@ +export class RectValue { + left: number = 0; + top: number = 0; + right: number = 0; + bottom: number = 0; +} + +export default class Utils { + static rect_left: number; + static rect_top: number; + static rect_right: number; + static rect_bottom: number; + static rect_value: RectValue; + + static sleep(time: number) { + return new Promise((resolve, reject) => { + setTimeout(() => { + resolve("ok") + }, time) + }).then(() => { + console.info(`sleep ${time} over...`) + }) + } + + static getComponentRect(key: string) { + let strJson = getInspectorByKey(key); + console.info("[getInspectorByKey] current component obj is: " + JSON.stringify(JSON.parse(strJson))); + console.info("[getInspectorByKey] rectInfo is: " + JSON.parse('[' + JSON.parse(strJson).$rect + ']')); + Utils.rect_left = JSON.parse('[' + JSON.parse('[' + JSON.parse(strJson).$rect + ']')[0] + ']')[0] + Utils.rect_top = JSON.parse('[' + JSON.parse('[' + JSON.parse(strJson).$rect + ']')[0] + ']')[1] + Utils.rect_right = JSON.parse('[' + JSON.parse('[' + JSON.parse(strJson).$rect + ']')[1] + ']')[0] + Utils.rect_bottom = JSON.parse('[' + JSON.parse('[' + JSON.parse(strJson).$rect + ']')[1] + ']')[1] + return Utils.rect_value = { + left: Utils.rect_left, top: Utils.rect_top, right: Utils.rect_right, bottom: Utils.rect_bottom + } + } + + static async swipe(downX: number, downY: number, upX: number, upY: number, steps: number) { + console.info('start to swipe') + Utils.drags(downX, downY, upX, upY, steps, false) + } + + static async drag(downX: number, downY: number, upX: number, upY: number, steps: number) { + console.info('start to drag') + Utils.drags(downX, downY, upX, upY, steps, true) + } + + static async drags(downX: number, downY: number, upX: number, upY: number, steps: number, drag: boolean) { + let xStep: number; + let yStep: number; + let swipeSteps: number; + let ret: boolean; + xStep = 0; + yStep = 0; + ret = false; + swipeSteps = steps; + if (swipeSteps == 0) { + swipeSteps = 1; + } + xStep = (upX - downX) / swipeSteps; + yStep = (upY - downY) / swipeSteps; + console.info('move step is: ' + 'xStep: ' + xStep + ' yStep: ' + yStep) + let downPonit: TouchObject = { + id: 1, + x: downX, + y: downY, + type: TouchType.Down, + screenX: 0, + screenY: 0, + windowX: 0, + windowY: 0, + displayX: 0, + displayY: 0 + } + console.info('down touch started: ' + JSON.stringify(downPonit)) + sendTouchEvent(downPonit); + console.info('start to move') + if (drag) { + await Utils.sleep(500) + } + for (let i = 1;i <= swipeSteps; i++) { + let movePoint: TouchObject = { + id: 1, + x: downX + (xStep * i), + y: downY + (yStep * i), + type: TouchType.Move, + screenX: 0, + screenY: 0, + windowX: 0, + windowY: 0, + displayX: 0, + displayY: 0 + } + console.info('move touch started: ' + JSON.stringify(movePoint)) + ret = sendTouchEvent(movePoint) + if (ret == false) { + break; + } + await Utils.sleep(5) + } + console.info('start to up') + if (drag) { + await Utils.sleep(100) + } + let upPoint: TouchObject = { + id: 1, + x: upX, + y: upY, + type: TouchType.Up, + screenX: 0, + screenY: 0, + windowX: 0, + windowY: 0, + displayX: 0, + displayY: 0 + } + console.info('up touch started: ' + JSON.stringify(upPoint)) + sendTouchEvent(upPoint) + await Utils.sleep(500) + } +} + + + + diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/hvigor/hvigor-config.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/hvigor/hvigor-config.json5 new file mode 100644 index 0000000000000000000000000000000000000000..bd35d296933eed3d5ced1a114a7be486cec8df93 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/hvigor/hvigor-config.json5 @@ -0,0 +1,23 @@ +{ + "modelVersion": "6.0.0", + "dependencies": { + }, + "execution": { + // "analyze": "normal", /* Define the build analyze mode. Value: [ "normal" | "advanced" | "ultrafine" | false ]. Default: "normal" */ + // "daemon": true, /* Enable daemon compilation. Value: [ true | false ]. Default: true */ + // "incremental": true, /* Enable incremental compilation. Value: [ true | false ]. Default: true */ + // "parallel": true, /* Enable parallel compilation. Value: [ true | false ]. Default: true */ + // "typeCheck": false, /* Enable typeCheck. Value: [ true | false ]. Default: false */ + // "optimizationStrategy": "memory" /* Define the optimization strategy. Value: [ "memory" | "performance" ]. Default: "memory" */ + }, + "logging": { + // "level": "info" /* Define the log level. Value: [ "debug" | "info" | "warn" | "error" ]. Default: "info" */ + }, + "debugging": { + // "stacktrace": false /* Disable stacktrace compilation. Value: [ true | false ]. Default: false */ + }, + "nodeOptions": { + // "maxOldSpaceSize": 8192 /* Enable nodeOptions maxOldSpaceSize compilation. Unit M. Used for the daemon process. Default: 8192*/ + // "exposeGC": true /* Enable to trigger garbage collection explicitly. Default: true*/ + } +} diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/hvigorfile.ts b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/hvigorfile.ts new file mode 100644 index 0000000000000000000000000000000000000000..47113e2e36ecefde41c136272a0bd6ff745cffe4 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/hvigorfile.ts @@ -0,0 +1,6 @@ +import { appTasks } from '@ohos/hvigor-ohos-plugin'; + +export default { + system: appTasks, /* Built-in plugin of Hvigor. It cannot be modified. */ + plugins: [] /* Custom plugin to extend the functionality of Hvigor. */ +} \ No newline at end of file diff --git a/code/DocsSample/ArkUISample/PreviewProject/basicComponent/oh-package.json5 b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/oh-package.json5 new file mode 100644 index 0000000000000000000000000000000000000000..0c69600094f7d2a3da13081edd5adb3c6ad3d758 --- /dev/null +++ b/code/DocsSample/ArkUISample/PreviewProject/basicComponent/oh-package.json5 @@ -0,0 +1,10 @@ +{ + "modelVersion": "6.0.0", + "description": "Please describe the basic information.", + "dependencies": { + }, + "devDependencies": { + "@ohos/hypium": "1.0.21", + "@ohos/hamock": "1.0.1-rc2" + } +}