Give us some feedback, any feedback, we just want feedback!

Your name:

Your email:

Your feedback:

 

Simple Responsive Design

Project Description:

Super Simple Responsive Design

Created: 9 Years ago

Last edited: 9 Years ago

Branch Project

Project name:

Project description:

 

Simple Responsive Design
HTML <body>
1
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.min.css">
2
<link href='https://fonts.googleapis.com/css?family=Alex+Brush' rel='stylesheet' type='text/css'>
3
<link href='https://fonts.googleapis.com/css?family=Open+Sans:400,700,600,300,800' rel='stylesheet' type='text/css'>
4
<link href='https://fonts.googleapis.com/css?family=Lato:400,300,700' rel='stylesheet' type='text/css'>        
5
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
6
 
7
<div class="cwrapper red">
8
  <div class="vcenter container">
9
    <p id="simple">Simple</p>
10
    <i id="star" class="fa fa-star"></i>
11
  </div>
12
  <div class="arrow bounce"><i class="fa fa-chevron-down"></i></div>
13
</div>
14
 
15
<div class="cwrapper white">
16
  <div class="vcenter container">
17
    <h1 class="cd-headline slide">
18
      <span>Lorem ipsum </span>
19
      <span class="cd-words-wrapper">
20
        <b class="is-visible">dolor.</b>
21
        <b>sit.</b>
22
        <b>amet.</b>
23
        <b>consectetur.</b>
24
        <b>adipiscing.</b>
25
        <b>elit.</b>
26
        <b>sed.</b>
27
        <b>eiusmod.</b>
28
        <b>tempor.</b>
29
        <b>incididunt.</b>
30
        <b>labore.</b>
31
        <b>magna.</b>
32
      </span>
33
    </h1>
34
  </div>
35
</div>
36
 
37
<div class="cwrapper blue">
38
  <div class="container css">
39
    <p>Lorem ipsum dolor sit amet</p>
40
  </div>
41
</div>
42
 
43
<div class="cwrapper maroon">
44
  <div class="container vcenter">
45
    <p>Lorem ipsum dolor sit amet<br /><span>Consectetur?</span></p>
46
  </div>
47
</div>
 
CSS <style>
1
* {padding:0; margin:0;}
2
body {background-color:#FFF;}
3
 
4
.cwrapper {height:100vh;}
5
  .cwrapper.red {background-color:#ff6b6b;}
6
  .cwrapper.white {background-color:#f9f9f9;}
7
    .cwrapper.white div span {font-family:'Open Sans', sans-serif; font-size:2em; font-weight:600; letter-spacing:-1.5px; color:#4ECDC4;}
8
  .cwrapper.blue {background:#235378 url(http://www.unixstickers.com/image/data/stickers/css3/css3_unofficial_shaped.png) no-repeat center; background-size:25%;}
9
  .cwrapper.maroon {background-color:#c44d58;}
10
    .cwrapper.maroon p {font-family:'Lato', sans-serif; font-weight:400; color: #FFF; font-size:2em;}
11
      .cwrapper.maroon p span {font-family:'Alex Brush', cursive; font-size:3em;}
12
 
13
.container {width:100%; text-align:center;}
14
  .container.vcenter {position:relative; top:50%; transform: translateY(-50%); -webkit-transform: translateY(-50%); -moz-transform: translateY(-50%); -ms-transform: translateY(-50%);}
15
  .container.css {position:relative; top:25%; transform: translateY(-30%); -webkit-transform: translateY(-30%); -moz-transform: translateY(-30%); -ms-transform: translateY(-30%);}
16
    .container.css p {font-family:'Open Sans', sans-serif; font-weight:600; font-size:1.6em; color:#FFF;}
17
 
18
#simple {text-align:center; color:#FFF; font-size:8em; font-family:'Alex Brush', cursive;}
19
#star {color:#FFF; font-size:3em; margin-top:-20px;}
20
 
21
 
22
/* arrow bounce */
23
 
24
.arrow {position:absolute; right:0; bottom:5px; left:0; margin:auto; width:32px; color:#FFF; font-size:2em; cursor:pointer;}
25
 
26
@keyframes bounce {
27
  0%, 20%, 50%, 80%, 100% {
28
    -moz-transform: translateY(0);
29
    -ms-transform: translateY(0);
30
    -webkit-transform: translateY(0);
31
    transform: translateY(0);
32
      opacity: 1;
33
  }
34
  40% {
35
    -moz-transform: translateY(-5px);
36
    -ms-transform: translateY(-5px);
37
    -webkit-transform: translateY(-5px);
38
    transform: translateY(-5px);
39
      opacity: .3;
40
  }
41
  60% {
42
    -moz-transform: translateY(-5px);
43
    -ms-transform: translateY(-5px);
44
    -webkit-transform: translateY(-5px);
45
    transform: translateY(-5px);
46
      opacity: .3;
47
  }
48
}
49
@-webkit-keyframes bounce {
50
  0%, 20%, 50%, 80%, 100% {
51
    -webkit-transform: translateY(0);
52
    transform: translateY(0);
53
  }
54
  40% {
55
    -webkit-transform: translateY(-5px);
56
    transform: translateY(-5px);
57
  }
58
  60% {
59
    -webkit-transform: translateY(-5px);
60
    transform: translateY(-5px);
61
  }
62
}
63
@-moz-keyframes .bounce{
64
  0%, 20%, 50%, 80%, 100% {
65
    -moz-transform: translateY(0);
66
    transform: translateY(0);
67
  }
68
  40% {
69
    -moz-transform: translateY(-5px);
70
    transform: translateY(-5px);
71
  }
72
  60% {
73
    -moz-transform: translateY(-5px);
74
    transform: translateY(-5px);
75
  }
76
}
77
 
78
.arrow.bounce {animation:bounce 2s infinite; -webkit-animation:bounce 2s infinite; -moz-animation:bounce 2s infinite;}
79
 
80
 
81
/* xslide styles */
82
 
83
.cd-headline {
84
  font-size: 1rem;
85
  line-height: 1.2;
86
}
87
 
88
.cd-words-wrapper {
89
  display: inline-block;
90
  position: relative;
91
  text-align: left;
92
}
93
.cd-words-wrapper b {
94
  display: inline-block;
95
  position: absolute;
96
  white-space: nowrap;
97
  left: 0;
98
  top: 0;
99
}
100
.cd-words-wrapper b.is-visible {
101
  position: relative;
102
}
103
.no-js .cd-words-wrapper b {
104
  opacity: 0;
105
}
106
.no-js .cd-words-wrapper b.is-visible {
107
  opacity: 1;
108
}
109
 
110
/* xslide animation */
111
 
112
.cd-headline.slide span {
113
  display: inline-block;
114
  padding: .2em 0;
115
}
116
.cd-headline.slide .cd-words-wrapper {
117
  overflow: hidden;
118
  vertical-align: top;
119
}
120
.cd-headline.slide b {
121
  opacity: 0;
122
  top: .2em;
123
}
124
.cd-headline.slide b.is-visible {
125
  top: 0;
126
  opacity: 1;
127
  -webkit-animation: slide-in 0.6s;
128
  -moz-animation: slide-in 0.6s;
129
  animation: slide-in 0.6s;
130
}
131
.cd-headline.slide b.is-hidden {
132
  -webkit-animation: slide-out 0.6s;
133
  -moz-animation: slide-out 0.6s;
134
  animation: slide-out 0.6s;
135
}
136
 
137
@-webkit-keyframes slide-in {
138
  0% {
139
    opacity: 0;
140
    -webkit-transform: translateY(-100%);
141
  }
142
  60% {
143
    opacity: 1;
144
    -webkit-transform: translateY(20%);
145
  }
146
  100% {
147
    opacity: 1;
148
    -webkit-transform: translateY(0);
149
  }
150
}
151
@-moz-keyframes slide-in {
152
  0% {
153
    opacity: 0;
154
    -moz-transform: translateY(-100%);
155
  }
156
  60% {
157
    opacity: 1;
158
    -moz-transform: translateY(20%);
159
  }
160
  100% {
161
    opacity: 1;
162
    -moz-transform: translateY(0);
163
  }
164
}
165
@keyframes slide-in {
166
  0% {
167
    opacity: 0;
168
    -webkit-transform: translateY(-100%);
169
    -moz-transform: translateY(-100%);
170
    -ms-transform: translateY(-100%);
171
    -o-transform: translateY(-100%);
172
    transform: translateY(-100%);
173
  }
174
  60% {
175
    opacity: 1;
176
    -webkit-transform: translateY(20%);
177
    -moz-transform: translateY(20%);
178
    -ms-transform: translateY(20%);
179
    -o-transform: translateY(20%);
180
    transform: translateY(20%);
181
  }
182
  100% {
183
    opacity: 1;
184
    -webkit-transform: translateY(0);
185
    -moz-transform: translateY(0);
186
    -ms-transform: translateY(0);
187
    -o-transform: translateY(0);
188
    transform: translateY(0);
189
  }
190
}
191
@-webkit-keyframes slide-out {
192
  0% {
193
    opacity: 1;
194
    -webkit-transform: translateY(0);
195
  }
196
  60% {
197
    opacity: 0;
198
    -webkit-transform: translateY(120%);
199
  }
200
  100% {
201
    opacity: 0;
202
    -webkit-transform: translateY(100%);
203
  }
204
}
205
@-moz-keyframes slide-out {
206
  0% {
207
    opacity: 1;
208
    -moz-transform: translateY(0);
209
  }
210
  60% {
211
    opacity: 0;
212
    -moz-transform: translateY(120%);
213
  }
214
  100% {
215
    opacity: 0;
216
    -moz-transform: translateY(100%);
217
  }
218
}
219
@keyframes slide-out {
220
  0% {
221
    opacity: 1;
222
    -webkit-transform: translateY(0);
223
    -moz-transform: translateY(0);
224
    -ms-transform: translateY(0);
225
    -o-transform: translateY(0);
226
    transform: translateY(0);
227
  }
228
  60% {
229
    opacity: 0;
230
    -webkit-transform: translateY(120%);
231
    -moz-transform: translateY(120%);
232
    -ms-transform: translateY(120%);
233
    -o-transform: translateY(120%);
234
    transform: translateY(120%);
235
  }
236
  100% {
237
    opacity: 0;
238
    -webkit-transform: translateY(100%);
239
    -moz-transform: translateY(100%);
240
    -ms-transform: translateY(100%);
241
    -o-transform: translateY(100%);
242
    transform: translateY(100%);
243
  }
244
}
 
JS <script> (jQuery supported)
1
jQuery(document).ready(function($){
2
  //set animation timing
3
  var animationDelay = 2500,
4
    //loading bar effect
5
    barAnimationDelay = 3800,
6
    barWaiting = barAnimationDelay - 3000, //3000 is the duration of the transition on the loading bar - set in the scss/css file
7
    //letters effect
8
    lettersDelay = 50,
9
    //type effect
10
    typeLettersDelay = 150,
11
    selectionDuration = 500,
12
    typeAnimationDelay = selectionDuration + 800,
13
    //clip effect 
14
    revealDuration = 600,
15
    revealAnimationDelay = 1500;
16
  
17
  initHeadline();
18
  
19
 
20
  function initHeadline() {
21
    //insert <i> element for each letter of a changing word
22
    singleLetters($('.cd-headline.letters').find('b'));
23
    //initialise headline animation
24
    animateHeadline($('.cd-headline'));
25
  }
26
 
27
  function singleLetters($words) {
28
    $words.each(function(){
29
      var word = $(this),
30
        letters = word.text().split(''),
31
        selected = word.hasClass('is-visible');
32
      for (i in letters) {
33
        if(word.parents('.rotate-2').length > 0) letters[i] = '<em>' + letters[i] + '</em>';
34
        letters[i] = (selected) ? '<i class="in">' + letters[i] + '</i>': '<i>' + letters[i] + '</i>';
35
      }
36
        var newLetters = letters.join('');
37
        word.html(newLetters).css('opacity', 1);
38
    });
39
  }
40
 
41
  function animateHeadline($headlines) {
42
    var duration = animationDelay;
43
    $headlines.each(function(){
44
      var headline = $(this);
45
      
46
      if(headline.hasClass('loading-bar')) {
47
        duration = barAnimationDelay;
48
        setTimeout(function(){ headline.find('.cd-words-wrapper').addClass('is-loading') }, barWaiting);
49
      } else if (headline.hasClass('clip')){
50
        var spanWrapper = headline.find('.cd-words-wrapper'),
51
          newWidth = spanWrapper.width() + 10
52
        spanWrapper.css('width', newWidth);
53
      } else if (!headline.hasClass('type') ) {
54
        //assign to .cd-words-wrapper the width of its longest word
55
        var words = headline.find('.cd-words-wrapper b'),
56
          width = 0;
57
        words.each(function(){
58
          var wordWidth = $(this).width();
59
            if (wordWidth > width) width = wordWidth;
60
        });
61
        headline.find('.cd-words-wrapper').css('width', width);
62
      };
63
 
64
      //trigger animation
65
      setTimeout(function(){ hideWord( headline.find('.is-visible').eq(0) ) }, duration);
66
    });
67
  }
68
 
69
  function hideWord($word) {
70
    var nextWord = takeNext($word);
71
    
72
    if($word.parents('.cd-headline').hasClass('type')) {
73
      var parentSpan = $word.parent('.cd-words-wrapper');
74
      parentSpan.addClass('selected').removeClass('waiting'); 
75
      setTimeout(function(){ 
76
        parentSpan.removeClass('selected'); 
77
        $word.removeClass('is-visible').addClass('is-hidden').children('i').removeClass('in').addClass('out');
78
      }, selectionDuration);
79
      setTimeout(function(){ showWord(nextWord, typeLettersDelay) }, typeAnimationDelay);
80
    
81
    } else if($word.parents('.cd-headline').hasClass('letters')) {
82
      var bool = ($word.children('i').length >= nextWord.children('i').length) ? true : false;
83
      hideLetter($word.find('i').eq(0), $word, bool, lettersDelay);
84
      showLetter(nextWord.find('i').eq(0), nextWord, bool, lettersDelay);
85
 
86
    }  else if($word.parents('.cd-headline').hasClass('clip')) {
87
      $word.parents('.cd-words-wrapper').animate({ width : '2px' }, revealDuration, function(){
88
        switchWord($word, nextWord);
89
        showWord(nextWord);
90
      });
91
 
92
    } else if ($word.parents('.cd-headline').hasClass('loading-bar')){
93
      $word.parents('.cd-words-wrapper').removeClass('is-loading');
94
      switchWord($word, nextWord);
95
      setTimeout(function(){ hideWord(nextWord) }, barAnimationDelay);
96
      setTimeout(function(){ $word.parents('.cd-words-wrapper').addClass('is-loading') }, barWaiting);
97
 
98
    } else {
99
      switchWord($word, nextWord);
100
      setTimeout(function(){ hideWord(nextWord) }, animationDelay);
101
    }
102
  }
103
 
104
  function showWord($word, $duration) {
105
    if($word.parents('.cd-headline').hasClass('type')) {
106
      showLetter($word.find('i').eq(0), $word, false, $duration);
107
      $word.addClass('is-visible').removeClass('is-hidden');
108
 
109
    }  else if($word.parents('.cd-headline').hasClass('clip')) {
110
      $word.parents('.cd-words-wrapper').animate({ 'width' : $word.width() + 10 }, revealDuration, function(){ 
111
        setTimeout(function(){ hideWord($word) }, revealAnimationDelay); 
112
      });
113
    }
114
  }
115
 
116
  function hideLetter($letter, $word, $bool, $duration) {
117
    $letter.removeClass('in').addClass('out');
118
    
119
    if(!$letter.is(':last-child')) {
120
      setTimeout(function(){ hideLetter($letter.next(), $word, $bool, $duration); }, $duration);  
121
    } else if($bool) { 
122
      setTimeout(function(){ hideWord(takeNext($word)) }, animationDelay);
123
    }
124
 
125
    if($letter.is(':last-child') && $('html').hasClass('no-csstransitions')) {
126
      var nextWord = takeNext($word);
127
      switchWord($word, nextWord);
128
    } 
129
  }
130
 
131
  function showLetter($letter, $word, $bool, $duration) {
132
    $letter.addClass('in').removeClass('out');
133
    
134
    if(!$letter.is(':last-child')) { 
135
      setTimeout(function(){ showLetter($letter.next(), $word, $bool, $duration); }, $duration); 
136
    } else { 
137
      if($word.parents('.cd-headline').hasClass('type')) { setTimeout(function(){ $word.parents('.cd-words-wrapper').addClass('waiting'); }, 200);}
138
      if(!$bool) { setTimeout(function(){ hideWord($word) }, animationDelay) }
139
    }
140
  }
141
 
142
  function takeNext($word) {
143
    return (!$word.is(':last-child')) ? $word.next() : $word.parent().children().eq(0);
144
  }
145
 
146
  function takePrev($word) {
147
    return (!$word.is(':first-child')) ? $word.prev() : $word.parent().children().last();
148
  }
149
 
150
  function switchWord($oldWord, $newWord) {
151
    $oldWord.removeClass('is-visible').addClass('is-hidden');
152
    $newWord.removeClass('is-hidden').addClass('is-visible');
153
  }
154
});
155
 
156
$(document).ready(function() {
157
  $('body').css('display', 'none');
158
  $('body').fadeIn(1000);
159
 
160
  $('.link').click(function(event) {
161
    event.preventDefault();
162
    newLocation = this.href;
163
    $('body').fadeOut(1000, newpage);
164
  });
165
 
166
  function newpage() {
167
    window.location = newLocation;
168
  }
169
});
170
 
171
$(".arrow.bounce").click(function() {
172
  $('html,body').animate({
173
    scrollTop: $(".cwrapper.white").offset().top},'slow');
174
});