-
-
Notifications
You must be signed in to change notification settings - Fork 624
Expand file tree
/
Copy pathEventClient.ts
More file actions
70 lines (57 loc) · 1.46 KB
/
EventClient.ts
File metadata and controls
70 lines (57 loc) · 1.46 KB
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
import { EventClient } from '@tanstack/devtools-event-client'
import type { AnyFormOptions, AnyFormState } from './FormApi'
type ExtractEventNames<T> = T extends `${string}:${infer EventName}`
? EventName
: never
export type BroadcastFormState = {
id: string
state: AnyFormState
}
export type BroadcastFormApi = {
id: string
state: AnyFormState
options: AnyFormOptions
}
export type BroadcastFormSubmissionState =
| {
id: string
submissionAttempt: number
successful: false
stage: 'validateAllFields' | 'validate'
errors: any[]
}
| {
id: string
submissionAttempt: number
successful: false
stage: 'inflight'
onError: unknown
}
| {
id: string
submissionAttempt: number
successful: true
}
export type BroadcastFormId = {
id: string
}
type EventMap = {
'form-state': BroadcastFormState
'form-api': BroadcastFormApi
'form-submission': BroadcastFormSubmissionState
'request-form-state': BroadcastFormId
'request-form-reset': BroadcastFormId
'request-form-force-submit': BroadcastFormId
'form-unmounted': BroadcastFormId
}
export type EventClientEventMap = keyof EventMap
export type EventClientEventNames = ExtractEventNames<EventClientEventMap>
class FormEventClient extends EventClient<EventMap> {
constructor() {
super({
pluginId: 'form-devtools',
reconnectEveryMs: 1000,
})
}
}
export const formEventClient = new FormEventClient()