diff options
author | Roeland Jago Douma <roeland@famdouma.nl> | 2015-02-24 21:46:24 +0100 |
---|---|---|
committer | Roeland Jago Douma <roeland@famdouma.nl> | 2015-03-03 20:57:50 +0100 |
commit | c9272be0b9963eb358d0aa6e7b728d37e6caa7d6 (patch) | |
tree | 20de99d452ed096ea59a6b8f31fca5c583046f93 /core/js | |
parent | e271fa3ee8b1ce13940a33ec7266cee345323e2d (diff) | |
download | nextcloud-server-c9272be0b9963eb358d0aa6e7b728d37e6caa7d6.tar.gz nextcloud-server-c9272be0b9963eb358d0aa6e7b728d37e6caa7d6.zip |
Avatars in share dialog fixes
* Avatar for "xxxx share with you..." to the left
* Avatars for groups and remote shares (use default placeholder)
* Modified and added unit tests
* Use the same css for all the avatars in the dropdown
Diffstat (limited to 'core/js')
-rw-r--r-- | core/js/core.json | 6 | ||||
-rw-r--r-- | core/js/share.js | 36 | ||||
-rw-r--r-- | core/js/tests/specs/shareSpec.js | 52 |
3 files changed, 63 insertions, 31 deletions
diff --git a/core/js/core.json b/core/js/core.json index 7f3b313e898..44dea370279 100644 --- a/core/js/core.json +++ b/core/js/core.json @@ -5,12 +5,14 @@ "jquery-ui/ui/jquery-ui.custom.js", "underscore/underscore.js", "moment/min/moment-with-locales.js", - "handlebars/handlebars.js" + "handlebars/handlebars.js", + "blueimp-md5/js/md5.js" ], "libraries": [ "jquery-showpassword.js", "jquery-tipsy.js", - "jquery.avatar.js" + "jquery.avatar.js", + "placeholder.js" ], "modules": [ "compatibility.js", diff --git a/core/js/share.js b/core/js/share.js index 2370916e8be..8804db12a08 100644 --- a/core/js/share.js +++ b/core/js/share.js @@ -357,20 +357,17 @@ OC.Share={ var dropDownEl; var html = '<div id="dropdown" class="drop shareDropDown" data-item-type="'+itemType+'" data-item-source="'+itemSource+'">'; if (data !== false && data.reshare !== false && data.reshare.uid_owner !== undefined) { + html += '<span class="reshare">'; + if (oc_config.enable_avatars === true) { + html += '<div class="avatar"></div> '; + } + if (data.reshare.share_type == OC.Share.SHARE_TYPE_GROUP) { - html += '<span class="reshare">'+t('core', 'Shared with you and the group {group} by {owner}', {group: data.reshare.share_with, owner: data.reshare.displayname_owner}); - if (oc_config.enable_avatars === true) { - html += ' <div id="avatar-share-owner" style="display: inline-block"></div>'; - } - html += '</span>'; + html += t('core', 'Shared with you and the group {group} by {owner}', {group: data.reshare.share_with, owner: data.reshare.displayname_owner}); } else { - html += '<span class="reshare">'+t('core', 'Shared with you by {owner}', {owner: data.reshare.displayname_owner}); - if (oc_config.enable_avatars === true) { - html += ' <div id="avatar-share-owner" style="display: inline-block"></div>'; - } - html += '</span>'; + html += t('core', 'Shared with you by {owner}', {owner: data.reshare.displayname_owner}); } - html += '<br />'; + html += '</span><br />'; // reduce possible permissions to what the original share allowed possiblePermissions = possiblePermissions & data.reshare.permissions; } @@ -448,7 +445,7 @@ OC.Share={ //Get owner avatars if (oc_config.enable_avatars === true && data !== false && data.reshare !== false && data.reshare.uid_owner !== undefined) { - $('#avatar-share-owner').avatar(data.reshare.uid_owner, 32); + dropDownEl.find(".avatar").avatar(data.reshare.uid_owner, 32); } // Reset item shares @@ -665,11 +662,7 @@ OC.Share={ var showCrudsButton; html += '<a href="#" class="unshare"><img class="svg" alt="'+t('core', 'Unshare')+'" title="'+t('core', 'Unshare')+'" src="'+OC.imagePath('core', 'actions/delete')+'"/></a>'; if (oc_config.enable_avatars === true) { - if (shareType === OC.Share.SHARE_TYPE_USER) { - html += '<div data-user="' + escapeHTML(shareWith) + '" class="avatar"></div>'; - } else { - html += '<div class="avatar" style="padding-right: 32px"></div>'; - } + html += '<div class="avatar"></div>'; } html += '<span class="username">' + escapeHTML(shareWithDisplayName) + '</span>'; var mailNotificationEnabled = $('input:hidden[name=mailNotificationEnabled]').val(); @@ -702,8 +695,13 @@ OC.Share={ html += '</div>'; html += '</li>'; html = $(html).appendTo('#shareWithList'); - if (oc_config.enable_avatars === true && shareType === OC.Share.SHARE_TYPE_USER) { - $('.avatar[data-user="' + escapeHTML(shareWith) + '"]').avatar(escapeHTML(shareWith), 32); + if (oc_config.enable_avatars === true) { + if (shareType === OC.Share.SHARE_TYPE_USER) { + html.find('.avatar').avatar(escapeHTML(shareWith), 32); + } else { + //Add sharetype to generate different seed if there is a group and use with the same name + html.find('.avatar').imageplaceholder(escapeHTML(shareWith) + ' ' + shareType); + } } // insert cruds button into last label element var lastLabel = html.find('>label:last'); diff --git a/core/js/tests/specs/shareSpec.js b/core/js/tests/specs/shareSpec.js index bcdc1df3d37..4a2da645029 100644 --- a/core/js/tests/specs/shareSpec.js +++ b/core/js/tests/specs/shareSpec.js @@ -28,6 +28,7 @@ describe('OC.Share tests', function() { var autocompleteStub; var oldEnableAvatars; var avatarStub; + var placeholderStub; beforeEach(function() { $('#testArea').append($('<div id="shareContainer"></div>')); @@ -60,6 +61,7 @@ describe('OC.Share tests', function() { oldEnableAvatars = oc_config.enable_avatars; oc_config.enable_avatars = false; avatarStub = sinon.stub($.fn, 'avatar'); + placeholderStub = sinon.stub($.fn, 'imageplaceholder'); }); afterEach(function() { /* jshint camelcase:false */ @@ -68,6 +70,7 @@ describe('OC.Share tests', function() { autocompleteStub.restore(); avatarStub.restore(); + placeholderStub.restore(); oc_config.enable_avatars = oldEnableAvatars; $('#dropdown').remove(); }); @@ -416,7 +419,12 @@ describe('OC.Share tests', function() { describe('check for avatar', function() { beforeEach(function() { loadItemStub.returns({ - reshare: [], + reshare: { + share_type: OC.Share.SHARE_TYPE_USER, + uid_owner: 'owner', + displayname_owner: 'Owner', + permissions: 31 + }, shares: [{ id: 100, item_source: 123, @@ -431,6 +439,14 @@ describe('OC.Share tests', function() { share_type: OC.Share.SHARE_TYPE_GROUP, share_with: 'group', share_with_displayname: 'group' + },{ + id: 102, + item_source: 123, + permissions: 31, + share_type: OC.Share.SHARE_TYPE_REMOTE, + share_with: 'foo@bar.com/baz', + share_with_displayname: 'foo@bar.com/baz' + }] }); }); @@ -452,21 +468,35 @@ describe('OC.Share tests', function() { oc_config.enable_avatars = false; }); - it('test correct function call', function() { - expect(avatarStub.calledOnce).toEqual(true); - var args = avatarStub.getCall(0).args; - + it('test correct function calls', function() { + expect(avatarStub.calledTwice).toEqual(true); + expect(placeholderStub.calledTwice).toEqual(true); + expect($('#shareWithList').children().length).toEqual(3); + expect($('.avatar').length).toEqual(4); + }); - expect($('#shareWithList').children().length).toEqual(2); + it('test avatar owner', function() { + var args = avatarStub.getCall(0).args; + expect(args.length).toEqual(2); + expect(args[0]).toEqual('owner'); + }); - expect($('.avatar[data-user="user1"]').length).toEqual(1); + it('test avatar user', function() { + var args = avatarStub.getCall(1).args; expect(args.length).toEqual(2); expect(args[0]).toEqual('user1'); }); - it('test no avatar for groups', function() { - expect($('#shareWithList').children().length).toEqual(2); - expect($('#shareWithList li:nth-child(2) .avatar').attr('id')).not.toBeDefined(); + it('test avatar for groups', function() { + var args = placeholderStub.getCall(0).args; + expect(args.length).toEqual(1); + expect(args[0]).toEqual('group ' + OC.Share.SHARE_TYPE_GROUP); + }); + + it('test avatar for remotes', function() { + var args = placeholderStub.getCall(1).args; + expect(args.length).toEqual(1); + expect(args[0]).toEqual('foo@bar.com/baz ' + OC.Share.SHARE_TYPE_REMOTE); }); }); @@ -484,6 +514,8 @@ describe('OC.Share tests', function() { it('no avatar classes', function() { expect($('.avatar').length).toEqual(0); + expect(avatarStub.callCount).toEqual(0); + expect(placeholderStub.callCount).toEqual(0); }); }); }); |