jellyfish-web/dashboard-ui/scripts/mysync.js

75 lines
2 KiB
JavaScript
Raw Normal View History

2016-08-16 14:54:08 -04:00
define(['loading', 'apphost', 'localsync'], function (loading, appHost) {
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
return function (view, params) {
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
var interval;
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
function isLocalSyncManagement() {
return appHost.supports('sync') && params.mode == 'offline';
}
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
function refreshSyncStatus(page) {
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
if (isLocalSyncManagement()) {
2016-06-19 12:53:53 -04:00
2016-08-16 14:54:08 -04:00
var status = LocalSync.getSyncStatus();
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
page.querySelector('.labelSyncStatus').innerHTML = Globalize.translate('LabelLocalSyncStatusValue', status);
if (status == 'Active') {
loading.show();
} else {
loading.hide();
}
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
if (status == "Active") {
page.querySelector('.btnSyncNow').classList.add('hide');
}
else {
page.querySelector('.btnSyncNow').classList.remove('hide');
}
}
}
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
function syncNow(page) {
2015-08-12 17:39:02 -04:00
2016-08-16 14:54:08 -04:00
LocalSync.sync();
require(['toast'], function (toast) {
toast(Globalize.translate('MessageSyncStarted'));
});
refreshSyncStatus(page);
}
2015-08-12 17:39:02 -04:00
2016-06-19 12:53:53 -04:00
view.querySelector('.btnSyncNow').addEventListener('click', function () {
syncNow(view);
2015-08-12 17:39:02 -04:00
});
2016-08-16 14:54:08 -04:00
if (isLocalSyncManagement()) {
2015-10-02 02:14:04 -04:00
2016-06-19 12:53:53 -04:00
view.querySelector('.localSyncStatus').classList.remove('hide');
2015-10-02 02:14:04 -04:00
2016-06-19 12:53:53 -04:00
} else {
view.querySelector('.localSyncStatus').classList.add('hide');
}
2015-08-12 17:39:02 -04:00
2016-06-19 12:53:53 -04:00
view.addEventListener('viewbeforeshow', function () {
var page = this;
2015-08-12 17:39:02 -04:00
refreshSyncStatus(page);
2016-06-19 12:53:53 -04:00
interval = setInterval(function () {
refreshSyncStatus(page);
}, 5000);
});
2015-08-12 17:39:02 -04:00
2016-06-19 12:53:53 -04:00
view.addEventListener('viewbeforehide', function () {
var page = this;
2015-08-12 17:39:02 -04:00
2016-07-02 14:29:10 -04:00
loading.hide();
2015-08-12 17:39:02 -04:00
2016-06-19 12:53:53 -04:00
if (interval) {
clearInterval(interval);
interval = null;
}
});
};
});