Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add haptic feedback to Toggle in Safari on iOS 18+ #29942

Open
3 tasks done
jedlikowski opened this issue Oct 16, 2024 · 7 comments · Fixed by #29945
Open
3 tasks done

feat: add haptic feedback to Toggle in Safari on iOS 18+ #29942

jedlikowski opened this issue Oct 16, 2024 · 7 comments · Fixed by #29945
Labels
type: feature request a new feature, enhancement, or improvement

Comments

@jedlikowski
Copy link

jedlikowski commented Oct 16, 2024

Prerequisites

Describe the Feature Request

Safari since iOS 18 supports haptic feedback on checkbox elements via a non-standard switch attribute. We could use it to provide haptic feedback when switching Toggle in non-hybrid environments. This could be a workaround for lack of support for Vibration API in Safari.

Describe the Use Case

Adding haptic feedback to Toggle component in non-hybrid environments would improve native feel of web and PWA apps built with Ionic.

Describe Preferred Solution

To trigger haptic feedback programatically we need an <input type=checkbox switch> element with an associated <label> element. With this setup, when we programatically trigger click() on the label, safari will emit the haptic feedback.

Describe Alternatives

Keep current implementation and wait for Safari to implement Vibration API (if it ever does).

Related Code

Codepen provided in WebKit release notes, demonstrating haptic feedback in checkbox of type switch: https://codepen.io/jensimmons/pen/GReLKWg

Additional Information

No response

@DwieDima
Copy link
Contributor

This sounds really interesting!
Would you mind to also include the option to configure this using IonicConfig with defaults to false?

You can find a similar PR for config extension here.

@jedlikowski
Copy link
Author

Hi @DwieDima, thanks for the suggestion 🙇 Added configurability to my PR 😄

@thetaPC
Copy link
Contributor

thetaPC commented Mar 18, 2025

Thank you for the feature request!

Are there any examples in the native iOS that provide haptic feedback? This will help determine if we would proceed with this request since we want to align with native.

@thetaPC thetaPC added needs: reply the issue needs a response from the user and removed triage labels Mar 18, 2025
@DwieDima
Copy link
Contributor

@thetaPC you can find these in the settings app for every toggle (e.g notifications)

@ionitron-bot ionitron-bot bot added triage and removed needs: reply the issue needs a response from the user labels Mar 18, 2025
@thetaPC
Copy link
Contributor

thetaPC commented Mar 18, 2025

Thank you for providing a use case! I was able to verify that this is a possibility with native iOS and toggles. I'll be adding the feature request label so the team can look into this.

@thetaPC thetaPC added the type: feature request a new feature, enhancement, or improvement label Mar 18, 2025
@ionitron-bot ionitron-bot bot removed the triage label Mar 18, 2025
@posaune0423
Copy link

posaune0423 commented Mar 31, 2025

Just came across this discussion - I've been working with the checkbox switch approach for haptic feedback in Safari on iOS as well. Created a small library that implements this technique: https://github.com/posaune0423/use-haptic.
Might be useful as a reference for your implementation.

There's also a demo site if you want to try it out(code sandbox): https://kjwzkv.csb.app
Might be useful as a reference for your implementation.

@thetaPC
Copy link
Contributor

thetaPC commented Apr 4, 2025

Thanks for the feature request! This has been resolved via PR #29945 and will be available in an upcoming minor release of Ionic.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type: feature request a new feature, enhancement, or improvement
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants