diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 00000000..adf3373d --- /dev/null +++ b/.gitmodules @@ -0,0 +1,3 @@ +[submodule "_site/themes/docdock"] + path = _site/themes/docdock + url = https://github.com/vjeantet/hugo-theme-docdock.git diff --git a/_site/config.toml b/_site/config.toml index ed79d848..60465521 100644 --- a/_site/config.toml +++ b/_site/config.toml @@ -1,12 +1,62 @@ -baseURL = "https://wtfutil.com/" +baseURL = "/" + languageCode = "en-us" +DefaultContentLanguage = "en" +title = "WTF - the terminal dashboard" +theme = "docdock" +# themesdir = "../.." pygmentsCodeFences = true -pygmentsUseClasses = true -publishDir = "../docs" -sectionPagesMenu = "main" -theme = "hyde-hyde" -title = "WTF - A Terminal Dashboard" +pygmentsStyle = "monokailight" + +defaultContentLanguage = "en" +defaultContentLanguageInSubdir= false +enableMissingTranslationPlaceholders = false + + +# [Languages] +# [Languages.en] +# title = "Documentation for WTF" +# weight = 1 +# languageName = "English" +# +# [Languages.fr] +# title = "Documentation du WTF" +# weight = 2 +# languageName = "Français" + + + [params] - author = "Chris Cummer" - authorimage = "/img/wtf.png" +editURL = "https://github.com/vjeantet/hugo-theme-docdock/edit/master/exampleSite/content/" +showVisitedLinks = true # default is false +themeStyle = "flex" # "original" or "flex" # default "flex" +themeVariant = "" # choose theme variant "green", "gold" , "gray", "blue" (default) +ordersectionsby = "weight" # ordersectionsby = "title" +disableHomeIcon = false # default is false +disableSearch = false # default is false +disableNavChevron = false # set true to hide next/prev chevron, default is false +highlightClientSide = false # set true to use highlight.pack.js instead of the default hugo chroma highlighter +menushortcutsnewtab = false # set true to open shortcuts links to a new tab/window +enableGitInfo = true + +[outputs] +home = [ "HTML", "RSS", "JSON"] + + +[[menu.shortcuts]] +pre = "

More

" +name = " " +identifier = "ds" +url = "https://github.com/senorprogrammer/wtf" +weight = 10 + +[[menu.shortcuts]] +name = " " +url = "https://github.com/senorprogrammer/wtf/releases" +weight = 11 + +[[menu.shortcuts]] +name = " " +url = "https://github.com/senorprogrammer/wtf/blob/master/README.md" +weight = 30 diff --git a/_site/config.toml-orig b/_site/config.toml-orig new file mode 100644 index 00000000..ed79d848 --- /dev/null +++ b/_site/config.toml-orig @@ -0,0 +1,12 @@ +baseURL = "https://wtfutil.com/" +languageCode = "en-us" +pygmentsCodeFences = true +pygmentsUseClasses = true +publishDir = "../docs" +sectionPagesMenu = "main" +theme = "hyde-hyde" +title = "WTF - A Terminal Dashboard" + +[params] + author = "Chris Cummer" + authorimage = "/img/wtf.png" diff --git a/_site/public/404.html b/_site/public/404.html new file mode 100644 index 00000000..5e6a2f00 --- /dev/null +++ b/_site/public/404.html @@ -0,0 +1,442 @@ + + + + WTF - the terminal dashboard + + + + +404 Page not found :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+ + +
+ + + + + + +
+ + +

404 Page not found

+ + +

Error

+

+

+

Woops. Looks like this page doesn't exist.

+

+

Go to homepage

+

+ + +
+ +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + diff --git a/_site/public/categories/index.html b/_site/public/categories/index.html new file mode 100644 index 00000000..486f4298 --- /dev/null +++ b/_site/public/categories/index.html @@ -0,0 +1,459 @@ + + + + WTF - the terminal dashboard + + + + +Categories :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+ + +
+ + + + + + +
+ + +

Categories

+ + + + + + +
+ + +
+ + + +
+ + + + + + + + +
+ +
+ +
+
+ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/_site/public/categories/index.xml b/_site/public/categories/index.xml new file mode 100644 index 00000000..879aea08 --- /dev/null +++ b/_site/public/categories/index.xml @@ -0,0 +1,14 @@ + + + + Categories on WTF - the terminal dashboard + /categories/ + Recent content in Categories on WTF - the terminal dashboard + Hugo -- gohugo.io + en-us + + + + + + \ No newline at end of file diff --git a/_site/public/categories/page/1/index.html b/_site/public/categories/page/1/index.html new file mode 100644 index 00000000..504f47ad --- /dev/null +++ b/_site/public/categories/page/1/index.html @@ -0,0 +1 @@ +/categories/ \ No newline at end of file diff --git a/_site/public/css/auto-complete.css b/_site/public/css/auto-complete.css new file mode 100644 index 00000000..c144cd38 --- /dev/null +++ b/_site/public/css/auto-complete.css @@ -0,0 +1,49 @@ +.autocomplete-suggestions { + text-align: left; + cursor: default; + border: 1px solid #ccc; + border-top: 0; + background: #fff; + box-shadow: 1px 2px 6px; + transition: left 0.1s ease-in-out; + + /* core styles should not be changed */ + position: absolute; + display: none; + z-index: 9999; + max-height: 70vh; + width: 265px; + overflow: hidden; + overflow-y: hidden; + box-sizing: border-box; + +} +.autocomplete-suggestion { + position: relative; + cursor: pointer; + padding: 7px; + line-height: 23px; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + color: #333; +} + +.autocomplete-suggestion b { + font-weight: normal; + color: #1f8dd6; +} + +.autocomplete-suggestion.selected { + background: #333; + color: #fff; +} + +.autocomplete-suggestion:hover { + background: #444; + color: #fff; +} + +.autocomplete-suggestion > .context { + font-size: 12px; +} diff --git a/_site/public/css/bootstrap.min.css b/_site/public/css/bootstrap.min.css new file mode 100644 index 00000000..156aa3c7 --- /dev/null +++ b/_site/public/css/bootstrap.min.css @@ -0,0 +1 @@ +.btn,.glyphicon{display:inline-block}.btn,[role=button]{cursor:pointer}.btn,.btn-danger.active,.btn-danger:active,.btn-default.active,.btn-default:active,.btn-info.active,.btn-info:active,.btn-primary.active,.btn-primary:active,.btn-success.active,.btn-success:active,.btn-warning.active,.btn-warning:active,.open>.dropdown-toggle.btn-danger,.open>.dropdown-toggle.btn-default,.open>.dropdown-toggle.btn-info,.open>.dropdown-toggle.btn-primary,.open>.dropdown-toggle.btn-success,.open>.dropdown-toggle.btn-warning{background-image:none}@font-face{font-family:'Glyphicons Halflings';src:url(../fonts/glyphicons-halflings-regular.eot);src:url(../fonts/glyphicons-halflings-regular.eot?#iefix) format('embedded-opentype'),url(../fonts/glyphicons-halflings-regular.woff2) format('woff2'),url(../fonts/glyphicons-halflings-regular.woff) format('woff'),url(../fonts/glyphicons-halflings-regular.ttf) format('truetype'),url(../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular) format('svg')}.glyphicon{position:relative;top:1px;font-family:'Glyphicons Halflings';font-style:normal;font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\2a"}.glyphicon-plus:before{content:"\2b"}.glyphicon-eur:before,.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before,.glyphicon-btc:before,.glyphicon-xbt:before{content:"\e227"}.glyphicon-jpy:before,.glyphicon-yen:before{content:"\00a5"}.glyphicon-rub:before,.glyphicon-ruble:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert>p,.alert>ul,.btn{margin-bottom:0}.alert h4{margin-top:0;color:inherit}.alert>p+p,.btn-block+.btn-block{margin-top:5px}.alert .alert-link{font-weight:700}.btn,.btn-link{font-weight:400}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.btn .badge,.btn .label{position:relative;top:-1px}.alert-success{background-color:#dff0d8;border-color:#d6e9c6;color:#3c763d}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{background-color:#d9edf7;border-color:#bce8f1;color:#31708f}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{background-color:#fcf8e3;border-color:#faebcc;color:#8a6d3b}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{background-color:#f2dede;border-color:#ebccd1;color:#a94442}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}.btn{text-align:center;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;border:1px solid transparent;white-space:nowrap;padding:6px 12px;font-size:14px;line-height:1.42857143;border-radius:4px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:dotted thin;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{outline:0;background-image:none;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);-webkit-box-shadow:none;box-shadow:none}a.btn.disabled,fieldset[disabled] a.btn{pointer-events:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.focus,.btn-default:focus{color:#333;background-color:#e6e6e6;border-color:#8c8c8c}.btn-default.active,.btn-default:active,.btn-default:hover,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active.focus,.btn-default.active:focus,.btn-default.active:hover,.btn-default:active.focus,.btn-default:active:focus,.btn-default:active:hover,.open>.dropdown-toggle.btn-default.focus,.open>.dropdown-toggle.btn-default:focus,.open>.dropdown-toggle.btn-default:hover{color:#333;background-color:#d4d4d4;border-color:#8c8c8c}.btn-default.disabled,.btn-default.disabled.active,.btn-default.disabled.focus,.btn-default.disabled:active,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled],.btn-default[disabled].active,.btn-default[disabled].focus,.btn-default[disabled]:active,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default,fieldset[disabled] .btn-default.active,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:active,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#337ab7;border-color:#2e6da4}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#286090;border-color:#122b40}.btn-primary.active,.btn-primary:active,.btn-primary:hover,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{color:#fff;background-color:#204d74;border-color:#122b40}.btn-primary.disabled,.btn-primary.disabled.active,.btn-primary.disabled.focus,.btn-primary.disabled:active,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled],.btn-primary[disabled].active,.btn-primary[disabled].focus,.btn-primary[disabled]:active,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary,fieldset[disabled] .btn-primary.active,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:active,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#337ab7;border-color:#2e6da4}.btn-primary .badge{color:#337ab7;background-color:#fff}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#449d44;border-color:#255625}.btn-success.active,.btn-success:active,.btn-success:hover,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover{color:#fff;background-color:#398439;border-color:#255625}.btn-success.disabled,.btn-success.disabled.active,.btn-success.disabled.focus,.btn-success.disabled:active,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled],.btn-success[disabled].active,.btn-success[disabled].focus,.btn-success[disabled]:active,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success,fieldset[disabled] .btn-success.active,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:active,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#5cb85c;border-color:#4cae4c}.btn-success .badge{color:#5cb85c;background-color:#fff}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#31b0d5;border-color:#1b6d85}.btn-info.active,.btn-info:active,.btn-info:hover,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active.focus,.btn-info.active:focus,.btn-info.active:hover,.btn-info:active.focus,.btn-info:active:focus,.btn-info:active:hover,.open>.dropdown-toggle.btn-info.focus,.open>.dropdown-toggle.btn-info:focus,.open>.dropdown-toggle.btn-info:hover{color:#fff;background-color:#269abc;border-color:#1b6d85}.btn-info.disabled,.btn-info.disabled.active,.btn-info.disabled.focus,.btn-info.disabled:active,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled],.btn-info[disabled].active,.btn-info[disabled].focus,.btn-info[disabled]:active,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info,fieldset[disabled] .btn-info.active,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:active,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#5bc0de;border-color:#46b8da}.btn-info .badge{color:#5bc0de;background-color:#fff}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning.focus,.btn-warning:focus{color:#fff;background-color:#ec971f;border-color:#985f0d}.btn-warning.active,.btn-warning:active,.btn-warning:hover,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover{color:#fff;background-color:#d58512;border-color:#985f0d}.btn-warning.disabled,.btn-warning.disabled.active,.btn-warning.disabled.focus,.btn-warning.disabled:active,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled],.btn-warning[disabled].active,.btn-warning[disabled].focus,.btn-warning[disabled]:active,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning,fieldset[disabled] .btn-warning.active,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:active,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#f0ad4e;border-color:#eea236}.btn-warning .badge{color:#f0ad4e;background-color:#fff}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#c9302c;border-color:#761c19}.btn-danger.active,.btn-danger:active,.btn-danger:hover,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active.focus,.btn-danger.active:focus,.btn-danger.active:hover,.btn-danger:active.focus,.btn-danger:active:focus,.btn-danger:active:hover,.open>.dropdown-toggle.btn-danger.focus,.open>.dropdown-toggle.btn-danger:focus,.open>.dropdown-toggle.btn-danger:hover{color:#fff;background-color:#ac2925;border-color:#761c19}.btn-danger.disabled,.btn-danger.disabled.active,.btn-danger.disabled.focus,.btn-danger.disabled:active,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled],.btn-danger[disabled].active,.btn-danger[disabled].focus,.btn-danger[disabled]:active,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger,fieldset[disabled] .btn-danger.active,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:active,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#d9534f;border-color:#d43f3a}.btn-danger .badge{color:#d9534f;background-color:#fff}.btn-link{color:#337ab7;border-radius:0}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#23527c;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-sm,.btn-xs{font-size:12px;line-height:1.5;border-radius:3px}.btn-sm{padding:5px 10px}.btn-xs{padding:1px 5px}.badge,.label{font-weight:700;line-height:1;white-space:nowrap;text-align:center;color:#fff}.btn-block{display:block;width:100%}.label{display:inline;padding:.2em .6em .3em;font-size:75%;vertical-align:baseline;border-radius:.25em}a.label:focus,a.label:hover{color:#fff;text-decoration:none;cursor:pointer}.label:empty{display:none}.label-default{background-color:#777}.label-default[href]:focus,.label-default[href]:hover{background-color:#5e5e5e}.label-primary{background-color:#337ab7}.label-primary[href]:focus,.label-primary[href]:hover{background-color:#286090}.label-success{background-color:#5cb85c}.label-success[href]:focus,.label-success[href]:hover{background-color:#449d44}.label-info{background-color:#5bc0de}.label-info[href]:focus,.label-info[href]:hover{background-color:#31b0d5}.label-warning{background-color:#f0ad4e}.label-warning[href]:focus,.label-warning[href]:hover{background-color:#ec971f}.label-danger{background-color:#d9534f}.label-danger[href]:focus,.label-danger[href]:hover{background-color:#c9302c}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;vertical-align:middle;background-color:#777;border-radius:10px}.badge:empty{display:none}.btn-group-xs>.btn .badge,.btn-xs .badge{top:0;padding:1px 5px}a.badge:focus,a.badge:hover{color:#fff;text-decoration:none;cursor:pointer}.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#337ab7;background-color:#fff}.panel-heading>.dropdown .dropdown-toggle,.panel-title,.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}.nav-pills>li>a>.badge{margin-left:3px}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,.05);box-shadow:0 1px 1px rgba(0,0,0,.05)}.panel-title,.panel>.list-group,.panel>.panel-collapse>.list-group,.panel>.panel-collapse>.table,.panel>.table,.panel>.table-responsive>.table{margin-bottom:0}.panel-body{padding:15px}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-right-radius:3px;border-top-left-radius:3px}.panel-title{margin-top:0;font-size:16px}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.list-group .list-group-item,.panel>.panel-collapse>.list-group .list-group-item{border-width:1px 0;border-radius:0}.panel-group .panel-heading,.panel>.table-bordered>tbody>tr:first-child>td,.panel>.table-bordered>tbody>tr:first-child>th,.panel>.table-bordered>tbody>tr:last-child>td,.panel>.table-bordered>tbody>tr:last-child>th,.panel>.table-bordered>tfoot>tr:last-child>td,.panel>.table-bordered>tfoot>tr:last-child>th,.panel>.table-bordered>thead>tr:first-child>td,.panel>.table-bordered>thead>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>th,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>td,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>th,.panel>.table-responsive>.table-bordered>thead>tr:first-child>td,.panel>.table-responsive>.table-bordered>thead>tr:first-child>th{border-bottom:0}.panel>.table-responsive:last-child>.table:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child,.panel>.table:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child{border-bottom-left-radius:3px;border-bottom-right-radius:3px}.panel>.list-group:first-child .list-group-item:first-child,.panel>.panel-collapse>.list-group:first-child .list-group-item:first-child{border-top:0;border-top-right-radius:3px;border-top-left-radius:3px}.panel>.list-group:last-child .list-group-item:last-child,.panel>.panel-collapse>.list-group:last-child .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.panel-heading+.panel-collapse>.list-group .list-group-item:first-child{border-top-right-radius:0;border-top-left-radius:0}.panel>.table-responsive:first-child>.table:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child,.panel>.table:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child,.panel>.table:first-child>thead:first-child>tr:first-child{border-top-right-radius:3px;border-top-left-radius:3px}.list-group+.panel-footer,.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.panel>.panel-collapse>.table caption,.panel>.table caption,.panel>.table-responsive>.table caption{padding-left:15px;padding-right:15px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table:first-child>thead:first-child>tr:first-child th:first-child{border-top-left-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table:first-child>thead:first-child>tr:first-child th:last-child{border-top-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:first-child{border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:last-child{border-bottom-right-radius:3px}.panel>.panel-body+.table,.panel>.panel-body+.table-responsive,.panel>.table+.panel-body,.panel>.table-responsive+.panel-body{border-top:1px solid #ddd}.panel>.table>tbody:first-child>tr:first-child td,.panel>.table>tbody:first-child>tr:first-child th{border-top:0}.panel>.table-bordered,.panel>.table-responsive>.table-bordered{border:0}.panel>.table-bordered>tbody>tr>td:first-child,.panel>.table-bordered>tbody>tr>th:first-child,.panel>.table-bordered>tfoot>tr>td:first-child,.panel>.table-bordered>tfoot>tr>th:first-child,.panel>.table-bordered>thead>tr>td:first-child,.panel>.table-bordered>thead>tr>th:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:first-child,.panel>.table-responsive>.table-bordered>thead>tr>td:first-child,.panel>.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.panel>.table-bordered>tbody>tr>td:last-child,.panel>.table-bordered>tbody>tr>th:last-child,.panel>.table-bordered>tfoot>tr>td:last-child,.panel>.table-bordered>tfoot>tr>th:last-child,.panel>.table-bordered>thead>tr>td:last-child,.panel>.table-bordered>thead>tr>th:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:last-child,.panel>.table-responsive>.table-bordered>thead>tr>td:last-child,.panel>.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.panel>.table-responsive{border:0;margin-bottom:0}.panel-group{margin-bottom:20px}.panel-group .panel{margin-bottom:0;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading+.panel-collapse>.list-group,.panel-group .panel-heading+.panel-collapse>.panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ddd}.panel-default>.panel-heading .badge{color:#f5f5f5;background-color:#333}.panel-default>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#337ab7}.panel-primary>.panel-heading{color:#fff;background-color:#337ab7;border-color:#337ab7}.panel-primary>.panel-heading+.panel-collapse>.panel-body{border-top-color:#337ab7}.panel-primary>.panel-heading .badge{color:#337ab7;background-color:#fff}.panel-primary>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#337ab7}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse>.panel-body{border-top-color:#d6e9c6}.panel-success>.panel-heading .badge{color:#dff0d8;background-color:#3c763d}.panel-success>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#d6e9c6}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse>.panel-body{border-top-color:#bce8f1}.panel-info>.panel-heading .badge{color:#d9edf7;background-color:#31708f}.panel-info>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#bce8f1}.panel-warning{border-color:#faebcc}.panel-warning>.panel-heading{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.panel-warning>.panel-heading+.panel-collapse>.panel-body{border-top-color:#faebcc}.panel-warning>.panel-heading .badge{color:#fcf8e3;background-color:#8a6d3b}.panel-warning>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#faebcc}.panel-danger{border-color:#ebccd1}.panel-danger>.panel-heading{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.panel-danger>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ebccd1}.panel-danger>.panel-heading .badge{color:#f2dede;background-color:#a94442}.panel-danger>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ebccd1}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.05);box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px} diff --git a/_site/public/css/featherlight.min.css b/_site/public/css/featherlight.min.css new file mode 100644 index 00000000..f225bec5 --- /dev/null +++ b/_site/public/css/featherlight.min.css @@ -0,0 +1,8 @@ +/** + * Featherlight - ultra slim jQuery lightbox + * Version 1.2.3 - http://noelboss.github.io/featherlight/ + * + * Copyright 2015, Noël Raoul Bossart (http://www.noelboss.com) + * MIT Licensed. +**/ +@media all{.featherlight{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:2147483647;text-align:center;white-space:nowrap;cursor:pointer;background:#333;background:rgba(0,0,0,0)}.featherlight:last-of-type{background:rgba(0,0,0,.8)}.featherlight:before{content:'';display:inline-block;height:100%;vertical-align:middle;margin-right:-.25em}.featherlight .featherlight-content{position:relative;text-align:left;vertical-align:middle;display:inline-block;overflow:auto;padding:25px 25px 0;border-bottom:25px solid transparent;min-width:30%;margin-left:5%;margin-right:5%;max-height:95%;background:#fff;cursor:auto;white-space:normal}.featherlight .featherlight-inner{display:block}.featherlight .featherlight-close-icon{position:absolute;z-index:9999;top:0;right:0;line-height:25px;width:25px;cursor:pointer;text-align:center;font:Arial,sans-serif;background:#fff;background:rgba(255,255,255,.3);color:#000}.featherlight .featherlight-image{width:100%}.featherlight-iframe .featherlight-content{border-bottom:0;padding:0}.featherlight iframe{border:0}}@media only screen and (max-width:1024px){.featherlight .featherlight-content{margin-left:10px;margin-right:10px;max-height:98%;padding:10px 10px 0;border-bottom:10px solid transparent}} \ No newline at end of file diff --git a/_site/public/css/font-awesome.min.css b/_site/public/css/font-awesome.min.css new file mode 100644 index 00000000..540440ce --- /dev/null +++ b/_site/public/css/font-awesome.min.css @@ -0,0 +1,4 @@ +/*! + * Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome + * License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License) + */@font-face{font-family:'FontAwesome';src:url('../fonts/fontawesome-webfont.eot?v=4.7.0');src:url('../fonts/fontawesome-webfont.eot?#iefix&v=4.7.0') format('embedded-opentype'),url('../fonts/fontawesome-webfont.woff2?v=4.7.0') format('woff2'),url('../fonts/fontawesome-webfont.woff?v=4.7.0') format('woff'),url('../fonts/fontawesome-webfont.ttf?v=4.7.0') format('truetype'),url('../fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular') format('svg');font-weight:normal;font-style:normal}.fa{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-lg{font-size:1.33333333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571429em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14285714em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14285714em;width:2.14285714em;top:.14285714em;text-align:center}.fa-li.fa-lg{left:-1.85714286em}.fa-border{padding:.2em .25em .15em;border:solid .08em #eee;border-radius:.1em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa.fa-pull-left{margin-right:.3em}.fa.fa-pull-right{margin-left:.3em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}.fa-pulse{-webkit-animation:fa-spin 1s infinite steps(8);animation:fa-spin 1s infinite steps(8)}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)";-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)";-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)";-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)";-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.fa-flip-vertical{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)";-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:"\f000"}.fa-music:before{content:"\f001"}.fa-search:before{content:"\f002"}.fa-envelope-o:before{content:"\f003"}.fa-heart:before{content:"\f004"}.fa-star:before{content:"\f005"}.fa-star-o:before{content:"\f006"}.fa-user:before{content:"\f007"}.fa-film:before{content:"\f008"}.fa-th-large:before{content:"\f009"}.fa-th:before{content:"\f00a"}.fa-th-list:before{content:"\f00b"}.fa-check:before{content:"\f00c"}.fa-remove:before,.fa-close:before,.fa-times:before{content:"\f00d"}.fa-search-plus:before{content:"\f00e"}.fa-search-minus:before{content:"\f010"}.fa-power-off:before{content:"\f011"}.fa-signal:before{content:"\f012"}.fa-gear:before,.fa-cog:before{content:"\f013"}.fa-trash-o:before{content:"\f014"}.fa-home:before{content:"\f015"}.fa-file-o:before{content:"\f016"}.fa-clock-o:before{content:"\f017"}.fa-road:before{content:"\f018"}.fa-download:before{content:"\f019"}.fa-arrow-circle-o-down:before{content:"\f01a"}.fa-arrow-circle-o-up:before{content:"\f01b"}.fa-inbox:before{content:"\f01c"}.fa-play-circle-o:before{content:"\f01d"}.fa-rotate-right:before,.fa-repeat:before{content:"\f01e"}.fa-refresh:before{content:"\f021"}.fa-list-alt:before{content:"\f022"}.fa-lock:before{content:"\f023"}.fa-flag:before{content:"\f024"}.fa-headphones:before{content:"\f025"}.fa-volume-off:before{content:"\f026"}.fa-volume-down:before{content:"\f027"}.fa-volume-up:before{content:"\f028"}.fa-qrcode:before{content:"\f029"}.fa-barcode:before{content:"\f02a"}.fa-tag:before{content:"\f02b"}.fa-tags:before{content:"\f02c"}.fa-book:before{content:"\f02d"}.fa-bookmark:before{content:"\f02e"}.fa-print:before{content:"\f02f"}.fa-camera:before{content:"\f030"}.fa-font:before{content:"\f031"}.fa-bold:before{content:"\f032"}.fa-italic:before{content:"\f033"}.fa-text-height:before{content:"\f034"}.fa-text-width:before{content:"\f035"}.fa-align-left:before{content:"\f036"}.fa-align-center:before{content:"\f037"}.fa-align-right:before{content:"\f038"}.fa-align-justify:before{content:"\f039"}.fa-list:before{content:"\f03a"}.fa-dedent:before,.fa-outdent:before{content:"\f03b"}.fa-indent:before{content:"\f03c"}.fa-video-camera:before{content:"\f03d"}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:"\f03e"}.fa-pencil:before{content:"\f040"}.fa-map-marker:before{content:"\f041"}.fa-adjust:before{content:"\f042"}.fa-tint:before{content:"\f043"}.fa-edit:before,.fa-pencil-square-o:before{content:"\f044"}.fa-share-square-o:before{content:"\f045"}.fa-check-square-o:before{content:"\f046"}.fa-arrows:before{content:"\f047"}.fa-step-backward:before{content:"\f048"}.fa-fast-backward:before{content:"\f049"}.fa-backward:before{content:"\f04a"}.fa-play:before{content:"\f04b"}.fa-pause:before{content:"\f04c"}.fa-stop:before{content:"\f04d"}.fa-forward:before{content:"\f04e"}.fa-fast-forward:before{content:"\f050"}.fa-step-forward:before{content:"\f051"}.fa-eject:before{content:"\f052"}.fa-chevron-left:before{content:"\f053"}.fa-chevron-right:before{content:"\f054"}.fa-plus-circle:before{content:"\f055"}.fa-minus-circle:before{content:"\f056"}.fa-times-circle:before{content:"\f057"}.fa-check-circle:before{content:"\f058"}.fa-question-circle:before{content:"\f059"}.fa-info-circle:before{content:"\f05a"}.fa-crosshairs:before{content:"\f05b"}.fa-times-circle-o:before{content:"\f05c"}.fa-check-circle-o:before{content:"\f05d"}.fa-ban:before{content:"\f05e"}.fa-arrow-left:before{content:"\f060"}.fa-arrow-right:before{content:"\f061"}.fa-arrow-up:before{content:"\f062"}.fa-arrow-down:before{content:"\f063"}.fa-mail-forward:before,.fa-share:before{content:"\f064"}.fa-expand:before{content:"\f065"}.fa-compress:before{content:"\f066"}.fa-plus:before{content:"\f067"}.fa-minus:before{content:"\f068"}.fa-asterisk:before{content:"\f069"}.fa-exclamation-circle:before{content:"\f06a"}.fa-gift:before{content:"\f06b"}.fa-leaf:before{content:"\f06c"}.fa-fire:before{content:"\f06d"}.fa-eye:before{content:"\f06e"}.fa-eye-slash:before{content:"\f070"}.fa-warning:before,.fa-exclamation-triangle:before{content:"\f071"}.fa-plane:before{content:"\f072"}.fa-calendar:before{content:"\f073"}.fa-random:before{content:"\f074"}.fa-comment:before{content:"\f075"}.fa-magnet:before{content:"\f076"}.fa-chevron-up:before{content:"\f077"}.fa-chevron-down:before{content:"\f078"}.fa-retweet:before{content:"\f079"}.fa-shopping-cart:before{content:"\f07a"}.fa-folder:before{content:"\f07b"}.fa-folder-open:before{content:"\f07c"}.fa-arrows-v:before{content:"\f07d"}.fa-arrows-h:before{content:"\f07e"}.fa-bar-chart-o:before,.fa-bar-chart:before{content:"\f080"}.fa-twitter-square:before{content:"\f081"}.fa-facebook-square:before{content:"\f082"}.fa-camera-retro:before{content:"\f083"}.fa-key:before{content:"\f084"}.fa-gears:before,.fa-cogs:before{content:"\f085"}.fa-comments:before{content:"\f086"}.fa-thumbs-o-up:before{content:"\f087"}.fa-thumbs-o-down:before{content:"\f088"}.fa-star-half:before{content:"\f089"}.fa-heart-o:before{content:"\f08a"}.fa-sign-out:before{content:"\f08b"}.fa-linkedin-square:before{content:"\f08c"}.fa-thumb-tack:before{content:"\f08d"}.fa-external-link:before{content:"\f08e"}.fa-sign-in:before{content:"\f090"}.fa-trophy:before{content:"\f091"}.fa-github-square:before{content:"\f092"}.fa-upload:before{content:"\f093"}.fa-lemon-o:before{content:"\f094"}.fa-phone:before{content:"\f095"}.fa-square-o:before{content:"\f096"}.fa-bookmark-o:before{content:"\f097"}.fa-phone-square:before{content:"\f098"}.fa-twitter:before{content:"\f099"}.fa-facebook-f:before,.fa-facebook:before{content:"\f09a"}.fa-github:before{content:"\f09b"}.fa-unlock:before{content:"\f09c"}.fa-credit-card:before{content:"\f09d"}.fa-feed:before,.fa-rss:before{content:"\f09e"}.fa-hdd-o:before{content:"\f0a0"}.fa-bullhorn:before{content:"\f0a1"}.fa-bell:before{content:"\f0f3"}.fa-certificate:before{content:"\f0a3"}.fa-hand-o-right:before{content:"\f0a4"}.fa-hand-o-left:before{content:"\f0a5"}.fa-hand-o-up:before{content:"\f0a6"}.fa-hand-o-down:before{content:"\f0a7"}.fa-arrow-circle-left:before{content:"\f0a8"}.fa-arrow-circle-right:before{content:"\f0a9"}.fa-arrow-circle-up:before{content:"\f0aa"}.fa-arrow-circle-down:before{content:"\f0ab"}.fa-globe:before{content:"\f0ac"}.fa-wrench:before{content:"\f0ad"}.fa-tasks:before{content:"\f0ae"}.fa-filter:before{content:"\f0b0"}.fa-briefcase:before{content:"\f0b1"}.fa-arrows-alt:before{content:"\f0b2"}.fa-group:before,.fa-users:before{content:"\f0c0"}.fa-chain:before,.fa-link:before{content:"\f0c1"}.fa-cloud:before{content:"\f0c2"}.fa-flask:before{content:"\f0c3"}.fa-cut:before,.fa-scissors:before{content:"\f0c4"}.fa-copy:before,.fa-files-o:before{content:"\f0c5"}.fa-paperclip:before{content:"\f0c6"}.fa-save:before,.fa-floppy-o:before{content:"\f0c7"}.fa-square:before{content:"\f0c8"}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:"\f0c9"}.fa-list-ul:before{content:"\f0ca"}.fa-list-ol:before{content:"\f0cb"}.fa-strikethrough:before{content:"\f0cc"}.fa-underline:before{content:"\f0cd"}.fa-table:before{content:"\f0ce"}.fa-magic:before{content:"\f0d0"}.fa-truck:before{content:"\f0d1"}.fa-pinterest:before{content:"\f0d2"}.fa-pinterest-square:before{content:"\f0d3"}.fa-google-plus-square:before{content:"\f0d4"}.fa-google-plus:before{content:"\f0d5"}.fa-money:before{content:"\f0d6"}.fa-caret-down:before{content:"\f0d7"}.fa-caret-up:before{content:"\f0d8"}.fa-caret-left:before{content:"\f0d9"}.fa-caret-right:before{content:"\f0da"}.fa-columns:before{content:"\f0db"}.fa-unsorted:before,.fa-sort:before{content:"\f0dc"}.fa-sort-down:before,.fa-sort-desc:before{content:"\f0dd"}.fa-sort-up:before,.fa-sort-asc:before{content:"\f0de"}.fa-envelope:before{content:"\f0e0"}.fa-linkedin:before{content:"\f0e1"}.fa-rotate-left:before,.fa-undo:before{content:"\f0e2"}.fa-legal:before,.fa-gavel:before{content:"\f0e3"}.fa-dashboard:before,.fa-tachometer:before{content:"\f0e4"}.fa-comment-o:before{content:"\f0e5"}.fa-comments-o:before{content:"\f0e6"}.fa-flash:before,.fa-bolt:before{content:"\f0e7"}.fa-sitemap:before{content:"\f0e8"}.fa-umbrella:before{content:"\f0e9"}.fa-paste:before,.fa-clipboard:before{content:"\f0ea"}.fa-lightbulb-o:before{content:"\f0eb"}.fa-exchange:before{content:"\f0ec"}.fa-cloud-download:before{content:"\f0ed"}.fa-cloud-upload:before{content:"\f0ee"}.fa-user-md:before{content:"\f0f0"}.fa-stethoscope:before{content:"\f0f1"}.fa-suitcase:before{content:"\f0f2"}.fa-bell-o:before{content:"\f0a2"}.fa-coffee:before{content:"\f0f4"}.fa-cutlery:before{content:"\f0f5"}.fa-file-text-o:before{content:"\f0f6"}.fa-building-o:before{content:"\f0f7"}.fa-hospital-o:before{content:"\f0f8"}.fa-ambulance:before{content:"\f0f9"}.fa-medkit:before{content:"\f0fa"}.fa-fighter-jet:before{content:"\f0fb"}.fa-beer:before{content:"\f0fc"}.fa-h-square:before{content:"\f0fd"}.fa-plus-square:before{content:"\f0fe"}.fa-angle-double-left:before{content:"\f100"}.fa-angle-double-right:before{content:"\f101"}.fa-angle-double-up:before{content:"\f102"}.fa-angle-double-down:before{content:"\f103"}.fa-angle-left:before{content:"\f104"}.fa-angle-right:before{content:"\f105"}.fa-angle-up:before{content:"\f106"}.fa-angle-down:before{content:"\f107"}.fa-desktop:before{content:"\f108"}.fa-laptop:before{content:"\f109"}.fa-tablet:before{content:"\f10a"}.fa-mobile-phone:before,.fa-mobile:before{content:"\f10b"}.fa-circle-o:before{content:"\f10c"}.fa-quote-left:before{content:"\f10d"}.fa-quote-right:before{content:"\f10e"}.fa-spinner:before{content:"\f110"}.fa-circle:before{content:"\f111"}.fa-mail-reply:before,.fa-reply:before{content:"\f112"}.fa-github-alt:before{content:"\f113"}.fa-folder-o:before{content:"\f114"}.fa-folder-open-o:before{content:"\f115"}.fa-smile-o:before{content:"\f118"}.fa-frown-o:before{content:"\f119"}.fa-meh-o:before{content:"\f11a"}.fa-gamepad:before{content:"\f11b"}.fa-keyboard-o:before{content:"\f11c"}.fa-flag-o:before{content:"\f11d"}.fa-flag-checkered:before{content:"\f11e"}.fa-terminal:before{content:"\f120"}.fa-code:before{content:"\f121"}.fa-mail-reply-all:before,.fa-reply-all:before{content:"\f122"}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:"\f123"}.fa-location-arrow:before{content:"\f124"}.fa-crop:before{content:"\f125"}.fa-code-fork:before{content:"\f126"}.fa-unlink:before,.fa-chain-broken:before{content:"\f127"}.fa-question:before{content:"\f128"}.fa-info:before{content:"\f129"}.fa-exclamation:before{content:"\f12a"}.fa-superscript:before{content:"\f12b"}.fa-subscript:before{content:"\f12c"}.fa-eraser:before{content:"\f12d"}.fa-puzzle-piece:before{content:"\f12e"}.fa-microphone:before{content:"\f130"}.fa-microphone-slash:before{content:"\f131"}.fa-shield:before{content:"\f132"}.fa-calendar-o:before{content:"\f133"}.fa-fire-extinguisher:before{content:"\f134"}.fa-rocket:before{content:"\f135"}.fa-maxcdn:before{content:"\f136"}.fa-chevron-circle-left:before{content:"\f137"}.fa-chevron-circle-right:before{content:"\f138"}.fa-chevron-circle-up:before{content:"\f139"}.fa-chevron-circle-down:before{content:"\f13a"}.fa-html5:before{content:"\f13b"}.fa-css3:before{content:"\f13c"}.fa-anchor:before{content:"\f13d"}.fa-unlock-alt:before{content:"\f13e"}.fa-bullseye:before{content:"\f140"}.fa-ellipsis-h:before{content:"\f141"}.fa-ellipsis-v:before{content:"\f142"}.fa-rss-square:before{content:"\f143"}.fa-play-circle:before{content:"\f144"}.fa-ticket:before{content:"\f145"}.fa-minus-square:before{content:"\f146"}.fa-minus-square-o:before{content:"\f147"}.fa-level-up:before{content:"\f148"}.fa-level-down:before{content:"\f149"}.fa-check-square:before{content:"\f14a"}.fa-pencil-square:before{content:"\f14b"}.fa-external-link-square:before{content:"\f14c"}.fa-share-square:before{content:"\f14d"}.fa-compass:before{content:"\f14e"}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:"\f150"}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:"\f151"}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:"\f152"}.fa-euro:before,.fa-eur:before{content:"\f153"}.fa-gbp:before{content:"\f154"}.fa-dollar:before,.fa-usd:before{content:"\f155"}.fa-rupee:before,.fa-inr:before{content:"\f156"}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:"\f157"}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:"\f158"}.fa-won:before,.fa-krw:before{content:"\f159"}.fa-bitcoin:before,.fa-btc:before{content:"\f15a"}.fa-file:before{content:"\f15b"}.fa-file-text:before{content:"\f15c"}.fa-sort-alpha-asc:before{content:"\f15d"}.fa-sort-alpha-desc:before{content:"\f15e"}.fa-sort-amount-asc:before{content:"\f160"}.fa-sort-amount-desc:before{content:"\f161"}.fa-sort-numeric-asc:before{content:"\f162"}.fa-sort-numeric-desc:before{content:"\f163"}.fa-thumbs-up:before{content:"\f164"}.fa-thumbs-down:before{content:"\f165"}.fa-youtube-square:before{content:"\f166"}.fa-youtube:before{content:"\f167"}.fa-xing:before{content:"\f168"}.fa-xing-square:before{content:"\f169"}.fa-youtube-play:before{content:"\f16a"}.fa-dropbox:before{content:"\f16b"}.fa-stack-overflow:before{content:"\f16c"}.fa-instagram:before{content:"\f16d"}.fa-flickr:before{content:"\f16e"}.fa-adn:before{content:"\f170"}.fa-bitbucket:before{content:"\f171"}.fa-bitbucket-square:before{content:"\f172"}.fa-tumblr:before{content:"\f173"}.fa-tumblr-square:before{content:"\f174"}.fa-long-arrow-down:before{content:"\f175"}.fa-long-arrow-up:before{content:"\f176"}.fa-long-arrow-left:before{content:"\f177"}.fa-long-arrow-right:before{content:"\f178"}.fa-apple:before{content:"\f179"}.fa-windows:before{content:"\f17a"}.fa-android:before{content:"\f17b"}.fa-linux:before{content:"\f17c"}.fa-dribbble:before{content:"\f17d"}.fa-skype:before{content:"\f17e"}.fa-foursquare:before{content:"\f180"}.fa-trello:before{content:"\f181"}.fa-female:before{content:"\f182"}.fa-male:before{content:"\f183"}.fa-gittip:before,.fa-gratipay:before{content:"\f184"}.fa-sun-o:before{content:"\f185"}.fa-moon-o:before{content:"\f186"}.fa-archive:before{content:"\f187"}.fa-bug:before{content:"\f188"}.fa-vk:before{content:"\f189"}.fa-weibo:before{content:"\f18a"}.fa-renren:before{content:"\f18b"}.fa-pagelines:before{content:"\f18c"}.fa-stack-exchange:before{content:"\f18d"}.fa-arrow-circle-o-right:before{content:"\f18e"}.fa-arrow-circle-o-left:before{content:"\f190"}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:"\f191"}.fa-dot-circle-o:before{content:"\f192"}.fa-wheelchair:before{content:"\f193"}.fa-vimeo-square:before{content:"\f194"}.fa-turkish-lira:before,.fa-try:before{content:"\f195"}.fa-plus-square-o:before{content:"\f196"}.fa-space-shuttle:before{content:"\f197"}.fa-slack:before{content:"\f198"}.fa-envelope-square:before{content:"\f199"}.fa-wordpress:before{content:"\f19a"}.fa-openid:before{content:"\f19b"}.fa-institution:before,.fa-bank:before,.fa-university:before{content:"\f19c"}.fa-mortar-board:before,.fa-graduation-cap:before{content:"\f19d"}.fa-yahoo:before{content:"\f19e"}.fa-google:before{content:"\f1a0"}.fa-reddit:before{content:"\f1a1"}.fa-reddit-square:before{content:"\f1a2"}.fa-stumbleupon-circle:before{content:"\f1a3"}.fa-stumbleupon:before{content:"\f1a4"}.fa-delicious:before{content:"\f1a5"}.fa-digg:before{content:"\f1a6"}.fa-pied-piper-pp:before{content:"\f1a7"}.fa-pied-piper-alt:before{content:"\f1a8"}.fa-drupal:before{content:"\f1a9"}.fa-joomla:before{content:"\f1aa"}.fa-language:before{content:"\f1ab"}.fa-fax:before{content:"\f1ac"}.fa-building:before{content:"\f1ad"}.fa-child:before{content:"\f1ae"}.fa-paw:before{content:"\f1b0"}.fa-spoon:before{content:"\f1b1"}.fa-cube:before{content:"\f1b2"}.fa-cubes:before{content:"\f1b3"}.fa-behance:before{content:"\f1b4"}.fa-behance-square:before{content:"\f1b5"}.fa-steam:before{content:"\f1b6"}.fa-steam-square:before{content:"\f1b7"}.fa-recycle:before{content:"\f1b8"}.fa-automobile:before,.fa-car:before{content:"\f1b9"}.fa-cab:before,.fa-taxi:before{content:"\f1ba"}.fa-tree:before{content:"\f1bb"}.fa-spotify:before{content:"\f1bc"}.fa-deviantart:before{content:"\f1bd"}.fa-soundcloud:before{content:"\f1be"}.fa-database:before{content:"\f1c0"}.fa-file-pdf-o:before{content:"\f1c1"}.fa-file-word-o:before{content:"\f1c2"}.fa-file-excel-o:before{content:"\f1c3"}.fa-file-powerpoint-o:before{content:"\f1c4"}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:"\f1c5"}.fa-file-zip-o:before,.fa-file-archive-o:before{content:"\f1c6"}.fa-file-sound-o:before,.fa-file-audio-o:before{content:"\f1c7"}.fa-file-movie-o:before,.fa-file-video-o:before{content:"\f1c8"}.fa-file-code-o:before{content:"\f1c9"}.fa-vine:before{content:"\f1ca"}.fa-codepen:before{content:"\f1cb"}.fa-jsfiddle:before{content:"\f1cc"}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:"\f1cd"}.fa-circle-o-notch:before{content:"\f1ce"}.fa-ra:before,.fa-resistance:before,.fa-rebel:before{content:"\f1d0"}.fa-ge:before,.fa-empire:before{content:"\f1d1"}.fa-git-square:before{content:"\f1d2"}.fa-git:before{content:"\f1d3"}.fa-y-combinator-square:before,.fa-yc-square:before,.fa-hacker-news:before{content:"\f1d4"}.fa-tencent-weibo:before{content:"\f1d5"}.fa-qq:before{content:"\f1d6"}.fa-wechat:before,.fa-weixin:before{content:"\f1d7"}.fa-send:before,.fa-paper-plane:before{content:"\f1d8"}.fa-send-o:before,.fa-paper-plane-o:before{content:"\f1d9"}.fa-history:before{content:"\f1da"}.fa-circle-thin:before{content:"\f1db"}.fa-header:before{content:"\f1dc"}.fa-paragraph:before{content:"\f1dd"}.fa-sliders:before{content:"\f1de"}.fa-share-alt:before{content:"\f1e0"}.fa-share-alt-square:before{content:"\f1e1"}.fa-bomb:before{content:"\f1e2"}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:"\f1e3"}.fa-tty:before{content:"\f1e4"}.fa-binoculars:before{content:"\f1e5"}.fa-plug:before{content:"\f1e6"}.fa-slideshare:before{content:"\f1e7"}.fa-twitch:before{content:"\f1e8"}.fa-yelp:before{content:"\f1e9"}.fa-newspaper-o:before{content:"\f1ea"}.fa-wifi:before{content:"\f1eb"}.fa-calculator:before{content:"\f1ec"}.fa-paypal:before{content:"\f1ed"}.fa-google-wallet:before{content:"\f1ee"}.fa-cc-visa:before{content:"\f1f0"}.fa-cc-mastercard:before{content:"\f1f1"}.fa-cc-discover:before{content:"\f1f2"}.fa-cc-amex:before{content:"\f1f3"}.fa-cc-paypal:before{content:"\f1f4"}.fa-cc-stripe:before{content:"\f1f5"}.fa-bell-slash:before{content:"\f1f6"}.fa-bell-slash-o:before{content:"\f1f7"}.fa-trash:before{content:"\f1f8"}.fa-copyright:before{content:"\f1f9"}.fa-at:before{content:"\f1fa"}.fa-eyedropper:before{content:"\f1fb"}.fa-paint-brush:before{content:"\f1fc"}.fa-birthday-cake:before{content:"\f1fd"}.fa-area-chart:before{content:"\f1fe"}.fa-pie-chart:before{content:"\f200"}.fa-line-chart:before{content:"\f201"}.fa-lastfm:before{content:"\f202"}.fa-lastfm-square:before{content:"\f203"}.fa-toggle-off:before{content:"\f204"}.fa-toggle-on:before{content:"\f205"}.fa-bicycle:before{content:"\f206"}.fa-bus:before{content:"\f207"}.fa-ioxhost:before{content:"\f208"}.fa-angellist:before{content:"\f209"}.fa-cc:before{content:"\f20a"}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:"\f20b"}.fa-meanpath:before{content:"\f20c"}.fa-buysellads:before{content:"\f20d"}.fa-connectdevelop:before{content:"\f20e"}.fa-dashcube:before{content:"\f210"}.fa-forumbee:before{content:"\f211"}.fa-leanpub:before{content:"\f212"}.fa-sellsy:before{content:"\f213"}.fa-shirtsinbulk:before{content:"\f214"}.fa-simplybuilt:before{content:"\f215"}.fa-skyatlas:before{content:"\f216"}.fa-cart-plus:before{content:"\f217"}.fa-cart-arrow-down:before{content:"\f218"}.fa-diamond:before{content:"\f219"}.fa-ship:before{content:"\f21a"}.fa-user-secret:before{content:"\f21b"}.fa-motorcycle:before{content:"\f21c"}.fa-street-view:before{content:"\f21d"}.fa-heartbeat:before{content:"\f21e"}.fa-venus:before{content:"\f221"}.fa-mars:before{content:"\f222"}.fa-mercury:before{content:"\f223"}.fa-intersex:before,.fa-transgender:before{content:"\f224"}.fa-transgender-alt:before{content:"\f225"}.fa-venus-double:before{content:"\f226"}.fa-mars-double:before{content:"\f227"}.fa-venus-mars:before{content:"\f228"}.fa-mars-stroke:before{content:"\f229"}.fa-mars-stroke-v:before{content:"\f22a"}.fa-mars-stroke-h:before{content:"\f22b"}.fa-neuter:before{content:"\f22c"}.fa-genderless:before{content:"\f22d"}.fa-facebook-official:before{content:"\f230"}.fa-pinterest-p:before{content:"\f231"}.fa-whatsapp:before{content:"\f232"}.fa-server:before{content:"\f233"}.fa-user-plus:before{content:"\f234"}.fa-user-times:before{content:"\f235"}.fa-hotel:before,.fa-bed:before{content:"\f236"}.fa-viacoin:before{content:"\f237"}.fa-train:before{content:"\f238"}.fa-subway:before{content:"\f239"}.fa-medium:before{content:"\f23a"}.fa-yc:before,.fa-y-combinator:before{content:"\f23b"}.fa-optin-monster:before{content:"\f23c"}.fa-opencart:before{content:"\f23d"}.fa-expeditedssl:before{content:"\f23e"}.fa-battery-4:before,.fa-battery:before,.fa-battery-full:before{content:"\f240"}.fa-battery-3:before,.fa-battery-three-quarters:before{content:"\f241"}.fa-battery-2:before,.fa-battery-half:before{content:"\f242"}.fa-battery-1:before,.fa-battery-quarter:before{content:"\f243"}.fa-battery-0:before,.fa-battery-empty:before{content:"\f244"}.fa-mouse-pointer:before{content:"\f245"}.fa-i-cursor:before{content:"\f246"}.fa-object-group:before{content:"\f247"}.fa-object-ungroup:before{content:"\f248"}.fa-sticky-note:before{content:"\f249"}.fa-sticky-note-o:before{content:"\f24a"}.fa-cc-jcb:before{content:"\f24b"}.fa-cc-diners-club:before{content:"\f24c"}.fa-clone:before{content:"\f24d"}.fa-balance-scale:before{content:"\f24e"}.fa-hourglass-o:before{content:"\f250"}.fa-hourglass-1:before,.fa-hourglass-start:before{content:"\f251"}.fa-hourglass-2:before,.fa-hourglass-half:before{content:"\f252"}.fa-hourglass-3:before,.fa-hourglass-end:before{content:"\f253"}.fa-hourglass:before{content:"\f254"}.fa-hand-grab-o:before,.fa-hand-rock-o:before{content:"\f255"}.fa-hand-stop-o:before,.fa-hand-paper-o:before{content:"\f256"}.fa-hand-scissors-o:before{content:"\f257"}.fa-hand-lizard-o:before{content:"\f258"}.fa-hand-spock-o:before{content:"\f259"}.fa-hand-pointer-o:before{content:"\f25a"}.fa-hand-peace-o:before{content:"\f25b"}.fa-trademark:before{content:"\f25c"}.fa-registered:before{content:"\f25d"}.fa-creative-commons:before{content:"\f25e"}.fa-gg:before{content:"\f260"}.fa-gg-circle:before{content:"\f261"}.fa-tripadvisor:before{content:"\f262"}.fa-odnoklassniki:before{content:"\f263"}.fa-odnoklassniki-square:before{content:"\f264"}.fa-get-pocket:before{content:"\f265"}.fa-wikipedia-w:before{content:"\f266"}.fa-safari:before{content:"\f267"}.fa-chrome:before{content:"\f268"}.fa-firefox:before{content:"\f269"}.fa-opera:before{content:"\f26a"}.fa-internet-explorer:before{content:"\f26b"}.fa-tv:before,.fa-television:before{content:"\f26c"}.fa-contao:before{content:"\f26d"}.fa-500px:before{content:"\f26e"}.fa-amazon:before{content:"\f270"}.fa-calendar-plus-o:before{content:"\f271"}.fa-calendar-minus-o:before{content:"\f272"}.fa-calendar-times-o:before{content:"\f273"}.fa-calendar-check-o:before{content:"\f274"}.fa-industry:before{content:"\f275"}.fa-map-pin:before{content:"\f276"}.fa-map-signs:before{content:"\f277"}.fa-map-o:before{content:"\f278"}.fa-map:before{content:"\f279"}.fa-commenting:before{content:"\f27a"}.fa-commenting-o:before{content:"\f27b"}.fa-houzz:before{content:"\f27c"}.fa-vimeo:before{content:"\f27d"}.fa-black-tie:before{content:"\f27e"}.fa-fonticons:before{content:"\f280"}.fa-reddit-alien:before{content:"\f281"}.fa-edge:before{content:"\f282"}.fa-credit-card-alt:before{content:"\f283"}.fa-codiepie:before{content:"\f284"}.fa-modx:before{content:"\f285"}.fa-fort-awesome:before{content:"\f286"}.fa-usb:before{content:"\f287"}.fa-product-hunt:before{content:"\f288"}.fa-mixcloud:before{content:"\f289"}.fa-scribd:before{content:"\f28a"}.fa-pause-circle:before{content:"\f28b"}.fa-pause-circle-o:before{content:"\f28c"}.fa-stop-circle:before{content:"\f28d"}.fa-stop-circle-o:before{content:"\f28e"}.fa-shopping-bag:before{content:"\f290"}.fa-shopping-basket:before{content:"\f291"}.fa-hashtag:before{content:"\f292"}.fa-bluetooth:before{content:"\f293"}.fa-bluetooth-b:before{content:"\f294"}.fa-percent:before{content:"\f295"}.fa-gitlab:before{content:"\f296"}.fa-wpbeginner:before{content:"\f297"}.fa-wpforms:before{content:"\f298"}.fa-envira:before{content:"\f299"}.fa-universal-access:before{content:"\f29a"}.fa-wheelchair-alt:before{content:"\f29b"}.fa-question-circle-o:before{content:"\f29c"}.fa-blind:before{content:"\f29d"}.fa-audio-description:before{content:"\f29e"}.fa-volume-control-phone:before{content:"\f2a0"}.fa-braille:before{content:"\f2a1"}.fa-assistive-listening-systems:before{content:"\f2a2"}.fa-asl-interpreting:before,.fa-american-sign-language-interpreting:before{content:"\f2a3"}.fa-deafness:before,.fa-hard-of-hearing:before,.fa-deaf:before{content:"\f2a4"}.fa-glide:before{content:"\f2a5"}.fa-glide-g:before{content:"\f2a6"}.fa-signing:before,.fa-sign-language:before{content:"\f2a7"}.fa-low-vision:before{content:"\f2a8"}.fa-viadeo:before{content:"\f2a9"}.fa-viadeo-square:before{content:"\f2aa"}.fa-snapchat:before{content:"\f2ab"}.fa-snapchat-ghost:before{content:"\f2ac"}.fa-snapchat-square:before{content:"\f2ad"}.fa-pied-piper:before{content:"\f2ae"}.fa-first-order:before{content:"\f2b0"}.fa-yoast:before{content:"\f2b1"}.fa-themeisle:before{content:"\f2b2"}.fa-google-plus-circle:before,.fa-google-plus-official:before{content:"\f2b3"}.fa-fa:before,.fa-font-awesome:before{content:"\f2b4"}.fa-handshake-o:before{content:"\f2b5"}.fa-envelope-open:before{content:"\f2b6"}.fa-envelope-open-o:before{content:"\f2b7"}.fa-linode:before{content:"\f2b8"}.fa-address-book:before{content:"\f2b9"}.fa-address-book-o:before{content:"\f2ba"}.fa-vcard:before,.fa-address-card:before{content:"\f2bb"}.fa-vcard-o:before,.fa-address-card-o:before{content:"\f2bc"}.fa-user-circle:before{content:"\f2bd"}.fa-user-circle-o:before{content:"\f2be"}.fa-user-o:before{content:"\f2c0"}.fa-id-badge:before{content:"\f2c1"}.fa-drivers-license:before,.fa-id-card:before{content:"\f2c2"}.fa-drivers-license-o:before,.fa-id-card-o:before{content:"\f2c3"}.fa-quora:before{content:"\f2c4"}.fa-free-code-camp:before{content:"\f2c5"}.fa-telegram:before{content:"\f2c6"}.fa-thermometer-4:before,.fa-thermometer:before,.fa-thermometer-full:before{content:"\f2c7"}.fa-thermometer-3:before,.fa-thermometer-three-quarters:before{content:"\f2c8"}.fa-thermometer-2:before,.fa-thermometer-half:before{content:"\f2c9"}.fa-thermometer-1:before,.fa-thermometer-quarter:before{content:"\f2ca"}.fa-thermometer-0:before,.fa-thermometer-empty:before{content:"\f2cb"}.fa-shower:before{content:"\f2cc"}.fa-bathtub:before,.fa-s15:before,.fa-bath:before{content:"\f2cd"}.fa-podcast:before{content:"\f2ce"}.fa-window-maximize:before{content:"\f2d0"}.fa-window-minimize:before{content:"\f2d1"}.fa-window-restore:before{content:"\f2d2"}.fa-times-rectangle:before,.fa-window-close:before{content:"\f2d3"}.fa-times-rectangle-o:before,.fa-window-close-o:before{content:"\f2d4"}.fa-bandcamp:before{content:"\f2d5"}.fa-grav:before{content:"\f2d6"}.fa-etsy:before{content:"\f2d7"}.fa-imdb:before{content:"\f2d8"}.fa-ravelry:before{content:"\f2d9"}.fa-eercast:before{content:"\f2da"}.fa-microchip:before{content:"\f2db"}.fa-snowflake-o:before{content:"\f2dc"}.fa-superpowers:before{content:"\f2dd"}.fa-wpexplorer:before{content:"\f2de"}.fa-meetup:before{content:"\f2e0"}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto} diff --git a/_site/public/css/horsey.css b/_site/public/css/horsey.css new file mode 100644 index 00000000..358f72d8 --- /dev/null +++ b/_site/public/css/horsey.css @@ -0,0 +1,35 @@ +.sey-list { + display: none; + position: absolute; + padding: 0; + margin: 0; + list-style-type: none; + box-shadow: 1px 2px 6px; + background-color: #fff; + color: #333; + transition: left 0.1s ease-in-out; + max-height: 70vh; + overflow: auto; + width: 265px; +} +.sey-show { + display: block; +} +.sey-hide { + display: none; +} +.sey-item { + cursor: pointer; + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; + padding: 7px; +} +.sey-item:hover { + background-color: #444; + color: #fff; +} +.sey-selected { + background-color: #333; + color: #fff; +} diff --git a/_site/public/css/hybrid.css b/_site/public/css/hybrid.css new file mode 100644 index 00000000..29735a18 --- /dev/null +++ b/_site/public/css/hybrid.css @@ -0,0 +1,102 @@ +/* + +vim-hybrid theme by w0ng (https://github.com/w0ng/vim-hybrid) + +*/ + +/*background color*/ +.hljs { + display: block; + overflow-x: auto; + padding: 0.5em; + background: #1d1f21; +} + +/*selection color*/ +.hljs::selection, +.hljs span::selection { + background: #373b41; +} + +.hljs::-moz-selection, +.hljs span::-moz-selection { + background: #373b41; +} + +/*foreground color*/ +.hljs { + color: #c5c8c6; +} + +/*color: fg_yellow*/ +.hljs-title, +.hljs-name { + color: #f0c674; +} + +/*color: fg_comment*/ +.hljs-comment, +.hljs-meta, +.hljs-meta .hljs-keyword { + color: #707880; +} + +/*color: fg_red*/ +.hljs-number, +.hljs-symbol, +.hljs-literal, +.hljs-deletion, +.hljs-link { + color: #cc6666 +} + +/*color: fg_green*/ +.hljs-string, +.hljs-doctag, +.hljs-addition, +.hljs-regexp, +.hljs-selector-attr, +.hljs-selector-pseudo { + color: #b5bd68; +} + +/*color: fg_purple*/ +.hljs-attribute, +.hljs-code, +.hljs-selector-id { + color: #b294bb; +} + +/*color: fg_blue*/ +.hljs-keyword, +.hljs-selector-tag, +.hljs-bullet, +.hljs-tag { + color: #81a2be; +} + +/*color: fg_aqua*/ +.hljs-subst, +.hljs-variable, +.hljs-template-tag, +.hljs-template-variable { + color: #8abeb7; +} + +/*color: fg_orange*/ +.hljs-type, +.hljs-built_in, +.hljs-builtin-name, +.hljs-quote, +.hljs-section, +.hljs-selector-class { + color: #de935f; +} + +.hljs-emphasis { + font-style: italic; +} + +.hljs-strong { + font-weight: bold; +} diff --git a/_site/public/css/nucleus.css b/_site/public/css/nucleus.css new file mode 100644 index 00000000..ed2c0a38 --- /dev/null +++ b/_site/public/css/nucleus.css @@ -0,0 +1,617 @@ +*, *::before, *::after { + -webkit-box-sizing: border-box; + -moz-box-sizing: border-box; + box-sizing: border-box; } + +@-webkit-viewport { + width: device-width; } +@-moz-viewport { + width: device-width; } +@-ms-viewport { + width: device-width; } +@-o-viewport { + width: device-width; } +@viewport { + width: device-width; } +html { + font-size: 100%; + -ms-text-size-adjust: 100%; + -webkit-text-size-adjust: 100%; } + +body { + margin: 0; } + +article, +aside, +details, +figcaption, +figure, +footer, +header, +hgroup, +main, +nav, +section, +summary { + display: block; } + +audio, +canvas, +progress, +video { + display: inline-block; + vertical-align: baseline; } + +audio:not([controls]) { + display: none; + height: 0; } + +[hidden], +template { + display: none; } + +a { + background: transparent; + text-decoration: none; } + +a:active, +a:hover { + outline: 0; } + +abbr[title] { + border-bottom: 1px dotted; } + +b, +strong { + font-weight: bold; } + +dfn { + font-style: italic; } + +mark { + background: #FFFF27; + color: #333; } + +sub, +sup { + font-size: 0.8rem; + line-height: 0; + position: relative; + vertical-align: baseline; } + +sup { + top: -0.5em; } + +sub { + bottom: -0.25em; } + +img { + border: 0; + max-width: 100%; } + +svg:not(:root) { + overflow: hidden; } + +figure { + margin: 1em 40px; } + +hr { + height: 0; } + +pre { + overflow: auto; } + +button, +input, +optgroup, +select, +textarea { + color: inherit; + font: inherit; + margin: 0; } + +button { + overflow: visible; } + +button, +select { + text-transform: none; } + +button, +html input[type="button"], +input[type="reset"], +input[type="submit"] { + -webkit-appearance: button; + cursor: pointer; } + +button[disabled], +html input[disabled] { + cursor: default; } + +button::-moz-focus-inner, +input::-moz-focus-inner { + border: 0; + padding: 0; } + +input { + line-height: normal; } + +input[type="checkbox"], +input[type="radio"] { + padding: 0; } + +input[type="number"]::-webkit-inner-spin-button, +input[type="number"]::-webkit-outer-spin-button { + height: auto; } + +input[type="search"] { + -webkit-appearance: textfield; } + +input[type="search"]::-webkit-search-cancel-button, +input[type="search"]::-webkit-search-decoration { + -webkit-appearance: none; } + +legend { + border: 0; + padding: 0; } + +textarea { + overflow: auto; } + +optgroup { + font-weight: bold; } + +table { + border-collapse: collapse; + border-spacing: 0; + table-layout: fixed; + width: 100%; } + +tr, td, th { + vertical-align: middle; } + +th, td { + padding: 0.425rem 0; } + +th { + text-align: left; } + +.container { + width: 75em; + margin: 0 auto; + padding: 0; } + @media only all and (min-width: 60em) and (max-width: 74.938em) { + .container { + width: 60em; } } + @media only all and (min-width: 48em) and (max-width: 59.938em) { + .container { + width: 48em; } } + @media only all and (min-width: 30.063em) and (max-width: 47.938em) { + .container { + width: 30em; } } + @media only all and (max-width: 30em) { + .container { + width: 100%; } } + +.grid { + display: -webkit-box; + display: -moz-box; + display: box; + display: -webkit-flex; + display: -moz-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-flow: row; + -moz-flex-flow: row; + flex-flow: row; + list-style: none; + margin: 0; + padding: 0; } + @media only all and (max-width: 47.938em) { + .grid { + -webkit-flex-flow: row wrap; + -moz-flex-flow: row wrap; + flex-flow: row wrap; } } + +.block { + -webkit-box-flex: 1; + -moz-box-flex: 1; + box-flex: 1; + -webkit-flex: 1; + -moz-flex: 1; + -ms-flex: 1; + flex: 1; + min-width: 0; + min-height: 0; } + @media only all and (max-width: 47.938em) { + .block { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 100%; + -moz-flex: 0 100%; + -ms-flex: 0 100%; + flex: 0 100%; } } + +.content { + margin: 0.625rem; + padding: 0.938rem; } + +@media only all and (max-width: 47.938em) { + body [class*="size-"] { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 100%; + -moz-flex: 0 100%; + -ms-flex: 0 100%; + flex: 0 100%; } } + +.size-1-2 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 50%; + -moz-flex: 0 50%; + -ms-flex: 0 50%; + flex: 0 50%; } + +.size-1-3 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 33.33333%; + -moz-flex: 0 33.33333%; + -ms-flex: 0 33.33333%; + flex: 0 33.33333%; } + +.size-1-4 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 25%; + -moz-flex: 0 25%; + -ms-flex: 0 25%; + flex: 0 25%; } + +.size-1-5 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 20%; + -moz-flex: 0 20%; + -ms-flex: 0 20%; + flex: 0 20%; } + +.size-1-6 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 16.66667%; + -moz-flex: 0 16.66667%; + -ms-flex: 0 16.66667%; + flex: 0 16.66667%; } + +.size-1-7 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 14.28571%; + -moz-flex: 0 14.28571%; + -ms-flex: 0 14.28571%; + flex: 0 14.28571%; } + +.size-1-8 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 12.5%; + -moz-flex: 0 12.5%; + -ms-flex: 0 12.5%; + flex: 0 12.5%; } + +.size-1-9 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 11.11111%; + -moz-flex: 0 11.11111%; + -ms-flex: 0 11.11111%; + flex: 0 11.11111%; } + +.size-1-10 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 10%; + -moz-flex: 0 10%; + -ms-flex: 0 10%; + flex: 0 10%; } + +.size-1-11 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 9.09091%; + -moz-flex: 0 9.09091%; + -ms-flex: 0 9.09091%; + flex: 0 9.09091%; } + +.size-1-12 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 8.33333%; + -moz-flex: 0 8.33333%; + -ms-flex: 0 8.33333%; + flex: 0 8.33333%; } + +@media only all and (min-width: 48em) and (max-width: 59.938em) { + .size-tablet-1-2 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 50%; + -moz-flex: 0 50%; + -ms-flex: 0 50%; + flex: 0 50%; } + + .size-tablet-1-3 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 33.33333%; + -moz-flex: 0 33.33333%; + -ms-flex: 0 33.33333%; + flex: 0 33.33333%; } + + .size-tablet-1-4 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 25%; + -moz-flex: 0 25%; + -ms-flex: 0 25%; + flex: 0 25%; } + + .size-tablet-1-5 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 20%; + -moz-flex: 0 20%; + -ms-flex: 0 20%; + flex: 0 20%; } + + .size-tablet-1-6 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 16.66667%; + -moz-flex: 0 16.66667%; + -ms-flex: 0 16.66667%; + flex: 0 16.66667%; } + + .size-tablet-1-7 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 14.28571%; + -moz-flex: 0 14.28571%; + -ms-flex: 0 14.28571%; + flex: 0 14.28571%; } + + .size-tablet-1-8 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 12.5%; + -moz-flex: 0 12.5%; + -ms-flex: 0 12.5%; + flex: 0 12.5%; } + + .size-tablet-1-9 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 11.11111%; + -moz-flex: 0 11.11111%; + -ms-flex: 0 11.11111%; + flex: 0 11.11111%; } + + .size-tablet-1-10 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 10%; + -moz-flex: 0 10%; + -ms-flex: 0 10%; + flex: 0 10%; } + + .size-tablet-1-11 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 9.09091%; + -moz-flex: 0 9.09091%; + -ms-flex: 0 9.09091%; + flex: 0 9.09091%; } + + .size-tablet-1-12 { + -webkit-box-flex: 0; + -moz-box-flex: 0; + box-flex: 0; + -webkit-flex: 0 8.33333%; + -moz-flex: 0 8.33333%; + -ms-flex: 0 8.33333%; + flex: 0 8.33333%; } } +@media only all and (max-width: 47.938em) { + @supports not (flex-wrap: wrap) { + .grid { + display: block; + -webkit-box-lines: inherit; + -moz-box-lines: inherit; + box-lines: inherit; + -webkit-flex-wrap: inherit; + -moz-flex-wrap: inherit; + -ms-flex-wrap: inherit; + flex-wrap: inherit; } + + .block { + display: block; + -webkit-box-flex: inherit; + -moz-box-flex: inherit; + box-flex: inherit; + -webkit-flex: inherit; + -moz-flex: inherit; + -ms-flex: inherit; + flex: inherit; } } } +.first-block { + -webkit-box-ordinal-group: 0; + -webkit-order: -1; + -ms-flex-order: -1; + order: -1; } + +.last-block { + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + +.fixed-blocks { + -webkit-flex-flow: row wrap; + -moz-flex-flow: row wrap; + flex-flow: row wrap; } + .fixed-blocks .block { + -webkit-box-flex: inherit; + -moz-box-flex: inherit; + box-flex: inherit; + -webkit-flex: inherit; + -moz-flex: inherit; + -ms-flex: inherit; + flex: inherit; + width: 25%; } + @media only all and (min-width: 60em) and (max-width: 74.938em) { + .fixed-blocks .block { + width: 33.33333%; } } + @media only all and (min-width: 48em) and (max-width: 59.938em) { + .fixed-blocks .block { + width: 50%; } } + @media only all and (max-width: 47.938em) { + .fixed-blocks .block { + width: 100%; } } + +body { + font-size: 1.05rem; + line-height: 1.7; } + +h1, h2, h3, h4, h5, h6 { + margin: 0.85rem 0 1.7rem 0; + text-rendering: optimizeLegibility; } + +h1 { + font-size: 3.25rem; } + +h2 { + font-size: 2.55rem; } + +h3 { + font-size: 2.15rem; } + +h4 { + font-size: 1.8rem; } + +h5 { + font-size: 1.4rem; } + +h6 { + font-size: 0.9rem; } + +p { + margin: 1.7rem 0; } + +ul, ol { + margin-top: 1.7rem; + margin-bottom: 1.7rem; } + ul ul, ul ol, ol ul, ol ol { + margin-top: 0; + margin-bottom: 0; } + +blockquote { + margin: 1.7rem 0; + padding-left: 0.85rem; } + +cite { + display: block; + font-size: 0.925rem; } + cite:before { + content: "\2014 \0020"; } + +pre { + margin: 1.7rem 0; + padding: 0.938rem; } + +code { + vertical-align: bottom; } + +small { + font-size: 0.925rem; } + +hr { + border-left: none; + border-right: none; + border-top: none; + margin: 1.7rem 0; } + +fieldset { + border: 0; + padding: 0.938rem; + margin: 0 0 1.7rem 0; } + +input, +label, +select { + display: block; } + +label { + margin-bottom: 0.425rem; } + label.required:after { + content: "*"; } + label abbr { + display: none; } + +textarea, input[type="email"], input[type="number"], input[type="password"], input[type="search"], input[type="tel"], input[type="text"], input[type="url"], input[type="color"], input[type="date"], input[type="datetime"], input[type="datetime-local"], input[type="month"], input[type="time"], input[type="week"], select[multiple=multiple] { + -webkit-transition: border-color; + -moz-transition: border-color; + transition: border-color; + border-radius: 0.1875rem; + margin-bottom: 0.85rem; + padding: 0.425rem 0.425rem; + width: 100%; } + textarea:focus, input[type="email"]:focus, input[type="number"]:focus, input[type="password"]:focus, input[type="search"]:focus, input[type="tel"]:focus, input[type="text"]:focus, input[type="url"]:focus, input[type="color"]:focus, input[type="date"]:focus, input[type="datetime"]:focus, input[type="datetime-local"]:focus, input[type="month"]:focus, input[type="time"]:focus, input[type="week"]:focus, select[multiple=multiple]:focus { + outline: none; } + +textarea { + resize: vertical; } + +input[type="checkbox"], input[type="radio"] { + display: inline; + margin-right: 0.425rem; } + +input[type="file"] { + width: 100%; } + +select { + width: auto; + max-width: 100%; + margin-bottom: 1.7rem; } + +button, +input[type="submit"] { + cursor: pointer; + user-select: none; + vertical-align: middle; + white-space: nowrap; + border: inherit; } + +/*# sourceMappingURL=nucleus.css.map */ diff --git a/_site/public/fonts/FontAwesome.otf b/_site/public/fonts/FontAwesome.otf new file mode 100644 index 00000000..401ec0f3 Binary files /dev/null and b/_site/public/fonts/FontAwesome.otf differ diff --git a/_site/public/fonts/Inconsolata.eot b/_site/public/fonts/Inconsolata.eot new file mode 100644 index 00000000..0a705d65 Binary files /dev/null and b/_site/public/fonts/Inconsolata.eot differ diff --git a/_site/public/fonts/Inconsolata.svg b/_site/public/fonts/Inconsolata.svg new file mode 100644 index 00000000..b7f97c87 --- /dev/null +++ b/_site/public/fonts/Inconsolata.svg @@ -0,0 +1,359 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/_site/public/fonts/Inconsolata.ttf b/_site/public/fonts/Inconsolata.ttf new file mode 100644 index 00000000..4b8a36d2 Binary files /dev/null and b/_site/public/fonts/Inconsolata.ttf differ diff --git a/_site/public/fonts/Inconsolata.woff b/_site/public/fonts/Inconsolata.woff new file mode 100644 index 00000000..6f39625e Binary files /dev/null and b/_site/public/fonts/Inconsolata.woff differ diff --git a/_site/public/fonts/Lato-Bold.ttf b/_site/public/fonts/Lato-Bold.ttf new file mode 100644 index 00000000..74343694 Binary files /dev/null and b/_site/public/fonts/Lato-Bold.ttf differ diff --git a/_site/public/fonts/Lato-Bold.woff2 b/_site/public/fonts/Lato-Bold.woff2 new file mode 100644 index 00000000..254684c7 Binary files /dev/null and b/_site/public/fonts/Lato-Bold.woff2 differ diff --git a/_site/public/fonts/Lato-Regular.ttf b/_site/public/fonts/Lato-Regular.ttf new file mode 100644 index 00000000..04ea8efb Binary files /dev/null and b/_site/public/fonts/Lato-Regular.ttf differ diff --git a/_site/public/fonts/Lato-Regular.woff2 b/_site/public/fonts/Lato-Regular.woff2 new file mode 100644 index 00000000..c4e8b1ab Binary files /dev/null and b/_site/public/fonts/Lato-Regular.woff2 differ diff --git a/_site/public/fonts/Novecentosanswide-Normal-webfont.eot b/_site/public/fonts/Novecentosanswide-Normal-webfont.eot new file mode 100644 index 00000000..9984682f Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-Normal-webfont.eot differ diff --git a/_site/public/fonts/Novecentosanswide-Normal-webfont.svg b/_site/public/fonts/Novecentosanswide-Normal-webfont.svg new file mode 100644 index 00000000..c412ea8c --- /dev/null +++ b/_site/public/fonts/Novecentosanswide-Normal-webfont.svg @@ -0,0 +1,1019 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/_site/public/fonts/Novecentosanswide-Normal-webfont.ttf b/_site/public/fonts/Novecentosanswide-Normal-webfont.ttf new file mode 100644 index 00000000..8cfb62dd Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-Normal-webfont.ttf differ diff --git a/_site/public/fonts/Novecentosanswide-Normal-webfont.woff b/_site/public/fonts/Novecentosanswide-Normal-webfont.woff new file mode 100644 index 00000000..d5c42907 Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-Normal-webfont.woff differ diff --git a/_site/public/fonts/Novecentosanswide-Normal-webfont.woff2 b/_site/public/fonts/Novecentosanswide-Normal-webfont.woff2 new file mode 100644 index 00000000..eefb4a31 Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-Normal-webfont.woff2 differ diff --git a/_site/public/fonts/Novecentosanswide-UltraLight-webfont.eot b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.eot new file mode 100644 index 00000000..2a26561f Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.eot differ diff --git a/_site/public/fonts/Novecentosanswide-UltraLight-webfont.svg b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.svg new file mode 100644 index 00000000..e642ab07 --- /dev/null +++ b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.svg @@ -0,0 +1,918 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/_site/public/fonts/Novecentosanswide-UltraLight-webfont.ttf b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.ttf new file mode 100644 index 00000000..9ce9c7f9 Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.ttf differ diff --git a/_site/public/fonts/Novecentosanswide-UltraLight-webfont.woff b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.woff new file mode 100644 index 00000000..381650c9 Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.woff differ diff --git a/_site/public/fonts/Novecentosanswide-UltraLight-webfont.woff2 b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.woff2 new file mode 100644 index 00000000..7e659549 Binary files /dev/null and b/_site/public/fonts/Novecentosanswide-UltraLight-webfont.woff2 differ diff --git a/_site/public/fonts/Roboto-Italic.ttf b/_site/public/fonts/Roboto-Italic.ttf new file mode 100644 index 00000000..ff6046d5 Binary files /dev/null and b/_site/public/fonts/Roboto-Italic.ttf differ diff --git a/_site/public/fonts/Roboto-Medium.ttf b/_site/public/fonts/Roboto-Medium.ttf new file mode 100644 index 00000000..39c63d74 Binary files /dev/null and b/_site/public/fonts/Roboto-Medium.ttf differ diff --git a/_site/public/fonts/Roboto-Regular.ttf b/_site/public/fonts/Roboto-Regular.ttf new file mode 100644 index 00000000..8c082c8d Binary files /dev/null and b/_site/public/fonts/Roboto-Regular.ttf differ diff --git a/_site/public/fonts/RobotoMono-Medium.ttf b/_site/public/fonts/RobotoMono-Medium.ttf new file mode 100644 index 00000000..0bcdc740 Binary files /dev/null and b/_site/public/fonts/RobotoMono-Medium.ttf differ diff --git a/_site/public/fonts/RobotoMono-Regular.ttf b/_site/public/fonts/RobotoMono-Regular.ttf new file mode 100644 index 00000000..495a82ce Binary files /dev/null and b/_site/public/fonts/RobotoMono-Regular.ttf differ diff --git a/_site/public/fonts/Work_Sans_200.eot b/_site/public/fonts/Work_Sans_200.eot new file mode 100644 index 00000000..4052e4f9 Binary files /dev/null and b/_site/public/fonts/Work_Sans_200.eot differ diff --git a/_site/public/fonts/Work_Sans_200.svg b/_site/public/fonts/Work_Sans_200.svg new file mode 100644 index 00000000..58ab4ba2 --- /dev/null +++ b/_site/public/fonts/Work_Sans_200.svg @@ -0,0 +1,332 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/_site/public/fonts/Work_Sans_200.ttf b/_site/public/fonts/Work_Sans_200.ttf new file mode 100644 index 00000000..68019e1c Binary files /dev/null and b/_site/public/fonts/Work_Sans_200.ttf differ diff --git a/_site/public/fonts/Work_Sans_200.woff b/_site/public/fonts/Work_Sans_200.woff new file mode 100644 index 00000000..a1bd9e46 Binary files /dev/null and b/_site/public/fonts/Work_Sans_200.woff differ diff --git a/_site/public/fonts/Work_Sans_200.woff2 b/_site/public/fonts/Work_Sans_200.woff2 new file mode 100644 index 00000000..20c68a75 Binary files /dev/null and b/_site/public/fonts/Work_Sans_200.woff2 differ diff --git a/_site/public/fonts/Work_Sans_300.eot b/_site/public/fonts/Work_Sans_300.eot new file mode 100644 index 00000000..ace79938 Binary files /dev/null and b/_site/public/fonts/Work_Sans_300.eot differ diff --git a/_site/public/fonts/Work_Sans_300.svg b/_site/public/fonts/Work_Sans_300.svg new file mode 100644 index 00000000..f29d0c8a --- /dev/null +++ b/_site/public/fonts/Work_Sans_300.svg @@ -0,0 +1,331 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/_site/public/fonts/Work_Sans_300.ttf b/_site/public/fonts/Work_Sans_300.ttf new file mode 100644 index 00000000..35387c23 Binary files /dev/null and b/_site/public/fonts/Work_Sans_300.ttf differ diff --git a/_site/public/fonts/Work_Sans_300.woff b/_site/public/fonts/Work_Sans_300.woff new file mode 100644 index 00000000..8d789eae Binary files /dev/null and b/_site/public/fonts/Work_Sans_300.woff differ diff --git a/_site/public/fonts/Work_Sans_300.woff2 b/_site/public/fonts/Work_Sans_300.woff2 new file mode 100644 index 00000000..f6e216d6 Binary files /dev/null and b/_site/public/fonts/Work_Sans_300.woff2 differ diff --git a/_site/public/fonts/Work_Sans_500.eot b/_site/public/fonts/Work_Sans_500.eot new file mode 100644 index 00000000..9df69294 Binary files /dev/null and b/_site/public/fonts/Work_Sans_500.eot differ diff --git a/_site/public/fonts/Work_Sans_500.svg b/_site/public/fonts/Work_Sans_500.svg new file mode 100644 index 00000000..4b030b79 --- /dev/null +++ b/_site/public/fonts/Work_Sans_500.svg @@ -0,0 +1,333 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/_site/public/fonts/Work_Sans_500.ttf b/_site/public/fonts/Work_Sans_500.ttf new file mode 100644 index 00000000..5b8cc534 Binary files /dev/null and b/_site/public/fonts/Work_Sans_500.ttf differ diff --git a/_site/public/fonts/Work_Sans_500.woff b/_site/public/fonts/Work_Sans_500.woff new file mode 100644 index 00000000..df058514 Binary files /dev/null and b/_site/public/fonts/Work_Sans_500.woff differ diff --git a/_site/public/fonts/Work_Sans_500.woff2 b/_site/public/fonts/Work_Sans_500.woff2 new file mode 100644 index 00000000..b06c54df Binary files /dev/null and b/_site/public/fonts/Work_Sans_500.woff2 differ diff --git a/_site/public/fonts/fontawesome-webfont.eot b/_site/public/fonts/fontawesome-webfont.eot new file mode 100644 index 00000000..e9f60ca9 Binary files /dev/null and b/_site/public/fonts/fontawesome-webfont.eot differ diff --git a/_site/public/fonts/fontawesome-webfont.svg b/_site/public/fonts/fontawesome-webfont.svg new file mode 100644 index 00000000..855c845e --- /dev/null +++ b/_site/public/fonts/fontawesome-webfont.svg @@ -0,0 +1,2671 @@ + + + + +Created by FontForge 20120731 at Mon Oct 24 17:37:40 2016 + By ,,, +Copyright Dave Gandy 2016. All rights reserved. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/_site/public/fonts/fontawesome-webfont.ttf b/_site/public/fonts/fontawesome-webfont.ttf new file mode 100644 index 00000000..35acda2f Binary files /dev/null and b/_site/public/fonts/fontawesome-webfont.ttf differ diff --git a/_site/public/fonts/fontawesome-webfont.woff b/_site/public/fonts/fontawesome-webfont.woff new file mode 100644 index 00000000..400014a4 Binary files /dev/null and b/_site/public/fonts/fontawesome-webfont.woff differ diff --git a/_site/public/fonts/fontawesome-webfont.woff2 b/_site/public/fonts/fontawesome-webfont.woff2 new file mode 100644 index 00000000..4d13fc60 Binary files /dev/null and b/_site/public/fonts/fontawesome-webfont.woff2 differ diff --git a/_site/public/fonts/glyphicons-halflings-regular.eot b/_site/public/fonts/glyphicons-halflings-regular.eot new file mode 100644 index 00000000..b93a4953 Binary files /dev/null and b/_site/public/fonts/glyphicons-halflings-regular.eot differ diff --git a/_site/public/fonts/glyphicons-halflings-regular.svg b/_site/public/fonts/glyphicons-halflings-regular.svg new file mode 100644 index 00000000..94fb5490 --- /dev/null +++ b/_site/public/fonts/glyphicons-halflings-regular.svg @@ -0,0 +1,288 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/_site/public/fonts/glyphicons-halflings-regular.ttf b/_site/public/fonts/glyphicons-halflings-regular.ttf new file mode 100644 index 00000000..1413fc60 Binary files /dev/null and b/_site/public/fonts/glyphicons-halflings-regular.ttf differ diff --git a/_site/public/fonts/glyphicons-halflings-regular.woff b/_site/public/fonts/glyphicons-halflings-regular.woff new file mode 100644 index 00000000..9e612858 Binary files /dev/null and b/_site/public/fonts/glyphicons-halflings-regular.woff differ diff --git a/_site/public/fonts/glyphicons-halflings-regular.woff2 b/_site/public/fonts/glyphicons-halflings-regular.woff2 new file mode 100644 index 00000000..64539b54 Binary files /dev/null and b/_site/public/fonts/glyphicons-halflings-regular.woff2 differ diff --git a/_site/public/images/clippy.svg b/_site/public/images/clippy.svg new file mode 100644 index 00000000..8a77a330 --- /dev/null +++ b/_site/public/images/clippy.svg @@ -0,0 +1,4 @@ + + + + diff --git a/_site/public/images/favicon.png b/_site/public/images/favicon.png new file mode 100644 index 00000000..0f3bda8e Binary files /dev/null and b/_site/public/images/favicon.png differ diff --git a/_site/public/images/gopher-404.jpg b/_site/public/images/gopher-404.jpg new file mode 100644 index 00000000..df106486 Binary files /dev/null and b/_site/public/images/gopher-404.jpg differ diff --git a/_site/public/imgs/iterm2prefs.png b/_site/public/imgs/iterm2prefs.png new file mode 100644 index 00000000..f98086aa Binary files /dev/null and b/_site/public/imgs/iterm2prefs.png differ diff --git a/_site/public/imgs/modules/bittrex.png b/_site/public/imgs/modules/bittrex.png new file mode 100644 index 00000000..669139d3 Binary files /dev/null and b/_site/public/imgs/modules/bittrex.png differ diff --git a/_site/public/imgs/modules/blockfolio.png b/_site/public/imgs/modules/blockfolio.png new file mode 100644 index 00000000..1a820c07 Binary files /dev/null and b/_site/public/imgs/modules/blockfolio.png differ diff --git a/_site/public/imgs/modules/circleci.png b/_site/public/imgs/modules/circleci.png new file mode 100644 index 00000000..e2447b41 Binary files /dev/null and b/_site/public/imgs/modules/circleci.png differ diff --git a/_site/public/imgs/modules/clocks.png b/_site/public/imgs/modules/clocks.png new file mode 100644 index 00000000..3bf984a7 Binary files /dev/null and b/_site/public/imgs/modules/clocks.png differ diff --git a/_site/public/imgs/modules/cryptolive.png b/_site/public/imgs/modules/cryptolive.png new file mode 100644 index 00000000..d3bd19de Binary files /dev/null and b/_site/public/imgs/modules/cryptolive.png differ diff --git a/_site/public/imgs/modules/gcal.png b/_site/public/imgs/modules/gcal.png new file mode 100644 index 00000000..95cf62fb Binary files /dev/null and b/_site/public/imgs/modules/gcal.png differ diff --git a/_site/public/imgs/modules/gerrit.png b/_site/public/imgs/modules/gerrit.png new file mode 100644 index 00000000..8b472e5c Binary files /dev/null and b/_site/public/imgs/modules/gerrit.png differ diff --git a/_site/public/imgs/modules/git.png b/_site/public/imgs/modules/git.png new file mode 100644 index 00000000..08772695 Binary files /dev/null and b/_site/public/imgs/modules/git.png differ diff --git a/_site/public/imgs/modules/github.png b/_site/public/imgs/modules/github.png new file mode 100644 index 00000000..0414537b Binary files /dev/null and b/_site/public/imgs/modules/github.png differ diff --git a/_site/public/imgs/modules/gitlab.png b/_site/public/imgs/modules/gitlab.png new file mode 100644 index 00000000..6e806a41 Binary files /dev/null and b/_site/public/imgs/modules/gitlab.png differ diff --git a/_site/public/imgs/modules/ipinfo.png b/_site/public/imgs/modules/ipinfo.png new file mode 100644 index 00000000..45eb5831 Binary files /dev/null and b/_site/public/imgs/modules/ipinfo.png differ diff --git a/_site/public/imgs/modules/jenkins.png b/_site/public/imgs/modules/jenkins.png new file mode 100644 index 00000000..5074eca1 Binary files /dev/null and b/_site/public/imgs/modules/jenkins.png differ diff --git a/_site/public/imgs/modules/jira.png b/_site/public/imgs/modules/jira.png new file mode 100644 index 00000000..8f80afee Binary files /dev/null and b/_site/public/imgs/modules/jira.png differ diff --git a/_site/public/imgs/modules/newrelic.png b/_site/public/imgs/modules/newrelic.png new file mode 100644 index 00000000..b1cc1db5 Binary files /dev/null and b/_site/public/imgs/modules/newrelic.png differ diff --git a/_site/public/imgs/modules/opsgenie.png b/_site/public/imgs/modules/opsgenie.png new file mode 100644 index 00000000..ccb3fbbe Binary files /dev/null and b/_site/public/imgs/modules/opsgenie.png differ diff --git a/_site/public/imgs/modules/power.png b/_site/public/imgs/modules/power.png new file mode 100644 index 00000000..1abd6ab9 Binary files /dev/null and b/_site/public/imgs/modules/power.png differ diff --git a/_site/public/imgs/modules/prettyweather.png b/_site/public/imgs/modules/prettyweather.png new file mode 100644 index 00000000..77c06b7b Binary files /dev/null and b/_site/public/imgs/modules/prettyweather.png differ diff --git a/_site/public/imgs/modules/security.png b/_site/public/imgs/modules/security.png new file mode 100644 index 00000000..380ee287 Binary files /dev/null and b/_site/public/imgs/modules/security.png differ diff --git a/_site/public/imgs/modules/textfile.png b/_site/public/imgs/modules/textfile.png new file mode 100644 index 00000000..b852062e Binary files /dev/null and b/_site/public/imgs/modules/textfile.png differ diff --git a/_site/public/imgs/modules/todo.png b/_site/public/imgs/modules/todo.png new file mode 100644 index 00000000..dc1fd744 Binary files /dev/null and b/_site/public/imgs/modules/todo.png differ diff --git a/_site/public/imgs/modules/todoist.png b/_site/public/imgs/modules/todoist.png new file mode 100644 index 00000000..086d0ec8 Binary files /dev/null and b/_site/public/imgs/modules/todoist.png differ diff --git a/_site/public/imgs/modules/travisci.png b/_site/public/imgs/modules/travisci.png new file mode 100644 index 00000000..eb423fa9 Binary files /dev/null and b/_site/public/imgs/modules/travisci.png differ diff --git a/_site/public/imgs/modules/trello.png b/_site/public/imgs/modules/trello.png new file mode 100644 index 00000000..79fa6965 Binary files /dev/null and b/_site/public/imgs/modules/trello.png differ diff --git a/_site/public/imgs/modules/weather.png b/_site/public/imgs/modules/weather.png new file mode 100644 index 00000000..1ab0beab Binary files /dev/null and b/_site/public/imgs/modules/weather.png differ diff --git a/_site/public/index.html b/_site/public/index.html new file mode 100644 index 00000000..510dbd37 --- /dev/null +++ b/_site/public/index.html @@ -0,0 +1,456 @@ + + + + WTF - the terminal dashboard + + + + +WTF - the terminal dashboard :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+ + +
+ + + + + + +
+ + + + + + + + navigation + + + +

Customize your own home page

+

+ The site is working. Don't forget to customize this homepage with your own. You typically have 2 choices : +

+ + +

+ + + + + +
+ +
+ +
+
+ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/_site/public/index.json b/_site/public/index.json new file mode 100644 index 00000000..de5b47c1 --- /dev/null +++ b/_site/public/index.json @@ -0,0 +1,295 @@ +[ +{ + "uri": "/posts/modules/twitter/", + "title": "Twitter", + "tags": [], + "description": "", + "content": " Added in v0.1.2.\nConnects to the Twitter API and displays a single user\u0026rsquo;s tweets.\nNOTE: This only works for single-application developer accounts for now.\nSource Code wtf/twitter/ Keyboard Commands None.\nConfiguration twitter: bearerToken: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 0 left: 1 height: 1 width: 1 refreshInterval: 20000 Attributes bearerToken Value: Your Twitter single-application Bearer Token\nenabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: Any positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/zendesk/", + "title": "Zendesk", + "tags": [], + "description": "", + "content": " Added in v0.1.0.\nDisplays tickets in the \u0026ldquo;New\u0026rdquo; status - i.e. have not yet been assigned.\nSource Code wtf/zendesk/ Keyboard Commands Key: [return] Action: Open the selected ticket in the browser.\nKey: j Action: Select the next item in the list.\nKey: k Action: Select the previous item in the list.\nKey: ↓ Action: Scroll down the list.\nKey: ↑ Action: Scroll up the list.\nConfiguration zendesk: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 0 left: 2 height: 1 width: 1 status: \u0026#34;new\u0026#34; subdomain: \u0026#34;your_domain\u0026#34; username: \u0026#34;your_email@acme.com\u0026#34; Attributes apiKey Value: Your Zendesk API token.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. status The status of tickets you want to retrieve. Values: new, open, pending, hold.\nsubdomain Value: Your Zendesk subdomain.\nusername Your Zendesk username Values: A valid Zendesk username (usually an email address).\n" +}, +{ + "uri": "/posts/modules/travisci/", + "title": "TravisCI", + "tags": [], + "description": "", + "content": " Added in v0.0.12.\nDisplays build information for your Travis CI account.\nSource Code wtf/travisci/ Keyboard Commands None.\nConfiguration travisci: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 4 left: 1 height: 1 width: 2 pro: false refreshInterval: 900 Attributes apiKey Value: Your Travis CI API access token.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\npro Determines whether or not this module will use the Pro version of Travis CI.\nValues: true, false.\n" +}, +{ + "uri": "/posts/modules/todoist/", + "title": "Todoist", + "tags": [], + "description": "", + "content": " Added in v0.0.11.\nDisplays all items on specified project.\nSource Code wtf/todoist/ Keyboard Commands Key: h Action: Show the previous project.\nKey: ← Action: Show the previous project.\nKey: l Action: Show the next project.\nKey: → Action: Show the next project.\nKey: j Action: Select the next item in the list.\nKey: ↓ Action: Select the next item in the list.\nKey: k Action: Select the previous item in the list.\nKey: ↑ Action: Select the previous item in the list.\nKey: c Action: Close current item.\nKey: d Action: Delete current item.\nKey: r Action: Reload all projects.\nConfiguration todoist: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 0 left: 2 height: 1 width: 1 projects: - 122247497 refreshInterval: 3600 Attributes apiKey Value: Your Todoist API token.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Where in the grid this module\u0026rsquo;s widget will be displayed. projects The todoist projects to fetch items from. Values: The integer ID of the project.\nrefreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/gerrit/", + "title": "Gerrit", + "tags": [], + "description": "", + "content": " Displays information about your projects hosted on Gerrit:\nOpen Incoming Reviews All open reviews that are requesting your approval.\nMy Outgoing Reviews All open reviews created by you.\nSource Code wtf/gerrit/ Keyboard Commands Key: / Action: Open/close the widget\u0026rsquo;s help window.\nKey: h Action: Show the previous project.\nKey: l Action: Show the next project.\nKey: j Action: Select the next review in the list.\nKey: k Action: Select the previous review in the list.\nKey: r Action: Refresh the data.\nKey: ← Action: Show the previous project.\nKey: → Action: Show the next project.\nKey: ↓ Action: Select the next review in the list.\nKey: ↑ Action: Select the previous review in the list.\nKey: [return] Action: Open the selected review in the browser.\nConfiguration gerrit: colors: rows: even: \u0026#34;lightblue\u0026#34; odd: \u0026#34;white\u0026#34; domain: https://gerrit-review.googlesource.com enabled: true password: \u0026#34;mypassword\u0026#34; position: top: 2 left: 3 height: 2 width: 2 projects: - org/test-project\u0026#34; - dotfiles refreshInterval: 300 username: \u0026#34;myname\u0026#34; verifyServerCertificate: false Attributes colors.rows.even Define the foreground color for even-numbered rows. Values: Any X11 color name.\ncolors.rows.odd Define the foreground color for odd-numbered rows. Values: Any X11 color name.\ndomain Your Gerrit corporate domain. Values: A valid URI.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\npassword Value: Your Gerrit HTTP Password.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. projects A list of Gerrit project names to fetch data for. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nusername Your Gerrit username.\nverifyServerCertificate Optional Determines whether or not the server\u0026rsquo;s certificate chain and host name are verified. Values: true, false.\n" +}, +{ + "uri": "/posts/modules/logger/", + "title": "Logger", + "tags": [], + "description": "", + "content": " Displays the contents of the WTF log file.\nTo log to this file in your own modules:\nrequire \u0026#34;github.com/senorprogrammer/wtf/logger\u0026#34; logger.Log(\u0026#34;This is a log entry\u0026#34;) Source Code wtf/logger/ Required ENV Variables None.\nKeyboard Commands Arrow keys scroll through the log file.\nConfiguration logger: enabled: true position: top: 5 left: 4 height: 2 width: 1 refreshInterval: 1 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Note: If you\u0026rsquo;re using logging and logging is disabled, your logs will still be written to file, the widget just won\u0026rsquo;t be shown onscreen. If you have logger.Log calls in your code, regardless of this setting, they will be written out. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/cryptocurrencies/blockfolio/", + "title": "Blockfolio", + "tags": [], + "description": "", + "content": " Added in v0.0.8.\nDisplay your Blockfolio crypto holdings.\nSource wtf/blockfolio/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration blockfolio: colors: name: blue grows: green drop: red device_token: \u0026#34;device token\u0026#34; displayHoldings: true enabled: true position: top: 3 left: 1 width: 1 height: 1 refreshInterval: 400 Attributes colors.name Values: Any X11 color name.\ncolors.grows Values: Any X11 color name.\ncolors.drop Values: Any X11 color name.\ndevice_token Value: See this gist for details on how to get your Blockfolio API token.\ndisplayHoldings enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/ipapi/", + "title": "IP-API", + "tags": [], + "description": "", + "content": " Added in v0.0.7.\nDisplays your current IP address information, from IP-APIcom.\nNote: IP-API.com has a free-plan rate limit of 120 requests per minute.\nSource Code wtf/ipapi/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration ipinfo: colors: name: red value: white enabled: true position: top: 1 left: 2 height: 1 width: 1 refreshInterval: 150 Attributes colors.name The default colour for the row names. Values: Any X11 color name.\ncolors.value The default colour for the row values. Values: Any X11 color name.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/circleci/", + "title": "CircleCI", + "tags": [], + "description": "", + "content": " Added in v0.0.7.\nDisplays build information for your CircleCI account.\nSource Code wtf/circleci/ Keyboard Commands None.\nConfiguration circleci: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 4 left: 1 height: 1 width: 2 refreshInterval: 900 Attributes apiKey Value: Your CircleCI API token.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/gspreadsheet/", + "title": "Google Spreadsheets", + "tags": [], + "description": "", + "content": " Added in v0.0.7.\nDisplay information from cells in a Google Spreadsheet.\nwtf/gspreadsheets/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration gspreadsheets: colors: values: \u0026#34;green\u0026#34; cells: names: - \u0026#34;Cell 1 name\u0026#34; - \u0026#34;Cell 2 name\u0026#34; addresses: - \u0026#34;A1\u0026#34; - \u0026#34;A2\u0026#34; enabled: true position: top: 0 left: 0 width: 1 height: 1 refreshInterval: \u0026#34;300\u0026#34; secretFile: \u0026#34;~/.config/wtf/gspreadsheets/client_secret.json\u0026#34; sheetId: \u0026#34;id_of_google_spreadsheet\u0026#34; Attributes colors.values The color to display the cell values in. Values: Any X11 color name.\ncells.names cells.addresses enabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nsecretFile Your Google client secret JSON file. Values: A string representing a file path to the JSON secret file.\n" +}, +{ + "uri": "/posts/modules/jenkins/", + "title": "Modules: Jenkins", + "tags": [], + "description": "", + "content": " Added in v0.0.8.\nDisplays jenkins status of given builds in a project or view\nSource Code wtf/jenkins/ Keyboard Commands None.\nConfiguration jenkins: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 2 left: 3 height: 2 width: 3 refreshInterval: 300 url: \u0026#34;https://jenkins.domain.com/jenkins/view_url\u0026#34; user: \u0026#34;username\u0026#34; verifyServerCertificate: true Attributes apiKey Value: Your Jenkins API key.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed.\nrefreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nuser Your Jenkins username. url The url to your Jenkins project or view. Values: A valid URI.\nverifyServerCertificate Optional Determines whether or not the server\u0026rsquo;s certificate chain and host name are verified. Values: true, false.\n" +}, +{ + "uri": "/posts/modules/gitlab/", + "title": "GitLab", + "tags": [], + "description": "", + "content": " Added in v0.0.8.\nDisplays information about your projects hosted on GitLab:\nOpen Approval Requests All open merge requests that are requesting your approval.\nOpen Merge Requests All open merge requests created by you.\nSource Code wtf/gitlab/ Keyboard Commands Key: / Action: Open/close the widget\u0026rsquo;s help window.\nKey: h Action: Show the previous project.\nKey: l Action: Show the next project.\nKey: ← Action: Show the previous project.\nKey: → Action: Show the next project.\nConfiguration gitlab: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 2 left: 3 height: 2 width: 2 refreshInterval: 300 projects: tasks: \u0026#34;gitlab-org/release\u0026#34; gitlab-ce: \u0026#34;gitlab-org\u0026#34; username: \u0026#34;senorprogrammer\u0026#34; Attributes apiKey Value: A GitLab personal access token. Requires at least api access.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\ndomain Optional. Your GitLab corporate domain. Values: A valid URI.\nprojects A list of key/value pairs each describing a GitLab project to fetch data for. Key: The name of the project. Value: The namespace of the project.\nusername Your GitLab username. Used to figure out which requests require your approval\n" +}, +{ + "uri": "/posts/modules/cryptocurrencies/bittrex/", + "title": "Bittrex", + "tags": [], + "description": "", + "content": " Added in v0.0.5.\nGet the last 24 hour summary of cryptocurrencies market using Bittrex.\nSource Code wtf/cryptoexchanges/bittrex/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration bittrex: enabled: true position: top: 1 left: 2 height: 3 width: 1 refreshInterval: 5 summary: BTC: displayName: Bitcoin market: - LTC - ETH colors: base: name: orange displayName: red market: name: red field: white value: green Attributes colors.base.name Values: Any X11 color name.\ncolors.base.dispayName Values: Any X11 color name.\ncolors.market.name Values: Any X11 color name.\ncolors.market.field Values: Any X11 color name.\ncolors.market.value Values: Any X11 color name.\nsummary enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/cryptocurrencies/cryptolive/", + "title": "CryptoLive", + "tags": [], + "description": "", + "content": " Added in v0.0.5.\nCompare crypto currencies using CryptoCompare.\nSource Code wtf/cryptoexchanges/cryptolive/ Required ENV Vars None.\nKeyboard Commands None.\nConfiguration cryptolive: enabled: true position: top: 5 left: 2 height: 1 width: 2 updateInterval: 15 currencies: BTC: displayName: Bitcoin to: - USD - EUR - ETH - LTC - DOGE LTC: displayName: Ethereum to: - USD - EUR - BTC top: BTC: displayName: Bitcoin limit: 5 to: - USD colors: from: name: coral displayName: grey to: name: white price: green top: from: name: grey displayName: coral to: name: red field: white value: green Attributes colors.from.name Values: Any X11 color name.\ncolors.from.dispayName Values: Any X11 color name.\ncolors.to.name Values: Any X11 color name.\ncolors.to.price Values: Any X11 color name.\ncurrencies enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/prettyweather/", + "title": "Pretty Weather", + "tags": [], + "description": "", + "content": " Displays weather information as ASCII art from Wttr.in.\nSource Code wtf/prettyweather/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration prettyweather: enabled: true city: \u0026#34;tehran\u0026#34; position: top: 3 left: 5 height: 1 width: 1 refreshInterval: 300 unit: \u0026#34;c\u0026#34; view: 0 language: \u0026#34;en\u0026#34; Attributes city Optional. It will grab the current location from your IP address if omitted.\nValues: The name of any city supported by Wttr.in.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nunit Optional. It will use metric if you are out of US and imperial for US.\nThe temperature scale in which to display temperature values. Values: F for Fahrenheit, C for Celcius.\nview Optional Wttr.in view configuration. Values: See curl wttr.in/:help for more details.\nlanguage Optional Wttr.in language configuration. Values: See curl wttr.in/:translation for more details.\n" +}, +{ + "uri": "/posts/modules/ipinfo/", + "title": "IPInfo", + "tags": [], + "description": "", + "content": " Displays your current IP address information, from ipinfo.io.\nNote: IPInfo.io has a free-plan rate limit of 1000 requests per day.\nSource Code wtf/ipinfo/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration ipinfo: colors: name: red value: white enabled: true position: top: 1 left: 2 height: 1 width: 1 refreshInterval: 150 Attributes colors.name The default colour for the row names. Values: Any X11 color name.\ncolors.value The default colour for the row values. Values: Any X11 color name.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/power/", + "title": "Power", + "tags": [], + "description": "", + "content": " Displays information about the current power source.\nFor battery, also displays the current charge, estimated time remaining, and whether it is charging or discharging.\nSource Code wtf/power/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration power: enabled: true position: top: 5 left: 0 height: 2 width: 1 refreshInterval: 15 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/configuration/iterm2/", + "title": "Configuration: iTerm2", + "tags": [], + "description": "", + "content": "Many terminal apps don\u0026rsquo;t properly display multibyte emoji characters properly. This may fix the issue for you in iTerm2, it also may not.\nBy default iTerm2 uses a unicode rendering format that is not comletely compatible with some emoji characters. Instead what you\u0026rsquo;ll see is the emoji over-lapping normal text characters, or drawing outside the bounds of where they should be.\nIn iTerm2 open:\nPreferences -\u0026gt; Profiles -\u0026gt; Text and check on the \u0026ldquo;Use Unicode Version 9 Widths\u0026rdquo; checkbox. Then restart WTF.\n(Note: This issue is not unique to iTerm2. As of this writing it also affects Terminal, and Hyper.)\n" +}, +{ + "uri": "/posts/overview/", + "title": "Overview", + "tags": [], + "description": "", + "content": " WTF is a personal information dashboard for your terminal, developed for those who spend most of their day in the command line.\nIt allows you to monitor services and systems that you otherwise might keep browser tabs open for, the kinds of things you don\u0026rsquo;t always need visible, but might check in on every now and then.\nQuick Start Download the stand-alone, compiled binary. Unzip the downloaded file. From the command line, cd into the newly-created /wtf directory. From the command line, run the app: ./wtf This should launch the app in your terminal using the default simple configuration. See Configuration for more details.\nCommand-line Options --config, -c Allows you to define a custom config file to use. See Configuration for more details.\n--help, -h Shows help information for the command-line arguments that WTF takes.\n--module, -m Shows help information for the specific named module, if that module supports help text. Example: wtf --module=todo.\n--version, -v Shows version info.\nKeyboard Commands Key: Ctrl-R Action: Force-refresh the data for all modules.\nKey: Esc Action: Unfocus the currently-focused widget.\nKey: Tab Action: Move between focusable modules (Shift-Tab to move backwards).\n" +}, +{ + "uri": "/posts/installation/", + "title": "Installation", + "tags": [], + "description": "", + "content": " There are two ways to install WTF:\nFrom Source Get this repo and install the dependencies:\ngo get -u github.com/senorprogrammer/wtf cd $GOPATH/src/github.com/senorprogrammer/wtf make install make run and that should probably do it.\nAs a Binary Grab the latest version from here:\nhttps://github.com/senorprogrammer/wtf/releases expand it, and cd into the resulting directory. Then run:\n./wtf and that should also do it.\n" +}, +{ + "uri": "/posts/modules/cmdrunner/", + "title": "CmdRunner", + "tags": [], + "description": "", + "content": " Runs a terminal command on a schedule.\nSource Code wtf/cmdrunner/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration cmdrunner: args: [\u0026#34;-g\u0026#34;, \u0026#34;batt\u0026#34;] cmd: \u0026#34;pmset\u0026#34; enabled: true position: top: 6 left: 1 height: 1 width: 3 refreshInterval: 30 Attributes args The arguments to the command, with each item as an element in an array. Example: for curl -I cisco.com, the arguments array would be [\u0026quot;-I\u0026quot;, \u0026quot;cisco.com\u0026quot;].\ncmd The terminal command to be run, withouth the arguments. Ie: ping, whoami, curl. enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed.\nrefreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/configuration/attributes/", + "title": "Configuration: Attributes", + "tags": [], + "description": "", + "content": " The following top-level attributes are configurable in config.yml. See this example config file for more details.\nwtf: colors: background: \u0026#34;red\u0026#34; border: Focusable: \u0026#34;darkslateblue\u0026#34; focused: \u0026#34;orange\u0026#34; normal: \u0026#34;gray\u0026#34; grid: # How _wide_ the columns are, in terminal characters. In this case we have # six columns, each of which are 35 characters wide columns: [35, 35, 35, 35, 35, 35] # How _high_ the rows are, in terminal lines. In this case we have five rows # that support ten line of text, one of three lines, and one of four rows: [10, 10, 10, 10, 10, 3, 4] # The app redraws itself once a second openFileUtil: open refreshInterval: 1 term: \u0026#34;xterm-256color\u0026#34; Attributes colors.background The color to draw the background of the app in. Use this to match your terminal colors. May be over-written by individual module configurations. Values: Any X11 color name.\ncolors.border.focusable The color in which to draw the border of widgets that can accept keyboard focus. Values: Any X11 color name.\ncolors.border.focused The color in which to draw the border of the widget that currently has keyboard focus. Values: Any X11 color name.\ncolors.border.normal The color in which to draw the borders of the widgets that cannot accept focus. Values: Any X11 color name.\ngrid.columns An array that defines the widths of all the columns. Values: See tview\u0026rsquo;s Grid for details.\ngrid.rows An array that defines the heights of all the rows. Values: See tview\u0026rsquo;s Grid for details.\nopenFileUtil Command to use to open a file or URL\nrefreshInterval How often, in seconds, the UI refreshes itself. Note: This implementation is probably wrong and buggy and likely to change. Values: A positive integer, 0..n.\nterm Optional. Sets a custom value for the terminal type this app runs in. Leave this entry out of the config if you simply want to use your terminal\u0026rsquo;s default setting. Note: If an invalid value is provided for this setting, the app will crash with a \u0026quot;terminal entry not found\u0026quot; error. Values: Any valid terminal type (ie: vt100, xterm, xterm-256color, ansi, etc.).\n" +}, +{ + "uri": "/posts/modules/todo/", + "title": "Todo", + "tags": [], + "description": "", + "content": " An interactive todo list.\nSource Code wtf/todo/ Required ENV Variables None.\nKeyboard Commands Key: [return] Action: Edit the selected item. Action: Close the modal item dialog and save changes. Key: [esc] Action: Remove focus from the selected item. Action: Close the modal item dialog without saving changes.\nKey: [space] Action: Check/uncheck the selected item.\nKey: / Action: Open/close the widget\u0026rsquo;s help window.\nKey: j Action: Select the next item in the list.\nKey: k Action: Select the previous item in the list.\nKey: n Action: Create a new list item.\nKey: o Action: Opens the todo list file in whichever text editor is associated with that file type.\nKey: ↓ Action: Select the next item in the list.\nKey: ↑ Action: Select the previous item in the list.\nKey: Ctrl-d Action: Delete the selected item.\nKey: Ctrl-J Action: Move the selected item down the list.\nKey: Ctrl-K Action: Move the selected item up the list.\nConfiguration todo: checkedIcon: \u0026#34;X\u0026#34; colors: checked: gray highlight: fore: \u0026#34;black\u0026#34; back: \u0026#34;orange\u0026#34; enabled: true filename: \u0026#34;todo.yml\u0026#34; position: top: 2 left: 2 height: 2 width: 1 refreshInterval: 3600 Attributes checkedIcon The icon used to denote a \u0026ldquo;checked\u0026rdquo; todo item. Values: Any displayable unicode character.\ncolors.checked Values: Any X11 color name.\ncolors.highlight.fore The foreground color for the currently-selected row. Values: Any X11 color name.\ncolors.highlight.back The background color for the currently-selected row. Values: Any X11 color name.\nenabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nfilename The name for the todo file. Values: Any valid filename, ideally ending in yml.\nposition Where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/jira/", + "title": "Jira", + "tags": [], + "description": "", + "content": " Displays all Jira issues assigned to you for the specified project.\nSource Code wtf/jira/ Keyboard Commands Key: [return] Action: Open the selected issue in the browser.\nKey: j Action: Select the next item in the list.\nKey: k Action: Select the previous item in the list.\nKey: ↓ Action: Select the next item in the list.\nKey: ↑ Action: Select the previous item in the list.\nConfiguration Single Jira Project jira: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; colors: rows: even: \u0026#34;lightblue\u0026#34; odd: \u0026#34;white\u0026#34; domain: \u0026#34;https://umbrellacorp.atlassian.net\u0026#34; email: \u0026#34;chriscummer@me.com\u0026#34; enabled: true jql: \u0026#34;issueType = Story\u0026#34; position: top: 4 left: 1 height: 1 width: 2 project: \u0026#34;ProjectA\u0026#34; refreshInterval: 900 username: \u0026#34;chris.cummer\u0026#34; verifyServerCertificate: true Multiple Jira Projects If you want to monitor multiple Jira projects, use the following configuration (note the difference in project):\njira: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; colors: rows: even: \u0026#34;lightblue\u0026#34; odd: \u0026#34;white\u0026#34; domain: \u0026#34;https://umbrellacorp.atlassian.net\u0026#34; email: \u0026#34;chriscummer@me.com\u0026#34; enabled: true jql: \u0026#34;issueType = Story\u0026#34; position: top: 4 left: 1 height: 1 width: 2 project: [\u0026#34;ProjectA\u0026#34;, \u0026#34;ProjectB\u0026#34;] refreshInterval: 900 username: \u0026#34;chris.cummer\u0026#34; verifyServerCertificate: true Attributes apiKey Value: Your Jira API key.\ncolors.rows.even Define the foreground color for even-numbered rows. Values: Any X11 color name.\ncolors.rows.odd Define the foreground color for odd-numbered rows. Values: Any X11 color name.\ndomain Your Jira corporate domain. Values: A valid URI.\nemail The email address associated with your Jira account. Values: A valid email address string.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\njql Optional Custom JQL to be appended to the search query. Values: See Search Jira like a boss with JQL for details.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. project The Jira project to fetch information for. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nusername Your Jira username. verifyServerCertificate Optional Determines whether or not the server\u0026rsquo;s certificate chain and host name are verified. Values: true, false.\n" +}, +{ + "uri": "/posts/modules/trello/", + "title": "Trello", + "tags": [], + "description": "", + "content": " Displays all Trello cards on specified lists.\nSource Code wtf/trello/ Keyboard Commands None.\nConfiguration Single Trello List trello: accessToken: \u0026#34;7b8b14f8743a408a93276d7155dd9ee2\u0026#34; apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; board: Main enabled: true list: \u0026#34;Todo\u0026#34; position: height: 1 left: 2 top: 0 width: 1 refreshInterval: 3600 username: myname Multiple Trello Lists If you want to monitor multiple Trello lists, use the following configuration (note the difference in list):\ntrello: accessToken: \u0026#34;7b8b14f8743a408a93276d7155dd9ee2\u0026#34; apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; board: Main enabled: true list: [\u0026#34;Todo\u0026#34;, \u0026#34;Done\u0026#34;] position: height: 1 left: 2 top: 0 width: 1 refreshInterval: 3600 username: myname Attributes accessToken Value: Your Trello access token.\napiKey Value: Your Trello API key.\nboard The name of the Trello board. enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nlist The Trello lists to fetch cards from. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nusername Your Trello username. position Where in the grid this module\u0026rsquo;s widget will be displayed. " +}, +{ + "uri": "/posts/modules/gcal/", + "title": "Google Calendar", + "tags": [], + "description": "", + "content": " Displays your upcoming Google calendar events.\nNot: Setting up access to Google Calendars for Go is a bit unobvious. Check out Google\u0026rsquo;s Go Quickstart first and if you have problems, then take a look at this comment by WesleydeSouza which offers a slightly different approach.\nSource Code wtf/gcal/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration gcal: colors: title: \u0026#34;red\u0026#34; description: \u0026#34;lightblue\u0026#34; highlights: - [\u0026#39;1on1|1\\/11\u0026#39;, \u0026#39;green\u0026#39;] - [\u0026#39;apple|google|aws\u0026#39;, \u0026#39;blue\u0026#39;] - [\u0026#39;interview|meet\u0026#39;, \u0026#39;magenta\u0026#39;] - [\u0026#39;lunch\u0026#39;, \u0026#39;yellow\u0026#39;] past: \u0026#34;gray\u0026#34; conflictIcon: \u0026#34;🚨\u0026#34; currentIcon: \u0026#34;💥\u0026#34; displayResponseStatus: true email: \u0026#34;chriscummer@me.com\u0026#34; enabled: true eventCount: 12 multiCalendar: true position: top: 0 left: 0 height: 4 width: 1 refreshInterval: 300 secretFile: \u0026#34;~/.config/wtf/gcal/client_secret.json\u0026#34; showDeclined: true withLocation: true Attributes colors.title The default colour for calendar event titles. Values: Any X11 color name.\ncolors.description The default color for calendar event descriptions. Values: Any X11 color name.\ncolors.highlights A list of arrays that define a regular expression pattern and a color. If a calendar event title matches a regular expression, the title will be drawn in that colour. Over-rides the default title colour. Values: [a valid regular expression, any X11 color name.]\ncolors.past The color for calendar events that have passed. Values: Any X11 color name.\nconflictIcon The icon displayed beside calendar events that have conflicting times (they intersect or overlap in some way). Values: Any displayable unicode character.\ncurrentIcon The icon displayed beside the current calendar event. Values: Any displayable unicode character.\ndisplayLocation Whether or not to display the location of the calendar event. Values: true, false.\ndisplayResponseStatus Whether or not to display your response status to the calendar event. Values: true, false.\nemail The email address associated with your Google account. Necessary for determining responseStatus. Values: A valid email address string.\nenabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false.\neventCount The number of calendar events to display. Values: A positive integer, 0..n.\nmultiCalendar Whether or not to display your primary calendar or all calendars you have access to. Values: true, or false\nposition Where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nsecretFile Your Google client secret JSON file. Values: A string representing a file path to the JSON secret file.\nshowDeclined Optional. Whether or not to display events you\u0026rsquo;ve declined to attend. Values: true, or false\nwithLocation Whether or not to show the location of the appointment. Values: true, or false\n" +}, +{ + "uri": "/posts/modules/github/", + "title": "GitHub", + "tags": [], + "description": "", + "content": " Displays information about your git repositories hosted on GitHub:\nOpen Review Requests All open code review requests assigned to you.\nOpen Pull Requests All open pull requests created by you.\nSource Code wtf/github/ Keyboard Commands Key: / Action: Open/close the widget\u0026rsquo;s help window.\nKey: h Action: Show the previous git repository.\nKey: l Action: Show the next git repository.\nKey: ← Action: Show the previous git repository.\nKey: → Action: Show the next git repository.\nConfiguration github: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; baseURL: \u0026#34;\u0026#34; enabled: true enableStatus: true position: top: 2 left: 3 height: 2 width: 2 refreshInterval: 300 repositories: wesker-api: \u0026#34;UmbrellaCorp\u0026#34; wtf: \u0026#34;senorprogrammer\u0026#34; uploadURL: \u0026#34;\u0026#34; username: \u0026#34;senorprogrammer\u0026#34; Attributes apiKey Value: Your GitHub API token.\nbaseURL Optional Value: Your GitHub Enterprise API URL.\nenabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nenableStatus Display pull request mergeability status (\u0026lsquo;dirty\u0026rsquo;, \u0026lsquo;clean\u0026rsquo;, \u0026lsquo;unstable\u0026rsquo;, \u0026lsquo;blocked\u0026rsquo;).\nValues: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nrepositories A list of key/value pairs each describing a GitHub repository to fetch data for. Key: The name of the repository. Value: The name of the account or organization that owns the repository.\nuploadURL Optional Value: Your GitHub Enterprise upload URL (often the same as API URL).\nusername Your GitHub username. Used to figure out which review requests you\u0026rsquo;ve been added to.\n" +}, +{ + "uri": "/posts/modules/git/", + "title": "Git", + "tags": [], + "description": "", + "content": " Displays information about local git repositories: branch, changed files, and recent commits.\nBranch The name of the currently-active git branch.\nChanged Files A list of all the files that have changed since the last commit, and their status.\nRecent Commits A list of n recent commits, who committed it, and when.\nSource Code wtf/git/ Required ENV Variables None.\nKeyboard Commands Key: / Action: Open/close the widget\u0026rsquo;s help window.\nKey: h Action: Show the previous git repository.\nKey: l Action: Show the next git repository.\nKey: ← Action: Show the previous git repository.\nKey: → Action: Show the next git repository.\nConfiguration git: commitCount: 5 commitFormat: \u0026#34;[forestgreen]%h [grey]%cd [white]%s [grey]%an[white]\u0026#34; dateFormat: \u0026#34;%H:%M %d %b %y\u0026#34; enabled: true position: top: 0 left: 3 height: 2 width: 2 refreshInterval: 8 repositories: - \u0026#34;/Users/chris/go/src/github.com/senorprogrammer/wtf\u0026#34; - \u0026#34;/Users/user/fakeapp\u0026#34; Attributes commitCount The number of past commits to display. Values: A positive integer, 0..n.\ncommitFormat Optional The string format for the commit message. dateFormat Optional The string format for the date/time in the commit message. enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nrepositories Defines which git repositories to watch. Values: A list of zero or more local file paths pointing to valid git repositories.\n" +}, +{ + "uri": "/posts/modules/weather/", + "title": "Weather", + "tags": [], + "description": "", + "content": " Displays a configurable list of current weather report, including current temperature, sunrise time, and sunset time.\nSource Code wtf/weather/ Required ENV Variables Key: WTF_OWM_API_KEY Action: Your OpenWeatherMap API key. Note: DEPRECATED. See the apiKey config value, below.\nKeyboard Commands Key: / Action: Open/close the widget\u0026rsquo;s help window.\nKey: h Action: Show the previous weather location.\nKey: l Action: Show the next weather location.\nKey: ← Action: Show the previous weather location.\nKey: → Action: Show the next weather location.\nConfiguration weather: apiKey: \u0026#34;2dfb3e3650a1950adddb6badf5ba1aaa\u0026#34; # From http://openweathermap.org/help/city_list.txt cityids: - 6173331 - 3128760 - 6167865 - 6176823 colors: current: \u0026#34;lightblue\u0026#34; enabled: true language: \u0026#34;EN\u0026#34; position: top: 0 left: 2 height: 1 width: 1 refreshInterval: 900 tempUnit: \u0026#34;C\u0026#34; Attributes apiKey Your OpenWeatherMap API key.\ncityids A list of the OpenWeatherMap city IDs for the cities you want to view. Values: A list of positive integers, 0..n\ncolors.current The color to highlight the current temperature in. Values: Any X11 color name.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nlanguage The human language in which to present the weather data. Values: Any language identifier specified by OpenWeatherMap.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\ntempUnit The temperature scale in which to display temperature values. Values: F for Fahrenheit, C for Celcius.\n" +}, +{ + "uri": "/posts/modules/textfile/", + "title": "Textfile", + "tags": [], + "description": "", + "content": " Displays the contents of the specified text file in the widget.\nSource Code wtf/textfile/ Required ENV Variables None.\nKeyboard Commands Key: / Action: Open/close the widget\u0026rsquo;s help window.\nKey: o Action: Opens the text file in whichever text editor is associated with that file type.\nConfiguration textfile: enabled: true filePath: \u0026#34;~/Desktop/notes.md\u0026#34; position: top: 5 left: 4 height: 2 width: 1 refreshInterval: 15 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nfilePath The path to the file to be displayed in the widget. position Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/newrelic/", + "title": "New Relic", + "tags": [], + "description": "", + "content": " Connects to the New Relic API and displays the last n deploys of the monitored application: deploy ID, deploy time, and who deployed it.\nSource Code wtf/newrelic/ Keyboard Commands None.\nConfiguration newrelic: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; applicationId: 10549735 deployCount: 6 enabled: true position: top: 4 left: 3 height: 1 width: 2 refreshInterval: 900 Attributes apiKey Value: Your New Relic API token.\napplicationId The integer ID of the New Relic application you wish to report on. Values: A positive integer, 0..n.\ndeployCount The number of past deploys to display on screen. Values: A positive integer, 0..n.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/opsgenie/", + "title": "OpsGenie", + "tags": [], + "description": "", + "content": " Connects to the OpsGenie API and displays all your scheduled rotations and who\u0026rsquo;s currently on call.\nSource Code wtf/opsgenie/ Keyboard Commands None.\nConfiguration opsgenie: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; displayEmpty: false enabled: true position: top: 2 left: 1 height: 2 width: 1 refreshInterval: 21600 Attributes apiKey \u0026lt; br /\u0026gt; Value: Your OpsGenie API token.\ndisplayEmpty Whether schedules with no assigned person on-call should be displayed. Values: true, false.\nenabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/security/", + "title": "Security", + "tags": [], + "description": "", + "content": " Displays some general information about the state of the machine\u0026rsquo;s wifi connection, firewall, DNS settings, and logged-in users.\nWifi Network The name of the current network Whether or not the network uses encryption and if so, what flavour Firewall Whether or not the firewall is enabled Whether or not Stealth Mode is enabled DNS Which DNS resolvers (servers) the machine is configured to use Users Which users are logged into the machine. Note: Does not yet show hidden users. Source Code wtf/security/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration security: enabled: true position: top: 1 left: 2 height: 1 width: 1 refreshInterval: 3600 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "/posts/modules/bamboohr/", + "title": "BambooHR", + "tags": [], + "description": "", + "content": " Connects to the BambooHR API and displays who will be Away today.\nSource Code wtf/bamboohr/ Keyboard Commands None.\nConfiguration bamboohr: apiKey: \u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34; enabled: true position: top: 0 left: 1 height: 2 width: 1 refreshInterval: 900 subdomain: \u0026#34;testco\u0026#34; Attributes apiKey Value: Your BambooHR API token.\nenabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: Any positive integer, 0..n.\nsubdomain Value: Your BambooHR API subdomain name.\n" +}, +{ + "uri": "/posts/modules/clocks/", + "title": "Clocks", + "tags": [], + "description": "", + "content": " Displays a configurable list of world clocks, the local time, and date.\nSource Code wtf/clocks/ Required ENV Variables None.\nKeyboard Commands None.\nConfiguration clocks: colors: rows: even: \u0026#34;lightblue\u0026#34; odd: \u0026#34;white\u0026#34; enabled: true locations: # From https://en.wikipedia.org/wiki/List_of_tz_database_time_zones Avignon: \u0026#34;Europe/Paris\u0026#34; Barcelona: \u0026#34;Europe/Madrid\u0026#34; Dubai: \u0026#34;Asia/Dubai\u0026#34; New York: \u0026#34;America/New York\u0026#34; Toronto: \u0026#34;America/Toronto\u0026#34; UTC: \u0026#34;Etc/UTC\u0026#34; Vancouver: \u0026#34;America/Vancouver\u0026#34; position: top: 4 left: 0 height: 1 width: 1 refreshInterval: 15 # Valid options are: alphabetical, chronological sort: \u0026#34;alphabetical\u0026#34; Attributes colors.rows.even The foreground color for even-numbered rows. Values: Any X11 color name.\ncolors.rows.odd The foreground color for the odd-numbered rows. Values: Any X11 color name.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nlocations Defines the timezones for the world clocks that you want to display. key is a unique label that will be displayed in the UI. value is a timezone name. Values: Any TZ database timezone.\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed.\nrefreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\nsort Defines the display order of the clocks in the widget. Values: alphabetical or chronological. alphabetical will sort in acending order by key, chronological will sort in ascending order by date/time.\n" +}, +{ + "uri": "/posts/modules/", + "title": "Modules", + "tags": [], + "description": "", + "content": "The heart of WTF is the modules. A module is a discreet unit of functionality that extracts data from some source and packages that data for display.\nFor example, the New Relic module uses New Relic\u0026rsquo;s API to retrieve a list of the latest deploys and packages that information as a list for display in the \u0026ldquo;New Relic\u0026rdquo; widget.\nThe Clocks module takes a list of timezones and packages that information as a list of city/time pairs for display in the \u0026ldquo;Clocks\u0026rdquo; widget.\nSee available modules at left.\n" +}, +{ + "uri": "/posts/glossary/", + "title": "Glossary", + "tags": [], + "description": "", + "content": " Module A discreet unit of data collection and display. A data interface concept. A package inside the app.\nExamples: New Relic, Git, Weather.\nWidget The onscreen representation of a Module. The widget is responsible for being the interface between the app and the data collection.\nWidgets are defined by a required widget.go file in a Module.\n" +}, +{ + "uri": "/posts/configuration/", + "title": "Configuration", + "tags": [], + "description": "", + "content": " Index Configuration Files Environment (ENV) Variables Grid Layout Configuration Files By default WTF looks in a ~/.config/wtf/ directory for a YAML file called config.yml. If the ~/.config/wtf/ directory doesn\u0026rsquo;t exist, WTF will create that directory on start-up, and then display instructions for creating a new configuration file.\nIn other words, WTF expects to have a YAML config file at: ~/.config/wtf/config.yml.\nExample Configuration Files A couple of example config files are provided in the _sample_configs/ directory of the Git repository.\nTo try out WTF quickly, copy simple_config.yml into ~/.config/wtf/ as config.yml and relaunch WTF. You should see the app launch and display the Security, Clocks and Status widgets onscreen.\nCustom Configuration Files To try out different configurations (or run multiple instances of WTF), you can pass the path to a config file via command line arguments on start-up.\nTo load a custom configuration file (ie: one that\u0026rsquo;s not ~/.config/wtf/config.yml), pass in the path to configuration file as a parameter on launch:\n$\u0026gt; wtf --config=path/to/custom/config.yml Configuration Attributes A number of top-level attributes can be set to customize your WTF install. See Attributes for details.\nEnvironment (ENV) Variables Some modules require the presence of environment variables to function properly. Usually these are API keys or other sensitive data that one wouldn\u0026rsquo;t want to have laying about in the config files.\nFor modules that require them, the name of the required environment variable(s) can be found in that module\u0026rsquo;s \u0026ldquo;Required ENV Variables\u0026rdquo; section of the documentation. See OpsGenie for an example.\nGrid Layout WTF uses the Grid layout system from tview to position widgets onscreen. It\u0026rsquo;s not immediately obvious how this works, so here\u0026rsquo;s an explanation:\nThink of your terminal screen as a matrix of letter positions, say 100 chrs wide and 58 chrs tall.\nColumns breaks up the width of the screen into chunks, each chunk a specified number of characters wide. use\n[10, 10, 10, 10, 10, 10, 10, 10, 10, 10]\nTen columns that are ten characters wide\nRows break up the height of the screen into chunks, each chunk a specified number of characters tall. If we wanted to have five rows:\n[10, 10, 10, 10, 18]\nThe co-ordinate system starts at top-left and defines how wide and tall a widget is. If we wanted to put a 2-col, 2-row widget in the bottom of the screen, we\u0026rsquo;d position it at:\n top: 4 // top starts in the 4th row left: 9 // left starts in the 9th column height: 2 // span down rows 4 \u0026amp; 5 (18 characters in size, total) width: 2 // span across cols 9 \u0026amp; 10 (20 characters in size, total) " +}, +{ + "uri": "/categories/", + "title": "Categories", + "tags": [], + "description": "", + "content": "" +}, +{ + "uri": "/posts/", + "title": "Posts", + "tags": [], + "description": "", + "content": "" +}, +{ + "uri": "/tags/", + "title": "Tags", + "tags": [], + "description": "", + "content": "" +}, +{ + "uri": "/", + "title": "WTF - the terminal dashboard", + "tags": [], + "description": "", + "content": "" +}] \ No newline at end of file diff --git a/_site/public/index.xml b/_site/public/index.xml new file mode 100644 index 00000000..8b7755b9 --- /dev/null +++ b/_site/public/index.xml @@ -0,0 +1,529 @@ + + + + WTF - the terminal dashboard + / + Recent content on WTF - the terminal dashboard + Hugo -- gohugo.io + en-us + Tue, 31 Jul 2018 20:21:37 -0700 + + + + + + Twitter + /posts/modules/twitter/ + Tue, 31 Jul 2018 20:21:37 -0700 + + /posts/modules/twitter/ + Added in v0.1.2. +Connects to the Twitter API and displays a single user’s tweets. +NOTE: This only works for single-application developer accounts for now. +Source Code wtf/twitter/ Keyboard Commands None. +Configuration twitter: bearerToken: "3276d7155dd9ee27b8b14f8743a408a9" enabled: true position: top: 0 left: 1 height: 1 width: 1 refreshInterval: 20000 Attributes bearerToken Value: Your Twitter single-application Bearer Token +enabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false. + + + + Zendesk + /posts/modules/zendesk/ + Mon, 23 Jul 2018 18:55:37 -0800 + + /posts/modules/zendesk/ + Added in v0.1.0. +Displays tickets in the “New” status - i.e. have not yet been assigned. +Source Code wtf/zendesk/ Keyboard Commands Key: [return] Action: Open the selected ticket in the browser. +Key: j Action: Select the next item in the list. +Key: k Action: Select the previous item in the list. +Key: ↓ Action: Scroll down the list. +Key: ↑ Action: Scroll up the list. +Configuration zendesk: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" enabled: true position: top: 0 left: 2 height: 1 width: 1 status: "new" subdomain: "your_domain" username: "your_email@acme. + + + + TravisCI + /posts/modules/travisci/ + Wed, 18 Jul 2018 14:36:08 -0400 + + /posts/modules/travisci/ + Added in v0.0.12. +Displays build information for your Travis CI account. +Source Code wtf/travisci/ Keyboard Commands None. +Configuration travisci: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" enabled: true position: top: 4 left: 1 height: 1 width: 2 pro: false refreshInterval: 900 Attributes apiKey Value: Your Travis CI API access token. +enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. +position Defines where in the grid this module’s widget will be displayed. + + + + Todoist + /posts/modules/todoist/ + Thu, 05 Jul 2018 22:55:55 -0300 + + /posts/modules/todoist/ + Added in v0.0.11. +Displays all items on specified project. +Source Code wtf/todoist/ Keyboard Commands Key: h Action: Show the previous project. +Key: ← Action: Show the previous project. +Key: l Action: Show the next project. +Key: → Action: Show the next project. +Key: j Action: Select the next item in the list. +Key: ↓ Action: Select the next item in the list. +Key: k Action: Select the previous item in the list. + + + + Gerrit + /posts/modules/gerrit/ + Wed, 27 Jun 2018 15:55:42 -0700 + + /posts/modules/gerrit/ + Displays information about your projects hosted on Gerrit: +Open Incoming Reviews All open reviews that are requesting your approval. +My Outgoing Reviews All open reviews created by you. +Source Code wtf/gerrit/ Keyboard Commands Key: / Action: Open/close the widget’s help window. +Key: h Action: Show the previous project. +Key: l Action: Show the next project. +Key: j Action: Select the next review in the list. +Key: k Action: Select the previous review in the list. + + + + Logger + /posts/modules/logger/ + Sat, 16 Jun 2018 14:22:18 -0700 + + /posts/modules/logger/ + Displays the contents of the WTF log file. +To log to this file in your own modules: +require "github.com/senorprogrammer/wtf/logger" logger.Log("This is a log entry") Source Code wtf/logger/ Required ENV Variables None. +Keyboard Commands Arrow keys scroll through the log file. +Configuration logger: enabled: true position: top: 5 left: 4 height: 2 width: 1 refreshInterval: 1 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. + + + + Blockfolio + /posts/modules/cryptocurrencies/blockfolio/ + Wed, 13 Jun 2018 09:29:59 -0700 + + /posts/modules/cryptocurrencies/blockfolio/ + Added in v0.0.8. +Display your Blockfolio crypto holdings. +Source wtf/blockfolio/ Required ENV Variables None. +Keyboard Commands None. +Configuration blockfolio: colors: name: blue grows: green drop: red device_token: "device token" displayHoldings: true enabled: true position: top: 3 left: 1 width: 1 height: 1 refreshInterval: 400 Attributes colors.name Values: Any X11 color name. +colors.grows Values: Any X11 color name. +colors.drop Values: Any X11 color name. +device_token Value: See this gist for details on how to get your Blockfolio API token. + + + + IP-API + /posts/modules/ipapi/ + Sun, 10 Jun 2018 19:41:52 -0400 + + /posts/modules/ipapi/ + Added in v0.0.7. +Displays your current IP address information, from IP-APIcom. +Note: IP-API.com has a free-plan rate limit of 120 requests per minute. +Source Code wtf/ipapi/ Required ENV Variables None. +Keyboard Commands None. +Configuration ipinfo: colors: name: red value: white enabled: true position: top: 1 left: 2 height: 1 width: 1 refreshInterval: 150 Attributes colors.name The default colour for the row names. Values: Any X11 color name. +colors.value The default colour for the row values. + + + + CircleCI + /posts/modules/circleci/ + Sun, 10 Jun 2018 19:26:08 -0400 + + /posts/modules/circleci/ + Added in v0.0.7. +Displays build information for your CircleCI account. +Source Code wtf/circleci/ Keyboard Commands None. +Configuration circleci: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" enabled: true position: top: 4 left: 1 height: 1 width: 2 refreshInterval: 900 Attributes apiKey Value: Your CircleCI API token. +enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. +position Defines where in the grid this module’s widget will be displayed. + + + + Google Spreadsheets + /posts/modules/gspreadsheet/ + Sun, 10 Jun 2018 18:26:26 -0400 + + /posts/modules/gspreadsheet/ + Added in v0.0.7. +Display information from cells in a Google Spreadsheet. +wtf/gspreadsheets/ Required ENV Variables None. +Keyboard Commands None. +Configuration gspreadsheets: colors: values: "green" cells: names: - "Cell 1 name" - "Cell 2 name" addresses: - "A1" - "A2" enabled: true position: top: 0 left: 0 width: 1 height: 1 refreshInterval: "300" secretFile: "~/.config/wtf/gspreadsheets/client_secret.json" sheetId: "id_of_google_spreadsheet" Attributes colors.values The color to display the cell values in. Values: Any X11 color name. + + + + Modules: Jenkins + /posts/modules/jenkins/ + Sat, 09 Jun 2018 20:53:35 -0700 + + /posts/modules/jenkins/ + Added in v0.0.8. +Displays jenkins status of given builds in a project or view +Source Code wtf/jenkins/ Keyboard Commands None. +Configuration jenkins: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" enabled: true position: top: 2 left: 3 height: 2 width: 3 refreshInterval: 300 url: "https://jenkins.domain.com/jenkins/view_url" user: "username" verifyServerCertificate: true Attributes apiKey Value: Your Jenkins API key. +enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. +position Defines where in the grid this module’s widget will be displayed. + + + + GitLab + /posts/modules/gitlab/ + Fri, 08 Jun 2018 13:14:11 -0700 + + /posts/modules/gitlab/ + Added in v0.0.8. +Displays information about your projects hosted on GitLab: +Open Approval Requests All open merge requests that are requesting your approval. +Open Merge Requests All open merge requests created by you. +Source Code wtf/gitlab/ Keyboard Commands Key: / Action: Open/close the widget’s help window. +Key: h Action: Show the previous project. +Key: l Action: Show the next project. +Key: ← Action: Show the previous project. +Key: → Action: Show the next project. + + + + Bittrex + /posts/modules/cryptocurrencies/bittrex/ + Mon, 04 Jun 2018 20:06:40 -0700 + + /posts/modules/cryptocurrencies/bittrex/ + Added in v0.0.5. +Get the last 24 hour summary of cryptocurrencies market using Bittrex. +Source Code wtf/cryptoexchanges/bittrex/ Required ENV Variables None. +Keyboard Commands None. +Configuration bittrex: enabled: true position: top: 1 left: 2 height: 3 width: 1 refreshInterval: 5 summary: BTC: displayName: Bitcoin market: - LTC - ETH colors: base: name: orange displayName: red market: name: red field: white value: green Attributes colors.base.name Values: Any X11 color name. +colors.base.dispayName Values: Any X11 color name. + + + + CryptoLive + /posts/modules/cryptocurrencies/cryptolive/ + Sun, 03 Jun 2018 20:06:40 -0700 + + /posts/modules/cryptocurrencies/cryptolive/ + Added in v0.0.5. +Compare crypto currencies using CryptoCompare. +Source Code wtf/cryptoexchanges/cryptolive/ Required ENV Vars None. +Keyboard Commands None. +Configuration cryptolive: enabled: true position: top: 5 left: 2 height: 1 width: 2 updateInterval: 15 currencies: BTC: displayName: Bitcoin to: - USD - EUR - ETH - LTC - DOGE LTC: displayName: Ethereum to: - USD - EUR - BTC top: BTC: displayName: Bitcoin limit: 5 to: - USD colors: from: name: coral displayName: grey to: name: white price: green top: from: name: grey displayName: coral to: name: red field: white value: green Attributes colors. + + + + Pretty Weather + /posts/modules/prettyweather/ + Sat, 02 Jun 2018 05:32:04 -0700 + + /posts/modules/prettyweather/ + Displays weather information as ASCII art from Wttr.in. +Source Code wtf/prettyweather/ Required ENV Variables None. +Keyboard Commands None. +Configuration prettyweather: enabled: true city: "tehran" position: top: 3 left: 5 height: 1 width: 1 refreshInterval: 300 unit: "c" view: 0 language: "en" Attributes city Optional. It will grab the current location from your IP address if omitted. +Values: The name of any city supported by Wttr.in. +enabled Determines whether or not this module is executed and if its data displayed onscreen. + + + + IPInfo + /posts/modules/ipinfo/ + Fri, 01 Jun 2018 23:18:48 -0700 + + /posts/modules/ipinfo/ + Displays your current IP address information, from ipinfo.io. +Note: IPInfo.io has a free-plan rate limit of 1000 requests per day. +Source Code wtf/ipinfo/ Required ENV Variables None. +Keyboard Commands None. +Configuration ipinfo: colors: name: red value: white enabled: true position: top: 1 left: 2 height: 1 width: 1 refreshInterval: 150 Attributes colors.name The default colour for the row names. Values: Any X11 color name. +colors.value The default colour for the row values. + + + + Power + /posts/modules/power/ + Sat, 26 May 2018 19:26:23 -0700 + + /posts/modules/power/ + Displays information about the current power source. +For battery, also displays the current charge, estimated time remaining, and whether it is charging or discharging. +Source Code wtf/power/ Required ENV Variables None. +Keyboard Commands None. +Configuration power: enabled: true position: top: 5 left: 0 height: 2 width: 1 refreshInterval: 15 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. +position Defines where in the grid this module’s widget will be displayed. + + + + Configuration: iTerm2 + /posts/configuration/iterm2/ + Thu, 24 May 2018 09:57:40 -0700 + + /posts/configuration/iterm2/ + Many terminal apps don’t properly display multibyte emoji characters properly. This may fix the issue for you in iTerm2, it also may not. +By default iTerm2 uses a unicode rendering format that is not comletely compatible with some emoji characters. Instead what you’ll see is the emoji over-lapping normal text characters, or drawing outside the bounds of where they should be. +In iTerm2 open: +Preferences -> Profiles -> Text and check on the “Use Unicode Version 9 Widths” checkbox. + + + + Overview + /posts/overview/ + Mon, 21 May 2018 16:11:58 -0700 + + /posts/overview/ + WTF is a personal information dashboard for your terminal, developed for those who spend most of their day in the command line. +It allows you to monitor services and systems that you otherwise might keep browser tabs open for, the kinds of things you don’t always need visible, but might check in on every now and then. +Quick Start Download the stand-alone, compiled binary. Unzip the downloaded file. From the command line, cd into the newly-created /wtf directory. + + + + Installation + /posts/installation/ + Fri, 18 May 2018 09:59:40 -0700 + + /posts/installation/ + There are two ways to install WTF: +From Source Get this repo and install the dependencies: +go get -u github.com/senorprogrammer/wtf cd $GOPATH/src/github.com/senorprogrammer/wtf make install make run and that should probably do it. +As a Binary Grab the latest version from here: +https://github.com/senorprogrammer/wtf/releases expand it, and cd into the resulting directory. Then run: +./wtf and that should also do it. + + + + CmdRunner + /posts/modules/cmdrunner/ + Thu, 17 May 2018 17:17:10 -0700 + + /posts/modules/cmdrunner/ + Runs a terminal command on a schedule. +Source Code wtf/cmdrunner/ Required ENV Variables None. +Keyboard Commands None. +Configuration cmdrunner: args: ["-g", "batt"] cmd: "pmset" enabled: true position: top: 6 left: 1 height: 1 width: 3 refreshInterval: 30 Attributes args The arguments to the command, with each item as an element in an array. Example: for curl -I cisco.com, the arguments array would be ["-I", "cisco.com"]. +cmd The terminal command to be run, withouth the arguments. + + + + Configuration: Attributes + /posts/configuration/attributes/ + Wed, 16 May 2018 21:51:23 -0700 + + /posts/configuration/attributes/ + The following top-level attributes are configurable in config.yml. See this example config file for more details. +wtf: colors: background: "red" border: Focusable: "darkslateblue" focused: "orange" normal: "gray" grid: # How _wide_ the columns are, in terminal characters. In this case we have # six columns, each of which are 35 characters wide columns: [35, 35, 35, 35, 35, 35] # How _high_ the rows are, in terminal lines. In this case we have five rows # that support ten line of text, one of three lines, and one of four rows: [10, 10, 10, 10, 10, 3, 4] # The app redraws itself once a second openFileUtil: open refreshInterval: 1 term: "xterm-256color" Attributes colors. + + + + Todo + /posts/modules/todo/ + Thu, 10 May 2018 12:41:50 -0700 + + /posts/modules/todo/ + An interactive todo list. +Source Code wtf/todo/ Required ENV Variables None. +Keyboard Commands Key: [return] Action: Edit the selected item. Action: Close the modal item dialog and save changes. Key: [esc] Action: Remove focus from the selected item. Action: Close the modal item dialog without saving changes. +Key: [space] Action: Check/uncheck the selected item. +Key: / Action: Open/close the widget’s help window. +Key: j Action: Select the next item in the list. + + + + Jira + /posts/modules/jira/ + Thu, 10 May 2018 10:44:35 -0700 + + /posts/modules/jira/ + Displays all Jira issues assigned to you for the specified project. +Source Code wtf/jira/ Keyboard Commands Key: [return] Action: Open the selected issue in the browser. +Key: j Action: Select the next item in the list. +Key: k Action: Select the previous item in the list. +Key: ↓ Action: Select the next item in the list. +Key: ↑ Action: Select the previous item in the list. +Configuration Single Jira Project jira: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" colors: rows: even: "lightblue" odd: "white" domain: "https://umbrellacorp. + + + + Trello + /posts/modules/trello/ + Thu, 10 May 2018 10:44:35 -0700 + + /posts/modules/trello/ + Displays all Trello cards on specified lists. +Source Code wtf/trello/ Keyboard Commands None. +Configuration Single Trello List trello: accessToken: "7b8b14f8743a408a93276d7155dd9ee2" apiKey: "3276d7155dd9ee27b8b14f8743a408a9" board: Main enabled: true list: "Todo" position: height: 1 left: 2 top: 0 width: 1 refreshInterval: 3600 username: myname Multiple Trello Lists If you want to monitor multiple Trello lists, use the following configuration (note the difference in list): +trello: accessToken: "7b8b14f8743a408a93276d7155dd9ee2" apiKey: "3276d7155dd9ee27b8b14f8743a408a9" board: Main enabled: true list: ["Todo", "Done"] position: height: 1 left: 2 top: 0 width: 1 refreshInterval: 3600 username: myname Attributes accessToken Value: Your Trello access token. + + + + Google Calendar + /posts/modules/gcal/ + Thu, 10 May 2018 08:25:33 -0700 + + /posts/modules/gcal/ + Displays your upcoming Google calendar events. +Not: Setting up access to Google Calendars for Go is a bit unobvious. Check out Google’s Go Quickstart first and if you have problems, then take a look at this comment by WesleydeSouza which offers a slightly different approach. +Source Code wtf/gcal/ Required ENV Variables None. +Keyboard Commands None. +Configuration gcal: colors: title: "red" description: "lightblue" highlights: - ['1on1|1\/11', 'green'] - ['apple|google|aws', 'blue'] - ['interview|meet', 'magenta'] - ['lunch', 'yellow'] past: "gray" conflictIcon: "🚨" currentIcon: "💥" displayResponseStatus: true email: "chriscummer@me. + + + + GitHub + /posts/modules/github/ + Wed, 09 May 2018 19:20:20 -0700 + + /posts/modules/github/ + Displays information about your git repositories hosted on GitHub: +Open Review Requests All open code review requests assigned to you. +Open Pull Requests All open pull requests created by you. +Source Code wtf/github/ Keyboard Commands Key: / Action: Open/close the widget’s help window. +Key: h Action: Show the previous git repository. +Key: l Action: Show the next git repository. +Key: ← Action: Show the previous git repository. +Key: → Action: Show the next git repository. + + + + Git + /posts/modules/git/ + Wed, 09 May 2018 14:20:48 -0700 + + /posts/modules/git/ + Displays information about local git repositories: branch, changed files, and recent commits. +Branch The name of the currently-active git branch. +Changed Files A list of all the files that have changed since the last commit, and their status. +Recent Commits A list of n recent commits, who committed it, and when. +Source Code wtf/git/ Required ENV Variables None. +Keyboard Commands Key: / Action: Open/close the widget’s help window. +Key: h Action: Show the previous git repository. + + + + Weather + /posts/modules/weather/ + Wed, 09 May 2018 11:44:13 -0700 + + /posts/modules/weather/ + Displays a configurable list of current weather report, including current temperature, sunrise time, and sunset time. +Source Code wtf/weather/ Required ENV Variables Key: WTF_OWM_API_KEY Action: Your OpenWeatherMap API key. Note: DEPRECATED. See the apiKey config value, below. +Keyboard Commands Key: / Action: Open/close the widget’s help window. +Key: h Action: Show the previous weather location. +Key: l Action: Show the next weather location. +Key: ← Action: Show the previous weather location. + + + + Textfile + /posts/modules/textfile/ + Wed, 09 May 2018 11:13:11 -0700 + + /posts/modules/textfile/ + Displays the contents of the specified text file in the widget. +Source Code wtf/textfile/ Required ENV Variables None. +Keyboard Commands Key: / Action: Open/close the widget’s help window. +Key: o Action: Opens the text file in whichever text editor is associated with that file type. +Configuration textfile: enabled: true filePath: "~/Desktop/notes.md" position: top: 5 left: 4 height: 2 width: 1 refreshInterval: 15 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. + + + + New Relic + /posts/modules/newrelic/ + Wed, 09 May 2018 09:01:14 -0700 + + /posts/modules/newrelic/ + Connects to the New Relic API and displays the last n deploys of the monitored application: deploy ID, deploy time, and who deployed it. +Source Code wtf/newrelic/ Keyboard Commands None. +Configuration newrelic: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" applicationId: 10549735 deployCount: 6 enabled: true position: top: 4 left: 3 height: 1 width: 2 refreshInterval: 900 Attributes apiKey Value: Your New Relic API token. +applicationId The integer ID of the New Relic application you wish to report on. + + + + OpsGenie + /posts/modules/opsgenie/ + Tue, 08 May 2018 20:53:40 -0700 + + /posts/modules/opsgenie/ + Connects to the OpsGenie API and displays all your scheduled rotations and who’s currently on call. +Source Code wtf/opsgenie/ Keyboard Commands None. +Configuration opsgenie: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" displayEmpty: false enabled: true position: top: 2 left: 1 height: 2 width: 1 refreshInterval: 21600 Attributes apiKey < br /> Value: Your OpsGenie API token. +displayEmpty Whether schedules with no assigned person on-call should be displayed. Values: true, false. +enabled Whether or not this module is executed and if its data displayed onscreen. + + + + Security + /posts/modules/security/ + Tue, 08 May 2018 20:33:28 -0700 + + /posts/modules/security/ + Displays some general information about the state of the machine’s wifi connection, firewall, DNS settings, and logged-in users. +Wifi Network The name of the current network Whether or not the network uses encryption and if so, what flavour Firewall Whether or not the firewall is enabled Whether or not Stealth Mode is enabled DNS Which DNS resolvers (servers) the machine is configured to use Users Which users are logged into the machine. + + + + BambooHR + /posts/modules/bamboohr/ + Mon, 07 May 2018 20:17:37 -0700 + + /posts/modules/bamboohr/ + Connects to the BambooHR API and displays who will be Away today. +Source Code wtf/bamboohr/ Keyboard Commands None. +Configuration bamboohr: apiKey: "3276d7155dd9ee27b8b14f8743a408a9" enabled: true position: top: 0 left: 1 height: 2 width: 1 refreshInterval: 900 subdomain: "testco" Attributes apiKey Value: Your BambooHR API token. +enabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false. +position Defines where in the grid this module’s widget will be displayed. + + + + Clocks + /posts/modules/clocks/ + Mon, 07 May 2018 19:47:31 -0700 + + /posts/modules/clocks/ + Displays a configurable list of world clocks, the local time, and date. +Source Code wtf/clocks/ Required ENV Variables None. +Keyboard Commands None. +Configuration clocks: colors: rows: even: "lightblue" odd: "white" enabled: true locations: # From https://en.wikipedia.org/wiki/List_of_tz_database_time_zones Avignon: "Europe/Paris" Barcelona: "Europe/Madrid" Dubai: "Asia/Dubai" New York: "America/New York" Toronto: "America/Toronto" UTC: "Etc/UTC" Vancouver: "America/Vancouver" position: top: 4 left: 0 height: 1 width: 1 refreshInterval: 15 # Valid options are: alphabetical, chronological sort: "alphabetical" Attributes colors. + + + + Modules + /posts/modules/ + Mon, 07 May 2018 18:04:58 -0700 + + /posts/modules/ + The heart of WTF is the modules. A module is a discreet unit of functionality that extracts data from some source and packages that data for display. +For example, the New Relic module uses New Relic’s API to retrieve a list of the latest deploys and packages that information as a list for display in the “New Relic” widget. +The Clocks module takes a list of timezones and packages that information as a list of city/time pairs for display in the “Clocks” widget. + + + + Glossary + /posts/glossary/ + Tue, 17 Apr 2018 12:34:51 -0700 + + /posts/glossary/ + Module A discreet unit of data collection and display. A data interface concept. A package inside the app. +Examples: New Relic, Git, Weather. +Widget The onscreen representation of a Module. The widget is responsible for being the interface between the app and the data collection. +Widgets are defined by a required widget.go file in a Module. + + + + Configuration + /posts/configuration/ + Sun, 15 Apr 2018 21:17:16 -0700 + + /posts/configuration/ + Index Configuration Files Environment (ENV) Variables Grid Layout Configuration Files By default WTF looks in a ~/.config/wtf/ directory for a YAML file called config.yml. If the ~/.config/wtf/ directory doesn’t exist, WTF will create that directory on start-up, and then display instructions for creating a new configuration file. +In other words, WTF expects to have a YAML config file at: ~/.config/wtf/config.yml. +Example Configuration Files A couple of example config files are provided in the _sample_configs/ directory of the Git repository. + + + + \ No newline at end of file diff --git a/_site/public/js/auto-complete.js b/_site/public/js/auto-complete.js new file mode 100644 index 00000000..7fbde995 --- /dev/null +++ b/_site/public/js/auto-complete.js @@ -0,0 +1,223 @@ +/* + JavaScript autoComplete v1.0.4 + Copyright (c) 2014 Simon Steinberger / Pixabay + GitHub: https://github.com/Pixabay/JavaScript-autoComplete + License: http://www.opensource.org/licenses/mit-license.php +*/ + +var autoComplete = (function(){ + // "use strict"; + function autoComplete(options){ + if (!document.querySelector) return; + + // helpers + function hasClass(el, className){ return el.classList ? el.classList.contains(className) : new RegExp('\\b'+ className+'\\b').test(el.className); } + + function addEvent(el, type, handler){ + if (el.attachEvent) el.attachEvent('on'+type, handler); else el.addEventListener(type, handler); + } + function removeEvent(el, type, handler){ + // if (el.removeEventListener) not working in IE11 + if (el.detachEvent) el.detachEvent('on'+type, handler); else el.removeEventListener(type, handler); + } + function live(elClass, event, cb, context){ + addEvent(context || document, event, function(e){ + var found, el = e.target || e.srcElement; + while (el && !(found = hasClass(el, elClass))) el = el.parentElement; + if (found) cb.call(el, e); + }); + } + + var o = { + selector: 0, + source: 0, + minChars: 3, + delay: 150, + offsetLeft: 0, + offsetTop: 1, + cache: 1, + menuClass: '', + renderItem: function (item, search){ + // escape special characters + search = search.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&'); + var re = new RegExp("(" + search.split(' ').join('|') + ")", "gi"); + return '
' + item.replace(re, "$1") + '
'; + }, + onSelect: function(e, term, item){} + }; + for (var k in options) { if (options.hasOwnProperty(k)) o[k] = options[k]; } + + // init + var elems = typeof o.selector == 'object' ? [o.selector] : document.querySelectorAll(o.selector); + for (var i=0; i 0) + that.sc.scrollTop = selTop + that.sc.suggestionHeight + scrTop - that.sc.maxHeight; + else if (selTop < 0) + that.sc.scrollTop = selTop + scrTop; + } + } + } + addEvent(window, 'resize', that.updateSC); + document.body.appendChild(that.sc); + + live('autocomplete-suggestion', 'mouseleave', function(e){ + var sel = that.sc.querySelector('.autocomplete-suggestion.selected'); + if (sel) setTimeout(function(){ sel.className = sel.className.replace('selected', ''); }, 20); + }, that.sc); + + live('autocomplete-suggestion', 'mouseover', function(e){ + var sel = that.sc.querySelector('.autocomplete-suggestion.selected'); + if (sel) sel.className = sel.className.replace('selected', ''); + this.className += ' selected'; + }, that.sc); + + live('autocomplete-suggestion', 'mousedown', function(e){ + if (hasClass(this, 'autocomplete-suggestion')) { // else outside click + var v = this.getAttribute('data-val'); + that.value = v; + o.onSelect(e, v, this); + that.sc.style.display = 'none'; + } + }, that.sc); + + that.blurHandler = function(){ + try { var over_sb = document.querySelector('.autocomplete-suggestions:hover'); } catch(e){ var over_sb = 0; } + if (!over_sb) { + that.last_val = that.value; + that.sc.style.display = 'none'; + setTimeout(function(){ that.sc.style.display = 'none'; }, 350); // hide suggestions on fast input + } else if (that !== document.activeElement) setTimeout(function(){ that.focus(); }, 20); + }; + addEvent(that, 'blur', that.blurHandler); + + var suggest = function(data){ + var val = that.value; + that.cache[val] = data; + if (data.length && val.length >= o.minChars) { + var s = ''; + for (var i=0;i 40) && key != 13 && key != 27) { + var val = that.value; + if (val.length >= o.minChars) { + if (val != that.last_val) { + that.last_val = val; + clearTimeout(that.timer); + if (o.cache) { + if (val in that.cache) { suggest(that.cache[val]); return; } + // no requests if previous suggestions were empty + for (var i=1; ir;r++)n[r].fn.apply(n[r].ctx,e);return this},off:function(t,e){var n=this.e||(this.e={}),r=n[t],o=[];if(r&&e)for(var i=0,a=r.length;a>i;i++)r[i].fn!==e&&r[i].fn._!==e&&o.push(r[i]);return o.length?n[t]=o:delete n[t],this}},e.exports=r},{}],8:[function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}n.__esModule=!0;var i=function(){function t(t,e){for(var n=0;n"; + } + }); + + // Change styles, depending on parameters set to the image + images.each(function (index) { + var image = $(this); + var o = getUrlParameter(image[0].src); + if (typeof o !== "undefined") { + var h = o["height"]; + var w = o["width"]; + var c = o["classes"]; + image.css({ + width: function () { + if (typeof w !== "undefined") { + return w; + } + }, + height: function () { + if (typeof h !== "undefined") { + return h; + } + } + }); + if (typeof c !== "undefined") { + var classes = c.split(','); + $.each(classes, function(i) { + image.addClass(classes[i]); + }); + } + } + }); + + // Add link button for every + var text, clip = new Clipboard('.anchor'); + $("h1~h2,h1~h3,h1~h4,h1~h5,h1~h6").append(function (index, html) { + var element = $(this); + var url = document.location.origin + document.location.pathname; + var link = url + "#" + element[0].id; + return " " + + "" + + ""; + }); + + $(".anchor").on('mouseleave', function (e) { + $(this).attr('aria-label', null).removeClass('tooltipped tooltipped-s tooltipped-w'); + }); + + clip.on('success', function (e) { + e.clearSelection(); + $(e.trigger).attr('aria-label', 'Link copied to clipboard!').addClass('tooltipped tooltipped-s'); + }); + +}); + + + +function fallbackMessage(action) { + var actionMsg = ''; + var actionKey = (action === 'cut' ? 'X' : 'C'); + + if (/iPhone|iPad/i.test(navigator.userAgent)) { + actionMsg = 'No support :('; + } + else if (/Mac/i.test(navigator.userAgent)) { + actionMsg = 'Press ⌘-' + actionKey + ' to ' + action; + } + else { + actionMsg = 'Press Ctrl-' + actionKey + ' to ' + action; + } + + return actionMsg; +} + +jQuery(document).ready(function() { + jQuery('#sidebar .category-icon').on('click', function() { + $( this ).toggleClass("fa-angle-down fa-angle-right") ; + $( this ).parent().parent().children('ul').toggle() ; + return false; + }); + + + jQuery('[data-clear-history-toggle]').on('click', function() { + sessionStorage.clear(); + location.reload(); + return false; + }); + + var ajax; + jQuery('[data-search-input]').on('input', function() { + var input = jQuery(this), + value = input.val(), + items = jQuery('[data-nav-id]'); + items.removeClass('search-match'); + if (!value.length) { + $('ul.topics').removeClass('searched'); + items.css('display', 'block'); + sessionStorage.removeItem('search-value'); + $(".highlightable").unhighlight({ element: 'mark' }) + return; + } + + sessionStorage.setItem('search-value', value); + $(".highlightable").unhighlight({ element: 'mark' }).highlight(value, { element: 'mark' }); + + if (ajax && ajax.abort) ajax.abort(); + + jQuery('[data-search-clear]').on('click', function() { + jQuery('[data-search-input]').val('').trigger('input'); + sessionStorage.removeItem('search-input'); + $(".highlightable").unhighlight({ element: 'mark' }) + }); + }); + + $.expr[":"].contains = $.expr.createPseudo(function(arg) { + return function( elem ) { + return $(elem).text().toUpperCase().indexOf(arg.toUpperCase()) >= 0; + }; + }); + + if (sessionStorage.getItem('search-value')) { + var searchValue = sessionStorage.getItem('search-value') + sessionStorage.removeItem('search-value'); + var searchedElem = $('article').find(':contains(' + searchValue + ')').get(0); + searchedElem && searchedElem.scrollIntoView(); + $(".highlightable").highlight(searchValue, { element: 'mark' }); + } + + // clipboard + var clipInit = false; + $('code').each(function() { + var code = $(this), + text = code.text(); + + if (text.length > 5) { + if (!clipInit) { + var text, clip = new Clipboard('.copy-to-clipboard', { + text: function(trigger) { + text = $(trigger).prev('code').text(); + return text.replace(/^\$\s/gm, ''); + } + }); + + var inPre; + clip.on('success', function(e) { + e.clearSelection(); + inPre = $(e.trigger).parent().prop('tagName') == 'PRE'; + $(e.trigger).attr('aria-label', 'Copied to clipboard!').addClass('tooltipped tooltipped-' + (inPre ? 'w' : 's')); + }); + + clip.on('error', function(e) { + inPre = $(e.trigger).parent().prop('tagName') == 'PRE'; + $(e.trigger).attr('aria-label', fallbackMessage(e.action)).addClass('tooltipped tooltipped-' + (inPre ? 'w' : 's')); + $(document).one('copy', function(){ + $(e.trigger).attr('aria-label', 'Copied to clipboard!').addClass('tooltipped tooltipped-' + (inPre ? 'w' : 's')); + }); + }); + + clipInit = true; + } + + code.after(''); + code.next('.copy-to-clipboard').on('mouseleave', function() { + $(this).attr('aria-label', null).removeClass('tooltipped tooltipped-s tooltipped-w'); + }); + } + }); + + // allow keyboard control for prev/next links + jQuery(function() { + jQuery('.nav-prev').click(function(){ + location.href = jQuery(this).attr('href'); + }); + jQuery('.nav-next').click(function() { + location.href = jQuery(this).attr('href'); + }); + }); + + jQuery(document).keydown(function(e) { + // prev links - left arrow key + if(e.which == '37') { + jQuery('.nav.nav-prev').click(); + } + + // next links - right arrow key + if(e.which == '39') { + jQuery('.nav.nav-next').click(); + } + }); + + $('#top-bar a:not(:has(img)):not(.btn)').addClass('highlight'); + $('article a:not(:has(img)):not(.btn)').addClass('highlight'); +}); + +jQuery(window).on('load', function() { + // store this page in session + sessionStorage.setItem(jQuery('body').data('url'), 1); + + // loop through the sessionStorage and see if something should be marked as visited + for (var url in sessionStorage) { + if (sessionStorage.getItem(url) == 1) jQuery('[data-nav-id="' + url + '"]').addClass('visited'); + } +}); + +$(function() { + $('a[rel="lightbox"]').featherlight({ + root: 'section#body' + }); +}); + +jQuery.extend({ + highlight: function(node, re, nodeName, className) { + if (node.nodeType === 3) { + var match = node.data.match(re); + if (match && !(node.parentNode.ownerSVGElement instanceof SVGElement)) { + var highlight = document.createElement(nodeName || 'span'); + highlight.className = className || 'highlight'; + var wordNode = node.splitText(match.index); + wordNode.splitText(match[0].length); + var wordClone = wordNode.cloneNode(true); + highlight.appendChild(wordClone); + wordNode.parentNode.replaceChild(highlight, wordNode); + return 1; //skip added node in parent + } + } else if ((node.nodeType === 1 && node.childNodes) && // only element nodes that have children + !/(script|style)/i.test(node.tagName) && // ignore script and style nodes + !(node.tagName === nodeName.toUpperCase() && node.className === className)) { // skip if already highlighted + for (var i = 0; i < node.childNodes.length; i++) { + i += jQuery.highlight(node.childNodes[i], re, nodeName, className); + } + } + return 0; + } +}); + +jQuery.fn.unhighlight = function(options) { + var settings = { + className: 'highlight', + element: 'span' + }; + jQuery.extend(settings, options); + + return this.find(settings.element + "." + settings.className).each(function() { + var parent = this.parentNode; + parent.replaceChild(this.firstChild, this); + parent.normalize(); + }).end(); +}; + +jQuery.fn.highlight = function(words, options) { + var settings = { + className: 'highlight', + element: 'span', + caseSensitive: false, + wordsOnly: false + }; + jQuery.extend(settings, options); + + if (!words) { return; } + + if (words.constructor === String) { + words = [words]; + } + words = jQuery.grep(words, function(word, i) { + return word != ''; + }); + words = jQuery.map(words, function(word, i) { + return word.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&"); + }); + if (words.length == 0) { return this; } + ; + + var flag = settings.caseSensitive ? "" : "i"; + var pattern = "(" + words.join("|") + ")"; + if (settings.wordsOnly) { + pattern = "\\b" + pattern + "\\b"; + } + var re = new RegExp(pattern, flag); + + return this.each(function() { + jQuery.highlight(this, re, settings.element, settings.className); + }); +}; diff --git a/_site/public/js/featherlight.min.js b/_site/public/js/featherlight.min.js new file mode 100644 index 00000000..63590819 --- /dev/null +++ b/_site/public/js/featherlight.min.js @@ -0,0 +1,8 @@ +/** + * Featherlight - ultra slim jQuery lightbox + * Version 1.2.3 - http://noelboss.github.io/featherlight/ + * + * Copyright 2015, Noël Raoul Bossart (http://www.noelboss.com) + * MIT Licensed. +**/ +!function(a){"use strict";function b(a,c){if(!(this instanceof b)){var d=new b(a,c);return d.open(),d}this.id=b.id++,this.setup(a,c),this.chainCallbacks(b._callbackChain)}if("undefined"==typeof a)return void("console"in window&&window.console.info("Too much lightness, Featherlight needs jQuery."));var c=[],d=function(b){return c=a.grep(c,function(a){return a!==b&&a.$instance.closest("body").length>0})},e=function(a,b){var c={},d=new RegExp("^"+b+"([A-Z])(.*)");for(var e in a){var f=e.match(d);if(f){var g=(f[1]+f[2].replace(/([A-Z])/g,"-$1")).toLowerCase();c[g]=a[e]}}return c},f={keyup:"onKeyUp",resize:"onResize"},g=function(c){a.each(b.opened().reverse(),function(){return c.isDefaultPrevented()||!1!==this[f[c.type]](c)?void 0:(c.preventDefault(),c.stopPropagation(),!1)})},h=function(c){if(c!==b._globalHandlerInstalled){b._globalHandlerInstalled=c;var d=a.map(f,function(a,c){return c+"."+b.prototype.namespace}).join(" ");a(window)[c?"on":"off"](d,g)}};b.prototype={constructor:b,namespace:"featherlight",targetAttr:"data-featherlight",variant:null,resetCss:!1,background:null,openTrigger:"click",closeTrigger:"click",filter:null,root:"body",openSpeed:250,closeSpeed:250,closeOnClick:"background",closeOnEsc:!0,closeIcon:"✕",loading:"",otherClose:null,beforeOpen:a.noop,beforeContent:a.noop,beforeClose:a.noop,afterOpen:a.noop,afterContent:a.noop,afterClose:a.noop,onKeyUp:a.noop,onResize:a.noop,type:null,contentFilters:["jquery","image","html","ajax","iframe","text"],setup:function(b,c){"object"!=typeof b||b instanceof a!=!1||c||(c=b,b=void 0);var d=a.extend(this,c,{target:b}),e=d.resetCss?d.namespace+"-reset":d.namespace,f=a(d.background||['
','
','',d.closeIcon,"",'
'+d.loading+"
","
","
"].join("")),g="."+d.namespace+"-close"+(d.otherClose?","+d.otherClose:"");return d.$instance=f.clone().addClass(d.variant),d.$instance.on(d.closeTrigger+"."+d.namespace,function(b){var c=a(b.target);("background"===d.closeOnClick&&c.is("."+d.namespace)||"anywhere"===d.closeOnClick||c.closest(g).length)&&(b.preventDefault(),d.close())}),this},getContent:function(){var b=this,c=this.constructor.contentFilters,d=function(a){return b.$currentTarget&&b.$currentTarget.attr(a)},e=d(b.targetAttr),f=b.target||e||"",g=c[b.type];if(!g&&f in c&&(g=c[f],f=b.target&&e),f=f||d("href")||"",!g)for(var h in c)b[h]&&(g=c[h],f=b[h]);if(!g){var i=f;if(f=null,a.each(b.contentFilters,function(){return g=c[this],g.test&&(f=g.test(i)),!f&&g.regex&&i.match&&i.match(g.regex)&&(f=i),!f}),!f)return"console"in window&&window.console.error("Featherlight: no content filter found "+(i?' for "'+i+'"':" (no target specified)")),!1}return g.process.call(b,f)},setContent:function(b){var c=this;return(b.is("iframe")||a("iframe",b).length>0)&&c.$instance.addClass(c.namespace+"-iframe"),c.$instance.removeClass(c.namespace+"-loading"),c.$instance.find("."+c.namespace+"-inner").slice(1).remove().end().replaceWith(a.contains(c.$instance[0],b[0])?"":b),c.$content=b.addClass(c.namespace+"-inner"),c},open:function(b){var d=this;if(d.$instance.hide().appendTo(d.root),!(b&&b.isDefaultPrevented()||d.beforeOpen(b)===!1)){b&&b.preventDefault();var e=d.getContent();if(e)return c.push(d),h(!0),d.$instance.fadeIn(d.openSpeed),d.beforeContent(b),a.when(e).always(function(a){d.setContent(a),d.afterContent(b)}).then(d.$instance.promise()).done(function(){d.afterOpen(b)})}return d.$instance.detach(),a.Deferred().reject().promise()},close:function(b){var c=this,e=a.Deferred();return c.beforeClose(b)===!1?e.reject():(0===d(c).length&&h(!1),c.$instance.fadeOut(c.closeSpeed,function(){c.$instance.detach(),c.afterClose(b),e.resolve()})),e.promise()},chainCallbacks:function(b){for(var c in b)this[c]=a.proxy(b[c],this,a.proxy(this[c],this))}},a.extend(b,{id:0,autoBind:"[data-featherlight]",defaults:b.prototype,contentFilters:{jquery:{regex:/^[#.]\w/,test:function(b){return b instanceof a&&b},process:function(b){return a(b).clone(!0)}},image:{regex:/\.(png|jpg|jpeg|gif|tiff|bmp)(\?\S*)?$/i,process:function(b){var c=this,d=a.Deferred(),e=new Image,f=a('');return e.onload=function(){f.naturalWidth=e.width,f.naturalHeight=e.height,d.resolve(f)},e.onerror=function(){d.reject(f)},e.src=b,d.promise()}},html:{regex:/^\s*<[\w!][^<]*>/,process:function(b){return a(b)}},ajax:{regex:/./,process:function(b){var c=a.Deferred(),d=a("
").load(b,function(a,b){"error"!==b&&c.resolve(d.contents()),c.fail()});return c.promise()}},iframe:{process:function(b){var c=new a.Deferred,d=a(" + + +``` + + +### API + +The ``Reveal`` object exposes a JavaScript API for controlling navigation and reading state: + +```javascript +// Navigation +Reveal.slide( indexh, indexv, indexf ); +Reveal.left(); +Reveal.right(); +Reveal.up(); +Reveal.down(); +Reveal.prev(); +Reveal.next(); +Reveal.prevFragment(); +Reveal.nextFragment(); + +// Randomize the order of slides +Reveal.shuffle(); + +// Toggle presentation states, optionally pass true/false to force on/off +Reveal.toggleOverview(); +Reveal.togglePause(); +Reveal.toggleAutoSlide(); + +// Shows a help overlay with keyboard shortcuts, optionally pass true/false +// to force on/off +Reveal.toggleHelp(); + +// Change a config value at runtime +Reveal.configure({ controls: true }); + +// Returns the present configuration options +Reveal.getConfig(); + +// Fetch the current scale of the presentation +Reveal.getScale(); + +// Retrieves the previous and current slide elements +Reveal.getPreviousSlide(); +Reveal.getCurrentSlide(); + +Reveal.getIndices(); // { h: 0, v: 0 } } +Reveal.getPastSlideCount(); +Reveal.getProgress(); // (0 == first slide, 1 == last slide) +Reveal.getSlides(); // Array of all slides +Reveal.getTotalSlides(); // total number of slides + +// Returns the speaker notes for the current slide +Reveal.getSlideNotes(); + +// State checks +Reveal.isFirstSlide(); +Reveal.isLastSlide(); +Reveal.isOverview(); +Reveal.isPaused(); +Reveal.isAutoSliding(); +``` + +### Slide Changed Event + +A 'slidechanged' event is fired each time the slide is changed (regardless of state). The event object holds the index values of the current slide as well as a reference to the previous and current slide HTML nodes. + +Some libraries, like MathJax (see [#226](https://github.com/hakimel/reveal.js/issues/226#issuecomment-10261609)), get confused by the transforms and display states of slides. Often times, this can be fixed by calling their update or render function from this callback. + +```javascript +Reveal.addEventListener( 'slidechanged', function( event ) { + // event.previousSlide, event.currentSlide, event.indexh, event.indexv +} ); +``` + +### Presentation State + +The presentation's current state can be fetched by using the `getState` method. A state object contains all of the information required to put the presentation back as it was when `getState` was first called. Sort of like a snapshot. It's a simple object that can easily be stringified and persisted or sent over the wire. + +```javascript +Reveal.slide( 1 ); +// we're on slide 1 + +var state = Reveal.getState(); + +Reveal.slide( 3 ); +// we're on slide 3 + +Reveal.setState( state ); +// we're back on slide 1 +``` + +### Slide States + +If you set ``data-state="somestate"`` on a slide ``
``, "somestate" will be applied as a class on the document element when that slide is opened. This allows you to apply broad style changes to the page based on the active slide. + +Furthermore you can also listen to these changes in state via JavaScript: + +```javascript +Reveal.addEventListener( 'somestate', function() { + // TODO: Sprinkle magic +}, false ); +``` + +### Slide Backgrounds + +Slides are contained within a limited portion of the screen by default to allow them to fit any display and scale uniformly. You can apply full page backgrounds outside of the slide area by adding a ```data-background``` attribute to your ```
``` elements. Four different types of backgrounds are supported: color, image, video and iframe. + +#### Color Backgrounds +All CSS color formats are supported, like rgba() or hsl(). +```html +
+

Color

+
+``` + +#### Image Backgrounds +By default, background images are resized to cover the full page. Available options: + +| Attribute | Default | Description | +| :--------------------------- | :--------- | :---------- | +| data-background-image | | URL of the image to show. GIFs restart when the slide opens. | +| data-background-size | cover | See [background-size](https://developer.mozilla.org/docs/Web/CSS/background-size) on MDN. | +| data-background-position | center | See [background-position](https://developer.mozilla.org/docs/Web/CSS/background-position) on MDN. | +| data-background-repeat | no-repeat | See [background-repeat](https://developer.mozilla.org/docs/Web/CSS/background-repeat) on MDN. | +```html +
+

Image

+
+
+

This background image will be sized to 100px and repeated

+
+``` + +#### Video Backgrounds +Automatically plays a full size video behind the slide. + +| Attribute | Default | Description | +| :--------------------------- | :------ | :---------- | +| data-background-video | | A single video source, or a comma separated list of video sources. | +| data-background-video-loop | false | Flags if the video should play repeatedly. | +| data-background-video-muted | false | Flags if the audio should be muted. | +| data-background-size | cover | Use `cover` for full screen and some cropping or `contain` for letterboxing. | + +```html +
+

Video

+
+``` + +#### Iframe Backgrounds +Embeds a web page as a slide background that covers 100% of the reveal.js width and height. The iframe is in the background layer, behind your slides, and as such it's not possible to interact with it by default. To make your background interactive, you can add the `data-background-interactive` attribute. +```html +
+

Iframe

+
+``` + +#### Background Transitions +Backgrounds transition using a fade animation by default. This can be changed to a linear sliding transition by passing ```backgroundTransition: 'slide'``` to the ```Reveal.initialize()``` call. Alternatively you can set ```data-background-transition``` on any section with a background to override that specific transition. + + +### Parallax Background + +If you want to use a parallax scrolling background, set the first two config properties below when initializing reveal.js (the other two are optional). + +```javascript +Reveal.initialize({ + + // Parallax background image + parallaxBackgroundImage: '', // e.g. "https://s3.amazonaws.com/hakim-static/reveal-js/reveal-parallax-1.jpg" + + // Parallax background size + parallaxBackgroundSize: '', // CSS syntax, e.g. "2100px 900px" - currently only pixels are supported (don't use % or auto) + + // Number of pixels to move the parallax background per slide + // - Calculated automatically unless specified + // - Set to 0 to disable movement along an axis + parallaxBackgroundHorizontal: 200, + parallaxBackgroundVertical: 50 + +}); +``` + +Make sure that the background size is much bigger than screen size to allow for some scrolling. [View example](http://revealjs.com/?parallaxBackgroundImage=https%3A%2F%2Fs3.amazonaws.com%2Fhakim-static%2Freveal-js%2Freveal-parallax-1.jpg¶llaxBackgroundSize=2100px%20900px). + + + +### Slide Transitions +The global presentation transition is set using the ```transition``` config value. You can override the global transition for a specific slide by using the ```data-transition``` attribute: + +```html +
+

This slide will override the presentation transition and zoom!

+
+ +
+

Choose from three transition speeds: default, fast or slow!

+
+``` + +You can also use different in and out transitions for the same slide: + +```html +
+ The train goes on … +
+
+ and on … +
+
+ and stops. +
+
+ (Passengers entering and leaving) +
+
+ And it starts again. +
+``` + + +### Internal links + +It's easy to link between slides. The first example below targets the index of another slide whereas the second targets a slide with an ID attribute (```
```): + +```html +Link +Link +``` + +You can also add relative navigation links, similar to the built in reveal.js controls, by appending one of the following classes on any element. Note that each element is automatically given an ```enabled``` class when it's a valid navigation route based on the current slide. + +```html + + + + + + +``` + + +### Fragments +Fragments are used to highlight individual elements on a slide. Every element with the class ```fragment``` will be stepped through before moving on to the next slide. Here's an example: http://revealjs.com/#/fragments + +The default fragment style is to start out invisible and fade in. This style can be changed by appending a different class to the fragment: + +```html +
+

grow

+

shrink

+

fade-out

+

fade-up (also down, left and right!)

+

visible only once

+

blue only once

+

highlight-red

+

highlight-green

+

highlight-blue

+
+``` + +Multiple fragments can be applied to the same element sequentially by wrapping it, this will fade in the text on the first step and fade it back out on the second. + +```html +
+ + I'll fade in, then out + +
+``` + +The display order of fragments can be controlled using the ```data-fragment-index``` attribute. + +```html +
+

Appears last

+

Appears first

+

Appears second

+
+``` + +### Fragment events + +When a slide fragment is either shown or hidden reveal.js will dispatch an event. + +Some libraries, like MathJax (see #505), get confused by the initially hidden fragment elements. Often times this can be fixed by calling their update or render function from this callback. + +```javascript +Reveal.addEventListener( 'fragmentshown', function( event ) { + // event.fragment = the fragment DOM element +} ); +Reveal.addEventListener( 'fragmenthidden', function( event ) { + // event.fragment = the fragment DOM element +} ); +``` + +### Code syntax highlighting + +By default, Reveal is configured with [highlight.js](https://highlightjs.org/) for code syntax highlighting. Below is an example with clojure code that will be syntax highlighted. When the `data-trim` attribute is present, surrounding whitespace is automatically removed. HTML will be escaped by default. To avoid this, for example if you are using `` to call out a line of code, add the `data-noescape` attribute to the `` element. + +```html +
+

+(def lazy-fib
+  (concat
+   [0 1]
+   ((fn rfib [a b]
+        (lazy-cons (+ a b) (rfib b (+ a b)))) 0 1)))
+	
+
+``` + +### Slide number +If you would like to display the page number of the current slide you can do so using the ```slideNumber``` and ```showSlideNumber``` configuration values. + +```javascript +// Shows the slide number using default formatting +Reveal.configure({ slideNumber: true }); + +// Slide number formatting can be configured using these variables: +// "h.v": horizontal . vertical slide number (default) +// "h/v": horizontal / vertical slide number +// "c": flattened slide number +// "c/t": flattened slide number / total slides +Reveal.configure({ slideNumber: 'c/t' }); + +// Control which views the slide number displays on using the "showSlideNumber" value: +// "all": show on all views (default) +// "speaker": only show slide numbers on speaker notes view +// "print": only show slide numbers when printing to PDF +Reveal.configure({ showSlideNumber: 'speaker' }); + +``` + + +### Overview mode + +Press "Esc" or "o" keys to toggle the overview mode on and off. While you're in this mode, you can still navigate between slides, +as if you were at 1,000 feet above your presentation. The overview mode comes with a few API hooks: + +```javascript +Reveal.addEventListener( 'overviewshown', function( event ) { /* ... */ } ); +Reveal.addEventListener( 'overviewhidden', function( event ) { /* ... */ } ); + +// Toggle the overview mode programmatically +Reveal.toggleOverview(); +``` + + +### Fullscreen mode +Just press »F« on your keyboard to show your presentation in fullscreen mode. Press the »ESC« key to exit fullscreen mode. + + +### Embedded media +Add `data-autoplay` to your media element if you want it to automatically start playing when the slide is shown: + +```html + +``` + +If you want to enable or disable autoplay globally, for all embedded media, you can use the `autoPlayMedia` configuration option. If you set this to `true` ALL media will autoplay regardless of individual `data-autoplay` attributes. If you initialize with `autoPlayMedia: false` NO media will autoplay. + +Note that embedded HTML5 `