mirror of
https://github.com/Karaka-Management/jsOMS.git
synced 2026-01-11 09:58:39 +00:00
127 lines
3.7 KiB
JavaScript
127 lines
3.7 KiB
JavaScript
/**
|
|
* Logger class.
|
|
*
|
|
* @author OMS Development Team <dev@oms.com>
|
|
* @author Dennis Eichhorn <d.eichhorn@oms.com>
|
|
* @copyright 2013 Dennis Eichhorn
|
|
* @license OMS License 1.0
|
|
* @version 1.0.0 * @since 1.0.0
|
|
*/
|
|
(function (jsOMS, undefined)
|
|
{
|
|
"use strict";
|
|
|
|
jsOMS.Logger.layout = '{datetime}; {level}; {version}; {os}; {browser}; {path}; {message}';
|
|
|
|
/**
|
|
* @constructor
|
|
*
|
|
* @since 1.0.0
|
|
* @author Dennis Eichhorn <d.eichhorn@oms.com>
|
|
*/
|
|
jsOMS.Logger = function (verbose, ui, remote)
|
|
{
|
|
this.verbose = typeof verbose !== 'undefined' ? verbose : true;
|
|
this.ui = typeof ui !== 'undefined' ? ui : true;
|
|
this.remote = typeof remote !== 'undefined' ? remote : false;
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.interpolate = function(message, context, level)
|
|
{
|
|
let newMessage = jsOMS.Logger.layout;
|
|
|
|
for(replace in context) {
|
|
newMessage = newMessage.replace('{'+replace+'}', context[replace]);
|
|
}
|
|
|
|
return newMessage;
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.createContext = function(message, context, level)
|
|
{
|
|
context['datetime'] = (new Date()).toISOString();
|
|
context['version'] = '1.0.0';
|
|
context['os'] = jsOMS.Request.getOS();
|
|
context['browser'] = jsOMS.Request.getBrowser();
|
|
context['path'] = window.location.href;
|
|
context['level'] = level;
|
|
context['message'] = message;
|
|
|
|
return context;
|
|
}
|
|
|
|
jsOMS.FormManager.prototype.write = function(message, context, level)
|
|
{
|
|
context = this.createContext(message, context, level);
|
|
|
|
if(this.verbose) {
|
|
console.log(this.interpolate(message, context, level)));
|
|
}
|
|
|
|
if(this.ui) {
|
|
// todo: fill log box, set class and initiate animation
|
|
}
|
|
|
|
if(this.remote) {
|
|
let request = new jsOMS.Request(),
|
|
request.setData(context);
|
|
request.setType(jsOMS.EnumResponseType.JSON);
|
|
request.setUri('/{/lang}/api/log');
|
|
request.setMethod(jsOMS.EnumRequestMethod.POST);
|
|
request.setRequestHeader('Content-Type', 'application/json');
|
|
request.setSuccess(function (xhr) {});
|
|
request.send();
|
|
}
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.emergency = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.EMERGENCY)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.alert = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.ALERT)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.critical = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.CRITICAL)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.error = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.ERROR)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.warning = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.WARNING)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.notice = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.NOTICE)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.info = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.INFO)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.debug = function(message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.DEBUG)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.log = function(level, message, context)
|
|
{
|
|
this.write(message, context, context)
|
|
};
|
|
|
|
jsOMS.FormManager.prototype.console = function(level, message, context)
|
|
{
|
|
this.write(message, context, jsOMS.EnumLogLevel.INFO)
|
|
};
|
|
}(window.jsOMS = window.jsOMS || {}));
|