anki-mcp-http
Version:
Model Context Protocol server for Anki - enables AI assistants to interact with your Anki flashcards
85 lines • 4.4 kB
JavaScript
;
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