dev.index.html 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Dioxus app</title>
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
  6. <style>
  7. /* Inter Font */
  8. @import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap');
  9. #dx-toast-template {
  10. display: none;
  11. visibility: hidden;
  12. }
  13. .dx-toast {
  14. position: absolute;
  15. top: 10px;
  16. right: 0;
  17. padding-right: 10px;
  18. user-select: none;
  19. /* transition: transform 0.2s ease; */
  20. z-index: 2147483647;
  21. }
  22. .dx-toast .dx-toast-inner {
  23. /* transition: right 0.2s ease-out; */
  24. position: fixed;
  25. background-color: #181B20;
  26. color: #ffffff;
  27. font-family: "Inter", sans-serif;
  28. display: grid;
  29. grid-template-columns: auto auto;
  30. max-width: 400px;
  31. min-height: 56px;
  32. border-radius: 5px;
  33. }
  34. .dx-toast .dx-toast-inner {
  35. cursor: pointer;
  36. margin-right: 10px;
  37. }
  38. .dx-toast .dx-toast-level-bar-container {
  39. height: 100%;
  40. width: 6px;
  41. }
  42. .dx-toast .dx-toast-level-bar-container .dx-toast-level-bar {
  43. width: 100%;
  44. height: 100%;
  45. border-radius: 5px 0px 0px 5px;
  46. }
  47. .dx-toast .dx-toast-content {
  48. padding: 8px;
  49. }
  50. .dx-toast .dx-toast-header {
  51. display: flex;
  52. flex-direction: row;
  53. justify-content: start;
  54. align-items: end;
  55. margin-bottom: 10px;
  56. }
  57. .dx-toast .dx-toast-header>svg {
  58. height: 18px;
  59. margin-right: 5px;
  60. }
  61. .dx-toast .dx-toast-header .dx-toast-header-text {
  62. font-size: 14px;
  63. font-weight: 700;
  64. padding: 0;
  65. margin: 0;
  66. }
  67. .dx-toast .dx-toast-msg {
  68. font-size: 11px;
  69. font-weight: 400;
  70. padding: 0;
  71. margin: 0;
  72. }
  73. .dx-toast-level-bar.info {
  74. background-color: #428EFF;
  75. }
  76. .dx-toast-level-bar.success {
  77. background-color: #42FF65;
  78. }
  79. .dx-toast-level-bar.error {
  80. background-color: #FF4242;
  81. }
  82. </style>
  83. <script>
  84. const STORAGE_KEY = "SCHEDULED-DX-TOAST";
  85. let currentTimeout = null;
  86. let currentToastId = 0;
  87. // Show a toast, removing the previous one.
  88. function showDXToast(headerText, message, progressLevel, durationMs) {
  89. document.getElementById("__dx-toast-decor").className = `dx-toast-level-bar ${progressLevel}`;
  90. document.getElementById("__dx-toast-text").innerText = headerText;
  91. document.getElementById("__dx-toast-msg").innerText = message;
  92. document.getElementById("__dx-toast-inner").style.right = "0";
  93. document.getElementById("__dx-toast").addEventListener("click", closeDXToast);
  94. // Wait a bit of time so animation plays correctly.
  95. setTimeout(
  96. () => {
  97. let ourToastId = currentToastId;
  98. currentTimeout = setTimeout(() => {
  99. if (ourToastId == currentToastId) {
  100. closeDXToast();
  101. }
  102. }, durationMs);
  103. },
  104. 100
  105. );
  106. currentToastId += 1;
  107. }
  108. // Schedule a toast to be displayed after reload.
  109. function scheduleDXToast(headerText, message, level, durationMs) {
  110. let data = {
  111. headerText,
  112. message,
  113. level,
  114. durationMs,
  115. };
  116. let jsonData = JSON.stringify(data);
  117. sessionStorage.setItem(STORAGE_KEY, jsonData);
  118. }
  119. // Close the current toast.
  120. function closeDXToast() {
  121. document.getElementById("__dx-toast-inner").style.right = "-1000px";
  122. clearTimeout(currentTimeout);
  123. }
  124. // Handle any scheduled toasts after reload.
  125. let potentialData = sessionStorage.getItem(STORAGE_KEY);
  126. if (potentialData) {
  127. sessionStorage.removeItem(STORAGE_KEY);
  128. let data = JSON.parse(potentialData);
  129. showDXToast(data.headerText, data.message, data.level, data.durationMs);
  130. }
  131. window.scheduleDXToast = scheduleDXToast;
  132. window.showDXToast = showDXToast;
  133. window.closeDXToast = closeDXToast;
  134. </script>
  135. <!-- CUSTOM HEAD -->
  136. </head>
  137. <body>
  138. <div id="__dx-toast" class="dx-toast">
  139. <div id="__dx-toast-inner" class="dx-toast-inner" style="right:-1000px;">
  140. <div class="dx-toast-level-bar-container">
  141. <div id="__dx-toast-decor" class="dx-toast-level-bar __info"></div>
  142. </div>
  143. <div class="dx-toast-content">
  144. <div class="dx-toast-header">
  145. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32" preserveAspectRatio="none">
  146. <path d="M22.158 1.783c0 3.077-.851 5.482-2.215 7.377s-3.32 3.557-5.447 5.33-4.425 3.657-6.252 6.195-3.102 5.515-3.102 9.532h4.699c0-3.077.853-5.377 2.217-7.272s3.32-3.557 5.447-5.33 4.425-3.657 6.252-6.195 3.102-5.62 3.102-9.637z" fill="#e96020"/>
  147. <path d="M9.531 25.927c-.635 0-1.021.515-1.02 1.15s.385 1.151 1.02 1.15H22.47a1.151 1.151 0 1 0 0-2.301zm1.361-4.076c-.608 0-.954.558-.953 1.166s.346 1.035.953 1.035h10.217a1.101 1.101 0 1 0 0-2.201zm0-13.594a1.101 1.101 0 1 0 0 2.201h10.217c.607 0 .953-.598.953-1.205s-.345-.996-.953-.996zM9.531 4.021A1.15 1.15 0 0 0 8.38 5.17a1.15 1.15 0 0 0 1.15 1.15h12.94c.635 0 1.021-.498 1.02-1.133s-.386-1.166-1.02-1.166z" fill="#2d323b"/>
  148. <path d="M5.142 1.783c0 4.016 1.275 7.099 3.102 9.637s4.125 4.422 6.252 6.195 4.083 3.656 5.447 5.551 2.215 3.974 2.215 7.051h4.701c0-4.016-1.275-7.038-3.102-9.576s-4.125-4.422-6.252-6.195-4.083-3.435-5.447-5.33S9.841 4.86 9.841 1.783z" fill="#00a8d6"/>
  149. </svg>
  150. <h3 id="__dx-toast-text" class="dx-toast-header-text">Your app is being rebuilt.</h3>
  151. </div>
  152. <p id="__dx-toast-msg" class="dx-toast-msg">A non-hot-reloadable change occurred and we must rebuild.</p>
  153. </div>
  154. </div>
  155. </div>
  156. <div id="main"></div>
  157. <!-- MODULE LOADER -->
  158. </body>
  159. </html>