Paint editor for Scratch 3.0
Find a file
Matthew Taylor 671237498c
Merge pull request #244 from mewtaylor/issue/gh-226
Fix GH-226: set enterExitTransitionDurationMs to imperceptibly small value
2018-01-03 15:27:36 -05:00
.tx Adding scratch-l10n dependency 2017-10-19 08:34:13 -04:00
scripts Adding scratch-l10n dependency 2017-10-19 08:34:13 -04:00
src set enterExitDuration to imperceptibly small value 2017-12-29 09:20:29 -05:00
test fix linting, tests 2017-11-08 10:13:17 -05:00
.babelrc add i18n support 2017-08-21 17:58:38 -04:00
.editorconfig Make a paint editor component 2017-07-13 14:03:48 -04:00
.eslintignore newlines 2017-08-21 18:01:41 -04:00
.eslintrc.js Add eslint config scratch 2017-07-17 14:20:32 -04:00
.gitattributes Make a paint editor component 2017-07-13 14:03:48 -04:00
.gitignore ignore generated folders 2017-08-23 17:11:44 -04:00
.travis.yml Attempt to fix canvas dep 2017-11-06 11:58:42 -05:00
LICENSE Make a paint editor component 2017-07-13 14:03:48 -04:00
package.json Add coming soon for bitmap, text tool 2017-12-21 11:24:38 -05:00
README.md add readme 2017-10-12 12:05:38 -04:00
TRADEMARK Make a paint editor component 2017-07-13 14:03:48 -04:00
webpack.config.js Use a raster for the guid layer background 2017-10-25 14:47:40 -04:00

scratch-paint

Scratch paint provides a React component which is a vector paint editor. It is very much still under construction!

Installation

This requires you to have Git and Node.js installed.

In your own node environment/application:

npm install https://github.com/LLK/scratch-paint.git

If you want to edit/play yourself:

git clone https://github.com/LLK/scratch-paint.git
cd scratch-paint
npm install

Playground

This requires Node.js to be installed.

Run the paint editor independent of Scratch by running the development server. Open a Command Prompt or Terminal in the repository and run:

npm start

Then go to http://localhost:8078/playground/. 8078 is BLOB upside-down.

Code for the playground is in scratch-paint/src/playground/playground.jsx. You can change the SVG vector that is passed in, and onUpdateSvg, which is called with the new SVG each time the vector drawing is edited.

How to include in a Node.js App

For an example, check out the scratch-paint/src/playground directory.

In the component:

import PaintEditor from 'scratch-paint';
...
<PaintEditor
    svg={optionalSvg}
    rotationCenterX={optionalCenterPointXRelativeToSvg}
    rotationCenterY={optionalCenterPointYRelativeToSvg}
    onUpdateSvg={handleUpdateSvgFunction}
/>

In the top-level combineReducers function:

import {ScratchPaintReducer} from 'scratch-paint';
...
combineReducers({
	...
    scratchPaint: ScratchPaintReducer
});

Note that scratch-paint expects its state to be in state.scratchPaint so the name must be exact.

Scratch paint shares state with its parent component because it expects to share the parent's IntlProvider, which inserts translations into the state. See the intlProvider setup in scratch-gui here.

Testing

npm run test

Just unit tests:

npm run unit

Individual unit test: (from scratch-paint directory)

./node_modules/.bin/jest ./test/unit/undo-reducer.test.js

Publishing to GitHub Pages

npm run deploy

This will push the currently built playground to the gh-pages branch of the currently tracked remote. If you would like to change where to push to, add a repo url argument:

npm run deploy -- -r <your repo url>

Donate

We provide Scratch free of charge, and want to keep it that way! Please consider making a donation to support our continued engineering, design, community, and resource development efforts. Donations of any size are appreciated. Thank you!