events.rs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. //! Convert a serialized event to an event trigger
  2. use dioxus_core::ElementId;
  3. use dioxus_html::events::*;
  4. use serde::{Deserialize, Serialize};
  5. use serde_json::from_value;
  6. use std::any::Any;
  7. use std::rc::Rc;
  8. #[derive(Deserialize, Serialize)]
  9. pub(crate) struct IpcMessage {
  10. method: String,
  11. params: serde_json::Value,
  12. }
  13. impl IpcMessage {
  14. pub(crate) fn method(&self) -> &str {
  15. self.method.as_str()
  16. }
  17. pub(crate) fn params(self) -> serde_json::Value {
  18. self.params
  19. }
  20. }
  21. pub(crate) fn parse_ipc_message(payload: &str) -> Option<IpcMessage> {
  22. match serde_json::from_str(payload) {
  23. Ok(message) => Some(message),
  24. Err(e) => {
  25. log::error!("could not parse IPC message, error: {}", e);
  26. None
  27. }
  28. }
  29. }
  30. macro_rules! match_data {
  31. (
  32. $m:ident;
  33. $name:ident;
  34. $(
  35. $tip:ty => $($mname:literal)|* ;
  36. )*
  37. ) => {
  38. match $name {
  39. $( $($mname)|* => {
  40. println!("casting to type {:?}", std::any::TypeId::of::<$tip>());
  41. let val: $tip = from_value::<$tip>($m).ok()?;
  42. Rc::new(val) as Rc<dyn Any>
  43. })*
  44. _ => return None,
  45. }
  46. };
  47. }
  48. #[derive(Deserialize)]
  49. pub struct EventMessage {
  50. pub contents: serde_json::Value,
  51. pub event: String,
  52. pub mounted_dom_id: usize,
  53. }
  54. pub fn decode_event(value: EventMessage) -> Option<Rc<dyn Any>> {
  55. let val = value.contents;
  56. let name = value.event.as_str();
  57. type DragData = MouseData;
  58. let evt = match_data! { val; name;
  59. MouseData => "click" | "contextmenu" | "dblclick" | "doubleclick" | "mousedown" | "mouseenter" | "mouseleave" | "mousemove" | "mouseout" | "mouseover" | "mouseup";
  60. ClipboardData => "copy" | "cut" | "paste";
  61. CompositionData => "compositionend" | "compositionstart" | "compositionupdate";
  62. KeyboardData => "keydown" | "keypress" | "keyup";
  63. FocusData => "blur" | "focus" | "focusin" | "focusout";
  64. FormData => "change" | "input" | "invalid" | "reset" | "submit";
  65. DragData => "drag" | "dragend" | "dragenter" | "dragexit" | "dragleave" | "dragover" | "dragstart" | "drop";
  66. PointerData => "pointerlockchange" | "pointerlockerror" | "pointerdown" | "pointermove" | "pointerup" | "pointerover" | "pointerout" | "pointerenter" | "pointerleave" | "gotpointercapture" | "lostpointercapture";
  67. SelectionData => "selectstart" | "selectionchange" | "select";
  68. TouchData => "touchcancel" | "touchend" | "touchmove" | "touchstart";
  69. ScrollData => "scroll";
  70. WheelData => "wheel";
  71. MediaData => "abort" | "canplay" | "canplaythrough" | "durationchange" | "emptied"
  72. | "encrypted" | "ended" | "interruptbegin" | "interruptend" | "loadeddata"
  73. | "loadedmetadata" | "loadstart" | "pause" | "play" | "playing" | "progress"
  74. | "ratechange" | "seeked" | "seeking" | "stalled" | "suspend" | "timeupdate"
  75. | "volumechange" | "waiting" | "error" | "load" | "loadend" | "timeout";
  76. AnimationData => "animationstart" | "animationend" | "animationiteration";
  77. TransitionData => "transitionend";
  78. ToggleData => "toggle";
  79. // ImageData => "load" | "error";
  80. // OtherData => "abort" | "afterprint" | "beforeprint" | "beforeunload" | "hashchange" | "languagechange" | "message" | "offline" | "online" | "pagehide" | "pageshow" | "popstate" | "rejectionhandled" | "storage" | "unhandledrejection" | "unload" | "userproximity" | "vrdisplayactivate" | "vrdisplayblur" | "vrdisplayconnect" | "vrdisplaydeactivate" | "vrdisplaydisconnect" | "vrdisplayfocus" | "vrdisplaypointerrestricted" | "vrdisplaypointerunrestricted" | "vrdisplaypresentchange";
  81. };
  82. Some(evt)
  83. }