type Asana = {
token: string;
};
/**
* Create a portfolio
* Creates a new portfolio in the given workspace with the supplied name.
Note that portfolios created in the Asana UI may have some state
(like the “Priority” custom field) which is automatically added
to the portfolio when it is created. Portfolios created via our
API will *not* be created with the same initial state to allow
integrations to create their own starting state on a portfolio.
*/
export async function main(
auth: Asana,
opt_pretty: string | undefined,
opt_fields: string | undefined,
body: {
data?: (({ gid?: string; resource_type?: string; [k: string]: unknown } & {
name?: string;
[k: string]: unknown;
}) & {
color?:
| "dark-pink"
| "dark-green"
| "dark-blue"
| "dark-red"
| "dark-teal"
| "dark-brown"
| "dark-orange"
| "dark-purple"
| "dark-warm-gray"
| "light-pink"
| "light-green"
| "light-blue"
| "light-red"
| "light-teal"
| "light-brown"
| "light-orange"
| "light-purple"
| "light-warm-gray";
[k: string]: unknown;
}) & {
members?: string[];
public?: boolean;
workspace?: string;
[k: string]: unknown;
};
[k: string]: unknown;
}
) {
const url = new URL(`https://app.asana.com/api/1.0/portfolios`);
for (const [k, v] of [
["opt_pretty", opt_pretty],
["opt_fields", opt_fields],
]) {
if (v !== undefined && v !== "") {
url.searchParams.append(k, v);
}
}
const response = await fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: "Bearer " + auth.token,
},
body: JSON.stringify(body),
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 22 days ago
type Asana = {
token: string;
};
/**
* Create a portfolio
* Creates a new portfolio in the given workspace with the supplied name.
Note that portfolios created in the Asana UI may have some state
(like the “Priority” custom field) which is automatically added
to the portfolio when it is created. Portfolios created via our
API will *not* be created with the same initial state to allow
integrations to create their own starting state on a portfolio.
*/
export async function main(
auth: Asana,
opt_pretty: string | undefined,
opt_fields: string | undefined,
body: {
data?: (({ gid?: string; resource_type?: string; [k: string]: unknown } & {
name?: string;
[k: string]: unknown;
}) & {
color?:
| "dark-pink"
| "dark-green"
| "dark-blue"
| "dark-red"
| "dark-teal"
| "dark-brown"
| "dark-orange"
| "dark-purple"
| "dark-warm-gray"
| "light-pink"
| "light-green"
| "light-blue"
| "light-red"
| "light-teal"
| "light-brown"
| "light-orange"
| "light-purple"
| "light-warm-gray";
[k: string]: unknown;
}) & {
members?: string[];
public?: boolean;
workspace?: string;
[k: string]: unknown;
};
[k: string]: unknown;
}
) {
const url = new URL(`https://app.asana.com/api/1.0/portfolios`);
for (const [k, v] of [
["opt_pretty", opt_pretty],
["opt_fields", opt_fields],
]) {
if (v !== undefined && v !== "") {
url.searchParams.append(k, v);
}
}
const response = await fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: "Bearer " + auth.token,
},
body: JSON.stringify(body),
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 576 days ago