diff --git a/_site/config.toml b/_site/config.toml index e1aceb2a..97e8200f 100644 --- a/_site/config.toml +++ b/_site/config.toml @@ -1,16 +1,14 @@ -baseURL = "/" - -languageCode = "en-us" -DefaultContentLanguage = "en" -title = "WTF - the terminal dashboard" -theme = "docdock" -# themesdir = "../.." -pygmentsCodeFences = true -pygmentsStyle = "monokailight" - +baseURL = "https://wtfutil.com/" defaultContentLanguage = "en" defaultContentLanguageInSubdir= false enableMissingTranslationPlaceholders = false +languageCode = "en-us" +publishDir = "../docs" +pygmentsCodeFences = true +pygmentsUseClasses = true +pygmentsStyle = "monokailight" +theme = "docdock" +title = "WTF - the terminal dashboard" # [Languages] # [Languages.en] diff --git a/_site/config.toml-orig b/_site/config.toml-orig index ed79d848..4e405d5a 100644 --- a/_site/config.toml-orig +++ b/_site/config.toml-orig @@ -1,8 +1,8 @@ baseURL = "https://wtfutil.com/" languageCode = "en-us" +publishDir = "../docs" pygmentsCodeFences = true pygmentsUseClasses = true -publishDir = "../docs" sectionPagesMenu = "main" theme = "hyde-hyde" title = "WTF - A Terminal Dashboard" diff --git a/docs/404.html b/docs/404.html index aad522fa..8c4d59b1 100644 --- a/docs/404.html +++ b/docs/404.html @@ -1,134 +1,489 @@ - - - - - - - - - + + + WTF - the terminal dashboard + + + +404 Page not found :: WTF - the terminal dashboard + + + + -404 Page not found | WTF - A Terminal Dashboard - - - - - - - - - - - - - - - - - - - - - - + + + + - + - - + + + + +
+
+
+ +
+ + +
+ + + + + + +
+ + +

404 Page not found

+ + +

Error

+

+

+

Woops. Looks like this page doesn't exist.

+

+

Go to homepage

+

+ + +
+ +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + diff --git a/docs/categories/index.html b/docs/categories/index.html index c3e3a661..258130e3 100644 --- a/docs/categories/index.html +++ b/docs/categories/index.html @@ -1,137 +1,506 @@ - - - - - - - - - + + + WTF - the terminal dashboard + + + +Categories :: WTF - the terminal dashboard + + + + -Categories | WTF - A Terminal Dashboard - - - - - - - - - - - - - - - - - - - - - - - - + + + + - + - - + + + + +
+ +
+ +
+
+ +
+ + +
+ + + + + + +
+ + +

Categories

+ + + + + + +
+ - -
-
-

Categories

-
    - -
- -
- - - - + +
+ + + + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/categories/index.xml b/docs/categories/index.xml index 03f71ced..c99d6b17 100644 --- a/docs/categories/index.xml +++ b/docs/categories/index.xml @@ -1,9 +1,9 @@ - Categories on WTF - A Terminal Dashboard + Categories on WTF - the terminal dashboard https://wtfutil.com/categories/ - Recent content in Categories on WTF - A Terminal Dashboard + Recent content in Categories on WTF - the terminal dashboard Hugo -- gohugo.io en-us diff --git a/docs/categories/page/1/index.html b/docs/categories/page/1/index.html new file mode 100644 index 00000000..5eea3f9c --- /dev/null +++ b/docs/categories/page/1/index.html @@ -0,0 +1 @@ +https://wtfutil.com/categories/ \ No newline at end of file diff --git a/docs/configuration/attributes/index.html b/docs/configuration/attributes/index.html new file mode 100644 index 00000000..e11b628e --- /dev/null +++ b/docs/configuration/attributes/index.html @@ -0,0 +1,568 @@ + + + + WTF - the terminal dashboard + + + + +Attributes :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + + + +
+ + + +
+
+ +
+ + +
+ + + + + + +
+ + +

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]
+  openFileUtil: open      # the name of the utility to call to open files
+  refreshInterval: 1      # the app refreshes once per second
+  term: "xterm-256color"
+

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.

+ +

colors.border.focusable
+The color in which to draw the border of widgets that can accept +keyboard focus.
+Values: Any X11 +color name.

+ +

colors.border.focused
+The color in which to draw the border of the widget that currently has +keyboard focus.
+Values: Any X11 +color name.

+ +

colors.border.normal
+The color in which to draw the borders of the widgets that cannot accept +focus.
+Values: Any X11 +color name.

+ +

grid.columns
+An array that defines the widths of all the columns.
+Values: See tview’s +Grid for details.

+ +

grid.rows
+An array that defines the heights of all the rows.
+Values: See tview’s +Grid for details.

+ +

openFileUtil
+Command to use to open a file or URL

+ +

refreshInterval
+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.

+ +

term
+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’s +default setting.
+Note: If an invalid value is provided for this setting, the app will + crash with a "terminal entry not found" error.
+Values: Any valid terminal type (ie: vt100, xterm, xterm-256color, ansi, +etc.).

+ + + + + + +
+
+ +
+ +
+ + + + + +
+ Last update on 16/05/2018 +
+ + + +
+ + +
+ + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/configuration/index.html b/docs/configuration/index.html new file mode 100644 index 00000000..312be0f6 --- /dev/null +++ b/docs/configuration/index.html @@ -0,0 +1,568 @@ + + + + WTF - the terminal dashboard + + + + +Configuration :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + + + +
+ + + +
+
+ +
+ + +
+ + + + + + +
+ + +

Configuration

+ + + + + + +

Index

+ + + +

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.

+ +

To 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.

+ +

Custom 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.

+ +

To load a custom configuration file (ie: one that’s not +~/.config/wtf/config.yml), pass in the path to configuration file as a +parameter on launch:

+
    $> 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.

+ +

Grid Layout

+ +

WTF uses the Grid layout system from tview to position widgets +onscreen. It’s not immediately obvious how this works, so here’s an +explanation:

+ +

Think of your terminal screen as a matrix of letter positions, say 100 chrs wide and 58 chrs tall.

+ +

Columns breaks up the width of the screen into chunks, each chunk a specified number of characters wide. use

+ +

[10, 10, 10, 10, 10, 10, 10, 10, 10, 10]

+ +

Ten columns that are ten characters wide

+ +

Rows break up the height of the screen into chunks, each chunk a specified number of characters tall. If we wanted to have five rows:

+ +

[10, 10, 10, 10, 18]

+ +

The 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’d position it at:

+ +
  top:    4  // top starts in the 4th row
+  left:   9  // left starts in the 9th column
+  height: 2  // span down rows 4 & 5 (18 characters in size, total)
+  width:  2  // span across cols 9 & 10 (20 characters in size, total)
+
+ + + + + + + +
+
+ +
+ +
+ + + + + +
+ Last update on 15/04/2018 +
+ + + +
+ + +
+ + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/configuration/index.xml b/docs/configuration/index.xml new file mode 100644 index 00000000..3a645727 --- /dev/null +++ b/docs/configuration/index.xml @@ -0,0 +1,37 @@ + + + + Configuration on WTF - the terminal dashboard + https://wtfutil.com/configuration/ + Recent content in Configuration on WTF - the terminal dashboard + Hugo -- gohugo.io + en-us + Sun, 15 Apr 2018 21:17:16 -0700 + + + + + + Attributes + https://wtfutil.com/configuration/attributes/ + Wed, 16 May 2018 21:51:23 -0700 + + https://wtfutil.com/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 widecolumns:[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 fourrows:[10,10,10,10,10,3,4]openFileUtil:open# the name of the utility to call to open filesrefreshInterval:1# the app refreshes once per secondterm:"xterm-256color" Attributes colors. + + + + iTerm2 + https://wtfutil.com/configuration/iterm2/ + Thu, 24 May 2018 09:57:40 -0700 + + https://wtfutil.com/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. + + + + \ No newline at end of file diff --git a/docs/configuration/iterm2/index.html b/docs/configuration/iterm2/index.html new file mode 100644 index 00000000..86a031d1 --- /dev/null +++ b/docs/configuration/iterm2/index.html @@ -0,0 +1,510 @@ + + + + WTF - the terminal dashboard + + + + +iTerm2 :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + + + +
+ + + +
+
+ +
+ + +
+ + + + + + +
+ + +

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. Then +restart WTF.

+ +

iTerm2
+Prefs

+ +

(Note: This issue is not unique to iTerm2. As of this writing it also +affects Terminal, and Hyper.)

+ + + + + + +
+
+ +
+ +
+ + + + + +
+ Last update on 24/05/2018 +
+ + + +
+ + +
+ + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/css/auto-complete.css b/docs/css/auto-complete.css new file mode 100644 index 00000000..c144cd38 --- /dev/null +++ b/docs/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/docs/css/bootstrap.min.css b/docs/css/bootstrap.min.css new file mode 100644 index 00000000..156aa3c7 --- /dev/null +++ b/docs/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/docs/css/custom.css b/docs/css/custom.css index 40856419..eaf75db9 100644 --- a/docs/css/custom.css +++ b/docs/css/custom.css @@ -1,90 +1,57 @@ -html, body -{ - font-family: 'Fira Sans', sans-serif; - font-size: 18px; - font-weight: 300; - line-height: 1.5; +.caption { + color: #111; + display: inline-block; + font-weight: bold; + min-width: 64px; + text-align: right; } -.clear { - clear: both; +#navigation a { + color: #666 !important; } -.img-circle -{ - border-radius: 50%; +#navigation a:hover { + color: #333 !important; } -.headshot -{ - width: 115px; - height: 115px; +#navigation a label { + cursor: pointer !important; } -.brand -{ - font-size: 2.6em; - - margin-bottom: 0; -} - -.text-center -{ - text-align: center; -} - -.meta -{ - font-size: .8rem; - font-weight: 300; -} - -pre -{ - padding: 1px; - - tab-size: 2; -} - - -.hljs { - white-space: pre; - - overflow-x: auto; /* no line wrapping */ -} - -pre code, li code, td code, code -{ - /*border-radius: 4px;*/ - white-space: pre-wrap; - background-color: white; - margin: 0 !important; - padding: 0; - /*padding:1px 4px;*/ - /*background: #eee;*/ - /* color: #444; */ - /*border: 1px solid #d9d9d9;*/ +a.highlight { + border-bottom: none !important; + padding-left: 6px !important; } code { - font-family: 'Roboto Mono', monospace; - font-size: 90%; -} -.copyright, -.poweredby -{ - font-size: 13px; - font-weight: 300; + color: #b97208; + display: inline-block; + margin: 0 4px !important; + padding-left: 0px !important; } -.center -{ - display: block; +h1 { + text-align: left !important; +} - margin-right: auto; - margin-left: auto; +h2 { + font-weight: normal; } -/* Changing from font-awesome 4 to 5, the class pull-right was removed */ -.pull-right { - float: right; + +h3 { + font-weight: normal; +} + +img.screenshot { + margin: 0 0 0 24px !important; + padding: 0 !important ; + float: right; +} + +p { + line-height: 26px; +} + +pre { + outline: 1px solid #cdcdcd; } diff --git a/docs/css/featherlight.min.css b/docs/css/featherlight.min.css new file mode 100644 index 00000000..f225bec5 --- /dev/null +++ b/docs/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/docs/css/font-awesome.min.css b/docs/css/font-awesome.min.css new file mode 100644 index 00000000..540440ce --- /dev/null +++ b/docs/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/docs/css/horsey.css b/docs/css/horsey.css new file mode 100644 index 00000000..358f72d8 --- /dev/null +++ b/docs/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/docs/css/hybrid.css b/docs/css/hybrid.css new file mode 100644 index 00000000..29735a18 --- /dev/null +++ b/docs/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/docs/css/nucleus.css b/docs/css/nucleus.css new file mode 100644 index 00000000..ed2c0a38 --- /dev/null +++ b/docs/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/docs/fonts/FontAwesome.otf b/docs/fonts/FontAwesome.otf new file mode 100644 index 00000000..401ec0f3 Binary files /dev/null and b/docs/fonts/FontAwesome.otf differ diff --git a/docs/fonts/Inconsolata.eot b/docs/fonts/Inconsolata.eot new file mode 100644 index 00000000..0a705d65 Binary files /dev/null and b/docs/fonts/Inconsolata.eot differ diff --git a/docs/fonts/Inconsolata.svg b/docs/fonts/Inconsolata.svg new file mode 100644 index 00000000..b7f97c87 --- /dev/null +++ b/docs/fonts/Inconsolata.svg @@ -0,0 +1,359 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/docs/fonts/Inconsolata.ttf b/docs/fonts/Inconsolata.ttf new file mode 100644 index 00000000..4b8a36d2 Binary files /dev/null and b/docs/fonts/Inconsolata.ttf differ diff --git a/docs/fonts/Inconsolata.woff b/docs/fonts/Inconsolata.woff new file mode 100644 index 00000000..6f39625e Binary files /dev/null and b/docs/fonts/Inconsolata.woff differ diff --git a/docs/fonts/Lato-Bold.ttf b/docs/fonts/Lato-Bold.ttf new file mode 100644 index 00000000..74343694 Binary files /dev/null and b/docs/fonts/Lato-Bold.ttf differ diff --git a/docs/fonts/Lato-Bold.woff2 b/docs/fonts/Lato-Bold.woff2 new file mode 100644 index 00000000..254684c7 Binary files /dev/null and b/docs/fonts/Lato-Bold.woff2 differ diff --git a/docs/fonts/Lato-Regular.ttf b/docs/fonts/Lato-Regular.ttf new file mode 100644 index 00000000..04ea8efb Binary files /dev/null and b/docs/fonts/Lato-Regular.ttf differ diff --git a/docs/fonts/Lato-Regular.woff2 b/docs/fonts/Lato-Regular.woff2 new file mode 100644 index 00000000..c4e8b1ab Binary files /dev/null and b/docs/fonts/Lato-Regular.woff2 differ diff --git a/docs/fonts/Novecentosanswide-Normal-webfont.eot b/docs/fonts/Novecentosanswide-Normal-webfont.eot new file mode 100644 index 00000000..9984682f Binary files /dev/null and b/docs/fonts/Novecentosanswide-Normal-webfont.eot differ diff --git a/docs/fonts/Novecentosanswide-Normal-webfont.svg b/docs/fonts/Novecentosanswide-Normal-webfont.svg new file mode 100644 index 00000000..c412ea8c --- /dev/null +++ b/docs/fonts/Novecentosanswide-Normal-webfont.svg @@ -0,0 +1,1019 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/fonts/Novecentosanswide-Normal-webfont.ttf b/docs/fonts/Novecentosanswide-Normal-webfont.ttf new file mode 100644 index 00000000..8cfb62dd Binary files /dev/null and b/docs/fonts/Novecentosanswide-Normal-webfont.ttf differ diff --git a/docs/fonts/Novecentosanswide-Normal-webfont.woff b/docs/fonts/Novecentosanswide-Normal-webfont.woff new file mode 100644 index 00000000..d5c42907 Binary files /dev/null and b/docs/fonts/Novecentosanswide-Normal-webfont.woff differ diff --git a/docs/fonts/Novecentosanswide-Normal-webfont.woff2 b/docs/fonts/Novecentosanswide-Normal-webfont.woff2 new file mode 100644 index 00000000..eefb4a31 Binary files /dev/null and b/docs/fonts/Novecentosanswide-Normal-webfont.woff2 differ diff --git a/docs/fonts/Novecentosanswide-UltraLight-webfont.eot b/docs/fonts/Novecentosanswide-UltraLight-webfont.eot new file mode 100644 index 00000000..2a26561f Binary files /dev/null and b/docs/fonts/Novecentosanswide-UltraLight-webfont.eot differ diff --git a/docs/fonts/Novecentosanswide-UltraLight-webfont.svg b/docs/fonts/Novecentosanswide-UltraLight-webfont.svg new file mode 100644 index 00000000..e642ab07 --- /dev/null +++ b/docs/fonts/Novecentosanswide-UltraLight-webfont.svg @@ -0,0 +1,918 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/fonts/Novecentosanswide-UltraLight-webfont.ttf b/docs/fonts/Novecentosanswide-UltraLight-webfont.ttf new file mode 100644 index 00000000..9ce9c7f9 Binary files /dev/null and b/docs/fonts/Novecentosanswide-UltraLight-webfont.ttf differ diff --git a/docs/fonts/Novecentosanswide-UltraLight-webfont.woff b/docs/fonts/Novecentosanswide-UltraLight-webfont.woff new file mode 100644 index 00000000..381650c9 Binary files /dev/null and b/docs/fonts/Novecentosanswide-UltraLight-webfont.woff differ diff --git a/docs/fonts/Novecentosanswide-UltraLight-webfont.woff2 b/docs/fonts/Novecentosanswide-UltraLight-webfont.woff2 new file mode 100644 index 00000000..7e659549 Binary files /dev/null and b/docs/fonts/Novecentosanswide-UltraLight-webfont.woff2 differ diff --git a/docs/fonts/Roboto-Italic.ttf b/docs/fonts/Roboto-Italic.ttf new file mode 100644 index 00000000..ff6046d5 Binary files /dev/null and b/docs/fonts/Roboto-Italic.ttf differ diff --git a/docs/fonts/Roboto-Medium.ttf b/docs/fonts/Roboto-Medium.ttf new file mode 100644 index 00000000..39c63d74 Binary files /dev/null and b/docs/fonts/Roboto-Medium.ttf differ diff --git a/docs/fonts/Roboto-Regular.ttf b/docs/fonts/Roboto-Regular.ttf new file mode 100644 index 00000000..8c082c8d Binary files /dev/null and b/docs/fonts/Roboto-Regular.ttf differ diff --git a/docs/fonts/RobotoMono-Medium.ttf b/docs/fonts/RobotoMono-Medium.ttf new file mode 100644 index 00000000..0bcdc740 Binary files /dev/null and b/docs/fonts/RobotoMono-Medium.ttf differ diff --git a/docs/fonts/RobotoMono-Regular.ttf b/docs/fonts/RobotoMono-Regular.ttf new file mode 100644 index 00000000..495a82ce Binary files /dev/null and b/docs/fonts/RobotoMono-Regular.ttf differ diff --git a/docs/fonts/Work_Sans_200.eot b/docs/fonts/Work_Sans_200.eot new file mode 100644 index 00000000..4052e4f9 Binary files /dev/null and b/docs/fonts/Work_Sans_200.eot differ diff --git a/docs/fonts/Work_Sans_200.svg b/docs/fonts/Work_Sans_200.svg new file mode 100644 index 00000000..58ab4ba2 --- /dev/null +++ b/docs/fonts/Work_Sans_200.svg @@ -0,0 +1,332 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/docs/fonts/Work_Sans_200.ttf b/docs/fonts/Work_Sans_200.ttf new file mode 100644 index 00000000..68019e1c Binary files /dev/null and b/docs/fonts/Work_Sans_200.ttf differ diff --git a/docs/fonts/Work_Sans_200.woff b/docs/fonts/Work_Sans_200.woff new file mode 100644 index 00000000..a1bd9e46 Binary files /dev/null and b/docs/fonts/Work_Sans_200.woff differ diff --git a/docs/fonts/Work_Sans_200.woff2 b/docs/fonts/Work_Sans_200.woff2 new file mode 100644 index 00000000..20c68a75 Binary files /dev/null and b/docs/fonts/Work_Sans_200.woff2 differ diff --git a/docs/fonts/Work_Sans_300.eot b/docs/fonts/Work_Sans_300.eot new file mode 100644 index 00000000..ace79938 Binary files /dev/null and b/docs/fonts/Work_Sans_300.eot differ diff --git a/docs/fonts/Work_Sans_300.svg b/docs/fonts/Work_Sans_300.svg new file mode 100644 index 00000000..f29d0c8a --- /dev/null +++ b/docs/fonts/Work_Sans_300.svg @@ -0,0 +1,331 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/docs/fonts/Work_Sans_300.ttf b/docs/fonts/Work_Sans_300.ttf new file mode 100644 index 00000000..35387c23 Binary files /dev/null and b/docs/fonts/Work_Sans_300.ttf differ diff --git a/docs/fonts/Work_Sans_300.woff b/docs/fonts/Work_Sans_300.woff new file mode 100644 index 00000000..8d789eae Binary files /dev/null and b/docs/fonts/Work_Sans_300.woff differ diff --git a/docs/fonts/Work_Sans_300.woff2 b/docs/fonts/Work_Sans_300.woff2 new file mode 100644 index 00000000..f6e216d6 Binary files /dev/null and b/docs/fonts/Work_Sans_300.woff2 differ diff --git a/docs/fonts/Work_Sans_500.eot b/docs/fonts/Work_Sans_500.eot new file mode 100644 index 00000000..9df69294 Binary files /dev/null and b/docs/fonts/Work_Sans_500.eot differ diff --git a/docs/fonts/Work_Sans_500.svg b/docs/fonts/Work_Sans_500.svg new file mode 100644 index 00000000..4b030b79 --- /dev/null +++ b/docs/fonts/Work_Sans_500.svg @@ -0,0 +1,333 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/docs/fonts/Work_Sans_500.ttf b/docs/fonts/Work_Sans_500.ttf new file mode 100644 index 00000000..5b8cc534 Binary files /dev/null and b/docs/fonts/Work_Sans_500.ttf differ diff --git a/docs/fonts/Work_Sans_500.woff b/docs/fonts/Work_Sans_500.woff new file mode 100644 index 00000000..df058514 Binary files /dev/null and b/docs/fonts/Work_Sans_500.woff differ diff --git a/docs/fonts/Work_Sans_500.woff2 b/docs/fonts/Work_Sans_500.woff2 new file mode 100644 index 00000000..b06c54df Binary files /dev/null and b/docs/fonts/Work_Sans_500.woff2 differ diff --git a/docs/fonts/fontawesome-webfont.eot b/docs/fonts/fontawesome-webfont.eot new file mode 100644 index 00000000..e9f60ca9 Binary files /dev/null and b/docs/fonts/fontawesome-webfont.eot differ diff --git a/docs/fonts/fontawesome-webfont.svg b/docs/fonts/fontawesome-webfont.svg new file mode 100644 index 00000000..855c845e --- /dev/null +++ b/docs/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/docs/fonts/fontawesome-webfont.ttf b/docs/fonts/fontawesome-webfont.ttf new file mode 100644 index 00000000..35acda2f Binary files /dev/null and b/docs/fonts/fontawesome-webfont.ttf differ diff --git a/docs/fonts/fontawesome-webfont.woff b/docs/fonts/fontawesome-webfont.woff new file mode 100644 index 00000000..400014a4 Binary files /dev/null and b/docs/fonts/fontawesome-webfont.woff differ diff --git a/docs/fonts/fontawesome-webfont.woff2 b/docs/fonts/fontawesome-webfont.woff2 new file mode 100644 index 00000000..4d13fc60 Binary files /dev/null and b/docs/fonts/fontawesome-webfont.woff2 differ diff --git a/docs/fonts/glyphicons-halflings-regular.eot b/docs/fonts/glyphicons-halflings-regular.eot new file mode 100644 index 00000000..b93a4953 Binary files /dev/null and b/docs/fonts/glyphicons-halflings-regular.eot differ diff --git a/docs/fonts/glyphicons-halflings-regular.svg b/docs/fonts/glyphicons-halflings-regular.svg new file mode 100644 index 00000000..94fb5490 --- /dev/null +++ b/docs/fonts/glyphicons-halflings-regular.svg @@ -0,0 +1,288 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/fonts/glyphicons-halflings-regular.ttf b/docs/fonts/glyphicons-halflings-regular.ttf new file mode 100644 index 00000000..1413fc60 Binary files /dev/null and b/docs/fonts/glyphicons-halflings-regular.ttf differ diff --git a/docs/fonts/glyphicons-halflings-regular.woff b/docs/fonts/glyphicons-halflings-regular.woff new file mode 100644 index 00000000..9e612858 Binary files /dev/null and b/docs/fonts/glyphicons-halflings-regular.woff differ diff --git a/docs/fonts/glyphicons-halflings-regular.woff2 b/docs/fonts/glyphicons-halflings-regular.woff2 new file mode 100644 index 00000000..64539b54 Binary files /dev/null and b/docs/fonts/glyphicons-halflings-regular.woff2 differ diff --git a/docs/getting_started/glossary/index.html b/docs/getting_started/glossary/index.html new file mode 100644 index 00000000..58996541 --- /dev/null +++ b/docs/getting_started/glossary/index.html @@ -0,0 +1,507 @@ + + + + WTF - the terminal dashboard + + + + +Glossary :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + + + +
+ + + +
+
+ +
+ + +
+ + + + + + +
+ + +

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.

+ + + + + + +
+
+ +
+ +
+ + + + + +
+ Last update on 17/04/2018 +
+ + + +
+ + +
+ + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/getting_started/index.html b/docs/getting_started/index.html new file mode 100644 index 00000000..3255eb77 --- /dev/null +++ b/docs/getting_started/index.html @@ -0,0 +1,537 @@ + + + + WTF - the terminal dashboard + + + + +Getting Started :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + + + +
+ + + +
+
+ +
+ + +
+ + + + + + +
+ + +

Getting Started

+ + + + + + +

Quick Start

+ +
    +
  1. Download the stand-alone, compiled binary.
  2. +
  3. Unzip the downloaded file.
  4. +
  5. From the command line, cd into the newly-created /wtf directory.
  6. +
  7. From the command line, run the app: ./wtf
  8. +
+ +

This should launch the app in your terminal using the default simple +configuration. See Configuration for +more details.

+ +

Command-line Options

+ +

--config, -c
+Allows you to define a custom config file to use. See Configuration for more details.

+ +

--help, -h
+Shows help information for the command-line arguments that WTF +takes.

+ +

--module, -m
+Shows help information for the specific named module, if that module +supports help text.
+Example: wtf --module=todo.

+ +

--version, -v
+Shows version info.

+ +

Keyboard Commands

+ +

Key: Ctrl-R
+Action: Force-refresh the data for all modules.

+ +

Key: Esc
+Action: Unfocus the currently-focused +widget.

+ +

Key: Tab
+Action: Move between focusable modules (Shift-Tab to move backwards).

+ + + + + + + +
+
+ +
+ +
+ + + + + +
+ Last update on 21/05/2018 +
+ + + +
+ + +
+ + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/getting_started/index.xml b/docs/getting_started/index.xml new file mode 100644 index 00000000..fdcb345e --- /dev/null +++ b/docs/getting_started/index.xml @@ -0,0 +1,40 @@ + + + + Getting Started on WTF - the terminal dashboard + https://wtfutil.com/getting_started/ + Recent content in Getting Started on WTF - the terminal dashboard + Hugo -- gohugo.io + en-us + Mon, 21 May 2018 16:11:58 -0700 + + + + + + Installation + https://wtfutil.com/getting_started/installation/ + Fri, 18 May 2018 09:59:40 -0700 + + https://wtfutil.com/getting_started/installation/ + 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. +From Source Download the source code repo and install the dependencies: +go get -u github.com/senorprogrammer/wtf cd $GOPATH/src/github.com/senorprogrammer/wtf go install -ldflags="-s -w" make run and that should do it. + + + + Glossary + https://wtfutil.com/getting_started/glossary/ + Tue, 17 Apr 2018 12:34:51 -0700 + + https://wtfutil.com/getting_started/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. + + + + \ No newline at end of file diff --git a/docs/getting_started/installation/index.html b/docs/getting_started/installation/index.html new file mode 100644 index 00000000..9f42502e --- /dev/null +++ b/docs/getting_started/installation/index.html @@ -0,0 +1,510 @@ + + + + WTF - the terminal dashboard + + + + +Installation :: WTF - the terminal dashboard + + + + + + + + + + + + + + + + + + +
+ + + +
+
+ +
+ + +
+ + + + + + +
+ + +

Installation

+ + + + + +

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.

+ +

From Source

+ +

Download the source code repo and install the dependencies:

+
go get -u github.com/senorprogrammer/wtf
+cd $GOPATH/src/github.com/senorprogrammer/wtf
+go install -ldflags="-s -w"
+make run
+

and that should do it.

+ + + + + + +
+
+ +
+ +
+ + + + + +
+ Last update on 18/05/2018 +
+ + + +
+ + +
+ + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/images/clippy.svg b/docs/images/clippy.svg new file mode 100644 index 00000000..8a77a330 --- /dev/null +++ b/docs/images/clippy.svg @@ -0,0 +1,4 @@ + + + + diff --git a/docs/images/favicon.png b/docs/images/favicon.png new file mode 100644 index 00000000..0f3bda8e Binary files /dev/null and b/docs/images/favicon.png differ diff --git a/docs/images/gopher-404.jpg b/docs/images/gopher-404.jpg new file mode 100644 index 00000000..df106486 Binary files /dev/null and b/docs/images/gopher-404.jpg differ diff --git a/docs/imgs/modules/gitlab.png b/docs/imgs/modules/gitlab.png index 6e806a41..e72042d6 100644 Binary files a/docs/imgs/modules/gitlab.png and b/docs/imgs/modules/gitlab.png differ diff --git a/docs/imgs/modules/travisci.png b/docs/imgs/modules/travisci.png index eb423fa9..45b037cd 100644 Binary files a/docs/imgs/modules/travisci.png and b/docs/imgs/modules/travisci.png differ diff --git a/docs/imgs/modules/trello.png b/docs/imgs/modules/trello.png index 79fa6965..4a440dd8 100644 Binary files a/docs/imgs/modules/trello.png and b/docs/imgs/modules/trello.png differ diff --git a/docs/imgs/screenshot.jpg b/docs/imgs/screenshot.jpg new file mode 100644 index 00000000..81a572bc Binary files /dev/null and b/docs/imgs/screenshot.jpg differ diff --git a/docs/index.html b/docs/index.html index c33abbbf..9f056d92 100644 --- a/docs/index.html +++ b/docs/index.html @@ -1,165 +1,506 @@ - - - - - - - - - + + + WTF - the terminal dashboard + + + -WTF - A Terminal Dashboard - - - - - - - - - - - - +WTF :: WTF - the terminal dashboard + + + + - - - - - - - - - - - + + + + - + - - + + + + +
+
+
+ +
+ + +
+ + + + + + +
+ + + + + + + + navigation + + +

WTF

+ +

+ +

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 systems, services, and important information that you otherwise might keep browser tabs open for, the kinds of things you don’t always need visible, but do check in on every now and then.

+ +

Keep an eye on your OpsGenie schedules, Google Calendar, Git and GitHub repositories, and New Relic deployments.

+ +

See who’s away in BambooHR, which Jira tickets are assigned to you, and what time it is in Barcelona.

+ +

It even has weather. And clocks. And emoji.

+ + + + + + + + +
+
+ +
+ +
+ + + + + +
+ Last update on 14/08/2018 +
+ + + +
+ + +
+ + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/index.json b/docs/index.json new file mode 100644 index 00000000..d6b0b636 --- /dev/null +++ b/docs/index.json @@ -0,0 +1,337 @@ +[ +{ + "uri": "https://wtfutil.com/getting_started/", + "title": "Getting Started", + "tags": [], + "description": "", + "content": " Quick 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": "https://wtfutil.com/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/ Configuration bittrex:enabled:trueposition:top:1left:2height:3width:1refreshInterval:5summary:BTC:displayName:Bitcoinmarket:-LTC-ETHcolors:base:name:orangedisplayName:redmarket:name:redfield:whitevalue: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": "https://wtfutil.com/configuration/attributes/", + "title": "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 widecolumns:[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 fourrows:[10,10,10,10,10,3,4]openFileUtil:open# the name of the utility to call to open filesrefreshInterval:1# the app refreshes once per secondterm:\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": "https://wtfutil.com/configuration/", + "title": "Configuration", + "tags": [], + "description": "", + "content": " Index Configuration Files Example Configuration Files Custom Configuration Files Configuration Attributes 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.\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": "https://wtfutil.com/modules/cryptocurrencies/blockfolio/", + "title": "Blockfolio", + "tags": [], + "description": "", + "content": " Added in v0.0.8.\nDisplay your Blockfolio crypto holdings.\nSource wtf/blockfolio/ Configuration blockfolio:colors:name:bluegrows:greendrop:reddevice_token:\u0026#34;device token\u0026#34;displayHoldings:trueenabled:trueposition:top:3left:1width:1height:1refreshInterval: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": "https://wtfutil.com/modules/ipaddress/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/ Configuration ipinfo:colors:name:redvalue:whiteenabled:trueposition:top:1left:2height:1width:1refreshInterval: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": "https://wtfutil.com/modules/weather_services/prettyweather/", + "title": "Pretty Weather", + "tags": [], + "description": "", + "content": " Displays weather information as ASCII art from Wttr.in.\nSource Code wtf/prettyweather/ Configuration prettyweather:enabled:truecity:\u0026#34;tehran\u0026#34;position:top:3left:5height:1width:1refreshInterval:300unit:\u0026#34;c\u0026#34;view:0language:\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": "https://wtfutil.com/configuration/iterm2/", + "title": "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": "https://wtfutil.com/modules/google/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/ Configuration 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:trueemail:\u0026#34;chriscummer@me.com\u0026#34;enabled:trueeventCount:12multiCalendar:trueposition:top:0left:0height:4width:1refreshInterval:300secretFile:\u0026#34;~/.config/wtf/gcal/client_secret.json\u0026#34;showDeclined:truewithLocation: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": "https://wtfutil.com/modules/bamboohr/", + "title": "BambooHR", + "tags": [], + "description": "", + "content": " Connects to the BambooHR API and displays who will be Away today.\nSource Code wtf/bamboohr/ Configuration bamboohr:apiKey:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;enabled:trueposition:top:0left:1height:2width:1refreshInterval:900subdomain:\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": "https://wtfutil.com/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": "https://wtfutil.com/modules/cryptocurrencies/cryptolive/", + "title": "CryptoLive", + "tags": [], + "description": "", + "content": " Added in v0.0.5.\nCompare crypto currencies using CryptoCompare.\nSource Code wtf/cryptoexchanges/cryptolive/ Configuration cryptolive:enabled:trueposition:top:5left:2height:1width:2updateInterval:15currencies:BTC:displayName:Bitcointo:-USD-EUR-ETH-LTC-DOGELTC:displayName:Ethereumto:-USD-EUR-BTCtop:BTC:displayName:Bitcoinlimit:5to:-USDcolors:from:name:coraldisplayName:greyto:name:whiteprice:greentop:from:name:greydisplayName:coralto:name:redfield:whitevalue: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": "https://wtfutil.com/modules/circleci/", + "title": "CircleCI", + "tags": [], + "description": "", + "content": " Added in v0.0.7.\nDisplays build information for your CircleCI account.\nSource Code wtf/circleci/ Configuration circleci:apiKey:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;enabled:trueposition:top:4left:1height:1width:2refreshInterval: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": "https://wtfutil.com/modules/ipaddress/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/ Configuration ipinfo:colors:name:redvalue:whiteenabled:trueposition:top:1left:2height:1width:1refreshInterval: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": "https://wtfutil.com/modules/weather_services/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/ Keyboard 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.txtcityids:-6173331-3128760-6167865-6176823colors:current:\u0026#34;lightblue\u0026#34;enabled:truelanguage:\u0026#34;EN\u0026#34;position:top:0left:2height:1width:1refreshInterval:900tempUnit:\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": "https://wtfutil.com/modules/clocks/", + "title": "Clocks", + "tags": [], + "description": "", + "content": " Displays a configurable list of world clocks, the local time, and date.\nSource Code wtf/clocks/ Configuration clocks:colors:rows:even:\u0026#34;lightblue\u0026#34;odd:\u0026#34;white\u0026#34;enabled:truelocations:# From https://en.wikipedia.org/wiki/List_of_tz_database_time_zonesAvignon:\u0026#34;Europe/Paris\u0026#34;Barcelona:\u0026#34;Europe/Madrid\u0026#34;Dubai:\u0026#34;Asia/Dubai\u0026#34;NewYork:\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:4left:0height:1width:1refreshInterval:15# Valid options are: alphabetical, chronologicalsort:\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": "https://wtfutil.com/modules/cmdrunner/", + "title": "CmdRunner", + "tags": [], + "description": "", + "content": " Runs a terminal command on a schedule.\nSource Code wtf/cmdrunner/ Configuration cmdrunner:args:[\u0026#34;-g\u0026#34;,\u0026#34;batt\u0026#34;]cmd:\u0026#34;pmset\u0026#34;enabled:trueposition:top:6left:1height:1width:3refreshInterval: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": "https://wtfutil.com/modules/google/gspreadsheet/", + "title": "Google Spreadsheets", + "tags": [], + "description": "", + "content": " Added in v0.0.7.\nDisplay information from cells in a Google Spreadsheet.\nwtf/gspreadsheets/ Configuration 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:trueposition:top:0left:0width:1height:1refreshInterval:\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": "https://wtfutil.com/modules/cryptocurrencies/", + "title": "Crypo Currencies", + "tags": [], + "description": "", + "content": "For all modules cryptocurrency-related.\n" +}, +{ + "uri": "https://wtfutil.com/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.comenabled:truepassword:\u0026#34;mypassword\u0026#34;position:top:2left:3height:2width:2projects:-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": "https://wtfutil.com/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/ 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 git:commitCount:5commitFormat:\u0026#34;[forestgreen]%h [grey]%cd [white]%s [grey]%an[white]\u0026#34;dateFormat:\u0026#34;%H:%M %d %b %y\u0026#34;enabled:trueposition:top:0left:3height:2width:2refreshInterval:8repositories:-\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": "https://wtfutil.com/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:trueenableStatus:trueposition:top:2left:3height:2width:2refreshInterval:300repositories: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": "https://wtfutil.com/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:trueposition:top:2left:3height:2width:2refreshInterval:300projects: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": "https://wtfutil.com/modules/gitter/", + "title": "Gitter", + "tags": [], + "description": "", + "content": " Added in v0.2.1.\nDisplays chat messages from Gitter.\nSource Code wtf/gitter/ Keyboard Commands Key: j Action: Select the next message in the list.\nKey: k Action: Select the previous message in the list.\nKey: r Action: Refresh the data.\nKey: ↓ Action: Select the next message in the list.\nKey: ↑ Action: Select the previous message in the list.\nConfiguration gitter:apiToken:\u0026#34;ab345546asdfasb465234fgjgh068f39a35c3e4139ee383f7\u0026#34;enabled:truenumberOfMessages:10position:top:4left:1height:1width:4roomUri:wtfutil/LobbyrefreshInterval:300 Attributes apiToken Value: Your GitterPersonal Access Token.\nenabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nnumberOfMessages Optional Maximum number of (newest) messages to be displayed. Default is 10\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. roomUri Optional new, top, job, ask\nrefreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "https://wtfutil.com/modules/google/", + "title": "Google Apps", + "tags": [], + "description": "", + "content": "Google Apps.\n Google Calendar Google Spreadsheets " +}, +{ + "uri": "https://wtfutil.com/modules/hackernews/", + "title": "Hacker News", + "tags": [], + "description": "", + "content": " Added in v0.1.2.\nDisplays stories from Hacker News.\nSource Code wtf/hackernews/ Keyboard Commands Key: [return] Action: Open the selected story in the browser.\nKey: j Action: Select the next story in the list.\nKey: k Action: Select the previous story in the list.\nKey: r Action: Refresh the data.\nKey: ↓ Action: Select the next story in the list.\nKey: ↑ Action: Select the previous story in the list.\nConfiguration hackernews:enabled:truenumberOfStories:10position:top:4left:1height:1width:2storyType:toprefreshInterval:900 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false.\nnumberOfStories Optional Defines number of stories to be displayed. Default is 10\nposition Defines where in the grid this module\u0026rsquo;s widget will be displayed. storyType Optional new, top, job, ask\nrefreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "https://wtfutil.com/modules/ipaddress/", + "title": "IP Addresses", + "tags": [], + "description": "", + "content": "For all modules IP address-related.\n IP-API IPInfo " +}, +{ + "uri": "https://wtfutil.com/modules/jenkins/", + "title": "Jenkins", + "tags": [], + "description": "", + "content": " Added in v0.0.8.\nDisplays jenkins status of given builds in a project or view\nSource Code wtf/jenkins/ Configuration jenkins:apiKey:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;enabled:trueposition:top:2left:3height:2width:3refreshInterval:300url:\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": "https://wtfutil.com/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:truejql:\u0026#34;issueType = Story\u0026#34;position:top:4left:1height:1width:2project:\u0026#34;ProjectA\u0026#34;refreshInterval:900username:\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:truejql:\u0026#34;issueType = Story\u0026#34;position:top:4left:1height:1width:2project:[\u0026#34;ProjectA\u0026#34;,\u0026#34;ProjectB\u0026#34;]refreshInterval:900username:\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": "https://wtfutil.com/modules/logger/", + "title": "Logger", + "tags": [], + "description": "", + "content": " Displays the contents of the WTF log file. The log file is located at ~/.config/wtf/log.txt.\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/ Keyboard Commands Arrow keys scroll through the log file.\nConfiguration logger:enabled:trueposition:top:5left:4height:2width:1refreshInterval: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": "https://wtfutil.com/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/ Configuration newrelic:apiKey:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;applicationId:10549735deployCount:6enabled:trueposition:top:4left:3height:1width:2refreshInterval: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": "https://wtfutil.com/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/ Configuration opsgenie:apiKey:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;displayEmpty:falseenabled:trueposition:top:2left:1height:2width:1refreshInterval: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": "https://wtfutil.com/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/ Configuration power:enabled:trueposition:top:5left:0height:2width:1refreshInterval: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": "https://wtfutil.com/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/ Configuration security:enabled:trueposition:top:1left:2height:1width:1refreshInterval: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": "https://wtfutil.com/modules/textfile/", + "title": "Textfile", + "tags": [], + "description": "", + "content": " Displays the contents of the specified text file in the widget.\nSource Code wtf/textfile/ Keyboard 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:truefilePath:\u0026#34;~/Desktop/notes.md\u0026#34;position:top:5left:4height:2width:1refreshInterval: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": "https://wtfutil.com/modules/todo/", + "title": "Todo", + "tags": [], + "description": "", + "content": " An interactive todo list.\nSource Code wtf/todo/ 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.\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:grayhighlight:fore:\u0026#34;black\u0026#34;back:\u0026#34;orange\u0026#34;enabled:truefilename:\u0026#34;todo.yml\u0026#34;position:top:2left:2height:2width:1refreshInterval: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": "https://wtfutil.com/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:trueposition:top:0left:2height:1width:1projects:-122247497refreshInterval: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": "https://wtfutil.com/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 Key: [return] Action: Open the selected build in the browser.\nKey: j Action: Select the next build in the list.\nKey: k Action: Select the previous build in the list.\nKey: r Action: Refresh the data.\nKey: ↓ Action: Select the next build in the list.\nKey: ↑ Action: Select the previous build in the list.\nConfiguration travisci:apiKey:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;enabled:trueposition:top:4left:1height:1width:2pro:falserefreshInterval: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. pro Determines whether or not this module will use the Pro version of Travis CI.\nValues: true, false.\nrefreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n.\n" +}, +{ + "uri": "https://wtfutil.com/modules/trello/", + "title": "Trello", + "tags": [], + "description": "", + "content": " Displays all Trello cards on specified lists.\nSource Code wtf/trello/ Configuration Single Trello List trello:accessToken:\u0026#34;7b8b14f8743a408a93276d7155dd9ee2\u0026#34;apiKey:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;board:Mainenabled:truelist:\u0026#34;Todo\u0026#34;position:height:1left:2top:0width:1refreshInterval:3600username: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:Mainenabled:truelist:[\u0026#34;Todo\u0026#34;,\u0026#34;Done\u0026#34;]position:height:1left:2top:0width:1refreshInterval:3600username: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": "https://wtfutil.com/modules/twitter/", + "title": "Twitter", + "tags": [], + "description": "", + "content": " Added in v0.2.0.\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/ Configuration twitter:bearerToken:\u0026#34;3276d7155dd9ee27b8b14f8743a408a9\u0026#34;enabled:trueposition:top:0left:1height:1width:1refreshInterval: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": "https://wtfutil.com/modules/weather_services/", + "title": "Weather Services", + "tags": [], + "description": "", + "content": "For all modules weather-related.\n Pretty Weather Weather " +}, +{ + "uri": "https://wtfutil.com/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:trueposition:top:0left:2height:1width:1status:\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": "https://wtfutil.com/", + "title": "WTF", + "tags": [], + "description": "", + "content": "WTF 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 systems, services, and important information that you otherwise might keep browser tabs open for, the kinds of things you don\u0026rsquo;t always need visible, but do check in on every now and then.\nKeep an eye on your OpsGenie schedules, Google Calendar, Git and GitHub repositories, and New Relic deployments.\nSee who\u0026rsquo;s away in BambooHR, which Jira tickets are assigned to you, and what time it is in Barcelona.\nIt even has weather. And clocks. And emoji.\n" +}, +{ + "uri": "https://wtfutil.com/getting_started/installation/", + "title": "Installation", + "tags": [], + "description": "", + "content": " As 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.\nFrom Source Download the source code repo and install the dependencies:\ngo get -u github.com/senorprogrammer/wtf cd $GOPATH/src/github.com/senorprogrammer/wtf go install -ldflags=\u0026#34;-s -w\u0026#34; make run and that should do it.\n" +}, +{ + "uri": "https://wtfutil.com/getting_started/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": "https://wtfutil.com/_footer/", + "title": "", + "tags": [], + "description": "", + "content": "" +}, +{ + "uri": "https://wtfutil.com/categories/", + "title": "Categories", + "tags": [], + "description": "", + "content": "" +}, +{ + "uri": "https://wtfutil.com/tags/", + "title": "Tags", + "tags": [], + "description": "", + "content": "" +}] \ No newline at end of file diff --git a/docs/index.xml b/docs/index.xml index 4bcd1598..cbdbe48e 100644 --- a/docs/index.xml +++ b/docs/index.xml @@ -1,119 +1,220 @@ - WTF - A Terminal Dashboard + WTF on WTF - the terminal dashboard https://wtfutil.com/ - Recent content on WTF - A Terminal Dashboard + Recent content in WTF on WTF - the terminal dashboard Hugo -- gohugo.io en-us - Thu, 02 Aug 2018 16:36:08 -0400 + Tue, 14 Aug 2018 01:51:58 -0700 - Hacker News - https://wtfutil.com/posts/modules/hackernews/ - Thu, 02 Aug 2018 16:36:08 -0400 + Bittrex + https://wtfutil.com/modules/cryptocurrencies/bittrex/ + Mon, 04 Jun 2018 20:06:40 -0700 - https://wtfutil.com/posts/modules/hackernews/ - Added in v0.1.2. -Displays stories from Hacker News. -Source Code wtf/hackernews/ Keyboard Commands Key: [return] Action: Open the selected story in the browser. -Key: j Action: Select the next story in the list. -Key: k Action: Select the previous story in the list. -Key: r Action: Refresh the data. -Key: ↓ Action: Select the next story in the list. -Key: ↑ Action: Select the previous story in the list. + https://wtfutil.com/modules/cryptocurrencies/bittrex/ + Added in v0.0.5. +Get the last 24 hour summary of cryptocurrencies market using Bittrex. +Source Code wtf/cryptoexchanges/bittrex/ Configuration bittrex:enabled:trueposition:top:1left:2height:3width:1refreshInterval:5summary:BTC:displayName:Bitcoinmarket:-LTC-ETHcolors:base:name:orangedisplayName:redmarket:name:redfield:whitevalue:green Attributes colors.base.name Values: Any X11 color name. +colors.base.dispayName Values: Any X11 color name. +colors.market.name Values: Any X11 color name. +colors.market.field Values: Any X11 color name. +colors.market.value Values: Any X11 color name. +summary enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. - Gitter - https://wtfutil.com/posts/modules/gitter/ - Thu, 02 Aug 2018 12:36:08 -0400 + Attributes + https://wtfutil.com/configuration/attributes/ + Wed, 16 May 2018 21:51:23 -0700 - https://wtfutil.com/posts/modules/gitter/ - Added in v0.2.1. -Displays chat messages from Gitter. -Source Code wtf/gitter/ Keyboard Commands Key: j Action: Select the next message in the list. -Key: k Action: Select the previous message in the list. -Key: r Action: Refresh the data. -Key: ↓ Action: Select the next message in the list. -Key: ↑ Action: Select the previous message in the list. -Configuration gitter:apiToken:"ab345546asdfasb465234fgjgh068f39a35c3e4139ee383f7"enabled:truenumberOfMessages:10position:top:4left:1height:1width:4roomUri:wtfutil/LobbyrefreshInterval:300 Attributes apiToken Value: Your GitterPersonal Access Token. + https://wtfutil.com/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 widecolumns:[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 fourrows:[10,10,10,10,10,3,4]openFileUtil:open# the name of the utility to call to open filesrefreshInterval:1# the app refreshes once per secondterm:"xterm-256color" Attributes colors. + + + + Blockfolio + https://wtfutil.com/modules/cryptocurrencies/blockfolio/ + Wed, 13 Jun 2018 09:29:59 -0700 + + https://wtfutil.com/modules/cryptocurrencies/blockfolio/ + Added in v0.0.8. +Display your Blockfolio crypto holdings. +Source wtf/blockfolio/ Configuration blockfolio:colors:name:bluegrows:greendrop:reddevice_token:"device token"displayHoldings:trueenabled:trueposition:top:3left:1width:1height:1refreshInterval: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. +displayHoldings 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. + + + + IP-API + https://wtfutil.com/modules/ipaddress/ipapi/ + Sun, 10 Jun 2018 19:41:52 -0400 + + https://wtfutil.com/modules/ipaddress/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/ Configuration ipinfo:colors:name:redvalue:whiteenabled:trueposition:top:1left:2height:1width:1refreshInterval: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. Values: Any X11 color name. enabled Determines whether or not this module is executed and if its data displayed onscreen. - Twitter - https://wtfutil.com/posts/modules/twitter/ - Tue, 31 Jul 2018 20:21:37 -0700 + Pretty Weather + https://wtfutil.com/modules/weather_services/prettyweather/ + Sat, 02 Jun 2018 05:32:04 -0700 - https://wtfutil.com/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:trueposition:top:0left:1height:1width:1refreshInterval: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. + https://wtfutil.com/modules/weather_services/prettyweather/ + Displays weather information as ASCII art from Wttr.in. +Source Code wtf/prettyweather/ Configuration prettyweather:enabled:truecity:"tehran"position:top:3left:5height:1width:1refreshInterval:300unit:"c"view:0language:"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. Values: true, false. position Defines where in the grid this module’s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. - Zendesk - https://wtfutil.com/posts/modules/zendesk/ - Mon, 23 Jul 2018 18:55:37 -0800 + iTerm2 + https://wtfutil.com/configuration/iterm2/ + Thu, 24 May 2018 09:57:40 -0700 - https://wtfutil.com/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:trueposition:top:0left:2height:1width:1status:"new"subdomain:"your_domain"username:"your_email@acme.com" Attributes apiKey Value: Your Zendesk API token. + https://wtfutil.com/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. - TravisCI - https://wtfutil.com/posts/modules/travisci/ - Wed, 18 Jul 2018 14:36:08 -0400 + Google Calendar + https://wtfutil.com/modules/google/gcal/ + Thu, 10 May 2018 08:25:33 -0700 - https://wtfutil.com/posts/modules/travisci/ - Added in v0.0.12. -Displays build information for your Travis CI account. -Source Code wtf/travisci/ Keyboard Commands Key: [return] Action: Open the selected build in the browser. -Key: j Action: Select the next build in the list. -Key: k Action: Select the previous build in the list. -Key: r Action: Refresh the data. -Key: ↓ Action: Select the next build in the list. -Key: ↑ Action: Select the previous build in the list. + https://wtfutil.com/modules/google/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/ 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:trueemail:"chriscummer@me.com"enabled:trueeventCount:12multiCalendar:trueposition:top:0left:0height:4width:1refreshInterval:300secretFile:"~/.config/wtf/gcal/client_secret.json"showDeclined:truewithLocation:true Attributes colors.title The default colour for calendar event titles. Values: Any X11 color name. +colors.description The default color for calendar event descriptions. - Todoist - https://wtfutil.com/posts/modules/todoist/ - Thu, 05 Jul 2018 22:55:55 -0300 + BambooHR + https://wtfutil.com/modules/bamboohr/ + Mon, 07 May 2018 20:17:37 -0700 - https://wtfutil.com/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. + https://wtfutil.com/modules/bamboohr/ + Connects to the BambooHR API and displays who will be Away today. +Source Code wtf/bamboohr/ Configuration bamboohr:apiKey:"3276d7155dd9ee27b8b14f8743a408a9"enabled:trueposition:top:0left:1height:2width:1refreshInterval:900subdomain:"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. refreshInterval How often, in seconds, this module will update its data. Values: Any positive integer, 0..n. + + + + CryptoLive + https://wtfutil.com/modules/cryptocurrencies/cryptolive/ + Sun, 03 Jun 2018 20:06:40 -0700 + + https://wtfutil.com/modules/cryptocurrencies/cryptolive/ + Added in v0.0.5. +Compare crypto currencies using CryptoCompare. +Source Code wtf/cryptoexchanges/cryptolive/ Configuration cryptolive:enabled:trueposition:top:5left:2height:1width:2updateInterval:15currencies:BTC:displayName:Bitcointo:-USD-EUR-ETH-LTC-DOGELTC:displayName:Ethereumto:-USD-EUR-BTCtop:BTC:displayName:Bitcoinlimit:5to:-USDcolors:from:name:coraldisplayName:greyto:name:whiteprice:greentop:from:name:greydisplayName:coralto:name:redfield:whitevalue:green Attributes colors.from.name Values: Any X11 color name. +colors.from.dispayName Values: Any X11 color name. +colors.to.name Values: Any X11 color name. +colors.to.price Values: Any X11 color name. +currencies 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. refreshInterval How often, in seconds, this module will update its data. + + + + CircleCI + https://wtfutil.com/modules/circleci/ + Sun, 10 Jun 2018 19:26:08 -0400 + + https://wtfutil.com/modules/circleci/ + Added in v0.0.7. +Displays build information for your CircleCI account. +Source Code wtf/circleci/ Configuration circleci:apiKey:"3276d7155dd9ee27b8b14f8743a408a9"enabled:trueposition:top:4left:1height:1width:2refreshInterval: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. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0..n. + + + + IPInfo + https://wtfutil.com/modules/ipaddress/ipinfo/ + Fri, 01 Jun 2018 23:18:48 -0700 + + https://wtfutil.com/modules/ipaddress/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/ Configuration ipinfo:colors:name:redvalue:whiteenabled:trueposition:top:1left:2height:1width:1refreshInterval: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. Values: Any X11 color name. +enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. + + + + Weather + https://wtfutil.com/modules/weather_services/weather/ + Wed, 09 May 2018 11:44:13 -0700 + + https://wtfutil.com/modules/weather_services/weather/ + Displays a configurable list of current weather report, including current temperature, sunrise time, and sunset time. +Source Code wtf/weather/ 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. +Key: → Action: Show the next weather location. +Configuration weather:apiKey:"2dfb3e3650a1950adddb6badf5ba1aaa"# From http://openweathermap.org/help/city_list.txtcityids:-6173331-3128760-6167865-6176823colors:current:"lightblue"enabled:truelanguage:"EN"position:top:0left:2height:1width:1refreshInterval:900tempUnit:"C" Attributes apiKey Your OpenWeatherMap API key. + + + + Clocks + https://wtfutil.com/modules/clocks/ + Mon, 07 May 2018 19:47:31 -0700 + + https://wtfutil.com/modules/clocks/ + Displays a configurable list of world clocks, the local time, and date. +Source Code wtf/clocks/ Configuration clocks:colors:rows:even:"lightblue"odd:"white"enabled:truelocations:# From https://en.wikipedia.org/wiki/List_of_tz_database_time_zonesAvignon:"Europe/Paris"Barcelona:"Europe/Madrid"Dubai:"Asia/Dubai"NewYork:"America/New York"Toronto:"America/Toronto"UTC:"Etc/UTC"Vancouver:"America/Vancouver"position:top:4left:0height:1width:1refreshInterval:15# Valid options are: alphabetical, chronologicalsort:"alphabetical" Attributes colors.rows.even The foreground color for even-numbered rows. Values: Any X11 color name. +colors.rows.odd The foreground color for the odd-numbered rows. Values: Any X11 color name. +enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. + + + + CmdRunner + https://wtfutil.com/modules/cmdrunner/ + Thu, 17 May 2018 17:17:10 -0700 + + https://wtfutil.com/modules/cmdrunner/ + Runs a terminal command on a schedule. +Source Code wtf/cmdrunner/ Configuration cmdrunner:args:["-g","batt"]cmd:"pmset"enabled:trueposition:top:6left:1height:1width:3refreshInterval: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. Ie: ping, whoami, curl. enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. + + + + Google Spreadsheets + https://wtfutil.com/modules/google/gspreadsheet/ + Sun, 10 Jun 2018 18:26:26 -0400 + + https://wtfutil.com/modules/google/gspreadsheet/ + Added in v0.0.7. +Display information from cells in a Google Spreadsheet. +wtf/gspreadsheets/ Configuration gspreadsheets:colors:values:"green"cells:names:-"Cell 1 name"-"Cell 2 name"addresses:-"A1"-"A2"enabled:trueposition:top:0left:0width:1height:1refreshInterval:"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. +cells.names cells.addresses enabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false. +position Where in the grid this module’s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Gerrit - https://wtfutil.com/posts/modules/gerrit/ + https://wtfutil.com/modules/gerrit/ Wed, 27 Jun 2018 15:55:42 -0700 - https://wtfutil.com/posts/modules/gerrit/ + https://wtfutil.com/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. @@ -125,101 +226,41 @@ Key: k Action: Select the previous review in the list. - Logger - https://wtfutil.com/posts/modules/logger/ - Sat, 16 Jun 2018 14:22:18 -0700 + Git + https://wtfutil.com/modules/git/ + Wed, 09 May 2018 14:20:48 -0700 - https://wtfutil.com/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:trueposition:top:5left:4height:2width:1refreshInterval:1 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Note: If you’re using logging and logging is disabled, your logs will still be written to file, the widget just won’t be shown onscreen. + https://wtfutil.com/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/ Keyboard Commands Key: / Action: Open/close the widget’s help window. +Key: h Action: Show the previous git repository. - Blockfolio - https://wtfutil.com/posts/modules/cryptocurrencies/blockfolio/ - Wed, 13 Jun 2018 09:29:59 -0700 + GitHub + https://wtfutil.com/modules/github/ + Wed, 09 May 2018 19:20:20 -0700 - https://wtfutil.com/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:bluegrows:greendrop:reddevice_token:"device token"displayHoldings:trueenabled:trueposition:top:3left:1width:1height:1refreshInterval: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. -displayHoldings enabled Determines whether or not this module is executed and if its data displayed onscreen. - - - - IP-API - https://wtfutil.com/posts/modules/ipapi/ - Sun, 10 Jun 2018 19:41:52 -0400 - - https://wtfutil.com/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:redvalue:whiteenabled:trueposition:top:1left:2height:1width:1refreshInterval: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. Values: Any X11 color name. -enabled Determines whether or not this module is executed and if its data displayed onscreen. - - - - CircleCI - https://wtfutil.com/posts/modules/circleci/ - Sun, 10 Jun 2018 19:26:08 -0400 - - https://wtfutil.com/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:trueposition:top:4left:1height:1width:2refreshInterval: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. refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0. - - - - Google Spreadsheets - https://wtfutil.com/posts/modules/gspreadsheet/ - Sun, 10 Jun 2018 18:26:26 -0400 - - https://wtfutil.com/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:trueposition:top:0left:0width:1height:1refreshInterval:"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. -cells.names cells.addresses enabled Whether or not this module is executed and if its data displayed onscreen. Values: true, false. -position Where in the grid this module’s widget will be displayed. - - - - Modules: Jenkins - https://wtfutil.com/posts/modules/jenkins/ - Sat, 09 Jun 2018 20:53:35 -0700 - - https://wtfutil.com/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:trueposition:top:2left:3height:2width:3refreshInterval:300url:"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. -refreshInterval How often, in seconds, this module will update its data. + https://wtfutil.com/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. GitLab - https://wtfutil.com/posts/modules/gitlab/ + https://wtfutil.com/modules/gitlab/ Fri, 08 Jun 2018 13:14:11 -0700 - https://wtfutil.com/posts/modules/gitlab/ + https://wtfutil.com/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. @@ -232,165 +273,58 @@ Key: → Action: Show the next project. - Bittrex - https://wtfutil.com/posts/modules/cryptocurrencies/bittrex/ - Mon, 04 Jun 2018 20:06:40 -0700 + Gitter + https://wtfutil.com/modules/gitter/ + Thu, 02 Aug 2018 12:36:08 -0400 - https://wtfutil.com/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:trueposition:top:1left:2height:3width:1refreshInterval:5summary:BTC:displayName:Bitcoinmarket:-LTC-ETHcolors:base:name:orangedisplayName:redmarket:name:redfield:whitevalue:green Attributes colors.base.name Values: Any X11 color name. -colors.base.dispayName Values: Any X11 color name. -colors.market.name Values: Any X11 color name. -colors.market.field Values: Any X11 color name. -colors.market.value Values: Any X11 color name. -summary enabled Determines whether or not this module is executed and if its data displayed onscreen. - - - - CryptoLive - https://wtfutil.com/posts/modules/cryptocurrencies/cryptolive/ - Sun, 03 Jun 2018 20:06:40 -0700 - - https://wtfutil.com/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:trueposition:top:5left:2height:1width:2updateInterval:15currencies:BTC:displayName:Bitcointo:-USD-EUR-ETH-LTC-DOGELTC:displayName:Ethereumto:-USD-EUR-BTCtop:BTC:displayName:Bitcoinlimit:5to:-USDcolors:from:name:coraldisplayName:greyto:name:whiteprice:greentop:from:name:greydisplayName:coralto:name:redfield:whitevalue:green Attributes colors.from.name Values: Any X11 color name. -colors.from.dispayName Values: Any X11 color name. -colors.to.name Values: Any X11 color name. -colors.to.price Values: Any X11 color name. -currencies 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. - - - - Pretty Weather - https://wtfutil.com/posts/modules/prettyweather/ - Sat, 02 Jun 2018 05:32:04 -0700 - - https://wtfutil.com/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:truecity:"tehran"position:top:3left:5height:1width:1refreshInterval:300unit:"c"view:0language:"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. Values: true, false. -position Defines where in the grid this module’s widget will be displayed. - - - - IPInfo - https://wtfutil.com/posts/modules/ipinfo/ - Fri, 01 Jun 2018 23:18:48 -0700 - - https://wtfutil.com/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:redvalue:whiteenabled:trueposition:top:1left:2height:1width:1refreshInterval: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. Values: Any X11 color name. + https://wtfutil.com/modules/gitter/ + Added in v0.2.1. +Displays chat messages from Gitter. +Source Code wtf/gitter/ Keyboard Commands Key: j Action: Select the next message in the list. +Key: k Action: Select the previous message in the list. +Key: r Action: Refresh the data. +Key: ↓ Action: Select the next message in the list. +Key: ↑ Action: Select the previous message in the list. +Configuration gitter:apiToken:"ab345546asdfasb465234fgjgh068f39a35c3e4139ee383f7"enabled:truenumberOfMessages:10position:top:4left:1height:1width:4roomUri:wtfutil/LobbyrefreshInterval:300 Attributes apiToken Value: Your GitterPersonal Access Token. enabled Determines whether or not this module is executed and if its data displayed onscreen. - Power - https://wtfutil.com/posts/modules/power/ - Sat, 26 May 2018 19:26:23 -0700 + Hacker News + https://wtfutil.com/modules/hackernews/ + Thu, 02 Aug 2018 16:36:08 -0400 - https://wtfutil.com/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:trueposition:top:5left:0height:2width:1refreshInterval: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. refreshInterval How often, in seconds, this module will update its data. + https://wtfutil.com/modules/hackernews/ + Added in v0.1.2. +Displays stories from Hacker News. +Source Code wtf/hackernews/ Keyboard Commands Key: [return] Action: Open the selected story in the browser. +Key: j Action: Select the next story in the list. +Key: k Action: Select the previous story in the list. +Key: r Action: Refresh the data. +Key: ↓ Action: Select the next story in the list. +Key: ↑ Action: Select the previous story in the list. - Configuration: iTerm2 - https://wtfutil.com/posts/configuration/iterm2/ - Thu, 24 May 2018 09:57:40 -0700 + Jenkins + https://wtfutil.com/modules/jenkins/ + Sat, 09 Jun 2018 20:53:35 -0700 - https://wtfutil.com/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 - https://wtfutil.com/posts/overview/ - Mon, 21 May 2018 16:11:58 -0700 - - https://wtfutil.com/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 - https://wtfutil.com/posts/installation/ - Fri, 18 May 2018 09:59:40 -0700 - - https://wtfutil.com/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 - https://wtfutil.com/posts/modules/cmdrunner/ - Thu, 17 May 2018 17:17:10 -0700 - - https://wtfutil.com/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:trueposition:top:6left:1height:1width:3refreshInterval: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. Ie: ping, whoami, curl. enabled Determines whether or not this module is executed and if its data displayed onscreen. - - - - Configuration: Attributes - https://wtfutil.com/posts/configuration/attributes/ - Wed, 16 May 2018 21:51:23 -0700 - - https://wtfutil.com/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 widecolumns:[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 fourrows:[10,10,10,10,10,3,4]# The app redraws itself once a secondopenFileUtil:openrefreshInterval:1term:"xterm-256color" Attributes colors. - - - - Todo - https://wtfutil.com/posts/modules/todo/ - Thu, 10 May 2018 12:41:50 -0700 - - https://wtfutil.com/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. + https://wtfutil.com/modules/jenkins/ + Added in v0.0.8. +Displays jenkins status of given builds in a project or view +Source Code wtf/jenkins/ Configuration jenkins:apiKey:"3276d7155dd9ee27b8b14f8743a408a9"enabled:trueposition:top:2left:3height:2width:3refreshInterval:300url:"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. +refreshInterval How often, in seconds, this module will update its data. Values: A positive integer, 0. Jira - https://wtfutil.com/posts/modules/jira/ + https://wtfutil.com/modules/jira/ Thu, 10 May 2018 10:44:35 -0700 - https://wtfutil.com/posts/modules/jira/ + https://wtfutil.com/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. @@ -401,172 +335,186 @@ Configuration Single Jira Project jira:apiKey:"3276d7155dd9ee27b8b14f874 - Trello - https://wtfutil.com/posts/modules/trello/ - Thu, 10 May 2018 10:44:35 -0700 + Logger + https://wtfutil.com/modules/logger/ + Sat, 16 Jun 2018 14:22:18 -0700 - https://wtfutil.com/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:Mainenabled:truelist:"Todo"position:height:1left:2top:0width:1refreshInterval:3600username: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:Mainenabled:truelist:["Todo","Done"]position:height:1left:2top:0width:1refreshInterval:3600username:myname Attributes accessToken Value: Your Trello access token. -apiKey Value: Your Trello API key. -board The name of the Trello board. enabled Determines whether or not this module is executed and if its data displayed onscreen. - - - - Google Calendar - https://wtfutil.com/posts/modules/gcal/ - Thu, 10 May 2018 08:25:33 -0700 - - https://wtfutil.com/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:trueemail:"chriscummer@me.com"enabled:trueeventCount:12multiCalendar:trueposition:top:0left:0height:4width:1refreshInterval:300secretFile:"~/.config/wtf/gcal/client_secret.json"showDeclined:truewithLocation:true Attributes colors.title The default colour for calendar event titles. Values: Any X11 color name. - - - - GitHub - https://wtfutil.com/posts/modules/github/ - Wed, 09 May 2018 19:20:20 -0700 - - https://wtfutil.com/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 - https://wtfutil.com/posts/modules/git/ - Wed, 09 May 2018 14:20:48 -0700 - - https://wtfutil.com/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 - https://wtfutil.com/posts/modules/weather/ - Wed, 09 May 2018 11:44:13 -0700 - - https://wtfutil.com/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 - https://wtfutil.com/posts/modules/textfile/ - Wed, 09 May 2018 11:13:11 -0700 - - https://wtfutil.com/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:truefilePath:"~/Desktop/notes.md"position:top:5left:4height:2width:1refreshInterval:15 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. -filePath The path to the file to be displayed in the widget. + https://wtfutil.com/modules/logger/ + Displays the contents of the WTF log file. The log file is located at ~/.config/wtf/log.txt. +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/ Keyboard Commands Arrow keys scroll through the log file. +Configuration logger:enabled:trueposition:top:5left:4height:2width:1refreshInterval:1 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Note: If you’re using logging and logging is disabled, your logs will still be written to file, the widget just won’t be shown onscreen. New Relic - https://wtfutil.com/posts/modules/newrelic/ + https://wtfutil.com/modules/newrelic/ Wed, 09 May 2018 09:01:14 -0700 - https://wtfutil.com/posts/modules/newrelic/ + https://wtfutil.com/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:10549735deployCount:6enabled:trueposition:top:4left:3height:1width:2refreshInterval:900 Attributes apiKey Value: Your New Relic API token. +Source Code wtf/newrelic/ Configuration newrelic:apiKey:"3276d7155dd9ee27b8b14f8743a408a9"applicationId:10549735deployCount:6enabled:trueposition:top:4left:3height:1width:2refreshInterval:900 Attributes apiKey Value: Your New Relic API token. applicationId The integer ID of the New Relic application you wish to report on. Values: A positive integer, 0..n. deployCount The number of past deploys to display on screen. Values: A positive integer, 0. OpsGenie - https://wtfutil.com/posts/modules/opsgenie/ + https://wtfutil.com/modules/opsgenie/ Tue, 08 May 2018 20:53:40 -0700 - https://wtfutil.com/posts/modules/opsgenie/ + https://wtfutil.com/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:falseenabled:trueposition:top:2left:1height:2width:1refreshInterval:21600 Attributes apiKey < br /> Value: Your OpsGenie API token. +Source Code wtf/opsgenie/ Configuration opsgenie:apiKey:"3276d7155dd9ee27b8b14f8743a408a9"displayEmpty:falseenabled:trueposition:top:2left:1height:2width:1refreshInterval: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. Values: true, false. position Where in the grid this module’s widget will be displayed. + + Power + https://wtfutil.com/modules/power/ + Sat, 26 May 2018 19:26:23 -0700 + + https://wtfutil.com/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/ Configuration power:enabled:trueposition:top:5left:0height:2width:1refreshInterval: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. refreshInterval How often, in seconds, this module will update its data. + + Security - https://wtfutil.com/posts/modules/security/ + https://wtfutil.com/modules/security/ Tue, 08 May 2018 20:33:28 -0700 - https://wtfutil.com/posts/modules/security/ + https://wtfutil.com/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 - https://wtfutil.com/posts/modules/bamboohr/ - Mon, 07 May 2018 20:17:37 -0700 + Textfile + https://wtfutil.com/modules/textfile/ + Wed, 09 May 2018 11:13:11 -0700 - https://wtfutil.com/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:trueposition:top:0left:1height:2width:1refreshInterval:900subdomain:"testco" Attributes apiKey Value: Your BambooHR API token. + https://wtfutil.com/modules/textfile/ + Displays the contents of the specified text file in the widget. +Source Code wtf/textfile/ 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:truefilePath:"~/Desktop/notes.md"position:top:5left:4height:2width:1refreshInterval:15 Attributes enabled Determines whether or not this module is executed and if its data displayed onscreen. Values: true, false. +filePath The path to the file to be displayed in the widget. + + + + Todo + https://wtfutil.com/modules/todo/ + Thu, 10 May 2018 12:41:50 -0700 + + https://wtfutil.com/modules/todo/ + An interactive todo list. +Source Code wtf/todo/ 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. +Key: k Action: Select the previous item in the list. + + + + Todoist + https://wtfutil.com/modules/todoist/ + Thu, 05 Jul 2018 22:55:55 -0300 + + https://wtfutil.com/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. + + + + TravisCI + https://wtfutil.com/modules/travisci/ + Wed, 18 Jul 2018 14:36:08 -0400 + + https://wtfutil.com/modules/travisci/ + Added in v0.0.12. +Displays build information for your Travis CI account. +Source Code wtf/travisci/ Keyboard Commands Key: [return] Action: Open the selected build in the browser. +Key: j Action: Select the next build in the list. +Key: k Action: Select the previous build in the list. +Key: r Action: Refresh the data. +Key: ↓ Action: Select the next build in the list. +Key: ↑ Action: Select the previous build in the list. + + + + Trello + https://wtfutil.com/modules/trello/ + Thu, 10 May 2018 10:44:35 -0700 + + https://wtfutil.com/modules/trello/ + Displays all Trello cards on specified lists. +Source Code wtf/trello/ Configuration Single Trello List trello:accessToken:"7b8b14f8743a408a93276d7155dd9ee2"apiKey:"3276d7155dd9ee27b8b14f8743a408a9"board:Mainenabled:truelist:"Todo"position:height:1left:2top:0width:1refreshInterval:3600username: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:Mainenabled:truelist:["Todo","Done"]position:height:1left:2top:0width:1refreshInterval:3600username:myname Attributes accessToken Value: Your Trello access token. +apiKey Value: Your Trello API key. +board The name of the Trello board. enabled Determines whether or not this module is executed and if its data displayed onscreen. + + + + Twitter + https://wtfutil.com/modules/twitter/ + Tue, 31 Jul 2018 20:21:37 -0700 + + https://wtfutil.com/modules/twitter/ + Added in v0.2.0. +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/ Configuration twitter:bearerToken:"3276d7155dd9ee27b8b14f8743a408a9"enabled:trueposition:top:0left:1height:1width:1refreshInterval: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. -position Defines where in the grid this module’s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. Values: Any positive integer, 0. +position Defines where in the grid this module’s widget will be displayed. refreshInterval How often, in seconds, this module will update its data. - Clocks - https://wtfutil.com/posts/modules/clocks/ - Mon, 07 May 2018 19:47:31 -0700 + Zendesk + https://wtfutil.com/modules/zendesk/ + Mon, 23 Jul 2018 18:55:37 -0800 - https://wtfutil.com/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:truelocations:# From https://en.wikipedia.org/wiki/List_of_tz_database_time_zonesAvignon:"Europe/Paris"Barcelona:"Europe/Madrid"Dubai:"Asia/Dubai"NewYork:"America/New York"Toronto:"America/Toronto"UTC:"Etc/UTC"Vancouver:"America/Vancouver"position:top:4left:0height:1width:1refreshInterval:15# Valid options are: alphabetical, chronologicalsort:"alphabetical" Attributes colors.rows.even The foreground color for even-numbered rows. Values: Any X11 color name. -colors.rows.odd The foreground color for the odd-numbered rows. Values: Any X11 color name. -enabled Determines whether or not this module is executed and if its data displayed onscreen. + https://wtfutil.com/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:trueposition:top:0left:2height:1width:1status:"new"subdomain:"your_domain"username:"your_email@acme.com" Attributes apiKey Value: Your Zendesk API token. - Modules - https://wtfutil.com/posts/modules/ - Mon, 07 May 2018 18:04:58 -0700 + Installation + https://wtfutil.com/getting_started/installation/ + Fri, 18 May 2018 09:59:40 -0700 - https://wtfutil.com/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. + https://wtfutil.com/getting_started/installation/ + 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. +From Source Download the source code repo and install the dependencies: +go get -u github.com/senorprogrammer/wtf cd $GOPATH/src/github.com/senorprogrammer/wtf go install -ldflags="-s -w" make run and that should do it. Glossary - https://wtfutil.com/posts/glossary/ + https://wtfutil.com/getting_started/glossary/ Tue, 17 Apr 2018 12:34:51 -0700 - https://wtfutil.com/posts/glossary/ + https://wtfutil.com/getting_started/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. @@ -574,14 +522,12 @@ Widgets are defined by a required widget.go file in a Module. - Configuration - https://wtfutil.com/posts/configuration/ - Sun, 15 Apr 2018 21:17:16 -0700 + + https://wtfutil.com/_footer/ + Mon, 01 Jan 0001 00:00:00 +0000 - https://wtfutil.com/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. + https://wtfutil.com/_footer/ + diff --git a/docs/js/auto-complete.js b/docs/js/auto-complete.js new file mode 100644 index 00000000..7fbde995 --- /dev/null +++ b/docs/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/docs/js/featherlight.min.js b/docs/js/featherlight.min.js new file mode 100644 index 00000000..63590819 --- /dev/null +++ b/docs/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 `