2020-02-21 14:34:18 -05:00
|
|
|
import { ExcalidrawElement, PointerType } from "./element/types";
|
2020-02-07 18:42:24 +01:00
|
|
|
import { SHAPES } from "./shapes";
|
2020-01-06 20:24:54 +04:00
|
|
|
|
2020-02-19 08:25:01 -08:00
|
|
|
export type FlooredNumber = number & { _brand: "FlooredNumber" };
|
|
|
|
|
2020-01-06 20:24:54 +04:00
|
|
|
export type AppState = {
|
|
|
|
draggingElement: ExcalidrawElement | null;
|
|
|
|
resizingElement: ExcalidrawElement | null;
|
2020-02-01 15:49:18 +04:00
|
|
|
multiElement: ExcalidrawElement | null;
|
2020-02-05 22:47:10 +04:00
|
|
|
selectionElement: ExcalidrawElement | null;
|
2020-01-19 23:32:24 +01:00
|
|
|
// element being edited, but not necessarily added to elements array yet
|
|
|
|
// (e.g. text element when typing into the input)
|
|
|
|
editingElement: ExcalidrawElement | null;
|
2020-02-07 18:42:24 +01:00
|
|
|
elementType: typeof SHAPES[number]["value"];
|
2020-01-20 15:52:19 -08:00
|
|
|
elementLocked: boolean;
|
2020-01-06 20:24:54 +04:00
|
|
|
exportBackground: boolean;
|
|
|
|
currentItemStrokeColor: string;
|
|
|
|
currentItemBackgroundColor: string;
|
2020-01-25 18:58:57 +01:00
|
|
|
currentItemFillStyle: string;
|
|
|
|
currentItemStrokeWidth: number;
|
|
|
|
currentItemRoughness: number;
|
|
|
|
currentItemOpacity: number;
|
2020-01-07 22:21:05 +05:00
|
|
|
currentItemFont: string;
|
2020-01-06 20:24:54 +04:00
|
|
|
viewBackgroundColor: string;
|
2020-02-19 08:25:01 -08:00
|
|
|
scrollX: FlooredNumber;
|
|
|
|
scrollY: FlooredNumber;
|
2020-01-09 12:34:46 +01:00
|
|
|
cursorX: number;
|
|
|
|
cursorY: number;
|
2020-02-01 16:52:10 +00:00
|
|
|
scrolledOutside: boolean;
|
2020-01-06 20:24:54 +04:00
|
|
|
name: string;
|
2020-01-30 16:39:37 -03:00
|
|
|
selectedId?: string;
|
basic Socket.io implementation of collaborative editing (#879)
* Enable collaborative syncing for elements
* Don't fall back to local storage if using a room, as that is confusing
* Use remote socket server
* Send updates to new users when they join
* ~
* add mouse tracking
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* Add Live button and app state to support tracking collaborator counts
* Enable collaborative syncing for elements
* add mouse tracking
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* fix syncing bugs and add a button to start syncing mid session
* Add Live button and app state to support tracking collaborator counts
* prettier
* Fix bug with remote pointers not changing on scroll
* Enable collaborative syncing for elements
* add mouse tracking
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* Add Live button and app state to support tracking collaborator counts
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* fix syncing bugs and add a button to start syncing mid session
* Fix bug with remote pointers not changing on scroll
* remove UI for collaboration
* remove link
* clean up lingering unused UI
* set random IV passed per encrypted message, reduce room id length, refactored socket broadcasting API, rename room_id to room, removed throttling of pointer movement
* fix package.json conflict
2020-03-09 08:48:25 -07:00
|
|
|
isCollaborating: boolean;
|
2020-02-03 21:52:21 +04:00
|
|
|
isResizing: boolean;
|
2020-02-15 21:03:32 +01:00
|
|
|
zoom: number;
|
2020-03-01 14:39:03 -05:00
|
|
|
openMenu: "canvas" | "shape" | null;
|
2020-02-21 14:34:18 -05:00
|
|
|
lastPointerDownWith: PointerType;
|
2020-03-08 10:20:55 -07:00
|
|
|
selectedElementIds: { [id: string]: boolean };
|
basic Socket.io implementation of collaborative editing (#879)
* Enable collaborative syncing for elements
* Don't fall back to local storage if using a room, as that is confusing
* Use remote socket server
* Send updates to new users when they join
* ~
* add mouse tracking
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* Add Live button and app state to support tracking collaborator counts
* Enable collaborative syncing for elements
* add mouse tracking
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* fix syncing bugs and add a button to start syncing mid session
* Add Live button and app state to support tracking collaborator counts
* prettier
* Fix bug with remote pointers not changing on scroll
* Enable collaborative syncing for elements
* add mouse tracking
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* Add Live button and app state to support tracking collaborator counts
* enable collaboration, rooms, and mouse tracking
* fix syncing bugs and add a button to start syncing mid session
* fix syncing bugs and add a button to start syncing mid session
* Fix bug with remote pointers not changing on scroll
* remove UI for collaboration
* remove link
* clean up lingering unused UI
* set random IV passed per encrypted message, reduce room id length, refactored socket broadcasting API, rename room_id to room, removed throttling of pointer movement
* fix package.json conflict
2020-03-09 08:48:25 -07:00
|
|
|
remotePointers: { [id: string]: { x: number; y: number } };
|
|
|
|
collaboratorCount: number;
|
2020-01-06 20:24:54 +04:00
|
|
|
};
|
2020-02-21 08:17:20 -05:00
|
|
|
|
2020-03-08 19:25:16 -07:00
|
|
|
export type PointerCoords = Readonly<{
|
2020-02-21 08:17:20 -05:00
|
|
|
x: number;
|
|
|
|
y: number;
|
|
|
|
}>;
|
|
|
|
|
|
|
|
export type Gesture = {
|
2020-03-08 19:25:16 -07:00
|
|
|
pointers: Map<number, PointerCoords>;
|
2020-02-21 08:17:20 -05:00
|
|
|
lastCenter: { x: number; y: number } | null;
|
|
|
|
initialDistance: number | null;
|
|
|
|
initialScale: number | null;
|
|
|
|
};
|
2020-03-01 14:39:03 -05:00
|
|
|
|
|
|
|
export declare class GestureEvent extends UIEvent {
|
|
|
|
readonly rotation: number;
|
|
|
|
readonly scale: number;
|
|
|
|
}
|