# Writable Book

{% hint style="warning" %}
This tutorial is subject to change in future plugin releases. This feature is experimental.
{% endhint %}

{% tabs %}
{% tab title="Modern (Recommended)" %}
To create a custom writable book you have to declare the written book first.

```yaml
info:
  namespace: test
items:
  written_letter:
    name: Written Letter
    material: WRITTEN_BOOK
    graphics:
      texture: item/other/written_letter
```

Then declare the writable book and specify which properties to copy from the written book, in this case the `item_model`, so that it inherits the texture on write.

```yaml
  letter:
    name: Letter
    material: WRITABLE_BOOK
    graphics:
      texture: item/other/letter
    events:
      book_write:
        replace_properties:
          item_model:
            copy_from_item: test:written_letter
```

{% endtab %}

{% tab title="Old (1.21.3 and lower)" %}
To create a custom writable book you have to declare the written book first.

```yaml
info:
  namespace: test
items:
  letter_written_letter:
    name: Written Letter
    resource:
      material: WRITTEN_BOOK
      generate: true
      textures:
        - item/other/written_letter
```

Then declare the writable book and specify which properties to copy from the written book, in this case the `custom_model_data`, so that it inherits the texture on write.

```yaml
  letter:
    name: Letter
    resource:
      material: WRITABLE_BOOK
      generate: true
      textures:
        - item/other/letter
    events:
      book_write:
        replace_properties:
          custom_model_data:
            copy_from_item: test:letter_written_letter
```

{% endtab %}
{% endtabs %}

<figure><img src="/files/34Xo4EDzhQV60hkTygio" alt=""><figcaption></figcaption></figure>

<figure><img src="/files/O56oeNnw4xEn7dpvhbLI" alt=""><figcaption></figcaption></figure>


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://itemsadder.devs.beer/adding-content/items/writable-book.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
