// ==UserScript== // @name RAP2 Simple Ts // @namespace *://rap2.taobao.org/* // @version 0.2 // @description rap2 接口文档一键复制属性列表为 ts 类型标注 // @author Cleves // @match *://rap2.taobao.org/* // @icon  // @grant none // @license MIT // @downloadURL https://update.greasyfork.icu/scripts/469686/RAP2%20Simple%20Ts.user.js // @updateURL https://update.greasyfork.icu/scripts/469686/RAP2%20Simple%20Ts.meta.js // ==/UserScript== (function() { 'use strict'; const urls = new URL(location.href); const itf = urls.searchParams.get('itf'); let requestTSTemplate = ''; let responseTSTemplate = ''; /** copy text */ const copyTextToClipboard = (text) => { const textarea = document.createElement('textarea'); textarea.value = text; document.body.appendChild(textarea); textarea.select(); document.execCommand('copy'); document.body.removeChild(textarea); } const addCopyClickEvent = () => { const handleCopyRequestTSTemplate = () => { copyTextToClipboard(requestTSTemplate); alert('复制成功') } const handleCopyResponseTSTemplate = () => { copyTextToClipboard(responseTSTemplate); alert('复制成功') } document.querySelector('.copy-requestTSTemplate').addEventListener('click', handleCopyRequestTSTemplate) document.querySelector('.copy-responseTSTemplate').addEventListener('click', handleCopyResponseTSTemplate) } const appendCopyBtn = () => { const copyBtn = (className) => { return `` } document.querySelectorAll('.PropertyList .header.clearfix .title').forEach((elm, idx) => { elm.innerHTML += copyBtn(idx === 0 ? 'copy-requestTSTemplate' : 'copy-responseTSTemplate'); }) addCopyClickEvent() } const watchTitleElm = () => { const copyBtnWrap = document.querySelectorAll('.PropertyList .header.clearfix .title'); if (!copyBtnWrap.length) { setTimeout(watchTitleElm, 1000) } else { // show copy btn appendCopyBtn() } } watchTitleElm() const fetchData = async () => { return fetch(`http://rap2api.taobao.org/interface/get?id=${itf}`, { "headers": { "accept": "*/*", "accept-language": "zh-CN,zh;q=0.9", "proxy-connection": "keep-alive" }, "referrer": "http://rap2.taobao.org/", "referrerPolicy": "strict-origin-when-cross-origin", "body": null, "method": "GET", "mode": "cors", "credentials": "include" }).then(response => { if (response.ok) { return response.json(); } throw new Error('请求失败'); }); } const capitalizeFirstLetter = (str) => { return str.charAt(0).toUpperCase() + str.slice(1); } /** data to ts-template */ const templateFactory = (propsData, name = 'Data') => { if (propsData?.length) { let t = `export interface ${capitalizeFirstLetter(name)} {\n`; const childT = [] const complex = ['Object', 'Array'] propsData.forEach((item) => { const type = complex.includes(item.type) ? capitalizeFirstLetter(item.name) : item.type.toLowerCase() t += item.description ? `\t/** ${item.description} */\n` : '' t += `\t${item.name}${item.required ? '?' : ''}: ${type}\n` if (complex.includes(item.type)) { childT.push(templateFactory(item.children, item.name)) } }) t += '}\n' return `${t}\n${childT.join('\n\n')}` // return (t += childT.join('\n\n')) } return '' } fetchData().then((res) => { const data = res.data; requestTSTemplate = templateFactory(data.requestProperties, 'Request'); responseTSTemplate = templateFactory(data.responseProperties, 'Respones'); }) })();