js:add notification plugin
This commit is contained in:
parent
b4018abe9f
commit
b520ffb5df
@ -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;
|
||||||
|
@ -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;
|
||||||
|
16
doric-js/lib/src/native/notification.d.ts
vendored
Normal file
16
doric-js/lib/src/native/notification.d.ts
vendored
Normal 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>;
|
||||||
|
};
|
18
doric-js/lib/src/native/notification.js
Normal file
18
doric-js/lib/src/native/notification.js
Normal 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 });
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
2
doric-js/lib/src/runtime/sandbox.d.ts
vendored
2
doric-js/lib/src/runtime/sandbox.d.ts
vendored
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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'
|
||||||
|
34
doric-js/src/native/notification.ts
Normal file
34
doric-js/src/native/notification.ts
Normal 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 })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -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
|
||||||
|
@ -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)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user