Swagger优化主题

Swagger显示优化,Swagger优化主题

// ==UserScript==
// @name         Swagger优化主题
// @version      0.0.2
// @description  Swagger显示优化,Swagger优化主题
// @author       wilderliu
// @match        *://*/swagger-ui/*
// @icon         
// @grant        none
// @license      MIT
// @namespace https://greasyfork.org/users/1211834
// ==/UserScript==

(function() {
    'use strict';
    console.log('开始')
    // 优化样式
    let style = document.createElement('style')
    style.innerText = `
     :root {
       --swagger-left-panel-width:250px;
     }
     html {
      color-theme: dark;
     }
     #swagger-ui > .swagger-ui{
       width:calc(100% - var(--swagger-left-panel-width));
       margin-left: var(--swagger-left-panel-width);
     }
     #swagger-ui .swagger-ui .wrapper{
       // max-width:1000px;
     }
     .left-panel {
       width:var(--swagger-left-panel-width);
       height:100vh;
       position:fixed;
       overflow: auto;
       top:0;
       left:0;
       background: #1b1b1b;
       color:#f9f9f9;
       padding: 20px 0;
     }
     .left-panel .item a{
       display: inline-block;
       padding: 12px 15px;
       cursor:pointer;
       width: 100%;
       font-size: 16px;
       border-bottom: 1px solid #222;
       transition: all .3s;
       font-family:'微软雅黑';
     }
     .left-panel .item a:hover{
        // color: #49cc90;
        background-color: rgba(73,204,144,.6);
     }
      .left-panel .item a.active{
        color: #fff;
        background-color: #49cc90;
      }
    `
    document.head.append(style)

    //
    let leftPanel = document.createElement('div')
    leftPanel.className = 'left-panel'
    leftPanel.innerText = "liuwei"

    let swagger = document.querySelector('#swagger-ui')
    // 延迟重置主题
    setTimeout(()=>{
        let leftPanelHtml = []
        swagger.appendChild(leftPanel)
        let tags = document.querySelectorAll('.opblock-tag')
        tags.forEach((item)=>{
            leftPanelHtml.push(`
              <div class="item"><a data-id="${item.getAttribute('id')}">${item.getAttribute('data-tag')}</a></div>
            `)
        })
        leftPanel.innerHTML = leftPanelHtml.join('')
        leftPanel.addEventListener('click',(e)=>{
            let item = e.target
            let id = item.getAttribute('data-id')
            if(id){
                tags = document.querySelectorAll('.opblock-tag')
                tags.forEach((tag)=>{
                    let isOpen = tag.getAttribute('data-is-open')
                    if(isOpen === 'true'){
                        console.log(isOpen)
                       tag.click()
                    }
                })

                let target = document.querySelector(`#${id}`)
                target.click()
                target.scrollIntoView({behavior:'smooth'})

                document.querySelectorAll('.left-panel .item a').forEach(val=>{
                    val.classList.remove('active')
                })
                document.querySelector(`.left-panel .item a[data-id="${id}"]`).classList.add('active')
            }
        })
    },1000)
})();