-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathplugin.tap.ts
84 lines (75 loc) · 2.08 KB
/
plugin.tap.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/**
* Plugin to add taps (on touch devices) or clicks (on desktop) to the core.
* Scope:
* - Capture the tap/click events
* @extends PluginBuilder
*/
import { BaseOptions, BindResult } from '../../types'
import { PluginBuilder } from '../core'
import { shouldCaptureEvent } from '../helpers'
export default class TapPlugin extends PluginBuilder {
override key: string = 'tap'
override bind(options: BaseOptions): BindResult[] {
return [
{
name: 'click',
target: document,
event: 'click',
callback: (event: Event) => {
return this.captureEvent(event, options)
},
condition: () => {
return !('ontouchstart' in window)
}
},
{
name: 'click',
target: document,
event: 'dblclick',
callback: (event: Event) => {
return this.captureEvent(event, options)
},
condition: () => {
return !('ontouchstart' in window)
}
},
{
name: 'click',
target: document,
event: 'contextmenu',
callback: (event: Event) => {
return this.captureEvent(event, options)
}
},
{
name: 'tap',
target: document,
event: 'touchstart',
callback: (event: Event) => {
return this.captureEvent(event, options)
}
}
]
}
/**
* A function to capture the tap/click event.
*/
private captureEvent(event: Event, options: BaseOptions): Record<string, any> | false {
const { elements, safelist } = options
// Skip the event if the target is not in the elements list
if (!shouldCaptureEvent(elements, event)) {
return false
}
// Skip the event if the target is in the safe list selector
if (safelist.some(selector => (event.target as HTMLElement).matches(selector))) {
return false
}
// Determine the type of the event.
const eventType = event.type === 'touchstart' ? 'tap' : event.type
return {
type: eventType,
x: (event as any).clientX,
y: (event as any).clientY
}
}
}