events.rs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. //! Convert a serialized event to an event Trigger
  2. //!
  3. use std::any::Any;
  4. use std::sync::Arc;
  5. use dioxus_core::{ElementId, EventPriority, UserEvent};
  6. use dioxus_html::on::*;
  7. #[derive(serde::Serialize, serde::Deserialize)]
  8. struct ImEvent {
  9. event: String,
  10. mounted_dom_id: u64,
  11. // scope: u64,
  12. contents: serde_json::Value,
  13. }
  14. pub fn trigger_from_serialized(val: serde_json::Value) -> UserEvent {
  15. let ims: Vec<ImEvent> = serde_json::from_value(val).unwrap();
  16. let ImEvent {
  17. event,
  18. mounted_dom_id,
  19. contents,
  20. } = ims.into_iter().next().unwrap();
  21. // let scope_id = ScopeId(scope as usize);
  22. let mounted_dom_id = Some(ElementId(mounted_dom_id as usize));
  23. let name = event_name_from_typ(&event);
  24. let event = make_synthetic_event(&event, contents);
  25. UserEvent {
  26. name,
  27. priority: EventPriority::Low,
  28. scope_id: None,
  29. element: mounted_dom_id,
  30. data: event,
  31. }
  32. }
  33. fn make_synthetic_event(name: &str, val: serde_json::Value) -> Arc<dyn Any + Send + Sync> {
  34. match name {
  35. "copy" | "cut" | "paste" => {
  36. //
  37. Arc::new(ClipboardData {})
  38. }
  39. "compositionend" | "compositionstart" | "compositionupdate" => {
  40. Arc::new(serde_json::from_value::<CompositionData>(val).unwrap())
  41. }
  42. "keydown" | "keypress" | "keyup" => {
  43. let evt = serde_json::from_value::<KeyboardData>(val).unwrap();
  44. Arc::new(evt)
  45. }
  46. "focus" | "blur" | "focusout" | "focusin" => {
  47. //
  48. Arc::new(FocusData {})
  49. }
  50. // todo: these handlers might get really slow if the input box gets large and allocation pressure is heavy
  51. // don't have a good solution with the serialized event problem
  52. "change" | "input" | "invalid" | "reset" | "submit" => {
  53. Arc::new(serde_json::from_value::<FormData>(val).unwrap())
  54. }
  55. "click" | "contextmenu" | "doubleclick" | "drag" | "dragend" | "dragenter" | "dragexit"
  56. | "dragleave" | "dragover" | "dragstart" | "drop" | "mousedown" | "mouseenter"
  57. | "mouseleave" | "mousemove" | "mouseout" | "mouseover" | "mouseup" => {
  58. Arc::new(serde_json::from_value::<MouseData>(val).unwrap())
  59. }
  60. "pointerdown" | "pointermove" | "pointerup" | "pointercancel" | "gotpointercapture"
  61. | "lostpointercapture" | "pointerenter" | "pointerleave" | "pointerover" | "pointerout" => {
  62. Arc::new(serde_json::from_value::<PointerData>(val).unwrap())
  63. }
  64. "select" => {
  65. //
  66. Arc::new(serde_json::from_value::<SelectionData>(val).unwrap())
  67. }
  68. "touchcancel" | "touchend" | "touchmove" | "touchstart" => {
  69. Arc::new(serde_json::from_value::<TouchData>(val).unwrap())
  70. }
  71. "scroll" => Arc::new(()),
  72. "wheel" => Arc::new(serde_json::from_value::<WheelData>(val).unwrap()),
  73. "animationstart" | "animationend" | "animationiteration" => {
  74. Arc::new(serde_json::from_value::<AnimationData>(val).unwrap())
  75. }
  76. "transitionend" => Arc::new(serde_json::from_value::<TransitionData>(val).unwrap()),
  77. "abort" | "canplay" | "canplaythrough" | "durationchange" | "emptied" | "encrypted"
  78. | "ended" | "error" | "loadeddata" | "loadedmetadata" | "loadstart" | "pause" | "play"
  79. | "playing" | "progress" | "ratechange" | "seeked" | "seeking" | "stalled" | "suspend"
  80. | "timeupdate" | "volumechange" | "waiting" => {
  81. //
  82. Arc::new(MediaData {})
  83. }
  84. "toggle" => Arc::new(ToggleData {}),
  85. _ => Arc::new(()),
  86. }
  87. }
  88. fn event_name_from_typ(typ: &str) -> &'static str {
  89. match typ {
  90. "copy" => "copy",
  91. "cut" => "cut",
  92. "paste" => "paste",
  93. "compositionend" => "compositionend",
  94. "compositionstart" => "compositionstart",
  95. "compositionupdate" => "compositionupdate",
  96. "keydown" => "keydown",
  97. "keypress" => "keypress",
  98. "keyup" => "keyup",
  99. "focus" => "focus",
  100. "focusout" => "focusout",
  101. "focusin" => "focusin",
  102. "blur" => "blur",
  103. "change" => "change",
  104. "input" => "input",
  105. "invalid" => "invalid",
  106. "reset" => "reset",
  107. "submit" => "submit",
  108. "click" => "click",
  109. "contextmenu" => "contextmenu",
  110. "doubleclick" => "doubleclick",
  111. "drag" => "drag",
  112. "dragend" => "dragend",
  113. "dragenter" => "dragenter",
  114. "dragexit" => "dragexit",
  115. "dragleave" => "dragleave",
  116. "dragover" => "dragover",
  117. "dragstart" => "dragstart",
  118. "drop" => "drop",
  119. "mousedown" => "mousedown",
  120. "mouseenter" => "mouseenter",
  121. "mouseleave" => "mouseleave",
  122. "mousemove" => "mousemove",
  123. "mouseout" => "mouseout",
  124. "mouseover" => "mouseover",
  125. "mouseup" => "mouseup",
  126. "pointerdown" => "pointerdown",
  127. "pointermove" => "pointermove",
  128. "pointerup" => "pointerup",
  129. "pointercancel" => "pointercancel",
  130. "gotpointercapture" => "gotpointercapture",
  131. "lostpointercapture" => "lostpointercapture",
  132. "pointerenter" => "pointerenter",
  133. "pointerleave" => "pointerleave",
  134. "pointerover" => "pointerover",
  135. "pointerout" => "pointerout",
  136. "select" => "select",
  137. "touchcancel" => "touchcancel",
  138. "touchend" => "touchend",
  139. "touchmove" => "touchmove",
  140. "touchstart" => "touchstart",
  141. "scroll" => "scroll",
  142. "wheel" => "wheel",
  143. "animationstart" => "animationstart",
  144. "animationend" => "animationend",
  145. "animationiteration" => "animationiteration",
  146. "transitionend" => "transitionend",
  147. "abort" => "abort",
  148. "canplay" => "canplay",
  149. "canplaythrough" => "canplaythrough",
  150. "durationchange" => "durationchange",
  151. "emptied" => "emptied",
  152. "encrypted" => "encrypted",
  153. "ended" => "ended",
  154. "error" => "error",
  155. "loadeddata" => "loadeddata",
  156. "loadedmetadata" => "loadedmetadata",
  157. "loadstart" => "loadstart",
  158. "pause" => "pause",
  159. "play" => "play",
  160. "playing" => "playing",
  161. "progress" => "progress",
  162. "ratechange" => "ratechange",
  163. "seeked" => "seeked",
  164. "seeking" => "seeking",
  165. "stalled" => "stalled",
  166. "suspend" => "suspend",
  167. "timeupdate" => "timeupdate",
  168. "volumechange" => "volumechange",
  169. "waiting" => "waiting",
  170. "toggle" => "toggle",
  171. _ => {
  172. panic!("unsupported event type")
  173. }
  174. }
  175. }