2020-05-04 12:44:12 +02:00
|
|
|
define(['playbackSettings', 'dom', 'globalize', 'loading', 'userSettings', 'autoFocuser', 'listViewStyle'], function (PlaybackSettings, dom, globalize, loading, userSettings, autoFocuser) {
|
|
|
|
'use strict';
|
2019-11-06 13:43:39 +03:00
|
|
|
|
2020-05-27 16:14:24 +03:00
|
|
|
// Shortcuts
|
|
|
|
const UserSettings = userSettings.UserSettings;
|
|
|
|
|
2019-11-06 13:43:39 +03:00
|
|
|
return function (view, params) {
|
2018-10-23 01:05:09 +03:00
|
|
|
function onBeforeUnload(e) {
|
2019-11-06 13:43:39 +03:00
|
|
|
if (hasChanges) {
|
2020-05-04 12:44:12 +02:00
|
|
|
e.returnValue = 'You currently have unsaved changes. Are you sure you wish to leave?';
|
2019-11-06 13:43:39 +03:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-11-06 13:43:39 +03:00
|
|
|
|
|
|
|
var settingsInstance;
|
|
|
|
var hasChanges;
|
|
|
|
var userId = params.userId || ApiClient.getCurrentUserId();
|
2020-05-27 16:14:24 +03:00
|
|
|
var currentSettings = userId === ApiClient.getCurrentUserId() ? userSettings : new UserSettings();
|
2020-05-04 12:44:12 +02:00
|
|
|
view.addEventListener('viewshow', function () {
|
|
|
|
window.addEventListener('beforeunload', onBeforeUnload);
|
2019-11-06 13:43:39 +03:00
|
|
|
|
|
|
|
if (settingsInstance) {
|
|
|
|
settingsInstance.loadData();
|
|
|
|
} else {
|
|
|
|
settingsInstance = new PlaybackSettings({
|
|
|
|
serverId: ApiClient.serverId(),
|
|
|
|
userId: userId,
|
2020-05-04 12:44:12 +02:00
|
|
|
element: view.querySelector('.settingsContainer'),
|
2020-04-03 03:16:06 +09:00
|
|
|
userSettings: currentSettings,
|
2019-11-06 13:43:39 +03:00
|
|
|
enableSaveButton: false,
|
2019-11-02 20:38:58 +03:00
|
|
|
enableSaveConfirmation: false,
|
2019-11-14 20:34:17 +03:00
|
|
|
autoFocus: autoFocuser.isEnabled()
|
2019-11-06 13:43:39 +03:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2020-05-04 12:44:12 +02:00
|
|
|
view.addEventListener('change', function () {
|
2019-11-06 13:43:39 +03:00
|
|
|
hasChanges = true;
|
|
|
|
});
|
2020-05-04 12:44:12 +02:00
|
|
|
view.addEventListener('viewbeforehide', function () {
|
2019-11-06 13:43:39 +03:00
|
|
|
hasChanges = false;
|
|
|
|
|
|
|
|
if (settingsInstance) {
|
|
|
|
settingsInstance.submit();
|
|
|
|
}
|
|
|
|
});
|
2020-05-04 12:44:12 +02:00
|
|
|
view.addEventListener('viewdestroy', function () {
|
2019-11-06 13:43:39 +03:00
|
|
|
if (settingsInstance) {
|
|
|
|
settingsInstance.destroy();
|
|
|
|
settingsInstance = null;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
});
|