2020-03-17 20:55:40 +01:00
|
|
|
import { Point } from "../types";
|
2020-05-27 15:14:50 +02:00
|
|
|
import { FONT_FAMILY } from "../constants";
|
2020-03-17 20:55:40 +01:00
|
|
|
|
2020-05-26 13:07:46 -07:00
|
|
|
export type GroupId = string;
|
|
|
|
|
2020-03-17 20:55:40 +01:00
|
|
|
type _ExcalidrawElementBase = Readonly<{
|
|
|
|
id: string;
|
|
|
|
x: number;
|
|
|
|
y: number;
|
|
|
|
strokeColor: string;
|
|
|
|
backgroundColor: string;
|
|
|
|
fillStyle: string;
|
|
|
|
strokeWidth: number;
|
2020-05-14 17:04:33 +02:00
|
|
|
strokeStyle: "solid" | "dashed" | "dotted";
|
2020-03-17 20:55:40 +01:00
|
|
|
roughness: number;
|
|
|
|
opacity: number;
|
|
|
|
width: number;
|
|
|
|
height: number;
|
2020-04-02 17:40:26 +09:00
|
|
|
angle: number;
|
2020-03-17 20:55:40 +01:00
|
|
|
seed: number;
|
|
|
|
version: number;
|
|
|
|
versionNonce: number;
|
|
|
|
isDeleted: boolean;
|
2020-05-30 22:48:57 +02:00
|
|
|
groupIds: readonly GroupId[];
|
2020-03-17 20:55:40 +01:00
|
|
|
}>;
|
|
|
|
|
2020-05-28 11:41:34 +02:00
|
|
|
export type ExcalidrawSelectionElement = _ExcalidrawElementBase & {
|
|
|
|
type: "selection";
|
|
|
|
};
|
2020-05-26 13:07:46 -07:00
|
|
|
/**
|
|
|
|
* These are elements that don't have any additional properties.
|
|
|
|
*/
|
2020-05-28 11:41:34 +02:00
|
|
|
export type ExcalidrawGenericElement =
|
|
|
|
| ExcalidrawSelectionElement
|
|
|
|
| (_ExcalidrawElementBase & {
|
|
|
|
type: "rectangle" | "diamond" | "ellipse";
|
|
|
|
});
|
2020-01-06 19:34:22 +04:00
|
|
|
|
2020-03-08 10:20:55 -07:00
|
|
|
/**
|
|
|
|
* ExcalidrawElement should be JSON serializable and (eventually) contain
|
|
|
|
* no computed data. The list of all ExcalidrawElements should be shareable
|
|
|
|
* between peers and contain no state local to the peer.
|
|
|
|
*/
|
2020-03-17 20:55:40 +01:00
|
|
|
export type ExcalidrawElement =
|
|
|
|
| ExcalidrawGenericElement
|
|
|
|
| ExcalidrawTextElement
|
|
|
|
| ExcalidrawLinearElement;
|
2020-03-09 22:34:50 -07:00
|
|
|
|
2020-04-08 09:49:52 -07:00
|
|
|
export type NonDeleted<TElement extends ExcalidrawElement> = TElement & {
|
|
|
|
isDeleted: false;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type NonDeletedExcalidrawElement = NonDeleted<ExcalidrawElement>;
|
|
|
|
|
2020-03-17 20:55:40 +01:00
|
|
|
export type ExcalidrawTextElement = _ExcalidrawElementBase &
|
2020-03-10 20:11:02 -07:00
|
|
|
Readonly<{
|
|
|
|
type: "text";
|
2020-05-27 15:14:50 +02:00
|
|
|
fontSize: number;
|
|
|
|
fontFamily: FontFamily;
|
2020-03-10 20:11:02 -07:00
|
|
|
text: string;
|
|
|
|
baseline: number;
|
2020-04-08 21:00:27 +01:00
|
|
|
textAlign: TextAlign;
|
2020-06-25 21:21:27 +02:00
|
|
|
verticalAlign: VerticalAlign;
|
2020-03-10 20:11:02 -07:00
|
|
|
}>;
|
2020-03-09 22:34:50 -07:00
|
|
|
|
2020-03-17 20:55:40 +01:00
|
|
|
export type ExcalidrawLinearElement = _ExcalidrawElementBase &
|
|
|
|
Readonly<{
|
2020-05-12 20:10:11 +01:00
|
|
|
type: "arrow" | "line" | "draw";
|
2020-06-01 11:35:44 +02:00
|
|
|
points: readonly Point[];
|
2020-03-18 16:43:06 +01:00
|
|
|
lastCommittedPoint?: Point | null;
|
2020-03-17 20:55:40 +01:00
|
|
|
}>;
|
|
|
|
|
2020-02-21 14:34:18 -05:00
|
|
|
export type PointerType = "mouse" | "pen" | "touch";
|
2020-04-08 21:00:27 +01:00
|
|
|
|
|
|
|
export type TextAlign = "left" | "center" | "right";
|
2020-06-25 21:21:27 +02:00
|
|
|
export type VerticalAlign = "top" | "middle";
|
2020-05-27 15:14:50 +02:00
|
|
|
|
|
|
|
export type FontFamily = keyof typeof FONT_FAMILY;
|
|
|
|
export type FontString = string & { _brand: "fontString" };
|