FuckImage

摸鱼大法好,隐藏或缩小页面中的图片,别让老板在十万八千里外就能看到你在摸鱼!

Aby zainstalować ten skrypt, wymagana jest instalacje jednego z następujących rozszerzeń: Tampermonkey, Greasemonkey lub Violentmonkey.

Aby zainstalować ten skrypt, wymagana jest instalacje jednego z następujących rozszerzeń: Tampermonkey, Violentmonkey.

Aby zainstalować ten skrypt, wymagana jest instalacje jednego z następujących rozszerzeń: Tampermonkey, Violentmonkey.

Aby zainstalować ten skrypt, wymagana będzie instalacja rozszerzenia Tampermonkey lub Userscripts.

You will need to install an extension such as Tampermonkey to install this script.

Aby zainstalować ten skrypt, musisz zainstalować rozszerzenie menedżera skryptów użytkownika.

(Mam już menedżera skryptów użytkownika, pozwól mi to zainstalować!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

Będziesz musiał zainstalować rozszerzenie menedżera stylów użytkownika, aby zainstalować ten styl.

Będziesz musiał zainstalować rozszerzenie menedżera stylów użytkownika, aby zainstalować ten styl.

Musisz zainstalować rozszerzenie menedżera stylów użytkownika, aby zainstalować ten styl.

(Mam już menedżera stylów użytkownika, pozwól mi to zainstalować!)

// ==UserScript==
// @name         FuckImage
// @namespace    http://tampermonkey.net/
// @version      1.2
// @description  摸鱼大法好,隐藏或缩小页面中的图片,别让老板在十万八千里外就能看到你在摸鱼!
// @author       [email protected]
// @match        *://*/*
// @grant        none
// @exclude      https://lanhuapp.com/*
// @exclude      *://localhost:*/*
// @exclude      *://*.*.*.*/*
// @exclude      *://*.*.*.*:*/*
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    let imageArr = document.getElementsByTagName('img')

    let currentWork = null // 'hide' 'show' 'mini'

    let timer = null

    let miniSizeDefault = 50

    let color = "#f4b579"

    let picture = ""
    let activeShow = ""
    let grayShow = ""
    let activeHide = ""
    let grayHide = ""
    let zoom = ""

    function addGlobalStyle(css) {
        var head, style;
        head = document.getElementsByTagName('head')[0];
        if (!head) { return; }
        style = document.createElement('style');
        style.type = 'text/css';
        style.innerHTML = css;
        head.appendChild(style);
    }

    function hideShowImg(action){
        for(let i = 0; i < imageArr.length; i++) {
            let imageItem = imageArr[i]
            let sizeType = imageItem.width > imageItem.height ? 'width' : 'height'
            let miniSizeInputValue = +document.getElementById("zk-mini-size-input").value
            let miniSize = miniSizeInputValue && miniSizeInputValue >= 0 ? miniSizeInputValue : miniSizeDefault
            if(action) { console.log(action)}
            switch(action) {
                case 'show':
                    //console.log('show')
                    imageItem.style.display = ''
                    imageItem.style.width = ''
                    imageItem.style.height = ''
                    break
                case 'hide':
                    //console.log('hide')
                    imageItem.style.display = 'none'
                    imageItem.style.width = ''
                    imageItem.style.height = ''
                    break
                case 'mini':
                    //console.log('mini')
                    imageItem.style.display = ''
                    imageItem[sizeType] > miniSize && (imageItem.style[sizeType] = `${miniSize}px`)
                    break
            }
        }
    }

    function hideImg() { hideShowImg('hide')}

    function showImg() { hideShowImg('show')}

    function miniImg() { hideShowImg('mini')}

    function createBtn() {
        let container = document.createElement('DIV')
        container.id = "zk-image-container"
        container.innerHTML = `
            <i class="logo-img zk-item"></i>
            <span id="zk-hide-image-btn" class="zk-image-btn zk-item" title="隐藏图片"></span>
            <span id="zk-show-image-btn" class="zk-image-btn zk-item" title="显示图片"></span>
            <input class="size-input zk-item" placeholder="50" id="zk-mini-size-input"/>
            <span id="zk-mini-image-btn" class="zk-image-btn zk-item" title="缩小图片"></span>`
        document.body.appendChild(container)
        //document.getElementById("zk-mini-size-input").value = miniSizeDefault
        //container.style.position = 'fixed'
        //container.style.right="100px"
        //container.style.top="100px"
        //container.style.zIndex=1000000000



        addGlobalStyle(`#zk-image-container { position: fixed; right: -170px; top: 100px; z-index: 1000000; background-image: linear-gradient(120deg, #84fab0 0%, #8fd3f4 100%); height: 44px; line-height: 44px; border-radius: 22px 0 0 22px; padding: 0 22px; transition: all 300ms;}` )
        addGlobalStyle(`#zk-image-container:hover { right: 0; transition: all 300ms}`)
        addGlobalStyle(`#zk-image-container .logo-img{ background-image: url(${picture}); display: inline-block; width: 32px; height: 32px; background-size: 100% 100%; position: relative; left: -16px;}`)
        addGlobalStyle(`#zk-image-container .zk-image-btn{cursor: pointer; display: inline-block; width: 32px; height: 32px; background-size: 100% 100%; background-repeat: no-repeat;}`)
        addGlobalStyle(`#zk-image-container .size-input.zk-item { display: inline-block; height: 20px; width: 20px; border: none; outline: none; font-size: 12px; line-height: 20px; margin-top: 11px; margin-left: 4px; padding: 0; vertical-align: top; background: transparent; border-bottom: 1px solid ${color}; color:${color};}`)

        addGlobalStyle(`#zk-image-container #zk-hide-image-btn { background-image: url(${activeHide})}`)
        addGlobalStyle(`#zk-image-container #zk-show-image-btn { background-image: url(${activeShow})}`)
        addGlobalStyle(`#zk-image-container #zk-mini-image-btn { background-image: url(${zoom}); background-size: 24px 24px; background-position: center center; }`)
        addGlobalStyle(`#zk-image-container .zk-item { margin-top: 6px}`)
    }

    function bind() {
        document.getElementById("zk-hide-image-btn").addEventListener('click', ev => {
            hideImg()
            currentWork = 'hide'
        })
        document.getElementById("zk-show-image-btn").addEventListener('click', ev => {
            showImg()
            currentWork = 'show'
        })
        document.getElementById("zk-mini-image-btn").addEventListener('click', ev => {
            miniImg()
            currentWork = 'mini'
        })
    }

    function setTimeWork() {
        timer && clearInterval(timer)
        timer = setInterval(() => {
            currentWork && hideShowImg(currentWork)
            if(!document.getElementById("zk-image-container")){
                createBtn()
                bind()
            }
        }, 50)
    }


    createBtn()
    bind()
    setTimeWork()

})();