사용자:하늘/autoInsertLinkTitle.js: 두 판 사이의 차이

잔글 (Chirho님이 사용자:Cerulean/filesaver.js 문서를 넘겨주기를 만들지 않고 사용자:하늘/filesaver.js 문서로 이동했습니다: "Cerulean" 사용자의 이름을 "하늘"(으)로 바꿀 때 문서를 자동으로 이동했습니다)
(내용을 "let url = document.querySelector(".mw-wikiEditor-InsertLink-TitleInputField .oo-ui-inputWidget-input").value; fetch(`https://api.allorigins.win/get?url=${encodeURIComponent(url)}`) .then(response => { if (response.ok) return response.json() throw new Error('Network response was not ok.') }) .then(data => console.log(data.contents));"(으)로 바꿈)
태그: 대체됨
1번째 줄: 1번째 줄:
var _global = typeof window === 'object' && window.window === window
let url = document.querySelector(".mw-wikiEditor-InsertLink-TitleInputField .oo-ui-inputWidget-input").value; fetch(`https://api.allorigins.win/get?url=${encodeURIComponent(url)}`)
  ? window : typeof self === 'object' && self.self === self
                    .then(response => {
    ? self : typeof global === 'object' && global.global === global
                      if (response.ok) return response.json()
      ? global
                      throw new Error('Network response was not ok.')
      : this
                    })
 
                    .then(data => console.log(data.contents));
function bom(blob, opts) {
  if (typeof opts === 'undefined') opts = { autoBom: false }
  else if (typeof opts !== 'object') {
    console.warn('Deprecated: Expected third argument to be a object')
    opts = { autoBom: !opts }
  }
 
  // prepend BOM for UTF-8 XML and text/* types (including HTML)
  // note: your browser will automatically convert UTF-16 U+FEFF to EF BB BF
  if (opts.autoBom && /^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(blob.type)) {
    return new Blob([String.fromCharCode(0xFEFF), blob], { type: blob.type })
  }
  return blob
}
 
function download(url, name, opts) {
  var xhr = new XMLHttpRequest()
  xhr.open('GET', url)
  xhr.responseType = 'blob'
  xhr.onload = function () {
    saveAs(xhr.response, name, opts)
  }
  xhr.onerror = function () {
    console.error('could not download file')
  }
  xhr.send()
}
 
function corsEnabled(url) {
  var xhr = new XMLHttpRequest()
  // use sync to avoid popup blocker
  xhr.open('HEAD', url, false)
  try {
    xhr.send()
  } catch (e) { }
  return xhr.status >= 200 && xhr.status <= 299
}
 
// `a.click()` doesn't work for all browsers (#465)
function click(node) {
  try {
    node.dispatchEvent(new MouseEvent('click'))
  } catch (e) {
    var evt = document.createEvent('MouseEvents')
    evt.initMouseEvent('click', true, true, window, 0, 0, 0, 80,
      20, false, false, false, false, 0, null)
    node.dispatchEvent(evt)
  }
}
 
// Detect WebView inside a native macOS app by ruling out all browsers
// We just need to check for 'Safari' because all other browsers (besides Firefox) include that too
// https://www.whatismybrowser.com/guides/the-latest-user-agent/macos
var isMacOSWebView = _global.navigator && /Macintosh/.test(navigator.userAgent) && /AppleWebKit/.test(navigator.userAgent) && !/Safari/.test(navigator.userAgent)
 
var saveAs = _global.saveAs || (
  // probably in some web worker
  (typeof window !== 'object' || window !== _global)
    ? function saveAs() { /* noop */ }
 
    // Use download attribute first if possible (#193 Lumia mobile) unless this is a macOS WebView
    : ('download' in HTMLAnchorElement.prototype && !isMacOSWebView)
      ? function saveAs(blob, name, opts) {
        var URL = _global.URL || _global.webkitURL
        var a = document.createElement('a')
        name = name || blob.name || 'download'
 
        a.download = name
        a.rel = 'noopener' // tabnabbing
 
        // TODO: detect chrome extensions & packaged apps
        // a.target = '_blank'
 
        if (typeof blob === 'string') {
          // Support regular links
          a.href = blob
          if (a.origin !== location.origin) {
            corsEnabled(a.href)
              ? download(blob, name, opts)
              : click(a, a.target = '_blank')
          } else {
            click(a)
          }
        } else {
          // Support blobs
          a.href = URL.createObjectURL(blob)
          setTimeout(function () { URL.revokeObjectURL(a.href) }, 4E4) // 40s
          setTimeout(function () { click(a) }, 0)
        }
      }
 
      // Use msSaveOrOpenBlob as a second approach
      : 'msSaveOrOpenBlob' in navigator
        ? function saveAs(blob, name, opts) {
          name = name || blob.name || 'download'
 
          if (typeof blob === 'string') {
            if (corsEnabled(blob)) {
              download(blob, name, opts)
            } else {
              var a = document.createElement('a')
              a.href = blob
              a.target = '_blank'
              setTimeout(function () { click(a) })
            }
          } else {
            navigator.msSaveOrOpenBlob(bom(blob, opts), name)
          }
        }
 
        // Fallback to using FileReader and a popup
        : function saveAs(blob, name, opts, popup) {
          // Open a popup immediately do go around popup blocker
          // Mostly only available on user interaction and the fileReader is async so...
          popup = popup || open('', '_blank')
          if (popup) {
            popup.document.title =
              popup.document.body.innerText = 'downloading...'
          }
 
          if (typeof blob === 'string') return download(blob, name, opts)
 
          var force = blob.type === 'application/octet-stream'
          var isSafari = /constructor/i.test(_global.HTMLElement) || _global.safari
          var isChromeIOS = /CriOS\/[\d]+/.test(navigator.userAgent)
 
          if ((isChromeIOS || (force && isSafari) || isMacOSWebView) && typeof FileReader !== 'undefined') {
            // Safari doesn't allow downloading of blob URLs
            var reader = new FileReader()
            reader.onloadend = function () {
              var url = reader.result
              url = isChromeIOS ? url : url.replace(/^data:[^;]*;/, 'data:attachment/file;')
              if (popup) popup.location.href = url
              else location = url
              popup = null // reverse-tabnabbing #460
            }
            reader.readAsDataURL(blob)
          } else {
            var URL = _global.URL || _global.webkitURL
            var url = URL.createObjectURL(blob)
            if (popup) popup.location = url
            else location.href = url
            popup = null // reverse-tabnabbing #460
            setTimeout(function () { URL.revokeObjectURL(url) }, 4E4) // 40s
          }
        }
)
 
_global.saveAs = saveAs.saveAs = saveAs
 
if (typeof module !== 'undefined') {
  module.exports = saveAs;
}

2023년 12월 15일 (금) 13:26 판

let url = document.querySelector(".mw-wikiEditor-InsertLink-TitleInputField .oo-ui-inputWidget-input").value; fetch(`https://api.allorigins.win/get?url=${encodeURIComponent(url)}`)
                    .then(response => {
                      if (response.ok) return response.json()
                      throw new Error('Network response was not ok.')
                    })
                    .then(data => console.log(data.contents));