Skip to main content
Glama

browser_unselect_checkbox

Unselect a checkbox in a web browser by specifying a locator strategy and value, enabling automation of form interactions and UI testing.

Instructions

Unselect a checkbox

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
byYesLocator strategy to find element
valueYesValue for the locator strategy
timeoutNoMaximum time to wait for element in milliseconds

Implementation Reference

  • Handler function for the browser_unselect_checkbox tool, which locates the checkbox using ActionService and unselects it if selected.
    server.tool('browser_unselect_checkbox', 'Unselect a checkbox', { ...locatorSchema }, async ({ by, value }) => {
      try {
        const driver = stateManager.getDriver();
        const actionService = new ActionService(driver);
        await actionService.unselectCheckbox({ by, value });
        return {
          content: [{ type: 'text', text: `Unselected checkbox` }],
        };
      } catch (e) {
        return {
          content: [
            {
              type: 'text',
              text: `Error unselecting checkbox: ${(e as Error).message}`,
            },
          ],
        };
      }
    });
  • Core implementation of unselecting a checkbox: waits for the element, checks if selected, and clicks to toggle off.
    async unselectCheckbox(params: LocatorParams): Promise<void> {
      const locator = LocatorFactory.createLocator(params.by, params.value);
      const checkbox = await this.driver.wait(until.elementLocated(locator), params.timeout || 15000);
      if (await checkbox.isSelected()) {
        await checkbox.click();
      }
    }
  • Zod schema definition for locator parameters (by, value, timeout) used in the tool input.
    export const locatorSchema = {
      by: z
        .enum(['id', 'css', 'xpath', 'name', 'tag', 'class', 'link', 'partialLink'])
        .describe('Locator strategy to find element'),
      value: z.string().describe('Value for the locator strategy'),
      timeout: z.number().optional().describe('Maximum time to wait for element in milliseconds'),
    };

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/pshivapr/selenium-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server