<form class="msform" method="post">
<ul class="progressbar">
<li class="active">Über Dich</li>
<li>Fragen</li>
<li>Spamschutz</li>
</ul>
<fieldset data-check-id="1">
<h2 class="fs-title">Zu Deiner Person</h2>
<h3 class="fs-subtitle">This is step 1</h3>
<input name="name" placeholder="Name">
<input type="email" name="email" placeholder="Email">
<input type="button" name="next" class="next action-button" value="Weiter">
</fieldset>
<fieldset data-check-id="2">
<h2 class="fs-title">Fragen zum Thema</h2>
<h3 class="fs-subtitle">Bitte antworte spontan</h3>
<input name="q1" placeholder="Was denkst Du zu Twitter">
<input name="q2" placeholder="Was denkst Du zu Facebook">
<input name="q3" placeholder="Was denkst Du zu Google Plus">
<input type="button" name="previous" class="previous action-button" value="Zurück">
<input type="button" name="next" class="next action-button" value="Weiter">
</fieldset>
<fieldset data-check-id="3">
<h2 class="fs-title">Spamschutz</h2>
<h3 class="fs-subtitle">Gleich geschafft! (:</h3>
<input class="vtcha-spamschutz">
<input type="button" name="previous" class="previous action-button" value="Zurück" />
<input type="submit" name="submit" class="submit action-button" value="Absenden" />
</fieldset>
</form>
<script src="http://thecodeplayer.com/uploads/js/jquery-1.9.1.min.js" type="text/javascript"></script>
<script src="http://thecodeplayer.com/uploads/js/jquery.easing.min.js" type="text/javascript"></script>
@import url(https://fonts.googleapis.com/css?family=Montserrat);
* {margin: 0; padding: 0;}
html {
height: 100%;
background-color: rgb(64,64,64);
}
body {
font-family: montserrat, arial, verdana;
}
.msform {
width: 400px;
margin: 50px auto;
text-align: center;
position: relative;
}
.msform fieldset {
background: white;
border: 0 none;
border-radius: 3px;
box-shadow: 0 0 15px 1px rgba(0, 0, 0, 0.4);
padding: 20px 30px;
box-sizing: border-box;
width: 80%;
margin: 0 10%;
position: absolute;
}
.msform fieldset:not(:first-of-type) {
display: none;
}
.msform input, .msform textarea {
padding: 15px;
border: 1px solid rgba(0,0,0, .05);
border-radius: 3px;
margin-bottom: 10px;
width: 100%;
box-sizing: border-box;
font-family: montserrat;
color: #2C3E50;
font-size: 13px;
}
.msform input.error, .msform textarea.error{
border-color: rgb(255,99,71);
}
.msform .action-button {
width: 100px;
background: rgb(64,64,64);
font-weight: bold;
color: white;
border: 0 none;
border-radius: 2px;
cursor: pointer;
padding: 10px 5px;
margin: 10px 5px;
transition: all .4s;
}
.msform .action-button:hover, .msform .action-button:focus {
box-shadow: 0 0 0 2px white, 0 0 0 3px rgb(255,99,71);
background-color: rgb(255,99,71);
}
.fs-title {
font-size: 15px;
text-transform: uppercase;
color: #2C3E50;
margin-bottom: 10px;
}
.fs-subtitle {
font-weight: normal;
font-size: 13px;
color: #666;
margin-bottom: 20px;
}
.progressbar {
overflow: hidden;
counter-reset: step;
width: 60%;
margin: 0 auto 30px;
}
.progressbar li {
list-style-type: none;
color: white;
text-transform: uppercase;
font-size: 9px;
width: 33.33%;
float: left;
position: relative;
}
.progressbar li:before {
content: counter(step);
counter-increment: step;
width: 20px;
line-height: 20px;
display: block;
font-size: 10px;
color: #333;
background: white;
border-radius: 50%;
margin: 0 auto 5px auto;
}
.progressbar li:after {
content: '';
width: 100%;
height: 2px;
background: white;
position: absolute;
left: -50%;
top: 9px;
z-index: -1;
}
.progressbar li:first-child:after {
content: none;
}
.progressbar li.active:before, .progressbar li.active:after{
background: rgb(255,99,71);
color: white;
}
.vtcha{
max-width: 100%;
}
.vtcha .item-box,.vtcha .target-box{
width: 170px;
margin: 10px auto 0;
}
$(document).ready(function(){
spamschutz_init();
msform_init();
$('form').submit(function(event){
if(
form_completeCheck() &&
true
){
}
else{
event.preventDefault();
}
})
})
function check($fs){
var ok = true;
switch($fs.attr('data-check-id')){
case '1':
$i_name = $('input[name="name"]',$fs);
$i_email = $('input[name="email"]',$fs);
if ($i_name.val().length < 3) {
ok=false;
$i_name.addClass('error');
}
else{$i_name.removeClass('error');}
if ($i_email.val().length < 6) {
ok=false;
$i_email.addClass('error');
}
else{$i_email.removeClass('error');}
break;
case '2':
$i_q1 = $('input[name="q1"]',$fs);
$i_q2 = $('input[name="q2"]',$fs);
$i_q3 = $('input[name="q3"]',$fs);
if ($i_q1.val().length < 3) {
ok=false;
$i_q1.addClass('error');
}
else{$i_q1.removeClass('error');}
if ($i_q2.val().length < 3) {
ok=false;
$i_q2.addClass('error');
}
else{$i_q2.removeClass('error');}
if ($i_q3.val().length < 3) {
ok=false;
$i_q3.addClass('error');
}
else{$i_q3.removeClass('error');}
break;
case '3':
if (spamschutz_check() === false) {
ok=false;
}
break;
}
if(ok === true){
$fs.attr('data-complete', true);
return true;
}
else{
$fs.attr('data-complete', false);
return false;
}
}
function unCheck($fieldset){
$fieldset.attr('data-complete', false);
}
function form_completeCheck(){
var ok = true;
$('fieldset').each(function(index,elem){
$this = $(this);
if ($this.attr('data-complete') != 'true') {
ok = false;
};
})
if (ok === true) {
return true;
}
else{
swal('Irgendwo hast Du Daten vergessen :/','Überprüfe nochmal deine Eingaben!','error');
return false;
}
}
function msform_init(){
var current_fs, next_fs, previous_fs;
var left, opacity, scale;
var animating;
$('.submit').click(function(){
check($(this).parent());
})
$(".next").click(function(){
if(animating) return false;
animating = true;
current_fs = $(this).parent();
next_fs = $(this).parent().next();
if( check(current_fs) === false ) {
animating = false;
return false;
}
$(".progressbar li").eq($("fieldset").index(next_fs)).addClass("active");
next_fs.show();
current_fs.animate({opacity: 0}, {
step: function(now, mx) {
scale = 1 - (1 - now) * 0.2;
left = (now * 50)+"%";
opacity = 1 - now;
current_fs.css({'transform': 'scale('+scale+')'});
next_fs.css({'left': left, 'opacity': opacity});
},
duration: 800,
complete: function(){
current_fs.hide();
animating = false;
},
easing: 'easeInOutBack'
});
});
$(".previous").click(function(){
if(animating) return false;
animating = true;
current_fs = $(this).parent();
previous_fs = $(this).parent().prev();
unCheck(previous_fs)
$(".progressbar li").eq($("fieldset").index(current_fs)).removeClass("active");
previous_fs.show();
current_fs.animate({opacity: 0}, {
step: function(now, mx) {
scale = 0.8 + (1 - now) * 0.2;
left = ((1-now) * 50)+"%";
opacity = 1 - now;
current_fs.css({'left': left});
previous_fs.css({'transform': 'scale('+scale+')', 'opacity': opacity});
},
duration: 800,
complete: function(){
current_fs.hide();
animating = false;
},
easing: 'easeInOutBack'
});
});
};
function spamschutz_init(){
$('.vtcha-spamschutz').vtcha({
ok: 'multi_human_detected',
})
}
function spamschutz_check(){
$this = $('.vtcha-spamschutz');
if($this.val() == 'multi_human_detected'){
return true;
}
else{
return false;
}
}