aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2015-10-26 15:35:11 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2015-10-26 15:35:11 +0100
commitcbd31e4fa9e7d4e469f2f3fc955e9b8e76f8628e (patch)
tree84a46fb0aaf6b11e8ac14a28b21cf4442cd66623
parent5181e5c29a1037137e8435c46c3a9075fe858a21 (diff)
parentc64fb46fbf1deab67ffc958584c04357582f8a28 (diff)
downloadnextcloud-server-cbd31e4fa9e7d4e469f2f3fc955e9b8e76f8628e.tar.gz
nextcloud-server-cbd31e4fa9e7d4e469f2f3fc955e9b8e76f8628e.zip
Merge pull request #20046 from owncloud/share-clicklinkfocus
Fix share link focus on click
-rw-r--r--core/js/sharedialoglinkshareview.js5
-rw-r--r--core/js/tests/specs/sharedialogviewSpec.js23
2 files changed, 26 insertions, 2 deletions
diff --git a/core/js/sharedialoglinkshareview.js b/core/js/sharedialoglinkshareview.js
index beb8b01c8a8..74afbc9fe02 100644
--- a/core/js/sharedialoglinkshareview.js
+++ b/core/js/sharedialoglinkshareview.js
@@ -151,8 +151,9 @@
},
onLinkTextClick: function() {
- this.focus();
- this.select();
+ var $el = this.$el.find('.linkText');
+ $el.focus();
+ $el.select();
},
onShowPasswordClick: function() {
diff --git a/core/js/tests/specs/sharedialogviewSpec.js b/core/js/tests/specs/sharedialogviewSpec.js
index 1c05bf21968..a557ff6f03b 100644
--- a/core/js/tests/specs/sharedialogviewSpec.js
+++ b/core/js/tests/specs/sharedialogviewSpec.js
@@ -237,6 +237,29 @@ describe('OC.Share.ShareDialogView', function() {
expect(dialog.$el.find('.linkCheckbox').prop('checked')).toEqual(true);
expect(dialog.$el.find('.linkText').val()).toEqual(link);
});
+ it('autofocus link text when clicked', function() {
+ $('#allowShareWithLink').val('yes');
+
+ dialog.render();
+
+ // Toggle linkshare
+ dialog.$el.find('.linkCheckbox').click();
+ fakeServer.requests[0].respond(
+ 200,
+ { 'Content-Type': 'application/json' },
+ JSON.stringify({data: {token: 'xyz'}, status: 'success'})
+ );
+
+ var focusStub = sinon.stub($.fn, 'focus');
+ var selectStub = sinon.stub($.fn, 'select');
+ dialog.$el.find('.linkText').click();
+
+ expect(focusStub.calledOnce).toEqual(true);
+ expect(selectStub.calledOnce).toEqual(true);
+
+ focusStub.restore();
+ selectStub.restore();
+ });
describe('password', function() {
var slideToggleStub;