> ## Documentation Index
> Fetch the complete documentation index at: https://docs.topsort.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Tomi Email Composer

> Generate emails from a prompt leveraging all of your marketplace data

export const ChangelogActions = () => {
  return <>
      <style>{`
        .changelog-actions {
          display: flex;
          justify-content: center;
          gap: 12px;
          margin-top: 2rem;
          padding-top: 1.5rem;
          border-top: 1px solid #e5e7eb;
        }
        
        [data-theme="dark"] .changelog-actions {
          border-top-color: #374151;
        }
        
        .changelog-btn {
          display: inline-flex;
          align-items: center;
          gap: 6px;
          padding: 8px 16px;
          border-radius: 9999px;
          border: 1px solid #d1d5db;
          background: transparent;
          color: #6b7280;
          font-size: 14px;
          cursor: pointer;
          transition: all 0.2s ease;
        }
        
        .changelog-btn:hover {
          border-color: #9ca3af;
          background: #f9fafb;
        }
        
        [data-theme="dark"] .changelog-btn {
          border-color: #4b5563;
          color: #9ca3af;
        }
        
        [data-theme="dark"] .changelog-btn:hover {
          border-color: #6b7280;
          background: #1f2937;
        }
      `}</style>
      <div className="changelog-actions">
        <button className="changelog-btn" onClick={() => {
    const btn = event.target.closest("button");
    btn.innerHTML = "❤️ Like";
    btn.style.borderColor = "#ec4899";
  }}>
          🤍 Like
        </button>
        <button className="changelog-btn" onClick={() => {
    const btn = event.target.closest("button");
    navigator.clipboard.writeText(window.location.href);
    const originalContent = btn.innerHTML;
    btn.innerHTML = "✓ Copied";
    btn.style.borderColor = "#22c55e";
    btn.style.color = "#22c55e";
    setTimeout(() => {
      btn.innerHTML = originalContent;
      btn.style.borderColor = "";
      btn.style.color = "";
    }, 2000);
  }}>
          ↗ Share
        </button>
      </div>
    </>;
};

<div className="cl-badge-group">
  <Badge color="gray" size="sm" icon="calendar">
    June 12, 2026
  </Badge>

  <Badge color="blue" size="sm" icon="rectangle-ad">
    Ad Platform
  </Badge>

  <Badge color="green" size="sm" icon="sparkles">
    New Feature
  </Badge>
</div>

## What's New

**Tomi Email Composer** is now available in the Marketplace Admin sidebar for
marketplaces with Tomi enabled. Describe the email you want to write, and Tomi
drafts it using live marketplace data from Topsort's APIs.

### Highlights

* **Prompt-to-email generation** with access to campaign metrics, vendor
  performance, and other marketplace data
* **Three tone variations** — Operational, Good News, and Apology — so the
  message tone can be easily made appropriate to the situation
* **Automatic draft saving** when you navigate away; reopen and continue editing
  anytime
* **Send mail** opens your default email client with subject and body pre-filled
* **Edit with Tomi** to refine drafts through the Tomi agent chat

### Example Use Cases

* Draft a vendor performance summary for the last 90 days and encourage them to
  scale spend
* Draft an internal ad ops update summarizing marketplace performance for the
  last 30 days
* Draft a marketplace-wide email sharing common campaign optimization
  opportunities

<div
  style={{
margin: "3rem 0",
height: "3px",
background:
  "linear-gradient(to right, transparent, #00ff88 20%, #00d4ff 40%, #8280ff 60%, #ff6b9d 80%, transparent)",
borderRadius: "2px",
opacity: "0.6",
}}
/>

Automatically activated for all marketplaces that have Tomi enabled. Learn more
in the [Tomi Email Composer](/en/knowledge-base/ad-platform/tomi/email-composer)
guide.

<ChangelogActions />
