BRALFANETLayoutApp


SUBMITTED BY: BRALFANET

DATE: April 26, 2024, 9:56 p.m.

UPDATED: April 26, 2024, 10:46 p.m.

FORMAT: Text only

SIZE: 54.7 kB

HITS: 512

  1. <html><head>
  2. <meta charset="UTF-8">
  3. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  4. <meta http-equiv="Expires" content="Tue, 31 Dec 2030 23:59:59 GMT">
  5. <meta http-equiv="Cache-Control" content="public, max-age=31536000">
  6. <meta name="viewport" content="width=device-width,initial-scale=1">
  7. <title>GUARDIAN</title>
  8. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css">
  9. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/css/bootstrap.min.css">
  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: #0000008f;
  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. background: #4071ff;
  51. }
  52. button.power-icon {
  53. background: #ccc;
  54. border-radius: 80px;
  55. display: flex;
  56. -webkit-text-stroke: 3px;
  57. }
  58. .app-bg-gray-1 {
  59. background: var(--config);
  60. }
  61. .app-bg-gray-2 {
  62. background: #ffffff;
  63. box-shadow: rgba(0, 0, 0, 0.2) 0px 20px 30px;
  64. box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
  65. }
  66. .app-bg-gray-3 {
  67. background: #fff;
  68. }
  69. .app-bg-4 {
  70. background: linear-gradient(-45deg, #4071ff, #2b4089, #0098ff, #5995fd);
  71. background-size: 400% 400%;
  72. animation: gradient 5s ease infinite;
  73. }
  74. @keyframes gradient {
  75. 0% {
  76. background-position: 0% 50%;
  77. }
  78. 50% {
  79. background-position: 100% 50%;
  80. }
  81. 100% {
  82. background-position: 0% 50%;
  83. }
  84. }
  85. .app-bg-blue {
  86. background: #0000ff;
  87. BORDER: 1PX SOLID #fff;
  88. PADDING: 12PX 10PX !IMPORTANT;
  89. box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
  90. }
  91. .app-bg-blue2 {
  92. background: #62656a;
  93. BORDER: 0PX SOLID #fff;
  94. PADDING: 0PX 0PX !IMPORTANT;
  95. box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
  96. }
  97. .app-color-blue {
  98. color: #4071FF;
  99. }
  100. .app-color-blue-escuro {
  101. color: #00003f;
  102. }
  103. .app-color-gray-1 {
  104. color: #4d4d4d;
  105. }
  106. .app-rounded {
  107. border-bottom-left-radius: 50px;
  108. border-bottom-right-radius: 50px;
  109. background: blue;
  110. }
  111. .status {
  112. font-size: 1em;
  113. color: #fff !important;
  114. }
  115. .put {
  116. border-radius: 60px;
  117. }
  118. .icon {
  119. font-size: 0.8em;
  120. color: var(--box-icon);
  121. }
  122. input {
  123. width: 100%;
  124. background: transparent;
  125. border: none;
  126. outline: none;
  127. color: var(--box-typing);
  128. line-height: 1;
  129. font-weight: 600;
  130. font-size: 17.6px;
  131. }
  132. .box {
  133. border: var(--box-border);
  134. background: var(--box-bg);
  135. }
  136. .tool {
  137. align-items: center;
  138. justify-content: center;
  139. text-align: center;
  140. border: none;
  141. }
  142. .tool-bt {
  143. background: var(--btn-modal);
  144. height: 50px;
  145. width: 150px;
  146. }
  147. .info {
  148. color: var(--info2);
  149. }
  150. .info1 {
  151. color: var(--info1);
  152. }
  153. .info2 {
  154. color: var(--modal-icon);
  155. }
  156. .info3 {
  157. font-size: 1.2em;
  158. color: #0000ff;
  159. }
  160. .modal {
  161. backdrop-filter: blur(5px);
  162. -webkit-backdrop-filter: blur(5px);
  163. }
  164. .modal-content {
  165. border: none;
  166. background: #00000000;
  167. color: var(--text-color);
  168. border: none !important;
  169. box-shadow: none !important;
  170. border: none !important;
  171. }
  172. .modal-dialog {
  173. padding: 0 0.5rem;
  174. }
  175. .bg-category {
  176. background: var(--category-color);
  177. }
  178. .bg-config {
  179. background: var(--config-color);
  180. }
  181. .btn {
  182. width: 150px;
  183. background-color: #171e2e;
  184. outline: none;
  185. height: 49px;
  186. border-radius: var(--btn-modal-border);
  187. text-transform: uppercase;
  188. font-weight: 600;
  189. margin: 10px 0;
  190. cursor: pointer;
  191. BORDER: NONE;
  192. transition: 0.5s;
  193. }
  194. </style>
  195. <style>/* ! tailwindcss v3.3.2 | 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-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}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: }::-webkit-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: }::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: }.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.relative{position:relative}.-top-32{top:-8rem}.-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}.ml-auto{margin-left:auto}.mr-2{margin-right:0.5rem}.ms-2{-webkit-margin-start:0.5rem;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}.h-12{height:3rem}.h-44{height:11rem}.h-56{height:14rem}.w-12{width:3rem}.w-44{width:11rem}.w-56{width:14rem}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.place-items-center{place-items:center}.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-full{border-radius:9999px}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.p-0{padding:0px}.p-1{padding:0.25rem}.p-10{padding:2.5rem}.p-2{padding:0.5rem}.p-5{padding:1.25rem}.px-5{padding-left:1.25rem;padding-right: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}.pb-44{padding-bottom:11rem}.pt-10{padding-top:2.5rem}.text-center{text-align:center}.text-start{text-align:start}.text-xs{font-size:0.75rem;line-height:1rem}.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.2 | 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-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}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: }::-webkit-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: }::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: }.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.relative{position:relative}.-top-32{top:-8rem}.-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}.ml-auto{margin-left:auto}.mr-2{margin-right:0.5rem}.ms-2{-webkit-margin-start:0.5rem;margin-inline-start:0.5rem}.mt-1{margin-top:0.25rem}.flex{display:flex}.h-12{height:3rem}.h-44{height:11rem}.h-56{height:14rem}.h-screen{height:100vh}.w-12{width:3rem}.w-44{width:11rem}.w-56{width:14rem}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-nowrap{flex-wrap:nowrap}.place-items-center{place-items:center}.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-full{border-radius:9999px}.rounded-xl{border-radius:0.75rem}.border-0{border-width:0px}.border-2{border-width:2px}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.p-0{padding:0px}.p-1{padding:0.25rem}.p-10{padding:2.5rem}.p-2{padding:0.5rem}.p-5{padding:1.25rem}.px-5{padding-left:1.25rem;padding-right: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}.pb-44{padding-bottom:11rem}.pt-10{padding-top:2.5rem}.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></head>
  196. <body style="
  197. background-color: white;
  198. background-image: none;
  199. " class="h-screen">
  200. <div class="container px-2 pt-10 pb-44 app-rounded" id="backverde" style="display: ;padding-bottom: 122px;padding-top: 38px;">
  201. <button class="app-bg-blue h-12 rounded-2xl py-2 px-2 text-white" onclick="ToolsModal.show()"><i class="bi bi-list-nested mr-2"></i>Menu</button>
  202. <button class="app-bg-blue h-12 rounded-2xl py-2 px-2 text-white" onclick="DtStartAppUpdate.execute()"><i class="bi bi-arrow-repeat mr-2"></i>Atualizar</button>
  203. <button class="app-bg-blue h-12 rounded-2xl py-2 px-2 text-white" onclick="loggerModal.show()"><i class="bi bi-file-earmark-text mr-2"></i>Registros</button>
  204. </div>
  205. <div class="flex flex-row items-center justify-center -top-32 relative" style="justify-content: center;display: flex;margin-left: -1rem;margin-top: 16px;">
  206. <div class="welcome d-flex align-items-center" style="font-family:inherit;font-size:21px;padding:0 0;height:70px;color:#fff;justify-items:normal;width:30pc;margin-top: -42px;justify-content:flex-start;margin-left: 37px;">
  207. <i class="bi bi-person" style="font-size:41px;margin-right:10px;margin-bottom:11px;margin-left:7px" id="usericon1"></i>
  208. <div class="d-flex flex-column" style="display:flex!important">
  209. <div style="display:inline-grid;margin-top:11px;margin-top:10px">
  210. <span style="font-size:19px;font-family:inherit" id="userinfo1">Bem-vindo (a)</span>
  211. <span style="font-size:13px;font-family:inherit" id="userinfo2">Desconectado</span>
  212. </div>
  213. <div style="display:inline-flex;margin-left:-47px;top:14px;left:19px;margin-bottom:-11px;margin-top:7px">
  214. <a class="ml-auto" onclick="DtStartWebViewActivity.execute('https://vpsbagual.xyz/renovar.php')" style="display:block;background: rgba(0, 0, 0, 0.2);padding:4px 9px;color:#fff;border-radius:10px;margin-left:4px;font-family:inherit;font-size: 12px;display:block;border: 1px solid #fff;">
  215. RENOVAR
  216. </a>
  217. </div>
  218. </div>
  219. </div>
  220. <div class="w-56 h-56 app-bg-gray-3 rounded-full items-center justify-center flex" style="display:block;width:auto;height:auto;margin-top:0;background-color: white;background-image: none;">
  221. <div class="w-44 h-44 app-bg-4 rounded-full flex justify-center items-center" id="btnc" style="width: 140px;height: 140px;align-items:center;background:linear-gradient(-45deg,#4071ff,#2b4089,#0098ff,#5995fd);border-radius:50em;border:6px solid #fff">
  222. <button id="icop" class="bi bi-power bg-white app-color-blue rounded-full p-10 power-icon" onclick="startStopVpn()" style="color:#4071ff;width: 120px;height: 120px;font-size: 40px;justify-content:center;top:1px"></button>
  223. </div>
  224. </div>
  225. </div>
  226. <div class="flex flex-col -top-36 relative" style="
  227. top: -130px;
  228. ">
  229. <div class="py-3 flex flex-row justify-center items-center">
  230. <span class="app-color-gray-1 mr-2">INSIRA SEUS DADOS</span>
  231. <i class="bi bi-box-arrow-in-right" style="color:#c0c6de"></i>
  232. </div>
  233. <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="
  234. color: #Fff;
  235. border: 1px solid #c3c9e0;
  236. border-radius: 10px;
  237. ">
  238. <i class="bi bi-lightning-fill" style="color:#000000"></i>
  239. <input placeholder="Escolha uma operadora" disabled="" id="config">
  240. <i class="bi bi-list" style="color:#000000"></i>
  241. </div>
  242. <div class="box d-flex gap-2 justify-content-center mb-2 mt-1 items-center px-6 py-2 mx-6 rounded-xl border-slate-150 border-2" style="display:flex!important;border: 1px solid #c3c9e0;border-radius: 10px;">
  243. <i class="bi bi-person-fill" style="color:#000000"></i>
  244. <input placeholder="USUÁRIO " id="username">
  245. </div>
  246. <div class="box d-flex gap-2 justify-content-center items-center px-6 py-2 mx-6 rounded-xl border-slate-150 border-2" style="display:flex!important;border: 1px solid #c3c9e0;border-radius: 10px;">
  247. <i class="bi bi-key-fill" style="color:#000000"></i>
  248. <input placeholder="SENHA" id="password" style="
  249. ">
  250. <i class="bi bi-eye-fill" style="color:#c0c6de" onclick="password.type==`text`?password.type = `password`:password.type = `text`"></i>
  251. </div>
  252. <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">
  253. <i class="icon fa fa-lock" style="color:#c0c6de"></i>
  254. <input placeholder="V2ray UUID" id="uuid">
  255. <i class="icon fa fa-eye" onclick="uuid.type==`text`?uuid.type = `password`:uuid.type = `text`"></i>
  256. </div>
  257. <div style="
  258. padding: 0px 28px;
  259. display: flex;
  260. color: #00f;
  261. justify-content: center;
  262. align-items: center;
  263. margin-top: -117px;
  264. justify-content: center;
  265. align-items: center;
  266. flex-wrap: wrap;
  267. margin-top: 57px;
  268. margin-bottom: 2px;
  269. ">
  270. <item style="
  271. background: transparent;
  272. border: 2px solid #C0C6DE;
  273. padding: 8px 10px;
  274. width: calc(48% - 5px);
  275. border-radius: 10px;
  276. text-align: center;
  277. display: flex;
  278. flex-direction: row;
  279. justify-content: space-between;
  280. align-items: center;
  281. text-align: center;
  282. margin-bottom: 11px;
  283. margin-right: 5px;
  284. color: #C0C6DE;
  285. height: 145px;
  286. display: block;
  287. ">
  288. <div>
  289. <font color="#1AA200">
  290. <i class="bi bi-shield-fill-check" style="
  291. font-size: 44px;
  292. margin-right: 0px;
  293. padding: 0px;
  294. text-align: center;
  295. justify-content: center;
  296. "></i>
  297. </font>
  298. <div style="
  299. ">
  300. <font color="#000000"><a style="
  301. font-size: 14px;
  302. margin-bottom: 0px;
  303. font-weight: 600;
  304. ">Rápido e Seguro</a></font>
  305. <a style="
  306. font-size: 10px;
  307. display: block;
  308. font-weight: 300;
  309. ">Sua conexão é criptografada e segura</a>
  310. <font color="#000000">
  311. <i id="inter" class="bi bi-toggle-off" style="
  312. font-size: 29px;
  313. margin-left: 4px;
  314. "></i>
  315. </font>
  316. </div>
  317. </div>
  318. </item>
  319. <item style="
  320. background: transparent;
  321. border: 2px solid #C0C6DE;
  322. padding: 8px 10px;
  323. width: calc(48% - 5px);
  324. border-radius: 10px;
  325. text-align: center;
  326. display: block;
  327. flex-direction: row;
  328. justify-content: space-between;
  329. align-items: center;
  330. text-align: center;
  331. margin-bottom: 11px;
  332. height: 145px;
  333. margin-right: 5px;
  334. color: #C0C6DE;
  335. margin-left: 9px;
  336. ">
  337. <div>
  338. <font color="#fcb503">
  339. <i class="bi bi-infinity" style="
  340. font-size: 44px;
  341. margin-right: 0px;
  342. padding: 0px;
  343. text-align: center;
  344. justify-content: center;
  345. "></i>
  346. </font>
  347. <div style="
  348. ">
  349. <font color="#000000"><a style="
  350. font-size: 14px;
  351. margin-bottom: 0px;
  352. font-weight: 600;
  353. ">Sem Limites</a></font>
  354. <a style="
  355. font-size: 10px;
  356. display: block;
  357. font-weight: 300;
  358. ">Navegue na internet sem limite de dados.</a>
  359. <font color="#000000"><i id="inter2" class="bi bi-toggle-off" style="
  360. font-size: 29px;
  361. margin-left: 4px;
  362. "></i></font>
  363. </div>
  364. </div>
  365. </item>
  366. <item style="
  367. background: transparent;
  368. border: 2px solid #C0C6DE;
  369. padding: 4px 4px;
  370. width: calc(97% - 0px);
  371. border-radius: 10px;
  372. text-align: start;
  373. flex-direction: row;
  374. justify-content: space-between;
  375. align-items: center;
  376. margin-bottom: 11px;
  377. height: 36px;
  378. display: block;
  379. margin-right: 5px;
  380. color: #C0C6DE;
  381. text-align: center;
  382. margin-left: -1px;
  383. ">
  384. <div style="display: inline-flex;align-items: center;">
  385. <div style="
  386. padding: 0px 5px;
  387. ">
  388. <i class="bi bi-hdd-network" style="
  389. font-size: 19px;
  390. margin-left: 2px;
  391. margin-right: 9px;
  392. "></i>
  393. <a style="
  394. font-size: 12px;
  395. margin-bottom: 0px;
  396. font-weight: 600;
  397. ">IP:</a>
  398. <a style="font-size: 12px;" id="ip">192.168.0.1</a>
  399. </div>
  400. <div style="
  401. padding: 0px 5px;
  402. ">
  403. <i class="bi bi-diagram-2" style="
  404. font-size: 19px;
  405. margin-left: 2px;
  406. margin-right: 9px;
  407. "></i>
  408. <a style="
  409. font-size: 12px;
  410. margin-bottom: 0px;
  411. font-weight: 600;
  412. ">DNS:</a>
  413. <a id="dns1" style="font-size: 12px;">Lento</a>
  414. </div>
  415. </div>
  416. </item>
  417. </div>
  418. </div>
  419. <div onclick="loggerModal.show()" class="teste" id="footer1" style="background:red;color:#fff;padding:10px;position:fixed;bottom:0;border-top-left-radius:20px;left:0;width:100%;text-align:center;z-index:9999;border-top-right-radius:20px">
  420. <i class="bi bi-broadcast-pin mr-2"></i>
  421. <a href="">Status:</a>
  422. <span class="status app-color-blue font-semibold" style="color:red" id="state">LBL_STATE_DISCONNECTED</span>
  423. </div>
  424. <div class="modal fade" id="configModal">
  425. <div class="modal-dialog modal-dialog-centered" role="document">
  426. <div class="modal-content rounded-3 shadow">
  427. <div class="modal-header border-bottom-0 pb-0">
  428. <h1 class="modal-title fs-5" style="color:var(--text-color)">Selecione uma Conexão:</h1>
  429. <button class="btn-close btn-close-white" data-bs-dismiss="modal"></button>
  430. </div>
  431. <div class="modal-body p-1 text-center">
  432. <ul class="list-group app-bg-blue2 overflow-y-auto config-body" style="max-height:600px"></ul>
  433. </div>
  434. </div>
  435. </div>
  436. </div>
  437. <div class="modal fade" id="loggerModal">
  438. <div class="modal-dialog modal-dialog-centered" role="document">
  439. <div class="modal-content rounded-3 shadow">
  440. <div class="modal-body p-1 text-center">
  441. <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>
  442. </div>
  443. <div class="modal-footer flex-nowrap p-0">
  444. <button class="btn btn-primary w-100 clear-logger" style="background-color:var(--btn-modal)">LIMPAR</button>
  445. <button type="button" class="btn btn-primary w-100" data-bs-dismiss="modal" style="background-color:var(--btn-modal)">FECHAR</button>
  446. </div>
  447. </div>
  448. </div>
  449. </div>
  450. <div class="tool webm modal fade" index="-1" id="ToolsModal">
  451. <div class="modal-dialog modal-dialog-centered" role="document">
  452. <div class="modal-content">
  453. <div class="tool modal-header">
  454. <h5 class="modal-title" style="color:#fff">FERRAMENTAS</h5>
  455. </div>
  456. <div class="modal-body" style="display: flex; justify-content: center; align-items: center;">
  457. <button type="button" class="rounded-2xl text-white" id="hotspot-button" style="background: rgba(0, 0, 0, 0.3); padding: 10px; outline: none; border: 0; display: flex; align-items: center; gap: 5px;">
  458. <i class="bi bi-router"></i>
  459. <span id="hotspot-value">ATIVAR HOTSPOT</span>
  460. </button>
  461. </div>
  462. <div class="modal-body">
  463. <button class="tool-bt rounded-2xl text-white" onclick="DtStartWebViewActivity.execute(&quot;https://www.speedtest.net/pt&quot;)"><i class="info2 bi bi-speedometer mr-2"></i> SPEEDTEST</button>
  464. </div>
  465. <div class="modal-body">
  466. <button class="tool-bt rounded-2xl text-white" onclick="DtStartApnActivity.execute()"><i class="bi bi-wrench-adjustable-circle"></i> CONFIGURAR APN</button>
  467. <div class="modal-body">
  468. <button class="tool-bt rounded-2xl text-white" onclick="DtStartWebViewActivity.execute('https://bit.ly/3MWk3Os')"><i class="bi bi-file-earmark-text mr-2"></i> TERMOS DE USO</button>
  469. </div>
  470. <div class="modal-body">
  471. <button class="tool-bt rounded-2xl text-white" onclick="DtCleanApp.execute()"><i class="info2 bi bi-trash3 mr-2"></i> LIMPAR DADOS</button>
  472. </div>
  473. <div class="modal-body">
  474. </div>
  475. <div class="tool modal-footer">
  476. <button type="button" class="btn btn-primary" data-bs-dismiss="modal" style="background-color: var(--btn-modal);">FECHAR</button>
  477. </div>
  478. </div>
  479. </div>
  480. </div>
  481. <div class="modal fade" id="checkUserModal" index="1">
  482. <div class="modal-dialog modal-dialog-centered" role="document">
  483. <div class="modal-content rounded-3 shadow">
  484. <div class="modal-header border-bottom-0 pb-0">
  485. <h1 class="modal-title fs-5 chk-title text-light"></h1>
  486. <button class="btn-close btn-close-white" data-bs-dismiss="modal"></button>
  487. </div>
  488. <div class="modal-body text-center">
  489. <p class="fs-5 mb-0 chk-message text-light"></p>
  490. </div>
  491. </div>
  492. </div>
  493. </div>
  494. <div class="md modal fade" id="speedTestModal">
  495. <div class="md modal-dialog modal-dialog-centered" role="document">
  496. <div class="md modal-content rounded-3 shadow">
  497. <div class="md modal-header border-bottom-0 py-3">
  498. <button class="btn-close btn-close-white" data-bs-dismiss="modal" aria-label="Close"></button>
  499. </div>
  500. <div class="modal-body ratio rounded-bottom-3" style="height:600px">
  501. <div class="spinner d-flex w-100 h-100 align-items-center justify-content-center">
  502. <div class="spinner-border text-light p-5" role="status">
  503. <span class="visually-hidden">Loading...</span>
  504. </div>
  505. </div>
  506. <iframe class="rounded-bottom-3" id="speedFrame"></iframe>
  507. </div>
  508. </div>
  509. </div>
  510. </div>
  511. <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/js/bootstrap.min.js"></script>
  512. <script>
  513. const appGetStatusHotspot = () => DtGetStatusHotSpotService.execute()
  514. const appStartHotspot = () => DtStartHotSpotService.execute()
  515. const appStopHotspot = () => DtStopHotSpotService.execute()
  516. const hotspotValue = document.querySelector('#hotspot-value')
  517. const hotspotButton = document.querySelector('#hotspot-button')
  518. const startHotspot = () => {
  519. appStartHotspot()
  520. hotspotValue.innerHTML = 'PARAR HOTSPOT'
  521. }
  522. const stopHotspot = () => {
  523. appStopHotspot()
  524. hotspotValue.innerHTML = 'INICIAR HOTSPOT'
  525. }
  526. const toggleHotspot = () => {
  527. appGetStatusHotspot() === 'STOPPED' ? startHotspot() : stopHotspot()
  528. }
  529. const setStatusHotspot = () => {
  530. if (appGetStatusHotspot() === 'STOPPED') {
  531. hotspotValue.innerHTML = 'INICIAR HOTSPOT'
  532. } else {
  533. hotspotValue.innerHTML = 'PARAR HOTSPOT'
  534. }
  535. }
  536. hotspotButton.addEventListener('click', (e) => {
  537. e.preventDefault()
  538. toggleHotspot()
  539. })
  540. setStatusHotspot()
  541. </script>
  542. <script>
  543. Object.defineProperty(String.prototype, 't', {
  544. value: function t() {
  545. return window?.DtTranslateText?.execute('' + this) ?? '' + this
  546. },
  547. writable: true,
  548. configurable: true,
  549. })
  550. const config = document.querySelector('#config')
  551. config.parentElement.onclick = () => showConfigsModal();
  552. const username = document.querySelector('#username')
  553. username.oninput = e => DtUsername.set(e.target.value)
  554. const password = document.querySelector('#password')
  555. password.oninput = e => DtPassword.set(e.target.value)
  556. const uuid = document.querySelector('#uuid')
  557. uuid.oninput = e => DtUuid.set(e.target.value)
  558. const clearLogger = document.querySelector('.clear-logger')
  559. const checkUserModal = new bootstrap.Modal(document.querySelector('#checkUserModal'))
  560. const configModal = new bootstrap.Modal(document.querySelector('#configModal'))
  561. const loggerModal = new bootstrap.Modal(document.querySelector('#loggerModal'))
  562. const ToolsModal = new bootstrap.Modal(document.querySelector('#ToolsModal'))
  563. const speedTestModal = new bootstrap.Modal(document.querySelector('#speedTestModal'))
  564. const dtConfigClickListener = () => {
  565. const data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{ "auth": {"username": ""} }`)
  566. const isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');
  567. config.placeholder = data.name ?? 'ESCOLHA UMA OPERADORA ';
  568. username.parentElement.style.setProperty('display', !data?.auth?.username && !isV2ray ? 'flex' : 'none', 'important')
  569. password.parentElement.style.setProperty('display', !data?.auth?.password && !isV2ray ? 'flex' : 'none', 'important')
  570. uuid.parentElement.style.setProperty('display', !data?.auth?.v2ray_uuid && isV2ray ? 'flex' : 'none', 'important')
  571. }
  572. const startStopVpn = e => {
  573. if (DtGetVpnState.execute() != 'DISCONNECTED') {
  574. DtExecuteVpnStop.execute()
  575. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #4071ff, #2b4089, #0098ff, #5995fd)";
  576. document.getElementById("btnc").style.background = "blue";
  577. } else {
  578. DtExecuteVpnStart.execute()
  579. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #4071ff, #2b4089, #0098ff, #5995fd)";
  580. document.getElementById("btnc").style.background = "blue";
  581. }
  582. }
  583. clearLogger.addEventListener('click', () => DtClearLogs.execute())
  584. speedTestModal._element.addEventListener('shown.bs.modal', () => {
  585. const iframe = document.querySelector('#speedFrame');
  586. if (!iframe.src) {
  587. iframe.src = 'https://fast.com/pt/'
  588. iframe.addEventListener('load', () => {
  589. mp3Modal._element.querySelector('.spinner').classList.add('d-none')
  590. })
  591. }
  592. })
  593. speedTestModal._element.addEventListener('hide.bs.modal', () => {
  594. const iframe = document.querySelector('#speedFrame');
  595. iframe.src = '';
  596. })
  597. const dtVpnStateListener = state => {
  598. const isRunning = state != 'DISCONNECTED';
  599. const isConnected = state == 'CONNECTED';
  600. const isDesconnected = state == 'DISCONNECTED';
  601. const status = document.querySelector('#state')
  602. status.innerHTML = ('LBL_STATE_' + state).t()
  603. if (isRunning) {
  604. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #ffcc00, #d5de0a, #ebd138, #ffcc00)";
  605. document.getElementById("footer1").style.background = "#ffcc00";
  606. document.getElementById("icop").style.color = "#dce600";
  607. username.setAttribute('readonly', 'true')
  608. password.setAttribute('readonly', 'true')
  609. status.style.color = '#00ff15'
  610. } else {
  611. username.removeAttribute('readonly')
  612. password.removeAttribute('readonly')
  613. status.style.color = 'RED'
  614. }
  615. if (isConnected) {
  616. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #64dd17, #00ce6e, #64dd17, #5ddf15)";
  617. document.getElementById("footer1").style.background = "#64dd17";
  618. document.getElementById("icop").style.color = "#64dd17";
  619. const inter = document.getElementById('inter');
  620. const inter2 = document.getElementById('inter2');
  621. inter.className = "bi bi-toggle-on";
  622. inter2.className = "bi bi-toggle-on";
  623. const elemento = document.getElementById('userinfo1');
  624. elemento.innerHTML = username.value;
  625. dns1.innerHTML = "1.1.1.1";
  626. username.setAttribute('readonly', 'true')
  627. password.setAttribute('readonly', 'true')
  628. status.style.color = '#00ff15'
  629. fetch('https://api.ipify.org/?format=json')
  630. .then(response => response.json())
  631. .then(data => {
  632. const publicIP = data.ip;
  633. document.getElementById('ip').textContent = publicIP;
  634. })
  635. .catch(error => {
  636. console.log('Erro ao obter o endereço IP público:', error);
  637. });
  638. }
  639. if (isDesconnected) {
  640. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #ff8764, #ff7463, #ff5c5f, #ff3858)";
  641. document.getElementById("footer1").style.background = "red";
  642. document.getElementById("icop").style.color = "#ff0000";
  643. const elemento3 = document.getElementById('usericon1');
  644. const elemento2 = document.getElementById('userinfo2');
  645. elemento3.className = "bi bi-person";
  646. elemento2.innerHTML = "Desconectado";
  647. const inter3 = document.getElementById('inter');
  648. const inter4 = document.getElementById('inter2');
  649. inter3.className = "bi bi-toggle-off";
  650. inter4.className = "bi bi-toggle-off";
  651. }
  652. }
  653. const dtCheckUserStartedListener = () => {
  654. const data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{}`)
  655. const isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');
  656. if (isV2ray || !data.urlCheckUser)
  657. return;
  658. const html = `
  659. <div class="d-flex justify-content-center">
  660. <div class="spinner-border p-4" role="status">
  661. <span class="visually-hidden">Loading...</span>
  662. </div>
  663. </div>
  664. `
  665. checkUserModal._element.querySelector('.chk-title').textContent = 'CHECK USER'
  666. checkUserModal._element.querySelector('.chk-message').innerHTML = html;
  667. checkUserModal.show()
  668. }
  669. const dtCheckUserModelListener = model => {
  670. const data = JSON.parse(model ?? `{"username": "test"}`)
  671. const elemento2 = document.getElementById('userinfo2');
  672. const elemento3 = document.getElementById('usericon1');
  673. var dias = `${data.expiration_days}`;
  674. var diasrestantes = "dias restantes";
  675. var resultado = dias + " " + diasrestantes;
  676. elemento2.innerHTML = resultado;
  677. elemento3.className = "bi bi-person-check";
  678. }
  679. const showConfigsModal = () => {
  680. 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"}]}]'
  681. const data = JSON.parse(window?.DtGetConfigs?.execute() || mock)
  682. data.sort((a, b) => a.sorter - b.sorter)
  683. data.forEach(item => item.items.sort((a, b) => a.sorter - b.sorter))
  684. const body = configModal._element.querySelector('.config-body')
  685. body.innerHTML = ''
  686. data.forEach(category => {
  687. const categoryElement = document.createElement('li')
  688. categoryElement.className = 'list-group-item bg-transparent border-0 mb-1 rounded-1 px-1'
  689. categoryElement.style.color = 'var(--text-color)'
  690. categoryElement.innerHTML = `<span class="fw-bold w-100 d-block p-1 rounded-1 mb-1 bg-category">${category.name}</span>`
  691. const configUlElement = document.createElement('ul')
  692. configUlElement.className = 'list-group overflow-y-auto'
  693. category.items.forEach(item => {
  694. const configElement = document.createElement('li')
  695. configElement.className = 'list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1'
  696. configElement.style.color = 'var(--text-color)'
  697. configElement.innerHTML = `
  698. <img src="${item.icon}" width="40" height="35">
  699. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  700. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">${item.name}</span>
  701. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;">${item.description || ''}</span>
  702. </div>
  703. <div class="d-flex flex-column ms-2">
  704. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">${item.mode}</span>
  705. </div>
  706. </li>
  707. `
  708. configElement.addEventListener('click', e => {
  709. window?.DtSetConfig?.execute(item.id)
  710. configModal.hide()
  711. })
  712. configUlElement.appendChild(configElement)
  713. })
  714. categoryElement.appendChild(configUlElement)
  715. body.appendChild(categoryElement)
  716. })
  717. configModal.show()
  718. }
  719. const dtOnNewLogListener = () => {
  720. const mock = [];
  721. for (let i = 0; i < 30; i++) {
  722. mock.push({
  723. 'TIME': 'MESSAGE ' + i
  724. })
  725. }
  726. const log = window?.DtGetLogs?.execute() || JSON.stringify(mock)
  727. const data = JSON.parse(log)
  728. let content = '';
  729. data.forEach(item => {
  730. 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);">';
  731. content += Object.keys(item)[0] + " " + item[Object.keys(item)]
  732. content += '</li>';
  733. })
  734. loggerModal._element.querySelector('.logger-content').innerHTML = content;
  735. const listGroup = loggerModal._element.querySelector('.list-group')
  736. listGroup.scrollTo(0, listGroup.scrollHeight)
  737. }
  738. username.value = window?.DtUsername?.get() ?? ''
  739. password.value = window?.DtPassword?.get() ?? ''
  740. uuid.value = window?.DtUuid?.get() ?? ''
  741. dtOnNewLogListener()
  742. dtConfigClickListener()
  743. dtVpnStateListener(window?.DtGetVpnState?.execute() ?? 'DISCONNECTED')
  744. </script>
  745. <script>
  746. const config = JSON.parse(DtGetAppConfig.execute());
  747. const urlCheckUser = new URL(config.urlCheckUser);
  748. urlCheckUser.protocol = 'http:';
  749. const createConnection = () => new WebSocket(urlCheckUser);
  750. const startActions = socket => {
  751. socket.send(JSON.stringify({
  752. action: 'all',
  753. data: {}
  754. }));
  755. }
  756. const parseResponseData = data => {
  757. data = JSON.parse(data);
  758. console.log(data)
  759. if (data.total != undefined) {
  760. const total = data.total;
  761. document.getElementById('total').innerHTML = String(total).padStart(2, '0');
  762. }
  763. }
  764. const startSocket = () => {
  765. const socket = createConnection();
  766. socket.onopen = e => startActions(socket);
  767. socket.onmessage = e => parseResponseData(e.data);
  768. }
  769. const setVpnState = state => {
  770. if (state == 'CONNECTED')
  771. startSocket();
  772. }
  773. startSocket();
  774. </script>
  775. <script>
  776. class AndroidMock {
  777. static getLocalIP() {
  778. return '192.168.0.1';
  779. }
  780. static getConfig() {
  781. return JSON.stringify({
  782. urlCheckUser: ''
  783. });
  784. }
  785. static openRadioInfo() {
  786. console.log('openRadioInfo');
  787. }
  788. }
  789. </script>
  790. <script>
  791. function showLocalIP(android) {
  792. document.getElementById('ip').innerHTML = android.getLocalIP();
  793. setInterval(() => {
  794. document.getElementById('ip').innerHTML = android.getLocalIP();
  795. }, 2000000)
  796. }
  797. function showCheckUser(android) {
  798. const config = JSON.parse(window?.DtGetDefaultConfig?.execute() ?? android.getConfig());
  799. const urlCheckUser = new URL(config.urlCheckUser);
  800. urlCheckUser.protocol = 'ws:';
  801. const socket = new WebSocket(urlCheckUser);
  802. socket.onopen = function(e) {
  803. socket.send(JSON.stringify({
  804. action: 'all',
  805. data: {}
  806. }));
  807. };
  808. socket.onmessage = function(event) {
  809. const data = JSON.parse(event.data);
  810. if (data.total === undefined)
  811. return;
  812. const total = data.total;
  813. document.getElementById('total').innerHTML = ' ' + String(total).padStart(2, '0');
  814. socket.close();
  815. };
  816. }
  817. window.onload = function() {
  818. const android = window.Android || AndroidMock;
  819. showLocalIP(android);
  820. showCheckUser(android);
  821. }
  822. </script>
  823. </body></html>

comments powered by Disqus