mirror of
https://github.com/langgenius/dify.git
synced 2026-04-25 09:36:40 +08:00
add collaborate event
This commit is contained in:
parent
74b4719af8
commit
f9aedb2118
@ -1,4 +1,5 @@
|
|||||||
import json
|
import json
|
||||||
|
import time
|
||||||
|
|
||||||
from flask import request
|
from flask import request
|
||||||
from flask_restful import Resource, marshal_with, reqparse
|
from flask_restful import Resource, marshal_with, reqparse
|
||||||
@ -106,3 +107,43 @@ class OnlineUserApi(Resource):
|
|||||||
return {"data": results}
|
return {"data": results}
|
||||||
|
|
||||||
api.add_resource(OnlineUserApi, "/online-users")
|
api.add_resource(OnlineUserApi, "/online-users")
|
||||||
|
|
||||||
|
|
||||||
|
@ext_socketio.on("collaboration_event")
|
||||||
|
def handle_collaboration_event(data):
|
||||||
|
"""
|
||||||
|
Handle general collaboration events, include:
|
||||||
|
1. mouseMove
|
||||||
|
2. openPanel
|
||||||
|
|
||||||
|
"""
|
||||||
|
sid = request.sid
|
||||||
|
mapping = redis_client.get(f"ws_sid_map:{sid}")
|
||||||
|
|
||||||
|
if not mapping:
|
||||||
|
return {"msg": "unauthorized"}, 401
|
||||||
|
|
||||||
|
mapping_data = json.loads(mapping)
|
||||||
|
workflow_id = mapping_data["workflow_id"]
|
||||||
|
user_id = mapping_data["user_id"]
|
||||||
|
|
||||||
|
event_type = data.get("type")
|
||||||
|
event_data = data.get("data")
|
||||||
|
timestamp = data.get("timestamp", int(time.time()))
|
||||||
|
|
||||||
|
if not event_type or not event_data:
|
||||||
|
return {"msg": "invalid event data"}, 400
|
||||||
|
|
||||||
|
ext_socketio.emit(
|
||||||
|
"collaboration_update",
|
||||||
|
{
|
||||||
|
"type": event_type,
|
||||||
|
"userId": user_id,
|
||||||
|
"data": event_data,
|
||||||
|
"timestamp": timestamp
|
||||||
|
},
|
||||||
|
room=workflow_id,
|
||||||
|
skip_sid=sid
|
||||||
|
)
|
||||||
|
|
||||||
|
return {"msg": "event_broadcasted"}
|
||||||
|
|||||||
@ -24,16 +24,35 @@ export function useCollaborativeCursors(appId: string) {
|
|||||||
const socket = connectOnlineUserWebSocket(appId)
|
const socket = connectOnlineUserWebSocket(appId)
|
||||||
socketRef.current = socket
|
socketRef.current = socket
|
||||||
|
|
||||||
// Listen for other users' cursor updates
|
// Listen for collaboration updates from other users
|
||||||
socket.on('users_mouse_positions', (positions: Record<string, Cursor>) => {
|
socket.on('collaboration_update', (update: {
|
||||||
setCursors(positions)
|
type: string
|
||||||
|
userId: string
|
||||||
|
data: any
|
||||||
|
timestamp: number
|
||||||
|
}) => {
|
||||||
|
if (update.type === 'mouseMove') {
|
||||||
|
setCursors(prev => ({
|
||||||
|
...prev,
|
||||||
|
[update.userId]: {
|
||||||
|
x: update.data.x,
|
||||||
|
y: update.data.y,
|
||||||
|
userId: update.userId,
|
||||||
|
},
|
||||||
|
}))
|
||||||
|
}
|
||||||
|
// if (update.type === 'openPanel') { ... }
|
||||||
})
|
})
|
||||||
|
|
||||||
// Mouse move handler with throttle (e.g. 30ms)
|
// Mouse move handler with throttle 300ms
|
||||||
const handleMouseMove = (e: MouseEvent) => {
|
const handleMouseMove = (e: MouseEvent) => {
|
||||||
const now = Date.now()
|
const now = Date.now()
|
||||||
if (now - lastSent.current > 30) {
|
if (now - lastSent.current > 300) {
|
||||||
socket.emit('mouse_move', { x: e.clientX, y: e.clientY })
|
socket.emit('collaboration_event', {
|
||||||
|
type: 'mouseMove',
|
||||||
|
data: { x: e.clientX, y: e.clientY },
|
||||||
|
timestamp: now,
|
||||||
|
})
|
||||||
lastSent.current = now
|
lastSent.current = now
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -41,7 +60,7 @@ export function useCollaborativeCursors(appId: string) {
|
|||||||
|
|
||||||
return () => {
|
return () => {
|
||||||
window.removeEventListener('mousemove', handleMouseMove)
|
window.removeEventListener('mousemove', handleMouseMove)
|
||||||
socket.off('users_mouse_positions')
|
socket.off('collaboration_update')
|
||||||
disconnectOnlineUserWebSocket()
|
disconnectOnlineUserWebSocket()
|
||||||
}
|
}
|
||||||
}, [appId])
|
}, [appId])
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user