Save and add, notif settings cleanup

This commit is contained in:
Mark McDowall 2013-06-27 18:55:45 -07:00
parent 7f59062215
commit f7c340d795
15 changed files with 151 additions and 43 deletions

View File

@ -8,13 +8,13 @@ namespace NzbDrone.Core.Notifications.Growl
{ {
public class GrowlSettings : INotifcationSettings public class GrowlSettings : INotifcationSettings
{ {
[FieldDefinition(0, Label = "Host", HelpText = "Growl Host (IP or Hostname)")] [FieldDefinition(0, Label = "Host")]
public String Host { get; set; } public String Host { get; set; }
[FieldDefinition(1, Label = "Port", HelpText = "Growl Port")] [FieldDefinition(1, Label = "Port")]
public Int32 Port { get; set; } public Int32 Port { get; set; }
[FieldDefinition(2, Label = "Password", HelpText = "Password for Growl")] [FieldDefinition(2, Label = "Password")]
public String Password { get; set; } public String Password { get; set; }
public bool IsValid public bool IsValid

View File

@ -8,16 +8,16 @@ namespace NzbDrone.Core.Notifications.Plex
{ {
public class PlexClientSettings : INotifcationSettings public class PlexClientSettings : INotifcationSettings
{ {
[FieldDefinition(0, Label = "Host", HelpText = "Plex Client Host (IP or Hostname)")] [FieldDefinition(0, Label = "Host")]
public String Host { get; set; } public String Host { get; set; }
[FieldDefinition(1, Label = "Port", HelpText = "Plex Client Port")] [FieldDefinition(1, Label = "Port")]
public Int32 Port { get; set; } public Int32 Port { get; set; }
[FieldDefinition(2, Label = "Username", HelpText = "Username for Plex")] [FieldDefinition(2, Label = "Username")]
public String Username { get; set; } public String Username { get; set; }
[FieldDefinition(3, Label = "Password", HelpText = "Password for Plex")] [FieldDefinition(3, Label = "Password")]
public String Password { get; set; } public String Password { get; set; }
public bool IsValid public bool IsValid

View File

@ -8,13 +8,13 @@ namespace NzbDrone.Core.Notifications.Plex
{ {
public class PlexServerSettings : INotifcationSettings public class PlexServerSettings : INotifcationSettings
{ {
[FieldDefinition(0, Label = "Host", HelpText = "Plex Server Host (IP or Hostname)")] [FieldDefinition(0, Label = "Host")]
public String Host { get; set; } public String Host { get; set; }
[FieldDefinition(1, Label = "Port")] [FieldDefinition(1, Label = "Port")]
public Int32 Port { get; set; } public Int32 Port { get; set; }
[FieldDefinition(2, Label = "Update Library")] [FieldDefinition(2, Label = "Update Library", Type = FieldType.Checkbox)]
public Boolean UpdateLibrary { get; set; } public Boolean UpdateLibrary { get; set; }
public bool IsValid public bool IsValid

View File

@ -8,10 +8,10 @@ namespace NzbDrone.Core.Notifications.Prowl
{ {
public class ProwlSettings : INotifcationSettings public class ProwlSettings : INotifcationSettings
{ {
[FieldDefinition(0, Label = "API Key", HelpText = "API Key for Prowl")] [FieldDefinition(0, Label = "API Key")]
public String ApiKey { get; set; } public String ApiKey { get; set; }
[FieldDefinition(1, Label = "Priority", HelpText = "Priority to send messages at", Type = FieldType.Select, SelectOptions= typeof(ProwlPriority) )] [FieldDefinition(1, Label = "Priority", Type = FieldType.Select, SelectOptions= typeof(ProwlPriority) )]
public Int32 Priority { get; set; } public Int32 Priority { get; set; }
public bool IsValid public bool IsValid

View File

@ -11,7 +11,7 @@ define(
tagName : 'tr', tagName : 'tr',
events: { events: {
'click .x-remove': 'removeFolder', 'click .x-delete': 'removeFolder',
'click .x-folder': 'folderSelected' 'click .x-folder': 'folderSelected'
}, },

View File

@ -40,5 +40,16 @@
<button class="btn btn-danger pull-left x-remove">delete</button> <button class="btn btn-danger pull-left x-remove">delete</button>
{{/if}} {{/if}}
<button class="btn" data-dismiss="modal">cancel</button> <button class="btn" data-dismiss="modal">cancel</button>
<div class="btn-group">
<button class="btn btn-primary x-save">save</button> <button class="btn btn-primary x-save">save</button>
<button class="btn btn-primary dropdown-toggle" data-toggle="dropdown">
<span class="caret"></span>
</button>
<ul class="dropdown-menu">
<li class="save-and-add x-save-and-add">
save and add
</li>
</ul>
</div>
</div> </div>

View File

@ -2,23 +2,54 @@
define( define(
[ [
'app',
'marionette', 'marionette',
'Mixins/AsModelBoundView' 'Mixins/AsModelBoundView'
], function (Marionette, AsModelBoundView) { ], function (App, Marionette, AsModelBoundView) {
var view = Marionette.ItemView.extend({ var view = Marionette.ItemView.extend({
template: 'Settings/Indexers/EditTemplate', template: 'Settings/Indexers/EditTemplate',
events: { events: {
'click .x-save': 'save' 'click .x-save': '_save',
'click .x-save-and-add': '_saveAndAdd'
}, },
initialize: function (options) { initialize: function (options) {
this.indexerCollection = options.indexerCollection; this.indexerCollection = options.indexerCollection;
}, },
save: function () { _save: function () {
this.model.saveSettings(); var self = this;
var promise = this.model.saveSettings();
if (promise) {
promise.done(function () {
self.indexerCollection.add(self.model, { merge: true });
App.modalRegion.closeModal();
});
}
},
_saveAndAdd: function () {
var self = this;
var promise = this.model.saveSettings();
if (promise) {
promise.done(function () {
self.indexerCollection.add(self.model, { merge: true });
self.model.set({
id: undefined,
name: '',
enable: false
});
_.each(self.model.get('fields'), function (value, key, list) {
self.model.set('fields.' + key +'.value', '');
});
});
}
} }
}); });

View File

@ -2,10 +2,9 @@
define([ define([
'app', 'app',
'marionette', 'marionette',
'Settings/Notifications/Collection',
'Settings/Notifications/ItemView', 'Settings/Notifications/ItemView',
'Settings/Notifications/AddView' 'Settings/Notifications/SchemaModal'
], function (App, Marionette, NotificationCollection, NotificationItemView, AddSelectionNotificationView) { ], function (App, Marionette, NotificationItemView, SchemaModal) {
return Marionette.CompositeView.extend({ return Marionette.CompositeView.extend({
itemView : NotificationItemView, itemView : NotificationItemView,
itemViewContainer: '.notifications', itemViewContainer: '.notifications',
@ -16,13 +15,7 @@ define([
}, },
_openSchemaModal: function () { _openSchemaModal: function () {
var schemaCollection = new NotificationCollection(); SchemaModal.open(this.collection);
schemaCollection.url = '/api/notification/schema';
schemaCollection.fetch();
schemaCollection.url = '/api/notification';
var view = new AddSelectionNotificationView({ collection: schemaCollection, notificationCollection: this.collection});
App.modalRegion.show(view);
} }
}); });
}); });

View File

@ -61,10 +61,23 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
{{#if id}} {{#if id}}
<button class="btn btn-danger pull-left x-remove">delete</button> <button class="btn btn-danger pull-left x-delete">delete</button>
{{else}}
<button class="btn pull-left x-back">back</button>
{{/if}} {{/if}}
<button class="btn x-test">test <i class="x-test-icon"/></button>
<button class="btn x-test">test <i class="x-test-icon"/></button>
<button class="btn" data-dismiss="modal">cancel</button> <button class="btn" data-dismiss="modal">cancel</button>
<div class="btn-group">
<button class="btn btn-primary x-save">save</button> <button class="btn btn-primary x-save">save</button>
<button class="btn btn-primary dropdown-toggle" data-toggle="dropdown">
<span class="caret"></span>
</button>
<ul class="dropdown-menu">
<li class="save-and-add x-save-and-add">
save and add
</li>
</ul>
</div>
</div> </div>

View File

@ -16,7 +16,9 @@ define([
events: { events: {
'click .x-save' : '_saveNotification', 'click .x-save' : '_saveNotification',
'click .x-remove': '_deleteNotification', 'click .x-save-and-add' : '_saveAndAddNotification',
'click .x-delete' : '_deleteNotification',
'click .x-back' : '_back',
'click .x-test' : '_test' 'click .x-test' : '_test'
}, },
@ -41,14 +43,26 @@ define([
} }
}, },
_saveAndAddNotification: function () {
var self = this;
var promise = this.model.saveSettings();
if (promise) {
promise.done(function () {
self.notificationCollection.add(self.model, { merge: true });
require('Settings/Notifications/SchemaModal').open(self.notificationCollection);
});
}
},
_deleteNotification: function () { _deleteNotification: function () {
var view = new DeleteView({ model: this.model }); var view = new DeleteView({ model: this.model });
App.modalRegion.show(view); App.modalRegion.show(view);
}, },
_saveSuccess: function () { _back: function () {
this.notificationCollection.add(this.model, { merge: true }); require('Settings/Notifications/SchemaModal').open(this.notificationCollection);
App.modalRegion.closeModal();
}, },
_test: function () { _test: function () {

View File

@ -7,7 +7,7 @@
</span> </span>
</div> </div>
<div> <div class="settings">
{{#if onGrab}} {{#if onGrab}}
<span class="label label-success">On Grab</span> <span class="label label-success">On Grab</span>
{{else}} {{else}}

View File

@ -0,0 +1,19 @@
'use strict';
define([
'app',
'Settings/Notifications/Collection',
'Settings/Notifications/AddView'
], function (App, NotificationCollection, AddSelectionNotificationView) {
return ({
open: function (collection) {
var schemaCollection = new NotificationCollection();
schemaCollection.url = '/api/notification/schema';
schemaCollection.fetch();
schemaCollection.url = '/api/notification';
var view = new AddSelectionNotificationView({ collection: schemaCollection, notificationCollection: collection});
App.modalRegion.show(view);
}
});
});

View File

@ -23,24 +23,27 @@
} }
.notifications { .notifications {
width: -webkit-fit-content;
width: -moz-fit-content;
width: fit-content;
li { li {
display: inline-block; display: inline-block;
vertical-align: top; vertical-align: top;
} }
} }
.notification-item { .notification-item {
.card; .card;
width: 250px; width: 290px;
height: 80px; height: 90px;
padding: 10px 15px; padding: 20px 20px;
h3 { h3 {
margin-top: 0px; margin-top: 0px;
display: inline-block; display: inline-block;
width: 200px; width: 230px;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
@ -49,4 +52,8 @@
.btn-group { .btn-group {
margin-top: 8px; margin-top: 8px;
} }
.settings {
margin-top: 5px;
}
} }

View File

@ -52,7 +52,7 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
{{#if id}} {{#if id}}
<button class="btn btn-danger pull-left x-remove">delete</button> <button class="btn btn-danger pull-left x-delete">delete</button>
{{/if}} {{/if}}
<button class="btn" data-dismiss="modal">cancel</button> <button class="btn" data-dismiss="modal">cancel</button>
<button class="btn btn-primary x-save">save</button> <button class="btn btn-primary x-save">save</button>

View File

@ -1,3 +1,23 @@
@import "../Shared/Styles/clickable.less";
@import "Indexers/indexers"; @import "Indexers/indexers";
@import "Quality/quality"; @import "Quality/quality";
@import "Notifications/notifications"; @import "Notifications/notifications";
li.save-and-add {
.clickable;
display: block;
padding: 3px 20px;
clear: both;
font-weight: normal;
line-height: 20px;
color: rgb(51, 51, 51);
white-space: nowrap;
}
li.save-and-add:hover {
text-decoration: none;
color: rgb(255, 255, 255);
background-color: rgb(0, 129, 194);
}