Skip to content

satori-com/paint

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Satori Paint Demo

Satori Image

Satori provides an API that sends data between apps at high speed. The API uses a publish/subscribe model: Apps publish data of any type to a channel, and other apps subscribe to that channel and retrieve data from it. The API, based on WebSocket, transfers any amount of data with almost no delay.

The paint demo app shows you how the Satori API works. It displays a whiteboard and drawing tools. As you draw on the whiteboard, the app publishes drawing information to a channel hosted by Satori. To subscribe to the channel, you get a URL for it and send it to other users. When they open the URL, they see the drawing you do and you can see the drawings they do.

Hint: Send the URL to lots of people. No matter how many people are painting, the whiteboard immediately draws their input.

You can also get the source files for the demo and run it locally, using your own Satori project channel. To learn how, see "Run the demo locally".

Run the online demo

  1. Navigate to the Satori paint demo site. The site displays a whiteboard with a toolbar at the top.
  2. To share the whiteboard with others, click the share icon to display a URL for the channel.
  3. Copy the URL and send it to the users you want to share with. You can share with as many users as you want. When the users navigate to the URL in their browser, they also see a whiteboard.
  4. Both you and the other users can draw on your whiteboards and see the results of other drawings.

Draw on the whiteboard

  1. Select a color from the toolbar.
  2. To draw:
    1. On a mobile device, drag your finger on the whiteboard.
    2. On a computer, drag the pencil icon on the whiteboard.
  3. To erase, toggle the eraser tool. To stop erasing, toggle it again.
  4. To clear the entire whiteboard, click the refresh icon.
  5. To change the line width, click the small dot.

Run the demo locally

You can get the source files for the demo and run it locally. The source includes the browser JavaScript that runs the whiteboard, the Satori API library, and a server that hosts a Satori project channel.

Prerequisites

To run the demo locally, you need the following:

  • A computer that supports Node.js.
  • Node.js version 6.0.0 or later

Ensure that the Node package manager npm is available.

All of the code for the demo is included in the GitHub clone, or it is installed using npm after you have the code.

Get credentials from Satori

Set up a Satori account and create a project for credentials.

  1. Log in or sign up for a Satori account at https://developer.satori.com.
  2. From the dashboard, navigate to the Projects page.
  3. Click Add a project, then enter the name "Paint" and click Add.
  4. Satori displays an appkey and endpoint for your project. These credentials let the JavaScript app connect with Satori. Make a copy of them.
  5. Save the project.

Get the demo code

The demo code is available in a public GitHub repository. It's based on React, using the Create React App framework. As a result, you have access to all the tools provided by react-scripts.

To use the code, all you have to do is clone it from GitHub, build it, and run it.

Need instructions for cloning the Git repository

Note: The Create React App documentation describes the framework in more detail. To learn more about creating Satori projects for your own apps, see the Dev Portal tutorial.

  1. Clone the demo source files from GitHub:
git clone [email protected]:satori-com/paint.git
cd paint-demo
  1. Build the code
npm install
  1. In paint-demo, edit .env, then add the appkey and endpoint values:
REACT_APP_ENDPOINT='<endpoint_value>'
REACT_APP_APPKEY='<appkey_value>'
  1. Run the app server
npm run start

This starts the local server, which uses port 3000 (https://localhost:3000).

  1. The local server displays a whiteboard with a toolbar at the top.
  2. To share the whiteboard with others:
    1. Don't use the share button, because it just displays the URL for your local server. You need your server's IP address and channel information.
    2. Instead, switch focus to the terminal app in which you started the server. A message lists the IP address of the server on your local network.
    3. Copy the URL and send it to the users you want to share with.
  3. To see the instructions for using the whiteboard, see the section "Draw on the whiteboard".

App architecture

The paint demo uses two components:

  • App.js: Publishes movement events to a Satori project channel when users draw in the browser
  • Whiteboard.js: Subscribes to the project channel, gets movement events, and draws the coordinates to the browser canvas

Notice that the online demo uses a Satori public channel that's shared by everyone, but your local server uses a project channel that's only available to you and the users who have your local server URL.

App.js

This component publishes mouse/touch events it detects in the browser canvas. Each event contains an event type, such as mousedown, and a canvas-based coordinate. When users click, tap, or drag, App.js publishes an event to a Satori project channel. App.js also publishes drawing information such as drawing color, line width, and user information. Whiteboard.js uses this information to control the drawing and display a list of participants.

Whiteboard.js

This component subscribes to the Satori project channel and reads events and information from the channel. It tracks each user's color and line width state and draws on its canvas based on incoming mouse/touch events.

The Satori Motion Demo and Satori Chat Demo show you other ways to interact with users.

Next steps

This demo shows you a simple app that shares a whiteboard among users. Try extending this application to include more complex drawing tools or more colors. You may embed this app in your other projects or the other demo projects we provide.

Further reading

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •