Layout4.2.5


SUBMITTED BY: hyperloko21

DATE: Nov. 5, 2022, 1:18 a.m.

UPDATED: March 18, 2024, 7:48 p.m.

FORMAT: Text only

SIZE: 40.9 kB

HITS: 717

  1. [
  2. {
  3. "label": "Iniciar o app automaticamente ao reiniciar o dispositivo",
  4. "name": "APP_AUTO_START",
  5. "value": false,
  6. "type": "BOOLEAN"
  7. },
  8. {
  9. "label": "Logo do app",
  10. "name": "APP_LOGO",
  11. "value": null,
  12. "type": "IMAGE"
  13. },
  14. {
  15. "label": "Imagem de fundo",
  16. "name": "APP_BACKGROUND_IMAGE",
  17. "value": null,
  18. "type": "IMAGE"
  19. },
  20. {
  21. "label": "Tipo do fundo do app",
  22. "name": "APP_BACKGROUND_TYPE",
  23. "value": {
  24. "options": [
  25. {
  26. "label": "Imagem",
  27. "value": "IMAGE"
  28. },
  29. {
  30. "label": "Cor",
  31. "value": "COLOR"
  32. }
  33. ],
  34. "selected": "COLOR"
  35. },
  36. "type": "SELECT"
  37. },
  38. {
  39. "label": "Cor de fundo",
  40. "name": "APP_BACKGROUND_COLOR",
  41. "value": "#080e16c7",
  42. "type": "COLOR"
  43. },
  44. {
  45. "label": "Cor do card inicial",
  46. "name": "APP_CARD_COLOR",
  47. "value": "#1d242e73",
  48. "type": "COLOR"
  49. },
  50. {
  51. "label": "Raio do card inicial",
  52. "name": "APP_CARD_RADIUS",
  53. "value": 20,
  54. "type": "INTEGER"
  55. },
  56. {
  57. "label": "Cor do card de status",
  58. "name": "APP_CARD_STATUS_COLOR",
  59. "value": "#1d242e73",
  60. "type": "COLOR"
  61. },
  62. {
  63. "label": "Raio do card de status",
  64. "name": "APP_CARD_STATUS_RADIUS",
  65. "value": 25,
  66. "type": "INTEGER"
  67. },
  68. {
  69. "label": "Cor do card de configurações",
  70. "name": "APP_CARD_CONFIG_COLOR",
  71. "value": "#0E171EC9",
  72. "type": "COLOR"
  73. },
  74. {
  75. "label": "Cor do fundo dos dialogs",
  76. "name": "APP_DIALOG_BACKGROUND_COLOR",
  77. "value": "#050C5AE4",
  78. "type": "COLOR"
  79. },
  80. {
  81. "label": "Cor do fundo do dialog de log",
  82. "name": "APP_DIALOG_LOGGER_COLOR",
  83. "value": "#080e16c7",
  84. "type": "COLOR"
  85. },
  86. {
  87. "label": "Cor das bordas",
  88. "name": "APP_BORDER_COLOR",
  89. "value": "#1d242e73",
  90. "type": "COLOR"
  91. },
  92. {
  93. "label": "Cor dos inputs",
  94. "name": "APP_INPUT_COLOR",
  95. "value": "#1d242e73",
  96. "type": "COLOR"
  97. },
  98. {
  99. "label": "Raio dos inputs",
  100. "name": "APP_INPUT_RADIUS",
  101. "value": 25,
  102. "type": "INTEGER"
  103. },
  104. {
  105. "label": "Cor dos textos",
  106. "name": "APP_TEXT_COLOR",
  107. "value": "#FFFFFFFF",
  108. "type": "COLOR"
  109. },
  110. {
  111. "label": "Cor dos botões",
  112. "name": "APP_BUTTON_COLOR",
  113. "value": "#1d242e73",
  114. "type": "COLOR"
  115. },
  116. {
  117. "label": "Raio dos botões",
  118. "name": "APP_BUTTON_RADIUS",
  119. "value": 25,
  120. "type": "INTEGER"
  121. },
  122. {
  123. "label": "Cor dos icones",
  124. "name": "APP_ICON_COLOR",
  125. "value": "#FFFFFFFF",
  126. "type": "COLOR"
  127. },
  128. {
  129. "label": "Exibir modo de conexão",
  130. "name": "APP_SHOW_CONNECTION_MODE",
  131. "value": true,
  132. "type": "BOOLEAN"
  133. },
  134. {
  135. "label": "Atualizar automaticamente as configurações ao lançar uma atualização.",
  136. "name": "APP_CONFIG_AUTO_UPDATE",
  137. "value": false,
  138. "type": "BOOLEAN"
  139. },
  140. {
  141. "label": "Usar limiter de conexão",
  142. "name": "APP_CONNECTION_LIMITER",
  143. "value": false,
  144. "type": "BOOLEAN"
  145. },
  146. {
  147. "label": "Usar botão de atualizações",
  148. "name": "APP_BTN_UPDATE_ENABLED",
  149. "value": true,
  150. "type": "BOOLEAN"
  151. },
  152. {
  153. "label": "Usar botão de registros",
  154. "name": "APP_BTN_LOGGER_ENABLED",
  155. "value": true,
  156. "type": "BOOLEAN"
  157. },
  158. {
  159. "label": "Usar botão de pagina webview",
  160. "name": "APP_BTN_PAGE_ENABLED",
  161. "value": true,
  162. "type": "BOOLEAN"
  163. },
  164. {
  165. "label": "Ativar dialog de erros",
  166. "name": "APP_DIALOG_ERROR_ENABLED",
  167. "value": true,
  168. "type": "BOOLEAN"
  169. },
  170. {
  171. "label": "Ativar dialog de checkuser",
  172. "name": "APP_CHECKUSER_DIALOG_ENABLED",
  173. "value": true,
  174. "type": "BOOLEAN"
  175. },
  176. {
  177. "label": "Ativar toast de sucesso",
  178. "name": "APP_SUCCESS_TOAST_ENABLED",
  179. "value": true,
  180. "type": "BOOLEAN"
  181. },
  182. {
  183. "label": "Ativar toast de erro",
  184. "name": "APP_ERROR_TOAST_ENABLED",
  185. "value": true,
  186. "type": "BOOLEAN"
  187. },
  188. {
  189. "label": "Ativar IP local no layout nativo",
  190. "name": "APP_LOCAL_IP_ENABLED",
  191. "value": true,
  192. "type": "BOOLEAN"
  193. },
  194. {
  195. "label": "Filtrar configurações pelo nome da rede",
  196. "name": "APP_CONFIG_FILTER_ENABLED",
  197. "value": false,
  198. "type": "BOOLEAN"
  199. },
  200. {
  201. "label": "Ativar serviço de ping",
  202. "name": "APP_PING_SERVICE_ENABLED",
  203. "value": true,
  204. "type": "BOOLEAN"
  205. },
  206. {
  207. "label": "Ativar alertas sonoros",
  208. "name": "APP_ALERT_SOUND_ENABLED",
  209. "value": false,
  210. "type": "BOOLEAN"
  211. },
  212. {
  213. "label": "Usar layout webview",
  214. "name": "APP_LAYOUT_WEBVIEW_ENABLED",
  215. "value": true,
  216. "type": "BOOLEAN"
  217. },
  218. {
  219. "label": "Mensagem",
  220. "name": "APP_MESSAGE",
  221. "value": null,
  222. "type": "TEXT"
  223. },
  224. {
  225. "label": "Tipo de mensagem",
  226. "name": "APP_MESSAGE_TYPE",
  227. "value": {
  228. "options": [
  229. {
  230. "label": "Alerta",
  231. "value": "ALERT"
  232. },
  233. {
  234. "label": "Informação",
  235. "value": "INFO"
  236. },
  237. {
  238. "label": "Boas vindas",
  239. "value": "WELCOME"
  240. },
  241. {
  242. "label": "Sem mensagem",
  243. "value": "NONE"
  244. }
  245. ],
  246. "selected": "NONE"
  247. },
  248. "type": "SELECT"
  249. },
  250. {
  251. "label": "URL de atualização do aplicativo",
  252. "name": "APP_UPDATE_URL",
  253. "value": null,
  254. "type": "URL"
  255. },
  256. {
  257. "label": "LAYOUT WEBVIEW (POR SUA CONTA E RISCO)",
  258. "name": "APP_LAYOUT_WEBVIEW",
  259. "value": "<!DOCTYPE html>\n<html lang=\"pt-BR\">\n\n<head>\n <meta charset=\"UTF-8\" />\n <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\" />\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n\n <title>DTunnel</title>\n\n <link rel=\"stylesheet\" type=\"text/css\" href=\"https://cdn.jsdelivr.net/npm/toastify-js/src/toastify.min.css\">\n <link href=\"https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/css/bootstrap.min.css\" rel=\"stylesheet\"\n integrity=\"sha384-KK94CHFLLe+nY2dmCWGMq91rCGa5gtU4mk92HdvYe+M/SXH301p5ILy+dN9+nJOZ\" crossorigin=\"anonymous\">\n <script type=\"text/javascript\"\n src=\"https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/js/bootstrap.bundle.min.js\"\n integrity=\"sha384-ENjdO4Dr2bkBIFxQpeoTz1HIcje39Wm4jDKdf19U8gI4ddQ3GYNS7NTKfAdVQSZe\"\n crossorigin=\"anonymous\"></script>\n\n <style>\n @import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');\n\n :root {\n --background-img: linear-gradient(180deg, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 35%, rgba(255,0,0,1) 100%);\n --logo-img-url: url(https://plenonet.com.br/assets/images/plenonet-512512px-2-512x512.webp);\n\n --input-border-radius: 5px;\n --input-background-color: #0a091a55;\n\n --card-border-radius: 5px;\n --card-background-color: #0b092868;\n\n --btn-background-color: #0a091a55;\n --btn-border-radius: 5px;\n\n --modal-background-color: #0b092868;\n\n --text-color: #ffffff;\n --icon-color: #FFFFFF;\n }\n\n * {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n font-family: 'Roboto', sans-serif;\n }\n\n body {\n height: 100vh;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n background-repeat: no-repeat;\n background-size: cover;\n }\n\n .container {\n height: 100%;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n max-width: 465px;\n background: linear-gradient(180deg, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 35%, rgba(255,0,0,1) 100%);\n}\n\n.logo {\n width: 100%;\n\tmargin-bottom: 10px;\n}\n\n.card {\n background: #080808;\n border-radius: 20px;\n border: 1px solid #1e1e1e !important;\n box-shadow: -8px 12px 20px 0 rgb(13 15 18 / 63%) !important;\n padding: 15px !important;\n max-width: 450px;\n height: auto;\n position: relative;\n}\n\n .btn-dark {\n border: none;\n background: linear-gradient( to top right, #ff0000, #121212 );\n border-radius: 15px;\n}\n\n.modal-content {\n background-color: transparent;\n backdrop-filter: blur(25px);\n}\n\t\t\n\t\t.tool {\n align-items: center;\n justify-content: center;\n text-align: center;\n}\n\n.tool-bt {\n background: linear-gradient( to top right, #ff0000, #121212 );\n border-radius: 20px;\n color: #ffffff !important;\n height: 35px;\n width: 100%;\n border: var(--btn-border);\n}\n\n.input-group, .form-control, .input-group-text {\n background: #080808;\n color: var(--icon-color);\n border: none;\n border-radius: 15px;\n outline: none;\n}\n\n .form-control::placeholder {\n color: var(--text-color);\n }\n\n .form-control:focus {\n color: var(--text-color);\n outline: none;\n box-shadow: none;\n }\n\n .input-group-text {\n padding-right: 0;\n }\n\t\t\n\n.fs-5 {\n font-size: 1rem!important;\n}\n\nnav {\n background: linear-gradient( to top right, #ff0000, #121212 );\n border-radius: 20px;\n font-size: 0;\n width: 100%;\n max-width: 450px;\n height: auto;\n position: relative;\n margin-top: 20px;\n margin-bottom: 10px;\n}\n\nnav a {\n line-height: 35px;\n height: 100%;\n font-size: 15px;\n display: inline-block;\n position: relative;\n z-index: 1;\n text-decoration: none;\n text-align: center;\n color: white !important;\n cursor: pointer;\n}\nnav .animation {\n position: absolute;\n height: 100%;\n top: 0;\n z-index: 0;\n transition: all .5s ease 0s;\n border-radius: 8px;\n}\na:nth-child(1) {\n width: 30%;\n}\na:nth-child(2) {\n width: 30%;\n}\na:nth-child(3) {\n width: 40%;\n}\n\nnav .start-home, a:nth-child(1):hover~.animation {\n width: 30%;\n left: 0;\n background-color: #121212;\n border-radius: 20px;\n}\nnav .start-about, a:nth-child(2):hover~.animation {\n width: 30%;;\n left: 30%;\n background-color: #121212;\n border-radius: 20px;\n}\nnav .start-blog, a:nth-child(3):hover~.animation {\n width: 40%;\n left: 60%;\n background-color: #121212;\n border-radius: 20px;\n}\n\nbody {\n font-size: 12px;\n font-family: sans-serif;\n background: linear-gradient(180deg, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 35%, rgba(255,0,0,1) 100%);\n}\n\n@media (min-width: 768px) {\n.container, .container-md, .container-sm {\n max-width: 100%;\n}\n}\n\n.rede {\ncolor: #ff0000;\n}\n\n.iplocal {\ncolor: #ffffff;\n}\n\n.containerlocal {\n background: #080808;\n border-radius: 20px;\n border: 1px solid #1e1e1e !important;\n padding: 15px !important;\n width: 95%;\n max-width: 450px;\n height: auto;\n position: relative;\n margin-top: 50px;\n margin-bottom: -70px;\n}\n\n.hidden {\n display: none;\n}\n\n </style>\n</head>\n\n<body>\n <div class=\"containerlocal\"> \t\n<span class=\"font-semibold text-xs mr-2\" style=\"color: #ffffff;\"\">📢\tIP Local da sua operadora:</span><span class=\"rede font-semibold text-xs mr-2\" id=\"name\">REDE</span> <span class=\"iplocal font-semibold text-xs\" id=\"ip\">127.0.0.1</span>\t\n</div>\n \n <div class=\"container\"> \n<div class=\"card border-0 p-2 shadow mb-3 w-100\">\n<span style=\"color:#ffffff;font-size: 18px;border-radius: 15px;padding: 0px 0px 0px 5px;margin-bottom: 10px;display: block !important;text-align: start;\">AG SSH BR - Versão: 2.0.4</span>\n<img class=\"logo\" src=\"https://s13.gifyu.com/images/S05Y3.gif\">\n <div class=\"input-group mb-2 shadow\" id=\"config-area\">\n <input class=\"form-control\" type=\"text\" placeholder=\"CONFIGURAÇÃO\" readonly title=\"configurações\"\n id=\"config\" style=\"background-color: #080808;\" />\n <span class=\"input-group-text me-2\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" fill=\"currentColor\"\n class=\"bi bi:bar-chart\" viewBox=\"0 0 16 16\">\n <path\n d=\"M4 11H2v3h2v-3zm5-4H7v7h2V7zm5-5v12h-2V2h2zm-2-1a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1h-2zM6 7a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V7zm-5 4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-3z\"/></svg>\n\t\t\t\t\t\t\t</span>\n </div>\n <div class=\"input-group input mb-2 shadow\">\n <span class=\"input-group-text\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" fill=\"currentColor\"\n class=\"bi bi:file-person\" viewBox=\"0 0 16 16\">\n <path\n d=\"M12 1a1 1 0 0 1 1 1v10.755S12 11 8 11s-5 1.755-5 1.755V2a1 1 0 0 1 1-1h8zM4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4z\"/><path d=\"M8 10a3 3 0 1 0 0-6a3 3 0 0 0 0 6z\"/></g></svg>\n </span>\n <input class=\"form-control\" type=\"text\" placeholder=\"usuario\" id=\"username\" style=\"background-color: #080808;\" />\n </div>\n <div class=\"input-group input mb-2 shadow\">\n <span class=\"input-group-text\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" fill=\"currentColor\" class=\"bi bi:file-earmark-lock\"\n viewBox=\"0 0 16 16\">\n <path\n d=\"M10 7v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V9.3c0-.627.46-1.058 1-1.224V7a2 2 0 1 1 4 0zM7 7v1h2V7a1 1 0 0 0-2 0zM6 9.3v2.4c0 .042.02.107.105.175A.637.637 0 0 0 6.5 12h3a.64.64 0 0 0 .395-.125c.085-.068.105-.133.105-.175V9.3c0-.042-.02-.107-.105-.175A.637.637 0 0 0 9.5 9h-3a.637.637 0 0 0-.395.125C6.02 9.193 6 9.258 6 9.3z\"/><path d=\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"/></g></svg>\n\t\t\t\t\t\t </span>\n <input class=\"form-control\" type=\"password\" placeholder=\"senha\" id=\"password\" style=\"background-color: #080808;\" />\n <span class=\"input-group-text me-2\"\n onclick=\"password.type==`text`?password.type = `password`:password.type = `text`\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" class=\"bi bi-eye\"\n viewBox=\"0 0 16 16\">\n <path\n d=\"M16 8s-3-5.5-8-5.5S0 8 0 8s3 5.5 8 5.5S16 8 16 8zM1.173 8a13.133 13.133 0 0 1 1.66-2.043C4.12 4.668 5.88 3.5 8 3.5c2.12 0 3.879 1.168 5.168 2.457A13.133 13.133 0 0 1 14.828 8c-.058.087-.122.183-.195.288-.335.48-.83 1.12-1.465 1.755C11.879 11.332 10.119 12.5 8 12.5c-2.12 0-3.879-1.168-5.168-2.457A13.134 13.134 0 0 1 1.172 8z\" />\n <path\n d=\"M8 5.5a2.5 2.5 0 1 0 0 5 2.5 2.5 0 0 0 0-5zM4.5 8a3.5 3.5 0 1 1 7 0 3.5 3.5 0 0 1-7 0z\" />\n </svg>\n </span>\n </div>\n\t\t\t <div class=\"input-group input mb-2 shadow\">\n <span class=\"input-group-text\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" fill=\"currentColor\" class=\"bi bi-key\"\n viewBox=\"0 0 16 16\">\n <path\n d=\"M0 8a4 4 0 0 1 7.465-2H14a.5.5 0 0 1 .354.146l1.5 1.5a.5.5 0 0 1 0 .708l-1.5 1.5a.5.5 0 0 1-.708 0L13 9.207l-.646.647a.5.5 0 0 1-.708 0L11 9.207l-.646.647a.5.5 0 0 1-.708 0L9 9.207l-.646.647A.5.5 0 0 1 8 10h-.535A4 4 0 0 1 0 8zm4-3a3 3 0 1 0 2.712 4.285A.5.5 0 0 1 7.163 9h.63l.853-.854a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708 0l.646.647.793-.793-1-1h-6.63a.5.5 0 0 1-.451-.285A3 3 0 0 0 4 5z\" />\n <path d=\"M4 8a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\" />\n </svg>\n </span>\n <input class=\"form-control\" type=\"text\" placeholder=\"V2ray UUID\" id=\"uuid\" style=\"background: #080808;\" />\n <span class=\"input-group-text me-2\"\n onclick=\"uuid.type==`text`?uuid.type = `password`:uuid.type = `text`\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" class=\"bi bi-eye\"\n viewBox=\"0 0 16 16\">\n <path\n d=\"M16 8s-3-5.5-8-5.5S0 8 0 8s3 5.5 8 5.5S16 8 16 8zM1.173 8a13.133 13.133 0 0 1 1.66-2.043C4.12 4.668 5.88 3.5 8 3.5c2.12 0 3.879 1.168 5.168 2.457A13.133 13.133 0 0 1 14.828 8c-.058.087-.122.183-.195.288-.335.48-.83 1.12-1.465 1.755C11.879 11.332 10.119 12.5 8 12.5c-2.12 0-3.879-1.168-5.168-2.457A13.134 13.134 0 0 1 1.172 8z\" />\n <path\n d=\"M8 5.5a2.5 2.5 0 1 0 0 5 2.5 2.5 0 0 0 0-5zM4.5 8a3.5 3.5 0 1 1 7 0 3.5 3.5 0 0 1-7 0z\" />\n </svg>\n </span>\n </div>\n <button class=\"btn btn-dark w-100 shadow\" id=\"start-stop\">INICIAR</button>\n\t\t\t <nav>\n <a id=\"sync\" onclick=\"DtStartAppUpdate.execute()\">Atualizar</a>\n <a id=\"logger\">Registro</a>\n <a onclick=\"ToolsModal.show()\">Menu</a>\n <div class=\"animation start-home\"></div>\n</nav>\n </div>\n \n <div class=\"card my-3 w-100 text-center border-0 p-2 shadow text-light fs-5 text-uppercase fw-bold\" id=\"state\" style=\"padding: 5px !important; font-size: 15px !important;\">\n </div>\n<p style=\"color: #5e9ca0;\"><span style=\"color: #ffffff; font-size: 17px;\">AGSSHBR - Conex&otilde;es @2020-2024</span></p>\n </div>\n </div>\n <div class=\"modal fade\" id=\"checkUserModal\">\n <div class=\"modal-dialog modal-dialog-centered\" role=\"document\">\n <div class=\"modal-content rounded-3 shadow\">\n <div class=\"modal-header border-bottom-0 pb-0\">\n <h1 class=\"modal-title fs-5 chk-title text-light\"></h1>\n <button type=\"button\" class=\"btn-close btn-close-white\" data-bs-dismiss=\"modal\"\n aria-label=\"Close\"></button>\n </div>\n <div class=\"modal-body text-center\">\n <p class=\"fs-5 mb-0 chk-message text-light\"></p>\n </div>\n </div>\n </div>\n </div>\n <div class=\"modal fade\" id=\"errorModal\">\n <div class=\"modal-dialog modal-dialog-centered\" role=\"document\">\n <div class=\"modal-content rounded-3 shadow\">\n <div class=\"modal-header border-bottom-0 pb-0\">\n <h1 class=\"modal-title fs-5 err-title text-light\"></h1>\n <button type=\"button\" class=\"btn-close btn-close-white\" data-bs-dismiss=\"modal\"\n aria-label=\"Close\"></button>\n </div>\n <div class=\"modal-body text-center\">\n <p class=\"fs-5 mb-0 err-message text-light\"></p>\n </div>\n </div>\n </div>\n </div>\n <div class=\"modal fade\" id=\"loggerModal\">\n <div class=\"modal-dialog modal-dialog-centered\" role=\"document\">\n <div class=\"modal-content rounded-3 shadow\">\n <div class=\"modal-body p-1 text-center\">\n <ul class=\"list-group bg-transparent overflow-y-auto logger-content\" style=\"max-height: 600px;\">\n </ul>\n </div>\n <div class=\"modal-footer flex-nowrap p-0\">\n <button type=\"button\" class=\"btn btn-lg btn-dark text-light w-100 clear-logger\">LIMPAR</button>\n <button type=\"button\" class=\"btn btn-lg btn-dark text-light w-100\"\n data-bs-dismiss=\"modal\">FECHAR</button>\n </div>\n </div>\n </div>\n </div>\n\t <div class=\"tool webm modal fade\" index=\"-1\" id=\"ToolsModal\">\n <div class=\"modal-dialog modal-dialog-centered\" role=\"document\">\n <div class=\"modal-content\">\n <div class=\"tool modal-header\">\n <h5 class=\"modal-title\" style=\"color:#ffffff;\">Configurações do aplicativo</h5>\n </div>\n <div class=\"modal-body\">\n <button class=\"tool-bt rounded-2xl text-white\" onclick=\"DtStartWebViewActivity.execute('https://t.me/agvendasbr_bot')\"><i class=\"info2 bi bi-globe mr-2\"></i>Comprar ou Gerar teste Grátis</button>\n </div>\n <div class=\"modal-body\">\n <button class=\"tool-bt rounded-2xl text-white\" onclick=\"DtStartWebViewActivity.execute('https://m.youtube.com/')\"><i class=\"info2 bi bi-globe mr-2\"></i>YOUTUBE</button>\n </div>\t\n\t\t<div class=\"modal-body\">\n <button class=\"tool-bt rounded-2xl text-white\" onclick=\"DtStartApnActivity.execute()\"><i class=\"info2 bi bi-wifi mr-2\"></i>Alterar protocolo de APN</button>\n </div>\n <div class=\"modal-body\">\n <button class=\"tool-bt rounded-2xl text-white\" onclick=\"DtIgnoreBatteryOptimizations.execute()\"><i class=\"info2 bi bi-battery-full mr-2\"></i>Otimizar Bateria</button>\n </div>\n <div class=\"modal-body\">\n <button class=\"tool-bt rounded-2xl text-white\" onclick=\"DtCleanApp.execute()\"><i class=\"info2 bi bi-trash3 mr-2\"></i>Limpar cachê e dados</button>\n </div>\n\t\t<div class=\"modal-body\">\n\t\t<button class=\"tool-bt rounded-2xl text-white\" onclick=\"DtStartWebViewActivity.execute('https://t.me/wesley898')\"><i class=\"info2 bi bi-globe mr-2\"></i>SUPORTE CLIQUE AQUI</button>\n </div>\n <div class=\"tool modal-footer\">\n <button type=\"button\" class=\"btn btn-primary\" data-bs-dismiss=\"modal\" style=\"background-color: var(--btn-modal);\">FECHAR</button>\n \n </div>\n </div>\n </div>\n</div>\n <div class=\"modal fade\" id=\"configModal\">\n <div class=\"modal-dialog modal-dialog-centered\" role=\"document\">\n <div class=\"modal-content rounded-3 shadow\">\n <div class=\"modal-header border-bottom-0 pb-0\">\n <h1 class=\"modal-title fs-5 text-white\">CONFIGURAÇÕES</h1>\n <button type=\"button\" class=\"btn-close btn-close-white\" data-bs-dismiss=\"modal\"\n aria-label=\"Close\"></button>\n </div>\n <div class=\"modal-body p-1 text-center\">\n <ul class=\"list-group bg-transparent overflow-y-auto config-body\" style=\"max-height: 600px;\">\n <li class=\"list-group-item bg-transparent text-white border-0\">\n <p>CATEGORIA</p>\n <ul class=\"list-group bg-transparent overflow-y-auto text-start\">\n <li\n class=\"list-group-item d-flex bg-transparent text-white border-0 border-bottom rounded-0\">\n <img src=\"https://cdn-icons-png.flaticon.com/512/3686/3686811.png\" width=\"40\"\n height=\"40\">\n <div class=\"d-flex flex-column ms-2 w-100\">\n <span>CONFIG 01</span>\n <span>DESC 01</span>\n </div>\n <div class=\"d-flex flex-column ms-2 w-100\">\n <span class=\"text-end\">CONFIG_MODE</span>\n </div>\n </li>\n </ul>\n </li>\n </ul>\n </div>\n </div>\n </div>\n </div>\n\t\t <div class=\"modal fade\" id=\"RenovarModal\">\n <div class=\"modal-dialog modal-dialog-centered\" role=\"document\">\n <div class=\"modal-content rounded-3 shadow\">\n <div class=\"modal-header border-bottom-0 py-3\">\n <button type=\"button\" class=\"btn-close btn-close-white\" data-bs-dismiss=\"modal\"\n aria-label=\"Close\"></button>\n </div>\n <div class=\"modal-body ratio rounded-bottom-3\" style=\"height: 600px;\">\n <div class=\"spinner d-flex w-100 h-100 align-items-center justify-content-center\">\n <div class=\"spinner-border text-light p-5\" role=\"status\">\n <span class=\"visually-hidden\">Loading...</span>\n </div>\n </div>\n <iframe class=\"rounded-bottom-3\" id=\"RenovarFrame\"></iframe>\n </div>\n </div>\n </div>\n </div>\n <script type=\"text/javascript\" src=\"https://cdn.jsdelivr.net/npm/toastify-js\"></script>\n\t\t\n\t\t <script>\n class AndroidMock {\n static getLocalIP() {\n return '192.168.0.1';\n }\n \n static getConfig() {\n return JSON.stringify({\n urlCheckUser: 'URLAQUI'\n });\n }\n \n static getNetworkName() {\n return 'REDE';\n }\n \n static openRadioInfo() {\n console.log('openRadioInfo');\n }\n }\n </script>\n\t\n\t <script>\n function showLocalIP(android) {\n console.log(android.getNetworkName());\n document.getElementById('name').innerHTML = ' ' + android.getNetworkName() + ':';\n document.getElementById('ip').innerHTML = android.getLocalIP();\n \n setInterval(() => {\n document.getElementById('name').innerHTML =\n ' ' + android.getNetworkName() + ':';\n document.getElementById('ip').innerHTML = android.getLocalIP();\n }, 2000)\n }\n\t\t\n\t\t window.onload = function () {\n const android = window.Android || AndroidMock;\n showLocalIP(android);\n }\n\t\t\n\t\tfunction mostrar(id) {\n if (document.getElementById(id).style.display !== \"none\") {\n document.getElementById(id).style.display = \"none\";\n return;\n }\n Array.from(document.getElementsByClassName(\"hidden\")).forEach(\n div => (div.style.display = \"none\")\n );\n document.getElementById(id).style.display = \"block\";\n}\n\t\t\n\t\t </script>\n\t\t\n <script>\n const configArea = document.querySelector('#config-area')\n const config = document.querySelector('#config')\n const username = document.querySelector('#username')\n const password = document.querySelector('#password')\n\t\tconst uuid = document.querySelector('#uuid')\n const logger = document.querySelector('#logger')\n\t\t\n\t\tconst networkStatus = document.querySelector('#section.local-ip')\n\t\t\n const startStopVpn = document.querySelector('#start-stop')\n const stateStatus = document.querySelector('#state')\n\n const loggerModal = new bootstrap.Modal(document.querySelector('#loggerModal'))\n const checkUserModal = new bootstrap.Modal(document.querySelector('#checkUserModal'))\n const errorModal = new bootstrap.Modal(document.querySelector('#errorModal'))\n const configModal = new bootstrap.Modal(document.querySelector('#configModal'))\n\t\t\n\t\tconst ToolsModal = new bootstrap.Modal(document.querySelector('#ToolsModal'))\n\n const clearLogger = document.querySelector('.clear-logger')\n\n const RenovarModal = new bootstrap.Modal(document.querySelector('#RenovarModal'))\n\n configArea.addEventListener('click', e => showConfigsModal())\n username.addEventListener('input', e => DtUsername.set(e.target.value))\n password.addEventListener('input', e => DtPassword.set(e.target.value))\n\t\tuuid.addEventListener('input', e => DtUuid.set(e.target.value))\n logger.addEventListener('click', e => loggerModal.show())\n\n startStopVpn.addEventListener('click', (e) => {\n if (DtGetVpnState.execute() != 'DISCONNECTED') {\n DtExecuteVpnStop.execute()\n } else {\n DtExecuteVpnStart.execute()\n }\n })\n clearLogger.addEventListener('click', () => DtClearLogs.execute())\n\n RenovarModal._element.addEventListener('shown.bs.modal', () => {\n const iframe = document.querySelector('#RenovarFrame');\n if (!iframe.src) {\n iframe.src = 'https://painel.plenonet.com.br/renovar.php'\n iframe.addEventListener('load', () => {\n mp3Modal._element.querySelector('.spinner').classList.add('d-none')\n })\n }\n })\n RenovarModal._element.addEventListener('hide.bs.modal', () => {\n const iframe = document.querySelector('#RenovarFrame');\n iframe.src = '';\n })\n\n Object.defineProperty(String.prototype, 't', {\n value: function t() {\n return window?.DtTranslateText?.execute('' + this) ?? '' + this\n },\n writable: true,\n configurable: true,\n })\n\n const dtConfigClickListener = () => {\n const data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{ \"auth\": {}, \"mode\": \"v2ray\" }`)\n\t\t\tconst isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');\n config.placeholder = data.name ?? 'LBL_CHOOSE_CONFIG'.t()\n username.parentElement.style.display = !data?.auth?.username && !isV2ray ? 'flex' : 'none';\n password.parentElement.style.display = !data?.auth?.password && !isV2ray ? 'flex' : 'none';\n\t\t\tuuid.parentElement.style.display = !data?.auth?.v2ray_uuid && isV2ray ? 'flex' : 'none';\n }\n\n const dtVpnStateListener = state => {\n const isRunning = state != 'DISCONNECTED';\n\n stateStatus.innerHTML = ('LBL_STATE_' + state).t()\n startStopVpn.innerHTML = isRunning ? 'LBL_BTN_STOP'.t() : 'LBL_BTN_START'.t()\n\n if (isRunning) {\n username.setAttribute('readonly', 'true')\n password.setAttribute('readonly', 'true')\n } else {\n username.removeAttribute('readonly')\n password.removeAttribute('readonly')\n }\n\n if (state == 'CONNECTING') dtShowSuccessToastListener('Conectando...')\n }\n\n const dtCheckUserStartedListener = () => {\n\t\tconst data = JSON.parse(window?.DtGetDefaultConfig?.execute() || `{}`)\n\t\tconst isV2ray = data?.mode?.toLowerCase()?.startsWith('v2ray');\n if (isV2ray) return;\n const html = `\n <div class=\"d-flex justify-content-center\">\n <div class=\"spinner-border p-5\" role=\"status\">\n <span class=\"visually-hidden\">Loading...</span>\n </div>\n </div>\n `\n\n checkUserModal._element.querySelector('.chk-title').textContent = 'CHECK USER'\n checkUserModal._element.querySelector('.chk-message').innerHTML = html;\n checkUserModal.show()\n }\n\n const dtCheckUserModelListener = model => {\n const data = JSON.parse(model ?? `{\"username\": \"test\"}`)\n const html = `\n <div class=\"d-flex flex-column text-white\">\n <span>👤Nome de usuario: ${data.username}</span>\n <span>📆Expira em: ${data.expiration_date}</span>\n <span>📆Dias restantes: ${data.expiration_days}</span>\n <span>🚫Conexoes: ${data.count_connections}|${data.limit_connections}</span>\n </div>\n `\n\n checkUserModal._element.querySelector('.chk-title').textContent = '📆 Olá, ' + data.username.toUpperCase() + '👤'\n checkUserModal._element.querySelector('.chk-message').innerHTML = html;\n checkUserModal.show()\n }\n\n const dtMessageErrorListener = message => {\n const data = JSON.parse(message)\n errorModal._element.querySelector('.err-title').textContent = data.title;\n errorModal._element.querySelector('.err-message').innerHTML = data.content;\n errorModal.show()\n }\n\n const dtOnNewLogListener = () => {\n const mock = [];\n for (let i = 0; i < 30; i++) {\n mock.push({ 'TIME': 'MESSAGE ' + i })\n }\n\n const log = window?.DtGetLogs?.execute() || JSON.stringify(mock)\n const data = JSON.parse(log)\n\n let content = '';\n data.forEach(item => {\n content += '<li class=\"list-group-item fs-6 bg-transparent text-white p-0 border-0 text-start ms-2 text-wrap\">';\n content += Object.keys(item)[0] + \" \" + item[Object.keys(item)]\n content += '</li>';\n })\n\n loggerModal._element.querySelector('.logger-content').innerHTML = content;\n const listGroup = loggerModal._element.querySelector('.list-group')\n listGroup.scrollTo(0, listGroup.scrollHeight)\n }\n\n const dtVpnStartedSuccessListener = () => dtShowSuccessToastListener('Conectado com sucesso')\n\n const dtVpnStoppedSuccessListener = () => dtShowSuccessToastListener('Desconectado com sucesso')\n\n const dtShowSuccessToastListener = text => {\n Toastify({\n text: text,\n close: true,\n style: {\n background: 'linear-gradient(to right, #00b09b, #96c93d)',\n marginTop: '35px',\n }\n }).showToast()\n }\n\n const dtShowErrorToastListener = text => {\n Toastify({\n text: text,\n close: true,\n style: {\n background: 'linear-gradient(to right, #ff5c33, #e69900)',\n marginTop: '35px',\n }\n }).showToast()\n }\n\n const showConfigsModal = () => {\n\t\t\tconst 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\"}]}]' \n\t\t\tconst data = JSON.parse(window?.DtGetConfigs?.execute() || mock)\n\n data.sort((a, b) => a.sorter - b.sorter)\n data.forEach(item => item.items.sort((a, b) => a.sorter - b.sorter))\n\n const body = configModal._element.querySelector('.config-body')\n body.innerHTML = ''\n\n data.forEach(category => {\n const categoryElement = document.createElement('li')\n categoryElement.classList.add('list-group-item', 'bg-transparent', 'text-white', 'border-0', 'mb-1', 'rounded-1', 'px-1')\n categoryElement.innerHTML = `<span class=\"fw-bold btn-dark w-100 d-block p-1 rounded-1 mb-1\">${category.name}</span>`\n\n const configUlElement = document.createElement('ul')\n configUlElement.classList.add('list-group', 'bg-transparent', 'overflow-y-auto')\n\n category.items.forEach(item => {\n const configElement = document.createElement('li')\n configElement.classList.add('list-group-item', 'd-flex', 'btn-dark', 'text-white', 'border-0', 'rounded-2', 'px-1', 'py-2', 'mb-1')\n configElement.innerHTML = `\n <img src=\"${item.icon}\" width=\"40\" height=\"40\">\n <div class=\"text-start d-flex flex-column ms-2 w-100 text-truncate\">\n <span class=\"fw-bold text-uppercase\" style=\"font-size: 0.8rem;\">${item.name}</span>\n\t\t\t\t\t\t<span class=\"fst-italic fw-bold\" style=\"font-size: 0.7rem;\">${item.description || ''}</span> \n </div>\n <div class=\"d-flex flex-column ms-2\">\n <span class=\"fst-italic fw-bold text-end text-uppercase text-nowrap\" style=\"font-size: 0.8rem;\">${item.mode}</span>\n </div>\n </li>\n `\n configElement.addEventListener('click', e => {\n window?.DtSetConfig?.execute(item.id)\n configModal.hide()\n })\n configUlElement.appendChild(configElement)\n })\n\n categoryElement.appendChild(configUlElement)\n body.appendChild(categoryElement)\n })\n\n configModal.show()\n }\n\n username.value = window?.DtUsername?.get() ?? ''\n password.value = window?.DtPassword?.get() ?? ''\n\t\tuuid.value = window?.DtUuid?.get() ?? ''\n\n username.placeholder = 'LBL_USERNAME'.t()\n password.placeholder = 'LBL_PASSWORD'.t()\n\t\tuuid.placeholder = 'LBL_UUID'.t()\n\n dtOnNewLogListener()\n dtVpnStateListener(window?.DtGetVpnState?.execute() ?? 'DISCONNECTED')\n dtConfigClickListener()\n\t\t\n\t\tconsole.log('Pleno Layouts!🚀')\n </script>\n\n</body>\n</html>",
  260. "type": "HTML"
  261. },
  262. {
  263. "label": "ANDROID WEBVIEW (POR SUA CONTA E RISCO)",
  264. "name": "APP_SUPPORT_BUTTON",
  265. "value": null,
  266. "type": "HTML"
  267. },
  268. {
  269. "label": "PAGINA WEBVIEW (POR SUA CONTA E RISCO)",
  270. "name": "APP_WEB_VIEW",
  271. "value": null,
  272. "type": "HTML"
  273. }
  274. ]

comments powered by Disqus