'use strict'; define( [ 'app', 'marionette', 'Settings/SettingsModel', 'Settings/General/GeneralSettingsModel', 'Settings/MediaManagement/Naming/Model', 'Settings/MediaManagement/Layout', 'Settings/Quality/QualityLayout', 'Settings/Indexers/Layout', 'Settings/Indexers/Collection', 'Settings/DownloadClient/Layout', 'Settings/Notifications/CollectionView', 'Settings/Notifications/Collection', 'Settings/General/GeneralView', 'Shared/LoadingView', 'Config' ], function (App, Marionette, SettingsModel, GeneralSettingsModel, NamingModel, MediaManagementLayout, QualityLayout, IndexerLayout, IndexerCollection, DownloadClientLayout, NotificationCollectionView, NotificationCollection, GeneralView, LoadingView, Config) { return Marionette.Layout.extend({ template: 'Settings/SettingsLayoutTemplate', regions: { mediaManagement : '#media-management', quality : '#quality', indexers : '#indexers', downloadClient : '#download-client', notifications : '#notifications', general : '#general', loading : '#loading-region' }, ui: { mediaManagementTab : '.x-media-management-tab', qualityTab : '.x-quality-tab', indexersTab : '.x-indexers-tab', downloadClientTab : '.x-download-client-tab', notificationsTab : '.x-notifications-tab', generalTab : '.x-general-tab', advancedSettings : '.x-advanced-settings' }, events: { 'click .x-media-management-tab' : '_showMediaManagement', 'click .x-quality-tab' : '_showQuality', 'click .x-indexers-tab' : '_showIndexers', 'click .x-download-client-tab' : '_showDownloadClient', 'click .x-notifications-tab' : '_showNotifications', 'click .x-general-tab' : '_showGeneral', 'click .x-save-settings' : '_save', 'change .x-advanced-settings' : '_toggleAdvancedSettings' }, initialize: function (options) { if (options.action) { this.action = options.action.toLowerCase(); } }, onRender: function () { this.loading.show(new LoadingView()); var self = this; this.settings = new SettingsModel(); this.generalSettings = new GeneralSettingsModel(); this.namingSettings = new NamingModel(); this.indexerSettings = new IndexerCollection(); this.notificationSettings = new NotificationCollection(); $.when(this.settings.fetch(), this.generalSettings.fetch(), this.namingSettings.fetch(), this.indexerSettings.fetch(), this.notificationSettings.fetch() ).done(function () { self.loading.$el.hide(); self.mediaManagement.show(new MediaManagementLayout({ settings: self.settings, namingSettings: self.namingSettings })); self.quality.show(new QualityLayout({ settings: self.settings })); self.indexers.show(new IndexerLayout({ settings: self.settings, indexersCollection: self.indexerSettings })); self.downloadClient.show(new DownloadClientLayout({ model: self.settings })); self.notifications.show(new NotificationCollectionView({ collection: self.notificationSettings })); self.general.show(new GeneralView({ model: self.generalSettings })); }); this._setAdvancedSettingsState(); }, onShow: function () { switch (this.action) { case 'quality': this._showQuality(); break; case 'indexers': this._showIndexers(); break; case 'downloadclient': this._showDownloadClient(); break; case 'connect': this._showNotifications(); break; case 'notifications': this._showNotifications(); break; case 'general': this._showGeneral(); break; default: this._showMediaManagement(); } }, _showMediaManagement: function (e) { if (e) { e.preventDefault(); } this.ui.mediaManagementTab.tab('show'); this._navigate('settings/mediamanagement'); }, _showQuality: function (e) { if (e) { e.preventDefault(); } this.ui.qualityTab.tab('show'); this._navigate('settings/quality'); }, _showIndexers: function (e) { if (e) { e.preventDefault(); } this.ui.indexersTab.tab('show'); this._navigate('settings/indexers'); }, _showDownloadClient: function (e) { if (e) { e.preventDefault(); } this.ui.downloadClientTab.tab('show'); this._navigate('settings/downloadclient'); }, _showNotifications: function (e) { if (e) { e.preventDefault(); } this.ui.notificationsTab.tab('show'); this._navigate('settings/connect'); }, _showGeneral: function (e) { if (e) { e.preventDefault(); } this.ui.generalTab.tab('show'); this._navigate('settings/general'); }, _navigate:function(route){ require(['Router'], function(){ App.Router.navigate(route); }); }, _save: function () { App.vent.trigger(App.Commands.SaveSettings); }, _setAdvancedSettingsState: function () { var checked = Config.getValueBoolean('advancedSettings'); this.ui.advancedSettings.prop('checked', checked); if (checked) { this.$el.addClass('show-advanced-settings'); } }, _toggleAdvancedSettings: function () { var checked = this.ui.advancedSettings.prop('checked'); Config.setValue('advancedSettings', checked); if (checked) { this.$el.addClass('show-advanced-settings'); } else { this.$el.removeClass('show-advanced-settings'); } } }); });