anki-mcp-http
Version:
Model Context Protocol server for Anki - enables AI assistants to interact with your Anki flashcards
87 lines • 4.58 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 GuiSelectCardTool_1;
Object.defineProperty(exports, "__esModule", { value: true });
exports.GuiSelectCardTool = 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 GuiSelectCardTool = GuiSelectCardTool_1 = class GuiSelectCardTool {
ankiClient;
logger = new common_1.Logger(GuiSelectCardTool_1.name);
constructor(ankiClient) {
this.ankiClient = ankiClient;
}
async guiSelectCard({ card }, context) {
try {
this.logger.log(`Selecting card ${card} in Card Browser`);
await context.reportProgress({ progress: 50, total: 100 });
const success = await this.ankiClient.invoke('guiSelectCard', { card });
await context.reportProgress({ progress: 100, total: 100 });
if (!success) {
this.logger.warn('Card Browser is not open');
return (0, anki_utils_1.createErrorResponse)(new Error('Card Browser is not open'), {
cardId: card,
hint: 'Use guiBrowse to open the Card Browser first, then try selecting the card again.',
});
}
this.logger.log(`Successfully selected card ${card} in Card Browser`);
return (0, anki_utils_1.createSuccessResponse)({
success: true,
cardId: card,
browserOpen: true,
message: `Successfully selected card ${card} in Card Browser`,
hint: 'The card is now selected. Use guiEditNote to edit the associated note, or guiSelectedNotes to get note IDs.',
});
}
catch (error) {
this.logger.error('Failed to select card in browser', error);
if (error instanceof Error) {
if (error.message.includes('not found') || error.message.includes('invalid')) {
return (0, anki_utils_1.createErrorResponse)(error, {
cardId: card,
hint: 'Card ID not found. Make sure the card exists and is visible in the current browser search.',
});
}
}
return (0, anki_utils_1.createErrorResponse)(error, {
cardId: card,
hint: 'Make sure Anki is running, the Card Browser is open, and the card ID is valid',
});
}
}
};
exports.GuiSelectCardTool = GuiSelectCardTool;
__decorate([
(0, mcp_nest_1.Tool)({
name: 'guiSelectCard',
description: 'Select a specific card in an open Card Browser window. Returns true if browser is open and card was selected, false if browser is not open. ' +
'IMPORTANT: Only use when user explicitly requests selecting a card in the browser. ' +
'This tool is for note editing/creation workflows, NOT for review sessions. ' +
'The Card Browser must already be open (use guiBrowse first).',
parameters: zod_1.z.object({
card: zod_1.z
.number()
.positive()
.describe('Card ID to select in the browser (get from guiBrowse results)'),
}),
}),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object, Object]),
__metadata("design:returntype", Promise)
], GuiSelectCardTool.prototype, "guiSelectCard", null);
exports.GuiSelectCardTool = GuiSelectCardTool = GuiSelectCardTool_1 = __decorate([
(0, common_1.Injectable)(),
__metadata("design:paramtypes", [anki_connect_client_1.AnkiConnectClient])
], GuiSelectCardTool);
//# sourceMappingURL=gui-select-card.tool.js.map