enable version bumping for collaboration

This commit is contained in:
idlewinn 2020-03-09 22:34:50 -07:00
parent 30903fbe04
commit 1419f17175
8 changed files with 179 additions and 85 deletions

View file

@ -88,6 +88,7 @@ import { LayerUI } from "./LayerUI";
import { ScrollBars } from "../scene/types";
import { invalidateShapeForElement } from "../renderer/renderElement";
import { generateCollaborationLink, getCollaborationLinkData } from "../data";
import { mutateElement } from "../element/mutateElement";
// -----------------------------------------------------------------------------
// TEST HOOKS
@ -262,7 +263,29 @@ export class App extends React.Component<any, AppState> {
sceneAppState || getDefaultAppState(),
{ scrollToContent: true },
);
elements = restoredState.elements;
if (elements == null || elements.length === 0) {
elements = restoredState.elements;
} else {
const elementMap = elements.reduce(
(
acc: { [key: string]: ExcalidrawElement },
element: ExcalidrawElement,
) => {
acc[element.id] = element;
return acc;
},
{},
);
elements = restoredState.elements.map(element => {
if (
elementMap.hasOwnProperty(element.id) &&
elementMap[element.id].version > element.version
) {
return elementMap[element.id];
}
return element;
});
}
this.setState({});
if (this.socketInitialized === false) {
this.socketInitialized = true;
@ -774,8 +797,10 @@ export class App extends React.Component<any, AppState> {
textY = centerElementYInViewport;
// x and y will change after calling newTextElement function
element.x = centerElementX;
element.y = centerElementY;
mutateElement(element, element => {
element.x = centerElementX;
element.y = centerElementY;
});
} else if (!event.altKey) {
const snappedToCenterPosition = this.getTextWysiwygSnappedToCenterPosition(
x,
@ -783,8 +808,10 @@ export class App extends React.Component<any, AppState> {
);
if (snappedToCenterPosition) {
element.x = snappedToCenterPosition.elementCenterX;
element.y = snappedToCenterPosition.elementCenterY;
mutateElement(element, element => {
element.x = snappedToCenterPosition.elementCenterX;
element.y = snappedToCenterPosition.elementCenterY;
});
textX = snappedToCenterPosition.wysiwygX;
textY = snappedToCenterPosition.wysiwygY;
}
@ -1336,13 +1363,17 @@ export class App extends React.Component<any, AppState> {
const dx = element.x + width + p1[0];
const dy = element.y + height + p1[1];
element.x = dx;
element.y = dy;
mutateElement(element, element => {
element.x = dx;
element.y = dy;
});
p1[0] = absPx - element.x;
p1[1] = absPy - element.y;
} else {
element.x += deltaX;
element.y += deltaY;
mutateElement(element, element => {
element.x += deltaX;
element.y += deltaY;
});
p1[0] -= deltaX;
p1[1] -= deltaY;
}
@ -1452,16 +1483,17 @@ export class App extends React.Component<any, AppState> {
event.shiftKey,
);
} else {
element.width -= deltaX;
element.x += deltaX;
if (event.shiftKey) {
element.y += element.height - element.width;
element.height = element.width;
} else {
element.height -= deltaY;
element.y += deltaY;
}
mutateElement(element, element => {
element.width -= deltaX;
element.x += deltaX;
if (event.shiftKey) {
element.y += element.height - element.width;
element.height = element.width;
} else {
element.height -= deltaY;
element.y += deltaY;
}
});
}
break;
case "ne":
@ -1484,14 +1516,16 @@ export class App extends React.Component<any, AppState> {
event.shiftKey,
);
} else {
element.width += deltaX;
if (event.shiftKey) {
element.y += element.height - element.width;
element.height = element.width;
} else {
element.height -= deltaY;
element.y += deltaY;
}
mutateElement(element, element => {
element.width += deltaX;
if (event.shiftKey) {
element.y += element.height - element.width;
element.height = element.width;
} else {
element.height -= deltaY;
element.y += deltaY;
}
});
}
break;
case "sw":
@ -1514,13 +1548,15 @@ export class App extends React.Component<any, AppState> {
event.shiftKey,
);
} else {
element.width -= deltaX;
element.x += deltaX;
if (event.shiftKey) {
element.height = element.width;
} else {
element.height += deltaY;
}
mutateElement(element, element => {
element.width -= deltaX;
element.x += deltaX;
if (event.shiftKey) {
element.height = element.width;
} else {
element.height += deltaY;
}
});
}
break;
case "se":
@ -1543,18 +1579,22 @@ export class App extends React.Component<any, AppState> {
event.shiftKey,
);
} else {
if (event.shiftKey) {
element.width += deltaX;
element.height = element.width;
} else {
element.width += deltaX;
element.height += deltaY;
}
mutateElement(element, element => {
if (event.shiftKey) {
element.width += deltaX;
element.height = element.width;
} else {
element.width += deltaX;
element.height += deltaY;
}
});
}
break;
case "n": {
element.height -= deltaY;
element.y += deltaY;
mutateElement(element, element => {
element.height -= deltaY;
element.y += deltaY;
});
if (element.points.length > 0) {
const len = element.points.length;
@ -1569,8 +1609,10 @@ export class App extends React.Component<any, AppState> {
break;
}
case "w": {
element.width -= deltaX;
element.x += deltaX;
mutateElement(element, element => {
element.width -= deltaX;
element.x += deltaX;
});
if (element.points.length > 0) {
const len = element.points.length;
@ -1584,29 +1626,37 @@ export class App extends React.Component<any, AppState> {
break;
}
case "s": {
element.height += deltaY;
if (element.points.length > 0) {
const len = element.points.length;
const points = [...element.points].sort((a, b) => a[1] - b[1]);
mutateElement(element, element => {
element.height += deltaY;
if (element.points.length > 0) {
const len = element.points.length;
const points = [...element.points].sort(
(a, b) => a[1] - b[1],
);
for (let i = 1; i < points.length; ++i) {
const pnt = points[i];
pnt[1] += deltaY / (len - i);
for (let i = 1; i < points.length; ++i) {
const pnt = points[i];
pnt[1] += deltaY / (len - i);
}
}
}
});
break;
}
case "e": {
element.width += deltaX;
if (element.points.length > 0) {
const len = element.points.length;
const points = [...element.points].sort((a, b) => a[0] - b[0]);
mutateElement(element, element => {
element.width += deltaX;
if (element.points.length > 0) {
const len = element.points.length;
const points = [...element.points].sort(
(a, b) => a[0] - b[0],
);
for (let i = 1; i < points.length; ++i) {
const pnt = points[i];
pnt[0] += deltaX / (len - i);
for (let i = 1; i < points.length; ++i) {
const pnt = points[i];
pnt[0] += deltaX / (len - i);
}
}
}
});
break;
}
}
@ -1620,8 +1670,10 @@ export class App extends React.Component<any, AppState> {
element,
resizeHandle,
});
el.x = element.x;
el.y = element.y;
mutateElement(el, el => {
el.x = element.x;
el.y = element.y;
});
invalidateShapeForElement(el);
lastX = x;
@ -1644,8 +1696,10 @@ export class App extends React.Component<any, AppState> {
);
selectedElements.forEach(element => {
element.x += x - lastX;
element.y += y - lastY;
mutateElement(element, element => {
element.x += x - lastX;
element.y += y - lastY;
});
});
lastX = x;
lastY = y;
@ -1707,11 +1761,13 @@ export class App extends React.Component<any, AppState> {
}
}
draggingElement.x = x < originX ? originX - width : originX;
draggingElement.y = y < originY ? originY - height : originY;
mutateElement(draggingElement, draggingElement => {
draggingElement.x = x < originX ? originX - width : originX;
draggingElement.y = y < originY ? originY - height : originY;
draggingElement.width = width;
draggingElement.height = height;
draggingElement.width = width;
draggingElement.height = height;
});
}
invalidateShapeForElement(draggingElement);