mirror of
				https://github.com/telekom-security/tpotce.git
				synced 2025-10-25 01:34:43 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			319 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			319 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| /*
 | |
|  * 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 =
 | |
| 			'<ul id="shareWithList" class="shareWithList">' +
 | |
| 			'{{#each sharees}}' +
 | |
| 			'<li data-share-id="{{shareId}}" data-share-type="{{shareType}}" data-share-with="{{shareWith}}">' +
 | |
| 			'<a href="#" class="unshare"><span class="icon-loading-small hidden"></span><span class="icon icon-delete"></span><span class="hidden-visually">{{unshareLabel}}</span></a>' +
 | |
| 			'{{#if avatarEnabled}}' +
 | |
| 			'<div class="avatar {{#if modSeed}}imageplaceholderseed{{/if}}" data-username="{{shareWith}}" {{#if modSeed}}data-seed="{{shareWith}} {{shareType}}"{{/if}}></div>' +
 | |
| 			'{{/if}}' +
 | |
| 			'<span class="has-tooltip username" title="{{shareWith}}">{{shareWithDisplayName}}</span>' +
 | |
| 			'{{#if shareWithAdditionalInfo}}' +
 | |
| 			'<span class="has-tooltip user-additional-info">({{shareWithAdditionalInfo}})</span>' +
 | |
| 			'{{/if}}' +
 | |
| 			'{{#if mailNotificationEnabled}}  {{#unless isRemoteShare}}' +
 | |
| 			'<span class="shareOption">' +
 | |
| 			'{{#unless wasMailSent}}' +
 | |
| 			'<span class="mailNotificationSpinner icon-loading-small hidden"></span>' +
 | |
| 			'<input id="mail-{{cid}}-{{shareWith}}" type="button" name="mailNotification" value="{{notifyByMailLabel}}" class="mailNotification checkbox" />' +
 | |
| 			'{{/unless}}' +
 | |
| 			'</span>' +
 | |
| 			'{{/unless}} {{/if}}' +
 | |
| 			'{{#if isResharingAllowed}} {{#if sharePermissionPossible}}' +
 | |
| 			'<span class="shareOption">' +
 | |
| 			'<input id="canShare-{{cid}}-{{shareWith}}" type="checkbox" name="share" class="permissions checkbox" {{#if hasSharePermission}}checked="checked"{{/if}} data-permissions="{{sharePermission}}" />' +
 | |
| 			'<label for="canShare-{{cid}}-{{shareWith}}">{{canShareLabel}}</label>' +
 | |
| 			'</span>' +
 | |
| 			'{{/if}} {{/if}}' +
 | |
| 			'{{#if editPermissionPossible}}' +
 | |
| 			'<span class="shareOption">' +
 | |
| 			'<input id="canEdit-{{cid}}-{{shareWith}}" type="checkbox" name="edit" class="permissions checkbox" {{#if hasEditPermission}}checked="checked"{{/if}} />' +
 | |
| 			'<label for="canEdit-{{cid}}-{{shareWith}}">{{canEditLabel}}</label>' +
 | |
| 			'<a href="#" class="showCruds"><img alt="{{crudsLabel}}" src="{{triangleSImage}}"/></a>' +
 | |
| 			'</span>' +
 | |
| 			'{{/if}}' +
 | |
| 			'<div class="cruds hidden">' +
 | |
| 			'{{#if createPermissionPossible}}' +
 | |
| 			'<span class="shareOption">' +
 | |
| 			'<input id="canCreate-{{cid}}-{{shareWith}}" type="checkbox" name="create" class="permissions checkbox" {{#if hasCreatePermission}}checked="checked"{{/if}} data-permissions="{{createPermission}}"/>' +
 | |
| 			'<label for="canCreate-{{cid}}-{{shareWith}}">{{createPermissionLabel}}</label>' +
 | |
| 			'</span>' +
 | |
| 			'{{/if}}' +
 | |
| 			'{{#if updatePermissionPossible}}' +
 | |
| 			'<span class="shareOption">' +
 | |
| 			'<input id="canUpdate-{{cid}}-{{shareWith}}" type="checkbox" name="update" class="permissions checkbox" {{#if hasUpdatePermission}}checked="checked"{{/if}} data-permissions="{{updatePermission}}"/>' +
 | |
| 			'<label for="canUpdate-{{cid}}-{{shareWith}}">{{updatePermissionLabel}}</label>' +
 | |
| 			'</span>' +
 | |
| 			'{{/if}}' +
 | |
| 			'{{#if deletePermissionPossible}}' +
 | |
| 			'<span class="shareOption">' +
 | |
| 			'<input id="canDelete-{{cid}}-{{shareWith}}" type="checkbox" name="delete" class="permissions checkbox" {{#if hasDeletePermission}}checked="checked"{{/if}} data-permissions="{{deletePermission}}"/>' +
 | |
| 			'<label for="canDelete-{{cid}}-{{shareWith}}">{{deletePermissionLabel}}</label>' +
 | |
| 			'</span>' +
 | |
| 			'{{/if}}' +
 | |
| 			'</div>' +
 | |
| 			'</li>' +
 | |
| 			'{{/each}}' +
 | |
| 			'</ul>'
 | |
| 		;
 | |
| 
 | |
| 	/**
 | |
| 	 * @class OCA.Share.ShareDialogShareeListView
 | |
| 	 * @member {OC.Share.ShareItemModel} model
 | |
| 	 * @member {jQuery} $el
 | |
| 	 * @memberof OCA.Sharing
 | |
| 	 * @classdesc
 | |
| 	 *
 | |
| 	 * Represents the sharee list part in the GUI of the share dialogue
 | |
| 	 *
 | |
| 	 */
 | |
| 	var ShareDialogShareeListView = OC.Backbone.View.extend({
 | |
| 		/** @type {string} **/
 | |
| 		id: 'shareDialogLinkShare',
 | |
| 
 | |
| 		/** @type {OC.Share.ShareConfigModel} **/
 | |
| 		configModel: undefined,
 | |
| 
 | |
| 		/** @type {Function} **/
 | |
| 		_template: undefined,
 | |
| 
 | |
| 		events: {
 | |
| 			'click .unshare': 'onUnshare',
 | |
| 			'click .permissions': 'onPermissionChange',
 | |
| 			'click .showCruds': 'onCrudsToggle',
 | |
| 			'click .mailNotification': 'onSendMailNotification'
 | |
| 		},
 | |
| 
 | |
| 		initialize: function(options) {
 | |
| 			if(!_.isUndefined(options.configModel)) {
 | |
| 				this.configModel = options.configModel;
 | |
| 			} else {
 | |
| 				throw 'missing OC.Share.ShareConfigModel';
 | |
| 			}
 | |
| 
 | |
| 			var view = this;
 | |
| 			this.model.on('change:shares', function() {
 | |
| 				view.render();
 | |
| 			});
 | |
| 		},
 | |
| 
 | |
| 		/**
 | |
| 		 *
 | |
| 		 * @param {OC.Share.Types.ShareInfo} shareInfo
 | |
| 		 * @returns {object}
 | |
| 		 */
 | |
| 		getShareeObject: function(shareIndex) {
 | |
| 			var shareWith = this.model.getShareWith(shareIndex);
 | |
| 			var shareWithDisplayName = this.model.getShareWithDisplayName(shareIndex);
 | |
| 			var shareType = this.model.getShareType(shareIndex);
 | |
| 			var shareWithAdditionalInfo = this.model.getShareWithAdditionalInfo(shareIndex);
 | |
| 
 | |
| 			var hasPermissionOverride = {};
 | |
| 			if (shareType === OC.Share.SHARE_TYPE_GROUP) {
 | |
| 				shareWithDisplayName = shareWithDisplayName + " (" + t('core', 'group') + ')';
 | |
| 			} else if (shareType === OC.Share.SHARE_TYPE_REMOTE) {
 | |
| 				shareWithDisplayName = shareWithDisplayName + " (" + t('core', 'federated') + ')';
 | |
| 			}
 | |
| 
 | |
| 			return _.extend(hasPermissionOverride, {
 | |
| 				cid: this.cid,
 | |
| 				hasSharePermission: this.model.hasSharePermission(shareIndex),
 | |
| 				hasEditPermission: this.model.hasEditPermission(shareIndex),
 | |
| 				hasCreatePermission: this.model.hasCreatePermission(shareIndex),
 | |
| 				hasUpdatePermission: this.model.hasUpdatePermission(shareIndex),
 | |
| 				hasDeletePermission: this.model.hasDeletePermission(shareIndex),
 | |
| 				wasMailSent: this.model.notificationMailWasSent(shareIndex),
 | |
| 				shareWith: shareWith,
 | |
| 				shareWithDisplayName: shareWithDisplayName,
 | |
| 				shareWithAdditionalInfo: shareWithAdditionalInfo,
 | |
| 				shareType: shareType,
 | |
| 				shareId: this.model.get('shares')[shareIndex].id,
 | |
| 				modSeed: shareType !== OC.Share.SHARE_TYPE_USER,
 | |
| 				isRemoteShare: shareType === OC.Share.SHARE_TYPE_REMOTE
 | |
| 			});
 | |
| 		},
 | |
| 
 | |
| 		getShareeList: function() {
 | |
| 			var universal = {
 | |
| 				avatarEnabled: this.configModel.areAvatarsEnabled(),
 | |
| 				mailNotificationEnabled: this.configModel.isMailNotificationEnabled(),
 | |
| 				notifyByMailLabel: t('core', 'notify by email'),
 | |
| 				unshareLabel: t('core', 'Unshare'),
 | |
| 				canShareLabel: t('core', 'can share'),
 | |
| 				canEditLabel: t('core', 'can edit'),
 | |
| 				createPermissionLabel: t('core', 'create'),
 | |
| 				updatePermissionLabel: t('core', 'change'),
 | |
| 				deletePermissionLabel: t('core', 'delete'),
 | |
| 				crudsLabel: t('core', 'access control'),
 | |
| 				triangleSImage: OC.imagePath('core', 'actions/triangle-s'),
 | |
| 				isResharingAllowed: this.configModel.get('isResharingAllowed'),
 | |
| 				sharePermissionPossible: this.model.sharePermissionPossible(),
 | |
| 				editPermissionPossible: this.model.editPermissionPossible(),
 | |
| 				createPermissionPossible: this.model.createPermissionPossible(),
 | |
| 				updatePermissionPossible: this.model.updatePermissionPossible(),
 | |
| 				deletePermissionPossible: this.model.deletePermissionPossible(),
 | |
| 				sharePermission: OC.PERMISSION_SHARE,
 | |
| 				createPermission: OC.PERMISSION_CREATE,
 | |
| 				updatePermission: OC.PERMISSION_UPDATE,
 | |
| 				deletePermission: OC.PERMISSION_DELETE
 | |
| 			};
 | |
| 
 | |
| 			if(!this.model.hasUserShares()) {
 | |
| 				return [];
 | |
| 			}
 | |
| 
 | |
| 			var shares = this.model.get('shares');
 | |
| 			var list = [];
 | |
| 			for(var index = 0; index < shares.length; index++) {
 | |
| 				// first empty {} is necessary, otherwise we get in trouble
 | |
| 				// with references
 | |
| 				list.push(_.extend({}, universal, this.getShareeObject(index)));
 | |
| 			}
 | |
| 
 | |
| 			return list;
 | |
| 		},
 | |
| 
 | |
| 		render: function() {
 | |
| 			this.$el.html(this.template({
 | |
| 				cid: this.cid,
 | |
| 				sharees: this.getShareeList()
 | |
| 			}));
 | |
| 
 | |
| 			if(this.configModel.areAvatarsEnabled()) {
 | |
| 				this.$el.find('.avatar').each(function() {
 | |
| 					var $this = $(this);
 | |
| 					if ($this.hasClass('imageplaceholderseed')) {
 | |
| 						$this.css({width: 32, height: 32});
 | |
| 						$this.imageplaceholder($this.data('seed'));
 | |
| 					} else {
 | |
| 						$this.avatar($this.data('username'), 32);
 | |
| 					}
 | |
| 				});
 | |
| 			}
 | |
| 
 | |
| 			this.$el.find('.has-tooltip').tooltip({
 | |
| 				placement: 'bottom'
 | |
| 			});
 | |
| 
 | |
| 			this.delegateEvents();
 | |
| 
 | |
| 			return this;
 | |
| 		},
 | |
| 
 | |
| 		/**
 | |
| 		 * @returns {Function} from Handlebars
 | |
| 		 * @private
 | |
| 		 */
 | |
| 		template: function (data) {
 | |
| 			if (!this._template) {
 | |
| 				this._template = Handlebars.compile(TEMPLATE);
 | |
| 			}
 | |
| 			return this._template(data);
 | |
| 		},
 | |
| 
 | |
| 		onUnshare: function(event) {
 | |
| 			var self = this;
 | |
| 			var $element = $(event.target);
 | |
| 			if (!$element.is('a')) {
 | |
| 				$element = $element.closest('a');
 | |
| 			}
 | |
| 
 | |
| 			var $loading = $element.find('.icon-loading-small').eq(0);
 | |
| 			if(!$loading.hasClass('hidden')) {
 | |
| 				// in process
 | |
| 				return false;
 | |
| 			}
 | |
| 			$loading.removeClass('hidden');
 | |
| 
 | |
| 			var $li = $element.closest('li');
 | |
| 
 | |
| 			var shareId = $li.data('share-id');
 | |
| 
 | |
| 			self.model.removeShare(shareId)
 | |
| 				.done(function() {
 | |
| 					$li.remove();
 | |
| 				})
 | |
| 				.fail(function() {
 | |
| 					$loading.addClass('hidden');
 | |
| 					OC.Notification.showTemporary(t('core', 'Could not unshare'));
 | |
| 				});
 | |
| 			return false;
 | |
| 		},
 | |
| 
 | |
| 		onPermissionChange: function(event) {
 | |
| 			var $element = $(event.target);
 | |
| 			var $li = $element.closest('li');
 | |
| 			var shareId = $li.data('share-id');
 | |
| 			var shareType = $li.data('share-type');
 | |
| 			var shareWith = $li.attr('data-share-with');
 | |
| 
 | |
| 			// adjust checkbox states
 | |
| 			var $checkboxes = $('.permissions', $li).not('input[name="edit"]').not('input[name="share"]');
 | |
| 			var checked;
 | |
| 			if ($element.attr('name') === 'edit') {
 | |
| 				checked = $element.is(':checked');
 | |
| 				// Check/uncheck Create, Update, and Delete checkboxes if Edit is checked/unck
 | |
| 				$($checkboxes).prop('checked', checked);
 | |
| 			} else {
 | |
| 				var numberChecked = $checkboxes.filter(':checked').length;
 | |
| 				checked = numberChecked > 0;
 | |
| 				$('input[name="edit"]', $li).prop('checked', checked);
 | |
| 			}
 | |
| 
 | |
| 			var permissions = OC.PERMISSION_READ;
 | |
| 			$('.permissions', $li).not('input[name="edit"]').filter(':checked').each(function(index, checkbox) {
 | |
| 				permissions |= $(checkbox).data('permissions');
 | |
| 			});
 | |
| 
 | |
| 			this.model.updateShare(shareId, {permissions: permissions});
 | |
| 		},
 | |
| 
 | |
| 		onCrudsToggle: function(event) {
 | |
| 			var $target = $(event.target);
 | |
| 			$target.closest('li').find('.cruds').toggleClass('hidden');
 | |
| 			return false;
 | |
| 		},
 | |
| 
 | |
| 		onSendMailNotification: function(event) {
 | |
| 			var $target = $(event.target);
 | |
| 			var $li = $(event.target).closest('li');
 | |
| 			var shareType = $li.data('share-type');
 | |
| 			var shareWith = $li.attr('data-share-with');
 | |
| 
 | |
| 			var $loading = $target.prev('.icon-loading-small');
 | |
| 
 | |
| 			$target.addClass('hidden');
 | |
| 			$loading.removeClass('hidden');
 | |
| 
 | |
| 			this.model.sendNotificationForShare(shareType, shareWith, true).then(function(result) {
 | |
| 				if (result.status === 'success') {
 | |
| 					OC.Notification.showTemporary(t('core', 'Email notification was sent!'));
 | |
| 					$target.remove();
 | |
| 				} else {
 | |
| 					// sending was successful but some users might not have any email address
 | |
| 					OC.dialogs.alert(t('core', result.data.message), t('core', 'Email notification not sent'));
 | |
| 				}
 | |
| 
 | |
| 				$target.removeClass('hidden');
 | |
| 				$loading.addClass('hidden');
 | |
| 			});
 | |
| 		}
 | |
| 	});
 | |
| 
 | |
| 	OC.Share.ShareDialogShareeListView = ShareDialogShareeListView;
 | |
| 
 | |
| })();
 | 
