0

List Columns

by
Published Oct 17, 2025

Gets a list of all columns belonging to the sheet specified in the URL.

Script smartsheet Verified

The script

Submitted by hugo697 Bun
Verified 235 days ago
1
//native
2
type Smartsheet = {
3
  token: string;
4
  baseUrl: string;
5
};
6
/**
7
 * List Columns
8
 * Gets a list of all columns belonging to the sheet specified in the URL.
9
 */
10
export async function main(
11
  auth: Smartsheet,
12
  sheetId: string,
13
  level: string | undefined,
14
  page: string | undefined,
15
  pageSize: string | undefined,
16
  includeAll: string | undefined,
17
) {
18
  const url = new URL(`${auth.baseUrl}/sheets/${sheetId}/columns`);
19
  for (const [k, v] of [
20
    ["level", level],
21
    ["page", page],
22
    ["pageSize", pageSize],
23
    ["includeAll", includeAll],
24
  ]) {
25
    if (v !== undefined && v !== "" && k !== undefined) {
26
      url.searchParams.append(k, v);
27
    }
28
  }
29
  const response = await fetch(url, {
30
    method: "GET",
31
    headers: {
32
      Authorization: "Bearer " + auth.token,
33
    },
34
    body: undefined,
35
  });
36
  if (!response.ok) {
37
    const text = await response.text();
38
    throw new Error(`${response.status} ${text}`);
39
  }
40
  return await response.json();
41
}
42