Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Investigate Observable Framework for prototyping #372

Open
hancush opened this issue Jun 6, 2024 · 9 comments
Open

Investigate Observable Framework for prototyping #372

hancush opened this issue Jun 6, 2024 · 9 comments
Assignees
Labels

Comments

@hancush
Copy link
Member

hancush commented Jun 6, 2024

Background

@fgregg has used Observable notebooks for a number of really cool data projects, and we've talked at length about its usefulness as a prototyping tool. Yet, the notebook interface is confusing to some clients. Enter Observable Framework, which allows us to do the same rapid development, but publish it in a format that looks like a website.

Observable Framework is an open-source static site generator for data apps, dashboards, reports, and more. Framework includes a preview server for local development, and a command-line interface for automating builds & deploys.

Proposal

We're making some charts for the CPS OSP project. I'd like to use Observable Framework to create and publish them.

Deliverables

A single-page static site with a few charts, hosted on Observable Framework.

Timeline

I expect this to take less than a day.

@hancush hancush added the R&D label Jun 6, 2024
@hancush hancush self-assigned this Jun 6, 2024
@hancush
Copy link
Member Author

hancush commented Jun 6, 2024

Set up a site and made some charts in 2 hours. PR: https://github.com/datamade/cps-osp/pull/11 (private repo)

@hancush
Copy link
Member Author

hancush commented Jun 13, 2024

Prototyped a new site in a day: https://github.com/datamade/tpc-noah-prototype (private repo)

Includes data loaders (e.g., https://github.com/datamade/tpc-noah-prototype/blob/main/src/data/msa_clusters.geojson.sh), several maps, multiple pages, and a GitHub Actions workflow to build and deploy the site to GitHub Pages (https://github.com/datamade/tpc-noah-prototype/blob/main/.github/workflows/deploy.yml).

Demo with the client went super well! It was so nice to be able to think together using their real data.

@hancush
Copy link
Member Author

hancush commented Jun 13, 2024

Their docs are excellent: https://observablehq.com/framework/getting-started

@hancush
Copy link
Member Author

hancush commented Jun 13, 2024

Oh, and I used Observable Plot for mapping / charts: https://observablehq.com/plot/

One really cool feature is that it includes faceting out of the box. So, you don't have to wrangle your flat data, you just let Plot do the work for you, for example: https://github.com/datamade/cps-osp/blob/main/exemplary-charts/src/prevalence-of-sexual-harassment-over-time.md#by-raceethnicity-and-sex

I also love how easy it is to include data tables. (See Inputs.table) below the plot block in the last link.

Screenshot 2024-06-13 at 2 33 48 PM

@hancush
Copy link
Member Author

hancush commented Aug 15, 2024

How to use Observable Plot in React: https://codesandbox.io/p/sandbox/observable-plot-in-react-demo-7kwdi

@fgregg
Copy link
Member

fgregg commented Aug 26, 2024

one downside of framework vs observablehq.com is that there's not an easy way to get svg or png of an image, yet. observablehq/framework#869

@antidipyramid
Copy link
Contributor

After the McCormick project is wrapped we can make a formal recommendation for adopting Observable.

@antidipyramid
Copy link
Contributor

antidipyramid commented Dec 4, 2024

Include documentation on integrating Observable and Makefiles from McCormick.

@haowens
Copy link

haowens commented Dec 4, 2024

Need to add below to the observablehq.config.js file

interpreters: {
    ".mk": ["make", "-s", "-f"],
 },

The way Observable data loaders work is they will call the commands in that array followed by the name of the data file, so

var ACS5Data = await FileAttachment("./data/acs5_data.json").json();

in a .md file will call and execute:

make -s -f src/data/acs5_data.json.mk

and then acs5_data.json.mk's top output needs to be called src/data/acs5_data.json and needs to be getting output to standard output. (if you don't put the file in the data folder then Observable will re-load the file everytime it goes to build. Which is potentially fine, but for our case it isn't since the data loader takes too long)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants