/* * Copyright (c) 2015 * * This file is licensed under the Affero General Public License version 3 * or later. * * See the COPYING-README file. * */ (function() { if (!OC.Share) { OC.Share = {}; } var TEMPLATE = '{{#if shareAllowed}}' + '' + '' + '
' + '' + '' + ' {{#if showPasswordCheckBox}}' + '' + ' {{/if}}' + '
' + ' ' + ' ' + ' ' + '
' + ' {{#if publicUpload}}' + '
' + ' ' + ' ' + '' + '
' + ' {{/if}}' + ' {{#if mailPublicNotificationEnabled}}' + '' + ' {{/if}}' + '{{else}}' + '' + '{{/if}}' ; /** * @class OCA.Share.ShareDialogLinkShareView * @member {OC.Share.ShareItemModel} model * @member {jQuery} $el * @memberof OCA.Sharing * @classdesc * * Represents the GUI of the share dialogue * */ var ShareDialogLinkShareView = OC.Backbone.View.extend({ /** @type {string} **/ id: 'shareDialogLinkShare', /** @type {OC.Share.ShareConfigModel} **/ configModel: undefined, /** @type {Function} **/ _template: undefined, /** @type {boolean} **/ showLink: true, events: { 'submit .emailPrivateLinkForm': '_onEmailPrivateLink' }, initialize: function(options) { var view = this; this.model.on('change:permissions', function() { view.render(); }); this.model.on('change:itemType', function() { view.render(); }); this.model.on('change:allowPublicUploadStatus', function() { view.render(); }); this.model.on('change:linkShare', function() { view.render(); }); if(!_.isUndefined(options.configModel)) { this.configModel = options.configModel; } else { throw 'missing OC.Share.ShareConfigModel'; } _.bindAll(this, 'onLinkCheckBoxChange', 'onPasswordEntered', 'onShowPasswordClick', 'onAllowPublicUploadChange'); }, onLinkCheckBoxChange: function() { var $checkBox = this.$el.find('#linkCheckbox'); var $loading = $checkBox.siblings('.icon-loading-small'); if(!$loading.hasClass('hidden')) { return false; } if($checkBox.is(':checked')) { if(this.configModel.get('enforcePasswordForPublicLink') === false) { $loading.removeClass('hidden'); // this will create it this.model.saveLinkShare(); } else { this.$el.find('#linkPass').slideToggle(OC.menuSpeed); // TODO drop with IE8 drop if($('html').hasClass('ie8')) { this.$el.find('#linkPassText').attr('placeholder', null); this.$el.find('#linkPassText').val(''); } this.$el.find('#linkPassText').focus(); } } else { this.model.removeLinkShare(); } }, onLinkTextClick: function() { this.focus(); this.select(); }, onShowPasswordClick: function() { this.$el.find('#linkPass').slideToggle(OC.menuSpeed); if(!this.$el.find('#showPassword').is(':checked')) { this.model.setPassword(''); this.model.saveLinkShare(); } else { this.$el.find('#linkPassText').focus(); } }, onPasswordEntered: function() { var self = this; var $loading = this.$el.find('#linkPass .icon-loading-small'); if (!$loading.hasClass('hidden')) { // still in process return; } var $input = this.$el.find('#linkPassText'); $input.removeClass('error'); var password = $input.val(); if(password === '') { return; } $loading .removeClass('hidden') .addClass('inlineblock'); this.model.setPassword(password); this.model.saveLinkShare({}, { error: function(model, msg) { $loading.removeClass('inlineblock').addClass('hidden'); $input.addClass('error'); $input.attr('title', msg); $input.tooltip({placement: 'bottom', trigger: 'manual'}); $input.tooltip('show'); } }); }, onAllowPublicUploadChange: function() { this.$el.find('#sharingDialogAllowPublicUpload') .siblings('.icon-loading-small').removeClass('hidden').addClass('inlineblock'); this.model.setPublicUpload(this.$el.find('#sharingDialogAllowPublicUpload').is(':checked')); this.model.saveLinkShare(); }, _onEmailPrivateLink: function(event) { event.preventDefault(); var $emailField = this.$el.find('#email'); var $emailButton = this.$el.find('#emailButton'); var email = this.$el.find('#email').val(); if (email !== '') { $emailField.prop('disabled', true); $emailButton.prop('disabled', true); $emailField.val(t('core', 'Sending ...')); this.model.sendEmailPrivateLink(email).then(function() { $emailField.css('font-weight', 'bold').val(t('core','Email sent')); setTimeout(function() { $emailField.css('font-weight', 'normal').val(''); $emailField.prop('disabled', false); $emailButton.prop('disabled', false); }, 2000); }); } return false; }, render: function() { var linkShareTemplate = this.template(); if( !this.model.sharePermissionPossible() || !this.showLink || !this.configModel.isShareWithLinkAllowed()) { this.$el.html(linkShareTemplate({ shareAllowed: false, noSharingPlaceholder: t('core', 'Resharing is not allowed') })); return this; } var publicUpload = this.model.isFolder() && this.model.createPermissionPossible() && this.configModel.isPublicUploadEnabled(); var publicUploadChecked = ''; if(this.model.isPublicUploadAllowed()) { publicUploadChecked = 'checked="checked"'; } var isLinkShare = this.model.get('linkShare').isLinkShare; var isPasswordSet = !!this.model.get('linkShare').password; var showPasswordCheckBox = isLinkShare && ( !this.configModel.get('enforcePasswordForPublicLink') || !this.model.get('linkShare').password); this.$el.html(linkShareTemplate({ shareAllowed: true, isLinkShare: isLinkShare, shareLinkURL: this.model.get('linkShare').link, linkShareLabel: t('core', 'Share link'), urlLabel: t('core', 'Link'), enablePasswordLabel: t('core', 'Password protect'), passwordLabel: t('core', 'Password'), passwordPlaceholder: isPasswordSet ? '**********' : t('core', 'Choose a password for the public link'), isPasswordSet: isPasswordSet, showPasswordCheckBox: showPasswordCheckBox, publicUpload: publicUpload && isLinkShare, publicUploadChecked: publicUploadChecked, publicUploadLabel: t('core', 'Allow editing'), mailPublicNotificationEnabled: isLinkShare && this.configModel.isMailPublicNotificationEnabled(), mailPrivatePlaceholder: t('core', 'Email link to person'), mailButtonText: t('core', 'Send') })); // TODO: move this to delegate events instead this.$el.find('#linkCheckbox').click(this.onLinkCheckBoxChange); this.$el.find('#sharingDialogAllowPublicUpload').change(this.onAllowPublicUploadChange); this.$el.find('#linkText').click(this.onLinkTextClick); this.$el.find('#showPassword').click(this.onShowPasswordClick); this.$el.find('#linkPassText').focusout(this.onPasswordEntered); var view = this; this.$el.find('#linkPassText').keyup(function(event) { if(event.keyCode == 13) { view.onPasswordEntered(); } }); var $emailField = this.$el.find('#email'); if (isLinkShare && $emailField.length !== 0) { $emailField.autocomplete({ minLength: 1, source: function (search, response) { $.get( OC.generateUrl('core/ajax/share.php'), { fetch: 'getShareWithEmail', search: search.term }, function(result) { if (result.status == 'success' && result.data.length > 0) { response(result.data); } }); }, select: function( event, item ) { $emailField.val(item.item.email); return false; } }) .data("ui-autocomplete")._renderItem = function( ul, item ) { return $('
  • ') .append('' + escapeHTML(item.displayname) + "
    " + escapeHTML(item.email) + '
    ' ) .appendTo( ul ); }; } this.delegateEvents(); return this; }, /** * @returns {Function} from Handlebars * @private */ template: function () { if (!this._template) { this._template = Handlebars.compile(TEMPLATE); } return this._template; } }); OC.Share.ShareDialogLinkShareView = ShareDialogLinkShareView; })();