diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2016-02-17 10:59:03 +0100 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2016-02-17 10:59:03 +0100 |
commit | 92e5160003def4d13d75c3fd755b1753a821a6ce (patch) | |
tree | eb77911be408e2055344a412a23c9b7204edca96 /core | |
parent | 9e415a956af39692e470fab5b48ffaa787ffe3f5 (diff) | |
parent | a9a3947e6177cc8f1e379e55453bf0d54ac0b01c (diff) | |
download | nextcloud-server-92e5160003def4d13d75c3fd755b1753a821a6ce.tar.gz nextcloud-server-92e5160003def4d13d75c3fd755b1753a821a6ce.zip |
Merge pull request #22452 from owncloud/fix_22441
Unlock sharee input field when sharing fails
Diffstat (limited to 'core')
-rw-r--r-- | core/js/sharedialogview.js | 6 | ||||
-rw-r--r-- | core/js/tests/specs/sharedialogviewSpec.js | 37 |
2 files changed, 43 insertions, 0 deletions
diff --git a/core/js/sharedialogview.js b/core/js/sharedialogview.js index f5ba3639e06..fbb3a915810 100644 --- a/core/js/sharedialogview.js +++ b/core/js/sharedialogview.js @@ -281,6 +281,12 @@ .attr('disabled', false); $loading.addClass('hidden') .removeClass('inlineblock'); + }, error: function(obj, msg) { + OC.Notification.showTemporary(msg); + $(e.target).attr('disabled', false) + .autocomplete('search', $(e.target).val()); + $loading.addClass('hidden') + .removeClass('inlineblock'); }}); }, diff --git a/core/js/tests/specs/sharedialogviewSpec.js b/core/js/tests/specs/sharedialogviewSpec.js index 3a94379789a..23214a7fe86 100644 --- a/core/js/tests/specs/sharedialogviewSpec.js +++ b/core/js/tests/specs/sharedialogviewSpec.js @@ -990,6 +990,43 @@ describe('OC.Share.ShareDialogView', function() { addShareStub.restore(); }); + + it('calls addShare after selection and fail to share', function() { + dialog.render(); + + var shareWith = $('.shareWithField')[0]; + var $shareWith = $(shareWith); + var addShareStub = sinon.stub(shareModel, 'addShare'); + var autocompleteOptions = autocompleteStub.getCall(0).args[0]; + autocompleteOptions.select(new $.Event('select', {target: shareWith}), { + item: { + label: 'User Two', + value: { + shareType: OC.Share.SHARE_TYPE_USER, + shareWith: 'user2' + } + } + }); + + expect(addShareStub.calledOnce).toEqual(true); + expect(addShareStub.firstCall.args[0]).toEqual({ + shareType: OC.Share.SHARE_TYPE_USER, + shareWith: 'user2' + }); + + //Input is locked + expect($shareWith.val()).toEqual('User Two'); + expect($shareWith.attr('disabled')).toEqual('disabled'); + + //Callback is called + addShareStub.firstCall.args[1].error(); + + //Input is unlocked + expect($shareWith.val()).toEqual('User Two'); + expect($shareWith.attr('disabled')).toEqual(undefined); + + addShareStub.restore(); + }); }); describe('reshare permissions', function() { it('does not show sharing options when sharing not allowed', function() { |