summaryrefslogtreecommitdiff
path: root/devtools/client/webide/content/logs.js
blob: 157d83b676986da04b954e7b6c6df4b113294300 (plain)
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
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

var Cu = Components.utils;
const {require} = Cu.import("resource://devtools/shared/Loader.jsm", {});
const {AppManager} = require("devtools/client/webide/modules/app-manager");

window.addEventListener("load", function onLoad() {
  window.removeEventListener("load", onLoad);

  Logs.init();
});

window.addEventListener("unload", function onUnload() {
  window.removeEventListener("unload", onUnload);

  Logs.uninit();
});

const Logs = {
  init: function () {
    this.list = document.getElementById("logs");

    Logs.onAppManagerUpdate = Logs.onAppManagerUpdate.bind(this);
    AppManager.on("app-manager-update", Logs.onAppManagerUpdate);

    document.getElementById("close").onclick = Logs.close.bind(this);
  },

  uninit: function () {
    AppManager.off("app-manager-update", Logs.onAppManagerUpdate);
  },

  onAppManagerUpdate: function (event, what, details) {
    switch (what) {
      case "pre-package":
        this.prePackageLog(details);
        break;
    }
  },

  close: function () {
    window.parent.UI.openProject();
  },

  prePackageLog: function (msg, details) {
    if (msg == "start") {
      this.clear();
    } else if (msg == "succeed") {
      setTimeout(function () {
        Logs.close();
      }, 1000);
    } else if (msg == "failed") {
      this.log(details);
    } else {
      this.log(msg);
    }
  },

  clear: function () {
    this.list.innerHTML = "";
  },

  log: function (msg) {
    let line = document.createElement("li");
    line.textContent = msg;
    this.list.appendChild(line);
  }
};