[Git][reproducible-builds/debian-rebuilder-setup][master] visualizer: add dummy splash page

Santiago Torres-Arias gitlab at salsa.debian.org
Thu Nov 29 22:34:11 CET 2018


Santiago Torres-Arias pushed to branch master at Reproducible Builds / debian-rebuilder-setup


Commits:
049b593f by Santiago Torres at 2018-11-29T21:31:55Z
visualizer: add dummy splash page

- - - - -


27 changed files:

- roles/visualizers/tasks/main.yml
- + visualizer/static/css/Raleway/Raleway-Black.ttf
- + visualizer/static/css/Raleway/Raleway-BlackItalic.ttf
- + visualizer/static/css/Raleway/Raleway-Bold.ttf
- + visualizer/static/css/Raleway/Raleway-BoldItalic.ttf
- + visualizer/static/css/Raleway/Raleway-ExtraBold.ttf
- + visualizer/static/css/Raleway/Raleway-ExtraBoldItalic.ttf
- + visualizer/static/css/Raleway/Raleway-ExtraLight.ttf
- + visualizer/static/css/Raleway/Raleway-ExtraLightItalic.ttf
- + visualizer/static/css/Raleway/Raleway-Italic.ttf
- + visualizer/static/css/Raleway/Raleway-Light.ttf
- + visualizer/static/css/Raleway/Raleway-LightItalic.ttf
- + visualizer/static/css/Raleway/Raleway-Medium.ttf
- + visualizer/static/css/Raleway/Raleway-MediumItalic.ttf
- + visualizer/static/css/Raleway/Raleway-Regular.ttf
- + visualizer/static/css/Raleway/Raleway-SemiBold.ttf
- + visualizer/static/css/Raleway/Raleway-SemiBoldItalic.ttf
- + visualizer/static/css/Raleway/Raleway-Thin.ttf
- + visualizer/static/css/Raleway/Raleway-ThinItalic.ttf
- + visualizer/static/css/Raleway/SIL Open Font License.txt
- + visualizer/static/css/main.css
- + visualizer/static/css/normalize.css
- + visualizer/static/css/skeleton.css
- + visualizer/static/images/logos/icon_white.svg
- + visualizer/static/images/rb-logo.svg
- + visualizer/templates/index.html
- visualizer/visualizer.py


Changes:

=====================================
roles/visualizers/tasks/main.yml
=====================================
@@ -20,6 +20,7 @@
     - { src: ../../../visualizer/accumulator.py, dest: /var/accumulator/accumulator.py }
     - { src: ../../../visualizer/visualizer.py, dest: /var/visualizer/visualizer.py }
     - { src: ../../../visualizer/requirements.txt, dest: /var/requirements.txt }
+    - { src: ../../../visualizer/static, dest: /var/visualizer/ }
     - { src: ../../../visualizer/templates, dest: /var/visualizer/ }
     - { src: ../../../visualizer/schema.sql, dest: /var/schema.sql }
 


=====================================
visualizer/static/css/Raleway/Raleway-Black.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-Black.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-BlackItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-BlackItalic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-Bold.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-Bold.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-BoldItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-BoldItalic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-ExtraBold.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-ExtraBold.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-ExtraBoldItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-ExtraBoldItalic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-ExtraLight.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-ExtraLight.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-ExtraLightItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-ExtraLightItalic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-Italic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-Italic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-Light.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-Light.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-LightItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-LightItalic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-Medium.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-Medium.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-MediumItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-MediumItalic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-Regular.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-Regular.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-SemiBold.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-SemiBold.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-SemiBoldItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-SemiBoldItalic.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-Thin.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-Thin.ttf differ


=====================================
visualizer/static/css/Raleway/Raleway-ThinItalic.ttf
=====================================
Binary files /dev/null and b/visualizer/static/css/Raleway/Raleway-ThinItalic.ttf differ


=====================================
visualizer/static/css/Raleway/SIL Open Font License.txt
=====================================
@@ -0,0 +1,43 @@
+Copyright (c) 2010 - 2012, Matt McInerney (matt at pixelspread.com), Pablo Impallari(impallari at gmail.com), Rodrigo Fuenzalida (hello at rfuenzalida.com) with Reserved Font Name "Raleway"
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at: http://scripts.sil.org/OFL
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide development of collaborative font projects, to support the font creation efforts of academic and linguistic communities, and to provide a free and open framework in which fonts may be shared and improved in partnership with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and redistributed freely as long as they are not sold by themselves. The fonts, including any derivative works, can be bundled, embedded, redistributed and/or sold with any software provided that any reserved names are not used by derivative works. The fonts and derivatives, however, cannot be released under any other type of license. The requirement for fonts to remain under this license does not apply to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright Holder(s) under this license and clearly marked as such. This may include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting, or substituting -- in part or in whole -- any of the components of the Original Version, by changing formats or by porting the Font Software to a new environment.
+
+"Author" refers to any designer, engineer, programmer, technical writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining a copy of the Font Software, to use, study, copy, merge, embed, modify, redistribute, and sell modified and unmodified copies of the Font Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components, in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled, redistributed and/or sold with any software, provided that each copy contains the above copyright notice and this license. These can be included either as stand-alone text files, human-readable headers or in the appropriate machine-readable metadata fields within text or binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font Name(s) unless explicit written permission is granted by the corresponding Copyright Holder. This restriction only applies to the primary font name as presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font Software shall not be used to promote, endorse or advertise any Modified Version, except to acknowledge the contribution(s) of the Copyright Holder(s) and the Author(s) or with their explicit written permission.
+
+5) The Font Software, modified or unmodified, in part or in whole, must be distributed entirely under this license, and must not be distributed under any other license. The requirement for fonts to remain under this license does not apply to any document created using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM OTHER DEALINGS IN THE FONT SOFTWARE.
\ No newline at end of file


=====================================
visualizer/static/css/main.css
=====================================
@@ -0,0 +1,497 @@
+.site-header {
+  background: #1e5b96;
+  color: #fff;
+  width: 100%;
+  min-height: 56px;
+  margin-bottom: 4.0rem;
+}
+
+.home header {
+  text-align: center;
+  padding-bottom: 1.0rem;
+}
+.home header h1 {
+  padding-top: 4.0rem;
+  padding-bottom: 2.0rem;
+}
+.site-header .punctuation {
+  color: #2b89d6;
+}
+.home header .tagline {
+  font-size: 2.0rem;
+}
+ at media (min-width: 480px) {
+  .home header h1 {
+    font-size: 5.8rem;
+  }
+}
+ at media (min-width: 750px) {
+  .home .title, .post-content .title  {
+    text-align: right;
+    padding-left: 1rem;
+    padding-right: 1rem;
+    margin-bottom: 2rem;
+  }
+  .home .title  h2, .post-content .title h2 {
+    line-height: 1;
+    margin-bottom: 0;
+    font-size: 2.8rem;
+  }
+}
+ at media (min-width: 900px) {
+  .home .title h2, .post-content .title h2 {
+    font-size: 3.0rem;
+  }
+}
+ at media (min-width: 1000px) {
+  .home .title h2, .post-content .title h2 {
+    font-size: 3.2rem;
+  }
+}
+ at media (min-width: 1100px) {
+  .home .title h2, .post-content .title h2 {
+    font-size: 3.4rem;
+  }
+}
+ at media (min-width: 1200px) {
+  .home .title h2, .post-content .title h2 {
+    font-size: 3.6rem;
+  }
+}
+
+.home .text p, .post-content .text p, .home .text ul, .home .text ol, .post-content .text ul, .post-content .text ol {
+  max-width: 60ex;
+  margin-bottom: 1rem;
+}
+
+a {
+    color: #1e5b96;
+}
+
+.text p {
+  text-align: justify;
+}
+
+.home .posts { list-style-type: none; }
+
+.home .posts li { margin-bottom: 30px; }
+
+.home .posts .post-link {
+  font-size: 24px;
+  letter-spacing: -1px;
+  line-height: 1;
+}
+
+.home .posts .post-date {
+  display: block;
+  font-size: 15px;
+  color: #818181;
+}
+
+.site-title,
+.site-title:hover,
+.site-title:visited {
+  display: block;
+  color: white;
+  font-size: 23px;
+  letter-spacing: -1px;
+  float: left;
+  line-height: 50px;
+  position: relative;
+  z-index: 1;
+  text-decoration: none;
+}
+
+.site-nav {
+  float: right;
+  line-height: 56px;
+}
+
+.home nav {
+  line-height: 56px;
+  text-align: center;
+}
+
+.home .site-header {
+  margin-bottom: 0.5rem;
+}
+.home nav {
+  margin-bottom: 4rem;
+}
+
+.site-nav a, .home nav a {
+  text-decoration: none;
+  font-weight: 700;
+}
+
+.site-nav a:hover, .home nav a:hover {
+  text-decoration: underline;
+}
+
+.site-nav .menu-icon { display: none; }
+
+.site-nav .page-link {
+  margin-left: 20px;
+  color: white;
+  letter-spacing: -.5px;
+}
+
+.home nav .page-link {
+  margin-left: 20px;
+  letter-spacing: -.5px;
+}
+
+.show-on-mobiles {
+  display: none;
+}
+
+.current a {
+  font-weight: bold;
+}
+
+ at media screen and (max-width: 749px) {
+  .show-on-mobiles {
+    display: block !important;
+  }
+  .hide-on-mobiles {
+    display: none;
+  }
+
+  .site-footer .row .columns {
+    margin-bottom: 3rem;
+  }
+
+  .site-footer .git-location p {
+    text-align: left;
+  }
+  .site-footer .git-location code {
+    text-align: left;
+    font-size: 1.2rem;
+    padding: 0;
+    margin: 0;
+    background: transparent;
+    border: none;
+    white-space: normal;
+  }
+}
+
+ at media screen and (max-width: 899px) {
+  .site-nav .show-on-mobiles {
+    display: block !important;
+  }
+  .site-nav .hide-on-mobiles {
+    display: none;
+  }
+  .site-nav {
+    position: fixed;
+    z-index: 10;
+    top: 10px; right: 8px;
+    background-color: #1e5b96;
+    -webkit-border-radius: 5px;
+    -moz-border-radius: 5px;
+    border-radius: 5px;
+    border: 1px solid #2b89d6;
+  }
+
+  .site-nav .menu-icon {
+    display: block;
+    font-size: 24px;
+    color: white;
+    float: right;
+    width: 36px;
+    text-align: center;
+    line-height: 36px;
+  }
+
+  .site-nav .menu-icon svg { width: 18px; height: 16px; }
+
+  .site-nav .trigger {
+    clear: both;
+    margin-bottom: 5px;
+    display: none;
+  }
+
+  .site-nav:hover .trigger { display: block; }
+
+  .site-nav .page-link {
+    display: block;
+    text-align: right;
+    line-height: 1.25;
+    padding: 5px 10px;
+    margin: 0;
+  }
+}
+
+aside h4 {
+  font-size: 2.0rem;
+}
+
+aside li {
+  list-style: none;
+  margin-bottom: 0;
+}
+
+aside li a {
+  text-decoration: none;
+}
+
+.section-nav {
+  margin-top: 5rem;
+}
+
+.section-nav .disabled {
+  opacity: .5;
+  cursor: default;
+  border: 1px solid #bbb;
+  color: #555;
+}
+
+.section-nav > div {
+  width: 49.5%;
+  float: left;
+}
+
+.section-nav .next {
+  float: right;
+}
+
+.post-content .doc-index h4 {
+  font-size: 2.4rem;
+  margin-bottom: 1rem;
+}
+
+.post-content .doc-index ul {
+  padding-left: 0;
+}
+.post-content .doc-index li {
+  list-style: none;
+  margin-bottom: 0;
+}
+
+ at media (min-width: 750px) {
+  .post-content h2 { font-size: 3.6rem; font-weight: bold; }
+  .post-content h3 { font-size: 3.0rem; font-weight: bold; }
+  .post-content h4 { font-size: 2.4rem; font-weight: bold; }
+  .post-content h5 { font-size: 1.8rem; font-weight: bold; }
+  .post-content h6 { font-size: 1.5rem; font-weight: bold; }
+}
+
+.post-header { margin: 0px 0 30px; }
+
+.post-header h1 {
+  line-height: 1;
+  margin-bottom: 1rem;
+}
+
+.post-header .meta, .title .meta {
+  font-size: 15px;
+  color: #818181;
+  margin-top: 5px;
+}
+.post-header .meta {
+  line-height: 6.0rem;
+}
+.title .meta {
+  line-height: 5.0rem;
+}
+
+ at media (min-width: 750px) {
+  .post-header .meta {
+    text-align: right;
+  }
+}
+
+.post-content h3 a {
+  text-decoration: none;
+  color: black;
+}
+
+.post-content dl {
+  margin-top: 0;
+}
+
+.post-content ul, .post-content ol {
+  list-style-position: outside;
+  padding-left: 1.5rem;
+}
+.post-content ul ul,
+.post-content ul ol,
+.post-content ol ul,
+.post-content ol ol {
+  margin: 0 0 0 3rem;
+}
+
+.post-content li {
+  margin-bottom: 0;
+}
+
+.post-content .footnotes {
+  margin-top: 4rem;
+  font-size: small;
+}
+
+.post-content .wrong code {
+  border-color: red;
+  background-color: #f1c1c1;
+}
+
+.post-content .correct code {
+  border-color: green;
+  background-color: #c1f1c1;
+}
+
+.site-footer {
+  border-top: 1px solid #e8e8e8;
+  padding: 3.0rem 0;
+}
+
+.site-footer ul { list-style: none; }
+
+.footer-heading {
+  font-size: 18px;
+  font-weight: 300;
+  letter-spacing: -.5px;
+  margin-bottom: 15px;
+}
+
+.site-footer li,
+.site-footer p {
+  font-size: 15px;
+  letter-spacing: -.3px;
+  color: #828282;
+  margin-bottom: 0;
+}
+
+.site-footer .git-location {
+  text-align: center;
+}
+
+.twitter-icon-svg {
+  display: inline-block;
+  width: 16px;
+  height: 16px;
+  position: relative;
+  top: 3px;
+}
+
+ at font-face {
+  font-family: 'Raleway';
+  font-style: normal;
+  font-weight: 300;
+  src: local('Raleway Light'), local('Raleway-Light'), url(Raleway/Raleway-Light.ttf) format('truetype');
+}
+ at font-face {
+  font-family: 'Raleway';
+  font-style: italic;
+  font-weight: 300;
+  src: local('Raleway Light Italic'), local('Raleway-LightItalic'), url(Raleway/Raleway-LightItalic.ttf) format('truetype');
+}
+ at font-face {
+  font-family: 'Raleway';
+  font-style: normal;
+  font-weight: 400;
+  src: url(Raleway/Raleway-Regular.ttf) format('truetype'), local('Raleway');
+}
+ at font-face {
+  font-family: 'Raleway';
+  font-style: italic;
+  font-weight: 400;
+  src: local('Raleway Italic'), local('Raleway-Italic'), url(Raleway/Raleway-Italic.ttf) format('truetype');
+}
+ at font-face {
+  font-family: 'Raleway';
+  font-style: normal;
+  font-weight: 600;
+  src: local('Raleway SemiBold Italic'), local('Raleway-SemiBold'), url(Raleway/Raleway-SemiBold.ttf) format('truetype');
+}
+ at font-face {
+  font-family: 'Raleway';
+  font-style: italic;
+  font-weight: 600;
+  src: local('Raleway SemiBold Italic'), local('Raleway-SemiBoldItalic'), url(Raleway/Raleway-SemiBoldItalic.ttf) format('truetype');
+}
+
+/* Syntax highlighting styles */
+/* ----------------------------------------------------------*/
+
+.highlight  { background: #ffffff; }
+.highlight .c { color: #999988; font-style: italic } /* Comment */
+.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
+.highlight .k { font-weight: bold } /* Keyword */
+.highlight .o { font-weight: bold } /* Operator */
+.highlight .cm { color: #999988; font-style: italic } /* Comment.Multiline */
+.highlight .cp { color: #999999; font-weight: bold } /* Comment.Preproc */
+.highlight .c1 { color: #999988; font-style: italic } /* Comment.Single */
+.highlight .cs { color: #999999; font-weight: bold; font-style: italic } /* Comment.Special */
+.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
+.highlight .gd .x { color: #000000; background-color: #ffaaaa } /* Generic.Deleted.Specific */
+.highlight .ge { font-style: italic } /* Generic.Emph */
+.highlight .gr { color: #aa0000 } /* Generic.Error */
+.highlight .gh { color: #999999 } /* Generic.Heading */
+.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
+.highlight .gi .x { color: #000000; background-color: #aaffaa } /* Generic.Inserted.Specific */
+.highlight .go { color: #888888 } /* Generic.Output */
+.highlight .gp { color: #555555 } /* Generic.Prompt */
+.highlight .gs { font-weight: bold } /* Generic.Strong */
+.highlight .gu { color: #aaaaaa } /* Generic.Subheading */
+.highlight .gt { color: #aa0000 } /* Generic.Traceback */
+.highlight .kc { font-weight: bold } /* Keyword.Constant */
+.highlight .kd { font-weight: bold } /* Keyword.Declaration */
+.highlight .kp { font-weight: bold } /* Keyword.Pseudo */
+.highlight .kr { font-weight: bold } /* Keyword.Reserved */
+.highlight .kt { color: #445588; font-weight: bold } /* Keyword.Type */
+.highlight .m { color: #009999 } /* Literal.Number */
+.highlight .s { color: #d14 } /* Literal.String */
+.highlight .na { color: #008080 } /* Name.Attribute */
+.highlight .nb { color: #0086B3 } /* Name.Builtin */
+.highlight .nc { color: #445588; font-weight: bold } /* Name.Class */
+.highlight .no { color: #008080 } /* Name.Constant */
+.highlight .ni { color: #800080 } /* Name.Entity */
+.highlight .ne { color: #990000; font-weight: bold } /* Name.Exception */
+.highlight .nf { color: #990000; font-weight: bold } /* Name.Function */
+.highlight .nn { color: #555555 } /* Name.Namespace */
+.highlight .nt { color: #000080 } /* Name.Tag */
+.highlight .nv { color: #008080 } /* Name.Variable */
+.highlight .ow { font-weight: bold } /* Operator.Word */
+.highlight .w { color: #bbbbbb } /* Text.Whitespace */
+.highlight .mf { color: #009999 } /* Literal.Number.Float */
+.highlight .mh { color: #009999 } /* Literal.Number.Hex */
+.highlight .mi { color: #009999 } /* Literal.Number.Integer */
+.highlight .mo { color: #009999 } /* Literal.Number.Oct */
+.highlight .sb { color: #d14 } /* Literal.String.Backtick */
+.highlight .sc { color: #d14 } /* Literal.String.Char */
+.highlight .sd { color: #d14 } /* Literal.String.Doc */
+.highlight .s2 { color: #d14 } /* Literal.String.Double */
+.highlight .se { color: #d14 } /* Literal.String.Escape */
+.highlight .sh { color: #d14 } /* Literal.String.Heredoc */
+.highlight .si { color: #d14 } /* Literal.String.Interpol */
+.highlight .sx { color: #d14 } /* Literal.String.Other */
+.highlight .sr { color: #009926 } /* Literal.String.Regex */
+.highlight .s1 { color: #d14 } /* Literal.String.Single */
+.highlight .ss { color: #990073 } /* Literal.String.Symbol */
+.highlight .bp { color: #999999 } /* Name.Builtin.Pseudo */
+.highlight .vc { color: #008080 } /* Name.Variable.Class */
+.highlight .vg { color: #008080 } /* Name.Variable.Global */
+.highlight .vi { color: #008080 } /* Name.Variable.Instance */
+.highlight .il { color: #009999 } /* Literal.Number.Integer.Long */
+
+dl.talks dd {
+  margin-bottom: 20px;
+}
+
+nav select {
+  margin-top: 20px;
+}
+
+.post-simple {
+  text-align: justify;
+  padding-bottom: 40px;
+}
+
+.post-simple img {
+  max-width: 100%;
+}
+
+.post-simple h3 {
+  margin-top: 50px;
+}


=====================================
visualizer/static/css/normalize.css
=====================================
@@ -0,0 +1,427 @@
+/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
+
+/**
+ * 1. Set default font family to sans-serif.
+ * 2. Prevent iOS text size adjust after orientation change, without disabling
+ *    user zoom.
+ */
+
+html {
+  font-family: sans-serif; /* 1 */
+  -ms-text-size-adjust: 100%; /* 2 */
+  -webkit-text-size-adjust: 100%; /* 2 */
+}
+
+/**
+ * Remove default margin.
+ */
+
+body {
+  margin: 0;
+}
+
+/* HTML5 display definitions
+   ========================================================================== */
+
+/**
+ * Correct `block` display not defined for any HTML5 element in IE 8/9.
+ * Correct `block` display not defined for `details` or `summary` in IE 10/11
+ * and Firefox.
+ * Correct `block` display not defined for `main` in IE 11.
+ */
+
+article,
+aside,
+details,
+figcaption,
+figure,
+footer,
+header,
+hgroup,
+main,
+menu,
+nav,
+section,
+summary {
+  display: block;
+}
+
+/**
+ * 1. Correct `inline-block` display not defined in IE 8/9.
+ * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
+ */
+
+audio,
+canvas,
+progress,
+video {
+  display: inline-block; /* 1 */
+  vertical-align: baseline; /* 2 */
+}
+
+/**
+ * Prevent modern browsers from displaying `audio` without controls.
+ * Remove excess height in iOS 5 devices.
+ */
+
+audio:not([controls]) {
+  display: none;
+  height: 0;
+}
+
+/**
+ * Address `[hidden]` styling not present in IE 8/9/10.
+ * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
+ */
+
+[hidden],
+template {
+  display: none;
+}
+
+/* Links
+   ========================================================================== */
+
+/**
+ * Remove the gray background color from active links in IE 10.
+ */
+
+a {
+  background-color: transparent;
+}
+
+/**
+ * Improve readability when focused and also mouse hovered in all browsers.
+ */
+
+a:active,
+a:hover {
+  outline: 0;
+}
+
+/* Text-level semantics
+   ========================================================================== */
+
+/**
+ * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
+ */
+
+abbr[title] {
+  border-bottom: 1px dotted;
+}
+
+/**
+ * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
+ */
+
+b,
+strong {
+  font-weight: bold;
+}
+
+/**
+ * Address styling not present in Safari and Chrome.
+ */
+
+dfn {
+  font-style: italic;
+}
+
+/**
+ * Address variable `h1` font-size and margin within `section` and `article`
+ * contexts in Firefox 4+, Safari, and Chrome.
+ */
+
+h1 {
+  font-size: 2em;
+  margin: 0.67em 0;
+}
+
+/**
+ * Address styling not present in IE 8/9.
+ */
+
+mark {
+  background: #ff0;
+  color: #000;
+}
+
+/**
+ * Address inconsistent and variable font size in all browsers.
+ */
+
+small {
+  font-size: 80%;
+}
+
+/**
+ * Prevent `sub` and `sup` affecting `line-height` in all browsers.
+ */
+
+sub,
+sup {
+  font-size: 75%;
+  line-height: 0;
+  position: relative;
+  vertical-align: baseline;
+}
+
+sup {
+  top: -0.5em;
+}
+
+sub {
+  bottom: -0.25em;
+}
+
+/* Embedded content
+   ========================================================================== */
+
+/**
+ * Remove border when inside `a` element in IE 8/9/10.
+ */
+
+img {
+  border: 0;
+}
+
+/**
+ * Correct overflow not hidden in IE 9/10/11.
+ */
+
+svg:not(:root) {
+  overflow: hidden;
+}
+
+/* Grouping content
+   ========================================================================== */
+
+/**
+ * Address margin not present in IE 8/9 and Safari.
+ */
+
+figure {
+  margin: 1em 40px;
+}
+
+/**
+ * Address differences between Firefox and other browsers.
+ */
+
+hr {
+  -moz-box-sizing: content-box;
+  box-sizing: content-box;
+  height: 0;
+}
+
+/**
+ * Contain overflow in all browsers.
+ */
+
+pre {
+  overflow: auto;
+}
+
+/**
+ * Address odd `em`-unit font size rendering in all browsers.
+ */
+
+code,
+kbd,
+pre,
+samp {
+  font-family: monospace, monospace;
+  font-size: 1em;
+}
+
+/* Forms
+   ========================================================================== */
+
+/**
+ * Known limitation: by default, Chrome and Safari on OS X allow very limited
+ * styling of `select`, unless a `border` property is set.
+ */
+
+/**
+ * 1. Correct color not being inherited.
+ *    Known issue: affects color of disabled elements.
+ * 2. Correct font properties not being inherited.
+ * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
+ */
+
+button,
+input,
+optgroup,
+select,
+textarea {
+  color: inherit; /* 1 */
+  font: inherit; /* 2 */
+  margin: 0; /* 3 */
+}
+
+/**
+ * Address `overflow` set to `hidden` in IE 8/9/10/11.
+ */
+
+button {
+  overflow: visible;
+}
+
+/**
+ * Address inconsistent `text-transform` inheritance for `button` and `select`.
+ * All other form control elements do not inherit `text-transform` values.
+ * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
+ * Correct `select` style inheritance in Firefox.
+ */
+
+button,
+select {
+  text-transform: none;
+}
+
+/**
+ * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
+ *    and `video` controls.
+ * 2. Correct inability to style clickable `input` types in iOS.
+ * 3. Improve usability and consistency of cursor style between image-type
+ *    `input` and others.
+ */
+
+button,
+html input[type="button"], /* 1 */
+input[type="reset"],
+input[type="submit"] {
+  -webkit-appearance: button; /* 2 */
+  cursor: pointer; /* 3 */
+}
+
+/**
+ * Re-set default cursor for disabled elements.
+ */
+
+button[disabled],
+html input[disabled] {
+  cursor: default;
+}
+
+/**
+ * Remove inner padding and border in Firefox 4+.
+ */
+
+button::-moz-focus-inner,
+input::-moz-focus-inner {
+  border: 0;
+  padding: 0;
+}
+
+/**
+ * Address Firefox 4+ setting `line-height` on `input` using `!important` in
+ * the UA stylesheet.
+ */
+
+input {
+  line-height: normal;
+}
+
+/**
+ * It's recommended that you don't attempt to style these elements.
+ * Firefox's implementation doesn't respect box-sizing, padding, or width.
+ *
+ * 1. Address box sizing set to `content-box` in IE 8/9/10.
+ * 2. Remove excess padding in IE 8/9/10.
+ */
+
+input[type="checkbox"],
+input[type="radio"] {
+  box-sizing: border-box; /* 1 */
+  padding: 0; /* 2 */
+}
+
+/**
+ * Fix the cursor style for Chrome's increment/decrement buttons. For certain
+ * `font-size` values of the `input`, it causes the cursor style of the
+ * decrement button to change from `default` to `text`.
+ */
+
+input[type="number"]::-webkit-inner-spin-button,
+input[type="number"]::-webkit-outer-spin-button {
+  height: auto;
+}
+
+/**
+ * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
+ * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
+ *    (include `-moz` to future-proof).
+ */
+
+input[type="search"] {
+  -webkit-appearance: textfield; /* 1 */
+  -moz-box-sizing: content-box;
+  -webkit-box-sizing: content-box; /* 2 */
+  box-sizing: content-box;
+}
+
+/**
+ * Remove inner padding and search cancel button in Safari and Chrome on OS X.
+ * Safari (but not Chrome) clips the cancel button when the search input has
+ * padding (and `textfield` appearance).
+ */
+
+input[type="search"]::-webkit-search-cancel-button,
+input[type="search"]::-webkit-search-decoration {
+  -webkit-appearance: none;
+}
+
+/**
+ * Define consistent border, margin, and padding.
+ */
+
+fieldset {
+  border: 1px solid #c0c0c0;
+  margin: 0 2px;
+  padding: 0.35em 0.625em 0.75em;
+}
+
+/**
+ * 1. Correct `color` not being inherited in IE 8/9/10/11.
+ * 2. Remove padding so people aren't caught out if they zero out fieldsets.
+ */
+
+legend {
+  border: 0; /* 1 */
+  padding: 0; /* 2 */
+}
+
+/**
+ * Remove default vertical scrollbar in IE 8/9/10/11.
+ */
+
+textarea {
+  overflow: auto;
+}
+
+/**
+ * Don't inherit the `font-weight` (applied by a rule above).
+ * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
+ */
+
+optgroup {
+  font-weight: bold;
+}
+
+/* Tables
+   ========================================================================== */
+
+/**
+ * Remove most spacing between table cells.
+ */
+
+table {
+  border-collapse: collapse;
+  border-spacing: 0;
+}
+
+td,
+th {
+  padding: 0;
+}
\ No newline at end of file


=====================================
visualizer/static/css/skeleton.css
=====================================
@@ -0,0 +1,415 @@
+/*
+* Skeleton V2.0.4
+* Copyright 2014, Dave Gamache
+* www.getskeleton.com
+* Free to use under the MIT license.
+* http://www.opensource.org/licenses/mit-license.php
+* 12/29/2014
+*/
+
+
+/* Table of contents
+––––––––––––––––––––––––––––––––––––––––––––––––––
+- Grid
+- Base Styles
+- Typography
+- Links
+- Buttons
+- Forms
+- Lists
+- Code
+- Tables
+- Spacing
+- Utilities
+- Clearing
+- Media Queries
+*/
+
+
+/* Grid
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+.container {
+  position: relative;
+  width: 100%;
+  max-width: 960px;
+  margin: 0 auto;
+  padding: 0 20px;
+  box-sizing: border-box; }
+.column,
+.columns {
+  width: 100%;
+  float: left;
+  box-sizing: border-box; }
+
+/* For devices larger than 400px */
+ at media (min-width: 400px) {
+  .container {
+    width: 85%;
+    padding: 0; }
+}
+
+/* For devices larger than 750px */
+ at media (min-width: 750px) {
+  .container {
+    width: 80%; }
+  .column,
+  .columns {
+    margin-left: 4%; }
+  .column:first-child,
+  .columns:first-child {
+    margin-left: 0; }
+
+  .one.column,
+  .one.columns                    { width: 4.66666666667%; }
+  .two.columns                    { width: 13.3333333333%; }
+  .three.columns                  { width: 22%;            }
+  .four.columns                   { width: 30.6666666667%; }
+  .five.columns                   { width: 39.3333333333%; }
+  .six.columns                    { width: 48%;            }
+  .seven.columns                  { width: 56.6666666667%; }
+  .eight.columns                  { width: 65.3333333333%; }
+  .nine.columns                   { width: 74.0%;          }
+  .ten.columns                    { width: 82.6666666667%; }
+  .eleven.columns                 { width: 91.3333333333%; }
+  .twelve.columns                 { width: 100%; margin-left: 0; }
+
+  .one-third.column               { width: 30.6666666667%; }
+  .two-thirds.column              { width: 65.3333333333%; }
+
+  .one-half.column                { width: 48%; }
+
+  /* Offsets */
+  .offset-by-one.column,
+  .offset-by-one.columns          { margin-left: 8.66666666667%; }
+  .offset-by-two.column,
+  .offset-by-two.columns          { margin-left: 17.3333333333%; }
+  .offset-by-three.column,
+  .offset-by-three.columns        { margin-left: 26%;            }
+  .offset-by-four.column,
+  .offset-by-four.columns         { margin-left: 34.6666666667%; }
+  .offset-by-five.column,
+  .offset-by-five.columns         { margin-left: 43.3333333333%; }
+  .offset-by-six.column,
+  .offset-by-six.columns          { margin-left: 52%;            }
+  .offset-by-seven.column,
+  .offset-by-seven.columns        { margin-left: 60.6666666667%; }
+  .offset-by-eight.column,
+  .offset-by-eight.columns        { margin-left: 69.3333333333%; }
+  .offset-by-nine.column,
+  .offset-by-nine.columns         { margin-left: 78.0%;          }
+  .offset-by-ten.column,
+  .offset-by-ten.columns          { margin-left: 86.6666666667%; }
+  .offset-by-eleven.column,
+  .offset-by-eleven.columns       { margin-left: 95.3333333333%; }
+
+  .offset-by-one-third.column,
+  .offset-by-one-third.columns    { margin-left: 34.6666666667%; }
+  .offset-by-two-thirds.column,
+  .offset-by-two-thirds.columns   { margin-left: 69.3333333333%; }
+
+  .offset-by-one-half.column,
+  .offset-by-one-half.columns     { margin-left: 52%; }
+
+}
+
+
+/* Base Styles
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+/* NOTE
+html is set to 62.5% so that all the REM measurements throughout Skeleton
+are based on 10px sizing. So basically 1.5rem = 15px :) */
+html {
+  font-size: 62.5%; }
+body {
+  font-size: 1.5em; /* currently ems cause chrome bug misinterpreting rems on body element */
+  line-height: 1.6;
+  font-weight: 400;
+  font-family: "Raleway", "HelveticaNeue", "Helvetica Neue", Helvetica, Arial, sans-serif;
+  color: #222; }
+
+
+/* Typography
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+h1, h2, h3, h4, h5, h6 {
+  margin-top: 0;
+  margin-bottom: 2rem;
+  font-weight: 300; }
+h1 { font-size: 4.0rem; line-height: 1.2;  letter-spacing: -.1rem;}
+h2 { font-size: 3.6rem; line-height: 1.25; letter-spacing: -.1rem; }
+h3 { font-size: 3.0rem; line-height: 1.3;  letter-spacing: -.1rem; }
+h4 { font-size: 2.4rem; line-height: 1.35; letter-spacing: -.08rem; }
+h5 { font-size: 1.8rem; line-height: 1.5;  letter-spacing: -.05rem; }
+h6 { font-size: 1.5rem; line-height: 1.6;  letter-spacing: 0; }
+
+/* Larger than tablet */
+ at media (min-width: 750px) {
+  h1 { font-size: 5.0rem; }
+  h2 { font-size: 4.2rem; }
+  h3 { font-size: 3.6rem; }
+  h4 { font-size: 3.0rem; }
+  h5 { font-size: 2.4rem; }
+  h6 { font-size: 1.5rem; }
+}
+
+p {
+  margin-top: 0; }
+
+
+/* Links
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+a {
+  color: #1EAEDB; }
+a:hover {
+  color: #0FA0CE; }
+
+
+/* Buttons
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+.button,
+button,
+input[type="submit"],
+input[type="reset"],
+input[type="button"] {
+  display: inline-block;
+  height: 38px;
+  padding: 0 30px;
+  color: #555;
+  text-align: center;
+  font-size: 11px;
+  font-weight: 600;
+  line-height: 38px;
+  letter-spacing: .1rem;
+  text-transform: uppercase;
+  text-decoration: none;
+  white-space: nowrap;
+  background-color: transparent;
+  border-radius: 4px;
+  border: 1px solid #bbb;
+  cursor: pointer;
+  box-sizing: border-box; }
+.button:hover,
+button:hover,
+input[type="submit"]:hover,
+input[type="reset"]:hover,
+input[type="button"]:hover,
+.button:focus,
+button:focus,
+input[type="submit"]:focus,
+input[type="reset"]:focus,
+input[type="button"]:focus {
+  color: #333;
+  border-color: #888;
+  outline: 0; }
+.button.button-primary,
+button.button-primary,
+input[type="submit"].button-primary,
+input[type="reset"].button-primary,
+input[type="button"].button-primary {
+  color: #FFF;
+  background-color: #33C3F0;
+  border-color: #33C3F0; }
+.button.button-primary:hover,
+button.button-primary:hover,
+input[type="submit"].button-primary:hover,
+input[type="reset"].button-primary:hover,
+input[type="button"].button-primary:hover,
+.button.button-primary:focus,
+button.button-primary:focus,
+input[type="submit"].button-primary:focus,
+input[type="reset"].button-primary:focus,
+input[type="button"].button-primary:focus {
+  color: #FFF;
+  background-color: #1EAEDB;
+  border-color: #1EAEDB; }
+
+
+/* Forms
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+input[type="email"],
+input[type="number"],
+input[type="search"],
+input[type="text"],
+input[type="tel"],
+input[type="url"],
+input[type="password"],
+textarea,
+select {
+  height: 38px;
+  padding: 6px 10px; /* The 6px vertically centers text on FF, ignored by Webkit */
+  background-color: #fff;
+  border: 1px solid #D1D1D1;
+  border-radius: 4px;
+  box-shadow: none;
+  box-sizing: border-box; }
+/* Removes awkward default styles on some inputs for iOS */
+input[type="email"],
+input[type="number"],
+input[type="search"],
+input[type="text"],
+input[type="tel"],
+input[type="url"],
+input[type="password"],
+textarea {
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none; }
+textarea {
+  min-height: 65px;
+  padding-top: 6px;
+  padding-bottom: 6px; }
+input[type="email"]:focus,
+input[type="number"]:focus,
+input[type="search"]:focus,
+input[type="text"]:focus,
+input[type="tel"]:focus,
+input[type="url"]:focus,
+input[type="password"]:focus,
+textarea:focus,
+select:focus {
+  border: 1px solid #33C3F0;
+  outline: 0; }
+label,
+legend {
+  display: block;
+  margin-bottom: .5rem;
+  font-weight: 600; }
+fieldset {
+  padding: 0;
+  border-width: 0; }
+input[type="checkbox"],
+input[type="radio"] {
+  display: inline; }
+label > .label-body {
+  display: inline-block;
+  margin-left: .5rem;
+  font-weight: normal; }
+
+
+/* Lists
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+ul {
+  list-style: circle inside; }
+ol {
+  list-style: decimal inside; }
+ol, ul {
+  padding-left: 0;
+  margin-top: 0; }
+ul ul,
+ul ol,
+ol ol,
+ol ul {
+  margin: 1.5rem 0 1.5rem 3rem;
+  font-size: 90%; }
+li {
+  margin-bottom: 1rem; }
+
+
+/* Code
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+code {
+  padding: .2rem .5rem;
+  margin: 0 .2rem;
+  font-size: 90%;
+  white-space: nowrap;
+  background: #F1F1F1;
+  border: 1px solid #E1E1E1;
+  border-radius: 4px; }
+pre > code {
+  display: block;
+  padding: 1rem 1.5rem;
+  white-space: pre; }
+
+
+/* Tables
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+th,
+td {
+  padding: 12px 15px;
+  text-align: left;
+  border-bottom: 1px solid #E1E1E1; }
+th:first-child,
+td:first-child {
+  padding-left: 0; }
+th:last-child,
+td:last-child {
+  padding-right: 0; }
+
+
+/* Spacing
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+button,
+.button {
+  margin-bottom: 1rem; }
+input,
+textarea,
+select,
+fieldset {
+  margin-bottom: 1.5rem; }
+pre,
+blockquote,
+dl,
+figure,
+table,
+p,
+ul,
+ol,
+form {
+  margin-bottom: 2.5rem; }
+
+
+/* Utilities
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+.u-full-width {
+  width: 100%;
+  box-sizing: border-box; }
+.u-max-full-width {
+  max-width: 100%;
+  box-sizing: border-box; }
+.u-pull-right {
+  float: right; }
+.u-pull-left {
+  float: left; }
+
+
+/* Misc
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+hr {
+  margin-top: 3rem;
+  margin-bottom: 3.5rem;
+  border-width: 0;
+  border-top: 1px solid #E1E1E1; }
+
+
+/* Clearing
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+
+/* Self Clearing Goodness */
+.container:after,
+.row:after,
+.u-cf {
+  content: "";
+  display: table;
+  clear: both; }
+
+
+/* Media Queries
+–––––––––––––––––––––––––––––––––––––––––––––––––– */
+/*
+Note: The best way to structure the use of media queries is to create the queries
+near the relevant code. For example, if you wanted to change the styles for buttons
+on small devices, paste the mobile query code up in the buttons section and style it
+there.
+*/
+
+
+/* Larger than mobile */
+ at media (min-width: 400px) {}
+
+/* Larger than tablet (also point when grid becomes active) */
+ at media (min-width: 750px) {}
+
+/* Larger than desktop */
+ at media (min-width: 1000px) {}
+
+/* Larger than Desktop HD */
+ at media (min-width: 1200px) {}


=====================================
visualizer/static/images/logos/icon_white.svg
=====================================
@@ -0,0 +1,49 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Generator: Adobe Illustrator 22.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
+<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
+	 width="131.6px" height="131.6px" viewBox="0 0 131.6 131.6" style="enable-background:new 0 0 131.6 131.6;" xml:space="preserve"
+	>
+<style type="text/css">
+	.st0{fill:#1E5B96;}
+	.st1{fill:#2B89D6;}
+	.st2{fill:#FFFFFF;}
+</style>
+<g>
+	<g>
+		<g id="g26_6_" transform="rotate(90,40.7,44.8)">
+			<g id="circle2_6_">
+				<circle class="st2" cx="61.7" cy="-33.5" r="12.6"/>
+			</g>
+			<g id="circle4_6_">
+				<circle class="st2" cx="61.7" cy="72.9" r="12.6"/>
+			</g>
+			<g id="circle6_6_">
+				<circle class="st2" cx="114.9" cy="19.7" r="12.6"/>
+			</g>
+			<g id="circle8_6_">
+				<circle class="st2" cx="8.5" cy="19.7" r="12.6"/>
+			</g>
+			<g id="g12_6_">
+				<g id="polygon10_6_">
+					<polygon class="st2" points="66.3,-8.9 80.2,5 100.5,5 100.5,-15.4 86.6,-29.3 86.6,-8.9 					"/>
+				</g>
+			</g>
+			<g id="g16_6_">
+				<g id="polygon14_6_">
+					<polygon class="st2" points="12.7,44.6 26.6,58.5 47,58.5 47,38.2 33.1,24.3 33.1,44.6 					"/>
+				</g>
+			</g>
+			<g id="g20_6_">
+				<g id="polygon18_6_">
+					<polygon class="st2" points="86.5,68.7 100.4,54.8 100.5,34.4 80.1,34.4 66.2,48.3 86.6,48.2 					"/>
+				</g>
+			</g>
+			<g id="g24_6_">
+				<g id="polygon22_6_">
+					<polygon class="st2" points="33,15.1 47,1.1 47,-19.2 26.6,-19.2 12.7,-5.2 33.1,-5.3 					"/>
+				</g>
+			</g>
+		</g>
+	</g>
+</g>
+</svg>


=====================================
visualizer/static/images/rb-logo.svg
=====================================
@@ -0,0 +1,107 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Generator: Adobe Illustrator 22.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
+<svg version="1.1"
+	 id="Layer_1" inkscape:version="0.92.2 5c3e80d, 2017-08-06" sodipodi:docname="ReproducibleBuilds_ICONS_55_r90.svg" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:svg="http://www.w3.org/2000/svg"
+	 xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="402.205px"
+	 height="102.544px" viewBox="0 0 402.205 102.544" enable-background="new 0 0 402.205 102.544" xml:space="preserve">
+<g>
+	<g>
+		<g>
+			<g id="g26_25_" transform="rotate(90,40.7,44.8)">
+				<g id="circle2_25_">
+					<circle fill="#1E5B96" cx="47.136" cy="-7.244" r="9.8"/>
+				</g>
+				<g id="circle4_25_">
+					<circle fill="#1E5B96" cx="47.207" cy="75.7" r="9.8"/>
+				</g>
+				<g id="circle6_25_">
+					<circle fill="#1E5B96" cx="88.644" cy="34.264" r="9.8"/>
+				</g>
+				<g id="circle8_25_">
+					<circle fill="#1E5B96" cx="5.7" cy="34.193" r="9.8"/>
+				</g>
+				<g id="g12_25_">
+					<g id="polygon10_25_">
+						<polygon fill="#2B89D6" points="50.743,11.919 61.561,22.738 77.401,22.738 77.401,6.899 66.582,-3.92 66.582,11.919 						
+							"/>
+					</g>
+				</g>
+				<g id="g16_25_">
+					<g id="polygon14_25_">
+						<polygon fill="#2B89D6" points="9.023,53.638 19.842,64.457 35.681,64.457 35.681,48.618 24.863,37.799 24.863,53.638 						
+							"/>
+					</g>
+				</g>
+				<g id="g20_25_">
+					<g id="polygon18_25_">
+						<polygon fill="#2B89D6" points="66.511,72.377 77.33,61.558 77.401,45.648 61.491,45.719 50.672,56.537 66.582,56.467 						
+							"/>
+					</g>
+				</g>
+				<g id="g24_25_">
+					<g id="polygon22_25_">
+						<polygon fill="#2B89D6" points="24.792,30.657 35.681,19.768 35.681,3.929 19.842,3.929 8.953,14.818 24.863,14.747 						"/>
+					</g>
+				</g>
+			</g>
+		</g>
+	</g>
+	<g>
+		<path fill="#1E5B96" d="M124.629,11.171h15.273c8.271,0,10.998,4.889,10.998,10.293c0,3.713-2.115,7.989-6.393,9.493L150.9,44.07
+			h-7.145L137.6,31.803h-6.627V44.07h-6.344C124.629,44.07,124.629,11.171,124.629,11.171z M139.996,25.787
+			c3.243,0,4.324-2.067,4.324-4.323c0-2.068-0.939-4.277-4.324-4.277h-9.023v8.601L139.996,25.787L139.996,25.787z"/>
+		<path fill="#1E5B96" d="M153.721,32.038c0-7.755,4.371-12.548,11.232-12.548c5.922,0,10.621,3.618,10.621,11.326
+			c0,0.939,0,2.303-0.188,3.618h-15.65c0.234,3.103,2.584,4.841,5.217,4.841c2.209,0,3.807-0.752,5.17-2.49l3.76,3.807
+			c-2.021,2.443-4.936,4.042-8.93,4.042C157.997,44.634,153.721,39.934,153.721,32.038z M169.606,29.266
+			c-0.376-2.82-2.209-4.418-4.652-4.418c-2.867,0-4.794,1.41-5.17,4.418C159.784,29.266,169.606,29.266,169.606,29.266z"/>
+		<path fill="#1E5B96" d="M186.619,42.33v8.366l-6.109,2.772V20.054h6.109v1.739c1.082-1.363,2.773-2.303,5.17-2.303
+			c5.922,0,9.916,4.464,9.916,12.595c0,7.896-4.229,12.549-9.963,12.549C189.346,44.634,187.701,43.694,186.619,42.33z
+			 M195.596,32.085c0-4.042-1.645-6.721-4.793-6.721c-2.021,0-3.29,0.752-4.184,1.927v9.494c0.611,0.986,2.068,1.974,4.184,1.974
+			C193.857,38.759,195.596,36.363,195.596,32.085z"/>
+		<path fill="#1E5B96" d="M206.877,20.054h6.109v2.115c0.705-1.504,2.068-2.679,4.465-2.679c2.021,0,3.525,0.704,4.889,1.833
+			l-0.848,5.592c-1.127-0.799-2.49-1.409-4.369-1.409c-2.115,0-4.137,1.033-4.137,5.169V44.07h-6.109V20.054z"/>
+		<path fill="#1E5B96" d="M223.984,32.085c0-7.802,4.277-12.595,11.045-12.595s11.043,4.793,11.043,12.595
+			c0,7.896-4.275,12.549-11.043,12.549S223.984,39.981,223.984,32.085z M239.963,32.085c0-4.183-1.832-6.721-4.934-6.721
+			c-3.008,0-4.936,2.538-4.936,6.721s1.928,6.674,4.936,6.674C238.131,38.759,239.963,36.268,239.963,32.085z"/>
+		<path fill="#1E5B96" d="M250.068,32.038c0-7.755,4.23-12.548,9.965-12.548c2.396,0,4.041,0.939,5.121,2.303V12.91l6.111-2.772
+			V44.07h-6.111v-1.74c-0.986,1.457-2.725,2.304-5.168,2.304C253.971,44.634,250.068,40.169,250.068,32.038z M265.154,36.832v-9.493
+			c-0.656-0.894-2.066-1.975-4.182-1.975c-3.055,0-4.793,2.35-4.793,6.674c0,4.136,1.645,6.721,4.793,6.721
+			C262.994,38.759,264.262,38.101,265.154,36.832z"/>
+		<path fill="#1E5B96" d="M292.227,41.814c-1.457,1.833-3.666,2.82-6.439,2.82c-4.088,0-8.412-2.304-8.412-9.447V20.054h6.109
+			v13.159c0,3.854,1.316,5.546,4.184,5.546c2.914,0,4.559-1.598,4.559-5.452V20.054h6.109V44.07h-6.109v-2.256H292.227z"/>
+		<path fill="#1E5B96" d="M303.508,32.085c0-7.802,4.324-12.595,10.949-12.595c4.889,0,8.461,2.161,10.012,7.049l-5.828,1.927
+			c-0.705-1.832-2.115-3.102-4.041-3.102c-2.961,0-4.889,2.679-4.889,6.721c0,4.089,1.928,6.674,4.746,6.674
+			c2.068,0,3.525-1.222,4.23-3.478l5.828,1.738c-1.457,5.076-4.842,7.614-10.059,7.614
+			C307.832,44.634,303.508,39.981,303.508,32.085z"/>
+		<path fill="#1E5B96" d="M329.217,13.662c0-1.974,1.598-3.524,3.572-3.524c2.02,0,3.57,1.551,3.57,3.524s-1.551,3.572-3.57,3.572
+			C330.815,17.235,329.217,15.636,329.217,13.662z M329.734,20.054h6.109V44.07h-6.109V20.054z"/>
+		<path fill="#1E5B96" d="M348.346,42.33v1.739h-6.111V12.911l6.111-2.772v11.655c1.08-1.363,2.725-2.303,5.121-2.303
+			c5.734,0,9.965,4.793,9.965,12.548c0,8.131-3.949,12.596-10.199,12.596C350.93,44.634,349.426,43.834,348.346,42.33z
+			 M357.322,32.038c0-4.324-1.74-6.674-4.795-6.674c-2.115,0-3.525,1.034-4.182,1.975v9.493c0.893,1.269,2.16,1.927,4.182,1.927
+			C355.676,38.759,357.322,36.174,357.322,32.038z"/>
+		<path fill="#1E5B96" d="M368.836,13.004l6.109-2.866V44.07h-6.109V13.004z"/>
+		<path fill="#1E5B96" d="M380.352,32.038c0-7.755,4.371-12.548,11.232-12.548c5.922,0,10.621,3.618,10.621,11.326
+			c0,0.939,0,2.303-0.188,3.618h-15.65c0.234,3.103,2.584,4.841,5.217,4.841c2.209,0,3.807-0.752,5.17-2.49l3.76,3.807
+			c-2.021,2.443-4.936,4.042-8.93,4.042C384.629,44.634,380.352,39.934,380.352,32.038z M396.236,29.266
+			c-0.375-2.82-2.209-4.418-4.652-4.418c-2.867,0-4.795,1.41-5.17,4.418C386.414,29.266,396.236,29.266,396.236,29.266z"/>
+		<path fill="#1E5B96" d="M138.517,52.869c9.297,0,12.209,5.152,12.209,10.36c0,3.584-2.129,6.608-5.769,8.176
+			c4.536,1.4,7.168,4.928,7.168,9.408c0,5.32-3.136,11.256-12.712,11.256h-14.784v-39.2
+			C124.629,52.869,138.517,52.869,138.517,52.869z M145.91,63.286c0-2.855-1.232-5.991-7.112-5.991h-9.296v12.207h8.064
+			C143.109,69.501,145.91,67.037,145.91,63.286z M147.31,81.15c0-3.752-1.793-7.224-9.129-7.224h-8.68v13.663h10.473
+			C145.742,87.589,147.31,84.286,147.31,81.15z"/>
+		<path fill="#1E5B96" d="M178.22,89.326c-1.903,2.464-4.199,3.416-7.223,3.416c-6.721,0-10.416-3.584-10.416-12.768V63.453h4.871
+			v17.248c0,5.433,2.633,7.504,6.16,7.504c3.752,0,6.607-1.792,6.607-7.392v-17.36h4.873V92.07h-4.873v-2.744H178.22z"/>
+		<path fill="#1E5B96" d="M192.164,55.222c0-1.736,1.345-3.136,3.024-3.136c1.736,0,3.08,1.399,3.08,3.136
+			c0,1.68-1.344,3.023-3.08,3.023C193.508,58.245,192.164,56.902,192.164,55.222z M192.781,63.453h4.871V92.07h-4.871V63.453z"/>
+		<path fill="#1E5B96" d="M207.564,53.934l4.871-2.296V92.07h-4.871V53.934z"/>
+		<path fill="#1E5B96" d="M220.611,77.734c0-9.408,4.705-14.952,11.816-14.952c3.359,0,5.6,1.232,7.225,2.688V53.934l4.871-2.296
+			V92.07h-4.871v-2.24c-1.625,1.681-3.809,2.912-7.225,2.912C225.148,92.742,220.611,86.974,220.611,77.734z M239.652,84.342v-13.44
+			c-1.064-1.68-3.248-3.64-6.553-3.64c-4.816,0-7.561,3.752-7.561,10.472c0,5.936,2.857,10.472,7.561,10.472
+			C235.787,88.205,238.195,86.806,239.652,84.342z"/>
+		<path fill="#1E5B96" d="M252.195,87.926l3.473-2.969c1.455,1.568,3.92,3.416,7,3.416c3.023,0,5.32-1.12,5.32-3.64
+			c0-2.856-3.193-4.144-6.553-5.432c-5.264-1.96-8.848-4.256-8.848-8.96s4.145-7.561,9.631-7.561c4.369,0,7.561,1.849,9.633,4.313
+			l-3.359,2.8c-1.232-1.288-3.248-2.744-6.328-2.744c-2.912,0-4.76,1.176-4.76,3.192c0,2.407,2.855,3.472,6.047,4.76
+			c5.209,1.848,9.297,4.088,9.297,9.52c0,5.152-3.977,8.12-10.193,8.12C258.355,92.742,254.435,90.782,252.195,87.926z"/>
+	</g>
+</g>
+</svg>


=====================================
visualizer/templates/index.html
=====================================
@@ -0,0 +1,23 @@
+<!DOCTYPE html>
+<html>
+  <head>
+    <title> All sources </title>
+    <link rel='stylesheet' href='/static/css/main.css'>
+    <link rel='stylesheet' href='/static/css/skeleton.css'>
+    <link rel='stylesheet' href='/static/css/normalize.css'>
+  </head>
+  <body>
+    <div class="home">
+    <header class="site-header">
+
+      <h1><img src="/static/images/logos/icon_white.svg" style="height: 2ex; vertical-align: middle"> reproducible<span class="punctuation">-</span>builds<span class="punctuation">.org</span></h1>
+    </header>
+    <div class="container">
+      <article>
+          {{ request.host }}'s debian rebulider setup for.
+
+          Check out <a href='/sources'>a list of the packages re-built on this instance</a>
+      </article>
+    </div>
+  </body>
+</html>


=====================================
visualizer/visualizer.py
=====================================
@@ -7,6 +7,10 @@ app = Flask(__name__)
 DIR = '/var/builds/'
 DATABASE = '/var/rebuilder.db'
 
+ at app.route("/")
+def index():
+    return render_template('index.html')
+
 
 def get_db():
     db = getattr(g, '_database', None)



View it on GitLab: https://salsa.debian.org/reproducible-builds/debian-rebuilder-setup/commit/049b593f373caf4660b28fb3f468515cd8f17f75

-- 
View it on GitLab: https://salsa.debian.org/reproducible-builds/debian-rebuilder-setup/commit/049b593f373caf4660b28fb3f468515cd8f17f75
You're receiving this email because of your account on salsa.debian.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.reproducible-builds.org/pipermail/rb-commits/attachments/20181129/56b4485d/attachment.html>


More information about the rb-commits mailing list