gui.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. define([ "chroma-js", "map", "sidebar", "tabs", "container", "meshstats",
  2. "legend", "linklist", "nodelist", "simplenodelist", "infobox/main",
  3. "proportions", "forcegraph", "title", "about" ],
  4. function (chroma, Map, Sidebar, Tabs, Container, Meshstats, Legend, Linklist,
  5. Nodelist, SimpleNodelist, Infobox, Proportions, ForceGraph,
  6. Title, About) {
  7. return function (config, router) {
  8. var self = this
  9. var dataTargets = []
  10. var latestData
  11. var content
  12. var contentDiv
  13. var linkScale = chroma.scale(chroma.interpolate.bezier(["#04C714", "#FF5500", "#F02311"])).domain([1, 5])
  14. var sidebar
  15. var buttons = document.createElement("div")
  16. buttons.classList.add("buttons")
  17. function dataTargetRemove(d) {
  18. dataTargets = dataTargets.filter( function (e) { return d !== e })
  19. }
  20. function removeContent() {
  21. if (!content)
  22. return
  23. router.removeTarget(content)
  24. dataTargetRemove(content)
  25. content.destroy()
  26. content = null
  27. }
  28. function addContent(K) {
  29. removeContent()
  30. content = new K(config, linkScale, sidebar.getWidth, router, buttons)
  31. content.render(contentDiv)
  32. if (latestData)
  33. content.setData(latestData)
  34. dataTargets.push(content)
  35. router.addTarget(content)
  36. }
  37. function mkView(K) {
  38. return function () {
  39. addContent(K)
  40. }
  41. }
  42. contentDiv = document.createElement("div")
  43. contentDiv.classList.add("content")
  44. document.body.appendChild(contentDiv)
  45. sidebar = new Sidebar(document.body)
  46. contentDiv.appendChild(buttons)
  47. var buttonToggle = document.createElement("button")
  48. buttonToggle.textContent = ""
  49. buttonToggle.onclick = function () {
  50. if (content.constructor === Map)
  51. router.view("g")
  52. else
  53. router.view("m")
  54. }
  55. buttons.appendChild(buttonToggle)
  56. var title = new Title(config)
  57. var header = new Container("header")
  58. var infobox = new Infobox(config, sidebar, router)
  59. var tabs = new Tabs()
  60. var overview = new Container()
  61. var meshstats = new Meshstats(config)
  62. var legend = new Legend()
  63. var newnodeslist = new SimpleNodelist("new", "firstseen", router, "Neue Knoten")
  64. var lostnodeslist = new SimpleNodelist("lost", "lastseen", router, "Verschwundene Knoten")
  65. var nodelist = new Nodelist(router)
  66. var linklist = new Linklist(linkScale, router)
  67. var statistics = new Proportions(config)
  68. var about = new About()
  69. dataTargets.push(meshstats)
  70. dataTargets.push(newnodeslist)
  71. dataTargets.push(lostnodeslist)
  72. dataTargets.push(nodelist)
  73. dataTargets.push(linklist)
  74. dataTargets.push(statistics)
  75. sidebar.add(header)
  76. header.add(meshstats)
  77. header.add(legend)
  78. overview.add(newnodeslist)
  79. overview.add(lostnodeslist)
  80. sidebar.add(tabs)
  81. tabs.add("Aktuelles", overview)
  82. tabs.add("Knoten", nodelist)
  83. tabs.add("Verbindungen", linklist)
  84. tabs.add("Statistiken", statistics)
  85. tabs.add("Über", about)
  86. router.addTarget(title)
  87. router.addTarget(infobox)
  88. router.addView("m", mkView(Map))
  89. router.addView("g", mkView(ForceGraph))
  90. router.view("m")
  91. self.setData = function (data) {
  92. latestData = data
  93. dataTargets.forEach(function (d) {
  94. d.setData(data)
  95. })
  96. }
  97. return self
  98. }
  99. })