mirror of
https://gitee.com/openharmony/interface_sdk-js
synced 2024-11-30 10:53:31 +00:00
1287ee9886
Signed-off-by: huiqiang <huiqiangdev@icloud.com>
442 lines
9.9 KiB
TypeScript
442 lines
9.9 KiB
TypeScript
/*
|
|
* Copyright (c) 2021-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.
|
|
*/
|
|
|
|
/**
|
|
* @file
|
|
* @kit ArkUI
|
|
*/
|
|
|
|
import { AsyncCallback } from './@ohos.base';
|
|
import Want from './@ohos.app.ability.Want';
|
|
|
|
/**
|
|
* Plugin component template property.
|
|
*
|
|
* @interface PluginComponentTemplate
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
interface PluginComponentTemplate {
|
|
/**
|
|
* Defines the source
|
|
*
|
|
* @type { string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
source: string;
|
|
|
|
/**
|
|
* Defines the ability
|
|
*
|
|
* @type { string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
ability: string;
|
|
}
|
|
|
|
/**
|
|
* Plugin component manager interface.
|
|
*
|
|
* @namespace pluginComponentManager
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
declare namespace pluginComponentManager {
|
|
/**
|
|
* Defines KVObject
|
|
*
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
type KVObject = { [key: string]: number | string | boolean | [] | KVObject }
|
|
|
|
/**
|
|
* Plugin component push parameters.
|
|
*
|
|
* @interface PushParameters
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
interface PushParameters {
|
|
/**
|
|
* Defines want.
|
|
*
|
|
* @type { Want }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
want: Want;
|
|
|
|
/**
|
|
* Defines name.
|
|
*
|
|
* @type { string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
name: string;
|
|
|
|
/**
|
|
* Defines data.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
data: KVObject;
|
|
|
|
/**
|
|
* Defines extraData.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
extraData: KVObject;
|
|
|
|
/**
|
|
* Defines jsonPath.
|
|
*
|
|
* @type { ?string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
jsonPath?: string;
|
|
}
|
|
|
|
/**
|
|
* Plugin component push parameters which is used in push function.
|
|
*
|
|
* @interface PushParameterForStage
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
interface PushParameterForStage {
|
|
/**
|
|
* Defines owner.
|
|
*
|
|
* @type { Want }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
owner: Want;
|
|
|
|
/**
|
|
* Defines target.
|
|
*
|
|
* @type { Want }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
target: Want;
|
|
|
|
/**
|
|
* Defines name.
|
|
*
|
|
* @type { string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
name: string;
|
|
|
|
/**
|
|
* Defines data.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
data: KVObject;
|
|
|
|
/**
|
|
* Defines extraData.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
extraData: KVObject;
|
|
|
|
/**
|
|
* Defines jsonPath.
|
|
*
|
|
* @type { ?string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
jsonPath?: string;
|
|
}
|
|
|
|
/**
|
|
* Plugin component request parameters.
|
|
*
|
|
* @interface RequestParameters
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
interface RequestParameters {
|
|
/**
|
|
* Defines want.
|
|
*
|
|
* @type { Want }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
want: Want;
|
|
|
|
/**
|
|
* Defines name.
|
|
*
|
|
* @type { string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
name: string;
|
|
|
|
/**
|
|
* Defines data.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
data: KVObject;
|
|
|
|
/**
|
|
* Defines jsonPath.
|
|
*
|
|
* @type { ?string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
jsonPath?: string;
|
|
}
|
|
|
|
/**
|
|
* Plugin component request parameters which is used in request function.
|
|
*
|
|
* @interface RequestParameterForStage
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
interface RequestParameterForStage {
|
|
/**
|
|
* Defines owner.
|
|
*
|
|
* @type { Want }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
owner: Want;
|
|
|
|
/**
|
|
* Defines target.
|
|
*
|
|
* @type { Want }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
target: Want;
|
|
/**
|
|
* Defines name.
|
|
*
|
|
* @type { string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
name: string;
|
|
|
|
/**
|
|
* Defines data.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
data: KVObject;
|
|
|
|
/**
|
|
* Defines jsonPath.
|
|
*
|
|
* @type { ?string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @since 9
|
|
*/
|
|
jsonPath?: string;
|
|
}
|
|
|
|
/**
|
|
* Plugin component request callback parameters.
|
|
*
|
|
* @interface RequestCallbackParameters
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
interface RequestCallbackParameters {
|
|
|
|
/**
|
|
* Defines componentTemplate.
|
|
*
|
|
* @type { PluginComponentTemplate }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
componentTemplate: PluginComponentTemplate;
|
|
|
|
/**
|
|
* Defines data.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
data: KVObject;
|
|
|
|
/**
|
|
* Defines extraData.
|
|
*
|
|
* @type { KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
extraData: KVObject;
|
|
}
|
|
|
|
/**
|
|
* Plugin component request event result value.
|
|
*
|
|
* @interface RequestEventResult
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
interface RequestEventResult {
|
|
/**
|
|
* Defines template.
|
|
*
|
|
* @type { ?string }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
template?: string;
|
|
|
|
/**
|
|
* Defines data.
|
|
*
|
|
* @type { ?KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
data?: KVObject;
|
|
|
|
/**
|
|
* Defines extraData.
|
|
*
|
|
* @type { ?KVObject }
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
extraData?: KVObject;
|
|
}
|
|
|
|
/**
|
|
* Plugin component push event callback.
|
|
*
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
type OnPushEventCallback = (source: Want, template: PluginComponentTemplate, data: KVObject,
|
|
extraData: KVObject) => void;
|
|
|
|
/**
|
|
* Plugin component request event callback.
|
|
*
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
|
|
type OnRequestEventCallback = (source: Want, name: string, data: KVObject) => RequestEventResult;
|
|
|
|
/**
|
|
* Plugin component push method.
|
|
*
|
|
* @param { PushParameters } param
|
|
* @param { AsyncCallback<void> } callback
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
function push(param: PushParameters, callback: AsyncCallback<void>): void;
|
|
|
|
/**
|
|
* Plugin component request method.
|
|
*
|
|
* @param { RequestParameters } param
|
|
* @param { AsyncCallback<RequestCallbackParameters> } callback
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
function request(param: RequestParameters, callback: AsyncCallback<RequestCallbackParameters>): void;
|
|
|
|
/**
|
|
* Plugin component push method used to send the information of the template it provides.
|
|
*
|
|
* @param { PushParameterForStage } param - Plugin component push parameters for stage.
|
|
* @param { AsyncCallback<void> } callback - Plugin component push event callback.
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @StageModelOnly
|
|
* @since 9
|
|
*/
|
|
function push(param: PushParameterForStage, callback: AsyncCallback<void>): void;
|
|
|
|
/**
|
|
* Plugin component request method used to send a request for the information of the template it wants.
|
|
*
|
|
* @param { RequestParameterForStage } param - Plugin component request parameters for stage.
|
|
* @param { AsyncCallback<RequestCallbackParameters> } callback - Plugin component request event callback.
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @systemapi
|
|
* @StageModelOnly
|
|
* @since 9
|
|
*/
|
|
function request(param: RequestParameterForStage, callback: AsyncCallback<RequestCallbackParameters>): void;
|
|
|
|
/**
|
|
* Plugin component event listener.
|
|
*
|
|
* @param { string } eventType
|
|
* @param { OnPushEventCallback | OnRequestEventCallback } callback
|
|
* @syscap SystemCapability.ArkUI.ArkUI.Full
|
|
* @since 8
|
|
*/
|
|
function on(eventType: string, callback: OnPushEventCallback | OnRequestEventCallback): void;
|
|
}
|
|
|
|
export default pluginComponentManager;
|
|
export type { PluginComponentTemplate }; |