swagger-umi-request-generate

根据swagger生成umi request请求模板代码

目前為 2021-05-24 提交的版本,檢視 最新版本

// ==UserScript==
// @name         swagger-umi-request-generate
// @namespace
// @version      1.0
// @description  根据swagger生成umi request请求模板代码
// @author       leesher
// @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
// @namespace https://greasyfork.org/users/775580
// ==/UserScript==

(function() {
  'use strict'
  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 function ${methoudName}(data:DataType){
                  return request<ResType>('${path}',{
                    method: 'post',
                    data
                  })
                }`

      case 'GET':
        return `// ${description}
              export function ${methoudName}(params:paramType){
                  return request<ResType>('${path}',{
                    method: 'get',
                    params
                  })
                }`

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

  $('body')
    .delegate('.opblock-tag', 'click', function(event) {
      console.log($(this).next())
      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)))
          )
        })
      })
    })
})()