flash-swagger

swagger 快捷插件

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         flash-swagger
// @namespace    https://www.flashexpress.com/
// @version      0.5
// @description  swagger 快捷插件
// @author       杨淼
// @match        http://*/swagger-ui.html*
// @grant        GM_addStyle
// @run-at       document-end
// @require     https://cdn.bootcdn.net/ajax/libs/jquery/3.4.1/jquery.min.js
// @require     https://cdn.bootcdn.net/ajax/libs/clipboard.js/2.0.6/clipboard.js
// ==/UserScript==

(function() {
  'use strict'

  console.log('油猴启动')
  new ClipboardJS('.copy-btn')

  function createATag(text, content) {
    const temp = $(`<button class="btn copy-btn" data-clipboard-text="${content}">${text}</button>`)

    temp.on('click', function(event) {
      event.preventDefault()
    })

    return temp
  }

  function toHump(name) {
    return name.replace(/\-(\w)/g, function(all, letter){
      return letter.toUpperCase();
    });
  }

  function createFunc(methoud, path, description) {
    const methoudName = toHump(path.match('[^/]+(?!.*/)')[0])
    switch (methoud.toUpperCase()) {
      case 'POST':
        return `// ${description}
                export const ${methoudName} = (data) => {
                  return axiosRequest({
                    url: '${path}',
                    data
                  })
                }`

      case 'GET':
        return `// ${description}
                export const ${methoudName} = (params) => {
                  return axiosRequest({
                    url: '${path}',
                    method: 'get',
                    params
                  })
                }`

      case 'PUT':
        return `// ${description}
                export const ${methoudName} = (data) => {
                  return axiosRequest({
                    url: '${path}',
                    method: 'put',
                    data
                  })
                }`

      default:
        return '暂不支持当前请求格式'
    }
  }

  $('body')
    .delegate('.opblock-tag', 'click', function(event) {
      console.log($(this).next())
      // DOM异步展示 用宏任务包裹
      setTimeout(() => {
        $(this).next().children('span').each((index, $el) => {
          console.log($el)
          $el = $($el)

          const methoud = $($el).find('.opblock-summary-method').text()
          const path = $($el).find('.opblock-summary-path > a > span').text()
          const description = $($el).find('.opblock-summary-description').text()

          $el.before($('<div></div>')
            .append(createATag('复制URL', path))
            .append(createATag('复制函数', createFunc(methoud, path, description)))
          )
        })
      })
    })
})()