You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

types.ts 5.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. import * as monaco from "monaco-editor/esm/vs/editor/editor.api"
  2. import React from "react"
  3. /* -------------------------------------------------- */
  4. /* Client State */
  5. /* -------------------------------------------------- */
  6. export interface Data {
  7. isReadOnly: boolean
  8. settings: {
  9. fontSize: number
  10. isDarkMode: boolean
  11. isCodeOpen: boolean
  12. }
  13. camera: {
  14. point: number[]
  15. zoom: number
  16. }
  17. brush?: Bounds
  18. boundsRotation: number
  19. selectedIds: Set<string>
  20. pointedId?: string
  21. hoveredId?: string
  22. currentPageId: string
  23. currentCodeFileId: string
  24. codeControls: Record<string, CodeControl>
  25. document: {
  26. pages: Record<string, Page>
  27. code: Record<string, CodeFile>
  28. }
  29. }
  30. /* -------------------------------------------------- */
  31. /* Document */
  32. /* -------------------------------------------------- */
  33. export interface Page {
  34. id: string
  35. type: "page"
  36. childIndex: number
  37. name: string
  38. shapes: Record<string, Shape>
  39. }
  40. export enum ShapeType {
  41. Dot = "dot",
  42. Circle = "circle",
  43. Ellipse = "ellipse",
  44. Line = "line",
  45. Ray = "ray",
  46. Polyline = "polyline",
  47. Rectangle = "rectangle",
  48. }
  49. // Consider:
  50. // Glob = "glob",
  51. // Spline = "spline",
  52. // Cubic = "cubic",
  53. // Conic = "conic",
  54. export interface BaseShape {
  55. id: string
  56. type: ShapeType
  57. parentId: string
  58. childIndex: number
  59. isGenerated: boolean
  60. name: string
  61. point: number[]
  62. rotation: number
  63. style: Partial<React.SVGProps<SVGUseElement>>
  64. }
  65. export interface DotShape extends BaseShape {
  66. type: ShapeType.Dot
  67. }
  68. export interface CircleShape extends BaseShape {
  69. type: ShapeType.Circle
  70. radius: number
  71. }
  72. export interface EllipseShape extends BaseShape {
  73. type: ShapeType.Ellipse
  74. radiusX: number
  75. radiusY: number
  76. }
  77. export interface LineShape extends BaseShape {
  78. type: ShapeType.Line
  79. direction: number[]
  80. }
  81. export interface RayShape extends BaseShape {
  82. type: ShapeType.Ray
  83. direction: number[]
  84. }
  85. export interface PolylineShape extends BaseShape {
  86. type: ShapeType.Polyline
  87. points: number[][]
  88. }
  89. export interface RectangleShape extends BaseShape {
  90. type: ShapeType.Rectangle
  91. size: number[]
  92. }
  93. export type MutableShape =
  94. | DotShape
  95. | CircleShape
  96. | EllipseShape
  97. | LineShape
  98. | RayShape
  99. | PolylineShape
  100. | RectangleShape
  101. export type Shape = Readonly<MutableShape>
  102. export interface Shapes {
  103. [ShapeType.Dot]: Readonly<DotShape>
  104. [ShapeType.Circle]: Readonly<CircleShape>
  105. [ShapeType.Ellipse]: Readonly<EllipseShape>
  106. [ShapeType.Line]: Readonly<LineShape>
  107. [ShapeType.Ray]: Readonly<RayShape>
  108. [ShapeType.Polyline]: Readonly<PolylineShape>
  109. [ShapeType.Rectangle]: Readonly<RectangleShape>
  110. }
  111. export type ShapeByType<T extends ShapeType> = Shapes[T]
  112. export interface CodeFile {
  113. id: string
  114. name: string
  115. code: string
  116. }
  117. /* -------------------------------------------------- */
  118. /* Editor UI */
  119. /* -------------------------------------------------- */
  120. export interface PointerInfo {
  121. target: string
  122. pointerId: number
  123. origin: number[]
  124. point: number[]
  125. shiftKey: boolean
  126. ctrlKey: boolean
  127. metaKey: boolean
  128. altKey: boolean
  129. }
  130. export enum Edge {
  131. Top = "top_edge",
  132. Right = "right_edge",
  133. Bottom = "bottom_edge",
  134. Left = "left_edge",
  135. }
  136. export enum Corner {
  137. TopLeft = "top_left_corner",
  138. TopRight = "top_right_corner",
  139. BottomRight = "bottom_right_corner",
  140. BottomLeft = "bottom_left_corner",
  141. }
  142. export interface Bounds {
  143. minX: number
  144. minY: number
  145. maxX: number
  146. maxY: number
  147. width: number
  148. height: number
  149. }
  150. export interface RotatedBounds extends Bounds {
  151. rotation: number
  152. }
  153. export interface ShapeBounds extends Bounds {
  154. id: string
  155. }
  156. export interface PointSnapshot extends Bounds {
  157. nx: number
  158. nmx: number
  159. ny: number
  160. nmy: number
  161. }
  162. export interface BoundsSnapshot extends PointSnapshot {
  163. nw: number
  164. nh: number
  165. }
  166. export type Difference<A, B> = A extends B ? never : A
  167. export type ShapeSpecificProps<T extends Shape> = Pick<
  168. T,
  169. Difference<keyof T, keyof BaseShape>
  170. >
  171. export type ShapeIndicatorProps<T extends Shape> = ShapeSpecificProps<T>
  172. export type ShapeUtil<K extends Shape> = {
  173. create(props: Partial<K>): K
  174. getBounds(shape: K): Bounds
  175. hitTest(shape: K, test: number[]): boolean
  176. hitTestBounds(shape: K, bounds: Bounds): boolean
  177. rotate(shape: K): K
  178. translate(shape: K, delta: number[]): K
  179. scale(shape: K, scale: number): K
  180. stretch(shape: K, scaleX: number, scaleY: number): K
  181. render(shape: K): JSX.Element
  182. }
  183. export enum MoveType {
  184. Backward,
  185. Forward,
  186. ToFront,
  187. ToBack,
  188. }
  189. /* -------------------------------------------------- */
  190. /* Code Editor */
  191. /* -------------------------------------------------- */
  192. export type IMonaco = typeof monaco
  193. export type IMonacoEditor = monaco.editor.IStandaloneCodeEditor
  194. export enum ControlType {
  195. Number = "number",
  196. Vector = "vector",
  197. Text = "text",
  198. Select = "select",
  199. }
  200. export interface BaseCodeControl {
  201. id: string
  202. type: ControlType
  203. label: string
  204. }
  205. export interface NumberCodeControl extends BaseCodeControl {
  206. type: ControlType.Number
  207. min?: number
  208. max?: number
  209. value: number
  210. step: number
  211. format?: (value: number) => number
  212. }
  213. export interface VectorCodeControl extends BaseCodeControl {
  214. type: ControlType.Vector
  215. value: number[]
  216. isNormalized: boolean
  217. format?: (value: number[]) => number[]
  218. }
  219. export interface TextCodeControl extends BaseCodeControl {
  220. type: ControlType.Text
  221. value: string
  222. format?: (value: string) => string
  223. }
  224. export interface SelectCodeControl<T extends string = "">
  225. extends BaseCodeControl {
  226. type: ControlType.Select
  227. value: T
  228. options: T[]
  229. format?: (string: T) => string
  230. }
  231. export type CodeControl =
  232. | NumberCodeControl
  233. | VectorCodeControl
  234. | TextCodeControl
  235. | SelectCodeControl