<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Oatnil</title>
    <description>The latest articles on Forem by Oatnil (@oatnil).</description>
    <link>https://forem.com/oatnil</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3901364%2F169a5621-3dec-4111-904e-f8be3a4db579.jpeg</url>
      <title>Forem: Oatnil</title>
      <link>https://forem.com/oatnil</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/oatnil"/>
    <language>en</language>
    <item>
      <title>Access Anywhere — Web, Desktop, CLI, and Beyond</title>
      <dc:creator>Oatnil</dc:creator>
      <pubDate>Wed, 29 Apr 2026 01:20:59 +0000</pubDate>
      <link>https://forem.com/oatnil/access-anywhere-web-desktop-cli-and-beyond-28h</link>
      <guid>https://forem.com/oatnil/access-anywhere-web-desktop-cli-and-beyond-28h</guid>
      <description>&lt;p&gt;When choosing a productivity tool, you often face a familiar dilemma: web apps are powerful but useless offline, desktop apps feel great but lock your data locally, and CLI tools are developer-friendly but lack a visual interface. The root cause is the absence of a Single Source of Truth — each platform is an island, and your data is scattered across them. UnDercontrol's answer: four form factors, one data source. And that data source is entirely under your control — self-hosted on your own server or stored on your local disk, never passing through any third party. Privacy and security are defined by you.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fn2wr8nqvnpaacq7smjt7.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fn2wr8nqvnpaacq7smjt7.png" alt="Single Source of Truth architecture" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Web App — Remote Access, Zero Install
&lt;/h3&gt;

&lt;p&gt;UnDercontrol's web frontend is built with Vite + React + TypeScript and serves as the foundation of the entire platform. Open a browser and you're in — no installation required.&lt;/p&gt;

&lt;p&gt;Core capabilities:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Full task, budget, and expense management&lt;/li&gt;
&lt;li&gt;Tiptap rich-text editor (code blocks, Mermaid diagrams, tables, checklists)&lt;/li&gt;
&lt;li&gt;AI chat integration (supports Claude, OpenAI, and other providers)&lt;/li&gt;
&lt;li&gt;SSE real-time notifications with multi-tab sync&lt;/li&gt;
&lt;li&gt;Responsive design that works on mobile&lt;/li&gt;
&lt;li&gt;Bilingual interface (Chinese / English)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The web app also serves as the rendering layer for the Electron desktop app — same codebase, zero duplication.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Typical scenarios&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;On the go, quickly check task progress or approve expenses from your phone's browser&lt;/li&gt;
&lt;li&gt;Team members collaborate instantly — just open a link, no software to install&lt;/li&gt;
&lt;li&gt;The convergence point for all clients — docs pushed from CLI, tasks created on desktop, pages clipped by the extension — all viewable and manageable in one place&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fb3a04ngt6qdb5h8v3xtq.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fb3a04ngt6qdb5h8v3xtq.png" alt="UnDercontrol web app dashboard" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Electron Desktop App — Offline First, Local Data
&lt;/h3&gt;

&lt;p&gt;The desktop app is far more than a web wrapper. It embeds a full Go backend and SQLite database, ready to use out of the box with no server configuration.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Embedded backend architecture&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Automatically launches the Go backend on startup&lt;/li&gt;
&lt;li&gt;Dynamic port allocation to avoid conflicts&lt;/li&gt;
&lt;li&gt;Data stored in &lt;code&gt;~/Library/Application Support/UnDercontrol/&lt;/code&gt; (macOS)&lt;/li&gt;
&lt;li&gt;Fully offline-capable — works without any network connection&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Remote backend mode&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;The desktop app can also connect to a remote server, sharing the same data source as the web app&lt;/li&gt;
&lt;li&gt;Switch the API address in settings — no reinstallation needed&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Daemon mode&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Background daemon process that listens to the task queue via SSE&lt;/li&gt;
&lt;li&gt;Receives and automatically executes remotely dispatched tasks — ideal for AI Agent workflows&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Desktop-exclusive features&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;System tray (Windows) — minimize to tray for quick access&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;.md&lt;/code&gt; file association — double-click a Markdown file to open it in UnDercontrol&lt;/li&gt;
&lt;li&gt;Multi-window editing — open multiple editor, task, and sticky-note windows simultaneously&lt;/li&gt;
&lt;li&gt;Workspace management — local terminal windows for running commands&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Build targets&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;macOS — DMG installer, Universal Binary (x64 + ARM64)&lt;/li&gt;
&lt;li&gt;Windows — NSIS installer (x64)&lt;/li&gt;
&lt;li&gt;Linux — AppImage (x64)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Typical scenarios&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;On a plane or train with no network — create tasks and edit documents as usual; everything syncs when you're back online&lt;/li&gt;
&lt;li&gt;At home, connect the desktop app to your company server — see exactly the same data as the web app&lt;/li&gt;
&lt;li&gt;Receive remotely dispatched AI tasks via Daemon and execute them automatically on your local machine&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ffk1b5po39olbtkcvzk22.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ffk1b5po39olbtkcvzk22.png" alt="UnDercontrol task detail page" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  CLI — kubectl-Style, AI Agent Friendly
&lt;/h3&gt;

&lt;p&gt;The &lt;code&gt;ud&lt;/code&gt; CLI is a terminal tool designed for developers and automation, using a kubectl-style verb-resource command system.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Interactive TUI&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Run &lt;code&gt;ud&lt;/code&gt; to enter a full-screen TUI for browsing and managing tasks with your keyboard.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fn2wr8nqvnpaacq7smjt7.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fn2wr8nqvnpaacq7smjt7.png" alt="Multi-platform architecture — Single Source of Truth" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;One-liner operations&lt;/strong&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;ud get task                          &lt;span class="c"&gt;# list tasks&lt;/span&gt;
ud describe task abc123              &lt;span class="c"&gt;# view details&lt;/span&gt;
ud apply &lt;span class="nt"&gt;-f&lt;/span&gt; task.md                  &lt;span class="c"&gt;# create/update from file&lt;/span&gt;
ud task query &lt;span class="s2"&gt;"status:todo tag:api"&lt;/span&gt;  &lt;span class="c"&gt;# query and filter&lt;/span&gt;
ud task &lt;span class="nb"&gt;nl&lt;/span&gt; &lt;span class="s2"&gt;"tasks completed last week"&lt;/span&gt; &lt;span class="c"&gt;# natural language query&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;AI Agent integration&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;code&gt;ud prompt &amp;lt;skill-name&amp;gt;&lt;/code&gt; outputs skill documents that teach AI Agents (Claude Code, Codex, OpenCode, and others) how to operate tasks via the ud CLI. Structured command output and Markdown-formatted input make it a natural fit for AI Agents to read and write.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Typical scenarios&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;CI/CD pipelines automatically push release notes to ud — the team reads them on the web, no need to dig through Git logs&lt;/li&gt;
&lt;li&gt;Technical docs in your code repo (architecture designs, API specs, runbooks) are synced to ud via scripts — non-developers can read them on the web without accessing the repository&lt;/li&gt;
&lt;li&gt;AI Agents automatically record progress and decisions in task notes during coding — the team sees updates in real time&lt;/li&gt;
&lt;li&gt;Ops scripts periodically collect inspection results and &lt;code&gt;ud apply&lt;/code&gt; them as tasks, forming a traceable operations log&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Chrome Extension — One-Click Clipping
&lt;/h3&gt;

&lt;p&gt;The Chrome extension turns any web page into an UnDercontrol task.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;One-click save&lt;/strong&gt; — captures a full page snapshot (HTML + all embedded resources)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Markdown extraction&lt;/strong&gt; — automatically extracts the page body as clean Markdown&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Offline mode&lt;/strong&gt; — save directly to local disk without logging in&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Remote mode&lt;/strong&gt; — log in to create an UnDercontrol task directly, with the snapshot uploaded as an attachment&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Typical scenarios&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Researching competitors — clip product pages as tasks, then compare and organize on the web later&lt;/li&gt;
&lt;li&gt;Found a great technical article — clip it as Markdown into ud for the team to share&lt;/li&gt;
&lt;li&gt;Received a customer bug report on a web page — clip it as a bug task with full context attached&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  SSE Real-Time Sync
&lt;/h3&gt;

&lt;p&gt;All clients connected to the same backend — whether browser tabs, the desktop app, or another device — stay in sync via SSE (Server-Sent Events).&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Task status changes, new comments, attachment uploads — all events pushed in real time&lt;/li&gt;
&lt;li&gt;Daemon SSE Hub dispatches commands to desktop Daemon instances&lt;/li&gt;
&lt;li&gt;Workspace session state is automatically coordinated between the desktop app and the backend&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F6zd8pcyxfp3w9ofnxpig.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F6zd8pcyxfp3w9ofnxpig.png" alt="Four official clients" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  One Codebase, Consistent Experience
&lt;/h3&gt;

&lt;p&gt;UnDercontrol's multi-platform strategy isn't "build once for each platform." Instead:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Web app&lt;/strong&gt; is the single frontend codebase&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Electron&lt;/strong&gt; loads the web build directly — zero code duplication&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;CLI&lt;/strong&gt; shares the same API and data model&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Chrome extension&lt;/strong&gt; uses the same API endpoints&lt;/li&gt;
&lt;/ul&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Capability&lt;/th&gt;
&lt;th&gt;Web&lt;/th&gt;
&lt;th&gt;Desktop&lt;/th&gt;
&lt;th&gt;CLI&lt;/th&gt;
&lt;th&gt;Extension&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;Remote API access&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Embedded backend&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;✅ (switchable to remote)&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Offline mode&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;System tray&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;TUI interface&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Background Daemon&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Web clipping&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Real-time SSE&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;AI Agent friendly&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;✅&lt;/td&gt;
&lt;td&gt;❌&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fuke52hlmij8hsjg9izm5.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fuke52hlmij8hsjg9izm5.png" alt="Capability comparison table" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;And there's more — the open API lets you build any client you want.&lt;/p&gt;

&lt;h3&gt;
  
  
  Beyond Official Clients — Build Your Own
&lt;/h3&gt;

&lt;p&gt;Beyond the four official clients, UnDercontrol exposes a full RESTful API. Generate an API Key in your profile settings, pair it with the Swagger docs, and build your own client in any language — Python scripts, automation bots, internal tool integrations, or even your own mobile app.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;API Key authentication&lt;/strong&gt; — generate in Profile → API Key, call with Bearer Token&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Scoped permissions&lt;/strong&gt; — authorize independently by module (Tasks, Expenses, Budgets, Files, AI)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Swagger docs&lt;/strong&gt; — browse all endpoints at &lt;code&gt;https://your-server/swagger/index.html&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;X-UD-Channel audit&lt;/strong&gt; — custom channel identifier to trace every request's origin&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;CI/CD friendly&lt;/strong&gt; — environment variable configuration for seamless automation pipeline integration&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9mj66xqdf211kabc3sse.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9mj66xqdf211kabc3sse.png" alt="Build your own client" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Typical scenarios&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Build a Slack Bot in Python — your team types &lt;code&gt;/task&lt;/code&gt; in Slack to create and query ud tasks&lt;/li&gt;
&lt;li&gt;Connect your internal admin panel's ticketing system to ud via API for bidirectional status sync&lt;/li&gt;
&lt;li&gt;Build a native mobile app calling the same API for a personalized phone experience&lt;/li&gt;
&lt;li&gt;Monitoring system alerts automatically create ud tasks with context attached — on-call engineers handle them on the web&lt;/li&gt;
&lt;/ul&gt;




&lt;p&gt;Different scenarios, the right tool for the job — data always in sync, experience always consistent.&lt;/p&gt;

</description>
      <category>productivity</category>
      <category>devtools</category>
      <category>opensource</category>
      <category>selfhosted</category>
    </item>
    <item>
      <title>Rich Markdown in Your Tasks — Code, Diagrams, and More</title>
      <dc:creator>Oatnil</dc:creator>
      <pubDate>Tue, 28 Apr 2026 00:52:07 +0000</pubDate>
      <link>https://forem.com/oatnil/rich-markdown-in-your-tasks-code-diagrams-and-more-4eij</link>
      <guid>https://forem.com/oatnil/rich-markdown-in-your-tasks-code-diagrams-and-more-4eij</guid>
      <description>&lt;h3&gt;
  
  
  What Is a Task?
&lt;/h3&gt;

&lt;p&gt;In UnDercontrol, a Task is the core unit of information. If you've used Jira, think of it as an Issue; if you've used Obsidian, think of it as a Note. A Task is essentially a piece of content bound to a status, with first-class attributes (title, tags, link relationships, etc.) and support for unlimited custom metadata fields (key-value pairs), so you can attach any information to it. Through the Notes mechanism, a Task can continuously evolve — recording progress, discussions, and decisions, accumulating into a complete knowledge context over time.&lt;/p&gt;

&lt;p&gt;This post covers the rich-text capabilities shared across all text input surfaces in UnDercontrol. We say "tasks", but it's not just tasks — whether it's a task description, a note, an expense memo, or an account annotation, they all use the same Markdown editor. The code blocks, Mermaid diagrams, tables, and checklists you use in tasks work identically in notes and every other context.&lt;/p&gt;

&lt;h3&gt;
  
  
  WYSIWYG — A Markdown Editor Built on Tiptap 3
&lt;/h3&gt;

&lt;p&gt;UnDercontrol's editor is built on &lt;a href="https://tiptap.dev/" rel="noopener noreferrer"&gt;Tiptap 3&lt;/a&gt;. You can write directly in Markdown syntax or use the visual toolbar — the editor renders in real time, what you write is what you see. No switching between "edit mode" and "preview mode" — the input is the final output.&lt;/p&gt;

&lt;p&gt;The editor also supports switching to Source Mode to view and edit the raw Markdown directly — for users who prefer plain text editing or need precise format control, you can freely toggle between WYSIWYG and raw Markdown at any time.&lt;/p&gt;

&lt;h3&gt;
  
  
  Slash Commands — Format Without Leaving the Keyboard
&lt;/h3&gt;

&lt;p&gt;Type &lt;code&gt;/&lt;/code&gt; anywhere to open the command menu. Insert headings, code blocks, tables, Mermaid diagrams, checklists, and more — all without touching the mouse.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Flzll6vreniagnrf7cirr.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Flzll6vreniagnrf7cirr.png" alt="Slash command menu in the editor" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;The slash menu supports:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Headings&lt;/strong&gt; (H1–H5) for document structure&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Task lists&lt;/strong&gt; with interactive checkboxes&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Code blocks&lt;/strong&gt; with language selection and syntax highlighting&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Mermaid diagrams&lt;/strong&gt; for flowcharts, sequence diagrams, and more&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Tables&lt;/strong&gt; with full cell editing&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Blockquotes&lt;/strong&gt;, dividers, and images&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Syntax-Highlighted Code Blocks
&lt;/h3&gt;

&lt;p&gt;Paste code snippets directly into your tasks. The editor supports 100+ programming languages with proper syntax highlighting — from TypeScript and Go to SQL and YAML.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9u39v2bx7taxr5ay7jwg.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9u39v2bx7taxr5ay7jwg.png" alt="Task with syntax-highlighted TypeScript code block" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Code blocks include a language selector dropdown and a one-click copy button. Your code stays readable and properly formatted, whether you're documenting an API endpoint or saving a useful shell command.&lt;/p&gt;

&lt;h3&gt;
  
  
  Mermaid Diagrams — Visualize Architecture Inline
&lt;/h3&gt;

&lt;p&gt;One of the most powerful features: embed &lt;a href="https://mermaid.js.org/" rel="noopener noreferrer"&gt;Mermaid&lt;/a&gt; diagrams directly in your task descriptions. Insert a Mermaid block via the slash menu, write your diagram syntax, and it renders live.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fg1jf9hwk4a4n44zqeyim.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fg1jf9hwk4a4n44zqeyim.png" alt="Mermaid flowchart showing microservices architecture" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Supported diagram types include:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Flowcharts&lt;/strong&gt; — system architecture, decision trees&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Sequence diagrams&lt;/strong&gt; — API flows, authentication handshakes&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Class diagrams&lt;/strong&gt; — data models, entity relationships&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;State diagrams&lt;/strong&gt; — workflow states, lifecycle tracking&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fazlmfsz4a4383qpc3kws.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fazlmfsz4a4383qpc3kws.png" alt="Mermaid sequence diagram showing authentication flow" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;The diagram viewer supports fullscreen preview, SVG download, and automatic dark/light theme switching.&lt;/p&gt;

&lt;h3&gt;
  
  
  Tables for Structured Data
&lt;/h3&gt;

&lt;p&gt;Need to document status codes, compare metrics, or track a feature matrix? Insert a table and edit cells directly. Add or remove rows and columns, toggle header rows, and merge cells — all from a context menu.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F5rsun7sc4lzylen4vgzw.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F5rsun7sc4lzylen4vgzw.png" alt="Table with status codes and interactive checklist" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Checklists That Actually Work
&lt;/h3&gt;

&lt;p&gt;Task lists render as interactive checkboxes. Check items off directly in the rendered view — no need to switch to edit mode. Great for tracking sub-steps, acceptance criteria, or deployment checklists.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fk51pxg5kkgxkm9cc2pdl.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fk51pxg5kkgxkm9cc2pdl.png" alt="Interactive checklist in task description" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Images &amp;amp; Attachments — No More Obsidian-Style Resource Management Headaches
&lt;/h3&gt;

&lt;p&gt;If you've managed notes with images in Obsidian, you've probably experienced the pain: images scattered across local folders, paths break when you move things, attachments disappear on another device, multi-device sync creates endless conflicts. The root cause — Obsidian delegates resource management to the filesystem, and filesystems are inherently bad at cross-device sync.&lt;/p&gt;

&lt;p&gt;UnDercontrol solves this at the foundation. All images and attachments are managed through the &lt;code&gt;resource://&lt;/code&gt; protocol — upload once, stored in the database, no dependency on local paths. Whether you view content on the web, desktop, or via a shared link, images are always available — because resources follow the database, not the filesystem.&lt;/p&gt;

&lt;p&gt;UnDercontrol also provides bidirectional local folder sync, keeping files in a local directory synchronized with the server resource library. We'll cover this feature in detail in a future post.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Image Size Control&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Inserted images support three size presets — hover in edit mode to switch:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Small (25%)&lt;/strong&gt; — thumbnail, suitable for inline display&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Medium (50%)&lt;/strong&gt; — moderate size&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Large (100%)&lt;/strong&gt; — full width&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Size information is stored in Obsidian-compatible format (&lt;code&gt;![description|s](resource://id)&lt;/code&gt;). Click any image for fullscreen preview.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fldvj5abruksir84ctbu7.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fldvj5abruksir84ctbu7.png" alt="Image size controls — S, M, L presets" width="800" height="438"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Draw.io Diagrams — Built-in Visual Drawing
&lt;/h3&gt;

&lt;p&gt;UnDercontrol includes a built-in Draw.io editor, supporting &lt;code&gt;.drawio&lt;/code&gt; and &lt;code&gt;.drawio.png&lt;/code&gt; formats. Upload or create a Draw.io file, then edit it directly in the app — no desktop software needed. Saved as PNG with embedded XML source data, so it renders as a preview and can be re-edited at any time.&lt;/p&gt;

&lt;p&gt;Thanks to the &lt;code&gt;resource://&lt;/code&gt; protocol, Draw.io diagrams are managed as unified resources — no local path dependencies or sync issues.&lt;/p&gt;

&lt;h3&gt;
  
  
  AI-Powered Text Actions
&lt;/h3&gt;

&lt;p&gt;Select any text to reveal the bubble menu. Beyond standard formatting (bold, italic, strikethrough), you get AI-powered actions:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Refine&lt;/strong&gt; — rewrite selected text for clarity&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Translate&lt;/strong&gt; — translate to another language instantly&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Chat&lt;/strong&gt; — ask questions about the selected content&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F1r99skxrm66hvi4lyfaz.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F1r99skxrm66hvi4lyfaz.png" alt="Feature overview — everything you need to document" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Entity Links — Connect Tasks Like a Wiki
&lt;/h3&gt;

&lt;p&gt;Link to other tasks, notes, expenses, budgets, and accounts directly in your descriptions using custom protocols like &lt;code&gt;task://&lt;/code&gt;, &lt;code&gt;note://&lt;/code&gt;, and more. The links render as clickable references — click to jump straight to the referenced entity.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F1xjt7n17npy5guev03za.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F1xjt7n17npy5guev03za.png" alt="Rendered entity links in a task description" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Switch to source mode to see the raw markdown — each link uses a custom protocol like &lt;code&gt;[API Integration Guide](task://189571b0-...)&lt;/code&gt;:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fr631vg0pm704171jh5wi.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fr631vg0pm704171jh5wi.png" alt="Raw markdown showing task:// protocol links" width="800" height="500"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;This turns your task descriptions into a connected wiki, where context flows naturally between related items.&lt;/p&gt;

&lt;h3&gt;
  
  
  CLI + AI Agent — Let AI Write Your Content
&lt;/h3&gt;

&lt;p&gt;Because Markdown is plain text, it's a natural fit for AI agent collaboration. Through the &lt;code&gt;ud&lt;/code&gt; CLI, you can let Claude Code, Codex, OpenCode, or any terminal-based AI tool read, write, and update task content directly:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Summarize&lt;/strong&gt; — have AI read a set of tasks and generate a weekly report or sprint review&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Refine &amp;amp; restructure&lt;/strong&gt; — turn scattered notes into structured documentation&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Classify &amp;amp; tag&lt;/strong&gt; — automatically add tags and categories based on content&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Batch create&lt;/strong&gt; — generate multiple tasks from meeting notes or requirement docs&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Content pipes directly in:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="nb"&gt;cat&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&amp;lt;&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="no"&gt;EOF&lt;/span&gt;&lt;span class="sh"&gt;' | ud apply -f -
---
title: "API Integration Guide"
status: in-progress
tags: [api, backend]
---
## Authentication Flow

1. Client sends credentials to `/auth/login`
2. Server returns JWT token
3. Include in `Authorization: Bearer &amp;lt;token&amp;gt;` header
&lt;/span&gt;&lt;span class="no"&gt;EOF
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;AI-generated Markdown renders identically to hand-written Markdown across web, desktop, and shared views. Your content stays portable and version-controllable.&lt;/p&gt;




&lt;p&gt;Markdown support in UnDercontrol means your tasks can be as detailed and technical as they need to be — without leaving the tool where the work gets tracked. Code blocks, diagrams, tables, and checklists all live alongside your task status, deadlines, and collaboration context.&lt;/p&gt;

&lt;p&gt;Try it out — create a task and type &lt;code&gt;/&lt;/code&gt; to see what's possible.&lt;/p&gt;

</description>
      <category>markdown</category>
      <category>productivity</category>
      <category>tiptap</category>
      <category>devtools</category>
    </item>
  </channel>
</rss>
