-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfield_value_changes.ts
197 lines (183 loc) · 6.07 KB
/
field_value_changes.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
import type { AxiosInstance } from 'axios'
import { defaultTransformers } from './axios_default_transformers.ts'
import type { Value, ValueRaw } from './field_values.ts'
import type { Person } from './list_entries.ts'
import type { Field } from './lists.ts'
import type { DateTime, Replace, RequireOnlyOne } from './types.ts'
import { fieldValueChangesUrl } from './urls.ts'
/**
* Enum for Action Type.
*/
export enum ActionType {
/**
* Represents the action type for creating a field value change.
*/
CREATE = 0,
/**
* Represents the action type for deleting a field value change.
*/
DELETE = 1,
/**
* Represents the action type for updating a field value change.
*/
UPDATE = 2,
}
export type Changer =
& Person
& {
/**
* The unique identifier of the changer.
*/
id: number
}
/**
* Represents the response object for a field value change.
*
* *Note*: There are some extra attributes returned by this endpoint; they will be deprecated soon and should not be used.
*/
export type FieldValueChangeRaw = {
/**
* The unique identifier of the field value change object.
*/
id: number
/**
* The unique identifier of the field the value change is associated with.
*/
field_id: number
/**
* The unique identifier of the person, organization, or opportunity object the field value change is associated with.
*/
entity_id: number
/**
* The unique identifier of the list entry object the field value change is associated with.
*/
list_entry_id: number
/**
* Describes the action behind this field value change.
*/
action_type: ActionType
/**
* The changer object.
*/
changer: Changer
/**
* The timestamp when the field value change occurred.
*/
changed_at: DateTime
/**
* Represents the field's value.
*
* This attribute can take on many different types, depending on the field `value_type`.
* When the action type is {@link ActionType.DELETE}, `value` represents the old value; otherwise, it represents the new value.
*/
value: ValueRaw
}
export type FieldValueChangeResponseRaw = FieldValueChangeRaw[]
export type FieldValueChange = Replace<FieldValueChangeRaw, {
changed_at: Date
}>
export type FieldValueChangeResponse = FieldValueChange[]
export interface EntityRequestFilter {
/**
* A unique ID that represents a person object whose field value changes are to be retrieved.
*/
person_id: number
/**
* A unique ID that represents an organization object whose field value changes are to be retrieved.
*/
organization_id: number
/**
* A unique ID that represents an opportunity object whose field value changes are to be retrieved.
*/
opportunity_id: number
}
/**
* Only one of these properties can be present at a time
*/
export interface GetFieldValueChangesRequestFilter extends EntityRequestFilter {
/**
* A unique ID that represents a list entry object whose field value changes are to be retrieved.
*/
list_entry_id: number
}
export type GetFieldValueChangesRequestBase = {
/**
* A unique ID that represents a field object whose field values changes are to be retrieved.
*/
field_id: number
/**
* An integer that filters field value changes that were created with this specific action type.
*/
action_type?: ActionType
}
export type GetFieldValueChangesRequest =
| GetFieldValueChangesRequestBase
| (
& GetFieldValueChangesRequestBase
& RequireOnlyOne<GetFieldValueChangesRequestFilter>
)
/**
* Field value changes allow you to see historical changes to the values of fields in Affinity.
* This is especially useful for tracking progress through statuses (e.g. Lead --> Closed Won).
*
* *Supported field types*:
* Not all fields can track historical changes.
* Fields that are automatically created and "enriched" by Affinity do not support change tracking.
*
* Among fields that are not enriched, only the ones with the following data types support change tracking:
*
* Multi-valued fields:
* - {@link FieldValueType.PERSON}
* - {@link FieldValueType.ORGANIZATION}
* - {@link FieldValueType.NUMBER}
* - {@link FieldValueType.LOCATION}
*
* Single-valued fields:
* - {@link FieldValueType.PERSON}
* - {@link FieldValueType.ORGANIZATION}
* - {@link FieldValueType.NUMBER}
* - {@link FieldValueType.DATE}
* - {@link FieldValueType.LOCATION}
* - {@link FieldValueType.RANKED_DROPDOWN}
*
* You can also see if a field does so by looking at the {@link Field.track_changes} attribute in the Field Resource. The API will return an appropriate error if the field doesn't support historical tracking.
*/
export class FieldValueChanges {
/** @hidden */
constructor(private readonly axios: AxiosInstance) {
}
/**
* TODO(@joscha): transform DateTime values to Date objects and then change type {@link ValueRaw} to {@link Value}
*/
private static transformFieldValueChange(
fieldValueChange: FieldValueChangeRaw,
): FieldValueChange {
return {
...fieldValueChange,
changed_at: new Date(fieldValueChange.changed_at),
}
}
/**
* Returns all field values changes attached to a specific field.
* Field value changes can be filtered by `action_type`, person, organization, opportunity or `list_entry` by passing in the appropriate parameter.
*/
async all(
params: GetFieldValueChangesRequest,
): Promise<FieldValueChangeResponse> {
const response = await this.axios.get<FieldValueChangeResponse>(
fieldValueChangesUrl(),
{
params,
transformResponse: [
...defaultTransformers(),
(json: FieldValueChangeResponseRaw) => {
return json.map(
FieldValueChanges.transformFieldValueChange,
)
},
],
},
)
return response.data
}
}