aboutsummaryrefslogtreecommitdiffstats
path: root/core/js
diff options
context:
space:
mode:
authorRoeland Jago Douma <rullzer@owncloud.com>2016-02-16 19:40:44 +0100
committerRoeland Jago Douma <rullzer@owncloud.com>2016-02-17 09:21:12 +0100
commite1fd86ccb6a7b4e3d705829a5eb6c27b5085b4cd (patch)
tree1cb002a0c2d0b329f454762b418db6f39e478bac /core/js
parentfe29feae9a1ee759e09091941e3bcf96f72e3f21 (diff)
downloadnextcloud-server-e1fd86ccb6a7b4e3d705829a5eb6c27b5085b4cd.tar.gz
nextcloud-server-e1fd86ccb6a7b4e3d705829a5eb6c27b5085b4cd.zip
Unlock sharee input field when sharing fails
Fixes #22441 When addShares fails (for whatever reason) we should unlock the sharee input field so the user does not have to reload the page.
Diffstat (limited to 'core/js')
-rw-r--r--core/js/sharedialogview.js6
-rw-r--r--core/js/tests/specs/sharedialogviewSpec.js37
2 files changed, 43 insertions, 0 deletions
diff --git a/core/js/sharedialogview.js b/core/js/sharedialogview.js
index e7435877cb3..b406299a075 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).val('')
+ .attr('disabled', false);
+ $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() {