/**
* @module bot-logger
*/
import {isObject, isFunction} from "./bot-utils.js";
/**
* @description A Logger with colored output.
* @extends console.Console
* @example
* new BotLogger(opts)
*/
class BotLogger extends console.Console {
/**
* @param {Object} [opts] Optional arguments for `console.Console`.
* @param {Boolean} [opts.debug=false] Enable debug output.
* @param {Boolean} [opts.color=true] Enable colored output.
* @param {Object} [opts.stdout=process.stdout]
* @param {Object} [opts.stderr=process.stderr]
* @return {BotLogger}
*/
constructor(opts = {}) {
// Keep compatibility.
if (!isObject(opts)) {
opts = {"debug": opts};
}
super(
opts["stdout"] || process.stdout,
opts["stderr"] || process.stderr
);
this.opts = {};
this.opts["stdout"] = opts["stdout"] || process.stdout;
this.opts["stderr"] = opts["stderr"] || process.stderr;
this.opts["debug"] = opts["debug"] || false;
this.opts["color"] = opts["color"] == null ? true : opts["color"];
// Disable colored output if piped.
if (!this.opts["stdout"].isTTY || !this.opts["stderr"].isTTY) {
this.opts["color"] = false;
}
}
/**
* @param {String} str
* @return {String}
*/
blue(str) {
if (this.opts["color"]) {
return `\x1b[34m${str}\x1b[0m`;
}
return str;
}
/**
* @param {String} str
* @return {String}
*/
green(str) {
if (this.opts["color"]) {
return `\x1b[32m${str}\x1b[0m`;
}
return str;
}
/**
* @param {String} str
* @return {String}
*/
yellow(str) {
if (this.opts["color"]) {
return `\x1b[33m${str}\x1b[0m`;
}
return str;
}
/**
* @param {String} str
* @return {String}
*/
red(str) {
if (this.opts["color"]) {
return `\x1b[31m${str}\x1b[0m`;
}
return str;
}
/**
* @param {String} str
* @return {String}
*/
cyan(str) {
if (this.opts["color"]) {
return `\x1b[36m${str}\x1b[0m`;
}
return str;
}
/**
* @param {...*} strs
*/
log(...strs) {
return super.log("LOG:", ...strs);
}
/**
* @param {...*} strs
*/
info(...strs) {
return super.info(`${this.blue("INFO")}:`, ...strs);
}
/**
* @param {...*} strs
*/
debug(...strs) {
if (this.opts["debug"]) {
// Node.js 8 does not support `console.debug`.
if (isFunction(super.debug)) {
return super.debug(`${this.green("DEBUG")}:`, ...strs);
}
return super.log(`${this.green("DEBUG")}:`, ...strs);
}
}
/**
* @param {...*} strs
*/
warn(...strs) {
return super.warn(`${this.yellow("WARN")}:`, ...strs);
}
/**
* @param {...*} strs
*/
error(...strs) {
return super.error(`${this.red("ERROR")}:`, ...strs);
}
}
export default BotLogger;