macos-tools
$
npx mdskill add sonichi/sutando/macos-toolsIntegrates macOS tools for screen capture, calendar, reminders, contacts, and email
- Solves tasks like checking the screen, managing reminders, or sending email on macOS
- Uses AppleScript and native macOS apps like Calendar, Mail, and Reminders
- Triggers actions based on user requests about their schedule, to-do list, or contacts
- Returns results via script outputs or file paths for further processing
SKILL.md
.github/skills/macos-toolsView on GitHub ↗
--- name: macos-tools description: "macOS native integrations: screen capture, calendar, reminders, contacts, email (Mail.app), Spotlight search. Use when the user asks about their screen, schedule, to-do list, contacts, or wants to send email on macOS." --- # macOS Tools Native macOS integrations via AppleScript. No API keys needed — works on any Mac. ## When to Use - **Screen**: "What's on my screen?", "help me with this", "describe what I'm looking at" - **Calendar**: "What's on my schedule?", "do I have meetings today?" - **Reminders**: "Add a reminder", "what's on my todo list?", "mark X as done" - **Contacts**: "What's Bob's email?", "find contact for..." - **Email**: "Send an email to...", "draft a message to..." - **File search**: "Find my resume", "where's that PDF?" ## Tools ### Screen Capture ```bash bash "$SKILL_DIR/scripts/screen-capture.sh" ``` Returns path to PNG screenshot. Use the Read tool on the path to view it. ### Calendar Prefer the `google-calendar` skill if installed. Fallback to macOS Calendar: ```bash python3 "$SKILL_DIR/scripts/calendar-reader.py" 7 # next 7 days, JSON python3 "$SKILL_DIR/scripts/calendar-reader.py" 1 text # today, plain text ``` ### Reminders ```bash python3 "$SKILL_DIR/scripts/reminders.py" list # all incomplete python3 "$SKILL_DIR/scripts/reminders.py" add "Call Bob" # add reminder python3 "$SKILL_DIR/scripts/reminders.py" add "Fix bug" "2026-03-17" # with due date python3 "$SKILL_DIR/scripts/reminders.py" complete "Call Bob" # mark done ``` ### Contacts ```bash python3 "$SKILL_DIR/scripts/contacts.py" search "Bob" # find by name ``` Returns name, emails, phones. Use before sending email to resolve names to addresses. ### Email (Apple Mail) ```bash python3 "$SKILL_DIR/scripts/email-sender.py" "to@example.com" "Subject" "Body" python3 "$SKILL_DIR/scripts/email-sender.py" "to@example.com" "Subject" "Body" --draft ``` Sends via Mail.app. Use `--draft` to create without sending. **Always confirm with user before sending.** ### Spotlight File Search ```bash mdfind "quarterly report" # search by content or filename mdfind -name "resume.pdf" # search by filename only ``` ## Requirements - macOS (uses AppleScript) - Calendar, Reminders, Contacts, Mail apps (built into macOS) - Grant Accessibility permissions if prompted
More from sonichi/sutando
- agent-registryLocal Agent Registry — a standalone, dependency-free service that tracks running Claude Code (and other) agent instances. Agents self-register on startup and heartbeat while alive; the Electron overlay and Sutando dashboard read the live list. Use when you need to know which coding agents are running, where, and since when.
- bot2bot-postPost a coordination message from this bot to the shared bot2bot channel, @-mentioning the other Sutando node.
- claude-codexBash wrapper around the local Codex CLI for non-interactive runs from inside Sutando (bridges, cron, scripts). For interactive code review or task hand-off from this Claude Code session, prefer the official `/codex:*` plugin commands; this skill is the file-bridge-compatible path that `discord-bridge.py` invokes for team-tier sandboxed delegation.
- claude-geminiUse the local Gemini CLI from Claude Code with the user's existing Gemini authentication or API configuration. Use for large-context repo scans, multimodal analysis, second-opinion planning, or structured Gemini runs in the current workspace.
- claude-routerChoose between the local Codex CLI and Gemini CLI from Claude Code. Use for automatic model selection when the user wants the best local delegate for code review, repo-wide analysis, planning, or implementation.
- cross-node-syncRsync-over-ssh sync between Sutando nodes (Mac Studio and MacBook) for shared memory + notes. Optional — core runs fine without it; enables automatic cross-bot learning and note propagation by running from the proactive-loop cron on each pass.
- deal-finderScan configured sources (Craigslist now; eBay + Facebook Marketplace planned) for used-item listings matching the owner's criteria. Currently configured for a Mac mini search (M2+, 16GB+, 512GB+, ≤$500, near 94566). Notify owner via SMS + Telegram on a match.
- electron-overlay-dimmingReusable pattern for focus-based auto-dimming of Electron overlay windows — when the app loses focus, all overlay windows fade to a low opacity; when an overlay regains focus, they return to their configured opacity. Use when building always-on-top Electron overlays that should recede while the user works in other apps.
- gemini-ttsRender text to mp3 via Google Gemini Flash TTS. Free-tier eligible (1500 req/day). Use for video narration, demo voiceovers, audio notes. Parallels openai-tts; default for make-viral-video.
- macos-useGUI control for macOS apps via mediar-ai's mcp-server-macos-use. Click, type, scroll, key-press, open apps — driven by accessibility tree, works in non-interactive Claude Code mode. Use this for any Sutando task that needs to drive another macOS application (Safari, Zoom, Mail, Finder, etc.).