Skip to content

TypeScript port of log4javascript with customization and decoupling of heavy parts, and TypeScript interface based for easy customization.

License

Notifications You must be signed in to change notification settings

TeamworkGuy2/ts-simplog

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TypeScript Simple Log

Based on log4javascript@1.4.13 Sometimes you just want to log something, you want a simple static logging object with methods like log(), error(), and debug() and you want to customize how those messages are logged later. You want to write your own AJAX, HTML, or localStorage output formatter for your logging. And you want the library to be small and easy to customize.

I can't guarantee this will fit everyone's needs, but take a look at the API and example and decide for yourself.

import Level = require(".../path-to/ts-simplog/log4ts/Level");
import Log4TsRoot = require(".../path-to/ts-simplog/log4ts/Log4TsRoot");
import BrowserConsoleAppender = require(".../path-to/ts-simplog/appender/BrowserConsoleAppender");
import LocalStoreAppender = require(".../path-to/ts-simplog/appender/LocalStoreAppender");
// from dependency https://github.com/TeamworkGuy2/ts-local-storage-manager
import LocalStorageStore = require("ts-local-storage-manager/local-store/LocalStorageStore");
import LocalStoreByTimestamp = require("ts-local-storage-manager/local-store/LocalStoreByTimestamp");

function createLogger(name: string, console: Console) {
    // local storage wrapper for LocalStoreAppender
    var localStoreInst = LocalStoreByTimestamp.newTimestampInst(
            LocalStorageStore.newTimestampInst(window.localStorage));

    var logOptions: Log4Ts.LoggerOptions = {
        logOriginalLoggerName: false,
        logOutputLoggerName: false,
    };
    var log = Log4TsRoot.defaultInst.getLogger(name, logOptions);

    // add appenders to process logged messages, without appenders a logger does nothing
    log.addAppender(new BrowserConsoleAppender(console, null/*name*/, { doLogName: false }));
    log.addAppender(new LocalStoreAppender(localStoreInst, null/*name*/, true, { doLogName: false }));
    return log;
}

var logger = createLogger("my-app", window.console);
try {
    logger.info("Houston, we have logging!");

    logger.log(Level.DEBUG, "Any level you want");
} catch(err) {
    logger.error("operation failed", err);
}

About

TypeScript port of log4javascript with customization and decoupling of heavy parts, and TypeScript interface based for easy customization.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published