Preparing Observers.
This commit is contained in:
parent
bcec3b3a78
commit
510eb7fdfa
@ -2,11 +2,12 @@
|
||||
* @author Martin Karkowski
|
||||
* @email m.karkowski@zema.de
|
||||
* @create date 2020-08-25 23:27:28
|
||||
* @modify date 2020-09-10 08:18:46
|
||||
* @modify date 2020-09-11 09:06:27
|
||||
* @desc [description]
|
||||
*/
|
||||
|
||||
import { getSingleton } from "../helpers/singletonMethod";
|
||||
import { nopeObservable } from "../observables/nopeObservable";
|
||||
import { getDispatcher } from "./getDispatcher";
|
||||
import { ICommunicationInterface } from './nopeDispatcher';
|
||||
import { IExportFunctionToDispatcherParameters, IExportMethodToDispatcherParameters, IExportPropertyToDispatcherParameters } from "./nopeDispatcherDecorators";
|
||||
@ -25,7 +26,7 @@ export function getLinkedDispatcher(communicator: ICommunicationInterface) {
|
||||
}>(),
|
||||
parameters: new Map<string, {
|
||||
uri: string,
|
||||
callback: (...args) => Promise<any>,
|
||||
item: nopeObservable<any>,
|
||||
options: IExportPropertyToDispatcherParameters
|
||||
}>(),
|
||||
functions: new Map<string, {
|
||||
@ -53,11 +54,35 @@ export function getLinkedDispatcher(communicator: ICommunicationInterface) {
|
||||
}
|
||||
|
||||
// Iterate over the Functions
|
||||
// for (const [uri, settings] of container.instance.parameters.entries()) {
|
||||
// dispatcher.registerFunction(settings.callback, {
|
||||
// id: uri
|
||||
// });
|
||||
// }
|
||||
for (const [uri, settings] of container.instance.parameters.entries()) {
|
||||
|
||||
const _pathes = {
|
||||
get: uri + '.get',
|
||||
set: uri + '.set',
|
||||
subscribe: uri + '.subscribe'
|
||||
}
|
||||
|
||||
// Register Getter:
|
||||
dispatcher.registerFunction(async () => {
|
||||
return settings.item.getContent()
|
||||
}, {
|
||||
id: _pathes.get
|
||||
});
|
||||
|
||||
// Register Setter:
|
||||
dispatcher.registerFunction(async (content, ...args) => {
|
||||
return settings.item.setContent(content, ...args)
|
||||
}, {
|
||||
id: _pathes.set
|
||||
});
|
||||
|
||||
// Register Subscription:
|
||||
dispatcher.registerFunction(async (oberserver, ...args) => {
|
||||
return settings.item.subscribe(oberserver, ...args)
|
||||
}, {
|
||||
id: _pathes.subscribe
|
||||
});
|
||||
}
|
||||
|
||||
return dispatcher;
|
||||
}
|
||||
|
@ -1,4 +1,5 @@
|
||||
import { getSingleton } from "../helpers/singletonMethod";
|
||||
import { nopeObservable } from "../observables/nopeObservable";
|
||||
|
||||
// Symbols for the Property Registery:
|
||||
const _registeredDispatcherMethods_ = Symbol('_registeredDispatcherMethods_');
|
||||
@ -10,11 +11,16 @@ export interface IExportToDispatcherParameters {
|
||||
}
|
||||
|
||||
export interface IExportMethodToDispatcherParameters {
|
||||
// Different uri (instead of using the name)
|
||||
uri?: string,
|
||||
// Contains Either the Property Name or the idx name.
|
||||
deletableCallbacks?: Array<number> | Array<string>
|
||||
}
|
||||
|
||||
export interface IExportFunctionToDispatcherParameters {
|
||||
uri: string,
|
||||
uri?: string,
|
||||
// Contains Either the Property Name or the idx name.
|
||||
deletableCallbacks?: Array<number> | Array<string>
|
||||
}
|
||||
|
||||
export interface IExportPropertyToDispatcherParameters {
|
||||
@ -31,7 +37,7 @@ const container = getSingleton('nopeBackendDispatcher.container', () => {
|
||||
}>(),
|
||||
parameters: new Map<string, {
|
||||
uri: string,
|
||||
callback: (...args) => Promise<any>,
|
||||
item: nopeObservable<any>,
|
||||
options: IExportPropertyToDispatcherParameters
|
||||
}>(),
|
||||
functions: new Map<string, {
|
||||
@ -60,9 +66,9 @@ export function exportsElementsToDispatcher(options: IExportToDispatcherParamete
|
||||
|
||||
// Online if they are present, iterate over them
|
||||
if (registeredMethods) {
|
||||
registeredMethods.forEach((options, methodName) => {
|
||||
registeredMethods.forEach((_options, methodName) => {
|
||||
// Register the Methods
|
||||
const uri = (options.uri || Base.prototype.name) + (options.uri || methodName);
|
||||
const uri = (options.uri || Base.prototype.name) + (_options.uri || methodName);
|
||||
container.instance.methods.set(uri, {
|
||||
callback: async (...args) => _this[methodName](...args),
|
||||
uri,
|
||||
@ -73,11 +79,11 @@ export function exportsElementsToDispatcher(options: IExportToDispatcherParamete
|
||||
|
||||
// Online if they are present, iterate over them
|
||||
if (registeredParams) {
|
||||
registeredParams.forEach((options, parameterName) => {
|
||||
registeredParams.forEach((_options, parameterName) => {
|
||||
// Register the Methods
|
||||
const uri = (options.uri || Base.prototype.name) + (options.uri || parameterName);
|
||||
const uri = (options.uri || Base.prototype.name) + (_options.uri || parameterName);
|
||||
container.instance.parameters.set(uri, {
|
||||
callback: async (...args) => _this[parameterName](...args),
|
||||
item: _this[parameterName],
|
||||
uri,
|
||||
options
|
||||
});
|
||||
|
@ -21,7 +21,12 @@ export class nopeRemoteObservable<T, S = T, G = T> {
|
||||
path: string,
|
||||
}
|
||||
) {
|
||||
|
||||
// Assing the Pathes
|
||||
this._pathes = {
|
||||
get: this.options.path + '.get',
|
||||
set: this.options.path + '.set',
|
||||
subscribe: this.options.path + '.subscribe'
|
||||
}
|
||||
}
|
||||
|
||||
public get currentRemoteValue() {
|
||||
|
Loading…
Reference in New Issue
Block a user