evmux-app-framework 0.0.4 → 0.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/AppsObserver/AppsObserver.js +31 -6
- package/src/AppsObserver/AppsObserverCommentsHandler.js +32 -0
- package/src/AppsObserver/AppsObserverRequestHandlerBase.js +17 -0
- package/src/EvmuxAppsApi/EvmuxAppsApi.js +10 -2
- package/src/EvmuxAppsApi/EvmuxAppsApiComments.js +14 -0
package/package.json
CHANGED
|
@@ -4,11 +4,12 @@ import { createPromise, generateGuid, pubSub } from '../EvmuxAppsApi/HelpersFrom
|
|
|
4
4
|
|
|
5
5
|
import PostMessageManager from '../PostMessageManager/PostMessageManager';
|
|
6
6
|
import appsDataManager from '../AppsDataManager/AppsDataManager';
|
|
7
|
+
import AppsObserverCommentsHandler from './AppsObserverCommentsHandler'
|
|
7
8
|
|
|
8
|
-
let createEventResultObject = (eventName, result) => {
|
|
9
|
+
let createEventResultObject = (requestName, eventName, result) => {
|
|
9
10
|
|
|
10
11
|
let eventObj = {
|
|
11
|
-
requestName
|
|
12
|
+
requestName,
|
|
12
13
|
eventName,
|
|
13
14
|
data: {...result}
|
|
14
15
|
}
|
|
@@ -24,14 +25,28 @@ let createEventResultObject = (eventName, result) => {
|
|
|
24
25
|
this._userAppInstances = {}
|
|
25
26
|
this._messagesEventHandlers = new pubSub()
|
|
26
27
|
this._eventHandler = new pubSub()
|
|
28
|
+
this._requestHandlers = []
|
|
27
29
|
}
|
|
28
30
|
|
|
29
|
-
init() {
|
|
31
|
+
init(app) {
|
|
30
32
|
window.onmessage = this.onPostMessage.bind(this);
|
|
33
|
+
this.initRequestHandlerProjectSpecific(app)
|
|
31
34
|
}
|
|
35
|
+
|
|
36
|
+
initRequestHandlerProjectSpecific(app) {
|
|
37
|
+
this._requestHandlers.push(new AppsObserverCommentsHandler(app))
|
|
38
|
+
}
|
|
32
39
|
|
|
33
40
|
raiseEvent(eventName, data) {
|
|
34
|
-
|
|
41
|
+
for (const [key, value] of Object.entries(this._userAppInstances)) {
|
|
42
|
+
if (value.events && value.events[eventName]) {
|
|
43
|
+
let eventObj = createEventResultObject("EvEvent", eventName, data)
|
|
44
|
+
let stringObjToSend = JSON.stringify(eventObj)
|
|
45
|
+
for (const [key, instanceWindow] of Object.entries(this._userAppInstances[userAppInstanceId].instances)) {
|
|
46
|
+
instanceWindow.window.postMessage(stringObjToSend, "*")
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
35
50
|
}
|
|
36
51
|
|
|
37
52
|
getAppSettingsForAppInstanceId(appInstanceId)
|
|
@@ -51,7 +66,7 @@ let createEventResultObject = (eventName, result) => {
|
|
|
51
66
|
appsDataManager.updateUserAppInstanceSettings(userAppInstanceId, data)
|
|
52
67
|
if (this._userAppInstances[userAppInstanceId].events['settingsUpdated'])
|
|
53
68
|
{
|
|
54
|
-
let eventObj = createEventResultObject("settingsUpdated", data)
|
|
69
|
+
let eventObj = createEventResultObject("EvEvent","settingsUpdated", data)
|
|
55
70
|
let stringObjToSend = JSON.stringify(eventObj)
|
|
56
71
|
for (const [key, instanceWindow] of Object.entries(this._userAppInstances[userAppInstanceId].instances)) {
|
|
57
72
|
instanceWindow.window.postMessage(stringObjToSend, "*")
|
|
@@ -85,7 +100,7 @@ let createEventResultObject = (eventName, result) => {
|
|
|
85
100
|
|
|
86
101
|
if (this._userAppInstances[requestObj.userAppInstanceId]) {
|
|
87
102
|
|
|
88
|
-
let eventObj = createEventResultObject("settings", requestObj.data)
|
|
103
|
+
let eventObj = createEventResultObject("EvMessage", "settings", requestObj.data)
|
|
89
104
|
let stringObjToSend = JSON.stringify(eventObj)
|
|
90
105
|
result = (await appsDataManager.getUserAppInstanceById(requestObj.userAppInstanceId, false)).settings
|
|
91
106
|
//this._userAppInstances[requestObj.userAppInstanceId].window.postMessage(stringObjToSend, "*")
|
|
@@ -117,6 +132,16 @@ let createEventResultObject = (eventName, result) => {
|
|
|
117
132
|
this._makeSureAppInstanceExist(requestObj.userAppInstanceId);
|
|
118
133
|
delete this._userAppInstances[requestObj.userAppInstanceId].events[requestObj.data.eventName]
|
|
119
134
|
}
|
|
135
|
+
else {
|
|
136
|
+
for (let i = 0; i < this._requestHandlers.length; i++)
|
|
137
|
+
{
|
|
138
|
+
if (this._requestHandlers[i].canHandleRequest(requestObj)) {
|
|
139
|
+
result = await this._requestHandlers[i].handleRequest(requestObj)
|
|
140
|
+
break;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
}
|
|
120
145
|
|
|
121
146
|
PostMessageManager.respondForPromiseBasedRequest(requestObj, evt.source, evt.origin, result);
|
|
122
147
|
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import AppsObserverRequestHandlerBase from './AppsObserverRequestHandlerBase'
|
|
2
|
+
export default class AppsObserverCommentsHandler extends AppsObserverRequestHandlerBase {
|
|
3
|
+
constructor(){
|
|
4
|
+
super()
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
canHandleRequest(requestObj)
|
|
8
|
+
{
|
|
9
|
+
const supportedRequests = ["getComments"];
|
|
10
|
+
return supportedRequests.includes(requestObj.request);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
async handleRequest(requestObj)
|
|
14
|
+
{
|
|
15
|
+
return [{
|
|
16
|
+
id: '1fsdf',
|
|
17
|
+
title: 'Sample comment',
|
|
18
|
+
text: 'Comments will appear here once the broadcast starts.',
|
|
19
|
+
pic: 'https://evmuxstatic.s3-eu-west-1.amazonaws.com/AVATAR_EXAMPLE_FREE.jpg',
|
|
20
|
+
style: 'comment',
|
|
21
|
+
enabled: true,
|
|
22
|
+
created_time: new Date(Date.now() - 1000 * 60),
|
|
23
|
+
sn: 'fb',
|
|
24
|
+
flags: {
|
|
25
|
+
sample: true,
|
|
26
|
+
star: false,
|
|
27
|
+
shown: false
|
|
28
|
+
}
|
|
29
|
+
}]
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
}
|
|
@@ -1,6 +1,13 @@
|
|
|
1
1
|
import PostMessageManager from '../PostMessageManager/PostMessageManager.js'
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
import EvmuxAppsApiComments from './EvmuxAppsApiComments.js'
|
|
4
|
+
|
|
5
|
+
export const availableEvents = {
|
|
6
|
+
settingsUpdated: "settingsUpdated",
|
|
7
|
+
viewerCountChanged: "viewerCountChanged",
|
|
8
|
+
keystroke: "keystroke",
|
|
9
|
+
comments: "comments"
|
|
10
|
+
}
|
|
4
11
|
|
|
5
12
|
export default class EvmuxAppsApi {
|
|
6
13
|
|
|
@@ -27,7 +34,8 @@ export default class EvmuxAppsApi {
|
|
|
27
34
|
|
|
28
35
|
let reqObj = {request: "startLoad", userAppInstanceId: this._userAppInstanceId, componentId: this._componentId}
|
|
29
36
|
this._postMessageManager.sendRequest(reqObj);
|
|
30
|
-
|
|
37
|
+
|
|
38
|
+
this.comments = new EvmuxAppsApiComments(this);
|
|
31
39
|
}
|
|
32
40
|
|
|
33
41
|
async registerEvent(eventName, callback)
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
export default class EvmuxAppsApiComments {
|
|
4
|
+
|
|
5
|
+
constructor(evmuxAppsApi) {
|
|
6
|
+
this.evmuxAppsApi = evmuxAppsApi;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
async getComments() {
|
|
10
|
+
|
|
11
|
+
let reqObj = {request: "getComments", userAppInstanceId: this.evmuxAppsApi._userAppInstanceId, componentId: this.evmuxAppsApi._componentId}
|
|
12
|
+
return this.evmuxAppsApi._postMessageManager.sendRequestAsync(reqObj);
|
|
13
|
+
}
|
|
14
|
+
}
|