@river-build/sdk
Version:
For more details, visit the following resources:
68 lines • 3.32 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
import { check, dlogger } from '@river-build/dlog';
import { LoadPriority } from '../../../store/store';
import { PersistedObservable, persistedObservable } from '../../../observable/persistedObservable';
import { makeUserInboxStreamId } from '../../../id';
import { isDefined } from '../../../check';
const logger = dlogger('csb:userInbox');
let UserInbox = class UserInbox extends PersistedObservable {
riverConnection;
constructor(id, store, riverConnection) {
super({ id, streamId: makeUserInboxStreamId(id), initialized: false }, store, LoadPriority.high);
this.riverConnection = riverConnection;
}
onLoaded() {
this.riverConnection.registerView(this.onClientStarted);
}
onClientStarted = (client) => {
logger.log('onClientStarted');
if (this.riverConnection.client?.cryptoInitialized) {
const deviceId = this.riverConnection.client.userDeviceKey().deviceKey;
const streamView = this.riverConnection.client.stream(this.data.streamId)?.view;
if (streamView && deviceId) {
this.initialize(deviceId, streamView);
}
else if (deviceId) {
this.setData({ deviceId });
}
}
client.addListener('userInboxDeviceSummaryUpdated', this.onDeviceSummaryUpdated);
client.addListener('streamInitialized', this.onStreamInitialized);
return () => {
client.removeListener('userInboxDeviceSummaryUpdated', this.onDeviceSummaryUpdated);
client.removeListener('streamInitialized', this.onStreamInitialized);
};
};
onStreamInitialized = (streamId) => {
if (streamId === this.data.streamId) {
const streamView = this.riverConnection.client?.stream(this.data.streamId)?.view;
const deviceId = this.riverConnection.client?.userDeviceKey().deviceKey;
check(isDefined(deviceId), 'deviceId is not defined');
check(isDefined(streamView), 'streamView is not defined');
this.initialize(deviceId, streamView);
}
};
onDeviceSummaryUpdated = (streamId, deviceId, deviceSummary) => {
if (streamId === this.data.streamId) {
logger.log('onUserInboxDeviceSummaryUpdated', deviceId, deviceSummary);
this.setData({ deviceId, deviceSummary });
}
};
initialize(deviceId, streamView) {
this.setData({
initialized: true,
deviceId,
deviceSummary: streamView.userInboxContent.deviceSummary[deviceId],
});
}
};
UserInbox = __decorate([
persistedObservable({ tableName: 'userInbox' })
], UserInbox);
export { UserInbox };
//# sourceMappingURL=userInbox.js.map