parent
a8e2077fe3
commit
f32810d714
@ -0,0 +1,156 @@
|
|||||||
|
/* General styles for the modal */
|
||||||
|
|
||||||
|
/*
|
||||||
|
Styles for the html/body for special modal where we want 3d effects
|
||||||
|
Note that we need a container wrapping all content on the page for the
|
||||||
|
perspective effects (not including the modals and the overlay).
|
||||||
|
*/
|
||||||
|
.md-perspective,
|
||||||
|
.md-perspective body {
|
||||||
|
height: 100%;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.container {
|
||||||
|
background: steelblue;
|
||||||
|
min-height: 100%;
|
||||||
|
width:100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-modal {
|
||||||
|
position: fixed;
|
||||||
|
top: 50%;
|
||||||
|
left: 50%;
|
||||||
|
width: 50%;
|
||||||
|
max-width: 630px;
|
||||||
|
min-width: 320px;
|
||||||
|
height: auto;
|
||||||
|
z-index: 2000;
|
||||||
|
visibility: hidden;
|
||||||
|
-webkit-backface-visibility: hidden;
|
||||||
|
-moz-backface-visibility: hidden;
|
||||||
|
backface-visibility: hidden;
|
||||||
|
-webkit-transform: translateX(-50%) translateY(-50%);
|
||||||
|
-moz-transform: translateX(-50%) translateY(-50%);
|
||||||
|
-ms-transform: translateX(-50%) translateY(-50%);
|
||||||
|
transform: translateX(-50%) translateY(-50%);
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-show {
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-overlay {
|
||||||
|
position: fixed;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
visibility: hidden;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
z-index: 1000;
|
||||||
|
opacity: 0;
|
||||||
|
background: rgba(232, 232, 232, 0.5);
|
||||||
|
-webkit-transition: all 0.3s;
|
||||||
|
-moz-transition: all 0.3s;
|
||||||
|
transition: all 0.3s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-show ~ .md-overlay {
|
||||||
|
opacity: 1;
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Content styles */
|
||||||
|
.md-content {
|
||||||
|
color: black;
|
||||||
|
background: lightblue;
|
||||||
|
position: relative;
|
||||||
|
border-radius: 3px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-content h3 {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0.4em;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 2.4em;
|
||||||
|
font-weight: 300;
|
||||||
|
opacity: 0.8;
|
||||||
|
background: rgba(0,0,0,0.1);
|
||||||
|
border-radius: 3px 3px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-content > div {
|
||||||
|
padding: 15px 40px 30px;
|
||||||
|
margin: 0;
|
||||||
|
font-weight: 300;
|
||||||
|
font-size: 1.15em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-content > div p {
|
||||||
|
margin: 0;
|
||||||
|
padding: 10px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-content > div ul {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0 0 30px 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-content > div ul li {
|
||||||
|
padding: 5px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-content button {
|
||||||
|
display: block;
|
||||||
|
margin: 0 auto;
|
||||||
|
font-size: 0.8em;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Individual modal styles with animations/transitions */
|
||||||
|
|
||||||
|
|
||||||
|
/* Effect 13: 3D slit */
|
||||||
|
.md-effect-13.md-modal {
|
||||||
|
-webkit-perspective: 1300px;
|
||||||
|
-moz-perspective: 1300px;
|
||||||
|
perspective: 1300px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-effect-13 .md-content {
|
||||||
|
-webkit-transform-style: preserve-3d;
|
||||||
|
-moz-transform-style: preserve-3d;
|
||||||
|
transform-style: preserve-3d;
|
||||||
|
-webkit-transform: translateZ(-3000px) rotateY(90deg);
|
||||||
|
-moz-transform: translateZ(-3000px) rotateY(90deg);
|
||||||
|
-ms-transform: translateZ(-3000px) rotateY(90deg);
|
||||||
|
transform: translateZ(-3000px) rotateY(90deg);
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.md-show.md-effect-13 .md-content {
|
||||||
|
-webkit-animation: slit .7s forwards ease-out;
|
||||||
|
-moz-animation: slit .7s forwards ease-out;
|
||||||
|
animation: slit .7s forwards ease-out;
|
||||||
|
}
|
||||||
|
|
||||||
|
@-webkit-keyframes slit {
|
||||||
|
50% { -webkit-transform: translateZ(-250px) rotateY(89deg); opacity: .5; -webkit-animation-timing-function: ease-out;}
|
||||||
|
100% { -webkit-transform: translateZ(0) rotateY(0deg); opacity: 1; }
|
||||||
|
}
|
||||||
|
|
||||||
|
@-moz-keyframes slit {
|
||||||
|
50% { -moz-transform: translateZ(-250px) rotateY(89deg); opacity: .5; -moz-animation-timing-function: ease-out;}
|
||||||
|
100% { -moz-transform: translateZ(0) rotateY(0deg); opacity: 1; }
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes slit {
|
||||||
|
50% { transform: translateZ(-250px) rotateY(89deg); opacity: 1; animation-timing-function: ease-in;}
|
||||||
|
100% { transform: translateZ(0) rotateY(0deg); opacity: 1; }
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@media screen and (max-width: 32em) {
|
||||||
|
body { font-size: 75%; }
|
||||||
|
}
|
@ -0,0 +1,130 @@
|
|||||||
|
/* General Demo Style */
|
||||||
|
@import url(http://fonts.googleapis.com/css?family=Lato:300,400,700);
|
||||||
|
|
||||||
|
@font-face {
|
||||||
|
font-family: 'codropsicons';
|
||||||
|
src:url('../fonts/codropsicons/codropsicons.eot');
|
||||||
|
src:url('../fonts/codropsicons/codropsicons.eot?#iefix') format('embedded-opentype'),
|
||||||
|
url('../fonts/codropsicons/codropsicons.woff') format('woff'),
|
||||||
|
url('../fonts/codropsicons/codropsicons.ttf') format('truetype'),
|
||||||
|
url('../fonts/codropsicons/codropsicons.svg#codropsicons') format('svg');
|
||||||
|
font-weight: normal;
|
||||||
|
font-style: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
*, *:after, *:before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
|
||||||
|
body, html { font-size: 100%; padding: 0; margin: 0; }
|
||||||
|
|
||||||
|
/* Clearfix hack by Nicolas Gallagher: http://nicolasgallagher.com/micro-clearfix-hack/ */
|
||||||
|
.clearfix:before, .clearfix:after { content: " "; display: table; }
|
||||||
|
.clearfix:after { clear: both; }
|
||||||
|
|
||||||
|
body {
|
||||||
|
font-family: 'Lato', Calibri, Arial, sans-serif;
|
||||||
|
color: #fff;
|
||||||
|
background: lightblue;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Header Style */
|
||||||
|
.main,
|
||||||
|
.container > header {
|
||||||
|
margin: 0 auto;
|
||||||
|
padding: 2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container > header {
|
||||||
|
text-align: center;
|
||||||
|
background: lightblue;
|
||||||
|
padding: 3em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container > header h1 {
|
||||||
|
font-size: 2.625em;
|
||||||
|
line-height: 1.3;
|
||||||
|
margin: 0;
|
||||||
|
font-weight: 300;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container > header span {
|
||||||
|
display: block;
|
||||||
|
opacity: 0.7;
|
||||||
|
padding: 0 0 0.6em 0.1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Main Content */
|
||||||
|
.main {
|
||||||
|
max-width: 69em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.column {
|
||||||
|
float: left;
|
||||||
|
width: 50%;
|
||||||
|
padding: 0 2em;
|
||||||
|
min-height: 300px;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.column:nth-child(2) {
|
||||||
|
box-shadow: -1px 0 0 rgba(0,0,0,0.1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.column p {
|
||||||
|
font-weight: 300;
|
||||||
|
font-size: 2em;
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
text-align: right;
|
||||||
|
line-height: 1.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* To Navigation Style */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
button {
|
||||||
|
border: none;
|
||||||
|
padding: 0.6em 1.2em;
|
||||||
|
background: deepskyblue;
|
||||||
|
color: #fff;
|
||||||
|
font-family: 'Lato', Calibri, Arial, sans-serif;
|
||||||
|
font-size: 1em;
|
||||||
|
letter-spacing: 1px;
|
||||||
|
text-transform: uppercase;
|
||||||
|
cursor: pointer;
|
||||||
|
display: inline-block;
|
||||||
|
margin: 3px 2px;
|
||||||
|
border-radius: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
button:hover {
|
||||||
|
background: cornflowerblue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media screen and (max-width: 46.0625em) {
|
||||||
|
.column {
|
||||||
|
width: 100%;
|
||||||
|
min-width: auto;
|
||||||
|
min-height: auto;
|
||||||
|
padding: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.column p {
|
||||||
|
text-align: left;
|
||||||
|
font-size: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.column:nth-child(2) {
|
||||||
|
box-shadow: 0 -1px 0 rgba(0,0,0,0.1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media screen and (max-width: 25em) {
|
||||||
|
|
||||||
|
.codrops-icon span {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,150 +1,133 @@
|
|||||||
body{
|
body{
|
||||||
background: rgba(0,0,0,1);
|
background: white;
|
||||||
color: #DDD;
|
color: #DDD;
|
||||||
font-family: 'Helvetica', 'Lucida Grande', 'Arial', sans-serif;
|
font-family: 'Helvetica', 'Lucida Grande', 'Arial', sans-serif;
|
||||||
}
|
}
|
||||||
.border{
|
.border{
|
||||||
height: 99%;
|
height: 99%;
|
||||||
width: 30%;
|
width: 30%;
|
||||||
}
|
}
|
||||||
.rain{
|
.rain{
|
||||||
height: 400px;
|
height: 400px;
|
||||||
width: 35%;
|
width: 35%;
|
||||||
}
|
}
|
||||||
/* Layout with mask */
|
/* Layout with mask */
|
||||||
.rain{
|
.rain{
|
||||||
padding: 10px 12px 12px 10px;
|
padding: 10px 12px 12px 10px;
|
||||||
-moz-box-shadow: 10px 10px 10px rgba(0,0,0,1) inset, -9px -9px 8px rgba(0,0,0,1) inset;
|
-moz-box-shadow: 10px 10px 10px rgba(255,255,255,1) inset, -9px -9px 8px rgba(255,255,255,1) inset;
|
||||||
-webkit-box-shadow: 8px 8px 8px rgba(0,0,0,1) inset, -9px -9px 8px rgba(0,0,0,1) inset;
|
-webkit-box-shadow: 8px 8px 8px rgba(255,255,255,1) inset, -9px -9px 8px rgba(255,255,255,1) inset;
|
||||||
box-shadow: 8px 8px 8px rgba(0,0,0,1) inset, -9px -9px 8px rgba(0,0,0,1) inset;
|
box-shadow: 8px 8px 8px rgba(255,255,255,1) inset, -9px -9px 8px rgba(255,255,255,1) inset;
|
||||||
margin: 100px auto;
|
margin: 100px auto;
|
||||||
}
|
}
|
||||||
/* Artifical "border" to clear border to bypass mask */
|
/* Artifical "border" to clear border to bypass mask */
|
||||||
.border{
|
.border{
|
||||||
padding: 1px;
|
padding: 1px;
|
||||||
-moz-border-radius: 5px;
|
-moz-border-radius: 5px;
|
||||||
-webkit-border-radius: 5px;
|
-webkit-border-radius: 5px;
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.border,
|
.border,
|
||||||
.rain,
|
.rain,
|
||||||
.border.start,
|
.border.start,
|
||||||
.rain.start{
|
.rain.start{
|
||||||
background-repeat: repeat-x, repeat-x, repeat-x, repeat-x;
|
background-repeat: repeat-x, repeat-x, repeat-x, repeat-x;
|
||||||
background-position: 0 0, 0 0, 0 0, 0 0;
|
background-position: 0 0, 0 0, 0 0, 0 0;
|
||||||
/* Blue-ish Green Fallback for Mozilla */
|
/* Blue-ish Green Fallback for Mozilla */
|
||||||
background-image: -moz-linear-gradient(left, #09BA5E 0%, #00C7CE 15%, #3472CF 26%, #00C7CE 48%, #0CCF91 91%, #09BA5E 100%);
|
background-image: -moz-linear-gradient(left, #09BA5E 0%, #00C7CE 15%, #3472CF 26%, #00C7CE 48%, #0CCF91 91%, #09BA5E 100%);
|
||||||
/* Add "Highlight" Texture to the Animation */
|
/* Add "Highlight" Texture to the Animation */
|
||||||
background-image: -webkit-gradient(linear, left top, right top, color-stop(1%,rgba(0,0,0,.3)), color-stop(23%,rgba(0,0,0,.1)), color-stop(40%,rgba(255,231,87,.1)), color-stop(61%,rgba(255,231,87,.2)), color-stop(70%,rgba(255,231,87,.1)), color-stop(80%,rgba(0,0,0,.1)), color-stop(100%,rgba(0,0,0,.25)));
|
background-image: -webkit-gradient(linear, left top, right top, color-stop(1%,rgba(0,0,0,.3)), color-stop(23%,rgba(0,0,0,.1)), color-stop(40%,rgba(255,231,87,.1)), color-stop(61%,rgba(255,231,87,.2)), color-stop(70%,rgba(255,231,87,.1)), color-stop(80%,rgba(0,0,0,.1)), color-stop(100%,rgba(0,0,0,.25)));
|
||||||
/* Starting Color */
|
/* Starting Color */
|
||||||
background-color: #39f;
|
background-color: #39f;
|
||||||
/* Just do something for IE-suck */
|
/* Just do something for IE-suck */
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00BA1B', endColorstr='#00BA1B',GradientType=1 );
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00BA1B', endColorstr='#00BA1B',GradientType=1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Non-keyframe fallback animation */
|
|
||||||
.border.end,
|
|
||||||
.rain.end{
|
|
||||||
-moz-transition-property: background-position;
|
|
||||||
-moz-transition-duration: 30s;
|
|
||||||
-moz-transition-timing-function: linear;
|
|
||||||
-webkit-transition-property: background-position;
|
|
||||||
-webkit-transition-duration: 30s;
|
|
||||||
-webkit-transition-timing-function: linear;
|
|
||||||
-o-transition-property: background-position;
|
|
||||||
-o-transition-duration: 30s;
|
|
||||||
-o-transition-timing-function: linear;
|
|
||||||
transition-property: background-position;
|
|
||||||
transition-duration: 30s;
|
|
||||||
transition-timing-function: linear;
|
|
||||||
background-position: -5400px 0, -4600px 0, -3800px 0, -3000px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Keyfram-licious animation */
|
|
||||||
@-webkit-keyframes colors {
|
|
||||||
0% {background-color: #39f;}
|
|
||||||
15% {background-color: #F246C9;}
|
|
||||||
30% {background-color: #4453F2;}
|
|
||||||
45% {background-color: #44F262;}
|
|
||||||
60% {background-color: #F257D4;}
|
|
||||||
75% {background-color: #EDF255;}
|
|
||||||
90% {background-color: #F20006;}
|
|
||||||
100% {background-color: #39f;}
|
|
||||||
}
|
|
||||||
.border,.rain{
|
|
||||||
-webkit-animation-direction: normal;
|
|
||||||
-webkit-animation-duration: 20s;
|
|
||||||
-webkit-animation-iteration-count: infinite;
|
|
||||||
-webkit-animation-name: colors;
|
|
||||||
-webkit-animation-timing-function: ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* In-Active State Style */
|
|
||||||
.border.unfocus{
|
|
||||||
background: #333 !important;
|
|
||||||
-moz-box-shadow: 0px 0px 15px rgba(255,255,255,.2);
|
|
||||||
-webkit-box-shadow: 0px 0px 15px rgba(255,255,255,.2);
|
|
||||||
box-shadow: 0px 0px 15px rgba(255,255,255,.2);
|
|
||||||
-webkit-animation-name: none;
|
|
||||||
}
|
|
||||||
.rain.unfocus{
|
|
||||||
background: #000 !important;
|
|
||||||
-webkit-animation-name: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Regular Form Styles */
|
|
||||||
form{
|
|
||||||
background: #212121;
|
|
||||||
-moz-border-radius: 5px;
|
|
||||||
-webkit-border-radius: 5px;
|
|
||||||
border-radius: 5px;
|
|
||||||
height: 100%;
|
|
||||||
width: 335%;
|
|
||||||
background: -moz-radial-gradient(50% 46% 90deg,circle closest-corner, #242424, #090909);
|
|
||||||
background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 150, from(#242424), to(#090909));
|
|
||||||
}
|
|
||||||
form label{
|
|
||||||
display: block;
|
|
||||||
padding: 10px 10px 5px 15px;
|
|
||||||
font-size: 20px;
|
|
||||||
color: #777;
|
|
||||||
}
|
|
||||||
form input{
|
|
||||||
display: block;
|
|
||||||
margin: 5px 10px 10px 15px;
|
|
||||||
width: 85%;
|
|
||||||
background: #111;
|
|
||||||
-moz-box-shadow: 0px 0px 4px #000 inset;
|
|
||||||
-webkit-box-shadow: 0px 0px 4px #000 inset;
|
|
||||||
box-shadow: 0px 0px 4px #000 inset;
|
|
||||||
outline: 1px solid #333;
|
|
||||||
border: 1px solid #000;
|
|
||||||
padding: 5px;
|
|
||||||
color: #444;
|
|
||||||
font-size: 16px;
|
|
||||||
}
|
|
||||||
form input:focus{
|
|
||||||
outline: 1px solid #555;
|
|
||||||
color: #FFF;
|
|
||||||
}
|
|
||||||
|
|
||||||
form textarea{
|
/* Non-keyframe fallback animation */
|
||||||
display: block;
|
.border.end,
|
||||||
margin: 5px 10px 10px 15px;
|
.rain.end{
|
||||||
width: 85%;
|
-moz-transition-property: background-position;
|
||||||
background: #111;
|
-moz-transition-duration: 30s;
|
||||||
-moz-box-shadow: 0px 0px 4px #000 inset;
|
-moz-transition-timing-function: linear;
|
||||||
-webkit-box-shadow: 0px 0px 4px #000 inset;
|
-webkit-transition-property: background-position;
|
||||||
box-shadow: 0px 0px 4px #000 inset;
|
-webkit-transition-duration: 30s;
|
||||||
outline: 1px solid #333;
|
-webkit-transition-timing-function: linear;
|
||||||
border: 1px solid #000;
|
-o-transition-property: background-position;
|
||||||
padding: 5px;
|
-o-transition-duration: 30s;
|
||||||
color: #444;
|
-o-transition-timing-function: linear;
|
||||||
font-size: 16px;
|
transition-property: background-position;
|
||||||
}
|
transition-duration: 30s;
|
||||||
form textarea:focus{
|
transition-timing-function: linear;
|
||||||
outline: 1px solid #555;
|
background-position: -5400px 0, -4600px 0, -3800px 0, -3000px 0;
|
||||||
color: #FFF;
|
}
|
||||||
}
|
|
||||||
|
/* Keyfram-licious animation */
|
||||||
|
@-webkit-keyframes colors {
|
||||||
|
0% {background-color: pink;}
|
||||||
|
15% {background-color: steelblue;}
|
||||||
|
30% {background-color: hotpink;}
|
||||||
|
45% {background-color: black;}
|
||||||
|
60% {background-color: rosybrown;}
|
||||||
|
75% {background-color: #c9c0d3;}
|
||||||
|
90% {background-color: darkgreen;}
|
||||||
|
100% {background-color: orange;}
|
||||||
|
}
|
||||||
|
.border,.rain{
|
||||||
|
-webkit-animation-direction: normal;
|
||||||
|
-webkit-animation-duration: 20s;
|
||||||
|
-webkit-animation-iteration-count: infinite;
|
||||||
|
-webkit-animation-name: colors;
|
||||||
|
-webkit-animation-timing-function: ease;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* In-Active State Style */
|
||||||
|
.border.unfocus{
|
||||||
|
background: #333 !important;
|
||||||
|
-moz-box-shadow: 0px 0px 15px rgba(255,255,255,.2);
|
||||||
|
-webkit-box-shadow: 0px 0px 15px rgba(255,255,255,.2);
|
||||||
|
box-shadow: 0px 0px 15px rgba(255,255,255,.2);
|
||||||
|
-webkit-animation-name: none;
|
||||||
|
}
|
||||||
|
.rain.unfocus{
|
||||||
|
background: #000 !important;
|
||||||
|
-webkit-animation-name: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Regular Form Styles */
|
||||||
|
form{
|
||||||
|
background: darkred;
|
||||||
|
-moz-border-radius: 5px;
|
||||||
|
-webkit-border-radius: 5px;
|
||||||
|
border-radius: 5px;
|
||||||
|
height: 100%;
|
||||||
|
width: 335%;
|
||||||
|
background: -moz-radial-gradient(50% 46% 90deg,circle closest-corner, white, lightblue);
|
||||||
|
background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 150, from(lightcyan), to(lightblue));
|
||||||
|
}
|
||||||
|
form label{
|
||||||
|
display: block;
|
||||||
|
padding: 10px 10px 5px 15px;
|
||||||
|
font-size: 20px;
|
||||||
|
color: hotpink;
|
||||||
|
}
|
||||||
|
|
||||||
|
form textarea{
|
||||||
|
display: block;
|
||||||
|
margin: 5px 10px 10px 15px;
|
||||||
|
width: 85%;
|
||||||
|
background: #f0f8ff;
|
||||||
|
-moz-box-shadow: 0px 0px 4px grey inset;
|
||||||
|
-webkit-box-shadow: 0px 0px 4px grey inset;
|
||||||
|
box-shadow: 0px 0px 4px grey inset;
|
||||||
|
outline: 1px solid black;
|
||||||
|
border: 1px solid grey;
|
||||||
|
padding: 5px;
|
||||||
|
color: lightgrey;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
form textarea:focus{
|
||||||
|
outline: 2px solid white;
|
||||||
|
color: black;
|
||||||
|
background-color: white;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,4 @@
|
|||||||
|
@CHARSET "UTF-8";
|
||||||
|
.tab{
|
||||||
|
width:30%;
|
||||||
|
}
|
@ -0,0 +1,80 @@
|
|||||||
|
/*!
|
||||||
|
* classie - class helper functions
|
||||||
|
* from bonzo https://github.com/ded/bonzo
|
||||||
|
*
|
||||||
|
* classie.has( elem, 'my-class' ) -> true/false
|
||||||
|
* classie.add( elem, 'my-new-class' )
|
||||||
|
* classie.remove( elem, 'my-unwanted-class' )
|
||||||
|
* classie.toggle( elem, 'my-class' )
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*jshint browser: true, strict: true, undef: true */
|
||||||
|
/*global define: false */
|
||||||
|
|
||||||
|
( function( window ) {
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
// class helper functions from bonzo https://github.com/ded/bonzo
|
||||||
|
|
||||||
|
function classReg( className ) {
|
||||||
|
return new RegExp("(^|\\s+)" + className + "(\\s+|$)");
|
||||||
|
}
|
||||||
|
|
||||||
|
// classList support for class management
|
||||||
|
// altho to be fair, the api sucks because it won't accept multiple classes at once
|
||||||
|
var hasClass, addClass, removeClass;
|
||||||
|
|
||||||
|
if ( 'classList' in document.documentElement ) {
|
||||||
|
hasClass = function( elem, c ) {
|
||||||
|
return elem.classList.contains( c );
|
||||||
|
};
|
||||||
|
addClass = function( elem, c ) {
|
||||||
|
elem.classList.add( c );
|
||||||
|
};
|
||||||
|
removeClass = function( elem, c ) {
|
||||||
|
elem.classList.remove( c );
|
||||||
|
};
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
hasClass = function( elem, c ) {
|
||||||
|
return classReg( c ).test( elem.className );
|
||||||
|
};
|
||||||
|
addClass = function( elem, c ) {
|
||||||
|
if ( !hasClass( elem, c ) ) {
|
||||||
|
elem.className = elem.className + ' ' + c;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
removeClass = function( elem, c ) {
|
||||||
|
elem.className = elem.className.replace( classReg( c ), ' ' );
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
function toggleClass( elem, c ) {
|
||||||
|
var fn = hasClass( elem, c ) ? removeClass : addClass;
|
||||||
|
fn( elem, c );
|
||||||
|
}
|
||||||
|
|
||||||
|
var classie = {
|
||||||
|
// full names
|
||||||
|
hasClass: hasClass,
|
||||||
|
addClass: addClass,
|
||||||
|
removeClass: removeClass,
|
||||||
|
toggleClass: toggleClass,
|
||||||
|
// short names
|
||||||
|
has: hasClass,
|
||||||
|
add: addClass,
|
||||||
|
remove: removeClass,
|
||||||
|
toggle: toggleClass
|
||||||
|
};
|
||||||
|
|
||||||
|
// transport
|
||||||
|
if ( typeof define === 'function' && define.amd ) {
|
||||||
|
// AMD
|
||||||
|
define( classie );
|
||||||
|
} else {
|
||||||
|
// browser global
|
||||||
|
window.classie = classie;
|
||||||
|
}
|
||||||
|
|
||||||
|
})( window );
|
@ -0,0 +1,786 @@
|
|||||||
|
/*!
|
||||||
|
* css-filters-polyfill.js
|
||||||
|
*
|
||||||
|
* Author: Christian Schepp Schaefer
|
||||||
|
* Summary: A polyfill for CSS filter effects
|
||||||
|
* License: MIT
|
||||||
|
* Version: 0.22
|
||||||
|
*
|
||||||
|
* URL:
|
||||||
|
* https://github.com/Schepp/
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
;(function(window){
|
||||||
|
var polyfilter = {
|
||||||
|
// Detect if we are dealing with IE <= 9
|
||||||
|
// http://james.padolsey.com/javascript/detect-_ie-in-js-using-conditional-comments/
|
||||||
|
_ie: (function(){
|
||||||
|
var undef,
|
||||||
|
v = 3,
|
||||||
|
div = document.createElement('div'),
|
||||||
|
all = div.getElementsByTagName('i');
|
||||||
|
|
||||||
|
while(
|
||||||
|
div.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->',
|
||||||
|
all[0]
|
||||||
|
);
|
||||||
|
|
||||||
|
return v > 4 ? v : undef;
|
||||||
|
}()),
|
||||||
|
|
||||||
|
_svg_cache: {},
|
||||||
|
|
||||||
|
_create_svg_element: function(tagname,attributes){
|
||||||
|
var xmlns = 'http://www.w3.org/2000/svg';
|
||||||
|
var elem = document.createElementNS(xmlns,tagname);
|
||||||
|
for(key in attributes){
|
||||||
|
elem.setAttributeNS(null,key,attributes[key]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return elem;
|
||||||
|
},
|
||||||
|
|
||||||
|
_create_svg: function(id,filterelements){
|
||||||
|
var xmlns = 'http://www.w3.org/2000/svg';
|
||||||
|
var svg = document.createElementNS(xmlns,'svg');
|
||||||
|
svg.setAttributeNS(null,'width','0');
|
||||||
|
svg.setAttributeNS(null,'height','0');
|
||||||
|
svg.setAttributeNS(null,'style','position:absolute');
|
||||||
|
|
||||||
|
var svg_filter = document.createElementNS(xmlns,'filter');
|
||||||
|
svg_filter.setAttributeNS(null,'id',id);
|
||||||
|
svg.appendChild(svg_filter);
|
||||||
|
|
||||||
|
for(var i = 0; i < filterelements.length; i++){
|
||||||
|
svg_filter.appendChild(filterelements[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return svg;
|
||||||
|
},
|
||||||
|
|
||||||
|
_pending_stylesheets: 0,
|
||||||
|
|
||||||
|
_stylesheets: [],
|
||||||
|
|
||||||
|
_development_mode: (function(){
|
||||||
|
if(location.hostname === 'localhost' || location.hostname.search(/.local$/) !== -1 || location.hostname.search(/\d+\.\d+\.\d+\.\d+/) !== -1){
|
||||||
|
if(window.console) console.log('Detected localhost or IP address. Assuming you are a developer. Caching of stylesheets is disabled.');
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if(window.console) console.log('Caching of stylesheets is enabled. You need to refresh twice to see any changes.');
|
||||||
|
return false;
|
||||||
|
})(),
|
||||||
|
|
||||||
|
process_stylesheets: function(){
|
||||||
|
var xmlHttp = [];
|
||||||
|
|
||||||
|
// Check if path to library is correct, do that 2 secs. after this to not disturb initial processing
|
||||||
|
window.setTimeout(function(){
|
||||||
|
if (window.XMLHttpRequest) {
|
||||||
|
var xmlHttpCheck = new XMLHttpRequest();
|
||||||
|
} else if (window.ActiveXObject) {
|
||||||
|
var xmlHttpCheck = new ActiveXObject("Microsoft.XMLHTTP");
|
||||||
|
}
|
||||||
|
xmlHttpCheck.open('GET', window.polyfilter_scriptpath + 'htc/sepia.htc', true);
|
||||||
|
xmlHttpCheck.onreadystatechange = function(){
|
||||||
|
if(xmlHttp.readyState == 4 && xmlHttp.status != 200){
|
||||||
|
alert('The configured path \r\rvar polyfilter_scriptpath = "' + window.polyfilter_scriptpath + '"\r\rseems wrong!\r\rConfigure the polyfill\'s correct absolute(!) script path before referencing the css-filters-polyfill.js, like so:\r\rvar polyfilter_scriptpath = "/js/css-filters-polyfill/";\r\rLeaving IE dead in the water is no option. You damn Mac user... ;)');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
try{
|
||||||
|
xmlHttpCheck.send(null);
|
||||||
|
} catch(e){}
|
||||||
|
},2000);
|
||||||
|
|
||||||
|
|
||||||
|
var stylesheets = document.querySelectorAll ? document.querySelectorAll('style,link[rel="stylesheet"]') : document.getElementsByTagName('*');
|
||||||
|
|
||||||
|
for(var i = 0; i < stylesheets.length; i++){
|
||||||
|
(function(i){
|
||||||
|
switch(stylesheets[i].nodeName){
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'STYLE':
|
||||||
|
polyfilter._stylesheets.push({
|
||||||
|
media: stylesheets[i].media || 'all',
|
||||||
|
content: stylesheets[i].innerHTML
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'LINK':
|
||||||
|
if(stylesheets[i].rel === 'stylesheet'){
|
||||||
|
var index = polyfilter._stylesheets.length;
|
||||||
|
|
||||||
|
polyfilter._stylesheets.push({
|
||||||
|
media: stylesheets[i].media || 'all'
|
||||||
|
});
|
||||||
|
|
||||||
|
polyfilter._pending_stylesheets++;
|
||||||
|
|
||||||
|
// Fetch external stylesheet
|
||||||
|
var href = stylesheets[i].href;
|
||||||
|
|
||||||
|
// Use localStorage as cache for stylesheets, if available
|
||||||
|
if(!polyfilter._development_mode && window.localStorage && window.localStorage.getItem('polyfilter_' + href)){
|
||||||
|
polyfilter._pending_stylesheets--;
|
||||||
|
polyfilter._stylesheets[index].content = localStorage.getItem('polyfilter_' + href);
|
||||||
|
if(polyfilter._pending_stylesheets === 0){
|
||||||
|
polyfilter.process();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Always fetch stylesheets to reflect possible changes
|
||||||
|
try{
|
||||||
|
if(window.XMLHttpRequest) {
|
||||||
|
var xmlHttp = new XMLHttpRequest();
|
||||||
|
} else if(window.ActiveXObject) {
|
||||||
|
var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
|
||||||
|
}
|
||||||
|
xmlHttp.open('GET', href, true);
|
||||||
|
xmlHttp.onreadystatechange = function(){
|
||||||
|
if(xmlHttp.readyState === 4){
|
||||||
|
if(xmlHttp.status === 0){
|
||||||
|
if(window.console) console.log('Could not fetch external CSS via HTTP-Request ' + href + '. Probably because of cross origin.');
|
||||||
|
if(!polyfilter._stylesheets[index].content){
|
||||||
|
polyfilter._pending_stylesheets--;
|
||||||
|
polyfilter._stylesheets[index].content = xmlHttp.responseText;
|
||||||
|
if(polyfilter._pending_stylesheets === 0){
|
||||||
|
polyfilter.process();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if(!polyfilter._stylesheets[index].content){
|
||||||
|
polyfilter._pending_stylesheets--;
|
||||||
|
polyfilter._stylesheets[index].content = xmlHttp.responseText;
|
||||||
|
if(polyfilter._pending_stylesheets === 0){
|
||||||
|
polyfilter.process();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Cache stylesheet in localStorage, if available
|
||||||
|
if(!polyfilter._development_mode && window.localStorage){
|
||||||
|
try{
|
||||||
|
window.localStorage.setItem('polyfilter_' + href,polyfilter._stylesheets[index].content)
|
||||||
|
}
|
||||||
|
catch(e){
|
||||||
|
if(window.console) console.log('Local storage quota have been exceeded. Caching of stylesheet ' + href + ' is not possible');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
try{
|
||||||
|
xmlHttp.send(null);
|
||||||
|
} catch(e){
|
||||||
|
if(window.console) console.log('Could not fetch external CSS via HTTP-Request ' + href + '. Are you maybe testing using the file://-protocol?');
|
||||||
|
if(!polyfilter._stylesheets[index].content){
|
||||||
|
polyfilter._pending_stylesheets--;
|
||||||
|
if(polyfilter._pending_stylesheets === 0){
|
||||||
|
polyfilter.process();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch(e){}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
})(i);
|
||||||
|
}
|
||||||
|
if(this._pending_stylesheets === 0){
|
||||||
|
this.process();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_processDeclarations: function(rule){
|
||||||
|
var newstyles = '';
|
||||||
|
for(var k in rule.declarations){
|
||||||
|
var declaration = rule.declarations[k];
|
||||||
|
|
||||||
|
if(declaration.property === 'filter'){
|
||||||
|
|
||||||
|
if(document.querySelectorAll){
|
||||||
|
var elems = document.querySelectorAll(rule.mSelectorText);
|
||||||
|
for(var k = 0; k < elems.length; k++){
|
||||||
|
elems[k].style.polyfilterStore = declaration.valueText;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var gluedvalues = declaration.valueText;
|
||||||
|
var values = gluedvalues.split(/\)\s+/),
|
||||||
|
properties = {
|
||||||
|
filtersW3C: [],
|
||||||
|
filtersWebKit: [],
|
||||||
|
filtersSVG: [],
|
||||||
|
filtersIE: [],
|
||||||
|
behaviorsIE: []
|
||||||
|
};
|
||||||
|
|
||||||
|
for(idx in values){
|
||||||
|
var value = values[idx] + ')';
|
||||||
|
|
||||||
|
currentproperties = polyfilter.convert(value);
|
||||||
|
|
||||||
|
for(key in currentproperties){
|
||||||
|
if(typeof properties[key] !== 'undefined'){
|
||||||
|
properties[key] = properties[key].concat(currentproperties[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
newstyles += rule.mSelectorText + '{';
|
||||||
|
if(properties['filtersW3C'].length > 0){
|
||||||
|
var filter =
|
||||||
|
webkitFilter =
|
||||||
|
mozFilter =
|
||||||
|
oFilter =
|
||||||
|
msFilter =
|
||||||
|
properties['filtersW3C'].join(' ');
|
||||||
|
|
||||||
|
if(properties['filtersWebKit'] && properties['filtersWebKit'].length > 0){
|
||||||
|
webkitFilter = properties['filtersWebKit'].join(' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(typeof this._ie === 'undefined'){
|
||||||
|
newstyles += '-ms-filter:' + msFilter + ';';
|
||||||
|
}
|
||||||
|
|
||||||
|
newstyles += '-webkit-filter:' + webkitFilter + ';';
|
||||||
|
newstyles += '-moz-filter:' + mozFilter + ';';
|
||||||
|
newstyles += '-o-filter:' + oFilter + ';';
|
||||||
|
}
|
||||||
|
if(properties['filtersSVG'].length > 0){
|
||||||
|
if(properties['filtersSVG'][0] != 'none'){
|
||||||
|
var id = gluedvalues.replace(/[^a-z0-9]/g,'');
|
||||||
|
|
||||||
|
if(typeof this._svg_cache[id] === 'undefined'){
|
||||||
|
this._svg_cache[id] = this._create_svg(id,properties['filtersSVG']);
|
||||||
|
|
||||||
|
if(typeof XMLSerializer === 'undefined'){
|
||||||
|
document.body.appendChild(this._svg_cache[id]);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var s = new XMLSerializer();
|
||||||
|
var svgString = s.serializeToString(this._svg_cache[id]);
|
||||||
|
if(svgString.search('SourceGraphic') != -1){
|
||||||
|
document.body.appendChild(this._svg_cache[id]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(typeof XMLSerializer === 'undefined'){
|
||||||
|
newstyles += 'filter: url(#' + id + ')';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var s = new XMLSerializer();
|
||||||
|
var svgString = s.serializeToString(this._svg_cache[id]);
|
||||||
|
|
||||||
|
if(svgString.search('SourceGraphic') != -1){
|
||||||
|
newstyles += 'filter: url(#' + id + ')';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
newstyles += 'filter: url(\'data:image/svg+xml;utf8,' + svgString + '#' + id + '\')';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
newstyles += 'filter: none;';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(typeof this._ie !== 'undefined'){
|
||||||
|
if(properties['filtersIE'].length > 0){
|
||||||
|
var filtersIE = properties['filtersIE'].join(' ');
|
||||||
|
|
||||||
|
newstyles += 'filter:' + filtersIE + ';';
|
||||||
|
}
|
||||||
|
if(properties['behaviorsIE'].length > 0){
|
||||||
|
var behaviorsIE = properties['behaviorsIE'].join(' ');
|
||||||
|
|
||||||
|
newstyles += 'behavior:' + behaviorsIE + ';';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
newstyles += '}\r\n';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return newstyles;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Absolute path to the .htc-files
|
||||||
|
scriptpath:
|
||||||
|
window.polyfilter_scriptpath ? window.polyfilter_scriptpath : (function(){
|
||||||
|
alert('Please configure the polyfill\'s absolute(!) script path before referencing the css-filters-polyfill.js, like so:\r\nvar polyfilter_scriptpath = "/js/css-filters-polyfill/";');
|
||||||
|
return './'
|
||||||
|
})(),
|
||||||
|
|
||||||
|
// process stylesheets
|
||||||
|
process: function(){
|
||||||
|
var parser = new CSSParser();
|
||||||
|
|
||||||
|
for(var i = 0; i < this._stylesheets.length; i++){
|
||||||
|
var newstyles = '';
|
||||||
|
var sheet = parser.parse(this._stylesheets[i].content, false, true);
|
||||||
|
if(sheet !== null) for(var j in sheet.cssRules){
|
||||||
|
var rule = sheet.cssRules[j];
|
||||||
|
|
||||||
|
switch(rule.type){
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
newstyles += this._processDeclarations(rule);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 4:
|
||||||
|
newstyles += '@media ' + rule.media.join(',') + '{';
|
||||||
|
for(var k in rule.cssRules){
|
||||||
|
var mediarule = rule.cssRules[k];
|
||||||
|
|
||||||
|
newstyles += this._processDeclarations(mediarule);
|
||||||
|
}
|
||||||
|
newstyles += '}';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var newstylesheet = document.createElement('style');
|
||||||
|
newstylesheet.setAttribute('media',this._stylesheets[i].media);
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
newstylesheet.innerHTML = newstyles;
|
||||||
|
document.getElementsByTagName('head')[0].appendChild(newstylesheet);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
document.getElementsByTagName('head')[0].appendChild(newstylesheet);
|
||||||
|
newstylesheet.styleSheet.cssText = newstyles;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
init: function(){
|
||||||
|
if(Object.defineProperty){
|
||||||
|
Object.defineProperty(CSSStyleDeclaration.prototype, 'polyfilter', {
|
||||||
|
get: function(){
|
||||||
|
return this.polyfilterStore;
|
||||||
|
},
|
||||||
|
set: function(gluedvalues){
|
||||||
|
values = gluedvalues.split(/\)\s+/);
|
||||||
|
var properties = {
|
||||||
|
filtersW3C: [],
|
||||||
|
filtersWebKit: [],
|
||||||
|
filtersSVG: [],
|
||||||
|
filtersIE: [],
|
||||||
|
behaviorsIE: []
|
||||||
|
}
|
||||||
|
|
||||||
|
for(idx in values){
|
||||||
|
var value = values[idx] + ')';
|
||||||
|
|
||||||
|
currentproperties = polyfilter.convert(value);
|
||||||
|
|
||||||
|
for(key in currentproperties){
|
||||||
|
if(typeof properties[key] !== 'undefined'){
|
||||||
|
properties[key] = properties[key].concat(currentproperties[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(properties['filtersW3C'].length > 0){
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
this.msFilter =
|
||||||
|
properties['filtersW3C'].join(' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
this.webkitFilter =
|
||||||
|
this.mozFilter =
|
||||||
|
this.oFilter =
|
||||||
|
properties['filtersW3C'].join(' ');
|
||||||
|
}
|
||||||
|
if(properties['filtersWebKit'].length > 0){
|
||||||
|
this.webkitFilter = properties['filtersWebKit'].join(' ');
|
||||||
|
}
|
||||||
|
if(properties['filtersSVG'].length > 0){
|
||||||
|
if(properties['filtersSVG'][0] != 'none'){
|
||||||
|
var id = gluedvalues.replace(/[^a-z0-9]/g,'');
|
||||||
|
|
||||||
|
if(typeof polyfilter._svg_cache[id] === 'undefined'){
|
||||||
|
polyfilter._svg_cache[id] = polyfilter._create_svg(id,properties['filtersSVG']);
|
||||||
|
|
||||||
|
if(typeof XMLSerializer === 'undefined'){
|
||||||
|
document.body.appendChild(polyfilter._svg_cache[id]);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var s = new XMLSerializer();
|
||||||
|
var svgString = s.serializeToString(polyfilter._svg_cache[id]);
|
||||||
|
if(svgString.search('SourceGraphic') != -1){
|
||||||
|
document.body.appendChild(polyfilter._svg_cache[id]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(typeof XMLSerializer === 'undefined'){
|
||||||
|
this.filter = 'url(#' + id + ')';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var s = new XMLSerializer();
|
||||||
|
var svgString = s.serializeToString(polyfilter._svg_cache[id]);
|
||||||
|
if(svgString.search('SourceGraphic') != -1){
|
||||||
|
this.filter = 'url(#' + id + ')';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.filter = 'url(\'data:image/svg+xml;utf8,' + svgString + '#' + id + '\')';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.filter = 'none';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(typeof polyfilter._ie !== 'undefined'){
|
||||||
|
if(properties['filtersIE'].length > 0){
|
||||||
|
this.filter =
|
||||||
|
properties['filtersIE'].join(' ');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.filter = '';
|
||||||
|
}
|
||||||
|
if(properties['behaviorsIE'].length > 0){
|
||||||
|
this.behavior =
|
||||||
|
properties['behaviorsIE'].join(' ');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.behavior = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.polyfilterStore = gluedvalues;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
convert: function(value){
|
||||||
|
// None
|
||||||
|
var fmatch = value.match(/none/i);
|
||||||
|
if(fmatch !== null){
|
||||||
|
var properties = this.filters.none();
|
||||||
|
}
|
||||||
|
// Grayscale
|
||||||
|
var fmatch = value.match(/(grayscale)\(([0-9\.]+)\)/i);
|
||||||
|
if(fmatch !== null){
|
||||||
|
var amount = parseFloat(fmatch[2],10),
|
||||||
|
properties = this.filters.grayscale(amount);
|
||||||
|
}
|
||||||
|
// Sepia
|
||||||
|
var fmatch = value.match(/(sepia)\(([0-9\.]+)\)/i);
|
||||||
|
if(fmatch !== null){
|
||||||
|
var amount = parseFloat(fmatch[2],10),
|
||||||
|
properties = this.filters.sepia(amount);
|
||||||
|
}
|
||||||
|
// Blur
|
||||||
|
var fmatch = value.match(/(blur)\(([0-9]+)[px]*\)/i);
|
||||||
|
if(fmatch !== null){
|
||||||
|
var amount = parseInt(fmatch[2],10),
|
||||||
|
properties = this.filters.blur(amount);
|
||||||
|
}
|
||||||
|
// Invert
|
||||||
|
var fmatch = value.match(/(invert)\(([0-9\.]+)\)/i);
|
||||||
|
if(fmatch !== null){
|
||||||
|
var amount = parseFloat(fmatch[2],10),
|
||||||
|
properties = this.filters.invert(amount);
|
||||||
|
}
|
||||||
|
// Brightness
|
||||||
|
var fmatch = value.match(/(brightness)\(([0-9\.]+)%\)/i);
|
||||||
|
if(fmatch !== null){
|
||||||
|
var amount = parseFloat(fmatch[2],10),
|
||||||
|
properties = this.filters.brightness(amount);
|
||||||
|
}
|
||||||
|
// Drop Shadow
|
||||||
|
var fmatch = value.match(/(drop\-shadow)\(([0-9]+)[px]*\s+([0-9]+)[px]*\s+([0-9]+)[px]*\s+([#0-9]+)\)/i);
|
||||||
|
if(fmatch !== null){
|
||||||
|
var offsetX = parseInt(fmatch[2],10),
|
||||||
|
offsetY = parseInt(fmatch[3],10),
|
||||||
|
radius = parseInt(fmatch[4],10),
|
||||||
|
color = fmatch[5],
|
||||||
|
properties = this.filters.dropShadow(offsetX,offsetY,radius,color);
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
},
|
||||||
|
|
||||||
|
// EFFECTS SECTION -------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
filters: {
|
||||||
|
// None
|
||||||
|
none: function(){
|
||||||
|
var properties = {};
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
// Proposed spec
|
||||||
|
properties['filtersW3C'] = ['none'];
|
||||||
|
|
||||||
|
// Firefox
|
||||||
|
properties['filtersSVG'] = ['none'];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// IE
|
||||||
|
properties['filtersIE'] = ['none'];
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Grayscale
|
||||||
|
grayscale: function(amount){
|
||||||
|
amount = amount || 0;
|
||||||
|
|
||||||
|
var properties = {};
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
// Proposed spec
|
||||||
|
properties['filtersW3C'] = ['grayscale(' + amount + ')'];
|
||||||
|
|
||||||
|
// Firefox
|
||||||
|
// https://dvcs.w3.org/hg/FXTF/raw-file/tip/filters/index.html
|
||||||
|
var svg_fe1 = polyfilter._create_svg_element('feColorMatrix',{
|
||||||
|
type: 'matrix',
|
||||||
|
values: (0.2126 + 0.7874 * (1 - amount)) + ' '
|
||||||
|
+ (0.7152 - 0.7152 * (1 - amount)) + ' '
|
||||||
|
+ (0.0722 - 0.0722 * (1 - amount)) + ' 0 0 '
|
||||||
|
+ (0.2126 - 0.2126 * (1 - amount)) + ' '
|
||||||
|
+ (0.7152 + 0.2848 * (1 - amount)) + ' '
|
||||||
|
+ (0.0722 - 0.0722 * (1 - amount)) + ' 0 0 '
|
||||||
|
+ (0.2126 - 0.2126 * (1 - amount)) + ' '
|
||||||
|
+ (0.7152 - 0.7152 * (1 - amount)) + ' '
|
||||||
|
+ (0.0722 + 0.9278 * (1 - amount)) + ' 0 0 0 0 0 1 0'
|
||||||
|
});
|
||||||
|
properties['filtersSVG'] = [svg_fe1];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// IE
|
||||||
|
properties['filtersIE'] = amount >= 0.5 ? ['gray'] : [];
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Sepia
|
||||||
|
sepia: function(amount){
|
||||||
|
amount = amount || 0;
|
||||||
|
|
||||||
|
var properties = {};
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
|
||||||
|
// Proposed spec
|
||||||
|
properties['filtersW3C'] = ['sepia(' + amount + ')'];
|
||||||
|
|
||||||
|
// Firefox
|
||||||
|
// https://dvcs.w3.org/hg/FXTF/raw-file/tip/filters/index.html
|
||||||
|
var svg_fe1 = polyfilter._create_svg_element('feColorMatrix',{
|
||||||
|
type: 'matrix',
|
||||||
|
values: (0.393 + 0.607 * (1 - amount)) + ' '
|
||||||
|
+ (0.769 - 0.769 * (1 - amount)) + ' '
|
||||||
|
+ (0.189 - 0.189 * (1 - amount)) + ' 0 0 '
|
||||||
|
+ (0.349 - 0.349 * (1 - amount)) + ' '
|
||||||
|
+ (0.686 + 0.314 * (1 - amount)) + ' '
|
||||||
|
+ (0.168 - 0.168 * (1 - amount)) + ' 0 0 '
|
||||||
|
+ (0.272 - 0.272 * (1 - amount)) + ' '
|
||||||
|
+ (0.534 - 0.534 * (1 - amount)) + ' '
|
||||||
|
+ (0.131 + 0.869 * (1 - amount)) + ' 0 0 0 0 0 1 0'
|
||||||
|
});
|
||||||
|
properties['filtersSVG'] = [svg_fe1];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// IE
|
||||||
|
properties['filtersIE'] = amount >= 0.5 ? ['gray','progid:DXImageTransform.Microsoft.Light()'] : [];
|
||||||
|
properties['behaviorsIE'] = amount >= 0.5 ? ['url("' + polyfilter.scriptpath + 'htc/sepia.htc")'] : [];
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Blur
|
||||||
|
blur: function(amount){
|
||||||
|
amount = Math.round(amount) || 0;
|
||||||
|
|
||||||
|
var properties = {};
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
// Proposed spec
|
||||||
|
properties['filtersW3C'] = ['blur(' + amount + 'px)'];
|
||||||
|
|
||||||
|
// Firefox
|
||||||
|
// https://dvcs.w3.org/hg/FXTF/raw-file/tip/filters/index.html
|
||||||
|
var svg_fe1 = polyfilter._create_svg_element('feGaussianBlur',{
|
||||||
|
'in': 'SourceGraphic',
|
||||||
|
stdDeviation: amount
|
||||||
|
});
|
||||||
|
properties['filtersSVG'] = [svg_fe1];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// IE
|
||||||
|
properties['filtersIE'] = ['progid:DXImageTransform.Microsoft.Blur(pixelradius=' + amount + ')'];
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Invert
|
||||||
|
invert: function(amount){
|
||||||
|
amount = amount || 0;
|
||||||
|
|
||||||
|
var properties = {};
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
// Proposed spec
|
||||||
|
properties['filtersW3C'] = ['invert(' + amount + ')'];
|
||||||
|
|
||||||
|
// Firefox
|
||||||
|
// https://dvcs.w3.org/hg/FXTF/raw-file/tip/filters/index.html
|
||||||
|
var svg_fe1 = polyfilter._create_svg_element('feComponentTransfer',{});
|
||||||
|
var svg_fe1sub = polyfilter._create_svg_element('feFuncR',{
|
||||||
|
type: 'table',
|
||||||
|
tableValues: amount + ' ' + (1 - amount)
|
||||||
|
});
|
||||||
|
svg_fe1.appendChild(svg_fe1sub);
|
||||||
|
var svg_fe1sub = polyfilter._create_svg_element('feFuncG',{
|
||||||
|
type: 'table',
|
||||||
|
tableValues: amount + ' ' + (1 - amount)
|
||||||
|
});
|
||||||
|
svg_fe1.appendChild(svg_fe1sub);
|
||||||
|
var svg_fe1sub = polyfilter._create_svg_element('feFuncB',{
|
||||||
|
type: 'table',
|
||||||
|
tableValues: amount + ' ' + (1 - amount)
|
||||||
|
});
|
||||||
|
svg_fe1.appendChild(svg_fe1sub);
|
||||||
|
properties['filtersSVG'] = [svg_fe1];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// IE
|
||||||
|
properties['filtersIE'] = amount >= 0.5 ? ['invert'] : [];
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Brightness
|
||||||
|
brightness: function(amount){
|
||||||
|
amount = amount || 0;
|
||||||
|
|
||||||
|
var properties = {};
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
// Proposed spec
|
||||||
|
properties['filtersW3C'] = ['brightness(' + amount + '%)'];
|
||||||
|
|
||||||
|
// WebKit "specialty"
|
||||||
|
properties['filtersWebKit'] = ['brightness(' + (amount - 100) + '%)'];
|
||||||
|
|
||||||
|
// Firefox
|
||||||
|
// https://dvcs.w3.org/hg/FXTF/raw-file/tip/filters/index.html
|
||||||
|
var svg_fe1 = polyfilter._create_svg_element('feComponentTransfer',{});
|
||||||
|
var svg_fe1sub = polyfilter._create_svg_element('feFuncR',{
|
||||||
|
type: 'linear',
|
||||||
|
slope: amount / 100
|
||||||
|
});
|
||||||
|
svg_fe1.appendChild(svg_fe1sub);
|
||||||
|
var svg_fe1sub = polyfilter._create_svg_element('feFuncG',{
|
||||||
|
type: 'linear',
|
||||||
|
slope: amount / 100
|
||||||
|
});
|
||||||
|
svg_fe1.appendChild(svg_fe1sub);
|
||||||
|
var svg_fe1sub = polyfilter._create_svg_element('feFuncB',{
|
||||||
|
type: 'linear',
|
||||||
|
slope: amount / 100
|
||||||
|
});
|
||||||
|
svg_fe1.appendChild(svg_fe1sub);
|
||||||
|
properties['filtersSVG'] = [svg_fe1];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// IE
|
||||||
|
properties['filtersIE'] = ['progid:DXImageTransform.Microsoft.Light()'];
|
||||||
|
properties['behaviorsIE'] = ['url("' + polyfilter.scriptpath + 'htc/brightness.htc")'];
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Drop Shadow
|
||||||
|
dropShadow: function(offsetX,offsetY,radius,color){
|
||||||
|
offsetX = Math.round(offsetX) || 0;
|
||||||
|
offsetY = Math.round(offsetY) || 0;
|
||||||
|
radius = Math.round(radius) || 0;
|
||||||
|
color = color || '#000000';
|
||||||
|
|
||||||
|
var properties = {};
|
||||||
|
|
||||||
|
if(typeof polyfilter._ie === 'undefined'){
|
||||||
|
// Proposed spec
|
||||||
|
properties['filtersW3C'] = ['drop-shadow(' + offsetX + 'px ' + offsetY + 'px ' + radius + 'px ' + color + ')'];
|
||||||
|
|
||||||
|
// Firefox
|
||||||
|
// https://dvcs.w3.org/hg/FXTF/raw-file/tip/filters/index.html
|
||||||
|
var svg_fe1 = polyfilter._create_svg_element('feGaussianBlur',{
|
||||||
|
'in': 'SourceAlpha',
|
||||||
|
stdDeviation: radius
|
||||||
|
});
|
||||||
|
var svg_fe2 = polyfilter._create_svg_element('feOffset',{
|
||||||
|
dx: offsetX + 1,
|
||||||
|
dy: offsetY + 1,
|
||||||
|
result: 'offsetblur'
|
||||||
|
});
|
||||||
|
var svg_fe3 = polyfilter._create_svg_element('feFlood',{
|
||||||
|
'flood-color': color
|
||||||
|
});
|
||||||
|
var svg_fe4 = polyfilter._create_svg_element('feComposite',{
|
||||||
|
in2: 'offsetblur',
|
||||||
|
operator: 'in'
|
||||||
|
});
|
||||||
|
var svg_fe5 = polyfilter._create_svg_element('feMerge',{});
|
||||||
|
var svg_fe5sub = polyfilter._create_svg_element('feMergeNode',{});
|
||||||
|
svg_fe5.appendChild(svg_fe5sub);
|
||||||
|
var svg_fe5sub = polyfilter._create_svg_element('feMergeNode',{
|
||||||
|
'in': 'SourceGraphic'
|
||||||
|
});
|
||||||
|
svg_fe5.appendChild(svg_fe5sub);
|
||||||
|
properties['filtersSVG'] = [svg_fe1,svg_fe2,svg_fe3,svg_fe4,svg_fe5];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// IE
|
||||||
|
properties['filtersIE'] = ['progid:DXImageTransform.Microsoft.Glow(color=' + color + ',strength=0)','progid:DXImageTransform.Microsoft.Shadow(color=' + color + ',strength=0)'];
|
||||||
|
properties['behaviorsIE'] = ['url("' + polyfilter.scriptpath + 'htc/drop-shadow.htc")'];
|
||||||
|
}
|
||||||
|
|
||||||
|
return properties;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Inialize, either via jQuery...
|
||||||
|
if(window.jQuery){
|
||||||
|
window.jQuery(document).ready(function(e) {
|
||||||
|
polyfilter.process_stylesheets();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
// or via contentLoaded...
|
||||||
|
else if(window.contentLoaded){
|
||||||
|
contentLoaded(window,function(){
|
||||||
|
polyfilter.process_stylesheets();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
// or on DOM ready / load
|
||||||
|
else {
|
||||||
|
if(window.addEventListener) // W3C standard
|
||||||
|
{
|
||||||
|
document.addEventListener('DOMContentLoaded', function(){
|
||||||
|
polyfilter.process_stylesheets();
|
||||||
|
}, false);
|
||||||
|
}
|
||||||
|
else if(window.attachEvent) // Microsoft
|
||||||
|
{
|
||||||
|
window.attachEvent('onload', function(){
|
||||||
|
polyfilter.process_stylesheets();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Install style setters and getters
|
||||||
|
polyfilter.init();
|
||||||
|
})(window);
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,57 @@
|
|||||||
|
/**
|
||||||
|
* modalEffects.js v1.0.0
|
||||||
|
* http://www.codrops.com
|
||||||
|
*
|
||||||
|
* Licensed under the MIT license.
|
||||||
|
* http://www.opensource.org/licenses/mit-license.php
|
||||||
|
*
|
||||||
|
* Copyright 2013, Codrops
|
||||||
|
* http://www.codrops.com
|
||||||
|
*/
|
||||||
|
var ModalEffects = (function() {
|
||||||
|
|
||||||
|
function init() {
|
||||||
|
|
||||||
|
var overlay = document.querySelector( '.md-overlay' );
|
||||||
|
|
||||||
|
[].slice.call( document.querySelectorAll( '.md-trigger' ) ).forEach( function( el, i ) {
|
||||||
|
|
||||||
|
var modal = document.querySelector( '#' + el.getAttribute( 'data-modal' ) ),
|
||||||
|
close = modal.querySelector( '.md-close' );
|
||||||
|
|
||||||
|
function removeModal( hasPerspective ) {
|
||||||
|
classie.remove( modal, 'md-show' );
|
||||||
|
|
||||||
|
if( hasPerspective ) {
|
||||||
|
classie.remove( document.documentElement, 'md-perspective' );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeModalHandler() {
|
||||||
|
removeModal( classie.has( el, 'md-setperspective' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
el.addEventListener( 'click', function( ev ) {
|
||||||
|
classie.add( modal, 'md-show' );
|
||||||
|
overlay.removeEventListener( 'click', removeModalHandler );
|
||||||
|
overlay.addEventListener( 'click', removeModalHandler );
|
||||||
|
|
||||||
|
if( classie.has( el, 'md-setperspective' ) ) {
|
||||||
|
setTimeout( function() {
|
||||||
|
classie.add( document.documentElement, 'md-perspective' );
|
||||||
|
}, 25 );
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
close.addEventListener( 'click', function( ev ) {
|
||||||
|
ev.stopPropagation();
|
||||||
|
removeModalHandler();
|
||||||
|
});
|
||||||
|
|
||||||
|
} );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
init();
|
||||||
|
|
||||||
|
})();
|
File diff suppressed because one or more lines are too long
@ -0,0 +1,29 @@
|
|||||||
|
package servlet.reader;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javax.servlet.ServletException;
|
||||||
|
import javax.servlet.annotation.WebServlet;
|
||||||
|
import javax.servlet.http.HttpServlet;
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import javax.servlet.http.HttpSession;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Servlet implementation class exit
|
||||||
|
*/
|
||||||
|
@WebServlet("/reader/exit")
|
||||||
|
public class Exit extends HttpServlet {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
HttpSession session = req.getSession();
|
||||||
|
if (session.getAttribute("reader") != null) {
|
||||||
|
session.removeAttribute("reader");
|
||||||
|
}
|
||||||
|
resp.sendRedirect(req.getContextPath() + "/reader/04readerFrame.jsp");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in new issue