Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

types.ts 7.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399
  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. isStyleOpen: boolean
  13. nudgeDistanceSmall: number
  14. nudgeDistanceLarge: number
  15. isToolLocked: boolean
  16. isPenLocked: boolean
  17. }
  18. currentStyle: ShapeStyles
  19. camera: {
  20. point: number[]
  21. zoom: number
  22. }
  23. brush?: Bounds
  24. boundsRotation: number
  25. selectedIds: Set<string>
  26. pointedId?: string
  27. hoveredId?: string
  28. currentPageId: string
  29. currentCodeFileId: string
  30. codeControls: Record<string, CodeControl>
  31. document: {
  32. pages: Record<string, Page>
  33. code: Record<string, CodeFile>
  34. }
  35. }
  36. /* -------------------------------------------------- */
  37. /* Document */
  38. /* -------------------------------------------------- */
  39. export interface Page {
  40. id: string
  41. type: 'page'
  42. childIndex: number
  43. name: string
  44. shapes: Record<string, Shape>
  45. }
  46. export enum ShapeType {
  47. Dot = 'dot',
  48. Circle = 'circle',
  49. Ellipse = 'ellipse',
  50. Line = 'line',
  51. Ray = 'ray',
  52. Polyline = 'polyline',
  53. Rectangle = 'rectangle',
  54. Draw = 'draw',
  55. Arrow = 'arrow',
  56. }
  57. // Consider:
  58. // Glob = "glob",
  59. // Spline = "spline",
  60. // Cubic = "cubic",
  61. // Conic = "conic",
  62. export enum ColorStyle {
  63. White = 'White',
  64. LightGray = 'LightGray',
  65. Gray = 'Gray',
  66. Black = 'Black',
  67. Lime = 'Lime',
  68. Green = 'Green',
  69. Teal = 'Teal',
  70. Cyan = 'Cyan',
  71. Blue = 'Blue',
  72. Indigo = 'Indigo',
  73. Violet = 'Violet',
  74. Grape = 'Grape',
  75. Pink = 'Pink',
  76. Red = 'Red',
  77. Orange = 'Orange',
  78. Yellow = 'Yellow',
  79. }
  80. export enum SizeStyle {
  81. Small = 'Small',
  82. Medium = 'Medium',
  83. Large = 'Large',
  84. }
  85. export enum DashStyle {
  86. Solid = 'Solid',
  87. Dashed = 'Dashed',
  88. Dotted = 'Dotted',
  89. }
  90. export type ShapeStyles = {
  91. color: ColorStyle
  92. size: SizeStyle
  93. dash: DashStyle
  94. isFilled: boolean
  95. }
  96. // export type ShapeStyles = Partial<
  97. // React.SVGProps<SVGUseElement> & {
  98. // dash: DashStyle
  99. // }
  100. // >
  101. export interface BaseShape {
  102. id: string
  103. type: ShapeType
  104. parentId: string
  105. childIndex: number
  106. isGenerated: boolean
  107. name: string
  108. point: number[]
  109. rotation: number
  110. bindings?: Record<string, ShapeBinding>
  111. handles?: Record<string, ShapeHandle>
  112. style: ShapeStyles
  113. isLocked: boolean
  114. isHidden: boolean
  115. isAspectRatioLocked: boolean
  116. }
  117. export interface DotShape extends BaseShape {
  118. type: ShapeType.Dot
  119. }
  120. export interface CircleShape extends BaseShape {
  121. type: ShapeType.Circle
  122. radius: number
  123. }
  124. export interface EllipseShape extends BaseShape {
  125. type: ShapeType.Ellipse
  126. radiusX: number
  127. radiusY: number
  128. }
  129. export interface LineShape extends BaseShape {
  130. type: ShapeType.Line
  131. direction: number[]
  132. }
  133. export interface RayShape extends BaseShape {
  134. type: ShapeType.Ray
  135. direction: number[]
  136. }
  137. export interface PolylineShape extends BaseShape {
  138. type: ShapeType.Polyline
  139. points: number[][]
  140. }
  141. export interface RectangleShape extends BaseShape {
  142. type: ShapeType.Rectangle
  143. size: number[]
  144. radius: number
  145. }
  146. export interface DrawShape extends BaseShape {
  147. type: ShapeType.Draw
  148. points: number[][]
  149. }
  150. export interface ArrowShape extends BaseShape {
  151. type: ShapeType.Arrow
  152. points: number[][]
  153. handles: Record<string, ShapeHandle>
  154. bend: number
  155. decorations?: {
  156. start: Decoration
  157. end: Decoration
  158. middle: Decoration
  159. }
  160. }
  161. export type MutableShape =
  162. | DotShape
  163. | CircleShape
  164. | EllipseShape
  165. | LineShape
  166. | RayShape
  167. | PolylineShape
  168. | DrawShape
  169. | RectangleShape
  170. | ArrowShape
  171. export type Shape = Readonly<MutableShape>
  172. export interface Shapes {
  173. [ShapeType.Dot]: Readonly<DotShape>
  174. [ShapeType.Circle]: Readonly<CircleShape>
  175. [ShapeType.Ellipse]: Readonly<EllipseShape>
  176. [ShapeType.Line]: Readonly<LineShape>
  177. [ShapeType.Ray]: Readonly<RayShape>
  178. [ShapeType.Polyline]: Readonly<PolylineShape>
  179. [ShapeType.Draw]: Readonly<DrawShape>
  180. [ShapeType.Rectangle]: Readonly<RectangleShape>
  181. [ShapeType.Arrow]: Readonly<ArrowShape>
  182. }
  183. export type ShapeByType<T extends ShapeType> = Shapes[T]
  184. export interface CodeFile {
  185. id: string
  186. name: string
  187. code: string
  188. }
  189. export enum Decoration {
  190. Arrow = 'Arrow',
  191. }
  192. export interface ShapeBinding {
  193. id: string
  194. index: number
  195. point: number[]
  196. }
  197. export interface ShapeHandle {
  198. id: string
  199. index: number
  200. point: number[]
  201. }
  202. /* -------------------------------------------------- */
  203. /* Editor UI */
  204. /* -------------------------------------------------- */
  205. export interface PointerInfo {
  206. target: string
  207. pointerId: number
  208. origin: number[]
  209. point: number[]
  210. shiftKey: boolean
  211. ctrlKey: boolean
  212. metaKey: boolean
  213. altKey: boolean
  214. }
  215. export enum Edge {
  216. Top = 'top_edge',
  217. Right = 'right_edge',
  218. Bottom = 'bottom_edge',
  219. Left = 'left_edge',
  220. }
  221. export enum Corner {
  222. TopLeft = 'top_left_corner',
  223. TopRight = 'top_right_corner',
  224. BottomRight = 'bottom_right_corner',
  225. BottomLeft = 'bottom_left_corner',
  226. }
  227. export interface Bounds {
  228. minX: number
  229. minY: number
  230. maxX: number
  231. maxY: number
  232. width: number
  233. height: number
  234. }
  235. export interface RotatedBounds extends Bounds {
  236. rotation: number
  237. }
  238. export interface ShapeBounds extends Bounds {
  239. id: string
  240. }
  241. export interface PointSnapshot extends Bounds {
  242. nx: number
  243. nmx: number
  244. ny: number
  245. nmy: number
  246. }
  247. export interface BoundsSnapshot extends PointSnapshot {
  248. nw: number
  249. nh: number
  250. }
  251. export type Difference<A, B> = A extends B ? never : A
  252. export type ShapeSpecificProps<T extends Shape> = Pick<
  253. T,
  254. Difference<keyof T, keyof BaseShape>
  255. >
  256. export type ShapeIndicatorProps<T extends Shape> = ShapeSpecificProps<T>
  257. export type ShapeUtil<K extends Shape> = {
  258. create(props: Partial<K>): K
  259. getBounds(shape: K): Bounds
  260. hitTest(shape: K, test: number[]): boolean
  261. hitTestBounds(shape: K, bounds: Bounds): boolean
  262. rotate(shape: K): K
  263. translate(shape: K, delta: number[]): K
  264. scale(shape: K, scale: number): K
  265. stretch(shape: K, scaleX: number, scaleY: number): K
  266. render(shape: K): JSX.Element
  267. }
  268. export enum MoveType {
  269. Backward,
  270. Forward,
  271. ToFront,
  272. ToBack,
  273. }
  274. export enum AlignType {
  275. Top,
  276. CenterVertical,
  277. Bottom,
  278. Left,
  279. CenterHorizontal,
  280. Right,
  281. }
  282. export enum StretchType {
  283. Horizontal,
  284. Vertical,
  285. }
  286. export enum DistributeType {
  287. Horizontal,
  288. Vertical,
  289. }
  290. /* -------------------------------------------------- */
  291. /* Code Editor */
  292. /* -------------------------------------------------- */
  293. export type IMonaco = typeof monaco
  294. export type IMonacoEditor = monaco.editor.IStandaloneCodeEditor
  295. export enum ControlType {
  296. Number = 'number',
  297. Vector = 'vector',
  298. Text = 'text',
  299. Select = 'select',
  300. }
  301. export interface BaseCodeControl {
  302. id: string
  303. type: ControlType
  304. label: string
  305. }
  306. export interface NumberCodeControl extends BaseCodeControl {
  307. type: ControlType.Number
  308. min?: number
  309. max?: number
  310. value: number
  311. step: number
  312. format?: (value: number) => number
  313. }
  314. export interface VectorCodeControl extends BaseCodeControl {
  315. type: ControlType.Vector
  316. value: number[]
  317. isNormalized: boolean
  318. format?: (value: number[]) => number[]
  319. }
  320. export interface TextCodeControl extends BaseCodeControl {
  321. type: ControlType.Text
  322. value: string
  323. format?: (value: string) => string
  324. }
  325. export interface SelectCodeControl<T extends string = ''>
  326. extends BaseCodeControl {
  327. type: ControlType.Select
  328. value: T
  329. options: T[]
  330. format?: (string: T) => string
  331. }
  332. export type CodeControl =
  333. | NumberCodeControl
  334. | VectorCodeControl
  335. | TextCodeControl
  336. | SelectCodeControl
  337. export type PropsOfType<T extends object, K> = {
  338. [K in keyof T]: T[K] extends boolean ? K : never
  339. }[keyof T]
  340. export type Mutable<T extends Shape> = { -readonly [K in keyof T]: T[K] }