docx-rs 0.4.19

A .docx file writer with Rust/WebAssembly.
Documentation
<p align="center"><img src ="https://github.com/bokuweb/docx-rs/blob/main/logo.png?raw=true" /></p>

<p align="center">
    A .docx file `writer` with Rust/WebAssembly.
</p>

---

[![GitHub Actions Status](https://github.com/bokuweb/docx-rs/workflows/Continuous%20Integration/badge.svg)](https://github.com/bokuweb/docx-rs/actions)
[![docx-rs at crates.io](https://img.shields.io/crates/v/docx-rs.svg)](https://crates.io/crates/docx-rs)
[![](https://img.shields.io/npm/v/docx-wasm.svg)](https://www.npmjs.com/package/docx-wasm)
<a href="https://www.npmjs.com/package/docx-wasm">
<img src="https://img.shields.io/npm/dm/docx-wasm.svg" /></a>

## Installation

### Rust

```
[dependencies]
docx-rs = "0.4"
```

### Browser/Node.js

```
$ pnpm add docx-wasm
```

## Example

### Rust

```rust
use docx_rs::*;

pub fn hello() -> Result<(), DocxError> {
    let path = std::path::Path::new("./hello.docx");
    let file = std::fs::File::create(path).unwrap();
    Docx::new()
        .add_paragraph(Paragraph::new().add_run(Run::new().add_text("Hello")))
        .build()
        .pack(file)?;
    Ok(())
}
```

### Browser

```javascript
import { saveAs } from "file-saver";

// // Note that a dynamic `import` statement here is required due to webpack/webpack#6615,
import("docx-wasm").then((w) => {
  const { buffer } = new w.Docx()
    .addParagraph(
      new w.Paragraph().addRun(new w.Run().addText("Hello world!!"))
    )
    .build();
  saveAs(new Blob([buffer]), "hello.docx");
});
```

### Node.js

```javascript
const w = require("docx-wasm");
const { writeFileSync } = require("fs");

const { buffer } = new w.Docx()
  .addParagraph(new w.Paragraph().addRun(new w.Run().addText("Hello world!!")))
  .build();

writeFileSync("hello.docx", Buffer.from(buffer));
```

### More examples

- [Minimum]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/hello.rs
- [Indent]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/indent.rs
- [Alignment]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/alignment.rs
- [Font]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/font.rs
- [Numbering]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/numbering.rs
- [Table]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/table.rs
- [Comment]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/comment.rs
- [Image]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/image_inline.rs
- [History]https://github.com/bokuweb/docx-rs/blob/master/docx-core/examples/history.rs

## Development

### Requirements

- Node.js 16+
- pnpm 9+
- wasm-pack0.10.1 (https://rustwasm.github.io/wasm-pack/)
- insta (https://github.com/mitsuhiko/insta)

### Examples

You can run example with following code.
Please see `examples` directory.

```sh
$ cargo run --example [EXAMPLE_NAME]
```

For Example if you want to run `hello` example.
Please run following command.

```sh
$ cargo run --example hello
```

So you can see output file in output directory.

### Testing

#### Rust

Please run following command.

```
make lint && make test
```

If snapshot testing is failed, fix code or update snapshot files. (See https://insta.rs/).

```
$ cargo-insta review
```

Then re run test.

```
$ make test
```

#### Wasm

Please run following command.

```
$ cd docx-wasm && pnpm install && pnpm test
```

If snapshot testing is failed, fix code or update snapshot files. (See https://jestjs.io/docs/snapshot-testing).

```
$ pnpm test -- --updateSnapshot
```

## Features

- [x] Paragraph
  - [x] Alignment
  - [x] Indent
  - [x] Numbering
- [x] Run
  - [x] Bold
  - [x] Size
  - [x] Font
  - [x] Color
  - [x] Highlight
  - [x] Underline
  - [x] vanish
  - [x] Italic
  - [x] TextBorder
  - [x] Footnote
- [x] Break
- [x] Header
- [x] Footer
- [x] Comment
- [x] Image
- [x] Style
- [x] Table
- [x] HIstory
- [x] Table of contents
- [ ] Section
- [ ] Textbox