10 releases

0.2.0 Apr 6, 2021
0.2.0-beta2 Apr 5, 2021
0.1.5 Mar 22, 2021
Download history 148/week @ 2021-03-16 77/week @ 2021-03-23 49/week @ 2021-03-30 37/week @ 2021-04-06 34/week @ 2021-04-13 21/week @ 2021-04-20 4/week @ 2021-04-27

94 downloads per month
Used in timemachine

MIT license

667 lines


GitHub last commit Crates.io Docs.rs

A strongly-typed rust interface to the https://napchart.com API.

The public napchart api is pretty barebones right now, but this will let you use it!


Add to your Cargo.toml:

napchart = "0.2"


Creating a new napchart from scratch

Example: https://napchart.com/snapshot/O6kunUfuL

use napchart::prelude::*;

let mut chart = Napchart::default()
let first_lane = chart.get_lane_mut(0).unwrap();
first_lane.add_element(0, 60).unwrap()
    .text("Hour One");
first_lane.add_element(180, 240).unwrap()
    .text("Hour Four");
let second_lane = chart.add_lane();
second_lane.add_element(0, 120).unwrap()
second_lane.add_element(120, 240).unwrap()
    .text("Cool green time");

Downloading a napchart

Example Chart: https://napchart.com/3tbkt

use napchart::api::BlockingClient;

let client = BlockingClient::default();
let rchart = client.get_chart("3tbkt").unwrap();
assert_eq!(rchart.chartid, String::from("3tbkt"));
assert_eq!(rchart.title, Some(String::from("State test chart")));
assert_eq!(rchart.chart.shape, napchart::ChartShape::Circle);
assert_eq!(rchart.chart.lanes_len(), 1);

Uploading a napchart as a snapshot

Example Output: https://napchart.com/snapshot/TpCfggr4i

use napchart::prelude::*;
use napchart::api::BlockingClient;

let client = BlockingClient::default();
let mut chart = Napchart::default();
let lane = chart.add_lane();
lane.add_element(420, 1260)
let upload_builder = chart.upload()
    .title("readme doctest")
let remote_chart = client.create_snapshot(upload_builder).unwrap();


~180K SLoC