aboutsummaryrefslogtreecommitdiffstats
path: root/lib/logger.js
blob: 6bd8142056f59eeabff708ae304adf32632a5286 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// Released under the MIT/X11 license
// http://www.opensource.org/licenses/mit-license.php
"use strict";
var urlMod = require("url");
var urilMod = require("util");

var Logger = exports.Logger = function Logger(store, abbsMap) {
    this.EmptyLogsColor = new Color(0, 255, 0);
    this.FullLogsColor = new Color(0, 40, 103);

    this.store = store;
    this.abbsMap = abbsMap;
};

Logger.prototype.addLogRecord = function(that) {
    let rec = {};
    rec.date = new Date();
    rec.url = that.doc.location.toString();
    rec.title = that.title;
    let comment = jetpack.tabs.focused.contentWindow.prompt(
            "Enter comments for this comment");
    if (comment && comment.length > 0) {
        comment = comment.trim();
        rec.comment = comment;
        let recKey = utilMod.getISODate(rec.date) + "+"
            + urlMod.parse(rec.url).host
            + "+" + that.bugNo;
        let clearLogAElem = that.doc.getElementById("clearLogs");
        clearLogAElem.style.color = this.FullLogsColor;
        clearLogAElem.style.fontWeight = "bolder";
        if (this.store[recKey]) {
            this.store[recKey].comment += "<br/>\n" + comment;
        } else {
            this.store[recKey] = rec;
        }
        jetpack.storage.simple.sync();
        return rec;
    } else {
        return comment;
    }
};

Logger.prototype.getBugzillaAbbr = function(url) {
    // for https://bugzilla.redhat.com/show_bug.cgi?id=579123 get RH
    // for https://bugzilla.mozilla.org/show_bug.cgi?id=579123 get MoFo
    var abbr = this.abbsMap[urlMod.parse(url).host];
    return abbr;
}

Logger.prototype.timeSheetRecordsPrinter = function(body, records) {
    let that = this;
    let commentBugRE = new RegExp("[bB]ug\\s+([0-9]+)","g");
    // sort the records into temporary array
    let tmpArr = [];

    for ( let i in records) {
        if (records.hasOwnProperty(i)) {
            tmpArr.push( [ i, records[i] ]);
        }
    }
    tmpArr.sort(function(a, b) {
        return a[0] > b[0] ? 1 : -1;
    });

    let currentDay = "";
    // now print the array
    tmpArr.forEach(function(rec) {
                let x = rec[1];
                let dayStr = utilMod.getISODate(x.date);
                let host = urlMod.parse(x.url).host;
                let BZName = that.getBugzillaAbbr(x.url);
                let bugNo = utilMod.getBugNo(x.url);
                if (dayStr != currentDay) {
                    currentDay = dayStr;
                    body.innerHTML += "<hr/><p><strong>" + currentDay
                            + "</strong></p>";
                }
                // replace "bug ####" with a hyperlink to the current bugzilla
                let comment = x.comment.replace(commentBugRE,
                    "<a href='http://"+host+"/show_bug.cgi?id=$1'>$&</a>");
                body.innerHTML += "<p><em><a href='"
                        + x.url
                        + "'>Bug "
                        + BZName + "/" + bugNo + ": "
                        + x.title
                        + "</a>"
                        + " </em>\n<br/>" + comment + "</p>";
            });
};

/**
 * 
 */
Logger.prototype.createBlankPage = function (ttl, bodyBuildCB) {
    let title = ttl || "Yet another untitled page";
    let that = this;

    let logTab = jetpack.tabs.open("about:blank");
    jetpack.tabs.onReady(function() {
        let otherDoc = logTab.contentDocument;
        otherDoc.title = title;
        otherDoc.body.innerHTML = "<h1>" + title + "</h1>";
        bodyBuildCB.call(that, otherDoc.body);
        logTab.focus();
    });
};

Logger.prototype.generateTimeSheet = function(body) {
    let doc = body.ownerDocument;
    this.timeSheetRecordsPrinter(body, this.store);
};