HTML preprocessors can make writing HTML more powerful or convenient. For instance, Markdown is designed to be easier to write and read for text documents and you could write a loop in Pug.
In CodePen, whatever you write in the HTML editor is what goes within the <body>
tags in a basic HTML5 template. So you don't have access to higher-up elements like the <html>
tag. If you want to add classes there that can affect the whole document, this is the place to do it.
In CodePen, whatever you write in the HTML editor is what goes within the <body>
tags in a basic HTML5 template. If you need things in the <head>
of the document, put that code here.
The resource you are linking to is using the 'http' protocol, which may not work when the browser is using https.
CSS preprocessors help make authoring CSS easier. All of them offer things like variables and mixins to provide convenient abstractions.
It's a common practice to apply CSS to a page that styles elements such that they are consistent across all browsers. We offer two of the most popular choices: normalize.css and a reset. Or, choose Neither and nothing will be applied.
To get the best cross-browser support, it is a common practice to apply vendor prefixes to CSS properties and values that require them to work. For instance -webkit-
or -moz-
.
We offer two popular choices: Autoprefixer (which processes your CSS server-side) and -prefix-free (which applies prefixes via a script, client-side).
Any URL's added here will be added as <link>
s in order, and before the CSS in the editor. You can use the CSS from another Pen by using it's URL and the proper URL extention.
You can apply CSS to your Pen from any stylesheet on the web. Just put a URL to it here and we'll apply it, in the order you have them, before the CSS in the Pen itself.
You can also link to another Pen here (use the .css
URL Extension) and we'll pull the CSS from that Pen and include it. If it's using a matching preprocessor, use the appropriate URL Extension and we'll combine the code before preprocessing, so you can use the linked Pen as a true dependency.
JavaScript preprocessors can help make authoring JavaScript easier and more convenient.
Babel includes JSX processing.
Any URL's added here will be added as <script>
s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.
You can apply a script from anywhere on the web to your Pen. Just put a URL to it here and we'll add it, in the order you have them, before the JavaScript in the Pen itself.
If the script you link to has the file extension of a preprocessor, we'll attempt to process it before applying.
You can also link to another Pen here, and we'll pull the JavaScript from that Pen and include it. If it's using a matching preprocessor, we'll combine the code before preprocessing, so you can use the linked Pen as a true dependency.
Search for and use JavaScript packages from npm here. By selecting a package, an import
statement will be added to the top of the JavaScript editor for this package.
Using packages here is powered by Skypack, which makes packages from npm not only available on a CDN, but prepares them for native JavaScript ES6 import
usage.
All packages are different, so refer to their docs for how they work.
If you're using React / ReactDOM, make sure to turn on Babel for the JSX processing.
If active, Pens will autosave every 30 seconds after being saved once.
If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.
If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.
Visit your global Editor Settings.
<!--
An illustrative effect showing how user interaction can scale into an illustration.
Pen By Ashley Nolan.
Best viewed in Chrome or IE – bit memory intensive in Firefox and Safari does some weird glitchy animation at the higher scroll points.
Illustrations by Simon Kinslow and Lorena Teruel.
-->
<link href='https://fonts.googleapis.com/css?family=Sancreek' rel='stylesheet' type='text/css'>
<div class="l-container home">
<div class="illust-container">
<div class="illust-level illust-level--intro">
<div class="illustItem illustItem--bgGrass"></div>
<div class="illustItem illustItem--fencePost illustItem--fencePost--first">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fencepost.svg" alt="Fence post">
<div class="illustItem illustItem--northpole illustItem--fence-arrow illustItem--fence-arrow-left symbol symbol--northpole">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fence-arrow-left.svg" alt="Fence post Arrow Left">
<h2 class="symbol-title">North Pole </h2>
</div>
<div class="illustItem illustItem--grotto illustItem--fence-arrow illustItem--fence-arrow-right symbol symbol--grotto">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fence-arrow-right.svg" alt="Fence post Arrow Right">
<h2 class="symbol-title">Grotto</h2>
</div>
</div>
<div class="illustItem illustItem--holly symbol symbol--holly">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/holly.svg" alt="Holly">
</div>
<div class="illustItem illustItem--fencePost illustItem--fencePost--second">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fencepost.svg" alt="Fence post">
<div class="illustItem illustItem--lapland illustItem--fence-arrow illustItem--fence-arrow-right symbol symbol--lapland">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fence-arrow-right.svg" alt="Fence post arrow right">
<h2 class="symbol-title">Lapland</h2>
</div>
</div>
<div class="illustItem illustItem--ivy symbol symbol--ivy">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/ivy.svg" alt="Ivy">
</div>
</div>
</div>
<div class="illust-level--town">
<div class="illustItem illustItem--snowglobe">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/snowglobe.svg" alt="Snow Globe">
</div>
<div class="illustItem illustItem--town">
<img class="svg-town" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/town.svg" alt="Town">
<div class="svg-house">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/house.svg" alt="House">
<img class="svg-lights" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/lights.svg" alt="lights">
</div>
<img class="svg-sleigh" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/sleigh.svg" alt="Sleigh">
<div class="svg-star inactive">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/star.svg" alt="Star">
</div>
<img class="svg-sledge" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/sledge.svg" alt="sledge">
<img class="svg-robins" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/robins.svg" alt="robins">
<img class="svg-peace" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/peace.svg" alt="peace">
<img class="svg-shopping" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/shopping.svg" alt="shopping">
<div class="svg-carollers">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/carolers.svg" alt="carollers">
</div>
<img class="svg-firstfloor" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/firstfloor.svg" alt="firstfloor">
<img class="svg-secondfloor" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/secondfloor.svg" alt="secondfloor">
<img class="svg-nativity" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/nativity.svg" alt="nativity">
<div class="illust-level illust-level--symbolsTown">
<div class="illustItem illustItem--yuletide symbol symbol--yuletide">
<h2 class="symbol-title">Seasons Greetings</h2>
</div>
<div class="symbols--outside">
<div class="illustItem illustItem--carols symbol symbol--carols">
<h2 class="symbol-title">Merry Christmas</h2>
</div>
</div>
<div class="symbols--inside inactive">
<div class="illustItem illustItem--nutcracker symbol symbol--nutcracker">
<h2 class="symbol-title">Tiny Tim</h2>
</div>
<div class="illustItem illustItem--present symbol symbol--present">
<h2 class="symbol-title">Mum</h2>
</div>
<div class="illustItem illustItem--mincepie symbol symbol--mincepie">
<h2 class="symbol-title">Mince Pies</h2>
</div>
<div class="illustItem illustItem--christmascards symbol symbol--christmascards">
<h2 class="symbol-title">Happy Christmas</h2>
</div>
<div class="illustItem illustItem--bingcrosby symbol symbol--bingcrosby">
<h2 class="symbol-title">Bing Crosby</h2>
</div>
<div class="illustItem illustItem--mariahcarey symbol symbol--mariahcarey">
<h2 class="symbol-title">Mariah Carey</h2>
</div>
<div class="illustItem illustItem--endquote">
<h2 class="symbol-title"><span class="symbol-title-sub">Have</span>a Very Merry Jolly Christmas!</h2>
</div>
</div>
</div>
</div>
</div>
<div id="scroll-proxy"></div>
<footer class="page-footer">
<ul class="unstyled page-footer-links">
<li><a class="page-footer-info" href="https://twitter.com/AshNolan_" target="_blank">By AshNolan_</a>
</li>
</ul>
</footer>
</div>
// Generic colours
$blue : #e2f7f6;
$turquoise : #34a8a6;
$red : #e41f44;
$yellow : #f8e32a;
$yellowPale : #f2e397;
$brownLight : #eee0b7;
// Colour Scheme
$color-primary : $turquoise;
// Common colours
$color-text : #444;
$color-bg : #a6e1ee;
// Text Selection
$color-selection : #fff;
$color-selection-bg : $color-primary;
// Links
$color-link-default : $color-primary;
$color-link-hover : darken($color-primary, 20%);
// Buttons
$btn-default-bg : $turquoise;
$btn-default-bg-highlight : darken($btn-default-bg, 10%);
/**
* Typography
* =================================
*/
$font-size-base : 16;
$font-size-base-px : $font-size-base * 1px;
$leading-base : 1.4;
$line-height-base : round($font-size-base * $leading-base); // 20 * 1.4
$baseline : $line-height-base * 1px;
$type-scale : 1.25; // Major third
$type-base : 16;
$font-family-sans : "Helvetica Neue", Helvetica, Arial, sans-serif;
$font-family-serif : 'Sancreek', cursive;
$font-family-mono : Menlo, Monaco, "Courier New", monospace;
$font-family-base : $font-family-serif;
$font-family-alt : $font-family-serif;
$font-family-headings : inherit; // using inherit will use $font-family-base for all headings
$font-weight-headings : normal; // instead of browser default, bold
$line-height-headings : 1.2;
/**
* Breakpoints
*/
$bp-narrow : 550; // Set in px
$bp-mid : 768; // Set in px
$bp-wide : 992; // Set in px
$bp-huge : 1600; // Set in px
/*
Min-width media query:
* Equivalent to: @media screen and (min-width: 20em) { ... }
* Usage: @include respond-min(500) { ... };
* Argument is a pixel value WITHOUT a unit of measurement
========================================================================== */
@mixin respond-min($width) {
@media screen and (min-width: $width + px) {
@content;
}
}
/*
Max-width media query:
* Equivalent to: @media screen and (max-width: 20em) { ... }
* Usage: @include respond-max(500) { ... };
* Argument is a pixel value WITHOUT a unit of measurement
========================================================================== */
@mixin respond-max($width) {
// Otherwise, output it using a regular media query
@media screen and (max-width: $width + px) {
@content;
}
}
// Opacity
// @include opacity(50);
@mixin opacity($opacity: 100) {
zoom: 1;
filter: alpha(opacity=$opacity);
opacity: $opacity / 100;
}
/* ==========================================================================
Typography mixins
========================================================================== */
// @include font-size(16);
@mixin font-size($sizeValue: $font-size-base){
font-size: $sizeValue + px;
}
/**
* Typography
*/
* {
box-sizing: border-box;
}
html {
text-size-adjust: 100%;
}
body {
font-family: $font-family-base;
@include font-size($type-base);
line-height: $leading-base;
color: $color-text;
}
/**
* Headings
*/
h2 {
margin: 0;
font-family: $font-family-headings;
font-weight: $font-weight-headings;
line-height: $line-height-headings;
text-rendering: optimizelegibility; // Fix the character spacing for headings
}
h2 {
@include font-size(30);
margin-top: 0;
margin-bottom: $baseline;
}
/**
* Links
*/
a {
& {
color: $color-link-default;
text-decoration: none;
}
&:hover, &:focus {
color: $color-link-hover;
}
}
/**
* Lists
*/
ul {
list-style-type: disc;
}
// Unordered and Ordered lists
// Add a .unstyled class to unordered/ordered lists if you want them to have bullets/numbers
ul {
padding: 0;
margin: 0 0 $baseline $baseline;
}
.unstyled {
margin: 0;
padding: 0;
list-style: none;
list-style-image: none;
}
// Text selection
@mixin text-selection($color-selection, $color-selection-bg) {
::-moz-selection {
color: $color-selection;
background: $color-selection-bg;
text-shadow: none;
}
::selection {
color: $color-selection;
background: $color-selection-bg;
text-shadow: none;
}
}
@include text-selection($color-selection, $color-selection-bg);
.btn {
display:inline-block;
vertical-align:middle;
white-space:nowrap;
font-family:inherit;
font-size:100%;
cursor:pointer;
border:none;
margin:0;
padding-top: 0;
padding-bottom:0;
line-height: 2.5;
height: 2.5em;
padding-right:1.5em;
padding-left: 1.5em;
overflow:visible;
text-align: center;
// You may want to change this
background-color: $btn-default-bg;
color: #fff;
border-radius: 5px;
user-select: none;
&:hover {
background-color: $btn-default-bg-highlight;
}
&,
&:hover {
text-decoration: none;
}
}
/**
* Scrollbar styling (only in webkit)
*/
::-webkit-scrollbar {
width: 10px;
height: 10px;
background-color: darken($color-bg, 10%);
}
::-webkit-scrollbar-thumb {
background: darken($color-bg, 40%);
cursor: pointer;
border-radius: 5px;
}
/**
* Global app/site styles
*/
html, body,
.l-container {
@include respond-min($bp-narrow) {
width: 100%;
height: 100%;
}
}
body {
background-color: $color-bg;
color: #333;
//snow
background-image: url('');
background-repeat: repeat;
background-position: top left;
background-attachment: fixed;
transition: background-color 1000ms;
&.night {
background-color: #0d0f27;
background-image: url('');
}
}
/**
* Default layout container
*/
.l-container {
padding-left: 0px;
padding-right: 0px;
width: 95%;
max-width: 1000px;
margin: 0 auto;
// perspective: 300px;
@include respond-max($bp-narrow - 1) {
position: relative;
margin-bottom: 150px;
}
}
#scroll-proxy {
height: 10000px;
&.inactive {
display: none;
}
}
//SYMBOL RELATED STUFF
.symbol {
position: relative;
}
.symbol-title {
@include font-size(18);
text-transform: uppercase;
.symbol--carols & {
color: $brownLight;
@include font-size(20);
}
.symbol--mincepie & {
color: $yellowPale;
@include font-size(22);
}
}
.symbol-total {
letter-spacing: 1px;
}
//specific text sizing for certain symbols
.symbol-title,
.symbol-total {
margin-bottom: 0;
//where we want the title and count on one line
.symbol--inline & {
display: inline-block;
@include font-size(18);
}
.symbol--yuletide & {
@include respond-min($bp-narrow) {
@include font-size(20);
}
}
}
//hide symbols until needed
.overlay,
.symbols--inside,
.symbols--outside {
@include opacity(100);
transition: opacity 300ms;
&.inactive {
z-index: -10;
transition: opacity 300ms, z-index 0ms 300ms;
@include opacity(0);
}
}
.symbols--inside,
.symbols--outside {
position: absolute;
width: 100%;
height: 100%;
}
$layerIndex: level-1, level-2, level-3, level-4, level-5;
.illust-container {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
transform: translate3d(0, 0, 0);
backface-visibility: hidden;
}
.illust-level {
position: absolute;
left: 0;
top: 0;
}
.illust-level--intro {
position: relative;
width: 100%;
height: 700px;
max-width: 1400px;
margin: 0 auto;
& svg,
& img {
position: absolute;
z-index: index($layerIndex, level-2);
left: 0;
top: 0;
width: 100%;
height: 100%;
}
.symbol-title {
position: relative;
margin-top: 0;
z-index: index($layerIndex, level-3);
}
}
.illust-level--town {
position: fixed;
top: 50%; left: 50%;
z-index: index($layerIndex, level-2);
width: 350px;
height: 320px;
transform: translate(-50%, -160px);
.csstransforms3d & {
transform: translate3d(-50%, -160px, 0);
backface-visibility: hidden;
}
}
.illust-level--symbolsTown {
z-index: index($layerIndex, level-3);
width: 350px; height: 320px;
transform-origin: left top;
}
// INTRO LEVEL (HOME) ILLUSTRATIONS
// INCLUDES (IN Z-INDEX ORDER:
// BGGRASS
// SNOWGLOBE
// SNOWFLAKE
// DOVES
// HOLLY
// IVY
//every illustration component has this set on it, plus a more precise modifier class with the background
.illustItem {
position: absolute;
background-size: contain;
background-repeat: no-repeat;
background-position: center center;
}
.illustItem--bgGrass {
z-index: index($layerIndex, level-2);
top: 490px; left: 50%;
width: 200%; height: 50px;
background-image: url('');
background-repeat: repeat-x;
background-position: left top;
transform: translate(-50%);
@media screen and (min-height: 750px) { top: 520px; }
&:before {
content: '';
display: block;
margin-top: 50px;
width: 100%;
height: 800px;
background-color: $blue;
}
}
.illustItem--fencePost {
z-index: index($layerIndex, level-1);
width: 25px;
min-height: 252px;
@include respond-min($bp-mid) { width: 49px; }
&.illustItem--fencePost--first {
top: 320px;
left: 12%;
transition: left 300ms;
@include respond-min(820) { left: 15%; }
@include respond-min($bp-wide) { left: 20%; }
@media screen and (min-height: 750px) { top: 350px; }
}
&.illustItem--fencePost--second {
top: 360px;
right: 10%;
transition: right 300ms;
@include respond-min(760) { right: 15%; }
@media screen and (min-height: 750px) { top: 400px; }
}
& .symbol-title {
display: inline-block;
@include font-size(20);
}
}
.illustItem--fence-arrow-left {
z-index: index($layerIndex, level-2);
text-align: right;
width: 130px;
height: 41px;
@include respond-min($bp-mid) { width: 200px; }
.symbol-title {
padding-top: 8px;
padding-right: 25px;
@include respond-max($bp-mid) {
@include font-size(12);
padding-top: 12px;
}
}
}
.illustItem--fence-arrow-right {
z-index: index($layerIndex, level-2);
width: 120px;
height: 32px;
@include respond-min($bp-mid) { width: 158px; }
.symbol-title {
padding-top: 4px;
padding-left: 20px;
@include respond-max($bp-mid) {
@include font-size(12);
padding-top: 8px;
}
}
}
.illustItem--northpole {
top: 45px; left: -70px;
transform: rotate(-4deg);
@include respond-min($bp-mid) { top: 25px; left: -100px; }
}
.illustItem--grotto {
top: 90px; left: -50px;
transform: rotate(4deg);
text-transform: uppercase;
}
.illustItem--lapland {
top: 55px; left: -30px;
transform: rotate(4deg);
@include respond-min($bp-mid) { top: 20px; left: -50px; }
}
.illustItem--holly {
z-index: index($layerIndex, level-3);
top: 540px; left: -260px;
width: 400px; height: 130px;
background-repeat: repeat;
background-position: right center;
transition: left 300ms;
@include respond-min(660) { left: -200px; }
@include respond-min(720) { left: -160px; }
@include respond-min(840) { left: -100px; }
@include respond-min(980) { left: -40px; }
@media screen and (min-height: 750px) { top: 580px; }
}
.illustItem--ivy {
z-index: index($layerIndex, level-3);
top: 540px; right: -200px;
width: 325px; height: 114px;
//spacing for text
padding: 38px 0 0 80px;
transition: right 300ms;
@include respond-min(660) { right: -160px; }
@include respond-min(800) { right: -80px; }
@include respond-min($bp-wide) { right: 0; }
@media screen and (min-height: 750px) { top: 580px; }
}
.illustItem--snowglobe {
z-index: index($layerIndex, level-3);
width: 102%; height: 116%;
top: 0; left: 50%;
transform: translate(-50%);
}
.illustItem--town {
position: relative;
width: 100%; height: 100%;
-webkit-user-select: none; /* Chrome all / Safari all */
-moz-user-select: none; /* Firefox all */
-ms-user-select: none; /* IE 10+ */
}
.svg-town {
width: 100%; height: 100%;
}
.svg-house,
.svg-carollers,
.svg-star {
transition: opacity 300ms;
&.inactive { @include opacity(0); }
& svg,
& img {
width: 100%;
height: 100%;
}
}
.svg-house {
z-index: index($layerIndex, level-3);
position: absolute;
width: 100%; height: 100%;
top: 51%; left: 49.72%;
transform-origin: left top;
transform: scale(0.266) translate(-50%, 0);
}
.svg-lights {
z-index: index($layerIndex, level-4);
position: absolute;
width: 100%; height: 100%;
top: 53.1%; left: 50.5%;
transform-origin: left top;
transform: scale(0.4) translate(-50%, 0);
}
.svg-sleigh {
position: absolute;
width: 100%; height: 100%;
top: 70%; left: 50%;
transform-origin: left top;
transform: scale(0.14) translate(-43%, -245%) rotate(8deg);
&.inactive { @include opacity(0); }
}
.svg-star {
position: absolute;
width: 100%; height: 100%;
top: 38.5%; left: 47%;
background-color: rgb(13, 15, 39);
transform-origin: left top;
transform: scale(0.025) translate(-100%, 0);
}
.svg-sledge {
position: absolute;
width: 100%; height: 100%;
top: 75%; left: 64%;
transform-origin: left top;
transform: scale(0.14) translate(-50%, 0);
}
.svg-carollers {
z-index: index($layerIndex, level-3);
position: absolute;
width: 100%; height: 100%;
top: 72%; left: 58%;
transform-origin: left top;
transform: scale(0.08) translate(-50%, 0);
}
.svg-robins {
z-index: index($layerIndex, level-3);
position: absolute;
width: 100%; height: 100%;
top: 72%; left: 37%;
transform-origin: left top;
transform: scale(0.031) translate(0, 0);
}
.svg-shopping {
z-index: index($layerIndex, level-3);
position: absolute;
width: 100%; height: 100%;
top: 76%; left: 17%;
transform-origin: left top;
transform: scale(0.06) translate(0, 0);
}
.svg-peace {
z-index: index($layerIndex, level-3);
position: absolute;
width: 100%; height: 100%;
top: 68%; left: 69%;
transform-origin: left top;
transform: scale(0.05) translate(0, 0);
}
.svg-nativity {
z-index: index($layerIndex, level-2);
position: absolute;
width: 100%; height: 100%;
top: 54.62%; left: 50%;
transform-origin: left top;
transform: scale(0.11) translate(-50%, 0);
}
.svg-firstfloor {
z-index: index($layerIndex, level-2);
position: absolute;
width: 100%; height: 100%;
top: 66.4%; left: 50%;
transform-origin: left top;
transform: scale(0.1278) translate(-50.12%, 0);
}
.svg-secondfloor {
z-index: index($layerIndex, level-2);
position: absolute;
width: 100%; height: 100%;
top: 60%; left: 50%;
transform-origin: left top;
transform: scale(0.1278) translate(-50.12%, 0);
}
// LABELS
.illustItem--yuletide {
width: 184px; height: 30px;
bottom: -37px; left: 24%;
text-transform: uppercase;
text-align: center;
}
// OUTSIDE LABELS
.illustItem--carols {
width: 212px; height: 41px;
top: 233px; left: 97px;
padding: 8px 0;
transform: scale(0.07) translate(0, 15px);
text-align: center;
}
// INSIDE LABELS
.illustItem--present {
width: 110px; height: 41px;
top: 218px; left: 141px;
transform: scale(0.04) translate(18px, 5px) rotate(-30deg);
text-align: left;
}
.illustItem--nutcracker {
width: 140px; height: 41px;
top: 220px; left: 113px;
transform: scale(0.04) translate(21px, 28px) rotate(14deg);
text-align: left;
}
.illustItem--bingcrosby,
.illustItem--mariahcarey,
.illustItem--wham {
width: 180px; height: 41px;
top: 188px;
text-align: center;
}
.illustItem--bingcrosby {
left: 95px;
transform: scale(0.02) translate(13px, 22px);
}
.illustItem--mariahcarey {
left: 99px;
transform: scale(0.02) translate(16px, 22px);
}
.illustItem--mincepie {
width: 202px; height: 57px;
top: 191px; left: 63px;
padding: 8px 0;
transform: scale(0.025) translate(20px, 5px);
text-align: center;
}
.illustItem--stocking,
.illustItem--fireplace {
width: 202px; height: 57px;
left: 59px;
padding: 8px 0;
text-align: center;
}
.illustItem--fireplace {
top: 187px;
transform: scale(0.031) translate(12px, 0);
}
.illustItem--christmascards {
width: 100px; height: 57px;
top: 186px; left: 124px;
padding: 8px 0;
transform: scale(0.03) translate(28px, 14px);
}
// SLEIGH LABELS
.illustItem--santa {
width: 180px; height: 41px;
top: 126px; left: 105px;
transform: scale(0.03) translate(-10px, 9px) rotate(8deg);
text-align: center;
}
.illustItem--endquote {
width: 120px;
top: 86px; left: 129px;
transform: scale(0.12) translate(20px, 19px) skew(-12deg) rotate(-10deg);
color: #fff;
background-color: rgb(13, 15, 39);
}
.symbol-title-sub {
display: block;
font-size: 80%;
margin-bottom: 2px;
}
.page-footer {
z-index: 100;
position: fixed;
width: 100%;
padding: 0px 5% 16px;
background: #fff;
bottom: 0;
left: 0;
@include respond-min($bp-narrow) {
padding: 10px 20px;
}
@include respond-min($bp-wide) {
padding: 12px 6%;
}
&:before {
content: '';
position: absolute;
bottom: 100%;
left: 0;
display: block;
width: 100%;
height: 44px;
background-image: url('');
@include respond-min($bp-narrow) {
bottom: 90%;
}
}
&:after {
@include respond-min($bp-narrow) {
content: 'SCROLL';
position: absolute;
bottom: 10px;
left: 50%;
transform: translate(-50%, 0);
display: block;
width: 125px;
height: 57px;
background-image: url('');
background-position: -4px bottom;
background-repeat: no-repeat;
text-align: center;
}
}
}
.page-footer-links {
text-align: center;
text-transform: uppercase;
@include font-size(18);
@include respond-min($bp-narrow) {
width: 100%;
text-align: right;
margin-top: -10px;
}
li {
display: inline-block;
@include respond-min($bp-mid) {
margin-bottom: 0;
}
@include respond-max($bp-mid) {
display: block;
}
&:first-child {
@include respond-min($bp-narrow) {
float: left;
}
}
&:last-child {
margin-bottom: 0;
}
}
a {
color: black;
}
.page-footer-info {
display: inline-block;
text-decoration: underline;
display: inline-block;
vertical-align: middle;
height: 2.5em;
line-height: 2.5;
@include respond-min($bp-narrow) {
padding-top: 5px;
}
}
.page-footer-site {
color: #333;
background: url('') no-repeat center center;
padding-top: 5px;
@include respond-min($bp-narrow) {
margin-left: 20px;
}
}
}
;(function(KO, $) {
$(function() {
KO.UI.init();
});
KO.UI = {
scrollActive: false,
supports : {
transform3d: false
},
init : function () {
this.handleZooming();
},
handleZooming : function () {
var zoomContent = $('.illust-container');
ZUI = new Zoomer(zoomContent);
//make sure page is at the top when reloaded
window.scrollTo(0, 0);
}
};
// the constructor that will do all the work
function Zoomer( content ) {
this.setLevels = function() {
if (this.docWidth > 1500) {
this.levels = 6.2;
this.verticalTranslate = 3000;
} else if (this.docWidth > 1350) {
this.levels = 6;
this.verticalTranslate = 2750;
} else if (this.docWidth > 1250) {
this.levels = 5.8;
this.verticalTranslate = 2450;
} else if (this.docWidth > 1150) {
this.levels = 5.7;
this.verticalTranslate = 2350;
} else if (this.docWidth > 1050) {
this.levels = 5.5;
this.verticalTranslate = 2100;
} else if (this.docWidth > 950) {
this.levels = 5.35;
this.verticalTranslate = 1900;
} else if (this.docWidth > 850) {
this.levels = 5.15;
this.verticalTranslate = 1700;
} else {
this.levels = 4.9;
this.verticalTranslate = 1520;
}
};
// keep track of DOM
this.content = content;
this.header = $('.page-header');
this.body = $('body');
this.town = $('.illust-level--town');
this.townSymbols = $('.illust-level--symbolsTown');
this.house = $('.svg-house');
this.carollers = $('.svg-carollers');
this.star = $('.svg-star');
// position of vertical scroll
this.scrolled = 0;
var body = document.body,
html = document.documentElement;
// height of document
this.docHeight = Math.max( body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight );
this.docWidth = html.clientWidth;
// zero-based number of sections
this.setLevels();
// bind Zoomer to scroll event
window.addEventListener( 'scroll', this, false);
}
// enables constructor to be used within event listener
// like obj.addEventListener( eventName, this, false )
Zoomer.prototype.handleEvent = function( event ) {
if ( this[event.type] ) {
this[event.type](event);
}
};
// triggered every time window scrolls
Zoomer.prototype.scroll = function( event ) {
this.recalculatePositions();
};
Zoomer.prototype.recalculatePositions = function () {
//LETS HAVE SOME DEFAULTS HERE
var INITIAL_TOWN_WIDTH = 350,
INITIAL_TOWN_HEIGHT = 320,
TARGET_TOWN_WIDTH = 2800,
TARGET_TOWN_HEIGHT = 2560,
TARGET_BG_ZSCALE = 200,
OFFSET_MARGIN = 80,
TARGET_VERTICAL_TRANSLATE = 2600;
var supportPageOffset = window.pageXOffset !== undefined;
var isCSS1Compat = ((document.compatMode || "") === "CSS1Compat");
var yOffset = supportPageOffset ? window.pageYOffset : isCSS1Compat ? document.documentElement.scrollTop : document.body.scrollTop;
// normalize scroll value from 0 to 1
this.scrolled = yOffset / ( this.docHeight - window.innerHeight );
var transformValue,
townTransform,
symboltransformValue;
this.checkStates();
var scrollFactor = (this.scrolled < 0.5 ? this.scrolled : 0.5);
var scale = Math.pow( 3, scrollFactor * this.levels );
var townHeight = Math.round(scale * INITIAL_TOWN_HEIGHT);
var townWidth = Math.round(scale * INITIAL_TOWN_WIDTH);
var townOffset = Math.round(scale * OFFSET_MARGIN) - OFFSET_MARGIN;
//first half of app is the scale – this zooms into the house
if (scrollFactor < 0.5) {
var townYPos = Math.round(((townHeight / 2) + townOffset));
//if we support translate3d
if (KO.UI.supports.transform3d) {
transformValue = 'translate3d(0, 0, 0) scale(' + scale + ')';
townTransform = 'translate3d(-50%, -' + townYPos + 'px, 0)';
symboltransformValue = 'translate3d(-' + (townWidth / 2) + 'px, -' + townYPos + 'px, 0)' + ' scale(' + scale + ')';
} else {
transformValue = 'translate(0, 0) scale(' + scale + ')';
townTransform = 'translate(-50%, -' + townYPos + 'px)';
symboltransformValue = 'translate(-' + (townWidth / 2) + 'px, -' + townYPos + 'px)' + ' scale(' + scale + ')';
}
//the second half is the translate vertically
} else {
var percentageThroughSection = ((this.scrolled - 0.5) / 0.5); //get the percentage of the amount through the section (on a scale 0-1)
var verticalTranslate = percentageThroughSection * this.verticalTranslate; //gets a scaled amount dependent on the percentage of the section scrolled through
var townYPos = Math.round((townHeight / 2) + townOffset - verticalTranslate);
//if we support translate3d
if (KO.UI.supports.transform3d) {
transformValue = 'translate3d(0, 0, 0) scale(' + scale + ')';
townTransform = 'translate3d(-50%, -' + townYPos + 'px, 0)';
} else {
transformValue = 'translate(0, 0) scale(' + scale + ')';
townTransform = 'translate(-50%, -' + townYPos + 'px)';
}
}
// SETTING OF OUR NEW VALUES
//update width and height of town
this.town[0].style.width = townWidth + 'px';
this.town[0].style.height = townHeight + 'px';
// //update the transformed value for the town
this.town[0].style.WebkitTransform = townTransform;
this.town[0].style.MozTransform = townTransform;
this.town[0].style.msTransform = townTransform;
this.town[0].style.transform = townTransform;
// //update scale factor of the outside illustrations and text
// if(navigator.userAgent.toLowerCase().indexOf('firefox') === -1) {
this.content[0].style.WebkitTransform = transformValue;
this.content[0].style.MozTransform = transformValue;
this.content[0].style.msTransform = transformValue;
this.content[0].style.transform = transformValue;
// }
// //town symbols scaling
this.townSymbols[0].style.WebkitTransform = 'scale(' + scale + ')';
this.townSymbols[0].style.MozTransform = 'scale(' + scale + ')';
this.townSymbols[0].style.msTransform = 'scale(' + scale + ')';
this.townSymbols[0].style.transform = 'scale(' + scale + ')';
};
Zoomer.prototype.checkStates = function () {
if (this.scrolled > 0) {
this.header.addClass('scaled');
} else {
this.header.removeClass('scaled');
}
//do a test whether to switch to night or not (after 0.25 scrolled)
if (this.scrolled > 0.15) {
this.body.addClass('night');
} else {
this.body.removeClass('night');
}
//test between state of movement
if (this.scrolled < 0.5) {
this.house.removeClass('inactive'); //make house visible
this.carollers.removeClass('inactive'); //make carollers invisible
this.star.addClass('inactive'); //make carollers invisible
this.townSymbols.find('.symbols--inside').addClass('inactive'); //make nativity symbols not visible
this.townSymbols.find('.symbols--outside').removeClass('inactive'); //make nativity symbols not visible
} else {
this.house.addClass('inactive'); //make house not visible
this.carollers.addClass('inactive'); //make carollers invisible
this.star.removeClass('inactive'); //make carollers invisible
this.townSymbols.find('.symbols--inside').removeClass('inactive'); //make nativity symbols visible
this.townSymbols.find('.symbols--outside').addClass('inactive'); //make nativity symbols not visible
}
};
})(window.KO = window.KO || {}, jQuery);
Also see: Tab Triggers