Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mkosir/react-magnetic-board

🧲 Light, zero dependencies magnetic board component using HTML5 canvas
https://github.com/mkosir/react-magnetic-board

board canvas magnetic magnetic-board react

Last synced: 15 days ago
JSON representation

🧲 Light, zero dependencies magnetic board component using HTML5 canvas

Awesome Lists containing this project

README

        

# React Magnetic Board

[![npm version][npm-badge]][npm-url]
[![npm bundle size][size-badge]][npm-url]
[![Build Status][build-badge]][build-url]
[![storybook][storybook-badge]][storybook-url]

_Light, zero dependencies magnetic board component using HTML5 canvas 🧲_

![](demo.gif)

## Demo

**[Demos](https://mkosir.github.io/react-magnetic-board)** created with [React DemoTab 📑](https://github.com/mkosir/react-demo-tab)

## Install

```bash
npm install react-magnetic-board
```

## Example

```jsx
import React from 'react';
import ReactDOM from 'react-dom';
import MagneticBoard from 'react-magnetic-board';

const circleSVG = 'M 100, 100 m -75, 0 a 75,75 0 1,0 150,0 a 75,75 0 1,0 -150,0';

const App = () => {
return (

);
};

ReactDOM.render(, document.getElementById('root'));
```

## Props

All of the props are optional.
Below is the complete list of possible props and their options:

> ▶︎ indicates the default value if there's one

**magnet**: _Magnet_ ▶︎ `undefined`
_Magnet = {
**path**: string;
**scale?**: number;
**offsetX?**: number;
**offsetY?**: number;
**fillStyle?**: string;
**shadowColor?**: string;
**shadowBlur?**: number;
**x?**: number;
**y?**: number;
}_
Magnet resource.

**width**: _number_ ▶︎ `500`
Magnetic Board width.

**height**: _number_ ▶︎ `400`
Magnetic Board height.

**className**: _string_ ▶︎ `undefined`
Class name.

**initMagnets**: _Magnet[]_ ▶︎ `[]`
Initialize magnets.

**onUndo**: _boolean_ ▶︎ `undefined`
Inverting 'onUndo' prop value triggers undo command.

**onClear**: _boolean_ ▶︎ `undefined`
Inverting 'onClear' prop value clears the board.

**onMagnetChange**: _Function_ => (**magnets**: _Magnet[]_)
Gets triggered when user changes magnet(s) on the component.

## Development

_Easily set up a local development environment!_

Build all the examples and starts storybook server on [localhost:9009](http://localhost:9009):

- clone
- `npm install`
- `npm start`

OR

Clone this repo on your machine, navigate to its location in the terminal and run:

```bash
npm install
npm link # link your local repo to your global packages
npm run build:watch # build the files and watch for changes
```

Clone project repo that you wish to test with react-magnetic-board library and run:

```bash
npm install
npm link react-magnetic-board # link your local copy into this project's node_modules
npm start
```

**Start coding!** 🎉

## Roadmap

- Move magnet(s)
- Add marker pens and eraser
- Tests

[npm-url]: https://www.npmjs.com/package/react-magnetic-board
[npm-badge]: https://img.shields.io/npm/v/react-magnetic-board.svg
[size-badge]: https://img.shields.io/bundlephobia/minzip/react-magnetic-board.svg
[build-badge]: https://travis-ci.com/mkosir/react-magnetic-board.svg
[build-url]: https://travis-ci.com/mkosir/react-magnetic-board
[storybook-badge]: https://cdn.jsdelivr.net/gh/storybookjs/brand@master/badge/badge-storybook.svg
[storybook-url]: https://github.com/storybookjs/storybook