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.
 
 
 
 
 
 

237 lines
21 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 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
});
return UserController;
}());
exports.UserController = UserController;
},{"../model/AbstractModel":3,"../model/UserModel":5,"../view/AbstractView":6,"../view/UserView":7}],2:[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 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 ModelFactory_1 = require("./model/ModelFactory");
var ActiveUserViewModel_1 = require("./viewmodel/ActiveUserViewModel");
var ChatMessageViewModel_1 = require("./viewmodel/ChatMessageViewModel");
var handlebars_1 = __importDefault((typeof window !== "undefined" ? window['Handlebars'] : typeof global !== "undefined" ? global['Handlebars'] : null));
loglevel_1.default.setLevel("TRACE");
// let userModel = new UserModel();
var userModel = ModelFactory_1.ModelFactory.createModel("USER");
var userView = new UserView_1.UserView(userModel, 2);
userModel.attach(userView);
// userView.model
var userController = new UserController_1.UserController(userModel, userView);
userModel.someBusinessMethod(5);
loglevel_1.default.info("hello");
var chatMessageViewModel = new ChatMessageViewModel_1.ChatMessageViewModel();
var activeUserViewModel = new ActiveUserViewModel_1.ActiveUserViewModel();
activeUserViewModel.userName = "some user";
activeUserViewModel.lastActive = new Date();
activeUserViewModel.online = true;
function someFunc(vm) {
loglevel_1.default.info(vm);
}
someFunc(activeUserViewModel);
// @ts-ignore: Object is possibly 'null'.
var source = document.getElementById("msg_container_template").innerHTML;
var msgContainerTemplate = handlebars_1.default.compile(source);
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"./controller/UserController":1,"./model/ModelFactory":4,"./view/UserView":7,"./viewmodel/ActiveUserViewModel":8,"./viewmodel/ChatMessageViewModel":9}],3:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
},{}],4:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var UserModel_1 = require("./UserModel");
var ModelFactory = /** @class */ (function () {
function ModelFactory() {
}
ModelFactory.createModel = function (modelName) {
switch (modelName) {
case "USER":
return new UserModel_1.UserModel();
break;
default: throw new Error("Invalid model name");
}
};
return ModelFactory;
}());
exports.ModelFactory = ModelFactory;
},{"./UserModel":5}],5:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
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 = [];
this.state = 0;
}
/**
* 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 (num) {
this.state = num;
this.helperMethod();
console.log("Subject: My state has just changed to: " + this.state);
this.notify();
};
UserModel.prototype.helperMethod = function () { };
return UserModel;
}());
exports.UserModel = UserModel;
},{}],6:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
},{}],7:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var UserView = /** @class */ (function () {
function UserView(model, element) {
this._model = model;
this._element = element;
}
Object.defineProperty(UserView.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(UserView.prototype, "element", {
/**
* Getter element
* @return {any}
*/
get: function () {
return this._element;
},
/**
* Setter element
* @param {any} value
*/
set: function (value) {
this._element = value;
},
enumerable: true,
configurable: true
});
UserView.prototype.update = function (data) {
this.element = data;
console.log(this.element);
};
return UserView;
}());
exports.UserView = UserView;
},{}],8:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var ActiveUserViewModel = /** @class */ (function () {
function ActiveUserViewModel() {
}
return ActiveUserViewModel;
}());
exports.ActiveUserViewModel = ActiveUserViewModel;
},{}],9:[function(require,module,exports){
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var ChatMessageViewModel = /** @class */ (function () {
function ChatMessageViewModel() {
}
return ChatMessageViewModel;
}());
exports.ChatMessageViewModel = ChatMessageViewModel;
},{}]},{},[2])
//# 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/UserController.ts","src/main.ts","src/model/ModelFactory.ts","src/model/UserModel.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\";\n\nexport class UserController implements Controller{\n        private _model: Model;\n        private _view: View;\n\n\n\tconstructor(model: Model, view: View) {\n\t\tthis._model = model;\n\t\tthis._view = view;\n\t}\n\n    /**\n     * Getter model\n     * @return {Model}\n     */\n\tpublic get model(): Model {\n\t\treturn this._model;\n\t}\n\n    /**\n     * Getter view\n     * @return {View}\n     */\n\tpublic get view(): View {\n\t\treturn this._view;\n\t}\n\n    /**\n     * Setter model\n     * @param {Model} value\n     */\n\tpublic set model(value: Model) {\n\t\tthis._model = value;\n\t}\n\n    /**\n     * Setter view\n     * @param {View} value\n     */\n\tpublic set view(value: View) {\n\t\tthis._view = value;\n\t}\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\";\n\n\nlog.setLevel(\"TRACE\")\n// let userModel = new UserModel();\nconst userModel = ModelFactory.createModel(\"USER\");\n\nconst userView = new UserView(userModel, 2);\nuserModel.attach(userView);\n// userView.model\nconst userController = new UserController(userModel, userView);\nuserModel.someBusinessMethod(5);\nlog.info(\"hello\");\n\nconst chatMessageViewModel= new ChatMessageViewModel();\n\nconst activeUserViewModel = new ActiveUserViewModel();\nactiveUserViewModel.userName = \"some user\";\nactiveUserViewModel.lastActive = new Date();\nactiveUserViewModel.online = true;\n\nfunction someFunc(vm: ActiveUserViewModel): void {\n    log.info(vm);\n}\n\nsomeFunc(activeUserViewModel);\n\n// @ts-ignore: Object is possibly 'null'.\nvar source = document.getElementById(\"msg_container_template\").innerHTML; \n\nvar msgContainerTemplate = Handlebars.compile(source);","import { Model } from \"./AbstractModel\";\nimport { UserModel } from \"./UserModel\";\n\nexport class ModelFactory {\n    static createModel(modelName: string): Model {\n        switch (modelName) {\n            case \"USER\": return new UserModel();\n            break;\n            default: throw new Error(\"Invalid model name\");\n        }\n    }\n}","import { Subject } from \"../observe/Observable\";\nimport { Model } from \"./AbstractModel\";\nimport { Observer } from \"../observe/Observer\";\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 observers: Observer[] = [];\n    private state: number = 0;\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(num: number): void {\n        this.state = num;\n        this.helperMethod();\n        console.log(`Subject: My state has just changed to: ${this.state}`);\n        this.notify();\n    }\n\n    private helperMethod() {}\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\";\n\nexport class UserView implements Observer, View {\n    private _model: Model;\n    private _element: any;\n\n\n\n    constructor(model: Model, element: any) {\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(): any {\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: any): void {\n        this.element = data;\n        console.log(this.element);\n    }\n\n}","export class ActiveUserViewModel {\n    userName: string | undefined;\n    online: boolean | undefined;\n    lastActive: Date | 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}"]}