Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 7fb3688cb9 | |||
| ddf28a8d0e | |||
| b26aa04388 | |||
| 3726e29768 |
8
package-lock.json
generated
8
package-lock.json
generated
@@ -1,13 +1,13 @@
|
||||
{
|
||||
"name": "@designestate/dees-comms",
|
||||
"version": "1.0.4",
|
||||
"version": "1.0.6",
|
||||
"lockfileVersion": 1,
|
||||
"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.53",
|
||||
"resolved": "https://verdaccio.lossless.one/@apiglobal%2ftypedrequest/-/typedrequest-1.0.53.tgz",
|
||||
"integrity": "sha512-9KfG+ZfhryepIY1Q++OIMSU6k3Qy1MGRPXPLXQyPua5uXgHTPgT59+pczwpTAo1Mru4o0H87Xtwt596HV7FGsg==",
|
||||
"requires": {
|
||||
"@apiglobal/typedrequest-interfaces": "^1.0.15",
|
||||
"@pushrocks/isounique": "^1.0.4",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@designestate/dees-comms",
|
||||
"version": "1.0.4",
|
||||
"version": "1.0.6",
|
||||
"private": false,
|
||||
"description": "a comms module for communicating within the DOM",
|
||||
"main": "dist_ts/index.js",
|
||||
@@ -21,7 +21,7 @@
|
||||
"tslint-config-prettier": "^1.15.0"
|
||||
},
|
||||
"dependencies": {
|
||||
"@apiglobal/typedrequest": "^1.0.49",
|
||||
"@apiglobal/typedrequest": "^1.0.53",
|
||||
"@apiglobal/typedrequest-interfaces": "^1.0.15"
|
||||
},
|
||||
"files": [
|
||||
|
||||
@@ -3,9 +3,18 @@ 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 {'hitheretoo': 'greetings'};
|
||||
});
|
||||
|
||||
// lets fire a request
|
||||
const typedrequest = deesCommsTest.createTypedRequest<any>('test');
|
||||
const result = await typedrequest.fire({
|
||||
'hithere': 'hello'
|
||||
});
|
||||
console.log(JSON.stringify(result));
|
||||
});
|
||||
|
||||
tap.start();
|
||||
|
||||
@@ -7,15 +7,18 @@ 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) => {
|
||||
this.subscriptionChannel.onmessage = async (eventArg) => {
|
||||
const message = eventArg.data;
|
||||
this.typedrouter.routeAndAddResponse(message);
|
||||
console.log(JSON.stringify(message));
|
||||
const response = await this.typedrouter.routeAndAddResponse(message);
|
||||
if (response) {
|
||||
this.postMessage(response);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
@@ -25,7 +28,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 +50,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));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user