定制 jansuchanek/nchat 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

jansuchanek/nchat

最新稳定版本:v1.1.0

Composer 安装命令:

composer require jansuchanek/nchat

包简介

Reusable real-time admin chat extension for Nette Framework with WebSocket support (Soketi/Pusher), typing indicators, presence, read receipts, and optional AI responder.

README 文档

README

Reusable real-time chat extension for Nette Framework admin panels with WebSocket support (Soketi/Pusher), typing indicators, presence detection, read receipts, emoji reactions, sound alerts, and browser push notifications.

Features

  • 💬 Broadcast + DM + Group chat
  • WebSocket real-time (Soketi/Pusher) with polling fallback
  • ✍️ Typing indicators — "Jan píše…"
  • 👥 Online presence — instant online/offline
  • ✓✓ Read receipts — DM delivery confirmation
  • 😂 Emoji reactions — 👍❤️😂😮😢🙏
  • 🔔 Sound alerts — Web Audio API ping (toggleable)
  • 📢 Push notifications — Browser Notification API
  • 🤖 AI Bot integration — pluggable via AiResponderInterface
  • 🗄️ Database agnosticChatStorageInterface (DBAL included)

Installation

{
    "repositories": [
        {"type": "vcs", "url": "git@gitlab.com:JanSuchanek/nchat.git"}
    ],
    "require": {
        "jansuchanek/nchat": "dev-main"
    }
}

Configuration

extensions:
    nchat: NChat\ChatExtension

nchat:
    websocket:
        host: soketi
        port: 6001
        appId: my-app
        key: my-key
        secret: my-secret
    storage: NChat\Storage\DbalChatStorage  # or your own
    ai:
        enabled: true
        responder: App\Model\MyAiResponder  # implements AiResponderInterface

Usage

Add the trait to any presenter:

final class AdminPresenter extends BasePresenter
{
    use NChat\Presenter\ChatPresenterTrait;
}

Then add chat action names to your allowed actions:

$openActions = array_merge(['dashboard'], self::getChatActionNames());

Custom Database Storage

Implement ChatStorageInterface for any database:

class SqliteChatStorage implements ChatStorageInterface
{
    public function saveMessage(array $data): int { /* ... */ }
    public function fetchMessages(int $userId, array $criteria = []): array { /* ... */ }
    // ...8 methods total
}

Custom AI Responder

class MyAiResponder implements AiResponderInterface
{
    public function respond(string $context): string { /* call OpenAI/Claude/Gemini */ }
    public function getSystemPrompt(): string { return 'You are...'; }
    public function getBotName(): string { return '🤖 Bot'; }
}

License

MIT

统计信息

  • 总下载量: 3
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 6
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-18

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固