devdocs.io - Do not auto focus input

7/27/2024, 9:54:04 AM

이 스크립트를 설치하려면 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        devdocs.io - Do not auto focus input
// @namespace   Violentmonkey Scripts
// @match       https://devdocs.io/*
// @grant       none
// @version     1.0
// @author      -
// @license     MIT
// @description 7/27/2024, 9:54:04 AM
// ==/UserScript==

const $input = document.querySelector('input[search]') ?? document.querySelector('input._search-input')

if ($input) {
  let allowFocus = false
  $input.addEventListener('mousedown', () => {
    allowFocus = true
    setTimeout(() => {
      allowFocus = false
    }, 0)
  })
  $input.addEventListener('keydown', () => {
    allowFocus = true
    setTimeout(() => {
      allowFocus = false
    }, 0)
  })

  $input.addEventListener('focus', (e) => {
    if (!allowFocus) {
      e.target.blur()
    }
    allowFocus = false
  })
}