diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..7cd4f86
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,3 @@
+
+src/fonts/
+*rrschattdorf*
\ No newline at end of file
diff --git a/audio/AirHorn.mp3 b/audio/AirHorn.mp3
new file mode 100644
index 0000000..40b6e2b
Binary files /dev/null and b/audio/AirHorn.mp3 differ
diff --git a/audio/AirHornShip.mp3 b/audio/AirHornShip.mp3
new file mode 100644
index 0000000..1af0fbd
Binary files /dev/null and b/audio/AirHornShip.mp3 differ
diff --git a/audio/Buzz.mp3 b/audio/Buzz.mp3
new file mode 100644
index 0000000..08708f6
Binary files /dev/null and b/audio/Buzz.mp3 differ
diff --git a/audio/DoorBuzzer.mp3 b/audio/DoorBuzzer.mp3
new file mode 100644
index 0000000..704f59f
Binary files /dev/null and b/audio/DoorBuzzer.mp3 differ
diff --git a/audio/IndustrialAlarm.mp3 b/audio/IndustrialAlarm.mp3
new file mode 100644
index 0000000..067536a
Binary files /dev/null and b/audio/IndustrialAlarm.mp3 differ
diff --git a/example/beispielkampf.json b/example/beispielkampf.json
new file mode 100644
index 0000000..ebd66da
--- /dev/null
+++ b/example/beispielkampf.json
@@ -0,0 +1,129 @@
+{
+ "keymap": {
+ "toggle": "space",
+ "next": "z",
+ "prev": "t",
+ "reset": "y",
+ "incrRedWres": "f",
+ "decrRedWres": "d",
+ "incrRedTeam": "v",
+ "decrRedTeam": "c",
+ "incrBluWres": "j",
+ "decrBluWres": "k",
+ "incrBluTeam": "n",
+ "decrBluTeam": "m",
+ "activeRed": "e",
+ "activeBlu": "i",
+ "incrWarnRed": "w",
+ "decrWarnRed": "q",
+ "incrWarnBlu": "o",
+ "decrWarnBlu": "p",
+ "openMatchConfig": ",",
+ "toggleOverview": "1"
+ },
+ "fights": [{
+ "red": "Eduardo Enz",
+ "blu": "Newton Nordby",
+ "weight": "57",
+ "greco": false
+ }, {
+ "red": "Franklin Fredricks",
+ "blu": "Dario Dorsey",
+ "weight": "61",
+ "greco": true
+ }, {
+ "red": "Victor Valerius",
+ "blu": "Danny Dorr",
+ "weight": "65",
+ "greco": false
+ }, {
+ "red": "Fabian Freyberg",
+ "blu": "Jean-Jacques Joux",
+ "weight": "70",
+ "greco": true
+ }, {
+ "red": "Boris Blocker",
+ "blu": "David Demarus",
+ "weight": "74",
+ "greco": false
+ }, {
+ "red": "Claude Coble",
+ "blu": "Leon Lagrange",
+ "weight": "74",
+ "greco": true
+ }, {
+ "red": "Cornell Corsio",
+ "blu": "Beni Broderick",
+ "weight": "80",
+ "greco": false
+ }, {
+ "red": "Ramon Risch",
+ "blu": "Anton Augsberg",
+ "weight": "86",
+ "greco": true
+ }, {
+ "red": "Elias Eicher",
+ "blu": "Frankie Fagan",
+ "weight": "97",
+ "greco": false
+ }, {
+ "red": "Rolf Röthlisberger",
+ "blu": "Herbert Hayek",
+ "weight": "130",
+ "greco": true
+ }],
+ "match": {
+ "red": "RR Beispiel",
+ "blu": "RC Gegner",
+ "showWeigth": true,
+ "lastPeriod": 2,
+ "buzzer": "Buzz",
+ "mmSet": true,
+ "showTeams": true,
+ "sponsors": {
+ "directoryLight": "sponsoren/light/",
+ "directoryDark": "sponsoren/dark/",
+ "interval": 45,
+ "quantity": 8,
+ "show": true
+ },
+ "theme": false,
+ "wrestlersAboveTeams": true
+ },
+ "lang": {
+ "periodSuffix": ". Halbzeit",
+ "weightSuffix": " kg",
+ "greco": "Greco",
+ "nonGreco": "Freistil",
+ "grecoShort": "G",
+ "nonGrecoShort": "F",
+ "fullscreenOn": "Vollbild ein",
+ "fullscreenOff": "Vollbild aus"
+ },
+ "timer": {
+ "period": {
+ "name": "period",
+ "minutes": 3,
+ "seconds": 0,
+ "countdown": true,
+ "subsecond": 10,
+ "alwaysLeadZero": true
+ },
+ "pause": {
+ "name": "pause",
+ "minutes": 0,
+ "seconds": 30,
+ "countdown": true,
+ "subsecond": 0,
+ "alwaysLeadZero": false
+ },
+ "active": {
+ "name": "active",
+ "minutes": 0,
+ "seconds": 30,
+ "countdown": true,
+ "subsecond": 0,
+ "alwaysLeadZero": false
+ }
+ }
+}
diff --git a/index.html b/index.html
new file mode 100644
index 0000000..1dff481
--- /dev/null
+++ b/index.html
@@ -0,0 +1,354 @@
+
+
+
+
+
+ RRS scorebaord
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ |
+
+
+
+
+ |
+
+
+
+
+
+
+ |
+
+
+
+
+
+ |
+
+
+
+
+
+
+
+
+
+ |
+
+
+ |
+ |
+
+
+ |
+ |
+ |
+
+
+ |
+ |
+ |
+ |
+
+
+ |
+ |
+ |
+ |
+
+
+
+
+ |
+
+
+
+
+
+
+
+
+
+
+
+ |
+
+
+ |
+ |
+
+
+ |
+ |
+ |
+
+
+ |
+ |
+ |
+ |
+
+
+ |
+ |
+ |
+ |
+
+
+
+
+ |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
X
+
+
Kampfdauer
+
+
+
Ton
+
+
+
+
Optionen
+
+
+
Tastatur
+
+
+
+
+
+
+
+
+
Wettkampfliste
+
+ -
+
+
+ -
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Tastaturkürzel
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/sponsoren/dark/01.png b/sponsoren/dark/01.png
new file mode 100644
index 0000000..2904eb1
Binary files /dev/null and b/sponsoren/dark/01.png differ
diff --git a/sponsoren/dark/02.png b/sponsoren/dark/02.png
new file mode 100644
index 0000000..941f252
Binary files /dev/null and b/sponsoren/dark/02.png differ
diff --git a/sponsoren/dark/03.png b/sponsoren/dark/03.png
new file mode 100644
index 0000000..c734abd
Binary files /dev/null and b/sponsoren/dark/03.png differ
diff --git a/sponsoren/light/01.png b/sponsoren/light/01.png
new file mode 100644
index 0000000..250af44
Binary files /dev/null and b/sponsoren/light/01.png differ
diff --git a/sponsoren/light/02.png b/sponsoren/light/02.png
new file mode 100644
index 0000000..faa2932
Binary files /dev/null and b/sponsoren/light/02.png differ
diff --git a/sponsoren/light/03.png b/sponsoren/light/03.png
new file mode 100644
index 0000000..f65524d
Binary files /dev/null and b/sponsoren/light/03.png differ
diff --git a/src/css/dark.css b/src/css/dark.css
new file mode 100644
index 0000000..9f04946
--- /dev/null
+++ b/src/css/dark.css
@@ -0,0 +1,28 @@
+#board {
+ background-color: black;
+}
+
+.name {
+ color:white;
+}
+
+.time {
+ color: white;
+}
+
+.red .active, .blu .active {
+ color: white;
+}
+
+.config {
+ background-color: #333;
+}
+
+#overview {
+ background-color: black;
+ color:white;
+}
+
+#overview tr:nth-child(even) {
+ background-color: #333;
+}
diff --git a/src/css/normalize.css b/src/css/normalize.css
new file mode 100644
index 0000000..fa4e73d
--- /dev/null
+++ b/src/css/normalize.css
@@ -0,0 +1,447 @@
+/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */
+
+/* Document
+ ========================================================================== */
+
+/**
+ * 1. Correct the line height in all browsers.
+ * 2. Prevent adjustments of font size after orientation changes in
+ * IE on Windows Phone and in iOS.
+ */
+
+html {
+ line-height: 1.15; /* 1 */
+ -ms-text-size-adjust: 100%; /* 2 */
+ -webkit-text-size-adjust: 100%; /* 2 */
+}
+
+/* Sections
+ ========================================================================== */
+
+/**
+ * Remove the margin in all browsers (opinionated).
+ */
+
+body {
+ margin: 0;
+}
+
+/**
+ * Add the correct display in IE 9-.
+ */
+
+article,
+aside,
+footer,
+header,
+nav,
+section {
+ display: block;
+}
+
+/**
+ * Correct the font size and margin on `h1` elements within `section` and
+ * `article` contexts in Chrome, Firefox, and Safari.
+ */
+
+h1 {
+ font-size: 2em;
+ margin: 0.67em 0;
+}
+
+/* Grouping content
+ ========================================================================== */
+
+/**
+ * Add the correct display in IE 9-.
+ * 1. Add the correct display in IE.
+ */
+
+figcaption,
+figure,
+main { /* 1 */
+ display: block;
+}
+
+/**
+ * Add the correct margin in IE 8.
+ */
+
+figure {
+ margin: 1em 40px;
+}
+
+/**
+ * 1. Add the correct box sizing in Firefox.
+ * 2. Show the overflow in Edge and IE.
+ */
+
+hr {
+ box-sizing: content-box; /* 1 */
+ height: 0; /* 1 */
+ overflow: visible; /* 2 */
+}
+
+/**
+ * 1. Correct the inheritance and scaling of font size in all browsers.
+ * 2. Correct the odd `em` font sizing in all browsers.
+ */
+
+pre {
+ font-family: monospace, monospace; /* 1 */
+ font-size: 1em; /* 2 */
+}
+
+/* Text-level semantics
+ ========================================================================== */
+
+/**
+ * 1. Remove the gray background on active links in IE 10.
+ * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
+ */
+
+a {
+ background-color: transparent; /* 1 */
+ -webkit-text-decoration-skip: objects; /* 2 */
+}
+
+/**
+ * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
+ * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
+ */
+
+abbr[title] {
+ border-bottom: none; /* 1 */
+ text-decoration: underline; /* 2 */
+ text-decoration: underline dotted; /* 2 */
+}
+
+/**
+ * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
+ */
+
+b,
+strong {
+ font-weight: inherit;
+}
+
+/**
+ * Add the correct font weight in Chrome, Edge, and Safari.
+ */
+
+b,
+strong {
+ font-weight: bolder;
+}
+
+/**
+ * 1. Correct the inheritance and scaling of font size in all browsers.
+ * 2. Correct the odd `em` font sizing in all browsers.
+ */
+
+code,
+kbd,
+samp {
+ font-family: monospace, monospace; /* 1 */
+ font-size: 1em; /* 2 */
+}
+
+/**
+ * Add the correct font style in Android 4.3-.
+ */
+
+dfn {
+ font-style: italic;
+}
+
+/**
+ * Add the correct background and color in IE 9-.
+ */
+
+mark {
+ background-color: #ff0;
+ color: #000;
+}
+
+/**
+ * Add the correct font size in all browsers.
+ */
+
+small {
+ font-size: 80%;
+}
+
+/**
+ * Prevent `sub` and `sup` elements from affecting the line height in
+ * all browsers.
+ */
+
+sub,
+sup {
+ font-size: 75%;
+ line-height: 0;
+ position: relative;
+ vertical-align: baseline;
+}
+
+sub {
+ bottom: -0.25em;
+}
+
+sup {
+ top: -0.5em;
+}
+
+/* Embedded content
+ ========================================================================== */
+
+/**
+ * Add the correct display in IE 9-.
+ */
+
+audio,
+video {
+ display: inline-block;
+}
+
+/**
+ * Add the correct display in iOS 4-7.
+ */
+
+audio:not([controls]) {
+ display: none;
+ height: 0;
+}
+
+/**
+ * Remove the border on images inside links in IE 10-.
+ */
+
+img {
+ border-style: none;
+}
+
+/**
+ * Hide the overflow in IE.
+ */
+
+svg:not(:root) {
+ overflow: hidden;
+}
+
+/* Forms
+ ========================================================================== */
+
+/**
+ * 1. Change the font styles in all browsers (opinionated).
+ * 2. Remove the margin in Firefox and Safari.
+ */
+
+button,
+input,
+optgroup,
+select,
+textarea {
+ font-family: sans-serif; /* 1 */
+ font-size: 100%; /* 1 */
+ line-height: 1.15; /* 1 */
+ margin: 0; /* 2 */
+}
+
+/**
+ * Show the overflow in IE.
+ * 1. Show the overflow in Edge.
+ */
+
+button,
+input { /* 1 */
+ overflow: visible;
+}
+
+/**
+ * Remove the inheritance of text transform in Edge, Firefox, and IE.
+ * 1. Remove the inheritance of text transform in Firefox.
+ */
+
+button,
+select { /* 1 */
+ text-transform: none;
+}
+
+/**
+ * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
+ * controls in Android 4.
+ * 2. Correct the inability to style clickable types in iOS and Safari.
+ */
+
+button,
+html [type="button"], /* 1 */
+[type="reset"],
+[type="submit"] {
+ -webkit-appearance: button; /* 2 */
+}
+
+/**
+ * Remove the inner border and padding in Firefox.
+ */
+
+button::-moz-focus-inner,
+[type="button"]::-moz-focus-inner,
+[type="reset"]::-moz-focus-inner,
+[type="submit"]::-moz-focus-inner {
+ border-style: none;
+ padding: 0;
+}
+
+/**
+ * Restore the focus styles unset by the previous rule.
+ */
+
+button:-moz-focusring,
+[type="button"]:-moz-focusring,
+[type="reset"]:-moz-focusring,
+[type="submit"]:-moz-focusring {
+ outline: 1px dotted ButtonText;
+}
+
+/**
+ * Correct the padding in Firefox.
+ */
+
+fieldset {
+ padding: 0.35em 0.75em 0.625em;
+}
+
+/**
+ * 1. Correct the text wrapping in Edge and IE.
+ * 2. Correct the color inheritance from `fieldset` elements in IE.
+ * 3. Remove the padding so developers are not caught out when they zero out
+ * `fieldset` elements in all browsers.
+ */
+
+legend {
+ box-sizing: border-box; /* 1 */
+ color: inherit; /* 2 */
+ display: table; /* 1 */
+ max-width: 100%; /* 1 */
+ padding: 0; /* 3 */
+ white-space: normal; /* 1 */
+}
+
+/**
+ * 1. Add the correct display in IE 9-.
+ * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
+ */
+
+progress {
+ display: inline-block; /* 1 */
+ vertical-align: baseline; /* 2 */
+}
+
+/**
+ * Remove the default vertical scrollbar in IE.
+ */
+
+textarea {
+ overflow: auto;
+}
+
+/**
+ * 1. Add the correct box sizing in IE 10-.
+ * 2. Remove the padding in IE 10-.
+ */
+
+[type="checkbox"],
+[type="radio"] {
+ box-sizing: border-box; /* 1 */
+ padding: 0; /* 2 */
+}
+
+/**
+ * Correct the cursor style of increment and decrement buttons in Chrome.
+ */
+
+[type="number"]::-webkit-inner-spin-button,
+[type="number"]::-webkit-outer-spin-button {
+ height: auto;
+}
+
+/**
+ * 1. Correct the odd appearance in Chrome and Safari.
+ * 2. Correct the outline style in Safari.
+ */
+
+[type="search"] {
+ -webkit-appearance: textfield; /* 1 */
+ outline-offset: -2px; /* 2 */
+}
+
+/**
+ * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
+ */
+
+[type="search"]::-webkit-search-cancel-button,
+[type="search"]::-webkit-search-decoration {
+ -webkit-appearance: none;
+}
+
+/**
+ * 1. Correct the inability to style clickable types in iOS and Safari.
+ * 2. Change font properties to `inherit` in Safari.
+ */
+
+::-webkit-file-upload-button {
+ -webkit-appearance: button; /* 1 */
+ font: inherit; /* 2 */
+}
+
+/* Interactive
+ ========================================================================== */
+
+/*
+ * Add the correct display in IE 9-.
+ * 1. Add the correct display in Edge, IE, and Firefox.
+ */
+
+details, /* 1 */
+menu {
+ display: block;
+}
+
+/*
+ * Add the correct display in all browsers.
+ */
+
+summary {
+ display: list-item;
+}
+
+/* Scripting
+ ========================================================================== */
+
+/**
+ * Add the correct display in IE 9-.
+ */
+
+canvas {
+ display: inline-block;
+}
+
+/**
+ * Add the correct display in IE.
+ */
+
+template {
+ display: none;
+}
+
+/* Hidden
+ ========================================================================== */
+
+/**
+ * Add the correct display in IE 10-.
+ */
+
+[hidden] {
+ display: none;
+}
diff --git a/src/css/styles.css b/src/css/styles.css
new file mode 100644
index 0000000..59dc24a
--- /dev/null
+++ b/src/css/styles.css
@@ -0,0 +1,527 @@
+@font-face {
+ font-family: "Aurulent";
+ src: url("../fonts/AurulentSansMono-Regular.otf");
+}
+
+@font-face {
+ font-family: "Roboto";
+ src: url("../fonts/Roboto-Regular.ttf");
+}
+
+@font-face {
+ font-family: "Roboto Medium";
+ src: url("../fonts/Roboto-Medium.ttf");
+}
+
+* {
+ margin: 0;
+ padding: 0;
+}
+
+body, input {
+ font-family: Roboto, Helvetica, Arial, sans-serif;
+ font-size: 100%;
+}
+
+var {
+ font-style: normal;
+}
+
+a {color:inherit;}
+a:hover {text-decoration: none;}
+
+#board {
+ position: absolute;
+ width: 100%;
+ height: 100%;
+ background-color: white;
+}
+
+/* BOX */
+
+.box {
+ text-align: center;
+ position: absolute;
+ z-index: 1;
+ width: 32%;
+ font-size: 3em;
+}
+
+.head {
+ top: 2%;
+}
+
+.foot {
+ bottom: 10%;
+}
+
+.blu {
+ right: 2%;
+}
+
+.red {
+ left: 2%;
+}
+
+/* HOVERBAR */
+
+#titlebar {
+ width: 100%;
+ height: 10%;
+ position: absolute;
+ z-index: 3;
+ font-size: 1.2em;
+}
+
+#titlebar ul {
+ background-color: #f7f7f7;
+ border-bottom: 1px solid grey;
+ list-style-type: none;
+ margin: 0;
+ padding: 0;
+ width: 100%;
+ margin: auto;
+ text-align: center;
+}
+
+#titlebar li {
+ display: inline-block;
+ padding: 0.2em;
+ margin: 0 0.4em;
+}
+
+#titlebar button {
+ padding: 0.3em;
+}
+
+#titlebar a {
+ text-decoration: none;
+ color: black;
+ font-weight: bold;
+}
+
+#titlebar code {
+ font-family: Aurulent;
+ font-size: 0.8em;
+ font-weight: bold;
+}
+
+/* FIGHTOVERVIEW */
+
+#overview {
+ background-color: white;
+ position: absolute;
+ z-index: 2;
+ width: 100%;
+ height: 100%;
+ display: none;
+}
+
+#overview div {
+ display:flex;
+ justify-content: center;
+ align-items: center;
+ height:100%;
+ width:100%;
+}
+
+#overview table {
+ width:55%;
+ font-size: 180%;
+ border-collapse: collapse;
+}
+
+#overview tr:nth-child(even) {
+ background-color: #DDD;
+}
+
+#overview td {
+ text-align: center;
+ padding: 2% 1.4%;
+}
+
+#overview th {
+ padding: 0.4em;
+ font-family: "Roboto Medium";
+ font-size:180%;
+}
+
+#overview tr :first-child {
+ text-align: left;
+ width: 46%;
+}
+
+#overview tr :last-child {
+ text-align: right;
+ width: 46%;
+}
+
+#overview span {
+ display:flex;
+ justify-content: center;
+ align-items: center;
+ text-align: center;
+
+ height:100%;
+ padding: 0 0.4%;
+ font-size:6em;
+ position: absolute;
+}
+
+#overview img {
+ width:60%;
+ position:relative;
+ left:-2%;
+}
+
+#overviewRedBox {
+ background-color:#CC0000;
+ left: 0%;
+}
+
+#overviewBluBox {
+ background-color:#0000CC;
+ right: 0%;
+}
+
+
+/* SCORES */
+
+.box table {
+ width: 100%;
+ margin: auto;
+ text-align: center;
+ border-spacing: 0.08em;
+}
+
+.name {
+ font-family: 'Roboto Medium';
+ vertical-align: bottom;
+ padding-bottom: 0.2em;
+ height: 2.5em;
+}
+
+.box td {
+ border: 1px solid white;
+ border-color: transparent;
+}
+
+.score {
+ color: white;
+ font-family: 'Roboto Medium';
+ font-size: 1.8em;
+ width: 2em;
+ padding: 0.1em;
+}
+
+.red .score, .red .warning {
+ background-color: red;
+}
+
+.blu .score, .blu .warning {
+ background-color: blue;
+}
+
+.scoreside {
+ width: 0.3em;
+}
+
+.info .name {
+ margin-bottom: 1.8em;
+}
+
+/* TIME */
+
+.clock {
+ font-family: Aurulent, monospace;
+ font-weight: bold;
+}
+
+.middle {
+ width: 100%;
+}
+
+.middle td {
+ border: 0;
+}
+
+.time {
+ font-size: 1.8em;
+ color: black;
+}
+
+.center {
+ text-align: center;
+ margin: auto;
+ width: 50%;
+}
+
+.pt {
+ margin-left: -0.1em;
+ margin-right: -0.1em;
+}
+
+.active {
+ display: block;
+ text-align: center;
+ padding: 5%;
+ width: 50%;
+ margin: auto;
+ font-family: 'Roboto Medium';
+}
+
+.pause {
+ display: block;
+}
+
+.red .active {
+ color: red;
+}
+
+.blu .active {
+ color: blue;
+}
+
+.sponsors {
+ vertical-align: bottom;
+}
+
+.sponsors img {
+ vertical-align: bottom;
+ margin: auto;
+ max-width: 35%;
+ max-height: 4em;
+}
+
+/* Optionen */
+
+.submitBar {
+ display: block;
+ height: 1.8em;
+ clear: both;
+ padding-top: 1.8%;
+ margin-top: 1.8%;
+ border-top: 1px solid grey;
+}
+
+.config {
+ font-size: 1em;
+ position: absolute;
+ width: 100%;
+ height: 100%;
+ top: 0%;
+ left: 0%;
+ z-index: 5;
+ background-color: #EEE;
+ display: none;
+}
+
+.config .wrap {
+ width: 90%;
+ margin: auto;
+ background-color: white;
+ border: 1px solid grey;
+ padding: 2%;
+ margin-top: 2%;
+}
+
+.config .right {
+ float: right;
+ width: 30%;
+}
+
+#fights {
+ display: inline;
+ border-collapse: collapse;
+ margin-right: 5%;
+ /*margin-bottom: 5%;*/
+}
+
+#fights th {
+ padding-right: 0.6em;
+ padding-bottom: 0.3em;
+ text-align: left;
+}
+
+#fights td {
+ padding-bottom: 0.3em;
+ padding-right: 0.3em;
+}
+
+#fights td.weight {
+ width: 4em;
+}
+
+input[name=weight] {
+ width: 100%;
+}
+
+#fights td.greco {
+ text-align: center;
+}
+
+#fights select {
+ font-size: 0.7em;
+ width: 10em;
+}
+
+input[type="checkbox"] {
+ margin-right: 0.3em;
+}
+
+input[name^=red], input[name^=blu] {
+ width: 12em;
+}
+
+#input-buzzers {
+ width:9em;
+}
+
+.left {
+ float: left;
+ width: 12em;
+}
+
+/* lists */
+
+h3 {
+ font-size: 1em;
+ padding-top: 0.8em;
+ padding-bottom: 0.2em;
+}
+
+ul {
+ margin-bottom: 1.6em;
+ line-height: 1.4em;
+}
+
+li {
+ list-style-type: none;
+}
+
+li span {
+ display: inline-block;
+ width: 5em;
+}
+
+.config hr {
+ margin-top: 3%;
+ margin-bottom: 3%;
+ border: 0.5px solid grey;
+}
+
+input {
+ border: 0;
+ padding: 0.3em;
+ background-color: #EEE;
+}
+
+input.duration {
+ width: 4em;
+}
+
+input[type=file] {
+ display: none;
+}
+
+.invalid {
+ background-color: #f79b9b;
+}
+
+/* keys config */
+
+#keysConfig .col {
+ width: 51%;
+ float: left;
+ display: block;
+}
+
+#keysConfig .wrap {
+ width: 40%;
+ line-height: 2em;
+}
+
+#keysConfig span {
+ display: inline-block;
+ width: 11em;
+}
+
+#keysConfig input {
+ width: 3em;
+}
+
+#keysConfig .submitBar {
+ margin-top: 3em;
+}
+
+/* button */
+
+button {
+ padding: 0.3em;
+ margin: 0.2em;
+ background-color: #DDD;
+ border: 1px solid grey;
+}
+
+button:hover {
+ background-color: #EEE;
+}
+
+button:active {
+ background-color: #CCC;
+}
+
+.submit {
+ float: right;
+}
+
+nav button {
+ padding: 0.7em;
+}
+
+button.save {
+ background-color: #77DD77;
+}
+
+/* save */
+
+button.save:hover {
+ background-color: #88EE88;
+}
+
+button.save:active {
+ background-color: #5A5;
+}
+
+/* default button */
+
+button.loadDefaults {
+ /*width:6em;*/
+ display: inline;
+ text-align: left;
+}
+
+.closeX {
+ text-decoration: none;
+ color: black;
+ font-weight: bold;
+ float: right;
+}
+
+#impressum {
+ clear: both;
+ width: 30%;
+ margin: auto;
+ position: relative;
+ top: -2em;
+ text-align: center;
+ margin-bottom: -2em;
+ color: #999;
+ font-size: 0.9em;
+}
+
+#sound-attribution {
+ font-size: 80%;
+ margin-top:0px;
+ margin-bottom:5px;
+}
diff --git a/src/defaults.js b/src/defaults.js
new file mode 100644
index 0000000..928bd8e
--- /dev/null
+++ b/src/defaults.js
@@ -0,0 +1,332 @@
+"use strict";
+const defaults = {
+ keymaps: {
+ "info": {
+ toggle: "Start/Stop Uhr",
+ incrRedWres: "Einzelpunkte Rot +1",
+ decrRedWres: "Einzelpunkte Rot -1",
+ incrRedTeam: "Teampunkte Rot +1",
+ decrRedTeam: "Teampunkte Rot -1",
+ activeRed: "Aktivzeit Rot",
+ incrWarnRed: "Verwarnung Rot +1",
+ decrWarnRed: "Verwarnung Rot -1",
+ prev: "Vorheriger Kampf",
+ reset: "Kampf zurücksetzen",
+ openMatchConfig: "Einstellungen öffnen",
+ incrBluWres: "Einzelpunkte Blau +1",
+ decrBluWres: "Einzelpunkte Blau -1",
+ incrBluTeam: "Teampunkte Blau +1",
+ decrBluTeam: "Teampunkte Blau -1",
+ activeBlu: "Aktivzeit Blau",
+ incrWarnBlu: "Verwarnung Blau +1",
+ decrWarnBlu: "Verwarnung Blau -1",
+ next: "Nächster Kampf",
+ toggleOverview: "Matchübersicht öffnen"
+ },
+ "tastatur": {
+ toggle: "space",
+ next: "z",
+ prev: "t",
+ reset: "y",
+ incrRedWres: "f",
+ decrRedWres: "d",
+ incrRedTeam: "v",
+ decrRedTeam: "c",
+ incrBluWres: "j",
+ decrBluWres: "k",
+ incrBluTeam: "n",
+ decrBluTeam: "m",
+ activeRed: "e",
+ activeBlu: "i",
+ incrWarnRed: "w",
+ decrWarnRed: "q",
+ incrWarnBlu: "o",
+ decrWarnBlu: "p",
+ openMatchConfig: ",",
+ toggleOverview: "1"
+ },
+ "alos": {
+ toggle: "m",
+ next: "x",
+ prev: "c",
+ reset: "v",
+ incrRedWres: "f",
+ decrRedWres: "d",
+ incrRedTeam: "s",
+ decrRedTeam: "j",
+ incrBluWres: "r",
+ decrBluWres: "e",
+ incrBluTeam: "w",
+ decrBluTeam: "u",
+ activeRed: "f1",
+ activeBlu: "2",
+ incrWarnRed: "5",
+ decrWarnRed: "f2",
+ incrWarnBlu: "4",
+ decrWarnBlu: "3",
+ openMatchConfig: "6",
+ toggleOverview: "7"
+ }
+ },
+ fights: {
+ "mm": [
+ {
+ red: "",
+ blu: "",
+ weight: "57",
+ greco: false
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "61",
+ greco: true
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "65",
+ greco: false
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "70",
+ greco: true
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "74",
+ greco: false
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "74",
+ greco: true
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "80",
+ greco: false
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "86",
+ greco: true
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "97",
+ greco: false
+ },
+ {
+ red: "",
+ blu: "",
+ weight: "130",
+ greco: true
+ }
+ ],
+ },
+ buzzerFiles: {
+ "IndustrialAlarm": "audio/IndustrialAlarm.mp3",
+ "Schiff": "audio/AirHornShip.mp3",
+ "AirHorn": "audio/AirHorn.mp3",
+ "Buzz": "audio/Buzz.mp3",
+ "DoorBuzzer": "audio/DoorBuzzer.mp3",
+ "(Kein Ton)": ""
+ },
+ settings: {},
+ labels: {},
+ boxes: {}
+};
+defaults.settings = {
+ keymap: defaults.keymaps["tastatur"],
+ fights: defaults.fights["mm"],
+ match: {
+ red: "RR Schattdorf",
+ blu: "Gäste",
+ showWeigth: true,
+ lastPeriod: 2,
+ buzzer: "IndustrialAlarm",
+ mmSet: true,
+ showTeams: true,
+ sponsors: {
+ directoryLight: "sponsoren/light/",
+ directoryDark: "sponsoren/dark/",
+ interval: 45,
+ quantity: 3,
+ show: true
+ },
+ theme: false,
+ wrestlersAboveTeams: true
+ },
+ lang: {
+ periodSuffix: ". Halbzeit",
+ weightSuffix: " kg",
+ greco: "Greco",
+ nonGreco: "Freistil",
+ grecoShort: "G",
+ nonGrecoShort: "F",
+ fullscreenOn: "Vollbild ein",
+ fullscreenOff: "Vollbild aus"
+ },
+ timer: {
+ period: {
+ name: "period",
+ minutes: 3,
+ seconds: 0,
+ countdown: true,
+ subsecond: 10,
+ alwaysLeadZero: true
+ },
+ pause: {
+ name: "pause",
+ minutes: 0,
+ seconds: 30,
+ countdown: true,
+ subsecond: 0,
+ alwaysLeadZero: false
+ },
+ active: {
+ name: "active",
+ minutes: 0,
+ seconds: 30,
+ countdown: true,
+ subsecond: 0,
+ alwaysLeadZero: false
+ }
+ }
+};
+defaults.boxes.wrestlersAboveTeams = {
+ red: {
+ team: {
+ box: $(".box.foot.red"),
+ name: $("#red-foot-name"),
+ score: $("#red-foot-score")
+ },
+ wres: {
+ box: $(".box.head.red"),
+ name: $("#red-head-name"),
+ score: $("#red-head-score"),
+ time: $("#activeclock-red-head"),
+ warn: [
+ $(".head.red .w1"),
+ $(".head.red .w2"),
+ $(".head.red .w3")
+ ]
+ }
+ },
+ blu: {
+ team: {
+ box: $(".box.foot.blu"),
+ name: $("#blu-foot-name"),
+ score: $("#blu-foot-score")
+ },
+ wres: {
+ box: $(".box.head.blu"),
+ name: $("#blu-head-name"),
+ score: $("#blu-head-score"),
+ time: $("#activeclock-blu-head"),
+ warn: [
+ $(".head.blu .w1"),
+ $(".head.blu .w2"),
+ $(".head.blu .w3")
+ ]
+ }
+ }
+};
+defaults.boxes.wrestlersBelowTeams = {
+ red: {
+ team: {
+ box: $(".box.head.red"),
+ name: $("#red-head-name"),
+ score: $("#red-head-score")
+ },
+ wres: {
+ box: $(".box.foot.red"),
+ name: $("#red-foot-name"),
+ score: $("#red-foot-score"),
+ time: $("#activeclock-red-foot"),
+ warn: [
+ $(".foot.red .w1"),
+ $(".foot.red .w2"),
+ $(".foot.red .w3")
+ ]
+ }
+ },
+ blu: {
+ team: {
+ box: $(".box.head.blu"),
+ name: $("#blu-head-name"),
+ score: $("#blu-head-score")
+ },
+ wres: {
+ box: $(".box.foot.blu"),
+ name: $("#blu-foot-name"),
+ score: $("#blu-foot-score"),
+ time: $("#activeclock-blu-foot"),
+ warn: [
+ $(".foot.blu .w1"),
+ $(".foot.blu .w2"),
+ $(".foot.blu .w3")
+ ]
+ }
+ }
+};
+defaults.labels = {
+ boxes: defaults.boxes.wrestlersAboveTeams,
+ match: {
+ weight: $("#weight"),
+ style: $("#style"),
+ periodInfo: $("#periodInfo"),
+ periodClock: $("#periodClock"),
+ pauseClock: $("#pauseClock")
+ },
+ titlebar: {
+ div: $("#titlebar"),
+ settingsButton: $("#settingsButton"),
+ fullscreenButton: $("#fullscreenButton"),
+ },
+ config: {
+ match: $("#matchConfig"),
+ keys: $("#keysConfig"),
+ keymappingform: $("#keymappingform"),
+ selectDefaultWeights: $("#select-default-weights"),
+ selectDefaultKeymapping: $("#select-default-keymapping")
+ },
+ sponsor: $("#sponsor"),
+ board: document.querySelector("#board"),
+ overview: {
+ layer: $("#overview"),
+ red: $("#overviewRedBox"),
+ blu: $("#overviewBluBox"),
+ boxes: $("#overview span"),
+ table: $("#overview table"),
+ logo: $("#overview img")
+ },
+ css: {
+ showWarning: "warning",
+ hideScore: "hideScore",
+ invalid: "invalid",
+ timeseparator: "pt",
+ darkTheme: "src/css/dark.css"
+ },
+ html: {
+ inputname: {
+ weight: "weight",
+ greco: "greco",
+ red: "red",
+ blu: "blu"
+ },
+ },
+ loadsave: {
+ saveFileName: "rrs-anzeigetafel-einstellungen.json",
+ dummyAnchor: document.getElementById("dummyAnchor"),
+ fileInput: document.getElementById("fileInput")
+ },
+};
diff --git a/src/img/logo_favicon_small.png b/src/img/logo_favicon_small.png
new file mode 100644
index 0000000..b8ab938
Binary files /dev/null and b/src/img/logo_favicon_small.png differ
diff --git a/src/img/logo_grau.png b/src/img/logo_grau.png
new file mode 100644
index 0000000..f2cbaf8
Binary files /dev/null and b/src/img/logo_grau.png differ
diff --git a/src/lib/buzz.js b/src/lib/buzz.js
new file mode 100644
index 0000000..76c7a5f
--- /dev/null
+++ b/src/lib/buzz.js
@@ -0,0 +1,735 @@
+ // ----------------------------------------------------------------------------
+ // Buzz, a Javascript HTML5 Audio library
+ // v1.2.0 - Built 2016-05-22 15:16
+ // Licensed under the MIT license.
+ // http://buzz.jaysalvat.com/
+ // ----------------------------------------------------------------------------
+ // Copyright (C) 2010-2016 Jay Salvat
+ // http://jaysalvat.com/
+ // ----------------------------------------------------------------------------
+
+(function(context, factory) {
+ "use strict";
+ if (typeof module !== "undefined" && module.exports) {
+ module.exports = factory();
+ } else if (typeof define === "function" && define.amd) {
+ define([], factory);
+ } else {
+ context.buzz = factory();
+ }
+})(this, function() {
+ "use strict";
+ var AudioContext = window.AudioContext || window.webkitAudioContext;
+ var buzz = {
+ defaults: {
+ autoplay: false,
+ crossOrigin: null,
+ duration: 5e3,
+ formats: [],
+ loop: false,
+ placeholder: "--",
+ preload: "metadata",
+ volume: 80,
+ webAudioApi: false,
+ document: window.document
+ },
+ types: {
+ mp3: "audio/mpeg",
+ ogg: "audio/ogg",
+ wav: "audio/wav",
+ aac: "audio/aac",
+ m4a: "audio/x-m4a"
+ },
+ sounds: [],
+ el: document.createElement("audio"),
+ getAudioContext: function() {
+ if (this.audioCtx === undefined) {
+ try {
+ this.audioCtx = AudioContext ? new AudioContext() : null;
+ } catch (e) {
+ this.audioCtx = null;
+ }
+ }
+ return this.audioCtx;
+ },
+ sound: function(src, options) {
+ options = options || {};
+ var doc = options.document || buzz.defaults.document;
+ var pid = 0, events = [], eventsOnce = {}, supported = buzz.isSupported();
+ this.load = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.load();
+ return this;
+ };
+ this.play = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.play();
+ return this;
+ };
+ this.togglePlay = function() {
+ if (!supported) {
+ return this;
+ }
+ if (this.sound.paused) {
+ this.sound.play();
+ } else {
+ this.sound.pause();
+ }
+ return this;
+ };
+ this.pause = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.pause();
+ return this;
+ };
+ this.isPaused = function() {
+ if (!supported) {
+ return null;
+ }
+ return this.sound.paused;
+ };
+ this.stop = function() {
+ if (!supported) {
+ return this;
+ }
+ this.setTime(0);
+ this.sound.pause();
+ return this;
+ };
+ this.isEnded = function() {
+ if (!supported) {
+ return null;
+ }
+ return this.sound.ended;
+ };
+ this.loop = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.loop = "loop";
+ this.bind("ended.buzzloop", function() {
+ this.currentTime = 0;
+ this.play();
+ });
+ return this;
+ };
+ this.unloop = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.removeAttribute("loop");
+ this.unbind("ended.buzzloop");
+ return this;
+ };
+ this.mute = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.muted = true;
+ return this;
+ };
+ this.unmute = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.muted = false;
+ return this;
+ };
+ this.toggleMute = function() {
+ if (!supported) {
+ return this;
+ }
+ this.sound.muted = !this.sound.muted;
+ return this;
+ };
+ this.isMuted = function() {
+ if (!supported) {
+ return null;
+ }
+ return this.sound.muted;
+ };
+ this.setVolume = function(volume) {
+ if (!supported) {
+ return this;
+ }
+ if (volume < 0) {
+ volume = 0;
+ }
+ if (volume > 100) {
+ volume = 100;
+ }
+ this.volume = volume;
+ this.sound.volume = volume / 100;
+ return this;
+ };
+ this.getVolume = function() {
+ if (!supported) {
+ return this;
+ }
+ return this.volume;
+ };
+ this.increaseVolume = function(value) {
+ return this.setVolume(this.volume + (value || 1));
+ };
+ this.decreaseVolume = function(value) {
+ return this.setVolume(this.volume - (value || 1));
+ };
+ this.setTime = function(time) {
+ if (!supported) {
+ return this;
+ }
+ var set = true;
+ this.whenReady(function() {
+ if (set === true) {
+ set = false;
+ this.sound.currentTime = time;
+ }
+ });
+ return this;
+ };
+ this.getTime = function() {
+ if (!supported) {
+ return null;
+ }
+ var time = Math.round(this.sound.currentTime * 100) / 100;
+ return isNaN(time) ? buzz.defaults.placeholder : time;
+ };
+ this.setPercent = function(percent) {
+ if (!supported) {
+ return this;
+ }
+ return this.setTime(buzz.fromPercent(percent, this.sound.duration));
+ };
+ this.getPercent = function() {
+ if (!supported) {
+ return null;
+ }
+ var percent = Math.round(buzz.toPercent(this.sound.currentTime, this.sound.duration));
+ return isNaN(percent) ? buzz.defaults.placeholder : percent;
+ };
+ this.setSpeed = function(duration) {
+ if (!supported) {
+ return this;
+ }
+ this.sound.playbackRate = duration;
+ return this;
+ };
+ this.getSpeed = function() {
+ if (!supported) {
+ return null;
+ }
+ return this.sound.playbackRate;
+ };
+ this.getDuration = function() {
+ if (!supported) {
+ return null;
+ }
+ var duration = Math.round(this.sound.duration * 100) / 100;
+ return isNaN(duration) ? buzz.defaults.placeholder : duration;
+ };
+ this.getPlayed = function() {
+ if (!supported) {
+ return null;
+ }
+ return timerangeToArray(this.sound.played);
+ };
+ this.getBuffered = function() {
+ if (!supported) {
+ return null;
+ }
+ return timerangeToArray(this.sound.buffered);
+ };
+ this.getSeekable = function() {
+ if (!supported) {
+ return null;
+ }
+ return timerangeToArray(this.sound.seekable);
+ };
+ this.getErrorCode = function() {
+ if (supported && this.sound.error) {
+ return this.sound.error.code;
+ }
+ return 0;
+ };
+ this.getErrorMessage = function() {
+ if (!supported) {
+ return null;
+ }
+ switch (this.getErrorCode()) {
+ case 1:
+ return "MEDIA_ERR_ABORTED";
+
+ case 2:
+ return "MEDIA_ERR_NETWORK";
+
+ case 3:
+ return "MEDIA_ERR_DECODE";
+
+ case 4:
+ return "MEDIA_ERR_SRC_NOT_SUPPORTED";
+
+ default:
+ return null;
+ }
+ };
+ this.getStateCode = function() {
+ if (!supported) {
+ return null;
+ }
+ return this.sound.readyState;
+ };
+ this.getStateMessage = function() {
+ if (!supported) {
+ return null;
+ }
+ switch (this.getStateCode()) {
+ case 0:
+ return "HAVE_NOTHING";
+
+ case 1:
+ return "HAVE_METADATA";
+
+ case 2:
+ return "HAVE_CURRENT_DATA";
+
+ case 3:
+ return "HAVE_FUTURE_DATA";
+
+ case 4:
+ return "HAVE_ENOUGH_DATA";
+
+ default:
+ return null;
+ }
+ };
+ this.getNetworkStateCode = function() {
+ if (!supported) {
+ return null;
+ }
+ return this.sound.networkState;
+ };
+ this.getNetworkStateMessage = function() {
+ if (!supported) {
+ return null;
+ }
+ switch (this.getNetworkStateCode()) {
+ case 0:
+ return "NETWORK_EMPTY";
+
+ case 1:
+ return "NETWORK_IDLE";
+
+ case 2:
+ return "NETWORK_LOADING";
+
+ case 3:
+ return "NETWORK_NO_SOURCE";
+
+ default:
+ return null;
+ }
+ };
+ this.set = function(key, value) {
+ if (!supported) {
+ return this;
+ }
+ this.sound[key] = value;
+ return this;
+ };
+ this.get = function(key) {
+ if (!supported) {
+ return null;
+ }
+ return key ? this.sound[key] : this.sound;
+ };
+ this.bind = function(types, func) {
+ if (!supported) {
+ return this;
+ }
+ types = types.split(" ");
+ var self = this, efunc = function(e) {
+ func.call(self, e);
+ };
+ for (var t = 0; t < types.length; t++) {
+ var type = types[t], idx = type;
+ type = idx.split(".")[0];
+ events.push({
+ idx: idx,
+ func: efunc
+ });
+ this.sound.addEventListener(type, efunc, true);
+ }
+ return this;
+ };
+ this.unbind = function(types) {
+ if (!supported) {
+ return this;
+ }
+ types = types.split(" ");
+ for (var t = 0; t < types.length; t++) {
+ var idx = types[t], type = idx.split(".")[0];
+ for (var i = 0; i < events.length; i++) {
+ var namespace = events[i].idx.split(".");
+ if (events[i].idx === idx || namespace[1] && namespace[1] === idx.replace(".", "")) {
+ this.sound.removeEventListener(type, events[i].func, true);
+ events.splice(i, 1);
+ }
+ }
+ }
+ return this;
+ };
+ this.bindOnce = function(type, func) {
+ if (!supported) {
+ return this;
+ }
+ var self = this;
+ eventsOnce[pid++] = false;
+ this.bind(type + "." + pid, function() {
+ if (!eventsOnce[pid]) {
+ eventsOnce[pid] = true;
+ func.call(self);
+ }
+ self.unbind(type + "." + pid);
+ });
+ return this;
+ };
+ this.trigger = function(types, detail) {
+ if (!supported) {
+ return this;
+ }
+ types = types.split(" ");
+ for (var t = 0; t < types.length; t++) {
+ var idx = types[t];
+ for (var i = 0; i < events.length; i++) {
+ var eventType = events[i].idx.split(".");
+ if (events[i].idx === idx || eventType[0] && eventType[0] === idx.replace(".", "")) {
+ var evt = doc.createEvent("HTMLEvents");
+ evt.initEvent(eventType[0], false, true);
+ evt.originalEvent = detail;
+ this.sound.dispatchEvent(evt);
+ }
+ }
+ }
+ return this;
+ };
+ this.fadeTo = function(to, duration, callback) {
+ if (!supported) {
+ return this;
+ }
+ if (duration instanceof Function) {
+ callback = duration;
+ duration = buzz.defaults.duration;
+ } else {
+ duration = duration || buzz.defaults.duration;
+ }
+ var from = this.volume, delay = duration / Math.abs(from - to), self = this, fadeToTimeout;
+ this.play();
+ function doFade() {
+ clearTimeout(fadeToTimeout);
+ fadeToTimeout = setTimeout(function() {
+ if (from < to && self.volume < to) {
+ self.setVolume(self.volume += 1);
+ doFade();
+ } else if (from > to && self.volume > to) {
+ self.setVolume(self.volume -= 1);
+ doFade();
+ } else if (callback instanceof Function) {
+ callback.apply(self);
+ }
+ }, delay);
+ }
+ this.whenReady(function() {
+ doFade();
+ });
+ return this;
+ };
+ this.fadeIn = function(duration, callback) {
+ if (!supported) {
+ return this;
+ }
+ return this.setVolume(0).fadeTo(100, duration, callback);
+ };
+ this.fadeOut = function(duration, callback) {
+ if (!supported) {
+ return this;
+ }
+ return this.fadeTo(0, duration, callback);
+ };
+ this.fadeWith = function(sound, duration) {
+ if (!supported) {
+ return this;
+ }
+ this.fadeOut(duration, function() {
+ this.stop();
+ });
+ sound.play().fadeIn(duration);
+ return this;
+ };
+ this.whenReady = function(func) {
+ if (!supported) {
+ return null;
+ }
+ var self = this;
+ if (this.sound.readyState === 0) {
+ this.bind("canplay.buzzwhenready", function() {
+ func.call(self);
+ });
+ } else {
+ func.call(self);
+ }
+ };
+ this.addSource = function(src) {
+ var self = this, source = doc.createElement("source");
+ source.src = src;
+ if (buzz.types[getExt(src)]) {
+ source.type = buzz.types[getExt(src)];
+ }
+ this.sound.appendChild(source);
+ source.addEventListener("error", function(e) {
+ self.trigger("sourceerror", e);
+ });
+ return source;
+ };
+ function timerangeToArray(timeRange) {
+ var array = [], length = timeRange.length - 1;
+ for (var i = 0; i <= length; i++) {
+ array.push({
+ start: timeRange.start(i),
+ end: timeRange.end(i)
+ });
+ }
+ return array;
+ }
+ function getExt(filename) {
+ return filename.split(".").pop();
+ }
+ if (supported && src) {
+ for (var i in buzz.defaults) {
+ if (buzz.defaults.hasOwnProperty(i)) {
+ if (options[i] === undefined) {
+ options[i] = buzz.defaults[i];
+ }
+ }
+ }
+ this.sound = doc.createElement("audio");
+ if (options.crossOrigin !== null) {
+ this.sound.crossOrigin = options.crossOrigin;
+ }
+ if (options.webAudioApi) {
+ var audioCtx = buzz.getAudioContext();
+ if (audioCtx) {
+ this.source = audioCtx.createMediaElementSource(this.sound);
+ this.source.connect(audioCtx.destination);
+ }
+ }
+ if (src instanceof Array) {
+ for (var j in src) {
+ if (src.hasOwnProperty(j)) {
+ this.addSource(src[j]);
+ }
+ }
+ } else if (options.formats.length) {
+ for (var k in options.formats) {
+ if (options.formats.hasOwnProperty(k)) {
+ this.addSource(src + "." + options.formats[k]);
+ }
+ }
+ } else {
+ this.addSource(src);
+ }
+ if (options.loop) {
+ this.loop();
+ }
+ if (options.autoplay) {
+ this.sound.autoplay = "autoplay";
+ }
+ if (options.preload === true) {
+ this.sound.preload = "auto";
+ } else if (options.preload === false) {
+ this.sound.preload = "none";
+ } else {
+ this.sound.preload = options.preload;
+ }
+ this.setVolume(options.volume);
+ buzz.sounds.push(this);
+ }
+ },
+ group: function(sounds) {
+ sounds = argsToArray(sounds, arguments);
+ this.getSounds = function() {
+ return sounds;
+ };
+ this.add = function(soundArray) {
+ soundArray = argsToArray(soundArray, arguments);
+ for (var a = 0; a < soundArray.length; a++) {
+ sounds.push(soundArray[a]);
+ }
+ };
+ this.remove = function(soundArray) {
+ soundArray = argsToArray(soundArray, arguments);
+ for (var a = 0; a < soundArray.length; a++) {
+ for (var i = 0; i < sounds.length; i++) {
+ if (sounds[i] === soundArray[a]) {
+ sounds.splice(i, 1);
+ break;
+ }
+ }
+ }
+ };
+ this.load = function() {
+ fn("load");
+ return this;
+ };
+ this.play = function() {
+ fn("play");
+ return this;
+ };
+ this.togglePlay = function() {
+ fn("togglePlay");
+ return this;
+ };
+ this.pause = function(time) {
+ fn("pause", time);
+ return this;
+ };
+ this.stop = function() {
+ fn("stop");
+ return this;
+ };
+ this.mute = function() {
+ fn("mute");
+ return this;
+ };
+ this.unmute = function() {
+ fn("unmute");
+ return this;
+ };
+ this.toggleMute = function() {
+ fn("toggleMute");
+ return this;
+ };
+ this.setVolume = function(volume) {
+ fn("setVolume", volume);
+ return this;
+ };
+ this.increaseVolume = function(value) {
+ fn("increaseVolume", value);
+ return this;
+ };
+ this.decreaseVolume = function(value) {
+ fn("decreaseVolume", value);
+ return this;
+ };
+ this.loop = function() {
+ fn("loop");
+ return this;
+ };
+ this.unloop = function() {
+ fn("unloop");
+ return this;
+ };
+ this.setSpeed = function(speed) {
+ fn("setSpeed", speed);
+ return this;
+ };
+ this.setTime = function(time) {
+ fn("setTime", time);
+ return this;
+ };
+ this.set = function(key, value) {
+ fn("set", key, value);
+ return this;
+ };
+ this.bind = function(type, func) {
+ fn("bind", type, func);
+ return this;
+ };
+ this.unbind = function(type) {
+ fn("unbind", type);
+ return this;
+ };
+ this.bindOnce = function(type, func) {
+ fn("bindOnce", type, func);
+ return this;
+ };
+ this.trigger = function(type) {
+ fn("trigger", type);
+ return this;
+ };
+ this.fade = function(from, to, duration, callback) {
+ fn("fade", from, to, duration, callback);
+ return this;
+ };
+ this.fadeIn = function(duration, callback) {
+ fn("fadeIn", duration, callback);
+ return this;
+ };
+ this.fadeOut = function(duration, callback) {
+ fn("fadeOut", duration, callback);
+ return this;
+ };
+ function fn() {
+ var args = argsToArray(null, arguments), func = args.shift();
+ for (var i = 0; i < sounds.length; i++) {
+ sounds[i][func].apply(sounds[i], args);
+ }
+ }
+ function argsToArray(array, args) {
+ return array instanceof Array ? array : Array.prototype.slice.call(args);
+ }
+ },
+ all: function() {
+ return new buzz.group(buzz.sounds);
+ },
+ isSupported: function() {
+ return !!buzz.el.canPlayType;
+ },
+ isOGGSupported: function() {
+ return !!buzz.el.canPlayType && buzz.el.canPlayType('audio/ogg; codecs="vorbis"');
+ },
+ isWAVSupported: function() {
+ return !!buzz.el.canPlayType && buzz.el.canPlayType('audio/wav; codecs="1"');
+ },
+ isMP3Supported: function() {
+ return !!buzz.el.canPlayType && buzz.el.canPlayType("audio/mpeg;");
+ },
+ isAACSupported: function() {
+ return !!buzz.el.canPlayType && (buzz.el.canPlayType("audio/x-m4a;") || buzz.el.canPlayType("audio/aac;"));
+ },
+ toTimer: function(time, withHours) {
+ var h, m, s;
+ h = Math.floor(time / 3600);
+ h = isNaN(h) ? "--" : h >= 10 ? h : "0" + h;
+ m = withHours ? Math.floor(time / 60 % 60) : Math.floor(time / 60);
+ m = isNaN(m) ? "--" : m >= 10 ? m : "0" + m;
+ s = Math.floor(time % 60);
+ s = isNaN(s) ? "--" : s >= 10 ? s : "0" + s;
+ return withHours ? h + ":" + m + ":" + s : m + ":" + s;
+ },
+ fromTimer: function(time) {
+ var splits = time.toString().split(":");
+ if (splits && splits.length === 3) {
+ time = parseInt(splits[0], 10) * 3600 + parseInt(splits[1], 10) * 60 + parseInt(splits[2], 10);
+ }
+ if (splits && splits.length === 2) {
+ time = parseInt(splits[0], 10) * 60 + parseInt(splits[1], 10);
+ }
+ return time;
+ },
+ toPercent: function(value, total, decimal) {
+ var r = Math.pow(10, decimal || 0);
+ return Math.round(value * 100 / total * r) / r;
+ },
+ fromPercent: function(percent, total, decimal) {
+ var r = Math.pow(10, decimal || 0);
+ return Math.round(total / 100 * percent * r) / r;
+ }
+ };
+ return buzz;
+});
\ No newline at end of file
diff --git a/src/lib/clone.js b/src/lib/clone.js
new file mode 100644
index 0000000..dc8c6cc
--- /dev/null
+++ b/src/lib/clone.js
@@ -0,0 +1,74 @@
+/*
+ Tree Kit
+ Copyright (c) 2014 - 2018 Cédric Ronvel
+ The MIT License (MIT)
+ Permission is hereby granted, free of charge, to any person obtaining a copy
+ of this software and associated documentation files (the "Software"), to deal
+ in the Software without restriction, including without limitation the rights
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ copies of the Software, and to permit persons to whom the Software is
+ furnished to do so, subject to the following conditions:
+ The above copyright notice and this permission notice shall be included in all
+ copies or substantial portions of the Software.
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ SOFTWARE.
+*/
+function clone(originalObject) {
+ let circular = false;
+ // First create an empty object with
+ // same prototype of our original source
+
+ var propertyIndex,
+ descriptor,
+ keys,
+ current,
+ nextSource,
+ indexOf,
+ copies = [{
+ source: originalObject,
+ target: Object.create(Object.getPrototypeOf(originalObject))
+ }],
+ cloneObject = copies[0].target,
+ sourceReferences = [originalObject],
+ targetReferences = [cloneObject];
+
+ // First in, first out
+ while (current = copies.shift()) {
+ keys = Object.getOwnPropertyNames(current.source);
+
+ for (propertyIndex = 0; propertyIndex < keys.length; propertyIndex++) {
+ // Save the source's descriptor
+ descriptor = Object.getOwnPropertyDescriptor(current.source, keys[propertyIndex]);
+
+ if (!descriptor.value || typeof descriptor.value !== 'object') {
+ Object.defineProperty(current.target, keys[propertyIndex], descriptor);
+ continue;
+ }
+
+ nextSource = descriptor.value;
+ descriptor.value = Array.isArray(nextSource) ?
+ [] :
+ Object.create(Object.getPrototypeOf(nextSource));
+
+ if (circular) {
+ indexOf = sourceReferences.indexOf(nextSource);
+ if (indexOf !== -1) {
+ // The source is already referenced, just assign reference
+ descriptor.value = targetReferences[indexOf];
+ Object.defineProperty(current.target, keys[propertyIndex], descriptor);
+ continue;
+ }
+ sourceReferences.push(nextSource);
+ targetReferences.push(descriptor.value);
+ }
+ Object.defineProperty(current.target, keys[propertyIndex], descriptor);
+ copies.push({ source: nextSource, target: descriptor.value });
+ }
+ }
+ return cloneObject;
+};
diff --git a/src/lib/fscreen.js b/src/lib/fscreen.js
new file mode 100644
index 0000000..98a4089
--- /dev/null
+++ b/src/lib/fscreen.js
@@ -0,0 +1,72 @@
+/*
+
+LICENSE: MIT
+*/
+
+'use strict';
+
+/*
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+*/
+var key = {
+ fullscreenEnabled: 0,
+ fullscreenElement: 1,
+ requestFullscreen: 2,
+ exitFullscreen: 3,
+ fullscreenchange: 4,
+ fullscreenerror: 5
+};
+
+var webkit = ['webkitFullscreenEnabled', 'webkitFullscreenElement', 'webkitRequestFullscreen', 'webkitExitFullscreen', 'webkitfullscreenchange', 'webkitfullscreenerror'];
+
+var moz = ['mozFullScreenEnabled', 'mozFullScreenElement', 'mozRequestFullScreen', 'mozCancelFullScreen', 'mozfullscreenchange', 'mozfullscreenerror'];
+
+var ms = ['msFullscreenEnabled', 'msFullscreenElement', 'msRequestFullscreen', 'msExitFullscreen', 'MSFullscreenChange', 'MSFullscreenError'];
+
+// so it doesn't throw if no window or document
+// var document = typeof window !== 'undefined' && typeof window.document !== 'undefined' ? window.document : {};
+
+var vendor = 'fullscreenEnabled' in document && Object.keys(key) || webkit[0] in document && webkit || moz[0] in document && moz || ms[0] in document && ms || [];
+
+var fscreen = {
+ requestFullscreen: function requestFullscreen(element) {
+ return element[vendor[key.requestFullscreen]]();
+ },
+ requestFullscreenFunction: function requestFullscreenFunction(element) {
+ return element[vendor[key.requestFullscreen]];
+ },
+ get exitFullscreen() {
+ return document[vendor[key.exitFullscreen]].bind(document);
+ },
+ addEventListener: function addEventListener(type, handler, options) {
+ return document.addEventListener(vendor[key[type]], handler, options);
+ },
+ removeEventListener: function removeEventListener(type, handler) {
+ return document.removeEventListener(vendor[key[type]], handler);
+ },
+ get fullscreenEnabled() {
+ return Boolean(document[vendor[key.fullscreenEnabled]]);
+ },
+ set fullscreenEnabled(val) {},
+ get fullscreenElement() {
+ return document[vendor[key.fullscreenElement]];
+ },
+ set fullscreenElement(val) {},
+ get onfullscreenchange() {
+ return document[('on' + vendor[key.fullscreenchange]).toLowerCase()];
+ },
+ set onfullscreenchange(handler) {
+ return document[('on' + vendor[key.fullscreenchange]).toLowerCase()] = handler;
+ },
+ get onfullscreenerror() {
+ return document[('on' + vendor[key.fullscreenerror]).toLowerCase()];
+ },
+ set onfullscreenerror(handler) {
+ return document[('on' + vendor[key.fullscreenerror]).toLowerCase()] = handler;
+ },
+ is() {
+ return fscreen.fullscreenElement !== null;
+ }
+};
diff --git a/src/lib/jquery.js b/src/lib/jquery.js
new file mode 100644
index 0000000..644d35e
--- /dev/null
+++ b/src/lib/jquery.js
@@ -0,0 +1,4 @@
+/*! jQuery v3.2.1 | (c) JS Foundation and other contributors | jquery.org/license */
+!function(a,b){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){"use strict";var c=[],d=a.document,e=Object.getPrototypeOf,f=c.slice,g=c.concat,h=c.push,i=c.indexOf,j={},k=j.toString,l=j.hasOwnProperty,m=l.toString,n=m.call(Object),o={};function p(a,b){b=b||d;var c=b.createElement("script");c.text=a,b.head.appendChild(c).parentNode.removeChild(c)}var q="3.2.1",r=function(a,b){return new r.fn.init(a,b)},s=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,t=/^-ms-/,u=/-([a-z])/g,v=function(a,b){return b.toUpperCase()};r.fn=r.prototype={jquery:q,constructor:r,length:0,toArray:function(){return f.call(this)},get:function(a){return null==a?f.call(this):a<0?this[a+this.length]:this[a]},pushStack:function(a){var b=r.merge(this.constructor(),a);return b.prevObject=this,b},each:function(a){return r.each(this,a)},map:function(a){return this.pushStack(r.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(f.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(a<0?b:0);return this.pushStack(c>=0&&c0&&b-1 in a)}var x=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ha(),z=ha(),A=ha(),B=function(a,b){return a===b&&(l=!0),0},C={}.hasOwnProperty,D=[],E=D.pop,F=D.push,G=D.push,H=D.slice,I=function(a,b){for(var c=0,d=a.length;c+~]|"+K+")"+K+"*"),S=new RegExp("="+K+"*([^\\]'\"]*?)"+K+"*\\]","g"),T=new RegExp(N),U=new RegExp("^"+L+"$"),V={ID:new RegExp("^#("+L+")"),CLASS:new RegExp("^\\.("+L+")"),TAG:new RegExp("^("+L+"|[*])"),ATTR:new RegExp("^"+M),PSEUDO:new RegExp("^"+N),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+K+"*(even|odd|(([+-]|)(\\d*)n|)"+K+"*(?:([+-]|)"+K+"*(\\d+)|))"+K+"*\\)|)","i"),bool:new RegExp("^(?:"+J+")$","i"),needsContext:new RegExp("^"+K+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+K+"*((?:-\\d)?\\d*)"+K+"*\\)|)(?=[^-]|$)","i")},W=/^(?:input|select|textarea|button)$/i,X=/^h\d$/i,Y=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,$=/[+~]/,_=new RegExp("\\\\([\\da-f]{1,6}"+K+"?|("+K+")|.)","ig"),aa=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:d<0?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},ba=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ca=function(a,b){return b?"\0"===a?"\ufffd":a.slice(0,-1)+"\\"+a.charCodeAt(a.length-1).toString(16)+" ":"\\"+a},da=function(){m()},ea=ta(function(a){return a.disabled===!0&&("form"in a||"label"in a)},{dir:"parentNode",next:"legend"});try{G.apply(D=H.call(v.childNodes),v.childNodes),D[v.childNodes.length].nodeType}catch(fa){G={apply:D.length?function(a,b){F.apply(a,H.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function ga(a,b,d,e){var f,h,j,k,l,o,r,s=b&&b.ownerDocument,w=b?b.nodeType:9;if(d=d||[],"string"!=typeof a||!a||1!==w&&9!==w&&11!==w)return d;if(!e&&((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,p)){if(11!==w&&(l=Z.exec(a)))if(f=l[1]){if(9===w){if(!(j=b.getElementById(f)))return d;if(j.id===f)return d.push(j),d}else if(s&&(j=s.getElementById(f))&&t(b,j)&&j.id===f)return d.push(j),d}else{if(l[2])return G.apply(d,b.getElementsByTagName(a)),d;if((f=l[3])&&c.getElementsByClassName&&b.getElementsByClassName)return G.apply(d,b.getElementsByClassName(f)),d}if(c.qsa&&!A[a+" "]&&(!q||!q.test(a))){if(1!==w)s=b,r=a;else if("object"!==b.nodeName.toLowerCase()){(k=b.getAttribute("id"))?k=k.replace(ba,ca):b.setAttribute("id",k=u),o=g(a),h=o.length;while(h--)o[h]="#"+k+" "+sa(o[h]);r=o.join(","),s=$.test(a)&&qa(b.parentNode)||b}if(r)try{return G.apply(d,s.querySelectorAll(r)),d}catch(x){}finally{k===u&&b.removeAttribute("id")}}}return i(a.replace(P,"$1"),b,d,e)}function ha(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ia(a){return a[u]=!0,a}function ja(a){var b=n.createElement("fieldset");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ka(a,b){var c=a.split("|"),e=c.length;while(e--)d.attrHandle[c[e]]=b}function la(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&a.sourceIndex-b.sourceIndex;if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function na(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function oa(a){return function(b){return"form"in b?b.parentNode&&b.disabled===!1?"label"in b?"label"in b.parentNode?b.parentNode.disabled===a:b.disabled===a:b.isDisabled===a||b.isDisabled!==!a&&ea(b)===a:b.disabled===a:"label"in b&&b.disabled===a}}function pa(a){return ia(function(b){return b=+b,ia(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function qa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=ga.support={},f=ga.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return!!b&&"HTML"!==b.nodeName},m=ga.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=n.documentElement,p=!f(n),v!==n&&(e=n.defaultView)&&e.top!==e&&(e.addEventListener?e.addEventListener("unload",da,!1):e.attachEvent&&e.attachEvent("onunload",da)),c.attributes=ja(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ja(function(a){return a.appendChild(n.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=Y.test(n.getElementsByClassName),c.getById=ja(function(a){return o.appendChild(a).id=u,!n.getElementsByName||!n.getElementsByName(u).length}),c.getById?(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){return a.getAttribute("id")===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c?[c]:[]}}):(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c,d,e,f=b.getElementById(a);if(f){if(c=f.getAttributeNode("id"),c&&c.value===a)return[f];e=b.getElementsByName(a),d=0;while(f=e[d++])if(c=f.getAttributeNode("id"),c&&c.value===a)return[f]}return[]}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){if("undefined"!=typeof b.getElementsByClassName&&p)return b.getElementsByClassName(a)},r=[],q=[],(c.qsa=Y.test(n.querySelectorAll))&&(ja(function(a){o.appendChild(a).innerHTML="",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+K+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+K+"*(?:value|"+J+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ja(function(a){a.innerHTML="";var b=n.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+K+"*[*^$|!~]?="),2!==a.querySelectorAll(":enabled").length&&q.push(":enabled",":disabled"),o.appendChild(a).disabled=!0,2!==a.querySelectorAll(":disabled").length&&q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=Y.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ja(function(a){c.disconnectedMatch=s.call(a,"*"),s.call(a,"[s!='']:x"),r.push("!=",N)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=Y.test(o.compareDocumentPosition),t=b||Y.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===n||a.ownerDocument===v&&t(v,a)?-1:b===n||b.ownerDocument===v&&t(v,b)?1:k?I(k,a)-I(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,g=[a],h=[b];if(!e||!f)return a===n?-1:b===n?1:e?-1:f?1:k?I(k,a)-I(k,b):0;if(e===f)return la(a,b);c=a;while(c=c.parentNode)g.unshift(c);c=b;while(c=c.parentNode)h.unshift(c);while(g[d]===h[d])d++;return d?la(g[d],h[d]):g[d]===v?-1:h[d]===v?1:0},n):n},ga.matches=function(a,b){return ga(a,null,null,b)},ga.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(S,"='$1']"),c.matchesSelector&&p&&!A[b+" "]&&(!r||!r.test(b))&&(!q||!q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return ga(b,n,null,[a]).length>0},ga.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},ga.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&C.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},ga.escape=function(a){return(a+"").replace(ba,ca)},ga.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},ga.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=ga.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=ga.selectors={cacheLength:50,createPseudo:ia,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(_,aa),a[3]=(a[3]||a[4]||a[5]||"").replace(_,aa),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||ga.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&ga.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return V.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&T.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(_,aa).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+K+")"+a+"("+K+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=ga.attr(d,a);return null==e?"!="===b:!b||(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(O," ")+" ").indexOf(c)>-1:"|="===b&&(e===c||e.slice(0,c.length+1)===c+"-"))}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h,t=!1;if(q){if(f){while(p){m=b;while(m=m[p])if(h?m.nodeName.toLowerCase()===r:1===m.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){m=q,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n&&j[2],m=n&&q.childNodes[n];while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if(1===m.nodeType&&++t&&m===b){k[a]=[w,n,t];break}}else if(s&&(m=b,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n),t===!1)while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if((h?m.nodeName.toLowerCase()===r:1===m.nodeType)&&++t&&(s&&(l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),k[a]=[w,t]),m===b))break;return t-=e,t===d||t%d===0&&t/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||ga.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ia(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=I(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ia(function(a){var b=[],c=[],d=h(a.replace(P,"$1"));return d[u]?ia(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ia(function(a){return function(b){return ga(a,b).length>0}}),contains:ia(function(a){return a=a.replace(_,aa),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ia(function(a){return U.test(a||"")||ga.error("unsupported lang: "+a),a=a.replace(_,aa).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:oa(!1),disabled:oa(!0),checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return X.test(a.nodeName)},input:function(a){return W.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:pa(function(){return[0]}),last:pa(function(a,b){return[b-1]}),eq:pa(function(a,b,c){return[c<0?c+b:c]}),even:pa(function(a,b){for(var c=0;c=0;)a.push(d);return a}),gt:pa(function(a,b,c){for(var d=c<0?c+b:c;++d1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function va(a,b,c){for(var d=0,e=b.length;d-1&&(f[j]=!(g[j]=l))}}else r=wa(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):G.apply(g,r)})}function ya(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=ta(function(a){return a===b},h,!0),l=ta(function(a){return I(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];i1&&ua(m),i>1&&sa(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(P,"$1"),c,i0,e=a.length>0,f=function(f,g,h,i,k){var l,o,q,r=0,s="0",t=f&&[],u=[],v=j,x=f||e&&d.find.TAG("*",k),y=w+=null==v?1:Math.random()||.1,z=x.length;for(k&&(j=g===n||g||k);s!==z&&null!=(l=x[s]);s++){if(e&&l){o=0,g||l.ownerDocument===n||(m(l),h=!p);while(q=a[o++])if(q(l,g||n,h)){i.push(l);break}k&&(w=y)}c&&((l=!q&&l)&&r--,f&&t.push(l))}if(r+=s,c&&s!==r){o=0;while(q=b[o++])q(t,u,g,h);if(f){if(r>0)while(s--)t[s]||u[s]||(u[s]=E.call(i));u=wa(u)}G.apply(i,u),k&&!f&&u.length>0&&r+b.length>1&&ga.uniqueSort(i)}return k&&(w=y,j=v),t};return c?ia(f):f}return h=ga.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=ya(b[c]),f[u]?d.push(f):e.push(f);f=A(a,za(e,d)),f.selector=a}return f},i=ga.select=function(a,b,c,e){var f,i,j,k,l,m="function"==typeof a&&a,n=!e&&g(a=m.selector||a);if(c=c||[],1===n.length){if(i=n[0]=n[0].slice(0),i.length>2&&"ID"===(j=i[0]).type&&9===b.nodeType&&p&&d.relative[i[1].type]){if(b=(d.find.ID(j.matches[0].replace(_,aa),b)||[])[0],!b)return c;m&&(b=b.parentNode),a=a.slice(i.shift().value.length)}f=V.needsContext.test(a)?0:i.length;while(f--){if(j=i[f],d.relative[k=j.type])break;if((l=d.find[k])&&(e=l(j.matches[0].replace(_,aa),$.test(i[0].type)&&qa(b.parentNode)||b))){if(i.splice(f,1),a=e.length&&sa(i),!a)return G.apply(c,e),c;break}}}return(m||h(a,n))(e,b,!p,c,!b||$.test(a)&&qa(b.parentNode)||b),c},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ja(function(a){return 1&a.compareDocumentPosition(n.createElement("fieldset"))}),ja(function(a){return a.innerHTML="","#"===a.firstChild.getAttribute("href")})||ka("type|href|height|width",function(a,b,c){if(!c)return a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ja(function(a){return a.innerHTML="",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ka("value",function(a,b,c){if(!c&&"input"===a.nodeName.toLowerCase())return a.defaultValue}),ja(function(a){return null==a.getAttribute("disabled")})||ka(J,function(a,b,c){var d;if(!c)return a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),ga}(a);r.find=x,r.expr=x.selectors,r.expr[":"]=r.expr.pseudos,r.uniqueSort=r.unique=x.uniqueSort,r.text=x.getText,r.isXMLDoc=x.isXML,r.contains=x.contains,r.escapeSelector=x.escape;var y=function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&r(a).is(c))break;d.push(a)}return d},z=function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c},A=r.expr.match.needsContext;function B(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()}var C=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i,D=/^.[^:#\[\.,]*$/;function E(a,b,c){return r.isFunction(b)?r.grep(a,function(a,d){return!!b.call(a,d,a)!==c}):b.nodeType?r.grep(a,function(a){return a===b!==c}):"string"!=typeof b?r.grep(a,function(a){return i.call(b,a)>-1!==c}):D.test(b)?r.filter(b,a,c):(b=r.filter(b,a),r.grep(a,function(a){return i.call(b,a)>-1!==c&&1===a.nodeType}))}r.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?r.find.matchesSelector(d,a)?[d]:[]:r.find.matches(a,r.grep(b,function(a){return 1===a.nodeType}))},r.fn.extend({find:function(a){var b,c,d=this.length,e=this;if("string"!=typeof a)return this.pushStack(r(a).filter(function(){for(b=0;b1?r.uniqueSort(c):c},filter:function(a){return this.pushStack(E(this,a||[],!1))},not:function(a){return this.pushStack(E(this,a||[],!0))},is:function(a){return!!E(this,"string"==typeof a&&A.test(a)?r(a):a||[],!1).length}});var F,G=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,H=r.fn.init=function(a,b,c){var e,f;if(!a)return this;if(c=c||F,"string"==typeof a){if(e="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:G.exec(a),!e||!e[1]&&b)return!b||b.jquery?(b||c).find(a):this.constructor(b).find(a);if(e[1]){if(b=b instanceof r?b[0]:b,r.merge(this,r.parseHTML(e[1],b&&b.nodeType?b.ownerDocument||b:d,!0)),C.test(e[1])&&r.isPlainObject(b))for(e in b)r.isFunction(this[e])?this[e](b[e]):this.attr(e,b[e]);return this}return f=d.getElementById(e[2]),f&&(this[0]=f,this.length=1),this}return a.nodeType?(this[0]=a,this.length=1,this):r.isFunction(a)?void 0!==c.ready?c.ready(a):a(r):r.makeArray(a,this)};H.prototype=r.fn,F=r(d);var I=/^(?:parents|prev(?:Until|All))/,J={children:!0,contents:!0,next:!0,prev:!0};r.fn.extend({has:function(a){var b=r(a,this),c=b.length;return this.filter(function(){for(var a=0;a-1:1===c.nodeType&&r.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?r.uniqueSort(f):f)},index:function(a){return a?"string"==typeof a?i.call(r(a),this[0]):i.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(r.uniqueSort(r.merge(this.get(),r(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function K(a,b){while((a=a[b])&&1!==a.nodeType);return a}r.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return y(a,"parentNode")},parentsUntil:function(a,b,c){return y(a,"parentNode",c)},next:function(a){return K(a,"nextSibling")},prev:function(a){return K(a,"previousSibling")},nextAll:function(a){return y(a,"nextSibling")},prevAll:function(a){return y(a,"previousSibling")},nextUntil:function(a,b,c){return y(a,"nextSibling",c)},prevUntil:function(a,b,c){return y(a,"previousSibling",c)},siblings:function(a){return z((a.parentNode||{}).firstChild,a)},children:function(a){return z(a.firstChild)},contents:function(a){return B(a,"iframe")?a.contentDocument:(B(a,"template")&&(a=a.content||a),r.merge([],a.childNodes))}},function(a,b){r.fn[a]=function(c,d){var e=r.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=r.filter(d,e)),this.length>1&&(J[a]||r.uniqueSort(e),I.test(a)&&e.reverse()),this.pushStack(e)}});var L=/[^\x20\t\r\n\f]+/g;function M(a){var b={};return r.each(a.match(L)||[],function(a,c){b[c]=!0}),b}r.Callbacks=function(a){a="string"==typeof a?M(a):r.extend({},a);var b,c,d,e,f=[],g=[],h=-1,i=function(){for(e=e||a.once,d=b=!0;g.length;h=-1){c=g.shift();while(++h-1)f.splice(c,1),c<=h&&h--}),this},has:function(a){return a?r.inArray(a,f)>-1:f.length>0},empty:function(){return f&&(f=[]),this},disable:function(){return e=g=[],f=c="",this},disabled:function(){return!f},lock:function(){return e=g=[],c||b||(f=c=""),this},locked:function(){return!!e},fireWith:function(a,c){return e||(c=c||[],c=[a,c.slice?c.slice():c],g.push(c),b||i()),this},fire:function(){return j.fireWith(this,arguments),this},fired:function(){return!!d}};return j};function N(a){return a}function O(a){throw a}function P(a,b,c,d){var e;try{a&&r.isFunction(e=a.promise)?e.call(a).done(b).fail(c):a&&r.isFunction(e=a.then)?e.call(a,b,c):b.apply(void 0,[a].slice(d))}catch(a){c.apply(void 0,[a])}}r.extend({Deferred:function(b){var c=[["notify","progress",r.Callbacks("memory"),r.Callbacks("memory"),2],["resolve","done",r.Callbacks("once memory"),r.Callbacks("once memory"),0,"resolved"],["reject","fail",r.Callbacks("once memory"),r.Callbacks("once memory"),1,"rejected"]],d="pending",e={state:function(){return d},always:function(){return f.done(arguments).fail(arguments),this},"catch":function(a){return e.then(null,a)},pipe:function(){var a=arguments;return r.Deferred(function(b){r.each(c,function(c,d){var e=r.isFunction(a[d[4]])&&a[d[4]];f[d[1]](function(){var a=e&&e.apply(this,arguments);a&&r.isFunction(a.promise)?a.promise().progress(b.notify).done(b.resolve).fail(b.reject):b[d[0]+"With"](this,e?[a]:arguments)})}),a=null}).promise()},then:function(b,d,e){var f=0;function g(b,c,d,e){return function(){var h=this,i=arguments,j=function(){var a,j;if(!(b=f&&(d!==O&&(h=void 0,i=[a]),c.rejectWith(h,i))}};b?k():(r.Deferred.getStackHook&&(k.stackTrace=r.Deferred.getStackHook()),a.setTimeout(k))}}return r.Deferred(function(a){c[0][3].add(g(0,a,r.isFunction(e)?e:N,a.notifyWith)),c[1][3].add(g(0,a,r.isFunction(b)?b:N)),c[2][3].add(g(0,a,r.isFunction(d)?d:O))}).promise()},promise:function(a){return null!=a?r.extend(a,e):e}},f={};return r.each(c,function(a,b){var g=b[2],h=b[5];e[b[1]]=g.add,h&&g.add(function(){d=h},c[3-a][2].disable,c[0][2].lock),g.add(b[3].fire),f[b[0]]=function(){return f[b[0]+"With"](this===f?void 0:this,arguments),this},f[b[0]+"With"]=g.fireWith}),e.promise(f),b&&b.call(f,f),f},when:function(a){var b=arguments.length,c=b,d=Array(c),e=f.call(arguments),g=r.Deferred(),h=function(a){return function(c){d[a]=this,e[a]=arguments.length>1?f.call(arguments):c,--b||g.resolveWith(d,e)}};if(b<=1&&(P(a,g.done(h(c)).resolve,g.reject,!b),"pending"===g.state()||r.isFunction(e[c]&&e[c].then)))return g.then();while(c--)P(e[c],h(c),g.reject);return g.promise()}});var Q=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;r.Deferred.exceptionHook=function(b,c){a.console&&a.console.warn&&b&&Q.test(b.name)&&a.console.warn("jQuery.Deferred exception: "+b.message,b.stack,c)},r.readyException=function(b){a.setTimeout(function(){throw b})};var R=r.Deferred();r.fn.ready=function(a){return R.then(a)["catch"](function(a){r.readyException(a)}),this},r.extend({isReady:!1,readyWait:1,ready:function(a){(a===!0?--r.readyWait:r.isReady)||(r.isReady=!0,a!==!0&&--r.readyWait>0||R.resolveWith(d,[r]))}}),r.ready.then=R.then;function S(){d.removeEventListener("DOMContentLoaded",S),
+a.removeEventListener("load",S),r.ready()}"complete"===d.readyState||"loading"!==d.readyState&&!d.documentElement.doScroll?a.setTimeout(r.ready):(d.addEventListener("DOMContentLoaded",S),a.addEventListener("load",S));var T=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===r.type(c)){e=!0;for(h in c)T(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,r.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(r(a),c)})),b))for(;h1,null,!0)},removeData:function(a){return this.each(function(){X.remove(this,a)})}}),r.extend({queue:function(a,b,c){var d;if(a)return b=(b||"fx")+"queue",d=W.get(a,b),c&&(!d||Array.isArray(c)?d=W.access(a,b,r.makeArray(c)):d.push(c)),d||[]},dequeue:function(a,b){b=b||"fx";var c=r.queue(a,b),d=c.length,e=c.shift(),f=r._queueHooks(a,b),g=function(){r.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return W.get(a,c)||W.access(a,c,{empty:r.Callbacks("once memory").add(function(){W.remove(a,[b+"queue",c])})})}}),r.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length\x20\t\r\n\f]+)/i,la=/^$|\/(?:java|ecma)script/i,ma={option:[1,""],thead:[1,""],col:[2,""],tr:[2,""],td:[3,""],_default:[0,"",""]};ma.optgroup=ma.option,ma.tbody=ma.tfoot=ma.colgroup=ma.caption=ma.thead,ma.th=ma.td;function na(a,b){var c;return c="undefined"!=typeof a.getElementsByTagName?a.getElementsByTagName(b||"*"):"undefined"!=typeof a.querySelectorAll?a.querySelectorAll(b||"*"):[],void 0===b||b&&B(a,b)?r.merge([a],c):c}function oa(a,b){for(var c=0,d=a.length;c-1)e&&e.push(f);else if(j=r.contains(f.ownerDocument,f),g=na(l.appendChild(f),"script"),j&&oa(g),c){k=0;while(f=g[k++])la.test(f.type||"")&&c.push(f)}return l}!function(){var a=d.createDocumentFragment(),b=a.appendChild(d.createElement("div")),c=d.createElement("input");c.setAttribute("type","radio"),c.setAttribute("checked","checked"),c.setAttribute("name","t"),b.appendChild(c),o.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="",o.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var ra=d.documentElement,sa=/^key/,ta=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,ua=/^([^.]*)(?:\.(.+)|)/;function va(){return!0}function wa(){return!1}function xa(){try{return d.activeElement}catch(a){}}function ya(a,b,c,d,e,f){var g,h;if("object"==typeof b){"string"!=typeof c&&(d=d||c,c=void 0);for(h in b)ya(a,h,c,d,b[h],f);return a}if(null==d&&null==e?(e=c,d=c=void 0):null==e&&("string"==typeof c?(e=d,d=void 0):(e=d,d=c,c=void 0)),e===!1)e=wa;else if(!e)return a;return 1===f&&(g=e,e=function(a){return r().off(a),g.apply(this,arguments)},e.guid=g.guid||(g.guid=r.guid++)),a.each(function(){r.event.add(this,b,e,d,c)})}r.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=W.get(a);if(q){c.handler&&(f=c,c=f.handler,e=f.selector),e&&r.find.matchesSelector(ra,e),c.guid||(c.guid=r.guid++),(i=q.events)||(i=q.events={}),(g=q.handle)||(g=q.handle=function(b){return"undefined"!=typeof r&&r.event.triggered!==b.type?r.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(L)||[""],j=b.length;while(j--)h=ua.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n&&(l=r.event.special[n]||{},n=(e?l.delegateType:l.bindType)||n,l=r.event.special[n]||{},k=r.extend({type:n,origType:p,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&r.expr.match.needsContext.test(e),namespace:o.join(".")},f),(m=i[n])||(m=i[n]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,o,g)!==!1||a.addEventListener&&a.addEventListener(n,g)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),r.event.global[n]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=W.hasData(a)&&W.get(a);if(q&&(i=q.events)){b=(b||"").match(L)||[""],j=b.length;while(j--)if(h=ua.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n){l=r.event.special[n]||{},n=(d?l.delegateType:l.bindType)||n,m=i[n]||[],h=h[2]&&new RegExp("(^|\\.)"+o.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;while(f--)k=m[f],!e&&p!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,o,q.handle)!==!1||r.removeEvent(a,n,q.handle),delete i[n])}else for(n in i)r.event.remove(a,n+b[j],c,d,!0);r.isEmptyObject(i)&&W.remove(a,"handle events")}},dispatch:function(a){var b=r.event.fix(a),c,d,e,f,g,h,i=new Array(arguments.length),j=(W.get(this,"events")||{})[b.type]||[],k=r.event.special[b.type]||{};for(i[0]=b,c=1;c=1))for(;j!==this;j=j.parentNode||this)if(1===j.nodeType&&("click"!==a.type||j.disabled!==!0)){for(f=[],g={},c=0;c-1:r.find(e,this,null,[j]).length),g[e]&&f.push(d);f.length&&h.push({elem:j,handlers:f})}return j=this,i\x20\t\r\n\f]*)[^>]*)\/>/gi,Aa=/