200 lines
5.2 KiB
JavaScript
200 lines
5.2 KiB
JavaScript
/*
|
|
* Copyright (c) 2015
|
|
*
|
|
* This file is licensed under the Affero General Public License version 3
|
|
* or later.
|
|
*
|
|
* See the COPYING-README file.
|
|
*
|
|
*/
|
|
|
|
(function() {
|
|
/**
|
|
* @memberof OCA.Versions
|
|
*/
|
|
var VersionsTabView = OCA.Files.DetailTabView.extend(/** @lends OCA.Versions.VersionsTabView.prototype */{
|
|
id: 'versionsTabView',
|
|
className: 'tab versionsTabView',
|
|
|
|
_template: null,
|
|
|
|
$versionsContainer: null,
|
|
|
|
events: {
|
|
'click .revertVersion': '_onClickRevertVersion'
|
|
},
|
|
|
|
initialize: function() {
|
|
OCA.Files.DetailTabView.prototype.initialize.apply(this, arguments);
|
|
this.collection = new OCA.Versions.VersionCollection();
|
|
this.collection.on('request', this._onRequest, this);
|
|
this.collection.on('sync', this._onEndRequest, this);
|
|
this.collection.on('update', this._onUpdate, this);
|
|
this.collection.on('error', this._onError, this);
|
|
this.collection.on('add', this._onAddModel, this);
|
|
},
|
|
|
|
getLabel: function() {
|
|
return t('files_versions', 'Versions');
|
|
},
|
|
|
|
getIcon: function() {
|
|
return 'icon-history';
|
|
},
|
|
|
|
nextPage: function() {
|
|
if (this._loading) {
|
|
return;
|
|
}
|
|
|
|
if (this.collection.getFileInfo() && this.collection.getFileInfo().isDirectory()) {
|
|
return;
|
|
}
|
|
this.collection.fetch();
|
|
},
|
|
|
|
_onClickRevertVersion: function(ev) {
|
|
var self = this;
|
|
var $target = $(ev.target);
|
|
var fileInfoModel = this.collection.getFileInfo();
|
|
var revision;
|
|
if (!$target.is('li')) {
|
|
$target = $target.closest('li');
|
|
}
|
|
|
|
ev.preventDefault();
|
|
revision = $target.attr('data-revision');
|
|
|
|
var versionModel = this.collection.get(revision);
|
|
versionModel.revert({
|
|
success: function() {
|
|
// reset and re-fetch the updated collection
|
|
self.$versionsContainer.empty();
|
|
self.collection.setFileInfo(fileInfoModel);
|
|
self.collection.reset([], {silent: true});
|
|
self.collection.fetch();
|
|
|
|
self.$el.find('.versions').removeClass('hidden');
|
|
|
|
// update original model
|
|
fileInfoModel.trigger('busy', fileInfoModel, false);
|
|
fileInfoModel.set({
|
|
size: versionModel.get('size'),
|
|
mtime: versionModel.get('timestamp') * 1000,
|
|
// temp dummy, until we can do a PROPFIND
|
|
etag: versionModel.get('id') + versionModel.get('timestamp')
|
|
});
|
|
},
|
|
|
|
error: function() {
|
|
fileInfoModel.trigger('busy', fileInfoModel, false);
|
|
self.$el.find('.versions').removeClass('hidden');
|
|
self._toggleLoading(false);
|
|
OC.Notification.show(t('files_version', 'Failed to revert {file} to revision {timestamp}.',
|
|
{
|
|
file: versionModel.getFullPath(),
|
|
timestamp: OC.Util.formatDate(versionModel.get('timestamp') * 1000)
|
|
}),
|
|
{
|
|
type: 'error'
|
|
}
|
|
);
|
|
}
|
|
});
|
|
|
|
// spinner
|
|
this._toggleLoading(true);
|
|
fileInfoModel.trigger('busy', fileInfoModel, true);
|
|
},
|
|
|
|
_toggleLoading: function(state) {
|
|
this._loading = state;
|
|
this.$el.find('.loading').toggleClass('hidden', !state);
|
|
},
|
|
|
|
_onRequest: function() {
|
|
this._toggleLoading(true);
|
|
},
|
|
|
|
_onEndRequest: function() {
|
|
this._toggleLoading(false);
|
|
this.$el.find('.empty').toggleClass('hidden', !!this.collection.length);
|
|
},
|
|
|
|
_onAddModel: function(model) {
|
|
var $el = $(this.itemTemplate(this._formatItem(model)));
|
|
this.$versionsContainer.append($el);
|
|
$el.find('.has-tooltip').tooltip();
|
|
},
|
|
|
|
template: function(data) {
|
|
return OCA.Versions.Templates['template'](data);
|
|
},
|
|
|
|
itemTemplate: function(data) {
|
|
return OCA.Versions.Templates['item'](data);
|
|
},
|
|
|
|
setFileInfo: function(fileInfo) {
|
|
if (fileInfo) {
|
|
this.render();
|
|
this.collection.setFileInfo(fileInfo);
|
|
this.collection.reset([], {silent: true});
|
|
this.nextPage();
|
|
} else {
|
|
this.render();
|
|
this.collection.reset();
|
|
}
|
|
},
|
|
|
|
_formatItem: function(version) {
|
|
var timestamp = version.get('timestamp') * 1000;
|
|
var size = version.has('size') ? version.get('size') : 0;
|
|
|
|
return _.extend({
|
|
versionId: version.get('id'),
|
|
formattedTimestamp: OC.Util.formatDate(timestamp),
|
|
relativeTimestamp: OC.Util.relativeModifiedDate(timestamp),
|
|
humanReadableSize: OC.Util.humanFileSize(size, true),
|
|
altSize: n('files', '%n byte', '%n bytes', size),
|
|
hasDetails: version.has('size'),
|
|
downloadUrl: version.getDownloadUrl(),
|
|
downloadIconUrl: OC.imagePath('core', 'actions/download'),
|
|
downloadName: version.get('name'),
|
|
revertIconUrl: OC.imagePath('core', 'actions/history'),
|
|
previewUrl: version.getPreviewUrl(),
|
|
revertLabel: t('files_versions', 'Restore'),
|
|
canRevert: (this.collection.getFileInfo().get('permissions') & OC.PERMISSION_UPDATE) !== 0
|
|
}, version.attributes);
|
|
},
|
|
|
|
/**
|
|
* Renders this details view
|
|
*/
|
|
render: function() {
|
|
this.$el.html(this.template({
|
|
emptyResultLabel: t('files_versions', 'No other versions available'),
|
|
}));
|
|
this.$el.find('.has-tooltip').tooltip();
|
|
this.$versionsContainer = this.$el.find('ul.versions');
|
|
this.delegateEvents();
|
|
},
|
|
|
|
/**
|
|
* Returns true for files, false for folders.
|
|
*
|
|
* @return {bool} true for files, false for folders
|
|
*/
|
|
canDisplay: function(fileInfo) {
|
|
if (!fileInfo) {
|
|
return false;
|
|
}
|
|
return !fileInfo.isDirectory();
|
|
}
|
|
});
|
|
|
|
OCA.Versions = OCA.Versions || {};
|
|
|
|
OCA.Versions.VersionsTabView = VersionsTabView;
|
|
})();
|