/*
* Copyright (c) 2025 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.
*/
// [Start web_BindSelectionMenu_Text]
import { webview } from '@kit.ArkWeb';
import { BusinessError } from '@kit.BasicServicesKit';
@Entry
@Component
struct WebComponent {
controller: webview.WebviewController = new webview.WebviewController();
clearSelection() {
try {
this.controller.runJavaScript(
'clearSelection()',
(error, result) => {
if (error) {
console.error(`run clearSelection JavaScript error, ErrorCode: ${(error as BusinessError).code}, Message: $ {(error as BusinessError).message}`);
return;
}
if (result) {
console.info(`The clearSelection() return value is: ${result}`);
}
});
} catch (error) {
console.error(`ErrorCode: ${(error as BusinessError).code}, Message: ${(error as BusinessError).message}`);
}
}
@Builder
TextMenuBuilder() {
Menu() {
MenuItem({ content: 'Copy', })
.onClick(() => {
try {
this.controller.runJavaScript(
'copySelectedText()',
(error, result) => {
if (error) {
console.error(`run copySelectedText JavaScript error, ErrorCode: ${(error as BusinessError).code}, Message: ${(error as BusinessError).message}`);
return;
}
if (result) {
console.info(`The copySelectedText() return value is: ${result}`);
}
});
} catch (error) {
console.error(`ErrorCode: ${(error as BusinessError).code}, Message: ${(error as BusinessError).message}`);
}
this.clearSelection()
}).backgroundColor(Color.Pink)
}
}
build() {
Column() {
Web({ src: $rawfile('bindSelectionMenuText.html'), controller: this.controller })
.javaScriptAccess(true)
.fileAccess(true)
.onlineImageAccess(true)
.imageAccess(true)
.domStorageAccess(true)
.zoomAccess(true)
.bindSelectionMenu(WebElementType.TEXT, this.TextMenuBuilder, WebResponseType.LONG_PRESS,
{
onAppear: () => {},
onDisappear: () => {},
menuType: MenuType.SELECTION_MENU,
})
}
}
onBackPress(): boolean | void {
try {
if (this.controller.accessStep(-1)) {
this.controller.backward();
return true;
}
} catch (error) {
console.error('onBackPress failed: ' + error);
}
return false;
}
}
// [End web_BindSelectionMenu_Text]