Skip to content
This repository has been archived by the owner on Apr 12, 2024. It is now read-only.

ngMobile does not prevent ghost focus on form inputs after CSS transition #2810

Closed
damrbaby opened this issue May 28, 2013 · 10 comments
Closed

Comments

@damrbaby
Copy link
Contributor

Webkit based browsers synthesize mouse events roughly 300ms after the touchend event, which can cause form fields to undesirably gain focus after a CSS3 transition.

This issue has been addressed by fastclick: ftlabs/fastclick#27

My workaround is to disable and re-enable text inputs and textareas on $viewContentLoaded (not pretty):

$rootScope.$on '$viewContentLoaded', ->
  $('input[type=text], textarea').attr('disabled', true)
  $timeout ->
    $('input[type=text], textarea').removeAttr('disabled')
  , 1000

I also added the following CSS so disabled text inputs look like regular ones on iOS::

input[type="text"]:disabled
  opacity: 1
  -webkit-text-fill-color: black
@bshepherdson
Copy link
Contributor

There is code in ngMobile to prevent these ghost clicks. I had noticed some problems with the highlighting sticking on buttons on Android, which is annoying but not terrible. I hadn't seen anything like this before.

Looking at that patch, there probably isn't any reason why we can't do the same in ngMobile. When I can shake loose some 20% time to work on this, I'll take a look.

@ghost ghost assigned bshepherdson May 28, 2013
@damrbaby
Copy link
Contributor Author

@shepheb Thank you! Let me know if there's anything I can do to help

@damrbaby
Copy link
Contributor Author

FYI ... I solved this issue by including both ngMobile and fastclick in my app. They don't seem to conflict with each other and fastclick seems to solve the problem I had with ghost focusing occuring after CSS transitions.

An additional benefit to having fastclick is that it also removes the delay that occurs when focusing on form inputs on iOS.

@calvinl
Copy link

calvinl commented Jul 26, 2013

@damrbaby I'm having this issue too, but I can't seem to resolve it by including fastclick. Can you tell me how you've included it in your angular app?

@damrbaby
Copy link
Contributor Author

@calvinl I'm using fastclick 0.6.7 in conjunction with ngMobile / angularjs 1.1.5. So make sure you are still including ngMobile. It seems to work most of the time that way but there can be edge cases once in a while.

# Fastclick works in conjunction with ngMobile to prevent ghost focus after CSS transitions
# It also remove input focus delay on iOS
# https://github.com/angular/angular.js/issues/2810
window.addEventListener 'load', ->
  FastClick.attach document.body
, false

angular.module('myapp', ['ngMobile'])

@calvinl
Copy link

calvinl commented Jul 26, 2013

Yeah, I'm including ngMobile too. I just tried both 0.6.7 and the latest (0.6.9) and I'm still getting the extra ghostclick on my form fields 100% of the time. I tried your hack and it works, but like you said it's not really pretty.

@damrbaby
Copy link
Contributor Author

Yeah I hate my initial hack :) I'm wondering if you are using CSS transitions, and if so, what the duration is for them. I've noticed that the ghosclick happens when the transition happens immediately, vs. when it happens 300ms. Either way this is something that should be fixed in angular itself.

@calvinl
Copy link

calvinl commented Jul 26, 2013

That's an interesting thought...the transitions are CSS3 and are set at 500ms right now. I'll play around with the timing and report back.

@damrbaby
Copy link
Contributor Author

damrbaby commented Aug 9, 2013

FYI I switched to just using fastclick instead of ngMoble altogether, and I am no longer getting unwanted focus of the soft keyboard, which I have found happens with current ngMobile when transitioning between views with or without CSS3 transitions.

@tbosch tbosch modified the milestones: 1.2.12, 1.2.11, 1.2.13 Feb 3, 2014
@btford btford modified the milestones: 1.2.14, 1.2.13 Feb 15, 2014
@IgorMinar IgorMinar modified the milestones: 1.3.0-beta.1, 1.2.14 Mar 1, 2014
@btford btford modified the milestones: 1.3.0-beta.2, 1.3.0-beta.1 Mar 10, 2014
@tbosch tbosch modified the milestones: 1.3.0-beta.3, 1.3.0-beta.2 Mar 14, 2014
@btford btford modified the milestones: 1.3.0-beta.4, 1.3.0-beta.3 Mar 24, 2014
@petebacondarwin petebacondarwin added this to the 1.3.0-beta.5 milestone Mar 28, 2014
@petebacondarwin petebacondarwin removed this from the 1.3.0-beta.4 milestone Mar 28, 2014
@jeffbcross jeffbcross modified the milestones: 1.3.0-beta.6, 1.3.0-beta.5 Apr 3, 2014
@IgorMinar IgorMinar modified the milestones: 1.3.0-beta.7, 1.3.0-beta.6 Apr 22, 2014
@caitp caitp modified the milestones: 1.3.0-beta.9, 1.3.0-beta.8 May 9, 2014
@IgorMinar IgorMinar modified the milestones: 1.3.0, 1.3.0-beta.9 May 12, 2014
@btford btford removed the gh: issue label Aug 20, 2014
@IgorMinar
Copy link
Contributor

I believe that this was fixed by #2989. closing.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

9 participants