Update an enum option

Updates an existing enum option. Enum custom fields require at least one enabled enum option. Locked custom fields can only be updated by the user who locked the field. Returns the full record of the updated enum option.

Script asana Verified

by hugo697 ยท 10/31/2023

The script

Submitted by hugo697 Typescript (fetch-only)
Verified 383 days ago
1
type Asana = {
2
  token: string;
3
};
4
/**
5
 * Update an enum option
6
 * Updates an existing enum option. Enum custom fields require at least one enabled enum option.
7
Locked custom fields can only be updated by the user who locked the field.
8
Returns the full record of the updated enum option.
9
 */
10
export async function main(
11
  auth: Asana,
12
  enum_option_gid: string,
13
  opt_pretty: string | undefined,
14
  opt_fields: string | undefined,
15
  body: {
16
    data?: ({ gid?: string; resource_type?: string; [k: string]: unknown } & {
17
      color?: string;
18
      enabled?: boolean;
19
      name?: string;
20
      [k: string]: unknown;
21
    }) & {
22
      insert_after?: string;
23
      insert_before?: string;
24
      [k: string]: unknown;
25
    };
26
    [k: string]: unknown;
27
  }
28
) {
29
  const url = new URL(
30
    `https://app.asana.com/api/1.0/enum_options/${enum_option_gid}`
31
  );
32
  for (const [k, v] of [
33
    ["opt_pretty", opt_pretty],
34
    ["opt_fields", opt_fields],
35
  ]) {
36
    if (v !== undefined && v !== "") {
37
      url.searchParams.append(k, v);
38
    }
39
  }
40
  const response = await fetch(url, {
41
    method: "PUT",
42
    headers: {
43
      "Content-Type": "application/json",
44
      Authorization: "Bearer " + auth.token,
45
    },
46
    body: JSON.stringify(body),
47
  });
48
  if (!response.ok) {
49
    const text = await response.text();
50
    throw new Error(`${response.status} ${text}`);
51
  }
52
  return await response.json();
53
}
54