This repository has been archived by the owner on Oct 18, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.ts
96 lines (77 loc) · 2.76 KB
/
index.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import { ComponentLifeCycleEvent } from '../../common/types/events.types';
import { Group, Participant } from '../../common/types/participant.types';
import { Logger, Observable } from '../../common/utils';
import config from '../../services/config';
import { EventBus } from '../../services/event-bus';
import { AblyRealtimeService } from '../../services/realtime';
import { ComponentNames } from '../types';
import { DefaultAttachComponentOptions } from './types';
export abstract class BaseComponent extends Observable {
public abstract name: ComponentNames;
protected abstract logger: Logger;
protected localParticipant: Participant;
protected group: Group;
protected realtime: AblyRealtimeService;
protected eventBus: EventBus;
protected isAttached = false;
/**
* @function attach
* @description attach component
* @returns {void}
*/
public attach = (params: DefaultAttachComponentOptions): void => {
if (Object.values(params).includes(null) || Object.values(params).includes(undefined)) {
const message = `${this.name} @ attach - params are required`;
this.logger.log(message);
throw new Error(message);
}
const { realtime, localParticipant, group, config: globalConfig, eventBus } = params;
if (!realtime.isDomainWhitelisted) {
const message = `Component ${this.name} can't be used because this website's domain is not whitelisted. Please add your domain in https://dashboard.superviz.com/developer`;
this.logger.log(message);
console.error(message);
return;
}
config.setConfig(globalConfig);
this.realtime = realtime;
this.localParticipant = localParticipant;
this.group = group;
this.eventBus = eventBus;
this.isAttached = true;
if (!this.realtime.isJoinedRoom) {
this.logger.log(`${this.name} @ attach - not joined yet`);
setTimeout(() => {
this.logger.log(`${this.name} @ attach - retrying`);
this.attach(params);
}, 1000);
return;
}
this.logger.log(`${this.name} @ attached`);
this.start();
this.publish(ComponentLifeCycleEvent.MOUNT);
};
/*
* @function detach
* @description detach component
* @returns {void}
* */
public detach = (): void => {
if (!this.isAttached) {
this.logger.log(`${this.name} @ detach - component is not attached`);
return;
}
this.logger.log('detached');
this.publish(ComponentLifeCycleEvent.UNMOUNT);
this.destroy();
Object.values(this.observers).forEach((observer) => {
observer.reset();
observer.destroy();
});
this.observers = undefined;
this.realtime = undefined;
this.localParticipant = undefined;
this.isAttached = false;
};
protected abstract destroy(): void;
protected abstract start(): void;
}