GitHub Reader New

Ajusta automaticamente a largura do GitHub para melhorar a visualização.

当前为 2024-04-13 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name        GitHub Reader New
// @namespace   Violentmonkey Scripts
// @match       https://*.github.com/*
// @grant       none
// @version     1.4
// @author      EmersonxD
// @description Ajusta automaticamente a largura do GitHub para melhorar a visualização.
// @license     MIT
// ==/UserScript==

(function() {

    'use strict';


    // Verifica se o estilo já existe antes de criar um novo

    if (!document.querySelector('#github-reader-enhancer-style')) {

        var style = document.createElement('style');

        style.id = 'github-reader-enhancer-style';

        document.head.appendChild(style);

    }


    // Define variáveis para valores repetidos

    var maxWidth = '100%';

    var containerMaxWidth = '90%';


    // Aplica o CSS personalizado

    document.querySelector('#github-reader-enhancer-style').innerHTML = `

        .timeline-new-comment,

        .markdown-body {

            max-width: ${maxWidth};

        }

        .markdown-body {

            font-size: 1.4em;

        }

        .discussion-timeline,

        .container-lg,

        .container-xl {

            max-width: ${containerMaxWidth};

        }

    `;


    // Função para enviar e-mails

    function sendEmail(subject, body, recipient) {

        // Verifica se o destinatário é um endereço de e-mail válido

        if (!validateEmail(recipient)) {

            alert('O destinatário deve ser um endereço de e-mail válido.');

            return;

        }


        // Verifica se o corpo do e-mail não está vazio

        if (body.trim() === '') {

            alert('O corpo do e-mail não pode estar vazio.');

            return;

        }


        // Cria um link de e-mail com o assunto, corpo e destinatário especificados

        var link = `mailto:${recipient}?subject=${encodeURIComponent(subject)}&body=${encodeURIComponent(body)}`;


        // Exibe uma mensagem de confirmação antes de enviar o e-mail

        if (confirm('Tem certeza de que deseja enviar o e-mail?')) {

            window.location.href = link;

        }

    }


    // Função para validar endereços de e-mail

    function validateEmail(email) {

        var re = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;

        return re.test(String(email).toLowerCase());

    }


    // Cria o botão de "Salvar e Enviar E-mail"

    var saveAndSendBtn = document.createElement('button');

    saveAndSendBtn.textContent = 'Salvar e Enviar E-mail';

    saveAndSendBtn.style.position = 'fixed';

    saveAndSendBtn.style.bottom = '20px';

    saveAndSendBtn.style.right = '20px';

    saveAndSendBtn.style.zIndex = '9999';

    saveAndSendBtn.style.backgroundColor = '#4CAF50';

    saveAndSendBtn.style.color = '#fff';

    saveAndSendBtn.style.padding = '10px 20px';

    saveAndSendBtn.style.borderRadius = '5px';

    saveAndSendBtn.style.border = 'none';

    saveAndSendBtn.addEventListener('click', function() {

        var subject = 'Texto salvo do GitHub Reader New';

        var body = document.body.innerText;

        var recipient = '[email protected]';

        sendEmail(subject, body, recipient);

    });

    document.body.appendChild(saveAndSendBtn);

})();
// Função para enviar e-mails
function sendEmail(subject, body, recipient) {
    // Verifica se o destinatário é um endereço de e-mail válido
    if (!validateEmail(recipient)) {
        alert('O destinatário deve ser um endereço de e-mail válido.');
        return;
    }

    // Verifica se o corpo do e-mail não está vazio
    if (body.trim() === '') {
        alert('O corpo do e-mail não pode estar vazio.');
        return;
    }

    // Cria um link de e-mail com o assunto, corpo e destinatário especificados
    var link = `mailto:${recipient}?subject=${encodeURIComponent(subject)}&body=${encodeURIComponent(body)}`;

    // Exibe uma mensagem de confirmação antes de enviar o e-mail
    if (confirm('Tem certeza de que deseja enviar o e-mail?')) {
        window.location.href = link;
    }
}

// Função para validar endereços de e-mail
function validateEmail(email) {
    var re = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
    return re.test(String(email).toLowerCase());
}