anki-mcp-http
Version:
Model Context Protocol server for Anki - enables AI assistants to interact with your Anki flashcards
82 lines • 4.34 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 GuiSelectedNotesTool_1;
Object.defineProperty(exports, "__esModule", { value: true });
exports.GuiSelectedNotesTool = 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 GuiSelectedNotesTool = GuiSelectedNotesTool_1 = class GuiSelectedNotesTool {
ankiClient;
logger = new common_1.Logger(GuiSelectedNotesTool_1.name);
constructor(ankiClient) {
this.ankiClient = ankiClient;
}
async guiSelectedNotes(_args, context) {
try {
this.logger.log('Getting selected notes from Card Browser');
await context.reportProgress({ progress: 50, total: 100 });
const noteIds = await this.ankiClient.invoke('guiSelectedNotes');
await context.reportProgress({ progress: 100, total: 100 });
this.logger.log(`Retrieved ${noteIds.length} selected note(s) from Card Browser`);
if (noteIds.length === 0) {
return (0, anki_utils_1.createSuccessResponse)({
success: true,
noteIds: [],
noteCount: 0,
message: 'No notes are currently selected in the Card Browser',
hint: 'Open the Card Browser (guiBrowse) and select some cards/notes first.',
});
}
return (0, anki_utils_1.createSuccessResponse)({
success: true,
noteIds,
noteCount: noteIds.length,
message: `Retrieved ${noteIds.length} selected note ID(s) from Card Browser`,
hint: 'Use notesInfo to get details about these notes, or updateNoteFields/deleteNotes to modify them.',
});
}
catch (error) {
this.logger.error('Failed to get selected notes', error);
if (error instanceof Error) {
if (error.message.includes('browser') || error.message.includes('not open')) {
return (0, anki_utils_1.createErrorResponse)(error, {
hint: 'Card Browser is not open. Use guiBrowse to open it first.',
});
}
}
return (0, anki_utils_1.createErrorResponse)(error, {
hint: 'Make sure Anki is running and the Card Browser is open',
});
}
}
};
exports.GuiSelectedNotesTool = GuiSelectedNotesTool;
__decorate([
(0, mcp_nest_1.Tool)({
name: 'guiSelectedNotes',
description: 'Get the IDs of notes currently selected in the Card Browser. Returns array of note IDs (empty if no selection). ' +
'IMPORTANT: Only use when user explicitly requests getting selected notes. ' +
'This tool is for note editing/creation workflows, NOT for review sessions. ' +
'The Card Browser must be open with cards selected.',
parameters: zod_1.z.object({}),
}),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object, Object]),
__metadata("design:returntype", Promise)
], GuiSelectedNotesTool.prototype, "guiSelectedNotes", null);
exports.GuiSelectedNotesTool = GuiSelectedNotesTool = GuiSelectedNotesTool_1 = __decorate([
(0, common_1.Injectable)(),
__metadata("design:paramtypes", [anki_connect_client_1.AnkiConnectClient])
], GuiSelectedNotesTool);
//# sourceMappingURL=gui-selected-notes.tool.js.map