|
@ -3,6 +3,7 @@ const screenXpubsToolsScript = { |
|
|
explorerInfo: null, |
|
|
explorerInfo: null, |
|
|
currentXpub: null, |
|
|
currentXpub: null, |
|
|
isReimport: false, |
|
|
isReimport: false, |
|
|
|
|
|
rescanStatusTimerId: null, |
|
|
|
|
|
|
|
|
initPage: function() { |
|
|
initPage: function() { |
|
|
this.getExplorerInfo() |
|
|
this.getExplorerInfo() |
|
@ -32,8 +33,7 @@ const screenXpubsToolsScript = { |
|
|
lib_api.getExplorerPairingInfo().then(explorerInfo => { |
|
|
lib_api.getExplorerPairingInfo().then(explorerInfo => { |
|
|
this.explorerInfo = explorerInfo |
|
|
this.explorerInfo = explorerInfo |
|
|
}).catch(e => { |
|
|
}).catch(e => { |
|
|
lib_msg.displayErrors(lib_msg.extractJqxhrErrorMsg(e)) |
|
|
lib_errors.processError(e) |
|
|
console.log(e) |
|
|
|
|
|
}) |
|
|
}) |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
@ -70,14 +70,13 @@ const screenXpubsToolsScript = { |
|
|
this.showImportForm(false) |
|
|
this.showImportForm(false) |
|
|
} |
|
|
} |
|
|
}).catch(e => { |
|
|
}).catch(e => { |
|
|
lib_msg.displayErrors(lib_msg.extractJqxhrErrorMsg(e)) |
|
|
lib_errors.processError(e) |
|
|
console.log(e) |
|
|
|
|
|
throw e |
|
|
throw e |
|
|
}) |
|
|
}) |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
importXpub: function() { |
|
|
importXpub: function() { |
|
|
lib_msg.displayMessage('Processing xpub import...'); |
|
|
lib_msg.displayMessage('Processing xpub import. Please wait...'); |
|
|
|
|
|
|
|
|
const jsonData = { |
|
|
const jsonData = { |
|
|
'xpub': this.currentXpub, |
|
|
'xpub': this.currentXpub, |
|
@ -97,33 +96,73 @@ const screenXpubsToolsScript = { |
|
|
|
|
|
|
|
|
return lib_api.postXpub(jsonData) |
|
|
return lib_api.postXpub(jsonData) |
|
|
.then(result => { |
|
|
.then(result => { |
|
|
|
|
|
// Successful import
|
|
|
this._searchXpub(this.currentXpub).then(() => { |
|
|
this._searchXpub(this.currentXpub).then(() => { |
|
|
lib_msg.displayInfo('Import complete') |
|
|
lib_msg.displayInfo('Import complete') |
|
|
}) |
|
|
}) |
|
|
}).catch(e => { |
|
|
}).catch(e => { |
|
|
lib_msg.displayErrors(lib_msg.extractJqxhrErrorMsg(e)) |
|
|
// Check if import has timeout'd or if we have an error
|
|
|
console.log(e) |
|
|
if (e['status'] == 502 || e['status'] == 504) { |
|
|
|
|
|
// Wait for import completion
|
|
|
|
|
|
this.checkRescanStatus(() => { |
|
|
|
|
|
this._searchXpub(this.currentXpub).then(() => { |
|
|
|
|
|
lib_msg.displayInfo('Import complete') |
|
|
|
|
|
}) |
|
|
|
|
|
}) |
|
|
|
|
|
} else { |
|
|
|
|
|
lib_errors.processError(e) |
|
|
|
|
|
} |
|
|
}) |
|
|
}) |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
rescanXpub: function() { |
|
|
rescanXpub: function() { |
|
|
lib_msg.displayMessage('Processing xpub rescan...'); |
|
|
lib_msg.displayMessage('Processing xpub rescan. Please wait...'); |
|
|
let startIdx = $('#rescan-start-idx').val() |
|
|
let startIdx = $('#rescan-start-idx').val() |
|
|
startIdx = (startIdx == null) ? 0 : parseInt(startIdx) |
|
|
startIdx = (startIdx == null) ? 0 : parseInt(startIdx) |
|
|
let lookahead = $('#rescan-lookahead').val() |
|
|
let lookahead = $('#rescan-lookahead').val() |
|
|
lookahead = (lookahead == null) ? 100 : parseInt(lookahead) |
|
|
lookahead = (lookahead == null) ? 100 : parseInt(lookahead) |
|
|
return lib_api.getXpubRescan(this.currentXpub, lookahead, startIdx) |
|
|
return lib_api.getXpubRescan(this.currentXpub, lookahead, startIdx) |
|
|
.then(result => { |
|
|
.then(() => { |
|
|
|
|
|
// Successful rescan
|
|
|
this.hideRescanForm() |
|
|
this.hideRescanForm() |
|
|
this._searchXpub(this.currentXpub).then(() => { |
|
|
this._searchXpub(this.currentXpub).then(() => { |
|
|
lib_msg.displayInfo('Rescan complete') |
|
|
lib_msg.displayInfo('Rescan complete') |
|
|
}) |
|
|
}) |
|
|
}).catch(e => { |
|
|
}).catch(e => { |
|
|
lib_msg.displayErrors(lib_msg.extractJqxhrErrorMsg(e)) |
|
|
// Check if rescan has timeout'd or if we have an error
|
|
|
console.log(e) |
|
|
if (e['status'] == 502 || e['status'] == 504) { |
|
|
|
|
|
// Wait for rescan completion
|
|
|
|
|
|
this.checkRescanStatus(() => { |
|
|
|
|
|
this.hideRescanForm() |
|
|
|
|
|
this._searchXpub(this.currentXpub).then(() => { |
|
|
|
|
|
lib_msg.displayInfo('Rescan complete') |
|
|
|
|
|
}) |
|
|
|
|
|
}) |
|
|
|
|
|
} else { |
|
|
|
|
|
lib_errors.processError(e) |
|
|
|
|
|
} |
|
|
}) |
|
|
}) |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
checkRescanStatus: function(callback) { |
|
|
|
|
|
this.rescanStatusTimerId = setTimeout(() => { |
|
|
|
|
|
lib_api.getXpubRescanStatus(this.currentXpub) |
|
|
|
|
|
.then(result => { |
|
|
|
|
|
if (result['data']['import_in_progress']) { |
|
|
|
|
|
lib_msg.displayMessage('Rescan in progress. Please wait...'); |
|
|
|
|
|
return this.checkRescanStatus(callback) |
|
|
|
|
|
} else { |
|
|
|
|
|
clearTimeout(this.rescanStatusTimerId) |
|
|
|
|
|
return callback() |
|
|
|
|
|
} |
|
|
|
|
|
}).catch(e => { |
|
|
|
|
|
lib_errors.processError(e) |
|
|
|
|
|
lib_msg.displayMessage('Rescan in progress. Please wait...'); |
|
|
|
|
|
return this.checkRescanStatus(callback) |
|
|
|
|
|
}) |
|
|
|
|
|
}, 10000) |
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
setXpubDetails: function(xpubInfo) { |
|
|
setXpubDetails: function(xpubInfo) { |
|
|
$('tr.tx-row').remove() |
|
|
$('tr.tx-row').remove() |
|
|
$('tr.utxo-row').remove() |
|
|
$('tr.utxo-row').remove() |
|
|