Use the attached files to copy the examples shown in our 'Getting Creative with Home Pages' Blog Post.
Moveable Elements Home Page with Numbered Images:
Copy and paste the following code into your portal's Custom HTML box:
<div id="movement"> <div id="clips"><img src="https://LINK-TO-IMAGE-4" /></div> </div> <div id="movement2"> <div id="paper"><img src="https://LINK-TO-IMAGE-8" /></div> </div> <div id="movement4"> <div id="clips2"><img src="https://LINK-TO-IMAGE-3" /></div> </div> <div id="movement3"> <div id="box"><img src="https://LINK-TO-IMAGE-2" /></div> </div> <div id="movement5"> <div id="stamp"><img src="https://LINK-TO-IMAGE-5" /></div> </div> <div id="movement7"> <div id="notebook"><img src="https://LINK-TO-IMAGE-1" /></div> </div> <div id="movement10"> <div id="plant"><img src="https://LINK-TO-IMAGE-6" /></div> </div> <div id="movement8"> <div id="pen"><img src="https://LINK-TO-IMAGE-7" /></div> </div> <div id="movement9"> <div id="pencil"><img src="https://LINK-TO-IMAGE-9" /></div> </div> <div id="movement6"> <div id="bag"><img src="https://LINK-TO-IMAGE-10" /></div> </div>
Copy and paste the following code into your portal's Custom CSS box:
.inside-page-content { width:100%; height:100%; } .page-home{ background-image: url('https://LINK-TO-BACKGROUND-IMAGE'); background-size:cover; background-position:center center; } #movement { position: absolute; top: 10%; right: 11%; } #movement2 { position: absolute; top: 30%; right: 1%; } #movement3 { position: absolute; top: 13%; left: 19%; } #movement4 { position: absolute; top: 9%; right: 32%; } #movement5 { position: absolute; top: 19%; right: 26%; } #movement6 { position: absolute; top: 49%; left: 43%; } #movement7 { position: absolute; top: 34%; left: 6%; } #movement8 { position: absolute; top: 51%; left: 32%; } #movement9 { position: absolute; top: 52%; right: 25%; } #movement10 { position: absolute; top: 27%; left: 44%; } #paper, #box, #clips, #clips2, #notebook, #pen, #pencil, #plant, #stamp, #bag{ cursor: move; } @media only screen and (max-width: 1400px) { #movement3, #movement9, #movement6 { display:none } #movement5 { left:30%; } #movement8 { top: 62%; left: 41%; } header { position: relative; z-index: 1; } } .shoppingcartdisplay-container { padding: 10px 2px; width: 250px; }
Copy and paste the following code into your portal's Custom Javascript box:
function dmLoad() { dragElement(document.getElementById("movement")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement2")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement3")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement4")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement5")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement6")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement7")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement8")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement9")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } dragElement(document.getElementById("movement10")); function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (document.getElementById(elmnt.id)) { elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; document.onmouseup = closeDragElement; // call a function whenever the cursor moves: document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { document.onmouseup = null; document.onmousemove = null; } } };
Mouse-Generated Ball Pit Home Page:
Copy and paste the following code into your portal's Custom HTML box:
<script src="https://cdnjs.cloudflare.com/ajax/libs/pixi.js/4.5.1/pixi.min.js"></script>
<div class="instructions">
WE LOVE COLOUR
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/pixi.js/4.5.1/pixi.min.js"></script> <div class="instructions"> WE LOVE COLOUR </div>
Copy and paste the following code into your portal's Custom CSS box:
body { margin:0; overflow:hidden; color:rgba(255,255,255,.8); font-family:arial; font-size: 15px; text-shadow: 1px 1px 1px #000; cursor: none; } canvas { background: #000; } .instructions { position: absolute; top:30%; background-color: white; color: black; font-size: 5em; font-weight: 900; margin: 0px auto; padding:120px 0px; width: 60%; text-align: center; mix-blend-mode: screen; } .inside-page-content { margin:0px;} .page-home .page-content { min-height: 0px; }
Copy and paste the following code into your portal's Custom Javascript box:
function dmLoad() { const userDefined = { gravity: 10, friction: .99, ballSize: 50, wallFriction: .5, distribution: 10, spread: 10 } const colours = [ // Add custom colours by changing the hex code located on each line after the letter x '0xe34b4e', '0xe6826d', '0x71616d', '0xa1c4be', '0x217b7e', '0x1d558a' ] const coloursLength = colours.length; const halfSpread = userDefined.spread/2; var mouse = {x:0,y:0}; var oldMouse = {x:0,y:0}; var balls = []; const pixelTexture=PIXI.Texture.fromImage(''); var windowDimensions = { width: window.innerWidth, height: window.innerHeight } const app = new PIXI.Application(windowDimensions.width, windowDimensions.height, { antialias: true, transparent: true }); document.body.appendChild(app.view); $(window).on('resize', function () { windowDimensions = { width: window.innerWidth, height: window.innerHeight } app.renderer.resize(windowDimensions.width,windowDimensions.height); }); $(window).on('mousemove touchmove', function (e) { mouse = { x: e.originalEvent.touches ? e.originalEvent.touches[0].pageX : e.pageX, y: e.originalEvent.touches ? e.originalEvent.touches[0].pageY : e.pageY, } for (let i = 0, length = Math.random()*userDefined.distribution; i < length; i++) { createBall( mouse.x, mouse.y, (mouse.x - oldMouse.x)*Math.random(), (mouse.y - oldMouse.y)*Math.random()); } oldMouse = { x: mouse.x, y: mouse.y } }); function createBall (x, y, xv, yv) { var ball = new PIXI.Sprite(pixelTexture); ball.x = x; ball.y = y; ball.width = ball.height = userDefined.ballSize; ball.xv = xv + (-halfSpread+Math.random()*userDefined.spread); ball.yv = yv + (-halfSpread+Math.random()*userDefined.spread); ball.tint = colours[Math.floor(Math.random()*coloursLength)]; balls.push(ball); app.stage.addChild(ball); } setTimeout(function () { for (let i = 0, length = userDefined.distribution*100; i < length; i++) { createBall( Math.random()*windowDimensions.width, Math.random()*(-windowDimensions.height), -5+Math.random()*10, -5+Math.random()*10) } }, 2500); (function loop() { for (let i = 0, length = balls.length; i < length; i++) { balls[i].x += balls[i].xv; balls[i].y += balls[i].yv+userDefined.gravity; balls[i].xv *= userDefined.friction; balls[i].yv *= userDefined.friction; if (balls[i].x <= 0) { balls[i].x = 0; } else if (balls[i].x >= windowDimensions.width-userDefined.ballSize) { balls[i].x = windowDimensions.width-userDefined.ballSize; } if (balls[i].x <= 0 || balls[i].x >= windowDimensions.width-userDefined.ballSize) { balls[i].xv*=-1; balls[i].xv *= userDefined.wallFriction; } } for (let i = 0, length = balls.length; i < length; i++) { if (balls[i].y >= windowDimensions.height) { app.stage.removeChild(balls[i]); balls.splice(i, 1); length--; } } requestAnimationFrame(loop); })(); };
Neon Sign with Text Editing Home Page:
Copy and paste the following code into your portal's Custom HTML box:
<style> @import url('https://fonts.googleapis.com/css?family=Sacramento&display=swap'); @import url('https://fonts.googleapis.com/css?family=Quicksand&display=swap'); </style> <h1 contenteditable="true">Vintage Studio</h1> <h4 contenteditable="true">Click the sign to write your own message!</h4>
Copy and paste the following code into your portal's Custom CSS box:
h1 { font-size: calc(20px + 18vh); line-height: calc(20px + 20vh); text-shadow: 0 0 5px #ffa500, 0 0 15px #ffa500, 0 0 20px #ffa500, 0 0 40px #ffa500, 0 0 60px #ff0000, 0 0 10px #ff8d00, 0 0 98px #ff0000; color: #fff6a9; font-family: "Sacramento", cursive; text-align: center; animation: blink 12s infinite; -webkit-animation: blink 12s infinite; } h4 { font-size: calc(10px + 2vh); line-height: calc(10px +10vh); text-shadow: 0 0 5px #ffa500, 0 0 15px #ffa500, 0 0 20px #ffa500, 0 0 40px #ffa500, 0 0 60px #ff0000, 0 0 10px #ff8d00, 0 0 98px #ff0000; color: #fff6a9; font-family: 'Quicksand', sans-serif; text-align: center; animation: blink 12s infinite; -webkit-animation: blink 12s infinite; padding-top: 50px; margin-bottom: -50px; } .inside-page-content { display: flex; justify-content: center; align-items: center; height: calc(100vh - 109px); background: #222; background-image: repeating-linear-gradient( to bottom, transparent 7px, rgba(0, 0, 0, 0.8) 9px, rgba(0, 0, 0, 0.8) 13px, transparent 13px ); } @-webkit-keyframes blink { 20%, 24%, 55% { color: #111; text-shadow: none; } 0%, 19%, 21%, 23%, 25%, 54%, 56%, 100% { text-shadow: 0 0 5px #ffa500, 0 0 15px #ffa500, 0 0 20px #ffa500, 0 0 40px #ffa500, 0 0 60px #ff0000, 0 0 10px #ff8d00, 0 0 98px #ff0000; color: #fff6a9; } } @keyframes blink { 20%, 24%, 55% { color: #111; text-shadow: none; } 0%, 19%, 21%, 23%, 25%, 54%, 56%, 100% { text-shadow: 0 0 5px #ffa500, 0 0 15px #ffa500, 0 0 20px #ffa500, 0 0 40px #ffa500, 0 0 60px #ff0000, 0 0 10px #ff8d00, 0 0 98px #ff0000; color: #fff6a9; } }