UNPKG

anki-mcp-http

Version:

Model Context Protocol server for Anki - enables AI assistants to interact with your Anki flashcards

85 lines 4.4 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var GuiDeckOverviewTool_1; Object.defineProperty(exports, "__esModule", { value: true }); exports.GuiDeckOverviewTool = void 0; const common_1 = require("@nestjs/common"); const mcp_nest_1 = require("@rekog/mcp-nest"); const zod_1 = require("zod"); const anki_connect_client_1 = require("../../../clients/anki-connect.client"); const anki_utils_1 = require("../../../utils/anki.utils"); let GuiDeckOverviewTool = GuiDeckOverviewTool_1 = class GuiDeckOverviewTool { ankiClient; logger = new common_1.Logger(GuiDeckOverviewTool_1.name); constructor(ankiClient) { this.ankiClient = ankiClient; } async guiDeckOverview({ name }, context) { try { this.logger.log(`Opening Deck Overview for deck "${name}"`); await context.reportProgress({ progress: 50, total: 100 }); const success = await this.ankiClient.invoke('guiDeckOverview', { name }); await context.reportProgress({ progress: 100, total: 100 }); if (!success) { this.logger.warn(`Failed to open Deck Overview for deck "${name}"`); return (0, anki_utils_1.createErrorResponse)(new Error(`Failed to open Deck Overview for deck "${name}"`), { deckName: name, hint: 'Deck not found or Anki GUI is not responding. Use list_decks to see available decks.', }); } this.logger.log(`Deck Overview opened for deck "${name}"`); return (0, anki_utils_1.createSuccessResponse)({ success: true, deckName: name, message: `Deck Overview opened for deck "${name}"`, hint: 'The deck statistics and study options are now visible in the Anki GUI.', }); } catch (error) { this.logger.error('Failed to open Deck Overview', error); if (error instanceof Error) { if (error.message.includes('not found') || error.message.includes('invalid')) { return (0, anki_utils_1.createErrorResponse)(error, { deckName: name, hint: 'Deck not found. Use list_decks to see available decks.', }); } } return (0, anki_utils_1.createErrorResponse)(error, { deckName: name, hint: 'Make sure Anki is running and the deck name is correct', }); } } }; exports.GuiDeckOverviewTool = GuiDeckOverviewTool; __decorate([ (0, mcp_nest_1.Tool)({ name: 'guiDeckOverview', description: 'Open Anki Deck Overview dialog for a specific deck. Shows deck statistics and study options. Returns true if succeeded. ' + 'IMPORTANT: Only use when user explicitly requests opening deck overview. ' + 'This tool is for deck management and note organization workflows, NOT for review sessions.', parameters: zod_1.z.object({ name: zod_1.z .string() .min(1) .describe('Deck name to open (get from list_decks)'), }), }), __metadata("design:type", Function), __metadata("design:paramtypes", [Object, Object]), __metadata("design:returntype", Promise) ], GuiDeckOverviewTool.prototype, "guiDeckOverview", null); exports.GuiDeckOverviewTool = GuiDeckOverviewTool = GuiDeckOverviewTool_1 = __decorate([ (0, common_1.Injectable)(), __metadata("design:paramtypes", [anki_connect_client_1.AnkiConnectClient]) ], GuiDeckOverviewTool); //# sourceMappingURL=gui-deck-overview.tool.js.map