Imaglr Scale Content to Screen

Scale videos and images on Imaglr to fit on one screen

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Imaglr Scale Content to Screen
// @namespace    https://imaglr.com/
// @version      1.3
// @license      Public Domain
// @description  Scale videos and images on Imaglr to fit on one screen
// @author       Literally ChatGPT
// @match        https://imaglr.com/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=imaglr.com
// @grant        none
// ==/UserScript==

const MAX_VH = 0.9;

function clampMedia(el) {
  // Reset width so we can measure correctly
  el.style.width = '100%';
  el.style.maxWidth = '100%';

  const rect = el.getBoundingClientRect();
  const maxHeightPx = window.innerHeight * MAX_VH;

  if (rect.height > maxHeightPx) {
    const scale = maxHeightPx / rect.height;
    const newWidth = rect.width * scale;
    el.style.width = `${newWidth}px`;
  }

  // Horizontal centering
  el.style.display = 'block';
  el.style.marginLeft = 'auto';
  el.style.marginRight = 'auto';
}

function centerContainers() {
  document.querySelectorAll('.vertical-media-item').forEach(el => {
    el.style.display = 'flex';
    el.style.justifyContent = 'center';
    el.style.alignItems = 'center';
  });
}

function processAll() {
  const media = document.querySelectorAll('img.w-full, video.w-full, .media-item');
  media.forEach(clampMedia);
  centerContainers();
}

// Initial pass
processAll();

// Re-run on window resize
window.addEventListener('resize', processAll);

// Robust MutationObserver (watch everything in body)
const observer = new MutationObserver(processAll);
observer.observe(document.body, { childList: true, subtree: true });

// Extra fallback: periodically process new posts in case the observer misses something
setInterval(processAll, 1000); // every 1 second