beeminder / road

Beebrain and Visual Graph Editor
http://graph.beeminder.com
Other
11 stars 3 forks source link

Quick Links

Beebrain and the Beeminder Graph Editor

This repository includes Javascript packages implementing all Beebrain functionality, as well as an interactive editor for Beeminder's Bright Red Lines.

Description of original Beebrain: http://doc.beeminder.com/beebrain

Components and Features

Getting started with local tests for basic functionality

The directory tests has HTML files illustrating various Beebrain functionality:

To load these in Chromium or Chrome, first, set up your environment:

export BBPATH=/absolule/path/to/this/repository

Then, if you are on Linux, you can load them in Chromium with the following example command:

chromium-browser --allow-file-access-from-files --disable-web-security --user-data-dir=$BBPATH/chromium-data --remote-debugging-port=9222 --use-gl=osmesa file://$BBPATH/tests/basic_test.html file://$BBPATH/tests/roadeditor_test.html file://$BBPATH/tests/sandbox.html

If you are on macOS, you can load them in Chrome with the following example command:

open -na /Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --args --allow-file-access-from-files --disable-web-security --user-data-dir=$BBPATH/chromium-data --remote-debugging-port=9222 --use-gl=osmesa file://$BBPATH/tests/basic_test.html file://$BBPATH/tests/roadeditor_test.html file://$BBPATH/tests/sandbox.html

The scary-looking arguments allow the browser to open local Beeminder files from within Javascript functions.

Note that these will use the files out of src/, not the generated files in lib/.

Getting started with the Node server for client-side graphs, graph editor, and sandbox demos

This repository contains a Node server instance for serving various demo pages to browser clients.

To install dependencies and compile the project, run the following commands:

npm ci # install all dependencies per package-lock.json
npm run compile # clear out lib/ and generate distribution files

Some demos have you to log in with your Beeminder account so it can access your Beeminder goals data.

After installing Node modules and using Gulp to compile js modules, you will need to provide a .env file with proper server settings to access central Beeminder servers for your login. After copying template.dev.env or template.prod.env to .env, read the comments in .env and update the file with proper settings.

Once this is done, you can start the demo server:

npm start

This starts a web server on localhost, with different features available through different paths. This server should also be embeddable in Glitch. The following paths are available:

The last three require setting up oauth redirect uri configuration properly with beeminder servers, so it would require proper settings in .env.

Note that getting the last three to work requires the Node server being accessible from beeminder servers for the redirect_uri provided in .env, associated with the clientid also configured in .env.

Getting started with the Node server for local server-side graph generation

See jsbrain_server/README.md for details.

This feature enables running a separate Node.js instance on a server, listening to GET requests that initiate the generation of PNG, SVG and JSON files for particular Beeminder goals.

Generating documentation

Do gulp gendoc in the root directory and point your browser to file:///path/to/road/docs/index.html

Appendix

A. Directory structure

The directory structure for this repository is organized as follows

B. Emacs development notes:

C. Deployment to Glitch (or similar)

  1. Import from https://github.com/beeminder/road
  2. Create a new Beeminder client at https://www.beeminder.com/apps/new
  3. Set the redirect URI in the .env file to https://[project].glitch.me/connect
  4. Add the client ID Beeminder assigns you to the .env file
  5. Same with the redirect URI, add it to the .env file
  6. Open the Glitch console and do mkdir .data and cd .data
  7. Create an empty SQLite file for the session store: touch database.sqlite

Credits

Uluç Saranlı