Unpaywall meetup.com

Remove paywall, unblur photos, enable scrolling, and re-enable dynamic content

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

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

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         Unpaywall meetup.com
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Remove paywall, unblur photos, enable scrolling, and re-enable dynamic content
// @author       louietyj
// @match        https://www.meetup.com/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    function unPaywall() {
        document.querySelectorAll('div[role="dialog"]').forEach(el => {
            if (el.textContent.includes('Join Meetup+')) {
                el.style.display = 'none';
            }
        });
        document.querySelectorAll('div[data-slot="modal-overlay"]').forEach(el => {
            el.style.display = 'none';
        });
    }

    function unblurPhotos() {
        const elements = document.querySelectorAll('[class*="blur"]');
        elements.forEach(element => {
            Array.from(element.classList).forEach(cls => {
                if (cls.includes('blur')) {
                    element.classList.remove(cls);
                }
            });
        });
    }

    function enableScrolling() {
        const style = document.createElement('style');
        style.textContent = `
            html, body {
                overflow: auto !important;
                overflow-y: auto !important;
                position: static !important;
                height: auto !important;
            }
        `;
        document.head.appendChild(style);

        window.addEventListener('wheel', function (e) {
            e.stopImmediatePropagation();
        }, { capture: true });
    }

    function removeLocks() {
        const svgs = document.querySelectorAll('svg[data-src="https://secure.meetupstatic.com/next/images/design-system-icons/lock-outline.svg"]');
        svgs.forEach(svg => {
            svg.remove();
        });
    }

    function removeInert() {
        document.querySelectorAll('.inert, [inert]').forEach(el => {
            el.classList.remove('inert');
            el.removeAttribute('inert');
        });
    };

    function run() {
        unPaywall();
        unblurPhotos();
        enableScrolling();
        removeLocks();
        removeInert();
    }

    //window.addEventListener('load', run);
    const observer = new MutationObserver(run);
    observer.observe(document.body, {
        childList: true,
        subtree: true
    });
})();