"mobile"
Bootstrap 3.0.0 Snippet by evarevirus

<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>

Related: See More


Questions / Comments: