js:add notification plugin

This commit is contained in:
pengfei.zhou 2020-01-08 19:44:24 +08:00 committed by osborn
parent b4018abe9f
commit b520ffb5df
10 changed files with 119 additions and 1 deletions

View File

@ -1310,6 +1310,17 @@ var doric = (function (exports) {
register(instance) { register(instance) {
this.entity = instance; this.entity = instance;
} }
function2Id(func) {
const functionId = uniqueId('function');
this.callbacks.set(functionId, {
resolve: func,
reject: () => { loge("This should not be called"); }
});
return functionId;
}
removeFuncById(funcId) {
this.callbacks.delete(funcId);
}
} }
const gContexts = new Map; const gContexts = new Map;
const gModules = new Map; const gModules = new Map;

View File

@ -1333,6 +1333,17 @@ class Context {
register(instance) { register(instance) {
this.entity = instance; this.entity = instance;
} }
function2Id(func) {
const functionId = uniqueId('function');
this.callbacks.set(functionId, {
resolve: func,
reject: () => { loge("This should not be called"); }
});
return functionId;
}
removeFuncById(funcId) {
this.callbacks.delete(funcId);
}
} }
const gContexts = new Map; const gContexts = new Map;
const gModules = new Map; const gModules = new Map;

View File

@ -0,0 +1,16 @@
import { BridgeContext } from "../runtime/global";
export declare function notification(context: BridgeContext): {
publish: (args: {
biz: string;
name: string;
data?: object | undefined;
androidSystem?: boolean | undefined;
}) => Promise<any>;
subscribe: (args: {
biz: string;
name: string;
callback: (data?: object | undefined) => void;
androidSystem?: boolean | undefined;
}) => Promise<string>;
unsubscribe: (subscribeId: string) => Promise<any>;
};

View File

@ -0,0 +1,18 @@
export function notification(context) {
return {
publish: (args) => {
if (args.data !== undefined) {
args.data = JSON.stringify(args.data);
}
return context.notification.publish(args);
},
subscribe: (args) => {
args.callback = context.function2Id(args.callback);
return context.notification.subscribe(args);
},
unsubscribe: (subscribeId) => {
context.removeFuncById(subscribeId);
return context.notification.unsubscribe({ subscribeId });
}
};
}

View File

@ -13,6 +13,8 @@ export declare class Context {
constructor(id: string); constructor(id: string);
callNative(namespace: string, method: string, args?: any): Promise<any>; callNative(namespace: string, method: string, args?: any): Promise<any>;
register(instance: Object): void; register(instance: Object): void;
function2Id(func: Function): string;
removeFuncById(funcId: string): void;
} }
export declare function jsObtainContext(id: string): Context | undefined; export declare function jsObtainContext(id: string): Context | undefined;
export declare function jsReleaseContext(id: string): void; export declare function jsReleaseContext(id: string): void;

View File

@ -128,6 +128,17 @@ export class Context {
register(instance) { register(instance) {
this.entity = instance; this.entity = instance;
} }
function2Id(func) {
const functionId = uniqueId('function');
this.callbacks.set(functionId, {
resolve: func,
reject: () => { loge("This should not be called"); }
});
return functionId;
}
removeFuncById(funcId) {
this.callbacks.delete(funcId);
}
} }
const gContexts = new Map; const gContexts = new Map;
const gModules = new Map; const gModules = new Map;

View File

@ -20,3 +20,4 @@ export * from './network'
export * from './storage' export * from './storage'
export * from './popover' export * from './popover'
export * from './animate' export * from './animate'
export * from './notification'

View File

@ -0,0 +1,34 @@
/*
* Copyright [2019] [Doric.Pub]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { BridgeContext } from "../runtime/global"
export function notification(context: BridgeContext) {
return {
publish: (args: { biz: string, name: string, data?: object, androidSystem?: boolean }) => {
if (args.data !== undefined) {
(args as any).data = JSON.stringify(args.data)
}
return context.notification.publish(args)
},
subscribe: (args: { biz: string, name: string, callback: (data?: object) => void, androidSystem?: boolean }) => {
(args as any).callback = (context as any).function2Id(args.callback)
return context.notification.subscribe(args) as Promise<string>
},
unsubscribe: (subscribeId: string) => {
(context as any).removeFuncById(subscribeId)
return context.notification.unsubscribe({ subscribeId })
}
}
}

View File

@ -15,7 +15,9 @@
*/ */
export * from 'reflect-metadata' export * from 'reflect-metadata'
export type BridgeContext = { [index: string]: { [index: string]: (args?: any) => Promise<any> } } export type BridgeContext = {
[index: string]: { [index: string]: (args?: any) => Promise<any> }
}
declare global { declare global {
const context: BridgeContext const context: BridgeContext

View File

@ -173,6 +173,18 @@ export class Context {
register(instance: Object) { register(instance: Object) {
this.entity = instance this.entity = instance
} }
function2Id(func: Function) {
const functionId = uniqueId('function')
this.callbacks.set(functionId, {
resolve: func,
reject: () => { loge("This should not be called") }
})
return functionId
}
removeFuncById(funcId: string) {
this.callbacks.delete(funcId)
}
} }