Untitled


SUBMITTED BY: Lucasalmeid

DATE: Nov. 2, 2023, 5:42 a.m.

UPDATED: Nov. 2, 2023, 6:43 a.m.

FORMAT: Text only

SIZE: 87.8 kB

HITS: 488

  1. <html lang="en" style="
  2. "><head>
  3. <meta charset="UTF-8">
  4. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>RIBLLU</title>
  7. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css">
  8. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/css/bootstrap.min.css">
  9. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css" integrity="sha512-Fo3rlrZj/k7ujTnHg4CGR2D7kSs0v4LLanw2qksYuRlEzO+tcaEPQogQ0KaoGN26/zrn20ImR1DfuLWnOo7aBA==" crossorigin="anonymous" referrerpolicy="no-referrer">
  10. <script src="https://cdn.tailwindcss.com"></script>
  11. <style>
  12. @import url('https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700&family=Outfit:wght@100;200;300;400;500;600;700&display=swap');
  13. :root {
  14. /*Editar o modal*/
  15. --btn-modal: #0000003f;
  16. --btn-border: 1px solid #4071FF;
  17. --btn-modal-border: 50px;
  18. --modal-shadow: #ffffff;
  19. --modal-bg: #171e2e;
  20. --modal-icon: #fff;
  21. --config-color: #0000003f;
  22. --category-color: #0000003f;
  23. --text-color: #ffffff;
  24. /*Editar Layout*/
  25. --fundo: #ffffff;
  26. --topo: #F7F7FC;
  27. --icon: #4071FF;
  28. --icon-bg: #E5EAFC;
  29. --config: #F7F7FC;
  30. --box-border: 1px solid #C0C6DE;
  31. --box-bg: transparent;
  32. --box-icon: black;
  33. --info1: #C0C6DE;
  34. --info2: #4071FF;
  35. }
  36. body {
  37. font-family: 'Be Vietnam Pro', sans-serif;
  38. background: var(--fundo);
  39. height: 100vh;
  40. width: 100vw;
  41. justify-content: center;
  42. align-items: center;
  43. }
  44. .container {
  45. display: flex;
  46. flex-direction: row;
  47. justify-content: space-between;
  48. background: var(--topo);
  49. width: 100vw;
  50. padding: 0 auto;
  51. }
  52. button.power-icon {
  53. font-size: 2.5em;
  54. box-shadow: 0 20px 25px 0px #4071ff54, 0 2px 0px 0px #4071ff10;
  55. }
  56. .app-bg-gray-1 {
  57. background: var(--config);
  58. }
  59. .app-bg-gray-2 {
  60. background: var(--icon-bg);
  61. }
  62. .app-bg-gray-3 {
  63. background: #fff;
  64. }
  65. .app-bg-4 {
  66. background: linear-gradient(-45deg, #13cf8e, #13cf8e, #0098ff, #5995fd);
  67. background-size: 400% 400%;
  68. animation: gradient 5s ease infinite;
  69. }
  70. @keyframes gradient {
  71. 0% {
  72. background-position: 0% 50%;
  73. }
  74. 50% {
  75. background-position: 100% 50%;
  76. }
  77. 100% {
  78. background-position: 0% 50%;
  79. }
  80. }
  81. .app-bg-blue {
  82. background: #4071FF;
  83. }
  84. .app-color-blue {
  85. color: #4071FF;
  86. }
  87. .app-color-gray-1 {
  88. color: #C0C6DE;
  89. }
  90. .app-rounded {
  91. border-bottom-left-radius: 50px;
  92. border-bottom-right-radius: 50px;
  93. }
  94. .status {
  95. font-size: 1em;
  96. }
  97. .put {
  98. border-radius: 60px;
  99. }
  100. .icon {
  101. font-size: 0.8em;
  102. color: var(--box-icon);
  103. }
  104. input {
  105. width: 100%;
  106. background: transparent;
  107. border: none;
  108. outline: none;
  109. color: var(--box-typing);
  110. line-height: 1;
  111. font-weight: 600;
  112. font-size: 1.1rem;
  113. }
  114. .box {
  115. border: var(--box-border);
  116. background: var(--box-bg);
  117. }
  118. .tool {
  119. align-items: center;
  120. justify-content: center;
  121. text-align: center;
  122. }
  123. .tool-bt {
  124. background: var(--btn-modal);
  125. height: 50px;
  126. width: 150px;
  127. border: var(--btn-border);
  128. }
  129. .info {
  130. color: var(--info2);
  131. }
  132. .info1 {
  133. color: var(--info1);
  134. }
  135. .info2 {
  136. color: var(--modal-icon);
  137. }
  138. .info3 {
  139. font-size: 1.2em;
  140. color: var(--icon);
  141. }
  142. .modal {
  143. backdrop-filter: blur(5px);
  144. -webkit-backdrop-filter: blur(5px);
  145. }
  146. .modal-content {
  147. border: none;
  148. background: var(--modal-bg);
  149. box-shadow: 0 5px 10px var(--modal-shadow);
  150. color: var(--text-color);
  151. }
  152. .modal-dialog {
  153. padding: 0 0.5rem;
  154. }
  155. .bg-category {
  156. background: var(--category-color);
  157. }
  158. .bg-config {
  159. background: var(--config-color);
  160. }
  161. .btn{
  162. width: 150px;
  163. background-color: #171e2e;
  164. outline: none;
  165. height: 49px;
  166. border-radius: var(--btn-modal-border);
  167. text-transform: uppercase;
  168. font-weight: 600;
  169. margin: 10px 0;
  170. cursor: pointer;
  171. transition: 0.5s;
  172. border: var(--btn-border);
  173. }
  174. </style>
  175. <style>/* ! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com */*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*, ::before, ::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.relative{position:relative}.-top-36{top:-9rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-2{margin-bottom:0.5rem}.mr-2{margin-right:0.5rem}.ms-2{margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-screen{height:100vh}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:0.5rem}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.p-0{padding:0px}.p-1{padding:0.25rem}.p-5{padding:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.pb-0{padding-bottom:0px}.text-center{text-align:center}.text-start{text-align:start}.font-semibold{font-weight:600}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}</style><style>/* ! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com */*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*, ::before, ::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.relative{position:relative}.-top-36{top:-9rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-2{margin-bottom:0.5rem}.mr-2{margin-right:0.5rem}.ms-2{margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-screen{height:100vh}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:0.5rem}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.p-0{padding:0px}.p-1{padding:0.25rem}.p-5{padding:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.pb-0{padding-bottom:0px}.text-center{text-align:center}.text-start{text-align:start}.font-semibold{font-weight:600}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}</style><style>/* ! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com */*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*, ::before, ::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.relative{position:relative}.-top-36{top:-9rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-2{margin-bottom:0.5rem}.mr-2{margin-right:0.5rem}.ms-2{margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-screen{height:100vh}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:0.5rem}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.p-0{padding:0px}.p-1{padding:0.25rem}.p-5{padding:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.pb-0{padding-bottom:0px}.text-center{text-align:center}.text-start{text-align:start}.font-semibold{font-weight:600}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}</style><style>/* ! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com */*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*, ::before, ::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.relative{position:relative}.-top-36{top:-9rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-2{margin-bottom:0.5rem}.mr-2{margin-right:0.5rem}.ms-2{margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-screen{height:100vh}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:0.5rem}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.p-0{padding:0px}.p-1{padding:0.25rem}.p-5{padding:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.pb-0{padding-bottom:0px}.text-center{text-align:center}.text-start{text-align:start}.font-semibold{font-weight:600}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}</style><style>/* ! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com */*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*, ::before, ::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.relative{position:relative}.-top-36{top:-9rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-2{margin-bottom:0.5rem}.mr-2{margin-right:0.5rem}.ms-2{margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-screen{height:100vh}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:0.5rem}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.p-0{padding:0px}.p-1{padding:0.25rem}.p-5{padding:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.pb-0{padding-bottom:0px}.text-center{text-align:center}.text-start{text-align:start}.font-semibold{font-weight:600}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}</style><style>/* ! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com */*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*, ::before, ::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.relative{position:relative}.-top-36{top:-9rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-2{margin-bottom:0.5rem}.mr-2{margin-right:0.5rem}.ms-2{margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-screen{height:100vh}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:0.5rem}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.p-0{padding:0px}.p-1{padding:0.25rem}.p-5{padding:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.pb-0{padding-bottom:0px}.text-center{text-align:center}.text-start{text-align:start}.font-semibold{font-weight:600}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}</style><style>/* ! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com */*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*, ::before, ::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.relative{position:relative}.-top-36{top:-9rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-2{margin-bottom:0.5rem}.mr-2{margin-right:0.5rem}.ms-2{margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-screen{height:100vh}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:0.5rem}.overflow-y-auto{overflow-y:auto}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.p-0{padding:0px}.p-1{padding:0.25rem}.p-5{padding:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.px-1{padding-left:0.25rem;padding-right:0.25rem}.pb-0{padding-bottom:0px}.text-center{text-align:center}.text-start{text-align:start}.text-end{text-align:end}.font-semibold{font-weight:600}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}</style></head>
  176. <body class="h-screen" style="font-size: 16px; background: rgb(35, 35, 35); font-family: sans-serif; height: 95%;">
  177. <div class="icon-container" style="
  178. font-size: 33px;
  179. background: none;
  180. color: #ccc;
  181. margin-top: 27px;
  182. "><!-- Button to open the popup -->
  183. <!-- Popup -->
  184. <div id="loginPopup" style="display: none; position: fixed; top: 0px; left: 0px; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.87); justify-content: center; align-items: center; z-index: 9999;">
  185. <div style="top: 0;background-color: #151515;padding: 20px;max-width: 300px;margin: 0 auto;border-radius: 18px;box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);">
  186. <div style="
  187. text-align: center;
  188. "><i class="bi bi-box-arrow-in-right" style="
  189. font-size: 67px;
  190. "></i></div><h2 style="
  191. text-align: center;
  192. font-size: 24px;
  193. ">Login</h2><p style="
  194. font-size: 15px;
  195. text-align: center;
  196. margin-bottom: 26px;
  197. ">Digite seu login e senha abaixo, certifique-se de não digitar errado.</p>
  198. <form id="loginForm" style="display: flex !important; flex-direction: column;">
  199. <label for="username" style="margin-bottom: 5px;font-size: 23px;">Login:</label>
  200. <input type="text" id="username" name="username" required="" style="margin-bottom: 10px;padding: 1px;background: #2a2a2a;font-size: 14px;color: #fff;padding: 15px 21px;border-radius: 29px;">
  201. <label for="password" style="margin-bottom: 5px;font-size: 23px;">Senha:</label>
  202. <input type="password" id="password" name="password" required="" style="color: #fff;border-radius: 29px;margin-bottom: 10px;padding: 1px;background: #2a2a2a;font-size: 14px;color: #fff;padding: 15px 21px;border-radius: 29px;">
  203. <button id="closePopupBtn" style="padding: 5px;cursor: pointer;border-radius: 20px;background: #1d1d1d;">Fechar</button>
  204. </form>
  205. </div>
  206. </div>
  207. <div onclick="ToolsModal.show()" style="display: flex;align-items: center;justify-content: center;background-color: #343434;border-radius: 12px;width: 56px;height: 50px;order: 2;color: #fff;font-size: 14px;font-weight: bold;">
  208. <i class="bi bi-list icon-left" style="color: #fff;font-size: 33px;padding: 5px 5px;"></i>
  209. </div><div onclick="DtStartAppUpdate.execute()" style="display: flex;align-items: center;justify-content: center;background-color: #343434;border-radius: 12px;width: 150px;height: 50px;order: 2;color: #fff;font-size: 14px;font-weight: bold;">
  210. <p style="margin: 0;margin-right: 5px;font-size: 14px;">Atualizar</p>
  211. <i class="bi bi-arrow-down-circle-fill" style="color: #fff;font-size: 30px;padding: 5px 5px;"></i>
  212. </div>
  213. </div><div style="display: flex;align-items: center;justify-content: center;background-color: none;border-radius: 68px;width: 90%;margin: 0 auto;padding: 10px;">
  214. <i class="bi bi-person-circle" style="font-size: 40px; color: #fff; margin-right: 10px;"></i>
  215. <div>
  216. <p id="user-name" style="color: #fff;margin: 5px 0;font-size: 18px;font-family: sans-serif;font-weight: 600;">Bem Vindo(a)</p>
  217. <p id="dias-rest" style="color: #fff;margin: 5px 0;margin-top: -8px;font-weight: 300;font-size: 13px;font-style: initial;">conecte-se primeiro</p>
  218. </div>
  219. <button id="btnrenovar" onclick="DtStartWebViewActivity.execute('https://painelssh.ribllu.com')" style="margin-left: auto;background-color: #18b446;color: #fff;font-size: 16px;border: none;border-radius: 30px;padding: 7px 13px;box-shadow: rgba(17, 12, 46, 0.15) 0px 48px 100px 0px;display: none;align-items: center;border-top-left-radius: 30px;border-bottom-left-radius: 30px;border-top-right-radius: 0px;border-bottom-right-radius: 0px;height: 38px;">
  220. <i class="bi bi-cash" style="font-size: 20px; margin-right: 5px;"></i>
  221. Renovar
  222. </button>
  223. <button id="openPopupBtn" style="margin-left: auto;background-color: #007bff;color: #fff;font-size: 16px;border: none;border-radius: 30px;padding: 7px 13px;box-shadow: rgba(17, 12, 46, 0.15) 0px 48px 100px 0px;display: flex;align-items: center;height: 38px;border-top-left-radius: 30px;border-bottom-left-radius: 30px;border-top-right-radius: 0px;border-bottom-right-radius: 0px;">
  224. <i class="bi bi-door-open" style="font-size: 20px; margin-right: 5px;"></i>
  225. Login
  226. </button>
  227. <div style="display: flex;align-items: center;justify-content: center;background-color: #343434;border-radius: 12px;width: 45px;height: 38px;border-bottom-left-radius: 0px;border-top-left-radius: 0px;color: #fff;justify-content: center;font-weight: bold;border-top-right-radius: 30px;border-bottom-right-radius: 30px;">
  228. <i onclick="loggerModal.show()" class="bi bi-file-earmark-text" style="color: #fff;font-size: 21px;padding: 5px 5px;padding: 9px 12px;"></i>
  229. </div>
  230. </div>
  231. <div onclick="startStopVpn()" style="display: flex;justify-content: center;align-items: center;height: auto;margin-top: 6px;background-color: transparent;margin-bottom: 33px;">
  232. <div class="btn-conectar" style="
  233. border: 10px solid #00000017;
  234. ">
  235. <i class="bi bi-lightning" style="font-size: 57px;text-shadow: 1px 1px #0000002b;color: #fff!important;"></i>
  236. <div class="pulse"></div>
  237. </div>
  238. </div>
  239. <div class="flex flex-row items-center justify-center mt-4" style="
  240. letter-spacing: 0px;
  241. margin-bottom: 0;
  242. font-weight: 400!important;
  243. ">
  244. <span class="status app-color-blue font-semibold" id="state" style="color: red;margin-bottom: 0px;font-weight: 400;">LBL_STATE_DISCONNECTED</span>
  245. </div>
  246. <div class="flex flex-row items-center justify-center mt-4" style="letter-spacing: 0px;font-weight: 400!important;color: #ccc;Z-INDEX: 1;">
  247. <span class="download" style="display: flex;flex-direction: column;align-items: center;background: #343434;width: 100px;border-radius: 13px;padding: 10px 0px;box-shadow: rgb(0 0 0 / 5%) 0px 3px 8px;">
  248. <i class="bi bi-cloud-download" style="font-size: 24px;color: #fff;margin-bottom: 4px;"></i>
  249. <span style="margin: 0;" id="networkDownload">0 B</span>
  250. <p style="margin: 0;font-weight: 600;">Download</p>
  251. </span>
  252. <span class="upload" style="
  253. display: flex;
  254. flex-direction: column;
  255. align-items: center;
  256. background: #343434;
  257. width: 100px;
  258. border-radius: 13px;
  259. padding: 10px 0px;
  260. JUSTIFY-CONTENT: space-between;
  261. margin-left: 15px;
  262. Z-INDEX: 1;
  263. box-shadow: rgb(0 0 0 / 5%) 0px 3px 8px;
  264. ">
  265. <i class="bi bi-cloud-upload" style="font-size: 24px;color: #fff;margin-bottom: 4px;"></i>
  266. <span style="margin: 0;" id="networkUpload">0 B</span>
  267. <p style="margin: 0;font-weight: 600;">Upload</p>
  268. </span>
  269. </div>
  270. <div style="
  271. top: 0;
  272. background: #ccc;
  273. border-radius: 10px;
  274. margin-bottom: 0px!important;
  275. background: transparent;
  276. border-radius: 27px;
  277. width: 100%;
  278. justify-content: center;
  279. text-align: center;
  280. margin-left: auto;
  281. margin-right: auto;
  282. " class="flex flex-col -top-36 relative">
  283. <div class="d-flex gap-2 justify-content-center mb-2 mt-1 flex flex-row items-center px-6 py-2 mx-6 rounded-xl border-slate-150 border-2" style="display: none !important;">
  284. <i class="icon fa fa-lock"></i>
  285. <input type="text" placeholder="V2ray UUID" id="uuid">
  286. <i class="icon fa fa-eye" onclick="uuid.type==`text`?uuid.type = `password`:uuid.type = `text`"></i>
  287. </div>
  288. <div class="flex flex-row items-center justify-center mt-2" style="
  289. margin-top: 0;
  290. margin-top: -1px;
  291. width: 100%;
  292. ">
  293. <div id="btnHotSpot" style="display: flex;align-items: center;MARGIN-RIGHT: 0;justify-content: center;background-color: #343434;border-radius: 12px;width: auto;height: 45px;color: #fff;padding: 18px 51PX;width: auto;margin-bottom: 18px;font-size: 14px;">
  294. <i class="bi bi-wifi" style="color: #fff;font-size: 21PX;padding: 5px 5px;"></i> Hotspot <i id="togglehot" class="bi bi-toggle-off" style="
  295. margin-left: 14px;
  296. font-size: 21px;
  297. "></i>
  298. </div>
  299. </div>
  300. <div style="
  301. display: flex;
  302. justify-content: center;
  303. "><div class="box d-flex gap-2 justify-content-center mb-1 mt-1 flex flex-row items-center px-6 py-2.5 mx-6 rounded-xl app-bg-gray-1 border-2" style="
  304. color: #ccc;
  305. margin-bottom: 35px;
  306. border-radius: 57px;
  307. font-size: 18px;
  308. width: auto;
  309. display: list-item;
  310. width: auto;
  311. margin-top: 8px!important;
  312. margin-top: 13px!important;
  313. box-shadow: rgba(17, 12, 46, 0.15) 0px 48px 100px 0px;
  314. border: 1px solid #545454;
  315. bottom: 60px;
  316. justify-content: center!important;
  317. ">
  318. <i class="icon fa fa-cogs" style="
  319. color: #ccc;
  320. "></i>
  321. <input type="text" placeholder="Escolha um servidor" disabled="" id="config" style="
  322. text-align: center;
  323. ">
  324. <i class="icon fa fa-angle-double-down" style="
  325. color: #ccc;
  326. "></i>
  327. </div></div>
  328. </div>
  329. <div class="modal fade" id="configModal" style="display: none;" aria-hidden="true">
  330. <div class="modal-dialog modal-dialog-centered" role="document">
  331. <div class="modal-content rounded-3 shadow" style="
  332. background: #2f2f2f;
  333. ">
  334. <div class="modal-header border-bottom-0 pb-0">
  335. <h1 class="modal-title fs-5" style="color: var(--text-color);font-weight: 600;">CONFIGURAÇÕES</h1>
  336. <button class="btn-close btn-close-white" data-bs-dismiss="modal"></button>
  337. </div>
  338. <div class="modal-body p-1 text-center">
  339. <ul class="list-group bg-transparent overflow-y-auto config-body" style="max-height: 600px;"><li class="list-group-item bg-transparent border-0 mb-1 rounded-1 px-1" style="color: var(--text-color);"><span class="fw-bold w-100 d-block p-1 rounded-1 mb-1 bg-category">CONFIG 2</span><ul class="list-group overflow-y-auto"><li class="list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1" style="color: var(--text-color);">
  340. <img src="https://cdn-icons-png.flaticon.com/512/8187/8187143.png" width="40" height="40">
  341. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  342. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">CONFIG 01</span>
  343. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;"></span>
  344. </div>
  345. <div class="d-flex flex-column ms-2">
  346. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">SSH_PROXY</span>
  347. </div>
  348. </li></ul></li><li class="list-group-item bg-transparent border-0 mb-1 rounded-1 px-1" style="color: var(--text-color);"><span class="fw-bold w-100 d-block p-1 rounded-1 mb-1 bg-category">CONFIG 3</span><ul class="list-group overflow-y-auto"><li class="list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1" style="color: var(--text-color);">
  349. <img src="https://cdn-icons-png.flaticon.com/512/8187/8187143.png" width="40" height="40">
  350. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  351. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">CONFIG. TEST</span>
  352. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;"></span>
  353. </div>
  354. <div class="d-flex flex-column ms-2">
  355. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">SSH_PROXY</span>
  356. </div>
  357. </li><li class="list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1" style="color: var(--text-color);">
  358. <img src="https://cdn-icons-png.flaticon.com/512/8187/8187143.png" width="40" height="40">
  359. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  360. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">CONFIG. TEST 2</span>
  361. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;"></span>
  362. </div>
  363. <div class="d-flex flex-column ms-2">
  364. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">OVPN_PROXY</span>
  365. </div>
  366. </li></ul></li><li class="list-group-item bg-transparent border-0 mb-1 rounded-1 px-1" style="color: var(--text-color);"><span class="fw-bold w-100 d-block p-1 rounded-1 mb-1 bg-category">CONFIG</span><ul class="list-group overflow-y-auto"><li class="list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1" style="color: var(--text-color);">
  367. <img src="https://cdn-icons-png.flaticon.com/512/8187/8187143.png" width="40" height="40">
  368. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  369. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">CONFIG 02</span>
  370. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;"></span>
  371. </div>
  372. <div class="d-flex flex-column ms-2">
  373. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">SSH_DIRECT</span>
  374. </div>
  375. </li><li class="list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1" style="color: var(--text-color);">
  376. <img src="https://cdn-icons-png.flaticon.com/512/8187/8187143.png" width="40" height="40">
  377. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  378. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">CONFIG 01</span>
  379. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;"></span>
  380. </div>
  381. <div class="d-flex flex-column ms-2">
  382. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">V2RAY - VLESS</span>
  383. </div>
  384. </li><li class="list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1" style="color: var(--text-color);">
  385. <img src="https://cdn-icons-png.flaticon.com/512/8187/8187143.png" width="40" height="40">
  386. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  387. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">CONFIG 03</span>
  388. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;"></span>
  389. </div>
  390. <div class="d-flex flex-column ms-2">
  391. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">OVPN_PROXY</span>
  392. </div>
  393. </li></ul></li></ul>
  394. </div>
  395. </div>
  396. </div>
  397. </div>
  398. <div class="modal fade" id="loggerModal" style="display: none;" aria-hidden="true">
  399. <div class="modal-dialog modal-dialog-centered" role="document" style="
  400. BORDER-RADIUS: 11PX;
  401. ">
  402. <div class="modal-content rounded-3 shadow" style="
  403. BACKGROUND: #1f1f1f;
  404. ">
  405. <div class="modal-body p-1 text-center">
  406. <ul class="list-group bg-transparent overflow-y-auto logger-content" style="max-height: 600px;"><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 0</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 1</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 2</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 3</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 4</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 5</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 6</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 7</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 8</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 9</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 10</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 11</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 12</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 13</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 14</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 15</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 16</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 17</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 18</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 19</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 20</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 21</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 22</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 23</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 24</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 25</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 26</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 27</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 28</li><li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">TIME MESSAGE 29</li></ul>
  407. </div>
  408. <div class="modal-footer flex-nowrap p-0">
  409. <button class="btn btn-primary w-100 clear-logger" style="background-color:var(--btn-modal);BORDER: 1PX SOLID #CCC;BORDER-RADIUS: 23PX!IMPORTANT;">LIMPAR</button>
  410. <button type="button" class="btn btn-primary w-100" data-bs-dismiss="modal" style="background-color: var(--btn-modal);BORDER: 1PX SOLID #CCC;">FECHAR</button>
  411. </div>
  412. </div>
  413. </div>
  414. </div>
  415. <div class="tool webm modal fade" index="-1" id="ToolsModal" style="display: none;" aria-hidden="true">
  416. <div class="modal-dialog modal-dialog-centered" role="document">
  417. <div class="modal-content" style="
  418. background: #1f1f1f;
  419. box-shadow: none;
  420. ">
  421. <div class="tool modal-header" style="
  422. border: none;
  423. font-size: 24px;
  424. ">
  425. <h5 class="modal-title" style="color:#ffffff;">FERRAMENTAS</h5>
  426. </div>
  427. <div class="modal-body" style="
  428. border: none;
  429. ">
  430. <button class="tool-bt rounded-2xl text-white" onclick="DtStartCheckUser.execute()" style="
  431. border: none;
  432. display: none;
  433. "><i class="info2 bi bi-calendar-check mr-2"></i>VALIDADE</button>
  434. </div>
  435. <div class="modal-body">
  436. <button class="tool-bt rounded-2xl text-white" data-bs-target="#speedTestModal" data-bs-toggle="modal" style="
  437. border: none;
  438. "><i class="info2 bi bi-speedometer mr-2"></i>SPEEDTEST</button>
  439. <button class="tool-bt rounded-2xl text-white" onclick="DtStartWebViewActivity.execute('https://t.me/ribllu')" style="
  440. border: none;
  441. "><i class="info2 bi bi-globe mr-2"></i>SUPORTE</button>
  442. </div>
  443. <div class="modal-body">
  444. <button class="tool-bt rounded-2xl text-white" onclick="DtStartApnActivity.execute()" style="
  445. border: none;
  446. "><i class="info2 bi bi-wifi mr-2"></i>APN</button>
  447. <button class="tool-bt rounded-2xl text-white" onclick="DtIgnoreBatteryOptimizations.execute()" style="
  448. border: none;
  449. "><i class="info2 bi bi-battery-full mr-2"></i>BATERIA</button>
  450. </div>
  451. <div class="modal-body">
  452. <button class="tool-bt rounded-2xl text-white" onclick="DtCleanApp.execute()" style="
  453. border: none;
  454. "><i class="info2 bi bi-trash3 mr-2"></i>LIMPAR</button>
  455. </div>
  456. <div class="tool modal-footer" style="
  457. border-top: 1px solid #323131;
  458. ">
  459. <button type="button" class="btn btn-primary" data-bs-dismiss="modal" style="background-color: var(--btn-modal);border: none;">FECHAR</button>
  460. </div>
  461. </div>
  462. </div>
  463. </div>
  464. <div class="modal fade" id="checkUserModal" index="1">
  465. <div class="modal-dialog modal-dialog-centered" role="document">
  466. <div class="modal-content rounded-3 shadow">
  467. <div class="modal-header border-bottom-0 pb-0">
  468. <h1 class="modal-title fs-5 chk-title text-light"></h1>
  469. <button class="btn-close btn-close-white" data-bs-dismiss="modal"></button>
  470. </div>
  471. <div class="modal-body text-center">
  472. <p class="fs-5 mb-0 chk-message text-light"></p>
  473. </div>
  474. </div>
  475. </div>
  476. </div>
  477. <div class="md modal fade" id="speedTestModal">
  478. <div class="md modal-dialog modal-dialog-centered" role="document">
  479. <div class="md modal-content rounded-3 shadow">
  480. <div class="md modal-header border-bottom-0 py-3">
  481. <button class="btn-close btn-close-white" data-bs-dismiss="modal" aria-label="Close"></button>
  482. </div>
  483. <div class="modal-body ratio rounded-bottom-3" style="height: 600px;">
  484. <div class="spinner d-flex w-100 h-100 align-items-center justify-content-center">
  485. <div class="spinner-border text-light p-5" role="status">
  486. <span class="visually-hidden">Loading...</span>
  487. </div>
  488. </div>
  489. <iframe class="rounded-bottom-3" id="speedFrame"></iframe>
  490. </div>
  491. </div>
  492. </div>
  493. </div>
  494. <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/js/bootstrap.min.js"></script>
  495. <script>
  496. Object.defineProperty(String.prototype, 't', {
  497. value: function t() {
  498. return window?.DtTranslateText?.execute('' + this) ?? '' + this
  499. },
  500. writable: true,
  501. configurable: true,
  502. })
  503. const config = document.querySelector('#config')
  504. config.parentElement.onclick = () => showConfigsModal();
  505. const username = document.querySelector('#username')
  506. username.oninput = e => DtUsername.set(e.target.value)
  507. const password = document.querySelector('#password')
  508. password.oninput = e => DtPassword.set(e.target.value)
  509. const uuid = document.querySelector('#uuid')
  510. uuid.oninput = e => DtUuid.set(e.target.value)
  511. const clearLogger = document.querySelector('.clear-logger')
  512. const checkUserModal = new bootstrap.Modal(document.querySelector('#checkUserModal'))
  513. const configModal = new bootstrap.Modal(document.querySelector('#configModal'))
  514. const loggerModal = new bootstrap.Modal(document.querySelector('#loggerModal'))
  515. const ToolsModal = new bootstrap.Modal(document.querySelector('#ToolsModal'))
  516. const speedTestModal = new bootstrap.Modal(document.querySelector('#speedTestModal'))
  517. const dtConfigClickListener = () => {
  518. const data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{ "auth": {"username": ""} }`)
  519. const isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');
  520. config.placeholder = data.name ?? 'Escolha um servidor';
  521. username.parentElement.style.setProperty('display', !data?.auth?.username && !isV2ray ? 'flex' : 'none', 'important')
  522. password.parentElement.style.setProperty('display', !data?.auth?.password && !isV2ray ? 'flex' : 'none', 'important')
  523. uuid.parentElement.style.setProperty('display', !data?.auth?.v2ray_uuid && isV2ray ? 'flex' : 'none', 'important')
  524. }
  525. const startStopVpn = e => {
  526. if (DtGetVpnState.execute() != 'DISCONNECTED') {
  527. DtExecuteVpnStop.execute()
  528. } else {
  529. DtExecuteVpnStart.execute()
  530. }
  531. }
  532. clearLogger.addEventListener('click', () => DtClearLogs.execute())
  533. speedTestModal._element.addEventListener('shown.bs.modal', () => {
  534. const iframe = document.querySelector('#speedFrame');
  535. if (!iframe.src) {
  536. iframe.src = 'http://speedtest.sercomtel.com.br/'
  537. iframe.addEventListener('load', () => {
  538. mp3Modal._element.querySelector('.spinner').classList.add('d-none')
  539. })
  540. }
  541. })
  542. speedTestModal._element.addEventListener('hide.bs.modal', () => {
  543. const iframe = document.querySelector('#speedFrame');
  544. iframe.src = '';
  545. })
  546. const dtVpnStateListener = state => {
  547. const isConectado= state === 'CONNECTED';
  548. const isDesconectado= state === 'DISCONNECTED';
  549. const isRunning = state != 'DISCONNECTED';
  550. const status = document.querySelector('#state')
  551. status.innerHTML = ('LBL_STATE_' + state).t()
  552. if (isRunning) {
  553. username.setAttribute('readonly', 'true')
  554. password.setAttribute('readonly', 'true')
  555. status.style.color = '#00ff15'
  556. } else {
  557. username.removeAttribute('readonly')
  558. password.removeAttribute('readonly')
  559. status.style.color = 'RED'
  560. }
  561. if (isDesconectado) {
  562. document.getElementById("dias-rest").innerHTML = "conecte-se primeiro"
  563. document.getElementById("user-name").innerHTML = "Bem Vindo(a)"
  564. document.getElementById("openPopupBtn").style.display = "flex";
  565. document.getElementById("btnrenovar").style.display = "none";
  566. }
  567. if (isConectado) {
  568. document.getElementById("user-name").innerHTML = username.value
  569. document.getElementById("openPopupBtn").style.display = "none";
  570. document.getElementById("btnrenovar").style.display = "flex";
  571. }
  572. }
  573. const dtCheckUserStartedListener = () => {
  574. const data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{}`)
  575. const isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');
  576. if (isV2ray || !data.urlCheckUser) return;
  577. const html = `
  578. <div class="d-flex justify-content-center">
  579. <div class="spinner-border p-4" role="status">
  580. <span class="visually-hidden">Loading...</span>
  581. </div>
  582. </div>
  583. `
  584. checkUserModal._element.querySelector('.chk-title').textContent = 'CHECK USER'
  585. checkUserModal._element.querySelector('.chk-message').innerHTML = html;
  586. checkUserModal.show()
  587. }
  588. const dtCheckUserModelListener = model => {
  589. const data = JSON.parse(model ?? `{"username": "test"}`)
  590. const html = `${data.expiration_days} dias restantes`
  591. document.getElementById("dias-rest").innerHTML = html
  592. }
  593. const showConfigsModal = () => {
  594. const mock = '[{"sorter":6,"color":"#6D08041C","name":"CONFIG","id":1393,"items":[{"mode":"V2RAY - VLESS","sorter":4,"tlsVersion":"TLSv1.2","name":"CONFIG 01","icon":"https://cdn-icons-png.flaticon.com/512/8187/8187143.png","id":11803,"status":"ACTIVE"},{"mode":"SSH_DIRECT","sorter":2,"tlsVersion":"TLSv1.2","name":"CONFIG 02","icon":"https://cdn-icons-png.flaticon.com/512/8187/8187143.png","id":28627,"status":"ACTIVE"},{"mode":"OVPN_PROXY","sorter":23,"tlsVersion":"TLSv1.2","name":"CONFIG 03","icon":"https://cdn-icons-png.flaticon.com/512/8187/8187143.png","id":30001,"status":"ACTIVE"}]},{"sorter":2,"color":"#6D08041C","name":"CONFIG 2","id":1846,"items":[{"mode":"SSH_PROXY","sorter":1,"tlsVersion":"TLSv1.2","name":"CONFIG 01","icon":"https://cdn-icons-png.flaticon.com/512/8187/8187143.png","id":26295,"status":"ACTIVE"}]},{"sorter":4,"color":"#80000000","name":"CONFIG 3","id":3310,"items":[{"mode":"SSH_PROXY","sorter":1,"tlsVersion":"TLSv1.2","name":"CONFIG. TEST","icon":"https://cdn-icons-png.flaticon.com/512/8187/8187143.png","id":29997,"status":"ACTIVE"},{"mode":"OVPN_PROXY","sorter":1,"tlsVersion":"TLSv1.2","name":"CONFIG. TEST 2","icon":"https://cdn-icons-png.flaticon.com/512/8187/8187143.png","id":29998,"status":"ACTIVE"}]}]'
  595. const data = JSON.parse(window?.DtGetConfigs?.execute() || mock)
  596. data.sort((a, b) => a.sorter - b.sorter)
  597. data.forEach(item => item.items.sort((a, b) => a.sorter - b.sorter))
  598. const body = configModal._element.querySelector('.config-body')
  599. body.innerHTML = ''
  600. data.forEach(category => {
  601. const categoryElement = document.createElement('li')
  602. categoryElement.className = 'list-group-item bg-transparent border-0 mb-1 rounded-1 px-1'
  603. categoryElement.style.color = 'var(--text-color)'
  604. categoryElement.innerHTML = `<span class="fw-bold w-100 d-block p-1 rounded-1 mb-1 bg-category">${category.name}</span>`
  605. const configUlElement = document.createElement('ul')
  606. configUlElement.className = 'list-group overflow-y-auto'
  607. category.items.forEach(item => {
  608. const configElement = document.createElement('li')
  609. configElement.className = 'list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1'
  610. configElement.style.color = 'var(--text-color)'
  611. configElement.innerHTML = `
  612. <img src="${item.icon}" width="40" height="40">
  613. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  614. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">${item.name}</span>
  615. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;">${item.description || ''}</span>
  616. </div>
  617. <div class="d-flex flex-column ms-2">
  618. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">${item.mode}</span>
  619. </div>
  620. </li>
  621. `
  622. configElement.addEventListener('click', e => {
  623. window?.DtSetConfig?.execute(item.id)
  624. configModal.hide()
  625. })
  626. configUlElement.appendChild(configElement)
  627. })
  628. categoryElement.appendChild(configUlElement)
  629. body.appendChild(categoryElement)
  630. })
  631. configModal.show()
  632. }
  633. const dtOnNewLogListener = () => {
  634. const mock = [];
  635. for (let i = 0; i < 30; i++) {
  636. mock.push({ 'TIME': 'MESSAGE ' + i })
  637. }
  638. const log = window?.DtGetLogs?.execute() || JSON.stringify(mock)
  639. const data = JSON.parse(log)
  640. let content = '';
  641. data.forEach(item => {
  642. content += '<li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">';
  643. content += Object.keys(item)[0] + " " + item[Object.keys(item)]
  644. content += '</li>';
  645. })
  646. loggerModal._element.querySelector('.logger-content').innerHTML = content;
  647. const listGroup = loggerModal._element.querySelector('.list-group')
  648. listGroup.scrollTo(0, listGroup.scrollHeight)
  649. }
  650. username.value = window?.DtUsername?.get() ?? ''
  651. password.value = window?.DtPassword?.get() ?? ''
  652. uuid.value = window?.DtUuid?.get() ?? ''
  653. dtOnNewLogListener()
  654. dtConfigClickListener()
  655. dtVpnStateListener(window?.DtGetVpnState?.execute() ?? 'DISCONNECTED')
  656. </script>
  657. <script>
  658. class AndroidMock {
  659. static getLocalIP() {
  660. return '192.168.0.1';
  661. }
  662. static getConfig() {
  663. return JSON.stringify({
  664. urlCheckUser: 'URLAQUI'
  665. });
  666. }
  667. static getNetworkName() {
  668. return 'REDE';
  669. }
  670. static openRadioInfo() {
  671. console.log('openRadioInfo');
  672. }
  673. }
  674. </script>
  675. <script>
  676. function showLocalIP(android) {
  677. console.log(android.getNetworkName());
  678. document.getElementById('name').innerHTML = ' ' + android.getNetworkName() + ':';
  679. document.getElementById('ip').innerHTML = android.getLocalIP();
  680. setInterval(() => {
  681. document.getElementById('name').innerHTML =
  682. ' ' + android.getNetworkName() + ':';
  683. document.getElementById('ip').innerHTML = android.getLocalIP();
  684. }, 2000)
  685. }
  686. window.onload = function () {
  687. const android = window.Android || AndroidMock;
  688. showLocalIP(android);
  689. showCheckUser(android);
  690. }
  691. </script>
  692. <script>
  693. const openPopupBtn = document.getElementById("openPopupBtn");
  694. const closePopupBtn = document.getElementById("closePopupBtn");
  695. const loginPopup = document.getElementById("loginPopup");
  696. openPopupBtn.addEventListener("click", () => {
  697. loginPopup.style.display = "flex";
  698. });
  699. closePopupBtn.addEventListener("click", () => {
  700. loginPopup.style.display = "none";
  701. });
  702. // Close the popup if the user clicks outside of it
  703. window.addEventListener("click", (event) => {
  704. if (event.target === loginPopup) {
  705. loginPopup.style.display = "none";
  706. }
  707. });
  708. // Prevent the default form submission behavior and add your login logic here
  709. const loginForm = document.getElementById("loginForm");
  710. loginForm.addEventListener("submit", (event) => {
  711. event.preventDefault();
  712. // Add your login logic here
  713. });
  714. </script><style> .icon-container {
  715. display: flex;
  716. justify-content: space-between;
  717. align-items: center;
  718. background-color: #ccc;
  719. border-radius: 68px;
  720. width: 90%;
  721. margin: 0 auto;
  722. padding: 10px;
  723. }
  724. .bi {
  725. font-size: 40px;
  726. color: #fff;
  727. }
  728. .icon-left {
  729. order: 1; /* Posiciona o ícone à esquerda */
  730. }
  731. .icon-right {
  732. order: 2; /* Posiciona o ícone à direita */
  733. }
  734. @keyframes pulseAnimation {
  735. 0% {
  736. transform: scale(1);
  737. opacity: 0.7;
  738. }
  739. 100% {
  740. transform: scale(2);
  741. opacity: 0;
  742. }
  743. }
  744. .btn-conectar {
  745. position: relative;
  746. display: flex;
  747. align-items: center;
  748. justify-content: center;
  749. background-color: #007bff;
  750. border-radius: 50%;
  751. width: 160px;
  752. height: 160px;
  753. cursor: pointer;
  754. box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  755. }
  756. .pulse {
  757. position: absolute;
  758. width: 100%;
  759. height: 100%;
  760. background-color: #0061ca5c;
  761. border-radius: 50%;
  762. animation: pulseAnimation 2s infinite;
  763. pointer-events: none;
  764. }.bi {
  765. font-size: 17px;
  766. color: #fff;
  767. }
  768. </style>
  769. <script>
  770. const startHotSpot = () => {
  771. DtStartHotSpotService.execute();
  772. document.getElementById("togglehot").className = "bi bi-toggle-on";
  773. }
  774. const stopHotSpot = () => {
  775. DtStopHotSpotService.execute();
  776. document.getElementById("togglehot").className = "bi bi-toggle-off";
  777. }
  778. const toggleHotSpot = () => {
  779. const hotSpotStatus = window?.DtGetStatusHotSpotService?.execute() ?? 'STOPPED';
  780. hotSpotStatus == 'RUNNING' ? stopHotSpot() : startHotSpot();
  781. }
  782. const btnHotSpot = document.querySelector("#btnHotSpot");
  783. btnHotSpot.addEventListener('click', toggleHotSpot);
  784. const formatBytes = bytes => {
  785. const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];
  786. if (bytes === 0) return '0 B';
  787. const i = parseInt(Math.floor(Math.log(bytes) / Math.log(1024)));
  788. return (bytes / Math.pow(1024, i)).toPrecision(3) + ' ' + sizes[i];
  789. }
  790. const currentNetworkDownload = window?.DtGetNetworkDownloadBytes?.execute() ?? 0
  791. const currentNetworkUpload = window?.DtGetNetworkUploadBytes?.execute() ?? 0
  792. setInterval(() => {
  793. const networkDownload = document.querySelector('#networkDownload');
  794. const networkUpload = document.querySelector('#networkUpload');
  795. const newNetworkDownload = window?.DtGetNetworkDownloadBytes?.execute() ?? 0;
  796. const newNetworkUpload = window?.DtGetNetworkUploadBytes?.execute() ?? 0;
  797. networkDownload.innerHTML = formatBytes(newNetworkDownload - currentNetworkDownload);
  798. networkUpload.innerHTML = formatBytes(newNetworkUpload - currentNetworkUpload);
  799. }, 1000)
  800. const setVpnState = state => {
  801. if (state == 'CONNECTED') startSocket();
  802. }
  803. startSocket();
  804. </script>
  805. </body></html>

comments powered by Disqus