diff --git a/Gruntfile.js b/Gruntfile.js
index 3b8f3c5..70f052b 100644
--- a/Gruntfile.js
+++ b/Gruntfile.js
@@ -6,7 +6,7 @@ module.exports = function(grunt) {
grunt.initConfig({
// Metadata.
pkg: pkg,
- banner: grunt.file.read("copy.js")
+ banner: grunt.file.read("./src/copy.js")
.replace(/@VERSION/, pkg.version)
.replace(/@DATE/, grunt.template.today("yyyy-mm-dd")) + "\n",
// Task configuration.
diff --git a/README.md b/README.md
index cda34a0..fe5357b 100644
--- a/README.md
+++ b/README.md
@@ -1,4 +1,6 @@
savage
======
-JavaScript library for SVG.
\ No newline at end of file
+JavaScript library for SVG.
+
+API Reference is in `dist/reference.html`
\ No newline at end of file
diff --git a/dist/css/dr.css b/dist/css/dr.css
new file mode 100644
index 0000000..169fa17
--- /dev/null
+++ b/dist/css/dr.css
@@ -0,0 +1,140 @@
+#content section.code {
+ display: block;
+ font-weight: 400;
+ background: #181818;
+ -moz-border-radius: 10px;
+ -webkit-border-radius: 10px;
+ border-radius: 10px;
+}
+#content section.code pre code {
+ font-size: 14px;
+}
+code {
+ font-family: source-code-pro, Menlo, "Arial Unicode MS", sans-serif;
+}
+a.dr-hash,
+a.dr-sourceline {
+ -webkit-transition: opacity 0.2s linear;
+ color: #333;
+ font-family: Menlo, "Arial Unicode MS", sans-serif;
+ margin: 0 0 0 .3em;
+ opacity: 0;
+ text-decoration: none;
+}
+h2:hover a.dr-hash,
+h3:hover a.dr-hash,
+h4:hover a.dr-hash,
+h5:hover a.dr-hash,
+h2:hover a.dr-sourceline,
+h3:hover a.dr-sourceline,
+h4:hover a.dr-sourceline,
+h5:hover a.dr-sourceline {
+ opacity: 1;
+}
+.dr-param {
+ float: left;
+ min-width: 8em;
+}
+.dr-type {
+ float: left;
+}
+.dr-type em,
+.dr-returns em,
+.dr-property em {
+ -moz-border-radius: 5px;
+ -webkit-border-radius: 5px;
+ background: #ccc;
+ border-radius: 5px;
+ float: left;
+ font-size: .75em;
+ font-style: normal;
+ font-weight: 700;
+ margin: 0 8px 0 0;
+ min-width: 80px;
+ padding: 2px 5px;
+ text-align: center;
+}
+.dr-type em.amp,
+.dr-returns em.amp,
+.dr-property em.amp {
+ float: none;
+ background: none;
+ font-size: 1em;
+ font-weight: 400;
+ font-style: italic;
+ margin: 0;
+ padding: 0;
+ min-width: 0;
+}
+.dr-property em.dr-type {
+ margin: 4px 16px 0 0;
+}
+em.dr-type-string {
+ background: #e1edb1;
+ color: #3d4c00;
+}
+em.dr-type-object {
+ background: #edb1b1;
+ color: #4c0000;
+}
+em.dr-type-function {
+ background: #cfb1ed;
+ color: #26004c;
+}
+em.dr-type-number {
+ background: #b1c9ed;
+ color: #001e4c;
+}
+em.dr-type-boolean {
+ background: #b1edc9;
+ color: #004c1e;
+}
+em.dr-type-array {
+ background: #edd5b1;
+ color: #4c2d00;
+}
+.dr-optional {
+ display: none;
+}
+ol.dr-json {
+ background: #ddd;
+ list-style: none;
+ margin: 0 -30px;
+ padding: 16px 30px;
+ line-height: 1.5;
+}
+ol.dr-json .dr-json-key {
+ float: left;
+ min-width: 50px;
+ margin-right: 16px;
+}
+ol.dr-json .dr-json-description {
+ display: table;
+}
+ol.dr-json ol.dr-json {
+ margin: 0;
+ padding: 0 0 0 50px;
+}
+#pageNav li.dr-lvl1 a {
+ padding-left: 1em;
+}
+#pageNav li.dr-lvl2 a {
+ padding-left: 2em;
+}
+#pageNav li.dr-lvl3 a {
+ padding-left: 3em;
+}
+#pageNav li.dr-lvl4 a {
+ padding-left: 4em;
+}
+#pageNav li.dr-lvl5 a {
+ padding-left: 5em;
+}
+#pageNav li.dr-lvl6 a {
+ padding-left: 6em;
+}
+#pageNav ol {
+ list-style: none;
+ margin: 0;
+ padding: 0;
+}
\ No newline at end of file
diff --git a/dist/css/main.css b/dist/css/main.css
new file mode 100644
index 0000000..2d0bda3
--- /dev/null
+++ b/dist/css/main.css
@@ -0,0 +1,508 @@
+html,body{
+ margin:0;
+ padding:0;
+ height: 100%;
+}
+body {
+ font-family: source-sans-pro, sans-serif;
+ position: relative;
+ -webkit-font-smoothing: antialiased;
+}
+body.light {
+ background: #F4F4F4;
+}
+body.dark {
+ color: #F0F1F1;
+ background: #4A4D4E;
+}
+body.light {
+ color: #181919;
+}
+
+h1 {
+ font-weight: 600;
+}
+#wrapper {
+ width: 100%;
+ overflow-x: hidden;
+ background: inherit;
+ position: relative;
+}
+#site {
+ width: 100%;
+ position: relative;
+ z-index: 10;
+ background: inherit;
+ left: 0;
+ transition: all 0.2s ease-out;
+ -webkit-transition: all 0.2s ease-out;
+ transform: translate3d(0, 0, 0);
+ -webkit-transform: translate3d(0, 0, 0);
+}
+#site:before{
+ position: absolute;
+ content: '';
+ left: -4px;
+ height: 100%;
+ width: 4px;
+ background: #3B3E3E;
+}
+#site.open {
+ transform: translate3d(250px, 0, 0);
+ -webkit-transform: translate3d(250px, 0, 0);
+}
+pre {
+ font-family: source-code-pro, sans-serif;
+ font-size: 12px;
+}
+/* Main Header */
+#main-header {
+ color: #373435;
+ background: #fff;
+ height: 98px;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ padding: 10px 20px;
+ position: relative;
+}
+#main-header hgroup {
+ text-align: center;
+}
+#main-header hgroup h1 {
+ font-size: 40px;
+ margin: 5px 0 0;
+ letter-spacing: -.065em;
+ line-height: 1.1em;
+}
+#main-header hgroup a {
+ color: #464646;
+ text-decoration: none;
+}
+#main-header hgroup a:hover {
+ color: #000;
+}
+#main-header hgroup p {
+ font-size: 13px;
+ color: #999;
+ margin: 0;
+}
+#main-header nav {
+ display: none;
+}
+#slide-menu-button {
+ position: absolute;
+ top: 20px;
+ left: 20px;
+ display: inline-block;
+ vertical-align: top;
+ -webkit-box-sizing: border-box;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ -webkit-background-clip: padding;
+ -moz-background-clip: padding;
+ background-clip: padding-box;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ -o-text-overflow: ellipsis;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ padding: 0 0.5rem;
+ line-height: 2rem;
+ letter-spacing: 1px;
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ vertical-align: baseline;
+ -webkit-box-shadow: inset 0 1px #fff;
+ box-shadow: inset 0 1px #fff;
+ -webkit-border-radius: 3px;
+ border-radius: 3px;
+ width: 2.6rem;
+ height: 2.6rem;
+ line-height: 2.6rem;
+ border: 1px solid transparent;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+}
+#slide-menu:disabled,
+#slide-menu.is-disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+#slide-menu-button:active,
+#slide-menu-button.is-active {
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ background-color: #d3d7d7;
+ border: 1px solid #a5a8a8;
+ -webkit-box-shadow: inset 0 1px rgba(0,0,0,0.12);
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+#slide-menu-button span {
+ background-repeat: no-repeat;
+ background-image: url();
+ -webkit-background-size: cover;
+ -moz-background-size: cover;
+ background-size: cover;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ overflow: hidden;
+ vertical-align: middle;
+ width: 1.3rem;
+ height: 1.3rem;
+}
+#download-btn {
+ display: none;
+}
+/* Content */
+#content {
+ width: 100%;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ padding: 20px;
+}
+/* Code */
+#content section.code {
+ display: none;
+ background: #FFF;
+ border: 1px solid #E0E0E0;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ padding: 15px;
+ font-size: 12px;
+ -moz-border-radius: 1px;
+ -webkit-border-radius: 1px;
+ border-radius: 1px;
+ font-weight: 400;
+}
+article.component {
+ padding: 0 0 10px;
+}
+#content section.code h3 {
+ margin: 0;
+ font-size: 12px;
+ color: #000;
+ font-weight: 400;
+}
+#content header h2 {
+ font-weight: 300;
+ margin: 10px 0 25px;
+ font-size: 20px;
+ position: relative;
+ display: inline-block;
+ padding-right: 10px;
+}
+body.light #content header h2 {
+ background: #F4F4F4;
+}
+body.dark #content header h2 {
+ background: #4A4D4E;
+}
+#content header{
+ position: relative;
+}
+#content header:before {
+ content: '';
+ width: 100%;
+ display: block;
+ position: absolute;
+ left: 0;
+ top: 23px;
+}
+body.light #content header:before {
+ border-bottom: 1px solid #E0E0E0;
+}
+body.dark #content header:before {
+ border-bottom: 1px solid #58595A;
+}
+#content pre {
+ padding: 0;
+ margin: 2px 0 10px;
+}
+.showcode {
+ margin: 10px 0;
+}
+.showcode a, section.examples a {
+ color: #288edf;
+ text-decoration: none;
+}
+.showcode a:hover, section.examples a:hover {
+ text-decoration: underline;
+}
+section.examples ul {
+ margin: 0 0 20px;
+ padding: 0 0 0 20px;
+}
+section.examples h4 {
+ margin-bottom: 5px;
+}
+section.examples li {
+ color: #58595A;
+}
+/* Side Nav */
+#sideNav {
+ background: #4A4D4E;
+ position: absolute;
+ width: 100%;
+ z-index: 1;
+ height: 100%;
+ left: 0;
+}
+#sideNav ul {
+ list-style: none;
+ margin: 0;
+ padding: 0;
+}
+#sideNav li a {
+ color: #F0F1F1;
+ display: block;
+ height: 46px;
+ font-size: 16px;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ padding: 12px 0 0 20px;
+ text-decoration: none;
+}
+#sideNav nav.site, #sideNav .combo {
+ border-bottom: 1px solid #58595A;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ padding: 10px;
+ display: block;
+}
+#pageNav li {
+ border-bottom: 1px solid #58595A;
+}
+
+select.docNav {
+ -moz-border-radius: 3px;
+ -webkit-border-radius: 3px;
+ border-radius: 3px;
+ background: #595B5B;
+ background-image: none;
+ box-shadow: 0 0 0 1px #303233;
+ border: none;
+ border-top: 2px solid #666767;
+ color: #FFF;
+ text-shadow: 0 -1px 0 #000;
+ overflow: hidden;
+ font-size: 14px;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ padding: 20px;
+ -webkit-appearance: none;
+ -moz-appearance: button;
+}
+@media screen and (min-width: 650px) {
+ #site.open {
+ transform: translate3d(0, 0, 0);
+ -webkit-transform: translate3d(0, 0, 0);
+ }
+ #main-header nav {
+ display: inline-block;
+ position: absolute;
+ right: 0;
+ top: 40px;
+ }
+ #main-header ul {
+ list-style: none;
+ }
+ #main-header nav li {
+ display: inline-block;
+ margin: 0 18px;
+ }
+ #main-header nav li#download-btn {
+ display: none;
+ }
+ #main-header nav li a {
+ text-decoration: none;
+ font-size: 20px;
+ color: #7F7F7F;
+ }
+ #main-header nav li.selected a {
+ color: #373435;
+ }
+ #slide-menu-button{
+ display: none;
+ }
+ #main-header hgroup {
+ text-align: left;
+ position: absolute;
+ display: inline-block;
+ top: 24px;
+ }
+ #main-header hgroup h1 {
+ font-size: 60px;
+ }
+ #main-header hgroup p {
+ font-size: 15px;
+ }
+ #main-header {
+ color: #373435;
+ background: #fff;
+ height: 148px;
+ }
+ #content {
+ padding-left: 240px;
+ }
+ /* Side Nav */
+ #sideNav {
+ background: transparent;
+ width: 220px;
+ z-index: 20;
+ left: 10px;
+ top: 150px;
+ height: auto;
+ }
+ #sideNav nav.site {
+ display: none;
+ }
+ #sideNav .combo {
+ border-bottom: none;
+ padding: 36px 0;
+ }
+ #sideNav li a {
+ padding: 12px 0 0 10px;
+ }
+ body.light #sideNav li a {
+ color: #797B7B;
+ }
+ body.light #pageNav li {
+ border-bottom: 1px solid #E0E0E0;
+ }
+ select.docNav {
+ background: #595B5B;
+ box-shadow: 0 0 0 1px #303233;
+ border: none;
+ border-top: 2px solid #666767;
+ color: #FFF;
+ text-shadow: 0 -1px 0 #000;
+ padding: 3px 20px 4px 8px;
+ -webkit-appearance: none;
+ }
+ body.light select.docNav {
+ box-shadow: 0 0 0 1px #949696;
+ background: #DDE1E1;
+ border-top: 1px solid #FFF;
+ color: #454545;
+ text-shadow: 0 -1px 0 #FFF;
+ width: 192px;
+ }
+}
+@media screen and (min-width: 880px) {
+ #content {
+ padding-left: 300px;
+ }
+ #sideNav li a {
+ display: block;
+ height: 60px;
+ padding: 22px 0 0 10px;
+ text-decoration: none;
+ }
+ #content header h2 {
+ font-size: 28px;
+ }
+ #content header:before {
+ top: 30px;
+ }
+ section.code div {
+ display: inline-block;
+ width: 48%;
+ vertical-align: top;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ }
+ section.code div:first-child {
+ padding-right: 5px;
+ }
+ section.code div:last-child {
+ padding-left: 5px;
+ }
+ .max-width {
+ max-width: 1180px;
+ position: relative;
+ margin: 0 auto;
+ }
+ header#main-header .max-width {
+ top: -10px;
+ }
+ #main-header nav li a {
+ font-size: 22px;
+ }
+ #main-header nav {
+ display: inline-block;
+ }
+
+ #main-header nav li {
+ margin: 0 25px;
+ }
+ #main-header nav li:last-child {
+ margin-right: 0;
+ }
+}
+@media screen and (min-width: 940px) {
+ #main-header nav li#download-btn {
+ display: inline-block;
+ }
+ #main-header nav li a#download-btn{
+ position:relative;
+ top: -15px;
+ display:inline-block;
+ box-sizing:border-box;
+ -moz-box-sizing:border-box;
+ background-clip:padding-box;
+ font:inherit;
+ background:transparent;
+ -webkit-user-select:none;
+ -moz-user-select:none;
+ user-select:none;
+ text-overflow:ellipsis;
+ white-space:nowrap;
+ overflow:hidden;
+ font-size:16px;
+ line-height:3rem;
+ letter-spacing:1px;
+ color:#454545;
+ text-shadow:0 1px #fff;
+ vertical-align:top;
+ background-color:#e5e9e8;
+ box-shadow:inset 0 1px #fff;
+ border:1px solid #a5a8a8;
+ border-radius:6px;
+ margin:0;
+ padding:0 1.25rem;
+ }
+ #main-header nav li a#download-btn, #main-header nav li a#download-btn:hover {
+ border:1px solid #143250;
+ background-color:#288edf;
+ box-shadow:inset 0 1px rgba(255,255,255,0.36);
+ color:#fff;
+ font-weight:500;
+ text-shadow:0 -1px rgba(0,0,0,0.36);
+ }
+ #main-header nav li a#download-btn:hover {
+ background-color:#2f9cf3;
+ }
+ #main-header nav li a#download-btn:active, #main-header nav li a#download-btn.is-active {
+ background-color:#0380e8;
+ box-shadow:inset 0 1px rgba(0,0,0,0.12);
+ }
+ #main-header nav li a#download-btn:disabled, #main-header nav li a#download-btn.is-disabled {
+ opacity:.3;
+ cursor:default;
+ pointer-events:none;
+ }
+}
+
+
+
diff --git a/dist/css/prism.css b/dist/css/prism.css
new file mode 100644
index 0000000..b508b61
--- /dev/null
+++ b/dist/css/prism.css
@@ -0,0 +1,168 @@
+/**
+ * prism.js Twilight theme
+ * Based (more or less) on the Twilight theme originally of Textmate fame.
+ * @author Remy Bach
+ */
+code[class*="language-"],
+pre[class*="language-"] {
+ color: white;
+ direction: ltr;
+ font-family: source-code-pro, Consolas, Monaco, 'Andale Mono', monospace;
+ text-align: left;
+ text-shadow: 0 -.1em .2em black;
+ white-space: pre;
+ word-spacing: normal;
+
+ -moz-tab-size: 4;
+ -o-tab-size: 4;
+ tab-size: 4;
+
+ -webkit-hyphens: none;
+ -moz-hyphens: none;
+ -ms-hyphens: none;
+ hyphens: none;
+}
+
+pre[class*="language-"],
+:not(pre) > code[class*="language-"] {
+ background:#181818;
+}
+
+/* Code blocks */
+pre[class*="language-"] {
+ margin: .5em 0;
+ overflow: auto;
+}
+pre[class*="language-"]::selection { /* Safari */
+ background:hsl(200, 4%, 16%); /* #282A2B */
+}
+pre[class*="language-"]::selection { /* Firefox */
+ background:hsl(200, 4%, 16%); /* #282A2B */
+}
+
+/* Inline code */
+:not(pre) > code[class*="language-"] {
+ border-radius: .3em;
+ border: .13em solid hsl(0,0%,33%); /* #545454 */
+ box-shadow: 1px 1px .3em -.1em black inset;
+ padding: .15em .2em .05em;
+}
+
+.token.comment,
+.token.prolog,
+.token.doctype,
+.token.cdata {
+ color: hsl(0, 0%, 47%); /* #777777 */
+}
+
+.token.punctuation {
+ opacity: .7;
+}
+
+.namespace {
+ opacity: .7;
+}
+
+.token.tag,
+.token.boolean,
+.token.number {
+ color: hsl(14, 58%, 55%); /* #CF6A4C */
+}
+
+.token.keyword,
+.token.property,
+.token.selector {
+ color:hsl(53, 89%, 79%); /* #F9EE98 */
+}
+.token.attr-name,
+.token.attr-value,
+.token.string,
+.token.operator,
+.token.entity,
+.token.url,
+.language-css .token.string,
+.style .token.string {
+ color:hsl(76, 21%, 52%); /* #8F9D6A */
+}
+
+.token.atrule {
+ color:hsl(218, 22%, 55%); /* #7587A6 */
+}
+
+.token.regex,
+.token.important {
+ color: hsl(42, 75%, 65%); /* #E9C062 */
+}
+
+.token.important {
+ font-weight: bold;
+}
+
+.token.entity {
+ cursor: help;
+}
+pre[data-line] {
+ padding: 1em 0 1em 3em;
+ position: relative;
+}
+
+/* Markup */
+.language-markup .token.tag,
+.language-markup .token.attr-name,
+.language-markup .token.punctuation {
+ color: hsl(33, 33%, 52%); /* #AC885B */
+}
+
+/* Text Selection colour */
+::selection {
+ background: hsla(0,0%,93%,0.15); /* #EDEDED */
+}
+::-moz-selection {
+ background: hsla(0,0%,93%,0.15); /* #EDEDED */
+}
+
+/* Make the tokens sit above the line highlight so the colours don't look faded. */
+.token {
+ position:relative;
+ z-index:1;
+}
+.line-highlight {
+ background: -moz-linear-gradient(left, hsla(0, 0%, 33%,.1) 70%, hsla(0, 0%, 33%,0)); /* #545454 */
+ background: -o-linear-gradient(left, hsla(0, 0%, 33%,.1) 70%, hsla(0, 0%, 33%,0)); /* #545454 */
+ background: -webkit-linear-gradient(left, hsla(0, 0%, 33%,.1) 70%, hsla(0, 0%, 33%,0)); /* #545454 */
+ background: hsla(0, 0%, 33%, 0.25); /* #545454 */
+ background: linear-gradient(left, hsla(0, 0%, 33%,.1) 70%, hsla(0, 0%, 33%,0)); /* #545454 */
+ border-bottom:1px dashed hsl(0, 0%, 33%); /* #545454 */
+ border-top:1px dashed hsl(0, 0%, 33%); /* #545454 */
+ left: 0;
+ line-height: inherit;
+ margin-top: 0.75em; /* Same as .prism’s padding-top */
+ padding: inherit 0;
+ pointer-events: none;
+ position: absolute;
+ right: 0;
+ white-space: pre;
+ z-index:0;
+}
+.line-highlight:before,
+.line-highlight[data-end]:after {
+ background-color: hsl(215, 15%, 59%); /* #8794A6 */
+ border-radius: 999px;
+ box-shadow: 0 1px white;
+ color: hsl(24, 20%, 95%); /* #F5F2F0 */
+ content: attr(data-start);
+ font: bold 65%/1.5 sans-serif;
+ left: .6em;
+ min-width: 1em;
+ padding: 0 .5em;
+ position: absolute;
+ text-align: center;
+ text-shadow: none;
+ top: .4em;
+ vertical-align: .3em;
+}
+.line-highlight[data-end]:after {
+ bottom: .4em;
+ content: attr(data-end);
+ top: auto;
+}
\ No newline at end of file
diff --git a/dist/css/topcoat-desktop-light.css b/dist/css/topcoat-desktop-light.css
new file mode 100644
index 0000000..1e221af
--- /dev/null
+++ b/dist/css/topcoat-desktop-light.css
@@ -0,0 +1,2883 @@
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.button-bar {
+ display: table;
+ table-layout: fixed;
+ white-space: no-wrap;
+ margin: 0;
+ padding: 0;
+}
+
+.button-bar__item {
+ display: table-cell;
+ width: auto;
+ border-radius: 0;
+}
+
+.button_bar__item > input {
+ position: absolute;
+ overflow: hidden;
+ padding: 0;
+ border: 0;
+ opacity: 0.001;
+ z-index: 1;
+ vertical-align: top;
+ outline: none;
+}
+
+.button-bar__button {
+ border-radius: inherit;
+}
+
+.button-bar__item:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.button,
+.topcoat-button,
+.topcoat-button--quiet,
+.topcoat-button--large,
+.topcoat-button--large--quiet,
+.topcoat-button--cta,
+.topcoat-button--large--cta,
+.topcoat-button-bar__button,
+.topcoat-button-bar__button--large {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ text-decoration: none;
+}
+
+.button--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.button--disabled,
+.topcoat-button:disabled,
+.topcoat-button--quiet:disabled,
+.topcoat-button--large:disabled,
+.topcoat-button--large--quiet:disabled,
+.topcoat-button--cta:disabled,
+.topcoat-button--large--cta:disabled,
+.topcoat-button-bar__button:disabled,
+.topcoat-button-bar__button--large:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+.topcoat-button,
+.topcoat-button--quiet,
+.topcoat-button--large,
+.topcoat-button--large--quiet,
+.topcoat-button--cta,
+.topcoat-button--large--cta,
+.topcoat-button-bar__button,
+.topcoat-button-bar__button--large {
+ padding: 0 1.25rem;
+ font-size: 16px;
+ line-height: 3rem;
+ letter-spacing: 1px;
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ vertical-align: top;
+ background-color: #e5e9e8;
+ box-shadow: inset 0 1px #fff;
+ border: 1px solid #a5a8a8;
+ border-radius: 6px;
+}
+
+.topcoat-button:hover,
+.topcoat-button--quiet:hover,
+.topcoat-button--large:hover,
+.topcoat-button--large--quiet:hover,
+.topcoat-button-bar__button:hover,
+.topcoat-button-bar__button--large:hover {
+ background-color: #edf1f1;
+}
+
+.topcoat-button:active,
+.topcoat-button--large:active,
+.topcoat-button-bar__button:active,
+.topcoat-button-bar__button--large:active,
+:checked + .topcoat-button-bar__button {
+ background-color: #d3d7d7;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+.topcoat-button:focus,
+.topcoat-button--quiet:focus,
+.topcoat-button--large:focus,
+.topcoat-button--large--quiet:focus,
+.topcoat-button--cta:focus,
+.topcoat-button--large--cta:focus,
+.topcoat-button-bar__button:focus,
+.topcoat-button-bar__button--large:focus {
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+ outline: 0;
+}
+
+.topcoat-button--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.topcoat-button--quiet:hover,
+.topcoat-button--large--quiet:hover {
+ text-shadow: 0 1px #fff;
+ border: 1px solid #a5a8a8;
+ box-shadow: inset 0 1px #fff;
+}
+
+.topcoat-button--quiet:active,
+.topcoat-button--large--quiet:active {
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ background-color: #d3d7d7;
+ border: 1px solid #a5a8a8;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+.topcoat-button--large,
+.topcoat-button--large--quiet,
+.topcoat-button-bar__button--large {
+ font-size: 1.3rem;
+ font-weight: 400;
+ line-height: 4.375rem;
+ padding: 0 1.25rem;
+}
+
+.topcoat-button--large--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.topcoat-button--cta,
+.topcoat-button--large--cta {
+ border: 1px solid #143250;
+ background-color: #288edf;
+ box-shadow: inset 0 1px rgba(255,255,255,0.36);
+ color: #fff;
+ font-weight: 500;
+ text-shadow: 0 -1px rgba(0,0,0,0.36);
+}
+
+.topcoat-button--cta:hover,
+.topcoat-button--large--cta:hover {
+ background-color: #509bef;
+}
+
+.topcoat-button--cta:active,
+.topcoat-button--large--cta:active {
+ background-color: #0380e8;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+.topcoat-button--large--cta {
+ font-size: 1.3rem;
+ font-weight: 400;
+ line-height: 4.375rem;
+ padding: 0 1.25rem;
+}
+
+.button-bar,
+.topcoat-button-bar {
+ display: table;
+ table-layout: fixed;
+ white-space: no-wrap;
+ margin: 0;
+ padding: 0;
+}
+
+.button-bar__item,
+.topcoat-button-bar__item {
+ display: table-cell;
+ width: auto;
+ border-radius: 0;
+}
+
+.button_bar__item > input,
+.topcoat-button-bar__item > input {
+ position: absolute;
+ overflow: hidden;
+ padding: 0;
+ border: 0;
+ opacity: 0.001;
+ z-index: 1;
+ vertical-align: top;
+ outline: none;
+}
+
+.button-bar__button {
+ border-radius: inherit;
+}
+
+.button-bar__item:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/* topdoc
+ name: Button Bar
+ description: Component of grouped buttons
+ modifiers:
+ :disabled: Disabled state
+ markup:
+
+ examples:
+ mobile button bar: http://codepen.io/Topcoat/pen/kdKyg
+ tags:
+ - desktop
+ - light
+ - dark
+ - mobile
+ - button
+ - group
+ - bar
+*/
+
+.topcoat-button-bar > .topcoat-button-bar__item:first-child {
+ border-top-left-radius: 6px;
+ border-bottom-left-radius: 6px;
+}
+
+.topcoat-button-bar > .topcoat-button-bar__item:last-child {
+ border-top-right-radius: 6px;
+ border-bottom-right-radius: 6px;
+}
+
+.topcoat-button-bar__item:first-child > .topcoat-button-bar__button,
+.topcoat-button-bar__item:first-child > .topcoat-button-bar__button--large {
+ border-right: none;
+}
+
+.topcoat-button-bar__item:last-child > .topcoat-button-bar__button,
+.topcoat-button-bar__item:last-child > .topcoat-button-bar__button--large {
+ border-left: none;
+}
+
+.topcoat-button-bar__button {
+ border-radius: inherit;
+}
+
+.topcoat-button-bar__button:focus,
+.topcoat-button-bar__button--large:focus {
+ z-index: 1;
+}
+
+/* topdoc
+ name: Large Button Bar
+ description: A button bar, only larger
+ modifiers:
+ :disabled: Disabled state
+ markup:
+
+ tags:
+ - desktop
+ - light
+ - dark
+ - mobile
+ - button
+ - group
+ - bar
+ - large
+*/
+
+.topcoat-button-bar__button--large {
+ border-radius: inherit;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.button {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ text-decoration: none;
+}
+
+.button--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.button--disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.button,
+.topcoat-button,
+.topcoat-button--quiet,
+.topcoat-button--large,
+.topcoat-button--large--quiet,
+.topcoat-button--cta,
+.topcoat-button--large--cta {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ text-decoration: none;
+}
+
+.button--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.button--disabled,
+.topcoat-button:disabled,
+.topcoat-button--quiet:disabled,
+.topcoat-button--large:disabled,
+.topcoat-button--large--quiet:disabled,
+.topcoat-button--cta:disabled,
+.topcoat-button--large--cta:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/* topdoc
+ name: Button
+ description: A simple button
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+ Button
+ Button
+ examples:
+ mobile button: http://codepen.io/Topcoat/pen/DpKtf
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+*/
+
+.topcoat-button,
+.topcoat-button--quiet,
+.topcoat-button--large,
+.topcoat-button--large--quiet,
+.topcoat-button--cta,
+.topcoat-button--large--cta {
+ padding: 0 1.25rem;
+ font-size: 16px;
+ line-height: 3rem;
+ letter-spacing: 1px;
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ vertical-align: top;
+ background-color: #e5e9e8;
+ box-shadow: inset 0 1px #fff;
+ border: 1px solid #a5a8a8;
+ border-radius: 6px;
+}
+
+.topcoat-button:hover,
+.topcoat-button--quiet:hover,
+.topcoat-button--large:hover,
+.topcoat-button--large--quiet:hover {
+ background-color: #edf1f1;
+}
+
+.topcoat-button:active,
+.topcoat-button--large:active {
+ background-color: #d3d7d7;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+.topcoat-button:focus,
+.topcoat-button--quiet:focus,
+.topcoat-button--large:focus,
+.topcoat-button--large--quiet:focus,
+.topcoat-button--cta:focus,
+.topcoat-button--large--cta:focus {
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+ outline: 0;
+}
+
+/* topdoc
+ name: Quiet Button
+ description: A simple, yet quiet button
+ modifiers:
+ :active: Quiet button active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+ Button
+ Button
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - quiet
+*/
+
+.topcoat-button--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.topcoat-button--quiet:hover,
+.topcoat-button--large--quiet:hover {
+ text-shadow: 0 1px #fff;
+ border: 1px solid #a5a8a8;
+ box-shadow: inset 0 1px #fff;
+}
+
+.topcoat-button--quiet:active,
+.topcoat-button--large--quiet:active {
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ background-color: #d3d7d7;
+ border: 1px solid #a5a8a8;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+/* topdoc
+ name: Large Button
+ description: A big ol button
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+ Button
+ Button
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - large
+*/
+
+.topcoat-button--large,
+.topcoat-button--large--quiet {
+ font-size: 1.3rem;
+ font-weight: 400;
+ line-height: 4.375rem;
+ padding: 0 1.25rem;
+}
+
+/* topdoc
+ name: Large Quiet Button
+ description: A large, yet quiet button
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+ Button
+ Button
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - large
+ - quiet
+*/
+
+.topcoat-button--large--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+/* topdoc
+ name: Call To Action Button
+ description: A CALL TO ARMS, er, ACTION!
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+ Button
+ Button
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - call to action
+*/
+
+.topcoat-button--cta,
+.topcoat-button--large--cta {
+ border: 1px solid #143250;
+ background-color: #288edf;
+ box-shadow: inset 0 1px rgba(255,255,255,0.36);
+ color: #fff;
+ font-weight: 500;
+ text-shadow: 0 -1px rgba(0,0,0,0.36);
+}
+
+.topcoat-button--cta:hover,
+.topcoat-button--large--cta:hover {
+ background-color: #509bef;
+}
+
+.topcoat-button--cta:active,
+.topcoat-button--large--cta:active {
+ background-color: #0380e8;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+/* topdoc
+ name: Large Call To Action Button
+ description: Like call to action, but bigger
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+ Button
+ Button
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - large
+ - call to action
+*/
+
+.topcoat-button--large--cta {
+ font-size: 1.3rem;
+ font-weight: 400;
+ line-height: 4.375rem;
+ padding: 0 1.25rem;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+input[type="checkbox"] {
+ position: absolute;
+ overflow: hidden;
+ padding: 0;
+ border: 0;
+ opacity: 0.001;
+ z-index: 1;
+ vertical-align: top;
+ outline: none;
+}
+
+.checkbox {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.checkbox__label {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.checkbox--disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+.checkbox:before,
+.checkbox:after {
+ content: '';
+ position: absolute;
+}
+
+.checkbox:before {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+input[type="checkbox"] {
+ position: absolute;
+ overflow: hidden;
+ padding: 0;
+ border: 0;
+ opacity: 0.001;
+ z-index: 1;
+ vertical-align: top;
+ outline: none;
+}
+
+.checkbox,
+.topcoat-checkbox__checkmark {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.checkbox__label,
+.topcoat-checkbox {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.checkbox--disabled,
+input[type="checkbox"]:disabled + .topcoat-checkbox__checkmark {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+.checkbox:before,
+.checkbox:after,
+.topcoat-checkbox__checkmark:before,
+.topcoat-checkbox__checkmark:after {
+ content: '';
+ position: absolute;
+}
+
+.checkbox:before,
+.topcoat-checkbox__checkmark:before {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+}
+
+/* topdoc
+ name: Checkbox
+ description: Default skin for Topcoat checkbox
+ modifiers:
+ :focus: Focus state
+ :disabled: Disabled state
+ markup:
+
+
+
+ Default
+
+
+
+
+
+
+ Disabled
+
+ examples:
+ mobile checkbox: http://codepen.io/Topcoat/pen/piHcs
+ tags:
+ - desktop
+ - light
+ - mobile
+ - checkbox
+*/
+
+.topcoat-checkbox__checkmark {
+ height: 2rem;
+}
+
+input[type="checkbox"] {
+ height: 2rem;
+ width: 2rem;
+ margin-top: 0;
+ margin-right: -2rem;
+ margin-bottom: -2rem;
+ margin-left: 0;
+}
+
+input[type="checkbox"]:checked + .topcoat-checkbox__checkmark:after {
+ opacity: 1;
+}
+
+.topcoat-checkbox {
+ line-height: 2rem;
+}
+
+.topcoat-checkbox__checkmark:before {
+ width: 2rem;
+ height: 2rem;
+ background: #e5e9e8;
+ border: 1px solid #a5a8a8;
+ border-radius: 3px;
+ box-shadow: inset 0 1px #fff;
+}
+
+.topcoat-checkbox__checkmark {
+ width: 2rem;
+ height: 2rem;
+}
+
+.topcoat-checkbox__checkmark:after {
+ top: 1px;
+ left: 2px;
+ opacity: 0;
+ width: 28px;
+ height: 11px;
+ background: transparent;
+ border: 7px solid #666;
+ border-width: 7px;
+ border-top: none;
+ border-right: none;
+ border-radius: 2px;
+ -webkit-transform: rotate(-50deg);
+ -ms-transform: rotate(-50deg);
+ transform: rotate(-50deg);
+}
+
+input[type="checkbox"]:focus + .topcoat-checkbox__checkmark:before {
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.button,
+.topcoat-icon-button,
+.topcoat-icon-button--quiet,
+.topcoat-icon-button--large,
+.topcoat-icon-button--large--quiet {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ text-decoration: none;
+}
+
+.button--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.button--disabled,
+.topcoat-icon-button:disabled,
+.topcoat-icon-button--quiet:disabled,
+.topcoat-icon-button--large:disabled,
+.topcoat-icon-button--large--quiet:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/* topdoc
+ name: Icon Button
+ description: Like button, but it has an icon.
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+
+
+
+
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - icon
+*/
+
+.topcoat-icon-button,
+.topcoat-icon-button--quiet,
+.topcoat-icon-button--large,
+.topcoat-icon-button--large--quiet {
+ padding: 0 0.75rem;
+ line-height: 3rem;
+ letter-spacing: 1px;
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ vertical-align: baseline;
+ background-color: #e5e9e8;
+ box-shadow: inset 0 1px #fff;
+ border: 1px solid #a5a8a8;
+ border-radius: 6px;
+}
+
+.topcoat-icon-button:hover,
+.topcoat-icon-button--quiet:hover,
+.topcoat-icon-button--large:hover,
+.topcoat-icon-button--large--quiet:hover {
+ background-color: #edf1f1;
+}
+
+.topcoat-icon-button:active {
+ background-color: #d3d7d7;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+.topcoat-icon-button:focus,
+.topcoat-icon-button--quiet:focus,
+.topcoat-icon-button--quiet:hover:focus,
+.topcoat-icon-button--large:focus,
+.topcoat-icon-button--large--quiet:focus,
+.topcoat-icon-button--large--quiet:hover:focus {
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+ outline: 0;
+}
+
+/* topdoc
+ name: Quiet Icon Button
+ description: Like quiet button, but it has an icon.
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+
+
+
+
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - icon
+ - quiet
+*/
+
+.topcoat-icon-button--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.topcoat-icon-button--quiet:hover,
+.topcoat-icon-button--large--quiet:hover {
+ text-shadow: 0 1px #fff;
+ border: 1px solid #a5a8a8;
+ box-shadow: inset 0 1px #fff;
+}
+
+.topcoat-icon-button--quiet:active,
+.topcoat-icon-button--large--quiet:active {
+ color: #454545;
+ text-shadow: 0 1px #fff;
+ background-color: #d3d7d7;
+ border: 1px solid #a5a8a8;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+/* topdoc
+ name: Large Icon Button
+ description: Like large button, but it has an icon.
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ :focus: Focused
+ markup:
+
+
+
+
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - icon
+ - large
+*/
+
+.topcoat-icon-button--large,
+.topcoat-icon-button--large--quiet {
+ width: 4.375rem;
+ height: 4.375rem;
+ line-height: 4.375rem;
+}
+
+.topcoat-icon-button--large:active {
+ background-color: #d3d7d7;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+}
+
+/* topdoc
+ name: Large Quiet Icon Button
+ description: Like large button, but it has an icon and this one is quiet.
+ modifiers:
+ :active: Active state
+ :disabled: Disabled state
+ :hover: Hover state
+ markup:
+
+
+
+
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - button
+ - icon
+ - large
+ - quiet
+*/
+
+.topcoat-icon-button--large--quiet {
+ background: transparent;
+ border: 1px solid transparent;
+ box-shadow: none;
+}
+
+.topcoat-icon,
+.topcoat-icon--large {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ overflow: hidden;
+ width: 1.62rem;
+ height: 1.62rem;
+ vertical-align: middle;
+ top: -1px;
+}
+
+.topcoat-icon--large {
+ width: 2.499999998125rem;
+ height: 2.499999998125rem;
+ top: -2px;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.input {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ vertical-align: top;
+ outline: none;
+}
+
+.input:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.list {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ overflow: auto;
+ -webkit-overflow-scrolling: touch;
+}
+
+.list__header {
+ margin: 0;
+}
+
+.list__container {
+ padding: 0;
+ margin: 0;
+ list-style-type: none;
+}
+
+.list__item {
+ margin: 0;
+ padding: 0;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.list,
+.topcoat-list {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ overflow: auto;
+ -webkit-overflow-scrolling: touch;
+}
+
+.list__header,
+.topcoat-list__header {
+ margin: 0;
+}
+
+.list__container,
+.topcoat-list__container {
+ padding: 0;
+ margin: 0;
+ list-style-type: none;
+}
+
+.list__item,
+.topcoat-list__item {
+ margin: 0;
+ padding: 0;
+}
+
+/* topdoc
+ name: List
+ description: Topcoat default list skin
+ markup:
+
+
+
+
+ Item
+
+
+ Item
+
+
+ Item
+
+
+
+ tags:
+ - mobile
+ - list
+*/
+
+.topcoat-list {
+ border-top: 1px solid #bcbfbf;
+ border-bottom: 1px solid #eff1f1;
+ background-color: #dfe2e2;
+}
+
+.topcoat-list__header {
+ padding: 4px 20px;
+ font-size: 0.9em;
+ font-weight: 400;
+ background-color: #cccfcf;
+ color: #656565;
+ text-shadow: 0 1px 0 rgba(255,255,255,0.5);
+ border-top: 1px solid rgba(255,255,255,0.5);
+ border-bottom: 1px solid rgba(255,255,255,0.23);
+}
+
+.topcoat-list__container {
+ border-top: 1px solid #bcbfbf;
+ color: #454545;
+}
+
+.topcoat-list__item {
+ padding: 1.25rem;
+ border-top: 1px solid #eff1f1;
+ border-bottom: 1px solid #bcbfbf;
+}
+
+.topcoat-list__item:first-child {
+ border-top: 1px solid rgba(0,0,0,0.05);
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.navigation-bar {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ white-space: nowrap;
+ overflow: hidden;
+ word-spacing: 0;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.navigation-bar__item {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+}
+
+.navigation-bar__title {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.navigation-bar,
+.topcoat-navigation-bar {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ white-space: nowrap;
+ overflow: hidden;
+ word-spacing: 0;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.navigation-bar__item,
+.topcoat-navigation-bar__item {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+}
+
+.navigation-bar__title,
+.topcoat-navigation-bar__title {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+}
+
+/* topdoc
+ name: Navigation Bar
+ description: A place where navigation goes to drink
+ markup:
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - navigation
+ - bar
+*/
+
+.topcoat-navigation-bar {
+ height: 4.375rem;
+ padding-left: 1rem;
+ padding-right: 1rem;
+ background: #e5e9e8;
+ color: #000;
+ box-shadow: inset 0 -1px #b9bcbc, 0 1px #d4d6d6;
+}
+
+.topcoat-navigation-bar__item {
+ margin: 0;
+ line-height: 4.375rem;
+ vertical-align: top;
+}
+
+.topcoat-navigation-bar__title {
+ font-size: 1.3rem;
+ font-weight: 400;
+ color: #000;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+input[type="radio"] {
+ position: absolute;
+ overflow: hidden;
+ padding: 0;
+ border: 0;
+ opacity: 0.001;
+ z-index: 1;
+ vertical-align: top;
+ outline: none;
+}
+
+.radio-button {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.radio-button__label {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.radio-button:before,
+.radio-button:after {
+ content: '';
+ position: absolute;
+ border-radius: 100%;
+}
+
+.radio-button:after {
+ top: 50%;
+ left: 50%;
+ -webkit-transform: translate(-50%, -50%);
+ -ms-transform: translate(-50%, -50%);
+ transform: translate(-50%, -50%);
+}
+
+.radio-button:before {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+}
+
+.radio-button--disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+input[type="radio"] {
+ position: absolute;
+ overflow: hidden;
+ padding: 0;
+ border: 0;
+ opacity: 0.001;
+ z-index: 1;
+ vertical-align: top;
+ outline: none;
+}
+
+.radio-button,
+.topcoat-radio-button__checkmark {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.radio-button__label,
+.topcoat-radio-button {
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.radio-button:before,
+.radio-button:after,
+.topcoat-radio-button__checkmark:before,
+.topcoat-radio-button__checkmark:after {
+ content: '';
+ position: absolute;
+ border-radius: 100%;
+}
+
+.radio-button:after,
+.topcoat-radio-button__checkmark:after {
+ top: 50%;
+ left: 50%;
+ -webkit-transform: translate(-50%, -50%);
+ -ms-transform: translate(-50%, -50%);
+ transform: translate(-50%, -50%);
+}
+
+.radio-button:before,
+.topcoat-radio-button__checkmark:before {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+}
+
+.radio-button--disabled,
+input[type="radio"]:disabled + .topcoat-radio-button__checkmark {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/* topdoc
+ name: Radio Button
+ description: A button that can play music, but usually just plays ads.
+ modifiers:
+ markup:
+
+
+
+
+
+
+
+
+
+ Left label
+
+
+
+
+
+
+
+
+
+ Right label
+
+
+
+
+
+
+
+ Disabled
+
+ examples:
+ Mobile Radio Button: http://codepen.io/Topcoat/pen/HDcJj
+ tags:
+ - desktop
+ - light
+ - mobile
+ - Radio
+*/
+
+input[type="radio"] {
+ height: 1.875rem;
+ width: 1.875rem;
+ margin-top: 0;
+ margin-right: -1.875rem;
+ margin-bottom: -1.875rem;
+ margin-left: 0;
+}
+
+input[type="radio"]:checked + .topcoat-radio-button__checkmark:after {
+ opacity: 1;
+}
+
+.topcoat-radio-button {
+ color: #454545;
+ line-height: 1.875rem;
+}
+
+.topcoat-radio-button__checkmark:before {
+ width: 1.875rem;
+ height: 1.875rem;
+ background: #e5e9e8;
+ border: 1px solid #a5a8a8;
+ box-shadow: inset 0 1px #fff;
+}
+
+.topcoat-radio-button__checkmark {
+ position: relative;
+ width: 1.875rem;
+ height: 1.875rem;
+}
+
+.topcoat-radio-button__checkmark:after {
+ opacity: 0;
+ width: 0.875rem;
+ height: 0.875rem;
+ background: #666;
+ border: 1px solid rgba(0,0,0,0.1);
+ box-shadow: 0 1px rgba(255,255,255,0.5);
+ -webkit-transform: none;
+ -ms-transform: none;
+ transform: none;
+ top: 7px;
+ left: 7px;
+}
+
+input[type="radio"]:focus + .topcoat-radio-button__checkmark:before {
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.search-input {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ vertical-align: top;
+ outline: none;
+ -webkit-appearance: none;
+}
+
+input[type="search"]::-webkit-search-cancel-button {
+ -webkit-appearance: none;
+}
+
+.search-input:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.search-input,
+.topcoat-search-input,
+.topcoat-search-input--large {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ vertical-align: top;
+ outline: none;
+ -webkit-appearance: none;
+}
+
+input[type="search"]::-webkit-search-cancel-button {
+ -webkit-appearance: none;
+}
+
+.search-input:disabled,
+.topcoat-search-input:disabled,
+.topcoat-search-input--large:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/* topdoc
+ name: Search Input
+ description: A text input designed for searching.
+ modifiers:
+ :disabled: Disabled state
+ markup:
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - text
+ - input
+ - search
+ - form
+*/
+
+.topcoat-search-input,
+.topcoat-search-input--large {
+ line-height: 3rem;
+ font-size: 16px;
+ border: 1px solid #a5a8a8;
+ background-color: #d3d7d7;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+ color: #454545;
+ padding: 0 0 0 2rem;
+ border-radius: 30px;
+ background-image: url("../img/search.svg");
+ background-position: 1em center;
+ background-repeat: no-repeat;
+ background-size: 16px;
+}
+
+.topcoat-search-input:focus,
+.topcoat-search-input--large:focus {
+ background-image: url("../img/search_dark.svg");
+ background-color: #edf1f1;
+ color: #000;
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+}
+
+.topcoat-search-input::-webkit-search-cancel-button,
+.topcoat-search-input::-webkit-search-decoration,
+.topcoat-search-input--large::-webkit-search-cancel-button,
+.topcoat-search-input--large::-webkit-search-decoration {
+ margin-right: 5px;
+}
+
+.topcoat-search-input:focus::-webkit-input-placeholder,
+.topcoat-search-input:focus::-webkit-input-placeholder {
+ color: #c6c8c8;
+}
+
+.topcoat-search-input:disabled::-webkit-input-placeholder {
+ color: #000;
+}
+
+.topcoat-search-input:disabled::-moz-placeholder {
+ color: #000;
+}
+
+.topcoat-search-input:disabled:-ms-input-placeholder {
+ color: #000;
+}
+
+/* topdoc
+ name: Large Search Input
+ description: A large text input designed for searching.
+ modifiers:
+ :disabled: Disabled state
+ markup:
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - text
+ - input
+ - search
+ - form
+ - large
+*/
+
+.topcoat-search-input--large {
+ line-height: 4.375rem;
+ font-size: 1.3rem;
+ font-weight: 200;
+ padding: 0 0 0 2.9rem;
+ border-radius: 40px;
+ background-position: 1.2em center;
+ background-size: 1.3rem;
+}
+
+.topcoat-search-input--large:disabled {
+ color: #000;
+}
+
+.topcoat-search-input--large:disabled::-webkit-input-placeholder {
+ color: #000;
+}
+
+.topcoat-search-input--large:disabled::-moz-placeholder {
+ color: #000;
+}
+
+.topcoat-search-input--large:disabled:-ms-input-placeholder {
+ color: #000;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.input,
+.topcoat-text-input,
+.topcoat-text-input--large {
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ vertical-align: top;
+ outline: none;
+}
+
+.input:disabled,
+.topcoat-text-input:disabled,
+.topcoat-text-input--large:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/* topdoc
+ name: Text input
+ description: Topdoc text input
+ markup:
+
+
+
+
+ tags:
+ - desktop
+ - mobile
+ - text
+ - input
+*/
+
+.topcoat-text-input,
+.topcoat-text-input--large {
+ line-height: 3rem;
+ font-size: 16px;
+ letter-spacing: 1px;
+ padding: 0 1.25rem;
+ border: 1px solid #a5a8a8;
+ border-radius: 6px;
+ background-color: #d3d7d7;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+ color: #454545;
+ vertical-align: top;
+}
+
+.topcoat-text-input:focus,
+.topcoat-text-input--large:focus {
+ background-color: #edf1f1;
+ color: #000;
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+}
+
+.topcoat-text-input:disabled::-webkit-input-placeholder {
+ color: #000;
+}
+
+.topcoat-text-input:disabled::-moz-placeholder {
+ color: #000;
+}
+
+.topcoat-text-input:disabled:-ms-input-placeholder {
+ color: #000;
+}
+
+/* topdoc
+ name: Large Text Input
+ description: A bigger input, still for text.
+ modifiers:
+ :disabled: Disabled state
+ markup:
+
+
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - form
+ - input
+ - large
+*/
+
+.topcoat-text-input--large {
+ line-height: 4.375rem;
+ font-size: 1.3rem;
+}
+
+.topcoat-text-input--large:disabled {
+ color: #000;
+}
+
+.topcoat-text-input--large:disabled::-webkit-input-placeholder {
+ color: #000;
+}
+
+.topcoat-text-input--large:disabled::-moz-placeholder {
+ color: #000;
+}
+
+.topcoat-text-input--large:disabled:-ms-input-placeholder {
+ color: #000;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.textarea {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ vertical-align: top;
+ resize: none;
+ outline: none;
+}
+
+.textarea:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+/**
+*
+* Copyright 2012 Adobe Systems Inc.;
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*
+*/
+
+.textarea,
+.topcoat-textarea,
+.topcoat-textarea--large {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ vertical-align: top;
+ resize: none;
+ outline: none;
+}
+
+.textarea:disabled,
+.topcoat-textarea:disabled,
+.topcoat-textarea--large:disabled {
+ opacity: 0.3;
+ cursor: default;
+ pointer-events: none;
+}
+
+/* topdoc
+ name: Textarea
+ description: A whole area, just for text.
+ modifiers:
+ :disabled: Disabled state
+ markup:
+
+
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - form
+ - input
+ - textarea
+*/
+
+.topcoat-textarea,
+.topcoat-textarea--large {
+ padding: 2rem;
+ font-size: 2.5rem;
+ font-weight: 200;
+ border-radius: 6px;
+ line-height: 3rem;
+ border: 1px solid #a5a8a8;
+ background-color: #d3d7d7;
+ box-shadow: inset 0 1px rgba(0,0,0,0.12);
+ color: #454545;
+ letter-spacing: 1px;
+}
+
+.topcoat-textarea:focus,
+.topcoat-textarea--large:focus {
+ background-color: #edf1f1;
+ color: #000;
+ border: 1px solid #0940fd;
+ box-shadow: 0 0 0 2px #6fb5f1;
+}
+
+.topcoat-textarea:disabled::-webkit-input-placeholder {
+ color: #000;
+}
+
+.topcoat-textarea:disabled::-moz-placeholder {
+ color: #000;
+}
+
+.topcoat-textarea:disabled:-ms-input-placeholder {
+ color: #000;
+}
+
+/* topdoc
+ name: Large Textarea
+ description: A whole area, just for text; now available in large.
+ modifiers:
+ :disabled: Disabled state
+ markup:
+
+
+
+
+ tags:
+ - desktop
+ - light
+ - mobile
+ - form
+ - input
+ - textarea
+*/
+
+.topcoat-textarea--large {
+ font-size: 3rem;
+ line-height: 4.375rem;
+}
+
+.topcoat-textarea--large:disabled {
+ color: #000;
+}
+
+.topcoat-textarea--large:disabled::-webkit-input-placeholder {
+ color: #000;
+}
+
+.topcoat-textarea--large:disabled::-moz-placeholder {
+ color: #000;
+}
+
+.topcoat-textarea--large:disabled:-ms-input-placeholder {
+ color: #000;
+}
+
+@font-face {
+ font-family: "Source Sans";
+ src: url("../font/SourceSansPro-Regular.otf");
+}
+
+@font-face {
+ font-family: "Source Sans";
+ src: url("../font/SourceSansPro-Light.otf");
+ font-weight: 200;
+}
+
+@font-face {
+ font-family: "Source Sans";
+ src: url("../font/SourceSansPro-Semibold.otf");
+ font-weight: 600;
+}
+
+body {
+ margin: 0;
+ padding: 0;
+ background: #dfe2e2;
+ color: #000;
+ font: 16px "Source Sans", helvetica, arial, sans-serif;
+ font-weight: 200;
+ text-rendering: optimizeLegibility;
+}
+
+:focus {
+ outline-color: transparent;
+ outline-style: none;
+}
+
+.topcoat-icon--menu-stack {
+ background: url("../img/hamburger_dark.svg") no-repeat;
+ background-size: cover;
+}
+
+.quarter {
+ width: 25%;
+}
+
+.half {
+ width: 50%;
+}
+
+.three-quarters {
+ width: 75%;
+}
+
+.third {
+ width: 33.333%;
+}
+
+.two-thirds {
+ width: 66.666%;
+}
+
+.full {
+ width: 100%;
+}
+
+.left {
+ text-align: left;
+}
+
+.center {
+ text-align: center;
+}
+
+.right {
+ text-align: right;
+}
+
+.reset-ui {
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+ background-clip: padding-box;
+ position: relative;
+ display: inline-block;
+ vertical-align: top;
+ padding: 0;
+ margin: 0;
+ font: inherit;
+ color: inherit;
+ background: transparent;
+ border: none;
+ cursor: default;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+}
+
+/* Call To Action */
+
+/* Icons */
+
+/* Navigation Bar */
+
+/* Text Input */
+
+/* Search Input */
+
+/* List */
+
+/* Checkbox */
+
+/* Overlay */
+
+/* Progress bar */
+
+/* Checkbox */
+
+/* Radio Button */
+
+/* Icon Button */
+
+/* Navigation bar */
+
+/* List */
+
+/* Search Input */
+
+/* Textarea */
+
+/* Checkbox */
+
+/* Radio */
+
+/* Search Input */
+
+/* Call To Action */
+
+/* Icons */
+
+/* Navigation Bar */
+
+/* Text Input */
+
+/* List */
+
+/*Overlay*/
+
+/* Progress bar */
+
+/* Checkbox */
+
+/* Range input */
+
+/* Containers */
+
+/* Icon Button */
+
+/* Navigation bar */
+
+/* List */
+
+/* Search Input */
+
+/* Text Area */
+
+/* Checkbox */
+
+/* Radio */
+
+/* Range input */
+
+/* Search Input */
+
+/* Text Input */
+
+/* Radio input */
+
+/* Overlay */
+
+/* Textarea */
+
+/* Progress bar container */
+
+/* Progress bar progress */
+
+/* Search input */
\ No newline at end of file
diff --git a/dist/dr-print.css b/dist/dr-print.css
deleted file mode 100644
index 39b4cab..0000000
--- a/dist/dr-print.css
+++ /dev/null
@@ -1,339 +0,0 @@
-html, body {
- margin: 0;
- padding: 0;
-}
-#dr-js {
- margin: 0;
- padding: 0;
-}
-#src-dr-js {
- margin: 1em;
- padding: 0;
-}
-.dr-doc {
- font: 300 16px/1.4 "Myriad Pro", "Helvetica Neue", Helvetica, "Arial Unicode MS", Arial, sans-serif;
- margin: 0;
- padding: 0 30px 10px;
-}
-.dr-toc {
- font-family: Menlo, Consolas, Monaco, "Lucida Console", monospace;
- list-style: none;
- margin: 0;
- padding: 0 16px;
- float: right;
-}
-.dr-toc input {
- display: none;
-}
-#dr {
- margin: 0 auto;
-}
-.dr-doc code,
-.dr-type em,
-.dr-returns em,
-.dr-property em {
- font-family: Menlo, Consolas, Monaco, "Lucida Console", monospace;
-}
-.extra {
- display: none;
-}
-pre.code code {
- color: #000;
-}
-pre.code {
- background: #eee;
- border: solid 1px #ccc;
- color: #000;
- overflow-x: auto;
- padding: 16px 30px;
- margin: 0 -30px;
-}
-code b {
- color: #e98553;
- font-weight: normal;
-}
-code i,
-code i *,
-code i .d {
- color: #5c993f;
- font-style: normal;
-}
-code .s {
- color: #e7be61;
-}
-code .d {
- color: #cf6a4c;
-}
-code .c,
-code .c * {
- color: #999;
- font-style: italic;
-}
-em.amp {
- font-family: Baskerville, "Goudy Old Style", Palatino, "Book Antiqua", serif;
- font-style: italic;
-}
-dl.dr-parameters {
- margin: 8px 0;
-}
-dt.dr-param {
- color: #666;
- font-weight: 400;
- float: left;
- margin-right: 16px;
- min-width: 160px;
-}
-dd.dr-type {
- margin: 0;
-}
-dd.dr-description {
- display: table;
- min-height: 24px;
- border: solid 1px #fff;
-}
-.dr-type {
- float: left;
-}
-.dr-type em,
-.dr-returns em,
-.dr-property em {
- -moz-border-radius: 5px;
- -webkit-border-radius: 5px;
- background: #ccc;
- border-radius: 5px;
- float: left;
- font-size: .75em;
- font-style: normal;
- font-weight: 700;
- margin: 0 8px 0 0;
- min-width: 80px;
- padding: 2px 5px;
- text-align: center;
-}
-.dr-type em.amp,
-.dr-returns em.amp,
-.dr-property em.amp {
- float: none;
- background: none;
- font-size: 1em;
- font-weight: 400;
- font-style: italic;
- margin: 0;
- padding: 0;
- min-width: 0;
-}
-.dr-property em.dr-type {
- margin: 4px 16px 0 0;
-}
-em.dr-type-string {
- background: #e1edb1;
- color: #3d4c00;
-}
-em.dr-type-object {
- background: #edb1b1;
- color: #4c0000;
-}
-em.dr-type-function {
- background: #cfb1ed;
- color: #26004c;
-}
-em.dr-type-number {
- background: #b1c9ed;
- color: #001e4c;
-}
-em.dr-type-boolean {
- background: #b1edc9;
- color: #004c1e;
-}
-em.dr-type-array {
- background: #edd5b1;
- color: #4c2d00;
-}
-dd.dr-optional {
- display: none;
-}
-ol.dr-json {
- background: #ddd;
- list-style: none;
- margin: 0 -30px;
- padding: 16px 30px;
-}
-ol.dr-json .dr-json-key {
- float: left;
- min-width: 50px;
- margin-right: 16px;
-}
-ol.dr-json .dr-json-description {
- display: table;
-}
-ol.dr-json ol.dr-json {
- margin: 0;
- padding: 0 0 0 50px;
-}
-h1 {
- font-weight: 400;
- font-size: 2.6em;
- margin: 0;
-}
-h2, h3, h4, h5 {
- margin: 1em 0 .5em 0;
- padding: 6px 0 0;
- font-weight: 600;
- position: relative;
-}
-h5 {
- font-size: 18px;
-}
-h4 {
- font-size: 20px;
-}
-h3 {
- font-size: 28px;
-}
-h2 {
- font-size: 38px;
-}
-h2.dr-method,
-h3.dr-method,
-h4.dr-method,
-h5.dr-method {
- color: #900;
-}
-h2.dr-property,
-h3.dr-property,
-h4.dr-property,
-h5.dr-property {
- color: #009;
-}
-i.dr-trixie {
- display: none;
-}
-p.header {
- font-size: 19px;
- font-weight: 600;
- margin: 1em 0 .3em;
-}
-.dr-returns {
- margin-top: 16px;
-}
-.dr-returns .dr-title {
- float: left;
- margin-right: 16px;
- width: 160px;
-}
-.dr-toc a {
- display: block;
- text-decoration: none;
- color: #333;
- padding-top: 8px;
- position: relative;
- z-index: 1000;
-}
-.dr-toc li.dr-lvl1 a {
- padding-left: 1em;
-}
-.dr-toc li.dr-lvl2 a {
- padding-left: 2em;
-}
-.dr-toc li.dr-lvl3 a {
- padding-left: 3em;
-}
-.dr-toc li.dr-lvl4 a {
- padding-left: 4em;
-}
-.dr-toc li.dr-lvl5 a {
- padding-left: 5em;
-}
-.dr-toc li.dr-lvl6 a {
- padding-left: 6em;
-}
-.dr-toc a.dr-property {
- color: #339;
-}
-.dr-toc a.dr-method {
- color: #933;
-}
-.dr-toc a:hover {
- text-shadow: 0 0 2px #333;
-}
-.dr-toc a.dr-property:hover {
- text-shadow: 0 0 2px #66c;
-}
-.dr-toc a.dr-method:hover {
- text-shadow: 0 0 2px #c66;
-}
-a.dr-hash,
-a.dr-sourceline {
- -webkit-transition: opacity 0.2s linear;
- color: #333;
- font-family: Menlo, "Arial Unicode MS", sans-serif;
- margin: 0 0 0 .3em;
- opacity: 0;
- text-decoration: none;
-}
-a.dr-link {
- position: relative;
- color: #3875c0;
-}
-a.dr-link:hover {
- text-shadow: 0 1px 2px #999;
- bottom: 1px;
- padding-bottom: 1px;
-}
-a.dr-link:visited {
- color: #7051bc;
-}
-h2:hover a.dr-hash,
-h3:hover a.dr-hash,
-h4:hover a.dr-hash,
-h5:hover a.dr-hash,
-h2:hover a.dr-sourceline,
-h3:hover a.dr-sourceline,
-h4:hover a.dr-sourceline,
-h5:hover a.dr-sourceline {
- opacity: 1;
-}
-p {
- margin: 0 0 .5em;
-}
-
-.dr-source-line {
- margin: 0;
-}
-.dr-source-line a {
- -webkit-border-radius: 5px;
- -webkit-border-radius: 5px;
- -moz-border-radius: 5px;
- -moz-border-radius: 5px;
- border-radius: 5px;
- border-radius: 5px;
- color: #000;
- background: #999;
- font-weight: 400;
- font-size: .75em;
- text-decoration: none;
- padding: 5px;
-}
-#src-dr-js code {
- background: #000;
- display: block;
- color: #fff;
- font-family: Menlo, Consolas, Monaco, "Lucida Console", monospace;
- white-space: pre;
- padding-left: 100px;
- position: relative;
- line-height: 1.2;
-}
-#src-dr-js code:hover {
- background: #333;
-}
-#src-dr-js code:hover .ln {
- color: #fff;
-}
-#src-dr-js code .ln {
- position: absolute;
- left: 0;
- color: #333;
- width: 70px;
- text-align: right;
-}
\ No newline at end of file
diff --git a/dist/dr.css b/dist/dr.css
deleted file mode 100644
index 5319a9f..0000000
--- a/dist/dr.css
+++ /dev/null
@@ -1,399 +0,0 @@
-html, body {
- margin: 0;
- padding: 0;
-}
-#dr-js {
- background: #999;
- margin: 0;
- padding: 0;
-}
-#src-dr-js {
- background: #000;
- margin: 1em;
- padding: 0;
-}
-.dr-doc {
- background: #eee;
- border-right: solid #eee 3px;
- float: right;
- font: 300 16px/1.4 "Myriad Pro", "Helvetica Neue", Helvetica, "Arial Unicode MS", Arial, sans-serif;
- margin: 0 -275px 0 0;
- padding: 0 30px 10px;
- width: 800px;
- border-right: 275px solid #ddd;
-}
-.dr-toc {
- background: #ddd;
- border-right: solid #ddd 3px;
- float: right;
- font-family: Menlo, Consolas, Monaco, "Lucida Console", monospace;
- list-style: none;
- margin: 0;
- padding: 0 16px;
- width: 240px;
- position: relative;
-}
-#dr {
- margin: 0 auto;
- width: 1152px;
- height: 100%;
-}
-::-moz-selection {
- background: #c00;
- color: #fff;
-}
-::selection {
- background: #c00;
- color: #fff;
-}
-.dr-doc code,
-.dr-type em,
-.dr-returns em,
-.dr-property em {
- font-family: Menlo, Consolas, Monaco, "Lucida Console", monospace;
-}
-.extra {
- display: none;
-}
-pre.code code {
- color: #fff;
-}
-pre.code {
- background: #333;
- color: #fff;
- overflow-x: auto;
- padding: 16px 30px;
- margin: 0 -30px;
-}
-code b {
- color: #e9df8f;
- font-weight: normal;
-}
-code .s {
- color: #e7be61;
-}
-code .d {
- color: #cf6a4c;
-}
-code .c,
-code .c * {
- color: #999;
- font-style: italic;
-}
-code i,
-code i *,
-code i .c,
-code i .c *,
-code i .d {
- color: #8b9967;
- font-style: normal;
-}
-em.amp {
- font-family: Baskerville, "Goudy Old Style", Palatino, "Book Antiqua", serif;
- font-style: italic;
-}
-dl.dr-parameters {
- margin: 8px 0;
-}
-dt.dr-param {
- color: #666;
- font-weight: 400;
- float: left;
- margin-right: 16px;
- min-width: 160px;
-}
-dd.dr-type {
- margin: 0;
-}
-dd.dr-description {
- display: table;
- min-height: 24px;
- border: solid 1px #eee;
-}
-.dr-type {
- float: left;
-}
-.dr-type em,
-.dr-returns em,
-.dr-property em {
- -moz-border-radius: 5px;
- -webkit-border-radius: 5px;
- background: #ccc;
- border-radius: 5px;
- float: left;
- font-size: .75em;
- font-style: normal;
- font-weight: 700;
- margin: 0 8px 0 0;
- min-width: 80px;
- padding: 2px 5px;
- text-align: center;
-}
-.dr-type em.amp,
-.dr-returns em.amp,
-.dr-property em.amp {
- float: none;
- background: none;
- font-size: 1em;
- font-weight: 400;
- font-style: italic;
- margin: 0;
- padding: 0;
- min-width: 0;
-}
-.dr-property em.dr-type {
- margin: 4px 16px 0 0;
-}
-em.dr-type-string {
- background: #e1edb1;
- color: #3d4c00;
-}
-em.dr-type-object {
- background: #edb1b1;
- color: #4c0000;
-}
-em.dr-type-function {
- background: #cfb1ed;
- color: #26004c;
-}
-em.dr-type-number {
- background: #b1c9ed;
- color: #001e4c;
-}
-em.dr-type-boolean {
- background: #b1edc9;
- color: #004c1e;
-}
-em.dr-type-array {
- background: #edd5b1;
- color: #4c2d00;
-}
-dd.dr-optional {
- display: none;
-}
-ol.dr-json {
- background: #ddd;
- list-style: none;
- margin: 0 -30px;
- padding: 16px 30px;
-}
-ol.dr-json .dr-json-key {
- float: left;
- min-width: 50px;
- margin-right: 16px;
-}
-ol.dr-json .dr-json-description {
- display: table;
-}
-ol.dr-json ol.dr-json {
- margin: 0;
- padding: 0 0 0 50px;
-}
-h1 {
- font-weight: 400;
- font-size: 2.6em;
- margin: 0;
-}
-h2, h3, h4, h5 {
- margin: 1em 0 .5em 0;
- padding: 6px 0 0;
- font-weight: 600;
- position: relative;
-}
-h5 {
- font-size: 18px;
-}
-h4 {
- font-size: 20px;
-}
-h3 {
- font-size: 28px;
-}
-h2 {
- font-size: 38px;
-}
-h2.dr-method,
-h3.dr-method,
-h4.dr-method,
-h5.dr-method {
- color: #900;
-}
-h2.dr-property,
-h3.dr-property,
-h4.dr-property,
-h5.dr-property {
- color: #009;
-}
-i.dr-trixie {
- border: solid 10px #eee;
- border-left-color: #999;
- height: 0;
- margin-left: -30px;
- margin-top: -10px;
- overflow: hidden;
- position: absolute;
- top: 50%;
- width: 0;
-}
-p.header {
- font-size: 19px;
- font-weight: 600;
- margin: 1em 0 .3em;
-}
-.dr-returns {
- margin-top: 16px;
-}
-.dr-returns .dr-title {
- float: left;
- margin-right: 16px;
- width: 160px;
-}
-.dr-toc a {
- display: block;
- text-decoration: none;
- color: #333;
- padding-top: 8px;
- position: relative;
- z-index: 1000;
-}
-.dr-toc li.dr-lvl1 a {
- padding-left: 1em;
-}
-.dr-toc li.dr-lvl2 a {
- padding-left: 2em;
-}
-.dr-toc li.dr-lvl3 a {
- padding-left: 3em;
-}
-.dr-toc li.dr-lvl4 a {
- padding-left: 4em;
-}
-.dr-toc li.dr-lvl5 a {
- padding-left: 5em;
-}
-.dr-toc li.dr-lvl6 a {
- padding-left: 6em;
-}
-.dr-toc a.dr-property {
- color: #339;
-}
-.dr-toc a.dr-method {
- color: #933;
-}
-.dr-toc a:hover {
- text-shadow: 0 0 2px #333;
-}
-.dr-toc a.dr-property:hover {
- text-shadow: 0 0 2px #66c;
-}
-.dr-toc a.dr-method:hover {
- text-shadow: 0 0 2px #c66;
-}
-a.dr-hash,
-a.dr-sourceline {
- -webkit-transition: opacity 0.2s linear;
- color: #333;
- font-family: Menlo, "Arial Unicode MS", sans-serif;
- margin: 0 0 0 .3em;
- opacity: 0;
- text-decoration: none;
-}
-a.dr-link {
- position: relative;
- color: #3875c0;
-}
-a.dr-link:hover {
- text-shadow: 0 1px 2px #999;
- bottom: 1px;
- padding-bottom: 1px;
-}
-a.dr-link:visited {
- color: #7051bc;
-}
-h2:hover a.dr-hash,
-h3:hover a.dr-hash,
-h4:hover a.dr-hash,
-h5:hover a.dr-hash,
-h2:hover a.dr-sourceline,
-h3:hover a.dr-sourceline,
-h4:hover a.dr-sourceline,
-h5:hover a.dr-sourceline {
- opacity: 1;
-}
-p {
- margin: 0 0 .5em;
-}
-
-.dr-source-line {
- margin: 0;
-}
-.dr-source-line a {
- -webkit-border-radius: 5px;
- -webkit-border-radius: 5px;
- -moz-border-radius: 5px;
- -moz-border-radius: 5px;
- border-radius: 5px;
- border-radius: 5px;
- color: #000;
- background: #999;
- font-weight: 400;
- font-size: .75em;
- text-decoration: none;
- padding: 5px;
-}
-#src-dr-js code {
- background: #000;
- display: block;
- color: #fff;
- font-family: Menlo, Consolas, Monaco, "Lucida Console", monospace;
- white-space: pre;
- padding-left: 100px;
- position: relative;
- line-height: 1.2;
-}
-#src-dr-js code:hover {
- background: #333;
-}
-#src-dr-js code:hover .ln {
- color: #fff;
-}
-#src-dr-js code .ln {
- position: absolute;
- left: 0;
- color: #333;
- width: 70px;
- text-align: right;
-}
-
-/*Scrollbar*/
-.dr-doc::-webkit-scrollbar,
-.dr-toc::-webkit-scrollbar {
- width: 7px;
- height: 9px;
-}
-.dr-doc::-webkit-scrollbar-button:start:decrement,
-.dr-doc::-webkit-scrollbar-button:end:increment,
-.dr-toc::-webkit-scrollbar-button:start:decrement,
-.dr-toc::-webkit-scrollbar-button:end:increment {
- display: block;
- height: 0;
- background-color: transparent;
-}
-.dr-doc::-webkit-scrollbar-track-piece,
-.dr-toc::-webkit-scrollbar-track-piece {
- -webkit-border-radius: 0;
- -webkit-border-bottom-right-radius: 4px;
- -webkit-border-bottom-left-radius: 4px;
-}
-.dr-doc::-webkit-scrollbar-thumb:vertical,
-.dr-toc::-webkit-scrollbar-thumb:vertical {
- height: 50px;
- background-color: rgba(0, 0, 0, 0.2);
- -webkit-border-radius: 4px;
-}
-.dr-doc::-webkit-scrollbar-thumb:horizontal,
-.dr-toc::-webkit-scrollbar-thumb:horizontal {
- width: 50px;
- background-color: rgba(0, 0, 0, 0.2);
- -webkit-border-radius: 4px;
-}
diff --git a/dist/fonts/sourcecodepro-regular-webfont.eot b/dist/fonts/sourcecodepro-regular-webfont.eot
new file mode 100755
index 0000000..9e9e4de
Binary files /dev/null and b/dist/fonts/sourcecodepro-regular-webfont.eot differ
diff --git a/dist/fonts/sourcecodepro-regular-webfont.svg b/dist/fonts/sourcecodepro-regular-webfont.svg
new file mode 100755
index 0000000..f4a1739
--- /dev/null
+++ b/dist/fonts/sourcecodepro-regular-webfont.svg
@@ -0,0 +1,242 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/dist/fonts/sourcecodepro-regular-webfont.ttf b/dist/fonts/sourcecodepro-regular-webfont.ttf
new file mode 100755
index 0000000..6eb48e7
Binary files /dev/null and b/dist/fonts/sourcecodepro-regular-webfont.ttf differ
diff --git a/dist/fonts/sourcecodepro-regular-webfont.woff b/dist/fonts/sourcecodepro-regular-webfont.woff
new file mode 100755
index 0000000..2383f47
Binary files /dev/null and b/dist/fonts/sourcecodepro-regular-webfont.woff differ
diff --git a/dist/fonts/sourcesanspro-light-webfont.eot b/dist/fonts/sourcesanspro-light-webfont.eot
new file mode 100755
index 0000000..bda2005
Binary files /dev/null and b/dist/fonts/sourcesanspro-light-webfont.eot differ
diff --git a/dist/fonts/sourcesanspro-light-webfont.svg b/dist/fonts/sourcesanspro-light-webfont.svg
new file mode 100755
index 0000000..e031390
--- /dev/null
+++ b/dist/fonts/sourcesanspro-light-webfont.svg
@@ -0,0 +1,243 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/dist/fonts/sourcesanspro-light-webfont.ttf b/dist/fonts/sourcesanspro-light-webfont.ttf
new file mode 100755
index 0000000..0959ece
Binary files /dev/null and b/dist/fonts/sourcesanspro-light-webfont.ttf differ
diff --git a/dist/fonts/sourcesanspro-light-webfont.woff b/dist/fonts/sourcesanspro-light-webfont.woff
new file mode 100755
index 0000000..522d5ab
Binary files /dev/null and b/dist/fonts/sourcesanspro-light-webfont.woff differ
diff --git a/dist/fonts/sourcesanspro-regular-webfont.eot b/dist/fonts/sourcesanspro-regular-webfont.eot
new file mode 100755
index 0000000..2b75abb
Binary files /dev/null and b/dist/fonts/sourcesanspro-regular-webfont.eot differ
diff --git a/dist/fonts/sourcesanspro-regular-webfont.svg b/dist/fonts/sourcesanspro-regular-webfont.svg
new file mode 100755
index 0000000..581a849
--- /dev/null
+++ b/dist/fonts/sourcesanspro-regular-webfont.svg
@@ -0,0 +1,243 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/dist/fonts/sourcesanspro-regular-webfont.ttf b/dist/fonts/sourcesanspro-regular-webfont.ttf
new file mode 100755
index 0000000..e166286
Binary files /dev/null and b/dist/fonts/sourcesanspro-regular-webfont.ttf differ
diff --git a/dist/fonts/sourcesanspro-regular-webfont.woff b/dist/fonts/sourcesanspro-regular-webfont.woff
new file mode 100755
index 0000000..315c98a
Binary files /dev/null and b/dist/fonts/sourcesanspro-regular-webfont.woff differ
diff --git a/dist/fonts/sourcesanspro-semibold-webfont.eot b/dist/fonts/sourcesanspro-semibold-webfont.eot
new file mode 100755
index 0000000..ddf5d11
Binary files /dev/null and b/dist/fonts/sourcesanspro-semibold-webfont.eot differ
diff --git a/dist/fonts/sourcesanspro-semibold-webfont.svg b/dist/fonts/sourcesanspro-semibold-webfont.svg
new file mode 100755
index 0000000..317e536
--- /dev/null
+++ b/dist/fonts/sourcesanspro-semibold-webfont.svg
@@ -0,0 +1,243 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/dist/fonts/sourcesanspro-semibold-webfont.ttf b/dist/fonts/sourcesanspro-semibold-webfont.ttf
new file mode 100755
index 0000000..6d97e7b
Binary files /dev/null and b/dist/fonts/sourcesanspro-semibold-webfont.ttf differ
diff --git a/dist/fonts/sourcesanspro-semibold-webfont.woff b/dist/fonts/sourcesanspro-semibold-webfont.woff
new file mode 100755
index 0000000..d844315
Binary files /dev/null and b/dist/fonts/sourcesanspro-semibold-webfont.woff differ
diff --git a/dist/fonts/stylesheet.css b/dist/fonts/stylesheet.css
new file mode 100755
index 0000000..2d66502
--- /dev/null
+++ b/dist/fonts/stylesheet.css
@@ -0,0 +1,57 @@
+
+@font-face {
+ font-family: 'source-sans-pro';
+ src: url('sourcesanspro-light-webfont.eot');
+ src: url('sourcesanspro-light-webfont.eot?#iefix') format('embedded-opentype'),
+ url('sourcesanspro-light-webfont.woff') format('woff'),
+ url('sourcesanspro-light-webfont.ttf') format('truetype'),
+ url('sourcesanspro-light-webfont.svg#source_sans_prolight') format('svg');
+ font-weight: 300;
+ font-style: normal;
+
+}
+
+
+
+
+@font-face {
+ font-family: 'source-sans-pro';
+ src: url('sourcesanspro-regular-webfont.eot');
+ src: url('sourcesanspro-regular-webfont.eot?#iefix') format('embedded-opentype'),
+ url('sourcesanspro-regular-webfont.woff') format('woff'),
+ url('sourcesanspro-regular-webfont.ttf') format('truetype'),
+ url('sourcesanspro-regular-webfont.svg#source_sans_proregular') format('svg');
+ font-weight: 400;
+ font-style: normal;
+
+}
+
+
+
+
+@font-face {
+ font-family: 'source-sans-pro';
+ src: url('sourcesanspro-semibold-webfont.eot');
+ src: url('sourcesanspro-semibold-webfont.eot?#iefix') format('embedded-opentype'),
+ url('sourcesanspro-semibold-webfont.woff') format('woff'),
+ url('sourcesanspro-semibold-webfont.ttf') format('truetype'),
+ url('sourcesanspro-semibold-webfont.svg#source_sans_prosemibold') format('svg');
+ font-weight: 600;
+ font-style: normal;
+
+}
+
+
+
+
+@font-face {
+ font-family: 'source-code-pro';
+ src: url('sourcecodepro-regular-webfont.eot');
+ src: url('sourcecodepro-regular-webfont.eot?#iefix') format('embedded-opentype'),
+ url('sourcecodepro-regular-webfont.woff') format('woff'),
+ url('sourcecodepro-regular-webfont.ttf') format('truetype'),
+ url('sourcecodepro-regular-webfont.svg#source_code_proregular') format('svg');
+ font-weight: normal;
+ font-style: normal;
+
+}
\ No newline at end of file
diff --git a/dist/img/search.svg b/dist/img/search.svg
new file mode 100644
index 0000000..d18a4fa
--- /dev/null
+++ b/dist/img/search.svg
@@ -0,0 +1,11 @@
+
+
+ Slice 1
+ Created with Sketch (http://www.bohemiancoding.com/sketch)
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/dist/img/search_dark.svg b/dist/img/search_dark.svg
new file mode 100644
index 0000000..9ab9e71
--- /dev/null
+++ b/dist/img/search_dark.svg
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+]>
+
+
+
diff --git a/dist/js/prism.js b/dist/js/prism.js
new file mode 100644
index 0000000..8f1a555
--- /dev/null
+++ b/dist/js/prism.js
@@ -0,0 +1,9 @@
+/**
+ * Prism: Lightweight, robust, elegant syntax highlighting
+ * MIT license http://www.opensource.org/licenses/mit-license.php/
+ * @author Lea Verou http://lea.verou.me
+ */(function(){var e=/\blang(?:uage)?-(?!\*)(\w+)\b/i,t=self.Prism={util:{type:function(e){return Object.prototype.toString.call(e).match(/\[object (\w+)\]/)[1]},clone:function(e){var n=t.util.type(e);switch(n){case"Object":var r={};for(var i in e)e.hasOwnProperty(i)&&(r[i]=t.util.clone(e[i]));return r;case"Array":return e.slice()}return e}},languages:{extend:function(e,n){var r=t.util.clone(t.languages[e]);for(var i in n)r[i]=n[i];return r},insertBefore:function(e,n,r,i){i=i||t.languages;var s=i[e],o={};for(var u in s)if(s.hasOwnProperty(u)){if(u==n)for(var a in r)r.hasOwnProperty(a)&&(o[a]=r[a]);o[u]=s[u]}return i[e]=o},DFS:function(e,n){for(var r in e){n.call(e,r,e[r]);t.util.type(e)==="Object"&&t.languages.DFS(e[r],n)}}},highlightAll:function(e,n){var r=document.querySelectorAll('code[class*="language-"], [class*="language-"] code, code[class*="lang-"], [class*="lang-"] code');for(var i=0,s;s=r[i++];)t.highlightElement(s,e===!0,n)},highlightElement:function(r,i,s){var o,u,a=r;while(a&&!e.test(a.className))a=a.parentNode;if(a){o=(a.className.match(e)||[,""])[1];u=t.languages[o]}if(!u)return;r.className=r.className.replace(e,"").replace(/\s+/g," ")+" language-"+o;a=r.parentNode;/pre/i.test(a.nodeName)&&(a.className=a.className.replace(e,"").replace(/\s+/g," ")+" language-"+o);var f=r.textContent;if(!f)return;f=f.replace(/&/g,"&").replace(/e.length)break e;if(p instanceof i)continue;a.lastIndex=0;var d=a.exec(p);if(d){l&&(c=d[1].length);var v=d.index-1+c,d=d[0].slice(c),m=d.length,g=v+m,y=p.slice(0,v+1),b=p.slice(g+1),w=[h,1];y&&w.push(y);var E=new i(u,f?t.tokenize(d,f):d);w.push(E);b&&w.push(b);Array.prototype.splice.apply(s,w)}}}return s},hooks:{all:{},add:function(e,n){var r=t.hooks.all;r[e]=r[e]||[];r[e].push(n)},run:function(e,n){var r=t.hooks.all[e];if(!r||!r.length)return;for(var i=0,s;s=r[i++];)s(n)}}},n=t.Token=function(e,t){this.type=e;this.content=t};n.stringify=function(e,r,i){if(typeof e=="string")return e;if(Object.prototype.toString.call(e)=="[object Array]")return e.map(function(t){return n.stringify(t,r,e)}).join("");var s={type:e.type,content:n.stringify(e.content,r,i),tag:"span",classes:["token",e.type],attributes:{},language:r,parent:i};s.type=="comment"&&(s.attributes.spellcheck="true");t.hooks.run("wrap",s);var o="";for(var u in s.attributes)o+=u+'="'+(s.attributes[u]||"")+'"';return"<"+s.tag+' class="'+s.classes.join(" ")+'" '+o+">"+s.content+""+s.tag+">"};if(!self.document){self.addEventListener("message",function(e){var n=JSON.parse(e.data),r=n.language,i=n.code;self.postMessage(JSON.stringify(t.tokenize(i,t.languages[r])));self.close()},!1);return}var r=document.getElementsByTagName("script");r=r[r.length-1];if(r){t.filename=r.src;document.addEventListener&&!r.hasAttribute("data-manual")&&document.addEventListener("DOMContentLoaded",t.highlightAll)}})();;
+Prism.languages.clike={comment:{pattern:/(^|[^\\])(\/\*[\w\W]*?\*\/|(^|[^:])\/\/.*?(\r?\n|$))/g,lookbehind:!0},string:/("|')(\\?.)*?\1/g,"class-name":{pattern:/((?:(?:class|interface|extends|implements|trait|instanceof|new)\s+)|(?:catch\s+\())[a-z0-9_\.\\]+/ig,lookbehind:!0,inside:{punctuation:/(\.|\\)/}},keyword:/\b(if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\b/g,"boolean":/\b(true|false)\b/g,"function":{pattern:/[a-z0-9_]+\(/ig,inside:{punctuation:/\(/}}, number:/\b-?(0x[\dA-Fa-f]+|\d*\.?\d+([Ee]-?\d+)?)\b/g,operator:/[-+]{1,2}|!|<=?|>=?|={1,3}|(&){1,2}|\|?\||\?|\*|\/|\~|\^|\%/g,ignore:/&(lt|gt|amp);/gi,punctuation:/[{}[\];(),.:]/g};
+;
+Prism.languages.javascript=Prism.languages.extend("clike",{keyword:/\b(var|let|if|else|while|do|for|return|in|instanceof|function|new|with|typeof|try|throw|catch|finally|null|break|continue)\b/g,number:/\b-?(0x[\dA-Fa-f]+|\d*\.?\d+([Ee]-?\d+)?|NaN|-?Infinity)\b/g});Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:/(^|[^/])\/(?!\/)(\[.+?]|\\.|[^/\r\n])+\/[gim]{0,3}(?=\s*($|[\r\n,.;})]))/g,lookbehind:!0}});Prism.languages.markup&&Prism.languages.insertBefore("markup","tag",{script:{pattern:/(<|<)script[\w\W]*?(>|>)[\w\W]*?(<|<)\/script(>|>)/ig,inside:{tag:{pattern:/(<|<)script[\w\W]*?(>|>)|(<|<)\/script(>|>)/ig,inside:Prism.languages.markup.tag.inside},rest:Prism.languages.javascript}}});
+;
\ No newline at end of file
diff --git a/dist/reference.html b/dist/reference.html
index 2785f6d..7a800e4 100644
--- a/dist/reference.html
+++ b/dist/reference.html
@@ -1,183 +1,189 @@
-
-Savage Reference
-
-
-Element Element.after() Element.animate() Element.append() Element.asPX() Element.attr() Element.before() Element.click() Element.clone() Element.data() Element.dblclick() Element.drag() Element.getBBox() Element.getPointAtLength() Element.getSubpath() Element.getTotalLength() Element.hover() Element.inAnim() Element.insertAfter() Element.insertBefore() Element.marker() Element.mousedown() Element.mousemove() Element.mouseout() Element.mouseover() Element.mouseup() Element.onDragOver() Element.parent() Element.pattern() Element.prepend() Element.remove() Element.removeData() Element.select() Element.selectAll() Element.touchcancel() Element.touchend() Element.touchmove() Element.touchstart() Element.transform() Element.unclick() Element.undblclick() Element.undrag() Element.unhover() Element.unmousedown() Element.unmousemove() Element.unmouseout() Element.unmouseover() Element.unmouseup() Element.untouchcancel() Element.untouchend() Element.untouchmove() Element.untouchstart() Element.use() Fragment Fragment.select() Fragment.selectAll() Matrix Matrix.add() Matrix.clone() Matrix.invert() Matrix.rotate() Matrix.scale() Matrix.split() Matrix.toTransformString() Matrix.translate() Matrix.x() Matrix.y() Paper Paper.circle() Paper.el() Paper.ellipse() Paper.filter() Paper.filter.blur() Paper.g() Paper.gradient() Paper.group() Paper.image() Paper.line() Paper.path() Paper.polygon() Paper.polyline() Paper.rect() Paper.text() Savage() Savage.Matrix() Savage.animate() Savage.animation() Savage.color() Savage.deg() Savage.findDotsAtSegment() Savage.format() Savage.fragment() Savage.getRGB() Savage.hsb() Savage.hsb2rgb() Savage.hsl() Savage.hsl2rgb() Savage.is() Savage.parse() Savage.parsePathString() Savage.parseTransformString() Savage.path Savage.path.bezierBBox() Savage.path.getPointAtLength() Savage.path.getSubpath() Savage.path.getTotalLength() Savage.path.intersection() Savage.path.isBBoxIntersect() Savage.path.isPointInside() Savage.path.isPointInsideBBox() Savage.path.map() Savage.path.toAbsolute() Savage.path.toCubic() Savage.path.toRelative() Savage.pathBBox() Savage.rad() Savage.rgb() Savage.rgb2hsb() Savage.rgb2hsl() Savage.select() Savage.selectAll() Savage.snapTo() Set Set.clear() Set.exclude() Set.forEach() Set.pop() Set.push() Set.splice() mina() mina.backin() mina.backout() mina.bounce() mina.easein() mina.easeinout() mina.easeout() mina.elastic() mina.getById() mina.linear() mina.time() Savage Reference Inserts given element after the current one.
+
+
+
+
+
Savage API Reference
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Savage
+ API Reference
+
+
+
+
+
+
+Inserts given element after the current one.
-
el
-Element
-element to insert
-
+
el
+Element
+element to insert
+
Returns: Element parent
-
Element.animate(attrs, ms, [easing], [callback])⚓ ➭
-
Animate given attributes of the element.
+
Element.animate(attrs, ms, [easing], [callback])⚓ ➭
+Animate given attributes of the element.
-
-
attrs
-object
-key-value pairs of destination attributes
-ms
-number
-duration
-easing
-optional
-function
-easing function from mina or custom
-callback
-optional
-function
-
-
+
attrs
+object
+key-value pairs of destination attributes
+ms
+number
+duration
+easing
+optional
+function
+easing function from mina or custom
+callback
+optional
+function
+
+
Returns: Element the element
-
Appends given element to current one.
+
+Appends given element to current one.
-
-
el
-Element Set
-element to append
-
+
el
+Element Set
+element to append
+
Returns: Element parent
-
Element.asPX(attr, [value])⚓ ➭
-
Return given attribute of the element as a px
value. (Not %, em, etc)
+
Element.asPX(attr, [value])⚓ ➭
+Return given attribute of the element as a px
value. (Not %, em, etc)
-
-
attr
-string
-attribute name
-value
-optional
-string
-attribute value
-
+
attr
+string
+attribute name
+value
+optional
+string
+attribute value
+
Returns: Element result of query selection
-
Gets or sets given attributes of the element
+
+Gets or sets given attributes of the element
-
-
params
-object
-key-value pairs of attributes you want to set
-
+
params
+object
+key-value pairs of attributes you want to set
+
or
-
param
-string
-name of the attribute
-
+
param
+string
+name of the attribute
+
Returns: Element
or
Returns: string value of attribute
-
-
el.attr({
- fill: "#fc0" ,
- stroke: "#000 " ,
- strokeWidth: 2 , // CamelCase...
- "fill-opacity" : 0.5 // or dash-separated names
+Usage el.attr({
+ fill: "#fc0",
+ stroke: "#000",
+ strokeWidth: 2, // CamelCase...
+ "fill-opacity": 0.5 // or dash-separated names
});
-console.log(el.attr("fill" )); // “#fc0”
-
-
Inserts given element before the current one.
+console.log(el.attr("fill")); // “#fc0”
+
+
+Inserts given element before the current one.
-
-
el
-Element
-element to insert
-
+
el
+Element
+element to insert
+
Returns: Element parent
-
Element.click(handler)⚓ ➭
-
Adds event handler for click for the element.
+
+Adds event handler for click for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Creates <use>
element linked to the current element.
+
+Creates <use>
element linked to the current element.
Returns: Element <use>
element
-
Element.data(key, [value])⚓ ➭
-
Adds or retrieves given value asociated with given key.
+
Element.data(key, [value])⚓ ➭
+Adds or retrieves given value asociated with given key.
See also Element.removeData
-
-
key
-string
-key to store data
-value
-optional
-any
-value to store
-
+
key
+string
+key to store data
+value
+optional
+any
+value to store
+
Returns: object Element
or, if value is not specified:
Returns: any value
-
-
for (var i = 0 , i < 5 , i++) {
- paper.circle(10 + 15 * i, 10 , 10 )
- .attr({fill: "#000 " })
- .data("i" , i)
- .click(function () {
- alert(this .data("i" ));
+Usage for (var i = 0, i < 5, i++) {
+ paper.circle(10 + 15 * i, 10, 10)
+ .attr({fill: "#000"})
+ .data("i", i)
+ .click(function () {
+ alert(this.data("i"));
});
}
-
-
Element.dblclick(handler)⚓ ➭
-
Adds event handler for double click for the element.
+
+
Element.dblclick(handler)⚓ ➭
+Adds event handler for double click for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.drag(onmove, onstart, onend, [mcontext], [scontext], [econtext])⚓ ➭
-
Adds event handlers for drag of the element.
+
Element.drag(onmove, onstart, onend, [mcontext], [scontext], [econtext])⚓ ➭
+Adds event handlers for drag of the element.
-
-
onmove
-function
-handler for moving
-onstart
-function
-handler for drag start
-onend
-function
-handler for drag end
-mcontext
-optional
-object
-context for moving handler
-scontext
-optional
-object
-context for drag start handler
-econtext
-optional
-object
-context for drag end handler
-
+
onmove
+function
+handler for moving
+onstart
+function
+handler for drag start
+onend
+function
+handler for drag end
+mcontext
+optional
+object
+context for moving handler
+scontext
+optional
+object
+context for drag start handler
+econtext
+optional
+object
+context for drag end handler
+
Additionaly following drag
events will be triggered: drag.start.<id>
on start,
drag.end.<id>
on end and drag.move.<id>
on every move. When element will be dragged over another element
drag.over.<id>
will be fired as well.
@@ -201,8 +207,8 @@ See also Element.removeData
event object DOM event object
Returns: object Element
-
Returns bounding box descriptor for the given element.
+
+Returns bounding box descriptor for the given element.
Returns: object bounding box descriptor:
{cx: number x of the center,
@@ -221,60 +227,54 @@ See also Element.removeData
y2: number y of the right side,
y: number y of the left side
}
-
Element.getPointAtLength(length)⚓ ➭
-
Return coordinates of the point located at the given length on the given path. Only works for element of “path” type.
+
Element.getPointAtLength(length)⚓ ➭
+Return coordinates of the point located at the given length on the given path. Only works for element of “path” type.
-
-
length
-number
-
-
+
Returns: object representation of the point:
{x: number x coordinate
y: number y coordinate
alpha: number angle of derivative
}
-
Element.getSubpath(from, to)⚓ ➭
-
Return subpath of a given element from given length to given length. Only works for element of “path” type.
+
Element.getSubpath(from, to)⚓ ➭
+Return subpath of a given element from given length to given length. Only works for element of “path” type.
-
-
from
-number
-position of the start of the segment
-to
-number
-position of the end of the segment
-
+
from
+number
+position of the start of the segment
+to
+number
+position of the end of the segment
+
Returns: string pathstring for the segment
-
Element.getTotalLength()⚓ ➭
-
Returns length of the path in pixels. Only works for element of “path” type.
+
Element.getTotalLength()⚓ ➭
+Returns length of the path in pixels. Only works for element of “path” type.
Returns: number length.
-
Element.hover(f_in, f_out, [icontext], [ocontext])⚓ ➭
-
Adds event handlers for hover for the element.
+
Element.hover(f_in, f_out, [icontext], [ocontext])⚓ ➭
+Adds event handlers for hover for the element.
-
-
f_in
-function
-handler for hover in
-f_out
-function
-handler for hover out
-icontext
-optional
-object
-context for hover in handler
-ocontext
-optional
-object
-context for hover out handler
-
+
f_in
+function
+handler for hover in
+f_out
+function
+handler for hover out
+icontext
+optional
+object
+context for hover in handler
+ocontext
+optional
+object
+context for hover out handler
+
Returns: object Element
-
Returns an array of animations element currently in
+
+Returns an array of animations element currently in
Returns: object in format
{anim object animation object,
@@ -282,243 +282,209 @@ See also Element.removeData
status function gets or sets the status of the animation,
stop function stops the animation
}
-
Element.insertAfter(el)⚓ ➭
-
Inserts the element after the given one.
+
Element.insertAfter(el)⚓ ➭
+Inserts the element after the given one.
-
-
el
-Element
-element next to whom insert to
-
+
el
+Element
+element next to whom insert to
+
Returns: Element parent
-
Element.insertBefore(el)⚓ ➭
-
Inserts the element after the given one.
+
Element.insertBefore(el)⚓ ➭
+Inserts the element after the given one.
-
-
el
-Element
-element next to whom insert to
-
+
el
+Element
+element next to whom insert to
+
Returns: Element parent
-
Element.marker(x, y, width, height, refX, refY)⚓ ➭
-
Creates <marker>
element from the current element.
+
Element.marker(x, y, width, height, refX, refY)⚓ ➭
+Creates <marker>
element from the current element.
+To create a marker you have to specify the bounding rect and reference point:
-
To create a marker you have to specify the bounding rect and reference point:
-
-
x
-number
-
-y
-number
-
-width
-number
-
-height
-number
-
-refX
-number
-
-refY
-number
-
-
+
x
+number
+
+y
+number
+
+width
+number
+
+height
+number
+
+refX
+number
+
+refY
+number
+
+
Returns: Element <marker>
element
You can use pattern later on as an argument for marker-start
or marker-end
attributes.
-
Element.mousedown(handler)⚓ ➭
-
Adds event handler for mousedown for the element.
+
Element.mousedown(handler)⚓ ➭
+Adds event handler for mousedown for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.mousemove(handler)⚓ ➭
-
Adds event handler for mousemove for the element.
+
Element.mousemove(handler)⚓ ➭
+Adds event handler for mousemove for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.mouseout(handler)⚓ ➭
-
Adds event handler for mouseout for the element.
+
Element.mouseout(handler)⚓ ➭
+Adds event handler for mouseout for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.mouseover(handler)⚓ ➭
-
Adds event handler for mouseover for the element.
+
Element.mouseover(handler)⚓ ➭
+Adds event handler for mouseover for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.mouseup(handler)⚓ ➭
-
Adds event handler for mouseup for the element.
+
Element.mouseup(handler)⚓ ➭
+Adds event handler for mouseup for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.onDragOver(f)⚓ ➭
-
Shortcut for assigning event handler for drag.over.<id>
event, where id is id of the element (see Element.id ).
+
+Shortcut for assigning event handler for drag.over.<id>
event, where id is id of the element (see Element.id ).
-
-
f
-function
-handler for event, first argument would be the element you are dragging over
-
-
Returns parent of the element
+
f
+function
+handler for event, first argument would be the element you are dragging over
+
+
+Returns parent of the element
Returns: Element parent
-
Element.pattern(x, y, width, height)⚓ ➭
-
Creates <pattern>
element from the current element.
+
Element.pattern(x, y, width, height)⚓ ➭
+Creates <pattern>
element from the current element.
+To create a pattern you have to specify the pattern rect:
-
To create a pattern you have to specify the pattern rect:
-
-
x
-string number
-
-y
-string number
-
-width
-string number
-
-height
-string number
-
-
+
x
+string number
+
+y
+string number
+
+width
+string number
+
+height
+string number
+
+
Returns: Element <pattern>
element
You can use pattern later on as an argument for fill
attribute:
-
var p = paper.path("M10-5 -10 ,15M15,0 ,0 ,15M0-5 -20 ,15 " ).attr({
- fill: "none" ,
- stroke: "#bada55" ,
- strokeWidth: 5
- }).pattern(0 , 0 , 10 , 10 ),
- c = paper.circle(200 , 200 , 100 );
+var p = paper.path("M10-5-10,15M15,0,0,15M0-5-20,15").attr({
+ fill: "none",
+ stroke: "#bada55",
+ strokeWidth: 5
+ }).pattern(0, 0, 10, 10),
+ c = paper.circle(200, 200, 100);
c.attr({
fill: p
});
-
-
Prepends given element to current one.
+
+
+Prepends given element to current one.
-
-
el
-Element
-element to prepend
-
+
el
+Element
+element to prepend
+
Returns: Element parent
-
Removes element from the DOM
+
+Removes element from the DOM
-
Element.removeData([key])⚓ ➭
-
Removes value associated with an element by given key.
+
Element.removeData([key])⚓ ➭
+Removes value associated with an element by given key.
If key is not provided, removes all the data of the element.
-
-
key
-optional
-string
-key
-
+
key
+optional
+string
+key
+
Returns: object Element
-
Element.select(query)⚓ ➭
-
Applies CSS selector with the element as a parent and returns the result as an Element .
+
+Applies CSS selector with the element as a parent and returns the result as an Element .
-
-
query
-string
-CSS selector
-
+
query
+string
+CSS selector
+
Returns: Element result of query selection
-
Element.selectAll(query)⚓ ➭
-
Applies CSS selector with the element as a parent and returns the result as a set or array of elements.
+
Element.selectAll(query)⚓ ➭
+Applies CSS selector with the element as a parent and returns the result as a set or array of elements.
-
-
query
-string
-CSS selector
-
+
query
+string
+CSS selector
+
Returns: Set array result of query selection
-
Element.touchcancel(handler)⚓ ➭
-
Adds event handler for touchcancel for the element.
+
+Stops all the animations of the current element.
-
Returns: Element the element
+
Element.touchcancel(handler)⚓ ➭
+Adds event handler for touchcancel for the element.
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.touchend(handler)⚓ ➭
-
Adds event handler for touchend for the element.
+
Element.touchend(handler)⚓ ➭
+Adds event handler for touchend for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.touchmove(handler)⚓ ➭
-
Adds event handler for touchmove for the element.
+
Element.touchmove(handler)⚓ ➭
+Adds event handler for touchmove for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.touchstart(handler)⚓ ➭
-
Adds event handler for touchstart for the element.
+
Element.touchstart(handler)⚓ ➭
+Adds event handler for touchstart for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Gets or sets transformation of the element
+
+Gets or sets transformation of the element
-
-
tstr
-string
-transform string in Savage or SVG format
-
+
tstr
+string
+transform string in Savage or SVG format
+
Returns: Element
or
@@ -531,217 +497,187 @@ If key is not provided, removes all the data of the element.
local string local transformation as string,
toString function returns string
property
}
-
Element.unclick(handler)⚓ ➭
-
Removes event handler for click for the element.
+
Element.unclick(handler)⚓ ➭
+Removes event handler for click for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.undblclick(handler)⚓ ➭
-
Removes event handler for double click for the element.
+
Element.undblclick(handler)⚓ ➭
+Removes event handler for double click for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Removes all drag event handlers from given element.
+
+Removes all drag event handlers from given element.
-
Element.unhover(f_in, f_out)⚓ ➭
-
Removes event handlers for hover for the element.
+
Element.unhover(f_in, f_out)⚓ ➭
+Removes event handlers for hover for the element.
-
-
f_in
-function
-handler for hover in
-f_out
-function
-handler for hover out
-
+
f_in
+function
+handler for hover in
+f_out
+function
+handler for hover out
+
Returns: object Element
-
Element.unmousedown(handler)⚓ ➭
-
Removes event handler for mousedown for the element.
+
Element.unmousedown(handler)⚓ ➭
+Removes event handler for mousedown for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.unmousemove(handler)⚓ ➭
-
Removes event handler for mousemove for the element.
+
Element.unmousemove(handler)⚓ ➭
+Removes event handler for mousemove for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.unmouseout(handler)⚓ ➭
-
Removes event handler for mouseout for the element.
+
Element.unmouseout(handler)⚓ ➭
+Removes event handler for mouseout for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.unmouseover(handler)⚓ ➭
-
Removes event handler for mouseover for the element.
+
Element.unmouseover(handler)⚓ ➭
+Removes event handler for mouseover for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.unmouseup(handler)⚓ ➭
-
Removes event handler for mouseup for the element.
+
Element.unmouseup(handler)⚓ ➭
+Removes event handler for mouseup for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.untouchcancel(handler)⚓ ➭
-
Removes event handler for touchcancel for the element.
+
Element.untouchcancel(handler)⚓ ➭
+Removes event handler for touchcancel for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.untouchend(handler)⚓ ➭
-
Removes event handler for touchend for the element.
+
Element.untouchend(handler)⚓ ➭
+Removes event handler for touchend for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.untouchmove(handler)⚓ ➭
-
Removes event handler for touchmove for the element.
+
Element.untouchmove(handler)⚓ ➭
+Removes event handler for touchmove for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Element.untouchstart(handler)⚓ ➭
-
Removes event handler for touchstart for the element.
+
Element.untouchstart(handler)⚓ ➭
+Removes event handler for touchstart for the element.
-
-
handler
-function
-handler for the event
-
+
handler
+function
+handler for the event
+
Returns: object Element
-
Creates <use>
element linked to the current element.
+
+Creates <use>
element linked to the current element.
Returns: Element <use>
element
-
+
+
+ Matrix.add(a, b, c, d, e, f, matrix)⚓ ➭
-
Adds given matrix to existing one.
+
+ Matrix.add(a, b, c, d, e, f, matrix)⚓ ➭
+Adds given matrix to existing one.
-
-
a
-number
-
-b
-number
-
-c
-number
-
-d
-number
-
-e
-number
-
-f
-number
-
-matrix
-object
-Matrix
-
-
Returns copy of the matrix
+
a
+number
+
+b
+number
+
+c
+number
+
+d
+number
+
+e
+number
+
+f
+number
+
+matrix
+object
+Matrix
+
+
+Returns copy of the matrix
Returns: object Matrix
-
Returns inverted version of the matrix
+
+Returns inverted version of the matrix
Returns: object Matrix
-
Matrix.rotate(a, x, y)⚓ ➭
-
+Rotates the matrix
-
a
+number
+
+x
+number
+
+y
+number
+
+
+
Matrix.scale(x, [y], [cx], [cy])⚓ ➭
+Scales the matrix
-
a
-number
-
-x
-number
-
-y
-number
-
-
-
Matrix.scale(x, [y], [cx], [cy])⚓ ➭
-
Scales the matrix
-
-
-
x
-number
-
-y
-optional
-number
-
-cx
-optional
-number
-
-cy
-optional
-number
-
-
-
Splits matrix into primitive transformations
+
x
+number
+
+y
+optional
+number
+
+cx
+optional
+number
+
+cy
+optional
+number
+
+
+
+Splits matrix into primitive transformations
Returns: object in format:
dx number translation by x
@@ -752,213 +688,176 @@ If key is not provided, removes all the data of the element.
rotate number rotation in deg
isSimple boolean could it be represented via simple transformations
-
Return transform string that represents given matrix
+
+Return transform string that represents given matrix
Returns: string transform string
-
Matrix.translate(x, y)⚓ ➭
-
+Translate the matrix
-
x
+number
+
+y
+number
+
+
+
+Return x coordinate for given point after transformation described by the matrix. See also Matrix.y
-
x
-number
-
-y
-number
-
-
-
Return x coordinate for given point after transformation described by the matrix. See also Matrix.y
-
-
-
x
-number
-
-y
-number
-
-
+
x
+number
+
+y
+number
+
+
Returns: number x
-
Return y coordinate for given point after transformation described by the matrix. See also Matrix.x
+
+Return y coordinate for given point after transformation described by the matrix. See also Matrix.x
-
-
x
-number
-
-y
-number
-
-
+
x
+number
+
+y
+number
+
+
Returns: number y
-
Paper.circle(x, y, r)⚓ ➭
-
+
+Draws a circle.
-
-
x
-number
-x coordinate of the centre
-y
-number
-y coordinate of the centre
-r
-number
-radius
-
+
x
+number
+x coordinate of the centre
+y
+number
+y coordinate of the centre
+r
+number
+radius
+
Returns: object Element object with type “circle”
-
Usage var c = paper.circle(50, 50, 40);
+
+
+Creates element on paper with a given name and no attributes.
-
var c = paper.circle(50 , 50 , 40 );
-
-
Creates element on paper with a given name and no attributes.
-
-
-
name
-string
-element tag name
-
+
name
+string
+element tag name
+
Returns: Element the element
-
-
var c = paper.circle(10 , 10 , 10 ); // is the same as...
-var c = paper.el("circle" ).attr({
- cx: 10 ,
- cy: 10 ,
- r: 10
+Usage var c = paper.circle(10, 10, 10); // is the same as...
+var c = paper.el("circle").attr({
+ cx: 10,
+ cy: 10,
+ r: 10
});
-
-
Paper.ellipse(x, y, rx, ry)⚓ ➭
-
Paper.ellipse(x, y, rx, ry)⚓ ➭
+Draws an ellipse.
-
-
x
-number
-x coordinate of the centre
-y
-number
-y coordinate of the centre
-rx
-number
-horizontal radius
-ry
-number
-vertical radius
-
+
x
+number
+x coordinate of the centre
+y
+number
+y coordinate of the centre
+rx
+number
+horizontal radius
+ry
+number
+vertical radius
+
Returns: object Element object with type “ellipse”
-
Usage var c = paper.ellipse(50, 50, 40, 20);
+
+
+Creates filter element
-
var c = paper.ellipse(50 , 50 , 40 , 20 );
-
-
Creates filter element
-
-
-
filstr
-string
-SVG fragment of filter provided as a string.
-
+
filstr
+string
+SVG fragment of filter provided as a string.
+
Returns: object Element
Note: It is recommended to use filters embedded into page inside empty SVG element.
-
-
var f = paper.filter('<feGaussianBlur stdDeviation="2 "/>' ),
- c = paper.circle(10 , 10 , 10 ).attr({
+Usage var f = paper.filter('<feGaussianBlur stdDeviation="2"/>'),
+ c = paper.circle(10, 10, 10).attr({
filter: f
});
-
-
Paper.filter.blur(dx, dy, [blur], [color])⚓ ➭
-
Returns string of the blur filter.
+
+
Paper.filter.blur(dx, dy, [blur], [color])⚓ ➭
+Returns string of the blur filter.
-
-
x
-number
-amount of horisontal blur in px.
-y
-optional
-number
-amount of vertical blur in px.
-
+
x
+number
+amount of horisontal blur in px.
+y
+optional
+number
+amount of vertical blur in px.
+
Returns: string filter representation
-
-
var f = paper.filter(Savage.filter.blur(5 , 10 )),
- c = paper.circle(10 , 10 , 10 ).attr({
+Usage var f = paper.filter(Savage.filter.blur(5, 10)),
+ c = paper.circle(10, 10, 10).attr({
filter: f
});
-
+
Returns string of the blur filter.
-
-
dx
-number
-horisontal shift of the shadow in px.
-dy
-number
-vertical shift of the shadow in px.
-blur
-optional
-number
-amount of blur.
-color
-optional
-string
-color of the shadow.
-
+
dx
+number
+horisontal shift of the shadow in px.
+dy
+number
+vertical shift of the shadow in px.
+blur
+optional
+number
+amount of blur.
+color
+optional
+string
+color of the shadow.
+
Returns: string filter representation
-
-
var f = paper.filter(Savage.filter.shadow(5 , 10 )),
- c = paper.circle(10 , 10 , 10 ).attr({
+Usage var f = paper.filter(Savage.filter.shadow(5, 10)),
+ c = paper.circle(10, 10, 10).attr({
filter: f
});
-
-
Makes a group element.
+
+
+Makes a group element.
-
-
varargs
-optional
-…
-elements
-
+
varargs
+optional
+…
+elements
+
Returns: object Element object with type “g”
-
-
var c1 = paper.circle(),
- c2 = paper.rect(),
- g = paper.g(c2, c1); // note that the order of elements will be different
-
+
Usage var c1 = paper.circle(),
+ c2 = paper.rect(),
+ g = paper.g(c2, c1); // note that the order of elements will be different
+
or
-
var c1 = paper.circle(),
- c2 = paper.rect(),
- g = paper.g();
+var c1 = paper.circle(),
+ c2 = paper.rect(),
+ g = paper.g();
g.add(c2, c1);
-
-
Paper.gradient(gradient)⚓ ➭
-
Creates a gradient element.
+
+
Paper.gradient(gradient)⚓ ➭
+Creates a gradient element.
-
-
gradient
-string
-gradient descriptor
-
-
Gradient descriptor consists of <type>(<coords>)<colors>
. Type
+
gradient
+string
+gradient descriptor
+
+
Gradient Descriptor Gradient descriptor consists of <type>(<coords>)<colors>
. Type
could be linear or radial, which presented as letter “L” or “R”. Any
type could be absolute or relative, absolute gradient take it coords
relative to the SVG surface, while relative takes them relative to
@@ -969,119 +868,103 @@ vector of gradient for linear as x1, y1, x2, y2. For radial as cx,
cy, r and optional fx, fy. Colors are list of dash separated colors.
Optionally color could have offset after colon.
-
-
var g = paper.gradient("l(0 , 0 , 1 , 1 )#000 -#f00-#fff" );
-
+
Example var g = paper.gradient("l(0, 0, 1, 1)#000-#f00-#fff");
+
Linear gradient, relative from top-left corner to bottom-right
corner, from black through red to white.
-
var g = paper.gradient("L(0 , 0 , 100 , 100 )#000 -#f00:25 %-#fff" );
-
+
var g = paper.gradient("L(0, 0, 100, 100)#000-#f00:25%-#fff");
+
Linear gradient, absolute from (0, 0) to (100, 100), from black
through red at 25% to white.
-
var g = paper.gradient("r(0.5 , 0.5 , 0.5 )#000 -#fff" );
-
+
var g = paper.gradient("r(0.5, 0.5, 0.5)#000-#fff");
+
Radial gradient, relative from the center of the element with radius
0.5 of the width, from black to white.
-
paper.circle(50 , 50 , 40 ).attr({
+paper.circle(50, 50, 40).attr({
fill: g
});
-
+
Returns: object Element object with type “gradient”
-
+ Paper.image(src, x, y, width, height)⚓ ➭
-
Embeds an image into the surface.
+
Paper.image(src, x, y, width, height)⚓ ➭
+Embeds an image into the surface.
-
-
src
-string
-URI of the source image
-x
-number
-x coordinate position
-y
-number
-y coordinate position
-width
-number
-width of the image
-height
-number
-height of the image
-
+
src
+string
+URI of the source image
+x
+number
+x coordinate position
+y
+number
+y coordinate position
+width
+number
+width of the image
+height
+number
+height of the image
+
Returns: object Raphaël element object with type “image”
-
-
var c = paper.image("apple.png" , 10 , 10 , 80 , 80 );
-
+
Usage var c = paper.image("apple.png", 10, 10, 80, 80);
+
Embeds an image into the surface.
-
-
src
-string
-URI of the source image
-x
-number
-x coordinate position
-y
-number
-y coordinate position
-width
-number
-width of the image
-height
-number
-height of the image
-
+
src
+string
+URI of the source image
+x
+number
+x coordinate position
+y
+number
+y coordinate position
+width
+number
+width of the image
+height
+number
+height of the image
+
Returns: object Element object with type “image”
-
Usage var c = paper.image("apple.png", 10, 10, 80, 80);
+
+
Paper.line(x1, y1, x2, y2)⚓ ➭
+Draws a line.
-
var c = paper.image("apple.png" , 10 , 10 , 80 , 80 );
-
-
Paper.line(x1, y1, x2, y2)⚓ ➭
-
Draws a line.
-
-
-
x1
-number
-x coordinate position of the start
-y1
-number
-y coordinate position of the start
-x2
-number
-x coordinate position of the end
-y2
-number
-y coordinate position of the end
-
+
x1
+number
+x coordinate position of the start
+y1
+number
+y coordinate position of the start
+x2
+number
+x coordinate position of the end
+y2
+number
+y coordinate position of the end
+
Returns: object Element object with type “line”
-
Usage var t1 = paper.line(50, 50, 100, 100);
+
+
Paper.path([pathString])⚓ ➭
+Creates a path element by given path data string.
-
var t1 = paper.line(50 , 50 , 100 , 100 );
-
-
Paper.path([pathString])⚓ ➭
-
Creates a path element by given path data string.
-
-
-
pathString
-optional
-string
-path string in SVG format.
-
+
pathString
+optional
+string
+path string in SVG format.
+
Path string consists of one-letter commands, followed by comma seprarated arguments in numercal form. Example:
-
"M10,20L30,40 "
-
+
Here we can see two commands: “M”, with arguments (10, 20)
and “L” with arguments (30, 40)
. Upper case letter mean command is absolute, lower case—relative.
@@ -1101,151 +984,164 @@ through red at 25% to white.
“Catmull-Rom curveto” is a not standard SVG command and added to make life easier.
Note: there is a special case when path consist of just three commands: “M10,10R…z”. In this case path will smoothly connects to its beginning.
-
Usage var c = paper.path("M10 10L90 90");
+// draw a diagonal line:
+// move to 10,10, line to 90,90
+
+
+Draws a polygon. See Paper.polyline
-
var c = paper.path("M10 10L90 90 " );
-// draw a diagonal line:
-// move to 10 ,10 , line to 90 ,90
-
-
+Draws a polyline.
-
-
-
points
-array
-array of points
-
+
points
+array
+array of points
+
or
-
varargs
-…
-points
-
+
Returns: object Element object with type “text”
-
-
var p1 = paper.polyline([10 , 10 , 100 , 100 ]);
-var p2 = paper.polyline(10 , 10 , 100 , 100 );
-
-
Paper.rect(x, y, width, height, [rx], [ry])⚓ ➭
-
+
Usage var p1 = paper.polyline([10, 10, 100, 100]);
+var p2 = paper.polyline(10, 10, 100, 100);
+
+
Paper.rect(x, y, width, height, [rx], [ry])⚓ ➭
+
Draws a rectangle.
-
-
x
-number
-x coordinate of the top left corner
-y
-number
-y coordinate of the top left corner
-width
-number
-width
-height
-number
-height
-rx
-optional
-number
-horisontal radius for rounded corners, default is 0
-ry
-optional
-number
-vertical radius for rounded corners, default is rx or 0
-
+
x
+number
+x coordinate of the top left corner
+y
+number
+y coordinate of the top left corner
+width
+number
+width
+height
+number
+height
+rx
+optional
+number
+horisontal radius for rounded corners, default is 0
+ry
+optional
+number
+vertical radius for rounded corners, default is rx or 0
+
Returns: object Element object with type “rect”
-
Usage // regular rectangle
+var c = paper.rect(10, 10, 50, 50);
+// rectangle with rounded corners
+var c = paper.rect(40, 40, 50, 50, 10);
+
+
+Draws a text string.
-
// regular rectangle
-var c = paper.rect(10 , 10 , 50 , 50 );
-// rectangle with rounded corners
-var c = paper.rect(40 , 40 , 50 , 50 , 10 );
-
-
Paper.text(x, y, text)⚓ ➭
-
Draws a text string.
-
-
-
x
-number
-x coordinate position
-y
-number
-y coordinate position
-text
-string array
-The text string to draw or array of <tspan>s
-
+
x
+number
+x coordinate position
+y
+number
+y coordinate position
+text
+string array
+The text string to draw or array of <tspan>s
+
Returns: object Element object with type “text”
-
-
var t1 = paper.text(50 , 50 , "Savage" );
-var t2 = paper.text(50 , 50 , ["S" ,"a" ,"v" ,"a" ,"g" ,"e" ]);
-
-
Utility method
+
Usage var t1 = paper.text(50, 50, "Savage");
+var t2 = paper.text(50, 50, ["S","a","v","a","g","e"]);
+
+
+
+Utility method
Returns matrix based on given parameters.
-
-
a
-number
-
-b
-number
-
-c
-number
-
-d
-number
-
-e
-number
-
-f
-number
-
-
+
a
+number
+
+b
+number
+
+c
+number
+
+d
+number
+
+e
+number
+
+f
+number
+
+
or
-
svgMatrix
-SVGMatrix
-
-
+
Returns: object Matrix
-
Savage.animate(from, to, setter, ms, [easing], [callback])⚓ ➭
-
Runs generic animation of one number into another with a caring function.
+
+Simple implementation of Ajax.
-
url
+string
+URL
+postData
+object string
+data for post request
+callback
+function
+callback
+scope
+optional
+object
+scope of callback
+
+
or
-
from
-number array
-number or array of numbers
-to
-number array
-number or array of numbers
-setter
-function
-caring function that will take one number argument
-ms
-number
-duration
-easing
-optional
-function
-easing function from mina or custom
-callback
-optional
-function
-
-
+
url
+string
+URL
+callback
+function
+callback
+scope
+optional
+object
+scope of callback
+
+
Returns: XMLHttpRequest XMLHttpRequest (just in case)
+
Savage.animate(from, to, setter, ms, [easing], [callback])⚓ ➭
+Runs generic animation of one number into another with a caring function.
+
+
from
+number array
+number or array of numbers
+to
+number array
+number or array of numbers
+setter
+function
+caring function that will take one number argument
+ms
+number
+duration
+easing
+optional
+function
+easing function from mina or custom
+callback
+optional
+function
+
+
Returns: object animation object in mina format
{id string animation id, consider it read-only,
duration function gets or sets the duration of the animation,
@@ -1254,36 +1150,32 @@ Returns matrix based on given parameters.
status function gets or sets the status of the animation,
stop function stops the animation
}
-
Savage.animation(attr, ms, [easing], [callback])⚓ ➭
-
Creates animation object.
+
Savage.animation(attr, ms, [easing], [callback])⚓ ➭
+Creates animation object.
-
-
attr
-object
-attributes of final destination
-ms
-number
-animation duration
-easing
-optional
-function
-one of easing functions of mina or custom one
-callback
-optional
-function
-callback
-
+
attr
+object
+attributes of final destination
+ms
+number
+animation duration
+easing
+optional
+function
+one of easing functions of mina or custom one
+callback
+optional
+function
+callback
+
Returns: object animation object
-
Parses the color string and returns object with all values for the given color.
+
+Parses the color string and returns object with all values for the given color.
-
-
clr
-string
-color string in one of the supported formats (see Savage.getRGB )
-
+
clr
+string
+color string in one of the supported formats (see Savage.getRGB )
+
Returns: object Combined RGB & HSB object in format:
{r number red,
g number green,
@@ -1295,50 +1187,46 @@ Returns matrix based on given parameters.
v number value (brightness),
l number lightness
}
-
Transform angle to degrees
+
+Transform angle to degrees
-
-
deg
-number
-angle in radians
-
+
deg
+number
+angle in radians
+
Returns: number angle in degrees.
-
Savage.findDotsAtSegment(p1x, p1y, c1x, c1y, c2x, c2y, p2x, p2y, t)⚓ ➭
-
Savage.findDotsAtSegment(p1x, p1y, c1x, c1y, c2x, c2y, p2x, p2y, t)⚓ ➭
+Utility method
Find dot coordinates on the given cubic bezier curve at the given t.
-
-
p1x
-number
-x of the first point of the curve
-p1y
-number
-y of the first point of the curve
-c1x
-number
-x of the first anchor of the curve
-c1y
-number
-y of the first anchor of the curve
-c2x
-number
-x of the second anchor of the curve
-c2y
-number
-y of the second anchor of the curve
-p2x
-number
-x of the second point of the curve
-p2y
-number
-y of the second point of the curve
-t
-number
-position on the curve (0..1)
-
+
p1x
+number
+x of the first point of the curve
+p1y
+number
+y of the first point of the curve
+c1x
+number
+x of the first anchor of the curve
+c1y
+number
+y of the first anchor of the curve
+c2x
+number
+x of the second anchor of the curve
+c2y
+number
+y of the second anchor of the curve
+p2x
+number
+x of the second point of the curve
+p2y
+number
+y of the second point of the curve
+t
+number
+position on the curve (0..1)
+
Returns: object point information in format:
{x: number x coordinate of the point
y: number y coordinate of the point
@@ -1352,51 +1240,43 @@ Find dot coordinates on the given cubic bezier curve at the given t.
y: number y coordinate of the end of the curve
} alpha: number angle of the curve derivative at the point
}
-
Replaces construction of type “{<name>}
” to the corresponding argument.
+
+Replaces construction of type “{<name>}
” to the corresponding argument.
-
-
token
-string
-string to format
-json
-object
-object which properties will be used as a replacement
-
+
token
+string
+string to format
+json
+object
+object which properties will be used as a replacement
+
Returns: string formated string
-
-
// this will draw a rectangular shape equivalent to "M10,20h40v50h-40z"
-paper.path(Savage.format("M{x},{y}h{dim.width}v{dim.height}h{dim['negative width']}z" , {
- x: 10 ,
- y: 20 ,
+Usage // this will draw a rectangular shape equivalent to "M10,20h40v50h-40z"
+paper.path(Savage.format("M{x},{y}h{dim.width}v{dim.height}h{dim['negative width']}z", {
+ x: 10,
+ y: 20,
dim: {
- width: 40 ,
- height: 50 ,
- "negative width" : -40
+ width: 40,
+ height: 50,
+ "negative width": -40
}
}));
-
-
Savage.fragment(varargs)⚓ ➭
-
Creates DOM fragment from given list of elements or strings
+
+
Savage.fragment(varargs)⚓ ➭
+Creates DOM fragment from given list of elements or strings
-
-
varargs
-…
-SVG string
-
+
Returns: Fragment the Fragment
-
Savage.getRGB(colour)⚓ ➭
-
Parses colour string as RGB object
+
+Parses colour string as RGB object
-
-
colour
-string
-colour string in one of formats:
-
+
colour
+string
+colour string in one of formats:
+
Colour name (“red
”, “green
”, “cornflowerblue
”, etc)
#••• — shortened HTML colour: (“#000
”, “#fc0
”, etc)
@@ -1415,225 +1295,199 @@ paper.path(Savage.format("M{x},{y}h{dim.width}v{dim.height}h{dim['negative wi
hex string color in HTML/CSS format: #••••••,
error boolean true if string cant be parsed
}
- Converts HSB values to hex representation of the colour.
+
+Converts HSB values to hex representation of the colour.
-
-
h
-number
-hue
-s
-number
-saturation
-b
-number
-value or brightness
-
+
h
+number
+hue
+s
+number
+saturation
+b
+number
+value or brightness
+
Returns: string hex representation of the colour.
-
Savage.hsb2rgb(h, s, v)⚓ ➭
-
Converts HSB values to RGB object.
+
Savage.hsb2rgb(h, s, v)⚓ ➭
+Converts HSB values to RGB object.
-
-
h
-number
-hue
-s
-number
-saturation
-v
-number
-value or brightness
-
+
h
+number
+hue
+s
+number
+saturation
+v
+number
+value or brightness
+
Returns: object RGB object in format:
{r number red,
g number green,
b number blue,
hex string color in HTML/CSS format: #••••••
}
-
Converts HSL values to hex representation of the colour.
+
+Converts HSL values to hex representation of the colour.
-
-
h
-number
-hue
-s
-number
-saturation
-l
-number
-luminosity
-
+
h
+number
+hue
+s
+number
+saturation
+l
+number
+luminosity
+
Returns: string hex representation of the colour.
-
Savage.hsl2rgb(h, s, l)⚓ ➭
-
Converts HSL values to RGB object.
+
Savage.hsl2rgb(h, s, l)⚓ ➭
+Converts HSL values to RGB object.
-
-
h
-number
-hue
-s
-number
-saturation
-l
-number
-luminosity
-
+
h
+number
+hue
+s
+number
+saturation
+l
+number
+luminosity
+
Returns: object RGB object in format:
{r number red,
g number green,
b number blue,
hex string color in HTML/CSS format: #••••••
}
-
Handfull replacement for typeof
operator.
+
+Handfull replacement for typeof
operator.
-
-
o
-…
-any object or primitive
-type
-string
-name of the type, i.e. “string”, “function”, “number”, etc.
-
+
o
+…
+any object or primitive
+type
+string
+name of the type, i.e. “string”, “function”, “number”, etc.
+
Returns: boolean is given value is of given type
-
Parses SVG fragment and converts it into Fragment .
+
+Parses SVG fragment and converts it into Fragment .
-
-
svg
-string
-SVG string
-
+
svg
+string
+SVG string
+
Returns: Fragment the fragment
-
Savage.parsePathString(pathString)⚓ ➭
-
Savage.parsePathString(pathString)⚓ ➭
+Utility method
Parses given path string into an array of arrays of path segments.
-
-
pathString
-string array
-path string or array of segments (in the last case it will be returned straight away)
-
+
pathString
+string array
+path string or array of segments (in the last case it will be returned straight away)
+
Returns: array array of segments.
-
+Utility method
Parses given path string into an array of transformations.
-
-
TString
-string array
-transform string or array of transformations (in the last case it will be returned straight away)
-
+
TString
+string array
+transform string or array of transformations (in the last case it will be returned straight away)
+
Returns: array array of transformations.
-
Savage.path.bezierBBox(…)⚓ ➭
-
+ Savage.path.bezierBBox(…)⚓ ➭
+Utility method
Return bounding box of a given cubic bezier curve
-
-
p1x
-number
-x of the first point of the curve
-p1y
-number
-y of the first point of the curve
-c1x
-number
-x of the first anchor of the curve
-c1y
-number
-y of the first anchor of the curve
-c2x
-number
-x of the second anchor of the curve
-c2y
-number
-y of the second anchor of the curve
-p2x
-number
-x of the second point of the curve
-p2y
-number
-y of the second point of the curve
-
+
p1x
+number
+x of the first point of the curve
+p1y
+number
+y of the first point of the curve
+c1x
+number
+x of the first anchor of the curve
+c1y
+number
+y of the first anchor of the curve
+c2x
+number
+x of the second anchor of the curve
+c2y
+number
+y of the second anchor of the curve
+p2x
+number
+x of the second point of the curve
+p2y
+number
+y of the second point of the curve
+
or
-
bez
-array
-array of six points for bezier curve
-
+
bez
+array
+array of six points for bezier curve
+
Returns: object point information in format:
{ min: {x: number x coordinate of the left point
y: number y coordinate of the top point
} max: {x: number x coordinate of the right point
y: number y coordinate of the bottom point
} }
-
Savage.path.getPointAtLength(path, length)⚓ ➭
-
Return coordinates of the point located at the given length on the given path.
+
Savage.path.getPointAtLength(path, length)⚓ ➭
+Return coordinates of the point located at the given length on the given path.
-
-
path
-string
-SVG path string
-length
-number
-
-
+
path
+string
+SVG path string
+length
+number
+
+
Returns: object representation of the point:
{x: number x coordinate
y: number y coordinate
alpha: number angle of derivative
}
-
Savage.path.getSubpath(path, from, to)⚓ ➭
-
Return subpath of a given path from given length to given length.
+
Savage.path.getSubpath(path, from, to)⚓ ➭
+Return subpath of a given path from given length to given length.
-
-
path
-string
-SVG path string
-from
-number
-position of the start of the segment
-to
-number
-position of the end of the segment
-
+
path
+string
+SVG path string
+from
+number
+position of the start of the segment
+to
+number
+position of the end of the segment
+
Returns: string pathstring for the segment
-
Savage.path.getTotalLength(path)⚓ ➭
-
Returns length of the given path in pixels.
+
Savage.path.getTotalLength(path)⚓ ➭
+Returns length of the given path in pixels.
-
-
path
-string
-SVG path string.
-
+
path
+string
+SVG path string.
+
Returns: number length.
-
Savage.path.intersection(path1, path2)⚓ ➭
-
Savage.path.intersection(path1, path2)⚓ ➭
+Utility method
Finds intersections of two paths
-
-
path1
-string
-path string
-path2
-string
-path string
-
+
path1
+string
+path string
+path2
+string
+path string
+
Returns: array dots of intersection
[ {x: number x coordinate of the point
y: number y coordinate of the point
@@ -1644,110 +1498,94 @@ Finds intersections of two paths
bez1: array eight coordinates representing beziér curve for the segment of path1
bez2: array eight coordinates representing beziér curve for the segment of path2
} ]
-
Savage.path.isBBoxIntersect(bbox1, bbox2)⚓ ➭
-
Savage.path.isBBoxIntersect(bbox1, bbox2)⚓ ➭
+Utility method
Returns true
if two bounding boxes intersect
-
-
bbox1
-string
-first bounding box
-bbox2
-string
-second bounding box
-
+
bbox1
+string
+first bounding box
+bbox2
+string
+second bounding box
+
Returns: boolean true
if they intersect
-
Savage.path.isPointInside(path, x, y)⚓ ➭
-
Savage.path.isPointInside(path, x, y)⚓ ➭
+Utility method
Returns true
if given point is inside a given closed path.
-
-
path
-string
-path string
-x
-number
-x of the point
-y
-number
-y of the point
-
+
path
+string
+path string
+x
+number
+x of the point
+y
+number
+y of the point
+
Returns: boolean true, if point is inside the path
-
Savage.path.isPointInsideBBox(bbox, x, y)⚓ ➭
-
Savage.path.isPointInsideBBox(bbox, x, y)⚓ ➭
+Utility method
Returns true
if given point is inside bounding box.
-
-
bbox
-string
-bounding box
-x
-string
-x coordinate of the point
-y
-string
-y coordinate of the point
-
+
bbox
+string
+bounding box
+x
+string
+x coordinate of the point
+y
+string
+y coordinate of the point
+
Returns: boolean true
if point inside
-
Savage.path.map(path, matrix)⚓ ➭
-
Transform the path string with given matrix.
+
Savage.path.map(path, matrix)⚓ ➭
+Transform the path string with given matrix.
-
-
path
-string
-path string
-matrix
-object
-see Matrix
-
+
path
+string
+path string
+matrix
+object
+see Matrix
+
Returns: string transformed path string
-
Savage.path.toAbsolute(path)⚓ ➭
-
Savage.path.toAbsolute(path)⚓ ➭
+Utility method
Converts path coordinates into absolute values.
-
-
path
-string
-path string
-
+
path
+string
+path string
+
Returns: array path string
-
Savage.path.toCubic(pathString)⚓ ➭
-
Savage.path.toCubic(pathString)⚓ ➭
+Utility method
Converts path to a new path where all segments are cubic bezier curves.
-
-
pathString
-string array
-path string or array of segments
-
+
pathString
+string array
+path string or array of segments
+
Returns: array array of segments.
-
Savage.path.toRelative(path)⚓ ➭
-
Savage.path.toRelative(path)⚓ ➭
+Utility method
Converts path coordinates into relative values.
-
-
path
-string
-path string
-
+
path
+string
+path string
+
Returns: array path string
-
Savage.pathBBox(path)⚓ ➭
-
+Utility method
Return bounding box of a given path
-
-
path
-string
-path string
-
+
path
+string
+path string
+
Returns: object bounding box
{x: number x coordinate of the left top point of the box
y: number y coordinate of the left top point of the box
@@ -1756,191 +1594,169 @@ Return bounding box of a given path
width: number width of the box
height: number height of the box
}
-
Transform angle to radians
+
+Transform angle to radians
-
-
deg
-number
-angle in degrees
-
+
deg
+number
+angle in degrees
+
Returns: number angle in radians.
-
Converts RGB values to hex representation of the colour.
+
+Converts RGB values to hex representation of the colour.
-
-
r
-number
-red
-g
-number
-green
-b
-number
-blue
-
+
r
+number
+red
+g
+number
+green
+b
+number
+blue
+
Returns: string hex representation of the colour.
-
Savage.rgb2hsb(r, g, b)⚓ ➭
-
Converts RGB values to HSB object.
+
Savage.rgb2hsb(r, g, b)⚓ ➭
+Converts RGB values to HSB object.
-
-
r
-number
-red
-g
-number
-green
-b
-number
-blue
-
+
r
+number
+red
+g
+number
+green
+b
+number
+blue
+
Returns: object HSB object in format:
{h number hue
s number saturation
b number brightness
}
-
Savage.rgb2hsl(r, g, b)⚓ ➭
-
Converts RGB values to HSL object.
+
Savage.rgb2hsl(r, g, b)⚓ ➭
+Converts RGB values to HSL object.
-
-
r
-number
-red
-g
-number
-green
-b
-number
-blue
-
+
r
+number
+red
+g
+number
+green
+b
+number
+blue
+
Returns: object HSL object in format:
{h number hue
s number saturation
l number luminosity
}
-
Wraps DOM element specified by CSS selector as Element
+
+Wraps DOM element specified by CSS selector as Element
-
-
query
-string
-CSS selector of the element
-
+
query
+string
+CSS selector of the element
+
Returns: Element
-
Savage.selectAll(query)⚓ ➭
-
Wraps DOM elements specified by CSS selector as set or array of Element
+
Savage.selectAll(query)⚓ ➭
+Wraps DOM elements specified by CSS selector as set or array of Element
-
-
query
-string
-CSS selector of the element
-
+
query
+string
+CSS selector of the element
+
Returns: Element
-
Savage.snapTo(values, value, [tolerance])⚓ ➭
-
Snaps given value to given grid.
+
Savage.snapTo(values, value, [tolerance])⚓ ➭
+Snaps given value to given grid.
-
-
values
-array number
-given array of values or step of the grid
-value
-number
-value to adjust
-tolerance
-optional
-number
-tolerance for snapping. Default is 10
.
-
+
values
+array number
+given array of values or step of the grid
+value
+number
+value to adjust
+tolerance
+optional
+number
+tolerance for snapping. Default is 10
.
+
Returns: number adjusted value.
-
Removeds all elements from the set
+
+
+Removeds all elements from the set
-
Removes given element from the set
+
+Removes given element from the set
-
-
element
-object
-element to remove
-
+
element
+object
+element to remove
+
Returns: boolean true
if object was found & removed from the set
-
Set.forEach(callback, thisArg)⚓ ➭
-
Executes given function for each element in the set.
+
Set.forEach(callback, thisArg)⚓ ➭
+Executes given function for each element in the set.
If function returns false
it will stop loop running.
-
-
callback
-function
-function to run
-thisArg
-object
-context object for the callback
-
+
callback
+function
+function to run
+thisArg
+object
+context object for the callback
+
Returns: object Set object
-
Removes last element and returns it.
+
+Removes last element and returns it.
Returns: object element
-
Adds each argument to the current set.
+
+Adds each argument to the current set.
Returns: object original element
-
Set.splice(index, count, [insertion…])⚓ ➭
-
Removes given element from the set
+
Set.splice(index, count, [insertion…])⚓ ➭
+Removes given element from the set
-
-
index
-number
-position of the deletion
-count
-number
-number of element to remove
-insertion…
-optional
-object
-elements to insert
-
+
index
+number
+position of the deletion
+count
+number
+number of element to remove
+insertion…
+optional
+object
+elements to insert
+
Returns: object set elements that were deleted
-
mina(a, A, b, B, get, set, [easing])⚓ ➭
-
Generic animation of numbers.
+
mina(a, A, b, B, get, set, [easing])⚓ ➭
+Generic animation of numbers.
-
-
a
-number
-start “slave” number
-A
-number
-end “slave” number
-b
-number
-start “master” number (start time in gereal case)
-B
-number
-end “master” number (end time in gereal case)
-get
-function
-getter of “master” number (see mina.time )
-set
-function
-setter of “slave” number
-easing
-optional
-function
-easing function, default is mina.linear
-
+
a
+number
+start “slave” number
+A
+number
+end “slave” number
+b
+number
+start “master” number (start time in gereal case)
+B
+number
+end “master” number (end time in gereal case)
+get
+function
+getter of “master” number (see mina.time )
+set
+function
+setter of “slave” number
+easing
+optional
+function
+easing function, default is mina.linear
+
Returns: object animation descriptor
{id string animation id,
start number start “slave” number,
@@ -1957,121 +1773,105 @@ Return bounding box of a given path
duration function duration getter/setter,
stop function animation stopper
}
-
+Backin easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
+Backout easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
+Bounce easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
+Easein easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
+Easeinout easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
+Easeout easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
+Elastic easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
Returns animation by it’s id.
+
+Returns animation by it’s id.
-
-
id
-string
-animation’s id
-
+
id
+string
+animation’s id
+
Returns: object See mina
-
+Default linear easing.
-
-
n
-number
-input 0..1
-
+
Returns: number output 0..1
-
Returns current time. Equal to
+
+Returns current time. Equal to
-
function () {
- return (new Date).getTime();
+function () {
+ return (new Date).getTime();
}
-
-
-
+
+
+
+
+
+
+
+
-
+
\ No newline at end of file
diff --git a/dist/savage-min.js b/dist/savage-min.js
index 06bf86a..4c5ddb4 100644
--- a/dist/savage-min.js
+++ b/dist/savage-min.js
@@ -28,6 +28,7 @@
// See the License for the specific language governing permissions and
// limitations under the License.
//
-// build: 2013-08-23
-!function(a){var b,c,d="0.4.2",e="hasOwnProperty",f=/[\.\/]/,g="*",h=function(){},i=function(a,b){return a-b},j={n:{}},k=function(a,d){a=String(a);var e,f=c,g=Array.prototype.slice.call(arguments,2),h=k.listeners(a),j=0,l=[],m={},n=[],o=b;b=a,c=0;for(var p=0,q=h.length;q>p;p++)"zIndex"in h[p]&&(l.push(h[p].zIndex),h[p].zIndex<0&&(m[h[p].zIndex]=h[p]));for(l.sort(i);l[j]<0;)if(e=m[l[j++]],n.push(e.apply(d,g)),c)return c=f,n;for(p=0;q>p;p++)if(e=h[p],"zIndex"in e)if(e.zIndex==l[j]){if(n.push(e.apply(d,g)),c)break;do if(j++,e=m[l[j]],e&&n.push(e.apply(d,g)),c)break;while(e)}else m[e.zIndex]=e;else if(n.push(e.apply(d,g)),c)break;return c=f,b=o,n.length?n:null};k._events=j,k.listeners=function(a){var b,c,d,e,h,i,k,l,m=a.split(f),n=j,o=[n],p=[];for(e=0,h=m.length;h>e;e++){for(l=[],i=0,k=o.length;k>i;i++)for(n=o[i].n,c=[n[m[e]],n[g]],d=2;d--;)b=c[d],b&&(l.push(b),p=p.concat(b.f||[]));o=l}return p},k.on=function(a,b){if(a=String(a),"function"!=typeof b)return function(){};for(var c=a.split(f),d=j,e=0,g=c.length;g>e;e++)d=d.n,d=d.hasOwnProperty(c[e])&&d[c[e]]||(d[c[e]]={n:{}});for(d.f=d.f||[],e=0,g=d.f.length;g>e;e++)if(d.f[e]==b)return h;return d.f.push(b),function(a){+a==+a&&(b.zIndex=+a)}},k.f=function(a){var b=[].slice.call(arguments,1);return function(){k.apply(null,[a,null].concat(b).concat([].slice.call(arguments,0)))}},k.stop=function(){c=1},k.nt=function(a){return a?new RegExp("(?:\\.|\\/|^)"+a+"(?:\\.|\\/|$)").test(b):b},k.nts=function(){return b.split(f)},k.off=k.unbind=function(a,b){if(!a)return k._events=j={n:{}},void 0;var c,d,h,i,l,m,n,o=a.split(f),p=[j];for(i=0,l=o.length;l>i;i++)for(m=0;mi;i++)for(c=p[i];c.n;){if(b){if(c.f){for(m=0,n=c.f.length;n>m;m++)if(c.f[m]==b){c.f.splice(m,1);break}!c.f.length&&delete c.f}for(d in c.n)if(c.n[e](d)&&c.n[d].f){var q=c.n[d].f;for(m=0,n=q.length;n>m;m++)if(q[m]==b){q.splice(m,1);break}!q.length&&delete c.n[d].f}}else{delete c.f;for(d in c.n)c.n[e](d)&&c.n[d].f&&delete c.n[d].f}c=c.n}},k.once=function(a,b){var c=function(){return k.unbind(a,c),b.apply(this,arguments)};return k.on(a,c)},k.version=d,k.toString=function(){return"You are running Eve "+d},"undefined"!=typeof module&&module.exports?module.exports=k:"undefined"!=typeof define?define("eve",[],function(){return k}):a.eve=k}(this);var mina=function(a){var b={},c=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(a){setTimeout(a,16)},d=Array.isArray||function(a){return a instanceof Array||"[object Array]"==Object.prototype.toString.call(a)},e=0,f="M"+(+new Date).toString(36),g=function(){return f+(e++).toString(36)},h=function(){return+new Date},i=function(a){var b=this;if(null==a)return b.s;var c=b.s-a;b.b+=b.dur*c,b.B+=b.dur*c,b.s=a},j=function(a){var b=this;return null==a?b.spd:(b.spd=a,void 0)},k=function(a){var b=this;return null==a?b.dur:(b.s=b.s*a/b.dur,b.dur=a,void 0)},l=function(){var c=this;delete b[c.id],a("mina.stop."+c.id,c)},m=function(){var e=0;for(var f in b)if(b.hasOwnProperty(f)){var g,h=b[f],i=h.get();if(e++,h.s=(i-h.b)/(h.dur/h.spd),h.s>=1&&(delete b[f],h.s=1,e--),d(h.start)){g=[];for(var j=0,k=h.start.length;k>j;j++)g[j]=h.start[j]+(h.end[j]-h.start[j])*h.easing(h.s)}else g=h.start+(h.end-h.start)*h.easing(h.s);h.set(g),1==h.s&&a("mina.finish."+h.id,h)}e&&c(m)},n=function(a,d,e,f,h,o,p){var q={id:g(),start:a,end:d,b:e,s:0,dur:f-e,spd:1,get:h,set:o,easing:p||n.linear,status:i,speed:j,duration:k,stop:l};b[q.id]=q;var r,s=0;for(r in b)if(b.hasOwnProperty(r)&&(s++,2==s))break;return 1==s&&c(m),q};return n.time=h,n.getById=function(){return b[anim.id]||null},n.linear=function(a){return a},n.easeout=function(a){return Math.pow(a,1.7)},n.easein=function(a){return Math.pow(a,.48)},n.easeinout=function(a){var b=.48-a/1.04,c=Math.sqrt(.1734+b*b),d=c-b,e=Math.pow(Math.abs(d),1/3)*(0>d?-1:1),f=-c-b,g=Math.pow(Math.abs(f),1/3)*(0>f?-1:1),h=e+g+.5;return 3*(1-h)*h*h+h*h*h},n.backin=function(a){var b=1.70158;return a*a*((b+1)*a-b)},n.backout=function(a){a-=1;var b=1.70158;return a*a*((b+1)*a+b)+1},n.elastic=function(a){return a==!!a?a:Math.pow(2,-10*a)*Math.sin((a-.075)*2*Math.PI/.3)+1},n.bounce=function(a){var b,c=7.5625,d=2.75;return 1/d>a?b=c*a*a:2/d>a?(a-=1.5/d,b=c*a*a+.75):2.5/d>a?(a-=2.25/d,b=c*a*a+.9375):(a-=2.625/d,b=c*a*a+.984375),b},n}("undefined"==typeof eve?function(){}:eve);!function(){function a(a){a=a||Object(a);for(var c,d,e=1,g=a.length+1,h=b(a,0);g>e;e++)c=d,d=h,h=b(a,e),this.raw+=d,f.call(this,d,h,c);return this._beforeEnd=function(){f.call(this,"","",d)},this}function b(a,b){return a&&(a.charAt?a.charAt(b):a[b])}function c(a,b){this.events=this.events||{},this.events[a]=this.events[a]||[],this.events[a].push(b)}function d(a,b,c){"function"==typeof eve&&eve("elemental."+a+"."+b,null,b,c||"",this.raw);for(var d=this.events&&this.events[a],e=d&&d.length;e--;)try{this.events[a][e](b,c||"",this.raw)}catch(f){}this.raw=""}function e(){f.call(this,"eof"),this.event("eof")}function f(a,b,c){"\n"==a&&this.event("newline"),j[this.mode].call(this,a,b,c)}function g(b){var f=function(a){f.parse(a)};return f.mode="text",f.type=String(b||"html").toLowerCase(),f.textchunk="",f.raw="",f.parse=a,f.on=c,f.event=d,f.end=e,f}var h=/[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u2028\u2029\u202f\u205f\u3000]/,i=function(){for(var a in this.attr)this.attr.hasOwnProperty(a)&&this.event("attr",a,{value:this.attr[a],tagname:this.tagname,attr:this.attr})},j={text:function(a){switch(a){case"<":case"eof":this.nodename="",this.attr={},this.mode="tag name start",this.raw=this.raw.slice(0,-1),this.textchunk&&this.event("text",this.textchunk),this.raw+=a,this.textchunk="";break;default:this.textchunk+=a}},special:function(a,b,c){return"!"==c&&"-"==a&&"-"==b?(this.mode="comment start",void 0):"[CDATA"==this.textchunk&&"["==a?(this.mode="cdata",this.textchunk="",void 0):">"==a||"eof"==a?(this.event("special",this.textchunk),this.mode="text",this.textchunk="",void 0):(this.textchunk+=a,void 0)},cdata:function(a,b,c){return"]"==c&&"]"==a&&">"==b?(this.mode="cdata end",this.textchunk=this.textchunk.slice(0,-1),void 0):("eof"==a&&j["cdata end"].call(this),this.textchunk+=a,void 0)},"cdata end":function(){this.event("cdata",this.textchunk),this.textchunk="",this.mode="text"},"comment start":function(a,b){">"==b||"eof"==a?(this.event("comment",""),this.mode="comment instant end"):this.mode="comment"},"comment instant end":function(){this.mode="text"},comment:function(a,b,c){"-"==a&&"-"==c&&">"==b?(this.mode="comment end",this.textchunk=this.textchunk.slice(0,-1)):"eof"==a?this.event("comment",this.textchunk):this.textchunk+=a},"comment end":function(){this.event("comment",this.textchunk),this.textchunk="",this.mode="text"},declaration:function(a,b){return"?"==a&&">"==b?(this.mode="declaration end",void 0):("eof"==a&&this.event("comment",this.textchunk),this.textchunk+=a,void 0)},"declaration end":function(){this.event("comment",this.textchunk),this.textchunk="",this.mode="text"},"tag name start":function(a,b,c){if("eof"==a)return this.event("text","<"),void 0;if(!h.test(a)){if(this.mode="tag name","/"==a)return this.mode="close tag name start",void 0;if("!"==a)return this.mode="special",this.textchunk="",void 0;if("?"==a)return this.mode="declaration",void 0;j[this.mode].call(this,a,b,c)}},"close tag name start":function(a,b,c){h.test(a)||(this.mode="close tag name",this.tagname="",this.nodename="",j[this.mode].call(this,a,b,c))},"close tag name":function(a){if(h.test(a))this.tagname=this.nodename;else switch(a){case">":this.event("/tag",this.tagname||this.nodename),this.mode="text";break;default:!this.tagname&&(this.nodename+=a)}},"tag name":function(a){if(h.test(a))this.tagname=this.nodename,this.nodename="",this.mode="attr start";else switch(a){case">":this.event("tag",this.nodename),this.mode="text";break;default:this.nodename+=a}},"attr start":function(a,b,c){h.test(a)||(this.mode="attr",this.nodename="",j[this.mode].call(this,a,b,c))},attr:function(a){if(h.test(a)||"="==a)this.attr[this.nodename]="",this.mode="attr value start";else switch(a){case">":"/"==this.nodename?(delete this.attr["/"],this.event("tag",this.tagname,this.attr),i.call(this),this.event("/tag",this.tagname,!0)):(this.nodename&&(this.attr[this.nodename]=""),this.event("tag",this.tagname,this.attr),i.call(this)),this.mode="text";break;default:this.nodename+=a}},"attr value start":function(a,b,c){if(!h.test(a)){if(this.mode="attr value",this.quote=!1,"'"==a||'"'==a)return this.quote=a,void 0;j[this.mode].call(this,a,b,c)}},"attr value":function(a,b,c){if(h.test(a)&&!this.quote)this.mode="attr start";else if(">"!=a||this.quote)switch(a){case'"':case"'":this.quote==a&&"\\"!=c&&(this.mode="attr start");break;default:this.attr[this.nodename]+=a}else this.event("tag",this.tagname,this.attr),this.mode="text"}};g.version="0.2.1",("undefined"==typeof exports?this:exports).elemental=g}();var Savage=function(){function a(a,b){if(a){if(a.tagName)return s(a);if(a instanceof n)return a;if(null==b)return a=t.doc.querySelector(a),s(a)}return a=null==a?"100%":a,b=null==b?"100%":b,new r(a,b)}function b(a,c){if(c){if("string"==typeof a&&(a=b(a)),"string"==typeof c)return"xlink:"==c.substring(0,6)?a.getAttributeNS(T,c.substring(6)):a.getAttribute(c);for(var d in c)if(c[u](d)){var e=v(c[d]);e?"xlink:"==d.substring(0,6)?a.setAttributeNS(T,d.substring(6),e):a.setAttribute(d,e):a.removeAttribute(d)}}else a=t.doc.createElementNS("http://www.w3.org/2000/svg",a);return a}function c(a,b){return b=v.prototype.toLowerCase.call(b),"finite"==b?!H[u](+a):"array"==b&&(a instanceof Array||Array.isArray&&Array.isArray(a))?!0:"null"==b&&null===a||b==typeof a&&null!==a||"object"==b&&a===Object(a)||F.call(a).slice(8,-1).toLowerCase()==b}function d(a){if("function"==typeof a||Object(a)!==a)return a;var b=new a.constructor;for(var c in a)a[u](c)&&(b[c]=d(a[c]));return b}function e(a,b){for(var c=0,d=a.length;d>c;c++)if(a[c]===b)return a.push(a.splice(c,1)[0])}function f(a,b,c){function d(){var f=Array.prototype.slice.call(arguments,0),g=f.join("␀"),h=d.cache=d.cache||{},i=d.count=d.count||[];return h[u](g)?(e(i,g),c?c(h[g]):h[g]):(i.length>=1e3&&delete h[i.shift()],i.push(g),h[g]=a.apply(b,f),c?c(h[g]):h[g])}return d}function g(a){return a%360*C/180}function h(a){return 180*a/C%360}function i(){return this.x+E+this.y+E+this.width+" × "+this.height}function j(a,b,c,d,e,f){return null==b&&"[object SVGMatrix]"==F.call(a)?(this.a=a.a,this.b=a.b,this.c=a.c,this.d=a.d,this.e=a.e,this.f=a.f,void 0):(null!=a?(this.a=+a,this.b=+b,this.c=+c,this.d=+d,this.e=+e,this.f=+f):(this.a=1,this.b=0,this.c=0,this.d=1,this.e=0,this.f=0),void 0)}function k(a){var b=[];return a=a.replace(/(?:^|\s)(\w+)\(([^)]+)\)/g,function(a,c,d){return d=d.split(/\s*,\s*/),"rotate"==c&&1==d.length&&d.push(0,0),"scale"==c&&(2==d.length&&d.push(0,0),1==d.length&&d.push(d[0],0,0)),"skewX"==c?b.push(["m",1,0,y.tan(g(d[0])),1,0,0]):"skewY"==c?b.push(["m",1,y.tan(g(d[0])),0,1,0,0]):b.push([c.charAt(0)].concat(d)),a}),b}function l(a,b){if(null==b){var c=!0;if(b="linearGradient"==a.type||"radialGradient"==a.type?a.node.getAttribute("gradientTransform"):"pattern"==a.type?a.node.getAttribute("patternTransform"):a.node.getAttribute("transform"),!b)return new j;b=k(b)}else b=bb.test(b)?v(b).replace(/\.{3}|\u2026/g,a._.transform||D):k(b);var d=ab(b),e=0,f=0,g=0,h=1,i=1,l=a._,m=new j;if(l.transform=d||[],d){for(var n=0,o=d.length;o>n;n++){var p,q,r,s,t,u=d[n],w=u.length,x=v(u[0]).toLowerCase(),y=u[0]!=x,z=y?m.invert():0;"t"==x&&3==w?y?(p=z.x(0,0),q=z.y(0,0),r=z.x(u[1],u[2]),s=z.y(u[1],u[2]),m.translate(r-p,s-q)):m.translate(u[1],u[2]):"r"==x?2==w?(t=t||a.getBBox(1),m.rotate(u[1],t.x+t.width/2,t.y+t.height/2),e+=u[1]):4==w&&(y?(r=z.x(u[2],u[3]),s=z.y(u[2],u[3]),m.rotate(u[1],r,s)):m.rotate(u[1],u[2],u[3]),e+=u[1]):"s"==x?2==w||3==w?(t=t||a.getBBox(1),m.scale(u[1],u[w-1],t.x+t.width/2,t.y+t.height/2),h*=u[1],i*=u[w-1]):5==w&&(y?(r=z.x(u[3],u[4]),s=z.y(u[3],u[4]),m.scale(u[1],u[2],r,s)):m.scale(u[1],u[2],u[3],u[4]),h*=u[1],i*=u[2]):"m"==x&&7==w&&m.add(u[1],u[2],u[3],u[4],u[5],u[6])}if(c)return m;l.dirtyT=1,a.matrix=m}a.matrix=m,l.sx=h,l.sy=i,l.deg=e,l.dx=f=m.e,l.dy=g=m.f,1==h&&1==i&&!e&&l.bbox?(l.bbox.x+=+f,l.bbox.y+=+g):l.dirtyT=1}function m(a,c,d){function e(a){return null==a?D:a==+a?a:(b(j,{width:a}),j.getBBox().width)}function f(a){return null==a?D:a==+a?a:(b(j,{height:a}),j.getBBox().height)}function g(b,e){null==c?i[b]=e(a.attr(b)):b==c&&(i=e(null==d?a.attr(b):d))}var h=a.paper.defs,i={},j=a.paper.measurer;switch(j||(a.paper.measurer=j=b("rect"),b(j,{width:10,height:10}),h.appendChild(j)),a.type){case"rect":g("rx",e),g("ry",f);case"image":g("width",e),g("height",f);case"text":g("x",e),g("y",f);break;case"circle":g("cx",e),g("cy",f),g("r",e);break;case"ellipse":g("cx",e),g("cy",f),g("rx",e),g("ry",f);break;case"line":g("x1",e),g("x2",e),g("y1",f),g("y2",f);break;case"marker":g("refX",e),g("markerWidth",e),g("refY",f),g("markerHeight",f);break;case"radialGradient":g("fx",e),g("fy",f);break;case"tspan":g("dx",e),g("dy",f);break;default:i=null}return i}function n(a){if(a.savage in U)return U[a.savage];var b,c=this.id=S();try{b=a.ownerSVGElement}catch(d){}this.node=a,b&&(this.paper=new r(b)),this.type=a.tagName,this.anims={},this._={transform:[],sx:1,sy:1,deg:0,dx:0,dy:0,dirty:1},a.savage=c,U[c]=this}function o(a){for(var b,c=0,d=a.length;d>c;c++)if(b=b||a[c])return b}function p(a){this.node=a}function q(a,c){var d=b(a);c.appendChild(d);var e=s(d);return e.type=a,e}function r(a,c){var d,e,f,g=r.prototype;if(a&&"svg"==a.tagName){if(a.savage in U)return U[a.savage];d=new n(a),e=a.getElementsByTagName("desc")[0],f=a.getElementsByTagName("defs")[0]}else d=q("svg",t.doc.body),b(d.node,{height:c,version:1.1,width:a,xmlns:"http://www.w3.org/2000/svg"});e||(e=b("desc"),e.appendChild(t.doc.createTextNode("Created with Savage")),d.node.appendChild(e)),f||(f=b("defs"),d.node.appendChild(f));for(var h in g)g[u](h)&&(d[h]=g[h]);return d.paper=d,d.defs=f,d}function s(a){return a?a instanceof n||a instanceof p?a:"svg"==a.tagName?new r(a):new n(a):a}a.version="0.0.1",a.toString=function(){return"Savage v"+this.version},a._={};var t={win:window,doc:window.document},u="hasOwnProperty",v=String,w=parseFloat,x=parseInt,y=Math,z=y.max,A=y.min,B=y.abs,C=(y.pow,y.PI),D=(y.round,""),E=" ",F=Object.prototype.toString,G=/^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+%?)?)\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i,H={NaN:1,Infinity:1,"-Infinity":1},I=/^url\(#?([^)]+)\)$/,J=" \n\f\r \u2028\u2029",K=new RegExp("[,"+J+"]+"),L=(new RegExp("["+J+"]","g"),new RegExp("["+J+"]*,["+J+"]*")),M={hs:1,rg:1},N=new RegExp("([a-z])["+J+",]*((-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?["+J+"]*,?["+J+"]*)+)","ig"),O=new RegExp("([rstm])["+J+",]*((-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?["+J+"]*,?["+J+"]*)+)","ig"),P=new RegExp("(-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?)["+J+"]*,?["+J+"]*","ig"),Q=0,R="S"+(+new Date).toString(36),S=function(){return R+(Q++).toString(36)},T="http://www.w3.org/1999/xlink",U={};a._.$=b,a._.id=S,a.format=function(){var a=/\{([^\}]+)\}/g,b=/(?:(?:^|\.)(.+?)(?=\[|\.|$|\()|\[('|")(.+?)\2\])(\(\))?/g,c=function(a,c,d){var e=d;return c.replace(b,function(a,b,c,d,f){b=b||d,e&&(b in e&&(e=e[b]),"function"==typeof e&&f&&(e=e()))}),e=(null==e||e==d?a:e)+""};return function(b,d){return v(b).replace(a,function(a,b){return c(a,b,d)})}}();var V=function(){function a(){this.parentNode.removeChild(this)}return function(b,c){var d=t.doc.createElement("img"),e=t.doc.body;d.style.cssText="position:absolute;left:-9999em;top:-9999em",d.onload=function(){c.call(d),d.onload=d.onerror=null,e.removeChild(d)},d.onerror=a,e.appendChild(d),d.src=b}}();a._.clone=d,a._.cacher=f,a.rad=g,a.deg=h,a.is=c,a.snapTo=function(a,b,d){if(d=c(d,"finite")?d:10,c(a,"array")){for(var e=a.length;e--;)if(B(a[e]-b)<=d)return a[e]}else{a=+a;var f=b%a;if(d>f)return b-f;if(f>a-d)return b-f+a}return b},function(a){function b(a){return a[0]*a[0]+a[1]*a[1]}function c(a){var c=y.sqrt(b(a));a[0]&&(a[0]/=c),a[1]&&(a[1]/=c)}a.add=function(a,b,c,d,e,f){var g,h,i,k,l=[[],[],[]],m=[[this.a,this.c,this.e],[this.b,this.d,this.f],[0,0,1]],n=[[a,c,e],[b,d,f],[0,0,1]];for(a&&a instanceof j&&(n=[[a.a,a.c,a.e],[a.b,a.d,a.f],[0,0,1]]),g=0;3>g;g++)for(h=0;3>h;h++){for(k=0,i=0;3>i;i++)k+=m[g][i]*n[i][h];l[g][h]=k}return this.a=l[0][0],this.b=l[1][0],this.c=l[0][1],this.d=l[1][1],this.e=l[0][2],this.f=l[1][2],this},a.invert=function(){var a=this,b=a.a*a.d-a.b*a.c;return new j(a.d/b,-a.b/b,-a.c/b,a.a/b,(a.c*a.f-a.d*a.e)/b,(a.b*a.e-a.a*a.f)/b)},a.clone=function(){return new j(this.a,this.b,this.c,this.d,this.e,this.f)},a.translate=function(a,b){return this.add(1,0,0,1,a,b)},a.scale=function(a,b,c,d){return null==b&&(b=a),(c||d)&&this.add(1,0,0,1,c,d),this.add(a,0,0,b,0,0),(c||d)&&this.add(1,0,0,1,-c,-d),this},a.rotate=function(a,b,c){a=g(a),b=b||0,c=c||0;var d=+y.cos(a).toFixed(9),e=+y.sin(a).toFixed(9);return this.add(d,e,-e,d,b,c),this.add(1,0,0,1,-b,-c)},a.x=function(a,b){return a*this.a+b*this.c+this.e},a.y=function(a,b){return a*this.b+b*this.d+this.f},a.get=function(a){return+this[v.fromCharCode(97+a)].toFixed(4)},a.toString=function(){return"matrix("+[this.get(0),this.get(1),this.get(2),this.get(3),this.get(4),this.get(5)].join()+")"},a.offset=function(){return[this.e.toFixed(4),this.f.toFixed(4)]},a.split=function(){var a={};a.dx=this.e,a.dy=this.f;var d=[[this.a,this.c],[this.b,this.d]];a.scalex=y.sqrt(b(d[0])),c(d[0]),a.shear=d[0][0]*d[1][0]+d[0][1]*d[1][1],d[1]=[d[1][0]-d[0][0]*a.shear,d[1][1]-d[0][1]*a.shear],a.scaley=y.sqrt(b(d[1])),c(d[1]),a.shear/=a.scaley;var e=-d[0][1],f=d[1][1];return 0>f?(a.rotate=h(y.acos(f)),0>e&&(a.rotate=360-a.rotate)):a.rotate=h(y.asin(e)),a.isSimple=!(+a.shear.toFixed(9)||a.scalex.toFixed(9)!=a.scaley.toFixed(9)&&a.rotate),a.isSuperSimple=!+a.shear.toFixed(9)&&a.scalex.toFixed(9)==a.scaley.toFixed(9)&&!a.rotate,a.noRotation=!+a.shear.toFixed(9)&&!a.rotate,a},a.toTransformString=function(a){var b=a||this.split();return b.isSimple?(b.scalex=+b.scalex.toFixed(4),b.scaley=+b.scaley.toFixed(4),b.rotate=+b.rotate.toFixed(4),(b.dx||b.dy?"t"+[+b.dx.toFixed(4),+b.dy.toFixed(4)]:D)+(1!=b.scalex||1!=b.scaley?"s"+[b.scalex,b.scaley,0,0]:D)+(b.rotate?"r"+[+b.rotate.toFixed(4),0,0]:D)):"m"+[this.get(0),this.get(1),this.get(2),this.get(3),this.get(4),this.get(5)]}}(j.prototype),a.Matrix=j,a.getRGB=f(function(b){if(!b||(b=v(b)).indexOf("-")+1)return{r:-1,g:-1,b:-1,hex:"none",error:1,toString:Z};if("none"==b)return{r:-1,g:-1,b:-1,hex:"none",toString:Z};!(M[u](b.toLowerCase().substring(0,2))||"#"==b.charAt())&&(b=W(b));var d,e,f,g,h,i,j=b.match(G);return j?(j[2]&&(f=x(j[2].substring(5),16),e=x(j[2].substring(3,5),16),d=x(j[2].substring(1,3),16)),j[3]&&(f=x((h=j[3].charAt(3))+h,16),e=x((h=j[3].charAt(2))+h,16),d=x((h=j[3].charAt(1))+h,16)),j[4]&&(i=j[4].split(L),d=w(i[0]),"%"==i[0].slice(-1)&&(d*=2.55),e=w(i[1]),"%"==i[1].slice(-1)&&(e*=2.55),f=w(i[2]),"%"==i[2].slice(-1)&&(f*=2.55),"rgba"==j[1].toLowerCase().slice(0,4)&&(g=w(i[3])),i[3]&&"%"==i[3].slice(-1)&&(g/=100)),j[5]?(i=j[5].split(L),d=w(i[0]),"%"==i[0].slice(-1)&&(d*=2.55),e=w(i[1]),"%"==i[1].slice(-1)&&(e*=2.55),f=w(i[2]),"%"==i[2].slice(-1)&&(f*=2.55),("deg"==i[0].slice(-3)||"°"==i[0].slice(-1))&&(d/=360),"hsba"==j[1].toLowerCase().slice(0,4)&&(g=w(i[3])),i[3]&&"%"==i[3].slice(-1)&&(g/=100),a.hsb2rgb(d,e,f,g)):j[6]?(i=j[6].split(L),d=w(i[0]),"%"==i[0].slice(-1)&&(d*=2.55),e=w(i[1]),"%"==i[1].slice(-1)&&(e*=2.55),f=w(i[2]),"%"==i[2].slice(-1)&&(f*=2.55),("deg"==i[0].slice(-3)||"°"==i[0].slice(-1))&&(d/=360),"hsla"==j[1].toLowerCase().slice(0,4)&&(g=w(i[3])),i[3]&&"%"==i[3].slice(-1)&&(g/=100),a.hsl2rgb(d,e,f,g)):(j={r:d,g:e,b:f,toString:Z},j.hex="#"+(16777216|f|e<<8|d<<16).toString(16).slice(1),j.opacity=c(g,"finite")?g:1,j)):{r:-1,g:-1,b:-1,hex:"none",error:1,toString:Z}},a),a.hsb=f(function(b,c,d){return a.hsb2rgb(b,c,d).hex}),a.hsl=f(function(b,c,d){return a.hsl2rgb(b,c,d).hex}),a.rgb=f(function(a,b,d,e){if(c(e,"finite")){var f=y.round;return"rgba("+[f(a),f(b),f(d),+e.toFixed(2)]+")"}return"#"+(16777216|d|b<<8|a<<16).toString(16).slice(1)});var W=function(a){var b=t.doc.getElementsByTagName("head")[0];return W=f(function(a){b.style.color="inherit",b.style.color=a;var c=t.doc.defaultView.getComputedStyle(b,D).getPropertyValue("color");return"inherit"==c?null:c}),W(a)},X=function(){return"hsb("+[this.h,this.s,this.b]+")"},Y=function(){return"hsl("+[this.h,this.s,this.l]+")"},Z=function(){return 1==this.opacity||null==this.opacity?this.hex:"rgba("+[this.r,this.g,this.b,this.opacity]+")"},$=function(b,d,e){if(null==d&&c(b,"object")&&"r"in b&&"g"in b&&"b"in b&&(e=b.b,d=b.g,b=b.r),null==d&&c(b,string)){var f=a.getRGB(b);b=f.r,d=f.g,e=f.b}return(b>1||d>1||e>1)&&(b/=255,d/=255,e/=255),[b,d,e]},_=function(b,d,e,f){b=y.round(255*b),d=y.round(255*d),e=y.round(255*e);var g={r:b,g:d,b:e,opacity:c(f,"finite")?f:1,hex:a.rgb(b,d,e),toString:Z};return c(f,"finite")&&(g.opacity=f),g};a.color=function(b){var d;return c(b,"object")&&"h"in b&&"s"in b&&"b"in b?(d=a.hsb2rgb(b),b.r=d.r,b.g=d.g,b.b=d.b,b.opacity=1,b.hex=d.hex):c(b,"object")&&"h"in b&&"s"in b&&"l"in b?(d=a.hsl2rgb(b),b.r=d.r,b.g=d.g,b.b=d.b,b.opacity=1,b.hex=d.hex):(c(b,"string")&&(b=a.getRGB(b)),c(b,"object")&&"r"in b&&"g"in b&&"b"in b?(d=a.rgb2hsl(b),b.h=d.h,b.s=d.s,b.l=d.l,d=a.rgb2hsb(b),b.v=d.b):(b={hex:"none"},b.r=b.g=b.b=b.h=b.s=b.v=b.l=-1)),b.toString=Z,b},a.hsb2rgb=function(a,b,d,e){c(a,"object")&&"h"in a&&"s"in a&&"b"in a&&(d=a.b,b=a.s,a=a.h,e=a.o),a*=360;var f,g,h,i,j;return a=a%360/60,j=d*b,i=j*(1-B(a%2-1)),f=g=h=d-j,a=~~a,f+=[j,i,0,0,i,j][a],g+=[i,j,j,i,0,0][a],h+=[0,0,i,j,j,i][a],_(f,g,h,e)},a.hsl2rgb=function(a,b,d,e){c(a,"object")&&"h"in a&&"s"in a&&"l"in a&&(d=a.l,b=a.s,a=a.h),(a>1||b>1||d>1)&&(a/=360,b/=100,d/=100),a*=360;var f,g,h,i,j;return a=a%360/60,j=2*b*(.5>d?d:1-d),i=j*(1-B(a%2-1)),f=g=h=d-j/2,a=~~a,f+=[j,i,0,0,i,j][a],g+=[i,j,j,i,0,0][a],h+=[0,0,i,j,j,i][a],_(f,g,h,e)},a.rgb2hsb=function(a,b,c){c=$(a,b,c),a=c[0],b=c[1],c=c[2];var d,e,f,g;return f=z(a,b,c),g=f-A(a,b,c),d=0==g?null:f==a?(b-c)/g:f==b?(c-a)/g+2:(a-b)/g+4,d=60*((d+360)%6)/360,e=0==g?0:g/f,{h:d,s:e,b:f,toString:X}},a.rgb2hsl=function(a,b,c){c=$(a,b,c),a=c[0],b=c[1],c=c[2];var d,e,f,g,h,i;return g=z(a,b,c),h=A(a,b,c),i=g-h,d=0==i?null:g==a?(b-c)/i:g==b?(c-a)/i+2:(a-b)/i+4,d=60*((d+360)%6)/360,f=(g+h)/2,e=0==i?0:.5>f?i/(2*f):i/(2-2*f),{h:d,s:e,l:f,toString:Y}},a.parsePathString=function(b){if(!b)return null;var d=a.path(b);if(d.arr)return a.path.clone(d.arr);var e={a:7,c:6,o:2,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,u:3,z:0},f=[];return c(b,"array")&&c(b[0],"array")&&(f=a.path.clone(b)),f.length||v(b).replace(N,function(a,b,c){var d=[],g=b.toLowerCase();if(c.replace(P,function(a,b){b&&d.push(+b)}),"m"==g&&d.length>2&&(f.push([b].concat(d.splice(0,2))),g="l",b="m"==b?"l":"L"),"o"==g&&1==d.length&&f.push([b,d[0]]),"r"==g)f.push([b].concat(d));else for(;d.length>=e[g]&&(f.push([b].concat(d.splice(0,e[g]))),e[g]););}),f.toString=a.path.toString,d.arr=a.path.clone(f),f};var ab=a.parseTransformString=function(b){if(!b)return null;var d=[];return c(b,"array")&&c(b[0],"array")&&(d=a.path.clone(b)),d.length||v(b).replace(O,function(a,b,c){var e=[];b.toLowerCase(),c.replace(P,function(a,b){b&&e.push(+b)}),d.push([b].concat(e))}),d.toString=a.path.toString,d},bb=new RegExp("^[a-z]["+J+"]*-?\\.?\\d");a.select=function(a){return s(t.doc.querySelector(a))},a.selectAll=function(b){for(var c=t.doc.querySelectorAll(b),d=(a.set||Array)(),e=0;ed;d++){var f=b[d];f.node&&f.node.nodeType&&c.appendChild(f.node),f.nodeType&&c.appendChild(f),"string"==typeof f&&c.appendChild(a.parse(f).node)}return new p(c)},function(d){function e(a){c(a,"array")||(a=Array.prototype.slice.call(arguments,0));for(var b=0,d=0,e=this.node;this[b];)delete this[b++];for(b=0;b1&&(a=Array.prototype.slice.call(arguments,0));var b=q("polyline",this.node);return c(a,"object")&&!c(a,"array")?b.attr(a):null!=a&&b.attr({points:a}),b},d.polygon=function(a){arguments.length>1&&(a=Array.prototype.slice.call(arguments,0));var b=q("polygon",this.node);return c(a,"object")&&!c(a,"array")?b.attr(a):null!=a&&b.attr({points:a}),b},function(){function c(){return this.selectAll("stop")}function e(a,c){var d=b("stop");return b(d,{"stop-color":a,offset:+c+"%"}),this.node.appendChild(d),this}function f(){if("linearGradient"==this.type){var c=b(this.node,"x1")||0,d=b(this.node,"x2")||1,e=b(this.node,"y1")||0,f=b(this.node,"y2")||0;return a._.box(c,e,y.abs(d-c),y.abs(f-e))}var g=this.node.cx||.5,h=this.node.cy||.5,i=this.node.r||0;return a._.box(g-i,h-i,2*i,2*i)}d.gradient=function(a){function c(a,b){for(var c=(b-h)/(a-i),d=i;a>d;d++)f[d].offset=+(+h+c*(d-i)).toFixed(2);i=a,h=b}var d,e=o(eve("savage.util.grad.parse",null,a));
-d="l"==e.type.toLowerCase()?this.gradientLinear.apply(this,e.params):this.gradientRadial.apply(this,e.params),e.type!=e.type.toLowerCase()&&b(d.node,{gradientUnits:"userSpaceOnUse"});var f=e.stops,g=f.length,h=0,i=0;g--;for(var j=0;g>j;j++)"offset"in f[j]&&c(j,f[j].offset);for(f[g].offset=f[g].offset||100,c(g,f[g].offset),j=0;g>=j;j++){var k=f[j];d.addStop(k.color,k.offset)}return d},d.gradientLinear=function(a,d,g,h){var i=q("linearGradient",this.node);return i.stops=c,i.addStop=e,i.getBBox=f,null!=a&&b(i.node,{x1:a,y1:d,x2:g,y2:h}),i},d.gradientRadial=function(a,d,g,h,i){var j=q("radialGradient",this.node);return j.stops=c,j.addStop=e,j.getBBox=f,null!=a&&b(j.node,{cx:a,cy:d,r:g}),null!=h&&null!=i&&b(j.node,{fx:h,fy:i}),j}}()}(r.prototype),eve.on("savage.util.attr.mask",function(a){if(a instanceof n||a instanceof p){if(eve.stop(),a instanceof p&&1==a.node.childNodes.length&&(a=a.node.firstChild,this.paper.defs.appendChild(a),a=s(a)),"mask"==a.type)var c=a;else c=q("mask",this.paper.defs),c.node.appendChild(a.node),!c.node.id&&b(c.node,{id:c.id});b(this.node,{mask:"url(#"+c.id+")"})}}),function(a){eve.on("savage.util.attr.clip",a),eve.on("savage.util.attr.clip-path",a),eve.on("savage.util.attr.clipPath",a)}(function(a){if(a instanceof n||a instanceof p){if(eve.stop(),"clipPath"==a.type)var c=a;else c=q("clipPath",this.paper.defs),c.node.appendChild(a.node),!c.node.id&&b(c.node,{id:c.id});b(this.node,{"clip-path":"url(#"+c.id+")"})}}),eve.on("savage.util.attr.fill",function(c){if(eve.stop(),c instanceof p&&1==c.node.childNodes.length&&("radialGradient"==c.node.firstChild.tagName||"linearGradient"==c.node.firstChild.tagName||"pattern"==c.node.firstChild.tagName)&&(c=c.node.firstChild,this.paper.defs.appendChild(c),c=s(c)),c instanceof n&&("radialGradient"==c.type||"linearGradient"==c.type||"pattern"==c.type)){c.node.id||b(c.node,{id:c.id});var d="url(#"+c.node.id+")"}else if(d=a.color(c),d.error){var e=this.paper.gradient(c);e.node.id||b(e.node,{id:e.id}),d="url(#"+e.node.id+")"}else d=v(d);b(this.node,{fill:d}),this.node.style.fill=D});var cb=/^([lr])(?:\(([^)]*)\))?(.*)$/i;eve.on("savage.util.grad.parse",function(a){a=v(a);var b=a.match(cb),c=b[1],d=b[2],e=b[3];return d=d.split(/\s*,\s*/).map(function(a){return+a==a?+a:a}),1==d.length&&0==d[0]&&(d=[]),e=e.split("-"),e=e.map(function(a){a=a.split(":");var b={color:a[0]};return a[1]&&(b.offset=a[1]),b}),{type:c,params:d,stops:e}}),eve.on("savage.util.attr.d",function(d){eve.stop(),c(d,"array")&&c(d[0],"array")&&(d=a.path.toString.call(d)),d=v(d),d.match(/[ruo]/i)&&(d=a.path.toAbsolute(d)),b(this.node,{d:d})})(-1),eve.on("savage.util.attr.path",function(a){eve.stop(),this.attr({d:a})})(-1),eve.on("savage.util.attr.viewBox",function(a){var d;d=c(a,"object")&&"x"in a?[a.x,a.y,a.width,a.height].join(" "):c(a,"array")?a.join(" "):a,b(this.node,{viewBox:d}),eve.stop()})(-1),eve.on("savage.util.attr.transform",function(a){this.transform(a),eve.stop()})(-1),eve.on("savage.util.attr.r",function(a){"rect"==this.type&&(eve.stop(),b(this.node,{rx:a,ry:a}))})(-1),eve.on("savage.util.attr.text",function(a){if("text"==this.type){for(var d=this.node,e=function(a){var d=b("tspan");if(c(a,"array"))for(var f=0;fq;q++){if(k=d[q],"M"==k[0])h=+k[1],j=+k[2];else{if(l=g(h,j,k[1],k[2],k[3],k[4],k[5],k[6]),p+l>e){if(b&&!o.start){if(m=g(h,j,k[1],k[2],k[3],k[4],k[5],k[6],e-p),n+=["C"+c(m.start.x),c(m.start.y),c(m.m.x),c(m.m.y),c(m.x),c(m.y)],f)return n;o.start=n,n=["M"+c(m.x),c(m.y)+"C"+c(m.n.x),c(m.n.y),c(m.end.x),c(m.end.y),c(k[5]),c(k[6])].join(),p+=l,h=+k[5],j=+k[6];continue}if(!a&&!b)return m=g(h,j,k[1],k[2],k[3],k[4],k[5],k[6],e-p)}p+=l,h=+k[5],j=+k[6]}n+=k.shift()+k}return o.end=n,m=a?p:b?o:i(h,j,k[0],k[1],k[2],k[3],k[4],k[5],1)}}function i(a,b,c,d,e,f,g,h,i){var j=1-i,k=S(j,3),l=S(j,2),m=i*i,n=m*i,o=k*a+3*l*i*c+3*j*i*i*e+n*g,p=k*b+3*l*i*d+3*j*i*i*f+n*h,q=a+2*i*(c-a)+m*(e-2*c+a),r=b+2*i*(d-b)+m*(f-2*d+b),s=c+2*i*(e-c)+m*(g-2*e+c),t=d+2*i*(f-d)+m*(h-2*f+d),u=j*a+i*c,v=j*b+i*d,w=j*e+i*g,x=j*f+i*h,y=90-180*O.atan2(q-s,r-t)/P;return{x:o,y:p,m:{x:q,y:r},n:{x:s,y:t},start:{x:u,y:v},end:{x:w,y:x},alpha:y}}function j(b,c,e,f,g,h,i,j){a.is(b,"array")||(b=[b,c,e,f,g,h,i,j]);var k=E.apply(null,b);return d(k.min.x,k.min.y,k.max.x-k.min.x,k.max.y-k.min.y)}function k(a,b,c){return b>=a.x&&b<=a.x+a.width&&c>=a.y&&c<=a.y+a.height}function l(a,b){return a=d(a),b=d(b),k(b,a.x,a.y)||k(b,a.x2,a.y)||k(b,a.x,a.y2)||k(b,a.x2,a.y2)||k(a,b.x,b.y)||k(a,b.x2,b.y)||k(a,b.x,b.y2)||k(a,b.x2,b.y2)||(a.xb.x||b.xa.x)&&(a.yb.y||b.ya.y)}function m(a,b,c,d,e){var f=-3*b+9*c-9*d+3*e,g=a*f+6*b-12*c+6*d;return a*g-3*b+3*c}function n(a,b,c,d,e,f,g,h,i){null==i&&(i=1),i=i>1?1:0>i?0:i;for(var j=i/2,k=12,l=[-.1252,.1252,-.3678,.3678,-.5873,.5873,-.7699,.7699,-.9041,.9041,-.9816,.9816],n=[.2491,.2491,.2335,.2335,.2032,.2032,.1601,.1601,.1069,.1069,.0472,.0472],o=0,p=0;k>p;p++){var q=j*l[p]+j,r=m(q,a,c,e,g),s=m(q,b,d,f,h),t=r*r+s*s;o+=n[p]*O.sqrt(t)}return j*o}function o(a,b,c,d,e,f,g,h,i){if(!(0>i||n(a,b,c,d,e,f,g,h)o;)l/=2,m+=(i>j?1:-1)*l,j=n(a,b,c,d,e,f,g,h,m);return m}}function p(a,b,c,d,e,f,g,h){if(!(R(a,c)R(e,g)||R(b,d)R(f,h))){var i=(a*d-b*c)*(e-g)-(a-c)*(e*h-f*g),j=(a*d-b*c)*(f-h)-(b-d)*(e*h-f*g),k=(a-c)*(f-h)-(b-d)*(e-g);if(k){var l=i/k,m=j/k,n=+l.toFixed(2),o=+m.toFixed(2);if(!(n<+Q(a,c).toFixed(2)||n>+R(a,c).toFixed(2)||n<+Q(e,g).toFixed(2)||n>+R(e,g).toFixed(2)||o<+Q(b,d).toFixed(2)||o>+R(b,d).toFixed(2)||o<+Q(f,h).toFixed(2)||o>+R(f,h).toFixed(2)))return{x:l,y:m}}}}function q(a,b,c){var d=j(a),e=j(b);if(!l(d,e))return c?0:[];for(var f=n.apply(0,a),g=n.apply(0,b),h=~~(f/5),k=~~(g/5),m=[],o=[],q={},r=c?0:[],s=0;h+1>s;s++){var t=i.apply(0,a.concat(s/h));m.push({x:t.x,y:t.y,t:s/h})}for(s=0;k+1>s;s++)t=i.apply(0,b.concat(s/k)),o.push({x:t.x,y:t.y,t:s/k});for(s=0;h>s;s++)for(var u=0;k>u;u++){var v=m[s],w=m[s+1],x=o[u],y=o[u+1],z=T(w.x-v.x)<.001?"y":"x",A=T(y.x-x.x)<.001?"y":"x",B=p(v.x,v.y,w.x,w.y,x.x,x.y,y.x,y.y);if(B){if(q[B.x.toFixed(4)]==B.y.toFixed(4))continue;q[B.x.toFixed(4)]=B.y.toFixed(4);var C=v.t+T((B[z]-v[z])/(w[z]-v[z]))*(w.t-v.t),D=x.t+T((B[A]-x[A])/(y[A]-x[A]))*(y.t-x.t);C>=0&&1>=C&&D>=0&&1>=D&&(c?r++:r.push({x:B.x,y:B.y,t1:C,t2:D}))}}return r}function r(a,b){return t(a,b)}function s(a,b){return t(a,b,1)}function t(a,b,c){a=F(a),b=F(b);for(var d,e,f,g,h,i,j,k,l,m,n=c?0:[],o=0,p=a.length;p>o;o++){var r=a[o];if("M"==r[0])d=h=r[1],e=i=r[2];else{"C"==r[0]?(l=[d,e].concat(r.slice(1)),d=l[6],e=l[7]):(l=[d,e,d,e,h,i,h,i],d=h,e=i);for(var s=0,t=b.length;t>s;s++){var u=b[s];if("M"==u[0])f=j=u[1],g=k=u[2];else{"C"==u[0]?(m=[f,g].concat(u.slice(1)),f=m[6],g=m[7]):(m=[f,g,f,g,j,k,j,k],f=j,g=k);var v=q(l,m,c);if(c)n+=v;else{for(var w=0,x=v.length;x>w;w++)v[w].segment1=o,v[w].segment2=s,v[w].bez1=l,v[w].bez2=m;n=n.concat(v)}}}}}return n}function u(a,b,c){var d=v(a);return k(d,b,c)&&1==t(a,[["M",b,c],["H",d.x2+10]],1)%2}function v(a){var b=c(a);if(b.bbox)return K(b.bbox);if(!a)return d();a=F(a);for(var e,f=0,g=0,h=[],i=[],j=0,k=a.length;k>j;j++)if(e=a[j],"M"==e[0])f=e[1],g=e[2],h.push(f),i.push(g);else{var l=E(f,g,e[1],e[2],e[3],e[4],e[5],e[6]);h=h.concat(l.min.x,l.max.x),i=i.concat(l.min.y,l.max.y),f=e[5],g=e[6]}var m=Q.apply(0,h),n=Q.apply(0,i),o=R.apply(0,h),p=R.apply(0,i),q=d(m,n,o-m,p-n);return b.bbox=K(q),q}function w(a,b,c,d,f){if(f)return[["M",a+f,b],["l",c-2*f,0],["a",f,f,0,0,1,f,f],["l",0,d-2*f],["a",f,f,0,0,1,-f,f],["l",2*f-c,0],["a",f,f,0,0,1,-f,-f],["l",0,2*f-d],["a",f,f,0,0,1,f,-f],["z"]];var g=[["M",a,b],["l",c,0],["l",0,d],["l",-c,0],["z"]];return g.toString=e,g}function x(a,b,c,d,f){if(null==f&&null==d&&(d=c),null!=f)var g=Math.PI/180,h=a+c*Math.cos(-d*g),i=a+c*Math.cos(-f*g),j=b+c*Math.sin(-d*g),k=b+c*Math.sin(-f*g),l=[["M",h,j],["A",c,c,0,+(f-d>180),0,i,k]];else l=[["M",a,b],["m",0,-d],["a",c,d,0,1,1,0,2*d],["a",c,d,0,1,1,0,-2*d],["z"]];return l.toString=e,l}function y(b){var d=c(b);if(d.rel)return f(d.rel);a.is(b,"array")&&a.is(b&&b[0],"array")||(b=a.parsePathString(b));var g=[],h=0,i=0,j=0,k=0,l=0;"M"==b[0][0]&&(h=b[0][1],i=b[0][2],j=h,k=i,l++,g.push(["M",h,i]));for(var m=l,n=b.length;n>m;m++){var o=g[m]=[],p=b[m];if(p[0]!=lowerCase.call(p[0]))switch(o[0]=lowerCase.call(p[0]),o[0]){case"a":o[1]=p[1],o[2]=p[2],o[3]=p[3],o[4]=p[4],o[5]=p[5],o[6]=+(p[6]-h).toFixed(3),o[7]=+(p[7]-i).toFixed(3);break;case"v":o[1]=+(p[1]-i).toFixed(3);break;case"m":j=p[1],k=p[2];default:for(var q=1,r=p.length;r>q;q++)o[q]=+(p[q]-(q%2?h:i)).toFixed(3)}else{o=g[m]=[],"m"==p[0]&&(j=p[1]+h,k=p[2]+i);for(var s=0,t=p.length;t>s;s++)g[m][s]=p[s]}var u=g[m].length;switch(g[m][0]){case"z":h=j,i=k;break;case"h":h+=+g[m][u-1];break;case"v":i+=+g[m][u-1];break;default:h+=+g[m][u-2],i+=+g[m][u-1]}}return g.toString=e,d.rel=f(g),g}function z(b){var d=c(b);if(d.abs)return f(d.abs);if(J(b,"array")&&J(b&&b[0],"array")||(b=a.parsePathString(b)),!b||!b.length)return[["M",0,0]];var g,h=[],i=0,j=0,k=0,l=0,m=0;"M"==b[0][0]&&(i=+b[0][1],j=+b[0][2],k=i,l=j,m++,h[0]=["M",i,j]);for(var n,o,p=3==b.length&&"M"==b[0][0]&&"R"==b[1][0].toUpperCase()&&"Z"==b[2][0].toUpperCase(),q=m,r=b.length;r>q;q++){if(h.push(n=[]),o=b[q],g=o[0],g!=g.toUpperCase())switch(n[0]=g.toUpperCase(),n[0]){case"A":n[1]=o[1],n[2]=o[2],n[3]=o[3],n[4]=o[4],n[5]=o[5],n[6]=+(o[6]+i),n[7]=+(o[7]+j);break;case"V":n[1]=+o[1]+j;break;case"H":n[1]=+o[1]+i;break;case"R":for(var s=[i,j].concat(o.slice(1)),t=2,u=s.length;u>t;t++)s[t]=+s[t]+i,s[++t]=+s[t]+j;h.pop(),h=h.concat(H(s,p));break;case"O":h.pop(),s=x(i,j,o[1],o[2]),s.push(s[0]),h=h.concat(s);break;case"U":h.pop(),h=h.concat(x(i,j,o[1],o[2],o[3])),n=["U"].concat(h[h.length-1].slice(-2));break;case"M":k=+o[1]+i,l=+o[2]+j;default:for(t=1,u=o.length;u>t;t++)n[t]=+o[t]+(t%2?i:j)}else if("R"==g)s=[i,j].concat(o.slice(1)),h.pop(),h=h.concat(H(s,p)),n=["R"].concat(o.slice(-2));else if("O"==g)h.pop(),s=x(i,j,o[1],o[2]),s.push(s[0]),h=h.concat(s);else if("U"==g)h.pop(),h=h.concat(x(i,j,o[1],o[2],o[3])),n=["U"].concat(h[h.length-1].slice(-2));else for(var v=0,w=o.length;w>v;v++)n[v]=o[v];if(g=g.toUpperCase(),"O"!=g)switch(n[0]){case"Z":i=k,j=l;break;case"H":i=n[1];break;case"V":j=n[1];break;case"M":k=n[n.length-2],l=n[n.length-1];default:i=n[n.length-2],j=n[n.length-1]}}return h.toString=e,d.abs=f(h),h}function A(a,b,c,d){return[a,b,c,d,c,d]}function B(a,b,c,d,e,f){var g=1/3,h=2/3;return[g*a+h*c,g*b+h*d,g*e+h*c,g*f+h*d,e,f]}function C(a,b,c,d,e,f,g,h,i,j){var k,l=120*P/180,m=P/180*(+e||0),n=[],o=cacher(function(a,b,c){var d=a*O.cos(c)-b*O.sin(c),e=a*O.sin(c)+b*O.cos(c);return{x:d,y:e}});if(j)x=j[0],y=j[1],v=j[2],w=j[3];else{k=o(a,b,-m),a=k.x,b=k.y,k=o(h,i,-m),h=k.x,i=k.y;var p=(O.cos(P/180*e),O.sin(P/180*e),(a-h)/2),q=(b-i)/2,r=p*p/(c*c)+q*q/(d*d);r>1&&(r=O.sqrt(r),c=r*c,d=r*d);var s=c*c,t=d*d,u=(f==g?-1:1)*O.sqrt(T((s*t-s*q*q-t*p*p)/(s*q*q+t*p*p))),v=u*c*q/d+(a+h)/2,w=u*-d*p/c+(b+i)/2,x=O.asin(((b-w)/d).toFixed(9)),y=O.asin(((i-w)/d).toFixed(9));x=v>a?P-x:x,y=v>h?P-y:y,0>x&&(x=2*P+x),0>y&&(y=2*P+y),g&&x>y&&(x-=2*P),!g&&y>x&&(y-=2*P)}var z=y-x;if(T(z)>l){var A=y,B=h,D=i;y=x+l*(g&&y>x?1:-1),h=v+c*O.cos(y),i=w+d*O.sin(y),n=C(h,i,c,d,e,0,g,B,D,[y,A,v,w])}z=y-x;var E=O.cos(x),F=O.sin(x),G=O.cos(y),H=O.sin(y),I=O.tan(z/4),J=4/3*c*I,K=4/3*d*I,L=[a,b],M=[a+J*F,b-K*E],N=[h+J*H,i-K*G],Q=[h,i];if(M[0]=2*L[0]-M[0],M[1]=2*L[1]-M[1],j)return[M,N,Q].concat(n);n=[M,N,Q].concat(n).join().split(",");for(var R=[],S=0,U=n.length;U>S;S++)R[S]=S%2?o(n[S-1],n[S],m).y:o(n[S],n[S+1],m).x;return R}function D(a,b,c,d,e,f,g,h,i){var j=1-i;return{x:S(j,3)*a+3*S(j,2)*i*c+3*j*i*i*e+S(i,3)*g,y:S(j,3)*b+3*S(j,2)*i*d+3*j*i*i*f+S(i,3)*h}}function E(a,b,c,d,e,f,g,h){var i,j=e-2*c+a-(g-2*e+c),k=2*(c-a)-2*(e-c),l=a-c,m=(-k+O.sqrt(k*k-4*j*l))/2/j,n=(-k-O.sqrt(k*k-4*j*l))/2/j,o=[b,h],p=[a,g];return T(m)>"1e12"&&(m=.5),T(n)>"1e12"&&(n=.5),m>0&&1>m&&(i=D(a,b,c,d,e,f,g,h,m),p.push(i.x),o.push(i.y)),n>0&&1>n&&(i=D(a,b,c,d,e,f,g,h,n),p.push(i.x),o.push(i.y)),j=f-2*d+b-(h-2*f+d),k=2*(d-b)-2*(f-d),l=b-d,m=(-k+O.sqrt(k*k-4*j*l))/2/j,n=(-k-O.sqrt(k*k-4*j*l))/2/j,T(m)>"1e12"&&(m=.5),T(n)>"1e12"&&(n=.5),m>0&&1>m&&(i=D(a,b,c,d,e,f,g,h,m),p.push(i.x),o.push(i.y)),n>0&&1>n&&(i=D(a,b,c,d,e,f,g,h,n),p.push(i.x),o.push(i.y)),{min:{x:Q.apply(0,p),y:Q.apply(0,o)},max:{x:R.apply(0,p),y:R.apply(0,o)}}}function F(a,b){var d=!b&&c(a);if(!b&&d.curve)return f(d.curve);for(var e=z(a),g=b&&z(b),h={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},i={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},j=(function(a,b){var c,d;if(!a)return["C",b.x,b.y,b.x,b.y,b.x,b.y];switch(!(a[0]in{T:1,Q:1})&&(b.qx=b.qy=null),a[0]){case"M":b.X=a[1],b.Y=a[2];break;case"A":a=["C"].concat(C.apply(0,[b.x,b.y].concat(a.slice(1))));break;case"S":c=b.x+(b.x-(b.bx||b.x)),d=b.y+(b.y-(b.by||b.y)),a=["C",c,d].concat(a.slice(1));break;case"T":b.qx=b.x+(b.x-(b.qx||b.x)),b.qy=b.y+(b.y-(b.qy||b.y)),a=["C"].concat(B(b.x,b.y,b.qx,b.qy,a[1],a[2]));break;case"Q":b.qx=a[1],b.qy=a[2],a=["C"].concat(B(b.x,b.y,a[1],a[2],a[3],a[4]));break;case"L":a=["C"].concat(A(b.x,b.y,a[1],a[2]));break;case"H":a=["C"].concat(A(b.x,b.y,a[1],b.y));break;case"V":a=["C"].concat(A(b.x,b.y,b.x,a[1]));break;case"Z":a=["C"].concat(A(b.x,b.y,b.X,b.Y))}return a}),k=function(a,b){if(a[b].length>7){a[b].shift();for(var c=a[b];c.length;)a.splice(b++,0,["C"].concat(c.splice(0,6)));a.splice(b,1),n=R(e.length,g&&g.length||0)}},l=function(a,b,c,d,f){a&&b&&"M"==a[f][0]&&"M"!=b[f][0]&&(b.splice(f,0,["M",d.x,d.y]),c.bx=0,c.by=0,c.x=a[f][1],c.y=a[f][2],n=R(e.length,g&&g.length||0))},m=0,n=R(e.length,g&&g.length||0);n>m;m++){e[m]=j(e[m],h),k(e,m),g&&(g[m]=j(g[m],i)),g&&k(g,m),l(e,g,h,i,m),l(g,e,i,h,m);var o=e[m],p=g&&g[m],q=o.length,r=g&&p.length;h.x=o[q-2],h.y=o[q-1],h.bx=N(o[q-4])||h.x,h.by=N(o[q-3])||h.y,i.bx=g&&(N(p[r-4])||i.x),i.by=g&&(N(p[r-3])||i.y),i.x=g&&p[r-2],i.y=g&&p[r-1]}return g||(d.curve=f(e)),g?[e,g]:e}function G(a,b){if(!b)return a;var c,d,e,f,g,h,i;for(a=F(a),e=0,g=a.length;g>e;e++)for(i=a[e],f=1,h=i.length;h>f;f+=2)c=b.x(i[f],i[f+1]),d=b.y(i[f],i[f+1]),i[f]=c,i[f+1]=d;return a}function H(a,b){for(var c=[],d=0,e=a.length;e-2*!b>d;d+=2){var f=[{x:+a[d-2],y:+a[d-1]},{x:+a[d],y:+a[d+1]},{x:+a[d+2],y:+a[d+3]},{x:+a[d+4],y:+a[d+5]}];b?d?e-4==d?f[3]={x:+a[0],y:+a[1]}:e-2==d&&(f[2]={x:+a[0],y:+a[1]},f[3]={x:+a[2],y:+a[3]}):f[0]={x:+a[e-2],y:+a[e-1]}:e-4==d?f[3]=f[2]:d||(f[0]={x:+a[d],y:+a[d+1]}),c.push(["C",(-f[0].x+6*f[1].x+f[2].x)/6,(-f[0].y+6*f[1].y+f[2].y)/6,(f[1].x+6*f[2].x-f[3].x)/6,(f[1].y+6*f[2].y-f[3].y)/6,f[2].x,f[2].y])}return c}var I=b.prototype,J=a.is,K=a._.clone,L="hasOwnProperty",M=/,?([a-z]),?/gi,N=parseFloat,O=Math,P=O.PI,Q=O.min,R=O.max,S=O.pow,T=O.abs,U=h(1),V=h(),W=h(0,1),X={path:function(a){return a.attr("path")},circle:function(a){var b=unit2px(a);return x(b.cx,b.cy,b.r)},ellipse:function(a){var b=unit2px(a);return x(b.cx,b.cy,b.rx,b.ry)},rect:function(a){var b=unit2px(a);return w(b.x,b.y,b.width,b.height,b.rx,b.ry)},image:function(a){var b=unit2px(a);return w(b.x,b.y,b.width,b.height)},text:function(a){var b=a.node.getBBox();return w(b.x,b.y,b.width,b.height)},g:function(a){var b=a.node.getBBox();return w(b.x,b.y,b.width,b.height)},symbol:function(a){var b=a.getBBox();return w(b.x,b.y,b.width,b.height)}};a.path=c,a.path.getTotalLength=U,a.path.getPointAtLength=V,a.path.getSubpath=function(a,b,c){if(this.getTotalLength(a)-c<1e-6)return W(a,b).end;var d=W(a,c,1);return b?W(d,b).end:d},I.getTotalLength=function(){return this.node.getTotalLength?this.node.getTotalLength():void 0},I.getPointAtLength=function(a){return V(this.attr("d"),a)},I.getSubpath=function(a,b){return getSubpath(this.attr("d"),a,b)},a._.box=d,a.path.findDotsAtSegment=i,a.path.bezierBBox=j,a.path.isPointInsideBBox=k,a.path.isBBoxIntersect=l,a.path.intersection=r,a.path.intersectionNumber=s,a.path.isPointInside=u,a.path.getBBox=v,a.path.get=X,a.path.toRelative=y,a.path.toAbsolute=z,a.path.toCubic=F,a.path.map=G,a.path.toString=e,a.path.clone=f}),Savage.plugin(function(a){var b=Math.max,c=Math.min,d=function(a){if(this.items=[],this.length=0,this.type="set",a)for(var b=0,c=a.length;c>b;b++)a[b]&&(this[this.items.length]=this.items[this.items.length]=a[b],this.length++)},e=d.prototype;e.push=function(){for(var a,b,c=0,d=arguments.length;d>c;c++)a=arguments[c],a&&(b=this.items.length,this[b]=this.items[b]=a,this.length++);return this},e.pop=function(){return this.length&&delete this[this.length--],this.items.pop()},e.forEach=function(a,b){for(var c=0,d=this.items.length;d>c;c++)if(a.call(b,this.items[c],c)===!1)return this;return this},e.attr=function(a){for(var b=0,c=this.items.length;c>b;b++)this.items[b].attr(a);return this},e.clear=function(){for(;this.length;)this.pop()},e.splice=function(a,e){a=0>a?b(this.length+a,0):a,e=b(0,c(this.length-a,e));var f,g=[],h=[],i=[];for(f=2;ff;f++)h.push(this[a+f]);for(;ff?i[f]:g[f-j];for(f=this.items.length=this.length-=e-j;this[f];)delete this[f++];return new d(h)},e.exclude=function(a){for(var b=0,c=this.length;c>b;b++)if(this[b]==a)return this.splice(b,1),!0},e.insertAfter=function(a){for(var b=this.items.length;b--;)this.items[b].insertAfter(a);return this},e.getBBox=function(){for(var a=[],d=[],e=[],f=[],g=this.items.length;g--;)if(!this.items[g].removed){var h=this.items[g].getBBox();a.push(h.x),d.push(h.y),e.push(h.x+h.width),f.push(h.y+h.height)}return a=c.apply(0,a),d=c.apply(0,d),e=b.apply(0,e),f=b.apply(0,f),{x:a,y:d,x2:e,y2:f,width:e-a,height:f-d,cx:a+(e-a)/2,cy:d+(f-d)/2}},e.clone=function(a){a=new d;for(var b=0,c=this.items.length;c>b;b++)a.push(this.items[b].clone());return a},e.toString=function(){return"Savage‘s set"},e.type="set",a.set=function(){var a=new d;return arguments.length&&a.push.apply(a,Array.prototype.slice.call(arguments,0)),a}}),Savage.plugin(function(a,b){function c(a){var b=a[0];switch(b.toLowerCase()){case"t":return[b,0,0];case"m":return[b,1,0,0,1,0,0];case"r":return 4==a.length?[b,0,a[2],a[3]]:[b,0];case"s":return 5==a.length?[b,1,1,a[3],a[4]]:3==a.length?[b,1,1]:[b,1]}}function d(b,d){d=l(d).replace(/\.{3}|\u2026/g,b),b=a.parseTransformString(b)||[],d=a.parseTransformString(d)||[];for(var e,f,g,j,k=Math.max(b.length,d.length),m=[],n=[],o=0;k>o;o++){if(g=b[o]||c(d[o]),j=d[o]||c(g),g[0]!=j[0]||"r"==g[0].toLowerCase()&&(g[2]!=j[2]||g[3]!=j[3])||"s"==g[0].toLowerCase()&&(g[3]!=j[3]||g[4]!=j[4]))return;for(m[o]=[],n[o]=[],e=0,f=Math.max(g.length,j.length);f>e;e++)e in g&&(m[o][e]=g[e]),e in j&&(n[o][e]=j[e])}return{from:i(m),to:i(n),f:h(m)}}function e(a){return a}function f(a){return function(b){return+b.toFixed(3)+a}}function g(b){return a.rgb(b[0],b[1],b[2])}function h(a){var b,c,d,e,f,g,h=0,i=[];for(b=0,c=a.length;c>b;b++){for(f="[",g=['"'+a[b][0]+'"'],d=1,e=a[b].length;e>d;d++)g[d]="val["+h++ +"]";f+=g+"]",i[b]=f}return Function("val","return Savage.path.toString.call(["+i+"])")}function i(a){for(var b=[],c=0,d=a.length;d>c;c++)for(var e=1,f=a[c].length;f>e;e++)b.push(a[c][e]);return b}var j={},k=/[a-z]+$/i,l=String;j.stroke=j.fill="colour",b.prototype.equal=function(b,c){var m,n,o=l(this.attr(b)||"");if(o==+o&&c==+c)return{from:+o,to:+c,f:e};if("colour"==j[b])return m=a.color(o),n=a.color(c),{from:[m.r,m.g,m.b,m.opacity],to:[n.r,n.g,n.b,n.opacity],f:g};if("transform"==b||"gradientTransform"==b||"patternTransform"==b)return d(o.local,c);if("d"==b||"path"==b)return m=a.path.toCubic(o,c),{from:i(m[0]),to:i(m[1]),f:h(m[0])};var p=o.match(k),q=c.match(k);return p&&p==q?{from:parseFloat(o),to:parseFloat(c),f:f(p)}:{from:this.asPX(b),to:this.asPX(b,c),f:e}}}),Savage.plugin(function(a,b,c,d){for(var e=b.prototype,f="hasOwnProperty",g=("createTouch"in d.doc),h=["click","dblclick","mousedown","mousemove","mouseout","mouseover","mouseup","touchstart","touchmove","touchend","touchcancel"],i={mousedown:"touchstart",mousemove:"touchmove",mouseup:"touchend"},j=function(a){var b="y"==a?"scrollTop":"scrollLeft";return d.doc.documentElement[b]||d.doc.body[b]},k=function(){this.returnValue=!1},l=function(){return this.originalEvent.preventDefault()},m=function(){this.cancelBubble=!0},n=function(){return this.originalEvent.stopPropagation()},o=function(){return d.doc.addEventListener?function(a,b,c,d){var e=g&&i[b]?i[b]:b,h=function(e){var h=j("y"),k=j("x"),m=e.clientX+k,o=e.clientY+h;if(g&&i[f](b))for(var p=0,q=e.targetTouches&&e.targetTouches.length;q>p;p++)if(e.targetTouches[p].target==a){var r=e;e=e.targetTouches[p],e.originalEvent=r,e.preventDefault=l,e.stopPropagation=n;break}return c.call(d,e,m,o)};return a.addEventListener(e,h,!1),function(){return a.removeEventListener(e,h,!1),!0}}:d.doc.attachEvent?function(a,b,c,e){var f=function(a){a=a||d.win.event;var b=j("y"),f=j("x"),g=a.clientX+f,h=a.clientY+b;return a.preventDefault=a.preventDefault||k,a.stopPropagation=a.stopPropagation||m,c.call(e,a,g,h)};a.attachEvent("on"+b,f);var g=function(){return a.detachEvent("on"+b,f),!0};return g}:void 0}(),p=[],q=function(a){for(var b,c=a.clientX,d=a.clientY,e=j("y"),f=j("x"),h=p.length;h--;){if(b=p[h],g){for(var i,k=a.touches.length;k--;)if(i=a.touches[k],i.identifier==b.el._drag.id){c=i.clientX,d=i.clientY,(a.originalEvent?a.originalEvent:a).preventDefault();break}}else a.preventDefault();var l=b.el.node;l.nextSibling,l.parentNode,l.style.display,c+=f,d+=e,eve("savage.drag.move."+b.el.id,b.move_scope||b.el,c-b.el._drag.x,d-b.el._drag.y,c,d,a)}},r=function(b){a.unmousemove(q).unmouseup(r);for(var c,d=p.length;d--;)c=p[d],c.el._drag={},eve("savage.drag.end."+c.el.id,c.end_scope||c.start_scope||c.move_scope||c.el,b);p=[]},s=h.length;s--;)!function(b){a[b]=e[b]=function(c,e){return a.is(c,"function")&&(this.events=this.events||[],this.events.push({name:b,f:c,unbind:o(this.shape||this.node||d.doc,b,c,e||this)})),this},a["un"+b]=e["un"+b]=function(a){for(var c=this.events||[],d=c.length;d--;)if(c[d].name==b&&c[d].f==a)return c[d].unbind(),c.splice(d,1),!c.length&&delete this.events,this;return this}}(h[s]);e.data=function(b,c){var d=eldata[this.id]=eldata[this.id]||{};if(1==arguments.length){if(a.is(b,"object")){for(var e in b)b[f](e)&&this.data(e,b[e]);return this}return eve("savage.data.get."+this.id,this,d[b],b),d[b]}return d[b]=c,eve("savage.data.set."+this.id,this,c,b),this},e.removeData=function(a){return null==a?eldata[this.id]={}:eldata[this.id]&&delete eldata[this.id][a],this},e.hover=function(a,b,c,d){return this.mouseover(a,c).mouseout(b,d||c)},e.unhover=function(a,b){return this.unmouseover(a).unmouseout(b)};var t=[];e.drag=function(b,c,d,e,f,g){function h(h){(h.originalEvent||h).preventDefault();var i=j("y"),k=j("x");this._drag.x=h.clientX+k,this._drag.y=h.clientY+i,this._drag.id=h.identifier,!p.length&&a.mousemove(q).mouseup(r),p.push({el:this,move_scope:e,start_scope:f,end_scope:g}),c&&eve.on("savage.drag.start."+this.id,c),b&&eve.on("savage.drag.move."+this.id,b),d&&eve.on("savage.drag.end."+this.id,d),eve("savage.drag.start."+this.id,f||e||this,h.clientX+k,h.clientY+i,h)}if(!arguments.length){var i;return this.drag(function(a,b){this.attr({transform:i+(i?"T":"t")+[a,b]})},function(){i=this.transform().local})}return this._drag={},t.push({el:this,start:h}),this.mousedown(h),this},e.onDragOver=function(a){a?eve.on("savage.drag.over."+this.id,a):eve.unbind("savage.drag.over."+this.id)},e.undrag=function(){for(var b=t.length;b--;)t[b].el==this&&(this.unmousedown(t[b].start),t.splice(b,1),eve.unbind("savage.drag.*."+this.id));!t.length&&a.unmousemove(q).unmouseup(r)}}),Savage.plugin(function(a,b,c){var d=(b.prototype,c.prototype),e=/^\s*url\((.+)\)/,f=String,g=a._.$;a.filter={},d.filter=function(c){var d=a.parse(f(c)),e=a._.id(),h=this.node.offsetWidth,i=this.node.offsetHeight,j=g("filter");return g(j,{id:e,filterUnits:"userSpaceOnUse",x:0,y:0,width:h,height:i}),j.appendChild(d.node),this.defs.appendChild(j),new b(j)},eve.on("savage.util.getattr.filter",function(){eve.stop();var b=g(this.node,"filter");if(b){var c=f(b).match(e);return c&&a.select(c[1])}}),eve.on("savage.util.attr.filter",function(a){if(a instanceof b&&"filter"==a.type){eve.stop();var c=a.node.id;c||(g(a.node,{id:a.id}),c=a.id),g(this.node,{filter:"url(#"+c+")"})}a||(eve.stop(),this.node.removeAttribute("filter"))}),a.filter.blur=function(b,c){null==b&&(b=2);var d=null==c?b:[b,c];return a.format(' ',{def:d})},a.filter.blur.toString=function(){return this()},a.filter.shadow=function(b,c,d,e){return e=a.color(e||"#000"),null==d&&(d=2),null==b&&(b=0,c=4),null==c&&(c=b),a.format(' ',{r:e.r,g:e.g,b:e.b,o:e.opacity,dx:b,dy:c,blur:d})},a.filter.shadow.toString=function(){return this()}});
\ No newline at end of file
+// build: 2013-08-29
+!function(a){var b,c,d="0.4.2",e="hasOwnProperty",f=/[\.\/]/,g="*",h=function(){},i=function(a,b){return a-b},j={n:{}},k=function(a,d){a=String(a);var e,f=c,g=Array.prototype.slice.call(arguments,2),h=k.listeners(a),j=0,l=[],m={},n=[],o=b;b=a,c=0;for(var p=0,q=h.length;q>p;p++)"zIndex"in h[p]&&(l.push(h[p].zIndex),h[p].zIndex<0&&(m[h[p].zIndex]=h[p]));for(l.sort(i);l[j]<0;)if(e=m[l[j++]],n.push(e.apply(d,g)),c)return c=f,n;for(p=0;q>p;p++)if(e=h[p],"zIndex"in e)if(e.zIndex==l[j]){if(n.push(e.apply(d,g)),c)break;do if(j++,e=m[l[j]],e&&n.push(e.apply(d,g)),c)break;while(e)}else m[e.zIndex]=e;else if(n.push(e.apply(d,g)),c)break;return c=f,b=o,n.length?n:null};k._events=j,k.listeners=function(a){var b,c,d,e,h,i,k,l,m=a.split(f),n=j,o=[n],p=[];for(e=0,h=m.length;h>e;e++){for(l=[],i=0,k=o.length;k>i;i++)for(n=o[i].n,c=[n[m[e]],n[g]],d=2;d--;)b=c[d],b&&(l.push(b),p=p.concat(b.f||[]));o=l}return p},k.on=function(a,b){if(a=String(a),"function"!=typeof b)return function(){};for(var c=a.split(f),d=j,e=0,g=c.length;g>e;e++)d=d.n,d=d.hasOwnProperty(c[e])&&d[c[e]]||(d[c[e]]={n:{}});for(d.f=d.f||[],e=0,g=d.f.length;g>e;e++)if(d.f[e]==b)return h;return d.f.push(b),function(a){+a==+a&&(b.zIndex=+a)}},k.f=function(a){var b=[].slice.call(arguments,1);return function(){k.apply(null,[a,null].concat(b).concat([].slice.call(arguments,0)))}},k.stop=function(){c=1},k.nt=function(a){return a?new RegExp("(?:\\.|\\/|^)"+a+"(?:\\.|\\/|$)").test(b):b},k.nts=function(){return b.split(f)},k.off=k.unbind=function(a,b){if(!a)return k._events=j={n:{}},void 0;var c,d,h,i,l,m,n,o=a.split(f),p=[j];for(i=0,l=o.length;l>i;i++)for(m=0;mi;i++)for(c=p[i];c.n;){if(b){if(c.f){for(m=0,n=c.f.length;n>m;m++)if(c.f[m]==b){c.f.splice(m,1);break}!c.f.length&&delete c.f}for(d in c.n)if(c.n[e](d)&&c.n[d].f){var q=c.n[d].f;for(m=0,n=q.length;n>m;m++)if(q[m]==b){q.splice(m,1);break}!q.length&&delete c.n[d].f}}else{delete c.f;for(d in c.n)c.n[e](d)&&c.n[d].f&&delete c.n[d].f}c=c.n}},k.once=function(a,b){var c=function(){return k.unbind(a,c),b.apply(this,arguments)};return k.on(a,c)},k.version=d,k.toString=function(){return"You are running Eve "+d},"undefined"!=typeof module&&module.exports?module.exports=k:"undefined"!=typeof define?define("eve",[],function(){return k}):a.eve=k}(this);var mina=function(a){var b={},c=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(a){setTimeout(a,16)},d=Array.isArray||function(a){return a instanceof Array||"[object Array]"==Object.prototype.toString.call(a)},e=0,f="M"+(+new Date).toString(36),g=function(){return f+(e++).toString(36)},h=function(){return+new Date},i=function(a){var b=this;if(null==a)return b.s;var c=b.s-a;b.b+=b.dur*c,b.B+=b.dur*c,b.s=a},j=function(a){var b=this;return null==a?b.spd:(b.spd=a,void 0)},k=function(a){var b=this;return null==a?b.dur:(b.s=b.s*a/b.dur,b.dur=a,void 0)},l=function(){var c=this;delete b[c.id],a("mina.stop."+c.id,c)},m=function(){var e=0;for(var f in b)if(b.hasOwnProperty(f)){var g,h=b[f],i=h.get();if(e++,h.s=(i-h.b)/(h.dur/h.spd),h.s>=1&&(delete b[f],h.s=1,e--),d(h.start)){g=[];for(var j=0,k=h.start.length;k>j;j++)g[j]=h.start[j]+(h.end[j]-h.start[j])*h.easing(h.s)}else g=h.start+(h.end-h.start)*h.easing(h.s);h.set(g),1==h.s&&a("mina.finish."+h.id,h)}e&&c(m)},n=function(a,d,e,f,h,o,p){var q={id:g(),start:a,end:d,b:e,s:0,dur:f-e,spd:1,get:h,set:o,easing:p||n.linear,status:i,speed:j,duration:k,stop:l};b[q.id]=q;var r,s=0;for(r in b)if(b.hasOwnProperty(r)&&(s++,2==s))break;return 1==s&&c(m),q};return n.time=h,n.getById=function(){return b[anim.id]||null},n.linear=function(a){return a},n.easeout=function(a){return Math.pow(a,1.7)},n.easein=function(a){return Math.pow(a,.48)},n.easeinout=function(a){var b=.48-a/1.04,c=Math.sqrt(.1734+b*b),d=c-b,e=Math.pow(Math.abs(d),1/3)*(0>d?-1:1),f=-c-b,g=Math.pow(Math.abs(f),1/3)*(0>f?-1:1),h=e+g+.5;return 3*(1-h)*h*h+h*h*h},n.backin=function(a){var b=1.70158;return a*a*((b+1)*a-b)},n.backout=function(a){a-=1;var b=1.70158;return a*a*((b+1)*a+b)+1},n.elastic=function(a){return a==!!a?a:Math.pow(2,-10*a)*Math.sin((a-.075)*2*Math.PI/.3)+1},n.bounce=function(a){var b,c=7.5625,d=2.75;return 1/d>a?b=c*a*a:2/d>a?(a-=1.5/d,b=c*a*a+.75):2.5/d>a?(a-=2.25/d,b=c*a*a+.9375):(a-=2.625/d,b=c*a*a+.984375),b},n}("undefined"==typeof eve?function(){}:eve);!function(){function a(a){a=a||Object(a);for(var c,d,e=1,g=a.length+1,h=b(a,0);g>e;e++)c=d,d=h,h=b(a,e),this.raw+=d,f.call(this,d,h,c);return this._beforeEnd=function(){f.call(this,"","",d)},this}function b(a,b){return a&&(a.charAt?a.charAt(b):a[b])}function c(a,b){this.events=this.events||{},this.events[a]=this.events[a]||[],this.events[a].push(b)}function d(a,b,c){"function"==typeof eve&&eve("elemental."+a+"."+b,null,b,c||"",this.raw);for(var d=this.events&&this.events[a],e=d&&d.length;e--;)try{this.events[a][e](b,c||"",this.raw)}catch(f){}this.raw=""}function e(){f.call(this,"eof"),this.event("eof")}function f(a,b,c){"\n"==a&&this.event("newline"),j[this.mode].call(this,a,b,c)}function g(b){var f=function(a){f.parse(a)};return f.mode="text",f.type=String(b||"html").toLowerCase(),f.textchunk="",f.raw="",f.parse=a,f.on=c,f.event=d,f.end=e,f}var h=/[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u2028\u2029\u202f\u205f\u3000]/,i=function(){for(var a in this.attr)this.attr.hasOwnProperty(a)&&this.event("attr",a,{value:this.attr[a],tagname:this.tagname,attr:this.attr})},j={text:function(a){switch(a){case"<":case"eof":this.nodename="",this.attr={},this.mode="tag name start",this.raw=this.raw.slice(0,-1),this.textchunk&&this.event("text",this.textchunk),this.raw+=a,this.textchunk="";break;default:this.textchunk+=a}},special:function(a,b,c){return"!"==c&&"-"==a&&"-"==b?(this.mode="comment start",void 0):"[CDATA"==this.textchunk&&"["==a?(this.mode="cdata",this.textchunk="",void 0):">"==a||"eof"==a?(this.event("special",this.textchunk),this.mode="text",this.textchunk="",void 0):(this.textchunk+=a,void 0)},cdata:function(a,b,c){return"]"==c&&"]"==a&&">"==b?(this.mode="cdata end",this.textchunk=this.textchunk.slice(0,-1),void 0):("eof"==a&&j["cdata end"].call(this),this.textchunk+=a,void 0)},"cdata end":function(){this.event("cdata",this.textchunk),this.textchunk="",this.mode="text"},"comment start":function(a,b){">"==b||"eof"==a?(this.event("comment",""),this.mode="comment instant end"):this.mode="comment"},"comment instant end":function(){this.mode="text"},comment:function(a,b,c){"-"==a&&"-"==c&&">"==b?(this.mode="comment end",this.textchunk=this.textchunk.slice(0,-1)):"eof"==a?this.event("comment",this.textchunk):this.textchunk+=a},"comment end":function(){this.event("comment",this.textchunk),this.textchunk="",this.mode="text"},declaration:function(a,b){return"?"==a&&">"==b?(this.mode="declaration end",void 0):("eof"==a&&this.event("comment",this.textchunk),this.textchunk+=a,void 0)},"declaration end":function(){this.event("comment",this.textchunk),this.textchunk="",this.mode="text"},"tag name start":function(a,b,c){if("eof"==a)return this.event("text","<"),void 0;if(!h.test(a)){if(this.mode="tag name","/"==a)return this.mode="close tag name start",void 0;if("!"==a)return this.mode="special",this.textchunk="",void 0;if("?"==a)return this.mode="declaration",void 0;j[this.mode].call(this,a,b,c)}},"close tag name start":function(a,b,c){h.test(a)||(this.mode="close tag name",this.tagname="",this.nodename="",j[this.mode].call(this,a,b,c))},"close tag name":function(a){if(h.test(a))this.tagname=this.nodename;else switch(a){case">":this.event("/tag",this.tagname||this.nodename),this.mode="text";break;default:!this.tagname&&(this.nodename+=a)}},"tag name":function(a){if(h.test(a))this.tagname=this.nodename,this.nodename="",this.mode="attr start";else switch(a){case">":this.event("tag",this.nodename),this.mode="text";break;default:this.nodename+=a}},"attr start":function(a,b,c){h.test(a)||(this.mode="attr",this.nodename="",j[this.mode].call(this,a,b,c))},attr:function(a){if(h.test(a)||"="==a)this.attr[this.nodename]="",this.mode="attr value start";else switch(a){case">":"/"==this.nodename?(delete this.attr["/"],this.event("tag",this.tagname,this.attr),i.call(this),this.event("/tag",this.tagname,!0)):(this.nodename&&(this.attr[this.nodename]=""),this.event("tag",this.tagname,this.attr),i.call(this)),this.mode="text";break;default:this.nodename+=a}},"attr value start":function(a,b,c){if(!h.test(a)){if(this.mode="attr value",this.quote=!1,"'"==a||'"'==a)return this.quote=a,void 0;j[this.mode].call(this,a,b,c)}},"attr value":function(a,b,c){if(h.test(a)&&!this.quote)this.mode="attr start";else if(">"!=a||this.quote)switch(a){case'"':case"'":this.quote==a&&"\\"!=c&&(this.mode="attr start");break;default:this.attr[this.nodename]+=a}else this.event("tag",this.tagname,this.attr),this.mode="text"}};g.version="0.2.1",("undefined"==typeof exports?this:exports).elemental=g}();var Savage=function(){function a(a,b){if(a){if(a.tagName)return s(a);if(a instanceof n)return a;if(null==b)return a=t.doc.querySelector(a),s(a)}return a=null==a?"100%":a,b=null==b?"100%":b,new r(a,b)}function b(a,c){if(c){if("string"==typeof a&&(a=b(a)),"string"==typeof c)return"xlink:"==c.substring(0,6)?a.getAttributeNS(T,c.substring(6)):a.getAttribute(c);for(var d in c)if(c[u](d)){var e=v(c[d]);e?"xlink:"==d.substring(0,6)?a.setAttributeNS(T,d.substring(6),e):a.setAttribute(d,e):a.removeAttribute(d)}}else a=t.doc.createElementNS("http://www.w3.org/2000/svg",a);return a}function c(a,b){return b=v.prototype.toLowerCase.call(b),"finite"==b?!H[u](+a):"array"==b&&(a instanceof Array||Array.isArray&&Array.isArray(a))?!0:"null"==b&&null===a||b==typeof a&&null!==a||"object"==b&&a===Object(a)||F.call(a).slice(8,-1).toLowerCase()==b}function d(a){if("function"==typeof a||Object(a)!==a)return a;var b=new a.constructor;for(var c in a)a[u](c)&&(b[c]=d(a[c]));return b}function e(a,b){for(var c=0,d=a.length;d>c;c++)if(a[c]===b)return a.push(a.splice(c,1)[0])}function f(a,b,c){function d(){var f=Array.prototype.slice.call(arguments,0),g=f.join("␀"),h=d.cache=d.cache||{},i=d.count=d.count||[];return h[u](g)?(e(i,g),c?c(h[g]):h[g]):(i.length>=1e3&&delete h[i.shift()],i.push(g),h[g]=a.apply(b,f),c?c(h[g]):h[g])}return d}function g(a){return a%360*C/180}function h(a){return 180*a/C%360}function i(){return this.x+E+this.y+E+this.width+" × "+this.height}function j(a,b,c,d,e,f){return null==b&&"[object SVGMatrix]"==F.call(a)?(this.a=a.a,this.b=a.b,this.c=a.c,this.d=a.d,this.e=a.e,this.f=a.f,void 0):(null!=a?(this.a=+a,this.b=+b,this.c=+c,this.d=+d,this.e=+e,this.f=+f):(this.a=1,this.b=0,this.c=0,this.d=1,this.e=0,this.f=0),void 0)}function k(a){var b=[];return a=a.replace(/(?:^|\s)(\w+)\(([^)]+)\)/g,function(a,c,d){return d=d.split(/\s*,\s*/),"rotate"==c&&1==d.length&&d.push(0,0),"scale"==c&&(2==d.length&&d.push(0,0),1==d.length&&d.push(d[0],0,0)),"skewX"==c?b.push(["m",1,0,y.tan(g(d[0])),1,0,0]):"skewY"==c?b.push(["m",1,y.tan(g(d[0])),0,1,0,0]):b.push([c.charAt(0)].concat(d)),a}),b}function l(a,b){if(null==b){var c=!0;if(b="linearGradient"==a.type||"radialGradient"==a.type?a.node.getAttribute("gradientTransform"):"pattern"==a.type?a.node.getAttribute("patternTransform"):a.node.getAttribute("transform"),!b)return new j;b=k(b)}else b=bb.test(b)?v(b).replace(/\.{3}|\u2026/g,a._.transform||D):k(b);var d=ab(b),e=0,f=0,g=0,h=1,i=1,l=a._,m=new j;if(l.transform=d||[],d){for(var n=0,o=d.length;o>n;n++){var p,q,r,s,t,u=d[n],w=u.length,x=v(u[0]).toLowerCase(),y=u[0]!=x,z=y?m.invert():0;"t"==x&&3==w?y?(p=z.x(0,0),q=z.y(0,0),r=z.x(u[1],u[2]),s=z.y(u[1],u[2]),m.translate(r-p,s-q)):m.translate(u[1],u[2]):"r"==x?2==w?(t=t||a.getBBox(1),m.rotate(u[1],t.x+t.width/2,t.y+t.height/2),e+=u[1]):4==w&&(y?(r=z.x(u[2],u[3]),s=z.y(u[2],u[3]),m.rotate(u[1],r,s)):m.rotate(u[1],u[2],u[3]),e+=u[1]):"s"==x?2==w||3==w?(t=t||a.getBBox(1),m.scale(u[1],u[w-1],t.x+t.width/2,t.y+t.height/2),h*=u[1],i*=u[w-1]):5==w&&(y?(r=z.x(u[3],u[4]),s=z.y(u[3],u[4]),m.scale(u[1],u[2],r,s)):m.scale(u[1],u[2],u[3],u[4]),h*=u[1],i*=u[2]):"m"==x&&7==w&&m.add(u[1],u[2],u[3],u[4],u[5],u[6])}if(c)return m;l.dirtyT=1,a.matrix=m}a.matrix=m,l.sx=h,l.sy=i,l.deg=e,l.dx=f=m.e,l.dy=g=m.f,1==h&&1==i&&!e&&l.bbox?(l.bbox.x+=+f,l.bbox.y+=+g):l.dirtyT=1}function m(a,c,d){function e(a){return null==a?D:a==+a?a:(b(j,{width:a}),j.getBBox().width)}function f(a){return null==a?D:a==+a?a:(b(j,{height:a}),j.getBBox().height)}function g(b,e){null==c?i[b]=e(a.attr(b)):b==c&&(i=e(null==d?a.attr(b):d))}var h=a.paper.defs,i={},j=a.paper.measurer;switch(j||(a.paper.measurer=j=b("rect"),b(j,{width:10,height:10}),h.appendChild(j)),a.type){case"rect":g("rx",e),g("ry",f);case"image":g("width",e),g("height",f);case"text":g("x",e),g("y",f);break;case"circle":g("cx",e),g("cy",f),g("r",e);break;case"ellipse":g("cx",e),g("cy",f),g("rx",e),g("ry",f);break;case"line":g("x1",e),g("x2",e),g("y1",f),g("y2",f);break;case"marker":g("refX",e),g("markerWidth",e),g("refY",f),g("markerHeight",f);break;case"radialGradient":g("fx",e),g("fy",f);break;case"tspan":g("dx",e),g("dy",f);break;default:i=null}return i}function n(a){if(a.savage in U)return U[a.savage];var b,c=this.id=S();try{b=a.ownerSVGElement}catch(d){}this.node=a,b&&(this.paper=new r(b)),this.type=a.tagName,this.anims={},this._={transform:[],sx:1,sy:1,deg:0,dx:0,dy:0,dirty:1},a.savage=c,U[c]=this}function o(a){for(var b,c=0,d=a.length;d>c;c++)if(b=b||a[c])return b}function p(a){this.node=a}function q(a,c){var d=b(a);c.appendChild(d);var e=s(d);return e.type=a,e}function r(a,c){var d,e,f,g=r.prototype;if(a&&"svg"==a.tagName){if(a.savage in U)return U[a.savage];d=new n(a),e=a.getElementsByTagName("desc")[0],f=a.getElementsByTagName("defs")[0]}else d=q("svg",t.doc.body),b(d.node,{height:c,version:1.1,width:a,xmlns:"http://www.w3.org/2000/svg"});e||(e=b("desc"),e.appendChild(t.doc.createTextNode("Created with Savage")),d.node.appendChild(e)),f||(f=b("defs"),d.node.appendChild(f));for(var h in g)g[u](h)&&(d[h]=g[h]);return d.paper=d.root=d,d.defs=f,d}function s(a){return a?a instanceof n||a instanceof p?a:"svg"==a.tagName?new r(a):new n(a):a}a.version="0.0.1",a.toString=function(){return"Savage v"+this.version},a._={};var t={win:window,doc:window.document},u="hasOwnProperty",v=String,w=parseFloat,x=parseInt,y=Math,z=y.max,A=y.min,B=y.abs,C=(y.pow,y.PI),D=(y.round,""),E=" ",F=Object.prototype.toString,G=/^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+%?)?)\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i,H={NaN:1,Infinity:1,"-Infinity":1},I=/^url\(#?([^)]+)\)$/,J=" \n\f\r \u2028\u2029",K=new RegExp("[,"+J+"]+"),L=(new RegExp("["+J+"]","g"),new RegExp("["+J+"]*,["+J+"]*")),M={hs:1,rg:1},N=new RegExp("([a-z])["+J+",]*((-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?["+J+"]*,?["+J+"]*)+)","ig"),O=new RegExp("([rstm])["+J+",]*((-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?["+J+"]*,?["+J+"]*)+)","ig"),P=new RegExp("(-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?)["+J+"]*,?["+J+"]*","ig"),Q=0,R="S"+(+new Date).toString(36),S=function(){return R+(Q++).toString(36)},T="http://www.w3.org/1999/xlink",U={};a._.$=b,a._.id=S,a.format=function(){var a=/\{([^\}]+)\}/g,b=/(?:(?:^|\.)(.+?)(?=\[|\.|$|\()|\[('|")(.+?)\2\])(\(\))?/g,c=function(a,c,d){var e=d;return c.replace(b,function(a,b,c,d,f){b=b||d,e&&(b in e&&(e=e[b]),"function"==typeof e&&f&&(e=e()))}),e=(null==e||e==d?a:e)+""};return function(b,d){return v(b).replace(a,function(a,b){return c(a,b,d)})}}();var V=function(){function a(){this.parentNode.removeChild(this)}return function(b,c){var d=t.doc.createElement("img"),e=t.doc.body;d.style.cssText="position:absolute;left:-9999em;top:-9999em",d.onload=function(){c.call(d),d.onload=d.onerror=null,e.removeChild(d)},d.onerror=a,e.appendChild(d),d.src=b}}();a._.clone=d,a._.cacher=f,a.rad=g,a.deg=h,a.is=c,a.snapTo=function(a,b,d){if(d=c(d,"finite")?d:10,c(a,"array")){for(var e=a.length;e--;)if(B(a[e]-b)<=d)return a[e]}else{a=+a;var f=b%a;if(d>f)return b-f;if(f>a-d)return b-f+a}return b},function(a){function b(a){return a[0]*a[0]+a[1]*a[1]}function c(a){var c=y.sqrt(b(a));a[0]&&(a[0]/=c),a[1]&&(a[1]/=c)}a.add=function(a,b,c,d,e,f){var g,h,i,k,l=[[],[],[]],m=[[this.a,this.c,this.e],[this.b,this.d,this.f],[0,0,1]],n=[[a,c,e],[b,d,f],[0,0,1]];for(a&&a instanceof j&&(n=[[a.a,a.c,a.e],[a.b,a.d,a.f],[0,0,1]]),g=0;3>g;g++)for(h=0;3>h;h++){for(k=0,i=0;3>i;i++)k+=m[g][i]*n[i][h];l[g][h]=k}return this.a=l[0][0],this.b=l[1][0],this.c=l[0][1],this.d=l[1][1],this.e=l[0][2],this.f=l[1][2],this},a.invert=function(){var a=this,b=a.a*a.d-a.b*a.c;return new j(a.d/b,-a.b/b,-a.c/b,a.a/b,(a.c*a.f-a.d*a.e)/b,(a.b*a.e-a.a*a.f)/b)},a.clone=function(){return new j(this.a,this.b,this.c,this.d,this.e,this.f)},a.translate=function(a,b){return this.add(1,0,0,1,a,b)},a.scale=function(a,b,c,d){return null==b&&(b=a),(c||d)&&this.add(1,0,0,1,c,d),this.add(a,0,0,b,0,0),(c||d)&&this.add(1,0,0,1,-c,-d),this},a.rotate=function(a,b,c){a=g(a),b=b||0,c=c||0;var d=+y.cos(a).toFixed(9),e=+y.sin(a).toFixed(9);return this.add(d,e,-e,d,b,c),this.add(1,0,0,1,-b,-c)},a.x=function(a,b){return a*this.a+b*this.c+this.e},a.y=function(a,b){return a*this.b+b*this.d+this.f},a.get=function(a){return+this[v.fromCharCode(97+a)].toFixed(4)},a.toString=function(){return"matrix("+[this.get(0),this.get(1),this.get(2),this.get(3),this.get(4),this.get(5)].join()+")"},a.offset=function(){return[this.e.toFixed(4),this.f.toFixed(4)]},a.split=function(){var a={};a.dx=this.e,a.dy=this.f;var d=[[this.a,this.c],[this.b,this.d]];a.scalex=y.sqrt(b(d[0])),c(d[0]),a.shear=d[0][0]*d[1][0]+d[0][1]*d[1][1],d[1]=[d[1][0]-d[0][0]*a.shear,d[1][1]-d[0][1]*a.shear],a.scaley=y.sqrt(b(d[1])),c(d[1]),a.shear/=a.scaley;var e=-d[0][1],f=d[1][1];return 0>f?(a.rotate=h(y.acos(f)),0>e&&(a.rotate=360-a.rotate)):a.rotate=h(y.asin(e)),a.isSimple=!(+a.shear.toFixed(9)||a.scalex.toFixed(9)!=a.scaley.toFixed(9)&&a.rotate),a.isSuperSimple=!+a.shear.toFixed(9)&&a.scalex.toFixed(9)==a.scaley.toFixed(9)&&!a.rotate,a.noRotation=!+a.shear.toFixed(9)&&!a.rotate,a},a.toTransformString=function(a){var b=a||this.split();return b.isSimple?(b.scalex=+b.scalex.toFixed(4),b.scaley=+b.scaley.toFixed(4),b.rotate=+b.rotate.toFixed(4),(b.dx||b.dy?"t"+[+b.dx.toFixed(4),+b.dy.toFixed(4)]:D)+(1!=b.scalex||1!=b.scaley?"s"+[b.scalex,b.scaley,0,0]:D)+(b.rotate?"r"+[+b.rotate.toFixed(4),0,0]:D)):"m"+[this.get(0),this.get(1),this.get(2),this.get(3),this.get(4),this.get(5)]}}(j.prototype),a.Matrix=j,a.getRGB=f(function(b){if(!b||(b=v(b)).indexOf("-")+1)return{r:-1,g:-1,b:-1,hex:"none",error:1,toString:Z};if("none"==b)return{r:-1,g:-1,b:-1,hex:"none",toString:Z};!(M[u](b.toLowerCase().substring(0,2))||"#"==b.charAt())&&(b=W(b));var d,e,f,g,h,i,j=b.match(G);return j?(j[2]&&(f=x(j[2].substring(5),16),e=x(j[2].substring(3,5),16),d=x(j[2].substring(1,3),16)),j[3]&&(f=x((h=j[3].charAt(3))+h,16),e=x((h=j[3].charAt(2))+h,16),d=x((h=j[3].charAt(1))+h,16)),j[4]&&(i=j[4].split(L),d=w(i[0]),"%"==i[0].slice(-1)&&(d*=2.55),e=w(i[1]),"%"==i[1].slice(-1)&&(e*=2.55),f=w(i[2]),"%"==i[2].slice(-1)&&(f*=2.55),"rgba"==j[1].toLowerCase().slice(0,4)&&(g=w(i[3])),i[3]&&"%"==i[3].slice(-1)&&(g/=100)),j[5]?(i=j[5].split(L),d=w(i[0]),"%"==i[0].slice(-1)&&(d*=2.55),e=w(i[1]),"%"==i[1].slice(-1)&&(e*=2.55),f=w(i[2]),"%"==i[2].slice(-1)&&(f*=2.55),("deg"==i[0].slice(-3)||"°"==i[0].slice(-1))&&(d/=360),"hsba"==j[1].toLowerCase().slice(0,4)&&(g=w(i[3])),i[3]&&"%"==i[3].slice(-1)&&(g/=100),a.hsb2rgb(d,e,f,g)):j[6]?(i=j[6].split(L),d=w(i[0]),"%"==i[0].slice(-1)&&(d*=2.55),e=w(i[1]),"%"==i[1].slice(-1)&&(e*=2.55),f=w(i[2]),"%"==i[2].slice(-1)&&(f*=2.55),("deg"==i[0].slice(-3)||"°"==i[0].slice(-1))&&(d/=360),"hsla"==j[1].toLowerCase().slice(0,4)&&(g=w(i[3])),i[3]&&"%"==i[3].slice(-1)&&(g/=100),a.hsl2rgb(d,e,f,g)):(j={r:d,g:e,b:f,toString:Z},j.hex="#"+(16777216|f|e<<8|d<<16).toString(16).slice(1),j.opacity=c(g,"finite")?g:1,j)):{r:-1,g:-1,b:-1,hex:"none",error:1,toString:Z}},a),a.hsb=f(function(b,c,d){return a.hsb2rgb(b,c,d).hex}),a.hsl=f(function(b,c,d){return a.hsl2rgb(b,c,d).hex}),a.rgb=f(function(a,b,d,e){if(c(e,"finite")){var f=y.round;return"rgba("+[f(a),f(b),f(d),+e.toFixed(2)]+")"}return"#"+(16777216|d|b<<8|a<<16).toString(16).slice(1)});var W=function(a){var b=t.doc.getElementsByTagName("head")[0];return W=f(function(a){b.style.color="inherit",b.style.color=a;var c=t.doc.defaultView.getComputedStyle(b,D).getPropertyValue("color");return"inherit"==c?null:c}),W(a)},X=function(){return"hsb("+[this.h,this.s,this.b]+")"},Y=function(){return"hsl("+[this.h,this.s,this.l]+")"},Z=function(){return 1==this.opacity||null==this.opacity?this.hex:"rgba("+[this.r,this.g,this.b,this.opacity]+")"},$=function(b,d,e){if(null==d&&c(b,"object")&&"r"in b&&"g"in b&&"b"in b&&(e=b.b,d=b.g,b=b.r),null==d&&c(b,string)){var f=a.getRGB(b);b=f.r,d=f.g,e=f.b}return(b>1||d>1||e>1)&&(b/=255,d/=255,e/=255),[b,d,e]},_=function(b,d,e,f){b=y.round(255*b),d=y.round(255*d),e=y.round(255*e);var g={r:b,g:d,b:e,opacity:c(f,"finite")?f:1,hex:a.rgb(b,d,e),toString:Z};return c(f,"finite")&&(g.opacity=f),g};a.color=function(b){var d;return c(b,"object")&&"h"in b&&"s"in b&&"b"in b?(d=a.hsb2rgb(b),b.r=d.r,b.g=d.g,b.b=d.b,b.opacity=1,b.hex=d.hex):c(b,"object")&&"h"in b&&"s"in b&&"l"in b?(d=a.hsl2rgb(b),b.r=d.r,b.g=d.g,b.b=d.b,b.opacity=1,b.hex=d.hex):(c(b,"string")&&(b=a.getRGB(b)),c(b,"object")&&"r"in b&&"g"in b&&"b"in b?(d=a.rgb2hsl(b),b.h=d.h,b.s=d.s,b.l=d.l,d=a.rgb2hsb(b),b.v=d.b):(b={hex:"none"},b.r=b.g=b.b=b.h=b.s=b.v=b.l=-1)),b.toString=Z,b},a.hsb2rgb=function(a,b,d,e){c(a,"object")&&"h"in a&&"s"in a&&"b"in a&&(d=a.b,b=a.s,a=a.h,e=a.o),a*=360;var f,g,h,i,j;return a=a%360/60,j=d*b,i=j*(1-B(a%2-1)),f=g=h=d-j,a=~~a,f+=[j,i,0,0,i,j][a],g+=[i,j,j,i,0,0][a],h+=[0,0,i,j,j,i][a],_(f,g,h,e)},a.hsl2rgb=function(a,b,d,e){c(a,"object")&&"h"in a&&"s"in a&&"l"in a&&(d=a.l,b=a.s,a=a.h),(a>1||b>1||d>1)&&(a/=360,b/=100,d/=100),a*=360;var f,g,h,i,j;return a=a%360/60,j=2*b*(.5>d?d:1-d),i=j*(1-B(a%2-1)),f=g=h=d-j/2,a=~~a,f+=[j,i,0,0,i,j][a],g+=[i,j,j,i,0,0][a],h+=[0,0,i,j,j,i][a],_(f,g,h,e)},a.rgb2hsb=function(a,b,c){c=$(a,b,c),a=c[0],b=c[1],c=c[2];var d,e,f,g;return f=z(a,b,c),g=f-A(a,b,c),d=0==g?null:f==a?(b-c)/g:f==b?(c-a)/g+2:(a-b)/g+4,d=60*((d+360)%6)/360,e=0==g?0:g/f,{h:d,s:e,b:f,toString:X}},a.rgb2hsl=function(a,b,c){c=$(a,b,c),a=c[0],b=c[1],c=c[2];var d,e,f,g,h,i;return g=z(a,b,c),h=A(a,b,c),i=g-h,d=0==i?null:g==a?(b-c)/i:g==b?(c-a)/i+2:(a-b)/i+4,d=60*((d+360)%6)/360,f=(g+h)/2,e=0==i?0:.5>f?i/(2*f):i/(2-2*f),{h:d,s:e,l:f,toString:Y}},a.parsePathString=function(b){if(!b)return null;var d=a.path(b);if(d.arr)return a.path.clone(d.arr);var e={a:7,c:6,o:2,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,u:3,z:0},f=[];return c(b,"array")&&c(b[0],"array")&&(f=a.path.clone(b)),f.length||v(b).replace(N,function(a,b,c){var d=[],g=b.toLowerCase();if(c.replace(P,function(a,b){b&&d.push(+b)}),"m"==g&&d.length>2&&(f.push([b].concat(d.splice(0,2))),g="l",b="m"==b?"l":"L"),"o"==g&&1==d.length&&f.push([b,d[0]]),"r"==g)f.push([b].concat(d));else for(;d.length>=e[g]&&(f.push([b].concat(d.splice(0,e[g]))),e[g]););}),f.toString=a.path.toString,d.arr=a.path.clone(f),f};var ab=a.parseTransformString=function(b){if(!b)return null;var d=[];return c(b,"array")&&c(b[0],"array")&&(d=a.path.clone(b)),d.length||v(b).replace(O,function(a,b,c){var e=[];b.toLowerCase(),c.replace(P,function(a,b){b&&e.push(+b)}),d.push([b].concat(e))}),d.toString=a.path.toString,d},bb=new RegExp("^[a-z]["+J+"]*-?\\.?\\d");a.select=function(a){return s(t.doc.querySelector(a))},a.selectAll=function(b){for(var c=t.doc.querySelectorAll(b),d=(a.set||Array)(),e=0;eb;b++)a[b].stop();return this},d.animate=function(a,b,d,f){"function"==typeof d&&(f=d,d=mina.linear),a instanceof g&&(f=a.callback,d=a.easing,b=d.dur,a=a.attr);var h,i,j,k,l=[],m=[],n={},o=this;for(var p in a)if(a[u](p)){o.equal?(k=o.equal(p,v(a[p])),h=k.from,i=k.to,j=k.f):(h=+o.attr(p),i=+a[p]);var q=c(h,"array")?h.length:1;n[p]=e(l.length,l.length+q,j),l=l.concat(h),m=m.concat(i)}var r=mina.time(),s=mina(l,m,r,r+b,mina.time,function(a){var b={};for(var c in n)n[u](c)&&(b[c]=n[c](a));o.attr(b)},d);return o.anims[s.id]=s,s._attrs=a,s._callback=f,eve.once("mina.finish."+s.id,function(){delete o.anims[s.id],f&&f.call(o)}),eve.once("mina.stop."+s.id,function(){delete o.anims[s.id]}),o}}(n.prototype),a.parse=function(a){var c=document.createDocumentFragment(),d=c;return eve.on("elemental.tag",function(a,c){var e=b(a);c&&b(e,c),d.appendChild(e),d=e}),eve.on("elemental.text",function(a){d.appendChild(document.createTextNode(a))}),eve.on("elemental./tag",function(){d=d.parentNode}),eve.on("elemental.eof",function(){eve.off("elemental.*"),eve("savage.parsed",c)}),elemental().parse(a).end(),new p(c)},p.prototype.select=n.prototype.select,p.prototype.selectAll=n.prototype.selectAll,a.fragment=function(){for(var b=Array.prototype.slice.call(arguments,0),c=document.createDocumentFragment(),d=0,e=b.length;e>d;d++){var f=b[d];f.node&&f.node.nodeType&&c.appendChild(f.node),f.nodeType&&c.appendChild(f),"string"==typeof f&&c.appendChild(a.parse(f).node)}return new p(c)},function(d){function e(a){c(a,"array")||(a=Array.prototype.slice.call(arguments,0));for(var b=0,d=0,e=this.node;this[b];)delete this[b++];for(b=0;b1&&(a=Array.prototype.slice.call(arguments,0));var b=q("polyline",this.node);return c(a,"object")&&!c(a,"array")?b.attr(a):null!=a&&b.attr({points:a}),b},d.polygon=function(a){arguments.length>1&&(a=Array.prototype.slice.call(arguments,0));var b=q("polygon",this.node);return c(a,"object")&&!c(a,"array")?b.attr(a):null!=a&&b.attr({points:a}),b},function(){function c(){return this.selectAll("stop")}function e(a,c){var d=b("stop");return b(d,{"stop-color":a,offset:+c+"%"}),this.node.appendChild(d),this}function f(){if("linearGradient"==this.type){var c=b(this.node,"x1")||0,d=b(this.node,"x2")||1,e=b(this.node,"y1")||0,f=b(this.node,"y2")||0;return a._.box(c,e,y.abs(d-c),y.abs(f-e))}var g=this.node.cx||.5,h=this.node.cy||.5,i=this.node.r||0;return a._.box(g-i,h-i,2*i,2*i)}d.gradient=function(a){function c(a,b){for(var c=(b-h)/(a-i),d=i;a>d;d++)f[d].offset=+(+h+c*(d-i)).toFixed(2);
+i=a,h=b}var d,e=o(eve("savage.util.grad.parse",null,a));d="l"==e.type.toLowerCase()?this.gradientLinear.apply(this,e.params):this.gradientRadial.apply(this,e.params),e.type!=e.type.toLowerCase()&&b(d.node,{gradientUnits:"userSpaceOnUse"});var f=e.stops,g=f.length,h=0,i=0;g--;for(var j=0;g>j;j++)"offset"in f[j]&&c(j,f[j].offset);for(f[g].offset=f[g].offset||100,c(g,f[g].offset),j=0;g>=j;j++){var k=f[j];d.addStop(k.color,k.offset)}return d},d.gradientLinear=function(a,d,g,h){var i=q("linearGradient",this.node);return i.stops=c,i.addStop=e,i.getBBox=f,null!=a&&b(i.node,{x1:a,y1:d,x2:g,y2:h}),i},d.gradientRadial=function(a,d,g,h,i){var j=q("radialGradient",this.node);return j.stops=c,j.addStop=e,j.getBBox=f,null!=a&&b(j.node,{cx:a,cy:d,r:g}),null!=h&&null!=i&&b(j.node,{fx:h,fy:i}),j}}()}(r.prototype),a.ajax=function(a,b,d,e){var f=new XMLHttpRequest,g=S();if(f){if(c(b,"function"))e=d,d=b,b=null;else if(c(b,"object")){var h=[];for(var i in b)b.hasOwnProperty(i)&&h.push(encodeURIComponent(i)+"="+encodeURIComponent(b[i]));b=h.join("&")}return f.open(b?"POST":"GET",a,!0),f.setRequestHeader("X-Requested-With","XMLHttpRequest"),b&&f.setRequestHeader("Content-type","application/x-www-form-urlencoded"),d&&(eve.once("savage.ajax."+g+".0",d),eve.once("savage.ajax."+g+".200",d),eve.once("savage.ajax."+g+".304",d)),f.onreadystatechange=function(){4==f.readyState&&eve("savage.ajax."+g+"."+f.status,e,f)},4==f.readyState?f:(f.send(b),f)}},eve.on("savage.util.attr.mask",function(a){if(a instanceof n||a instanceof p){if(eve.stop(),a instanceof p&&1==a.node.childNodes.length&&(a=a.node.firstChild,this.paper.defs.appendChild(a),a=s(a)),"mask"==a.type)var c=a;else c=q("mask",this.paper.defs),c.node.appendChild(a.node),!c.node.id&&b(c.node,{id:c.id});b(this.node,{mask:"url(#"+c.id+")"})}}),function(a){eve.on("savage.util.attr.clip",a),eve.on("savage.util.attr.clip-path",a),eve.on("savage.util.attr.clipPath",a)}(function(a){if(a instanceof n||a instanceof p){if(eve.stop(),"clipPath"==a.type)var c=a;else c=q("clipPath",this.paper.defs),c.node.appendChild(a.node),!c.node.id&&b(c.node,{id:c.id});b(this.node,{"clip-path":"url(#"+c.id+")"})}}),eve.on("savage.util.attr.fill",function(c){if(eve.stop(),c instanceof p&&1==c.node.childNodes.length&&("radialGradient"==c.node.firstChild.tagName||"linearGradient"==c.node.firstChild.tagName||"pattern"==c.node.firstChild.tagName)&&(c=c.node.firstChild,this.paper.defs.appendChild(c),c=s(c)),c instanceof n&&("radialGradient"==c.type||"linearGradient"==c.type||"pattern"==c.type)){c.node.id||b(c.node,{id:c.id});var d="url(#"+c.node.id+")"}else if(d=a.color(c),d.error){var e=this.paper.gradient(c);e.node.id||b(e.node,{id:e.id}),d="url(#"+e.node.id+")"}else d=v(d);b(this.node,{fill:d}),this.node.style.fill=D});var cb=/^([lr])(?:\(([^)]*)\))?(.*)$/i;eve.on("savage.util.grad.parse",function(a){a=v(a);var b=a.match(cb),c=b[1],d=b[2],e=b[3];return d=d.split(/\s*,\s*/).map(function(a){return+a==a?+a:a}),1==d.length&&0==d[0]&&(d=[]),e=e.split("-"),e=e.map(function(a){a=a.split(":");var b={color:a[0]};return a[1]&&(b.offset=a[1]),b}),{type:c,params:d,stops:e}}),eve.on("savage.util.attr.d",function(d){eve.stop(),c(d,"array")&&c(d[0],"array")&&(d=a.path.toString.call(d)),d=v(d),d.match(/[ruo]/i)&&(d=a.path.toAbsolute(d)),b(this.node,{d:d})})(-1),eve.on("savage.util.attr.path",function(a){eve.stop(),this.attr({d:a})})(-1),eve.on("savage.util.attr.viewBox",function(a){var d;d=c(a,"object")&&"x"in a?[a.x,a.y,a.width,a.height].join(" "):c(a,"array")?a.join(" "):a,b(this.node,{viewBox:d}),eve.stop()})(-1),eve.on("savage.util.attr.transform",function(a){this.transform(a),eve.stop()})(-1),eve.on("savage.util.attr.r",function(a){"rect"==this.type&&(eve.stop(),b(this.node,{rx:a,ry:a}))})(-1),eve.on("savage.util.attr.text",function(a){if("text"==this.type){for(var d=this.node,e=function(a){var d=b("tspan");if(c(a,"array"))for(var f=0;fq;q++){if(k=d[q],"M"==k[0])h=+k[1],j=+k[2];else{if(l=g(h,j,k[1],k[2],k[3],k[4],k[5],k[6]),p+l>e){if(b&&!o.start){if(m=g(h,j,k[1],k[2],k[3],k[4],k[5],k[6],e-p),n+=["C"+c(m.start.x),c(m.start.y),c(m.m.x),c(m.m.y),c(m.x),c(m.y)],f)return n;o.start=n,n=["M"+c(m.x),c(m.y)+"C"+c(m.n.x),c(m.n.y),c(m.end.x),c(m.end.y),c(k[5]),c(k[6])].join(),p+=l,h=+k[5],j=+k[6];continue}if(!a&&!b)return m=g(h,j,k[1],k[2],k[3],k[4],k[5],k[6],e-p)}p+=l,h=+k[5],j=+k[6]}n+=k.shift()+k}return o.end=n,m=a?p:b?o:i(h,j,k[0],k[1],k[2],k[3],k[4],k[5],1)}}function i(a,b,c,d,e,f,g,h,i){var j=1-i,k=S(j,3),l=S(j,2),m=i*i,n=m*i,o=k*a+3*l*i*c+3*j*i*i*e+n*g,p=k*b+3*l*i*d+3*j*i*i*f+n*h,q=a+2*i*(c-a)+m*(e-2*c+a),r=b+2*i*(d-b)+m*(f-2*d+b),s=c+2*i*(e-c)+m*(g-2*e+c),t=d+2*i*(f-d)+m*(h-2*f+d),u=j*a+i*c,v=j*b+i*d,w=j*e+i*g,x=j*f+i*h,y=90-180*O.atan2(q-s,r-t)/P;return{x:o,y:p,m:{x:q,y:r},n:{x:s,y:t},start:{x:u,y:v},end:{x:w,y:x},alpha:y}}function j(b,c,e,f,g,h,i,j){a.is(b,"array")||(b=[b,c,e,f,g,h,i,j]);var k=E.apply(null,b);return d(k.min.x,k.min.y,k.max.x-k.min.x,k.max.y-k.min.y)}function k(a,b,c){return b>=a.x&&b<=a.x+a.width&&c>=a.y&&c<=a.y+a.height}function l(a,b){return a=d(a),b=d(b),k(b,a.x,a.y)||k(b,a.x2,a.y)||k(b,a.x,a.y2)||k(b,a.x2,a.y2)||k(a,b.x,b.y)||k(a,b.x2,b.y)||k(a,b.x,b.y2)||k(a,b.x2,b.y2)||(a.xb.x||b.xa.x)&&(a.yb.y||b.ya.y)}function m(a,b,c,d,e){var f=-3*b+9*c-9*d+3*e,g=a*f+6*b-12*c+6*d;return a*g-3*b+3*c}function n(a,b,c,d,e,f,g,h,i){null==i&&(i=1),i=i>1?1:0>i?0:i;for(var j=i/2,k=12,l=[-.1252,.1252,-.3678,.3678,-.5873,.5873,-.7699,.7699,-.9041,.9041,-.9816,.9816],n=[.2491,.2491,.2335,.2335,.2032,.2032,.1601,.1601,.1069,.1069,.0472,.0472],o=0,p=0;k>p;p++){var q=j*l[p]+j,r=m(q,a,c,e,g),s=m(q,b,d,f,h),t=r*r+s*s;o+=n[p]*O.sqrt(t)}return j*o}function o(a,b,c,d,e,f,g,h,i){if(!(0>i||n(a,b,c,d,e,f,g,h)o;)l/=2,m+=(i>j?1:-1)*l,j=n(a,b,c,d,e,f,g,h,m);return m}}function p(a,b,c,d,e,f,g,h){if(!(R(a,c)R(e,g)||R(b,d)R(f,h))){var i=(a*d-b*c)*(e-g)-(a-c)*(e*h-f*g),j=(a*d-b*c)*(f-h)-(b-d)*(e*h-f*g),k=(a-c)*(f-h)-(b-d)*(e-g);if(k){var l=i/k,m=j/k,n=+l.toFixed(2),o=+m.toFixed(2);if(!(n<+Q(a,c).toFixed(2)||n>+R(a,c).toFixed(2)||n<+Q(e,g).toFixed(2)||n>+R(e,g).toFixed(2)||o<+Q(b,d).toFixed(2)||o>+R(b,d).toFixed(2)||o<+Q(f,h).toFixed(2)||o>+R(f,h).toFixed(2)))return{x:l,y:m}}}}function q(a,b,c){var d=j(a),e=j(b);if(!l(d,e))return c?0:[];for(var f=n.apply(0,a),g=n.apply(0,b),h=~~(f/5),k=~~(g/5),m=[],o=[],q={},r=c?0:[],s=0;h+1>s;s++){var t=i.apply(0,a.concat(s/h));m.push({x:t.x,y:t.y,t:s/h})}for(s=0;k+1>s;s++)t=i.apply(0,b.concat(s/k)),o.push({x:t.x,y:t.y,t:s/k});for(s=0;h>s;s++)for(var u=0;k>u;u++){var v=m[s],w=m[s+1],x=o[u],y=o[u+1],z=T(w.x-v.x)<.001?"y":"x",A=T(y.x-x.x)<.001?"y":"x",B=p(v.x,v.y,w.x,w.y,x.x,x.y,y.x,y.y);if(B){if(q[B.x.toFixed(4)]==B.y.toFixed(4))continue;q[B.x.toFixed(4)]=B.y.toFixed(4);var C=v.t+T((B[z]-v[z])/(w[z]-v[z]))*(w.t-v.t),D=x.t+T((B[A]-x[A])/(y[A]-x[A]))*(y.t-x.t);C>=0&&1>=C&&D>=0&&1>=D&&(c?r++:r.push({x:B.x,y:B.y,t1:C,t2:D}))}}return r}function r(a,b){return t(a,b)}function s(a,b){return t(a,b,1)}function t(a,b,c){a=F(a),b=F(b);for(var d,e,f,g,h,i,j,k,l,m,n=c?0:[],o=0,p=a.length;p>o;o++){var r=a[o];if("M"==r[0])d=h=r[1],e=i=r[2];else{"C"==r[0]?(l=[d,e].concat(r.slice(1)),d=l[6],e=l[7]):(l=[d,e,d,e,h,i,h,i],d=h,e=i);for(var s=0,t=b.length;t>s;s++){var u=b[s];if("M"==u[0])f=j=u[1],g=k=u[2];else{"C"==u[0]?(m=[f,g].concat(u.slice(1)),f=m[6],g=m[7]):(m=[f,g,f,g,j,k,j,k],f=j,g=k);var v=q(l,m,c);if(c)n+=v;else{for(var w=0,x=v.length;x>w;w++)v[w].segment1=o,v[w].segment2=s,v[w].bez1=l,v[w].bez2=m;n=n.concat(v)}}}}}return n}function u(a,b,c){var d=v(a);return k(d,b,c)&&1==t(a,[["M",b,c],["H",d.x2+10]],1)%2}function v(a){var b=c(a);if(b.bbox)return K(b.bbox);if(!a)return d();a=F(a);for(var e,f=0,g=0,h=[],i=[],j=0,k=a.length;k>j;j++)if(e=a[j],"M"==e[0])f=e[1],g=e[2],h.push(f),i.push(g);else{var l=E(f,g,e[1],e[2],e[3],e[4],e[5],e[6]);h=h.concat(l.min.x,l.max.x),i=i.concat(l.min.y,l.max.y),f=e[5],g=e[6]}var m=Q.apply(0,h),n=Q.apply(0,i),o=R.apply(0,h),p=R.apply(0,i),q=d(m,n,o-m,p-n);return b.bbox=K(q),q}function w(a,b,c,d,f){if(f)return[["M",a+f,b],["l",c-2*f,0],["a",f,f,0,0,1,f,f],["l",0,d-2*f],["a",f,f,0,0,1,-f,f],["l",2*f-c,0],["a",f,f,0,0,1,-f,-f],["l",0,2*f-d],["a",f,f,0,0,1,f,-f],["z"]];var g=[["M",a,b],["l",c,0],["l",0,d],["l",-c,0],["z"]];return g.toString=e,g}function x(a,b,c,d,f){if(null==f&&null==d&&(d=c),null!=f)var g=Math.PI/180,h=a+c*Math.cos(-d*g),i=a+c*Math.cos(-f*g),j=b+c*Math.sin(-d*g),k=b+c*Math.sin(-f*g),l=[["M",h,j],["A",c,c,0,+(f-d>180),0,i,k]];else l=[["M",a,b],["m",0,-d],["a",c,d,0,1,1,0,2*d],["a",c,d,0,1,1,0,-2*d],["z"]];return l.toString=e,l}function y(b){var d=c(b);if(d.rel)return f(d.rel);a.is(b,"array")&&a.is(b&&b[0],"array")||(b=a.parsePathString(b));var g=[],h=0,i=0,j=0,k=0,l=0;"M"==b[0][0]&&(h=b[0][1],i=b[0][2],j=h,k=i,l++,g.push(["M",h,i]));for(var m=l,n=b.length;n>m;m++){var o=g[m]=[],p=b[m];if(p[0]!=lowerCase.call(p[0]))switch(o[0]=lowerCase.call(p[0]),o[0]){case"a":o[1]=p[1],o[2]=p[2],o[3]=p[3],o[4]=p[4],o[5]=p[5],o[6]=+(p[6]-h).toFixed(3),o[7]=+(p[7]-i).toFixed(3);break;case"v":o[1]=+(p[1]-i).toFixed(3);break;case"m":j=p[1],k=p[2];default:for(var q=1,r=p.length;r>q;q++)o[q]=+(p[q]-(q%2?h:i)).toFixed(3)}else{o=g[m]=[],"m"==p[0]&&(j=p[1]+h,k=p[2]+i);for(var s=0,t=p.length;t>s;s++)g[m][s]=p[s]}var u=g[m].length;switch(g[m][0]){case"z":h=j,i=k;break;case"h":h+=+g[m][u-1];break;case"v":i+=+g[m][u-1];break;default:h+=+g[m][u-2],i+=+g[m][u-1]}}return g.toString=e,d.rel=f(g),g}function z(b){var d=c(b);if(d.abs)return f(d.abs);if(J(b,"array")&&J(b&&b[0],"array")||(b=a.parsePathString(b)),!b||!b.length)return[["M",0,0]];var g,h=[],i=0,j=0,k=0,l=0,m=0;"M"==b[0][0]&&(i=+b[0][1],j=+b[0][2],k=i,l=j,m++,h[0]=["M",i,j]);for(var n,o,p=3==b.length&&"M"==b[0][0]&&"R"==b[1][0].toUpperCase()&&"Z"==b[2][0].toUpperCase(),q=m,r=b.length;r>q;q++){if(h.push(n=[]),o=b[q],g=o[0],g!=g.toUpperCase())switch(n[0]=g.toUpperCase(),n[0]){case"A":n[1]=o[1],n[2]=o[2],n[3]=o[3],n[4]=o[4],n[5]=o[5],n[6]=+(o[6]+i),n[7]=+(o[7]+j);break;case"V":n[1]=+o[1]+j;break;case"H":n[1]=+o[1]+i;break;case"R":for(var s=[i,j].concat(o.slice(1)),t=2,u=s.length;u>t;t++)s[t]=+s[t]+i,s[++t]=+s[t]+j;h.pop(),h=h.concat(H(s,p));break;case"O":h.pop(),s=x(i,j,o[1],o[2]),s.push(s[0]),h=h.concat(s);break;case"U":h.pop(),h=h.concat(x(i,j,o[1],o[2],o[3])),n=["U"].concat(h[h.length-1].slice(-2));break;case"M":k=+o[1]+i,l=+o[2]+j;default:for(t=1,u=o.length;u>t;t++)n[t]=+o[t]+(t%2?i:j)}else if("R"==g)s=[i,j].concat(o.slice(1)),h.pop(),h=h.concat(H(s,p)),n=["R"].concat(o.slice(-2));else if("O"==g)h.pop(),s=x(i,j,o[1],o[2]),s.push(s[0]),h=h.concat(s);else if("U"==g)h.pop(),h=h.concat(x(i,j,o[1],o[2],o[3])),n=["U"].concat(h[h.length-1].slice(-2));else for(var v=0,w=o.length;w>v;v++)n[v]=o[v];if(g=g.toUpperCase(),"O"!=g)switch(n[0]){case"Z":i=k,j=l;break;case"H":i=n[1];break;case"V":j=n[1];break;case"M":k=n[n.length-2],l=n[n.length-1];default:i=n[n.length-2],j=n[n.length-1]}}return h.toString=e,d.abs=f(h),h}function A(a,b,c,d){return[a,b,c,d,c,d]}function B(a,b,c,d,e,f){var g=1/3,h=2/3;return[g*a+h*c,g*b+h*d,g*e+h*c,g*f+h*d,e,f]}function C(a,b,c,d,e,f,g,h,i,j){var k,l=120*P/180,m=P/180*(+e||0),n=[],o=cacher(function(a,b,c){var d=a*O.cos(c)-b*O.sin(c),e=a*O.sin(c)+b*O.cos(c);return{x:d,y:e}});if(j)x=j[0],y=j[1],v=j[2],w=j[3];else{k=o(a,b,-m),a=k.x,b=k.y,k=o(h,i,-m),h=k.x,i=k.y;var p=(O.cos(P/180*e),O.sin(P/180*e),(a-h)/2),q=(b-i)/2,r=p*p/(c*c)+q*q/(d*d);r>1&&(r=O.sqrt(r),c=r*c,d=r*d);var s=c*c,t=d*d,u=(f==g?-1:1)*O.sqrt(T((s*t-s*q*q-t*p*p)/(s*q*q+t*p*p))),v=u*c*q/d+(a+h)/2,w=u*-d*p/c+(b+i)/2,x=O.asin(((b-w)/d).toFixed(9)),y=O.asin(((i-w)/d).toFixed(9));x=v>a?P-x:x,y=v>h?P-y:y,0>x&&(x=2*P+x),0>y&&(y=2*P+y),g&&x>y&&(x-=2*P),!g&&y>x&&(y-=2*P)}var z=y-x;if(T(z)>l){var A=y,B=h,D=i;y=x+l*(g&&y>x?1:-1),h=v+c*O.cos(y),i=w+d*O.sin(y),n=C(h,i,c,d,e,0,g,B,D,[y,A,v,w])}z=y-x;var E=O.cos(x),F=O.sin(x),G=O.cos(y),H=O.sin(y),I=O.tan(z/4),J=4/3*c*I,K=4/3*d*I,L=[a,b],M=[a+J*F,b-K*E],N=[h+J*H,i-K*G],Q=[h,i];if(M[0]=2*L[0]-M[0],M[1]=2*L[1]-M[1],j)return[M,N,Q].concat(n);n=[M,N,Q].concat(n).join().split(",");for(var R=[],S=0,U=n.length;U>S;S++)R[S]=S%2?o(n[S-1],n[S],m).y:o(n[S],n[S+1],m).x;return R}function D(a,b,c,d,e,f,g,h,i){var j=1-i;return{x:S(j,3)*a+3*S(j,2)*i*c+3*j*i*i*e+S(i,3)*g,y:S(j,3)*b+3*S(j,2)*i*d+3*j*i*i*f+S(i,3)*h}}function E(a,b,c,d,e,f,g,h){var i,j=e-2*c+a-(g-2*e+c),k=2*(c-a)-2*(e-c),l=a-c,m=(-k+O.sqrt(k*k-4*j*l))/2/j,n=(-k-O.sqrt(k*k-4*j*l))/2/j,o=[b,h],p=[a,g];return T(m)>"1e12"&&(m=.5),T(n)>"1e12"&&(n=.5),m>0&&1>m&&(i=D(a,b,c,d,e,f,g,h,m),p.push(i.x),o.push(i.y)),n>0&&1>n&&(i=D(a,b,c,d,e,f,g,h,n),p.push(i.x),o.push(i.y)),j=f-2*d+b-(h-2*f+d),k=2*(d-b)-2*(f-d),l=b-d,m=(-k+O.sqrt(k*k-4*j*l))/2/j,n=(-k-O.sqrt(k*k-4*j*l))/2/j,T(m)>"1e12"&&(m=.5),T(n)>"1e12"&&(n=.5),m>0&&1>m&&(i=D(a,b,c,d,e,f,g,h,m),p.push(i.x),o.push(i.y)),n>0&&1>n&&(i=D(a,b,c,d,e,f,g,h,n),p.push(i.x),o.push(i.y)),{min:{x:Q.apply(0,p),y:Q.apply(0,o)},max:{x:R.apply(0,p),y:R.apply(0,o)}}}function F(a,b){var d=!b&&c(a);if(!b&&d.curve)return f(d.curve);for(var e=z(a),g=b&&z(b),h={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},i={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},j=(function(a,b){var c,d;if(!a)return["C",b.x,b.y,b.x,b.y,b.x,b.y];switch(!(a[0]in{T:1,Q:1})&&(b.qx=b.qy=null),a[0]){case"M":b.X=a[1],b.Y=a[2];break;case"A":a=["C"].concat(C.apply(0,[b.x,b.y].concat(a.slice(1))));break;case"S":c=b.x+(b.x-(b.bx||b.x)),d=b.y+(b.y-(b.by||b.y)),a=["C",c,d].concat(a.slice(1));break;case"T":b.qx=b.x+(b.x-(b.qx||b.x)),b.qy=b.y+(b.y-(b.qy||b.y)),a=["C"].concat(B(b.x,b.y,b.qx,b.qy,a[1],a[2]));break;case"Q":b.qx=a[1],b.qy=a[2],a=["C"].concat(B(b.x,b.y,a[1],a[2],a[3],a[4]));break;case"L":a=["C"].concat(A(b.x,b.y,a[1],a[2]));break;case"H":a=["C"].concat(A(b.x,b.y,a[1],b.y));break;case"V":a=["C"].concat(A(b.x,b.y,b.x,a[1]));break;case"Z":a=["C"].concat(A(b.x,b.y,b.X,b.Y))}return a}),k=function(a,b){if(a[b].length>7){a[b].shift();for(var c=a[b];c.length;)a.splice(b++,0,["C"].concat(c.splice(0,6)));a.splice(b,1),n=R(e.length,g&&g.length||0)}},l=function(a,b,c,d,f){a&&b&&"M"==a[f][0]&&"M"!=b[f][0]&&(b.splice(f,0,["M",d.x,d.y]),c.bx=0,c.by=0,c.x=a[f][1],c.y=a[f][2],n=R(e.length,g&&g.length||0))},m=0,n=R(e.length,g&&g.length||0);n>m;m++){e[m]=j(e[m],h),k(e,m),g&&(g[m]=j(g[m],i)),g&&k(g,m),l(e,g,h,i,m),l(g,e,i,h,m);var o=e[m],p=g&&g[m],q=o.length,r=g&&p.length;h.x=o[q-2],h.y=o[q-1],h.bx=N(o[q-4])||h.x,h.by=N(o[q-3])||h.y,i.bx=g&&(N(p[r-4])||i.x),i.by=g&&(N(p[r-3])||i.y),i.x=g&&p[r-2],i.y=g&&p[r-1]}return g||(d.curve=f(e)),g?[e,g]:e}function G(a,b){if(!b)return a;var c,d,e,f,g,h,i;for(a=F(a),e=0,g=a.length;g>e;e++)for(i=a[e],f=1,h=i.length;h>f;f+=2)c=b.x(i[f],i[f+1]),d=b.y(i[f],i[f+1]),i[f]=c,i[f+1]=d;return a}function H(a,b){for(var c=[],d=0,e=a.length;e-2*!b>d;d+=2){var f=[{x:+a[d-2],y:+a[d-1]},{x:+a[d],y:+a[d+1]},{x:+a[d+2],y:+a[d+3]},{x:+a[d+4],y:+a[d+5]}];b?d?e-4==d?f[3]={x:+a[0],y:+a[1]}:e-2==d&&(f[2]={x:+a[0],y:+a[1]},f[3]={x:+a[2],y:+a[3]}):f[0]={x:+a[e-2],y:+a[e-1]}:e-4==d?f[3]=f[2]:d||(f[0]={x:+a[d],y:+a[d+1]}),c.push(["C",(-f[0].x+6*f[1].x+f[2].x)/6,(-f[0].y+6*f[1].y+f[2].y)/6,(f[1].x+6*f[2].x-f[3].x)/6,(f[1].y+6*f[2].y-f[3].y)/6,f[2].x,f[2].y])}return c}var I=b.prototype,J=a.is,K=a._.clone,L="hasOwnProperty",M=/,?([a-z]),?/gi,N=parseFloat,O=Math,P=O.PI,Q=O.min,R=O.max,S=O.pow,T=O.abs,U=h(1),V=h(),W=h(0,1),X={path:function(a){return a.attr("path")},circle:function(a){var b=unit2px(a);return x(b.cx,b.cy,b.r)},ellipse:function(a){var b=unit2px(a);return x(b.cx,b.cy,b.rx,b.ry)},rect:function(a){var b=unit2px(a);return w(b.x,b.y,b.width,b.height,b.rx,b.ry)},image:function(a){var b=unit2px(a);return w(b.x,b.y,b.width,b.height)},text:function(a){var b=a.node.getBBox();return w(b.x,b.y,b.width,b.height)},g:function(a){var b=a.node.getBBox();return w(b.x,b.y,b.width,b.height)},symbol:function(a){var b=a.getBBox();return w(b.x,b.y,b.width,b.height)}};a.path=c,a.path.getTotalLength=U,a.path.getPointAtLength=V,a.path.getSubpath=function(a,b,c){if(this.getTotalLength(a)-c<1e-6)return W(a,b).end;var d=W(a,c,1);return b?W(d,b).end:d},I.getTotalLength=function(){return this.node.getTotalLength?this.node.getTotalLength():void 0},I.getPointAtLength=function(a){return V(this.attr("d"),a)},I.getSubpath=function(a,b){return getSubpath(this.attr("d"),a,b)},a._.box=d,a.path.findDotsAtSegment=i,a.path.bezierBBox=j,a.path.isPointInsideBBox=k,a.path.isBBoxIntersect=l,a.path.intersection=r,a.path.intersectionNumber=s,a.path.isPointInside=u,a.path.getBBox=v,a.path.get=X,a.path.toRelative=y,a.path.toAbsolute=z,a.path.toCubic=F,a.path.map=G,a.path.toString=e,a.path.clone=f}),Savage.plugin(function(a){var b=Math.max,c=Math.min,d=function(a){if(this.items=[],this.length=0,this.type="set",a)for(var b=0,c=a.length;c>b;b++)a[b]&&(this[this.items.length]=this.items[this.items.length]=a[b],this.length++)},e=d.prototype;e.push=function(){for(var a,b,c=0,d=arguments.length;d>c;c++)a=arguments[c],a&&(b=this.items.length,this[b]=this.items[b]=a,this.length++);return this},e.pop=function(){return this.length&&delete this[this.length--],this.items.pop()},e.forEach=function(a,b){for(var c=0,d=this.items.length;d>c;c++)if(a.call(b,this.items[c],c)===!1)return this;return this},e.attr=function(a){for(var b=0,c=this.items.length;c>b;b++)this.items[b].attr(a);return this},e.clear=function(){for(;this.length;)this.pop()},e.splice=function(a,e){a=0>a?b(this.length+a,0):a,e=b(0,c(this.length-a,e));var f,g=[],h=[],i=[];for(f=2;ff;f++)h.push(this[a+f]);for(;ff?i[f]:g[f-j];for(f=this.items.length=this.length-=e-j;this[f];)delete this[f++];return new d(h)},e.exclude=function(a){for(var b=0,c=this.length;c>b;b++)if(this[b]==a)return this.splice(b,1),!0},e.insertAfter=function(a){for(var b=this.items.length;b--;)this.items[b].insertAfter(a);return this},e.getBBox=function(){for(var a=[],d=[],e=[],f=[],g=this.items.length;g--;)if(!this.items[g].removed){var h=this.items[g].getBBox();a.push(h.x),d.push(h.y),e.push(h.x+h.width),f.push(h.y+h.height)}return a=c.apply(0,a),d=c.apply(0,d),e=b.apply(0,e),f=b.apply(0,f),{x:a,y:d,x2:e,y2:f,width:e-a,height:f-d,cx:a+(e-a)/2,cy:d+(f-d)/2}},e.clone=function(a){a=new d;for(var b=0,c=this.items.length;c>b;b++)a.push(this.items[b].clone());return a},e.toString=function(){return"Savage‘s set"},e.type="set",a.set=function(){var a=new d;return arguments.length&&a.push.apply(a,Array.prototype.slice.call(arguments,0)),a}}),Savage.plugin(function(a,b){function c(a){var b=a[0];switch(b.toLowerCase()){case"t":return[b,0,0];case"m":return[b,1,0,0,1,0,0];case"r":return 4==a.length?[b,0,a[2],a[3]]:[b,0];case"s":return 5==a.length?[b,1,1,a[3],a[4]]:3==a.length?[b,1,1]:[b,1]}}function d(b,d){d=l(d).replace(/\.{3}|\u2026/g,b),b=a.parseTransformString(b)||[],d=a.parseTransformString(d)||[];for(var e,f,g,j,k=Math.max(b.length,d.length),m=[],n=[],o=0;k>o;o++){if(g=b[o]||c(d[o]),j=d[o]||c(g),g[0]!=j[0]||"r"==g[0].toLowerCase()&&(g[2]!=j[2]||g[3]!=j[3])||"s"==g[0].toLowerCase()&&(g[3]!=j[3]||g[4]!=j[4]))return;for(m[o]=[],n[o]=[],e=0,f=Math.max(g.length,j.length);f>e;e++)e in g&&(m[o][e]=g[e]),e in j&&(n[o][e]=j[e])}return{from:i(m),to:i(n),f:h(m)}}function e(a){return a}function f(a){return function(b){return+b.toFixed(3)+a}}function g(b){return a.rgb(b[0],b[1],b[2])}function h(a){var b,c,d,e,f,g,h=0,i=[];for(b=0,c=a.length;c>b;b++){for(f="[",g=['"'+a[b][0]+'"'],d=1,e=a[b].length;e>d;d++)g[d]="val["+h++ +"]";f+=g+"]",i[b]=f}return Function("val","return Savage.path.toString.call(["+i+"])")}function i(a){for(var b=[],c=0,d=a.length;d>c;c++)for(var e=1,f=a[c].length;f>e;e++)b.push(a[c][e]);return b}var j={},k=/[a-z]+$/i,l=String;j.stroke=j.fill="colour",b.prototype.equal=function(b,c){var m,n,o=l(this.attr(b)||"");if(o==+o&&c==+c)return{from:+o,to:+c,f:e};if("colour"==j[b])return m=a.color(o),n=a.color(c),{from:[m.r,m.g,m.b,m.opacity],to:[n.r,n.g,n.b,n.opacity],f:g};if("transform"==b||"gradientTransform"==b||"patternTransform"==b)return d(o.local,c);if("d"==b||"path"==b)return m=a.path.toCubic(o,c),{from:i(m[0]),to:i(m[1]),f:h(m[0])};var p=o.match(k),q=c.match(k);return p&&p==q?{from:parseFloat(o),to:parseFloat(c),f:f(p)}:{from:this.asPX(b),to:this.asPX(b,c),f:e}}}),Savage.plugin(function(a,b,c,d){for(var e=b.prototype,f="hasOwnProperty",g=("createTouch"in d.doc),h=["click","dblclick","mousedown","mousemove","mouseout","mouseover","mouseup","touchstart","touchmove","touchend","touchcancel"],i={mousedown:"touchstart",mousemove:"touchmove",mouseup:"touchend"},j=function(a){var b="y"==a?"scrollTop":"scrollLeft";return d.doc.documentElement[b]||d.doc.body[b]},k=function(){this.returnValue=!1},l=function(){return this.originalEvent.preventDefault()},m=function(){this.cancelBubble=!0},n=function(){return this.originalEvent.stopPropagation()},o=function(){return d.doc.addEventListener?function(a,b,c,d){var e=g&&i[b]?i[b]:b,h=function(e){var h=j("y"),k=j("x"),m=e.clientX+k,o=e.clientY+h;if(g&&i[f](b))for(var p=0,q=e.targetTouches&&e.targetTouches.length;q>p;p++)if(e.targetTouches[p].target==a){var r=e;e=e.targetTouches[p],e.originalEvent=r,e.preventDefault=l,e.stopPropagation=n;break}return c.call(d,e,m,o)};return a.addEventListener(e,h,!1),function(){return a.removeEventListener(e,h,!1),!0}}:d.doc.attachEvent?function(a,b,c,e){var f=function(a){a=a||d.win.event;var b=j("y"),f=j("x"),g=a.clientX+f,h=a.clientY+b;return a.preventDefault=a.preventDefault||k,a.stopPropagation=a.stopPropagation||m,c.call(e,a,g,h)};a.attachEvent("on"+b,f);var g=function(){return a.detachEvent("on"+b,f),!0};return g}:void 0}(),p=[],q=function(a){for(var b,c=a.clientX,d=a.clientY,e=j("y"),f=j("x"),h=p.length;h--;){if(b=p[h],g){for(var i,k=a.touches.length;k--;)if(i=a.touches[k],i.identifier==b.el._drag.id){c=i.clientX,d=i.clientY,(a.originalEvent?a.originalEvent:a).preventDefault();break}}else a.preventDefault();var l=b.el.node;l.nextSibling,l.parentNode,l.style.display,c+=f,d+=e,eve("savage.drag.move."+b.el.id,b.move_scope||b.el,c-b.el._drag.x,d-b.el._drag.y,c,d,a)}},r=function(b){a.unmousemove(q).unmouseup(r);for(var c,d=p.length;d--;)c=p[d],c.el._drag={},eve("savage.drag.end."+c.el.id,c.end_scope||c.start_scope||c.move_scope||c.el,b);p=[]},s=h.length;s--;)!function(b){a[b]=e[b]=function(c,e){return a.is(c,"function")&&(this.events=this.events||[],this.events.push({name:b,f:c,unbind:o(this.shape||this.node||d.doc,b,c,e||this)})),this},a["un"+b]=e["un"+b]=function(a){for(var c=this.events||[],d=c.length;d--;)if(c[d].name==b&&c[d].f==a)return c[d].unbind(),c.splice(d,1),!c.length&&delete this.events,this;return this}}(h[s]);e.data=function(b,c){var d=eldata[this.id]=eldata[this.id]||{};if(1==arguments.length){if(a.is(b,"object")){for(var e in b)b[f](e)&&this.data(e,b[e]);return this}return eve("savage.data.get."+this.id,this,d[b],b),d[b]}return d[b]=c,eve("savage.data.set."+this.id,this,c,b),this},e.removeData=function(a){return null==a?eldata[this.id]={}:eldata[this.id]&&delete eldata[this.id][a],this},e.hover=function(a,b,c,d){return this.mouseover(a,c).mouseout(b,d||c)},e.unhover=function(a,b){return this.unmouseover(a).unmouseout(b)};var t=[];e.drag=function(b,c,d,e,f,g){function h(h){(h.originalEvent||h).preventDefault();var i=j("y"),k=j("x");this._drag.x=h.clientX+k,this._drag.y=h.clientY+i,this._drag.id=h.identifier,!p.length&&a.mousemove(q).mouseup(r),p.push({el:this,move_scope:e,start_scope:f,end_scope:g}),c&&eve.on("savage.drag.start."+this.id,c),b&&eve.on("savage.drag.move."+this.id,b),d&&eve.on("savage.drag.end."+this.id,d),eve("savage.drag.start."+this.id,f||e||this,h.clientX+k,h.clientY+i,h)}if(!arguments.length){var i;return this.drag(function(a,b){this.attr({transform:i+(i?"T":"t")+[a,b]})},function(){i=this.transform().local})}return this._drag={},t.push({el:this,start:h}),this.mousedown(h),this},e.onDragOver=function(a){a?eve.on("savage.drag.over."+this.id,a):eve.unbind("savage.drag.over."+this.id)},e.undrag=function(){for(var b=t.length;b--;)t[b].el==this&&(this.unmousedown(t[b].start),t.splice(b,1),eve.unbind("savage.drag.*."+this.id));!t.length&&a.unmousemove(q).unmouseup(r)}}),Savage.plugin(function(a,b,c){var d=(b.prototype,c.prototype),e=/^\s*url\((.+)\)/,f=String,g=a._.$;a.filter={},d.filter=function(c){var d=a.parse(f(c)),e=a._.id(),h=this.node.offsetWidth,i=this.node.offsetHeight,j=g("filter");return g(j,{id:e,filterUnits:"userSpaceOnUse",x:0,y:0,width:h,height:i}),j.appendChild(d.node),this.defs.appendChild(j),new b(j)},eve.on("savage.util.getattr.filter",function(){eve.stop();var b=g(this.node,"filter");if(b){var c=f(b).match(e);return c&&a.select(c[1])}}),eve.on("savage.util.attr.filter",function(a){if(a instanceof b&&"filter"==a.type){eve.stop();var c=a.node.id;c||(g(a.node,{id:a.id}),c=a.id),g(this.node,{filter:"url(#"+c+")"})}a||(eve.stop(),this.node.removeAttribute("filter"))}),a.filter.blur=function(b,c){null==b&&(b=2);var d=null==c?b:[b,c];return a.format(' ',{def:d})},a.filter.blur.toString=function(){return this()},a.filter.shadow=function(b,c,d,e){return e=a.color(e||"#000"),null==d&&(d=2),null==b&&(b=0,c=4),null==c&&(c=b),a.format(' ',{r:e.r,g:e.g,b:e.b,o:e.opacity,dx:b,dy:c,blur:d})
+},a.filter.shadow.toString=function(){return this()}});
\ No newline at end of file
diff --git a/dist/savage.js b/dist/savage.js
index 2c1fc19..f834b00 100644
--- a/dist/savage.js
+++ b/dist/savage.js
@@ -28,7 +28,7 @@
// See the License for the specific language governing permissions and
// limitations under the License.
//
-// build: 2013-08-23
+// build: 2013-08-29
// Copyright (c) 2013 Adobe Systems Incorporated. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -2571,7 +2571,13 @@ function arrayFirstValue(arr) {
- el (Element|Set) element to append
= (Element) parent
\*/
- elproto.append = function (el) {
+ /*\
+ * Element.add
+ [ method ]
+ **
+ * See @Element.append.
+ \*/
+ elproto.append = elproto.add = function (el) {
if (el.type == "set") {
var it = this;
el.forEach(function (el) {
@@ -2968,6 +2974,21 @@ function arrayFirstValue(arr) {
callback && eve.once("mina.finish." + anim.id, callback);
return anim;
};
+ /*\
+ * Element.stop
+ [ method ]
+ **
+ * Stops all the animations of the current element.
+ **
+ = (Element) the element
+ \*/
+ elproto.stop = function () {
+ var anims = this.inAnim();
+ for (var i = 0, ii = anims.length; i < ii; i++) {
+ anims[i].stop();
+ }
+ return this;
+ };
/*\
* Element.animate
[ method ]
@@ -3147,7 +3168,7 @@ function Paper(w, h) {
for (var key in proto) if (proto[has](key)) {
res[key] = proto[key];
}
- res.paper = res;
+ res.paper = res.root = res;
res.defs = defs;
return res;
}
@@ -3447,6 +3468,9 @@ function wrap(dom) {
proto.group = proto.g = function () {
var el = make("g", this.node);
el.add = add2group;
+ for (var method in proto) if (proto[has](method)) {
+ el[method] = proto[method];
+ }
if (arguments.length) {
add2group.call(el, Array.prototype.slice.call(arguments, 0));
}
@@ -3701,6 +3725,64 @@ function wrap(dom) {
};
}());
}(Paper.prototype));
+
+// simple ajax
+/*\
+ * Savage.ajax
+ [ method ]
+ **
+ * Simple implementation of Ajax.
+ **
+ > Parameters
+ **
+ - url (string) URL
+ - postData (object|string) data for post request
+ - callback (function) callback
+ - scope (object) #optional scope of callback
+ * or
+ - url (string) URL
+ - callback (function) callback
+ - scope (object) #optional scope of callback
+ = (XMLHttpRequest) XMLHttpRequest (just in case)
+\*/
+Savage.ajax = function (url, postData, callback, scope){
+ var req = new XMLHttpRequest,
+ id = ID();
+ if (req) {
+ if (is(postData, "function")) {
+ scope = callback;
+ callback = postData;
+ postData = null;
+ } else if (is(postData, "object")) {
+ var pd = [];
+ for (var key in postData) if (postData.hasOwnProperty(key)) {
+ pd.push(encodeURIComponent(key) + "=" + encodeURIComponent(postData[key]));
+ }
+ postData = pd.join("&");
+ }
+ req.open((postData ? "POST" : "GET"), url, true);
+ req.setRequestHeader("X-Requested-With", "XMLHttpRequest");
+ if (postData) {
+ req.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
+ }
+ if (callback) {
+ eve.once("savage.ajax." + id + ".0", callback);
+ eve.once("savage.ajax." + id + ".200", callback);
+ eve.once("savage.ajax." + id + ".304", callback);
+ }
+ req.onreadystatechange = function() {
+ if (req.readyState != 4) return;
+ eve("savage.ajax." + id + "." + req.status, scope, req);
+ };
+ if (req.readyState == 4) {
+ return req;
+ }
+ req.send(postData);
+ return req;
+ }
+};
+
+
// Attributes event handlers
eve.on("savage.util.attr.mask", function (value) {
if (value instanceof Element || value instanceof Fragment) {
@@ -4021,8 +4103,240 @@ var availableAttributes = {
path: {
d: "",
"class": 0
+ },
+ feDistantLight: {
+ azimuth: 0,
+ elevation: 0
+ },
+ fePointLight: {
+ x: 0,
+ y: 0,
+ z: 0
+ },
+ feSpotLight: {
+ x: 0,
+ y: 0,
+ z: 0,
+ pointsAtX: 0,
+ pointsAtY: 0,
+ pointsAtZ: 0,
+ specularExponent: 0,
+ limitingConeAngle: 0
+ },
+ feBlend: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ in2: 0,
+ mode: 0
+ },
+ feColorMatrix: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ type: 0,
+ values: 0
+ },
+ feComponentTransfer: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0
+ },
+ feComposite: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ in2: 0,
+ operator: 0,
+ k1: 0,
+ k2: 0,
+ k3: 0,
+ k4: 0
+ },
+ feConvolveMatrix: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ order: 0,
+ kernelMatrix: 0,
+ divisor: 0,
+ bias: 0,
+ targetX: 0,
+ targetY: 0,
+ edgeMode: 0,
+ kernelUnitLength: 0,
+ preserveAlpha: 0
+ },
+ feDiffuseLighting: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ surfaceScale: 0,
+ diffuseConstant: 0,
+ kernelUnitLength: 0
+ },
+ feDisplacementMap: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ in2: 0,
+ scale: 0,
+ xChannelSelector: 0,
+ yChannelSelector: 0
+ },
+ feFlood: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "flood-color": 0,
+ "flood-opacity": 0
+ },
+ feGaussianBlur: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ stdDeviation: 0
+ },
+ feImage : {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ externalResourcesRequired: 0,
+ preserveAspectRatio: 0,
+ "xlink:href": 0
+ },
+ feMerge: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0
+ },
+ feMergeNode: {
+ "in": 0
+ },
+ feMorphology: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ operator: 0,
+ radius: 0
+ },
+ feOffset: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ dx: 0,
+ dy: 0
+ },
+ feSpecularLighting: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ surfaceScale: 0,
+ specularConstant: 0,
+ specularExponent: 0,
+ kernelUnitLength: 0
+ },
+ feTile: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0
+ },
+ feTurbulence: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ baseFrequency: 0,
+ numOctaves: 0,
+ seed: 0,
+ stitchTiles: 0,
+ type: 0
}
};
+availableAttributes.feFuncR = availableAttributes.feFuncG = availableAttributes.feFuncB = availableAttributes.feFuncA = {
+ type: 0,
+ tableValues: 0,
+ slope: 0,
+ intercept: 0,
+ amplitude: 0,
+ exponent: 0,
+ offset: 0
+};
eve.on("savage.util.attr", function (value) {
var att = eve.nt();
att = att.substring(att.lastIndexOf(".") + 1);
diff --git a/dr.json b/dr.json
index 1e835e4..0a0d480 100644
--- a/dr.json
+++ b/dr.json
@@ -1,27 +1,27 @@
{
"title": "Savage",
"output": "dist/reference.html",
- "scripts": ["savage.js", "reference.js"],
+ "scripts": ["../savage-min.js", "reference.js"],
"files": [{
- "url": "svg.js",
+ "url": "src/svg.js",
"link": "https://github.com/adobe-webplatform/savage/blob/master/svg.js"
}, {
- "url": "savage.equal.js",
+ "url": "src/equal.js",
"link": "https://github.com/adobe-webplatform/savage/blob/master/savage.equal.js"
}, {
- "url": "mina.js",
+ "url": "src/mina.js",
"link": "https://github.com/adobe-webplatform/savage/blob/master/mina.js"
}, {
- "url": "savage.filter.default.js",
+ "url": "src/filter.js",
"link": "https://github.com/adobe-webplatform/savage/blob/master/savage.filter.default.js"
}, {
- "url": "savage.mouse.js",
+ "url": "src/mouse.js",
"link": "https://github.com/adobe-webplatform/savage/blob/master/savage.mouse.js"
}, {
- "url": "savage.path.js",
+ "url": "src/path.js",
"link": "https://github.com/adobe-webplatform/savage/blob/master/savage.mouse.js"
}, {
- "url": "savage.set.js",
+ "url": "src/set.js",
"link": "https://github.com/adobe-webplatform/savage/blob/master/savage.mouse.js"
}]
}
\ No newline at end of file
diff --git a/src/filter.js b/src/filter.js
index 25dc401..4e28cd5 100644
--- a/src/filter.js
+++ b/src/filter.js
@@ -24,8 +24,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Creates filter element
**
- > Parameters
- **
- filstr (string) SVG fragment of filter provided as a string.
= (object) @Element
* Note: It is recommended to use filters embedded into page inside empty SVG element.
@@ -74,7 +72,7 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
filter: "url(#" + id + ")"
});
}
- if (!value) {
+ if (!value || value == "none") {
eve.stop();
this.node.removeAttribute("filter");
}
@@ -86,8 +84,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Returns string of the blur filter.
**
- > Parameters
- **
- x (number) amount of horisontal blur in px.
- y (number) #optional amount of vertical blur in px.
= (string) filter representation
@@ -115,8 +111,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Returns string of the blur filter.
**
- > Parameters
- **
- dx (number) horisontal shift of the shadow in px.
- dy (number) vertical shift of the shadow in px.
- blur (number) #optional amount of blur.
@@ -131,11 +125,11 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
Savage.filter.shadow = function (dx, dy, blur, color) {
color = Savage.color(color || "#000");
if (blur == null) {
- blur = 2;
+ blur = 4;
}
if (dx == null) {
dx = 0;
- dy = 4;
+ dy = 2;
}
if (dy == null) {
dy = dx;
diff --git a/src/mina.js b/src/mina.js
index b72202c..3ef2ba4 100644
--- a/src/mina.js
+++ b/src/mina.js
@@ -111,8 +111,6 @@ var mina = (function (eve) {
**
* Generic animation of numbers.
**
- > Parameters
- **
- a (number) start “slave” number
- A (number) end “slave” number
- b (number) start “master” number (start time in gereal case)
@@ -181,7 +179,6 @@ var mina = (function (eve) {
[ method ]
**
* Returns animation by it’s id.
- > Parameters
- id (string) animation’s id
= (object) See @mina
\*/
@@ -194,7 +191,6 @@ var mina = (function (eve) {
[ method ]
**
* Default linear easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
@@ -206,7 +202,6 @@ var mina = (function (eve) {
[ method ]
**
* Easeout easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
@@ -218,7 +213,6 @@ var mina = (function (eve) {
[ method ]
**
* Easein easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
@@ -230,7 +224,6 @@ var mina = (function (eve) {
[ method ]
**
* Easeinout easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
@@ -249,7 +242,6 @@ var mina = (function (eve) {
[ method ]
**
* Backin easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
@@ -262,7 +254,6 @@ var mina = (function (eve) {
[ method ]
**
* Backout easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
@@ -276,7 +267,6 @@ var mina = (function (eve) {
[ method ]
**
* Elastic easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
@@ -292,7 +282,6 @@ var mina = (function (eve) {
[ method ]
**
* Bounce easing.
- > Parameters
- n (number) input 0..1
= (number) output 0..1
\*/
diff --git a/src/mouse.js b/src/mouse.js
index 63aae81..dc38eac 100644
--- a/src/mouse.js
+++ b/src/mouse.js
@@ -148,7 +148,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for click for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -157,7 +156,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for click for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -167,7 +165,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for double click for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -176,7 +173,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for double click for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -186,7 +182,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for mousedown for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -195,7 +190,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for mousedown for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -205,7 +199,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for mousemove for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -214,7 +207,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for mousemove for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -224,7 +216,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for mouseout for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -233,7 +224,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for mouseout for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -243,7 +233,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for mouseover for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -252,7 +241,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for mouseover for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -262,7 +250,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for mouseup for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -271,7 +258,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for mouseup for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -281,7 +267,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for touchstart for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -290,7 +275,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for touchstart for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -300,7 +284,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for touchmove for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -309,7 +292,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for touchmove for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -319,7 +301,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for touchend for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -328,7 +309,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for touchend for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -338,7 +318,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handler for touchcancel for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -347,7 +326,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handler for touchcancel for the element.
- > Parameters
- handler (function) handler for the event
= (object) @Element
\*/
@@ -385,7 +363,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Adds or retrieves given value asociated with given key.
**
* See also @Element.removeData
- > Parameters
- key (string) key to store data
- value (any) #optional value to store
= (object) @Element
@@ -423,7 +400,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Removes value associated with an element by given key.
* If key is not provided, removes all the data of the element.
- > Parameters
- key (string) #optional key
= (object) @Element
\*/
@@ -440,7 +416,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handlers for hover for the element.
- > Parameters
- f_in (function) handler for hover in
- f_out (function) handler for hover out
- icontext (object) #optional context for hover in handler
@@ -455,7 +430,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Removes event handlers for hover for the element.
- > Parameters
- f_in (function) handler for hover in
- f_out (function) handler for hover out
= (object) @Element
@@ -469,7 +443,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Adds event handlers for drag of the element.
- > Parameters
- onmove (function) handler for moving
- onstart (function) handler for drag start
- onend (function) handler for drag end
@@ -529,7 +502,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Shortcut for assigning event handler for `drag.over.` event, where id is id of the element (see @Element.id).
- > Parameters
- f (function) handler for event, first argument would be the element you are dragging over
\*/
elproto.onDragOver = function (f) {
diff --git a/src/path.js b/src/path.js
index b06ff16..46eb0f2 100644
--- a/src/path.js
+++ b/src/path.js
@@ -1043,8 +1043,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Returns length of the given path in pixels.
**
- > Parameters
- **
- path (string) SVG path string.
**
= (number) length.
@@ -1056,8 +1054,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Return coordinates of the point located at the given length on the given path.
**
- > Parameters
- **
- path (string) SVG path string
- length (number)
**
@@ -1075,8 +1071,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Return subpath of a given path from given length to given length.
**
- > Parameters
- **
- path (string) SVG path string
- from (number) position of the start of the segment
- to (number) position of the end of the segment
@@ -1108,8 +1102,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Return coordinates of the point located at the given length on the given path. Only works for element of “path” type.
**
- > Parameters
- **
- length (number)
**
= (object) representation of the point:
@@ -1128,8 +1120,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Return subpath of a given element from given length to given length. Only works for element of “path” type.
**
- > Parameters
- **
- from (number) position of the start of the segment
- to (number) position of the end of the segment
**
@@ -1146,7 +1136,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Find dot coordinates on the given cubic bezier curve at the given t.
- > Parameters
- p1x (number) x of the first point of the curve
- p1y (number) y of the first point of the curve
- c1x (number) x of the first anchor of the curve
@@ -1187,7 +1176,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Return bounding box of a given cubic bezier curve
- > Parameters
- p1x (number) x of the first point of the curve
- p1y (number) y of the first point of the curve
- c1x (number) x of the first anchor of the curve
@@ -1218,7 +1206,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Returns `true` if given point is inside bounding box.
- > Parameters
- bbox (string) bounding box
- x (string) x coordinate of the point
- y (string) y coordinate of the point
@@ -1232,7 +1219,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Returns `true` if two bounding boxes intersect
- > Parameters
- bbox1 (string) first bounding box
- bbox2 (string) second bounding box
= (boolean) `true` if they intersect
@@ -1245,7 +1231,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Finds intersections of two paths
- > Parameters
- path1 (string) path string
- path2 (string) path string
= (array) dots of intersection
@@ -1271,7 +1256,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Returns `true` if given point is inside a given closed path.
- > Parameters
- path (string) path string
- x (number) x of the point
- y (number) y of the point
@@ -1285,7 +1269,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Return bounding box of a given path
- > Parameters
- path (string) path string
= (object) bounding box
o {
@@ -1306,7 +1289,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Converts path coordinates into relative values.
- > Parameters
- path (string) path string
= (array) path string
\*/
@@ -1318,7 +1300,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Converts path coordinates into absolute values.
- > Parameters
- path (string) path string
= (array) path string
\*/
@@ -1330,7 +1311,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
* Utility method
**
* Converts path to a new path where all segments are cubic bezier curves.
- > Parameters
- pathString (string|array) path string or array of segments
= (array) array of segments.
\*/
@@ -1340,7 +1320,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
[ method ]
**
* Transform the path string with given matrix.
- > Parameters
- path (string) path string
- matrix (object) see @Matrix
= (string) transformed path string
diff --git a/src/set.js b/src/set.js
index 08300c0..08cd493 100644
--- a/src/set.js
+++ b/src/set.js
@@ -69,8 +69,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
*
* If function returns `false` it will stop loop running.
**
- > Parameters
- **
- callback (function) function to run
- thisArg (object) context object for the callback
= (object) Set object
@@ -106,8 +104,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Removes given element from the set
**
- > Parameters
- **
- index (number) position of the deletion
- count (number) number of element to remove
- insertion… (object) #optional elements to insert
@@ -145,8 +141,6 @@ Savage.plugin(function (Savage, Element, Paper, glob) {
**
* Removes given element from the set
**
- > Parameters
- **
- element (object) element to remove
= (boolean) `true` if object was found & removed from the set
\*/
diff --git a/src/svg.js b/src/svg.js
index b67f1f3..3612bc8 100644
--- a/src/svg.js
+++ b/src/svg.js
@@ -20,8 +20,6 @@ Savage.version = "0.0.1";
**
* Creates drawing surface or wraps existing SVG element.
**
- > Parameters
- **
- width (number|string) width of surface
- height (number|string) height of surface
* or
@@ -156,8 +154,6 @@ function is(o, type) {
**
* Replaces construction of type “`{}`” to the corresponding argument.
**
- > Parameters
- **
- token (string) string to format
- json (object) object which properties will be used as a replacement
= (string) formated string
@@ -266,7 +262,6 @@ function x_y_w_h() {
[ method ]
**
* Transform angle to radians
- > Parameters
- deg (number) angle in degrees
= (number) angle in radians.
\*/
@@ -276,7 +271,6 @@ Savage.rad = rad;
[ method ]
**
* Transform angle to degrees
- > Parameters
- deg (number) angle in radians
= (number) angle in degrees.
\*/
@@ -286,7 +280,6 @@ Savage.deg = deg;
[ method ]
**
* Handfull replacement for `typeof` operator.
- > Parameters
- o (…) any object or primitive
- type (string) name of the type, i.e. “string”, “function”, “number”, etc.
= (boolean) is given value is of given type
@@ -297,7 +290,6 @@ Savage.is = is;
[ method ]
**
* Snaps given value to given grid.
- > Parameters
- values (array|number) given array of values or step of the grid
- value (number) value to adjust
- tolerance (number) #optional tolerance for snapping. Default is `10`.
@@ -356,7 +348,6 @@ function Matrix(a, b, c, d, e, f) {
[ method ]
**
* Adds given matrix to existing one.
- > Parameters
- a (number)
- b (number)
- c (number)
@@ -420,7 +411,6 @@ function Matrix(a, b, c, d, e, f) {
[ method ]
**
* Translate the matrix
- > Parameters
- x (number)
- y (number)
\*/
@@ -432,7 +422,6 @@ function Matrix(a, b, c, d, e, f) {
[ method ]
**
* Scales the matrix
- > Parameters
- x (number)
- y (number) #optional
- cx (number) #optional
@@ -450,7 +439,6 @@ function Matrix(a, b, c, d, e, f) {
[ method ]
**
* Rotates the matrix
- > Parameters
- a (number)
- x (number)
- y (number)
@@ -469,7 +457,6 @@ function Matrix(a, b, c, d, e, f) {
[ method ]
**
* Return x coordinate for given point after transformation described by the matrix. See also @Matrix.y
- > Parameters
- x (number)
- y (number)
= (number) x
@@ -482,7 +469,6 @@ function Matrix(a, b, c, d, e, f) {
[ method ]
**
* Return y coordinate for given point after transformation described by the matrix. See also @Matrix.x
- > Parameters
- x (number)
- y (number)
= (number) y
@@ -584,7 +570,6 @@ function Matrix(a, b, c, d, e, f) {
* Utility method
**
* Returns matrix based on given parameters.
- > Parameters
- a (number)
- b (number)
- c (number)
@@ -602,7 +587,6 @@ Savage.Matrix = Matrix;
[ method ]
**
* Parses colour string as RGB object
- > Parameters
- colour (string) colour string in one of formats:
#
# Colour name (“red
”, “green
”, “cornflowerblue
”, etc)
@@ -700,7 +684,6 @@ Savage.getRGB = cacher(function (colour) {
[ method ]
**
* Converts HSB values to hex representation of the colour.
- > Parameters
- h (number) hue
- s (number) saturation
- b (number) value or brightness
@@ -714,7 +697,6 @@ Savage.hsb = cacher(function (h, s, b) {
[ method ]
**
* Converts HSL values to hex representation of the colour.
- > Parameters
- h (number) hue
- s (number) saturation
- l (number) luminosity
@@ -728,7 +710,6 @@ Savage.hsl = cacher(function (h, s, l) {
[ method ]
**
* Converts RGB values to hex representation of the colour.
- > Parameters
- r (number) red
- g (number) green
- b (number) blue
@@ -803,7 +784,6 @@ packageRGB = function (r, g, b, o) {
[ method ]
**
* Parses the color string and returns object with all values for the given color.
- > Parameters
- clr (string) color string in one of the supported formats (see @Savage.getRGB)
= (object) Combined RGB & HSB object in format:
o {
@@ -858,7 +838,6 @@ Savage.color = function (clr) {
[ method ]
**
* Converts HSB values to RGB object.
- > Parameters
- h (number) hue
- s (number) saturation
- v (number) value or brightness
@@ -895,7 +874,6 @@ Savage.hsb2rgb = function (h, s, v, o) {
[ method ]
**
* Converts HSL values to RGB object.
- > Parameters
- h (number) hue
- s (number) saturation
- l (number) luminosity
@@ -936,7 +914,6 @@ Savage.hsl2rgb = function (h, s, l, o) {
[ method ]
**
* Converts RGB values to HSB object.
- > Parameters
- r (number) red
- g (number) green
- b (number) blue
@@ -970,7 +947,6 @@ Savage.rgb2hsb = function (r, g, b) {
[ method ]
**
* Converts RGB values to HSL object.
- > Parameters
- r (number) red
- g (number) green
- b (number) blue
@@ -1011,7 +987,6 @@ Savage.rgb2hsl = function (r, g, b) {
* Utility method
**
* Parses given path string into an array of arrays of path segments.
- > Parameters
- pathString (string|array) path string or array of segments (in the last case it will be returned straight away)
= (array) array of segments.
\*/
@@ -1065,7 +1040,6 @@ Savage.parsePathString = function (pathString) {
* Utility method
**
* Parses given path string into an array of transformations.
- > Parameters
- TString (string|array) transform string or array of transformations (in the last case it will be returned straight away)
= (array) array of transformations.
\*/
@@ -1315,7 +1289,6 @@ function unit2px(el, name, value) {
[ method ]
**
* Wraps DOM element specified by CSS selector as @Element
- > Parameters
- query (string) CSS selector of the element
= (Element)
\*/
@@ -1327,7 +1300,6 @@ Savage.select = function (query) {
[ method ]
**
* Wraps DOM elements specified by CSS selector as set or array of @Element
- > Parameters
- query (string) CSS selector of the element
= (Element)
\*/
@@ -1383,8 +1355,6 @@ function arrayFirstValue(arr) {
**
* Gets or sets given attributes of the element
**
- > Parameters
- **
- params (object) key-value pairs of attributes you want to set
* or
- param (string) name of the attribute
@@ -1471,8 +1441,6 @@ function arrayFirstValue(arr) {
**
* Gets or sets transformation of the element
**
- > Parameters
- **
- tstr (string) transform string in Savage or SVG format
= (Element)
* or
@@ -1538,12 +1506,16 @@ function arrayFirstValue(arr) {
**
* Appends given element to current one.
**
- > Parameters
- **
- el (Element|Set) element to append
= (Element) parent
\*/
- elproto.append = function (el) {
+ /*\
+ * Element.add
+ [ method ]
+ **
+ * See @Element.append.
+ \*/
+ elproto.append = elproto.add = function (el) {
if (el.type == "set") {
var it = this;
el.forEach(function (el) {
@@ -1562,8 +1534,6 @@ function arrayFirstValue(arr) {
**
* Prepends given element to current one.
**
- > Parameters
- **
- el (Element) element to prepend
= (Element) parent
\*/
@@ -1579,8 +1549,6 @@ function arrayFirstValue(arr) {
**
* Inserts given element before the current one.
**
- > Parameters
- **
- el (Element) element to insert
= (Element) parent
\*/
@@ -1597,8 +1565,6 @@ function arrayFirstValue(arr) {
**
* Inserts given element after the current one.
**
- > Parameters
- **
- el (Element) element to insert
= (Element) parent
\*/
@@ -1614,8 +1580,6 @@ function arrayFirstValue(arr) {
**
* Inserts the element after the given one.
**
- > Parameters
- **
- el (Element) element next to whom insert to
= (Element) parent
\*/
@@ -1631,8 +1595,6 @@ function arrayFirstValue(arr) {
**
* Inserts the element after the given one.
**
- > Parameters
- **
- el (Element) element next to whom insert to
= (Element) parent
\*/
@@ -1659,8 +1621,6 @@ function arrayFirstValue(arr) {
**
* Applies CSS selector with the element as a parent and returns the result as an @Element.
**
- > Parameters
- **
- query (string) CSS selector
= (Element) result of query selection
\*/
@@ -1673,8 +1633,6 @@ function arrayFirstValue(arr) {
**
* Applies CSS selector with the element as a parent and returns the result as a set or array of elements.
**
- > Parameters
- **
- query (string) CSS selector
= (Set|array) result of query selection
\*/
@@ -1692,8 +1650,6 @@ function arrayFirstValue(arr) {
**
* Return given attribute of the element as a `px` value. (Not %, em, etc)
**
- > Parameters
- **
- attr (string) attribute name
- value (string) #optional attribute value
= (Element) result of query selection
@@ -1751,8 +1707,6 @@ function arrayFirstValue(arr) {
**
* Creates `` element from the current element.
**
- > Parameters
- **
* To create a pattern you have to specify the pattern rect:
- x (string|number)
- y (string|number)
@@ -1799,8 +1753,6 @@ function arrayFirstValue(arr) {
**
* Creates `` element from the current element.
**
- > Parameters
- **
* To create a marker you have to specify the bounding rect and reference point:
- x (number)
- y (number)
@@ -1863,8 +1815,6 @@ function arrayFirstValue(arr) {
**
* Creates animation object.
**
- > Parameters
- **
- attr (object) attributes of final destination
- ms (number) animation duration
- easing (function) #optional one of easing functions of @mina or custom one
@@ -1913,7 +1863,6 @@ function arrayFirstValue(arr) {
**
* Runs generic animation of one number into another with a caring function.
**
- > Parameters
- from (number|array) number or array of numbers
- to (number|array) number or array of numbers
- setter (function) caring function that will take one number argument
@@ -1940,13 +1889,27 @@ function arrayFirstValue(arr) {
callback && eve.once("mina.finish." + anim.id, callback);
return anim;
};
+ /*\
+ * Element.stop
+ [ method ]
+ **
+ * Stops all the animations of the current element.
+ **
+ = (Element) the element
+ \*/
+ elproto.stop = function () {
+ var anims = this.inAnim();
+ for (var i = 0, ii = anims.length; i < ii; i++) {
+ anims[i].stop();
+ }
+ return this;
+ };
/*\
* Element.animate
[ method ]
**
* Animate given attributes of the element.
**
- > Parameters
- attrs (object) key-value pairs of destination attributes
- ms (number) duration
- easing (function) #optional easing function from @mina or custom
@@ -2008,7 +1971,6 @@ function arrayFirstValue(arr) {
**
* Parses SVG fragment and converts it into @Fragment.
**
- > Parameters
- svg (string) SVG string
= (Fragment) the fragment
\*/
@@ -2057,7 +2019,6 @@ Fragment.prototype.selectAll = Element.prototype.selectAll;
**
* Creates DOM fragment from given list of elements or strings
**
- > Parameters
- varargs (…) SVG string
= (Fragment) the @Fragment
\*/
@@ -2119,7 +2080,7 @@ function Paper(w, h) {
for (var key in proto) if (proto[has](key)) {
res[key] = proto[key];
}
- res.paper = res;
+ res.paper = res.root = res;
res.defs = defs;
return res;
}
@@ -2142,7 +2103,6 @@ function wrap(dom) {
**
* Creates element on paper with a given name and no attributes.
**
- > Parameters
- name (string) element tag name
= (Element) the element
> Usage
@@ -2162,8 +2122,6 @@ function wrap(dom) {
*
* Draws a rectangle.
**
- > Parameters
- **
- x (number) x coordinate of the top left corner
- y (number) y coordinate of the top left corner
- width (number) width
@@ -2207,8 +2165,6 @@ function wrap(dom) {
**
* Draws a circle.
**
- > Parameters
- **
- x (number) x coordinate of the centre
- y (number) y coordinate of the centre
- r (number) radius
@@ -2236,8 +2192,6 @@ function wrap(dom) {
**
* Embeds an image into the surface.
**
- > Parameters
- **
- src (string) URI of the source image
- x (number) x coordinate position
- y (number) y coordinate position
@@ -2254,8 +2208,6 @@ function wrap(dom) {
**
* Embeds an image into the surface.
**
- > Parameters
- **
- src (string) URI of the source image
- x (number) x coordinate position
- y (number) y coordinate position
@@ -2300,8 +2252,6 @@ function wrap(dom) {
**
* Draws an ellipse.
**
- > Parameters
- **
- x (number) x coordinate of the centre
- y (number) y coordinate of the centre
- rx (number) horizontal radius
@@ -2330,7 +2280,6 @@ function wrap(dom) {
[ method ]
**
* Creates a path element by given path data string.
- > Parameters
- pathString (string) #optional path string in SVG format.
* Path string consists of one-letter commands, followed by comma seprarated arguments in numercal form. Example:
| "M10,20L30,40"
@@ -2395,8 +2344,6 @@ function wrap(dom) {
**
* Makes a group element.
**
- > Parameters
- **
- varargs (…) #optional elements
= (object) Element object with type “g”
**
@@ -2419,6 +2366,9 @@ function wrap(dom) {
proto.group = proto.g = function () {
var el = make("g", this.node);
el.add = add2group;
+ for (var method in proto) if (proto[has](method)) {
+ el[method] = proto[method];
+ }
if (arguments.length) {
add2group.call(el, Array.prototype.slice.call(arguments, 0));
}
@@ -2430,8 +2380,6 @@ function wrap(dom) {
**
* Draws a text string.
**
- > Parameters
- **
- x (number) x coordinate position
- y (number) y coordinate position
- text (string|array) The text string to draw or array of s
@@ -2460,8 +2408,6 @@ function wrap(dom) {
**
* Draws a line.
**
- > Parameters
- **
- x1 (number) x coordinate position of the start
- y1 (number) y coordinate position of the start
- x2 (number) x coordinate position of the end
@@ -2491,8 +2437,6 @@ function wrap(dom) {
**
* Draws a polyline.
**
- > Parameters
- **
- points (array) array of points
* or
- varargs (…) points
@@ -2544,8 +2488,6 @@ function wrap(dom) {
**
* Creates a gradient element.
**
- > Parameters
- **
- gradient (string) gradient descriptor
> Gradient Descriptor
* Gradient descriptor consists of `()`. Type
@@ -2673,6 +2615,62 @@ function wrap(dom) {
};
}());
}(Paper.prototype));
+
+// simple ajax
+/*\
+ * Savage.ajax
+ [ method ]
+ **
+ * Simple implementation of Ajax.
+ **
+ - url (string) URL
+ - postData (object|string) data for post request
+ - callback (function) callback
+ - scope (object) #optional scope of callback
+ * or
+ - url (string) URL
+ - callback (function) callback
+ - scope (object) #optional scope of callback
+ = (XMLHttpRequest) XMLHttpRequest (just in case)
+\*/
+Savage.ajax = function (url, postData, callback, scope){
+ var req = new XMLHttpRequest,
+ id = ID();
+ if (req) {
+ if (is(postData, "function")) {
+ scope = callback;
+ callback = postData;
+ postData = null;
+ } else if (is(postData, "object")) {
+ var pd = [];
+ for (var key in postData) if (postData.hasOwnProperty(key)) {
+ pd.push(encodeURIComponent(key) + "=" + encodeURIComponent(postData[key]));
+ }
+ postData = pd.join("&");
+ }
+ req.open((postData ? "POST" : "GET"), url, true);
+ req.setRequestHeader("X-Requested-With", "XMLHttpRequest");
+ if (postData) {
+ req.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
+ }
+ if (callback) {
+ eve.once("savage.ajax." + id + ".0", callback);
+ eve.once("savage.ajax." + id + ".200", callback);
+ eve.once("savage.ajax." + id + ".304", callback);
+ }
+ req.onreadystatechange = function() {
+ if (req.readyState != 4) return;
+ eve("savage.ajax." + id + "." + req.status, scope, req);
+ };
+ if (req.readyState == 4) {
+ return req;
+ }
+ req.send(postData);
+ return req;
+ }
+};
+
+
// Attributes event handlers
eve.on("savage.util.attr.mask", function (value) {
if (value instanceof Element || value instanceof Fragment) {
@@ -2993,8 +2991,240 @@ var availableAttributes = {
path: {
d: "",
"class": 0
+ },
+ feDistantLight: {
+ azimuth: 0,
+ elevation: 0
+ },
+ fePointLight: {
+ x: 0,
+ y: 0,
+ z: 0
+ },
+ feSpotLight: {
+ x: 0,
+ y: 0,
+ z: 0,
+ pointsAtX: 0,
+ pointsAtY: 0,
+ pointsAtZ: 0,
+ specularExponent: 0,
+ limitingConeAngle: 0
+ },
+ feBlend: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ in2: 0,
+ mode: 0
+ },
+ feColorMatrix: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ type: 0,
+ values: 0
+ },
+ feComponentTransfer: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0
+ },
+ feComposite: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ in2: 0,
+ operator: 0,
+ k1: 0,
+ k2: 0,
+ k3: 0,
+ k4: 0
+ },
+ feConvolveMatrix: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ order: 0,
+ kernelMatrix: 0,
+ divisor: 0,
+ bias: 0,
+ targetX: 0,
+ targetY: 0,
+ edgeMode: 0,
+ kernelUnitLength: 0,
+ preserveAlpha: 0
+ },
+ feDiffuseLighting: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ surfaceScale: 0,
+ diffuseConstant: 0,
+ kernelUnitLength: 0
+ },
+ feDisplacementMap: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ in2: 0,
+ scale: 0,
+ xChannelSelector: 0,
+ yChannelSelector: 0
+ },
+ feFlood: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "flood-color": 0,
+ "flood-opacity": 0
+ },
+ feGaussianBlur: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ stdDeviation: 0
+ },
+ feImage : {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ externalResourcesRequired: 0,
+ preserveAspectRatio: 0,
+ "xlink:href": 0
+ },
+ feMerge: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0
+ },
+ feMergeNode: {
+ "in": 0
+ },
+ feMorphology: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ operator: 0,
+ radius: 0
+ },
+ feOffset: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ dx: 0,
+ dy: 0
+ },
+ feSpecularLighting: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0,
+ surfaceScale: 0,
+ specularConstant: 0,
+ specularExponent: 0,
+ kernelUnitLength: 0
+ },
+ feTile: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ "in": 0
+ },
+ feTurbulence: {
+ height: 0,
+ result: 0,
+ width: 0,
+ x: 0,
+ y: 0,
+ "class": 0,
+ style: 0,
+ baseFrequency: 0,
+ numOctaves: 0,
+ seed: 0,
+ stitchTiles: 0,
+ type: 0
}
};
+availableAttributes.feFuncR = availableAttributes.feFuncG = availableAttributes.feFuncB = availableAttributes.feFuncA = {
+ type: 0,
+ tableValues: 0,
+ slope: 0,
+ intercept: 0,
+ amplitude: 0,
+ exponent: 0,
+ offset: 0
+};
eve.on("savage.util.attr", function (value) {
var att = eve.nt();
att = att.substring(att.lastIndexOf(".") + 1);