penpot/library
2025-06-01 11:20:26 +02:00
..
.yarn/patches
playground 🐛 Fix incorrect boolean shapes generation on builder 2025-06-01 11:06:00 +02:00
scripts
src/lib 🐛 Fix compatibility issue with penpot 2.7 2025-06-01 11:20:26 +02:00
test
CHANGES.md 🐛 Fix compatibility issue with penpot 2.7 2025-06-01 11:20:26 +02:00
deps.edn
package.json 📎 Prepare for release 1.0.1 of the penpot library 2025-05-29 12:15:17 +02:00
README.md 📚 Add readme for library directory 2025-05-27 10:55:49 +02:00
shadow-cljs.edn
yarn.lock

Penpot Library

A library that exposes a limited set of Penpot's features for programmatic use. Currently, it provides methods to build Penpot files in memory and export them as .penpot files (ZIP archives containing all the necessary data to import them into a Penpot application).

User Guide

How to install

yarn add @penpot/library

Example of use

import * as penpot from "@penpot/library";
import { createWriteStream } from 'fs';
import { Writable } from "stream";

const context = penpot.createBuildContext();


context.addFile({name: "Test File 1"});
context.addPage({name: "Foo Page"});

context.addBoard({
  name: "Foo Board",
  x: 0,
  y: 0,
  width: 500,
  height: 300,
});

context.closeBoard();
context.closeFile();

// Create a file stream to write the zip to
const output = createWriteStream('sample-stream.zip');

// Wrap Node's stream in a WHATWG WritableStream
const writable = Writable.toWeb(output);
await penpot.exportStream(context, writable);

Developer Guide

How to publish

Build the library:

yarn run build

Login on npm:

yarn npm login

Publish on npm:

yarn npm publish --access public

License

This Source Code Form is subject to the terms of the Mozilla Public
License, v. 2.0. If a copy of the MPL was not distributed with this
file, You can obtain one at http://mozilla.org/MPL/2.0/.

Copyright (c) KALEIDOS INC