Skip to main content

A Python package for Hyperify Rune

Project description

Rune

Rune is a tool that combines different types of content (like YAML, HTML, Markdown, TSX, SVG, PNG, ZIP, JPG, and JSON) into one easy-to-use JSON format.

This output is designed to securely serve content through a REST API.

Rune is built for everyone on your team — developers, designers, and content creators. It simplifies collaboration by supporting familiar formats like HTML, YAML, Markdown, and TSX, making it easy to manage assets, translations, and views all in one place.

Metaphor: Rune and the Basket of Fruits

Think of Rune as a master basket weaver, skillfully crafting a basket to hold different kinds of fruits, each familiar to a specific audience:

  • HTML files are like apples — crisp, structured, and familiar to frontend developers.
  • YAML files are like oranges — layered, segmented, and a favorite of backend developers and system architects.
  • JSON translation files are like bananas—rich in meaning, easy to peel apart, and familiar for localization experts.
  • Markdown files are like grapes — small, simple, and versatile, perfect for documentation writers. Markdown is not yet implemented. See #22.
  • Assets (images, downloadable content, etc.) are like cherries — vibrant, eye-catching, and ready to be included.

Rune carefully weaves a basket — a JSON file — that organizes and holds all these fruits together in a portable and structured way. This basket isn't just static; it can be used as-is or handed to a backend, where more fruits (additional data or assets) can be added later to enrich its contents.

The result is an adaptable basket ready for any use case, whether it's for a simple picnic (a static web content) or a grand feast (a dynamic API-driven application).

Key Features

1. Dynamic Content Processing

  • Consolidates YAML (*.yml) and HTML (*.html) files into a single JSON output, embedding any referenced assets as Base64-encoded data URLs.
  • Supports reusable components, nested children, and parameterized elements.

2. Multilingual Support

  • Integrates translations from translations/*.LANG.json files.
  • Outputs a flat i18n structure compatible with popular localization libraries.

3. Embedded Assets

  • Automatically embeds image files and assets as Base64-encoded data URLs.
  • Supports SVG and other image formats with MIME type detection.

4. Portability

  • Outputs a self-contained JSON file that includes all views, translations, and assets.
  • Ideal for static or dynamic web applications.

5. Extensibility

  • Supports custom components and nested structures.
  • Allows easy addition of new file types, assets, or features.

Getting Started

Prerequisites

To use Rune, ensure you have the following installed:

  • Python 3.6 or later
  • Required Python libraries:
    pip install -r requirements.txt
    

Installation

You can install Rune using pip:

pip install hyperify-rune

Or clone the repository for development:

git clone https://github.com/hyperifyio/rune.git
cd rune

Usage

1. Prepare Your Project Directory

Structure your project directory as follows:

project/                 # Contains YAML and HTML files
├── translations/        # Contains translation JSON files
│   ├── HelloWorld.en.json
│   └── HelloWorld.fi.json
├── assets/              # May contain images or other assets (or anywhere else on your system)
└── Makefile             # Makefile for build automation. Optional, for easier rebuild.

2. Add YAML or HTML Views

Example YAML file (views/HelloWorld.yml):

- type: "View"
  name: "HelloWorld"
  body:
  - type: div
    classes:
    - "hello-world-container"
    body:
    - type: h1
      body:
      - "app.title"
  - type: p
    body:
    - "app.content"

Example HTML file (views/HelloWorld.html):

<View name="HelloWorld">
  <div class="hello-world-container">
    <h1>app.title</h1>
    <p>app.content</p>
  </div>
</View>

3. Add Translations

Create translation files in translations/ (e.g., HelloWorld.en.json):

{
  "app.title": "Hello, World!",
  "app.content": "Welcome to Rune!"
}

4. Build the Project

Run Rune to merge all YAML, HTML, and translation files into a single JSON:

python3 rune.py views json

The output will look like this:

[
  {
    "type": "View",
    "name": "HelloWorld",
    "body": [
      {
        "type": "div",
        "classes": ["hello-world-container"],
        "body": [
          {"type": "h1", "body": ["app.title"]},
          {"type": "p", "body": ["app.content"]}
        ]
      }
    ]
  },
  {
    "type": "i18n",
    "data": {
      "en": {
        "app.title": "Hello, World!",
        "app.content": "Welcome to Rune!"
      }
    }
  }
]

Advanced Features

Reusable Components

Define components with parameters and children:

Example (views/UsageCard.html):

<Component name="UsageCard">
  <div class="card">
    <UnfoldableCard title="usageCard.title">
      <Component.Children></Component.Children>
    </UnfoldableCard>
  </div>
</Component>

Embedded Assets

Embed files directly into the JSON output:

Example YAML asset (views/assets.yml):

- type: "Asset"
  name: "logo"
  body: "data:image/png;base64,xxxxx"

Image Handling

Automatically embed images referenced in properties like Image, src, or custom attributes.

Example HTML (views/Example.html):

<Foo heroImage="../assets/logo.png"></Foo>

CLI Options

python3 rune.py <directory> <output_type>
  • <directory>: The project directory containing *.yml, *.html, and translations/.
  • <output_type>: Either json or yml.

License

Rune is licensed under [./LICENSE.md](the Functional Source License, Version 1.1, MIT Future License).


Contact

For questions, feedback, or commercial inquiries, contact us at info@hyperify.io.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hyperify_rune-0.1.1.tar.gz (30.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hyperify_rune-0.1.1-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file hyperify_rune-0.1.1.tar.gz.

File metadata

  • Download URL: hyperify_rune-0.1.1.tar.gz
  • Upload date:
  • Size: 30.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.6

File hashes

Hashes for hyperify_rune-0.1.1.tar.gz
Algorithm Hash digest
SHA256 b8f2645cf15ab87baadbdd84f97a454eaa91c604e21436ccd44913bc33399a86
MD5 eedc25474926dfb5e7169c1a1c4762c1
BLAKE2b-256 38d183ccb5f8c36fb74037202a1e7ec195e811dca0274546103c121be80aabb4

See more details on using hashes here.

File details

Details for the file hyperify_rune-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: hyperify_rune-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 10.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.6

File hashes

Hashes for hyperify_rune-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0ec78bef3a16465bcce2c71142a1858fad938b273e0b82f0f6c63dc70fcc0c25
MD5 ad87f6e5c45cd45d9f5082ab4f3af843
BLAKE2b-256 9edf9d6a21c9b135ec2ebef4cf36eaef05075f760917a8fe3722f62352f75d6e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page