<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" rel="stylesheet" id="bootstrap-css">
<script src="//netdna.bootstrapcdn.com/bootstrap/3.0.0/js/bootstrap.min.js"></script>
<script src="//code.jquery.com/jquery-1.11.1.min.js"></script>
<!------ Include the above in your HEAD tag ---------->
<!DOCTYPE html><html lang='en' class=''>
<head><script src='//production-assets.codepen.io/assets/editor/live/console_runner-079c09a0e3b9ff743e39ee2d5637b9216b3545af0de366d4b9aad9dc87e26bfd.js'></script><script src='//production-assets.codepen.io/assets/editor/live/events_runner-73716630c22bbc8cff4bd0f07b135f00a0bdc5d14629260c3ec49e5606f98fdd.js'></script><script src='//production-assets.codepen.io/assets/editor/live/css_live_reload_init-2c0dc5167d60a5af3ee189d570b1835129687ea2a61bee3513dee3a50c115a77.js'></script><meta charset='UTF-8'><meta name="robots" content="noindex"><link rel="shortcut icon" type="image/x-icon" href="//production-assets.codepen.io/assets/favicon/favicon-8ea04875e70c4b0bb41da869e81236e54394d63638a1ef12fa558a4a835f1164.ico" /><link rel="mask-icon" type="" href="//production-assets.codepen.io/assets/favicon/logo-pin-f2d2b6d2c61838f7e76325261b7195c27224080bc099486ddd6dccb469b8e8e6.svg" color="#111" /><link rel="canonical" href="https://codepen.io/og2t/pen/AqlLn?limit=all&page=10&q=app" />
<style class="cp-pen-styles">*,
*:before,
*:after {
-webkit-box-sizing: border-box;
box-sizing: border-box;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
body {
margin: 0;
padding: 0;
background: #000;
overflow: hidden;
}
.icons-list {
position: absolute;
background: url("https://www.dropbox.com/s/v6plr4aagpfp0nu/iphone5s.png?raw=1") no-repeat;
background-size: 510px 883px;
width: 510px;
height: 883px;
margin: -403px 0 0 -249px;
left: 50%;
top: 50%;
}
.icons-list ul {
position: absolute;
padding: 26px 16px;
background: url("https://www.dropbox.com/s/guzcdl7itxkoecl/bgrd.png?raw=1");
background-size: 320px 568px;
width: 320px;
height: 568px;
left: 89px;
top: 103px;
overflow: hidden;
}
.icons-list ul.shaking .dragging div {
-webkit-animation: none;
animation: none;
}
.icons-list ul.shaking div {
-webkit-animation: shake 0.25s 0s ease-in-out infinite;
animation: shake 0.25s 0s ease-in-out infinite;
}
.icons-list li {
-webkit-transition: opacity, -webkit-transform 0.25s ease-in-out;
transition: opacity, -webkit-transform 0.25s ease-in-out;
transition: opacity, transform 0.25s ease-in-out;
transition: opacity, transform 0.25s ease-in-out, -webkit-transform 0.25s ease-in-out;
cursor: pointer;
list-style: none;
position: absolute;
text-align: center;
font-size: 11px;
color: #000;
font-family: Helvetica, Arial, sans-serif;
}
.icons-list li span {
width: 100%;
display: block;
position: absolute;
text-align: center;
top: 64px;
}
.icons-list li.placeholder {
cursor: auto;
}
.icons-list li.placeholder div {
background: none;
}
.icons-list li.placeholder span {
display: none;
}
.icons-list li.dragging {
-webkit-transition: none;
transition: none;
opacity: 0.75;
}
.icons-list li.dragging div {
-webkit-transform: scale(1.25);
transform: scale(1.25);
}
.icons-list li.dragging div:after {
opacity: 0.75;
}
.icons-list li div {
background: #fff url("https://www.dropbox.com/s/dx2rln3r2cni89c/icons.jpg?raw=1") no-repeat;
background-size: 1440px 60px;
width: 100%;
height: 100%;
border-radius: 12px;
-webkit-transition: -webkit-transform 0.25s ease-out;
transition: -webkit-transform 0.25s ease-out;
transition: transform 0.25s ease-out;
transition: transform 0.25s ease-out, -webkit-transform 0.25s ease-out;
}
.icons-list li div:after {
content: '';
left: 0;
top: 0;
background: #000;
position: absolute;
z-index: 1;
width: 100%;
height: 100%;
border-radius: 12px;
opacity: 0;
}
.icons-list li div.appstore {
background-position: 0px 0px;
}
.icons-list li div.calculator {
background-position: -60px 0px;
}
.icons-list li div.calendar {
background-position: -120px 0px;
}
.icons-list li div.camera {
background-position: -180px 0px;
}
.icons-list li div.clock {
background-position: -240px 0px;
}
.icons-list li div.compass {
background-position: -300px 0px;
}
.icons-list li div.facetime {
background-position: -360px 0px;
}
.icons-list li div.itunesstore {
background-position: -420px 0px;
}
.icons-list li div.mail {
background-position: -480px 0px;
}
.icons-list li div.maps {
background-position: -540px 0px;
}
.icons-list li div.messages {
background-position: -600px 0px;
}
.icons-list li div.music {
background-position: -660px 0px;
}
.icons-list li div.passbook {
background-position: -720px 0px;
}
.icons-list li div.phone {
background-position: -780px 0px;
}
.icons-list li div.photos {
background-position: -840px 0px;
}
.icons-list li div.reminders {
background-position: -900px 0px;
}
.icons-list li div.safari {
background-position: -960px 0px;
}
.icons-list li div.settings {
background-position: -1020px 0px;
}
.icons-list li div.stocks {
background-position: -1080px 0px;
}
.icons-list li div.twitter {
background-position: -1140px 0px;
}
.icons-list li div.weather {
background-position: -1200px 0px;
}
.icons-list li div.newsstand {
background-position: -1260px 0px;
}
.icons-list li div.videos {
background-position: -1320px 0px;
}
.icons-list li div.notes {
background-position: -1380px 0px;
}
.info {
width: 320px;
font-family: Arial, sans-serif;
position: absolute;
z-index: 1000;
left: -300px;
top: 350px;
}
.info h4 {
color: #fff;
margin-bottom: 10px;
}
.info p {
color: #fff;
font-size: 14px;
}
@-webkit-keyframes shake {
0% {
-webkit-transform: rotateZ(-2deg);
transform: rotateZ(-2deg);
}
33.3% {
-webkit-transform: rotateZ(0deg);
transform: rotateZ(0deg);
}
66.6% {
-webkit-transform: rotateZ(2deg);
transform: rotateZ(2deg);
}
100% {
-webkit-transform: rotateZ(0deg);
transform: rotateZ(0deg);
}
}
@keyframes shake {
0% {
-webkit-transform: rotateZ(-2deg);
transform: rotateZ(-2deg);
}
33.3% {
-webkit-transform: rotateZ(0deg);
transform: rotateZ(0deg);
}
66.6% {
-webkit-transform: rotateZ(2deg);
transform: rotateZ(2deg);
}
100% {
-webkit-transform: rotateZ(0deg);
transform: rotateZ(0deg);
}
}
</style></head><body>
<div class="icons-list">
<ul>
<li>
<div class="appstore"><span>App Store</span></div>
</li>
<li>
<div class="calculator"><span>Calculator</span></div>
</li>
<li>
<div class="calendar"><span>Calendar</span></div>
</li>
<li>
<div class="camera"><span>Camera</span></div>
</li>
<li>
<div class="compass"><span>Compass</span></div>
</li>
<li>
<div class="itunesstore"><span>iTunes</span></div>
</li>
<li>
<div class="mail"><span>Mail</span></div>
</li>
<li>
<div class="maps"><span>Maps</span></div>
</li>
<li>
<div class="music"><span>Music</span></div>
</li>
<li>
<div class="passbook"><span>Passbook</span></div>
</li>
<li>
<div class="photos"><span>Photos</span></div>
</li>
<li>
<div class="reminders"><span>Reminders</span></div>
</li>
<li>
<div class="safari"><span>Safari</span></div>
</li>
<li>
<div class="stocks"><span>Stocks</span></div>
</li>
<li>
<div class="weather"><span>Weather</span></div>
</li>
<li>
<div class="facetime"><span>FaceTime</span></div>
</li>
<li>
<div class="newsstand"><span>Newsstand</span></div>
</li>
<li>
<div class="videos"><span>Videos</span></div>
</li>
<li>
<div class="notes"><span>Notes</span></div>
</li>
<li class="placeholder">
<div class="twitter"><span>Twitter</span></div>
</li>
<li>
<div class="phone"><span>Phone</span></div>
</li>
<li>
<div class="messages"><span>Messages</span></div>
</li>
<li>
<div class="clock"><span>Clock</span></div>
</li>
<li>
<div class="settings"><span>Settings</span></div>
</li>
</ul>
<div class="info">
<h4>iOS apps reordering done right :)</h4>
<p>Use mouse to drag and drop (Webkit only)</p>
</div>
</div>
<script src='//production-assets.codepen.io/assets/common/stopExecutionOnTimeout-b2a7b3fe212eaa732349046d8416e00a9dec26eb7fd347590fbced3ab38af52e.js'></script>
<script >(function() {
// Polyfills
var ShuffleGrid, addClass, grid, hasClass, iconsList, removeClass;
addClass = function(el, className) {
if (hasClass(el, className)) {
return;
}
if (el.classList) {
el.classList.add(className);
} else {
el.className += ' ' + className;
}
};
removeClass = function(el, className) {
if (el.classList) {
el.classList.remove(className);
} else {
el.className = el.className.replace(new RegExp("(^|\\b)" + className.split(" ").join("|") + "(\\b|$)", "gi"), " ");
}
};
hasClass = function(el, className) {
if (el.classList) {
return el.classList.contains(className);
} else {
return new RegExp("(^| )" + className + "( |$)", "gi").test(el.className);
}
};
ShuffleGrid = (function() {
var VENDORS;
// Here we go...
class ShuffleGrid {
constructor(context, cols, rows, colSize, rowSize, paddingX = 0, paddingY = 0) {
this.initIndex = this.initIndex.bind(this);
this.addItem = this.addItem.bind(this);
this.shuffleItems = this.shuffleItems.bind(this);
this.snapToGrid = this.snapToGrid.bind(this);
this.positionItem = this.positionItem.bind(this);
this.getPosition = this.getPosition.bind(this);
this.getCell = this.getCell.bind(this);
this.onMousePress = this.onMousePress.bind(this);
this.onMouseMove = this.onMouseMove.bind(this);
this.onMouseRelease = this.onMouseRelease.bind(this);
this.numCells = this.numCells.bind(this);
this.startDrag = this.startDrag.bind(this);
this.stopDrag = this.stopDrag.bind(this);
this.context = context;
this.cols = cols;
this.rows = rows;
this.colSize = colSize;
this.rowSize = rowSize;
this.paddingX = paddingX;
this.paddingY = paddingY;
this.numItems = 0;
this.initIndex();
this.items = [].slice.call(this.context.children);
this.items.forEach((item, id) => {
return this.addItem(item);
});
return;
}
initIndex() {
var i;
this.itemVOs = [];
this.index = new Array(this.rows);
i = 0;
while (i < this.rows) {if (window.CP.shouldStopExecution(1)){break;}if (window.CP.shouldStopExecution(1)){break;}
this.index[i++] = new Array(this.cols);
}
window.CP.exitedLoop(1);
window.CP.exitedLoop(1);
}
addItem(item) {
var col, id, itemVO, position, row;
col = this.numItems % this.cols;
row = Math.floor(this.numItems / this.cols);
position = this.getPosition(row, col);
id = this.numItems;
this.numItems++;
itemVO = {
row: row,
col: col,
item: item,
id: id
};
item.style.width = `${this.colSize}px`;
item.style.height = `${this.rowSize}px`;
item.setAttribute('id', id);
this.positionItem(item, position.x, position.y);
this.index[row][col] = itemVO;
this.itemVOs[id] = itemVO;
if (hasClass(item, 'placeholder')) {
return;
}
item.children[0].style.webkitAnimationDelay = Math.random() * 0.5 + 's';
item.children[0].style.MozAnimationDelay = Math.random() * 0.5 + 's';
item.addEventListener('mousedown', this.onMousePress, false);
return item;
}
shuffleItems() {
var cell, col, hMove, i, item, itemVO, move, row, vMove;
itemVO = this.itemVOs[this.currentItem.getAttribute('id')];
cell = this.getCell(parseInt(this.currentItem.getAttribute('x')), parseInt(this.currentItem.getAttribute('y')));
col = cell.x;
row = cell.y;
if (col === itemVO.col && row === itemVO.row) {
return;
}
hMove = col - itemVO.col;
vMove = row - itemVO.row;
move = [];
if (hMove < 0) {
i = itemVO.col - 1;
while (i >= itemVO.col + hMove) {if (window.CP.shouldStopExecution(2)){break;}if (window.CP.shouldStopExecution(2)){break;}
if (this.index[itemVO.row][i]) {
item = this.index[itemVO.row][i];
item.col++;
this.index[item.row][item.col] = item;
move.push(item);
}
i--;
}
window.CP.exitedLoop(2);
window.CP.exitedLoop(2);
} else {
i = itemVO.col + 1;
while (i <= itemVO.col + hMove) {if (window.CP.shouldStopExecution(3)){break;}if (window.CP.shouldStopExecution(3)){break;}
if (this.index[itemVO.row][i]) {
item = this.index[itemVO.row][i];
item.col--;
this.index[item.row][item.col] = item;
move.push(item);
}
i++;
}
window.CP.exitedLoop(3);
window.CP.exitedLoop(3);
}
if (vMove < 0) {
i = itemVO.row - 1;
while (i >= itemVO.row + vMove) {if (window.CP.shouldStopExecution(4)){break;}if (window.CP.shouldStopExecution(4)){break;}
if (this.index[i][itemVO.col + hMove]) {
item = this.index[i][itemVO.col + hMove];
item.row++;
this.index[item.row][item.col] = item;
move.push(item);
}
i--;
}
window.CP.exitedLoop(4);
window.CP.exitedLoop(4);
} else {
i = itemVO.row + 1;
while (i <= itemVO.row + vMove) {if (window.CP.shouldStopExecution(5)){break;}if (window.CP.shouldStopExecution(5)){break;}
if (this.index[i][itemVO.col + hMove]) {
item = this.index[i][itemVO.col + hMove];
item.row--;
this.index[item.row][item.col] = item;
move.push(item);
}
i++;
}
window.CP.exitedLoop(5);
window.CP.exitedLoop(5);
}
i = 0;
while (i < move.length) {if (window.CP.shouldStopExecution(6)){break;}if (window.CP.shouldStopExecution(6)){break;}
this.snapToGrid(move[i++]);
}
window.CP.exitedLoop(6);
window.CP.exitedLoop(6);
itemVO.row = row;
itemVO.col = col;
this.index[row][col] = itemVO;
}
snapToGrid(itemVO) {
var position;
position = this.getPosition(itemVO.row, itemVO.col);
this.positionItem(itemVO.item, position.x, position.y);
}
positionItem(item, x, y) {
var j, len, vendor;
for (j = 0, len = VENDORS.length; j < len; j++) {if (window.CP.shouldStopExecution(7)){break;}if (window.CP.shouldStopExecution(7)){break;}
vendor = VENDORS[j];
item.style[`${vendor}Transform`] = `translateX(${x}px) translateY(${y}px)`;
}
window.CP.exitedLoop(7);
window.CP.exitedLoop(7);
}
getPosition(row, col) {
var offsetY, position;
// Only used for the iOS demo
if (row > 4) {
offsetY = 20;
} else {
offsetY = 0;
}
position = {
x: col * (this.colSize + this.paddingX),
y: row * (this.rowSize + this.paddingY) + offsetY
};
return position;
}
getCell(x, y) {
var cell;
cell = {
x: Math.max(0, Math.min(this.cols - 1, Math.round(x / (this.colSize + this.paddingX)))),
y: Math.max(0, Math.min(this.rows - 1, Math.round(y / (this.rowSize + this.paddingY))))
};
return cell;
}
onMousePress(event) {
var contextOffset;
this.currentItem = event.currentTarget;
contextOffset = this.context.getBoundingClientRect();
this.originOffset = {
x: event.offsetX + contextOffset.left + 16,
y: event.offsetY + contextOffset.top + 26
};
this.startDrag(this.currentItem);
this.onMouseMove(event);
this.context.addEventListener('mouseup', this.onMouseRelease, false);
this.context.addEventListener('mousemove', this.onMouseMove, false);
this.context.addEventListener('mouseleave', this.onMouseRelease, false);
}
onMouseMove(event) {
var x, y;
x = event.clientX - this.originOffset.x;
y = event.clientY - this.originOffset.y;
this.currentItem.setAttribute('x', x);
this.currentItem.setAttribute('y', y);
this.positionItem(this.currentItem, x, y);
this.shuffleItems();
}
onMouseRelease(event) {
this.currentItem.removeEventListener('mouseout', this.onMouseRelease);
this.stopDrag(this.currentItem);
this.context.removeEventListener('mousemove', this.onMouseMove);
this.snapToGrid(this.itemVOs[this.currentItem.getAttribute('id')]);
}
numCells() {
return this.rows * this.cols;
}
startDrag(item) {
this.zIndex++;
item.style.zIndex = this.zIndex;
addClass(item, 'dragging');
addClass(this.context, 'shaking');
}
stopDrag(item) {
removeClass(item, 'dragging');
removeClass(this.context, 'shaking');
}
};
VENDORS = ['webkit', 'Moz'];
ShuffleGrid.prototype.zIndex = 100;
return ShuffleGrid;
})();
// Time to launch
iconsList = document.querySelector('.icons-list ul');
grid = new ShuffleGrid(iconsList, 4, 6, 60, 60, 16, 28);
}).call(this);
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":["<anonymous>"],"names":[],"mappings":"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","sourcesContent":["# Polyfills\n\naddClass = (el, className) ->\n  if hasClass el, className then return\n  if el.classList\n    el.classList.add className\n  else\n    el.className += ' ' + className\n  return\n\nremoveClass = (el, className) ->\n  if el.classList\n    el.classList.remove className\n  else\n    el.className = el.className.replace(new RegExp(\"(^|\\\\b)\" + className.split(\" \").join(\"|\") + \"(\\\\b|$)\", \"gi\"), \" \")\n  return\n\nhasClass = (el, className) ->\n  if el.classList\n    return el.classList.contains className\n  else\n    return new RegExp(\"(^| )\" + className + \"( |$)\", \"gi\").test el.className\n\n\n# Here we go...\n\nclass ShuffleGrid\n\n  VENDORS = ['webkit', 'Moz']\n  \n  zIndex: 100\n\n  constructor: (@context, @cols, @rows, @colSize, @rowSize, @paddingX = 0, @paddingY = 0) ->\n    @numItems = 0\n    @initIndex()\n\n    @items = [].slice.call @context.children\n    @items.forEach (item, id) =>\n      @addItem item\n    return\n\n\n  initIndex: () =>\n    @itemVOs = []\n    @index = new Array @rows\n\n    i = 0\n    while i < @rows\n      @index[i++] = new Array @cols\n    return\n\n\n  addItem: (item) =>\n    col = @numItems % @cols\n    row = Math.floor @numItems / @cols\n\n    position = @getPosition row, col\n\n    id = @numItems\n    @numItems++\n    \n    itemVO =\n      row: row\n      col: col\n      item: item\n      id: id\n\n    item.style.width = \"#{@colSize}px\"\n    item.style.height = \"#{@rowSize}px\"\n    item.setAttribute 'id', id\n    @positionItem item, position.x, position.y\n\n    \n    @index[row][col] = itemVO\n    @itemVOs[id] = itemVO\n\n    if hasClass item, 'placeholder' then return\n\n    item.children[0].style.webkitAnimationDelay = Math.random() * 0.5 + 's'\n    item.children[0].style.MozAnimationDelay = Math.random() * 0.5 + 's'\n    \n    item.addEventListener 'mousedown', @onMousePress, false\n    return item\n\n\n  shuffleItems: () =>\n    itemVO = @itemVOs[@currentItem.getAttribute 'id']\n\n    cell = @getCell parseInt(@currentItem.getAttribute 'x'), parseInt(@currentItem.getAttribute 'y')\n\n    col = cell.x\n    row = cell.y\n\n    return if col is itemVO.col and row is itemVO.row\n\n    hMove = col - itemVO.col\n    vMove = row - itemVO.row\n\n    move = []\n\n    if hMove < 0\n      i = itemVO.col - 1\n      while i >= itemVO.col + hMove\n        if @index[itemVO.row][i]\n          item = @index[itemVO.row][i]\n          item.col++\n          @index[item.row][item.col] = item\n          move.push item\n        i--\n    else\n      i = itemVO.col + 1\n      while i <= itemVO.col + hMove\n        if @index[itemVO.row][i]\n          item = @index[itemVO.row][i]\n          item.col--\n          @index[item.row][item.col] = item\n          move.push item\n        i++\n\n    if vMove < 0\n      i = itemVO.row - 1\n      while i >= itemVO.row + vMove\n        if @index[i][itemVO.col + hMove]\n          item = @index[i][itemVO.col + hMove]\n          item.row++\n          @index[item.row][item.col] = item\n          move.push item\n        i--\n    else\n      i = itemVO.row + 1\n      while i <= itemVO.row + vMove\n        if @index[i][itemVO.col + hMove]\n          item = @index[i][itemVO.col + hMove]\n          item.row--\n          @index[item.row][item.col] = item\n          move.push item\n        i++\n    \n    i = 0\n    while i < move.length\n      @snapToGrid move[i++]\n\n    itemVO.row = row\n    itemVO.col = col\n    @index[row][col] = itemVO\n    return\n\n\n  snapToGrid: (itemVO) =>\n    position = @getPosition itemVO.row, itemVO.col\n    @positionItem itemVO.item, position.x, position.y\n    return\n\n\n  positionItem: (item, x, y) =>\n    for vendor in VENDORS\n      item.style[\"#{vendor}Transform\"] = \"translateX(#{x}px) translateY(#{y}px)\"\n    return\n\n\n  getPosition: (row, col) =>\n    # Only used for the iOS demo\n    if row > 4 then offsetY = 20 else offsetY = 0 \n\n    position = \n      x: col * (@colSize + @paddingX)\n      y: row * (@rowSize + @paddingY) + offsetY\n    return position\n\n\n  getCell: (x, y) =>\n    cell = \n      x: Math.max(0, Math.min(@cols - 1, Math.round(x / (@colSize + @paddingX))))\n      y: Math.max(0, Math.min(@rows - 1, Math.round(y / (@rowSize + @paddingY))))\n    return cell\n\n\n  onMousePress: (event) =>\n    @currentItem = event.currentTarget\n \n    contextOffset = @context.getBoundingClientRect()\n    @originOffset = \n      x: event.offsetX + contextOffset.left + 16\n      y: event.offsetY + contextOffset.top + 26\n\n    @startDrag @currentItem\n    @onMouseMove event\n    @context.addEventListener 'mouseup', @onMouseRelease, false\n    @context.addEventListener 'mousemove', @onMouseMove, false\n    @context.addEventListener 'mouseleave', @onMouseRelease, false\n    return\n\n\n  onMouseMove: (event) =>\n    x = event.clientX - @originOffset.x\n    y = event.clientY - @originOffset.y\n    @currentItem.setAttribute 'x', x\n    @currentItem.setAttribute 'y', y\n    @positionItem @currentItem, x, y\n    @shuffleItems()\n    return\n  \n\n  onMouseRelease: (event) =>\n    @currentItem.removeEventListener 'mouseout', @onMouseRelease\n    @stopDrag @currentItem\n    @context.removeEventListener 'mousemove', @onMouseMove\n    @snapToGrid @itemVOs[@currentItem.getAttribute 'id']\n    return\n\n\n  numCells: () =>\n   return @rows * @cols\n\n\n  startDrag: (item) =>\n    @zIndex++\n    item.style.zIndex = @zIndex\n    addClass item, 'dragging'\n    addClass @context, 'shaking'\n    return  \n\n\n  stopDrag: (item) =>\n    removeClass item, 'dragging'\n    removeClass @context, 'shaking'\n    return  \n\n\n# Time to launch \niconsList = document.querySelector '.icons-list ul'\ngrid = new ShuffleGrid iconsList, 4, 6, 60, 60, 16, 28"]}
//# sourceURL=coffeescript
//# sourceURL=pen.js
</script>
</body></html>