plugins/_office/skills/office-artifacts/SKILL.md
Use document_artifact for substantial deliverables that should remain editable in the custom document canvas or LibreOffice Desktop. Markdown remains the default for ordinary writing, notes, reports, briefs, and drafts when no binary office file is needed. For LibreOffice office files, ODF is first-class: use ODT for Writer, ODS for Spreadsheet/Calc, and ODP for Presentation/Impress. Use DOCX, XLSX, or PPTX only when the user explicitly asks for Microsoft compatibility, provides an existing file in that format, or needs that compatibility surface.
The canvas is user-owned UI. Creating, reading, or editing an artifact must save the file and update its state, but it must not open the canvas automatically if the user has not opened it. Tool results provide explicit Download and Open in canvas actions for the user.
For format-specific work, prefer the matching skill when available:
markdown-documents for Markdown-first editable writing.word-documents for Writer/ODT files and DOCX compatibility files.excel-workbooks for Calc/ODS spreadsheets and XLSX compatibility workbooks.presentation-decks for Impress/ODP decks and PPTX compatibility decks.document_artifact:create / document_artifact:open, or with tool_name: "document_artifact" plus method: "create" / method: "open".document_artifact:read with file_id or path.document_artifact:edit.version_history or restore_version when the user asks to audit or roll back.Canvas context may list opened files with file_id, path, version, size, and timestamp. It intentionally omits full file contents; use read when the content matters.
Create:
{
"tool_name": "document_artifact:create",
"tool_args": {
"kind": "document",
"title": "Project Brief",
"format": "md",
"content": "Draft text here."
}
}
For spreadsheets, content can be CSV, TSV, or a Markdown table; the tool writes real cells, not one text blob per row.
Read:
{
"tool_name": "document_artifact:read",
"tool_args": {
"file_id": "abc123"
}
}
Edit text in a Markdown, ODT, DOCX, ODP, or PPTX file:
{
"tool_name": "document_artifact:edit",
"tool_args": {
"file_id": "abc123",
"operation": "replace_text",
"find": "old phrase",
"replace": "new phrase"
}
}
Set spreadsheet cells:
{
"tool_name": "document_artifact:edit",
"tool_args": {
"path": "/a0/usr/workdir/documents/Budget.ods",
"operation": "set_cells",
"cells": {
"Sheet1!B2": 12500,
"Sheet1!B3": 9800
}
}
}
Create an embedded spreadsheet chart:
{
"tool_name": "document_artifact:edit",
"tool_args": {
"file_id": "abc123",
"operation": "create_chart",
"sheet": "Sheet1",
"chart": {
"type": "line",
"title": "Monthly Revenue",
"data_range": "B1:C13",
"categories": "A2:A13",
"position": "E1",
"width": 18,
"height": 10
}
}
}
set_text, append_text, prepend_text, replace_text, delete_text.set_cells, append_rows, set_rows, replace_text, delete_text.create_chart for embedded spreadsheet charts.set_slides, append_slide, replace_text, delete_text.Arguments:
replace_text and delete_text require find; replace_text uses replace.set_cells accepts { "A1": "value", "Sheet2!B3": 42 } or [{"sheet":"Sheet1","cell":"A1","value":"value"}].rows accepts an array of rows. content can also be CSV, TSV, or a Markdown table.create_chart accepts chart as an object or JSON string for XLSX compatibility workbooks. Supported XLSX chart types: line, bar, column, pie, area, scatter, stock, ohlc, candlestick. Use data_range, categories/labels, position, title, width, and height. For stock-style charts only, provide Open/High/Low/Close columns in that order, or rely on a sheet whose headers are Date, Open, High, Low, Close.slides accepts [{"title":"Slide title","bullets":["point"]}]. Text slides can be separated with a line containing ---.count limits text replacements.file_id from canvas context or prior tool output; use path when that is all you have.read before editing unless the current saved content is already known.create_chart for embedded spreadsheet charts. Reach for Python/code execution only when the requested chart behavior is not supported by the tool.edit for precise saved changes; use the visual document canvas for human/manual layout polish.