log_tracer.js 1.1 KB
Newer Older
1
function LogTracer(module) {
J
Jason Park 已提交
2 3 4 5 6
    if (Tracer.call(this, module || LogTracer)) {
        LogTracer.prototype.init.call(this);
        return true;
    }
    return false;
7 8 9 10
}

LogTracer.prototype = $.extend(true, Object.create(Tracer.prototype), {
    constructor: LogTracer,
J
Jason Park 已提交
11 12 13 14
    init: function () {
        this.$wrapper = this.capsule.$wrapper = $('<div class="wrapper">');
        this.$container.append(this.$wrapper);
    },
15 16 17 18 19 20 21 22 23 24 25 26 27
    _print: function (msg, delay) {
        tm.pushStep(this.capsule, {type: 'print', msg: msg}, delay);
    },
    processStep: function (step, options) {
        switch (step.type) {
            case 'print':
                this.printTrace(step.msg);
                break;
        }
    },
    refresh: function () {
        this.scrollToEnd(Math.min(50, this.interval));
    },
J
Jason Park 已提交
28 29 30 31 32
    clear: function () {
        Tracer.prototype.clear.call(this);

        this.$wrapper.empty();
    },
33
    printTrace: function (message) {
J
Jason Park 已提交
34
        this.$wrapper.append($('<span>').append(message + '<br/>'));
35 36
    },
    scrollToEnd: function (duration) {
J
Jason Park 已提交
37
        this.$container.animate({scrollTop: this.$container[0].scrollHeight}, duration);
38 39
    }
});