summaryrefslogtreecommitdiff
path: root/js/guix-web.js
blob: 019d64a7e24641074b7f251cd628e3168cb52326 (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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
var guix = {};

guix.Packages = function() {
  return m.request({ method: "GET", url: "packages.json" });
};

guix.controller = function() {
  this.packages = guix.Packages();
  this.visiblePackages = m.prop([]);
  this.searchTerm = m.prop("");

  // All packages are visible initially
  this.packages.then(this.visiblePackages);

  this.doSearch = function() {
    var regexp = new RegExp(this.searchTerm());

    this.visiblePackages(this.packages().filter(function(package) {
      return regexp.test(package.name);
    }));
  };
};

guix.view = function(ctrl) {
  function renderHomepage(package) {
    if(package.homepage) {
      return m("a", { href: package.homepage }, package.homepage);
    } else {
      return "";
    }
  }

  function renderLicense(package) {
    function licenseLink(license) {
      return m("a", { href: license.uri }, license.name);
    }

    if(_.isArray(package.license)) {
      return m("ul.list-inline", package.license.map(function(license) {
        return m("li", licenseLink(license));
      }));
    } else if(package.license) {
      return licenseLink(package.license);
    } else {
      return "";
    }
  }

  return [
    m("h1", "GNU Guix"),
    m("h2", [
      "Packages",
      m("span.badge", ctrl.packages().length)
    ]),
    m("div", [
      m("label", "Search"),
      m("input", {
        type: "text",
        placeholder: 'gui.*',
        onchange: m.withAttr("value", function(value) {
          ctrl.searchTerm(value);
          ctrl.doSearch();
        }),
        value: ctrl.searchTerm()
      })
    ]),
    m("table.table", [
      m("thead", [
        m("tr", [
          ["Name",
           "Version",
           "Synopsis",
           "Home Page",
           "License"].map(function(header) {
             return m("th", header);
           })
        ])
      ]),
      m("tbody", [
        ctrl.visiblePackages().map(function(package) {
          return m("tr", [
            m("td", package.name),
            m("td", package.version),
            m("td", package.synopsis),
            m("td", renderHomepage(package)),
            m("td", renderLicense(package))
          ]);
        })
      ])
    ])
  ];
};

m.module(document.getElementById("guix"), guix);