Always Visible Buttons

Ensure buttons with specific classes or attributes are always visible.

이 스크립트를 설치하려면 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         Always Visible Buttons
// @namespace    always-visible-buttons
// @version      1.0
// @description  Ensure buttons with specific classes or attributes are always visible.
// @author       gpt 4o 
// @match        https://t3.chat/*
// @license MIT
// @grant        none
// ==/UserScript==

(function () {
  'use strict';

  // Inject global CSS to override hover styles
  const injectGlobalCSS = () => {
    const style = document.createElement('style');
    style.textContent = `
      /* Target buttons hidden by hover effects */
      .group .opacity-0 {
        opacity: 1 !important; /* Make buttons fully visible */
        pointer-events: auto !important; /* Ensure buttons are clickable */
      }

      /* Disable hover effects */
      .group:hover .opacity-0 {
        opacity: 1 !important;
      }

      /* Disable transitions for immediate visibility */
      .group .transition-opacity {
        transition: none !important;
      }
    `;
    document.head.appendChild(style);
  };

  // Run the function to inject CSS
  injectGlobalCSS();
})();