ConnectWave — アクセシビリティ重視の音声・通話支援ウェブアプリ

Web

概要

ConnectWaveは、聴覚障がいや発話困難なユーザーを対象に、電話やリアルタイム会話を支援することを目的としたWebアプリケーションです。音声のリアルタイム文字起こし(Speech-to-Text)や、テキストの音声出力(Text-to-Speech)を組み合わせ、通話中でも相手の発言を視覚的に確認したり、ユーザーの入力を音声で伝えたりできます。アクセシビリティを最優先に設計され、複数のモードや明確な視覚フィードバック、シンプルで反応の良いUIを備えてインクルーシブな通話体験を実現します。

GitHub

リポジトリの統計情報

  • スター数: 22
  • フォーク数: 0
  • ウォッチャー数: 22
  • コミット数: 13
  • ファイル数: 14
  • メインの言語: TypeScript

主な特徴

  • ライブの音声→テキスト(STT)とテキスト→音声(TTS)による双方向コミュニケーション支援
  • アクセシビリティ優先のUI設計(視覚的フィードバック、モード選択)
  • フルスタックTypeScript構成でクライアントとサーバーを統合
  • 軽量で拡張しやすいプロジェクト構造(Drizzleなどの設定ファイルを含む)

技術的なポイント

ConnectWaveはTypeScriptベースのフルスタック構成で、クライアント側(clientディレクトリ)とバックエンドの設定が含まれています。リポジトリにあるdrizzle.config.tsから、Drizzle ORMを用いたデータ管理を想定でき、永続化やスキーマ定義を型安全に扱う設計が見て取れます。リアルタイムの音声処理はブラウザのWeb Speech API(SpeechRecognition / SpeechSynthesis)や、外部のクラウドSTT/TTSサービスを組み合わせる実装が考えられます。通話や低遅延の双方向伝達にはWebRTCやWebSocketが使われることが多く、本プロジェクトも同様の技術でリアルタイム性を確保している可能性が高いです。

アクセシビリティ面では、ARIA属性やキーボード操作対応、視覚的なフィードバック(テキストの強調表示や発話中インジケーター)などによって、聴覚や発話に制約があるユーザーが状況を把握しやすくなる工夫が期待できます。TypeScriptを全面的に使うことで型安全なフロントエンド/バックエンド間の契約が保たれ、機能追加や保守がしやすい構造です。さらに、生成されたアイコン(generated-icon.png)やクライアント側の構成から、アクセシビリティに配慮したUIリソースやアセット管理も行っていることが伺えます。

注意点として、STT/TTSや通話の品質は使用するブラウザAPIや外部サービス、ネットワーク環境に依存します。プロダクション運用時は認証・プライバシー(通話内容の取り扱い)や、低遅延のためのインフラ設計、障害時のフォールバック(例:テキストのみモード)を検討することが重要です。

プロジェクトの構成

主要なファイルとディレクトリ:

  • .gitignore: file
  • README.md: file
  • client: dir
  • drizzle.config.ts: file
  • generated-icon.png: file

…他 9 ファイル

まとめ

アクセシビリティ重視で現実的な通話支援を目指す、拡張しやすいTypeScriptプロジェクト。

リポジトリ情報:

READMEの抜粋:

ConnectWave

Accessibility-Focused Communication Platform

ConnectWave is a full-stack web application designed to help deaf and mute individuals communicate effectively during phone calls and real-time conversations.

The application follows an accessibility-first approach and provides features such as live speech-to-text, text-to-speech, multiple accessibility modes, and clear visual feedback to support inclusive communication.


Problem Statement

Traditional phone calls and real-…