Skip to main content
Glama

set_stroke_color

Change the stroke color of a Figma design element by specifying RGB values and optional transparency and weight.

Instructions

Set the stroke color of a node in Figma

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
nodeIdYesThe ID of the node to modify
rYesRed component (0-1)
gYesGreen component (0-1)
bYesBlue component (0-1)
aNoAlpha component (0-1)
weightNoStroke weight

Implementation Reference

  • Handler function that executes the tool logic by sending the 'set_stroke_color' command to the Figma plugin via WebSocket, using the provided nodeId, color components (r,g,b,a), and optional stroke weight. Returns a formatted text response with the result or error.
    async ({ nodeId, r, g, b, a, weight }) => {
      try {
        const result = await sendCommandToFigma("set_stroke_color", {
          nodeId,
          color: { r, g, b, a: a || 1 },
          weight: weight || 1,
        });
        const typedResult = result as { name: string };
        return {
          content: [
            {
              type: "text",
              text: `Set stroke color of node "${typedResult.name
                }" to RGBA(${r}, ${g}, ${b}, ${a || 1}) with weight ${weight || 1}`,
            },
          ],
        };
      } catch (error) {
        return {
          content: [
            {
              type: "text",
              text: `Error setting stroke color: ${error instanceof Error ? error.message : String(error)
                }`,
            },
          ],
        };
      }
  • Zod schema defining the input parameters for the set_stroke_color tool: required nodeId (string), r/g/b (numbers 0-1), optional a (0-1), optional positive weight.
    {
      nodeId: z.string().describe("The ID of the node to modify"),
      r: z.number().min(0).max(1).describe("Red component (0-1)"),
      g: z.number().min(0).max(1).describe("Green component (0-1)"),
      b: z.number().min(0).max(1).describe("Blue component (0-1)"),
      a: z.number().min(0).max(1).optional().describe("Alpha component (0-1)"),
      weight: z.number().positive().optional().describe("Stroke weight"),
    },
  • Registration of the 'set_stroke_color' MCP tool on the McpServer instance, including name, description, input schema, and handler function.
    server.tool(
      "set_stroke_color",
      "Set the stroke color of a node in Figma",
      {
        nodeId: z.string().describe("The ID of the node to modify"),
        r: z.number().min(0).max(1).describe("Red component (0-1)"),
        g: z.number().min(0).max(1).describe("Green component (0-1)"),
        b: z.number().min(0).max(1).describe("Blue component (0-1)"),
        a: z.number().min(0).max(1).optional().describe("Alpha component (0-1)"),
        weight: z.number().positive().optional().describe("Stroke weight"),
      },
      async ({ nodeId, r, g, b, a, weight }) => {
        try {
          const result = await sendCommandToFigma("set_stroke_color", {
            nodeId,
            color: { r, g, b, a: a || 1 },
            weight: weight || 1,
          });
          const typedResult = result as { name: string };
          return {
            content: [
              {
                type: "text",
                text: `Set stroke color of node "${typedResult.name
                  }" to RGBA(${r}, ${g}, ${b}, ${a || 1}) with weight ${weight || 1}`,
              },
            ],
          };
        } catch (error) {
          return {
            content: [
              {
                type: "text",
                text: `Error setting stroke color: ${error instanceof Error ? error.message : String(error)
                  }`,
              },
            ],
          };
        }
      }
    );

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/pipethedev/Talk-to-Figma-MCP'

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