A self hosted chat application with end-to-end encrypted messaging.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

794 lines
81 KiB

(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
require("../model/AbstractModel");
require("../model/UserModel");
require("../view/AbstractView");
require("../view/UserView");
var ChatMessageViewModel_1 = require("../viewmodel/ChatMessageViewModel");
var ChatController = /** @class */ (function () {
function ChatController(model, view) {
this._model = model;
this._view = view;
}
Object.defineProperty(ChatController.prototype, "model", {
/**
* Getter model
* @return {Model}
*/
get: function () {
return this._model;
},
/**
* Setter model
* @param {Model} value
*/
set: function (value) {
this._model = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ChatController.prototype, "view", {
/**
* Getter view
* @return {View}
*/
get: function () {
return this._view;
},
/**
* Setter view
* @param {View} value
*/
set: function (value) {
this._view = value;
},
enumerable: true,
configurable: true
});
/**
* eventHandler
*/
ChatController.prototype.eventHandler = function (vm) {
this.model.someBusinessMethod(vm);
};
ChatController.prototype.test = function () {
var chatMessageViewModels = [];
var chatMessageViewModelMock = new ChatMessageViewModel_1.ChatMessageViewModel();
chatMessageViewModelMock.fromUser = "user1";
chatMessageViewModelMock.toUser = "user2";
chatMessageViewModelMock.messageCipher = "";
chatMessageViewModelMock.messageTime = new Date();
chatMessageViewModels.push(chatMessageViewModelMock);
};
return ChatController;
}());
exports.ChatController = ChatController;
},{"../model/AbstractModel":4,"../model/UserModel":7,"../view/AbstractView":12,"../view/UserView":14,"../viewmodel/ChatMessageViewModel":16}],2:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
require("../model/AbstractModel");
require("../model/UserModel");
require("../view/AbstractView");
require("../view/UserView");
var ActiveUserViewModel_1 = require("../viewmodel/ActiveUserViewModel");
var UserController = /** @class */ (function () {
function UserController(model, view) {
this._model = model;
this._view = view;
}
Object.defineProperty(UserController.prototype, "model", {
/**
* Getter model
* @return {Model}
*/
get: function () {
return this._model;
},
/**
* Setter model
* @param {Model} value
*/
set: function (value) {
this._model = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(UserController.prototype, "view", {
/**
* Getter view
* @return {View}
*/
get: function () {
return this._view;
},
/**
* Setter view
* @param {View} value
*/
set: function (value) {
this._view = value;
},
enumerable: true,
configurable: true
});
/**
* eventHandler
*/
UserController.prototype.eventHandler = function (vm) {
this.model.someBusinessMethod(vm);
};
UserController.prototype.test = function () {
var activeUsersMock = [];
var activeUserViewModelMock = new ActiveUserViewModel_1.ActiveUserViewModel();
activeUserViewModelMock.userName = "some user";
activeUserViewModelMock.lastActive = "3 hrs ago";
activeUserViewModelMock.online = true;
activeUsersMock.push(activeUserViewModelMock);
activeUserViewModelMock = new ActiveUserViewModel_1.ActiveUserViewModel();
activeUserViewModelMock.lastActive = "3 hrs ago";
activeUserViewModelMock.online = true;
activeUserViewModelMock.userName = "some user 2";
activeUsersMock.push(activeUserViewModelMock);
this.eventHandler(activeUsersMock);
};
return UserController;
}());
exports.UserController = UserController;
},{"../model/AbstractModel":4,"../model/UserModel":7,"../view/AbstractView":12,"../view/UserView":14,"../viewmodel/ActiveUserViewModel":15}],3:[function(require,module,exports){
(function (global){
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
var UserModel_1 = require("./model/UserModel");
var UserView_1 = require("./view/UserView");
var UserController_1 = require("./controller/UserController");
var loglevel_1 = __importDefault((typeof window !== "undefined" ? window['log'] : typeof global !== "undefined" ? global['log'] : null));
var handlebars_1 = __importDefault((typeof window !== "undefined" ? window['Handlebars'] : typeof global !== "undefined" ? global['Handlebars'] : null));
var markdown_it_1 = __importDefault((typeof window !== "undefined" ? window['markdownit'] : typeof global !== "undefined" ? global['markdownit'] : null));
var ChatModel_1 = require("./model/ChatModel");
var ChatView_1 = require("./view/ChatView");
var ChatController_1 = require("./controller/ChatController");
var JsonAPI_1 = require("./singleton/JsonAPI");
var SJCLEncryptionService_1 = require("./service/SJCLEncryptionService");
var LogLevelLoggerService_1 = require("./service/LogLevelLoggerService");
// import { logger } from "./singleton/Logger";
// var markdownit = require('markdown-it');
var md = new markdown_it_1.default();
var logger = new LogLevelLoggerService_1.LogLevelLogger();
var userBox = document.getElementById('contacts-box');
loglevel_1.default.setLevel("TRACE");
var userModel = new UserModel_1.UserModel();
// const userModel = ModelFactory.createModel("USER");
// @ts-ignore: Argument of type 'HTMLElement | null' is not assignable to parameter of type 'HTMLElement'. Type 'null' is not assignable to type 'HTMLElement'.
var userView = new UserView_1.UserView(userModel, userBox);
// console.log(userBox);
userModel.attach(userView);
// userView.model
var userController = new UserController_1.UserController(userModel, userView);
userController.test();
// userModel.someBusinessMethod(activeUsersMock);
loglevel_1.default.info("hello");
var chatModel = new ChatModel_1.ChatModel();
// @ts-ignore: Argument of type 'HTMLElement | null' is not assignable to parameter of type 'HTMLElement'. Type 'null' is not assignable to type 'HTMLElement'.
var chatView = new ChatView_1.ChatView(chatModel, userBox);
var chatController = new ChatController_1.ChatController(chatModel, chatView);
function someFunc(vm) {
// log.info(vm);
// logger.info(vm)
}
logger.info("test");
// someFunc(activeUserViewModelMock);
// @ts-ignore: Object is possibly 'null'.
var source = document.getElementById("msg_container_template").innerHTML;
var msgContainerTemplate = handlebars_1.default.compile(source);
JsonAPI_1.JsonAPI.ActiveUsersGET;
var encryptionService = new SJCLEncryptionService_1.SJCLEncryptionService();
var ct = encryptionService.encrypt("password", "data");
console.log(encryptionService.decrypt("password", ct));
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"./controller/ChatController":1,"./controller/UserController":2,"./model/ChatModel":5,"./model/UserModel":7,"./service/LogLevelLoggerService":8,"./service/SJCLEncryptionService":9,"./singleton/JsonAPI":10,"./view/ChatView":13,"./view/UserView":14}],4:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
},{}],5:[function(require,module,exports){
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __generator = (this && this.__generator) || function (thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
};
Object.defineProperty(exports, "__esModule", { value: true });
var FetchErrorHandler_1 = require("./FetchErrorHandler");
var ChatModel = /** @class */ (function () {
function ChatModel() {
/**
* @type {Observer[]} List of subscribers. In real life, the list of
* subscribers can be stored more comprehensively (categorized by event
* type, etc.).
*/
this.observers = [];
// @ts-ignore: Cannot find name 'hostAddress'.
this.getActiveUsersUrl = "";
}
/**
* The subscription management methods.
*/
ChatModel.prototype.attach = function (observer) {
console.log('Subject: Attached an observer.');
this.observers.push(observer);
};
ChatModel.prototype.detach = function (observer) {
var observerIndex = this.observers.indexOf(observer);
this.observers.splice(observerIndex, 1);
console.log('Subject: Detached an observer.');
};
/**
* Trigger an update in each subscriber.
*/
ChatModel.prototype.notify = function () {
console.log('Subject: Notifying observers...');
for (var _i = 0, _a = this.observers; _i < _a.length; _i++) {
var observer = _a[_i];
observer.update(this.state);
}
};
ChatModel.prototype.someBusinessMethod = function (activeuserList) {
this.state = activeuserList;
this.helperMethod();
console.log("Subject: My state has just changed");
console.log(activeuserList);
this.notify();
};
/**
* getActiveUsers
*/
ChatModel.prototype.getActiveUsers = function () {
var _this = this;
this.getActiveUsersAjax(":")
.then(function (data) {
// // activeUsers = data;
// sessionStorage.setItem('activeUsers', JSON.stringify(data));
// console.log(sessionStorage.getItem('activeUsers'));
console.log("Subject: received ajax active users");
_this.state = data;
_this.notify();
});
};
ChatModel.prototype.getActiveUsersAjax = function (authToken2) {
return __awaiter(this, void 0, void 0, function () {
var headers, response, data;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
headers = new Headers();
// headers.append('Authorization', basicAuthToken);
headers.append('X-AUTH-TOKEN', authToken2);
return [4 /*yield*/, fetch(this.getActiveUsersUrl, {
method: 'GET',
headers: headers
})];
case 1:
response = _a.sent();
console.log(response.clone());
if (FetchErrorHandler_1.fetchErrorHandler(response.clone())) {
return [2 /*return*/, null];
}
return [4 /*yield*/, response.json()];
case 2:
data = _a.sent();
return [2 /*return*/, data];
}
});
});
};
ChatModel.prototype.helperMethod = function () { };
return ChatModel;
}());
exports.ChatModel = ChatModel;
},{"./FetchErrorHandler":6}],6:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
function fetchErrorHandler(response) {
// alertify.success('Current position : ' + alertify.get('notifier', 'position'));
if (!response.ok) {
return response.text().catch(function (err) {
// the status was not ok and there is no json body
// throw new Error(response.statusText);
// window.alert(sprintf('Some error occured. Http code is %s', response.status));
// alertify.error(sprintf('Some error occured. Http code is %s', response.status));
return true;
}).then(function (json) {
// the status was not ok but there is a json body
// throw new Error(json.error.message); // example error message returned by a REST API
// window.alert(sprintf('Error: %s (Http code %s)', json, response.status));
// alertify.error(sprintf('Some error occured. Http code is %s', response.status));
console.log(json);
return true;
});
}
}
exports.fetchErrorHandler = fetchErrorHandler;
},{}],7:[function(require,module,exports){
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __generator = (this && this.__generator) || function (thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
};
Object.defineProperty(exports, "__esModule", { value: true });
var FetchErrorHandler_1 = require("./FetchErrorHandler");
var UserModel = /** @class */ (function () {
function UserModel() {
/**
* @type {Observer[]} List of subscribers. In real life, the list of
* subscribers can be stored more comprehensively (categorized by event
* type, etc.).
*/
this.observers = [];
// @ts-ignore: Cannot find name 'hostAddress'.
this.getActiveUsersUrl = "";
}
/**
* The subscription management methods.
*/
UserModel.prototype.attach = function (observer) {
console.log('Subject: Attached an observer.');
this.observers.push(observer);
};
UserModel.prototype.detach = function (observer) {
var observerIndex = this.observers.indexOf(observer);
this.observers.splice(observerIndex, 1);
console.log('Subject: Detached an observer.');
};
/**
* Trigger an update in each subscriber.
*/
UserModel.prototype.notify = function () {
console.log('Subject: Notifying observers...');
for (var _i = 0, _a = this.observers; _i < _a.length; _i++) {
var observer = _a[_i];
observer.update(this.state);
}
};
UserModel.prototype.someBusinessMethod = function (activeuserList) {
this.state = activeuserList;
this.helperMethod();
console.log("Subject: My state has just changed");
console.log(activeuserList);
this.notify();
};
/**
* getActiveUsers
*/
UserModel.prototype.getActiveUsers = function () {
var _this = this;
this.getActiveUsersAjax(":")
.then(function (data) {
// // activeUsers = data;
// sessionStorage.setItem('activeUsers', JSON.stringify(data));
// console.log(sessionStorage.getItem('activeUsers'));
console.log("Subject: received ajax active users");
_this.state = data;
_this.notify();
});
};
UserModel.prototype.getActiveUsersAjax = function (authToken2) {
return __awaiter(this, void 0, void 0, function () {
var headers, response, data;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
headers = new Headers();
// headers.append('Authorization', basicAuthToken);
headers.append('X-AUTH-TOKEN', authToken2);
return [4 /*yield*/, fetch(this.getActiveUsersUrl, {
method: 'GET',
headers: headers
})];
case 1:
response = _a.sent();
console.log(response.clone());
if (FetchErrorHandler_1.fetchErrorHandler(response.clone())) {
return [2 /*return*/, null];
}
return [4 /*yield*/, response.json()];
case 2:
data = _a.sent();
return [2 /*return*/, data];
}
});
});
};
UserModel.prototype.helperMethod = function () { };
return UserModel;
}());
exports.UserModel = UserModel;
},{"./FetchErrorHandler":6}],8:[function(require,module,exports){
(function (global){
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
var loglevel_1 = __importDefault((typeof window !== "undefined" ? window['log'] : typeof global !== "undefined" ? global['log'] : null));
var LogLevelLogger = /** @class */ (function () {
function LogLevelLogger() {
loglevel_1.default.setLevel("DEBUG");
}
LogLevelLogger.prototype.info = function (message) {
loglevel_1.default.info(message);
};
LogLevelLogger.prototype.warn = function (message) {
loglevel_1.default.warn(message);
};
LogLevelLogger.prototype.error = function (message) {
loglevel_1.default.error(message);
};
LogLevelLogger.prototype.debug = function (message) {
loglevel_1.default.debug(message);
};
return LogLevelLogger;
}());
exports.LogLevelLogger = LogLevelLogger;
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{}],9:[function(require,module,exports){
(function (global){
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
var sjcl_1 = __importDefault((typeof window !== "undefined" ? window['sjcl'] : typeof global !== "undefined" ? global['sjcl'] : null));
var SJCLEncryptionService = /** @class */ (function () {
function SJCLEncryptionService() {
this.params = { mode: "gcm", ts: 128, adata: "", iter: 10000 };
}
SJCLEncryptionService.prototype.encrypt = function (passphrase, plainText) {
return sjcl_1.default.encrypt(passphrase, plainText, this.params);
};
SJCLEncryptionService.prototype.decrypt = function (passphrase, cipher) {
return sjcl_1.default.decrypt(passphrase, cipher, undefined, undefined);
};
return SJCLEncryptionService;
}());
exports.SJCLEncryptionService = SJCLEncryptionService;
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{}],10:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var JsonAPI;
(function (JsonAPI) {
// @ts-ignore: Cannot find name 'hostAddress'.
JsonAPI.ActiveUsersGET = "/api/chat/get/active-users/";
})(JsonAPI = exports.JsonAPI || (exports.JsonAPI = {}));
},{}],11:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var TemplateFactory = /** @class */ (function () {
function TemplateFactory() {
}
TemplateFactory.getTemplate = function () {
// @ts-ignore: Object is possibly 'null'.
var source = document.getElementById("user-contact-online-template").innerHTML;
var msgContainerTemplate = Handlebars.compile(source);
return msgContainerTemplate;
};
return TemplateFactory;
}());
exports.TemplateFactory = TemplateFactory;
},{}],12:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
},{}],13:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var TemplateFactory_1 = require("../template/TemplateFactory");
var ChatView = /** @class */ (function () {
// private userBoxes: any[] = [];
function ChatView(model, element) {
this._model = model;
this._element = element;
}
Object.defineProperty(ChatView.prototype, "model", {
/**
* Getter model
* @return {Model}
*/
get: function () {
return this._model;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ChatView.prototype, "element", {
/**
* Getter element
* @return {any}
*/
get: function () {
return this._element;
},
enumerable: true,
configurable: true
});
// /**
// * Setter model
// * @param {Model} value
// */
// public set model(value: Model) {
// this._model = value;
// }
// /**
// * Setter element
// * @param {any} value
// */
// public set element(value: any) {
// this._element = value;
// }
ChatView.prototype.update = function (data) {
var template = TemplateFactory_1.TemplateFactory.getTemplate();
var html = "";
data.forEach(function (element) {
html += template(element);
});
this.element.innerHTML = html;
this.addUserCallBacks();
console.log(this.element.innerHTML);
};
ChatView.prototype.helper = function () {
};
ChatView.prototype.addUserCallBacks = function () {
var userBoxes = document.getElementsByClassName('user-box');
for (var i = 0; i < userBoxes.length; i++) {
var userBox = userBoxes[i];
userBoxes[i].addEventListener('click', this.userCallBack.bind(this, userBox));
}
};
ChatView.prototype.userCallBack = function (el) {
var current = document.getElementsByClassName('user-box active');
var passphrase = "";
if (current.length > 0) {
if (passphrase == '') {
// alert('Please input passphrase')
// alertify.error('Please enter a passphrase');
// return;
}
current[0].className = current[0].className.replace(" active", "");
}
// Add the active class to the current/clicked button
else if (current.length == 0) {
var elem_1 = document.getElementById('passphrase-initial');
passphrase = "";
if (passphrase == '') {
// // alert('Please input passphrase')
// // alertify.error('Please enter a passphrase');
// return;
}
// @ts-ignore: Object is possibly 'null'.
document.getElementById('no-user-selected').hidden = true;
// @ts-ignore: Object is possibly 'null'.
document.getElementById('chat-card').hidden = false;
// @ts-ignore: Object is possibly 'null'.
elem_1.hidden = true;
}
// console.log(this.getElementsByClassName('to-user-span'));
var elem = el.getElementsByClassName('to-user-span')[0];
var userName = elem.innerText;
// @ts-ignore: Object is possibly 'null'.
document.getElementById('user-name-span').innerText = userName;
// populateMessages(userName, passphrase);
sessionStorage.setItem('selectedUser', userName);
el.className += " active";
};
return ChatView;
}());
exports.ChatView = ChatView;
},{"../template/TemplateFactory":11}],14:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var TemplateFactory_1 = require("../template/TemplateFactory");
var UserView = /** @class */ (function () {
// private userBoxes: any[] = [];
function UserView(model, element) {
this._model = model;
this._element = element;
}
Object.defineProperty(UserView.prototype, "model", {
/**
* Getter model
* @return {Model}
*/
get: function () {
return this._model;
},
enumerable: true,
configurable: true
});
Object.defineProperty(UserView.prototype, "element", {
/**
* Getter element
* @return {any}
*/
get: function () {
return this._element;
},
enumerable: true,
configurable: true
});
// /**
// * Setter model
// * @param {Model} value
// */
// public set model(value: Model) {
// this._model = value;
// }
// /**
// * Setter element
// * @param {any} value
// */
// public set element(value: any) {
// this._element = value;
// }
UserView.prototype.update = function (data) {
var template = TemplateFactory_1.TemplateFactory.getTemplate();
var html = "";
data.forEach(function (element) {
html += template(element);
});
this.element.innerHTML = html;
this.addUserCallBacks();
console.log(this.element.innerHTML);
};
UserView.prototype.helper = function () {
};
UserView.prototype.addUserCallBacks = function () {
var userBoxes = document.getElementsByClassName('user-box');
for (var i = 0; i < userBoxes.length; i++) {
var userBox = userBoxes[i];
userBoxes[i].addEventListener('click', this.userCallBack.bind(this, userBox));
}
};
UserView.prototype.userCallBack = function (el) {
var current = document.getElementsByClassName('user-box active');
var passphrase = "";
if (current.length > 0) {
if (passphrase == '') {
// alert('Please input passphrase')
// alertify.error('Please enter a passphrase');
// return;
}
current[0].className = current[0].className.replace(" active", "");
}
// Add the active class to the current/clicked button
else if (current.length == 0) {
var elem_1 = document.getElementById('passphrase-initial');
passphrase = "";
if (passphrase == '') {
// // alert('Please input passphrase')
// // alertify.error('Please enter a passphrase');
// return;
}
// @ts-ignore: Object is possibly 'null'.
document.getElementById('no-user-selected').hidden = true;
// @ts-ignore: Object is possibly 'null'.
document.getElementById('chat-card').hidden = false;
// @ts-ignore: Object is possibly 'null'.
elem_1.hidden = true;
}
// console.log(this.getElementsByClassName('to-user-span'));
var elem = el.getElementsByClassName('to-user-span')[0];
var userName = elem.innerText;
// @ts-ignore: Object is possibly 'null'.
document.getElementById('user-name-span').innerText = userName;
// populateMessages(userName, passphrase);
sessionStorage.setItem('selectedUser', userName);
el.className += " active";
};
return UserView;
}());
exports.UserView = UserView;
},{"../template/TemplateFactory":11}],15:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var ActiveUserViewModel = /** @class */ (function () {
function ActiveUserViewModel() {
}
return ActiveUserViewModel;
}());
exports.ActiveUserViewModel = ActiveUserViewModel;
},{}],16:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var ChatMessageViewModel = /** @class */ (function () {
function ChatMessageViewModel() {
}
return ChatMessageViewModel;
}());
exports.ChatMessageViewModel = ChatMessageViewModel;
},{}]},{},[3])
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../../../usr/local/lib/node_modules/watchify/node_modules/browser-pack/_prelude.js","src/controller/ChatController.ts","src/controller/UserController.ts","src/main.ts","src/model/ChatModel.ts","src/model/FetchErrorHandler.ts","src/model/UserModel.ts","src/service/LogLevelLoggerService.ts","src/service/SJCLEncryptionService.ts","src/singleton/JsonAPI.ts","src/template/TemplateFactory.ts","src/view/ChatView.ts","src/view/UserView.ts","src/viewmodel/ActiveUserViewModel.ts","src/viewmodel/ChatMessageViewModel.ts"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","import { Controller } from \"./AbstractController\";\nimport \"../model/AbstractModel\"\nimport \"../model/UserModel\"\nimport \"../view/AbstractView\"\nimport \"../view/UserView\"\nimport { Model } from \"../model/AbstractModel\";\nimport { View } from \"../view/AbstractView\";\nimport { ChatMessageViewModel } from \"../viewmodel/ChatMessageViewModel\";\n\nexport class ChatController implements Controller{\n    private _model: Model;\n    private _view: View;\n\n\n    constructor(model: Model, view: View) {\n        this._model = model;\n        this._view = view;\n    }\n\n    /**\n     * Getter model\n     * @return {Model}\n     */\n    public get model(): Model {\n        return this._model;\n    }\n\n    /**\n     * Getter view\n     * @return {View}\n     */\n    public get view(): View {\n        return this._view;\n    }\n\n    /**\n     * Setter model\n     * @param {Model} value\n     */\n    public set model(value: Model) {\n        this._model = value;\n    }\n\n    /**\n     * Setter view\n     * @param {View} value\n     */\n    public set view(value: View) {\n        this._view = value;\n    }\n\n    /**\n     * eventHandler\n     */\n    public eventHandler(vm: ChatMessageViewModel[]): void {\n        this.model.someBusinessMethod(vm);\n    }\n\n    public test(): void {\n        const chatMessageViewModels: ChatMessageViewModel[] = [];\n        let chatMessageViewModelMock = new ChatMessageViewModel();\n        chatMessageViewModelMock.fromUser = \"user1\";\n        chatMessageViewModelMock.toUser = \"user2\";\n        chatMessageViewModelMock.messageCipher = \"\";\n        chatMessageViewModelMock.messageTime = new Date();\n        chatMessageViewModels.push(chatMessageViewModelMock);\n    }\n\n    \n}","import { Controller } from \"./AbstractController\";\nimport \"../model/AbstractModel\"\nimport \"../model/UserModel\"\nimport \"../view/AbstractView\"\nimport \"../view/UserView\"\nimport { Model } from \"../model/AbstractModel\";\nimport { View } from \"../view/AbstractView\";\nimport { ActiveUserViewModel } from \"../viewmodel/ActiveUserViewModel\";\n\nexport class UserController implements Controller{\n    private _model: Model;\n    private _view: View;\n\n\n    constructor(model: Model, view: View) {\n        this._model = model;\n        this._view = view;\n    }\n\n    /**\n     * Getter model\n     * @return {Model}\n     */\n    public get model(): Model {\n        return this._model;\n    }\n\n    /**\n     * Getter view\n     * @return {View}\n     */\n    public get view(): View {\n        return this._view;\n    }\n\n    /**\n     * Setter model\n     * @param {Model} value\n     */\n    public set model(value: Model) {\n        this._model = value;\n    }\n\n    /**\n     * Setter view\n     * @param {View} value\n     */\n    public set view(value: View) {\n        this._view = value;\n    }\n\n    /**\n     * eventHandler\n     */\n    public eventHandler(vm: ActiveUserViewModel[]): void {\n        this.model.someBusinessMethod(vm);\n    }\n\n    public test(): void {\n        const activeUsersMock: ActiveUserViewModel[] = [];\n        let activeUserViewModelMock = new ActiveUserViewModel();\n        activeUserViewModelMock.userName = \"some user\";\n        activeUserViewModelMock.lastActive = \"3 hrs ago\";\n        activeUserViewModelMock.online = true;\n        activeUsersMock.push(activeUserViewModelMock);\n        activeUserViewModelMock = new ActiveUserViewModel();\n        activeUserViewModelMock.lastActive = \"3 hrs ago\";\n        activeUserViewModelMock.online = true;\n        activeUserViewModelMock.userName = \"some user 2\";\n        activeUsersMock.push(activeUserViewModelMock);\n        this.eventHandler(activeUsersMock);\n    }\n\n    \n}","import { Controller } from \"./controller/AbstractController\";\nimport { UserModel } from \"./model/UserModel\"\nimport { Model } from \"./model/AbstractModel\";\nimport { View } from \"./view/AbstractView\";\nimport { UserView } from \"./view/UserView\";\nimport { UserController } from \"./controller/UserController\";\nimport log from \"loglevel\";\nimport { ModelFactory } from \"./model/ModelFactory\";\nimport { ActiveUserViewModel } from \"./viewmodel/ActiveUserViewModel\";\nimport { ChatMessageViewModel } from \"./viewmodel/ChatMessageViewModel\";\nimport Handlebars from \"handlebars\";\nimport markdownit from \"markdown-it\";\nimport { ChatModel } from \"./model/ChatModel\";\nimport { ChatView } from \"./view/ChatView\";\nimport { ChatController } from \"./controller/ChatController\";\nimport { JsonAPI } from \"./singleton/JsonAPI\";\nimport { SJCLEncryptionService } from \"./service/SJCLEncryptionService\";\nimport { EncryptionService } from \"./service/EncryptionService\";\nimport { Logger } from \"./service/LoggerService\";\nimport { LogLevelLogger } from \"./service/LogLevelLoggerService\";\n// import { logger } from \"./singleton/Logger\";\n// var markdownit = require('markdown-it');\nvar md = new markdownit();\n\nconst logger: Logger = new LogLevelLogger();\n\nlet userBox = document.getElementById('contacts-box');\n\nlog.setLevel(\"TRACE\")\nlet userModel = new UserModel();\n// const userModel = ModelFactory.createModel(\"USER\");\n// @ts-ignore: Argument of type 'HTMLElement | null' is not assignable to parameter of type 'HTMLElement'. Type 'null' is not assignable to type 'HTMLElement'.\nconst userView = new UserView(userModel, userBox);\n\n// console.log(userBox);\n\nuserModel.attach(userView);\n// userView.model\nconst userController = new UserController(userModel, userView);\nuserController.test();\n\n\n\n// userModel.someBusinessMethod(activeUsersMock);\nlog.info(\"hello\");\n\nconst chatModel = new ChatModel();\n// @ts-ignore: Argument of type 'HTMLElement | null' is not assignable to parameter of type 'HTMLElement'. Type 'null' is not assignable to type 'HTMLElement'.\nconst chatView = new ChatView(chatModel, userBox);\nconst chatController = new ChatController(chatModel, chatView);\n\n\nfunction someFunc(vm: ActiveUserViewModel): void {\n    // log.info(vm);\n    // logger.info(vm)\n}\n\nlogger.info(\"test\");\n// someFunc(activeUserViewModelMock);\n\n// @ts-ignore: Object is possibly 'null'.\nvar source = document.getElementById(\"msg_container_template\").innerHTML;\n\nvar msgContainerTemplate = Handlebars.compile(source);\n\nJsonAPI.ActiveUsersGET\n\nlet encryptionService: EncryptionService = new SJCLEncryptionService();\nlet ct = encryptionService.encrypt(\"password\",\"data\");\nconsole.log(encryptionService.decrypt(\"password\", ct));","import { Subject } from \"../observe/Observable\";\nimport { Model } from \"./AbstractModel\";\nimport { Observer } from \"../observe/Observer\";\nimport { fetchErrorHandler } from \"./FetchErrorHandler\";\nimport { ActiveUserViewModel } from \"../viewmodel/ActiveUserViewModel\";\nimport { ChatMessageViewModel } from \"../viewmodel/ChatMessageViewModel\";\n\nexport class ChatModel implements Model, Subject {\n    /**\n  * @type {Observer[]} List of subscribers. In real life, the list of\n  * subscribers can be stored more comprehensively (categorized by event\n  * type, etc.).\n  */\n    private readonly observers: Observer[] = [];\n    private state: ChatMessageViewModel[] | undefined;\n    // @ts-ignore: Cannot find name 'hostAddress'.\n    getActiveUsersUrl = \"\";\n\n    constructor() { }\n    /**\n     * The subscription management methods.\n     */\n    public attach(observer: Observer): void {\n        console.log('Subject: Attached an observer.');\n        this.observers.push(observer);\n    }\n\n    public detach(observer: Observer): void {\n        const observerIndex = this.observers.indexOf(observer);\n        this.observers.splice(observerIndex, 1);\n        console.log('Subject: Detached an observer.');\n    }\n\n    /**\n     * Trigger an update in each subscriber.\n     */\n    public notify(): void {\n        console.log('Subject: Notifying observers...');\n        for (const observer of this.observers) {\n            observer.update(this.state);\n        }\n    }\n\n    public someBusinessMethod(activeuserList: ChatMessageViewModel[]): void {\n        this.state = activeuserList;\n        this.helperMethod();\n        console.log(`Subject: My state has just changed`);\n        console.log(activeuserList);\n        this.notify();\n    }\n\n    /**\n     * getActiveUsers\n     */\n    public getActiveUsers(): void {\n        this.getActiveUsersAjax(\":\")\n        .then(data => {\n            // // activeUsers = data;\n            // sessionStorage.setItem('activeUsers', JSON.stringify(data));\n            // console.log(sessionStorage.getItem('activeUsers'));\n            console.log(`Subject: received ajax active users`);\n            this.state = data;\n            this.notify();\n        })\n    }\n\n    async getActiveUsersAjax(authToken2: string) {\n        let headers = new Headers();\n        // headers.append('Authorization', basicAuthToken);\n        headers.append('X-AUTH-TOKEN', authToken2);\n        let response = await fetch(this.getActiveUsersUrl, {\n            method: 'GET',\n            headers: headers\n        });\n        console.log(response.clone());\n        if (fetchErrorHandler(response.clone())) {\n            return null;\n        }\n        let data = await response.json();\n        return data;\n    }\n    \n    private helperMethod() {}\n\n}","export function fetchErrorHandler(response: Response) {\n    // alertify.success('Current position : ' + alertify.get('notifier', 'position'));\n    if (!response.ok) {\n        return response.text().catch(err => {\n            // the status was not ok and there is no json body\n            // throw new Error(response.statusText);\n            // window.alert(sprintf('Some error occured. Http code is %s', response.status));\n            // alertify.error(sprintf('Some error occured. Http code is %s', response.status));\n            return true;\n        }).then(json => {\n            // the status was not ok but there is a json body\n            // throw new Error(json.error.message); // example error message returned by a REST API\n            // window.alert(sprintf('Error: %s (Http code %s)', json, response.status));\n            // alertify.error(sprintf('Some error occured. Http code is %s', response.status));\n            console.log(json);\n            return true;\n        });\n    }\n}","import { Subject } from \"../observe/Observable\";\nimport { Model } from \"./AbstractModel\";\nimport { Observer } from \"../observe/Observer\";\nimport { fetchErrorHandler } from \"./FetchErrorHandler\";\nimport { ActiveUserViewModel } from \"../viewmodel/ActiveUserViewModel\";\n\nexport class UserModel implements Model, Subject {\n    /**\n  * @type {Observer[]} List of subscribers. In real life, the list of\n  * subscribers can be stored more comprehensively (categorized by event\n  * type, etc.).\n  */\n    private readonly observers: Observer[] = [];\n    private state: ActiveUserViewModel[] | undefined;\n    // @ts-ignore: Cannot find name 'hostAddress'.\n    getActiveUsersUrl = ``;\n\n    constructor() { }\n    /**\n     * The subscription management methods.\n     */\n    public attach(observer: Observer): void {\n        console.log('Subject: Attached an observer.');\n        this.observers.push(observer);\n    }\n\n    public detach(observer: Observer): void {\n        const observerIndex = this.observers.indexOf(observer);\n        this.observers.splice(observerIndex, 1);\n        console.log('Subject: Detached an observer.');\n    }\n\n    /**\n     * Trigger an update in each subscriber.\n     */\n    public notify(): void {\n        console.log('Subject: Notifying observers...');\n        for (const observer of this.observers) {\n            observer.update(this.state);\n        }\n    }\n\n    public someBusinessMethod(activeuserList: ActiveUserViewModel[]): void {\n        this.state = activeuserList;\n        this.helperMethod();\n        console.log(`Subject: My state has just changed`);\n        console.log(activeuserList);\n        this.notify();\n    }\n\n    /**\n     * getActiveUsers\n     */\n    public getActiveUsers(): void {\n        this.getActiveUsersAjax(\":\")\n        .then(data => {\n            // // activeUsers = data;\n            // sessionStorage.setItem('activeUsers', JSON.stringify(data));\n            // console.log(sessionStorage.getItem('activeUsers'));\n            console.log(`Subject: received ajax active users`);\n            this.state = data;\n            this.notify();\n        })\n    }\n\n    async getActiveUsersAjax(authToken2: string) {\n        let headers = new Headers();\n        // headers.append('Authorization', basicAuthToken);\n        headers.append('X-AUTH-TOKEN', authToken2);\n        let response = await fetch(this.getActiveUsersUrl, {\n            method: 'GET',\n            headers: headers\n        });\n        console.log(response.clone());\n        if (fetchErrorHandler(response.clone())) {\n            return null;\n        }\n        let data = await response.json();\n        return data;\n    }\n    \n    private helperMethod() {}\n\n}","import { Logger } from \"./LoggerService\";\nimport log from \"loglevel\"\n\nexport class LogLevelLogger implements Logger{\n    constructor() {\n        log.setLevel(\"DEBUG\");\n    }\n    info(message: any): void {\n        log.info(message)\n    }\n    warn(message: any)\n    {\n        log.warn(message)\n    }\n    error(message: any)\n    {\n        log.error(message)\n    }\n    debug(message: any)\n    {\n        log.debug(message)\n    }\n}","import { EncryptionService } from \"./EncryptionService\";\nimport sjcl from \"sjcl\";\n\nexport class SJCLEncryptionService implements EncryptionService {\n    public params: any = { mode: \"gcm\", ts: 128, adata: \"\", iter: 10000}\n    public encrypt(passphrase: string, plainText: string): Object {\n        return sjcl.encrypt(passphrase, plainText, this.params);\n    } \n    \n    public decrypt(passphrase: string, cipher: Object): Object {\n        return sjcl.decrypt(passphrase, cipher as sjcl.SjclCipherEncrypted, undefined, undefined);\n    }\n}","export namespace JsonAPI {\n    // @ts-ignore: Cannot find name 'hostAddress'.\n    export const ActiveUsersGET = `/api/chat/get/active-users/`;\n    \n}","export class TemplateFactory {\n    static getTemplate(): Handlebars.TemplateDelegate<any> {\n        // @ts-ignore: Object is possibly 'null'.\n        var source = document.getElementById(\"user-contact-online-template\").innerHTML; \n        var msgContainerTemplate = Handlebars.compile(source);\n        return msgContainerTemplate;\n    }\n}","import { Observer } from \"../observe/Observer\";\nimport { Model } from \"../model/AbstractModel\";\nimport { Subject } from \"../observe/Observable\";\nimport { View } from \"./AbstractView\";\nimport { Controller } from \"../controller/AbstractController\";\nimport { TemplateFactory } from \"../template/TemplateFactory\";\nimport { ActiveUserViewModel } from \"../viewmodel/ActiveUserViewModel\";\n\nexport class ChatView implements Observer, View {\n    private readonly _model: Model;\n    private readonly _element: HTMLElement;\n    // private userBoxes: any[] =  [];\n\n\n    constructor(model: Model, element: HTMLElement) {\n        this._model = model;\n        this._element = element;\n    }\n\n\n\n    /**\n     * Getter model\n     * @return {Model}\n     */\n    public get model(): Model {\n        return this._model;\n    }\n\n\n    /**\n     * Getter element\n     * @return {any}\n     */\n    public get element(): HTMLElement {\n        return this._element;\n    }\n\n    // /**\n    //  * Setter model\n    //  * @param {Model} value\n    //  */\n    // public set model(value: Model) {\n    //     this._model = value;\n    // }\n\n\n    // /**\n    //  * Setter element\n    //  * @param {any} value\n    //  */\n    // public set element(value: any) {\n    //     this._element = value;\n    // }\n\n\n\n\n\n    update(data: ActiveUserViewModel[]): void {\n        let template = TemplateFactory.getTemplate();\n        let html: string = \"\";\n        data.forEach((element: ActiveUserViewModel) => {\n            html += template(element);\n        });\n        this.element.innerHTML = html;\n        this.addUserCallBacks();\n        console.log(this.element.innerHTML);\n    }\n\n    private helper(): void {\n        \n    }\n\n    private addUserCallBacks(): void {\n        let userBoxes = document.getElementsByClassName('user-box');\n        for (let i = 0; i < userBoxes.length; i++) {\n            let userBox = userBoxes[i];\n            userBoxes[i].addEventListener('click', this.userCallBack.bind(this, userBox));\n        }\n    }\n    \n\n    private userCallBack(el: Element): void {\n        let current = document.getElementsByClassName('user-box active');\n        let passphrase = \"\"\n        if (current.length > 0) {\n            if (passphrase == '') {\n                // alert('Please input passphrase')\n                // alertify.error('Please enter a passphrase');\n                // return;\n            }\n            current[0].className = current[0].className.replace(\" active\", \"\");\n    \n        }\n        // Add the active class to the current/clicked button\n        else if (current.length == 0) {\n            let elem = document.getElementById('passphrase-initial');\n            passphrase = \"\";\n            if (passphrase == '') {\n            //     // alert('Please input passphrase')\n            //     // alertify.error('Please enter a passphrase');\n            //     return;\n            }\n            // @ts-ignore: Object is possibly 'null'.\n            document.getElementById('no-user-selected').hidden = true;\n            // @ts-ignore: Object is possibly 'null'.\n            document.getElementById('chat-card').hidden = false;\n            // @ts-ignore: Object is possibly 'null'.\n            elem.hidden = true;\n        }\n        // console.log(this.getElementsByClassName('to-user-span'));\n        let elem = el.getElementsByClassName('to-user-span')[0] as HTMLElement;\n        let userName = elem.innerText;\n        // @ts-ignore: Object is possibly 'null'.\n        document.getElementById('user-name-span').innerText = userName;\n        // populateMessages(userName, passphrase);\n        sessionStorage.setItem('selectedUser', userName);\n        el.className += \" active\";\n    }\n\n}","import { Observer } from \"../observe/Observer\";\nimport { Model } from \"../model/AbstractModel\";\nimport { Subject } from \"../observe/Observable\";\nimport { View } from \"./AbstractView\";\nimport { Controller } from \"../controller/AbstractController\";\nimport { TemplateFactory } from \"../template/TemplateFactory\";\nimport { ActiveUserViewModel } from \"../viewmodel/ActiveUserViewModel\";\n\nexport class UserView implements Observer, View {\n    private readonly _model: Model;\n    private readonly _element: HTMLElement;\n    // private userBoxes: any[] =  [];\n\n\n    constructor(model: Model, element: HTMLElement) {\n        this._model = model;\n        this._element = element;\n    }\n\n\n\n    /**\n     * Getter model\n     * @return {Model}\n     */\n    public get model(): Model {\n        return this._model;\n    }\n\n\n    /**\n     * Getter element\n     * @return {any}\n     */\n    public get element(): HTMLElement {\n        return this._element;\n    }\n\n    // /**\n    //  * Setter model\n    //  * @param {Model} value\n    //  */\n    // public set model(value: Model) {\n    //     this._model = value;\n    // }\n\n\n    // /**\n    //  * Setter element\n    //  * @param {any} value\n    //  */\n    // public set element(value: any) {\n    //     this._element = value;\n    // }\n\n\n\n\n\n    update(data: ActiveUserViewModel[]): void {\n        let template = TemplateFactory.getTemplate();\n        let html: string = \"\";\n        data.forEach((element: ActiveUserViewModel) => {\n            html += template(element);\n        });\n        this.element.innerHTML = html;\n        this.addUserCallBacks();\n        console.log(this.element.innerHTML);\n    }\n\n    private helper(): void {\n        \n    }\n\n    private addUserCallBacks(): void {\n        let userBoxes = document.getElementsByClassName('user-box');\n        for (let i = 0; i < userBoxes.length; i++) {\n            let userBox = userBoxes[i];\n            userBoxes[i].addEventListener('click', this.userCallBack.bind(this, userBox));\n        }\n    }\n    \n\n    private userCallBack(el: Element): void {\n        let current = document.getElementsByClassName('user-box active');\n        let passphrase = \"\"\n        if (current.length > 0) {\n            if (passphrase == '') {\n                // alert('Please input passphrase')\n                // alertify.error('Please enter a passphrase');\n                // return;\n            }\n            current[0].className = current[0].className.replace(\" active\", \"\");\n    \n        }\n        // Add the active class to the current/clicked button\n        else if (current.length == 0) {\n            let elem = document.getElementById('passphrase-initial');\n            passphrase = \"\";\n            if (passphrase == '') {\n            //     // alert('Please input passphrase')\n            //     // alertify.error('Please enter a passphrase');\n            //     return;\n            }\n            // @ts-ignore: Object is possibly 'null'.\n            document.getElementById('no-user-selected').hidden = true;\n            // @ts-ignore: Object is possibly 'null'.\n            document.getElementById('chat-card').hidden = false;\n            // @ts-ignore: Object is possibly 'null'.\n            elem.hidden = true;\n        }\n        // console.log(this.getElementsByClassName('to-user-span'));\n        let elem = el.getElementsByClassName('to-user-span')[0] as HTMLElement;\n        let userName = elem.innerText;\n        // @ts-ignore: Object is possibly 'null'.\n        document.getElementById('user-name-span').innerText = userName;\n        // populateMessages(userName, passphrase);\n        sessionStorage.setItem('selectedUser', userName);\n        el.className += \" active\";\n    }\n\n}","export class ActiveUserViewModel {\n    userName: string | undefined;\n    online: boolean | undefined;\n    lastActive: string| undefined;\n}","export class ChatMessageViewModel {\n    public toUser: string | undefined;\n    public fromUser: string | undefined;\n    public messageCipher: any;\n    public messageTime!: Date;\n\n    \n}"]}