mirror of
https://github.com/scratchfoundation/scratch-paint.git
synced 2025-01-10 14:42:13 -05:00
Merge pull request #68 from fsih/selectionBug
Fix a bunch of things around import and export
This commit is contained in:
commit
09ef88cac1
3 changed files with 39 additions and 17 deletions
|
@ -29,8 +29,9 @@ class PaintEditor extends React.Component {
|
||||||
document.removeEventListener('keydown', this.props.onKeyPress);
|
document.removeEventListener('keydown', this.props.onKeyPress);
|
||||||
}
|
}
|
||||||
handleUpdateSvg (skipSnapshot) {
|
handleUpdateSvg (skipSnapshot) {
|
||||||
// Hide bounding box
|
// Hide guide layer
|
||||||
getGuideLayer().visible = false;
|
const guideLayer = getGuideLayer();
|
||||||
|
guideLayer.remove();
|
||||||
const bounds = paper.project.activeLayer.bounds;
|
const bounds = paper.project.activeLayer.bounds;
|
||||||
this.props.onUpdateSvg(
|
this.props.onUpdateSvg(
|
||||||
paper.project.exportSVG({
|
paper.project.exportSVG({
|
||||||
|
@ -42,7 +43,7 @@ class PaintEditor extends React.Component {
|
||||||
if (!skipSnapshot) {
|
if (!skipSnapshot) {
|
||||||
performSnapshot(this.props.undoSnapshot);
|
performSnapshot(this.props.undoSnapshot);
|
||||||
}
|
}
|
||||||
getGuideLayer().visible = true;
|
paper.project.addLayer(guideLayer);
|
||||||
}
|
}
|
||||||
handleUndo () {
|
handleUndo () {
|
||||||
performUndo(this.props.undoState, this.props.onUndo, this.handleUpdateSvg);
|
performUndo(this.props.undoState, this.props.onUndo, this.handleUpdateSvg);
|
||||||
|
|
|
@ -5,7 +5,8 @@ import {connect} from 'react-redux';
|
||||||
import paper from '@scratch/paper';
|
import paper from '@scratch/paper';
|
||||||
|
|
||||||
import {performSnapshot} from '../helper/undo';
|
import {performSnapshot} from '../helper/undo';
|
||||||
import {undoSnapshot} from '../reducers/undo';
|
import {undoSnapshot, clearUndoState} from '../reducers/undo';
|
||||||
|
import {isGroup, ungroupItems} from '../helper/group';
|
||||||
|
|
||||||
import styles from './paper-canvas.css';
|
import styles from './paper-canvas.css';
|
||||||
|
|
||||||
|
@ -23,17 +24,24 @@ class PaperCanvas extends React.Component {
|
||||||
paper.settings.handleSize = 0;
|
paper.settings.handleSize = 0;
|
||||||
if (this.props.svg) {
|
if (this.props.svg) {
|
||||||
this.importSvg(this.props.svg, this.props.rotationCenterX, this.props.rotationCenterY);
|
this.importSvg(this.props.svg, this.props.rotationCenterX, this.props.rotationCenterY);
|
||||||
}
|
} else {
|
||||||
performSnapshot(this.props.undoSnapshot);
|
performSnapshot(this.props.undoSnapshot);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
componentWillReceiveProps (newProps) {
|
componentWillReceiveProps (newProps) {
|
||||||
paper.project.activeLayer.removeChildren();
|
for (const layer of paper.project.layers) {
|
||||||
|
layer.removeChildren();
|
||||||
|
}
|
||||||
|
this.props.clearUndo();
|
||||||
|
if (newProps.svg) {
|
||||||
this.importSvg(newProps.svg, newProps.rotationCenterX, newProps.rotationCenterY);
|
this.importSvg(newProps.svg, newProps.rotationCenterX, newProps.rotationCenterY);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
componentWillUnmount () {
|
componentWillUnmount () {
|
||||||
paper.remove();
|
paper.remove();
|
||||||
}
|
}
|
||||||
importSvg (svg, rotationCenterX, rotationCenterY) {
|
importSvg (svg, rotationCenterX, rotationCenterY) {
|
||||||
|
const paperCanvas = this;
|
||||||
paper.project.importSVG(svg, {
|
paper.project.importSVG(svg, {
|
||||||
expandShapes: true,
|
expandShapes: true,
|
||||||
onLoad: function (item) {
|
onLoad: function (item) {
|
||||||
|
@ -67,7 +75,11 @@ class PaperCanvas extends React.Component {
|
||||||
// Center
|
// Center
|
||||||
item.position = paper.project.view.center;
|
item.position = paper.project.view.center;
|
||||||
}
|
}
|
||||||
|
if (isGroup(item)) {
|
||||||
|
ungroupItems([item]);
|
||||||
|
}
|
||||||
|
|
||||||
|
performSnapshot(paperCanvas.props.undoSnapshot);
|
||||||
paper.project.view.update();
|
paper.project.view.update();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -92,6 +104,7 @@ class PaperCanvas extends React.Component {
|
||||||
|
|
||||||
PaperCanvas.propTypes = {
|
PaperCanvas.propTypes = {
|
||||||
canvasRef: PropTypes.func,
|
canvasRef: PropTypes.func,
|
||||||
|
clearUndo: PropTypes.func.isRequired,
|
||||||
rotationCenterX: PropTypes.number,
|
rotationCenterX: PropTypes.number,
|
||||||
rotationCenterY: PropTypes.number,
|
rotationCenterY: PropTypes.number,
|
||||||
svg: PropTypes.string,
|
svg: PropTypes.string,
|
||||||
|
@ -100,6 +113,9 @@ PaperCanvas.propTypes = {
|
||||||
const mapDispatchToProps = dispatch => ({
|
const mapDispatchToProps = dispatch => ({
|
||||||
undoSnapshot: snapshot => {
|
undoSnapshot: snapshot => {
|
||||||
dispatch(undoSnapshot(snapshot));
|
dispatch(undoSnapshot(snapshot));
|
||||||
|
},
|
||||||
|
clearUndo: () => {
|
||||||
|
dispatch(clearUndoState());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -23,37 +23,41 @@ const groupSelection = function (clearSelectedItems) {
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
|
|
||||||
const ungroupLoop = function (group, recursive) {
|
const ungroupLoop = function (group, recursive, selectUngroupedItems) {
|
||||||
// don't ungroup items that are not groups
|
// Can't ungroup items that are not groups
|
||||||
if (!group || !group.children || !isGroup(group)) return;
|
if (!group || !group.children || !isGroup(group)) return;
|
||||||
|
|
||||||
group.applyMatrix = true;
|
group.applyMatrix = true;
|
||||||
// iterate over group children recursively
|
// iterate over group children recursively
|
||||||
for (let i = 0; i < group.children.length; i++) {
|
for (let i = 0; i < group.children.length; i++) {
|
||||||
const groupChild = group.children[i];
|
let groupChild = group.children[i];
|
||||||
if (groupChild.hasChildren()) {
|
if (groupChild.hasChildren()) {
|
||||||
// recursion (groups can contain groups, ie. from SVG import)
|
// recursion (groups can contain groups, ie. from SVG import)
|
||||||
if (recursive) {
|
if (recursive) {
|
||||||
ungroupLoop(groupChild, true /* recursive */);
|
ungroupLoop(groupChild, recursive, selectUngroupedItems);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (groupChild.children.length === 1) {
|
||||||
|
groupChild = groupChild.reduce();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
groupChild.applyMatrix = true;
|
groupChild.applyMatrix = true;
|
||||||
// move items from the group to the activeLayer (ungrouping)
|
// move items from the group to the activeLayer (ungrouping)
|
||||||
groupChild.insertBelow(group);
|
groupChild.insertBelow(group);
|
||||||
|
if (selectUngroupedItems) {
|
||||||
groupChild.selected = true;
|
groupChild.selected = true;
|
||||||
|
}
|
||||||
i--;
|
i--;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// ungroup items (only top hierarchy)
|
// ungroup items (only top hierarchy)
|
||||||
const ungroupItems = function (items, clearSelectedItems) {
|
const ungroupItems = function (items, selectUngroupedItems) {
|
||||||
clearSelection(clearSelectedItems);
|
|
||||||
const emptyGroups = [];
|
const emptyGroups = [];
|
||||||
for (let i = 0; i < items.length; i++) {
|
for (let i = 0; i < items.length; i++) {
|
||||||
const item = items[i];
|
const item = items[i];
|
||||||
if (isGroup(item) && !item.data.isPGTextItem) {
|
if (isGroup(item) && !item.data.isPGTextItem) {
|
||||||
ungroupLoop(item, false /* recursive */);
|
ungroupLoop(item, false /* recursive */, selectUngroupedItems /* selectUngroupedItems */);
|
||||||
|
|
||||||
if (!item.hasChildren()) {
|
if (!item.hasChildren()) {
|
||||||
emptyGroups.push(item);
|
emptyGroups.push(item);
|
||||||
|
@ -70,9 +74,10 @@ const ungroupItems = function (items, clearSelectedItems) {
|
||||||
// pg.undo.snapshot('ungroupItems');
|
// pg.undo.snapshot('ungroupItems');
|
||||||
};
|
};
|
||||||
|
|
||||||
const ungroupSelection = function () {
|
const ungroupSelection = function (clearSelectedItems) {
|
||||||
const items = getSelectedRootItems();
|
const items = getSelectedRootItems();
|
||||||
ungroupItems(items);
|
clearSelection(clearSelectedItems);
|
||||||
|
ungroupItems(items, true /* selectUngroupedItems */);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue