您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

types.ts 8.1KB

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