Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dendrofen/react-konva-to-svg
Extend Konva's functionality to export stages as SVG. Enhance the quality of exported images with SVG format.
https://github.com/dendrofen/react-konva-to-svg
canvas canvas-api konva nextjs react-konva react-konva-export react-konva-to-svg react-konva-utils svg svg-canvas
Last synced: 2 months ago
JSON representation
Extend Konva's functionality to export stages as SVG. Enhance the quality of exported images with SVG format.
- Host: GitHub
- URL: https://github.com/dendrofen/react-konva-to-svg
- Owner: dendrofen
- License: mit
- Created: 2023-08-08T21:30:22.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-02-28T07:26:37.000Z (11 months ago)
- Last Synced: 2024-11-03T06:33:19.474Z (3 months ago)
- Topics: canvas, canvas-api, konva, nextjs, react-konva, react-konva-export, react-konva-to-svg, react-konva-utils, svg, svg-canvas
- Language: CSS
- Homepage: https://dendrofen.github.io/react-konva-to-svg/
- Size: 108 KB
- Stars: 13
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# react-konva-to-svg
**Extend Konva's functionality to export stages as SVG. Enhance the quality of exported images with SVG format.**
[![GitHub License](https://img.shields.io/github/license/dendrofen/react-konva-to-svg)](LICENSE)
[![Build Size](https://img.shields.io/bundlephobia/minzip/react-konva-to-svg?label=bundle%20size&style=flat&colorA=000000&colorB=000000)](https://bundlephobia.com/result?p=react-konva-to-svg)
[![Version](https://img.shields.io/npm/v/react-konva-to-svg?style=flat&colorA=000000&colorB=000000)](https://www.npmjs.com/package/react-konva-to-svg)
[![Downloads](https://img.shields.io/npm/dt/react-konva-to-svg.svg?style=flat&colorA=000000&colorB=000000)](https://www.npmjs.com/package/react-konva-to-svg)## Features
- Export Konva stages to SVG format.
- Asynchronous export with progress tracking.
- Before and after export callbacks for custom processing.
- Flexible context with a function that handles Konva stage objects.
- Export results as text SVG or Blob SVG.## Table of Contents
- [Installation](#installation)
- [Usage](#usage)
- [Example](#example)
- [Demo](#demo)
- [Contributing](#contributing)
- [License](#license)## Installation
You can install `react-konva-to-svg` using npm, yarn, or directly from GitHub.
- **npm**: `npm install react-konva-to-svg`
- **yarn**: `yarn add react-konva-to-svg`
- **GitHub**: [GitHub Repository](https://github.com/dendrofen/react-konva-to-svg)## Usage
To use `react-konva-to-svg`, import the library and utilize the `exportStageSVG` function with your Konva stage object. This function allows you to customize the export process.
### `exportStageSVG(stage, blob, options)`
- `stage`: The Konva stage object you want to export.
- `blob` (optional): Set to `true` to export as Blob SVG, or `false` (default) to export as text SVG.
- `options` (optional): An object containing the following callbacks:
- `onBefore`: A callback function called before export. Receives an array `[stage, layer]` as an argument.
- `onAfter`: A callback function called after export. Receives an array `[stage, layer]` as an argument.**Example usage:**
```javascript
import { exportStageSVG } from 'react-konva-to-svg';// Example usage
const stage = /* your Konva stage */;
const result = await exportStageSVG(stage, false, {
onBefore: ([stage, layer]) => {
// Perform actions before export
},
onAfter: ([stage, layer]) => {
// Perform actions after export
},
});
```## Compatibility Notice
#### Node or group does not rendering properly
If some of nodes, or any group does not rendering properly - use node [caching](https://konvajs.org/docs/performance/Shape_Caching.html) for incorrect rendered node withing **onBefore** function.## Demo
Explore a live demo of react-konva-to-svg in action: [Demo](https://dendrofen.github.io/react-konva-to-svg/)