Logo : @tangentkitty
A small (actually really small, around 4KB) library, that attempts to mimic the three finger tap behaviour exhibited when you tap on a URL with three fingers in Safari.
In Safari, when the user taps on a hyperlink using three fingers, a small preview window opens that shows the webpage the link would have taken the use to. This library attempts to mimic that behaviour. But instead of using the three finger tap gesture to open the URL preview window (as it is not available on all hardware), in desktop, the library makes use of timed hover gesture to achieve the same.
In mobile, the user has to triple tap on a URL to open the preview window.
You can try out the demo here.
You can install the library as a dependency over NPM or you can simply download the release from the dist folder here.
npm i three-finger-tap-js
1.Assign an appropriate class name to all the <a>
(anchor) tags for which you wish to add the hover effect to.
<a href="https://wikipedia.org" class="three-finger-tap">Link</a>
2.Add references to threeFingerTap.min.js
and threeFingerTap.min.css
to the HTML page.
<link rel="stylesheet" href="../dist/css/threeFingerTap.min.css">
<script type="text/javascript" src="../dist/js/threeFingerTap.min.js"></script>
3.Call the library using the init method and see the magic happen.
threeFingerTap.init({
name : 'three-finger-tap',
hoverTimeout : 1000 // required only for desktop
})
init
Initializes the library and adds it to the window object with the name threeFingerTap. Use this method only once when you load the page.
Parameters
An object with name, hoverTimeout and customLoadingBackground as keys.
Name | Description | Type | Required | Default |
---|---|---|---|---|
name | name of the CSS class name that will be used to identify the links to apply the hover effect on | String | yes | N/A |
hoverTimeout | the duration for which a user needs to hover over an URL before the preview window appears. The value should be in milliseconds (Desktop only) | Number | yes | Ignored and set to 500 for Mobile |
customLoadingBackground | By default a loading background is added, you can use this parameter to set a custom image or gif as background. The value should be a valid value for the CSS background-image property. The path to the image/gif should be relative to page the effect will be displayed |
String | no | N/A |
Usage
threeFingerTap.init({
name : 'class-name',
hoverTimeout : 1000, // required only for Desktop
customLoadingBackground : "url('../assets/gifs/spinner.gif')"
})
All the three options can be specified either at the time the init
function is called by passing them as parameters, or
you can modify them any time after that using their corresponding getters and setters. All the three options are dynamic and changes
reflect as soon as they are modified.
disable
Disables the hover effect added by the library
Usage
threeFingerTap.disable();
enable
Enables the hover effect added by the library
Usage
threeFingerTap.enable();
Usage
Name | Description | Parameters | Required | Parameter Type |
---|---|---|---|---|
getName | Returns the current value of the name option |
N/A | N/A | N/A |
setName | Updates the name value to the value passed as parameter |
String | yes | A CSS valid class name |
getHoverTimeout | Returns the current value of the hoverTimeout option |
N/A | N/A | N/A |
setHoverTimeout | Updates the hoverTimeout to the value passed as parameter for desktop. In case of mobile, ignore the parameter passed. |
Number | yes | milliseconds |
getCustomLoadingBackground | Returns the current value of the customLoadingBackground option |
N/A | N/A | N/A |
setCustomLoadingBackground | Sets the loading effect to the passed GIF/image | String | yes | A valid value for the CSS background-image property |
destroy
Removes the DOM nodes and their respective event listeners. Also resets the library to the initial state.
Usage
threeFingerTap.destroy();
IE / Edge |
Firefox |
Chrome |
Safari |
Opera |
---|
If you have any issues report them at Issues