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{ | ||||
| 				background: rgba(0,0,0,1); | ||||
| 				color: #DDD; | ||||
| 				font-family: 'Helvetica', 'Lucida Grande', 'Arial', sans-serif; | ||||
| 			} | ||||
| 			.border{ | ||||
| 				height: 99%; | ||||
| 				width: 30%; | ||||
| 			} | ||||
| 			.rain{ | ||||
| 				height: 400px; | ||||
| 				width: 35%; | ||||
| 			} | ||||
| 			/* Layout with mask */ | ||||
| 			.rain{ | ||||
| 				 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; | ||||
| 				 -webkit-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(0,0,0,1) inset, -9px -9px 8px rgba(0,0,0,1) inset; | ||||
| 				 margin: 100px auto; | ||||
| 			} | ||||
| 			/* Artifical "border" to clear border to bypass mask */ | ||||
| 			.border{ | ||||
| 				padding: 1px; | ||||
| 				-moz-border-radius: 5px; | ||||
| 			    -webkit-border-radius: 5px; | ||||
| 				border-radius: 5px; | ||||
| 			} | ||||
| body{ | ||||
|     background: white; | ||||
|     color: #DDD; | ||||
|     font-family: 'Helvetica', 'Lucida Grande', 'Arial', sans-serif; | ||||
| } | ||||
| .border{ | ||||
|     height: 99%; | ||||
|     width: 30%; | ||||
| } | ||||
| .rain{ | ||||
|     height: 400px; | ||||
|     width: 35%; | ||||
| } | ||||
| /* Layout with mask */ | ||||
| .rain{ | ||||
|     padding: 10px 12px 12px 10px; | ||||
|     -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(255,255,255,1) inset, -9px -9px 8px rgba(255,255,255,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; | ||||
| } | ||||
| /* Artifical "border" to clear border to bypass mask */ | ||||
| .border{ | ||||
|     padding: 1px; | ||||
|     -moz-border-radius: 5px; | ||||
|     -webkit-border-radius: 5px; | ||||
|     border-radius: 5px; | ||||
| } | ||||
| 
 | ||||
| 			.border, | ||||
| 			.rain, | ||||
| 			.border.start, | ||||
| 			.rain.start{ | ||||
| 				background-repeat: repeat-x, repeat-x, repeat-x, repeat-x; | ||||
| 				background-position: 0 0, 0 0, 0 0, 0 0; | ||||
| 				/* Blue-ish Green Fallback for Mozilla */ | ||||
| 				background-image: -moz-linear-gradient(left, #09BA5E 0%, #00C7CE 15%, #3472CF 26%, #00C7CE 48%, #0CCF91 91%, #09BA5E 100%); | ||||
| 				/* 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))); | ||||
| 				/* Starting Color */ | ||||
| 				background-color: #39f; | ||||
| 				/* Just do something for IE-suck */ | ||||
| 				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; | ||||
| 			} | ||||
| .border, | ||||
| .rain, | ||||
| .border.start, | ||||
| .rain.start{ | ||||
|     background-repeat: repeat-x, repeat-x, repeat-x, repeat-x; | ||||
|     background-position: 0 0, 0 0, 0 0, 0 0; | ||||
|     /* Blue-ish Green Fallback for Mozilla */ | ||||
|     background-image: -moz-linear-gradient(left, #09BA5E 0%, #00C7CE 15%, #3472CF 26%, #00C7CE 48%, #0CCF91 91%, #09BA5E 100%); | ||||
|     /* 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))); | ||||
|     /* Starting Color */ | ||||
|     background-color: #39f; | ||||
|     /* Just do something for IE-suck */ | ||||
|     filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00BA1B', endColorstr='#00BA1B',GradientType=1 ); | ||||
| } | ||||
| 
 | ||||
| 			form textarea{ | ||||
| 				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 textarea:focus{ | ||||
| 				outline: 1px solid #555; | ||||
| 				color: #FFF; | ||||
| 			} | ||||
| /* 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: 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