window_event.rs 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. use dioxus::prelude::*;
  2. use dioxus_desktop::{window, Config, WindowBuilder};
  3. fn main() {
  4. Config::new()
  5. .with_window(
  6. WindowBuilder::new()
  7. .with_title("Borderless Window")
  8. .with_decorations(false),
  9. )
  10. .launch(app)
  11. }
  12. fn app() -> Element {
  13. let fullscreen = use_signal(|| false);
  14. let always_on_top = use_signal(|| false);
  15. let decorations = use_signal(|| false);
  16. rsx!(
  17. link { href:"https://unpkg.com/tailwindcss@^2/dist/tailwind.min.css", rel:"stylesheet" }
  18. header { class: "text-gray-400 bg-gray-900 body-font", onmousedown: move |_| window().drag(),
  19. div { class: "container mx-auto flex flex-wrap p-5 flex-col md:flex-row items-center",
  20. a { class: "flex title-font font-medium items-center text-white mb-4 md:mb-0",
  21. span { class: "ml-3 text-xl", "Dioxus"}
  22. }
  23. nav { class: "md:ml-auto flex flex-wrap items-center text-base justify-center" }
  24. button {
  25. class: "inline-flex items-center bg-gray-800 border-0 py-1 px-3 focus:outline-none hover:bg-gray-700 rounded text-base mt-4 md:mt-0",
  26. onmousedown: |evt| evt.stop_propagation(),
  27. onclick: move |_| window().set_minimized(true),
  28. "Minimize"
  29. }
  30. button {
  31. class: "inline-flex items-center bg-gray-800 border-0 py-1 px-3 focus:outline-none hover:bg-gray-700 rounded text-base mt-4 md:mt-0",
  32. onmousedown: |evt| evt.stop_propagation(),
  33. onclick: move |_| {
  34. window().set_fullscreen(!fullscreen());
  35. window().set_resizable(fullscreen());
  36. fullscreen.toggle();
  37. },
  38. "Fullscreen"
  39. }
  40. button {
  41. class: "inline-flex items-center bg-gray-800 border-0 py-1 px-3 focus:outline-none hover:bg-gray-700 rounded text-base mt-4 md:mt-0",
  42. onmousedown: |evt| evt.stop_propagation(),
  43. onclick: move |_| window().close(),
  44. "Close"
  45. }
  46. }
  47. }
  48. br {}
  49. div {
  50. class: "container mx-auto",
  51. div {
  52. class: "grid grid-cols-5",
  53. div {
  54. button {
  55. class: "inline-flex items-center text-white bg-green-500 border-0 py-1 px-3 hover:bg-green-700 rounded",
  56. onmousedown: |evt| evt.stop_propagation(),
  57. onclick: move |_| {
  58. window().set_always_on_top(!always_on_top());
  59. always_on_top.toggle();
  60. },
  61. "Always On Top"
  62. }
  63. }
  64. div {
  65. button {
  66. class: "inline-flex items-center text-white bg-blue-500 border-0 py-1 px-3 hover:bg-green-700 rounded",
  67. onmousedown: |evt| evt.stop_propagation(),
  68. onclick: move |_| {
  69. window().set_decorations(!decorations());
  70. decorations.toggle();
  71. },
  72. "Set Decorations"
  73. }
  74. }
  75. div {
  76. button {
  77. class: "inline-flex items-center text-white bg-blue-500 border-0 py-1 px-3 hover:bg-green-700 rounded",
  78. onmousedown: |evt| evt.stop_propagation(),
  79. onclick: move |_| window().set_title("Dioxus Application"),
  80. "Change Title"
  81. }
  82. }
  83. }
  84. }
  85. )
  86. }