From dd5fded210c07e416ce661f411889f8ce4c33045 Mon Sep 17 00:00:00 2001 From: John Furrow Date: Sat, 27 Feb 2016 18:33:32 -0800 Subject: [PATCH] Handle errors properly --- client/source/scripts/constants/EventTypes.js | 3 ++ .../scripts/stores/TorrentFilterStore.js | 10 ++++-- .../scripts/stores/TransferDataStore.js | 2 +- server/assets/app.js | 6 ++-- server/models/ClientRequest.js | 24 ++++++++++++-- server/models/HistoryEra.js | 24 +++++++++----- server/models/client.js | 33 ++++++++++++------- server/models/history.js | 9 ++--- server/models/uiSettings.js | 16 ++++----- server/util/ajaxUtil.js | 8 +++-- 10 files changed, 91 insertions(+), 44 deletions(-) diff --git a/client/source/scripts/constants/EventTypes.js b/client/source/scripts/constants/EventTypes.js index e2cfc8dc..e4ffb87d 100644 --- a/client/source/scripts/constants/EventTypes.js +++ b/client/source/scripts/constants/EventTypes.js @@ -5,12 +5,15 @@ const EventTypes = { CLIENT_SET_THROTTLE_SUCCESS: 'CLIENT_SET_THROTTLE_SUCCESS', CLIENT_TORRENTS_REQUEST_ERROR: 'CLIENT_TORRENTS_REQUEST_ERROR', CLIENT_TORRENT_STATUS_COUNT_CHANGE: 'CLIENT_TORRENT_STATUS_COUNT_CHANGE', + CLIENT_TORRENT_STATUS_COUNT_REQUEST_ERROR: 'CLIENT_TORRENT_STATUS_COUNT_REQUEST_ERROR', CLIENT_TORRENT_TRACKER_COUNT_CHANGE: 'CLIENT_TORRENT_TRACKER_COUNT_CHANGE', + CLIENT_TORRENT_TRACKER_COUNT_REQUEST_ERROR: 'CLIENT_TORRENT_TRACKER_COUNT_REQUEST_ERROR', CLIENT_TORRENTS_REQUEST_SUCCESS: 'CLIENT_TORRENTS_REQUEST_SUCCESS', CLIENT_TORRENT_DETAILS_CHANGE: 'CLIENT_TORRENT_DETAILS_CHANGE', CLIENT_TRANSFER_DATA_REQUEST_SUCCESS: 'CLIENT_TRANSFER_DATA_REQUEST_SUCCESS', CLIENT_TRANSFER_DATA_REQUEST_ERROR: 'CLIENT_TRANSFER_DATA_REQUEST_ERROR', CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS: 'CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS', + CLIENT_TRANSFER_HISTORY_REQUEST_ERROR: 'CLIENT_TRANSFER_HISTORY_REQUEST_ERROR', UI_CONTEXT_MENU_CHANGE: 'UI_CONTEXT_MENU_CHANGE', UI_MODAL_CHANGE: 'UI_MODAL_CHANGE', UI_LATEST_TORRENT_LOCATION_CHANGE: 'UI_LATEST_TORRENT_LOCATION_CHANGE', diff --git a/client/source/scripts/stores/TorrentFilterStore.js b/client/source/scripts/stores/TorrentFilterStore.js index a6065ce4..a4799dee 100644 --- a/client/source/scripts/stores/TorrentFilterStore.js +++ b/client/source/scripts/stores/TorrentFilterStore.js @@ -60,8 +60,12 @@ class TorrentFilterStoreClass extends BaseStore { this.setTorrentsSort(sortBy); } - handleTorrentStatusCountRequestError() { + handleTorrentTrackerCountRequestError(error) { + this.emit(EventTypes.CLIENT_TORRENT_TRACKER_COUNT_REQUEST_ERROR); + } + handleTorrentStatusCountRequestError(error) { + this.emit(EventTypes.CLIENT_TORRENT_STATUS_COUNT_REQUEST_ERROR); } isFilterActive() { @@ -127,13 +131,13 @@ AppDispatcher.register((payload) => { TorrentFilterStore.setTorrentStatusCount(action.data); break; case ActionTypes.CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_ERROR: - TorrentFilterStore.handleTorrentStatusCountRequestError(action.data); + TorrentFilterStore.handleTorrentStatusCountRequestError(action.error); break; case ActionTypes.CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_SUCCESS: TorrentFilterStore.setTorrentTrackerCount(action.data); break; case ActionTypes.CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_ERROR: - TorrentFilterStore.handleTorrentTrackerCountRequestError(action.data); + TorrentFilterStore.handleTorrentTrackerCountRequestError(action.error); break; } }); diff --git a/client/source/scripts/stores/TransferDataStore.js b/client/source/scripts/stores/TransferDataStore.js index 98c4734b..9cdbfd38 100644 --- a/client/source/scripts/stores/TransferDataStore.js +++ b/client/source/scripts/stores/TransferDataStore.js @@ -108,7 +108,7 @@ class TransferDataStoreClass extends BaseStore { } handleTransferHistoryError(error) { - console.trace(error); + this.emit(EventTypes.CLIENT_TRANSFER_HISTORY_REQUEST_ERROR); } handleTransferHistorySuccess(transferData) { diff --git a/server/assets/app.js b/server/assets/app.js index ce7be1f0..bf1e74d2 100644 --- a/server/assets/app.js +++ b/server/assets/app.js @@ -1100,7 +1100,7 @@ /* 176 */ /***/ function(module, exports) { - eval("'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n value: true\n});\nvar EventTypes = {\n CLIENT_ADD_TORRENT_ERROR: 'CLIENT_ADD_TORRENT_ERROR',\n CLIENT_ADD_TORRENT_SUCCESS: 'CLIENT_ADD_TORRENT_SUCCESS',\n CLIENT_SET_THROTTLE_ERROR: 'CLIENT_SET_THROTTLE_ERROR',\n CLIENT_SET_THROTTLE_SUCCESS: 'CLIENT_SET_THROTTLE_SUCCESS',\n CLIENT_TORRENTS_REQUEST_ERROR: 'CLIENT_TORRENTS_REQUEST_ERROR',\n CLIENT_TORRENT_STATUS_COUNT_CHANGE: 'CLIENT_TORRENT_STATUS_COUNT_CHANGE',\n CLIENT_TORRENT_TRACKER_COUNT_CHANGE: 'CLIENT_TORRENT_TRACKER_COUNT_CHANGE',\n CLIENT_TORRENTS_REQUEST_SUCCESS: 'CLIENT_TORRENTS_REQUEST_SUCCESS',\n CLIENT_TORRENT_DETAILS_CHANGE: 'CLIENT_TORRENT_DETAILS_CHANGE',\n CLIENT_TRANSFER_DATA_REQUEST_SUCCESS: 'CLIENT_TRANSFER_DATA_REQUEST_SUCCESS',\n CLIENT_TRANSFER_DATA_REQUEST_ERROR: 'CLIENT_TRANSFER_DATA_REQUEST_ERROR',\n CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS: 'CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS',\n UI_CONTEXT_MENU_CHANGE: 'UI_CONTEXT_MENU_CHANGE',\n UI_MODAL_CHANGE: 'UI_MODAL_CHANGE',\n UI_LATEST_TORRENT_LOCATION_CHANGE: 'UI_LATEST_TORRENT_LOCATION_CHANGE',\n UI_TORRENT_DETAILS_HASH_CHANGE: 'UI_TORRENT_DETAILS_HASH_CHANGE',\n UI_TORRENT_DETAILS_OPEN_CHANGE: 'UI_TORRENT_DETAILS_OPEN_CHANGE',\n UI_TORRENT_SELECTION_CHANGE: 'UI_TORRENT_SELECTION_CHANGE',\n UI_TORRENTS_FILTER_CHANGE: 'UI_TORRENTS_FILTER_CHANGE',\n UI_TORRENTS_FILTER_STATUS_CHANGE: 'UI_TORRENTS_FILTER_STATUS_CHANGE',\n UI_TORRENTS_FILTER_TRACKER_CHANGE: 'UI_TORRENTS_FILTER_TRACKER_CHANGE',\n UI_TORRENTS_FILTER_SEARCH_CHANGE: 'UI_TORRENTS_FILTER_SEARCH_CHANGE',\n UI_TORRENTS_SORT_CHANGE: 'UI_TORRENTS_SORT_CHANGE'\n};\n\nexports['default'] = EventTypes;\nmodule.exports = exports['default'];//@ sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9jbGllbnQvc291cmNlL3NjcmlwdHMvY29uc3RhbnRzL0V2ZW50VHlwZXMuanM/ZTRiMyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7QUFFQTtBQUNBO0FBQ0EsQ0FBQztBQUNEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EiLCJmaWxlIjoiMTc2LmpzIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5PYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ19fZXNNb2R1bGUnLCB7XG4gIHZhbHVlOiB0cnVlXG59KTtcbnZhciBFdmVudFR5cGVzID0ge1xuICBDTElFTlRfQUREX1RPUlJFTlRfRVJST1I6ICdDTElFTlRfQUREX1RPUlJFTlRfRVJST1InLFxuICBDTElFTlRfQUREX1RPUlJFTlRfU1VDQ0VTUzogJ0NMSUVOVF9BRERfVE9SUkVOVF9TVUNDRVNTJyxcbiAgQ0xJRU5UX1NFVF9USFJPVFRMRV9FUlJPUjogJ0NMSUVOVF9TRVRfVEhST1RUTEVfRVJST1InLFxuICBDTElFTlRfU0VUX1RIUk9UVExFX1NVQ0NFU1M6ICdDTElFTlRfU0VUX1RIUk9UVExFX1NVQ0NFU1MnLFxuICBDTElFTlRfVE9SUkVOVFNfUkVRVUVTVF9FUlJPUjogJ0NMSUVOVF9UT1JSRU5UU19SRVFVRVNUX0VSUk9SJyxcbiAgQ0xJRU5UX1RPUlJFTlRfU1RBVFVTX0NPVU5UX0NIQU5HRTogJ0NMSUVOVF9UT1JSRU5UX1NUQVRVU19DT1VOVF9DSEFOR0UnLFxuICBDTElFTlRfVE9SUkVOVF9UUkFDS0VSX0NPVU5UX0NIQU5HRTogJ0NMSUVOVF9UT1JSRU5UX1RSQUNLRVJfQ09VTlRfQ0hBTkdFJyxcbiAgQ0xJRU5UX1RPUlJFTlRTX1JFUVVFU1RfU1VDQ0VTUzogJ0NMSUVOVF9UT1JSRU5UU19SRVFVRVNUX1NVQ0NFU1MnLFxuICBDTElFTlRfVE9SUkVOVF9ERVRBSUxTX0NIQU5HRTogJ0NMSUVOVF9UT1JSRU5UX0RFVEFJTFNfQ0hBTkdFJyxcbiAgQ0xJRU5UX1RSQU5TRkVSX0RBVEFfUkVRVUVTVF9TVUNDRVNTOiAnQ0xJRU5UX1RSQU5TRkVSX0RBVEFfUkVRVUVTVF9TVUNDRVNTJyxcbiAgQ0xJRU5UX1RSQU5TRkVSX0RBVEFfUkVRVUVTVF9FUlJPUjogJ0NMSUVOVF9UUkFOU0ZFUl9EQVRBX1JFUVVFU1RfRVJST1InLFxuICBDTElFTlRfVFJBTlNGRVJfSElTVE9SWV9SRVFVRVNUX1NVQ0NFU1M6ICdDTElFTlRfVFJBTlNGRVJfSElTVE9SWV9SRVFVRVNUX1NVQ0NFU1MnLFxuICBVSV9DT05URVhUX01FTlVfQ0hBTkdFOiAnVUlfQ09OVEVYVF9NRU5VX0NIQU5HRScsXG4gIFVJX01PREFMX0NIQU5HRTogJ1VJX01PREFMX0NIQU5HRScsXG4gIFVJX0xBVEVTVF9UT1JSRU5UX0xPQ0FUSU9OX0NIQU5HRTogJ1VJX0xBVEVTVF9UT1JSRU5UX0xPQ0FUSU9OX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRfREVUQUlMU19IQVNIX0NIQU5HRTogJ1VJX1RPUlJFTlRfREVUQUlMU19IQVNIX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRfREVUQUlMU19PUEVOX0NIQU5HRTogJ1VJX1RPUlJFTlRfREVUQUlMU19PUEVOX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRfU0VMRUNUSU9OX0NIQU5HRTogJ1VJX1RPUlJFTlRfU0VMRUNUSU9OX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRTX0ZJTFRFUl9DSEFOR0U6ICdVSV9UT1JSRU5UU19GSUxURVJfQ0hBTkdFJyxcbiAgVUlfVE9SUkVOVFNfRklMVEVSX1NUQVRVU19DSEFOR0U6ICdVSV9UT1JSRU5UU19GSUxURVJfU1RBVFVTX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRTX0ZJTFRFUl9UUkFDS0VSX0NIQU5HRTogJ1VJX1RPUlJFTlRTX0ZJTFRFUl9UUkFDS0VSX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRTX0ZJTFRFUl9TRUFSQ0hfQ0hBTkdFOiAnVUlfVE9SUkVOVFNfRklMVEVSX1NFQVJDSF9DSEFOR0UnLFxuICBVSV9UT1JSRU5UU19TT1JUX0NIQU5HRTogJ1VJX1RPUlJFTlRTX1NPUlRfQ0hBTkdFJ1xufTtcblxuZXhwb3J0c1snZGVmYXVsdCddID0gRXZlbnRUeXBlcztcbm1vZHVsZS5leHBvcnRzID0gZXhwb3J0c1snZGVmYXVsdCddO1xuXG5cbi8qKioqKioqKioqKioqKioqKlxuICoqIFdFQlBBQ0sgRk9PVEVSXG4gKiogLi9jbGllbnQvc291cmNlL3NjcmlwdHMvY29uc3RhbnRzL0V2ZW50VHlwZXMuanNcbiAqKiBtb2R1bGUgaWQgPSAxNzZcbiAqKiBtb2R1bGUgY2h1bmtzID0gMFxuICoqLyJdLCJzb3VyY2VSb290IjoiIn0="); + eval("'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n value: true\n});\nvar EventTypes = {\n CLIENT_ADD_TORRENT_ERROR: 'CLIENT_ADD_TORRENT_ERROR',\n CLIENT_ADD_TORRENT_SUCCESS: 'CLIENT_ADD_TORRENT_SUCCESS',\n CLIENT_SET_THROTTLE_ERROR: 'CLIENT_SET_THROTTLE_ERROR',\n CLIENT_SET_THROTTLE_SUCCESS: 'CLIENT_SET_THROTTLE_SUCCESS',\n CLIENT_TORRENTS_REQUEST_ERROR: 'CLIENT_TORRENTS_REQUEST_ERROR',\n CLIENT_TORRENT_STATUS_COUNT_CHANGE: 'CLIENT_TORRENT_STATUS_COUNT_CHANGE',\n CLIENT_TORRENT_STATUS_COUNT_REQUEST_ERROR: 'CLIENT_TORRENT_STATUS_COUNT_REQUEST_ERROR',\n CLIENT_TORRENT_TRACKER_COUNT_CHANGE: 'CLIENT_TORRENT_TRACKER_COUNT_CHANGE',\n CLIENT_TORRENT_TRACKER_COUNT_REQUEST_ERROR: 'CLIENT_TORRENT_TRACKER_COUNT_REQUEST_ERROR',\n CLIENT_TORRENTS_REQUEST_SUCCESS: 'CLIENT_TORRENTS_REQUEST_SUCCESS',\n CLIENT_TORRENT_DETAILS_CHANGE: 'CLIENT_TORRENT_DETAILS_CHANGE',\n CLIENT_TRANSFER_DATA_REQUEST_SUCCESS: 'CLIENT_TRANSFER_DATA_REQUEST_SUCCESS',\n CLIENT_TRANSFER_DATA_REQUEST_ERROR: 'CLIENT_TRANSFER_DATA_REQUEST_ERROR',\n CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS: 'CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS',\n CLIENT_TRANSFER_HISTORY_REQUEST_ERROR: 'CLIENT_TRANSFER_HISTORY_REQUEST_ERROR',\n UI_CONTEXT_MENU_CHANGE: 'UI_CONTEXT_MENU_CHANGE',\n UI_MODAL_CHANGE: 'UI_MODAL_CHANGE',\n UI_LATEST_TORRENT_LOCATION_CHANGE: 'UI_LATEST_TORRENT_LOCATION_CHANGE',\n UI_TORRENT_DETAILS_HASH_CHANGE: 'UI_TORRENT_DETAILS_HASH_CHANGE',\n UI_TORRENT_DETAILS_OPEN_CHANGE: 'UI_TORRENT_DETAILS_OPEN_CHANGE',\n UI_TORRENT_SELECTION_CHANGE: 'UI_TORRENT_SELECTION_CHANGE',\n UI_TORRENTS_FILTER_CHANGE: 'UI_TORRENTS_FILTER_CHANGE',\n UI_TORRENTS_FILTER_STATUS_CHANGE: 'UI_TORRENTS_FILTER_STATUS_CHANGE',\n UI_TORRENTS_FILTER_TRACKER_CHANGE: 'UI_TORRENTS_FILTER_TRACKER_CHANGE',\n UI_TORRENTS_FILTER_SEARCH_CHANGE: 'UI_TORRENTS_FILTER_SEARCH_CHANGE',\n UI_TORRENTS_SORT_CHANGE: 'UI_TORRENTS_SORT_CHANGE'\n};\n\nexports['default'] = EventTypes;\nmodule.exports = exports['default'];//@ sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9jbGllbnQvc291cmNlL3NjcmlwdHMvY29uc3RhbnRzL0V2ZW50VHlwZXMuanM/ZTRiMyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7QUFFQTtBQUNBO0FBQ0EsQ0FBQztBQUNEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EiLCJmaWxlIjoiMTc2LmpzIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5PYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ19fZXNNb2R1bGUnLCB7XG4gIHZhbHVlOiB0cnVlXG59KTtcbnZhciBFdmVudFR5cGVzID0ge1xuICBDTElFTlRfQUREX1RPUlJFTlRfRVJST1I6ICdDTElFTlRfQUREX1RPUlJFTlRfRVJST1InLFxuICBDTElFTlRfQUREX1RPUlJFTlRfU1VDQ0VTUzogJ0NMSUVOVF9BRERfVE9SUkVOVF9TVUNDRVNTJyxcbiAgQ0xJRU5UX1NFVF9USFJPVFRMRV9FUlJPUjogJ0NMSUVOVF9TRVRfVEhST1RUTEVfRVJST1InLFxuICBDTElFTlRfU0VUX1RIUk9UVExFX1NVQ0NFU1M6ICdDTElFTlRfU0VUX1RIUk9UVExFX1NVQ0NFU1MnLFxuICBDTElFTlRfVE9SUkVOVFNfUkVRVUVTVF9FUlJPUjogJ0NMSUVOVF9UT1JSRU5UU19SRVFVRVNUX0VSUk9SJyxcbiAgQ0xJRU5UX1RPUlJFTlRfU1RBVFVTX0NPVU5UX0NIQU5HRTogJ0NMSUVOVF9UT1JSRU5UX1NUQVRVU19DT1VOVF9DSEFOR0UnLFxuICBDTElFTlRfVE9SUkVOVF9TVEFUVVNfQ09VTlRfUkVRVUVTVF9FUlJPUjogJ0NMSUVOVF9UT1JSRU5UX1NUQVRVU19DT1VOVF9SRVFVRVNUX0VSUk9SJyxcbiAgQ0xJRU5UX1RPUlJFTlRfVFJBQ0tFUl9DT1VOVF9DSEFOR0U6ICdDTElFTlRfVE9SUkVOVF9UUkFDS0VSX0NPVU5UX0NIQU5HRScsXG4gIENMSUVOVF9UT1JSRU5UX1RSQUNLRVJfQ09VTlRfUkVRVUVTVF9FUlJPUjogJ0NMSUVOVF9UT1JSRU5UX1RSQUNLRVJfQ09VTlRfUkVRVUVTVF9FUlJPUicsXG4gIENMSUVOVF9UT1JSRU5UU19SRVFVRVNUX1NVQ0NFU1M6ICdDTElFTlRfVE9SUkVOVFNfUkVRVUVTVF9TVUNDRVNTJyxcbiAgQ0xJRU5UX1RPUlJFTlRfREVUQUlMU19DSEFOR0U6ICdDTElFTlRfVE9SUkVOVF9ERVRBSUxTX0NIQU5HRScsXG4gIENMSUVOVF9UUkFOU0ZFUl9EQVRBX1JFUVVFU1RfU1VDQ0VTUzogJ0NMSUVOVF9UUkFOU0ZFUl9EQVRBX1JFUVVFU1RfU1VDQ0VTUycsXG4gIENMSUVOVF9UUkFOU0ZFUl9EQVRBX1JFUVVFU1RfRVJST1I6ICdDTElFTlRfVFJBTlNGRVJfREFUQV9SRVFVRVNUX0VSUk9SJyxcbiAgQ0xJRU5UX1RSQU5TRkVSX0hJU1RPUllfUkVRVUVTVF9TVUNDRVNTOiAnQ0xJRU5UX1RSQU5TRkVSX0hJU1RPUllfUkVRVUVTVF9TVUNDRVNTJyxcbiAgQ0xJRU5UX1RSQU5TRkVSX0hJU1RPUllfUkVRVUVTVF9FUlJPUjogJ0NMSUVOVF9UUkFOU0ZFUl9ISVNUT1JZX1JFUVVFU1RfRVJST1InLFxuICBVSV9DT05URVhUX01FTlVfQ0hBTkdFOiAnVUlfQ09OVEVYVF9NRU5VX0NIQU5HRScsXG4gIFVJX01PREFMX0NIQU5HRTogJ1VJX01PREFMX0NIQU5HRScsXG4gIFVJX0xBVEVTVF9UT1JSRU5UX0xPQ0FUSU9OX0NIQU5HRTogJ1VJX0xBVEVTVF9UT1JSRU5UX0xPQ0FUSU9OX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRfREVUQUlMU19IQVNIX0NIQU5HRTogJ1VJX1RPUlJFTlRfREVUQUlMU19IQVNIX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRfREVUQUlMU19PUEVOX0NIQU5HRTogJ1VJX1RPUlJFTlRfREVUQUlMU19PUEVOX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRfU0VMRUNUSU9OX0NIQU5HRTogJ1VJX1RPUlJFTlRfU0VMRUNUSU9OX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRTX0ZJTFRFUl9DSEFOR0U6ICdVSV9UT1JSRU5UU19GSUxURVJfQ0hBTkdFJyxcbiAgVUlfVE9SUkVOVFNfRklMVEVSX1NUQVRVU19DSEFOR0U6ICdVSV9UT1JSRU5UU19GSUxURVJfU1RBVFVTX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRTX0ZJTFRFUl9UUkFDS0VSX0NIQU5HRTogJ1VJX1RPUlJFTlRTX0ZJTFRFUl9UUkFDS0VSX0NIQU5HRScsXG4gIFVJX1RPUlJFTlRTX0ZJTFRFUl9TRUFSQ0hfQ0hBTkdFOiAnVUlfVE9SUkVOVFNfRklMVEVSX1NFQVJDSF9DSEFOR0UnLFxuICBVSV9UT1JSRU5UU19TT1JUX0NIQU5HRTogJ1VJX1RPUlJFTlRTX1NPUlRfQ0hBTkdFJ1xufTtcblxuZXhwb3J0c1snZGVmYXVsdCddID0gRXZlbnRUeXBlcztcbm1vZHVsZS5leHBvcnRzID0gZXhwb3J0c1snZGVmYXVsdCddO1xuXG5cbi8qKioqKioqKioqKioqKioqKlxuICoqIFdFQlBBQ0sgRk9PVEVSXG4gKiogLi9jbGllbnQvc291cmNlL3NjcmlwdHMvY29uc3RhbnRzL0V2ZW50VHlwZXMuanNcbiAqKiBtb2R1bGUgaWQgPSAxNzZcbiAqKiBtb2R1bGUgY2h1bmtzID0gMFxuICoqLyJdLCJzb3VyY2VSb290IjoiIn0="); /***/ }, /* 177 */ @@ -1466,7 +1466,7 @@ /* 237 */ /***/ function(module, exports, __webpack_require__) { - eval("'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = __webpack_require__(178);\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = __webpack_require__(179);\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = __webpack_require__(183);\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _constantsEventTypes = __webpack_require__(176);\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar _actionsTorrentActions = __webpack_require__(186);\n\nvar _actionsTorrentActions2 = _interopRequireDefault(_actionsTorrentActions);\n\nvar _actionsUIActions = __webpack_require__(206);\n\nvar _actionsUIActions2 = _interopRequireDefault(_actionsUIActions);\n\nvar TorrentFilterStoreClass = (function (_BaseStore) {\n _inherits(TorrentFilterStoreClass, _BaseStore);\n\n function TorrentFilterStoreClass() {\n _classCallCheck(this, TorrentFilterStoreClass);\n\n _get(Object.getPrototypeOf(TorrentFilterStoreClass.prototype), 'constructor', this).call(this);\n\n this.searchFilter = null;\n this.statusFilter = 'all';\n this.trackerFilter = 'all';\n this.sortTorrentsBy = {\n direction: 'desc',\n displayName: 'Date Added',\n property: 'sortBy',\n value: 'added'\n };\n }\n\n _createClass(TorrentFilterStoreClass, [{\n key: 'fetchSortProps',\n value: function fetchSortProps() {\n _actionsUIActions2['default'].fetchSortProps();\n }\n }, {\n key: 'fetchTorrentStatusCount',\n value: function fetchTorrentStatusCount() {\n _actionsTorrentActions2['default'].fetchTorrentStatusCount();\n }\n }, {\n key: 'fetchTorrentTrackerCount',\n value: function fetchTorrentTrackerCount() {\n _actionsTorrentActions2['default'].fetchTorrentTrackerCount();\n }\n }, {\n key: 'getSearchFilter',\n value: function getSearchFilter() {\n return this.searchFilter;\n }\n }, {\n key: 'getStatusFilter',\n value: function getStatusFilter() {\n return this.statusFilter;\n }\n }, {\n key: 'getTrackerFilter',\n value: function getTrackerFilter() {\n return this.trackerFilter;\n }\n }, {\n key: 'getTorrentsSort',\n value: function getTorrentsSort() {\n return this.sortTorrentsBy;\n }\n }, {\n key: 'getTorrentStatusCount',\n value: function getTorrentStatusCount() {\n return this.torrentStatusCount;\n }\n }, {\n key: 'getTorrentTrackerCount',\n value: function getTorrentTrackerCount() {\n return this.torrentTrackerCount;\n }\n }, {\n key: 'handleSortPropsRequestSuccess',\n value: function handleSortPropsRequestSuccess(sortBy) {\n this.setTorrentsSort(sortBy);\n }\n }, {\n key: 'handleTorrentStatusCountRequestError',\n value: function handleTorrentStatusCountRequestError() {}\n }, {\n key: 'isFilterActive',\n value: function isFilterActive() {\n return this.getStatusFilter() || this.getSearchFilter() || this.getTrackerFilter();\n }\n }, {\n key: 'setSearchFilter',\n value: function setSearchFilter(filter) {\n this.searchFilter = filter;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_SEARCH_CHANGE);\n }\n }, {\n key: 'setStatusFilter',\n value: function setStatusFilter(filter) {\n this.statusFilter = filter;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_STATUS_CHANGE);\n }\n }, {\n key: 'setTrackerFilter',\n value: function setTrackerFilter(filter) {\n this.trackerFilter = filter;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_TRACKER_CHANGE);\n }\n }, {\n key: 'setTorrentsSort',\n value: function setTorrentsSort(sortBy) {\n this.sortTorrentsBy = sortBy;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_SORT_CHANGE);\n }\n }, {\n key: 'setTorrentStatusCount',\n value: function setTorrentStatusCount(statusCount) {\n this.torrentStatusCount = statusCount;\n this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_STATUS_COUNT_CHANGE);\n }\n }, {\n key: 'setTorrentTrackerCount',\n value: function setTorrentTrackerCount(statusCount) {\n this.torrentTrackerCount = statusCount;\n this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_TRACKER_COUNT_CHANGE);\n }\n }]);\n\n return TorrentFilterStoreClass;\n})(_BaseStore3['default']);\n\nvar TorrentFilterStore = new TorrentFilterStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n var action = payload.action;\n var source = payload.source;\n\n switch (action.type) {\n case _constantsActionTypes2['default'].UI_SET_TORRENT_SEARCH_FILTER:\n TorrentFilterStore.setSearchFilter(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SET_TORRENT_STATUS_FILTER:\n TorrentFilterStore.setStatusFilter(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SET_TORRENT_TRACKER_FILTER:\n TorrentFilterStore.setTrackerFilter(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SET_TORRENT_SORT:\n TorrentFilterStore.setTorrentsSort(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SORT_PROPS_REQUEST_SUCCESS:\n TorrentFilterStore.handleSortPropsRequestSuccess(action.data);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_SUCCESS:\n TorrentFilterStore.setTorrentStatusCount(action.data);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_ERROR:\n TorrentFilterStore.handleTorrentStatusCountRequestError(action.data);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_SUCCESS:\n TorrentFilterStore.setTorrentTrackerCount(action.data);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_ERROR:\n TorrentFilterStore.handleTorrentTrackerCountRequestError(action.data);\n break;\n }\n});\n\nexports['default'] = TorrentFilterStore;\nmodule.exports = exports['default'];//@ sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///./client/source/scripts/stores/TorrentFilterStore.js?d3fc"],"names":[],"mappings":"AAAA;;AAEA;AACA;AACA,CAAC;;AAED,iCAAiC,2CAA2C,gBAAgB,kBAAkB,OAAO,2BAA2B,wDAAwD,gCAAgC,uDAAuD,2DAA2D,EAAE,EAAE,yDAAyD,qEAAqE,6DAA6D,oBAAoB,GAAG,EAAE;;AAEljB,uCAAuC,mBAAmB,4BAA4B,iDAAiD,gBAAgB,kDAAkD,8DAA8D,0BAA0B,4CAA4C,uBAAuB,kBAAkB,EAAE,OAAO,aAAa,gBAAgB,gBAAgB,eAAe,2BAA2B,oBAAoB,EAAE,EAAE,4BAA4B,mBAAmB,EAAE,OAAO,uBAAuB,4BAA4B,kBAAkB,EAAE,8BAA8B,EAAE,EAAE;;AAE/oB,sCAAsC,uCAAuC,kBAAkB;;AAE/F,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ,0CAA0C,+DAA+D,qGAAqG,EAAE,yEAAyE,eAAe,yEAAyE,EAAE,EAAE,uHAAuH;;AAE5e;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,CAAC;;AAED;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA","file":"237.js","sourcesContent":["'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n  value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = require('../constants/ActionTypes');\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = require('../dispatcher/AppDispatcher');\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = require('./BaseStore');\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _constantsEventTypes = require('../constants/EventTypes');\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar _actionsTorrentActions = require('../actions/TorrentActions');\n\nvar _actionsTorrentActions2 = _interopRequireDefault(_actionsTorrentActions);\n\nvar _actionsUIActions = require('../actions/UIActions');\n\nvar _actionsUIActions2 = _interopRequireDefault(_actionsUIActions);\n\nvar TorrentFilterStoreClass = (function (_BaseStore) {\n  _inherits(TorrentFilterStoreClass, _BaseStore);\n\n  function TorrentFilterStoreClass() {\n    _classCallCheck(this, TorrentFilterStoreClass);\n\n    _get(Object.getPrototypeOf(TorrentFilterStoreClass.prototype), 'constructor', this).call(this);\n\n    this.searchFilter = null;\n    this.statusFilter = 'all';\n    this.trackerFilter = 'all';\n    this.sortTorrentsBy = {\n      direction: 'desc',\n      displayName: 'Date Added',\n      property: 'sortBy',\n      value: 'added'\n    };\n  }\n\n  _createClass(TorrentFilterStoreClass, [{\n    key: 'fetchSortProps',\n    value: function fetchSortProps() {\n      _actionsUIActions2['default'].fetchSortProps();\n    }\n  }, {\n    key: 'fetchTorrentStatusCount',\n    value: function fetchTorrentStatusCount() {\n      _actionsTorrentActions2['default'].fetchTorrentStatusCount();\n    }\n  }, {\n    key: 'fetchTorrentTrackerCount',\n    value: function fetchTorrentTrackerCount() {\n      _actionsTorrentActions2['default'].fetchTorrentTrackerCount();\n    }\n  }, {\n    key: 'getSearchFilter',\n    value: function getSearchFilter() {\n      return this.searchFilter;\n    }\n  }, {\n    key: 'getStatusFilter',\n    value: function getStatusFilter() {\n      return this.statusFilter;\n    }\n  }, {\n    key: 'getTrackerFilter',\n    value: function getTrackerFilter() {\n      return this.trackerFilter;\n    }\n  }, {\n    key: 'getTorrentsSort',\n    value: function getTorrentsSort() {\n      return this.sortTorrentsBy;\n    }\n  }, {\n    key: 'getTorrentStatusCount',\n    value: function getTorrentStatusCount() {\n      return this.torrentStatusCount;\n    }\n  }, {\n    key: 'getTorrentTrackerCount',\n    value: function getTorrentTrackerCount() {\n      return this.torrentTrackerCount;\n    }\n  }, {\n    key: 'handleSortPropsRequestSuccess',\n    value: function handleSortPropsRequestSuccess(sortBy) {\n      this.setTorrentsSort(sortBy);\n    }\n  }, {\n    key: 'handleTorrentStatusCountRequestError',\n    value: function handleTorrentStatusCountRequestError() {}\n  }, {\n    key: 'isFilterActive',\n    value: function isFilterActive() {\n      return this.getStatusFilter() || this.getSearchFilter() || this.getTrackerFilter();\n    }\n  }, {\n    key: 'setSearchFilter',\n    value: function setSearchFilter(filter) {\n      this.searchFilter = filter;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_SEARCH_CHANGE);\n    }\n  }, {\n    key: 'setStatusFilter',\n    value: function setStatusFilter(filter) {\n      this.statusFilter = filter;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_STATUS_CHANGE);\n    }\n  }, {\n    key: 'setTrackerFilter',\n    value: function setTrackerFilter(filter) {\n      this.trackerFilter = filter;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_TRACKER_CHANGE);\n    }\n  }, {\n    key: 'setTorrentsSort',\n    value: function setTorrentsSort(sortBy) {\n      this.sortTorrentsBy = sortBy;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_SORT_CHANGE);\n    }\n  }, {\n    key: 'setTorrentStatusCount',\n    value: function setTorrentStatusCount(statusCount) {\n      this.torrentStatusCount = statusCount;\n      this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_STATUS_COUNT_CHANGE);\n    }\n  }, {\n    key: 'setTorrentTrackerCount',\n    value: function setTorrentTrackerCount(statusCount) {\n      this.torrentTrackerCount = statusCount;\n      this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_TRACKER_COUNT_CHANGE);\n    }\n  }]);\n\n  return TorrentFilterStoreClass;\n})(_BaseStore3['default']);\n\nvar TorrentFilterStore = new TorrentFilterStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n  var action = payload.action;\n  var source = payload.source;\n\n  switch (action.type) {\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_SEARCH_FILTER:\n      TorrentFilterStore.setSearchFilter(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_STATUS_FILTER:\n      TorrentFilterStore.setStatusFilter(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_TRACKER_FILTER:\n      TorrentFilterStore.setTrackerFilter(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_SORT:\n      TorrentFilterStore.setTorrentsSort(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SORT_PROPS_REQUEST_SUCCESS:\n      TorrentFilterStore.handleSortPropsRequestSuccess(action.data);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_SUCCESS:\n      TorrentFilterStore.setTorrentStatusCount(action.data);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_ERROR:\n      TorrentFilterStore.handleTorrentStatusCountRequestError(action.data);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_SUCCESS:\n      TorrentFilterStore.setTorrentTrackerCount(action.data);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_ERROR:\n      TorrentFilterStore.handleTorrentTrackerCountRequestError(action.data);\n      break;\n  }\n});\n\nexports['default'] = TorrentFilterStore;\nmodule.exports = exports['default'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./client/source/scripts/stores/TorrentFilterStore.js\n ** module id = 237\n ** module chunks = 0\n **/"],"sourceRoot":""}"); + eval("'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = __webpack_require__(178);\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = __webpack_require__(179);\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = __webpack_require__(183);\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _constantsEventTypes = __webpack_require__(176);\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar _actionsTorrentActions = __webpack_require__(186);\n\nvar _actionsTorrentActions2 = _interopRequireDefault(_actionsTorrentActions);\n\nvar _actionsUIActions = __webpack_require__(206);\n\nvar _actionsUIActions2 = _interopRequireDefault(_actionsUIActions);\n\nvar TorrentFilterStoreClass = (function (_BaseStore) {\n _inherits(TorrentFilterStoreClass, _BaseStore);\n\n function TorrentFilterStoreClass() {\n _classCallCheck(this, TorrentFilterStoreClass);\n\n _get(Object.getPrototypeOf(TorrentFilterStoreClass.prototype), 'constructor', this).call(this);\n\n this.searchFilter = null;\n this.statusFilter = 'all';\n this.trackerFilter = 'all';\n this.sortTorrentsBy = {\n direction: 'desc',\n displayName: 'Date Added',\n property: 'sortBy',\n value: 'added'\n };\n }\n\n _createClass(TorrentFilterStoreClass, [{\n key: 'fetchSortProps',\n value: function fetchSortProps() {\n _actionsUIActions2['default'].fetchSortProps();\n }\n }, {\n key: 'fetchTorrentStatusCount',\n value: function fetchTorrentStatusCount() {\n _actionsTorrentActions2['default'].fetchTorrentStatusCount();\n }\n }, {\n key: 'fetchTorrentTrackerCount',\n value: function fetchTorrentTrackerCount() {\n _actionsTorrentActions2['default'].fetchTorrentTrackerCount();\n }\n }, {\n key: 'getSearchFilter',\n value: function getSearchFilter() {\n return this.searchFilter;\n }\n }, {\n key: 'getStatusFilter',\n value: function getStatusFilter() {\n return this.statusFilter;\n }\n }, {\n key: 'getTrackerFilter',\n value: function getTrackerFilter() {\n return this.trackerFilter;\n }\n }, {\n key: 'getTorrentsSort',\n value: function getTorrentsSort() {\n return this.sortTorrentsBy;\n }\n }, {\n key: 'getTorrentStatusCount',\n value: function getTorrentStatusCount() {\n return this.torrentStatusCount;\n }\n }, {\n key: 'getTorrentTrackerCount',\n value: function getTorrentTrackerCount() {\n return this.torrentTrackerCount;\n }\n }, {\n key: 'handleSortPropsRequestSuccess',\n value: function handleSortPropsRequestSuccess(sortBy) {\n this.setTorrentsSort(sortBy);\n }\n }, {\n key: 'handleTorrentTrackerCountRequestError',\n value: function handleTorrentTrackerCountRequestError(error) {\n this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_TRACKER_COUNT_REQUEST_ERROR);\n }\n }, {\n key: 'handleTorrentStatusCountRequestError',\n value: function handleTorrentStatusCountRequestError(error) {\n this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_STATUS_COUNT_REQUEST_ERROR);\n }\n }, {\n key: 'isFilterActive',\n value: function isFilterActive() {\n return this.getStatusFilter() || this.getSearchFilter() || this.getTrackerFilter();\n }\n }, {\n key: 'setSearchFilter',\n value: function setSearchFilter(filter) {\n this.searchFilter = filter;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_SEARCH_CHANGE);\n }\n }, {\n key: 'setStatusFilter',\n value: function setStatusFilter(filter) {\n this.statusFilter = filter;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_STATUS_CHANGE);\n }\n }, {\n key: 'setTrackerFilter',\n value: function setTrackerFilter(filter) {\n this.trackerFilter = filter;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_TRACKER_CHANGE);\n }\n }, {\n key: 'setTorrentsSort',\n value: function setTorrentsSort(sortBy) {\n this.sortTorrentsBy = sortBy;\n this.emit(_constantsEventTypes2['default'].UI_TORRENTS_SORT_CHANGE);\n }\n }, {\n key: 'setTorrentStatusCount',\n value: function setTorrentStatusCount(statusCount) {\n this.torrentStatusCount = statusCount;\n this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_STATUS_COUNT_CHANGE);\n }\n }, {\n key: 'setTorrentTrackerCount',\n value: function setTorrentTrackerCount(statusCount) {\n this.torrentTrackerCount = statusCount;\n this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_TRACKER_COUNT_CHANGE);\n }\n }]);\n\n return TorrentFilterStoreClass;\n})(_BaseStore3['default']);\n\nvar TorrentFilterStore = new TorrentFilterStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n var action = payload.action;\n var source = payload.source;\n\n switch (action.type) {\n case _constantsActionTypes2['default'].UI_SET_TORRENT_SEARCH_FILTER:\n TorrentFilterStore.setSearchFilter(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SET_TORRENT_STATUS_FILTER:\n TorrentFilterStore.setStatusFilter(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SET_TORRENT_TRACKER_FILTER:\n TorrentFilterStore.setTrackerFilter(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SET_TORRENT_SORT:\n TorrentFilterStore.setTorrentsSort(action.data);\n break;\n case _constantsActionTypes2['default'].UI_SORT_PROPS_REQUEST_SUCCESS:\n TorrentFilterStore.handleSortPropsRequestSuccess(action.data);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_SUCCESS:\n TorrentFilterStore.setTorrentStatusCount(action.data);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_ERROR:\n TorrentFilterStore.handleTorrentStatusCountRequestError(action.error);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_SUCCESS:\n TorrentFilterStore.setTorrentTrackerCount(action.data);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_ERROR:\n TorrentFilterStore.handleTorrentTrackerCountRequestError(action.error);\n break;\n }\n});\n\nexports['default'] = TorrentFilterStore;\nmodule.exports = exports['default'];//@ sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///./client/source/scripts/stores/TorrentFilterStore.js?d3fc"],"names":[],"mappings":"AAAA;;AAEA;AACA;AACA,CAAC;;AAED,iCAAiC,2CAA2C,gBAAgB,kBAAkB,OAAO,2BAA2B,wDAAwD,gCAAgC,uDAAuD,2DAA2D,EAAE,EAAE,yDAAyD,qEAAqE,6DAA6D,oBAAoB,GAAG,EAAE;;AAEljB,uCAAuC,mBAAmB,4BAA4B,iDAAiD,gBAAgB,kDAAkD,8DAA8D,0BAA0B,4CAA4C,uBAAuB,kBAAkB,EAAE,OAAO,aAAa,gBAAgB,gBAAgB,eAAe,2BAA2B,oBAAoB,EAAE,EAAE,4BAA4B,mBAAmB,EAAE,OAAO,uBAAuB,4BAA4B,kBAAkB,EAAE,8BAA8B,EAAE,EAAE;;AAE/oB,sCAAsC,uCAAuC,kBAAkB;;AAE/F,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ,0CAA0C,+DAA+D,qGAAqG,EAAE,yEAAyE,eAAe,yEAAyE,EAAE,EAAE,uHAAuH;;AAE5e;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,CAAC;;AAED;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA","file":"237.js","sourcesContent":["'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n  value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = require('../constants/ActionTypes');\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = require('../dispatcher/AppDispatcher');\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = require('./BaseStore');\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _constantsEventTypes = require('../constants/EventTypes');\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar _actionsTorrentActions = require('../actions/TorrentActions');\n\nvar _actionsTorrentActions2 = _interopRequireDefault(_actionsTorrentActions);\n\nvar _actionsUIActions = require('../actions/UIActions');\n\nvar _actionsUIActions2 = _interopRequireDefault(_actionsUIActions);\n\nvar TorrentFilterStoreClass = (function (_BaseStore) {\n  _inherits(TorrentFilterStoreClass, _BaseStore);\n\n  function TorrentFilterStoreClass() {\n    _classCallCheck(this, TorrentFilterStoreClass);\n\n    _get(Object.getPrototypeOf(TorrentFilterStoreClass.prototype), 'constructor', this).call(this);\n\n    this.searchFilter = null;\n    this.statusFilter = 'all';\n    this.trackerFilter = 'all';\n    this.sortTorrentsBy = {\n      direction: 'desc',\n      displayName: 'Date Added',\n      property: 'sortBy',\n      value: 'added'\n    };\n  }\n\n  _createClass(TorrentFilterStoreClass, [{\n    key: 'fetchSortProps',\n    value: function fetchSortProps() {\n      _actionsUIActions2['default'].fetchSortProps();\n    }\n  }, {\n    key: 'fetchTorrentStatusCount',\n    value: function fetchTorrentStatusCount() {\n      _actionsTorrentActions2['default'].fetchTorrentStatusCount();\n    }\n  }, {\n    key: 'fetchTorrentTrackerCount',\n    value: function fetchTorrentTrackerCount() {\n      _actionsTorrentActions2['default'].fetchTorrentTrackerCount();\n    }\n  }, {\n    key: 'getSearchFilter',\n    value: function getSearchFilter() {\n      return this.searchFilter;\n    }\n  }, {\n    key: 'getStatusFilter',\n    value: function getStatusFilter() {\n      return this.statusFilter;\n    }\n  }, {\n    key: 'getTrackerFilter',\n    value: function getTrackerFilter() {\n      return this.trackerFilter;\n    }\n  }, {\n    key: 'getTorrentsSort',\n    value: function getTorrentsSort() {\n      return this.sortTorrentsBy;\n    }\n  }, {\n    key: 'getTorrentStatusCount',\n    value: function getTorrentStatusCount() {\n      return this.torrentStatusCount;\n    }\n  }, {\n    key: 'getTorrentTrackerCount',\n    value: function getTorrentTrackerCount() {\n      return this.torrentTrackerCount;\n    }\n  }, {\n    key: 'handleSortPropsRequestSuccess',\n    value: function handleSortPropsRequestSuccess(sortBy) {\n      this.setTorrentsSort(sortBy);\n    }\n  }, {\n    key: 'handleTorrentTrackerCountRequestError',\n    value: function handleTorrentTrackerCountRequestError(error) {\n      this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_TRACKER_COUNT_REQUEST_ERROR);\n    }\n  }, {\n    key: 'handleTorrentStatusCountRequestError',\n    value: function handleTorrentStatusCountRequestError(error) {\n      this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_STATUS_COUNT_REQUEST_ERROR);\n    }\n  }, {\n    key: 'isFilterActive',\n    value: function isFilterActive() {\n      return this.getStatusFilter() || this.getSearchFilter() || this.getTrackerFilter();\n    }\n  }, {\n    key: 'setSearchFilter',\n    value: function setSearchFilter(filter) {\n      this.searchFilter = filter;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_SEARCH_CHANGE);\n    }\n  }, {\n    key: 'setStatusFilter',\n    value: function setStatusFilter(filter) {\n      this.statusFilter = filter;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_STATUS_CHANGE);\n    }\n  }, {\n    key: 'setTrackerFilter',\n    value: function setTrackerFilter(filter) {\n      this.trackerFilter = filter;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_CHANGE);\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_FILTER_TRACKER_CHANGE);\n    }\n  }, {\n    key: 'setTorrentsSort',\n    value: function setTorrentsSort(sortBy) {\n      this.sortTorrentsBy = sortBy;\n      this.emit(_constantsEventTypes2['default'].UI_TORRENTS_SORT_CHANGE);\n    }\n  }, {\n    key: 'setTorrentStatusCount',\n    value: function setTorrentStatusCount(statusCount) {\n      this.torrentStatusCount = statusCount;\n      this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_STATUS_COUNT_CHANGE);\n    }\n  }, {\n    key: 'setTorrentTrackerCount',\n    value: function setTorrentTrackerCount(statusCount) {\n      this.torrentTrackerCount = statusCount;\n      this.emit(_constantsEventTypes2['default'].CLIENT_TORRENT_TRACKER_COUNT_CHANGE);\n    }\n  }]);\n\n  return TorrentFilterStoreClass;\n})(_BaseStore3['default']);\n\nvar TorrentFilterStore = new TorrentFilterStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n  var action = payload.action;\n  var source = payload.source;\n\n  switch (action.type) {\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_SEARCH_FILTER:\n      TorrentFilterStore.setSearchFilter(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_STATUS_FILTER:\n      TorrentFilterStore.setStatusFilter(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_TRACKER_FILTER:\n      TorrentFilterStore.setTrackerFilter(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SET_TORRENT_SORT:\n      TorrentFilterStore.setTorrentsSort(action.data);\n      break;\n    case _constantsActionTypes2['default'].UI_SORT_PROPS_REQUEST_SUCCESS:\n      TorrentFilterStore.handleSortPropsRequestSuccess(action.data);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_SUCCESS:\n      TorrentFilterStore.setTorrentStatusCount(action.data);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_STATUS_COUNT_REQUEST_ERROR:\n      TorrentFilterStore.handleTorrentStatusCountRequestError(action.error);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_SUCCESS:\n      TorrentFilterStore.setTorrentTrackerCount(action.data);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TORRENT_TRACKER_COUNT_REQUEST_ERROR:\n      TorrentFilterStore.handleTorrentTrackerCountRequestError(action.error);\n      break;\n  }\n});\n\nexports['default'] = TorrentFilterStore;\nmodule.exports = exports['default'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./client/source/scripts/stores/TorrentFilterStore.js\n ** module id = 237\n ** module chunks = 0\n **/"],"sourceRoot":""}"); /***/ }, /* 238 */ @@ -1514,7 +1514,7 @@ /* 245 */ /***/ function(module, exports, __webpack_require__) { - eval("'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x2, _x3, _x4) { var _again = true; _function: while (_again) { var object = _x2, property = _x3, receiver = _x4; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x2 = parent; _x3 = property; _x4 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = __webpack_require__(178);\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = __webpack_require__(179);\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = __webpack_require__(183);\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _actionsClientActions = __webpack_require__(246);\n\nvar _actionsClientActions2 = _interopRequireDefault(_actionsClientActions);\n\nvar _config = __webpack_require__(232);\n\nvar _config2 = _interopRequireDefault(_config);\n\nvar _constantsEventTypes = __webpack_require__(176);\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar TransferDataStoreClass = (function (_BaseStore) {\n _inherits(TransferDataStoreClass, _BaseStore);\n\n function TransferDataStoreClass() {\n _classCallCheck(this, TransferDataStoreClass);\n\n _get(Object.getPrototypeOf(TransferDataStoreClass.prototype), 'constructor', this).call(this);\n\n this.pollTransferDataID = null;\n this.transferRates = { download: [], upload: [] };\n this.transferTotals = { download: null, upload: null };\n this.throttles = { download: null, upload: null };\n }\n\n _createClass(TransferDataStoreClass, [{\n key: 'fetchTransferData',\n value: function fetchTransferData() {\n _actionsClientActions2['default'].fetchTransferHistory({\n snapshot: 'fiveMin'\n });\n\n _actionsClientActions2['default'].fetchTransferData();\n\n if (this.pollTransferDataID === null) {\n this.startPollingTransferData();\n }\n }\n }, {\n key: 'getThrottles',\n value: function getThrottles() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n if (options.latest) {\n return {\n download: this.throttles.download ? this.throttles.download[this.throttles.download.length - 1] : null,\n upload: this.throttles.upload ? this.throttles.upload[this.throttles.upload.length - 1] : null\n };\n }\n return this.throttles;\n }\n }, {\n key: 'getTransferTotals',\n value: function getTransferTotals() {\n return this.transferTotals;\n }\n }, {\n key: 'getTransferRate',\n value: function getTransferRate() {\n return this.transferRate;\n }\n }, {\n key: 'getTransferRates',\n value: function getTransferRates() {\n return this.transferRates;\n }\n }, {\n key: 'handleSetThrottleSuccess',\n value: function handleSetThrottleSuccess(data) {\n this.fetchTransferData();\n this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS);\n }\n }, {\n key: 'handleSetThrottleError',\n value: function handleSetThrottleError(error) {\n this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_ERROR);\n }\n }, {\n key: 'handleTransferDataSuccess',\n value: function handleTransferDataSuccess(transferData) {\n this.transferTotals = {\n download: transferData.downloadTotal,\n upload: transferData.uploadTotal\n };\n\n this.transferRate = {\n download: transferData.downloadRate,\n upload: transferData.uploadRate\n };\n\n // add the latest download & upload throttles to the end of the array and\n // remove the first element in the array. if the arrays are empty, fill in\n // zeros the last known throttle value.\n var index = 0;\n var downloadRateThrottleHistory = Object.assign([], this.throttles.download);\n var uploadRateThrottleHistory = Object.assign([], this.throttles.upload);\n\n if (downloadRateThrottleHistory.length === _config2['default'].maxHistoryStates) {\n\n downloadRateThrottleHistory.shift();\n uploadRateThrottleHistory.shift();\n\n downloadRateThrottleHistory.push(parseInt(transferData.downloadThrottle));\n uploadRateThrottleHistory.push(parseInt(transferData.uploadThrottle));\n } else {\n while (index < _config2['default'].maxHistoryStates) {\n // we assume the throttle history has been the same for all previous\n // history states.\n uploadRateThrottleHistory[index] = parseInt(transferData.uploadThrottle);\n downloadRateThrottleHistory[index] = parseInt(transferData.downloadThrottle);\n index++;\n }\n }\n\n this.throttles = {\n download: downloadRateThrottleHistory,\n upload: uploadRateThrottleHistory\n };\n\n this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_SUCCESS);\n }\n }, {\n key: 'handleTransferDataError',\n value: function handleTransferDataError() {\n this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_ERROR);\n }\n }, {\n key: 'handleTransferHistoryError',\n value: function handleTransferHistoryError(error) {\n console.trace(error);\n }\n }, {\n key: 'handleTransferHistorySuccess',\n value: function handleTransferHistorySuccess(transferData) {\n this.transferRates = {\n download: transferData.download,\n upload: transferData.upload\n };\n\n this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS);\n }\n }, {\n key: 'startPollingTransferData',\n value: function startPollingTransferData() {\n this.pollTransferDataID = setInterval(this.fetchTransferData.bind(this), _config2['default'].pollInterval);\n }\n }]);\n\n return TransferDataStoreClass;\n})(_BaseStore3['default']);\n\nvar TransferDataStore = new TransferDataStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n var action = payload.action;\n var source = payload.source;\n\n switch (action.type) {\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_SUCCESS:\n TransferDataStore.handleTransferDataSuccess(action.data.transferData);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_ERROR:\n TransferDataStore.handleTransferDataError(action.data.error);\n break;\n case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS:\n TransferDataStore.handleSetThrottleSuccess(action.data.transferData);\n break;\n case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_ERROR:\n TransferDataStore.handleSetThrottleError(action.data.error);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_ERROR:\n TransferDataStore.handleTransferHistoryError(action.error);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_SUCCESS:\n TransferDataStore.handleTransferHistorySuccess(action.data);\n break;\n }\n});\n\nexports['default'] = TransferDataStore;\nmodule.exports = exports['default'];//@ sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///./client/source/scripts/stores/TransferDataStore.js?11d1"],"names":[],"mappings":"AAAA;;AAEA;AACA;AACA,CAAC;;AAED,iCAAiC,2CAA2C,gBAAgB,kBAAkB,OAAO,2BAA2B,wDAAwD,gCAAgC,uDAAuD,2DAA2D,EAAE,EAAE,yDAAyD,qEAAqE,6DAA6D,oBAAoB,GAAG,EAAE;;AAEljB,wCAAwC,mBAAmB,4BAA4B,kDAAkD,gBAAgB,kDAAkD,8DAA8D,0BAA0B,4CAA4C,uBAAuB,kBAAkB,EAAE,OAAO,cAAc,gBAAgB,gBAAgB,eAAe,2BAA2B,oBAAoB,EAAE,EAAE,4BAA4B,mBAAmB,EAAE,OAAO,uBAAuB,4BAA4B,kBAAkB,EAAE,8BAA8B,EAAE,EAAE;;AAElpB,sCAAsC,uCAAuC,kBAAkB;;AAE/F,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ,0CAA0C,+DAA+D,qGAAqG,EAAE,yEAAyE,eAAe,yEAAyE,EAAE,EAAE,uHAAuH;;AAE5e;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA,0BAA0B;AAC1B,2BAA2B;AAC3B,sBAAsB;AACtB;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,4EAA4E;;AAE5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,CAAC;;AAED;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA","file":"245.js","sourcesContent":["'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n  value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x2, _x3, _x4) { var _again = true; _function: while (_again) { var object = _x2, property = _x3, receiver = _x4; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x2 = parent; _x3 = property; _x4 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = require('../constants/ActionTypes');\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = require('../dispatcher/AppDispatcher');\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = require('./BaseStore');\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _actionsClientActions = require('../actions/ClientActions');\n\nvar _actionsClientActions2 = _interopRequireDefault(_actionsClientActions);\n\nvar _config = require('../../../../config');\n\nvar _config2 = _interopRequireDefault(_config);\n\nvar _constantsEventTypes = require('../constants/EventTypes');\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar TransferDataStoreClass = (function (_BaseStore) {\n  _inherits(TransferDataStoreClass, _BaseStore);\n\n  function TransferDataStoreClass() {\n    _classCallCheck(this, TransferDataStoreClass);\n\n    _get(Object.getPrototypeOf(TransferDataStoreClass.prototype), 'constructor', this).call(this);\n\n    this.pollTransferDataID = null;\n    this.transferRates = { download: [], upload: [] };\n    this.transferTotals = { download: null, upload: null };\n    this.throttles = { download: null, upload: null };\n  }\n\n  _createClass(TransferDataStoreClass, [{\n    key: 'fetchTransferData',\n    value: function fetchTransferData() {\n      _actionsClientActions2['default'].fetchTransferHistory({\n        snapshot: 'fiveMin'\n      });\n\n      _actionsClientActions2['default'].fetchTransferData();\n\n      if (this.pollTransferDataID === null) {\n        this.startPollingTransferData();\n      }\n    }\n  }, {\n    key: 'getThrottles',\n    value: function getThrottles() {\n      var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n      if (options.latest) {\n        return {\n          download: this.throttles.download ? this.throttles.download[this.throttles.download.length - 1] : null,\n          upload: this.throttles.upload ? this.throttles.upload[this.throttles.upload.length - 1] : null\n        };\n      }\n      return this.throttles;\n    }\n  }, {\n    key: 'getTransferTotals',\n    value: function getTransferTotals() {\n      return this.transferTotals;\n    }\n  }, {\n    key: 'getTransferRate',\n    value: function getTransferRate() {\n      return this.transferRate;\n    }\n  }, {\n    key: 'getTransferRates',\n    value: function getTransferRates() {\n      return this.transferRates;\n    }\n  }, {\n    key: 'handleSetThrottleSuccess',\n    value: function handleSetThrottleSuccess(data) {\n      this.fetchTransferData();\n      this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS);\n    }\n  }, {\n    key: 'handleSetThrottleError',\n    value: function handleSetThrottleError(error) {\n      this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_ERROR);\n    }\n  }, {\n    key: 'handleTransferDataSuccess',\n    value: function handleTransferDataSuccess(transferData) {\n      this.transferTotals = {\n        download: transferData.downloadTotal,\n        upload: transferData.uploadTotal\n      };\n\n      this.transferRate = {\n        download: transferData.downloadRate,\n        upload: transferData.uploadRate\n      };\n\n      // add the latest download & upload throttles to the end of the array and\n      // remove the first element in the array. if the arrays are empty, fill in\n      // zeros the last known throttle value.\n      var index = 0;\n      var downloadRateThrottleHistory = Object.assign([], this.throttles.download);\n      var uploadRateThrottleHistory = Object.assign([], this.throttles.upload);\n\n      if (downloadRateThrottleHistory.length === _config2['default'].maxHistoryStates) {\n\n        downloadRateThrottleHistory.shift();\n        uploadRateThrottleHistory.shift();\n\n        downloadRateThrottleHistory.push(parseInt(transferData.downloadThrottle));\n        uploadRateThrottleHistory.push(parseInt(transferData.uploadThrottle));\n      } else {\n        while (index < _config2['default'].maxHistoryStates) {\n          // we assume the throttle history has been the same for all previous\n          // history states.\n          uploadRateThrottleHistory[index] = parseInt(transferData.uploadThrottle);\n          downloadRateThrottleHistory[index] = parseInt(transferData.downloadThrottle);\n          index++;\n        }\n      }\n\n      this.throttles = {\n        download: downloadRateThrottleHistory,\n        upload: uploadRateThrottleHistory\n      };\n\n      this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_SUCCESS);\n    }\n  }, {\n    key: 'handleTransferDataError',\n    value: function handleTransferDataError() {\n      this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_ERROR);\n    }\n  }, {\n    key: 'handleTransferHistoryError',\n    value: function handleTransferHistoryError(error) {\n      console.trace(error);\n    }\n  }, {\n    key: 'handleTransferHistorySuccess',\n    value: function handleTransferHistorySuccess(transferData) {\n      this.transferRates = {\n        download: transferData.download,\n        upload: transferData.upload\n      };\n\n      this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS);\n    }\n  }, {\n    key: 'startPollingTransferData',\n    value: function startPollingTransferData() {\n      this.pollTransferDataID = setInterval(this.fetchTransferData.bind(this), _config2['default'].pollInterval);\n    }\n  }]);\n\n  return TransferDataStoreClass;\n})(_BaseStore3['default']);\n\nvar TransferDataStore = new TransferDataStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n  var action = payload.action;\n  var source = payload.source;\n\n  switch (action.type) {\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_SUCCESS:\n      TransferDataStore.handleTransferDataSuccess(action.data.transferData);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_ERROR:\n      TransferDataStore.handleTransferDataError(action.data.error);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS:\n      TransferDataStore.handleSetThrottleSuccess(action.data.transferData);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_ERROR:\n      TransferDataStore.handleSetThrottleError(action.data.error);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_ERROR:\n      TransferDataStore.handleTransferHistoryError(action.error);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_SUCCESS:\n      TransferDataStore.handleTransferHistorySuccess(action.data);\n      break;\n  }\n});\n\nexports['default'] = TransferDataStore;\nmodule.exports = exports['default'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./client/source/scripts/stores/TransferDataStore.js\n ** module id = 245\n ** module chunks = 0\n **/"],"sourceRoot":""}"); + eval("'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x2, _x3, _x4) { var _again = true; _function: while (_again) { var object = _x2, property = _x3, receiver = _x4; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x2 = parent; _x3 = property; _x4 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = __webpack_require__(178);\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = __webpack_require__(179);\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = __webpack_require__(183);\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _actionsClientActions = __webpack_require__(246);\n\nvar _actionsClientActions2 = _interopRequireDefault(_actionsClientActions);\n\nvar _config = __webpack_require__(232);\n\nvar _config2 = _interopRequireDefault(_config);\n\nvar _constantsEventTypes = __webpack_require__(176);\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar TransferDataStoreClass = (function (_BaseStore) {\n _inherits(TransferDataStoreClass, _BaseStore);\n\n function TransferDataStoreClass() {\n _classCallCheck(this, TransferDataStoreClass);\n\n _get(Object.getPrototypeOf(TransferDataStoreClass.prototype), 'constructor', this).call(this);\n\n this.pollTransferDataID = null;\n this.transferRates = { download: [], upload: [] };\n this.transferTotals = { download: null, upload: null };\n this.throttles = { download: null, upload: null };\n }\n\n _createClass(TransferDataStoreClass, [{\n key: 'fetchTransferData',\n value: function fetchTransferData() {\n _actionsClientActions2['default'].fetchTransferHistory({\n snapshot: 'fiveMin'\n });\n\n _actionsClientActions2['default'].fetchTransferData();\n\n if (this.pollTransferDataID === null) {\n this.startPollingTransferData();\n }\n }\n }, {\n key: 'getThrottles',\n value: function getThrottles() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n if (options.latest) {\n return {\n download: this.throttles.download ? this.throttles.download[this.throttles.download.length - 1] : null,\n upload: this.throttles.upload ? this.throttles.upload[this.throttles.upload.length - 1] : null\n };\n }\n return this.throttles;\n }\n }, {\n key: 'getTransferTotals',\n value: function getTransferTotals() {\n return this.transferTotals;\n }\n }, {\n key: 'getTransferRate',\n value: function getTransferRate() {\n return this.transferRate;\n }\n }, {\n key: 'getTransferRates',\n value: function getTransferRates() {\n return this.transferRates;\n }\n }, {\n key: 'handleSetThrottleSuccess',\n value: function handleSetThrottleSuccess(data) {\n this.fetchTransferData();\n this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS);\n }\n }, {\n key: 'handleSetThrottleError',\n value: function handleSetThrottleError(error) {\n this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_ERROR);\n }\n }, {\n key: 'handleTransferDataSuccess',\n value: function handleTransferDataSuccess(transferData) {\n this.transferTotals = {\n download: transferData.downloadTotal,\n upload: transferData.uploadTotal\n };\n\n this.transferRate = {\n download: transferData.downloadRate,\n upload: transferData.uploadRate\n };\n\n // add the latest download & upload throttles to the end of the array and\n // remove the first element in the array. if the arrays are empty, fill in\n // zeros the last known throttle value.\n var index = 0;\n var downloadRateThrottleHistory = Object.assign([], this.throttles.download);\n var uploadRateThrottleHistory = Object.assign([], this.throttles.upload);\n\n if (downloadRateThrottleHistory.length === _config2['default'].maxHistoryStates) {\n\n downloadRateThrottleHistory.shift();\n uploadRateThrottleHistory.shift();\n\n downloadRateThrottleHistory.push(parseInt(transferData.downloadThrottle));\n uploadRateThrottleHistory.push(parseInt(transferData.uploadThrottle));\n } else {\n while (index < _config2['default'].maxHistoryStates) {\n // we assume the throttle history has been the same for all previous\n // history states.\n uploadRateThrottleHistory[index] = parseInt(transferData.uploadThrottle);\n downloadRateThrottleHistory[index] = parseInt(transferData.downloadThrottle);\n index++;\n }\n }\n\n this.throttles = {\n download: downloadRateThrottleHistory,\n upload: uploadRateThrottleHistory\n };\n\n this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_SUCCESS);\n }\n }, {\n key: 'handleTransferDataError',\n value: function handleTransferDataError() {\n this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_ERROR);\n }\n }, {\n key: 'handleTransferHistoryError',\n value: function handleTransferHistoryError(error) {\n this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_HISTORY_REQUEST_ERROR);\n }\n }, {\n key: 'handleTransferHistorySuccess',\n value: function handleTransferHistorySuccess(transferData) {\n this.transferRates = {\n download: transferData.download,\n upload: transferData.upload\n };\n\n this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS);\n }\n }, {\n key: 'startPollingTransferData',\n value: function startPollingTransferData() {\n this.pollTransferDataID = setInterval(this.fetchTransferData.bind(this), _config2['default'].pollInterval);\n }\n }]);\n\n return TransferDataStoreClass;\n})(_BaseStore3['default']);\n\nvar TransferDataStore = new TransferDataStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n var action = payload.action;\n var source = payload.source;\n\n switch (action.type) {\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_SUCCESS:\n TransferDataStore.handleTransferDataSuccess(action.data.transferData);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_ERROR:\n TransferDataStore.handleTransferDataError(action.data.error);\n break;\n case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS:\n TransferDataStore.handleSetThrottleSuccess(action.data.transferData);\n break;\n case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_ERROR:\n TransferDataStore.handleSetThrottleError(action.data.error);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_ERROR:\n TransferDataStore.handleTransferHistoryError(action.error);\n break;\n case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_SUCCESS:\n TransferDataStore.handleTransferHistorySuccess(action.data);\n break;\n }\n});\n\nexports['default'] = TransferDataStore;\nmodule.exports = exports['default'];//@ sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///./client/source/scripts/stores/TransferDataStore.js?11d1"],"names":[],"mappings":"AAAA;;AAEA;AACA;AACA,CAAC;;AAED,iCAAiC,2CAA2C,gBAAgB,kBAAkB,OAAO,2BAA2B,wDAAwD,gCAAgC,uDAAuD,2DAA2D,EAAE,EAAE,yDAAyD,qEAAqE,6DAA6D,oBAAoB,GAAG,EAAE;;AAEljB,wCAAwC,mBAAmB,4BAA4B,kDAAkD,gBAAgB,kDAAkD,8DAA8D,0BAA0B,4CAA4C,uBAAuB,kBAAkB,EAAE,OAAO,cAAc,gBAAgB,gBAAgB,eAAe,2BAA2B,oBAAoB,EAAE,EAAE,4BAA4B,mBAAmB,EAAE,OAAO,uBAAuB,4BAA4B,kBAAkB,EAAE,8BAA8B,EAAE,EAAE;;AAElpB,sCAAsC,uCAAuC,kBAAkB;;AAE/F,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ,0CAA0C,+DAA+D,qGAAqG,EAAE,yEAAyE,eAAe,yEAAyE,EAAE,EAAE,uHAAuH;;AAE5e;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA,0BAA0B;AAC1B,2BAA2B;AAC3B,sBAAsB;AACtB;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,4EAA4E;;AAE5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,CAAC;;AAED;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA","file":"245.js","sourcesContent":["'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n  value: true\n});\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x2, _x3, _x4) { var _again = true; _function: while (_again) { var object = _x2, property = _x3, receiver = _x4; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x2 = parent; _x3 = property; _x4 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _constantsActionTypes = require('../constants/ActionTypes');\n\nvar _constantsActionTypes2 = _interopRequireDefault(_constantsActionTypes);\n\nvar _dispatcherAppDispatcher = require('../dispatcher/AppDispatcher');\n\nvar _dispatcherAppDispatcher2 = _interopRequireDefault(_dispatcherAppDispatcher);\n\nvar _BaseStore2 = require('./BaseStore');\n\nvar _BaseStore3 = _interopRequireDefault(_BaseStore2);\n\nvar _actionsClientActions = require('../actions/ClientActions');\n\nvar _actionsClientActions2 = _interopRequireDefault(_actionsClientActions);\n\nvar _config = require('../../../../config');\n\nvar _config2 = _interopRequireDefault(_config);\n\nvar _constantsEventTypes = require('../constants/EventTypes');\n\nvar _constantsEventTypes2 = _interopRequireDefault(_constantsEventTypes);\n\nvar TransferDataStoreClass = (function (_BaseStore) {\n  _inherits(TransferDataStoreClass, _BaseStore);\n\n  function TransferDataStoreClass() {\n    _classCallCheck(this, TransferDataStoreClass);\n\n    _get(Object.getPrototypeOf(TransferDataStoreClass.prototype), 'constructor', this).call(this);\n\n    this.pollTransferDataID = null;\n    this.transferRates = { download: [], upload: [] };\n    this.transferTotals = { download: null, upload: null };\n    this.throttles = { download: null, upload: null };\n  }\n\n  _createClass(TransferDataStoreClass, [{\n    key: 'fetchTransferData',\n    value: function fetchTransferData() {\n      _actionsClientActions2['default'].fetchTransferHistory({\n        snapshot: 'fiveMin'\n      });\n\n      _actionsClientActions2['default'].fetchTransferData();\n\n      if (this.pollTransferDataID === null) {\n        this.startPollingTransferData();\n      }\n    }\n  }, {\n    key: 'getThrottles',\n    value: function getThrottles() {\n      var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n      if (options.latest) {\n        return {\n          download: this.throttles.download ? this.throttles.download[this.throttles.download.length - 1] : null,\n          upload: this.throttles.upload ? this.throttles.upload[this.throttles.upload.length - 1] : null\n        };\n      }\n      return this.throttles;\n    }\n  }, {\n    key: 'getTransferTotals',\n    value: function getTransferTotals() {\n      return this.transferTotals;\n    }\n  }, {\n    key: 'getTransferRate',\n    value: function getTransferRate() {\n      return this.transferRate;\n    }\n  }, {\n    key: 'getTransferRates',\n    value: function getTransferRates() {\n      return this.transferRates;\n    }\n  }, {\n    key: 'handleSetThrottleSuccess',\n    value: function handleSetThrottleSuccess(data) {\n      this.fetchTransferData();\n      this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS);\n    }\n  }, {\n    key: 'handleSetThrottleError',\n    value: function handleSetThrottleError(error) {\n      this.emit(_constantsEventTypes2['default'].CLIENT_SET_THROTTLE_ERROR);\n    }\n  }, {\n    key: 'handleTransferDataSuccess',\n    value: function handleTransferDataSuccess(transferData) {\n      this.transferTotals = {\n        download: transferData.downloadTotal,\n        upload: transferData.uploadTotal\n      };\n\n      this.transferRate = {\n        download: transferData.downloadRate,\n        upload: transferData.uploadRate\n      };\n\n      // add the latest download & upload throttles to the end of the array and\n      // remove the first element in the array. if the arrays are empty, fill in\n      // zeros the last known throttle value.\n      var index = 0;\n      var downloadRateThrottleHistory = Object.assign([], this.throttles.download);\n      var uploadRateThrottleHistory = Object.assign([], this.throttles.upload);\n\n      if (downloadRateThrottleHistory.length === _config2['default'].maxHistoryStates) {\n\n        downloadRateThrottleHistory.shift();\n        uploadRateThrottleHistory.shift();\n\n        downloadRateThrottleHistory.push(parseInt(transferData.downloadThrottle));\n        uploadRateThrottleHistory.push(parseInt(transferData.uploadThrottle));\n      } else {\n        while (index < _config2['default'].maxHistoryStates) {\n          // we assume the throttle history has been the same for all previous\n          // history states.\n          uploadRateThrottleHistory[index] = parseInt(transferData.uploadThrottle);\n          downloadRateThrottleHistory[index] = parseInt(transferData.downloadThrottle);\n          index++;\n        }\n      }\n\n      this.throttles = {\n        download: downloadRateThrottleHistory,\n        upload: uploadRateThrottleHistory\n      };\n\n      this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_SUCCESS);\n    }\n  }, {\n    key: 'handleTransferDataError',\n    value: function handleTransferDataError() {\n      this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_DATA_REQUEST_ERROR);\n    }\n  }, {\n    key: 'handleTransferHistoryError',\n    value: function handleTransferHistoryError(error) {\n      this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_HISTORY_REQUEST_ERROR);\n    }\n  }, {\n    key: 'handleTransferHistorySuccess',\n    value: function handleTransferHistorySuccess(transferData) {\n      this.transferRates = {\n        download: transferData.download,\n        upload: transferData.upload\n      };\n\n      this.emit(_constantsEventTypes2['default'].CLIENT_TRANSFER_HISTORY_REQUEST_SUCCESS);\n    }\n  }, {\n    key: 'startPollingTransferData',\n    value: function startPollingTransferData() {\n      this.pollTransferDataID = setInterval(this.fetchTransferData.bind(this), _config2['default'].pollInterval);\n    }\n  }]);\n\n  return TransferDataStoreClass;\n})(_BaseStore3['default']);\n\nvar TransferDataStore = new TransferDataStoreClass();\n\n_dispatcherAppDispatcher2['default'].register(function (payload) {\n  var action = payload.action;\n  var source = payload.source;\n\n  switch (action.type) {\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_SUCCESS:\n      TransferDataStore.handleTransferDataSuccess(action.data.transferData);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_DATA_ERROR:\n      TransferDataStore.handleTransferDataError(action.data.error);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_SUCCESS:\n      TransferDataStore.handleSetThrottleSuccess(action.data.transferData);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_SET_THROTTLE_ERROR:\n      TransferDataStore.handleSetThrottleError(action.data.error);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_ERROR:\n      TransferDataStore.handleTransferHistoryError(action.error);\n      break;\n    case _constantsActionTypes2['default'].CLIENT_FETCH_TRANSFER_HISTORY_SUCCESS:\n      TransferDataStore.handleTransferHistorySuccess(action.data);\n      break;\n  }\n});\n\nexports['default'] = TransferDataStore;\nmodule.exports = exports['default'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./client/source/scripts/stores/TransferDataStore.js\n ** module id = 245\n ** module chunks = 0\n **/"],"sourceRoot":""}"); /***/ }, /* 246 */ diff --git a/server/models/ClientRequest.js b/server/models/ClientRequest.js index f115f6e2..a3db819a 100644 --- a/server/models/ClientRequest.js +++ b/server/models/ClientRequest.js @@ -3,6 +3,7 @@ let util = require('util'); let clientUtil = require('../util/clientUtil'); +let Q = require('q'); let rTorrentPropMap = require('../util/rTorrentPropMap'); let scgi = require('../util/scgi'); let stringUtil = require('../../shared/util/stringUtil'); @@ -40,6 +41,10 @@ class ClientRequest { return item; } + clearRequestQueue() { + this.requests = []; + } + getMethodCall(methodName, params) { params = params || []; return {methodName, params}; @@ -48,19 +53,24 @@ class ClientRequest { handleError(error) { console.trace(error); + this.clearRequestQueue(); + if (this.onCompleteFn) { - this.onCompleteFn(error); + this.onCompleteFn(null, error); } } handleSuccess(data) { let response = data; + + this.clearRequestQueue(); + if (this.postProcessFn) { response = this.postProcessFn(data); } if (this.onCompleteFn) { - this.onCompleteFn(null, response); + this.onCompleteFn(response); } } @@ -147,6 +157,16 @@ class ClientRequest { this.requests.push(this.getMethodCall(options.method, [args])); } + moveTorrentsMethodCall(options) { + let hashes = this.getEnsuredArray(options.hashes); + let destinationPath = options.destinationPath; + let sourcePath = options.sourcePath; + + this.moveInProgress = true; + + // let {hashes, destinationPath, sourcePath} = options; + } + removeTorrentsMethodCall(options) { let hashes = this.getEnsuredArray(options.hashes); diff --git a/server/models/HistoryEra.js b/server/models/HistoryEra.js index 261db2b0..de7664a7 100644 --- a/server/models/HistoryEra.js +++ b/server/models/HistoryEra.js @@ -49,7 +49,7 @@ class HistoryEra { addData(data) { if (!this.ready) { - console.warn('database is not ready'); + console.error('database is not ready'); return; } @@ -74,12 +74,13 @@ class HistoryEra { let downAvg = ((currentDownAvg * numUpdates + Number(data.download)) / (numUpdates + 1)).toFixed(1); let upAvg = ((currentUpAvg * numUpdates + Number(data.upload)) / (numUpdates + 1)).toFixed(1); + // TODO: Remove this nonsense, I think this bug is resolved. if (downAvg == null || upAvg == null) { - console.log('\n\n'); - console.log('Warning: null values set in database!'); - console.log(`DB: ${this.opts.name}`); - console.log(`numUpdates: ${numUpdates}\ncurrentDownAvg: ${currentDownAvg}\ncurrentUpAvg: ${currentUpAvg}\ndownAvg: ${downAvg}\nupAvg: ${upAvg}`); - console.log('\n\n'); + console.error('\n\n'); + console.error('Warning: null values set in database!'); + console.error(`DB: ${this.opts.name}`); + console.error(`numUpdates: ${numUpdates}\ncurrentDownAvg: ${currentDownAvg}\ncurrentUpAvg: ${currentUpAvg}\ndownAvg: ${downAvg}\nupAvg: ${upAvg}`); + console.error('\n\n'); } this.db.update({ts: this.lastUpdate}, {ts: this.lastUpdate, up: Number(upAvg), dn: Number(downAvg), num: numUpdates + 1}); @@ -99,7 +100,12 @@ class HistoryEra { this.db.find({ts: {$gte: minTimestamp}}) .sort({ts: 1}) .exec(function (err, docs) { - callback(err, docs); + if (err) { + callback(null, err); + return; + } + + callback(docs); } ); } @@ -109,7 +115,7 @@ class HistoryEra { REQUIRED_FIELDS.forEach(function (field) { if (opts[field] == null) { - console.warn(`HistoryEra requires ${field}`); + console.error(`HistoryEra requires ${field}`); requirementsMet = false; } }); @@ -131,7 +137,7 @@ class HistoryEra { if (this.opts.maxTime > 0) { let minTimestamp = Date.now() - this.opts.maxTime; db.remove({ts: {$lt: minTimestamp}}, {multi: true}, (err, numRemoved) => { - console.log(`removed ${numRemoved} entries from ${this.opts.name}`) + console.error(`removed ${numRemoved} entries from ${this.opts.name}`) }); } } diff --git a/server/models/client.js b/server/models/client.js index 705cb319..239c3658 100644 --- a/server/models/client.js +++ b/server/models/client.js @@ -21,22 +21,24 @@ var client = { let files = req.files; let path = req.body.destination; let request = new ClientRequest(); - + request.add('createDirectory', {path}); request.send(); - // TODO: Clean this up, it's ugly. // Each torrent is sent individually because rTorrent accepts a total - // filesize of 524 kilobytes or less. + // filesize of 524 kilobytes or less. This allows the user to send many + // torrent files reliably. files.forEach((file, index) => { let fileRequest = new ClientRequest(); fileRequest.add('addFiles', {files: file, path}); - // Call the callback on the last request. + + // Set the callback for only the last request. if (index === files.length - 1) { fileRequest.onComplete(function (data) { callback(data); }); } + fileRequest.send(); }); }, @@ -61,11 +63,11 @@ var client = { }, getTorrentStatusCount: function(callback) { - callback(null, _statusCount); + callback(_statusCount); }, getTorrentTrackerCount: function(callback) { - callback(null, _trackerCount); + callback(_trackerCount); }, getTorrentDetails: function(hash, callback) { @@ -88,6 +90,7 @@ var client = { request.add('getTorrentList', {props: clientUtil.defaults.torrentPropertyMethods}); request.postProcess(function(data) { + // TODO: Remove this nasty nested array business. _torrentCollection.updateTorrents(data[0][0]); _statusCount = _torrentCollection.statusCount; _trackerCount = _torrentCollection.trackerCount; @@ -107,11 +110,19 @@ var client = { }, moveFiles: function(data, callback) { - // loop through the torrents: - // stop torrents, call d.stop and d.close - // move torrents - // set new torrent directory - // start torrents, call d.start and d.open + let destinationPath = data.destination; + let hashes = data.hashes; + let sourcePath = data.source; + let request = new ClientRequest(); + + request.add('createDirectory', {path: destinationPath}); + request.add('stopTorrents', {hashes}); + request.onComplete(function () { + request.add('moveTorrents', {hashes, destinationPath, sourcePath}); + request.add('startTorrents', {hashes}); + request.onComplete(callback); + }) + request.send(); }, setFilePriority: function (hashes, data, callback) { diff --git a/server/models/history.js b/server/models/history.js index 503ca2a7..164266c0 100644 --- a/server/models/history.js +++ b/server/models/history.js @@ -60,9 +60,10 @@ let fiveMinSnapshot = new HistoryEra({ nextEra: thirtyMinSnapshot }); -let processData = function (opts, callback, error, data) { +let processData = function (opts, callback, data, error) { if (error) { - callback(error); + callback(null, error); + return; } data = data.slice(data.length - config.maxHistoryStates); @@ -75,7 +76,7 @@ let processData = function (opts, callback, error, data) { uploadRateHistory.push(snapshot.up); }); - callback(error, { + callback({ download: downloadRateHistory, upload: uploadRateHistory }); @@ -104,7 +105,7 @@ let history = { startPolling: function () { pollInterval = setInterval(function() { - client.getTransferStats(function (err, data) { + client.getTransferStats(function (data, err) { if (err) { return; } diff --git a/server/models/uiSettings.js b/server/models/uiSettings.js index 7e9e29c0..b9dd7b44 100644 --- a/server/models/uiSettings.js +++ b/server/models/uiSettings.js @@ -15,12 +15,12 @@ let uiSettings = { getLatestTorrentLocation: function(callback) { uiDB.find({type: 'location'}, function(error, docs) { if (error) { - callback(error); + callback(null, error); return; } if (docs.length) { - callback(error, docs[0]); + callback(docs[0]); } }); }, @@ -28,12 +28,12 @@ let uiSettings = { getSortProps: function(callback) { uiDB.find({type: 'sort'}, function(error, docs) { if (error) { - callback(error); + callback(null, error); return; } if (docs.length) { - callback(error, docs[0]); + callback(docs[0]); } }); }, @@ -42,12 +42,12 @@ let uiSettings = { let newLocationData = Object.assign({}, {type: 'location'}, {path: data.destination}); uiDB.update({type: 'location'}, newLocationData, {upsert: true}, function (error, docs) { if (error) { - callback(error); + callback(null, error); return; } if (docs.length) { - callback(error, docs); + callback(docs); } }); }, @@ -56,12 +56,12 @@ let uiSettings = { let newSortPropData = Object.assign({}, {type: 'sort'}, sortProps); uiDB.update({type: 'sort'}, newSortPropData, {upsert: true}, function (error, docs) { if (error) { - callback(error); + callback(null, error); return; } if (docs.length) { - callback(error, docs); + callback(docs); } }); } diff --git a/server/util/ajaxUtil.js b/server/util/ajaxUtil.js index 65acecf8..e0691cb4 100644 --- a/server/util/ajaxUtil.js +++ b/server/util/ajaxUtil.js @@ -2,11 +2,13 @@ let ajaxUtil = { getResponseFn: function (res) { - return function (error, response) { + return function (data, error) { if (error) { - console.log('error in getResponseFn', error); + res.status(500).json(error); + return; + } else { + res.json(data); } - res.json(response); } } };