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

inputs.tsx 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import { PointerInfo } from "types"
  2. import { isDarwin } from "utils/utils"
  3. class Inputs {
  4. points: Record<string, PointerInfo> = {}
  5. pointerDown(e: PointerEvent | React.PointerEvent, target: string) {
  6. const { shiftKey, ctrlKey, metaKey, altKey } = e
  7. const info = {
  8. target,
  9. pointerId: e.pointerId,
  10. origin: [e.clientX, e.clientY],
  11. point: [e.clientX, e.clientY],
  12. shiftKey,
  13. ctrlKey,
  14. metaKey: isDarwin() ? metaKey : ctrlKey,
  15. altKey,
  16. }
  17. this.points[e.pointerId] = info
  18. return info
  19. }
  20. pointerEnter(e: PointerEvent | React.PointerEvent, target: string) {
  21. const { shiftKey, ctrlKey, metaKey, altKey } = e
  22. const info = {
  23. target,
  24. pointerId: e.pointerId,
  25. origin: [e.clientX, e.clientY],
  26. point: [e.clientX, e.clientY],
  27. shiftKey,
  28. ctrlKey,
  29. metaKey: isDarwin() ? metaKey : ctrlKey,
  30. altKey,
  31. }
  32. return info
  33. }
  34. pointerMove(e: PointerEvent | React.PointerEvent) {
  35. const { shiftKey, ctrlKey, metaKey, altKey } = e
  36. const prev = this.points[e.pointerId]
  37. const info = {
  38. ...prev,
  39. pointerId: e.pointerId,
  40. point: [e.clientX, e.clientY],
  41. shiftKey,
  42. ctrlKey,
  43. metaKey: isDarwin() ? metaKey : ctrlKey,
  44. altKey,
  45. }
  46. if (this.points[e.pointerId]) {
  47. this.points[e.pointerId] = info
  48. }
  49. return info
  50. }
  51. pointerUp(e: PointerEvent | React.PointerEvent) {
  52. const { shiftKey, ctrlKey, metaKey, altKey } = e
  53. const prev = this.points[e.pointerId]
  54. const info = {
  55. ...prev,
  56. origin: prev?.origin || [e.clientX, e.clientY],
  57. point: [e.clientX, e.clientY],
  58. shiftKey,
  59. ctrlKey,
  60. metaKey: isDarwin() ? metaKey : ctrlKey,
  61. altKey,
  62. }
  63. delete this.points[e.pointerId]
  64. return info
  65. }
  66. wheel(e: WheelEvent) {
  67. const { shiftKey, ctrlKey, metaKey, altKey } = e
  68. return { point: [e.clientX, e.clientY], shiftKey, ctrlKey, metaKey, altKey }
  69. }
  70. get pointer() {
  71. return this.points[Object.keys(this.points)[0]]
  72. }
  73. }
  74. export default new Inputs()