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;
}
}
create new ticket
check ticket status