mirror of
https://github.com/scratchfoundation/scratch-paint.git
synced 2025-01-10 06:32:07 -05:00
Merge pull request #8 from fsih/paintGuiIntegration
Fix the paint library so that it works in GUI
This commit is contained in:
commit
f3f4734ba4
7 changed files with 43 additions and 40 deletions
26
package.json
26
package.json
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"name": "scratch-blobs",
|
"name": "scratch-paint",
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"description": "Graphical User Interface for the Scratch 3.0 paint editor, which is used to make and edit sprites for use in projects.",
|
"description": "Graphical User Interface for the Scratch 3.0 paint editor, which is used to make and edit sprites for use in projects.",
|
||||||
"main": "./dist/scratch-paint.js",
|
"main": "./dist/scratch-paint.js",
|
||||||
|
@ -27,12 +27,12 @@
|
||||||
"react-dom": "^15"
|
"react-dom": "^15"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"autoprefixer": "7.1.1",
|
"autoprefixer": "7.1.2",
|
||||||
"babel-cli": "6.24.1",
|
"babel-cli": "6.26.0",
|
||||||
"babel-core": "^6.23.1",
|
"babel-core": "^6.23.1",
|
||||||
"babel-eslint": "^7.1.1",
|
"babel-eslint": "^7.2.3",
|
||||||
"babel-jest": "^20.0.3",
|
"babel-jest": "^20.0.3",
|
||||||
"babel-loader": "^7.0.0",
|
"babel-loader": "^7.1.0",
|
||||||
"babel-plugin-react-intl": "2.3.1",
|
"babel-plugin-react-intl": "2.3.1",
|
||||||
"babel-plugin-transform-object-rest-spread": "^6.22.0",
|
"babel-plugin-transform-object-rest-spread": "^6.22.0",
|
||||||
"babel-preset-es2015": "^6.22.0",
|
"babel-preset-es2015": "^6.22.0",
|
||||||
|
@ -40,13 +40,13 @@
|
||||||
"classnames": "2.2.5",
|
"classnames": "2.2.5",
|
||||||
"css-loader": "0.28.3",
|
"css-loader": "0.28.3",
|
||||||
"enzyme": "^2.8.2",
|
"enzyme": "^2.8.2",
|
||||||
"eslint": "^3.16.1",
|
"eslint": "^4.4.1",
|
||||||
"eslint-config-import": "^0.13.0",
|
"eslint-config-import": "^0.13.0",
|
||||||
"eslint-config-scratch": "^3.0.0",
|
"eslint-config-scratch": "^4.0.0",
|
||||||
"eslint-plugin-import": "^2.7.0",
|
"eslint-plugin-import": "^2.7.0",
|
||||||
"eslint-plugin-react": "^7.0.1",
|
"eslint-plugin-react": "^7.2.1",
|
||||||
"gh-pages": "github:rschamp/gh-pages#publish-branch-to-subfolder",
|
"gh-pages": "github:rschamp/gh-pages#publish-branch-to-subfolder",
|
||||||
"html-webpack-plugin": "2.28.0",
|
"html-webpack-plugin": "2.30.0",
|
||||||
"jest": "^20.0.4",
|
"jest": "^20.0.4",
|
||||||
"keymirror": "0.1.1",
|
"keymirror": "0.1.1",
|
||||||
"lodash.bindall": "4.4.0",
|
"lodash.bindall": "4.4.0",
|
||||||
|
@ -59,20 +59,20 @@
|
||||||
"postcss-simple-vars": "^4.0.0",
|
"postcss-simple-vars": "^4.0.0",
|
||||||
"prop-types": "^15.5.10",
|
"prop-types": "^15.5.10",
|
||||||
"react": "15.6.1",
|
"react": "15.6.1",
|
||||||
"react-dom": "15.5.4",
|
"react-dom": "15.6.1",
|
||||||
"react-intl": "2.3.0",
|
"react-intl": "2.3.0",
|
||||||
"react-intl-redux": "0.6.0",
|
"react-intl-redux": "0.6.0",
|
||||||
"react-redux": "5.0.5",
|
"react-redux": "5.0.5",
|
||||||
"react-test-renderer": "^15.5.4",
|
"react-test-renderer": "^15.5.4",
|
||||||
"redux": "3.6.0",
|
"redux": "3.7.0",
|
||||||
"redux-mock-store": "^1.2.3",
|
"redux-mock-store": "^1.2.3",
|
||||||
"redux-throttle": "0.1.1",
|
"redux-throttle": "0.1.1",
|
||||||
"regenerator-runtime": "^0.10.5",
|
"regenerator-runtime": "^0.10.5",
|
||||||
"rimraf": "^2.6.1",
|
"rimraf": "^2.6.1",
|
||||||
"style-loader": "^0.18.0",
|
"style-loader": "^0.18.0",
|
||||||
"tap": "^10.2.0",
|
"tap": "^10.2.0",
|
||||||
"webpack": "^2.4.1",
|
"webpack": "^3.5.4",
|
||||||
"webpack-dev-server": "^2.4.1"
|
"webpack-dev-server": "^2.7.0"
|
||||||
},
|
},
|
||||||
"jest": {
|
"jest": {
|
||||||
"moduleNameMapper": {
|
"moduleNameMapper": {
|
||||||
|
|
|
@ -1,8 +1,15 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
|
import {FormattedMessage} from 'react-intl';
|
||||||
|
|
||||||
const EraserModeComponent = props => (
|
const EraserModeComponent = props => (
|
||||||
<button onClick={props.onMouseDown}>Eraser</button>
|
<button onClick={props.onMouseDown}>
|
||||||
|
<FormattedMessage
|
||||||
|
defaultMessage="Eraser"
|
||||||
|
description="Label for the eraser tool"
|
||||||
|
id="paint.eraserMode.eraser"
|
||||||
|
/>
|
||||||
|
</button>
|
||||||
);
|
);
|
||||||
|
|
||||||
EraserModeComponent.propTypes = {
|
EraserModeComponent.propTypes = {
|
||||||
|
|
|
@ -64,7 +64,7 @@ class Blobbiness {
|
||||||
|
|
||||||
this.tool.onMouseDown = function (event) {
|
this.tool.onMouseDown = function (event) {
|
||||||
blob.resizeCursorIfNeeded(event.point);
|
blob.resizeCursorIfNeeded(event.point);
|
||||||
if (event.event.button > 0) return; // only first mouse button
|
if (event.event.button > 0) return; // only first mouse button
|
||||||
|
|
||||||
if (blob.options.brushSize < Blobbiness.THRESHOLD) {
|
if (blob.options.brushSize < Blobbiness.THRESHOLD) {
|
||||||
blob.brush = Blobbiness.BROAD;
|
blob.brush = Blobbiness.BROAD;
|
||||||
|
@ -80,7 +80,7 @@ class Blobbiness {
|
||||||
|
|
||||||
this.tool.onMouseDrag = function (event) {
|
this.tool.onMouseDrag = function (event) {
|
||||||
blob.resizeCursorIfNeeded(event.point);
|
blob.resizeCursorIfNeeded(event.point);
|
||||||
if (event.event.button > 0) return; // only first mouse button
|
if (event.event.button > 0) return; // only first mouse button
|
||||||
if (blob.brush === Blobbiness.BROAD) {
|
if (blob.brush === Blobbiness.BROAD) {
|
||||||
blob.broadBrushHelper.onBroadMouseDrag(event, blob.tool, blob.options);
|
blob.broadBrushHelper.onBroadMouseDrag(event, blob.tool, blob.options);
|
||||||
} else if (blob.brush === Blobbiness.SEGMENT) {
|
} else if (blob.brush === Blobbiness.SEGMENT) {
|
||||||
|
@ -96,7 +96,7 @@ class Blobbiness {
|
||||||
|
|
||||||
this.tool.onMouseUp = function (event) {
|
this.tool.onMouseUp = function (event) {
|
||||||
blob.resizeCursorIfNeeded(event.point);
|
blob.resizeCursorIfNeeded(event.point);
|
||||||
if (event.event.button > 0) return; // only first mouse button
|
if (event.event.button > 0) return; // only first mouse button
|
||||||
|
|
||||||
let lastPath;
|
let lastPath;
|
||||||
if (blob.brush === Blobbiness.BROAD) {
|
if (blob.brush === Blobbiness.BROAD) {
|
||||||
|
|
|
@ -22,7 +22,7 @@ class BroadBrushHelper {
|
||||||
onBroadMouseDown (event, tool, options) {
|
onBroadMouseDown (event, tool, options) {
|
||||||
tool.minDistance = options.brushSize / 2;
|
tool.minDistance = options.brushSize / 2;
|
||||||
tool.maxDistance = options.brushSize;
|
tool.maxDistance = options.brushSize;
|
||||||
if (event.event.button > 0) return; // only first mouse button
|
if (event.event.button > 0) return; // only first mouse button
|
||||||
|
|
||||||
this.finalPath = new paper.Path();
|
this.finalPath = new paper.Path();
|
||||||
stylePath(this.finalPath, options.isEraser);
|
stylePath(this.finalPath, options.isEraser);
|
||||||
|
|
|
@ -22,7 +22,7 @@ class SegmentBrushHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
onSegmentMouseDown (event, tool, options) {
|
onSegmentMouseDown (event, tool, options) {
|
||||||
if (event.event.button > 0) return; // only first mouse button
|
if (event.event.button > 0) return; // only first mouse button
|
||||||
|
|
||||||
tool.minDistance = 1;
|
tool.minDistance = 1;
|
||||||
tool.maxDistance = options.brushSize;
|
tool.maxDistance = options.brushSize;
|
||||||
|
@ -37,7 +37,7 @@ class SegmentBrushHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
onSegmentMouseDrag (event, tool, options) {
|
onSegmentMouseDrag (event, tool, options) {
|
||||||
if (event.event.button > 0) return; // only first mouse button
|
if (event.event.button > 0) return; // only first mouse button
|
||||||
|
|
||||||
const step = (event.delta).normalize(options.brushSize / 2);
|
const step = (event.delta).normalize(options.brushSize / 2);
|
||||||
const handleVec = step.clone();
|
const handleVec = step.clone();
|
||||||
|
@ -75,7 +75,7 @@ class SegmentBrushHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
onSegmentMouseUp (event) {
|
onSegmentMouseUp (event) {
|
||||||
if (event.event.button > 0) return; // only first mouse button
|
if (event.event.button > 0) return; // only first mouse button
|
||||||
|
|
||||||
// TODO: This smoothing tends to cut off large portions of the path! Would like to eventually
|
// TODO: This smoothing tends to cut off large portions of the path! Would like to eventually
|
||||||
// add back smoothing, maybe a custom implementation that only applies to a subset of the line?
|
// add back smoothing, maybe a custom implementation that only applies to a subset of the line?
|
||||||
|
|
|
@ -19,6 +19,6 @@ test('changeMode', () => {
|
||||||
|
|
||||||
test('invalidChangeMode', () => {
|
test('invalidChangeMode', () => {
|
||||||
expect(reducer(Modes.BRUSH /* state */, changeMode('non-existant mode') /* action */))
|
expect(reducer(Modes.BRUSH /* state */, changeMode('non-existant mode') /* action */))
|
||||||
.toBe(Modes.BRUSH);
|
.toBe(Modes.BRUSH);
|
||||||
expect(reducer(Modes.BRUSH /* state */, changeMode() /* action */)).toBe(Modes.BRUSH);
|
expect(reducer(Modes.BRUSH /* state */, changeMode() /* action */)).toBe(Modes.BRUSH);
|
||||||
});
|
});
|
||||||
|
|
|
@ -12,10 +12,6 @@ const postcssImport = require('postcss-import');
|
||||||
|
|
||||||
const base = {
|
const base = {
|
||||||
devtool: 'cheap-module-source-map',
|
devtool: 'cheap-module-source-map',
|
||||||
externals: {
|
|
||||||
React: 'react',
|
|
||||||
ReactDOM: 'react-dom'
|
|
||||||
},
|
|
||||||
module: {
|
module: {
|
||||||
rules: [{
|
rules: [{
|
||||||
test: /\.jsx?$/,
|
test: /\.jsx?$/,
|
||||||
|
@ -55,17 +51,13 @@ const base = {
|
||||||
}]
|
}]
|
||||||
}]
|
}]
|
||||||
},
|
},
|
||||||
plugins: [
|
plugins: []
|
||||||
new webpack.optimize.CommonsChunkPlugin({
|
.concat(process.env.NODE_ENV === 'production' ? [
|
||||||
name: 'lib',
|
new webpack.optimize.UglifyJsPlugin({
|
||||||
filename: 'lib.min.js'
|
include: /\.min\.js$/,
|
||||||
})
|
minimize: true
|
||||||
].concat(process.env.NODE_ENV === 'production' ? [
|
})
|
||||||
new webpack.optimize.UglifyJsPlugin({
|
] : [])
|
||||||
include: /\.min\.js$/,
|
|
||||||
minimize: true
|
|
||||||
})
|
|
||||||
] : [])
|
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports = [
|
module.exports = [
|
||||||
|
@ -77,7 +69,6 @@ module.exports = [
|
||||||
port: process.env.PORT || 8078
|
port: process.env.PORT || 8078
|
||||||
},
|
},
|
||||||
entry: {
|
entry: {
|
||||||
lib: ['react', 'react-dom'],
|
|
||||||
playground: './src/playground/playground.jsx'
|
playground: './src/playground/playground.jsx'
|
||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
|
@ -93,13 +84,18 @@ module.exports = [
|
||||||
}),
|
}),
|
||||||
// For use as a library
|
// For use as a library
|
||||||
defaultsDeep({}, base, {
|
defaultsDeep({}, base, {
|
||||||
|
externals: {
|
||||||
|
'react': 'react',
|
||||||
|
'react-dom': 'react-dom',
|
||||||
|
'minilog': 'minilog'
|
||||||
|
},
|
||||||
entry: {
|
entry: {
|
||||||
'lib': ['react', 'react-dom'],
|
|
||||||
'scratch-paint': './src/index.js'
|
'scratch-paint': './src/index.js'
|
||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
path: path.resolve(__dirname, 'dist'),
|
path: path.resolve(__dirname, 'dist'),
|
||||||
filename: '[name].js'
|
filename: '[name].js',
|
||||||
|
libraryTarget: 'commonjs2'
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
|
|
Loading…
Reference in a new issue