* Oauth2 and first view * Connect with Coinbase using mobile * Buy and Sell through Coinbase * Fix buy * Receive and send bitcoin to Coinbase account * Receive bitcoin from Coinbase to Copay * Complete user and account information. Connection errors * Improves error handler * Removes console.log * Coinbase background color. Send to Coinbase form validation * Fix send from different wallet * Send and receive using Coinbase * Pagination activity * Fix Buy and Sell * One option in the sidebar to Buy and Sell * Native balance on Coinbase homepage * Rename receive and send * Auto-close window after authenticate * Reorder * Get payment methods * Fix when token expired * Fix token expired * Integration: sell and send to Coinbase * Store pending transaction before sell * Sell flow completed * Removing files * Fix sell * Fix sell * Fix sell * Sell completed * Buy bitcoin through coinbase * Buy auto * Currency set to USD * Select payment methods. Limits * Removes payment methods from preferences * Fix signs. Tx ordered by updated. Minor fixes * Removes console.log * Improving ux-language things * Fix selectedpaymentmethod if not verified * Set error if tx not found * Price sensitivity. Minor fixes * Adds coinbase api key to gitignore * Coinbase production ready * Fix sell in usd * Bug fixes * New Sensitivity step * Refresh token with a simple click * Refresh token * Refactor * Fix auto reconnect if token expired Signed-off-by: Gustavo Maximiliano Cortez <cmgustavo83@gmail.com> * Fix calls if token expired
161 lines
4 KiB
JavaScript
161 lines
4 KiB
JavaScript
'use strict';
|
|
|
|
angular.module('copayApp.services').factory('animationService', function(isCordova) {
|
|
var root = {};
|
|
|
|
var cachedTransitionState, cachedBackPanel;
|
|
|
|
// DISABLE ANIMATION ON DESKTOP
|
|
root.modalAnimated = {
|
|
slideUp: isCordova ? 'full animated slideInUp' : 'full',
|
|
slideRight: isCordova ? 'full animated slideInRight' : 'full',
|
|
slideOutDown: isCordova ? 'slideOutDown' : 'hideModal',
|
|
slideOutRight: isCordova ? 'slideOutRight' : 'hideModal',
|
|
};
|
|
|
|
var pageWeight = {
|
|
walletHome: 0,
|
|
copayers: -1,
|
|
cordova: -1,
|
|
payment: -1,
|
|
uriglidera: -1,
|
|
|
|
preferences: 11,
|
|
preferencesGlobal: 11,
|
|
glidera: 11,
|
|
coinbase: 11,
|
|
preferencesColor: 12,
|
|
backup: 12,
|
|
preferencesAdvanced: 12,
|
|
buyGlidera: 12,
|
|
buyCoinbase: 12,
|
|
sellGlidera: 12,
|
|
sellCoinbase: 12,
|
|
preferencesGlidera: 12,
|
|
preferencesCoinbase: 12,
|
|
about: 12,
|
|
delete: 13,
|
|
preferencesLanguage: 12,
|
|
preferencesUnit: 12,
|
|
preferencesFee: 12,
|
|
preferencesAltCurrency: 12,
|
|
preferencesBwsUrl: 13,
|
|
preferencesHistory: 13,
|
|
preferencesAlias: 12,
|
|
preferencesEmail: 12,
|
|
export: 13,
|
|
paperWallet: 13,
|
|
logs: 13,
|
|
information: 13,
|
|
termOfUse: 13,
|
|
translators: 13,
|
|
add: 11,
|
|
buyandsell: 11,
|
|
create: 12,
|
|
join: 12,
|
|
import: 12,
|
|
importLegacy: 13
|
|
};
|
|
|
|
function cleanUpLater(e, e2) {
|
|
var cleanedUp = false,
|
|
timeoutID;
|
|
var cleanUp = function() {
|
|
if (cleanedUp) return;
|
|
cleanedUp = true;
|
|
e2.parentNode.removeChild(e2);
|
|
e2.innerHTML = "";
|
|
e.className = '';
|
|
cachedBackPanel = null;
|
|
cachedTransitionState = '';
|
|
if (timeoutID) {
|
|
timeoutID = null;
|
|
window.clearTimeout(timeoutID);
|
|
}
|
|
};
|
|
e.addEventListener("animationend", cleanUp, true);
|
|
e2.addEventListener("animationend", cleanUp, true);
|
|
e.addEventListener("webkitAnimationEnd", cleanUp, true);
|
|
e2.addEventListener("webkitAnimationEnd", cleanUp, true);
|
|
timeoutID = setTimeout(cleanUp, 500);
|
|
};
|
|
|
|
root.transitionAnimated = function(fromState, toState, event) {
|
|
|
|
if (isaosp)
|
|
return true;
|
|
|
|
// Animation in progress?
|
|
var x = document.getElementById('mainSectionDup');
|
|
if (x && !cachedTransitionState) {
|
|
console.log('Anim in progress');
|
|
return true;
|
|
}
|
|
|
|
var fromName = fromState.name;
|
|
var toName = toState.name;
|
|
if (!fromName || !toName)
|
|
return true;
|
|
|
|
var fromWeight = pageWeight[fromName];
|
|
var toWeight = pageWeight[toName];
|
|
|
|
|
|
var entering = null,
|
|
leaving = null;
|
|
|
|
// Horizontal Slide Animation?
|
|
if (isCordova && fromWeight && toWeight) {
|
|
if (fromWeight > toWeight) {
|
|
leaving = 'CslideOutRight';
|
|
} else {
|
|
entering = 'CslideInRight';
|
|
}
|
|
|
|
// Vertical Slide Animation?
|
|
} else if (isCordova && fromName && fromWeight >= 0 && toWeight >= 0) {
|
|
if (toWeight) {
|
|
entering = 'CslideInUp';
|
|
|
|
} else {
|
|
leaving = 'CslideOutDown';
|
|
}
|
|
|
|
// no Animation ?
|
|
} else {
|
|
return true;
|
|
}
|
|
|
|
var e = document.getElementById('mainSection');
|
|
|
|
|
|
var desiredTransitionState = (fromName || '-') + ':' + (toName || '-');
|
|
|
|
if (desiredTransitionState == cachedTransitionState) {
|
|
e.className = entering || '';
|
|
cachedBackPanel.className = leaving || '';
|
|
cleanUpLater(e, cachedBackPanel);
|
|
//console.log('USing animation', cachedTransitionState);
|
|
return true;
|
|
} else {
|
|
var sc;
|
|
// Keep prefDiv scroll
|
|
var contentDiv = e.getElementsByClassName('content');
|
|
if (contentDiv && contentDiv[0])
|
|
sc = contentDiv[0].scrollTop;
|
|
|
|
cachedBackPanel = e.cloneNode(true);
|
|
cachedBackPanel.id = 'mainSectionDup';
|
|
var c = document.getElementById('sectionContainer');
|
|
c.appendChild(cachedBackPanel);
|
|
|
|
if (sc)
|
|
cachedBackPanel.getElementsByClassName('content')[0].scrollTop = sc;
|
|
|
|
cachedTransitionState = desiredTransitionState;
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return root;
|
|
});
|