summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2016-02-17 10:59:03 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2016-02-17 10:59:03 +0100
commit92e5160003def4d13d75c3fd755b1753a821a6ce (patch)
treeeb77911be408e2055344a412a23c9b7204edca96 /core
parent9e415a956af39692e470fab5b48ffaa787ffe3f5 (diff)
parenta9a3947e6177cc8f1e379e55453bf0d54ac0b01c (diff)
downloadnextcloud-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.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 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() {