add-event-type
ユーザーが「新しいイベント」や「イベントブロック」に言及した場合、Reactコンポーネントを用いて、新しいイベントタイプをフロントエンドのフィードシステムに追加し、エージェントの新しい出力タイプを表示するSkill。
📜 元の英語説明(参考)
Add a new event type to the frontend feed system with corresponding React component. Use when user mentions "new event", "add event type", "event block", "new block type", or wants to display new agent output types.
🇯🇵 日本人クリエイター向け解説
ユーザーが「新しいイベント」や「イベントブロック」に言及した場合、Reactコンポーネントを用いて、新しいイベントタイプをフロントエンドのフィードシステムに追加し、エージェントの新しい出力タイプを表示するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o add-event-type.zip https://jpskill.com/download/17222.zip && unzip -o add-event-type.zip && rm add-event-type.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/17222.zip -OutFile "$d\add-event-type.zip"; Expand-Archive "$d\add-event-type.zip" -DestinationPath $d -Force; ri "$d\add-event-type.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
add-event-type.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
add-event-typeフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
イベントタイプの追加
手順
-
frontend/src/App.tsx内の現在のイベントタイプを読みます。EventTypeの union 型定義を見つけます。- 既存のブロックコンポーネント(UserMessageBlock、PlanBlock、TodoBlockなど)を確認します。
-
新しいイベントタイプのインターフェースを定義します。
type NewEventType = { type: 'new_type'; // 必要なフィールドを追加 }; -
EventType union に追加します。
type EventType = UserMessage | Plan | Todo | ... | NewEventType; -
既存のパターンに従って、新しいブロックコンポーネントを作成します。
function NewTypeBlock({ event }: { event: NewEventType }) { return ( <div className="p-3 bg-zinc-800/50 rounded-lg border border-zinc-700/50"> {/* イベントデータをレンダリング */} </div> ); } -
メインコンポーネントのフィードレンダリングの switch/conditional に case を追加します。
-
バックエンドがこのイベントタイプを送信する場合、WebSocket メッセージハンドラーを更新します。
例
- 「新しい 'search_result' イベントタイプを追加する」
- 「エラーを表示するためのブロックを作成する」
- 「進捗状況の更新のためのイベントタイプを追加する」
ガイドライン
- 既存の命名規則に従ってください(PascalCase コンポーネント、snake_case イベントタイプ)。
- 一貫したスタイリングのために、既存の Tailwind クラスを使用してください。
- TypeScript の型が完全であることを確認してください(
anyを使用しない)。 - WebSocket を介してモックイベントを送信してテストしてください。
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
Add Event Type
Instructions
-
Read current event types in
frontend/src/App.tsx:- Find the
EventTypeunion type definition - Review existing block components (UserMessageBlock, PlanBlock, TodoBlock, etc.)
- Find the
-
Define the new event type interface:
type NewEventType = { type: 'new_type'; // Add required fields }; -
Add to EventType union:
type EventType = UserMessage | Plan | Todo | ... | NewEventType; -
Create a new block component following existing patterns:
function NewTypeBlock({ event }: { event: NewEventType }) { return ( <div className="p-3 bg-zinc-800/50 rounded-lg border border-zinc-700/50"> {/* Render event data */} </div> ); } -
Add case to the feed rendering switch/conditional in the main component
-
Update WebSocket message handler if backend sends this event type
Examples
- "Add a new 'search_result' event type"
- "Create a block for displaying errors"
- "Add event type for progress updates"
Guardrails
- Follow existing naming conventions (PascalCase components, snake_case event types)
- Use existing Tailwind classes for consistent styling
- Ensure TypeScript types are complete (no
any) - Test by sending mock event through WebSocket