Greasy Fork is available in English.

Kirka.IO Enhanced

Wallhack, adblock and more for Kirka.IO.

  1. // ==UserScript==
  2. // @name Kirka.IO Enhanced
  3. // @namespace -
  4. // @version 1.5.0
  5. // @description Wallhack, adblock and more for Kirka.IO.
  6. // @author NotYou
  7. // @match *://kirka.io/*
  8. // @run-at document-end
  9. // @license GPL-3.0-or-later
  10. // @grant GM.info
  11. // @icon 
  12. // ==/UserScript==
  13.  
  14. (function() {
  15. const TITLE = (GM && GM.info && GM.info.script && GM.info.script.name) || 'Kirka.IO Enhanced'
  16.  
  17. let wallhackEnabled = false
  18.  
  19. const KEYS = {
  20. CHAT_VISIBILITY_TOGGLE: 'V',
  21. WALLHACK_TOGGLE: 'F'
  22. }
  23.  
  24. let players = []
  25.  
  26. class Visibility {
  27. static visible(el) {
  28. el.style.opacity = '1'
  29. el.style.pointerEvents = 'auto'
  30. }
  31.  
  32. static invisible(el) {
  33. el.style.opacity = '0'
  34. el.style.pointerEvents = 'none'
  35. }
  36.  
  37. static toggle(el) {
  38. if(el.style.opacity === '0') {
  39. return this.visible(el)
  40. }
  41.  
  42. this.invisible(el)
  43. }
  44. }
  45.  
  46. class Wallhack {
  47. static visible(e) {
  48. e.alphaTest = .99
  49. e.fog = false
  50. e.depthTest = false
  51. }
  52.  
  53. static invisible(e) {
  54. e.alphaTest = 1
  55. e.fog = true
  56. e.depthTest = true
  57. }
  58. }
  59.  
  60. class CSS {
  61. static init() {
  62. const _CSS = `
  63. .notification {
  64. position: absolute;
  65. background: var(--secondary-5);
  66. border: 4px solid rgb(62, 77, 124);
  67. border-bottom: 4px solid var(--secondary-6);
  68. border-top: 4px solid rgb(77, 92, 139);
  69. width: 250px;
  70. height: 100px;
  71. right: 15px;
  72. bottom: 15px;
  73. z-index: 100;
  74. color: rgb(255, 255, 255);
  75. transition: .3s;
  76. opacity: 0.85;
  77. pointer-events: none;
  78. }
  79.  
  80. .notification-title {
  81. font-size: x-large;
  82. text-align: center;
  83. margin: 2px;
  84. }
  85.  
  86. .notification-body {
  87. margin: 3px;
  88. font-size: medium;
  89. }
  90.  
  91. .highlight-disabled::after {
  92. content: 'disabled';
  93. color: rgb(210, 50, 50);
  94. }
  95.  
  96. .highlight-enabled::after {
  97. content: 'enabled';
  98. color: rgb(50, 210, 50);
  99. }
  100.  
  101. .bloody-screen {
  102. pointer-events: none !important;
  103. width: 100vw;
  104. height: 100vh;
  105. position: absolute;
  106. left: 0;
  107. top: 0;
  108. box-shadow: rgba(255, 0, 0, .8) 0 0 150px inset;
  109. transition: .3s opacity;
  110. }`
  111.  
  112. addStyle(_CSS)
  113. }
  114. }
  115.  
  116. class AdBlock {
  117. static init() {
  118. let adBlockCss
  119.  
  120. let ads = ['ad-left', 'ad-right', 'ad-bottom', 'ad-change-weapon']
  121. let adsSelectors = ''
  122.  
  123. ads.forEach(e => {
  124. let adSelector = ''
  125. let prefixes = ['.', '#']
  126.  
  127. prefixes.forEach(r => {
  128. adSelector += r + e + ','
  129. })
  130.  
  131. adsSelectors += adSelector
  132. })
  133.  
  134. adBlockCss = adsSelectors.slice(0, -1) + '{ display: none !important }'
  135.  
  136. addStyle(adBlockCss)
  137.  
  138. window.show_rewarded = _
  139. window.show_preroll = _
  140. }
  141. }
  142.  
  143. class Keybindings {
  144. static init() {
  145. let keybidings = [
  146. // Toggle Chat Visibility
  147. {
  148. key: KEYS.CHAT_VISIBILITY_TOGGLE,
  149. fn() {
  150. let chat = document.querySelector('.chat')
  151.  
  152. if(chat) {
  153. chat.style.transition = '.3s opacity'
  154. Visibility.toggle(chat)
  155. }
  156. }
  157. },
  158.  
  159. // Toggle Wallhack
  160. {
  161. key: KEYS.WALLHACK_TOGGLE,
  162. fn() {
  163. wallhackEnabled = !wallhackEnabled
  164.  
  165. if(wallhackEnabled) {
  166. players.forEach(visibleEach)
  167. } else {
  168. players.forEach(invisibleEach)
  169. }
  170.  
  171. function visibleEach(e) {
  172. Wallhack.visible(e)
  173. }
  174.  
  175. function invisibleEach(e) {
  176. Wallhack.invisible(e)
  177. }
  178.  
  179. notify('Wallhack', 'Wallhack is ', wallhackEnabled)
  180. }
  181. },
  182. ]
  183.  
  184. keybidings.forEach(e => {
  185. window.addEventListener('keydown', r => {
  186. const focusedElem = document.querySelector(':focus') || document.activeElement
  187.  
  188. if(focusedElem.matches('.chat .input')) {
  189. return
  190. }
  191.  
  192. if(r.code === 'Key' + e.key.toUpperCase()) {
  193. r.preventDefault()
  194. e.fn()
  195. }
  196. })
  197. })
  198. }
  199. }
  200.  
  201. class BloodyScreen {
  202. static init() {
  203. const bloodyScreen = document.createElement('div')
  204. bloodyScreen.className = 'bloody-screen'
  205. Visibility.invisible(bloodyScreen)
  206. document.body.appendChild(bloodyScreen)
  207.  
  208. const obs = new MutationObserver(() => {
  209. const progress = document.querySelector('.hp-progress')
  210.  
  211.  
  212. if(progress) {
  213. const hp = currentHealth()
  214.  
  215. if(hp < 35 && hp > 0) {
  216. Visibility.visible(bloodyScreen)
  217. } else {
  218. Visibility.invisible(bloodyScreen)
  219. }
  220. }
  221. })
  222.  
  223. obs.observe(document.body, {
  224. subtree: true,
  225. childList: true,
  226. })
  227.  
  228. function currentHealth() {
  229. return +document.querySelector('.hp-progress').style.width.slice(0, -1)
  230. }
  231. }
  232. }
  233.  
  234. class _Wallhack {
  235. static init() {
  236. Object.defineProperty(Object.prototype, 'material', {
  237. set(value) {
  238. this._material = value
  239.  
  240. if (this._material && this._material.name && this._material.name.indexOf('player') !== -1) {
  241. players.push(value)
  242.  
  243. if(wallhackEnabled) {
  244. Wallhack.visible(value)
  245. }
  246. }
  247. },
  248.  
  249. get() {
  250. return this._material
  251. }
  252. })
  253. }
  254. }
  255.  
  256. class Main {
  257. static init() {
  258. const MODULES = [
  259. CSS,
  260. AdBlock,
  261. Keybindings,
  262. BloodyScreen,
  263. _Wallhack,
  264. ]
  265.  
  266. initModules(MODULES)
  267. }
  268. }
  269.  
  270. Main.init()
  271.  
  272. function initModules(modules) {
  273. for (let i = 0; i < modules.length; i++) {
  274. const MODULE = modules[i]
  275.  
  276. initModule(MODULE)
  277. }
  278. }
  279.  
  280. function initModule(module) {
  281. try {
  282. module.init()
  283. } catch(e) {
  284. console.error(TITLE, module.name + ' module, has error:', e)
  285. }
  286. }
  287.  
  288. function notify(title, body, highlight) {
  289. const notifClass = 'notification'
  290. const notif = document.createElement('div')
  291. const notifTitle = document.createElement('h3')
  292. const notifBody = document.createElement('p')
  293.  
  294. notifTitle.className = notifClass + '-title'
  295. notifBody.className = notifClass + '-body'
  296. notif.className = notifClass
  297.  
  298. notifTitle.textContent = title ?? 'Kirka.IO Enchanced'
  299. notifBody.innerHTML = (body ?? '') + (`<span class="highlight-${highlight ? 'enabled' : highlight === false ? 'disabled' : ''}"></span>`)
  300.  
  301. notif.style.right = '100vw'
  302.  
  303. notif.appendChild(notifTitle)
  304. notif.appendChild(notifBody)
  305. document.body.appendChild(notif)
  306.  
  307. setTimeout(() => {
  308. notif.style.right = ''
  309. }, 300)
  310.  
  311. setTimeout(() => {
  312. notif.style.right = '100vw'
  313.  
  314. setTimeout(() => {
  315. notif.remove()
  316. }, 300)
  317. }, 1300)
  318. }
  319.  
  320. function addStyle(css) {
  321. const styleNode = document.createElement('style')
  322. styleNode.appendChild(document.createTextNode(css))
  323. document.head.appendChild(styleNode)
  324. }
  325.  
  326. function _() {}
  327. })()