build.rs 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. use dioxus_interpreter_js::binary_protocol::SLEDGEHAMMER_JS;
  2. use std::io::Write;
  3. const EDITS_PATH: &str = {
  4. #[cfg(any(target_os = "android", target_os = "windows"))]
  5. {
  6. "http://dioxus.index.html/edits"
  7. }
  8. #[cfg(not(any(target_os = "android", target_os = "windows")))]
  9. {
  10. "dioxus://index.html/edits"
  11. }
  12. };
  13. fn main() {
  14. let prevent_file_upload = r#"// Prevent file inputs from opening the file dialog on click
  15. let inputs = document.querySelectorAll("input");
  16. for (let input of inputs) {
  17. if (!input.getAttribute("data-dioxus-file-listener")) {
  18. // prevent file inputs from opening the file dialog on click
  19. const type = input.getAttribute("type");
  20. if (type === "file") {
  21. input.setAttribute("data-dioxus-file-listener", true);
  22. input.addEventListener("click", (event) => {
  23. let target = event.target;
  24. let target_id = find_real_id(target);
  25. if (target_id !== null) {
  26. const send = (event_name) => {
  27. const message = window.interpreter.serializeIpcMessage("file_diolog", { accept: target.getAttribute("accept"), directory: target.getAttribute("webkitdirectory") === "true", multiple: target.hasAttribute("multiple"), target: parseInt(target_id), bubbles: event_bubbles(event_name), event: event_name });
  28. window.ipc.postMessage(message);
  29. };
  30. send("change&input");
  31. }
  32. event.preventDefault();
  33. });
  34. }
  35. }
  36. }"#;
  37. let polling_request = format!(
  38. r#"// Poll for requests
  39. window.interpreter.wait_for_request = () => {{
  40. fetch(new Request("{EDITS_PATH}"))
  41. .then(response => {{
  42. response.arrayBuffer()
  43. .then(bytes => {{
  44. requestAnimationFrame(() => {{
  45. run_from_bytes(bytes);
  46. }});
  47. window.interpreter.wait_for_request();
  48. }});
  49. }})
  50. }}"#
  51. );
  52. let mut interpreter = SLEDGEHAMMER_JS
  53. .replace("/*POST_HANDLE_EDITS*/", prevent_file_upload)
  54. .replace("export", "")
  55. + &polling_request;
  56. while let Some(import_start) = interpreter.find("import") {
  57. let import_end = interpreter[import_start..]
  58. .find(|c| c == ';' || c == '\n')
  59. .map(|i| i + import_start)
  60. .unwrap_or_else(|| interpreter.len());
  61. interpreter.replace_range(import_start..import_end, "");
  62. }
  63. let js = format!("{interpreter}\nconst config = new InterpreterConfig(false);");
  64. use minify_js::*;
  65. let session = Session::new();
  66. let mut out = Vec::new();
  67. minify(&session, TopLevelMode::Module, js.as_bytes(), &mut out).unwrap();
  68. let minified = String::from_utf8(out).unwrap();
  69. let mut file = std::fs::File::create("src/minified.js").unwrap();
  70. file.write_all(minified.as_bytes()).unwrap();
  71. }