mcp-appium-gestures
Provides resources and tools for generating Appium mobile gesture code (tap, swipe, scroll, etc.) in JavaScript and Java.
README
MCP Appium Gestures
An MCP (Model Context Protocol) server providing resources and tools for Appium mobile gestures.
Features
-
Documentation resources for common Appium mobile gestures:
- Tap
- Swipe
- Scroll
- Pinch/Zoom
- Long Press
- Drag and Drop
- Double Tap
-
Tools to generate code for these gestures in different languages:
- JavaScript (WebdriverIO v9+ and below)
- Java (Appium Java Client)
Installation
# Clone the repository
git clone https://github.com/yourusername/mcp-appium-gestures.git
cd mcp-appium-gestures
# Install dependencies
npm install
Usage
Start with stdio transport (for local use)
# Start the server with stdio transport
npm start
# or
npm run start:stdio
Start with SSE transport (for remote use)
# Start the server with SSE transport on default port (8080)
npm run start:sse
# Start the server with SSE transport on a custom port
npm run start:sse:port 3000
Development and Testing
# Test with mcp-cli
npm run dev
# Inspect with MCP Inspector
npm run inspect
Usage with Claude
To use this MCP server with Claude, you need to add it to your MCP settings configuration file. The location of this file depends on your platform:
- For Cursor:
/Users/[username]/Library/Application Support/Cursor/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json - For Claude Desktop:
/Users/[username]/Library/Application Support/Claude/claude_desktop_config.json - For Cline or other MCP clients: Check your client's documentation for the configuration file location
Add the following configuration to the mcpServers object in the settings file:
{
"mcpServers": {
"appium-gestures": {
"command": "npx",
"disabled": false,
"args": ["mcp-appium-gestures"],
"autoApprove": [],
"timeout": 300,
"transportType": "stdio"
}
}
}
Once configured, you can use the MCP server's tools and resources directly in Claude:
<use_mcp_tool>
<server_name>appium-gestures</server_name>
<tool_name>generate-tap-code</tool_name>
<arguments>
{
"language": "javascript",
"useElement": true,
"elementId": "login-button"
}
</arguments>
</use_mcp_tool>
Or access resources:
<access_mcp_resource>
<server_name>appium-gestures</server_name>
<uri>gesture://tap</uri>
</access_mcp_resource>
Resources
The server provides documentation resources for the following gestures:
gesture://tap- Tap gesture documentationgesture://swipe- Swipe gesture documentationgesture://scroll- Scroll gesture documentationgesture://pinch-zoom- Pinch and zoom gestures documentationgesture://long-press- Long press gesture documentationgesture://drag-drop- Drag and drop gesture documentationgesture://double-tap- Double tap gesture documentation
You can also access a specific gesture by name using the template: gesture://{name}
Tools
The server provides the following tools to generate code for Appium gestures:
generate-tap-code
Generates code for tap gesture.
Parameters:
language: 'javascript' or 'java'useElement: boolean - whether to tap on an element or at coordinateselementId: string (required if useElement is true) - the element ID to tap onx: number (required if useElement is false) - x coordinate to tap aty: number (required if useElement is false) - y coordinate to tap at
generate-swipe-code
Generates code for swipe gesture.
Parameters:
language: 'javascript' or 'java'startX: number - starting x coordinatestartY: number - starting y coordinateendX: number - ending x coordinateendY: number - ending y coordinateduration: number (optional, default: 500) - duration of the swipe in milliseconds
generate-scroll-code
Generates code for scroll gesture.
Parameters:
language: 'javascript' or 'java'direction: 'up', 'down', 'left', or 'right'useElement: boolean (optional, default: false) - whether to scroll to an elementelementId: string (optional) - the element ID to scroll todistance: number (optional, default: 300) - distance to scroll
generate-long-press-code
Generates code for long press gesture.
Parameters:
language: 'javascript' or 'java'useElement: boolean - whether to long press on an element or at coordinateselementId: string (required if useElement is true) - the element ID to long press onx: number (required if useElement is false) - x coordinate to long press aty: number (required if useElement is false) - y coordinate to long press atduration: number (optional, default: 2000) - duration of the long press in milliseconds
generate-double-tap-code
Generates code for double tap gesture.
Parameters:
language: 'javascript' or 'java'useElement: boolean - whether to double tap on an element or at coordinateselementId: string (required if useElement is true) - the element ID to double tap onx: number (required if useElement is false) - x coordinate to double tap aty: number (required if useElement is false) - y coordinate to double tap atpauseDuration: number (optional, default: 200) - pause duration between taps in milliseconds
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
