fix(core): update
This commit is contained in:
parent
e500c8a7f6
commit
3726e29768
6
package-lock.json
generated
6
package-lock.json
generated
@ -5,9 +5,9 @@
|
||||
"requires": true,
|
||||
"dependencies": {
|
||||
"@apiglobal/typedrequest": {
|
||||
"version": "1.0.49",
|
||||
"resolved": "https://verdaccio.lossless.one/@apiglobal%2ftypedrequest/-/typedrequest-1.0.49.tgz",
|
||||
"integrity": "sha512-9pDu8a7aj2SnbiyRyYK7uyWyZYhH2Ej+ovGI1gXKX8CbG28FchoiiSVMCFnWdvCq2X1+Tm2nybSr50vB8vEvuw==",
|
||||
"version": "1.0.50",
|
||||
"resolved": "https://verdaccio.lossless.one/@apiglobal%2ftypedrequest/-/typedrequest-1.0.50.tgz",
|
||||
"integrity": "sha512-Jk4hkc6CjHf7mc1lw3RCvZEBgw1trf/kJTiXaOin3wMFLTu9JUC+GTjif/nWLmJfZJTXqpv6utL3msO+YkzRYA==",
|
||||
"requires": {
|
||||
"@apiglobal/typedrequest-interfaces": "^1.0.15",
|
||||
"@pushrocks/isounique": "^1.0.4",
|
||||
|
@ -21,7 +21,7 @@
|
||||
"tslint-config-prettier": "^1.15.0"
|
||||
},
|
||||
"dependencies": {
|
||||
"@apiglobal/typedrequest": "^1.0.49",
|
||||
"@apiglobal/typedrequest": "^1.0.50",
|
||||
"@apiglobal/typedrequest-interfaces": "^1.0.15"
|
||||
},
|
||||
"files": [
|
||||
|
@ -3,9 +3,20 @@ import * as deesComms from '../ts/index';
|
||||
|
||||
let deesCommsTest: deesComms.DeesComms;
|
||||
|
||||
tap.test('first test', async () => {
|
||||
tap.test('first test', async (tools) => {
|
||||
deesCommsTest = new deesComms.DeesComms();
|
||||
deesCommsTest;
|
||||
deesCommsTest.createTypedHandler<any>('test', async (requestData) => {
|
||||
return {};
|
||||
});
|
||||
|
||||
// lets fire a request
|
||||
const typedrequest = deesCommsTest.createTypedRequest<any>('test');
|
||||
const resultPromise = typedrequest.fire({
|
||||
method: 'test',
|
||||
request: {},
|
||||
response: {}
|
||||
});
|
||||
await tools.delayFor(2000);
|
||||
});
|
||||
|
||||
tap.start();
|
||||
|
@ -7,14 +7,14 @@ import * as plugins from './dees-comms.plugins';
|
||||
export class DeesComms {
|
||||
// sending messages
|
||||
private postChannel = new BroadcastChannel('dees-comms');
|
||||
private typedrouter = new plugins.typedrequest.TypedRouter();
|
||||
public typedrouter = new plugins.typedrequest.TypedRouter();
|
||||
|
||||
private subscriptionChannel = new BroadcastChannel('dees-comms');
|
||||
|
||||
|
||||
constructor() {
|
||||
this.subscriptionChannel.onmessage = (eventArg) => {
|
||||
const message = eventArg.data;
|
||||
console.log(JSON.stringify(message));
|
||||
this.typedrouter.routeAndAddResponse(message);
|
||||
};
|
||||
}
|
||||
@ -25,7 +25,13 @@ export class DeesComms {
|
||||
public createTypedRequest<T extends plugins.typedrequestInterfaces.ITypedRequest>(
|
||||
methodName: T['method']
|
||||
): TypedRequest<T> {
|
||||
const typedrequest = new plugins.typedrequest.TypedRequest(this.postMessage, methodName, this.typedrouter);
|
||||
const typedrequest = new plugins.typedrequest.TypedRequest(
|
||||
async (messageArg) => {
|
||||
this.postMessage(messageArg);
|
||||
},
|
||||
methodName,
|
||||
this.typedrouter
|
||||
);
|
||||
return typedrequest;
|
||||
}
|
||||
|
||||
@ -41,5 +47,10 @@ export class DeesComms {
|
||||
/**
|
||||
* subscribe to messages
|
||||
*/
|
||||
public async subscribe() {}
|
||||
public async createTypedHandler<T extends plugins.typedrequestInterfaces.ITypedRequest>(
|
||||
methodArg: T['method'],
|
||||
handlerFunction: plugins.typedrequest.THandlerFunction<T>
|
||||
) {
|
||||
this.typedrouter.addTypedHandler(new plugins.typedrequest.TypedHandler<T>(methodArg, handlerFunction));
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user