Email

Learn how to filter, read, update, and clear the email column on monday boards using the platform API

The email column allows you to attach an email address to an item and send emails to that contact with a single click. You can filter, read, update, and clear the email column via the API.

Filter the email column

Using the items_page object, you can easily filter a board's items by specific columns or column values. The table below contains the email column's supported operators and compare values.

Operators

Compare values

any_of

  • "" (blank values)
  • The whole email or display text value to filter by*
  • not_any_of

  • "" (blank values)
  • The whole email or display text value to filter by*
  • is_empty

    null

    is_not_empty

    null

    contains_text

    The partial or whole email or display text value to filter by

    *

    not_contains_text

    The partial or whole email or display text value to filter by

    *

    *Please note that you can use either the email or display text when using theany_of, not_any_of, contains_text, or not_contains_text operators, but it must match whatever is in the UI. For example, if the item just has an email without display text, you can search by email. If display text is present, you must search by that and not the email.

    Examples

    The following example returns all items on the specified board without "@gmail" in their email address. Please note that if the column had display text values, the query would have to utilize those instead of the email value.

    query {
      boards (ids: 1234567890) {
        items_page (query_params: {rules: [{column_id: "email", compare_value: ["@gmail"], operator:not_contains_text}]}) {
          items {
            id
            name
          }
        }
      }
    }
    import { ApiClient } from "@mondaydotcomorg/api";
    const mondayApiClient = new ApiClient({ token: myToken });
    
    const query = `query ($board_id: [ID!], $column_id: ID!, $operator: ItemsQueryRuleOperator!, $compare_value:CompareValue!) { boards (ids: $board_id) { items_page (query_params: {rules: [{column_id: $column_id, compare_value: $compare_value,  operator:$operator}]}) { items { id name } } } }`;
    const variables = {
      board_id: 9571351437,
      column_id: "email_mksr9hcd",
      compare_value: ["@gmail.com"], 
      operator: "contains_text",
    };
    
    const response = await mondayApiClient.request(query, variables);

    Read the email column

    You can query the email column using the column_values object that enables you to return column-specific subfields by sending a fragment in your query. Values for the email column are of the EmailValue type.

    query {
      items (ids:[1234567890, 9876543210]) {
        column_values {
          ... on EmailValue {
            email
            updated_at
          }
        }
      }
    }
    const query = `query($itemIds: [ID!], $columnType:[ColumnType!]) { items (ids:$itemIds) { id column_values (types:$columnType) { column { title id } ... on EmailValue { email } } } }`;
    const variables = {
      itemIds: [9571351485, 9572374902],
      columnType: "email"
    };
    
    const response = await mondayApiClient.request(query, variables);

    Fields

    FieldDescription
    column Column!The column the value belongs to.
    email StringThe column's email value.
    id ID!The column's unique identifier.
    label StringThe column's text value. Please note that this may be the same as the email value if the user didn't enter any text.
    text StringThe column's value as text. This field will return "" if the column has an empty value.
    type ColumnType!The column's type.
    updated_at DateThe column's last updated date.
    value JSONThe column's JSON-formatted raw value.

    Update the email column

    You can update an email column using the change_simple_column_value mutation and sending a simple string in the value argument. You can also use the change_multiple_column_values mutation and pass a JSON string in the column_values argument.

    Simple strings

    To update an email column, send both the email address and display text as a string separated by a space. You can also include spaces in the display text. Both are required.

    mutation {
      change_simple_column_value (item_id:9876543210, board_id:1234567890, column_id:"email", value: "[email protected] This is an example email") {
        id
      }
    }
    import { ApiClient } from "@mondaydotcomorg/api";
    const mondayApiClient = new ApiClient({ token: myToken });
    
    const query = `mutation ($myBoardId:ID!, $myItemId:ID!, $myColumnValue: String!, $myColumnId: String!) { change_simple_column_value (item_id:$myItemId, board_id:$myBoardId, column_id: $myColumnId, value: $myColumnValue) { id } }`;
    const variables = {
      myBoardId: 9571351437,
      myItemId: 9571351485,
      myColumnId: "email_mksr9hcd",
      myColumnValue: "[email protected] This is an example email",
    };
    
    const response = await mondayApiClient.request(query, variables); 

    JSON

    To update an email column with JSON, you should send the email address in the email key and display text in the text key. Both keys are required.

    👍

    Pro tip

    You can mix both string and JSON values in the change_multiple_column_values mutation.

    mutation {
      change_multiple_column_values (item_id:9876543210, board_id:1234567890, column_values: "{\"my_email_column\":{\"email\":\"[email protected]\",\"text\":\"This is an example email\"}}") {
        id
      }
    }
    import { ApiClient } from "@mondaydotcomorg/api";
    const mondayApiClient = new ApiClient({ token: myToken });
    
    const query = `mutation ($myBoardId:ID!, $myItemId:ID!, $myColumnValues:JSON!) { change_multiple_column_values(item_id:$myItemId, board_id:$myBoardId, column_values: $myColumnValues) { id } }`;
    const variables = {
      myBoardId: 9571351437,
      myItemId: 9571351485,
      myColumnValues: JSON.stringify({
        email_mksr9hcd: { // email_mksr9hcd is the column ID
          email : "[email protected]", 
          text: "This is an example email"
        }
      }),
    };
    
    const response = await mondayApiClient.request(query, variables); 

    Clear the email column

    You have two options to clear an email column. First, you can use the change_multiple_column_values mutation and pass null, an empty string, or an empty object in the column_values argument.

    mutation {
      change_multiple_column_values(item_id:9876543210, board_id:1234567890, column_values: "{\"email\" : null}") {
        id
      }
    }
    import { ApiClient } from "@mondaydotcomorg/api";
    const mondayApiClient = new ApiClient({ token: myToken });
    
    const query = `mutation ($myBoardId:ID!, $myItemId:ID!, $myColumnValues:JSON!) { change_multiple_column_values(item_id:$myItemId, board_id:$myBoardId, column_values: $myColumnValues) { id } }`;
    const variables = {
      myBoardId: 9571351437,
      myItemId: 9571351485,
      myColumnValues: JSON.stringify({
        email_mksr9hcd: null
      }),
    };
    
    const response = await mondayApiClient.request(query, variables); 

    You can also use the change_simple_column_value mutation and pass an empty string in the value argument.

    mutation {
      change_simple_column_value(item_id:9876543210, board_id:1234567890, column_id: "email", value: "") {
        id
      }
    }
    fetch ("https://api.monday.com/v2", {
      method: 'post',
      headers: {
        'Content-Type': 'application/json',
        'Authorization' : 'YOUR_API_KEY_HERE'
      },
      body: JSON.stringify({
        query : "mutation ($myBoardId:Int!, $myItemId:Int!, $myColumnValue: String!, $columnId: String!) { change_simple_column_value (item_id:$myItemId, board_id:$myBoardId, column_id: $columnId, value: $myColumnValue) { id } }",
        variables : JSON.stringify({
          myBoardId: 1234567890,
          myItemId: 9876543210,
          columnId: "email",
          myColumnValue: ""
          })
        })
      })
    📘

    Join our developer community!

    We've created a community specifically for our devs where you can search through previous topics to find solutions, ask new questions, hear about new features and updates, and learn tips and tricks from other devs. Come join in on the fun! 😎