2019-01-10 15:39:37 +03:00
|
|
|
define(['backdrop', 'mainTabsManager', 'layoutManager', 'emby-tabs'], function (backdrop, mainTabsManager, layoutManager) {
|
|
|
|
'use strict';
|
2018-10-23 01:05:09 +03:00
|
|
|
|
|
|
|
function onViewDestroy(e) {
|
2019-01-10 15:39:37 +03:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var tabControllers = this.tabControllers;
|
2019-01-10 15:39:37 +03:00
|
|
|
|
|
|
|
if (tabControllers) {
|
|
|
|
tabControllers.forEach(function (t) {
|
|
|
|
if (t.destroy) {
|
|
|
|
t.destroy();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
this.tabControllers = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.view = null;
|
|
|
|
this.params = null;
|
|
|
|
this.currentTabController = null;
|
|
|
|
this.initialTabIndex = null;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2019-01-10 15:39:37 +03:00
|
|
|
function onBeforeTabChange() {
|
|
|
|
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
|
|
|
function TabbedView(view, params) {
|
2019-01-10 15:39:37 +03:00
|
|
|
|
|
|
|
this.tabControllers = [];
|
|
|
|
this.view = view;
|
|
|
|
this.params = params;
|
|
|
|
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
var currentTabIndex = parseInt(params.tab || this.getDefaultTabIndex(params.parentId));
|
|
|
|
this.initialTabIndex = currentTabIndex;
|
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
function validateTabLoad(index) {
|
2019-01-10 15:39:37 +03:00
|
|
|
|
|
|
|
return self.validateTabLoad ? self.validateTabLoad(index) : Promise.resolve();
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function loadTab(index, previousIndex) {
|
2019-01-10 15:39:37 +03:00
|
|
|
|
|
|
|
validateTabLoad(index).then(function () {
|
|
|
|
self.getTabController(index).then(function (controller) {
|
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var refresh = !controller.refreshed;
|
2019-01-10 15:39:37 +03:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
controller.onResume({
|
2019-01-10 15:39:37 +03:00
|
|
|
autoFocus: previousIndex == null && layoutManager.tv,
|
2018-10-23 01:05:09 +03:00
|
|
|
refresh: refresh
|
2019-01-10 15:39:37 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
controller.refreshed = true;
|
|
|
|
|
|
|
|
currentTabIndex = index;
|
|
|
|
self.currentTabController = controller;
|
|
|
|
});
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getTabContainers() {
|
2019-01-10 15:39:37 +03:00
|
|
|
return view.querySelectorAll('.tabContent');
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function onTabChange(e) {
|
2019-01-10 15:39:37 +03:00
|
|
|
var newIndex = parseInt(e.detail.selectedTabIndex);
|
|
|
|
var previousIndex = e.detail.previousIndex;
|
|
|
|
|
|
|
|
var previousTabController = previousIndex == null ? null : self.tabControllers[previousIndex];
|
|
|
|
if (previousTabController && previousTabController.onPause) {
|
|
|
|
previousTabController.onPause();
|
|
|
|
}
|
|
|
|
|
|
|
|
loadTab(newIndex, previousIndex);
|
|
|
|
}
|
|
|
|
|
|
|
|
view.addEventListener('viewbeforehide', this.onPause.bind(this));
|
|
|
|
|
|
|
|
view.addEventListener('viewbeforeshow', function (e) {
|
|
|
|
|
|
|
|
mainTabsManager.setTabs(view, currentTabIndex, self.getTabs, getTabContainers, onBeforeTabChange, onTabChange, false);
|
|
|
|
});
|
|
|
|
|
|
|
|
view.addEventListener('viewshow', function (e) {
|
|
|
|
|
|
|
|
self.onResume(e.detail);
|
|
|
|
});
|
|
|
|
|
|
|
|
view.addEventListener('viewdestroy', onViewDestroy.bind(this));
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-01-10 15:39:37 +03:00
|
|
|
|
|
|
|
TabbedView.prototype.onResume = function (options) {
|
|
|
|
|
|
|
|
this.setTitle();
|
|
|
|
backdrop.clear();
|
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var currentTabController = this.currentTabController;
|
2019-01-10 15:39:37 +03:00
|
|
|
|
|
|
|
if (!currentTabController) {
|
|
|
|
mainTabsManager.selectedTabIndex(this.initialTabIndex);
|
2019-11-23 00:29:38 +09:00
|
|
|
} else if (currentTabController && currentTabController.onResume) {
|
2019-01-10 15:39:37 +03:00
|
|
|
currentTabController.onResume({});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TabbedView.prototype.onPause = function () {
|
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var currentTabController = this.currentTabController;
|
2019-01-10 15:39:37 +03:00
|
|
|
|
|
|
|
if (currentTabController && currentTabController.onPause) {
|
|
|
|
currentTabController.onPause();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TabbedView.prototype.setTitle = function () {
|
|
|
|
Emby.Page.setTitle('');
|
|
|
|
};
|
|
|
|
|
|
|
|
return TabbedView;
|
2020-02-22 11:47:03 -05:00
|
|
|
});
|