prune unused function and lint

This commit is contained in:
DD 2017-09-14 14:34:45 -04:00
parent 25478a87fb
commit 67ac013edf
10 changed files with 43 additions and 186 deletions

View file

@ -9,7 +9,7 @@ import {setHoveredItem, clearHoveredItem} from '../reducers/hover';
import {getHoveredItem} from '../helper/hover';
import {rectSelect} from '../helper/guides';
import {clearSelection, selectRootItem, processRectangularSelection} from '../helper/selection';
import {selectRootItem, processRectangularSelection} from '../helper/selection';
import SelectModeComponent from '../components/select-mode.jsx';
import BoundingBoxTool from '../helper/bounding-box/bounding-box-tool';
@ -66,12 +66,18 @@ class SelectMode extends React.Component {
this.boundingBoxTool.setSelectionBounds();
this.tool = new paper.Tool();
// Define these to sate linter
const selectMode = this;
const hoveredItemProp = this.props.hoveredItem;
const setHoveredItemProp = this.props.setHoveredItem;
const onUpdateSvgProp = this.props.onUpdateSvg;
this.tool.onMouseDown = function (event) {
if (event.event.button > 0) return; // only first mouse button
selectMode.props.clearHoveredItem();
if (!selectMode.boundingBoxTool.onMouseDown(
if (!selectMode.boundingBoxTool
.onMouseDown(
event,
event.modifiers.alt,
event.modifiers.shift,
@ -82,14 +88,13 @@ class SelectMode extends React.Component {
this.tool.onMouseMove = function (event) {
const hoveredItem = getHoveredItem(event, selectMode.getHitOptions());
const oldHoveredItem = selectMode.props.hoveredItem;
if ((!hoveredItem && oldHoveredItem) || // There is no longer a hovered item
(hoveredItem && !oldHoveredItem) || // There is now a hovered item
(hoveredItem && oldHoveredItem && hoveredItem.id !== oldHoveredItem.id)) { // hovered item changed
if (oldHoveredItem) {
oldHoveredItem.remove();
if ((!hoveredItem && hoveredItemProp) || // There is no longer a hovered item
(hoveredItem && !hoveredItemProp) || // There is now a hovered item
(hoveredItem && hoveredItemProp && hoveredItem.id !== hoveredItemProp.id)) { // hovered item changed
if (hoveredItemProp) {
hoveredItemProp.remove();
}
selectMode.props.setHoveredItem(hoveredItem);
setHoveredItemProp(hoveredItem);
}
};
@ -111,13 +116,13 @@ class SelectMode extends React.Component {
if (selectMode.selectionBoxMode) {
if (selectMode.selectionRect) {
processRectangularSelection(event, selectMode.selectionRect);
processRectangularSelection(event, selectMode.selectionRect, Modes.SELECT);
selectMode.selectionRect.remove();
}
selectMode.boundingBoxTool.setSelectionBounds();
} else {
selectMode.boundingBoxTool.onMouseUp(event);
selectMode.props.onUpdateSvg();
onUpdateSvgProp();
}
selectMode.selectionBoxMode = false;
selectMode.selectionRect = null;

View file

@ -10,7 +10,12 @@ import RotateTool from './rotate-tool';
import MoveTool from './move-tool';
/** SVG for the rotation icon on the bounding box */
const ARROW_PATH = 'M19.28,1.09C19.28.28,19,0,18.2,0c-1.67,0-3.34,0-5,0-.34,0-.88.24-1,.47a1.4,1.4,0,0,0,.36,1.08,15.27,15.27,0,0,0,1.46,1.36A6.4,6.4,0,0,1,6.52,4,5.85,5.85,0,0,1,5.24,3,15.27,15.27,0,0,0,6.7,1.61,1.4,1.4,0,0,0,7.06.54C7,.3,6.44.07,6.1.06c-1.67,0-3.34,0-5,0C.28,0,0,.31,0,1.12c0,1.67,0,3.34,0,5a1.23,1.23,0,0,0,.49,1,1.22,1.22,0,0,0,1-.31A14.38,14.38,0,0,0,2.84,5.26l.73.62a9.45,9.45,0,0,0,7.34,2,9.45,9.45,0,0,0,4.82-2.05l.73-.62a14.38,14.38,0,0,0,1.29,1.51,1.22,1.22,0,0,0,1,.31,1.23,1.23,0,0,0,.49-1C19.31,4.43,19.29,2.76,19.28,1.09Z';
const ARROW_PATH = 'M19.28,1.09C19.28.28,19,0,18.2,0c-1.67,0-3.34,0-5,0-.34,0-.88.24-1,.47a1.4,1.4,' +
'0,0,0,.36,1.08,15.27,15.27,0,0,0,1.46,1.36A6.4,6.4,0,0,1,6.52,4,5.85,5.85,0,0,1,5.24,3,15.27,15.27,' +
'0,0,0,6.7,1.61,1.4,1.4,0,0,0,7.06.54C7,.3,6.44.07,6.1.06c-1.67,0-3.34,0-5,0C.28,0,0,.31,0,1.12c0,1.67,' +
'0,3.34,0,5a1.23,1.23,0,0,0,.49,1,1.22,1.22,0,0,0,1-.31A14.38,14.38,0,0,0,2.84,5.26l.73.62a9.45,9.45,' +
'0,0,0,7.34,2,9.45,9.45,0,0,0,4.82-2.05l.73-.62a14.38,14.38,0,0,0,1.29,1.51,1.22,1.22,' +
'0,0,0,1,.31,1.23,1.23,0,0,0,.49-1C19.31,4.43,19.29,2.76,19.28,1.09Z';
/** Modes of the bounding box tool, which can do many things depending on how it's used. */
const Modes = keyMirror({
SCALE: null,

View file

@ -19,6 +19,8 @@ class ScaleTool {
/**
* @param {!paper.HitResult} hitResult Data about the location of the mouse click
* @param {!object} boundsPath Where the boundaries of the hit item are
* @param {!object} boundsScaleHandles Bounding box scale handles
* @param {!object} boundsRotHandles Bounding box rotation handle
* @param {!Array.<paper.Item>} selectedItems Set of selected paper.Items
* @param {boolean} clone Whether to clone on mouse down (e.g. alt key held)
* @param {boolean} multiselect Whether to multiselect on mouse down (e.g. shift key held)

View file

@ -20,59 +20,8 @@ const getItemsCompoundPath = function (item) {
};
// const createFromSelection = function () {
// const items = getSelectedPaths();
// if (items.length < 2) return;
// const path = new paper.CompoundPath({fillRule: 'evenodd'});
// for (let i = 0; i < items.length; i++) {
// path.addChild(items[i]);
// items[i].selected = false;
// }
// path = pg.stylebar.applyActiveToolbarStyle(path);
// pg.selection.setItemSelection(path, true);
// pg.undo.snapshot('createCompoundPathFromSelection');
// };
// const releaseSelection = function () {
// const items = pg.selection.getSelectedItems();
// const cPathsToDelete = [];
// for (const i=0; i<items.length; i++) {
// const item = items[i];
// if (isCompoundPath(item)) {
// for (const j=0; j<item.children.length; j++) {
// const path = item.children[j];
// path.parent = item.layer;
// pg.selection.setItemSelection(path, true);
// j--;
// }
// cPathsToDelete.push(item);
// pg.selection.setItemSelection(item, false);
// } else {
// items[i].parent = item.layer;
// }
// }
// for (const j=0; j<cPathsToDelete.length; j++) {
// cPathsToDelete[j].remove();
// }
// pg.undo.snapshot('releaseCompoundPath');
// };
export {
isCompoundPath,
isCompoundPathChild,
getItemsCompoundPath
// createFromSelection,
// releaseSelection
};

View file

@ -15,7 +15,7 @@ const groupSelection = function () {
for (let i = 0; i < group.children.length; i++) {
group.children[i].selected = true;
}
// jQuery(document).trigger('Grouped');
// @todo: Set selection bounds; enable/disable grouping icons
// @todo add back undo
// pg.undo.snapshot('groupSelection');
return group;
@ -65,7 +65,7 @@ const ungroupItems = function (items) {
for (let j = 0; j < emptyGroups.length; j++) {
emptyGroups[j].remove();
}
// jQuery(document).trigger('Ungrouped');
// @todo: Set selection bounds; enable/disable grouping icons
// @todo add back undo
// pg.undo.snapshot('ungroupItems');
};
@ -73,15 +73,13 @@ const ungroupItems = function (items) {
const ungroupSelection = function () {
const items = getSelectedItems();
ungroupItems(items);
// pg.statusbar.update();
};
const groupItems = function (items) {
if (items.length > 0) {
const group = new paper.Group(items);
// jQuery(document).trigger('Grouped');
// @todo: Set selection bounds; enable/disable grouping icons
// @todo add back undo
// pg.undo.snapshot('groupItems');
return group;

View file

@ -57,54 +57,6 @@ const rectSelect = function (event, color) {
return rect;
};
const line = function (from, to, color) {
const theLine = new paper.Path.Line(from, to);
const zoom = 1 / paper.view.zoom;
setDefaultGuideStyle(theLine);
if (!color) color = GUIDE_GREY;
theLine.parent = getGuideLayer();
theLine.strokeColor = color;
theLine.strokeColor = color;
theLine.dashArray = [5 * zoom, 5 * zoom];
theLine.data.isHelperItem = true;
return theLine;
};
const crossPivot = function (center, color) {
const zoom = 1 / paper.view.zoom;
const star = new paper.Path.Star(center, 4, 4 * zoom, 0.5 * zoom);
setDefaultGuideStyle(star);
if (!color) color = GUIDE_BLUE;
star.parent = getGuideLayer();
star.fillColor = color;
star.strokeColor = color;
star.strokeWidth = 0.5 * zoom;
star.data.isHelperItem = true;
star.rotate(45);
return star;
};
const rotPivot = function (center, color) {
const zoom = 1 / paper.view.zoom;
const path = new paper.Path.Circle(center, 3 * zoom);
setDefaultGuideStyle(path);
if (!color) color = GUIDE_BLUE;
path.parent = getGuideLayer();
path.fillColor = color;
path.data.isHelperItem = true;
return path;
};
const label = function (pos, content, color) {
const text = new paper.PointText(pos);
if (!color) color = GUIDE_GREY;
text.parent = getGuideLayer();
text.fillColor = color;
text.content = content;
};
const getGuideColor = function (colorName) {
if (colorName === 'blue') {
return GUIDE_BLUE;
@ -113,60 +65,20 @@ const getGuideColor = function (colorName) {
}
};
const getAllGuides = function () {
const allItems = [];
for (let i = 0; i < paper.project.layers.length; i++) {
const layer = paper.project.layers[i];
for (let j = 0; j < layer.children.length; j++) {
const child = layer.children[j];
// only give guides
if (!child.guide) {
continue;
}
allItems.push(child);
}
}
return allItems;
};
const getExportRectGuide = function () {
const guides = getAllGuides();
for (let i = 0; i < guides.length; i++){
if (guides[i].data && guides[i].data.isExportRect) {
return guides[i];
}
}
};
const removeHelperItems = function () {
removePaperItemsByDataTags(['isHelperItem']);
};
const removeAllGuides = function () {
removePaperItemsByTags(['guide']);
};
const removeExportRectGuide = function () {
removePaperItemsByDataTags(['isExportRect']);
};
export {
hoverItem,
hoverBounds,
rectSelect,
line,
crossPivot,
rotPivot,
label,
removeAllGuides,
removeHelperItems,
removeExportRectGuide,
getAllGuides,
getExportRectGuide,
getGuideColor,
setDefaultGuideStyle
};

View file

@ -28,7 +28,6 @@ const getPaperItemsByTags = function (tags) {
return foundItems;
};
const removePaperItemsByDataTags = function (tags) {
const allItems = getAllPaperItems(true);
for (const item of allItems) {
@ -40,7 +39,6 @@ const removePaperItemsByDataTags = function (tags) {
}
};
const removePaperItemsByTags = function (tags) {
const allItems = getAllPaperItems(true);
for (const item of allItems) {
@ -52,7 +50,6 @@ const removePaperItemsByTags = function (tags) {
}
};
export {
getAllPaperItems,
getPaperItemsByTags,

View file

@ -27,7 +27,6 @@ const snapDeltaToAngle = function (delta, snapAngle) {
return new paper.Point(dirx * d, diry * d);
};
export {
checkPointsClose,
getRandomInt,

View file

@ -58,21 +58,15 @@ const setItemSelection = function (item, state) {
if (parentGroup) {
// do it recursive
setItemSelection(parentGroup, state);
} else if (itemsCompoundPath) {
setItemSelection(itemsCompoundPath, state);
} else {
if (item.data && item.data.noSelect) {
return;
}
setGroupSelection(item, state);
}
// pg.statusbar.update();
// pg.stylebar.updateFromSelection();
// pg.stylebar.blurInputs();
// jQuery(document).trigger('SelectionChanged');
// @todo: Update toolbar state on change
};
@ -94,13 +88,10 @@ const selectAllSegments = function () {
const clearSelection = function () {
paper.project.deselectAll();
// pg.statusbar.update();
// pg.stylebar.blurInputs();
// jQuery(document).trigger('SelectionChanged');
// @todo: Update toolbar state on change
};
// this gets all selected non-grouped items and groups
// This gets all selected non-grouped items and groups
// (alternative to paper.project.selectedItems, which includes
// group children in addition to the group)
// Returns in increasing Z order
@ -137,8 +128,7 @@ const deleteItemSelection = function () {
items[i].remove();
}
// jQuery(document).trigger('DeleteItems');
// jQuery(document).trigger('SelectionChanged');
// @todo: Update toolbar state on change
paper.project.view.update();
// @todo add back undo
// pg.undo.snapshot('deleteItemSelection');
@ -290,8 +280,7 @@ const deleteSegmentSelection = function () {
deleteSegments(items[i]);
}
// jQuery(document).trigger('DeleteSegments');
// jQuery(document).trigger('SelectionChanged');
// @todo: Update toolbar state on change
paper.project.view.update();
// @todo add back undo
// pg.undo.snapshot('deleteSegmentSelection');
@ -308,7 +297,7 @@ const cloneSelection = function () {
// pg.undo.snapshot('cloneSelection');
};
// only returns paths, no compound paths, groups or any other stuff
// Only returns paths, no compound paths, groups or any other stuff
const getSelectedPaths = function () {
const allPaths = getSelectedItems();
const paths = [];
@ -359,7 +348,7 @@ const handleRectangularSelectionItems = function (item, event, rect, mode) {
for (let j = 0; j < item.segments.length; j++) {
const seg = item.segments[j];
if (rect.contains(seg.point)) {
if (mode === 'detail') {
if (mode === Modes.RESHAPE) {
if (event.modifiers.shift && seg.selected) {
seg.selected = false;
} else {
@ -384,7 +373,7 @@ const handleRectangularSelectionItems = function (item, event, rect, mode) {
if (intersections.length > 0 && !segmentMode) {
// if in detail select mode, select the curves that intersect
// with the selectionRect
if (mode === 'detail') {
if (mode === Modes.RESHAPE) {
for (let k = 0; k < intersections.length; k++) {
const curve = intersections[k].curve;
// intersections contains every curve twice because
@ -411,7 +400,7 @@ const handleRectangularSelectionItems = function (item, event, rect, mode) {
return false;
}
}
// pg.statusbar.update();
// @todo: Update toolbar state on change
} else if (isBoundsItem(item)) {
if (checkBoundsItem(rect, item, event)) {
@ -442,7 +431,7 @@ const processRectangularSelection = function (event, rect, mode) {
itemLoop:
for (let i = 0; i < allItems.length; i++) {
const item = allItems[i];
if (mode === 'detail' && isPGTextItem(getRootItem(item))) {
if (mode === Modes.RESHAPE && isPGTextItem(getRootItem(item))) {
continue itemLoop;
}
// check for item segment points inside selectionRect

View file

@ -4,7 +4,8 @@ const Modes = keyMirror({
BRUSH: null,
ERASER: null,
LINE: null,
SELECT: null
SELECT: null,
RESHAPE: null
});
export default Modes;