summaryrefslogtreecommitdiffstats
path: root/core/js/sharedialogview.js
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@owncloud.com>2015-08-21 15:40:50 +0200
committerVincent Petry <pvince81@owncloud.com>2015-09-16 07:23:26 +0200
commitf9c232c4ce16b101fce233f1f20e0cafc7e4d1fa (patch)
tree9924799f1fcc7bef0683ed19211aa9d3f5a17085 /core/js/sharedialogview.js
parent277b786886de7979fea308595e4cf658e85aacf7 (diff)
downloadnextcloud-server-f9c232c4ce16b101fce233f1f20e0cafc7e4d1fa.tar.gz
nextcloud-server-f9c232c4ce16b101fce233f1f20e0cafc7e4d1fa.zip
split off linkShareView
Diffstat (limited to 'core/js/sharedialogview.js')
-rw-r--r--core/js/sharedialogview.js94
1 files changed, 14 insertions, 80 deletions
diff --git a/core/js/sharedialogview.js b/core/js/sharedialogview.js
index 67017778632..cc9590815a7 100644
--- a/core/js/sharedialogview.js
+++ b/core/js/sharedialogview.js
@@ -25,7 +25,7 @@
'<ul id="shareWithList">' +
'</ul>' +
'{{#if shareAllowed}}' +
- '{{{linkShare}}}' +
+ '<div class="linkShare"></div>' +
'{{else}}' +
'{{{noSharing}}}' +
'{{/if}}' +
@@ -36,35 +36,6 @@
'<a target="_blank" class="icon-info svg shareWithRemoteInfo hasTooltip" href="{{docLink}}" ' +
'title="{{tooltip}}"></a>';
- var TEMPLATE_LINK_SHARE =
- '<div id="link" class="linkShare">' +
- ' <span class="icon-loading-small hidden"></span>' +
- ' <input type="checkbox" name="linkCheckbox" id="linkCheckbox" value="1" /><label for="linkCheckbox">{{linkShareLabel}}</label>' +
- ' <br />' +
- ' <label for="linkText" class="hidden-visually">{{urlLabel}}</label>' +
- ' <input id="linkText" type="text" readonly="readonly" />' +
- ' <input type="checkbox" name="showPassword" id="showPassword" value="1" class="hidden" /><label for="showPassword" class="hidden-visually">{{enablePasswordLabel}}</label>' +
- ' <div id="linkPass">' +
- ' <label for="linkPassText" class="hidden-visually">{{passwordLabel}}</label>' +
- ' <input id="linkPassText" type="password" placeholder="passwordPlaceholder" />' +
- ' <span class="icon-loading-small hidden"></span>' +
- ' </div>' +
- ' {{#if publicUpload}}' +
- ' <div id="allowPublicUploadWrapper" class="hidden">' +
- ' <span class="icon-loading-small hidden"></span>' +
- ' <input type="checkbox" value="1" name="allowPublicUpload" id="sharingDialogAllowPublicUpload" {{{publicUploadChecked}}} />' +
- ' <label for="sharingDialogAllowPublicUpload">{{publicUploadLabel}}</label>' +
- ' </div>' +
- ' {{/if}}' +
- ' {{#if mailPublicNotificationEnabled}}' +
- ' <form id="emailPrivateLink">' +
- ' <input id="email" class="hidden" value="" placeholder="{{mailPrivatePlaceholder}}" type="text" />' +
- ' <input id="emailButton" class="hidden" type="submit" value="{{mailButtonText}}" />' +
- ' </form>' +
- ' {{/if}}' +
- '</div>'
- ;
-
var TEMPLATE_NO_SHARING =
'<input id="shareWith" type="text" placeholder="{{placeholder}}" disabled="disabled"/>'
;
@@ -105,6 +76,9 @@
/** @type {object} **/
resharerInfoView: undefined,
+ /** @type {object} **/
+ linkShareView: undefined,
+
initialize: function(options) {
var view = this;
this.model.on('change', function() {
@@ -130,6 +104,10 @@
? new OC.Share.ShareDialogResharerInfoView(subViewOptions)
: options.resharerInfoView;
+ this.linkShareView = _.isUndefined(options.linkShareView)
+ ? new OC.Share.ShareDialogLinkShareView(subViewOptions)
+ : options.linkShareView;
+
},
render: function() {
@@ -139,7 +117,6 @@
shareLabel: t('core', 'Share'),
sharePlaceholder: this._renderSharePlaceholderPart(),
remoteShareInfo: this._renderRemoteShareInfoPart(),
- linkShare: this._renderLinkSharePart(),
shareAllowed: this.model.hasSharePermission(),
noSharing: this._renderNoSharing(),
expiration: this._renderExpirationPart()
@@ -148,6 +125,11 @@
this.resharerInfoView.$el = this.$el.find('.resharerInfo');
this.resharerInfoView.render();
+ if(this.model.hasSharePermission()) {
+ this.linkShareView.$el = this.$el.find('.linkShare');
+ this.linkShareView.render();
+ }
+
this.$el.find('.hasTooltip').tooltip();
if(this.configModel.areAvatarsEnabled()) {
this.$el.find('.avatar').avatar(this.model.getReshareOwner, 32);
@@ -164,6 +146,7 @@
*/
setShowLink: function(showLink) {
this._showLink = (typeof showLink === 'boolean') ? showLink : true;
+ this.linkShareView.showLink = this._showLink;
},
_renderRemoteShareInfoPart: function() {
@@ -179,41 +162,6 @@
return remoteShareInfo;
},
- _renderLinkSharePart: function() {
- var linkShare = '';
- if( this.model.hasSharePermission()
- && this._showLink
- && this.configModel.isShareWithLinkAllowed())
- {
- var linkShareTemplate = this._getLinkShareTemplate();
-
- var publicUpload =
- this.model.isFolder()
- && this.model.hasCreatePermission()
- && this.configModel.isPublicUploadEnabled();
-
- var publicUploadChecked = '';
- if(this.model.isPublicUploadAllowed) {
- publicUploadChecked = 'checked="checked"';
- }
-
- linkShare = linkShareTemplate({
- linkShareLabel: t('core', 'Share link'),
- urlLabel: t('core', 'Link'),
- enablePasswordLabel: t('core', 'Password protect'),
- passwordLabel: t('core', 'Password'),
- passwordPlaceholder: t('core', 'Choose a password for the public link'),
- publicUpload: publicUpload,
- publicUploadChecked: publicUploadChecked,
- publicUploadLabel: t('core', 'Allow editing'),
- mailPublicNotificationEnabled: this.configModel.isMailPublicNotificationEnabled(),
- mailPrivatePlaceholder: t('core', 'Email link to person'),
- mailButtonText: t('core', 'Send')
- });
- }
- return linkShare;
- },
-
_renderSharePlaceholderPart: function () {
var sharePlaceholder = t('core', 'Share with users or groups …');
if (this.configModel.isRemoteShareAllowed()) {
@@ -278,20 +226,6 @@
*/
_getRemoteShareInfoTemplate: function() {
return this._getTemplate('remoteShareInfo', TEMPLATE_REMOTE_SHARE_INFO);
- },
-
- /**
- * returns the info template for link sharing
- *
- * @returns {Function}
- * @private
- */
- _getLinkShareTemplate: function() {
- return this._getTemplate('linkShare', TEMPLATE_LINK_SHARE);
- },
-
- _getReshareTemplate: function() {
- return this._getTemplate('reshare', TEMPLATE_RESHARER_INFO);
}
});