Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/milancermak/graffiti

A Cairo library for building XML based documents
https://github.com/milancermak/graffiti

cairo html starknet svg xml

Last synced: about 2 months ago
JSON representation

A Cairo library for building XML based documents

Awesome Lists containing this project

README

        

# Graffiti

![tests](https://github.com/milancermak/graffiti/actions/workflows/tests.yml/badge.svg)

Graffiti is a Cairo library for building XML based documents - think SVG, HTML, RSS. If it has a ``, you can use Graffiti.

![](./graffiti.png)

## Installation

Add the package as a dependency in Scarb.toml:

```toml
[dependencies]
graffiti = { git = "https://github.com/milancermak/graffiti.git" }
```

## Usage

The main building block of a XML document is a tag. In Graffiti, it's represented by the `Tag` type:

```rust
let div: Tag = TagImpl::new("div");
```

A tag can have any number of `Attributes` assigned to it:

```rust
let div: Tag = TagImpl::new("div").attr("id", "hero").attr("class", "text-center");
```

A tag element can hold textual content:

```rust
let paragraph: Tag = TagImpl::new("p").content("Lorem ipsum dolor sit amet");
```

XML tags can be combined into a tree to get the desired structure:

```rust
let paragraph: Tag = TagImpl::new("p").content("Lorem ipsum dolor sit amet");
let text: Tag: TagImpl::new("text").insert(p);
let h1: Tag = TagImpl::new("h1").content("Graffiti");
let h2: Tag = TagImpl::new("h2").content("An awesome Cairo lib for building XML documents").
let body: Tag = TagImpl::new("body").insert("h1").insert("h2").insert("text");

// the outcome is the following structure:
//

Graffiti

An awesome Cairo lib for building XML documents

Lorem ipsum dolor sit amet


```

Note that Graffiti does not place any constraints on the names or values of the tags or attributes. Any text (Cairo's `ByteArray` type) is accepted. In future versions, there might be specific submodules for building HTML or SVG that do some kind of type checking to achieve valid output.

To get the `ByteArray` representation of the document built in Graffiti, call the `build` function on it. Following the example above:

```rust
assert(
body.build() ==
"

Graffiti

An awesome Cairo lib for building XML documents

Lorem ipsum dolor sit amet

",
"Nope"
);
```

### TagBuilder trait

The `TagBuilder` trait is the centerpiece of building documents with Graffiti:

```rust
trait TagBuilder {
fn new(name: ByteArray) -> T;
fn build(self: T) -> ByteArray;
fn attr(self: T, name: ByteArray, value: ByteArray) -> T;
fn content(self: T, content: ByteArray) -> T;
fn insert(self: T, child: T) -> T;
}
```

`Tag` implements this trait via `TagImpl`. Import both to use Graffiti:

```rust
use graffiti::{Tag, TagImpl};
```

### Examples

Check the [examples](./examples/) folder to see how to build a minimal HTML page, the Starknet logo in SVG or a single Loot bag using this library.