FriendAdded 事件: - 新增 hasAddedBack 字段(B 是否已回加 A) - Toast:已互相好友 → '你们现在互为好友 🎉' - Toast:未回加 → '但你还没有添加对方为好友' + [➕ 回加] 一键操作按钮 FriendRemoved 事件: - 新增 hadAddedBack 字段(之前是否互相好友) - Toast:之前互相好友 → 提示 + [🗑️ 同步移除] 一键操作按钮 - Toast:单向好友 → 简单通知,无操作按钮 Toast 改进: - 右上角 × 关闭按钮 - 快捷操作按钮支持 fetch 直接请求 - 完成后显示结果并自动关闭,延时改为 8 秒
65 lines
1.9 KiB
PHP
65 lines
1.9 KiB
PHP
<?php
|
||
|
||
/**
|
||
* 文件功能:好友添加广播事件
|
||
*
|
||
* 当用户 A 添加用户 B 为好友时,向 B 的私有频道广播此事件,
|
||
* B 的客户端收到后展示弹窗通知。
|
||
* 携带 has_added_back 字段:若 B 已将 A 加为好友则为 true(双向好友),
|
||
* 否则为 false,前端提示 B 可以点击回加。
|
||
*
|
||
* @author ChatRoom Laravel
|
||
*
|
||
* @version 1.0.0
|
||
*/
|
||
|
||
namespace App\Events;
|
||
|
||
use Illuminate\Broadcasting\Channel;
|
||
use Illuminate\Broadcasting\InteractsWithSockets;
|
||
use Illuminate\Broadcasting\PrivateChannel;
|
||
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
|
||
use Illuminate\Foundation\Events\Dispatchable;
|
||
use Illuminate\Queue\SerializesModels;
|
||
|
||
class FriendAdded implements ShouldBroadcast
|
||
{
|
||
use Dispatchable, InteractsWithSockets, SerializesModels;
|
||
|
||
/**
|
||
* 构造好友添加事件。
|
||
*
|
||
* @param string $fromUsername 发起添加的用户名(A)
|
||
* @param string $toUsername 被添加的用户名(B,接收通知方)
|
||
* @param bool $hasAddedBack B 是否已将 A 加为好友(互相添加=true)
|
||
*/
|
||
public function __construct(
|
||
public readonly string $fromUsername,
|
||
public readonly string $toUsername,
|
||
public readonly bool $hasAddedBack = false,
|
||
) {}
|
||
|
||
/**
|
||
* 广播到被添加用户的私有频道,仅本人可见。
|
||
*/
|
||
public function broadcastOn(): Channel
|
||
{
|
||
return new PrivateChannel('user.'.$this->toUsername);
|
||
}
|
||
|
||
/**
|
||
* 广播负载:包含发起人信息和互相好友状态,供前端弹窗使用。
|
||
*
|
||
* @return array<string, mixed>
|
||
*/
|
||
public function broadcastWith(): array
|
||
{
|
||
return [
|
||
'from_username' => $this->fromUsername,
|
||
'to_username' => $this->toUsername,
|
||
'type' => 'friend_added',
|
||
'has_added_back' => $this->hasAddedBack,
|
||
];
|
||
}
|
||
}
|