updating add existing series to use the common views.

pull/2/head
Keivan Beigi 12 years ago
parent 1b55859eb2
commit 3c686808f2

@ -1,5 +1,5 @@
<div class="row"> <div class="row">
<div class="input-prepend nz-input-large add-series-search span11"> <div class="input-prepend nz-input-large add-series-search span11 x-search-bar">
<i class="add-on icon-search"/> <i class="add-on icon-search"/>
<input type="text" class="input-block-level x-series-search" placeholder="Start typing the name of series you want to add ..."> <input type="text" class="input-block-level x-series-search" placeholder="Start typing the name of series you want to add ...">
</div> </div>
@ -7,3 +7,6 @@
<div class="row"> <div class="row">
<div id="search-result" class="result-list span12"/> <div id="search-result" class="result-list span12"/>
</div> </div>
<div class="text-center new-series-loadmore x-load-more" style="display: none;">
<i class="icon-angle-down"/> more
</div>

@ -14,15 +14,18 @@ define(
template: 'AddSeries/AddSeriesTemplate', template: 'AddSeries/AddSeriesTemplate',
ui: { ui: {
seriesSearch: '.x-series-search' seriesSearch: '.x-series-search',
searchBar : '.x-search-bar',
loadMore : '.x-load-more'
}, },
regions: { regions: {
searchResult: '#search-result' searchResult: '#search-result'
}, },
initialize: function () { initialize: function (options) {
this.collection = new AddSeriesCollection(); this.collection = new AddSeriesCollection();
this.isExisting = options.isExisting;
}, },
onRender: function () { onRender: function () {
@ -30,29 +33,43 @@ define(
this.ui.seriesSearch.data('timeout', null).keyup(function () { this.ui.seriesSearch.data('timeout', null).keyup(function () {
window.clearTimeout(self.$el.data('timeout')); window.clearTimeout(self.$el.data('timeout'));
self.$el.data('timeout', window.setTimeout(self.search, 500, self)); self.$el.data('timeout', window.setTimeout(function () {
self.search.call(self, {
term: self.ui.seriesSearch.val()
}); });
}, 500));
});
if (this.isExisting) {
this.ui.searchBar.hide();
}
this.resultView = new SearchResultCollectionView({ collection: this.collection }); this.resultView = new SearchResultCollectionView({
fullResult: this.collection,
isExisting: this.isExisting
});
}, },
search: function (context) { search: function (options) {
var self = this;
context.abortExistingRequest(); this.abortExistingRequest();
var term = context.ui.seriesSearch.val(); this.collection.reset();
context.collection.reset();
if (term === '') { if (!options || options.term === '') {
context.searchResult.close(); this.searchResult.close();
} }
else { else {
context.searchResult.show(new SpinnerView()); this.searchResult.show(new SpinnerView());
this.currentSearchRequest = this.collection.fetch({
data: { term: options.term }
}).done(function () {
self.searchResult.show(self.resultView);
context.currentSearchRequest = context.collection.fetch({ if (!self.showingAll && self.isExisting) {
data : { term: term }, self.ui.loadMore.show();
success: function () {
context.searchResult.show(context.resultView);
} }
}); });
} }

@ -2,13 +2,13 @@
define( define(
[ [
'marionette', 'marionette',
'AddSeries/Existing/CompositeView', 'AddSeries/AddSeriesView',
'AddSeries/Existing/UnmappedFolderCollection' 'AddSeries/Existing/UnmappedFolderCollection'
], function (Marionette, UnmappedFolderCompositeView, UnmappedFolderCollection) { ], function (Marionette, AddSeriesView, UnmappedFolderCollection) {
return Marionette.CollectionView.extend({ return Marionette.CollectionView.extend({
itemView: UnmappedFolderCompositeView, itemView: AddSeriesView,
initialize: function () { initialize: function () {
this.collection = new UnmappedFolderCollection(); this.collection = new UnmappedFolderCollection();
@ -26,14 +26,20 @@ define(
_showAndSearch: function (index) { _showAndSearch: function (index) {
var model = this.collection.at(index); var model = this.collection.at(index);
if (model) { if (model) {
var that = this; var that = this;
var currentIndex = index; var currentIndex = index;
var folderName = model.get('folder').name;
this.addItemView(model, this.getItemView(), index); this.addItemView(model, this.getItemView(), index);
$.when(this.children.findByModel(model).search()).then(function () { $.when(this.children.findByModel(model).search({term: folderName})).then(function () {
that._showAndSearch(currentIndex + 1); that._showAndSearch(currentIndex + 1);
}); });
} }
},
itemViewOptions: {
isExisting: true
} }
}); });

@ -20,7 +20,5 @@
<div class="row"> <div class="row">
<div class="x-folder-name-match-results folder-name-matches"/> <div class="x-folder-name-match-results folder-name-matches"/>
</div> </div>
<div class="text-center new-series-loadmore x-load-more" style="display: none;">
<i class="icon-angle-down"/> more
</div>
</div> </div>

@ -17,7 +17,6 @@ define(
removeFolder: function () { removeFolder: function () {
this.model.destroy({ wait: true }); this.model.destroy({ wait: true });
this.model.collection.remove(this.model);
}, },
folderSelected: function () { folderSelected: function () {

@ -1,6 +1,8 @@
<td name="path" class="span10 x-folder clickable"/> <td class="span10 x-folder clickable">
{{path}}
</td>
<td class="span3 x-folder clickable"> <td class="span3 x-folder clickable">
<span name="freeSpaceString"></span> <span>{{freeSpaceString}}</span>
</td> </td>
<td class="span1 nz-row-action"> <td class="span1 nz-row-action">
<div class="btn btn-danger icon-minus x-remove"> <div class="btn btn-danger icon-minus x-remove">

@ -2,15 +2,45 @@
define( define(
[ [
'marionette', 'marionette',
'AddSeries/SearchResultView' 'AddSeries/SearchResultView',
], function (Marionette, SearchResultView) { 'AddSeries/Collection'
], function (Marionette, SearchResultView, SearchResultCollection) {
return Marionette.CollectionView.extend({ return Marionette.CollectionView.extend({
itemView: SearchResultView, itemView: SearchResultView,
initialize: function () {
this.listenTo(this.collection, 'reset', this.render); initialize: function (options) {
this.isExisting = options.isExisting;
this.fullResult = options.fullResult;
this.listenTo(this.fullResult, 'sync', this._processResultCollection);
},
showAll: function () {
this.showingAll = true;
this.fullResult.each(function (searchResult) {
this.collection.add(searchResult);
});
this.render();
},
_processResultCollection: function () {
if (!this.showingAll && this.isExisting) {
this.collection = new SearchResultCollection();
this.collection.add(this.fullResult.shift());
} }
else {
this.collection = this.fullResult;
}
}
}); });
}); });

@ -1,5 +1,9 @@
'use strict'; 'use strict';
define(['app', 'Series/SeriesModel'], function () { define(
[
'app',
'Series/SeriesModel'
], function () {
NzbDrone.Series.Delete.DeleteSeriesView = Backbone.Marionette.ItemView.extend({ NzbDrone.Series.Delete.DeleteSeriesView = Backbone.Marionette.ItemView.extend({
template: 'Series/Delete/DeleteSeriesTemplate', template: 'Series/Delete/DeleteSeriesTemplate',
@ -18,14 +22,10 @@ define(['app', 'Series/SeriesModel'], function () {
this.model.destroy({ this.model.destroy({
data: { 'deleteFiles': deleteFiles }, data: { 'deleteFiles': deleteFiles },
wait : true, wait: true
success: function (model) { }).done(function () {
model.collection.remove(model);
}
});
NzbDrone.modalRegion.close(); NzbDrone.modalRegion.close();
});
} }
}); });

@ -1,5 +1,9 @@
"use strict"; "use strict";
define(['marionette', 'bootstrap'], function (Marionette) { define(
[
'marionette',
'bootstrap'
], function (Marionette) {
return Marionette.Region.extend({ return Marionette.Region.extend({
el: "#modal-region", el: "#modal-region",
@ -27,9 +31,13 @@ define(['marionette', 'bootstrap'], function (Marionette) {
}, },
onClose: function(){
this.closeModal();
},
closeModal: function () { closeModal: function () {
this.$el.modal('hide'); this.$el.modal('hide');
this.close();
} }
}); });

Loading…
Cancel
Save