返回顶部
🇺🇸 English
🇨🇳 简体中文
🇨🇳 繁體中文
🇺🇸 English
🇯🇵 日本語
🇰🇷 한국어
🇫🇷 Français
🇩🇪 Deutsch
🇪🇸 Español
🇷🇺 Русский
l

logseq

Provide commands for interacting with a local Logseq instance through its Plugin API. Use for creating pages, inserting blocks, querying the graph database, managing tasks, retrieving content, or automating workflows in Logseq. Only works with a locally running instance with the API enabled; default port or set path expected for [$API accessible skill].

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
3,216
下载量
6
收藏
概述
安装方式
版本历史

logseq

# Logseq Plugin API Interact with your local Logseq instance through its JavaScript Plugin API. This skill enables reading, writing, querying, and automating workflows in your Logseq graph. ## Prerequisites **Logseq must be running locally** with a plugin that exposes the API. The standard way is: 1. **Install a bridge plugin** that exposes `logseq` API via HTTP (e.g., via a custom plugin or localhost endpoint) 2. **Alternative**: Use Node.js with `@logseq/libs` package to script against the running Logseq instance The API is primarily designed for in-browser plugins, so accessing it from external scripts requires a bridge/proxy. ## Core API Namespaces The Logseq Plugin API is organized into these main proxies: ### `logseq.App` Application-level operations: getting app info, user configs, current graph, commands, UI state, external links. **Key methods:** - `getInfo()` - Get app version and info - `getUserConfigs()` - Get user preferences (theme, format, language, etc.) - `getCurrentGraph()` - Get current graph info (name, path, URL) - `registerCommand(type, opts, action)` - Register custom commands - `pushState(route, params, query)` - Navigate to routes ### `logseq.Editor` Block and page editing operations: creating, updating, moving, querying content. **Key methods:** - `getBlock(uuid)` - Get block by UUID - `getCurrentPage()` - Get current page entity - `getCurrentPageBlocksTree()` - Get all blocks on current page - `getPageBlocksTree(page)` - Get all blocks for a specific page - `insertBlock(target, content, opts)` - Insert a new block - `updateBlock(uuid, content)` - Update block content - `createPage(pageName, properties, opts)` - Create a new page - `deletePage(pageName)` - Delete a page - `getPageLinkedReferences(page)` - Get backlinks to a page - `registerSlashCommand(tag, action)` - Add custom slash commands ### `logseq.DB` Database queries using Datalog. **Key methods:** - `q(query, ...inputs)` - Run Datalog query - `datascriptQuery(query, ...inputs)` - Direct Datascript query ### `logseq.UI` UI operations: messages, dialogs, main UI visibility. **Key methods:** - `showMsg(content, status)` - Show toast notification - `queryElementById(id)` - Query DOM elements ### `logseq.Git` Git operations for the current graph. **Key methods:** - `execCommand(args)` - Execute git command ### `logseq.Assets` Asset management. **Key methods:** - `listFilesOfCurrentGraph(path)` - List files in graph ## Common Workflows ### Read Content ```javascript // Get current page const page = await logseq.Editor.getCurrentPage(); // Get all blocks on a page const blocks = await logseq.Editor.getPageBlocksTree('Daily Notes'); // Get a specific block const block = await logseq.Editor.getBlock('block-uuid-here'); // Query with Datalog const results = await logseq.DB.q(` [:find (pull ?b [*]) :where [?b :block/marker "TODO"]] `); ``` ### Write Content ```javascript // Create a new page await logseq.Editor.createPage('Project Notes', { tags: 'project', status: 'active' }, { redirect: false }); // Insert a block const block = await logseq.Editor.insertBlock( 'target-block-uuid', '- New task item', { before: false, sibling: true } ); // Update a block await logseq.Editor.updateBlock('block-uuid', 'Updated content'); // Batch insert multiple blocks const blocks = [ { content: 'First item' }, { content: 'Second item', children: [ { content: 'Nested item' } ]} ]; await logseq.Editor.insertBatchBlock('parent-uuid', blocks, { sibling: false }); ``` ### Task Management ```javascript // Find all TODO items const todos = await logseq.DB.q(` [:find (pull ?b [*]) :where [?b :block/marker ?marker] [(contains? #{"TODO" "DOING"} ?marker)]] `); // Mark task as DONE await logseq.Editor.updateBlock('task-uuid', 'DONE Task content'); // Get tasks on current page const page = await logseq.Editor.getCurrentPage(); const blocks = await logseq.Editor.getPageBlocksTree(page.name); const tasks = blocks.filter(b => b.marker === 'TODO' || b.marker === 'DOING'); ``` ### Navigation and UI ```javascript // Navigate to a page logseq.App.pushState('page', { name: 'Project Notes' }); // Show notification logseq.UI.showMsg('✅ Task completed!', 'success'); // Get app config const configs = await logseq.App.getUserConfigs(); console.log('Theme:', configs.preferredThemeMode); console.log('Format:', configs.preferredFormat); ``` ## Implementation Approaches Since Logseq's Plugin API is browser-based, you have several options: ### Option 1: Bridge Plugin Create a minimal Logseq plugin that exposes API calls via HTTP: ```javascript // In Logseq plugin (index.js) logseq.ready(() => { // Expose API endpoints logseq.provideModel({ async handleAPICall({ method, args }) { return await logseq.Editor[method](...args); } }); }); // Then call from external script via HTTP POST ``` ### Option 2: Node.js Script with @logseq/libs For automation scripts, use the `@logseq/libs` package: ```bash npm install @logseq/libs ``` **Note:** This requires a running Logseq instance and proper connection setup. ### Option 3: Direct Plugin Development Develop a full Logseq plugin following the plugin samples at: https://github.com/logseq/logseq-plugin-samples ## API Reference For complete API documentation, see: - **API Docs**: https://logseq.github.io/plugins/ - **Plugin Samples**: https://github.com/logseq/logseq-plugin-samples - **Type Definitions**: `references/api-types.md` (extracted from `@logseq/libs`) ## Key Data Structures ### BlockEntity ```typescript { id: number, // Entity ID uuid: string, // Block UUID content: string, // Block content format: 'markdown' | 'org', page: { id: number }, // Parent page parent: { id: number }, // Parent block left: { id: number }, // Previous sibling properties: {}, // Block properties marker?: string, // TODO/DOING/DONE children?: [] // Child blocks } ``` ### PageEntity ```typescript { id: number, uuid: string, name: string, // Page name (lowercase) originalName: string, // Original case 'journal?': boolean, properties: {}, journalDay?: number, // YYYYMMDD for journals } ``` ## Tips & Best Practices 1. **Always check for null**: API methods may return `null` if entity doesn't exist 2. **Use UUIDs over IDs**: Block UUIDs are stable, entity IDs can change 3. **Batch operations**: Use `insertBatchBlock` for multiple inserts 4. **Query efficiently**: Datalog queries are powerful but can be slow on large graphs 5. **Properties are objects**: Access with `block.properties.propertyName` 6. **Format matters**: Respect user's preferred format (markdown vs org-mode) 7. **Async all the way**: All API calls return Promises ## Common Gotchas - **Page names are lowercase**: When querying, use lowercase page names - **Journal pages**: Use `journalDay` format (YYYYMMDD) not date strings - **Block hierarchy**: Respect parent/child relationships when inserting - **Format differences**: Markdown uses `-` for bullets, Org uses `*` - **Properties syntax**: Different between markdown (`prop::`) and org (`:PROPERTIES:`)

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 logseq-1776373507 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 logseq-1776373507 技能

通过命令行安装

skillhub install logseq-1776373507

下载 Zip 包

⬇ 下载 logseq v1.0.0

文件大小: 12.37 KB | 发布时间: 2026-4-17 14:04

v1.0.0 最新 2026-4-17 14:04
Initial release – provides powerful local Logseq automation via Plugin API:

- Enables creating pages, inserting/updating blocks, managing tasks, and querying the graph database.
- Supports Git integration, asset management, and in-app navigation/notifications.
- Accesses all core Logseq Plugin API namespaces: App, Editor, DB, UI, Git, and Assets.
- Requires a locally running Logseq instance with API access via a bridge plugin or compatible setup.
- Includes usage tips, best practices, and quick code examples for streamlined workflows.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部