BRALFANETLayoutApp


SUBMITTED BY: BRALFANET

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

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

FORMAT: Text only

SIZE: 65.4 kB

HITS: 512

  1. [
  2. {
  3. "id": 3807,
  4. "label": "Nome do app",
  5. "name": "APP_NAME",
  6. "value": null,
  7. "type": "STRING",
  8. "status": "ACTIVE",
  9. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  10. },
  11. {
  12. "id": 3808,
  13. "label": "Logo do app",
  14. "name": "APP_LOGO",
  15. "value": null,
  16. "type": "IMAGE",
  17. "status": "ACTIVE",
  18. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  19. },
  20. {
  21. "id": 3809,
  22. "label": "Imagem de fundo",
  23. "name": "APP_BACKGROUND_IMAGE",
  24. "value": null,
  25. "type": "IMAGE",
  26. "status": "ACTIVE",
  27. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  28. },
  29. {
  30. "id": 3810,
  31. "label": "Tipo do fundo do app",
  32. "name": "APP_BACKGROUND_TYPE",
  33. "value": {
  34. "options": [
  35. {
  36. "label": "Imagem",
  37. "value": "IMAGE"
  38. },
  39. {
  40. "label": "Cor",
  41. "value": "COLOR"
  42. }
  43. ],
  44. "selected": "COLOR"
  45. },
  46. "type": "SELECT",
  47. "status": "ACTIVE",
  48. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  49. },
  50. {
  51. "id": 3811,
  52. "label": "Cor de fundo",
  53. "name": "APP_BACKGROUND_COLOR",
  54. "value": "#14142c",
  55. "type": "COLOR",
  56. "status": "ACTIVE",
  57. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  58. },
  59. {
  60. "id": 3812,
  61. "label": "Cor do card inicial",
  62. "name": "APP_CARD_COLOR",
  63. "value": "#16244700",
  64. "type": "COLOR",
  65. "status": "ACTIVE",
  66. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  67. },
  68. {
  69. "id": 7979,
  70. "label": "Raio do card inicial",
  71. "name": "APP_CARD_RADIUS",
  72. "value": 20,
  73. "type": "INTEGER",
  74. "status": "ACTIVE",
  75. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  76. },
  77. {
  78. "id": 7980,
  79. "label": "Cor do card de status",
  80. "name": "APP_CARD_STATUS_COLOR",
  81. "value": "#14152cff",
  82. "type": "COLOR",
  83. "status": "ACTIVE",
  84. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  85. },
  86. {
  87. "id": 7981,
  88. "label": "Raio do card de status",
  89. "name": "APP_CARD_STATUS_RADIUS",
  90. "value": 12,
  91. "type": "INTEGER",
  92. "status": "ACTIVE",
  93. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  94. },
  95. {
  96. "id": 3813,
  97. "label": "Cor do card de configurações",
  98. "name": "APP_CARD_CONFIG_COLOR",
  99. "value": "#14142c",
  100. "type": "COLOR",
  101. "status": "ACTIVE",
  102. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  103. },
  104. {
  105. "id": 3814,
  106. "label": "Cor do fundo dos dialogs",
  107. "name": "APP_DIALOG_BACKGROUND_COLOR",
  108. "value": "#14142c",
  109. "type": "COLOR",
  110. "status": "ACTIVE",
  111. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  112. },
  113. {
  114. "id": 11850,
  115. "label": "Cor do fundo do dialog de log",
  116. "name": "APP_DIALOG_LOGGER_COLOR",
  117. "value": "#14142c",
  118. "type": "COLOR",
  119. "status": "ACTIVE",
  120. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  121. },
  122. {
  123. "id": 3815,
  124. "label": "Cor das bordas",
  125. "name": "APP_BORDER_COLOR",
  126. "value": "#1210246b",
  127. "type": "COLOR",
  128. "status": "ACTIVE",
  129. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  130. },
  131. {
  132. "id": 7982,
  133. "label": "Cor dos inputs",
  134. "name": "APP_INPUT_COLOR",
  135. "value": "#1d242e00",
  136. "type": "COLOR",
  137. "status": "ACTIVE",
  138. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  139. },
  140. {
  141. "id": 7983,
  142. "label": "Raio dos inputs",
  143. "name": "APP_INPUT_RADIUS",
  144. "value": 17,
  145. "type": "INTEGER",
  146. "status": "ACTIVE",
  147. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  148. },
  149. {
  150. "id": 3816,
  151. "label": "Cor dos textos",
  152. "name": "APP_TEXT_COLOR",
  153. "value": "#b0a8ffff",
  154. "type": "COLOR",
  155. "status": "ACTIVE",
  156. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  157. },
  158. {
  159. "id": 3817,
  160. "label": "Cor dos botões",
  161. "name": "APP_BUTTON_COLOR",
  162. "value": "#1210246b",
  163. "type": "COLOR",
  164. "status": "ACTIVE",
  165. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  166. },
  167. {
  168. "id": 7984,
  169. "label": "Raio dos botões",
  170. "name": "APP_BUTTON_RADIUS",
  171. "value": 16,
  172. "type": "INTEGER",
  173. "status": "ACTIVE",
  174. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  175. },
  176. {
  177. "id": 3818,
  178. "label": "Cor dos icones",
  179. "name": "APP_ICON_COLOR",
  180. "value": "#9f9fffab",
  181. "type": "COLOR",
  182. "status": "ACTIVE",
  183. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  184. },
  185. {
  186. "id": 3819,
  187. "label": "Exibir modo de conexão",
  188. "name": "APP_SHOW_CONNECTION_MODE",
  189. "value": false,
  190. "type": "BOOLEAN",
  191. "status": "ACTIVE",
  192. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  193. },
  194. {
  195. "id": 22784,
  196. "label": "Atualizar automaticamente as configurações ao lançar uma atualização.",
  197. "name": "APP_CONFIG_AUTO_UPDATE",
  198. "value": true,
  199. "type": "BOOLEAN",
  200. "status": "ACTIVE",
  201. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  202. },
  203. {
  204. "id": 4922,
  205. "label": "Iniciar o app automaticamente ao reiniciar o dispositivo",
  206. "name": "APP_AUTO_START",
  207. "value": false,
  208. "type": "BOOLEAN",
  209. "status": "ACTIVE",
  210. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  211. },
  212. {
  213. "id": 7985,
  214. "label": "Usar limiter de conexão",
  215. "name": "APP_CONNECTION_LIMITER",
  216. "value": false,
  217. "type": "BOOLEAN",
  218. "status": "ACTIVE",
  219. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  220. },
  221. {
  222. "id": 12836,
  223. "label": "Usar botão de atualizações",
  224. "name": "APP_BTN_UPDATE_ENABLED",
  225. "value": true,
  226. "type": "BOOLEAN",
  227. "status": "ACTIVE",
  228. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  229. },
  230. {
  231. "id": 12837,
  232. "label": "Usar botão de registros",
  233. "name": "APP_BTN_LOGGER_ENABLED",
  234. "value": true,
  235. "type": "BOOLEAN",
  236. "status": "ACTIVE",
  237. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  238. },
  239. {
  240. "id": 12838,
  241. "label": "Usar botão de pagina webview",
  242. "name": "APP_BTN_PAGE_ENABLED",
  243. "value": true,
  244. "type": "BOOLEAN",
  245. "status": "ACTIVE",
  246. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  247. },
  248. {
  249. "id": 14425,
  250. "label": "Ativar dialog de erros",
  251. "name": "APP_DIALOG_ERROR_ENABLED",
  252. "value": true,
  253. "type": "BOOLEAN",
  254. "status": "ACTIVE",
  255. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  256. },
  257. {
  258. "id": 14426,
  259. "label": "Ativar dialog de checkuser",
  260. "name": "APP_CHECKUSER_DIALOG_ENABLED",
  261. "value": false,
  262. "type": "BOOLEAN",
  263. "status": "ACTIVE",
  264. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  265. },
  266. {
  267. "id": 14427,
  268. "label": "Ativar toast de sucesso",
  269. "name": "APP_SUCCESS_TOAST_ENABLED",
  270. "value": true,
  271. "type": "BOOLEAN",
  272. "status": "ACTIVE",
  273. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  274. },
  275. {
  276. "id": 14428,
  277. "label": "Ativar toast de erro",
  278. "name": "APP_ERROR_TOAST_ENABLED",
  279. "value": true,
  280. "type": "BOOLEAN",
  281. "status": "ACTIVE",
  282. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  283. },
  284. {
  285. "id": 14429,
  286. "label": "Usar layout webview",
  287. "name": "APP_LAYOUT_WEBVIEW_ENABLED",
  288. "value": true,
  289. "type": "BOOLEAN",
  290. "status": "ACTIVE",
  291. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  292. },
  293. {
  294. "id": 3820,
  295. "label": "Mensagem",
  296. "name": "APP_MESSAGE",
  297. "value": "Bem-vindo ao SSH T PROJECT - seu aplicativo de VPN confiável!\n<br><br>\nGostaríamos de informar que, para garantir a melhor experiência possível, é importante que você esteja ciente dos nossos termos e condições.\n<br><br>\nPara acessar essas informações importantes, você pode encontrar um botão dedicado na parte inferior da interface do aplicativo. Recomendamos que você leia atentamente todos os detalhes fornecidos nessa seção.\n<br><br>\nTenha uma experiência fantástica!\n<br><br>\nObrigado por escolher o SSH T Project. Estamos empolgados para fazer parte da sua jornada online. Aproveite todos os benefícios que nossa VPN tem a oferecer!\n<br><br>\nAtenciosamente,\nEquipe do SSH T PROJECT",
  298. "type": "TEXT",
  299. "status": "ACTIVE",
  300. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  301. },
  302. {
  303. "id": 3822,
  304. "label": "URL de atualização do aplicativo",
  305. "name": "APP_UPDATE_URL",
  306. "value": " ",
  307. "type": "URL",
  308. "status": "ACTIVE",
  309. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  310. },
  311. {
  312. "id": 3821,
  313. "label": "Tipo de mensagem",
  314. "name": "APP_MESSAGE_TYPE",
  315. "value": {
  316. "options": [
  317. {
  318. "label": "Alerta",
  319. "value": "ALERT"
  320. },
  321. {
  322. "label": "Informação",
  323. "value": "INFO"
  324. },
  325. {
  326. "label": "Boas vindas",
  327. "value": "WELCOME"
  328. },
  329. {
  330. "label": "Sem mensagem",
  331. "value": "NONE"
  332. }
  333. ],
  334. "selected": "WELCOME"
  335. },
  336. "type": "SELECT",
  337. "status": "ACTIVE",
  338. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  339. },
  340. {
  341. "id": 14430,
  342. "label": "LAYOUT WEBVIEW (POR SUA CONTA E RISCO)",
  343. "name": "APP_LAYOUT_WEBVIEW",
  344. "value": "<html><head>
  345. <meta charset="UTF-8">
  346. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  347. <meta http-equiv="Expires" content="Tue, 31 Dec 2030 23:59:59 GMT">
  348. <meta http-equiv="Cache-Control" content="public, max-age=31536000">
  349. <meta name="viewport" content="width=device-width,initial-scale=1">
  350. <title>GUARDIAN</title>
  351. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css">
  352. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/css/bootstrap.min.css">
  353. <script src="https://cdn.tailwindcss.com"></script>
  354. <style>
  355. @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');
  356. :root {
  357. /*Editar o modal*/
  358. --btn-modal: #0000003f;
  359. --btn-border: 1px solid #4071FF;
  360. --btn-modal-border: 50px;
  361. --modal-shadow: #ffffff;
  362. --modal-bg: #171e2e;
  363. --modal-icon: #fff;
  364. --config-color: #0000003f;
  365. --category-color: #0000003f;
  366. --text-color: #ffffff;
  367. /*Editar Layout*/
  368. --fundo: #ffffff;
  369. --topo: #0000008f;
  370. --icon: #4071FF;
  371. --icon-bg: #E5EAFC;
  372. --config: #F7F7FC;
  373. --box-border: 1px solid #C0C6DE;
  374. --box-bg: transparent;
  375. --box-icon: black;
  376. --info1: #C0C6DE;
  377. --info2: #4071FF;
  378. }
  379. body {
  380. font-family: 'Be Vietnam Pro', sans-serif;
  381. background: var(--fundo);
  382. height: 100vh;
  383. width: 100vw;
  384. justify-content: center;
  385. align-items: center;
  386. }
  387. .container {
  388. display: flex;
  389. flex-direction: row;
  390. justify-content: space-between;
  391. background: var(--topo);
  392. width: 100vw;
  393. background: #4071ff;
  394. }
  395. button.power-icon {
  396. background: #ccc;
  397. border-radius: 80px;
  398. display: flex;
  399. -webkit-text-stroke: 3px;
  400. }
  401. .app-bg-gray-1 {
  402. background: var(--config);
  403. }
  404. .app-bg-gray-2 {
  405. background: #ffffff;
  406. box-shadow: rgba(0, 0, 0, 0.2) 0px 20px 30px;
  407. box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
  408. }
  409. .app-bg-gray-3 {
  410. background: #fff;
  411. }
  412. .app-bg-4 {
  413. background: linear-gradient(-45deg, #4071ff, #2b4089, #0098ff, #5995fd);
  414. background-size: 400% 400%;
  415. animation: gradient 5s ease infinite;
  416. }
  417. @keyframes gradient {
  418. 0% {
  419. background-position: 0% 50%;
  420. }
  421. 50% {
  422. background-position: 100% 50%;
  423. }
  424. 100% {
  425. background-position: 0% 50%;
  426. }
  427. }
  428. .app-bg-blue {
  429. background: #0000ff;
  430. BORDER: 1PX SOLID #fff;
  431. PADDING: 12PX 10PX !IMPORTANT;
  432. box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
  433. }
  434. .app-bg-blue2 {
  435. background: #62656a;
  436. BORDER: 0PX SOLID #fff;
  437. PADDING: 0PX 0PX !IMPORTANT;
  438. box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
  439. }
  440. .app-color-blue {
  441. color: #4071FF;
  442. }
  443. .app-color-blue-escuro {
  444. color: #00003f;
  445. }
  446. .app-color-gray-1 {
  447. color: #4d4d4d;
  448. }
  449. .app-rounded {
  450. border-bottom-left-radius: 50px;
  451. border-bottom-right-radius: 50px;
  452. background: blue;
  453. }
  454. .status {
  455. font-size: 1em;
  456. color: #fff !important;
  457. }
  458. .put {
  459. border-radius: 60px;
  460. }
  461. .icon {
  462. font-size: 0.8em;
  463. color: var(--box-icon);
  464. }
  465. input {
  466. width: 100%;
  467. background: transparent;
  468. border: none;
  469. outline: none;
  470. color: var(--box-typing);
  471. line-height: 1;
  472. font-weight: 600;
  473. font-size: 17.6px;
  474. }
  475. .box {
  476. border: var(--box-border);
  477. background: var(--box-bg);
  478. }
  479. .tool {
  480. align-items: center;
  481. justify-content: center;
  482. text-align: center;
  483. border: none;
  484. }
  485. .tool-bt {
  486. background: var(--btn-modal);
  487. height: 50px;
  488. width: 150px;
  489. }
  490. .info {
  491. color: var(--info2);
  492. }
  493. .info1 {
  494. color: var(--info1);
  495. }
  496. .info2 {
  497. color: var(--modal-icon);
  498. }
  499. .info3 {
  500. font-size: 1.2em;
  501. color: #0000ff;
  502. }
  503. .modal {
  504. backdrop-filter: blur(5px);
  505. -webkit-backdrop-filter: blur(5px);
  506. }
  507. .modal-content {
  508. border: none;
  509. background: #00000000;
  510. color: var(--text-color);
  511. border: none !important;
  512. box-shadow: none !important;
  513. border: none !important;
  514. }
  515. .modal-dialog {
  516. padding: 0 0.5rem;
  517. }
  518. .bg-category {
  519. background: var(--category-color);
  520. }
  521. .bg-config {
  522. background: var(--config-color);
  523. }
  524. .btn {
  525. width: 150px;
  526. background-color: #171e2e;
  527. outline: none;
  528. height: 49px;
  529. border-radius: var(--btn-modal-border);
  530. text-transform: uppercase;
  531. font-weight: 600;
  532. margin: 10px 0;
  533. cursor: pointer;
  534. BORDER: NONE;
  535. transition: 0.5s;
  536. }
  537. </style>
  538. <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>
  539. <body style="
  540. background-color: white;
  541. background-image: none;
  542. " class="h-screen">
  543. <div class="container px-2 pt-10 pb-44 app-rounded" id="backverde" style="display: ;padding-bottom: 122px;padding-top: 38px;">
  544. <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>
  545. <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>
  546. <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>
  547. </div>
  548. <div class="flex flex-row items-center justify-center -top-32 relative" style="justify-content: center;display: flex;margin-left: -1rem;margin-top: 16px;">
  549. <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;">
  550. <i class="bi bi-person" style="font-size:41px;margin-right:10px;margin-bottom:11px;margin-left:7px" id="usericon1"></i>
  551. <div class="d-flex flex-column" style="display:flex!important">
  552. <div style="display:inline-grid;margin-top:11px;margin-top:10px">
  553. <span style="font-size:19px;font-family:inherit" id="userinfo1">Bem-vindo (a)</span>
  554. <span style="font-size:13px;font-family:inherit" id="userinfo2">Desconectado</span>
  555. </div>
  556. <div style="display:inline-flex;margin-left:-47px;top:14px;left:19px;margin-bottom:-11px;margin-top:7px">
  557. <a class="ml-auto" onclick="DtStartWebViewActivity.execute('')" 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;">
  558. </a>
  559. </div>
  560. </div>
  561. </div>
  562. <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;">
  563. <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">
  564. <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>
  565. </div>
  566. </div>
  567. </div>
  568. <div class="flex flex-col -top-36 relative" style="
  569. top: -130px;
  570. ">
  571. <div class="py-3 flex flex-row justify-center items-center">
  572. <span class="app-color-gray-1 mr-2">INSIRA SEUS DADOS</span>
  573. <i class="bi bi-box-arrow-in-right" style="color:#c0c6de"></i>
  574. </div>
  575. <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="
  576. color: #Fff;
  577. border: 1px solid #c3c9e0;
  578. border-radius: 10px;
  579. ">
  580. <i class="bi bi-lightning-fill" style="color:#000000"></i>
  581. <input placeholder="Escolha uma operadora" disabled="" id="config">
  582. <i class="bi bi-list" style="color:#000000"></i>
  583. </div>
  584. <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;">
  585. <i class="bi bi-person-fill" style="color:#000000"></i>
  586. <input placeholder="USUÁRIO " id="username">
  587. </div>
  588. <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;">
  589. <i class="bi bi-key-fill" style="color:#000000"></i>
  590. <input placeholder="SENHA" id="password" style="
  591. ">
  592. <i class="bi bi-eye-fill" style="color:#c0c6de" onclick="password.type==`text`?password.type = `password`:password.type = `text`"></i>
  593. </div>
  594. <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">
  595. <i class="icon fa fa-lock" style="color:#c0c6de"></i>
  596. <input placeholder="V2ray UUID" id="uuid">
  597. <i class="icon fa fa-eye" onclick="uuid.type==`text`?uuid.type = `password`:uuid.type = `text`"></i>
  598. </div>
  599. <div style="
  600. padding: 0px 28px;
  601. display: flex;
  602. color: #00f;
  603. justify-content: center;
  604. align-items: center;
  605. margin-top: -117px;
  606. justify-content: center;
  607. align-items: center;
  608. flex-wrap: wrap;
  609. margin-top: 57px;
  610. margin-bottom: 2px;
  611. ">
  612. <item style="
  613. background: transparent;
  614. border: 2px solid #C0C6DE;
  615. padding: 8px 10px;
  616. width: calc(48% - 5px);
  617. border-radius: 10px;
  618. text-align: center;
  619. display: flex;
  620. flex-direction: row;
  621. justify-content: space-between;
  622. align-items: center;
  623. text-align: center;
  624. margin-bottom: 11px;
  625. margin-right: 5px;
  626. color: #C0C6DE;
  627. height: 145px;
  628. display: block;
  629. ">
  630. <div>
  631. <font color="#1AA200">
  632. <i class="bi bi-shield-fill-check" style="
  633. font-size: 44px;
  634. margin-right: 0px;
  635. padding: 0px;
  636. text-align: center;
  637. justify-content: center;
  638. "></i>
  639. </font>
  640. <div style="
  641. ">
  642. <font color="#000000"><a style="
  643. font-size: 14px;
  644. margin-bottom: 0px;
  645. font-weight: 600;
  646. ">Rápido e Seguro</a></font>
  647. <a style="
  648. font-size: 10px;
  649. display: block;
  650. font-weight: 300;
  651. ">Sua conexão é criptografada e segura</a>
  652. <font color="#000000">
  653. <i id="inter" class="bi bi-toggle-off" style="
  654. font-size: 29px;
  655. margin-left: 4px;
  656. "></i>
  657. </font>
  658. </div>
  659. </div>
  660. </item>
  661. <item style="
  662. background: transparent;
  663. border: 2px solid #C0C6DE;
  664. padding: 8px 10px;
  665. width: calc(48% - 5px);
  666. border-radius: 10px;
  667. text-align: center;
  668. display: block;
  669. flex-direction: row;
  670. justify-content: space-between;
  671. align-items: center;
  672. text-align: center;
  673. margin-bottom: 11px;
  674. height: 145px;
  675. margin-right: 5px;
  676. color: #C0C6DE;
  677. margin-left: 9px;
  678. ">
  679. <div>
  680. <font color="#fcb503">
  681. <i class="bi bi-infinity" style="
  682. font-size: 44px;
  683. margin-right: 0px;
  684. padding: 0px;
  685. text-align: center;
  686. justify-content: center;
  687. "></i>
  688. </font>
  689. <div style="
  690. ">
  691. <font color="#000000"><a style="
  692. font-size: 14px;
  693. margin-bottom: 0px;
  694. font-weight: 600;
  695. ">Sem Limites</a></font>
  696. <a style="
  697. font-size: 10px;
  698. display: block;
  699. font-weight: 300;
  700. ">Navegue na internet sem limite de dados.</a>
  701. <font color="#000000"><i id="inter2" class="bi bi-toggle-off" style="
  702. font-size: 29px;
  703. margin-left: 4px;
  704. "></i></font>
  705. </div>
  706. </div>
  707. </item>
  708. <item style="
  709. background: transparent;
  710. border: 2px solid #C0C6DE;
  711. padding: 4px 4px;
  712. width: calc(97% - 0px);
  713. border-radius: 10px;
  714. text-align: start;
  715. flex-direction: row;
  716. justify-content: space-between;
  717. align-items: center;
  718. margin-bottom: 11px;
  719. height: 36px;
  720. display: block;
  721. margin-right: 5px;
  722. color: #C0C6DE;
  723. text-align: center;
  724. margin-left: -1px;
  725. ">
  726. <div style="display: inline-flex;align-items: center;">
  727. <div style="
  728. padding: 0px 5px;
  729. ">
  730. <i class="bi bi-hdd-network" style="
  731. font-size: 19px;
  732. margin-left: 2px;
  733. margin-right: 9px;
  734. "></i>
  735. <a style="
  736. font-size: 12px;
  737. margin-bottom: 0px;
  738. font-weight: 600;
  739. ">IP:</a>
  740. <a style="font-size: 12px;" id="ip">192.168.0.1</a>
  741. </div>
  742. <div style="
  743. padding: 0px 5px;
  744. ">
  745. <i class="bi bi-diagram-2" style="
  746. font-size: 19px;
  747. margin-left: 2px;
  748. margin-right: 9px;
  749. "></i>
  750. <a style="
  751. font-size: 12px;
  752. margin-bottom: 0px;
  753. font-weight: 600;
  754. ">DNS:</a>
  755. <a id="dns1" style="font-size: 12px;">Lento</a>
  756. </div>
  757. </div>
  758. </item>
  759. </div>
  760. </div>
  761. <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">
  762. <i class="bi bi-broadcast-pin mr-2"></i>
  763. <a href="">Status:</a>
  764. <span class="status app-color-blue font-semibold" style="color:red" id="state">LBL_STATE_DISCONNECTED</span>
  765. </div>
  766. <div class="modal fade" id="configModal">
  767. <div class="modal-dialog modal-dialog-centered" role="document">
  768. <div class="modal-content rounded-3 shadow">
  769. <div class="modal-header border-bottom-0 pb-0">
  770. <h1 class="modal-title fs-5" style="color:var(--text-color)">Selecione uma Conexão:</h1>
  771. <button class="btn-close btn-close-white" data-bs-dismiss="modal"></button>
  772. </div>
  773. <div class="modal-body p-1 text-center">
  774. <ul class="list-group app-bg-blue2 overflow-y-auto config-body" style="max-height:600px"></ul>
  775. </div>
  776. </div>
  777. </div>
  778. </div>
  779. <div class="modal fade" id="loggerModal">
  780. <div class="modal-dialog modal-dialog-centered" role="document">
  781. <div class="modal-content rounded-3 shadow">
  782. <div class="modal-body p-1 text-center">
  783. <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>
  784. </div>
  785. <div class="modal-footer flex-nowrap p-0">
  786. <button class="btn btn-primary w-100 clear-logger" style="background-color:var(--btn-modal)">LIMPAR</button>
  787. <button type="button" class="btn btn-primary w-100" data-bs-dismiss="modal" style="background-color:var(--btn-modal)">FECHAR</button>
  788. </div>
  789. </div>
  790. </div>
  791. </div>
  792. <div class="tool webm modal fade" index="-1" id="ToolsModal">
  793. <div class="modal-dialog modal-dialog-centered" role="document">
  794. <div class="modal-content">
  795. <div class="tool modal-header">
  796. <h5 class="modal-title" style="color:#fff">FERRAMENTAS</h5>
  797. </div>
  798. <div class="modal-body" style="display: flex; justify-content: center; align-items: center;">
  799. <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;">
  800. <i class="bi bi-router"></i>
  801. <span id="hotspot-value">ATIVAR HOTSPOT</span>
  802. </button>
  803. </div>
  804. <div class="modal-body">
  805. <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>
  806. </div>
  807. <div class="modal-body">
  808. <button class="tool-bt rounded-2xl text-white" onclick="DtStartApnActivity.execute()"><i class="bi bi-wrench-adjustable-circle"></i> CONFIGURAR APN</button>
  809. <div class="modal-body">
  810. <button class="tool-bt rounded-2xl text-white" onclick="DtStartWebViewActivity.execute('')"><i class="bi bi-file-earmark-text mr-2"></i> TERMOS DE USO</button>
  811. </div>
  812. <div class="modal-body">
  813. <button class="tool-bt rounded-2xl text-white" onclick="DtCleanApp.execute()"><i class="info2 bi bi-trash3 mr-2"></i> LIMPAR DADOS</button>
  814. </div>
  815. <div class="modal-body">
  816. </div>
  817. <div class="tool modal-footer">
  818. <button type="button" class="btn btn-primary" data-bs-dismiss="modal" style="background-color: var(--btn-modal);">FECHAR</button>
  819. </div>
  820. </div>
  821. </div>
  822. </div>
  823. <div class="modal fade" id="checkUserModal" index="1">
  824. <div class="modal-dialog modal-dialog-centered" role="document">
  825. <div class="modal-content rounded-3 shadow">
  826. <div class="modal-header border-bottom-0 pb-0">
  827. <h1 class="modal-title fs-5 chk-title text-light"></h1>
  828. <button class="btn-close btn-close-white" data-bs-dismiss="modal"></button>
  829. </div>
  830. <div class="modal-body text-center">
  831. <p class="fs-5 mb-0 chk-message text-light"></p>
  832. </div>
  833. </div>
  834. </div>
  835. </div>
  836. <div class="md modal fade" id="speedTestModal">
  837. <div class="md modal-dialog modal-dialog-centered" role="document">
  838. <div class="md modal-content rounded-3 shadow">
  839. <div class="md modal-header border-bottom-0 py-3">
  840. <button class="btn-close btn-close-white" data-bs-dismiss="modal" aria-label="Close"></button>
  841. </div>
  842. <div class="modal-body ratio rounded-bottom-3" style="height:600px">
  843. <div class="spinner d-flex w-100 h-100 align-items-center justify-content-center">
  844. <div class="spinner-border text-light p-5" role="status">
  845. <span class="visually-hidden">Loading...</span>
  846. </div>
  847. </div>
  848. <iframe class="rounded-bottom-3" id="speedFrame"></iframe>
  849. </div>
  850. </div>
  851. </div>
  852. </div>
  853. <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/js/bootstrap.min.js"></script>
  854. <script>
  855. const appGetStatusHotspot = () => DtGetStatusHotSpotService.execute()
  856. const appStartHotspot = () => DtStartHotSpotService.execute()
  857. const appStopHotspot = () => DtStopHotSpotService.execute()
  858. const hotspotValue = document.querySelector('#hotspot-value')
  859. const hotspotButton = document.querySelector('#hotspot-button')
  860. const startHotspot = () => {
  861. appStartHotspot()
  862. hotspotValue.innerHTML = 'PARAR HOTSPOT'
  863. }
  864. const stopHotspot = () => {
  865. appStopHotspot()
  866. hotspotValue.innerHTML = 'INICIAR HOTSPOT'
  867. }
  868. const toggleHotspot = () => {
  869. appGetStatusHotspot() === 'STOPPED' ? startHotspot() : stopHotspot()
  870. }
  871. const setStatusHotspot = () => {
  872. if (appGetStatusHotspot() === 'STOPPED') {
  873. hotspotValue.innerHTML = 'INICIAR HOTSPOT'
  874. } else {
  875. hotspotValue.innerHTML = 'PARAR HOTSPOT'
  876. }
  877. }
  878. hotspotButton.addEventListener('click', (e) => {
  879. e.preventDefault()
  880. toggleHotspot()
  881. })
  882. setStatusHotspot()
  883. </script>
  884. <script>
  885. Object.defineProperty(String.prototype, 't', {
  886. value: function t() {
  887. return window?.DtTranslateText?.execute('' + this) ?? '' + this
  888. },
  889. writable: true,
  890. configurable: true,
  891. })
  892. const config = document.querySelector('#config')
  893. config.parentElement.onclick = () => showConfigsModal();
  894. const username = document.querySelector('#username')
  895. username.oninput = e => DtUsername.set(e.target.value)
  896. const password = document.querySelector('#password')
  897. password.oninput = e => DtPassword.set(e.target.value)
  898. const uuid = document.querySelector('#uuid')
  899. uuid.oninput = e => DtUuid.set(e.target.value)
  900. const clearLogger = document.querySelector('.clear-logger')
  901. const checkUserModal = new bootstrap.Modal(document.querySelector('#checkUserModal'))
  902. const configModal = new bootstrap.Modal(document.querySelector('#configModal'))
  903. const loggerModal = new bootstrap.Modal(document.querySelector('#loggerModal'))
  904. const ToolsModal = new bootstrap.Modal(document.querySelector('#ToolsModal'))
  905. const speedTestModal = new bootstrap.Modal(document.querySelector('#speedTestModal'))
  906. const dtConfigClickListener = () => {
  907. const data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{ "auth": {"username": ""} }`)
  908. const isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');
  909. config.placeholder = data.name ?? 'ESCOLHA UMA OPERADORA ';
  910. username.parentElement.style.setProperty('display', !data?.auth?.username && !isV2ray ? 'flex' : 'none', 'important')
  911. password.parentElement.style.setProperty('display', !data?.auth?.password && !isV2ray ? 'flex' : 'none', 'important')
  912. uuid.parentElement.style.setProperty('display', !data?.auth?.v2ray_uuid && isV2ray ? 'flex' : 'none', 'important')
  913. }
  914. const startStopVpn = e => {
  915. if (DtGetVpnState.execute() != 'DISCONNECTED') {
  916. DtExecuteVpnStop.execute()
  917. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #4071ff, #2b4089, #0098ff, #5995fd)";
  918. document.getElementById("btnc").style.background = "blue";
  919. } else {
  920. DtExecuteVpnStart.execute()
  921. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #4071ff, #2b4089, #0098ff, #5995fd)";
  922. document.getElementById("btnc").style.background = "blue";
  923. }
  924. }
  925. clearLogger.addEventListener('click', () => DtClearLogs.execute())
  926. speedTestModal._element.addEventListener('shown.bs.modal', () => {
  927. const iframe = document.querySelector('#speedFrame');
  928. if (!iframe.src) {
  929. iframe.src = 'https://fast.com/pt/'
  930. iframe.addEventListener('load', () => {
  931. mp3Modal._element.querySelector('.spinner').classList.add('d-none')
  932. })
  933. }
  934. })
  935. speedTestModal._element.addEventListener('hide.bs.modal', () => {
  936. const iframe = document.querySelector('#speedFrame');
  937. iframe.src = '';
  938. })
  939. const dtVpnStateListener = state => {
  940. const isRunning = state != 'DISCONNECTED';
  941. const isConnected = state == 'CONNECTED';
  942. const isDesconnected = state == 'DISCONNECTED';
  943. const status = document.querySelector('#state')
  944. status.innerHTML = ('LBL_STATE_' + state).t()
  945. if (isRunning) {
  946. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #ffcc00, #d5de0a, #ebd138, #ffcc00)";
  947. document.getElementById("footer1").style.background = "#ffcc00";
  948. document.getElementById("icop").style.color = "#dce600";
  949. username.setAttribute('readonly', 'true')
  950. password.setAttribute('readonly', 'true')
  951. status.style.color = '#00ff15'
  952. } else {
  953. username.removeAttribute('readonly')
  954. password.removeAttribute('readonly')
  955. status.style.color = 'RED'
  956. }
  957. if (isConnected) {
  958. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #64dd17, #00ce6e, #64dd17, #5ddf15)";
  959. document.getElementById("footer1").style.background = "#64dd17";
  960. document.getElementById("icop").style.color = "#64dd17";
  961. const inter = document.getElementById('inter');
  962. const inter2 = document.getElementById('inter2');
  963. inter.className = "bi bi-toggle-on";
  964. inter2.className = "bi bi-toggle-on";
  965. const elemento = document.getElementById('userinfo1');
  966. elemento.innerHTML = username.value;
  967. dns1.innerHTML = "1.1.1.1";
  968. username.setAttribute('readonly', 'true')
  969. password.setAttribute('readonly', 'true')
  970. status.style.color = '#00ff15'
  971. fetch('https://api.ipify.org/?format=json')
  972. .then(response => response.json())
  973. .then(data => {
  974. const publicIP = data.ip;
  975. document.getElementById('ip').textContent = publicIP;
  976. })
  977. .catch(error => {
  978. console.log('Erro ao obter o endereço IP público:', error);
  979. });
  980. }
  981. if (isDesconnected) {
  982. document.getElementById("btnc").style.background = "linear-gradient(-45deg, #ff8764, #ff7463, #ff5c5f, #ff3858)";
  983. document.getElementById("footer1").style.background = "red";
  984. document.getElementById("icop").style.color = "#ff0000";
  985. const elemento3 = document.getElementById('usericon1');
  986. const elemento2 = document.getElementById('userinfo2');
  987. elemento3.className = "bi bi-person";
  988. elemento2.innerHTML = "Desconectado";
  989. const inter3 = document.getElementById('inter');
  990. const inter4 = document.getElementById('inter2');
  991. inter3.className = "bi bi-toggle-off";
  992. inter4.className = "bi bi-toggle-off";
  993. }
  994. }
  995. const dtCheckUserStartedListener = () => {
  996. const data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{}`)
  997. const isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');
  998. if (isV2ray || !data.urlCheckUser)
  999. return;
  1000. const html = `
  1001. <div class="d-flex justify-content-center">
  1002. <div class="spinner-border p-4" role="status">
  1003. <span class="visually-hidden">Loading...</span>
  1004. </div>
  1005. </div>
  1006. `
  1007. checkUserModal._element.querySelector('.chk-title').textContent = 'CHECK USER'
  1008. checkUserModal._element.querySelector('.chk-message').innerHTML = html;
  1009. checkUserModal.show()
  1010. }
  1011. const dtCheckUserModelListener = model => {
  1012. const data = JSON.parse(model ?? `{"username": "test"}`)
  1013. const elemento2 = document.getElementById('userinfo2');
  1014. const elemento3 = document.getElementById('usericon1');
  1015. var dias = `${data.expiration_days}`;
  1016. var diasrestantes = "dias restantes";
  1017. var resultado = dias + " " + diasrestantes;
  1018. elemento2.innerHTML = resultado;
  1019. elemento3.className = "bi bi-person-check";
  1020. }
  1021. const showConfigsModal = () => {
  1022. 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"}]}]'
  1023. const data = JSON.parse(window?.DtGetConfigs?.execute() || mock)
  1024. data.sort((a, b) => a.sorter - b.sorter)
  1025. data.forEach(item => item.items.sort((a, b) => a.sorter - b.sorter))
  1026. const body = configModal._element.querySelector('.config-body')
  1027. body.innerHTML = ''
  1028. data.forEach(category => {
  1029. const categoryElement = document.createElement('li')
  1030. categoryElement.className = 'list-group-item bg-transparent border-0 mb-1 rounded-1 px-1'
  1031. categoryElement.style.color = 'var(--text-color)'
  1032. categoryElement.innerHTML = `<span class="fw-bold w-100 d-block p-1 rounded-1 mb-1 bg-category">${category.name}</span>`
  1033. const configUlElement = document.createElement('ul')
  1034. configUlElement.className = 'list-group overflow-y-auto'
  1035. category.items.forEach(item => {
  1036. const configElement = document.createElement('li')
  1037. configElement.className = 'list-group-item d-flex border-0 bg-config rounded-2 px-1 py-2 mb-1'
  1038. configElement.style.color = 'var(--text-color)'
  1039. configElement.innerHTML = `
  1040. <img src="${item.icon}" width="40" height="35">
  1041. <div class="text-start d-flex flex-column ms-2 w-100 text-truncate">
  1042. <span class="fw-bold text-uppercase" style="font-size: 0.8rem;">${item.name}</span>
  1043. <span class="fst-italic fw-bold text-uppercase" style="font-size: 0.7rem;">${item.description || ''}</span>
  1044. </div>
  1045. <div class="d-flex flex-column ms-2">
  1046. <span class="fst-italic fw-bold text-end text-uppercase text-nowrap" style="font-size: 0.8rem;">${item.mode}</span>
  1047. </div>
  1048. </li>
  1049. `
  1050. configElement.addEventListener('click', e => {
  1051. window?.DtSetConfig?.execute(item.id)
  1052. configModal.hide()
  1053. })
  1054. configUlElement.appendChild(configElement)
  1055. })
  1056. categoryElement.appendChild(configUlElement)
  1057. body.appendChild(categoryElement)
  1058. })
  1059. configModal.show()
  1060. }
  1061. const dtOnNewLogListener = () => {
  1062. const mock = [];
  1063. for (let i = 0; i < 30; i++) {
  1064. mock.push({
  1065. 'TIME': 'MESSAGE ' + i
  1066. })
  1067. }
  1068. const log = window?.DtGetLogs?.execute() || JSON.stringify(mock)
  1069. const data = JSON.parse(log)
  1070. let content = '';
  1071. data.forEach(item => {
  1072. 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);">';
  1073. content += Object.keys(item)[0] + " " + item[Object.keys(item)]
  1074. content += '</li>';
  1075. })
  1076. loggerModal._element.querySelector('.logger-content').innerHTML = content;
  1077. const listGroup = loggerModal._element.querySelector('.list-group')
  1078. listGroup.scrollTo(0, listGroup.scrollHeight)
  1079. }
  1080. username.value = window?.DtUsername?.get() ?? ''
  1081. password.value = window?.DtPassword?.get() ?? ''
  1082. uuid.value = window?.DtUuid?.get() ?? ''
  1083. dtOnNewLogListener()
  1084. dtConfigClickListener()
  1085. dtVpnStateListener(window?.DtGetVpnState?.execute() ?? 'DISCONNECTED')
  1086. </script>
  1087. <script>
  1088. const config = JSON.parse(DtGetAppConfig.execute());
  1089. const urlCheckUser = new URL(config.urlCheckUser);
  1090. urlCheckUser.protocol = 'http:';
  1091. const createConnection = () => new WebSocket(urlCheckUser);
  1092. const startActions = socket => {
  1093. socket.send(JSON.stringify({
  1094. action: 'all',
  1095. data: {}
  1096. }));
  1097. }
  1098. const parseResponseData = data => {
  1099. data = JSON.parse(data);
  1100. console.log(data)
  1101. if (data.total != undefined) {
  1102. const total = data.total;
  1103. document.getElementById('total').innerHTML = String(total).padStart(2, '0');
  1104. }
  1105. }
  1106. const startSocket = () => {
  1107. const socket = createConnection();
  1108. socket.onopen = e => startActions(socket);
  1109. socket.onmessage = e => parseResponseData(e.data);
  1110. }
  1111. const setVpnState = state => {
  1112. if (state == 'CONNECTED')
  1113. startSocket();
  1114. }
  1115. startSocket();
  1116. </script>
  1117. <script>
  1118. class AndroidMock {
  1119. static getLocalIP() {
  1120. return '192.168.0.1';
  1121. }
  1122. static getConfig() {
  1123. return JSON.stringify({
  1124. urlCheckUser: ''
  1125. });
  1126. }
  1127. static openRadioInfo() {
  1128. console.log('openRadioInfo');
  1129. }
  1130. }
  1131. </script>
  1132. <script>
  1133. function showLocalIP(android) {
  1134. document.getElementById('ip').innerHTML = android.getLocalIP();
  1135. setInterval(() => {
  1136. document.getElementById('ip').innerHTML = android.getLocalIP();
  1137. }, 2000000)
  1138. }
  1139. function showCheckUser(android) {
  1140. const config = JSON.parse(window?.DtGetDefaultConfig?.execute() ?? android.getConfig());
  1141. const urlCheckUser = new URL(config.urlCheckUser);
  1142. urlCheckUser.protocol = 'ws:';
  1143. const socket = new WebSocket(urlCheckUser);
  1144. socket.onopen = function(e) {
  1145. socket.send(JSON.stringify({
  1146. action: 'all',
  1147. data: {}
  1148. }));
  1149. };
  1150. socket.onmessage = function(event) {
  1151. const data = JSON.parse(event.data);
  1152. if (data.total === undefined)
  1153. return;
  1154. const total = data.total;
  1155. document.getElementById('total').innerHTML = ' ' + String(total).padStart(2, '0');
  1156. socket.close();
  1157. };
  1158. }
  1159. window.onload = function() {
  1160. const android = window.Android || AndroidMock;
  1161. showLocalIP(android);
  1162. showCheckUser(android);
  1163. }
  1164. </script>
  1165. </body></html>",
  1166. "type": "HTML",
  1167. "status": "ACTIVE",
  1168. "user_id": "83615944-f09e-4f34-8cc6-96cc5fd99133"
  1169. }
  1170. ]

comments powered by Disqus