jpskill.com
🛠️ 開発・MCP コミュニティ

ui-toolkit/web

Reference skill for Zoom Video SDK UI Toolkit. Use after routing to a web video workflow when you want prebuilt React UI instead of building a fully custom Video SDK interface.

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o ui-toolkit-web.zip https://jpskill.com/download/22708.zip && unzip -o ui-toolkit-web.zip && rm ui-toolkit-web.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/22708.zip -OutFile "$d\ui-toolkit-web.zip"; Expand-Archive "$d\ui-toolkit-web.zip" -DestinationPath $d -Force; ri "$d\ui-toolkit-web.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して ui-toolkit-web.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → ui-toolkit-web フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-18
取得日時
2026-05-18
同梱ファイル
2

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

[Skill 名] ui-toolkit/web

Zoom Video SDK UI Toolkit

Web 用に事前に構築された Zoom Video SDK UI Toolkit の背景情報です。ユーザーがまだ Meeting SDK を必要とする可能性がある場合は、まず choose-zoom-approach を優先してください。

公式ドキュメント: https://developers.zoom.us/docs/video-sdk/web/ui-toolkit/ API リファレンス: https://marketplacefront.zoom.us/sdk/uitoolkit/web/ NPM パッケージ: https://www.npmjs.com/package/@zoom/videosdk-zoom-ui-toolkit ライブデモ: https://sdk.zoom.com/videosdk-uitoolkit

クイックリンク

UI Toolkit を初めてお使いの方はこちらのパスに従ってください:

  1. クイックスタート - 5分で実行できます(下記参照)
  2. JWT 認証 - サーバーサイドのトークン生成(必須)
  3. Composite と Components - アプローチを選択してください
  4. フレームワーク統合 - React、Vue、Angular、Next.js のパターン
  5. 統合インデックス - このファイルの下記のセクションを参照してください

問題が発生していますか?

  • セッションに参加できない → JWT 認証を確認してください(最も一般的な問題です)
  • React 18 のピア依存関係エラー → インストールセクションを参照してください
  • CSS が読み込まれない → トラブルシューティングを参照してください
  • コンポーネントが表示されない → コンポーネントのライフサイクルを確認してください
  • プレフライトチェックから開始する → 5分間のランブック

概要

Zoom Video SDK UI Toolkit は、最小限のコードで完全なビデオ会議体験をレンダリングする事前構築済みのビデオ UI ライブラリです。生の Video SDK とは異なり、UI Toolkit は以下を提供します。

  • すぐに使える UI - プロフェッショナルなビデオインターフェースをすぐに利用できます
  • UI コード不要 - ビデオレイアウト、コントロール、参加者管理を構築する必要はありません
  • フレームワークに依存しない - React、Vue、Angular、Next.js、Vanilla JS で動作します
  • 高度にカスタマイズ可能 - 有効にする機能を選択し、テーマをカスタマイズできます
  • 組み込み機能 - チャット、画面共有、設定、バーチャル背景が含まれています

UI Toolkit を使用する場合:

  • 完全なビデオソリューションを迅速に構築したい場合
  • Zoom のような UI の一貫性が必要な場合
  • カスタムビデオ UI を構築したくない場合
  • 標準機能(チャット、共有、参加者)が必要な場合

代わりに生の Video SDK を使用する場合:

  • 完全なカスタム UI コントロールが必要な場合
  • 非標準のビデオ体験を構築している場合
  • 生のビデオ/オーディオデータへのアクセスが必要な場合
  • 独自のレンダリングパイプラインを構築したい場合

インストール

npm install @zoom/videosdk-zoom-ui-toolkit jsrsasign
npm install -D @types/jsrsasign

: React のサポートは UI Toolkit のバージョンに依存します。インストールされているバージョンのパッケージのピア依存関係を確認してください(React 18 が一般的に必要です)。

クイックスタート

基本的な使用法 (Vanilla JS)

import uitoolkit from "@zoom/videosdk-zoom-ui-toolkit";
import "@zoom/videosdk-ui-toolkit/dist/videosdk-zoom-ui-toolkit.css";

const container = document.getElementById("sessionContainer");

const config = {
  videoSDKJWT: "your_jwt_token",
  sessionName: "my-session",
  userName: "John Doe",
  sessionPasscode: "",
  features: ["video", "audio", "share", "chat", "users", "settings"],
};

uitoolkit.joinSession(container, config);

uitoolkit.onSessionJoined(() => {
  console.log("Session joined");
});

uitoolkit.onSessionClosed(() => {
  console.log("Session closed");
});

Next.js / React 統合

'use client';

import { useEffect, useRef } from 'react';

export default function VideoSession({ jwt, sessionName, userName }) {
  const containerRef = useRef<HTMLDivElement>(null);
  const uitoolkitRef = useRef<any>(null);

  useEffect(() => {
    let isMounted = true;

    const init = async () => {
      const uitoolkitModule = await import('@zoom/videosdk-zoom-ui-toolkit');
      const uitoolkit = uitoolkitModule.default;
      uitoolkitRef.current = uitoolkit;

      // If TypeScript complains about CSS imports, configure your app to allow them
      // (for example via a global `declare module \"*.css\";`), or import the CSS from
      // a global entrypoint (Next.js layout/_app) instead of inlining here.
      await import('@zoom/videosdk-ui-toolkit/dist/videosdk-zoom-ui-toolkit.css');

      if (!isMounted || !containerRef.current) return;

      const config: any = {
        videoSDKJWT: jwt,
        sessionName: sessionName,
        userName: userName,
        sessionPasscode: '',
        features: ['video', 'audio', 'share', 'chat', 'users', 'settings'],
      };

      uitoolkit.joinSession(containerRef.current, config);
      uitoolkit.onSessionJoined(() => console.log('Joined'));
      uitoolkit.onSessionClosed(() => console.log('Closed'));
    };

    init();

    return () => {
      isMounted = false;
      if (uitoolkitRef.current && containerRef.current) {
        try {
          uitoolkitRef.current.closeSession(containerRef.current);
        } catch (e) {}
      }
    };
  }, [jwt, sessionName, userName]);

  return <div ref={containerRef} style={{ width: '100%', height: '100vh' }} />;
}

利用可能な機能

機能 説明
video ビデオレイアウトを有効にし、ビデオを送受信します
audio オーディオボタンを表示し、オーディオを送受信します
share 画面共有
chat セッション内メッセージング
users 参加者リスト
settings デバイス選択、バーチャル背景
preview 参加前のカメラ/マイクプレビュー
recording クラウドレコーディング(有料プラン)
leave セッションを退出/終了するボタン

トラブルシューティング

JWT トークン生成 (サーバーサイド)

必須: JWT トークンはサーバーで生成し、SDK シークレットをクライアントサイドに公開しないでください。

Node.js / Next.js API ルート

import { NextRequest, NextResponse } from 'next/server';
import { KJUR } from 'jsrsasign';

const ZOOM_VIDEO_SDK_KEY = process.env.ZOOM_VIDEO_SDK_KEY;
const ZOOM_VIDEO_SDK_SECRET = process.env.ZOOM_VIDEO_SDK_SECRET;

export async function POST(request: NextRequest) {
  const { sessionName, role, userName } = await request.json();

  if (!sessionName || role === undefined) {
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

Zoom Video SDK UI Toolkit

Background reference for the prebuilt Zoom Video SDK UI Toolkit on web. Prefer choose-zoom-approach first when the user might still need Meeting SDK instead.

Official Documentation: https://developers.zoom.us/docs/video-sdk/web/ui-toolkit/ API Reference: https://marketplacefront.zoom.us/sdk/uitoolkit/web/ NPM Package: https://www.npmjs.com/package/@zoom/videosdk-zoom-ui-toolkit Live Demo: https://sdk.zoom.com/videosdk-uitoolkit

Quick Links

New to UI Toolkit? Follow this path:

  1. Quick Start - Get running in 5 minutes (see below)
  2. JWT Authentication - Server-side token generation (required)
  3. Composite vs Components - Choose your approach
  4. Framework Integration - React, Vue, Angular, Next.js patterns
  5. Integrated Index - see the section below in this file

Having issues?

  • Session not joining → Check JWT Authentication (most common issue)
  • React 18 peer dependency error → See Installation section
  • CSS not loading → See Troubleshooting
  • Components not showing → Check Component Lifecycle
  • Start with preflight checks → 5-Minute Runbook

Overview

The Zoom Video SDK UI Toolkit is a pre-built video UI library that renders complete video conferencing experiences with minimal code. Unlike the raw Video SDK, the UI Toolkit provides:

  • Ready-to-use UI - Professional video interface out of the box
  • Zero UI code - No need to build video layouts, controls, or participant management
  • Framework agnostic - Works with React, Vue, Angular, Next.js, vanilla JS
  • Highly customizable - Choose which features to enable, customize themes
  • Built-in features - Chat, screen share, settings, virtual backgrounds included

When to use UI Toolkit:

  • You want a complete video solution quickly
  • You need Zoom-like UI consistency
  • You don't want to build custom video UI
  • You need standard features (chat, share, participants)

When to use raw Video SDK instead:

  • You need complete custom UI control
  • You're building a non-standard video experience
  • You need access to raw video/audio data
  • You want to build your own rendering pipeline

Installation

npm install @zoom/videosdk-zoom-ui-toolkit jsrsasign
npm install -D @types/jsrsasign

Note: React support depends on the UI Toolkit version. Check the package peer dependencies for your installed version (React 18 is commonly required).

Quick Start

Basic Usage (Vanilla JS)

import uitoolkit from "@zoom/videosdk-zoom-ui-toolkit";
import "@zoom/videosdk-ui-toolkit/dist/videosdk-zoom-ui-toolkit.css";

const container = document.getElementById("sessionContainer");

const config = {
  videoSDKJWT: "your_jwt_token",
  sessionName: "my-session",
  userName: "John Doe",
  sessionPasscode: "",
  features: ["video", "audio", "share", "chat", "users", "settings"],
};

uitoolkit.joinSession(container, config);

uitoolkit.onSessionJoined(() => {
  console.log("Session joined");
});

uitoolkit.onSessionClosed(() => {
  console.log("Session closed");
});

Next.js / React Integration

'use client';

import { useEffect, useRef } from 'react';

export default function VideoSession({ jwt, sessionName, userName }) {
  const containerRef = useRef<HTMLDivElement>(null);
  const uitoolkitRef = useRef<any>(null);

  useEffect(() => {
    let isMounted = true;

    const init = async () => {
      const uitoolkitModule = await import('@zoom/videosdk-zoom-ui-toolkit');
      const uitoolkit = uitoolkitModule.default;
      uitoolkitRef.current = uitoolkit;

      // If TypeScript complains about CSS imports, configure your app to allow them
      // (for example via a global `declare module \"*.css\";`), or import the CSS from
      // a global entrypoint (Next.js layout/_app) instead of inlining here.
      await import('@zoom/videosdk-ui-toolkit/dist/videosdk-zoom-ui-toolkit.css');

      if (!isMounted || !containerRef.current) return;

      const config: any = {
        videoSDKJWT: jwt,
        sessionName: sessionName,
        userName: userName,
        sessionPasscode: '',
        features: ['video', 'audio', 'share', 'chat', 'users', 'settings'],
      };

      uitoolkit.joinSession(containerRef.current, config);
      uitoolkit.onSessionJoined(() => console.log('Joined'));
      uitoolkit.onSessionClosed(() => console.log('Closed'));
    };

    init();

    return () => {
      isMounted = false;
      if (uitoolkitRef.current && containerRef.current) {
        try {
          uitoolkitRef.current.closeSession(containerRef.current);
        } catch (e) {}
      }
    };
  }, [jwt, sessionName, userName]);

  return <div ref={containerRef} style={{ width: '100%', height: '100vh' }} />;
}

Available Features

Feature Description
video Enable video layout and send/receive video
audio Show audio button, send/receive audio
share Screen sharing
chat In-session messaging
users Participant list
settings Device selection, virtual background
preview Pre-join camera/mic preview
recording Cloud recording (paid plan)
leave Leave/end session button

Troubleshooting

JWT Token Generation (Server-Side)

Required: Generate JWT tokens on your server, never expose SDK secret client-side.

Node.js / Next.js API Route

import { NextRequest, NextResponse } from 'next/server';
import { KJUR } from 'jsrsasign';

const ZOOM_VIDEO_SDK_KEY = process.env.ZOOM_VIDEO_SDK_KEY;
const ZOOM_VIDEO_SDK_SECRET = process.env.ZOOM_VIDEO_SDK_SECRET;

export async function POST(request: NextRequest) {
  const { sessionName, role, userName } = await request.json();

  if (!sessionName || role === undefined) {
    return NextResponse.json({ error: 'Missing params' }, { status: 400 });
  }

  const iat = Math.floor(Date.now() / 1000);
  const exp = iat + 60 * 60 * 2; // 2 hours

  const oHeader = { alg: 'HS256', typ: 'JWT' };
  const oPayload = {
    app_key: ZOOM_VIDEO_SDK_KEY,
    role_type: role, // 0 = participant, 1 = host
    tpc: sessionName,
    version: 1,
    iat,
    exp,
    user_identity: userName || 'User',
  };

  const signature = KJUR.jws.JWS.sign(
    'HS256',
    JSON.stringify(oHeader),
    JSON.stringify(oPayload),
    ZOOM_VIDEO_SDK_SECRET
  );

  return NextResponse.json({ signature });
}

JWT Payload Fields

Field Required Description
app_key Yes Your Video SDK Key
role_type Yes 0 = participant, 1 = host
tpc Yes Session/topic name
version Yes Always 1
iat Yes Issued at (Unix timestamp)
exp Yes Expiration (Unix timestamp)
user_identity No User identifier

API Reference

Core Methods

uitoolkit.joinSession(container, config);
uitoolkit.closeSession(container);

Event Listeners

uitoolkit.onSessionJoined(callback);
uitoolkit.onSessionClosed(callback);
uitoolkit.offSessionJoined(callback);
uitoolkit.offSessionClosed(callback);

Component Methods

uitoolkit.showChatComponent(container);
uitoolkit.hideChatComponent(container);
uitoolkit.showUsersComponent(container);
uitoolkit.hideUsersComponent(container);
uitoolkit.showControlsComponent(container);
uitoolkit.hideControlsComponent(container);
uitoolkit.showSettingsComponent(container);
uitoolkit.hideSettingsComponent(container);
uitoolkit.hideAllComponents();

CDN Usage (No Build Step)

<link rel="stylesheet" href="https://source.zoom.us/uitoolkit/2.3.5-1/videosdk-zoom-ui-toolkit.css" />
<script src="https://source.zoom.us/uitoolkit/2.3.5-1/videosdk-zoom-ui-toolkit.min.umd.js"></script>

<div id="sessionContainer"></div>

<script>
  const uitoolkit = window.UIToolkit;

  uitoolkit.joinSession(document.getElementById('sessionContainer'), {
    videoSDKJWT: 'your_jwt',
    sessionName: 'my-session',
    userName: 'User',
    features: ['video', 'audio', 'chat']
  });
</script>

Next.js with basePath

When deploying Next.js under a subpath:

// next.config.ts
const nextConfig = {
  basePath: "/your-app-path",
  assetPrefix: "/your-app-path",
};

Fetch API routes with full path:

fetch('/your-app-path/api/token', { ... })

Prerequisites

  1. Zoom Video SDK credentials from Zoom Marketplace
  2. React version compatible with your installed UI Toolkit package (check peer deps; React 18 is common)
  3. Server-side JWT generation (never expose SDK secret)
  4. Modern browser with WebRTC support

Browser Support

Browser Version
Chrome 78+
Firefox 76+
Safari 14.1+
Edge 79+

Common Issues

Issue Solution
peer react@"^18.0.0" error Use the React version required by the installed UI Toolkit package (check peer deps; React 18 is common)
CSS import TypeScript error Configure TS/CSS handling (prefer a global *.css module declaration); avoid @ts-ignore except in throwaway demos
Config type error Type config as any
API returns HTML not JSON Check basePath in fetch URL

Resources


Integrated Index

This section was migrated from SKILL.md.

Complete navigation for all UI Toolkit documentation.

📚 Start Here

New to the UI Toolkit? Follow this learning path:

  1. SKILL.md - Main overview and quick start
  2. 5-Minute Runbook - Preflight checks before deep debugging
  3. Quick Start Guide - Working code in 5 minutes (see skill.md)
  4. JWT Authentication - Server-side token generation (see skill.md)
  5. Choose Your Mode - Composite vs Components (see skill.md)

🎯 Core Concepts

Understanding how UI Toolkit works:

  • Composite vs Components - Two ways to use UI Toolkit (see skill.md)
  • UI Toolkit Architecture - How it wraps Video SDK internally
  • Feature Configuration - Understanding featuresOptions structure
  • Session Lifecycle - Join → Active → Leave/Close → Destroy flow

📖 Complete Guides

Getting Started

  • Installation - NPM install and React 18 setup (see skill.md)
  • Quick Start - Composite - Full UI in one container (see skill.md)
  • Quick Start - Components - Individual UI pieces (see skill.md)
  • JWT Authentication - Server-side token generation (see skill.md)

Framework Integration

  • React Integration - Hooks, useEffect patterns (see skill.md)
  • Vue.js Integration - Composition API and Options API (see skill.md)
  • Angular Integration - Component lifecycle (see skill.md)
  • Next.js Integration - App Router, Server Components (see skill.md)
  • Vanilla JavaScript - No framework usage (see skill.md)

Advanced Topics

  • Component Lifecycle - Mount, unmount, cleanup patterns
  • Event Listeners - React to session events
  • Session Management - Programmatic control
  • Quality Statistics - Monitor connection quality
  • Custom Themes - Theme customization
  • Virtual Backgrounds - Custom background images

📚 API Reference

Complete API documentation:

  • Core Methods (see skill.md)

    • joinSession() - Start a video session
    • closeSession() - End session and remove UI
    • destroy() - Clean up UI Toolkit instance
    • leaveSession() - Leave without destroying UI
  • Component Methods (see skill.md)

    • showControlsComponent() - Display control bar
    • showChatComponent() - Display chat panel
    • showUsersComponent() - Display participants list
    • showSettingsComponent() - Display settings panel
    • hideAllComponents() - Hide all components
  • Event Listeners (see skill.md)

    • onSessionJoined() - Session joined successfully
    • onSessionClosed() - Session ended
    • onSessionDestroyed() - UI Toolkit destroyed
    • onViewTypeChange() - View mode changed
    • on() - Subscribe to Video SDK events
    • off() - Unsubscribe from events
  • Information Methods (see skill.md)

    • getSessionInfo() - Get session details
    • getCurrentUserInfo() - Get current user
    • getAllUser() - Get all participants
    • getClient() - Get underlying Video SDK client
    • version() - Get version info
  • Control Methods (see skill.md)

    • changeViewType() - Switch view mode
    • mirrorVideo() - Mirror self video
    • isSupportCustomLayout() - Check device support
  • Statistics Methods (see skill.md)

    • subscribeAudioStatisticData() - Audio quality stats
    • subscribeVideoStatisticData() - Video quality stats
    • subscribeShareStatisticData() - Share quality stats

🔧 Configuration

  • Feature Configuration (see skill.md)

    • featuresOptions structure
    • Audio/Video options
    • Chat, Users, Settings
    • Virtual Background
    • Recording, Captions (paid features)
    • Theme customization
    • View modes
  • Session Configuration (see skill.md)

    • Required: videoSDKJWT, sessionName, userName
    • Optional: sessionPasscode, sessionIdleTimeoutMins
    • Debug mode
    • Web endpoint
    • Language settings

⚠️ Troubleshooting

Common Issues

  • React 18 peer dependency error
  • JWT token invalid
  • CSS not loading
  • Components not showing
  • Session join failures

See: troubleshooting/common-issues.md

Framework-Specific Issues

  • React: SSR, hydration, cleanup
  • Vue: Reactivity, lifecycle
  • Angular: Module imports, AOT
  • Next.js: App Router, basePath

Session Issues

  • Authentication failures
  • Connection problems
  • Video/audio not working
  • Screen share issues

📦 Sample Applications

Official Repositories:

Framework Repository Key Features
React videosdk-zoom-ui-toolkit-react-sample Hooks, TypeScript
Vue.js videosdk-zoom-ui-toolkit-vuejs-sample Composition API
Angular videosdk-zoom-ui-toolkit-angular-sample Services, Guards
JavaScript videosdk-zoom-ui-toolkit-javascript-sample Vanilla JS
Auth Endpoint videosdk-auth-endpoint-sample Node.js JWT

🌐 External Resources

🎓 Learning Path

Beginner

  1. Read SKILL.md overview
  2. Follow Quick Start - Composite
  3. Generate JWT on server
  4. Join your first session
  5. Explore available features

Intermediate

  1. Try Component Mode
  2. Add event listeners
  3. Customize theme
  4. Add virtual backgrounds
  5. Integrate with your framework

Advanced

  1. Access underlying Video SDK
  2. Subscribe to quality statistics
  3. Handle all edge cases
  4. Implement custom layouts
  5. Build production-ready app

📋 Quick Reference Card

Minimal Working Example

import uitoolkit from "@zoom/videosdk-zoom-ui-toolkit";
import "@zoom/videosdk-ui-toolkit/dist/videosdk-zoom-ui-toolkit.css";

const config = {
  videoSDKJWT: "YOUR_JWT",
  sessionName: "test-session",
  userName: "User",
  featuresOptions: {
    video: { enable: true },
    audio: { enable: true }
  }
};

uitoolkit.joinSession(document.getElementById("container"), config);
uitoolkit.onSessionJoined(() => console.log("Joined"));
uitoolkit.onSessionClosed(() => uitoolkit.destroy());

Must-Remember Rules

  1. Always generate JWT server-side
  2. Always call destroy() on cleanup
  3. Always use React 18 (not 17/19)
  4. Always import CSS file
  5. Never expose SDK secret client-side
  6. Never skip onSessionClosed cleanup
  7. Never call components before joinSession

📞 Support


Navigation: ← Back to SKILL.md

Environment Variables

同梱ファイル

※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。