Skip to content

<CursorChat /> SolidJS Component helps bring Figma's Cursor Chat to your web applications in less than 3 minutes, making real-time collaboration anywhere.

License

Notifications You must be signed in to change notification settings

dodomatrix/solid-cursor-chat

Repository files navigation

solid-cursor-chat

🧬 Introduction

A SolidJS component helps bring Figma's Cursor Chat to your web applications in less than 3 minutes, making real-time collaboration anywhere. based on Presencejs.

  • Press Ctrl + / to bring up the input box
  • Press ESC to close the input box

🤹🏻‍♀️ Quick Start

Installation

by npm:

$ npm i --save solid-cursor-chat

by yarn:

$ yarn add solid-cursor-chat

by pnpm:

$ pnpm i solid-cursor-chat

Request free dev/test account

Login with your Github account on https://presencejs.yomo.run, will get a free app_id and app_secret

then, add serverless functionality to netlify:

// example/functions/presence-auth.js
const fetch = require('node-fetch');

exports.handler = async function (event, context) {
    if (event.httpMethod === 'GET') {
        try {
            const response = await fetch('https://prsc.yomo.dev/api/v1/auth', {
                method: 'POST',
                headers: {
                    'Content-Type': 'application/json',
                },
                body: JSON.stringify({
                    app_id: process.env.APP_ID,
                    app_secret: process.env.APP_SECRET,
                }),
            });
            const data = await response.json();
            const token = data.data;
            if (token) {
                return {
                    statusCode: 200,
                    body: JSON.stringify(token),
                };
            } else {
                return {
                    statusCode: 400,
                    body: JSON.stringify({ msg: data.message }),
                };
            }
        } catch (error) {
            return {
                statusCode: 500,
                body: JSON.stringify({ msg: error.message }),
            };
        }
    } else {
        return {
            statusCode: 400,
            body: JSON.stringify({ msg: '' }),
        };
    }
};

Response data:

{
    "token": "eyJhbGciOiJIUzI1..."
}

Integrate to your project

import { render } from 'solid-js/web';
import CursorChat from 'solid-cursor-chat';
// Import theme styles
// import 'solid-cursor-chat/dist/esm/xinghuang.css';
import 'solid-cursor-chat/dist/esm/maolv.css';

const App = () => {
    return (
        <CursorChat
            showLatency
            presenceURL="wss://prsc.yomo.dev"
            presenceAuthEndpoint="/.netlify/functions/presence-auth"
            avatar="https://cursor-chat-example.vercel.app/_next/image?url=%2Flogo.png&w=256&q=75"
        />
    );
};

render(App, document.getElementById('root'));
  • presenceURL: string: to set the YoMo's service address.
  • presenceAuthEndpoint: string: to set api for getting access token
  • room?: string: to set room.
  • showLatency?: boolean: to show connected mesh server and the end-to-end latency.
  • avatar?: string: to set avatar.
  • name?: string: to set name.

LICENSE

License: MIT

About

<CursorChat /> SolidJS Component helps bring Figma's Cursor Chat to your web applications in less than 3 minutes, making real-time collaboration anywhere.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published