Permalink
Browse files

Merge branch 'master' of github.com:amigame/invadersunited

  • Loading branch information...
2 parents a202aaa + 1389fea commit b60fffd59216c3211eab8d76dcf4b2eaa924c04d @tracend tracend committed May 7, 2012
Showing with 506 additions and 2 deletions.
  1. +158 −0 public/assets/css/add2home.css
  2. +5 −0 public/assets/css/main.css
  3. +342 −0 public/assets/js/libs/add2home.js
  4. +1 −0 public/assets/js/main.js
  5. +0 −2 views/layout.jade
View
158 public/assets/css/add2home.css
@@ -0,0 +1,158 @@
+/**
+ *
+ * Main container
+ *
+ */
+#addToHomeScreen {
+ z-index:9999;
+ -webkit-user-select:none;
+ -webkit-box-sizing:border-box;
+ width:240px;
+ font-size:15px;
+ padding:12px 14px;
+ text-align:left;
+ font-family:helvetica;
+ background-image:-webkit-gradient(linear,0 0,0 100%,color-stop(0,#fff),color-stop(0.02,#eee),color-stop(0.98,#ccc),color-stop(1,#a3a3a3));
+ border:1px solid #505050;
+ -webkit-border-radius:8px;
+ -webkit-background-clip:padding-box;
+ color:#333;
+ text-shadow:0 1px 0 rgba(255,255,255,0.75);
+ line-height:130%;
+ -webkit-box-shadow:0 0 4px rgba(0,0,0,0.5);
+}
+
+#addToHomeScreen.addToHomeIpad {
+ width:268px;
+ font-size:18px;
+ padding:14px;
+}
+
+/**
+ *
+ * The 'wide' class is added when the popup contains the touch icon
+ *
+ */
+#addToHomeScreen.addToHomeWide {
+ width:296px;
+}
+
+#addToHomeScreen.addToHomeIpad.addToHomeWide {
+ width:320px;
+ font-size:18px;
+ padding:14px;
+}
+
+/**
+ *
+ * The balloon arrow
+ *
+ */
+#addToHomeScreen .addToHomeArrow {
+ position:absolute;
+ background-image:-webkit-gradient(linear,0 0,100% 100%,color-stop(0,rgba(204,204,204,0)),color-stop(0.4,rgba(204,204,204,0)),color-stop(0.4,#ccc));
+ border-width:0 1px 1px 0;
+ border-style:solid;
+ border-color:#505050;
+ width:16px; height:16px;
+ -webkit-transform:rotateZ(45deg);
+ bottom:-9px; left:50%;
+ margin-left:-8px;
+ -webkit-box-shadow:inset -1px -1px 0 #a9a9a9;
+ -webkit-border-bottom-right-radius:2px;
+}
+
+
+/**
+ *
+ * The balloon arrow for iPad
+ *
+ */
+#addToHomeScreen.addToHomeIpad .addToHomeArrow {
+ -webkit-transform:rotateZ(-135deg);
+ background-image:-webkit-gradient(linear,0 0,100% 100%,color-stop(0,rgba(238,238,238,0)),color-stop(0.4,rgba(238,238,238,0)),color-stop(0.4,#eee));
+ -webkit-box-shadow:inset -1px -1px 0 #fff;
+ top:-9px; bottom:auto; left:50%;
+}
+
+
+/**
+ *
+ * Close button
+ *
+ */
+#addToHomeScreen .addToHomeClose {
+ -webkit-box-sizing:border-box;
+ position:absolute;
+ right:4px;
+ top:4px;
+ width:18px;
+ height:18px; line-height:14px;
+ text-align:center;
+ text-indent:1px;
+ -webkit-border-radius:9px;
+ background:rgba(0,0,0,0.12);
+ color:#707070;
+ -webkit-box-shadow:0 1px 0 #fff;
+ font-size:16px;
+}
+
+
+/**
+ *
+ * The '+' icon, displayed only on iOS < 4.2
+ *
+ */
+#addToHomeScreen .addToHomePlus {
+ font-weight:bold;
+ font-size:1.3em;
+}
+
+
+/**
+ *
+ * The 'share' icon, displayed only on iOS >= 4.2
+ *
+ */
+#addToHomeScreen .addToHomeShare {
+ display:inline-block;
+ width:18px;
+ height:15px;
+ background-repeat:no-repeat;
+ background-image:url();
+ background-size:18px 15px;
+ text-indent:-9999em;
+ overflow:hidden;
+}
+
+
+/**
+ *
+ * The touch icon (if available)
+ *
+ */
+#addToHomeScreen .addToHomeTouchIcon {
+ display:block;
+ float:left;
+ -webkit-border-radius:6px;
+ -webkit-box-shadow:0 1px 3px rgba(0,0,0,0.5),
+ inset 0 0 2px rgba(255,255,255,0.9);
+ background-repeat:no-repeat;
+ width:57px; height:57px;
+ -webkit-background-size:57px 57px;
+ margin:0 12px 0 0;
+ border:1px solid #333;
+ -webkit-background-clip:padding-box;
+}
+
+
+/**
+ *
+ * The 'share' icon for retina display
+ *
+ */
+@media all and (-webkit-min-device-pixel-ratio: 2) {
+ #addToHomeScreen .addToHomeShare {
+ background-image:url();
+ }
+}
View
5 public/assets/css/main.css
@@ -1,3 +1,8 @@
+/* External stylesheets */
+@import url("add2home.css");
+@import url("jquery.noty.css");
+@import url("noty_theme_default.css");
+
* { margin: 0; padding: 0; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }
html, body { position: relative; width: 100%; height: 100%; overflow: hidden; font-family:Arial, Helvetica, sans-serif; font-size: 100%; }
#stage { }
View
342 public/assets/js/libs/add2home.js
@@ -0,0 +1,342 @@
+/*!
+ * Add to Homescreen v2.0.1 ~ Copyright (c) 2012 Matteo Spinelli, http://cubiq.org
+ * Released under MIT license, http://cubiq.org/license
+ */
+var addToHome = (function (w) {
+ var nav = w.navigator,
+ isIDevice = 'platform' in nav && (/iphone|ipod|ipad/gi).test(nav.platform),
+ isIPad,
+ isRetina,
+ isSafari,
+ isStandalone,
+ OSVersion,
+ startX = 0,
+ startY = 0,
+ lastVisit = 0,
+ isExpired,
+ isSessionActive,
+ isReturningVisitor,
+ balloon,
+ overrideChecks,
+
+ positionInterval,
+ closeTimeout,
+
+ options = {
+ autostart: true, // Automatically open the balloon
+ returningVisitor: false, // Show the balloon to returning visitors only (setting this to true is HIGHLY RECCOMENDED)
+ animationIn: 'drop', // drop || bubble || fade
+ animationOut: 'fade', // drop || bubble || fade
+ startDelay: 2000, // 2 seconds from page load before the balloon appears
+ lifespan: 15000, // 15 seconds before it is automatically destroyed
+ bottomOffset: 14, // Distance of the balloon from bottom
+ expire: 0, // Minutes to wait before showing the popup again (0 = always displayed)
+ message: '', // Customize your message or force a language ('' = automatic)
+ touchIcon: false, // Display the touch icon
+ arrow: true, // Display the balloon arrow
+ hookOnLoad: true, // Should we hook to onload event? (really advanced usage)
+ iterations: 100 // Internal/debug use
+ },
+
+ intl = {
+ ca_es: 'Per instal·lar aquesta aplicació al vostre %device premeu %icon i llavors <strong>Afegir a pantalla d\'inici</strong>.',
+ cs_cz: 'Pro instalaci aplikace na Váš %device, stiskněte %icon a v nabídce <strong>Přidat na plochu</strong>.',
+ da_dk: 'Tilføj denne side til din %device: tryk på %icon og derefter <strong>Føj til hjemmeskærm</strong>.',
+ de_de: 'Installieren Sie diese App auf Ihrem %device: %icon antippen und dann <strong>Zum Home-Bildschirm</strong>.',
+ el_gr: 'Εγκαταστήσετε αυτήν την Εφαρμογή στήν συσκευή σας %device: %icon μετά πατάτε <strong>Προσθήκη σε Αφετηρία</strong>.',
+ en_us: 'Install this web app on your %device: tap %icon and then <strong>Add to Home Screen</strong>.',
+ es_es: 'Para instalar esta app en su %device, pulse %icon y seleccione <strong>Añadir a pantalla de inicio</strong>.',
+ fi_fi: 'Asenna tämä web-sovellus laitteeseesi %device: paina %icon ja sen jälkeen valitse <strong>Lisää Koti-valikkoon</strong>.',
+ fr_fr: 'Ajoutez cette application sur votre %device en cliquant sur %icon, puis <strong>Ajouter à l\'écran d\'accueil</strong>.',
+ he_il: '<span dir="rtl">התקן אפליקציה זו על ה-%device שלך: הקש %icon ואז <strong>הוסף למסך הבית</strong>.</span>',
+ hu_hu: 'Telepítse ezt a web-alkalmazást az Ön %device-jára: nyomjon a %icon-ra majd a <strong>Főképernyőhöz adás</strong> gombra.',
+ it_it: 'Installa questa applicazione sul tuo %device: premi su %icon e poi <strong>Aggiungi a Home</strong>.',
+ ja_jp: 'このウェブアプリをあなたの%deviceにインストールするには%iconをタップして<strong>ホーム画面に追加</strong>を選んでください。',
+ ko_kr: '%device에 웹앱을 설치하려면 %icon을 터치 후 "홈화면에 추가"를 선택하세요',
+ nb_no: 'Installer denne appen på din %device: trykk på %icon og deretter <strong>Legg til på Hjem-skjerm</strong>',
+ nl_nl: 'Installeer deze webapp op uw %device: tik %icon en dan <strong>Zet in beginscherm</strong>.',
+ pl_pl: 'Aby zainstalować tę aplikacje na %device: naciśnij %icon a następnie <strong>Dodaj jako ikonę</strong>.',
+ pt_br: 'Instale este web app em seu %device: aperte %icon e selecione <strong>Adicionar à Tela Inicio</strong>.',
+ pt_pt: 'Para instalar esta aplicação no seu %device, prima o %icon e depois o <strong>Adicionar ao ecrã principal</strong>.',
+ ru_ru: 'Установите это веб-приложение на ваш %device: нажмите %icon, затем <strong>Добавить в «Домой»</strong>.',
+ sv_se: 'Lägg till denna webbapplikation på din %device: tryck på %icon och därefter <strong>Lägg till på hemskärmen</strong>.',
+ th_th: 'ติดตั้งเว็บแอพฯ นี้บน %device ของคุณ: แตะ %icon และ <strong>เพิ่มที่หน้าจอโฮม</strong>',
+ tr_tr: '%device için bu uygulamayı kurduktan sonra %icon simgesine dokunarak <strong>Ana Ekrana Ekle</strong>yin.',
+ zh_cn: '您可以将此应用程式安装到您的 %device 上。请按 %icon 然后点选<strong>添加至主屏幕</strong>。',
+ zh_tw: '您可以將此應用程式安裝到您的 %device 上。請按 %icon 然後點選<strong>加入主畫面螢幕</strong>。'
+ };
+
+ function init () {
+ // Preliminary check, prevents all further checks to be performed on iDevices only
+ if ( !isIDevice ) return;
+
+ var now = Date.now(),
+ i;
+
+ // Merge local with global options
+ if (w.addToHomeConfig) {
+ for ( i in w.addToHomeConfig ) {
+ options[i] = w.addToHomeConfig[i];
+ }
+ }
+ if ( !options.autostart ) options.hookOnLoad = false;
+
+ isIPad = (/ipad/gi).test(nav.platform);
+ isRetina = w.devicePixelRatio && w.devicePixelRatio > 1;
+ isSafari = nav.appVersion.match(/Safari/gi);
+ isStandalone = nav.standalone;
+
+ OSVersion = nav.appVersion.match(/OS (\d+_\d+)/i);
+ OSVersion = OSVersion[1] ? +OSVersion[1].replace('_', '.') : 0;
+
+ lastVisit = +w.localStorage.getItem('addToHome');
+
+ isSessionActive = w.sessionStorage.getItem('addToHomeSession');
+ isReturningVisitor = options.returningVisitor ? lastVisit && lastVisit + 28*24*60*60*1000 > now : true;
+
+ if ( !lastVisit ) lastVisit = now;
+
+ // If it is expired we need to reissue a new balloon
+ isExpired = isReturningVisitor && lastVisit <= now;
+
+ if ( options.hookOnLoad ) w.addEventListener('load', loaded, false);
+ else if ( !options.hookOnLoad && options.autostart ) loaded();
+ }
+
+ function loaded () {
+ w.removeEventListener('load', loaded, false);
+
+ if ( !isReturningVisitor ) w.localStorage.setItem('addToHome', Date.now());
+ else if ( options.expire && isExpired ) w.localStorage.setItem('addToHome', Date.now() + options.expire * 60000);
+
+ if ( !overrideChecks && ( !isSafari || !isExpired || isSessionActive || isStandalone || !isReturningVisitor ) ) return;
+
+ var icons = options.touchIcon ? document.querySelectorAll('head link[rel=apple-touch-icon],head link[rel=apple-touch-icon-precomposed]') : [],
+ sizes,
+ touchIcon = '',
+ closeButton,
+ platform = nav.platform.split(' ')[0],
+ language = nav.language.replace('-', '_'),
+ i, l;
+
+ balloon = document.createElement('div');
+ balloon.id = 'addToHomeScreen';
+ balloon.style.cssText += 'left:-9999px;-webkit-transition-property:-webkit-transform,opacity;-webkit-transition-duration:0;-webkit-transform:translate3d(0,0,0);position:' + (OSVersion < 5 ? 'absolute' : 'fixed');
+
+ // Localize message
+ if ( options.message in intl ) { // You may force a language despite the user's locale
+ language = options.message;
+ options.message = '';
+ }
+ if ( options.message === '' ) { // We look for a suitable language (defaulted to en_us)
+ options.message = language in intl ? intl[language] : intl['en_us'];
+ }
+
+ // Search for the apple-touch-icon
+ if ( icons.length ) {
+ for ( i = 0, l = icons.length; i < l; i++ ) {
+ sizes = icons[i].getAttribute('sizes');
+
+ if ( sizes ) {
+ if ( isRetina && sizes == '114x114' ) {
+ touchIcon = icons[i].href;
+ break;
+ }
+ } else {
+ touchIcon = icons[i].href;
+ }
+ }
+
+ touchIcon = '<span style="background-image:url(' + touchIcon + ')" class="addToHomeTouchIcon"></span>';
+ }
+
+ balloon.className = (isIPad ? 'addToHomeIpad' : 'addToHomeIphone') + (touchIcon ? ' addToHomeWide' : '');
+ balloon.innerHTML = touchIcon +
+ options.message.replace('%device', platform).replace('%icon', OSVersion >= 4.2 ? '<span class="addToHomeShare"></span>' : '<span class="addToHomePlus">+</span>') +
+ (options.arrow ? '<span class="addToHomeArrow"></span>' : '') +
+ '<span class="addToHomeClose">\u00D7</span>';
+
+ document.body.appendChild(balloon);
+
+ // Add the close action
+ closeButton = balloon.querySelector('.addToHomeClose');
+ if ( closeButton ) closeButton.addEventListener('click', clicked, false);
+
+ setTimeout(show, options.startDelay);
+ }
+
+ function show () {
+ var duration,
+ iPadXShift = 160;
+
+ // Set the initial position
+ if ( isIPad ) {
+ if ( OSVersion < 5 ) {
+ startY = w.scrollY;
+ startX = w.scrollX;
+ iPadXShift = 208;
+ }
+
+ balloon.style.top = startY + options.bottomOffset + 'px';
+ balloon.style.left = startX + iPadXShift - Math.round(balloon.offsetWidth / 2) + 'px';
+
+ switch ( options.animationIn ) {
+ case 'drop':
+ duration = '0.6s';
+ balloon.style.webkitTransform = 'translate3d(0,' + -(w.scrollY + options.bottomOffset + balloon.offsetHeight) + 'px,0)';
+ break;
+ case 'bubble':
+ duration = '0.6s';
+ balloon.style.opacity = '0';
+ balloon.style.webkitTransform = 'translate3d(0,' + (startY + 50) + 'px,0)';
+ break;
+ default:
+ duration = '1s';
+ balloon.style.opacity = '0';
+ }
+ } else {
+ startY = w.innerHeight + w.scrollY;
+
+ if ( OSVersion < 5 ) {
+ startX = Math.round((w.innerWidth - balloon.offsetWidth) / 2) + w.scrollX;
+ balloon.style.left = startX + 'px';
+ balloon.style.top = startY - balloon.offsetHeight - options.bottomOffset + 'px';
+ } else {
+ balloon.style.left = '50%';
+ balloon.style.marginLeft = -Math.round(balloon.offsetWidth / 2) + 'px';
+ balloon.style.bottom = options.bottomOffset + 'px';
+ }
+
+ switch (options.animationIn) {
+ case 'drop':
+ duration = '1s';
+ balloon.style.webkitTransform = 'translate3d(0,' + -(startY + options.bottomOffset) + 'px,0)';
+ break;
+ case 'bubble':
+ duration = '0.6s';
+ balloon.style.webkitTransform = 'translate3d(0,' + (balloon.offsetHeight + options.bottomOffset + 50) + 'px,0)';
+ break;
+ default:
+ duration = '1s';
+ balloon.style.opacity = '0';
+ }
+ }
+
+ balloon.offsetHeight; // repaint trick
+ balloon.style.webkitTransitionDuration = duration;
+ balloon.style.opacity = '1';
+ balloon.style.webkitTransform = 'translate3d(0,0,0)';
+ balloon.addEventListener('webkitTransitionEnd', transitionEnd, false);
+
+ closeTimeout = setTimeout(close, options.lifespan);
+ }
+
+ function manualShow (override) {
+ if ( !isIDevice || balloon ) return;
+
+ overrideChecks = override;
+ loaded();
+ }
+
+ function close () {
+ clearInterval( positionInterval );
+ clearTimeout( closeTimeout );
+ closeTimeout = null;
+
+ var posY = 0,
+ posX = 0,
+ opacity = '1',
+ duration = '0',
+ closeButton = balloon.querySelector('.addToHomeClose');
+
+ if ( closeButton ) closeButton.removeEventListener('click', close, false);
+
+ if ( OSVersion < 5 ) {
+ posY = isIPad ? w.scrollY - startY : w.scrollY + w.innerHeight - startY;
+ posX = isIPad ? w.scrollX - startX : w.scrollX + Math.round((w.innerWidth - balloon.offsetWidth)/2) - startX;
+ }
+
+ balloon.style.webkitTransitionProperty = '-webkit-transform,opacity';
+
+ switch ( options.animationOut ) {
+ case 'drop':
+ if ( isIPad ) {
+ duration = '0.4s';
+ opacity = '0';
+ posY = posY + 50;
+ } else {
+ duration = '0.6s';
+ posY = posY + balloon.offsetHeight + options.bottomOffset + 50;
+ }
+ break;
+ case 'bubble':
+ if ( isIPad ) {
+ duration = '0.8s';
+ posY = posY - balloon.offsetHeight - options.bottomOffset - 50;
+ } else {
+ duration = '0.4s';
+ opacity = '0';
+ posY = posY - 50;
+ }
+ break;
+ default:
+ duration = '0.8s';
+ opacity = '0';
+ }
+
+ balloon.addEventListener('webkitTransitionEnd', transitionEnd, false);
+ balloon.style.opacity = opacity;
+ balloon.style.webkitTransitionDuration = duration;
+ balloon.style.webkitTransform = 'translate3d(' + posX + 'px,' + posY + 'px,0)';
+ }
+
+
+ function clicked () {
+ w.sessionStorage.setItem('addToHomeSession', '1');
+ isSessionActive = true;
+ close();
+ }
+
+ function transitionEnd () {
+ balloon.removeEventListener('webkitTransitionEnd', transitionEnd, false);
+
+ balloon.style.webkitTransitionProperty = '-webkit-transform';
+ balloon.style.webkitTransitionDuration = '0.2s';
+
+ // We reached the end!
+ if ( !closeTimeout ) {
+ balloon.parentNode.removeChild(balloon);
+ balloon = null;
+ return;
+ }
+
+ // On iOS 4 we start checking the element position
+ if ( OSVersion < 5 && closeTimeout ) positionInterval = setInterval(setPosition, options.iterations);
+ }
+
+ function setPosition () {
+ var matrix = new WebKitCSSMatrix(w.getComputedStyle(balloon, null).webkitTransform),
+ posY = isIPad ? w.scrollY - startY : w.scrollY + w.innerHeight - startY,
+ posX = isIPad ? w.scrollX - startX : w.scrollX + Math.round((w.innerWidth - balloon.offsetWidth) / 2) - startX;
+
+ // Screen didn't move
+ if ( posY == matrix.m42 && posX == matrix.m41 ) return;
+
+ balloon.style.webkitTransform = 'translate3d(' + posX + 'px,' + posY + 'px,0)';
+ }
+
+ // Clear local and session storages (this is useful primarily in development)
+ function reset () {
+ w.localStorage.removeItem('addToHome');
+ w.sessionStorage.removeItem('addToHomeSession');
+ }
+
+ // Bootstrap!
+ init();
+
+ return {
+ show: manualShow,
+ close: close,
+ reset: reset
+ };
+})(this);
View
1 public/assets/js/main.js
@@ -14,6 +14,7 @@ require({
"order!libs/processing-1.3.6.min",
"order!libs/md5",
"order!libs/jquery.noty",
+ "order!libs/add2home",
"order!misc/helpers",
"order!misc/tracking",
"order!config",
View
2 views/layout.jade
@@ -2,8 +2,6 @@
html
head
title= title
- link(rel="stylesheet", href="/assets/css/jquery.noty.css")
- link(rel="stylesheet", href="/assets/css/noty_theme_default.css")
link(rel="stylesheet", href="/assets/css/main.css")
body
!= body

0 comments on commit b60fffd

Please sign in to comment.