Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/cdrubin/rig

αcτµαlly pδrταblε εxεcµταblε redbean-based local web application
https://github.com/cdrubin/rig

chartjs cosmopolitan-libc lua prismjs redbean sqlite yace

Last synced: about 1 month ago
JSON representation

αcτµαlly pδrταblε εxεcµταblε redbean-based local web application

Awesome Lists containing this project

README

        

# 📈 _rig_         ([redbean](https://justine.lol/redbean/)-interactive-[grapher](https://www.chartjs.org/))         [⧐](https://cdrubin.github.io/rig)
---

(This proof-of-concept was intended for single-use but it is made public here in case others might be interested!)

| | | |
| --- | --- | --- |
| _made with_ [__readbean 1.0__](https://justine.lol/redbean/) | [redbean-1.0.com](https://justine.lol/redbean/redbean-1.0.com) | [redbean-1.0.com.dbg](https://justine.lol/redbean/redbean-1.0.com.dbg) |

The code here is ___NOT___ intended to be an example of best-practice in Javascript, Lua or the use of [αcτµαlly pδrταblε εxεcµταblεs and redbean](https://justine.lol/ape.html). It uses garish colours specifically because the intent is for others to make modifications! All of the source code is to be found within [index.html](https://github.com/cdrubin/rig/blob/main/index.html) - no external CSS or Javascript, no Javascript framework even though I itched to find an excuse to use [Hyperapp](https://github.com/jorgebucaran/hyperapp). This was really an opportunity to play with what an ape webapp means!

[SQLite](SQLite) in the browser comes thanks to [SQL.js](https://github.com/sql-js/sql.js). Code highlighting thanks to [Prism](https://prismjs.com/) and [Yace](https://github.com/petersolopov/yace).

![user interface](https://user-images.githubusercontent.com/232306/119274102-47fe9d00-bbdc-11eb-929a-a846bd5e3ac7.png)

> This is a poorly accessible web application, if anyone is interested in better access please reach out - I'm super happy to help.

---
### Install

1. Download the latest [rig.com](https://github.com/cdrubin/rig/releases/download/0.1/rig.com) ape
2. Make ```rig.com``` executable according to your platform
3. Run it (a new browser window should open to http://localhost:8080)

> To be sure the story involves trusting that this executable will do nothing untoward. If you on are a Mac you will need to explicitly verify that you are okay with execution by visiting ```System Preferences```|```General``` and pressing the ```Allow Anyway``` button next to the message about rig.com coming from the untamed wilds.

---
### Usage

🟠 The ```SQL``` (in orange!) pane accepts queries against the in-memory DB. ```CTRL-Enter``` executes these.

🟢 Up to 10 rows of results represented in JSON appear in the ```Data``` pane (in green!) including a tiny actual row count.

🟣 The ```Javascript``` pane (in purple!) accepts JS and again executes when ```CTRL-Enter``` is pressed. To automate code execution whenever a SQL query is executed, check the checkbox!

Loading files is available using the ⇱ button in the top left-hand corner, and saving is available with the ⇲ button in the top right-hand corner of the screen. Remote files can be loaded by pasting a URL.

---
### Notes

- In queries we avoid joining to the location table for improved speed since this table is really just a static lookup table for location names and information. Using it in a legend for the graph may be sensible.