2016-06-30 12:01:48 -07:00
|
|
|
|
define(['appStorage', 'shell'], function (appStorage, shell) {
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
var supporterPlaybackKey = 'lastSupporterPlaybackMessage4';
|
2015-05-17 18:27:48 -07:00
|
|
|
|
|
2015-12-30 13:25:17 -07:00
|
|
|
|
function validatePlayback(resolve, reject) {
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
Dashboard.getPluginSecurityInfo().then(function (pluginSecurityInfo) {
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-07-26 22:03:34 -07:00
|
|
|
|
if (pluginSecurityInfo.IsMBSupporter) {
|
2015-12-30 13:25:17 -07:00
|
|
|
|
resolve();
|
2015-05-16 12:09:02 -07:00
|
|
|
|
} else {
|
|
|
|
|
|
2015-07-26 22:03:34 -07:00
|
|
|
|
var lastMessage = parseInt(appStorage.getItem(supporterPlaybackKey) || '0');
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-07-26 22:03:34 -07:00
|
|
|
|
if (!lastMessage) {
|
|
|
|
|
|
|
|
|
|
// Don't show on the very first playback attempt
|
|
|
|
|
appStorage.setItem(supporterPlaybackKey, new Date().getTime());
|
2015-12-30 13:25:17 -07:00
|
|
|
|
resolve();
|
2015-05-16 12:09:02 -07:00
|
|
|
|
}
|
2016-03-02 11:42:39 -07:00
|
|
|
|
else if ((new Date().getTime() - lastMessage) > 259200000) {
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-12-30 13:25:17 -07:00
|
|
|
|
showPlaybackOverlay(resolve, reject);
|
2015-07-26 22:03:34 -07:00
|
|
|
|
} else {
|
2015-12-30 13:25:17 -07:00
|
|
|
|
resolve();
|
2015-05-16 12:09:02 -07:00
|
|
|
|
}
|
|
|
|
|
}
|
2015-07-26 22:03:34 -07:00
|
|
|
|
});
|
|
|
|
|
}
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-11-26 21:52:50 -07:00
|
|
|
|
function getSubscriptionBenefits() {
|
|
|
|
|
|
|
|
|
|
var list = [];
|
|
|
|
|
|
|
|
|
|
list.push({
|
|
|
|
|
name: Globalize.translate('CoverArt'),
|
|
|
|
|
icon: 'photo',
|
|
|
|
|
text: Globalize.translate('CoverArtFeatureDescription')
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
list.push({
|
|
|
|
|
name: Globalize.translate('HeaderFreeApps'),
|
|
|
|
|
icon: 'check',
|
|
|
|
|
text: Globalize.translate('FreeAppsFeatureDescription')
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (Dashboard.capabilities().SupportsSync) {
|
|
|
|
|
list.push({
|
|
|
|
|
name: Globalize.translate('HeaderMobileSync'),
|
|
|
|
|
icon: 'sync',
|
|
|
|
|
text: Globalize.translate('MobileSyncFeatureDescription')
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
list.push({
|
|
|
|
|
name: Globalize.translate('HeaderCinemaMode'),
|
|
|
|
|
icon: 'movie',
|
|
|
|
|
text: Globalize.translate('CinemaModeFeatureDescription')
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return list;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getSubscriptionBenefitHtml(item) {
|
|
|
|
|
|
|
|
|
|
var html = '';
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '<div class="listItem">';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '<i class="listItemIcon md-icon">' + item.icon + '</i>';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '<div class="listItemBody two-line">';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
html += '<a class="clearLink" href="https://emby.media/premiere" target="_blank">';
|
|
|
|
|
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '<h3 class="listItemBodyText">';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
html += item.name;
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '</h3>';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '<div class="listItemBodyText secondary" style="white-space:normal;">';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
html += item.text;
|
|
|
|
|
html += '</div>';
|
|
|
|
|
|
|
|
|
|
html += '</a>';
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '</div>';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
2016-08-05 13:34:56 -07:00
|
|
|
|
html += '</div>';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
|
|
|
|
return html;
|
|
|
|
|
}
|
|
|
|
|
|
2015-12-30 13:25:17 -07:00
|
|
|
|
function showPlaybackOverlay(resolve, reject) {
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2016-09-09 09:58:08 -07:00
|
|
|
|
require(['dialogHelper', 'listViewStyle', 'emby-button', 'formDialogStyle'], function (dialogHelper) {
|
2015-07-26 22:03:34 -07:00
|
|
|
|
|
2016-03-23 12:03:17 -07:00
|
|
|
|
var dlg = dialogHelper.createDialog({
|
2016-06-18 13:31:22 -07:00
|
|
|
|
size: 'fullscreen-border',
|
2016-09-09 09:58:08 -07:00
|
|
|
|
removeOnClose: true,
|
|
|
|
|
scrollY: false
|
2016-01-30 13:59:09 -07:00
|
|
|
|
});
|
|
|
|
|
|
2016-09-09 09:58:08 -07:00
|
|
|
|
dlg.classList.add('formDialog');
|
2015-07-26 22:03:34 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
var html = '';
|
2016-09-09 09:58:08 -07:00
|
|
|
|
html += '<div class="formDialogHeader">';
|
|
|
|
|
html += '<button is="paper-icon-button-light" class="btnCancel autoSize" tabindex="-1"><i class="md-icon"></i></button>';
|
|
|
|
|
html += '<h3 class="formDialogHeaderTitle">';
|
|
|
|
|
html += '</h3>';
|
|
|
|
|
|
|
|
|
|
html += '</div>';
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2016-09-09 09:58:08 -07:00
|
|
|
|
|
|
|
|
|
html += '<div class="formDialogContent smoothScrollY">';
|
|
|
|
|
html += '<div class="dialogContentInner dialog-content-centered">';
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
html += '<h1>' + Globalize.translate('HeaderTryEmbyPremiere') + '</h1>';
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
html += '<p>' + Globalize.translate('MessageDidYouKnowCinemaMode') + '</p>';
|
|
|
|
|
html += '<p>' + Globalize.translate('MessageDidYouKnowCinemaMode2') + '</p>';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
html += '<br/>';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
html += '<h1>' + Globalize.translate('HeaderBenefitsEmbyPremiere') + '</h1>';
|
2015-11-26 21:52:50 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
html += '<div class="paperList">';
|
|
|
|
|
html += getSubscriptionBenefits().map(getSubscriptionBenefitHtml).join('');
|
|
|
|
|
html += '</div>';
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
html += '<br/>';
|
|
|
|
|
|
2016-09-09 09:58:08 -07:00
|
|
|
|
html += '<a class="clearLink" href="http://emby.media/premiere" target="_blank"><button is="emby-button" type="button" class="raised button-submit block" autoFocus><span>' + Globalize.translate('ButtonBecomeSupporter') + '</span></button></a>';
|
|
|
|
|
html += '<button is="emby-button" type="button" class="raised subdued block btnCancelSupporterInfo" style="background:#444;"><span>' + Globalize.translate('ButtonClosePlayVideo') + '</span></button>';
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2016-09-09 09:58:08 -07:00
|
|
|
|
html += '</div>';
|
2015-11-29 12:51:45 -07:00
|
|
|
|
html += '</div>';
|
2015-05-16 12:09:02 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
dlg.innerHTML = html;
|
2015-07-26 22:03:34 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
// Has to be assigned a z-index after the call to .open()
|
2016-03-22 10:46:57 -07:00
|
|
|
|
dlg.addEventListener('close', function (e) {
|
2015-11-29 12:51:45 -07:00
|
|
|
|
appStorage.setItem(supporterPlaybackKey, new Date().getTime());
|
2015-12-30 13:25:17 -07:00
|
|
|
|
resolve();
|
2015-11-29 12:51:45 -07:00
|
|
|
|
});
|
|
|
|
|
|
2016-03-23 12:03:17 -07:00
|
|
|
|
dialogHelper.open(dlg);
|
2015-11-29 12:51:45 -07:00
|
|
|
|
|
2016-06-18 13:31:22 -07:00
|
|
|
|
var onCancelClick = function () {
|
2016-03-23 12:03:17 -07:00
|
|
|
|
dialogHelper.close(dlg);
|
2016-06-18 13:31:22 -07:00
|
|
|
|
};
|
|
|
|
|
var i, length;
|
|
|
|
|
var elems = dlg.querySelectorAll('.btnCancelSupporterInfo');
|
|
|
|
|
for (i = 0, length = elems.length; i < length; i++) {
|
|
|
|
|
elems[i].addEventListener('click', onCancelClick);
|
|
|
|
|
}
|
2015-07-26 22:03:34 -07:00
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2015-12-30 13:25:17 -07:00
|
|
|
|
function validateSync(resolve, reject) {
|
2015-07-29 19:08:35 -07:00
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
Dashboard.getPluginSecurityInfo().then(function (pluginSecurityInfo) {
|
2015-07-29 19:08:35 -07:00
|
|
|
|
|
|
|
|
|
if (pluginSecurityInfo.IsMBSupporter) {
|
2015-12-30 13:25:17 -07:00
|
|
|
|
resolve();
|
2015-07-29 19:08:35 -07:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Dashboard.showLoadingMsg();
|
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
ApiClient.getRegistrationInfo('Sync').then(function (registrationInfo) {
|
2015-07-29 19:08:35 -07:00
|
|
|
|
|
|
|
|
|
Dashboard.hideLoadingMsg();
|
|
|
|
|
|
|
|
|
|
if (registrationInfo.IsRegistered) {
|
2015-12-30 13:25:17 -07:00
|
|
|
|
resolve();
|
2015-07-29 19:08:35 -07:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Dashboard.alert({
|
2015-10-01 09:28:24 -07:00
|
|
|
|
message: Globalize.translate('HeaderSyncRequiresSupporterMembership') + '<br/><p><a href="http://emby.media/premiere" target="_blank">' + Globalize.translate('ButtonLearnMore') + '</a></p>',
|
2015-12-14 08:43:03 -07:00
|
|
|
|
title: Globalize.translate('HeaderSync'),
|
2015-12-30 13:25:17 -07:00
|
|
|
|
callback: reject
|
2015-07-29 19:08:35 -07:00
|
|
|
|
});
|
|
|
|
|
|
2015-11-29 12:51:45 -07:00
|
|
|
|
}, function () {
|
2015-07-29 19:08:35 -07:00
|
|
|
|
|
2015-12-30 13:25:17 -07:00
|
|
|
|
reject();
|
2015-07-29 19:08:35 -07:00
|
|
|
|
Dashboard.hideLoadingMsg();
|
|
|
|
|
|
|
|
|
|
Dashboard.alert({
|
|
|
|
|
message: Globalize.translate('ErrorValidatingSupporterInfo')
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2016-08-16 13:54:13 -07:00
|
|
|
|
return {
|
2015-07-26 22:03:34 -07:00
|
|
|
|
validateFeature: function (name) {
|
2015-05-22 12:16:14 -07:00
|
|
|
|
|
2015-12-30 13:25:17 -07:00
|
|
|
|
return new Promise(function (resolve, reject) {
|
|
|
|
|
if (name == 'playback') {
|
|
|
|
|
validatePlayback(resolve, reject);
|
|
|
|
|
} else if (name == 'livetv') {
|
|
|
|
|
resolve();
|
|
|
|
|
} else if (name == 'sync') {
|
|
|
|
|
validateSync(resolve, reject);
|
|
|
|
|
} else {
|
|
|
|
|
resolve();
|
|
|
|
|
}
|
|
|
|
|
});
|
2016-06-30 12:01:48 -07:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
showPremiereInfo: function () {
|
|
|
|
|
shell.openUrl('https://emby.media/premiere');
|
2015-07-26 22:03:34 -07:00
|
|
|
|
}
|
|
|
|
|
};
|
2016-03-07 12:13:58 -07:00
|
|
|
|
});
|