Quicker-显示用户头像

在讨论区等地方显示头像

Install this script?
Author's suggested script

You may also like Change QuickerAction`s version.

Install this script
// ==UserScript==
// @name        Quicker-显示用户头像
// @version     1.6
// @description 在讨论区等地方显示头像
// @match       https://getquicker.net/*
// @icon          
// @grant             GM_openInTab
// @grant             GM_setValue
// @grant             GM_getValue
// @grant             GM_registerMenuCommand
// @grant             GM_getResourceText
// @require           https://unpkg.com/sweetalert2@10.16.6/dist/sweetalert2.min.js
// @namespace https://greasyfork.org/users/1082425
// ==/UserScript==

(function() {
    'use strict';

    function getAvatarImageSrc(uri) {
        var cachedData = localStorage.getItem(uri);
        if (cachedData) {
            var data = JSON.parse(cachedData);
            if (data.timestamp && Date.now() - data.timestamp < 24 * 60 * 60 * 1000) {
                return data.src;
            } else {
                localStorage.removeItem(uri); // 过期则释放缓存
            }
        }

        GM_registerMenuCommand('⌛清空头像缓存', () => {
            Swal.fire({
                showCancelButton: true,
                title: '确定要清空缓存吗?',
                icon: 'warning',
                confirmButtonText: '确定',
                cancelButtonText: '取消',
                customClass: {
                    popup: 'instant-popup',
                },
            }).then((res) => {
                if (res.isConfirmed) {
                    localStorage.clear();
                }
            });
        });

        var xhr = new XMLHttpRequest();
        xhr.open('GET', uri, false);
        xhr.send();
        if (xhr.status === 200) {
            var htmlContent = xhr.responseText;
            var parser = new DOMParser();
            var doc = parser.parseFromString(htmlContent, 'text/html');
            var xpathResult = doc.evaluate('/html/body/div[1]/div/div[2]/h2/div[1]/img', doc, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null);
            var avatarImage = xpathResult.singleNodeValue;
            if (avatarImage) {
                var newData = {
                    link: uri,
                    src: avatarImage.src,
                    timestamp: Date.now()
                };
                localStorage.setItem(uri, JSON.stringify(newData));

                return avatarImage.src;
            }
        }
        return null;
    }
    var url = window.location.href;
    var regex = /^https:\/\/getquicker\.net\/Sharedaction\?code=/i;
    var isMatch = regex.test(url);

    if (!isMatch) {
        var elements = document.querySelectorAll('.avatar');
        var userlinks = document.querySelectorAll('.username .user-link , .mb-1 .user-link');
        for (var i = 0; i < elements.length; i++) {
            var element = elements[i];
            var userlink = userlinks[i];

            var src = getAvatarImageSrc(userlink.href);
            if (!src) {
                continue;
            }

            var imgElement = document.createElement('img');
            var aElement = document.createElement('a');

            imgElement.src = src;
            imgElement.alt = 'Avatar';
            imgElement.style.borderRadius = '50%';

            var size = Math.min(parseInt(getComputedStyle(element).width), parseInt(getComputedStyle(element).height));
            imgElement.style.width = size + 'px';
            imgElement.style.height = size + 'px';

            aElement.href = userlink.href;
            aElement.style.width = getComputedStyle(element).width;
            aElement.style.height = getComputedStyle(element).height;
            aElement.target = '_blank';
            aElement.appendChild(imgElement);

            element.parentNode.replaceChild(aElement, element);
        }
    }
})();