-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathplugin.form.ts
87 lines (79 loc) · 2.11 KB
/
plugin.form.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
85
86
87
/**
* Plugin to add form functionality to the core.
* Scope:
* - Capture the input events
* - Capture the change events
* - Capture the form submit events
* - Capture the form reset events
* @extends PluginBuilder
*/
import { BaseOptions, BindResult } from '../../types'
import { PluginBuilder } from '../core'
import { shouldCaptureEvent } from '../helpers'
export default class FormPlugin extends PluginBuilder {
override key: string = 'form'
override bind(options: BaseOptions): BindResult[] {
return [
{
name: 'form',
target: document,
event: 'submit',
callback: (event: Event) => {
return this.captureEvent(event, options)
}
},
{
name: 'form',
target: document,
event: 'reset',
callback: (event: Event) => {
return this.captureEvent(event, options)
}
},
{
name: 'form',
target: document,
event: 'input',
callback: (event: Event) => {
return this.captureEvent(event, options)
}
},
{
name: 'form',
target: document,
event: 'change',
callback: (event: Event) => {
return this.captureEvent(event, options)
}
}
]
}
/**
* A function to capture the form events on your site.
*/
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;
}
const target = event.target as HTMLInputElement
let formData: Record<string, any> = {}
if (target.form) {
formData = {
action: target.form?.action,
method: target.form?.method,
id: target.form?.id,
name: target.form?.name,
}
}
return {
type: event.type,
...formData
}
}
}