Skip to content
Documentation
Collab Components
Group Hug

GroupHug

Live collaborator avatars for multiplayer web apps

Online Demo (opens in a new tab)

๐Ÿฅท๐Ÿผ Usage

Install with npm:

npm i --save @yomo/group-hug-react

Create a Presence (opens in a new tab) instance

import { createPresence } from "@yomo/presence";
 
// create an instance.
const presence = createPresence("https://lo.yomo.dev:8443/v1", { 
//If you want to use Allegro's Yomo service, please modify the URL to "https://prscd2.allegro.earth/v1"
  publicKey: "DEV_TOKEN",
  debug: true,
});

Add <GroupHug /> to pages:

const App = () => {
  const [darkMode, setDarkMode] = useState(true);
  return (
    <div>
      <GroupHug
        presence={presence}
        channel={channel}
        id={peerId}
        name={peerDisplayName}
        darkMode={darkMode}
      />
    </div>
  );
};

๐Ÿงช Props

According to the demo code above, we can see an avatar with the default style.

Furthermore, we offer the option to utilize custom styles should you desire

If the avatar image is not specified, avvvatars (opens in a new tab) will be utilized as the placeholder.

Similarly, if you do not specify the color of avatarBorderColor, a random color will be assigned automatically.

Grouphug provides many style-related properties, you can customize the avatar with your own style by setting these properties.

Grouphug offers a plethora of style-related properties, enabling you to personalize the avatar according to your own preferences by configuring these properties.

Below are the comprehensive customization options:

<GroupHug
  presence={presence}
  channel={channel}
  id={id}
  name={"Noah"}
  placeholder={shape}
  size={24}
  darkMode={true}
  avatar={"https://avatars.githubusercontent.com/u/33050549?v=4"}
  avatarTextColor={"white"}
  avatarBorderWidth={3}
  avatarBorderColor={"blue"}
  avatarBackgroundColor={"red"}
  overlapping={true}
  transparency={0.5}
  maximum={6}
  MPOP={true}
  onMouseEnter={() => console.log(`mouse enter`)}
  onMouseLeave={() => console.log(`mouse leave`)}
/>;

Here are the full props:

nametypedescription
presence*Promise<IPresence>The Presence instance
channel*stringThe channel name of the Presence instance
id*stringThe unique identifier of the user
name*stringThe name or display name of the user
avatarstringThe avatar image url of the user
placeholder'shape', 'character'The placeholder image when avatar absence
MPOPbooleanA boolean value indicating whether the MPOP (Multiple Points of Presence) feature is enabled for the user
darkModebooleanA boolean value indicating whether the dark mode is enabled for the user
avatarTextColorstringThe color of the text displayed on the user's avatar
avatarBackgroundColorstringThe background color of the user's avatar
avatarBorderColorstringThe border color of the user's avatar
avatarBorderWidthnumberThe width of the border around the user's avatar
sizenumberThe size of the avatar in pixels
overlappingbooleanA boolean value indicating whether the avatars should overlap when multiple users are present
transparencynumberThe transparency level of the avatars, ranging from 0 (fully transparent) to 1 (fully opaque)
maximumnumberThe maximum number of avatars stacking
onMouseEnter(user: User) => voidA callback function triggered when the mouse pointer enters the user's avatar
onMouseLeave(user: User) => voidA callback function triggered when the mouse pointer leaves the user's avatar

๐Ÿ‘ฉโ€๐Ÿ”ฌ Local Development

  1. Start local prscd dev server: bun run prscd:dev
  2. Start Grouphug code generator tool: bun run dev
image

๐ŸŒŽ Self-hosting

see prscd

๐Ÿง˜๐Ÿป License

The MIT License