diff --git a/OAT.xml b/OAT.xml new file mode 100644 index 0000000000000000000000000000000000000000..6c05fa6f669d45678d8535427c7e9d6f2bf8e63e --- /dev/null +++ b/OAT.xml @@ -0,0 +1,94 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/pdfx/.vscode/launch.json b/packages/pdfx/.vscode/launch.json deleted file mode 100644 index 5e9f1051481a547260a3f6e28135f0b0a8d4e290..0000000000000000000000000000000000000000 --- a/packages/pdfx/.vscode/launch.json +++ /dev/null @@ -1,24 +0,0 @@ -{ - "version": "0.2.0", - "configurations": [ - { - "name": "Debug", - "request": "launch", - "type": "dart", - "program": "./example/lib/main.dart", - "args": [ - "--web-enable-expression-evaluation" - ] - }, - { - "name": "Profile", - "request": "launch", - "type": "dart", - "program": "./example/lib/main.dart", - "flutterMode": "profile", - "args": [ - "--web-enable-expression-evaluation", - ] - } - ] -} diff --git a/packages/pdfx/.vscode/settings.json b/packages/pdfx/.vscode/settings.json deleted file mode 100644 index d105bf47038f3b905cd241a9385d53487ac2139d..0000000000000000000000000000000000000000 --- a/packages/pdfx/.vscode/settings.json +++ /dev/null @@ -1,21 +0,0 @@ -{ - "files.exclude": { - "**/.classpath": true, - "**/.project": true, - "**/.settings": true, - "**/.factorypath": true - }, - "cSpell.words": [ - "alloc", - "dont", - "macos", - "pdfium", - "pdfjs", - "pdfx", - "scer", - "Uint", - "uuid", - "WEBP" - ], - "C_Cpp.clang_format_fallbackStyle": "Google" -} diff --git a/packages/pdfx/example/lib/pinch.dart b/packages/pdfx/example/lib/pinch.dart index 459b00755c3b3337a834f4d55c9110c24d3d2819..6aafc1480cf8457ccf539f4ed0a7e7b98590ded7 100644 --- a/packages/pdfx/example/lib/pinch.dart +++ b/packages/pdfx/example/lib/pinch.dart @@ -20,12 +20,12 @@ class _PinchPageState extends State { @override void initState() { _pdfControllerPinch = PdfControllerPinch( - // document: PdfDocument.openAsset('assets/hello.pdf'), - document: PdfDocument.openData( - InternetFile.get( - 'https://api.codetabs.com/v1/proxy/?quest=http://www.africau.edu/images/default/sample.pdf', - ), - ), + document: PdfDocument.openAsset('assets/flutter_tutorial.pdf'), + // document: PdfDocument.openData( + // InternetFile.get( + // 'https://api.codetabs.com/v1/proxy/?quest=http://www.africau.edu/images/default/sample.pdf', + // ), + // ), initialPage: _initialPage, ); super.initState(); diff --git a/packages/pdfx/example/ohos/.gitignore b/packages/pdfx/example/ohos/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..6ca13b3170eec5dd5ac5ad7f1c4dd0118845f473 --- /dev/null +++ b/packages/pdfx/example/ohos/.gitignore @@ -0,0 +1,19 @@ +/node_modules +/oh_modules +/local.properties +/.idea +**/build +/.hvigor +.cxx +/.clangd +/.clang-format +/.clang-tidy +**/.test +*.har +**/BuildProfile.ets +**/oh-package-lock.json5 + +**/src/main/resources/rawfile/flutter_assets/ +**/libs/arm64-v8a/libapp.so +**/libs/arm64-v8a/libflutter.so +**/libs/arm64-v8a/libvmservice_snapshot.so diff --git a/packages/pdfx/example/ohos/AppScope/app.json5 b/packages/pdfx/example/ohos/AppScope/app.json5 new file mode 100644 index 0000000000000000000000000000000000000000..1318bcc37b881e170ea032c0ca2c65a3e5e86218 --- /dev/null +++ b/packages/pdfx/example/ohos/AppScope/app.json5 @@ -0,0 +1,25 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + + { + "app": { + "bundleName": "io.scer.example", + "vendor": "example", + "versionCode": 1000000, + "versionName": "1.0.0", + "icon": "$media:app_icon", + "label": "$string:app_name" + } +} diff --git a/packages/pdfx/example/ohos/AppScope/resources/base/element/string.json b/packages/pdfx/example/ohos/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..810f4a362c1d177309eec4f2efe5cac2f4558c28 --- /dev/null +++ b/packages/pdfx/example/ohos/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "app_name", + "value": "example" + } + ] +} diff --git a/packages/pdfx/example/ohos/AppScope/resources/base/media/app_icon.png b/packages/pdfx/example/ohos/AppScope/resources/base/media/app_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/packages/pdfx/example/ohos/AppScope/resources/base/media/app_icon.png differ diff --git a/packages/pdfx/example/ohos/build-profile.json5 b/packages/pdfx/example/ohos/build-profile.json5 new file mode 100644 index 0000000000000000000000000000000000000000..aff5a0fb3f879e45be56cb8caa338784ccc4b6a6 --- /dev/null +++ b/packages/pdfx/example/ohos/build-profile.json5 @@ -0,0 +1,43 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "app": { + "signingConfigs": [ + ], + "products": [ + { + "name": "default", + "signingConfig": "default", + "compatibleSdkVersion": "5.0.0(12)", + "runtimeOS": "HarmonyOS" + } + ] + }, + "modules": [ + { + "name": "entry", + "srcPath": "./entry", + "targets": [ + { + "name": "default", + "applyToProducts": [ + "default" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/dta/icudtl.dat b/packages/pdfx/example/ohos/dta/icudtl.dat new file mode 100644 index 0000000000000000000000000000000000000000..d1f10917ab52e3ebd251abd7f5377d7196b80d67 Binary files /dev/null and b/packages/pdfx/example/ohos/dta/icudtl.dat differ diff --git a/packages/pdfx/example/ohos/entry/.gitignore b/packages/pdfx/example/ohos/entry/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..2795a1c5b1fe53659dd1b71d90ba0592eaf7e043 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/.gitignore @@ -0,0 +1,7 @@ + +/node_modules +/oh_modules +/.preview +/build +/.cxx +/.test \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/build-profile.json5 b/packages/pdfx/example/ohos/entry/build-profile.json5 new file mode 100644 index 0000000000000000000000000000000000000000..69c9ed468a22797f4cfa464b027ab2bf41dcdd6b --- /dev/null +++ b/packages/pdfx/example/ohos/entry/build-profile.json5 @@ -0,0 +1,29 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "apiType": 'stageMode', + "buildOption": { + }, + "targets": [ + { + "name": "default", + "runtimeOS": "HarmonyOS" + }, + { + "name": "ohosTest", + } + ] +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/hvigorfile.ts b/packages/pdfx/example/ohos/entry/hvigorfile.ts new file mode 100644 index 0000000000000000000000000000000000000000..aeb4c3c6fca586d72e6d196121e1b09ceccb70bd --- /dev/null +++ b/packages/pdfx/example/ohos/entry/hvigorfile.ts @@ -0,0 +1,17 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently. +export { hapTasks } from '@ohos/hvigor-ohos-plugin'; diff --git a/packages/pdfx/example/ohos/entry/libs/arm64-v8a/libc++_shared.so b/packages/pdfx/example/ohos/entry/libs/arm64-v8a/libc++_shared.so new file mode 100644 index 0000000000000000000000000000000000000000..831c9353702073d45889352a4dafb93103d67d20 Binary files /dev/null and b/packages/pdfx/example/ohos/entry/libs/arm64-v8a/libc++_shared.so differ diff --git a/packages/pdfx/example/ohos/entry/oh-package.json5 b/packages/pdfx/example/ohos/entry/oh-package.json5 new file mode 100644 index 0000000000000000000000000000000000000000..edbf0a61241633a7b436a48233190d14464cfddb --- /dev/null +++ b/packages/pdfx/example/ohos/entry/oh-package.json5 @@ -0,0 +1,27 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "name": "entry", + "version": "1.0.0", + "description": "Please describe the basic information.", + "main": "", + "author": "", + "license": "", + "dependencies": { + "device_info_plus": "file:../har/device_info_plus.har", + "pdfx": "file:../har/pdfx.har" + } +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/main/ets/entryability/EntryAbility.ets b/packages/pdfx/example/ohos/entry/src/main/ets/entryability/EntryAbility.ets new file mode 100644 index 0000000000000000000000000000000000000000..b507051da8cfa52af81f1092e5806b5bd076c166 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/main/ets/entryability/EntryAbility.ets @@ -0,0 +1,24 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import { FlutterAbility, FlutterEngine } from '@ohos/flutter_ohos'; +import { GeneratedPluginRegistrant } from '../plugins/GeneratedPluginRegistrant'; + +export default class EntryAbility extends FlutterAbility { + configureFlutterEngine(flutterEngine: FlutterEngine) { + super.configureFlutterEngine(flutterEngine) + GeneratedPluginRegistrant.registerWith(flutterEngine) + } +} diff --git a/packages/pdfx/example/ohos/entry/src/main/ets/pages/Index.ets b/packages/pdfx/example/ohos/entry/src/main/ets/pages/Index.ets new file mode 100644 index 0000000000000000000000000000000000000000..77b5f78343024778749af85ab2553e1ffb9e4a52 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/main/ets/pages/Index.ets @@ -0,0 +1,38 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import common from '@ohos.app.ability.common'; +import { FlutterPage } from '@ohos/flutter_ohos' + +let storage = LocalStorage.getShared() +const EVENT_BACK_PRESS = 'EVENT_BACK_PRESS' + +@Entry(storage) +@Component +struct Index { + private context = getContext(this) as common.UIAbilityContext + @LocalStorageLink('viewId') viewId: string = ""; + + build() { + Column() { + FlutterPage({ viewId: this.viewId }) + } + } + + onBackPress(): boolean { + this.context.eventHub.emit(EVENT_BACK_PRESS) + return true + } +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/main/module.json5 b/packages/pdfx/example/ohos/entry/src/main/module.json5 new file mode 100644 index 0000000000000000000000000000000000000000..35eddfb7b898b8780fe5ffdba01e9bff58468cad --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/main/module.json5 @@ -0,0 +1,54 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "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:icon", + "label": "$string:EntryAbility_label", + "startWindowIcon": "$media:icon", + "startWindowBackground": "$color:start_window_background", + "exported": true, + "skills": [ + { + "entities": [ + "entity.system.home" + ], + "actions": [ + "action.system.home" + ] + } + ] + } + ], + "requestPermissions": [ + {"name" : "ohos.permission.INTERNET"}, + ] + } +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/main/resources/base/element/color.json b/packages/pdfx/example/ohos/entry/src/main/resources/base/element/color.json new file mode 100644 index 0000000000000000000000000000000000000000..3c712962da3c2751c2b9ddb53559afcbd2b54a02 --- /dev/null +++ b/packages/pdfx/example/ohos/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/packages/pdfx/example/ohos/entry/src/main/resources/base/element/string.json b/packages/pdfx/example/ohos/entry/src/main/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..67e0f4ff4ac762d1714f6e215c6636a4ad3d620e --- /dev/null +++ b/packages/pdfx/example/ohos/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": "example" + } + ] +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/main/resources/base/media/icon.png b/packages/pdfx/example/ohos/entry/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/packages/pdfx/example/ohos/entry/src/main/resources/base/media/icon.png differ diff --git a/packages/pdfx/example/ohos/entry/src/main/resources/base/profile/main_pages.json b/packages/pdfx/example/ohos/entry/src/main/resources/base/profile/main_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..1898d94f58d6128ab712be2c68acc7c98e9ab9ce --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/main/resources/base/profile/main_pages.json @@ -0,0 +1,5 @@ +{ + "src": [ + "pages/Index" + ] +} diff --git a/packages/pdfx/example/ohos/entry/src/main/resources/en_US/element/string.json b/packages/pdfx/example/ohos/entry/src/main/resources/en_US/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..67e0f4ff4ac762d1714f6e215c6636a4ad3d620e --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/main/resources/en_US/element/string.json @@ -0,0 +1,16 @@ +{ + "string": [ + { + "name": "module_desc", + "value": "module description" + }, + { + "name": "EntryAbility_desc", + "value": "description" + }, + { + "name": "EntryAbility_label", + "value": "example" + } + ] +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/main/resources/zh_CN/element/string.json b/packages/pdfx/example/ohos/entry/src/main/resources/zh_CN/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..601e2b5a1c273aa04920b126e3ab715a4450e58f --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/main/resources/zh_CN/element/string.json @@ -0,0 +1,16 @@ +{ + "string": [ + { + "name": "module_desc", + "value": "模块描述" + }, + { + "name": "EntryAbility_desc", + "value": "description" + }, + { + "name": "EntryAbility_label", + "value": "example" + } + ] +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/ets/test/Ability.test.ets b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/test/Ability.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..2d63b47876a5b77b2b3b7c3c4c2c576a0aa106a9 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/test/Ability.test.ets @@ -0,0 +1,50 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import hilog from '@ohos.hilog'; +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium' + +export default function abilityTest() { + describe('ActsAbilityTest', function () { + // Defines a test suite. Two parameters are supported: test suite name and test suite function. + beforeAll(function () { + // 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(function () { + // 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(function () { + // 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(function () { + // 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, function () { + // 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/packages/pdfx/example/ohos/entry/src/ohosTest/ets/test/List.test.ets b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..ef161b8cafbc518253c47469e0a87161204fab49 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/test/List.test.ets @@ -0,0 +1,20 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import abilityTest from './Ability.test' + +export default function testsuite() { + abilityTest() +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testability/TestAbility.ets b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testability/TestAbility.ets new file mode 100644 index 0000000000000000000000000000000000000000..8323146853ca3edc494e9e48406ccafc31f1b362 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testability/TestAbility.ets @@ -0,0 +1,63 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import UIAbility from '@ohos.app.ability.UIAbility'; +import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry'; +import hilog from '@ohos.hilog'; +import { Hypium } from '@ohos/hypium'; +import testsuite from '../test/List.test'; +import window from '@ohos.window'; + +export default class TestAbility extends UIAbility { + onCreate(want, launchParam) { + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onCreate'); + hilog.info(0x0000, 'testTag', '%{public}s', 'want param:' + JSON.stringify(want) ?? ''); + hilog.info(0x0000, 'testTag', '%{public}s', 'launchParam:'+ JSON.stringify(launchParam) ?? ''); + var abilityDelegator: any + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var abilityDelegatorArguments: any + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!'); + Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite) + } + + onDestroy() { + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onDestroy'); + } + + onWindowStageCreate(windowStage: window.WindowStage) { + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageCreate'); + windowStage.loadContent('testability/pages/Index', (err, data) => { + if (err.code) { + hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? ''); + return; + } + hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', + JSON.stringify(data) ?? ''); + }); + } + + onWindowStageDestroy() { + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageDestroy'); + } + + onForeground() { + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onForeground'); + } + + onBackground() { + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onBackground'); + } +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testability/pages/Index.ets b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testability/pages/Index.ets new file mode 100644 index 0000000000000000000000000000000000000000..62ba8c0138e3cc43736836b55d66d700c2b50a88 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testability/pages/Index.ets @@ -0,0 +1,49 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import hilog from '@ohos.hilog'; + +@Entry +@Component +struct Index { + aboutToAppear() { + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility index aboutToAppear'); + } + @State message: string = 'Hello World' + build() { + Row() { + Column() { + Text(this.message) + .fontSize(50) + .fontWeight(FontWeight.Bold) + Button() { + Text('next page') + .fontSize(20) + .fontWeight(FontWeight.Bold) + }.type(ButtonType.Capsule) + .margin({ + top: 20 + }) + .backgroundColor('#0D9FFB') + .width('35%') + .height('5%') + .onClick(()=>{ + }) + } + .width('100%') + } + .height('100%') + } + } \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testrunner/OpenHarmonyTestRunner.ts b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testrunner/OpenHarmonyTestRunner.ts new file mode 100644 index 0000000000000000000000000000000000000000..d547f682c192f02be1ad4d64b9151b25497b09a1 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/ets/testrunner/OpenHarmonyTestRunner.ts @@ -0,0 +1,64 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import hilog from '@ohos.hilog'; +import TestRunner from '@ohos.application.testRunner'; +import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry'; + +var abilityDelegator = undefined +var abilityDelegatorArguments = undefined + +async function onAbilityCreateCallback() { + hilog.info(0x0000, 'testTag', '%{public}s', 'onAbilityCreateCallback'); +} + +async function addAbilityMonitorCallback(err: any) { + hilog.info(0x0000, 'testTag', 'addAbilityMonitorCallback : %{public}s', JSON.stringify(err) ?? ''); +} + +export default class OpenHarmonyTestRunner implements TestRunner { + constructor() { + } + + onPrepare() { + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare '); + } + + async onRun() { + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run'); + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var testAbilityName = abilityDelegatorArguments.bundleName + '.TestAbility' + let lMonitor = { + abilityName: testAbilityName, + onAbilityCreate: onAbilityCreateCallback, + }; + abilityDelegator.addAbilityMonitor(lMonitor, addAbilityMonitorCallback) + var cmd = 'aa start -d 0 -a TestAbility' + ' -b ' + abilityDelegatorArguments.bundleName + var debug = abilityDelegatorArguments.parameters['-D'] + if (debug == 'true') + { + cmd += ' -D' + } + hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd); + abilityDelegator.executeShellCommand(cmd, + (err: any, d: any) => { + hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? ''); + hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', d.stdResult ?? ''); + hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', d.exitCode ?? ''); + }) + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun end'); + } +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/module.json5 b/packages/pdfx/example/ohos/entry/src/ohosTest/module.json5 new file mode 100644 index 0000000000000000000000000000000000000000..88bebb5005b337e0efaa194e50a734d2c4ec8024 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/module.json5 @@ -0,0 +1,51 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "module": { + "name": "entry_test", + "type": "feature", + "description": "$string:module_test_desc", + "mainElement": "TestAbility", + "deviceTypes": [ + "phone" + ], + "deliveryWithInstall": true, + "installationFree": false, + "pages": "$profile:test_pages", + "abilities": [ + { + "name": "TestAbility", + "srcEntry": "./ets/testability/TestAbility.ets", + "description": "$string:TestAbility_desc", + "icon": "$media:icon", + "label": "$string:TestAbility_label", + "exported": true, + "startWindowIcon": "$media:icon", + "startWindowBackground": "$color:start_window_background", + "skills": [ + { + "actions": [ + "action.system.home" + ], + "entities": [ + "entity.system.home" + ] + } + ] + } + ] + } +} diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/element/color.json b/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/element/color.json new file mode 100644 index 0000000000000000000000000000000000000000..3c712962da3c2751c2b9ddb53559afcbd2b54a02 --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/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/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/element/string.json b/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..65d8fa5a7cf54aa3943dcd0214f58d1771bc1f6c --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/element/string.json @@ -0,0 +1,16 @@ +{ + "string": [ + { + "name": "module_test_desc", + "value": "test ability description" + }, + { + "name": "TestAbility_desc", + "value": "the test ability" + }, + { + "name": "TestAbility_label", + "value": "test label" + } + ] +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/media/icon.png b/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/media/icon.png differ diff --git a/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/profile/test_pages.json b/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/profile/test_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..b7e7343cacb32ce982a45e76daad86e435e054fe --- /dev/null +++ b/packages/pdfx/example/ohos/entry/src/ohosTest/resources/base/profile/test_pages.json @@ -0,0 +1,5 @@ +{ + "src": [ + "testability/pages/Index" + ] +} diff --git a/packages/pdfx/example/ohos/hvigor/hvigor-config.json5 b/packages/pdfx/example/ohos/hvigor/hvigor-config.json5 new file mode 100644 index 0000000000000000000000000000000000000000..19128757dbaf32e0b4e1044c31662be55a65eb34 --- /dev/null +++ b/packages/pdfx/example/ohos/hvigor/hvigor-config.json5 @@ -0,0 +1,20 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "modelVersion": "5.0.0", + "dependencies": { + } +} \ No newline at end of file diff --git a/packages/pdfx/example/ohos/hvigorfile.ts b/packages/pdfx/example/ohos/hvigorfile.ts new file mode 100644 index 0000000000000000000000000000000000000000..f0e75b77798dcf0bb43963db24844fac2bd9d84d --- /dev/null +++ b/packages/pdfx/example/ohos/hvigorfile.ts @@ -0,0 +1,21 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +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/packages/pdfx/example/ohos/oh-package.json5 b/packages/pdfx/example/ohos/oh-package.json5 new file mode 100644 index 0000000000000000000000000000000000000000..818f91929e7099399acbaaeab7ca2b0278a57c53 --- /dev/null +++ b/packages/pdfx/example/ohos/oh-package.json5 @@ -0,0 +1,36 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "modelVersion": "5.0.0", + "name": "example", + "version": "1.0.0", + "description": "Please describe the basic information.", + "main": "", + "author": "", + "license": "", + "dependencies": { + "@ohos/flutter_ohos": "file:./har/flutter.har" + }, + "devDependencies": { + "@ohos/hypium": "1.0.6" + }, + "overrides": { + "@ohos/flutter_ohos": "file:./har/flutter.har", + "device_info_plus": "file:./har/device_info_plus.har", + "pdfx": "file:./har/pdfx.har", + "@ohos/flutter_module": "file:./entry" + } +} \ No newline at end of file diff --git a/packages/pdfx/lib/src/viewer/pinch/pdf_view_pinch.dart b/packages/pdfx/lib/src/viewer/pinch/pdf_view_pinch.dart index 97683437dfa1ab966e1f0b290467a9d350bc830f..e63c596cdc92f3d6e121aea5d852d0bac2d22488 100644 --- a/packages/pdfx/lib/src/viewer/pinch/pdf_view_pinch.dart +++ b/packages/pdfx/lib/src/viewer/pinch/pdf_view_pinch.dart @@ -294,7 +294,7 @@ class _PdfViewPinchState extends State if (pagesToUpdate > 0 || _forceUpdatePagePreviews) { _needPagePreviewGeneration(); } else { - _needRealSizeOverlayUpdate(); + // _needRealSizeOverlayUpdate(); } } diff --git a/packages/pdfx/ohos/.gitignore b/packages/pdfx/ohos/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..6ca13b3170eec5dd5ac5ad7f1c4dd0118845f473 --- /dev/null +++ b/packages/pdfx/ohos/.gitignore @@ -0,0 +1,19 @@ +/node_modules +/oh_modules +/local.properties +/.idea +**/build +/.hvigor +.cxx +/.clangd +/.clang-format +/.clang-tidy +**/.test +*.har +**/BuildProfile.ets +**/oh-package-lock.json5 + +**/src/main/resources/rawfile/flutter_assets/ +**/libs/arm64-v8a/libapp.so +**/libs/arm64-v8a/libflutter.so +**/libs/arm64-v8a/libvmservice_snapshot.so diff --git a/packages/pdfx/ohos/AppScope/app.json5 b/packages/pdfx/ohos/AppScope/app.json5 new file mode 100644 index 0000000000000000000000000000000000000000..74c198db286616ed7845372c3bc862cbbd005930 --- /dev/null +++ b/packages/pdfx/ohos/AppScope/app.json5 @@ -0,0 +1,25 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + + { + "app": { + "bundleName": "com.example.path_provider_ohos", + "vendor": "example", + "versionCode": 1000000, + "versionName": "1.0.0", + "icon": "$media:app_icon", + "label": "$string:app_name" + } +} diff --git a/packages/pdfx/ohos/AppScope/resources/base/element/string.json b/packages/pdfx/ohos/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..f3c1aa16f84ab64d075344886c68d1866321d8af --- /dev/null +++ b/packages/pdfx/ohos/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "app_name", + "value": "path_provider_ohos" + } + ] +} diff --git a/packages/pdfx/ohos/AppScope/resources/base/media/app_icon.png b/packages/pdfx/ohos/AppScope/resources/base/media/app_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/packages/pdfx/ohos/AppScope/resources/base/media/app_icon.png differ diff --git a/packages/pdfx/ohos/build-profile.json5 b/packages/pdfx/ohos/build-profile.json5 new file mode 100644 index 0000000000000000000000000000000000000000..b2cfb79a20c6d09fd51b219960acc54533649926 --- /dev/null +++ b/packages/pdfx/ohos/build-profile.json5 @@ -0,0 +1,25 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "apiType": "stageMode", + "buildOption": { + }, + "targets": [ + { + "name": "default" + } + ] +} \ No newline at end of file diff --git a/packages/pdfx/ohos/dta/icudtl.dat b/packages/pdfx/ohos/dta/icudtl.dat new file mode 100644 index 0000000000000000000000000000000000000000..d1f10917ab52e3ebd251abd7f5377d7196b80d67 Binary files /dev/null and b/packages/pdfx/ohos/dta/icudtl.dat differ diff --git a/packages/pdfx/ohos/hvigor/hvigor-config.json5 b/packages/pdfx/ohos/hvigor/hvigor-config.json5 new file mode 100644 index 0000000000000000000000000000000000000000..aaaf9c7f79d22826e968063286aae64d57966a30 --- /dev/null +++ b/packages/pdfx/ohos/hvigor/hvigor-config.json5 @@ -0,0 +1,21 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "hvigorVersion": "4.1.2", + "dependencies": { + "@ohos/hvigor-ohos-plugin": "4.1.2" + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/hvigor/hvigor-wrapper.js b/packages/pdfx/ohos/hvigor/hvigor-wrapper.js new file mode 100644 index 0000000000000000000000000000000000000000..26073b8c2cff8b61295873b6e829403ea6e21986 --- /dev/null +++ b/packages/pdfx/ohos/hvigor/hvigor-wrapper.js @@ -0,0 +1 @@ +"use strict";var u=require("path"),D=require("os"),e=require("fs"),t=require("crypto"),r=require("child_process"),n="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},i={},C={},E=n&&n.__importDefault||function(u){return u&&u.__esModule?u:{default:u}};Object.defineProperty(C,"__esModule",{value:!0}),C.maxPathLength=C.isMac=C.isLinux=C.isWindows=void 0;const F=E(D),A="Windows_NT",o="Darwin";function a(){return F.default.type()===A}function c(){return F.default.type()===o}C.isWindows=a,C.isLinux=function(){return"Linux"===F.default.type()},C.isMac=c,C.maxPathLength=function(){return c()?1016:a()?259:4095},function(e){var t=n&&n.__createBinding||(Object.create?function(u,D,e,t){void 0===t&&(t=e);var r=Object.getOwnPropertyDescriptor(D,e);r&&!("get"in r?!D.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return D[e]}}),Object.defineProperty(u,t,r)}:function(u,D,e,t){void 0===t&&(t=e),u[t]=D[e]}),r=n&&n.__setModuleDefault||(Object.create?function(u,D){Object.defineProperty(u,"default",{enumerable:!0,value:D})}:function(u,D){u.default=D}),i=n&&n.__importStar||function(u){if(u&&u.__esModule)return u;var D={};if(null!=u)for(var e in u)"default"!==e&&Object.prototype.hasOwnProperty.call(u,e)&&t(D,u,e);return r(D,u),D};Object.defineProperty(e,"__esModule",{value:!0}),e.ENABLE_SIGN_TASK_KEY=e.HVIGOR_CACHE_DIR_KEY=e.WORK_SPACE=e.HVIGOR_PROJECT_WRAPPER_HOME=e.HVIGOR_PROJECT_ROOT_DIR=e.HVIGOR_PROJECT_CACHES_HOME=e.HVIGOR_PNPM_STORE_PATH=e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=e.PROJECT_CACHES=e.HVIGOR_WRAPPER_TOOLS_HOME=e.HVIGOR_USER_HOME=e.DEFAULT_PACKAGE_JSON=e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME=e.PNPM=e.HVIGOR=e.NPM_TOOL=e.PNPM_TOOL=e.HVIGOR_ENGINE_PACKAGE_NAME=void 0;const E=i(D),F=i(u),A=C;e.HVIGOR_ENGINE_PACKAGE_NAME="@ohos/hvigor",e.PNPM_TOOL=(0,A.isWindows)()?"pnpm.cmd":"pnpm",e.NPM_TOOL=(0,A.isWindows)()?"npm.cmd":"npm",e.HVIGOR="hvigor",e.PNPM="pnpm",e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME="hvigor-config.json5",e.DEFAULT_PACKAGE_JSON="package.json",e.HVIGOR_USER_HOME=F.resolve(E.homedir(),".hvigor"),e.HVIGOR_WRAPPER_TOOLS_HOME=F.resolve(e.HVIGOR_USER_HOME,"wrapper","tools"),e.PROJECT_CACHES="project_caches",e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=F.resolve(e.HVIGOR_WRAPPER_TOOLS_HOME,"node_modules",".bin",e.PNPM_TOOL),e.HVIGOR_PNPM_STORE_PATH=F.resolve(e.HVIGOR_USER_HOME,"caches"),e.HVIGOR_PROJECT_CACHES_HOME=F.resolve(e.HVIGOR_USER_HOME,e.PROJECT_CACHES),e.HVIGOR_PROJECT_ROOT_DIR=process.cwd(),e.HVIGOR_PROJECT_WRAPPER_HOME=F.resolve(e.HVIGOR_PROJECT_ROOT_DIR,e.HVIGOR),e.WORK_SPACE="workspace",e.HVIGOR_CACHE_DIR_KEY="hvigor.cacheDir",e.ENABLE_SIGN_TASK_KEY="enableSignTask"}(i);var s={},l={};Object.defineProperty(l,"__esModule",{value:!0}),l.logInfoPrintConsole=l.logErrorAndExit=void 0,l.logErrorAndExit=function(u){u instanceof Error?console.error(u.message):console.error(u),process.exit(-1)},l.logInfoPrintConsole=function(u){console.log(u)};var B=n&&n.__createBinding||(Object.create?function(u,D,e,t){void 0===t&&(t=e);var r=Object.getOwnPropertyDescriptor(D,e);r&&!("get"in r?!D.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return D[e]}}),Object.defineProperty(u,t,r)}:function(u,D,e,t){void 0===t&&(t=e),u[t]=D[e]}),d=n&&n.__setModuleDefault||(Object.create?function(u,D){Object.defineProperty(u,"default",{enumerable:!0,value:D})}:function(u,D){u.default=D}),f=n&&n.__importStar||function(u){if(u&&u.__esModule)return u;var D={};if(null!=u)for(var e in u)"default"!==e&&Object.prototype.hasOwnProperty.call(u,e)&&B(D,u,e);return d(D,u),D};Object.defineProperty(s,"__esModule",{value:!0});var _=s.executeBuild=void 0;const O=f(e),p=f(u),h=l;_=s.executeBuild=function(u){const D=p.resolve(u,"node_modules","@ohos","hvigor","bin","hvigor.js");try{const u=O.realpathSync(D);require(u)}catch(e){(0,h.logErrorAndExit)(`Error: ENOENT: no such file ${D},delete ${u} and retry.`)}};var P={},v={};!function(u){var D=n&&n.__importDefault||function(u){return u&&u.__esModule?u:{default:u}};Object.defineProperty(u,"__esModule",{value:!0}),u.hashFile=u.hash=u.createHash=void 0;const r=D(t),i=D(e);u.createHash=(u="MD5")=>r.default.createHash(u);u.hash=(D,e)=>(0,u.createHash)(e).update(D).digest("hex");u.hashFile=(D,e)=>{if(i.default.existsSync(D))return(0,u.hash)(i.default.readFileSync(D,"utf-8"),e)}}(v);var g={},m={},R={};Object.defineProperty(R,"__esModule",{value:!0}),R.Unicode=void 0;class I{}R.Unicode=I,I.SPACE_SEPARATOR=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,I.ID_START=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,I.ID_CONTINUE=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/,Object.defineProperty(m,"__esModule",{value:!0}),m.JudgeUtil=void 0;const y=R;m.JudgeUtil=class{static isIgnoreChar(u){return"string"==typeof u&&("\t"===u||"\v"===u||"\f"===u||" "===u||" "===u||"\ufeff"===u||"\n"===u||"\r"===u||"\u2028"===u||"\u2029"===u)}static isSpaceSeparator(u){return"string"==typeof u&&y.Unicode.SPACE_SEPARATOR.test(u)}static isIdStartChar(u){return"string"==typeof u&&(u>="a"&&u<="z"||u>="A"&&u<="Z"||"$"===u||"_"===u||y.Unicode.ID_START.test(u))}static isIdContinueChar(u){return"string"==typeof u&&(u>="a"&&u<="z"||u>="A"&&u<="Z"||u>="0"&&u<="9"||"$"===u||"_"===u||"‌"===u||"‍"===u||y.Unicode.ID_CONTINUE.test(u))}static isDigitWithoutZero(u){return/[1-9]/.test(u)}static isDigit(u){return"string"==typeof u&&/[0-9]/.test(u)}static isHexDigit(u){return"string"==typeof u&&/[0-9A-Fa-f]/.test(u)}};var N=n&&n.__importDefault||function(u){return u&&u.__esModule?u:{default:u}};Object.defineProperty(g,"__esModule",{value:!0}),g.parseJsonText=g.parseJsonFile=void 0;const S=N(e),b=N(D),w=N(u),H=m;var x;!function(u){u[u.Char=0]="Char",u[u.EOF=1]="EOF",u[u.Identifier=2]="Identifier"}(x||(x={}));let M,T,G,V,j,J,U="start",L=[],W=0,$=1,K=0,k=!1,z="default",q="'",Z=1;function Y(u,D=!1){T=String(u),U="start",L=[],W=0,$=1,K=0,V=void 0,k=D;do{M=X(),nu[U]()}while("eof"!==M.type);return V}function X(){for(z="default",j="",q="'",Z=1;;){J=Q();const u=Du[z]();if(u)return u}}function Q(){if(T[W])return String.fromCodePoint(T.codePointAt(W))}function uu(){const u=Q();return"\n"===u?($++,K=0):u?K+=u.length:K++,u&&(W+=u.length),u}g.parseJsonFile=function(u,D=!1,e="utf-8"){const t=S.default.readFileSync(w.default.resolve(u),{encoding:e});try{return Y(t,D)}catch(D){if(D instanceof SyntaxError){const e=D.message.split("at");if(2===e.length)throw new Error(`${e[0].trim()}${b.default.EOL}\t at ${u}:${e[1].trim()}`)}throw new Error(`${u} is not in valid JSON/JSON5 format.`)}},g.parseJsonText=Y;const Du={default(){switch(J){case"/":return uu(),void(z="comment");case void 0:return uu(),eu("eof")}if(!H.JudgeUtil.isIgnoreChar(J)&&!H.JudgeUtil.isSpaceSeparator(J))return Du[U]();uu()},start(){z="value"},beforePropertyName(){switch(J){case"$":case"_":return j=uu(),void(z="identifierName");case"\\":return uu(),void(z="identifierNameStartEscape");case"}":return eu("punctuator",uu());case'"':case"'":return q=J,uu(),void(z="string")}if(H.JudgeUtil.isIdStartChar(J))return j+=uu(),void(z="identifierName");throw Fu(x.Char,uu())},afterPropertyName(){if(":"===J)return eu("punctuator",uu());throw Fu(x.Char,uu())},beforePropertyValue(){z="value"},afterPropertyValue(){switch(J){case",":case"}":return eu("punctuator",uu())}throw Fu(x.Char,uu())},beforeArrayValue(){if("]"===J)return eu("punctuator",uu());z="value"},afterArrayValue(){switch(J){case",":case"]":return eu("punctuator",uu())}throw Fu(x.Char,uu())},end(){throw Fu(x.Char,uu())},comment(){switch(J){case"*":return uu(),void(z="multiLineComment");case"/":return uu(),void(z="singleLineComment")}throw Fu(x.Char,uu())},multiLineComment(){switch(J){case"*":return uu(),void(z="multiLineCommentAsterisk");case void 0:throw Fu(x.Char,uu())}uu()},multiLineCommentAsterisk(){switch(J){case"*":return void uu();case"/":return uu(),void(z="default");case void 0:throw Fu(x.Char,uu())}uu(),z="multiLineComment"},singleLineComment(){switch(J){case"\n":case"\r":case"\u2028":case"\u2029":return uu(),void(z="default");case void 0:return uu(),eu("eof")}uu()},value(){switch(J){case"{":case"[":return eu("punctuator",uu());case"n":return uu(),tu("ull"),eu("null",null);case"t":return uu(),tu("rue"),eu("boolean",!0);case"f":return uu(),tu("alse"),eu("boolean",!1);case"-":case"+":return"-"===uu()&&(Z=-1),void(z="numerical");case".":case"0":case"I":case"N":return void(z="numerical");case'"':case"'":return q=J,uu(),j="",void(z="string")}if(void 0===J||!H.JudgeUtil.isDigitWithoutZero(J))throw Fu(x.Char,uu());z="numerical"},numerical(){switch(J){case".":return j=uu(),void(z="decimalPointLeading");case"0":return j=uu(),void(z="zero");case"I":return uu(),tu("nfinity"),eu("numeric",Z*(1/0));case"N":return uu(),tu("aN"),eu("numeric",NaN)}if(void 0!==J&&H.JudgeUtil.isDigitWithoutZero(J))return j=uu(),void(z="decimalInteger");throw Fu(x.Char,uu())},zero(){switch(J){case".":case"e":case"E":return void(z="decimal");case"x":case"X":return j+=uu(),void(z="hexadecimal")}return eu("numeric",0)},decimalInteger(){switch(J){case".":case"e":case"E":return void(z="decimal")}if(!H.JudgeUtil.isDigit(J))return eu("numeric",Z*Number(j));j+=uu()},decimal(){switch(J){case".":j+=uu(),z="decimalFraction";break;case"e":case"E":j+=uu(),z="decimalExponent"}},decimalPointLeading(){if(H.JudgeUtil.isDigit(J))return j+=uu(),void(z="decimalFraction");throw Fu(x.Char,uu())},decimalFraction(){switch(J){case"e":case"E":return j+=uu(),void(z="decimalExponent")}if(!H.JudgeUtil.isDigit(J))return eu("numeric",Z*Number(j));j+=uu()},decimalExponent(){switch(J){case"+":case"-":return j+=uu(),void(z="decimalExponentSign")}if(H.JudgeUtil.isDigit(J))return j+=uu(),void(z="decimalExponentInteger");throw Fu(x.Char,uu())},decimalExponentSign(){if(H.JudgeUtil.isDigit(J))return j+=uu(),void(z="decimalExponentInteger");throw Fu(x.Char,uu())},decimalExponentInteger(){if(!H.JudgeUtil.isDigit(J))return eu("numeric",Z*Number(j));j+=uu()},hexadecimal(){if(H.JudgeUtil.isHexDigit(J))return j+=uu(),void(z="hexadecimalInteger");throw Fu(x.Char,uu())},hexadecimalInteger(){if(!H.JudgeUtil.isHexDigit(J))return eu("numeric",Z*Number(j));j+=uu()},identifierNameStartEscape(){if("u"!==J)throw Fu(x.Char,uu());uu();const u=ru();switch(u){case"$":case"_":break;default:if(!H.JudgeUtil.isIdStartChar(u))throw Fu(x.Identifier)}j+=u,z="identifierName"},identifierName(){switch(J){case"$":case"_":case"‌":case"‍":return void(j+=uu());case"\\":return uu(),void(z="identifierNameEscape")}if(!H.JudgeUtil.isIdContinueChar(J))return eu("identifier",j);j+=uu()},identifierNameEscape(){if("u"!==J)throw Fu(x.Char,uu());uu();const u=ru();switch(u){case"$":case"_":case"‌":case"‍":break;default:if(!H.JudgeUtil.isIdContinueChar(u))throw Fu(x.Identifier)}j+=u,z="identifierName"},string(){switch(J){case"\\":return uu(),void(j+=function(){const u=Q(),D=function(){switch(Q()){case"b":return uu(),"\b";case"f":return uu(),"\f";case"n":return uu(),"\n";case"r":return uu(),"\r";case"t":return uu(),"\t";case"v":return uu(),"\v"}return}();if(D)return D;switch(u){case"0":if(uu(),H.JudgeUtil.isDigit(Q()))throw Fu(x.Char,uu());return"\0";case"x":return uu(),function(){let u="",D=Q();if(!H.JudgeUtil.isHexDigit(D))throw Fu(x.Char,uu());if(u+=uu(),D=Q(),!H.JudgeUtil.isHexDigit(D))throw Fu(x.Char,uu());return u+=uu(),String.fromCodePoint(parseInt(u,16))}();case"u":return uu(),ru();case"\n":case"\u2028":case"\u2029":return uu(),"";case"\r":return uu(),"\n"===Q()&&uu(),""}if(void 0===u||H.JudgeUtil.isDigitWithoutZero(u))throw Fu(x.Char,uu());return uu()}());case'"':case"'":if(J===q){const u=eu("string",j);return uu(),u}return void(j+=uu());case"\n":case"\r":case void 0:throw Fu(x.Char,uu());case"\u2028":case"\u2029":!function(u){console.warn(`JSON5: '${Eu(u)}' in strings is not valid ECMAScript; consider escaping.`)}(J)}j+=uu()}};function eu(u,D){return{type:u,value:D,line:$,column:K}}function tu(u){for(const D of u){if(Q()!==D)throw Fu(x.Char,uu());uu()}}function ru(){let u="",D=4;for(;D-- >0;){const D=Q();if(!H.JudgeUtil.isHexDigit(D))throw Fu(x.Char,uu());u+=uu()}return String.fromCodePoint(parseInt(u,16))}const nu={start(){if("eof"===M.type)throw Fu(x.EOF);iu()},beforePropertyName(){switch(M.type){case"identifier":case"string":return G=M.value,void(U="afterPropertyName");case"punctuator":return void Cu();case"eof":throw Fu(x.EOF)}},afterPropertyName(){if("eof"===M.type)throw Fu(x.EOF);U="beforePropertyValue"},beforePropertyValue(){if("eof"===M.type)throw Fu(x.EOF);iu()},afterPropertyValue(){if("eof"===M.type)throw Fu(x.EOF);switch(M.value){case",":return void(U="beforePropertyName");case"}":Cu()}},beforeArrayValue(){if("eof"===M.type)throw Fu(x.EOF);"punctuator"!==M.type||"]"!==M.value?iu():Cu()},afterArrayValue(){if("eof"===M.type)throw Fu(x.EOF);switch(M.value){case",":return void(U="beforeArrayValue");case"]":Cu()}},end(){}};function iu(){const u=function(){let u;switch(M.type){case"punctuator":switch(M.value){case"{":u={};break;case"[":u=[]}break;case"null":case"boolean":case"numeric":case"string":u=M.value}return u}();if(k&&"object"==typeof u&&(u._line=$,u._column=K),void 0===V)V=u;else{const D=L[L.length-1];Array.isArray(D)?k&&"object"!=typeof u?D.push({value:u,_line:$,_column:K}):D.push(u):D[G]=k&&"object"!=typeof u?{value:u,_line:$,_column:K}:u}!function(u){if(u&&"object"==typeof u)L.push(u),U=Array.isArray(u)?"beforeArrayValue":"beforePropertyName";else{const u=L[L.length-1];U=u?Array.isArray(u)?"afterArrayValue":"afterPropertyValue":"end"}}(u)}function Cu(){L.pop();const u=L[L.length-1];U=u?Array.isArray(u)?"afterArrayValue":"afterPropertyValue":"end"}function Eu(u){const D={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};if(D[u])return D[u];if(u<" "){const D=u.charCodeAt(0).toString(16);return`\\x${`00${D}`.substring(D.length)}`}return u}function Fu(u,D){let e="";switch(u){case x.Char:e=void 0===D?`JSON5: invalid end of input at ${$}:${K}`:`JSON5: invalid character '${Eu(D)}' at ${$}:${K}`;break;case x.EOF:e=`JSON5: invalid end of input at ${$}:${K}`;break;case x.Identifier:K-=5,e=`JSON5: invalid identifier character at ${$}:${K}`}const t=new Au(e);return t.lineNumber=$,t.columnNumber=K,t}class Au extends SyntaxError{}var ou={},au=n&&n.__createBinding||(Object.create?function(u,D,e,t){void 0===t&&(t=e);var r=Object.getOwnPropertyDescriptor(D,e);r&&!("get"in r?!D.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return D[e]}}),Object.defineProperty(u,t,r)}:function(u,D,e,t){void 0===t&&(t=e),u[t]=D[e]}),cu=n&&n.__setModuleDefault||(Object.create?function(u,D){Object.defineProperty(u,"default",{enumerable:!0,value:D})}:function(u,D){u.default=D}),su=n&&n.__importStar||function(u){if(u&&u.__esModule)return u;var D={};if(null!=u)for(var e in u)"default"!==e&&Object.prototype.hasOwnProperty.call(u,e)&&au(D,u,e);return cu(D,u),D},lu=n&&n.__importDefault||function(u){return u&&u.__esModule?u:{default:u}};Object.defineProperty(ou,"__esModule",{value:!0}),ou.isFileExists=ou.offlinePluginConversion=ou.executeCommand=ou.getNpmPath=ou.hasNpmPackInPaths=void 0;const Bu=r,du=lu(e),fu=su(u),_u=i,Ou=l;ou.hasNpmPackInPaths=function(u,D){try{return require.resolve(u,{paths:[...D]}),!0}catch(u){return!1}},ou.getNpmPath=function(){const u=process.execPath;return fu.join(fu.dirname(u),_u.NPM_TOOL)},ou.executeCommand=function(u,D,e){0!==(0,Bu.spawnSync)(u,D,e).status&&(0,Ou.logErrorAndExit)(`Error: ${u} ${D} execute failed.See above for details.`)},ou.offlinePluginConversion=function(u,D){return D.startsWith("file:")||D.endsWith(".tgz")?fu.resolve(u,_u.HVIGOR,D.replace("file:","")):D},ou.isFileExists=function(u){return du.default.existsSync(u)&&du.default.statSync(u).isFile()};var pu=n&&n.__createBinding||(Object.create?function(u,D,e,t){void 0===t&&(t=e);var r=Object.getOwnPropertyDescriptor(D,e);r&&!("get"in r?!D.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return D[e]}}),Object.defineProperty(u,t,r)}:function(u,D,e,t){void 0===t&&(t=e),u[t]=D[e]}),hu=n&&n.__setModuleDefault||(Object.create?function(u,D){Object.defineProperty(u,"default",{enumerable:!0,value:D})}:function(u,D){u.default=D}),Pu=n&&n.__importStar||function(u){if(u&&u.__esModule)return u;var D={};if(null!=u)for(var e in u)"default"!==e&&Object.prototype.hasOwnProperty.call(u,e)&&pu(D,u,e);return hu(D,u),D},vu=n&&n.__importDefault||function(u){return u&&u.__esModule?u:{default:u}};Object.defineProperty(P,"__esModule",{value:!0});var gu=P.initProjectWorkSpace=void 0;const mu=Pu(e),Ru=vu(D),Iu=Pu(u),yu=i,Nu=v,Su=g,bu=l,wu=ou;let Hu,xu,Mu;function Tu(u,D,e){return void 0!==e.dependencies&&(0,wu.offlinePluginConversion)(yu.HVIGOR_PROJECT_ROOT_DIR,D.dependencies[u])===Iu.normalize(e.dependencies[u])}gu=P.initProjectWorkSpace=function(){if(Hu=function(){const u=Iu.resolve(yu.HVIGOR_PROJECT_WRAPPER_HOME,yu.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME);mu.existsSync(u)||(0,bu.logErrorAndExit)(`Error: Hvigor config file ${u} does not exist.`);return(0,Su.parseJsonFile)(u)}(),Mu=function(u){let D;D=function(u){const D=u.hvigorVersion;if(D.startsWith("file:")||D.endsWith(".tgz"))return!1;const e=u.dependencies,t=Object.getOwnPropertyNames(e);for(const u of t){const D=e[u];if(D.startsWith("file:")||D.endsWith(".tgz"))return!1}if(1===t.length&&"@ohos/hvigor-ohos-plugin"===t[0])return D>"2.5.0";return!1}(u)?function(u){let D=`${yu.HVIGOR_ENGINE_PACKAGE_NAME}@${u.hvigorVersion}`;const e=u.dependencies;if(e){Object.getOwnPropertyNames(e).sort().forEach((u=>{D+=`,${u}@${e[u]}`}))}return(0,Nu.hash)(D)}(u):(0,Nu.hash)(process.cwd());return Iu.resolve(Ru.default.homedir(),".hvigor","project_caches",D)}(Hu),xu=function(){const u=Iu.resolve(Mu,yu.WORK_SPACE,yu.DEFAULT_PACKAGE_JSON);return mu.existsSync(u)?(0,Su.parseJsonFile)(u):{dependencies:{}}}(),function(){const u=Iu.resolve(yu.HVIGOR_USER_HOME,yu.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME);if(mu.existsSync(u))(0,Su.parseJsonFile)(u)}(),!(0,wu.hasNpmPackInPaths)(yu.HVIGOR_ENGINE_PACKAGE_NAME,[Iu.join(Mu,yu.WORK_SPACE)])||(0,wu.offlinePluginConversion)(yu.HVIGOR_PROJECT_ROOT_DIR,Hu.hvigorVersion)!==xu.dependencies[yu.HVIGOR_ENGINE_PACKAGE_NAME]||!function(){function u(u){const D=null==u?void 0:u.dependencies;return void 0===D?0:Object.getOwnPropertyNames(D).length}const D=u(Hu),e=u(xu);if(D+1!==e)return!1;for(const u in null==Hu?void 0:Hu.dependencies)if(!(0,wu.hasNpmPackInPaths)(u,[Iu.join(Mu,yu.WORK_SPACE)])||!Tu(u,Hu,xu))return!1;return!0}())try{!function(){(0,bu.logInfoPrintConsole)("Hvigor installing...");for(const u in Hu.dependencies)Hu.dependencies[u]&&(Hu.dependencies[u]=(0,wu.offlinePluginConversion)(yu.HVIGOR_PROJECT_ROOT_DIR,Hu.dependencies[u]));const u={dependencies:{...Hu.dependencies}};u.dependencies[yu.HVIGOR_ENGINE_PACKAGE_NAME]=(0,wu.offlinePluginConversion)(yu.HVIGOR_PROJECT_ROOT_DIR,Hu.hvigorVersion);const D=Iu.join(Mu,yu.WORK_SPACE);try{mu.mkdirSync(D,{recursive:!0});const e=Iu.resolve(D,yu.DEFAULT_PACKAGE_JSON);mu.writeFileSync(e,JSON.stringify(u))}catch(u){(0,bu.logErrorAndExit)(u)}(function(){const u=["config","set","store-dir",yu.HVIGOR_PNPM_STORE_PATH],D={cwd:Iu.join(Mu,yu.WORK_SPACE),stdio:["inherit","inherit","inherit"]};(0,wu.executeCommand)(yu.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,u,D)})(),function(){const u=["install"],D={cwd:Iu.join(Mu,yu.WORK_SPACE),stdio:["inherit","inherit","inherit"]};(0,wu.executeCommand)(yu.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,u,D)}(),(0,bu.logInfoPrintConsole)("Hvigor install success.")}()}catch(u){!function(){const u=Iu.join(Mu,yu.WORK_SPACE);if((0,bu.logInfoPrintConsole)("Hvigor cleaning..."),!mu.existsSync(u))return;const D=mu.readdirSync(u);if(!D||0===D.length)return;const e=Iu.resolve(Mu,"node_modules","@ohos","hvigor","bin","hvigor.js");mu.existsSync(e)&&(0,wu.executeCommand)(process.argv[0],[e,"--stop-daemon"],{});try{D.forEach((D=>{mu.rmSync(Iu.resolve(u,D),{recursive:!0})}))}catch(D){(0,bu.logErrorAndExit)(`The hvigor build tool cannot be installed. Please manually clear the workspace directory and synchronize the project again.\n\n Workspace Path: ${u}.`)}}()}return Mu};var Gu={};!function(t){var C=n&&n.__createBinding||(Object.create?function(u,D,e,t){void 0===t&&(t=e);var r=Object.getOwnPropertyDescriptor(D,e);r&&!("get"in r?!D.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return D[e]}}),Object.defineProperty(u,t,r)}:function(u,D,e,t){void 0===t&&(t=e),u[t]=D[e]}),E=n&&n.__setModuleDefault||(Object.create?function(u,D){Object.defineProperty(u,"default",{enumerable:!0,value:D})}:function(u,D){u.default=D}),F=n&&n.__importStar||function(u){if(u&&u.__esModule)return u;var D={};if(null!=u)for(var e in u)"default"!==e&&Object.prototype.hasOwnProperty.call(u,e)&&C(D,u,e);return E(D,u),D},A=n&&n.__importDefault||function(u){return u&&u.__esModule?u:{default:u}};Object.defineProperty(t,"__esModule",{value:!0}),t.executeInstallPnpm=t.isPnpmInstalled=t.environmentHandler=t.checkNpmConifg=t.PNPM_VERSION=void 0;const o=r,a=F(e),c=A(D),s=F(u),B=i,d=l,f=ou;t.PNPM_VERSION="7.30.0",t.checkNpmConifg=function(){const u=s.resolve(B.HVIGOR_PROJECT_ROOT_DIR,".npmrc"),D=s.resolve(c.default.homedir(),".npmrc");if((0,f.isFileExists)(u)||(0,f.isFileExists)(D))return;const e=(0,f.getNpmPath)(),t=(0,o.spawnSync)(e,["config","get","prefix"],{cwd:B.HVIGOR_PROJECT_ROOT_DIR});if(0!==t.status||!t.stdout)return void(0,d.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.");const r=s.resolve(`${t.stdout}`.replace(/[\r\n]/gi,""),".npmrc");(0,f.isFileExists)(r)||(0,d.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.")},t.environmentHandler=function(){process.env["npm_config_update-notifier"]="false"},t.isPnpmInstalled=function(){return!!a.existsSync(B.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH)&&(0,f.hasNpmPackInPaths)("pnpm",[B.HVIGOR_WRAPPER_TOOLS_HOME])},t.executeInstallPnpm=function(){(0,d.logInfoPrintConsole)(`Installing pnpm@${t.PNPM_VERSION}...`);const u=(0,f.getNpmPath)();!function(){const u=s.resolve(B.HVIGOR_WRAPPER_TOOLS_HOME,B.DEFAULT_PACKAGE_JSON);try{a.existsSync(B.HVIGOR_WRAPPER_TOOLS_HOME)||a.mkdirSync(B.HVIGOR_WRAPPER_TOOLS_HOME,{recursive:!0});const D={dependencies:{}};D.dependencies[B.PNPM]=t.PNPM_VERSION,a.writeFileSync(u,JSON.stringify(D))}catch(D){(0,d.logErrorAndExit)(`Error: EPERM: operation not permitted,create ${u} failed.`)}}(),(0,f.executeCommand)(u,["install","pnpm"],{cwd:B.HVIGOR_WRAPPER_TOOLS_HOME,stdio:["inherit","inherit","inherit"],env:process.env}),(0,d.logInfoPrintConsole)("Pnpm install success.")}}(Gu),function(){Gu.checkNpmConifg(),Gu.environmentHandler(),Gu.isPnpmInstalled()||Gu.executeInstallPnpm();const D=gu();_(u.join(D,i.WORK_SPACE))}(); \ No newline at end of file diff --git a/packages/pdfx/ohos/hvigorfile.ts b/packages/pdfx/ohos/hvigorfile.ts new file mode 100644 index 0000000000000000000000000000000000000000..15475bb3a1103d6b6bc24d45b2f6b871f0e69d0c --- /dev/null +++ b/packages/pdfx/ohos/hvigorfile.ts @@ -0,0 +1,16 @@ +/* +* Copyright (c) 2024 Huawei Device Co., Ltd. +* 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. +*/ + +export { harTasks } from '@ohos/hvigor-ohos-plugin'; \ No newline at end of file diff --git a/packages/pdfx/ohos/hvigorw b/packages/pdfx/ohos/hvigorw new file mode 100644 index 0000000000000000000000000000000000000000..255c29f9a9c62ecce36eb92b0cfa8fd8b427b270 --- /dev/null +++ b/packages/pdfx/ohos/hvigorw @@ -0,0 +1,61 @@ +#!/bin/bash + +# Copyright (c) 2023 Huawei Device Co., Ltd. +# 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. + +# ---------------------------------------------------------------------------- +# Hvigor startup script, version 1.0.0 +# +# Required ENV vars: +# ------------------ +# NODE_HOME - location of a Node home dir +# or +# Add /usr/local/nodejs/bin to the PATH environment variable +# ---------------------------------------------------------------------------- + +HVIGOR_APP_HOME=$(dirname $(readlink -f $0)) +HVIGOR_WRAPPER_SCRIPT=${HVIGOR_APP_HOME}/hvigor/hvigor-wrapper.js +warn() { + echo "" + echo -e "\033[1;33m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m" +} + +error() { + echo "" + echo -e "\033[1;31m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m" +} + +fail() { + error "$@" + exit 1 +} + +# Determine node to start hvigor wrapper script +if [ -n "${NODE_HOME}" ];then + EXECUTABLE_NODE="${NODE_HOME}/bin/node" + if [ ! -x "$EXECUTABLE_NODE" ];then + fail "ERROR: NODE_HOME is set to an invalid directory,check $NODE_HOME\n\nPlease set NODE_HOME in your environment to the location where your nodejs installed" + fi +else + EXECUTABLE_NODE="node" + which ${EXECUTABLE_NODE} > /dev/null 2>&1 || fail "ERROR: NODE_HOME is not set and not 'node' command found in your path" +fi + +# Check hvigor wrapper script +if [ ! -r "$HVIGOR_WRAPPER_SCRIPT" ];then + fail "ERROR: Couldn't find hvigor/hvigor-wrapper.js in ${HVIGOR_APP_HOME}" +fi + +# start hvigor-wrapper script +exec "${EXECUTABLE_NODE}" \ + "${HVIGOR_WRAPPER_SCRIPT}" "$@" diff --git a/packages/pdfx/ohos/hvigorw.bat b/packages/pdfx/ohos/hvigorw.bat new file mode 100644 index 0000000000000000000000000000000000000000..0c93915800ea3d2e2dda25075b8fa014d01e5703 --- /dev/null +++ b/packages/pdfx/ohos/hvigorw.bat @@ -0,0 +1,78 @@ +:: Copyright (c) 2023 Huawei Device Co., Ltd. +:: 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. + + +@if "%DEBUG%" == "" @echo off +@rem ########################################################################## +@rem +@rem Hvigor startup script for Windows +@rem +@rem ########################################################################## + +@rem Set local scope for the variables with windows NT shell +if "%OS%"=="Windows_NT" setlocal + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@rem Resolve any "." and ".." in APP_HOME to make it shorter. +for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi + +set WRAPPER_MODULE_PATH=%APP_HOME%\hvigor\hvigor-wrapper.js +set NODE_EXE=node.exe + +goto start + +:start +@rem Find node.exe +if defined NODE_HOME goto findNodeFromNodeHome + +%NODE_EXE% --version >NUL 2>&1 +if "%ERRORLEVEL%" == "0" goto execute + +echo. +echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH. +echo. +echo Please set the NODE_HOME variable in your environment to match the +echo location of your NodeJs installation. + +goto fail + +:findNodeFromNodeHome +set NODE_HOME=%NODE_HOME:"=% +set NODE_EXE_PATH=%NODE_HOME%/%NODE_EXE% + +if exist "%NODE_EXE_PATH%" goto execute +echo. +echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH. +echo. +echo Please set the NODE_HOME variable in your environment to match the +echo location of your NodeJs installation. + +goto fail + +:execute +@rem Execute hvigor +"%NODE_EXE%" %WRAPPER_MODULE_PATH% %* + +if "%ERRORLEVEL%" == "0" goto hvigorwEnd + +:fail +exit /b 1 + +:hvigorwEnd +if "%OS%" == "Windows_NT" endlocal + +:end diff --git a/packages/pdfx/ohos/index.ets b/packages/pdfx/ohos/index.ets new file mode 100644 index 0000000000000000000000000000000000000000..2395cae32f3b3aea3f195084db3b523678594833 --- /dev/null +++ b/packages/pdfx/ohos/index.ets @@ -0,0 +1,18 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import {PdfxPlugin} from './src/main/ets/io/scer/pdfx/PdfxPlugin.ets' + +export default PdfxPlugin \ No newline at end of file diff --git a/packages/pdfx/ohos/oh-package.json5 b/packages/pdfx/ohos/oh-package.json5 new file mode 100644 index 0000000000000000000000000000000000000000..90266cf67587c79f8d1b125f2b63e0bfc9b1ba8a --- /dev/null +++ b/packages/pdfx/ohos/oh-package.json5 @@ -0,0 +1,26 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "name": "pdfx", + "version": "1.0.0", + "description": "Please describe the basic information.", + "main": "", + "author": "", + "license": "", + "dependencies": { + "@ohos/flutter_ohos": "file:libs/flutter.har" + }, +} diff --git a/packages/pdfx/ohos/src/main/ets/dev/flutter/pigeon/Pigeon.ets b/packages/pdfx/ohos/src/main/ets/dev/flutter/pigeon/Pigeon.ets new file mode 100644 index 0000000000000000000000000000000000000000..6bfbe6746124e40475d227b873c81729d8fd8734 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/dev/flutter/pigeon/Pigeon.ets @@ -0,0 +1,1007 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import AbilityAware from '@ohos/flutter_ohos/src/main/ets/embedding/engine/plugins/ability/AbilityAware'; +import { AbilityPluginBinding } from '@ohos/flutter_ohos/src/main/ets/embedding/engine/plugins/ability/AbilityPluginBinding'; +import { FlutterPlugin, FlutterPluginBinding } from '@ohos/flutter_ohos/src/main/ets/embedding/engine/plugins/FlutterPlugin'; +import { MethodCallHandler, MethodResult } from '@ohos/flutter_ohos/src/main/ets/plugin/common/MethodChannel'; +import MethodChannel from '@ohos/flutter_ohos/src/main/ets/plugin/common/MethodChannel'; +import MethodCall from '@ohos/flutter_ohos/src/main/ets/plugin/common/MethodCall'; +import Log from '@ohos/flutter_ohos/src/main/ets/util/Log'; +import HashMap from '@ohos.util.HashMap'; +import StandardMessageCodec from '@ohos/flutter_ohos/src/main/ets/plugin/common/StandardMessageCodec'; +import { ByteBuffer } from '@ohos/flutter_ohos/src/main/ets/util/ByteBuffer'; +import MessageCodec from '@ohos/flutter_ohos/src/main/ets/plugin/common/MessageCodec'; +import { BinaryMessenger } from '@ohos/flutter_ohos/src/main/ets/plugin/common/BinaryMessenger'; +import BasicMessageChannel, { Reply } from '@ohos/flutter_ohos/src/main/ets/plugin/common/BasicMessageChannel'; + + + +export class OpenDataMessage{ + + private data: Uint8Array; + + constructor(data: Uint8Array) { + this.data = data; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("data", this.data); + return toMapResult; + } + + static fromMap(map: Map): OpenDataMessage{ + const data = map.get("data") as Uint8Array; + return new OpenDataMessage(data); + } + +} + +class OpenPathMessage { + + private path : string; + +/* setPath(path : string){ + this.path = path; + } + + getPath(): string { + return this.path; + }*/ + + private password : string; + +/* setPassword(password : string){ + this.password = password; + } + + getPassword(): string { + return this.password; + }*/ + + constructor(path : string, password : string) { + this.path = path; + this.password = password; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("path", this.path); + toMapResult.set("password", this.password); + return toMapResult; + } + + static fromMap(map: Map): OpenPathMessage{ + const path = map.get("path") as string; + const password = map.get("password") as string; + return new OpenPathMessage(path,password); + } + +} + +class OpenReply { + + private id : string; + + private pagesCount : number; + + constructor(id : string, pagesCount : number) { + this.id = id; + this.pagesCount = pagesCount; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("id", this.id); + toMapResult.set("pagesCount", this.pagesCount); + return toMapResult; + } + + static fromMap(map: Map): OpenReply{ + const path = map.get("id") as string; + const pagesCount = map.get("pagesCount") as number; + return new OpenReply(path,pagesCount); + } +} + +class IdMessage { + + private id : string; + + + constructor(id : string) { + this.id = id; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("id", this.id); + return toMapResult; + } + + static fromMap(map: Map): IdMessage{ + const path = map.get("id") as string; + return new IdMessage(path); + } +} + + +class GetPageMessage { + + private documentId : string; + + private pageNumber : number; + + private autoCloseOhOs : boolean; + + constructor(documentId : string, pageNumber : number, autoCloseOhOs : boolean) { + this.documentId = documentId; + this.pageNumber = pageNumber; + this.autoCloseOhOs = autoCloseOhOs; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("documentId", this.documentId); + toMapResult.set("pageNumber", this.pageNumber); + toMapResult.set("autoCloseOhOs", this.autoCloseOhOs); + return toMapResult; + } + + static fromMap(map: Map): GetPageMessage{ + const documentId = map.get("documentId") as string; + const pageNumber = map.get("pageNumber") as number; + const autoCloseOhOs = map.get("autoCloseOhOs") as boolean; + return new GetPageMessage(documentId,pageNumber,autoCloseOhOs); + } +} + +class GetPageReply { + + private id : string; + + private width : number; + + private height : number; + + constructor(id : string, width : number, height : number) { + this.id = id; + this.width = width; + this.height = height; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("id", this.id); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + return toMapResult; + } + + static fromMap(map: Map): GetPageReply{ + const id = map.get("id") as string; + const width = map.get("width") as number; + const height = map.get("height") as number; + return new GetPageReply(id,width,height); + } +} + +class RenderPageMessage { + + private pageId : string; + + private width : number; + + private height : number; + + private format : number; + + private backgroundColor : string; + + private crop : boolean; + + private cropX : number; + + private cropY : number; + + private cropHeight : number; + + private cropWidth : number; + + private quality : number; + + private forPrint : boolean; + + + constructor(pageId : string, width : number, height : number, format : number, backgroundColor : string, crop : boolean, + cropX : number, cropY : number, cropHeight : number, cropWidth : number, quality : number,forPrint : boolean ) { + this.pageId = pageId; + this.width = width; + this.height = height; + this.format = format; + this.backgroundColor = backgroundColor; + this.crop = crop; + this.cropX = cropX; + this.cropY = cropY; + this.cropHeight = cropHeight; + this.cropWidth = cropWidth; + this.quality = quality; + this.forPrint = forPrint; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("pageId", this.pageId); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + toMapResult.set("format", this.format); + toMapResult.set("backgroundColor", this.backgroundColor); + toMapResult.set("crop", this.crop); + toMapResult.set("cropX", this.cropX); + toMapResult.set("cropY", this.cropY); + toMapResult.set("cropHeight", this.cropHeight); + toMapResult.set("cropWidth", this.cropWidth); + toMapResult.set("quality", this.quality); + toMapResult.set("forPrint", this.forPrint); + + return toMapResult; + } + + static fromMap(map: Map): RenderPageMessage{ + const pageId = map.get("pageId") as string; + const width = map.get("width") as number; + const height = map.get("height") as number; + const format = map.get("format") as number; + const backgroundColor = map.get("backgroundColor") as string; + const crop = map.get("crop") as boolean; + const cropX = map.get("cropX") as number; + const cropY = map.get("cropY") as number; + const cropHeight = map.get("cropHeight") as number; + const cropWidth = map.get("cropWidth") as number; + const quality = map.get("quality") as number; + const forPrint = map.get("forPrint") as boolean; + return new RenderPageMessage(pageId,width,height,format,backgroundColor,crop,cropX,cropY,cropHeight,cropWidth,quality,forPrint); + } + +} + +class RenderPageReply { + + private width : number; + + private height : number; + + private path : string; + + private data : Uint8Array; + + + constructor(width : number, height : number, path : string, data : Uint8Array) { + this.width = width; + this.height = height; + this.path = path; + this.data = data; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + toMapResult.set("path", this.path); + toMapResult.set("data", this.data); + return toMapResult; + } + + static fromMap(map: Map): RenderPageReply{ + const width = map.get("width") as number; + const height = map.get("height") as number; + const path = map.get("path") as string; + const data = map.get("data") as Uint8Array; + return new RenderPageReply(width,height,path,data); + } + +} + +class RegisterTextureReply { + + private id : number; + + constructor(id : number) { + this.id = id; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("id", this.id); + return toMapResult; + } + + static fromMap(map: Map): RegisterTextureReply{ + const id = map.get("id") as number; + return new RegisterTextureReply(id); + } +} + +class UpdateTextureMessage { + + private documentId : string; + + private pageNumber : number; + + private pageId : string; + + private textureId : number; + + private width : number; + + private height : number; + + private backgroundColor : string; + + private sourceX : number; + + private sourceY : number; + + private destinationX : number; + + private destinationY : number; + + private fullWidth : number; + + private fullHeight : number; + + private textureWidth : number; + + private textureHeight : number; + + private allowAntiAliasing : boolean; + + constructor(documentId : string, pageNumber : number, pageId : string, textureId : number, width : number, height : number, + backgroundColor : string, sourceX : number, sourceY : number, destinationX : number, destinationY : number, + fullWidth : number, fullHeight : number, textureWidth : number, textureHeight : number, allowAntiAliasing : boolean) { + this.documentId = documentId; + this.pageNumber = pageNumber; + this.pageId = pageId; + this.textureId = textureId; + this.width = width; + this.height = height; + this.backgroundColor = backgroundColor; + this.sourceX = sourceX; + this.sourceY = sourceY; + this.destinationX = destinationX; + this.destinationY = destinationY; + this.fullWidth = fullWidth; + this.fullHeight = fullHeight; + this.textureWidth = textureWidth; + this.textureHeight = textureHeight; + this.allowAntiAliasing = allowAntiAliasing; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("documentId", this.documentId); + toMapResult.set("pageNumber", this.pageNumber); + toMapResult.set("pageId", this.pageId); + toMapResult.set("textureId", this.textureId); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + toMapResult.set("backgroundColor", this.backgroundColor); + toMapResult.set("sourceX", this.sourceX); + toMapResult.set("sourceY", this.sourceY); + toMapResult.set("destinationX", this.destinationX); + toMapResult.set("destinationY", this.destinationY); + toMapResult.set("fullWidth", this.fullWidth); + toMapResult.set("fullHeight", this.fullHeight); + toMapResult.set("textureWidth", this.textureWidth); + toMapResult.set("textureHeight", this.textureHeight); + toMapResult.set("allowAntiAliasing", this.allowAntiAliasing); + return toMapResult; + } + + static fromMap(map: Map): UpdateTextureMessage{ + const documentId = map.get("documentId") as string; + const pageNumber = map.get("pageNumber") as number; + const pageId = map.get("pageId") as string; + const textureId = map.get("textureId") as number; + const width = map.get("width") as number; + const height = map.get("height") as number; + const backgroundColor = map.get("backgroundColor") as string; + const sourceX = map.get("sourceX") as number; + const sourceY = map.get("sourceY") as number; + const destinationX = map.get("destinationX") as number; + const destinationY = map.get("destinationY") as number; + const fullWidth = map.get("fullWidth") as number; + const fullHeight = map.get("fullHeight") as number; + const textureWidth = map.get("textureWidth") as number; + const textureHeight = map.get("textureHeight") as number; + const allowAntiAliasing = map.get("allowAntiAliasing") as boolean; + return new UpdateTextureMessage(documentId,pageNumber,pageId,textureId,width,height,backgroundColor,sourceX,sourceY, + destinationX,destinationY,fullWidth,fullHeight,textureWidth,textureHeight,allowAntiAliasing); + } +} + +class ResizeTextureMessage { + + private textureId : number; + + private width : number; + + private height : number; + + constructor(textureId : number, width : number, height : number) { + this.textureId = textureId; + this.width = width; + this.height = height; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("textureId", this.textureId); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + return toMapResult; + } + + static fromMap(map: Map): ResizeTextureMessage{ + const textureId = map.get("textureId") as number; + const width = map.get("width") as number; + const height = map.get("height") as number; + return new ResizeTextureMessage(textureId,width,height); + } +} + +class UnregisterTextureMessage { + + private id : number; + + constructor(id : number) { + this.id = id; + } + + toMap(): Map{ + const toMapResult = new Map(); + toMapResult.set("id", this.id); + return toMapResult; + } + + static fromMap(map: Map): UnregisterTextureMessage{ + const id = map.get("id") as number; + return new UnregisterTextureMessage(id); + } +} + +export interface Result { + success: (result: T) => void; + + error: (error: Error) => void; +} + + class PdfxApiCodec extends StandardMessageCodec { + + public static INSTANCE :PdfxApiCodec = new PdfxApiCodec(); + + readValueOfType(type: number, buffer: ByteBuffer): ESObject { + switch (type) { + case 128: + return GetPageMessage.fromMap(super.readValue(buffer)); + + case 129: + return GetPageReply.fromMap(super.readValue(buffer)); + + case 130: + return IdMessage.fromMap(super.readValue(buffer)); + + case 131: + return OpenDataMessage.fromMap(super. readValue(buffer)); + + case 132: + return OpenPathMessage.fromMap(super.readValue(buffer)); + + case 133: + return OpenReply.fromMap(super.readValue(buffer)); + + case 134: + return RegisterTextureReply.fromMap(super.readValue(buffer)); + + case 135: + return RenderPageMessage.fromMap(super.readValue(buffer)); + + case 136: + return RenderPageReply.fromMap(super.readValue(buffer)); + + case 137: + return ResizeTextureMessage.fromMap(super.readValue(buffer)); + + case 138: + return UnregisterTextureMessage.fromMap(super.readValue(buffer)); + + case 139: + return UpdateTextureMessage.fromMap(super.readValue(buffer)); + + default: + return super.readValueOfType(type, buffer); + + } + + } + + writeValue(stream: ByteBuffer, value: ESObject): ESObject { + + if (value instanceof GetPageMessage) { + stream.writeInt8(128); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof GetPageReply) { + stream.writeInt8(129); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof IdMessage) { + stream.writeInt8(130); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof OpenDataMessage) { + stream.writeInt8(131); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof OpenPathMessage) { + stream.writeInt8(132); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof OpenReply) { + stream.writeInt8(133); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof RegisterTextureReply) { + stream.writeInt8(134); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof RenderPageMessage) { + stream.writeInt8(135); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof RenderPageReply) { + stream.writeInt8(136); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof ResizeTextureMessage) { + stream.writeInt8(137); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof UnregisterTextureMessage) { + stream.writeInt8(138); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof UpdateTextureMessage) { + stream.writeInt8(139); + super.writeValue(stream, value.toMap()); + } else + { + super.writeValue(stream, value); + } + + } +} + +export abstract class PdfxApi { + + abstract openDocumentData(message :OpenDataMessage , result:Result) : void; + + abstract openDocumentFile(message: OpenPathMessage, result: Result) : void; + + abstract openDocumentAsset(message: OpenPathMessage, result: Result) : void; + + abstract closeDocument(message: IdMessage) : void; + + abstract getPage(message: GetPageMessage, result: Result) : void; + + abstract renderPage(message: RenderPageMessage, result: Result ) : void; + + abstract closePage(message: IdMessage) : void; + + abstract registerTexture(): RegisterTextureReply; + + abstract updateTexture(message: UpdateTextureMessage, result: Result ) : void; + + abstract resizeTexture(message: ResizeTextureMessage, result: Result) : void; + + abstract unregisterTexture(message: UnregisterTextureMessage ) : void; + + static getCodec() : MessageCodec{ + return PdfxApiCodec.INSTANCE; + } + + setup(binaryMessenger: BinaryMessenger,api: PdfxApi):void{ + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.openDocumentData",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: OpenDataMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: OpenReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.openDocumentData(messageArg,resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.openDocumentFile",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: OpenPathMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: OpenReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.openDocumentFile(messageArg,resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.openDocumentAsset",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: OpenPathMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: OpenReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.openDocumentAsset(messageArg,resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.closeDocument",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: IdMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + api.closeDocument(messageArg); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + } + reply.reply(wrapped); + } + }); + } else { + channel.setMessageHandler(null); + } + } + + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.getPage",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: GetPageMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: GetPageReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.getPage(messageArg,resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.renderPage",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: RenderPageMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: RenderPageReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.renderPage(messageArg,resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.closePage",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: IdMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + api.closePage(messageArg); + wrapped.set("result", null); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + } + reply.reply(wrapped); + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.registerTexture",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const output = api.registerTexture(); + wrapped.set("result", output); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + } + reply.reply(wrapped); + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.updateTexture",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: UpdateTextureMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: void): void => { + wrapped.set("result", null); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.updateTexture(messageArg,resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.resizeTexture",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: ResizeTextureMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: void): void => { + wrapped.set("result", null); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.resizeTexture(messageArg,resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger,"dev.flutter.pigeon.PdfxApi.unregisterTexture",PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: UnregisterTextureMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + api.unregisterTexture(messageArg); + wrapped.set("result", null); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + } + + + static wrapError(exception: Error): Map { + const errorMap: Map = new Map(); + errorMap.set("message",exception.message); + errorMap.set("code", exception.name); + errorMap.set("details", exception.stack); + return errorMap; + } + +} + diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/Messages.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/Messages.ets new file mode 100644 index 0000000000000000000000000000000000000000..4c0473b22d50b1c131ca86a437fbca5999669e26 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/Messages.ets @@ -0,0 +1,265 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import { PlatformViewsController } from '@ohos/flutter_ohos'; +import { FlutterPluginBinding } from '@ohos/flutter_ohos/src/main/ets/embedding/engine/plugins/FlutterPlugin'; +import Log from '@ohos/flutter_ohos/src/main/ets/util/Log'; +import { + GetPageMessage, + GetPageReply, + IdMessage, + OpenDataMessage, + OpenPathMessage, + OpenReply, + PdfxApi, + RegisterTextureReply, + RenderPageMessage, + RenderPageReply, + ResizeTextureMessage, + Result, + UnregisterTextureMessage, + UpdateTextureMessage +} from './Pigeon'; + +import { PdfViewPlatformView } from './PdfxView' +import { Params } from '@ohos/flutter_ohos/src/main/ets/plugin/platform/PlatformView'; +import { common } from '@kit.AbilityKit'; +import fs from '@ohos.file.fs'; +import { randomID, randomFilename } from './utils/Random'; +import { pdfService } from '@kit.PDFKit'; +import { PageRepository } from './resources/PageRepository'; +import { DocumentRepository } from './resources/DocumentRepository'; +import { image } from '@kit.ImageKit'; +import { SurfaceTextureEntry } from '@ohos/flutter_ohos/src/main/ets/view/TextureRegistry'; + + +const TAG = "Messages"; + +export class Messages extends PdfxApi { + private binding: FlutterPluginBinding; + private documents: DocumentRepository; + private pages: PageRepository; + private platformViewController: PlatformViewsController | null; + private textures: Map = new Map(); + private platformViews: Map = new Map(); + + constructor(binding: FlutterPluginBinding, + documents: DocumentRepository, + pages: PageRepository) { + super(); + this.binding = binding; + this.documents = documents; + this.pages = pages; + this.platformViewController = this.binding.getFlutterEngine().getPlatformViewsController(); + } + + openDocumentData(message: OpenDataMessage, result: Result): void { + const resultResponse = new OpenReply(); + try { + let filePath = getContext(this).tempDir + '/' + randomFilename(); + let file = fs.openSync(filePath, fs.OpenMode.CREATE | fs.OpenMode.READ_WRITE); + fs.writeSync(file.fd, message.getData().buffer); + fs.closeSync(file); + + const pdfDocument = new pdfService.PdfDocument(); + pdfDocument.loadDocument(filePath, message.getPassword()); + + const document = this.documents.register(pdfDocument); + resultResponse.id = document.Id(); + resultResponse.pagesCount = document.pageCount(); + result.success(resultResponse); + } catch (e) { + result.error(e); + } + } + + openDocumentFile(message: OpenPathMessage, result: Result): void { + const resultResponse = new OpenReply(); + try { + const pdfDocument = new pdfService.PdfDocument(); + pdfDocument.loadDocument(message.getPath(), message.getPassword()); + + const document = this.documents.register(pdfDocument); + resultResponse.id = document.Id(); + resultResponse.pagesCount = document.pageCount(); + result.success(resultResponse); + } catch (e) { + result.error(e); + } + } + + openDocumentAsset(message: OpenPathMessage, result: Result): void { + const resultResponse: OpenReply = new OpenReply(); + try { + const pdfDocument = new pdfService.PdfDocument(); + const path = this.copyResourceFile(message.getPath()!!); + pdfDocument.loadDocument(path, message.getPassword()); + const document = this.documents.register(pdfDocument); + + resultResponse.id = document.Id(); + resultResponse.pagesCount = document.pageCount(); + result.success(resultResponse); + + } catch (e) { + result.error(e) + } + } + + + closeDocument(message: IdMessage): void { + try { + const id = message.getId(); + this.documents.close(id!!); + } catch (e) { + throw new Error(); + } + } + + getPage(message: GetPageMessage, result: Result): void { + const resultResponse = new GetPageReply() + try { + const documentId = message.documentId!!; + const pageNumber = message.pageNumber!!; + + if (message.autoCloseOhos!!) { + const page = this.documents.get(documentId).openPage(pageNumber); + resultResponse.width = page.getWidth(); + resultResponse.height = page.getHeight(); + + } else { + const pageRenderer = this.documents.get(documentId).openPage(pageNumber); + const page = this.pages.register(documentId, pageRenderer); + resultResponse.id = page.id; + resultResponse.width = page.getWidth() + 0.1; + resultResponse.height = page.getHeight() + 0.1; + } + result.success(resultResponse) + } catch (e) { + result.error(e) + } + } + + renderPage(message: RenderPageMessage, result: Result): void { + const resultResponse = new RenderPageReply(); + try { + const pageId = message.getPage(); + + const page = this.pages.get(pageId) + + const pageImage: image.PixelMap = page.render(); + + // 渲染 + + resultResponse.setPath(""); + resultResponse.setWidth(1.1); + resultResponse.setHeight(1.1) + result.success(resultResponse) + } catch (e) { + result.error(e); + } + } + + + closePage(message: IdMessage): void { + try { + const id = message.getId(); + this.pages.close(id); + } catch (e) { + throw new Error(); + } + } + + private flutterTexture?: SurfaceTextureEntry; + + registerTexture(): RegisterTextureReply { + const textureRegistry = this.binding.getTextureRegistry(); + const textureId = textureRegistry.getTextureId(); + const surfaceTexture = textureRegistry.registerTexture(textureId); + + this.textures.set(textureId, surfaceTexture); + + const platformView: PdfViewPlatformView = new PdfViewPlatformView(); + this.platformViews.set(textureId, platformView); + + return new RegisterTextureReply(textureId); + } + + updateTexture(message: UpdateTextureMessage, result: Result): void { + try { + const textureId = message.getTextureId(); + const pageNumber = message.getPageNumber(); + const surfaceTexture = this.textures.get(textureId); + const document = this.documents.get(message.getDocumentId()); + + const pdfPage: pdfService.PdfPage = document.openPage(pageNumber); + const pixelMap: image.PixelMap = pdfPage.getPagePixelMap(); + // todo: 刷新渲染 + // 找到textureId对应的platformView + const platformView = this.platformViews.get(textureId); + platformView!.setPixelMap(pixelMap); + platformView!.setWidth(message.getWidth()); + platformView!.setHeight(message.getHeight()); + platformView!.setLeft(message.getSourceX()); + platformView!.setTop(message.getSourceY()); + + this.platformViewController?.render(surfaceTexture?.getSurfaceId(), platformView!, + message.getWidth(), message.getHeight(), message.getSourceX(), message.getSourceY()); + + result.success(undefined); + } catch (e) { + result.error(e); + } + } + + resizeTexture(message: ResizeTextureMessage, result: Result): void { + const texId = message.getTextureId(); + const width = message.getWidth(); + const height = message.getHeight(); + const tex = this.textures.get(texId); + // todo:改变对应的纹理刷新宽高 + result.success() + } + + unregisterTexture(message: UnregisterTextureMessage): void { + const id = message.getId(); + const tex = this.textures.get(id); + tex?.release(); + this.textures.delete(id); + this.binding.getTextureRegistry().unregisterTexture(id); + } + + openDataDocument() { + + } + + + copyResourceFile(asset: string): string { + let context = getContext() as common.UIAbilityContext; + let dir = context.filesDir; + let filePath = dir + "input.pdf"; + let res = fs.accessSync(filePath); + if (res) { + console.info(TAG, "file exist 0"); + } else { + console.info(TAG, "file not exist"); + let newAsset = "flutter_assets/" + asset; + let content = context.resourceManager.getRawFileContentSync(newAsset); + let fdSand = fs.openSync(filePath, fs.OpenMode.WRITE_ONLY | fs.OpenMode.CREATE | fs.OpenMode.TRUNC); + fs.writeSync(fdSand.fd, content.buffer); + fs.closeSync(fdSand.fd); + } + return filePath; + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/OhosPdfView.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/OhosPdfView.ets new file mode 100644 index 0000000000000000000000000000000000000000..99ba62edb9fd89ef8dbb323e028602c50cd78516 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/OhosPdfView.ets @@ -0,0 +1,38 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import {pdfService} from '@kit.PDFKit'; +import { image } from '@kit.ImageKit'; +import { Params } from '@ohos/flutter_ohos/src/main/ets/plugin/platform/PlatformView'; +import {PdfViewPlatformView}from './PdfxView' + +const TAG = '[PDFKit_LOG_TAG]'; +@Entry +@Component +struct PDFPreview { + @Prop params: Params; + _pixelMap: image.PixelMap | undefined = undefined; + + build() { + Column(){ + Image(this._pixelMap) + } + } +} + +@Builder +export function PdfBuilder(params: Params){ + PDFPreview({params: params,_pixelMap: (params.platformView as PdfViewPlatformView).getPixelMap()}); +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/PdfxPlugin.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/PdfxPlugin.ets new file mode 100644 index 0000000000000000000000000000000000000000..9a2eebc55742d073d38f5e806e432489a9df9583 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/PdfxPlugin.ets @@ -0,0 +1,47 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import { + FlutterPlugin, + FlutterPluginBinding +} from '@ohos/flutter_ohos/src/main/ets/embedding/engine/plugins/FlutterPlugin'; +import { Messages } from './Messages'; +import { DocumentRepository } from './resources/DocumentRepository'; +import { PageRepository } from './resources/PageRepository'; + +import { PdfxApi } from './Pigeon'; + +const TAG: string = "PdfxPlugin"; + +export class PdfxPlugin implements FlutterPlugin { + private readonly documents = new DocumentRepository(); + private readonly pages = new PageRepository(); + + getUniqueClassName(): string { + return TAG; + } + + onAttachedToEngine(binding: FlutterPluginBinding): void { + PdfxApi.setup( + binding.getBinaryMessenger(), + new Messages(binding, this.documents, this.pages)); + } + + onDetachedFromEngine(binding: FlutterPluginBinding): void { + PdfxApi.setup(binding.getBinaryMessenger(), null) + this.documents.clear(); + this.pages.clear(); + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/PdfxView.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/PdfxView.ets new file mode 100644 index 0000000000000000000000000000000000000000..235b8b03df0cae4fe6352bd924d9b7c526ee10a8 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/PdfxView.ets @@ -0,0 +1,75 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + + +import { PlatformView } from '@ohos/flutter_ohos'; +import { Params } from '@ohos/flutter_ohos/src/main/ets/plugin/platform/PlatformView'; +import { PdfBuilder } from './OhosPdfView' +import { image } from '@kit.ImageKit'; + +export class PdfViewPlatformView extends PlatformView { + private _pixelMap: image.PixelMap | undefined = undefined; + private _width: number = 0; + private _height: number = 0; + private _left: number = 0; + private _top: number = 0; + + getView(): WrappedBuilder<[Params]> { + return new WrappedBuilder(PdfBuilder) + } + + dispose(): void { + } + + getPixelMap(): image.PixelMap | undefined { + return this._pixelMap; + } + + setPixelMap(_pixelMap: image.PixelMap | undefined): void { + this._pixelMap = _pixelMap; + } + + getWidth(): number { + return this._width; + } + + setWidth(setterArg: number) { + this._width = setterArg; + } + + getHeight(): number { + return this._height; + } + + setHeight(setterArg: number) { + this._height = setterArg; + } + + getLeft(): number { + return this._left; + } + + setLeft(setterArg: number) { + this._left = setterArg; + } + + getTop(): number { + return this._top; + } + + setTop(setterArg: number) { + this._top = setterArg; + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/Pigeon.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/Pigeon.ets new file mode 100644 index 0000000000000000000000000000000000000000..6c65e51cbbccd33b60f4bb35b04eecd4e59c47f8 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/Pigeon.ets @@ -0,0 +1,1320 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import StandardMessageCodec from '@ohos/flutter_ohos/src/main/ets/plugin/common/StandardMessageCodec'; +import { ByteBuffer } from '@ohos/flutter_ohos/src/main/ets/util/ByteBuffer'; +import MessageCodec from '@ohos/flutter_ohos/src/main/ets/plugin/common/MessageCodec'; +import { BinaryMessenger } from '@ohos/flutter_ohos/src/main/ets/plugin/common/BinaryMessenger'; +import BasicMessageChannel, { Reply } from '@ohos/flutter_ohos/src/main/ets/plugin/common/BasicMessageChannel'; + + +export class OpenDataMessage { + private data: Uint8Array = new Uint8Array; + + setData(data: Uint8Array) { + this.data = data; + } + + getData(): Uint8Array { + return this.data; + } + + private password: string = ""; + + setPassword(password: string) { + this.password = password; + } + + getPassword(): string { + return this.password; + } + + public static Builder(): OpenDataMessageBuilder { + const builder: OpenDataMessageBuilder = { + data: new Uint8Array, + setData(data: Uint8Array): OpenDataMessageBuilder { + builder.data = data; + return builder; + }, + + build(): OpenDataMessage { + const pigeonReturn = new OpenDataMessage(); + pigeonReturn.setData(builder.data); + return pigeonReturn; + } + }; + return builder; + } + + private constructor() { + } + + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("data", this.data); + return toMapResult; + } + + static fromMap(map: Map): OpenDataMessage { + + const pigeonResult = new OpenDataMessage(); + const data = map.get("data") as Uint8Array; + pigeonResult.setData(data); + return pigeonResult; + } +} + +interface OpenDataMessageBuilder { + data: Uint8Array; + setData: (data: Uint8Array) => OpenDataMessageBuilder; + build: () => OpenDataMessage; +} + +export class OpenPathMessage { + private path?: string; + + setPath(path: string) { + this.path = path; + } + + getPath(): string | undefined { + return this.path; + } + + private password: string = ""; + + setPassword(password: string) { + this.password = password; + } + + getPassword(): string { + return this.password; + } + + constructor() { + } + + public static Builder(): OpenPathMessageBuilder { + const builder: OpenPathMessageBuilder = { + path: "", + setPath(path: string): OpenPathMessageBuilder { + builder.path = path; + return builder; + }, + password: "", + setPassword(password: string): OpenPathMessageBuilder { + builder.password = password; + return builder; + }, + build(): OpenPathMessage { + const pigeonReturn = new OpenPathMessage(); + pigeonReturn.setPath(builder.path); + pigeonReturn.setPassword(builder.path); + return pigeonReturn; + } + }; + return builder; + } + + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("path", this.path!); + toMapResult.set("password", this.password); + return toMapResult; + } + + static fromMap(map: Map): OpenPathMessage { + const pigeonResult = new OpenPathMessage(); + const path = map.get("path") as string; + pigeonResult.setPath(path); + const password = map.get("password") as string; + pigeonResult.setPassword(password); + return pigeonResult; + } +} + +interface OpenPathMessageBuilder { + path: string; + setPath: (path: string) => OpenPathMessageBuilder; + password: string; + setPassword: (password: string) => OpenPathMessageBuilder; + build: () => OpenPathMessage; +} + + +export class OpenReply { + public id?: string; + public pagesCount?: number; + + constructor(id?: string, pagesCount?: number) { + this.id = id; + this.pagesCount = pagesCount; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("id", this.id!); + toMapResult.set("pagesCount", this.pagesCount!); + return toMapResult; + } + + static fromMap(map: Map): OpenReply { + const path = map.get("id") as string; + const pagesCount = map.get("pagesCount") as number; + return new OpenReply(path, pagesCount); + } +} + +export class IdMessage { + private id: string; + + public getId(): string { + return this.id; + } + + public setId(setterArg: string) { + this.id = setterArg; + } + + constructor(id: string) { + this.id = id; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("id", this.id); + return toMapResult; + } + + static fromMap(map: Map): IdMessage { + const path = map.get("id") as string; + return new IdMessage(path); + } +} + + +export class GetPageMessage { + public documentId: string; + public pageNumber: number; + public autoCloseOhos: boolean; + + constructor(documentId: string, pageNumber: number, autoCloseOhos: boolean) { + this.documentId = documentId; + this.pageNumber = pageNumber; + this.autoCloseOhos = autoCloseOhos; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("documentId", this.documentId); + toMapResult.set("pageNumber", this.pageNumber); + toMapResult.set("autoCloseOhos", this.autoCloseOhos); + return toMapResult; + } + + static fromMap(map: Map): GetPageMessage { + const documentId = map.get("documentId") as string; + const pageNumber = map.get("pageNumber") as number; + const autoCloseOhos = map.get("autoCloseOhos") as boolean; + return new GetPageMessage(documentId, pageNumber, autoCloseOhos); + } +} + +export class GetPageReply { + public id?: string; + public width?: number; + public height?: number; + + constructor(id?: string, width?: number, height?: number) { + this.id = id; + this.width = width; + this.height = height; + } + + public getId() { + return this.id; + } + + public setId(setterArg: string) { + this.id = setterArg; + } + + public getWidth() { + return this.width; + } + + public setWidth(setterArg: number) { + this.width = setterArg; + } + + public getHeight() { + return this.height; + } + + public setHeight(setterArg: number) { + this.height = setterArg; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("id", this.id!); + toMapResult.set("width", this.width!); + toMapResult.set("height", this.height!); + return toMapResult; + } + + static fromMap(map: Map): GetPageReply { + const id = map.get("id") as string; + const width = map.get("width") as number; + const height = map.get("height") as number; + return new GetPageReply(id, width, height); + } +} + +export class RenderPageMessage { + private pageId: string; + + public getPage(): string { + return this.pageId; + } + + public setPage(setterArg: string) { + this.pageId = setterArg; + } + + private width: number; + + public getWidth(): number { + return this.width; + } + + public setWidth(setterArg: number) { + this.width = setterArg; + } + + private height: number; + + public getHeight(): number { + return this.height; + } + + public setHeight(setterArg: number) { + this.height = setterArg; + } + + private format: number; + + public getFormat() { + return this.format; + } + + public setFormat(setterArg: number) { + this.format = setterArg; + } + + private backgroundColor: string; + + public getBackgroundColor() { + return this.backgroundColor; + } + + public setBackgroundColor(setterArg: string) { + this.backgroundColor = setterArg; + } + + private crop: boolean; + + public getCrop() { + return this.crop; + } + + public setCrop(setterArg: boolean) { + this.crop = setterArg; + } + + private cropX: number; + + public getCropX() { + return this.cropX; + } + + public setCropX(setterArg: number) { + this.cropX = setterArg; + } + + private cropY: number; + + public getCropY() { + return this.cropY; + } + + public setCropY(setterArg: number) { + this.cropY = setterArg; + } + + private cropHeight: number; + + public getCropHeight() { + return this.cropHeight; + } + + public setCropHeight(setterArg: number) { + this.cropHeight = setterArg; + } + + private cropWidth: number; + + public getCropWidth() { + return this.cropWidth; + } + + public setCropWidth(setterArg: number) { + this.cropWidth = setterArg; + } + + private quality: number; + + public getQuality(): number { + return this.quality; + } + + public setQuality(setterArg: number) { + this.quality = setterArg; + } + + private forPrint: boolean; + + public getForPrint() { + return this.forPrint; + } + + public setForPrint(setterArg: boolean) { + this.forPrint = setterArg; + } + + constructor(pageId: string, width: number, height: number, format: number, backgroundColor: string, crop: boolean, + cropX: number, cropY: number, cropHeight: number, cropWidth: number, quality: number, forPrint: boolean) { + this.pageId = pageId; + this.width = width; + this.height = height; + this.format = format; + this.backgroundColor = backgroundColor; + this.crop = crop; + this.cropX = cropX; + this.cropY = cropY; + this.cropHeight = cropHeight; + this.cropWidth = cropWidth; + this.quality = quality; + this.forPrint = forPrint; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("pageId", this.pageId); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + toMapResult.set("format", this.format); + toMapResult.set("backgroundColor", this.backgroundColor); + toMapResult.set("crop", this.crop); + toMapResult.set("cropX", this.cropX); + toMapResult.set("cropY", this.cropY); + toMapResult.set("cropHeight", this.cropHeight); + toMapResult.set("cropWidth", this.cropWidth); + toMapResult.set("quality", this.quality); + toMapResult.set("forPrint", this.forPrint); + + return toMapResult; + } + + static fromMap(map: Map): RenderPageMessage { + const pageId = map.get("pageId") as string; + const width = map.get("width") as number; + const height = map.get("height") as number; + const format = map.get("format") as number; + const backgroundColor = map.get("backgroundColor") as string; + const crop = map.get("crop") as boolean; + const cropX = map.get("cropX") as number; + const cropY = map.get("cropY") as number; + const cropHeight = map.get("cropHeight") as number; + const cropWidth = map.get("cropWidth") as number; + const quality = map.get("quality") as number; + const forPrint = map.get("forPrint") as boolean; + return new RenderPageMessage(pageId, width, height, format, backgroundColor, crop, cropX, cropY, cropHeight, + cropWidth, quality, forPrint); + } +} + +export class RenderPageReply { + private width?: number; + + public getWidth(): number | undefined { + return this.width; + } + + public setWidth(setterArg: number) { + this.width = setterArg; + } + + private height?: number; + + public getHeight(): number | undefined { + return this.height; + } + + public setHeight(setterArg: number) { + this.height = setterArg; + } + + private path?: string; + + public getPath(): string | undefined { + return this.path; + } + + public setPath(setterArg: string) { + this.path = setterArg; + } + + private data?: Uint8Array; + + public getData() { + return this.data; + } + + public setData(setterArg: Uint8Array) { + this.data = setterArg; + } + + // constructor(width: number, height: number, path: string, data: Uint8Array) { + // this.width = width; + // this.height = height; + // this.path = path; + // this.data = data; + // } + + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("width", this.width!); + toMapResult.set("height", this.height!); + toMapResult.set("path", this.path!); + toMapResult.set("data", this.data!); + return toMapResult; + } + + static fromMap(map: Map): RenderPageReply { + const pigeonResult: RenderPageReply = new RenderPageReply(); + const width = map.get("width") as number; + pigeonResult.setWidth(width); + const height = map.get("height") as number; + pigeonResult.setHeight(height); + const path = map.get("path") as string; + pigeonResult.setPath(path); + const data = map.get("data") as Uint8Array; + pigeonResult.setData(data); + return pigeonResult; + } +} + +export class RegisterTextureReply { + private id: number; + + constructor(id: number) { + this.id = id; + } + + public getId(): number { + return this.id; + } + + public setId(setterArg: number) { + this.id = setterArg; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("id", this.id); + return toMapResult; + } + + static fromMap(map: Map): RegisterTextureReply { + const id = map.get("id") as number; + return new RegisterTextureReply(id); + } +} + +export class UpdateTextureMessage { + private documentId: string; + + public getDocumentId(): string { + return this.documentId; + } + + public setDocumentId(setterArg: string) { + this.documentId = setterArg; + } + + private pageNumber: number; + + public getPageNumber(): number { + return this.pageNumber; + } + + public setPageNumber(setterArg: number) { + this.pageNumber = setterArg; + } + + private pageId: string; + private textureId: number; + + public getTextureId(): number { + return this.textureId; + } + + public setTextureId(setterArg: number) { + this.textureId = setterArg; + } + + private width: number; + + public getWidth(): number { + return this.width; + } + + public setWidth(setterArg: number) { + this.width = setterArg; + } + + private height: number; + + public getHeight(): number { + return this.height; + } + + public setHeight(setterArg: number) { + this.height = setterArg; + } + + private backgroundColor: string; + private sourceX: number; + + public getSourceX(): number { + return this.sourceX; + } + + public setSourceX(setterArg: number) { + this.sourceX = setterArg; + } + + private sourceY: number; + + public getSourceY(): number { + return this.sourceY; + } + + public setSourceY(setterArg: number) { + this.sourceY = setterArg; + } + + private destinationX: number; + private destinationY: number; + private fullWidth: number; + private fullHeight: number; + private textureWidth: number; + private textureHeight: number; + private allowAntiAliasing: boolean; + + constructor(documentId: string, pageNumber: number, pageId: string, textureId: number, width: number, height: number, + backgroundColor: string, sourceX: number, sourceY: number, destinationX: number, destinationY: number, + fullWidth: number, fullHeight: number, textureWidth: number, textureHeight: number, allowAntiAliasing: boolean) { + this.documentId = documentId; + this.pageNumber = pageNumber; + this.pageId = pageId; + this.textureId = textureId; + this.width = width; + this.height = height; + this.backgroundColor = backgroundColor; + this.sourceX = sourceX; + this.sourceY = sourceY; + this.destinationX = destinationX; + this.destinationY = destinationY; + this.fullWidth = fullWidth; + this.fullHeight = fullHeight; + this.textureWidth = textureWidth; + this.textureHeight = textureHeight; + this.allowAntiAliasing = allowAntiAliasing; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("documentId", this.documentId); + toMapResult.set("pageNumber", this.pageNumber); + toMapResult.set("pageId", this.pageId); + toMapResult.set("textureId", this.textureId); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + toMapResult.set("backgroundColor", this.backgroundColor); + toMapResult.set("sourceX", this.sourceX); + toMapResult.set("sourceY", this.sourceY); + toMapResult.set("destinationX", this.destinationX); + toMapResult.set("destinationY", this.destinationY); + toMapResult.set("fullWidth", this.fullWidth); + toMapResult.set("fullHeight", this.fullHeight); + toMapResult.set("textureWidth", this.textureWidth); + toMapResult.set("textureHeight", this.textureHeight); + toMapResult.set("allowAntiAliasing", this.allowAntiAliasing); + return toMapResult; + } + + static fromMap(map: Map): UpdateTextureMessage { + const documentId = map.get("documentId") as string; + const pageNumber = map.get("pageNumber") as number; + const pageId = map.get("pageId") as string; + const textureId = map.get("textureId") as number; + const width = map.get("width") as number; + const height = map.get("height") as number; + const backgroundColor = map.get("backgroundColor") as string; + const sourceX = map.get("sourceX") as number; + const sourceY = map.get("sourceY") as number; + const destinationX = map.get("destinationX") as number; + const destinationY = map.get("destinationY") as number; + const fullWidth = map.get("fullWidth") as number; + const fullHeight = map.get("fullHeight") as number; + const textureWidth = map.get("textureWidth") as number; + const textureHeight = map.get("textureHeight") as number; + const allowAntiAliasing = map.get("allowAntiAliasing") as boolean; + return new UpdateTextureMessage(documentId, pageNumber, pageId, textureId, width, height, backgroundColor, sourceX, + sourceY, + destinationX, destinationY, fullWidth, fullHeight, textureWidth, textureHeight, allowAntiAliasing); + } +} + +export class ResizeTextureMessage { + private textureId: number; + + public getTextureId(): number { + return this.textureId; + } + + public setTextureId(setterArg: number) { + this.textureId = setterArg; + } + + private width: number; + + public getWidth(): number { + return this.width; + } + + public setWidth(setterArg: number) { + this.width = setterArg; + } + + private height: number; + + public getHeight(): number { + return this.height; + } + + public setHeight(setterArg: number) { + this.height = setterArg; + } + + constructor(textureId: number, width: number, height: number) { + this.textureId = textureId; + this.width = width; + this.height = height; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("textureId", this.textureId); + toMapResult.set("width", this.width); + toMapResult.set("height", this.height); + return toMapResult; + } + + static fromMap(map: Map): ResizeTextureMessage { + const textureId = map.get("textureId") as number; + const width = map.get("width") as number; + const height = map.get("height") as number; + return new ResizeTextureMessage(textureId, width, height); + } +} + +export class UnregisterTextureMessage { + private id: number; + + constructor(id: number) { + this.id = id; + } + + public getId(): number { + return this.id; + } + + public setId(setterArg: number) { + this.id = setterArg; + } + + toMap(): Map { + const toMapResult = new Map(); + toMapResult.set("id", this.id); + return toMapResult; + } + + static fromMap(map: Map): UnregisterTextureMessage { + const id = map.get("id") as number; + return new UnregisterTextureMessage(id); + } +} + +export interface Result { + success: (result: T) => void; + error: (error: Error) => void; +} + +export class PdfxApiCodec extends StandardMessageCodec { + public static INSTANCE: PdfxApiCodec = new PdfxApiCodec(); + + readValueOfType(type: number, buffer: ByteBuffer): ESObject { + switch (type) { + case 128: + return GetPageMessage.fromMap(super.readValue(buffer)); + + case 129: + return GetPageReply.fromMap(super.readValue(buffer)); + + case 130: + return IdMessage.fromMap(super.readValue(buffer)); + + case 131: + return OpenDataMessage.fromMap(super.readValue(buffer)); + + case 132: + return OpenPathMessage.fromMap(super.readValue(buffer)); + + case 133: + return OpenReply.fromMap(super.readValue(buffer)); + + case 134: + return RegisterTextureReply.fromMap(super.readValue(buffer)); + + case 135: + return RenderPageMessage.fromMap(super.readValue(buffer)); + + case 136: + return RenderPageReply.fromMap(super.readValue(buffer)); + + case 137: + return ResizeTextureMessage.fromMap(super.readValue(buffer)); + + case 138: + return UnregisterTextureMessage.fromMap(super.readValue(buffer)); + + case 139: + return UpdateTextureMessage.fromMap(super.readValue(buffer)); + + default: + return super.readValueOfType(type, buffer); + + } + + } + + writeValue(stream: ByteBuffer, value: ESObject): ESObject { + + if (value instanceof GetPageMessage) { + stream.writeInt8(128); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof GetPageReply) { + stream.writeInt8(129); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof IdMessage) { + stream.writeInt8(130); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof OpenDataMessage) { + stream.writeInt8(131); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof OpenPathMessage) { + stream.writeInt8(132); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof OpenReply) { + stream.writeInt8(133); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof RegisterTextureReply) { + stream.writeInt8(134); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof RenderPageMessage) { + stream.writeInt8(135); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof RenderPageReply) { + stream.writeInt8(136); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof ResizeTextureMessage) { + stream.writeInt8(137); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof UnregisterTextureMessage) { + stream.writeInt8(138); + super.writeValue(stream, value.toMap()); + } else + if (value instanceof UpdateTextureMessage) { + stream.writeInt8(139); + super.writeValue(stream, value.toMap()); + } else { + super.writeValue(stream, value); + } + + } +} + +export abstract class PdfxApi { + abstract openDocumentData(message: OpenDataMessage, result: Result): void; + + abstract openDocumentFile(message: OpenPathMessage, result: Result): void; + + abstract openDocumentAsset(message: OpenPathMessage, result: Result): void; + + abstract closeDocument(message: IdMessage): void; + + abstract getPage(message: GetPageMessage, result: Result): void; + + abstract renderPage(message: RenderPageMessage, result: Result): void; + + abstract closePage(message: IdMessage): void; + + abstract registerTexture(): RegisterTextureReply; + + abstract updateTexture(message: UpdateTextureMessage, result: Result): void; + + abstract resizeTexture(message: ResizeTextureMessage, result: Result): void; + + abstract unregisterTexture(message: UnregisterTextureMessage): void; + + static getCodec(): MessageCodec { + return PdfxApiCodec.INSTANCE; + } + + static setup(binaryMessenger: BinaryMessenger, api: PdfxApi | null): void { + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.openDocumentData", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: OpenDataMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: OpenReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.openDocumentData(messageArg, resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.openDocumentFile", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: OpenPathMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: OpenReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.openDocumentFile(messageArg, resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.openDocumentAsset", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: OpenPathMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: OpenReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.openDocumentAsset(messageArg, resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.closeDocument", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: IdMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + api.closeDocument(messageArg); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + } + reply.reply(wrapped); + } + }); + } else { + channel.setMessageHandler(null); + } + } + + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.getPage", PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: GetPageMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: GetPageReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.getPage(messageArg, resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.renderPage", PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: RenderPageMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: RenderPageReply): void => { + wrapped.set("result", result); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.renderPage(messageArg, resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.closePage", PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: IdMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + api.closePage(messageArg); + wrapped.set("result", null); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + } + reply.reply(wrapped); + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.registerTexture", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const output = api.registerTexture(); + wrapped.set("result", output); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + } + reply.reply(wrapped); + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.updateTexture", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: UpdateTextureMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: void): void => { + wrapped.set("result", null); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.updateTexture(messageArg, resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.resizeTexture", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: ResizeTextureMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + const resultCallback: Result = + { + success: (result: void): void => { + wrapped.set("result", null); + reply.reply(wrapped); + }, + + error: (error: Error): void => { + wrapped.set("error", PdfxApi.wrapError(error)); + reply.reply(wrapped); + } + }; + api.resizeTexture(messageArg, resultCallback); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + { + const channel: BasicMessageChannel = + new BasicMessageChannel(binaryMessenger, "dev.flutter.pigeon.PdfxApi.unregisterTexture", + PdfxApi.getCodec()); + if (api != null) { + channel.setMessageHandler( + { + onMessage: (message: ESObject, reply: Reply) => { + let wrapped: Map = new Map(); + try { + const args: Array = message; + const messageArg: UnregisterTextureMessage = args[0]; + if (messageArg == null) { + throw new Error("messageArg unexpectedly null.") + } + + api.unregisterTexture(messageArg); + wrapped.set("result", null); + } catch (err) { + wrapped.set("error", PdfxApi.wrapError(err)); + reply.reply(wrapped); + } + } + }); + } else { + channel.setMessageHandler(null); + } + } + + } + + + static wrapError(exception: Error): Map { + const errorMap: Map = new Map(); + errorMap.set("message", exception.message); + errorMap.set("code", exception.name); + errorMap.set("details", exception.stack); + return errorMap; + } +} + diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/document/Document.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/document/Document.ets new file mode 100644 index 0000000000000000000000000000000000000000..a32e4901084246b3c585821bc5c6bea53e8e8dbf --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/document/Document.ets @@ -0,0 +1,53 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import { pdfService } from '@kit.PDFKit'; + +export class Document { + readonly id: string; + private pdfDocument: pdfService.PdfDocument; + + // private fileDescriptor: ParcelFileDescriptor; + + constructor(id: string, pdfDocument: pdfService.PdfDocument) { + this.id = id; + this.pdfDocument = pdfDocument; + // this.fileDescriptor = fileDescriptor; + } + + public Id() { + return this.id; + } + + public pageCount() { + return this.pdfDocument.getPageCount(); + } + + public infoMap(): Map { + const resultMap = new Map(); + resultMap.set('id', this.id); + resultMap.set('pagesCount', this.pageCount()); + return resultMap; + } + + public close() { + // this.pdfDocument.close(); + // this.fileDescriptor.close(); + } + + public openPage(pageNumber: number): pdfService.PdfPage { + return this.pdfDocument.getPage(pageNumber - 1); + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/document/Page.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/document/Page.ets new file mode 100644 index 0000000000000000000000000000000000000000..b90f9654d33fde0dc28640e6faef8722708f1af9 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/document/Page.ets @@ -0,0 +1,74 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import { pdfService } from '@kit.PDFKit'; +import { image } from '@kit.ImageKit'; + +class Data { + readonly width: number; + readonly height: number; + readonly path: string; + + constructor(width: number, height: number, path: string) { + this.width = width; + this.height = height; + this.path = path; + } +} + + +export class Page { + readonly id: string; + private readonly documentId: string; + private readonly pageRenderer: pdfService.PdfPage; + + constructor(id: string, documentId: string, pageRenderer: pdfService.PdfPage) { + this.id = id; + this.documentId = documentId; + this.pageRenderer = pageRenderer; + } + + /** Page number in document */ + private getNumber(): number { + return this.pageRenderer.getIndex(); + } + + public getWidth(): number { + return this.pageRenderer.getWidth(); + } + + public getHeight(): number { + return this.pageRenderer.getHeight(); + } + + public infoMap(): Map { + const resultMap = new Map(); + resultMap.set('documentId', this.documentId); + resultMap.set('id', this.id); + resultMap.set('pageNumber', this.getNumber()); + resultMap.set('width', this.getWidth()); + resultMap.set('height', this.getHeight()); + return resultMap; + } + + public close() { + // this.pageRenderer.close(); + } + + render(): image.PixelMap { + return this.pageRenderer.getPagePixelMap(); + } +} + diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/DocumentRepository.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/DocumentRepository.ets new file mode 100644 index 0000000000000000000000000000000000000000..22a498fa7b156748270b0eb51f85c4d68ff7a978 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/DocumentRepository.ets @@ -0,0 +1,33 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import { Repository } from './Repository'; +import { Document } from '../document/Document'; +import { randomID } from '../utils/Random'; +import { pdfService } from '@kit.PDFKit'; + +export class DocumentRepository extends Repository { + register(pdfDocument: pdfService.PdfDocument): Document { + const id = randomID(); + const document = new Document(id, pdfDocument); + super.set(id, document); + return document; + } + + public close(id: string) { + super.get(id).close(); + super.close(id); + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/PageRepository.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/PageRepository.ets new file mode 100644 index 0000000000000000000000000000000000000000..be4aa7c739c97e3003e6cd689cfcabd1fce354ed --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/PageRepository.ets @@ -0,0 +1,33 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +import { pdfService } from '@kit.PDFKit'; +import { Page } from '../document/Page'; +import { randomID } from '../utils/Random'; +import { Repository } from './Repository'; + +export class PageRepository extends Repository { + public register(documentId: string, pageRenderer: pdfService.PdfPage): Page { + const id = randomID(); + const page = new Page(id, documentId, pageRenderer); + super.set(id, page); + return page; + } + + public close(id: string) { + super.get(id).close(); + super.close(id); + } +} diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/Repository.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/Repository.ets new file mode 100644 index 0000000000000000000000000000000000000000..6f8dd79147e46cc50cb5971981765c2de1f039d2 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/resources/Repository.ets @@ -0,0 +1,44 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + + +import { HashMap } from '@kit.ArkTS' + +export abstract class Repository { + private items: HashMap = new HashMap(); + + get(id: string): T { + if (!this.exist(id)) { + throw Error(''); + } + return this.items.get(id); + } + + set(id: string, item: T) { + this.items.set(id, item); + } + + clear() { + this.items.clear(); + } + + private exist(id: string): boolean { + return this.items.hasKey(id); + } + + protected close(id: string) { + this.items.remove(id); + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/utils/Random.ets b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/utils/Random.ets new file mode 100644 index 0000000000000000000000000000000000000000..973bfa463fe28b822085151eb20ef3d1dbd63678 --- /dev/null +++ b/packages/pdfx/ohos/src/main/ets/io/scer/pdfx/utils/Random.ets @@ -0,0 +1,22 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + + +import util from '@ohos.util'; + + +export const randomID = () => util.generateRandomUUID(true); + +export const randomFilename = () => randomID().replace("-", ""); diff --git a/packages/pdfx/ohos/src/main/module.json5 b/packages/pdfx/ohos/src/main/module.json5 new file mode 100644 index 0000000000000000000000000000000000000000..afa55e30beccd7640f390385e3c3f75b804447b7 --- /dev/null +++ b/packages/pdfx/ohos/src/main/module.json5 @@ -0,0 +1,26 @@ +/** + * Copyright (c) 2024 Huawei Device Co., Ltd. + * 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. + */ + +{ + "module": { + "name": "pdfx", + "type": "har", + "deviceTypes": [ + "default", + "tablet", + "2in1" + ] + } +} \ No newline at end of file diff --git a/packages/pdfx/ohos/src/main/resources/base/element/string.json b/packages/pdfx/ohos/src/main/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..f51a9c8461a55f6312ef950344e3145b7f82d607 --- /dev/null +++ b/packages/pdfx/ohos/src/main/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "page_show", + "value": "page from package" + } + ] +} diff --git a/packages/pdfx/ohos/src/main/resources/en_US/element/string.json b/packages/pdfx/ohos/src/main/resources/en_US/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..f51a9c8461a55f6312ef950344e3145b7f82d607 --- /dev/null +++ b/packages/pdfx/ohos/src/main/resources/en_US/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "page_show", + "value": "page from package" + } + ] +} diff --git a/packages/pdfx/ohos/src/main/resources/zh_CN/element/string.json b/packages/pdfx/ohos/src/main/resources/zh_CN/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..f51a9c8461a55f6312ef950344e3145b7f82d607 --- /dev/null +++ b/packages/pdfx/ohos/src/main/resources/zh_CN/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "page_show", + "value": "page from package" + } + ] +} diff --git a/packages/pdfx/pubspec.yaml b/packages/pdfx/pubspec.yaml index b5b4f124de34c402871dae3e319990ca12e5e8bc..d4e4c9d3be2ba545ba1bdf46190153c47dcb4ecf 100644 --- a/packages/pdfx/pubspec.yaml +++ b/packages/pdfx/pubspec.yaml @@ -15,7 +15,10 @@ dependencies: sdk: flutter plugin_platform_interface: ^2.1.2 js: ^0.6.4 - device_info_plus: ^4.0.0 + device_info_plus: + git: + url: "https://gitee.com/openharmony-sig/flutter_plus_plugins.git" + path: "packages/device_info_plus/device_info_plus" uuid: ^3.0.6 meta: ^1.7.0 extension: ^0.5.0 @@ -36,6 +39,9 @@ flutter: android: package: io.scer.pdfx pluginClass: PdfxPlugin + ohos: + package: io.scer.pdfx + pluginClass: PdfxPlugin ios: pluginClass: PdfxPlugin macos: