JSON Viewer

格式化显示 JSON 使数据看起来更加漂亮。支持 JSON 主题色切换。支持 JSON 脑图,清晰明了的查看 JSON 层级。支持通过 JSON Crack 查看 JSON。支持手动输入 JSON,HTTP 请求获取 JSON

  1. // ==UserScript==
  2. // @name JSON Viewer
  3. // @namespace http://tampermonkey.net/
  4. // @version 1.1.0c
  5. // @author Feny
  6. // @description 格式化显示 JSON 使数据看起来更加漂亮。支持 JSON 主题色切换。支持 JSON 脑图,清晰明了的查看 JSON 层级。支持通过 JSON Crack 查看 JSON。支持手动输入 JSON,HTTP 请求获取 JSON
  7. // @license GPL-3.0-only
  8. // @icon data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAeAB4AAD/4QAiRXhpZgAATU0AKgAAAAgAAQESAAMAAAABAAEAAAAAAAD/2wBDAAIBAQIBAQICAgICAgICAwUDAwMDAwYEBAMFBwYHBwcGBwcICQsJCAgKCAcHCg0KCgsMDAwMBwkODw0MDgsMDAz/2wBDAQICAgMDAwYDAwYMCAcIDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAz/wAARCAAgACADASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD9wvjF8bLX4ZrHZx+XNqlwnmKjH5YUyRvb6kEAd8H058d1b47XV5Ir3eoN++bagaXYrN6KOBn2FfPPx5/aEutX8a+KNWhIubhruZLSNj8u1WMcIOP4QoXOOwNS/wDBM79lDTfjh8YNe+IXj63TxRdeHfKjsE1KMTxtdSbmMmxvlAiVV2IBsUybgAyKR9ZTy6lhsM69Xovm2+iPmKmOqYjEKjT6v5WXU9e8beKrjxZpp/s/xFrfhjWIwWs9X0q42z2kmPlZo2zDcxjqYZ0eNv7obDDf/YL/AG8L745eJNc+G3xCttP0n4qeEWZZ2sVZNP8AENsu0rd2ysS0ZKPG7RMSQsisCcukWd+3x4RtfhpqGk+JNPjS0g1mV7a8iT5UM4XesgHYsofdjglQepJPxwPE1x4V/au8LePtNkeK40ma0lmdDgyorvHMhPo9uxjP+y1bUcHRxmGbS1adn1TXT0/4fcipiqmExCi3pfVdGn19f+GLni/w7ceGf2wPFXga+Vo5rW/vDbI3WWI/v4HA/wBqBg3tk+lfWX7AXia1+F/iDV9B1CRbWHXjFLayyHannpuUxk+rqy4zxlMdWAPQft7fsL33x91nQfiD4DutP0r4oeDXVrT7cWWx1y3UsTZ3LKCyAh5FEigkLLIpHzBk5vwj4JuvE2kLJfeHdY8N6lGAl5pepwBZrOT+JRIuYp0ByBNCzxPg4bIICqYyljMKot62Sa6prr6P/gBDC1MLiHJLS90+jT6ev/Dnmn/BVP8Aaw0nxv4/8P8Aw18KXK69qmk3MlxqEdiRMwuivlpbrtPLopkMnZNy5IIYLyPwa/Z8vvEmv+HtHu4/Ovr+5iS6KDcqAtukwe6om7nuEJxX0XoH7PK/bJG0vRoY5rr/AFslvbLGZf8AfcAf+PGvafgv8CbX4byNqFyI5tWmXYCoytsh6qvqx7t+A4yWiWYUsLhlRpbr72318kVHA1MTiHVqbP7kl0P/2Q==
  9. // @homepage https://github.com/xFeny/UserScript/tree/main/monkey-jsonviewer
  10. // @match *://*/*
  11. // @require https://unpkg.com/jsmind@0.8.7/es6/jsmind.js
  12. // @require data:application/javascript,%3Bwindow.jsmind%3DjsMind%3B
  13. // @require https://unpkg.com/dom-to-image@2.6.0/src/dom-to-image.js
  14. // @require data:application/javascript,%3Bwindow.domtoimage%3Ddomtoimage%3B
  15. // @require https://unpkg.com/beautifier@0.1.7
  16. // @require data:application/javascript,%3Bwindow.beautifier%3Djs_beautify%3Bwindow.js_beautify%3Djs_beautify%3Bwindow.css_beautify%3Dcss_beautify%3B
  17. // @require https://unpkg.com/@highlightjs/cdn-assets@11.10.0/highlight.min.js
  18. // @require data:application/javascript,%3Bwindow.hljs%3Dhljs%3B
  19. // @grant GM_addStyle
  20. // @grant GM_getValue
  21. // @grant GM_openInTab
  22. // @grant GM_registerMenuCommand
  23. // @grant GM_setClipboard
  24. // @grant GM_setValue
  25. // @grant unsafeWindow
  26. // ==/UserScript==
  27.  
  28. (o=>{window.addEventListener("message",r=>{const{data:t}=r;if(!t?.addStyle)return;if(typeof GM_addStyle=="function")return GM_addStyle(o);const e=document.createElement("style");e.textContent=o,document.head.append(e)})})(` @charset "UTF-8";body,iframe,ul{margin:0;padding:0}iframe{border:0}input:focus,select:focus,textarea:focus{outline:0}.jsonp{color:#657b83}#jsoncrackEmbed{border:0;width:100%;height:100%}.tippy-box[data-theme~=layer]{color:#fff;padding:5px;font-size:12px;line-height:20px;background-color:#2e59a7}.tippy-box[data-theme~=layer] .tippy-arrow{color:#2e59a7}.tippy-box[data-theme~=imagebox]{background-color:#d9d9d9}.tippy-box[data-theme~=imagebox] .tippy-arrow{color:#d9d9d9}@media screen and (max-width: 640px){.rightbox{right:0!important}.rightbox .tools{display:none!important}}@media screen and (max-width: 400px){.searchbox{display:none!important}}.json-viewer-layout{top:0;left:0;z-index:10;width:100vw;height:100vh;display:flex;position:fixed;flex-direction:column}.json-viewer-layout .panel{display:flex;line-height:28px;user-select:none;flex-direction:column;background-color:#ececec}.json-viewer-layout .tabs,.json-viewer-layout .toolbar{display:flex;border-bottom:1px solid #ccc}.json-viewer-layout .tabs>div,.json-viewer-layout .toolbar>div{cursor:pointer;padding:0 10px;font-size:12px;transition:background-color .2s ease}.json-viewer-layout .tabs>div:hover,.json-viewer-layout .toolbar>div:hover{background-color:#d4d4d4}.json-viewer-layout .tabs-item{border-top:3px solid #ececec}.json-viewer-layout .tabs-item:hover{border-top-color:#c3c3c6}.json-viewer-layout .tabs-item.active{color:#0060df;border-top-color:#0060df;background-color:#f1f1f1}.json-viewer-layout .toolbar{line-height:23px}.json-viewer-layout .toolbar .searchbox{padding:0;display:flex;flex-grow:1}.json-viewer-layout .toolbar .searchbox:hover{background-color:transparent}.json-viewer-layout .toolbar .searchbox input{flex-grow:1;border:none;outline:none;font-size:12px;padding-left:23px;border-left:1.5px solid #ccc;background-size:14px;background-repeat:no-repeat;background-position:7px center;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAipJREFUWEftljuIE1EUhv8zpJB0FqugItiIdmKnnQ+wjPhq3EILRYt1JTDnDvhgUJG55zY+ELO7hRZupYWCCIK6nXYiNoqlrIUKaxes5siFBGKYSSbJTnaLTDMwl/Ofj8Pc/z+ENX5ojftjfQFYay8AuEFEU2VMRlV/A7hujGm09f+bgIj8APCtjOYdmjuZeWsewCMAZwBcYub7qwkiIjMA7gF4zMxnMwHiOK5Wq9UXAA6r6kljzLPVgLDWniCipwDeNJvNWhzHzUwA/zFJku1BEHiIPUS0PwzDD6NAOOf2qep7AJ/SNK1FUfS9Uy/zFojIXgAeYhsRbQ7D8NcwEM65Tar6E8AygBozf+zWyb2GSZIcCYLgORH9DcNw45AAf1R1Q5qmR6Moep2l0dMHrLWniegJgK/MvHsQCBH5AmCXqk4bYxbzavsakYjMArgD4B0zHyoCISJvARwEcJmZ7/aq6Qvgi0XkJoCrqrpgjDnfS9BaO09E5wDcYuZr/YALAbQgHgLwTpnrER13vcHMF/s19+eFAVoQS/7NzAeyxJ1zS6qaez7wT9hdICITgMkEJhOYTMCq6jEimmXmV90+UboRtdzQ7wZ+aW1UKpUr9Xp9pQ0yFoCuXFhW1agdt2MD8BDOOb83zgPYAWAxCILbqvqg1CzIChMRmQPgI3qFiD773Z+ZTxVJwoHTME9URI4TUV1VtwCYYeaXYwUo2mzkOB6l0dA7YRlNOzX/ATTlNjBwsoHnAAAAAElFTkSuQmCC)}.json-viewer-layout .toolbar .searchbox .clear{flex:0 0 auto;align-self:center;margin:0 4px;padding:0;border:0;width:16px;height:16px;background-color:transparent;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAANZJREFUOE+t0zFKg0EQhuEndbpgIVZ26eIJFK1SeQcPYKuWmlJIb6lHkJRpFFKnE2zTpBAknaUgA/+Q5SfBwGaaZWfne3dmdraj0job9Ae4wwAn+MUcn3jCotS0Aad4RW9LYj+4xkuel4ArPO9Y0RlmEZuAY3ygi/cGct6Clf4V+vhOwCNuG0EEXuAB941v1OzfkOAxbhIwwWVxYwoCEhZrCQzfFMMELHHUSjkhCchsMuwLh3sDVJfwXxOj/ihpaxOrnzEaUzVI2dmqUU5I1Wfa8Susw/4A1fw8ES1B6icAAAAASUVORK5CYII=)}.json-viewer-layout .rightbox{right:200px;display:flex;font-size:12px;position:absolute}.json-viewer-layout .rightbox>div{padding:0 5px;margin-top:2px}.json-viewer-layout .rightbox>div span{cursor:pointer;display:inline;padding:5px 10px;border-radius:3px;transition:background-color .2s ease}.json-viewer-layout .rightbox>div span:hover{background-color:#ccc}.json-viewer-layout .rightbox>div span:after{content:"";width:0;height:0;right:-5px;position:relative;border-style:solid;display:inline-block;vertical-align:middle;border-width:7px 5px 0 5px;border-color:#999 transparent transparent transparent;transform:rotate(0);transition:transform .3s ease}.json-viewer-layout .rightbox>div span.active:after{transform:rotate(180deg)}.json-viewer-layout .rightbox>div ul{color:#333;cursor:pointer;text-align:center;border-radius:3px}.json-viewer-layout .rightbox>div ul li{font-size:12px;padding:5px 20px;list-style-type:none;background-color:#dfdfdf;transition:background-color .2s ease}.json-viewer-layout .rightbox>div ul li:hover{border-radius:3px;background-color:#ccc}.json-viewer-layout .rightbox>div ul li.active:before{left:15px;content:"\u221A";display:inline;position:absolute}.json-viewer-layout .rightbox>div .tippy-box{background-color:#dfdfdf!important}.json-viewer-layout .rightbox>div .tippy-box .tippy-content{padding:5px}.json-viewer-layout .rightbox>div .tippy-box .tippy-arrow{color:#dfdfdf!important}.json-viewer-layout .container{flex-grow:1;overflow:auto;line-height:1.4;font-size:13.5px;font-family:monospace}.json-viewer-layout .container>div{display:none}.json-viewer-layout .container>div.active{display:block}.json-viewer-layout .container #formatBox{padding:5px 0 8px 8px}.json-viewer-layout .container #rawTextBox{font-size:13px;padding:5px 8px}.json-viewer-layout .container #rawTextBox pre{margin:0;padding:0;white-space:pre-wrap;overflow-wrap:break-word}.json-viewer-layout #mindBox{width:100vw;height:calc(100vh - 57px)}.json-viewer-layout #mindBox jmnode{display:flex;align-items:center;padding:0 7px 0 22px;color:#475872!important;box-shadow:none!important;background-color:transparent!important}.json-viewer-layout #mindBox jmnode.root{padding:0;color:transparent!important}.json-viewer-layout #mindBox jmnode:before{content:"";margin-top:1px;position:absolute;border-radius:50%;top:50%!important;transform:translateY(-50%);background-color:#8149bf80}.json-viewer-layout #mindBox jmnode.root:before{left:50%;width:18px;height:18px;transform:translate(-18px,-50%)}.json-viewer-layout #mindBox jmnode:hover{text-shadow:0px 0px 1px currentColor}.json-viewer-layout #mindBox jmnode:not(.root):before{left:0;width:15px;height:15px}.json-viewer-layout #mindBox jmexpander{margin-top:1px;line-height:9px}.json-viewer-layout #mindBox .datatype{opacity:.6;font-size:12px;margin-top:2px;padding-left:5px}.httpRequest{padding:30px 20px;width:700px}.httpRequest>div{display:flex;height:35px;margin-bottom:20px}.httpRequest input,.httpRequest select{border-radius:0;padding-left:10px;border:1px solid #ccc}.httpRequest input{flex-grow:1}.httpRequest input[name=url],.httpRequest input:first-child,.httpRequest select{border-right:none}.httpRequest button{cursor:pointer;padding:0 15px;border:1px solid #ccc}.httpRequest button:active{background-color:#cfcfcf}.dark-theme .json-viewer-layout li,.dark-theme .json-viewer-layout pre,.dark-theme .json-viewer-layout td:first-child,.dark-plus-theme .json-viewer-layout li,.dark-plus-theme .json-viewer-layout pre,.dark-plus-theme .json-viewer-layout td:first-child{color:#ccc}.dark-theme .json-viewer-layout .panel,.dark-plus-theme .json-viewer-layout .panel{color:#c4c4c4;background-color:#333}.dark-theme .json-viewer-layout .panel>div,.dark-plus-theme .json-viewer-layout .panel>div{border-bottom-color:#464646}.dark-theme .json-viewer-layout .panel .tabs-item:hover,.dark-theme .json-viewer-layout .panel .toolbar-item:hover,.dark-plus-theme .json-viewer-layout .panel .tabs-item:hover,.dark-plus-theme .json-viewer-layout .panel .toolbar-item:hover{background-color:#464646}.dark-theme .json-viewer-layout .panel .tabs-item,.dark-plus-theme .json-viewer-layout .panel .tabs-item{border-top-color:#333}.dark-theme .json-viewer-layout .panel .tabs-item:hover,.dark-plus-theme .json-viewer-layout .panel .tabs-item:hover{border-top-color:#c3c3c6}.dark-theme .json-viewer-layout .panel .tabs-item.active,.dark-plus-theme .json-viewer-layout .panel .tabs-item.active{color:#c4c4c4;border-top-color:#64b7ff;background-color:#464646}.dark-theme .json-viewer-layout .searchbox input,.dark-plus-theme .json-viewer-layout .searchbox input{color:#ccc;background-color:#464646;border-left-color:#333}.dark-theme .json-viewer-layout .searchbox .clear,.dark-plus-theme .json-viewer-layout .searchbox .clear{filter:invert(.8)}.dark-theme .json-viewer-layout .rightbox>div span:hover,.dark-plus-theme .json-viewer-layout .rightbox>div span:hover{background-color:#464646}.dark-theme .json-viewer-layout .rightbox .tippy-box,.dark-plus-theme .json-viewer-layout .rightbox .tippy-box{background-color:#4e4e4e!important}.dark-theme .json-viewer-layout .rightbox .tippy-box .tippy-arrow,.dark-plus-theme .json-viewer-layout .rightbox .tippy-box .tippy-arrow{color:#4e4e4e!important}.dark-theme .json-viewer-layout .rightbox .tippy-box li,.dark-plus-theme .json-viewer-layout .rightbox .tippy-box li{background-color:#4e4e4e!important}.dark-theme .json-viewer-layout .rightbox .tippy-box li:hover,.dark-plus-theme .json-viewer-layout .rightbox .tippy-box li:hover{background-color:#464646!important}.dark-theme .json-viewer-layout jmnode,.dark-plus-theme .json-viewer-layout jmnode{filter:brightness(2)}.dark-theme .json-viewer-layout jmexpander,.dark-plus-theme .json-viewer-layout jmexpander{background-color:#dfdfdf}.js-mind-child-node{width:300px;height:300px;margin:10px;overflow-y:scroll;position:relative;padding:5px 20px;background-color:#f8f9fa}.js-mind-child-node div{color:#475872;line-height:25px}.js-mind-copy{top:5px;right:10px;width:20px;height:20px;cursor:pointer;position:absolute;background-size:20px;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAYRJREFUWEftlzFOw0AQRefbF+EMVJFA1kzcUNGRW8ABkFBASBQgUZAiLSUiHb29W1DTQUFFzxFQvGglO8JW1uuElQIGl8545/n/0eQbtOELG+5PNYA8z28AHIaAMsZMhsPhke+sBYDW+mE+nz9FUaR9D3X5vSgKjuN4m5n32+oXAEopQ0QiIkEAlFJMREpEWm3uP0BD/ndjzAzArFLaq0Appdf2pnWVBdbWLw9vEdEYwJSZL+39VoA8z3cAPHq7Ez3HcTxKkuSlqnXNQJZlp1EU7YnIwAvQobGzxAXQvO+1YF2I/gBYz7qokKZprS6YAhsH6PL2y2qCKfC3AbTWB8aY+y4qABgx88y3iFbeA99dxc1/w5UBurz9/xD2Q4EqEzZX6rozYDfoskzYNoS7RHRORDbLhbhstjwRkVqecAI4fFREdBYqqNoevw7gCsAHMx+H8MSe4YxkDgsGAC6KorgD8BoAogql18w8qWVC1+GlZ+NAw/lWztRt1e9nfZwGkHjlIz4Bw1VmMCtaHCkAAAAASUVORK5CYII=)}.tippy-box[data-animation=fade][data-state=hidden]{opacity:0}[data-tippy-root]{max-width:calc(100vw - 10px)}.tippy-box{position:relative;background-color:#333;color:#fff;border-radius:4px;font-size:14px;line-height:1.4;white-space:normal;outline:0;transition-property:transform,visibility,opacity}.tippy-box[data-placement^=top]>.tippy-arrow{bottom:0}.tippy-box[data-placement^=top]>.tippy-arrow:before{bottom:-7px;left:0;border-width:8px 8px 0;border-top-color:initial;transform-origin:center top}.tippy-box[data-placement^=bottom]>.tippy-arrow{top:0}.tippy-box[data-placement^=bottom]>.tippy-arrow:before{top:-7px;left:0;border-width:0 8px 8px;border-bottom-color:initial;transform-origin:center bottom}.tippy-box[data-placement^=left]>.tippy-arrow{right:0}.tippy-box[data-placement^=left]>.tippy-arrow:before{border-width:8px 0 8px 8px;border-left-color:initial;right:-7px;transform-origin:center left}.tippy-box[data-placement^=right]>.tippy-arrow{left:0}.tippy-box[data-placement^=right]>.tippy-arrow:before{left:-7px;border-width:8px 8px 8px 0;border-right-color:initial;transform-origin:center right}.tippy-box[data-inertia][data-state=visible]{transition-timing-function:cubic-bezier(.54,1.5,.38,1.11)}.tippy-arrow{width:16px;height:16px;color:#333}.tippy-arrow:before{content:"";position:absolute;border-color:transparent;border-style:solid}.tippy-content{position:relative;padding:5px 9px;z-index:1}.monkey-js-css-beautify body{padding-top:20px;padding-left:5px}.monkey-js-css-beautify body .beautify_checkbox{top:0;left:0;z-index:999;width:100vw;display:flex;position:fixed;padding:5px 10px;user-select:none;align-items:center;background-color:#f3f3f3;border-bottom:1px solid #ccc}.monkey-js-css-beautify body .beautify_checkbox label{font-size:13px}.monkey-js-css-beautify body .beautify_checkbox input[type=checkbox]{top:1.5px;width:14px;height:14px;margin-right:5px;position:relative}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{background:#fff;color:#000}.xml .hljs-meta{color:silver}.hljs-comment,.hljs-quote{color:#007400}.hljs-attribute,.hljs-keyword,.hljs-literal,.hljs-name,.hljs-selector-tag,.hljs-tag{color:#aa0d91}.hljs-template-variable,.hljs-variable{color:#3f6e74}.hljs-code,.hljs-meta .hljs-string,.hljs-string{color:#c41a16}.hljs-link,.hljs-regexp{color:#0e0eff}.hljs-bullet,.hljs-number,.hljs-symbol,.hljs-title{color:#1c00cf}.hljs-meta,.hljs-section{color:#643820}.hljs-built_in,.hljs-class .hljs-title,.hljs-params,.hljs-title.class_,.hljs-type{color:#5c2699}.hljs-attr{color:#836c28}.hljs-subst{color:#000}.hljs-formula{background-color:#eee;font-style:italic}.hljs-addition{background-color:#baeeba}.hljs-deletion{background-color:#ffc8bd}.hljs-selector-class,.hljs-selector-id{color:#9b703f}.hljs-doctag,.hljs-strong{font-weight:700}.hljs-emphasis{font-style:italic}ul,li{list-style-type:none}wrapper{display:contents}.hidden{display:none!important}.json-viewer ul{border-left:.5px dotted #ccc}.json-viewer ul li{padding-left:20px}.json-bracket{font-weight:700}.json-copy{width:13px;height:13px;cursor:pointer;margin-left:.15em;display:inline-block;background-size:13px;vertical-align:text-bottom;background-repeat:no-repeat;transition:background-image ease .3s;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAYRJREFUWEftlzFOw0AQRefbF+EMVJFA1kzcUNGRW8ABkFBASBQgUZAiLSUiHb29W1DTQUFFzxFQvGglO8JW1uuElQIGl8545/n/0eQbtOELG+5PNYA8z28AHIaAMsZMhsPhke+sBYDW+mE+nz9FUaR9D3X5vSgKjuN4m5n32+oXAEopQ0QiIkEAlFJMREpEWm3uP0BD/ndjzAzArFLaq0Appdf2pnWVBdbWLw9vEdEYwJSZL+39VoA8z3cAPHq7Ez3HcTxKkuSlqnXNQJZlp1EU7YnIwAvQobGzxAXQvO+1YF2I/gBYz7qokKZprS6YAhsH6PL2y2qCKfC3AbTWB8aY+y4qABgx88y3iFbeA99dxc1/w5UBurz9/xD2Q4EqEzZX6rozYDfoskzYNoS7RHRORDbLhbhstjwRkVqecAI4fFREdBYqqNoevw7gCsAHMx+H8MSe4YxkDgsGAC6KorgD8BoAogql18w8qWVC1+GlZ+NAw/lWztRt1e9nfZwGkHjlIz4Bw1VmMCtaHCkAAAAASUVORK5CYII=)}.json-copy.success{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAhZJREFUWEftlU1IFGEYx//Pu2R0kLrYwUMg7M5EHjwklNUOLoInxYMg7W6HTkEIgkLMLF6CsllDokN4Vfy4SnSqk+7sRghBFBT7IWKHQATFSxCLM09sabjjO/thLnuZ9zjPx//3/t9n3pfQ5EVN1ocP4DvgO9AwB/RMsJNYjAF4wEwz01rukeyXbwjAZEbttpmXAKhHokQ8bN4prLghzhwgkVHCzLQE8JUyMeblpFa411AAIxXshxCLAC6fFOKbZriw3jAA3VKHiLgk3uoS+UWMqKnlX9c8AwkreA0i0GM7vFu0i2svI1v7ld4M3VLuEmEBwLnjeQTsMyiaDOfeetVLZ8BIhz4CdP2w6CuxM2JqG99kTYz3oftwaE4S23Zsij3vza1Wgj8BYKSDvYBwF0khdEt9SMSzEoHvJETUvJ39UO219XBA2QHQ5iougzAsZRyEFxKBHAJONHlr41M18VLc6wgmAXoqafAHgoUYAuOZJP6Z2Il5HVfNQ1hK1NPKKAGvZBAAOiXf1wGOJcOFzVp2/u+CqpRsZNQ4/t5oVRalAkWOT/Xlf1TLrPseSKRDAw7TIhEuyS3kd2gJxM0b2d16xT1nwN1IT4U0IWiegY6yGPObg4sXYjNdX36eRrxmgMOZ6CLQE4AHGdgTjOXzdvvE48jawWnF6wI4EkmsKlfNSD77P6LHa8/8NawXzAfwHfAdaLoDvwHyYK0h/tY7mwAAAABJRU5ErkJggg==)}.json-arrow{width:0;opacity:.2;display:inline-block}.json-arrow:hover{opacity:.35}.json-arrow:before{width:0;height:0;left:-13px;content:"";cursor:pointer;position:relative;border-style:solid;display:inline-block;vertical-align:middle;transform:rotate(90deg);border-width:5px 0 5px 8px;transition:transform .3s ease;border-color:transparent transparent transparent currentColor}.collapsed .json-arrow:before{transform:rotate(0)}.json-desc{display:none;cursor:pointer;font-size:12px;font-weight:700;color:#9aa160;user-select:none;margin-left:.3em}.json-desc span{margin:0 .5em;font-weight:400}.json-desc span:hover{text-decoration:underline}.json-color{width:.7em;height:.7em;margin-right:.3em;display:inline-block;vertical-align:middle;border:1px solid #ccc}.json-comma{margin-left:.15em;font-family:Courier New,monospace}.json-colon{margin:0 .3em 0 .15em}.default-theme{background-color:#fefefe}.default-theme .json-bracket[type=object]{color:#6d9331}.default-theme .json-bracket[type=array]{color:#8e9331}.default-theme .json-key{color:#910f93;cursor:pointer}.default-theme .json-string,.default-theme .json-string a{color:#2e7c16}.default-theme .json-bigint,.default-theme .json-number{color:#164ff1}.default-theme .json-boolean{color:#c41a16}.default-theme .json-null{color:#228fec}.light-theme{background-color:#fefefe}.light-theme .json-bracket[type=object]{color:#6d9331}.light-theme .json-bracket[type=array]{color:#8e9331}.light-theme .json-key{color:#0040cf;cursor:pointer}.light-theme .json-string,.light-theme .json-string a{color:#a31515}.light-theme .json-bigint,.light-theme .json-number{color:#0b7500}.light-theme .json-boolean{color:#00f}.light-theme .json-null{color:#05f}.dark-theme{background-color:#252526}.dark-theme .json-bracket[type=object]{color:#9bba43}.dark-theme .json-bracket[type=array]{color:#c4af00}.dark-theme .json-key{color:#9cdcfe;cursor:pointer}.dark-theme .json-string,.dark-theme .json-string a{color:#ce9178}.dark-theme .json-bigint,.dark-theme .json-number{color:#b5cea8}.dark-theme .json-boolean{color:#358cd6}.dark-theme .json-null{color:#569cd6}.dark-plus-theme{background-color:#1e1f22}.dark-plus-theme .json-bracket[type=object]{color:#bb9667}.dark-plus-theme .json-bracket[type=array]{color:#a1a84e}.dark-plus-theme .json-key{color:#c77dbb;cursor:pointer}.dark-plus-theme .json-string,.dark-plus-theme .json-string a{color:#6aab73}.dark-plus-theme .json-bigint,.dark-plus-theme .json-number{color:#28aab4}.dark-plus-theme .json-boolean{color:#ce8951}.dark-plus-theme .json-null{color:#c78d61}.dark-theme .json-viewer ul,.dark-plus-theme .json-viewer ul{border-left:.5px dotted #5e5e5e}.dark-theme .json-colon,.dark-theme .json-comma,.dark-plus-theme .json-colon,.dark-plus-theme .json-comma{color:#ccc}.dark-theme .json-arrow,.dark-plus-theme .json-arrow{color:#fff;opacity:.35}.dark-theme .json-arrow:hover,.dark-plus-theme .json-arrow:hover{opacity:.5}.json-tree-table{border-collapse:collapse;width:-webkit-fill-available}.json-tree-table tr.selected *{color:#fff!important;background-color:#3875d7}.json-tree-table tr:hover{background-color:#f0f9fe}.json-tree-table tr td:first-child{width:120px}.dark-theme .json-tree-table tr:hover,.dark-plus-theme .json-tree-table tr:hover{background-color:#353b48}.scroll-top{right:15px;width:45px;height:45px;z-index:999;bottom:30px;display:none;font-size:12px;cursor:pointer;position:fixed;border-radius:50%;background-size:30px;background-color:#fff;background-position:center;background-repeat:no-repeat;box-shadow:0 0 5px #3eaf7c4d;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHN0eWxlPSJmaWxsOiMzZWFmN2MiIGNsYXNzPSJpY29uIGJhY2stdG8tdG9wLWljb24iIHZpZXdCb3g9IjAgMCAxMDI0IDEwMjQiIGZpbGw9ImN1cnJlbnRDb2xvciIgYXJpYS1sYWJlbD0iYmFjay10by10b3AgaWNvbiI+PHBhdGggZD0iTTUxMiA4NDMuMmMtMzYuMiAwLTY2LjQtMTMuNi04NS44LTIxLjgtMTAuOC00LjYtMjIuNiAzLjYtMjEuOCAxNS4ybDcgMTAyYy40IDYuMiA3LjYgOS40IDEyLjYgNS42bDI5LTIyYzMuNi0yLjggOS0xLjggMTEuNCAybDQxIDY0LjJjMyA0LjggMTAuMiA0LjggMTMuMiAwbDQxLTY0LjJjMi40LTMuOCA3LjgtNC44IDExLjQtMmwyOSAyMmM1IDMuOCAxMi4yLjYgMTIuNi01LjZsNy0xMDJjLjgtMTEuNi0xMS0yMC0yMS44LTE1LjItMTkuNiA4LjItNDkuNiAyMS44LTg1LjggMjEuOHoiPjwvcGF0aD48cGF0aCBkPSJtNzk1LjQgNTg2LjItOTYtOTguMkM2OTkuNCAxNzIgNTEzIDMyIDUxMyAzMlMzMjQuOCAxNzIgMzI0LjggNDg4bC05NiA5OC4yYy0zLjYgMy42LTUuMiA5LTQuNCAxNC4yTDI2MS4yIDgyNGMxLjggMTEuNCAxNC4yIDE3IDIzLjYgMTAuOEw0MTkgNzQ0czQxLjQgNDAgOTQuMiA0MGM1Mi44IDAgOTIuMi00MCA5Mi4yLTQwbDEzNC4yIDkwLjhjOS4yIDYuMiAyMS42LjYgMjMuNi0xMC44bDM3LTIyMy44Yy40LTUuMi0xLjItMTAuNC00LjgtMTR6TTUxMyAzODRjLTM0IDAtNjEuNC0yOC42LTYxLjQtNjRzMjcuNi02NCA2MS40LTY0YzM0IDAgNjEuNCAyOC42IDYxLjQgNjRTNTQ3IDM4NCA1MTMgMzg0eiI+PC9wYXRoPjwvc3ZnPg==)}.scroll-top:hover{background-color:#f9f9f9}.dark-theme .scroll-top,.dark-plus-theme .scroll-top{background-color:#464646;box-shadow:0 0 5px #505050}.tippy-box[data-theme~=scroll]{font-size:12px}/**
  29. * @license BSD
  30. * @copyright 2014-2025 hizzgdev@163.com
  31. *
  32. * Project Home:
  33. * https://github.com/hizzgdev/jsmind/
  34. */.jsmind-inner{position:relative;overflow:auto;width:100%;height:100%;outline:none}.jsmind-inner{moz-user-select:-moz-none;-moz-user-select:none;-o-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.jsmind-inner canvas{position:absolute}svg.jsmind{position:absolute;z-index:1}canvas.jsmind{position:absolute;z-index:1}jmnodes{position:absolute;z-index:2;background-color:#0000}jmnode{position:absolute;cursor:default;max-width:400px}jmexpander{position:absolute;width:11px;height:11px;display:block;overflow:hidden;line-height:12px;font-size:10px;text-align:center;border-radius:6px;border-width:1px;border-style:solid;cursor:pointer}.jmnode-overflow-wrap jmnodes{min-width:420px}.jmnode-overflow-hidden jmnode{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}jmnode{padding:10px;background-color:#fff;color:#333;border-radius:5px;box-shadow:1px 1px 1px #666;font:16px/1.125 Verdana,Arial,Helvetica,sans-serif}jmnode:hover{box-shadow:2px 2px 8px #000;background-color:#ebebeb;color:#333}jmnode.selected{background-color:#11f;color:#fff;box-shadow:2px 2px 8px #000}jmnode.root{font-size:24px}jmexpander{border-color:gray}jmexpander:hover{border-color:#000}@media screen and (max-device-width: 1024px){jmnode{padding:5px;border-radius:3px;font-size:14px}jmnode.root{font-size:21px}}jmnodes.theme-primary jmnode{background-color:#428bca;color:#fff;border-color:#357ebd}jmnodes.theme-primary jmnode:hover{background-color:#3276b1;border-color:#285e8e}jmnodes.theme-primary jmnode.selected{background-color:#f1c40f;color:#fff}jmnodes.theme-warning jmnode{background-color:#f0ad4e;border-color:#eea236;color:#fff}jmnodes.theme-warning jmnode:hover{background-color:#ed9c28;border-color:#d58512}jmnodes.theme-warning jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-danger jmnode{background-color:#d9534f;border-color:#d43f3a;color:#fff}jmnodes.theme-danger jmnode:hover{background-color:#d2322d;border-color:#ac2925}jmnodes.theme-danger jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-success jmnode{background-color:#5cb85c;border-color:#4cae4c;color:#fff}jmnodes.theme-success jmnode:hover{background-color:#47a447;border-color:#398439}jmnodes.theme-success jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-info jmnode{background-color:#5dc0de;border-color:#46b8da;color:#fff}jmnodes.theme-info jmnode:hover{background-color:#39b3d7;border-color:#269abc}jmnodes.theme-info jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-greensea jmnode{background-color:#1abc9c;color:#fff}jmnodes.theme-greensea jmnode:hover{background-color:#16a085}jmnodes.theme-greensea jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-nephrite jmnode{background-color:#2ecc71;color:#fff}jmnodes.theme-nephrite jmnode:hover{background-color:#27ae60}jmnodes.theme-nephrite jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-belizehole jmnode{background-color:#3498db;color:#fff}jmnodes.theme-belizehole jmnode:hover{background-color:#2980b9}jmnodes.theme-belizehole jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-wisteria jmnode{background-color:#9b59b6;color:#fff}jmnodes.theme-wisteria jmnode:hover{background-color:#8e44ad}jmnodes.theme-wisteria jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-asphalt jmnode{background-color:#34495e;color:#fff}jmnodes.theme-asphalt jmnode:hover{background-color:#2c3e50}jmnodes.theme-asphalt jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-orange jmnode{background-color:#f1c40f;color:#fff}jmnodes.theme-orange jmnode:hover{background-color:#f39c12}jmnodes.theme-orange jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-pumpkin jmnode{background-color:#e67e22;color:#fff}jmnodes.theme-pumpkin jmnode:hover{background-color:#d35400}jmnodes.theme-pumpkin jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-pomegranate jmnode{background-color:#e74c3c;color:#fff}jmnodes.theme-pomegranate jmnode:hover{background-color:#c0392b}jmnodes.theme-pomegranate jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-clouds jmnode{background-color:#ecf0f1;color:#333}jmnodes.theme-clouds jmnode:hover{background-color:#bdc3c7}jmnodes.theme-clouds jmnode.selected{background-color:#11f;color:#fff}jmnodes.theme-asbestos jmnode{background-color:#95a5a6;color:#fff}jmnodes.theme-asbestos jmnode:hover{background-color:#7f8c8d}jmnodes.theme-asbestos jmnode.selected{background-color:#11f;color:#fff} `);
  35.  
  36. !function(){function e(e,t){return(t||"")+" (SystemJS Error#"+e+" https://github.com/systemjs/systemjs/blob/main/docs/errors.md#"+e+")"}function t(e,t){if(-1!==e.indexOf("\\")&&(e=e.replace(j,"/")),"/"===e[0]&&"/"===e[1])return t.slice(0,t.indexOf(":")+1)+e;if("."===e[0]&&("/"===e[1]||"."===e[1]&&("/"===e[2]||2===e.length&&(e+="/"))||1===e.length&&(e+="/"))||"/"===e[0]){var n,r=t.slice(0,t.indexOf(":")+1);if(n="/"===t[r.length+1]?"file:"!==r?(n=t.slice(r.length+2)).slice(n.indexOf("/")+1):t.slice(8):t.slice(r.length+("/"===t[r.length])),"/"===e[0])return t.slice(0,t.length-n.length-1)+e;for(var i=n.slice(0,n.lastIndexOf("/")+1)+e,o=[],s=-1,u=0;u<i.length;u++)-1!==s?"/"===i[u]&&(o.push(i.slice(s,u+1)),s=-1):"."===i[u]?"."!==i[u+1]||"/"!==i[u+2]&&u+2!==i.length?"/"===i[u+1]||u+1===i.length?u+=1:s=u:(o.pop(),u+=2):s=u;return-1!==s&&o.push(i.slice(s)),t.slice(0,t.length-n.length)+o.join("")}}function n(e,n){return t(e,n)||(-1!==e.indexOf(":")?e:t("./"+e,n))}function r(e,n,r,i,o){for(var s in e){var a=t(s,r)||s,f=e[s];if("string"==typeof f){var l=c(i,t(f,r)||f,o);l?n[a]=l:u("W1",s,f,"bare specifier did not resolve")}}}function i(e,t,i){var o;for(o in e.imports&&r(e.imports,i.imports,t,i,null),e.scopes||{}){var s=n(o,t);r(e.scopes[o],i.scopes[s]||(i.scopes[s]={}),t,i,s)}for(o in e.depcache||{})i.depcache[n(o,t)]=e.depcache[o];for(o in e.integrity||{})i.integrity[n(o,t)]=e.integrity[o]}function o(e,t){if(t[e])return e;var n=e.length;do{var r=e.slice(0,n+1);if(r in t)return r}while(-1!==(n=e.lastIndexOf("/",n-1)))}function s(e,t){var n=o(e,t);if(n){var r=t[n];if(null===r)return;if(!(e.length>n.length&&"/"!==r[r.length-1]))return r+e.slice(n.length);u("W2",n,r,"should have a trailing '/'")}}function u(t,n,r,i){console.warn(e(t,"Package target "+i+", resolving target '"+r+"' for "+n))}function c(e,t,n){for(var r=e.scopes,i=n&&o(n,r);i;){var u=s(t,r[i]);if(u)return u;i=o(i.slice(0,i.lastIndexOf("/")),r)}return s(t,e.imports)||-1!==t.indexOf(":")&&t}function a(){this[M]={}}function f(e){return e.id}function l(e,t,n,r){if(e.onload(n,t.id,t.d&&t.d.map(f),!!r),n)throw n}function d(t,n,r,i){var o=t[M][n];if(o)return o;var s=[],u=Object.create(null);P&&Object.defineProperty(u,P,{value:"Module"});var c=Promise.resolve().then((function(){return t.instantiate(n,r,i)})).then((function(r){if(!r)throw Error(e(2,"Module "+n+" did not instantiate"));var i=r[1]((function(e,t){o.h=!0;var n=!1;if("string"==typeof e)e in u&&u[e]===t||(u[e]=t,n=!0);else{for(var r in e)t=e[r],r in u&&u[r]===t||(u[r]=t,n=!0);e&&e.__esModule&&(u.__esModule=e.__esModule)}if(n)for(var i=0;i<s.length;i++){var c=s[i];c&&c(u)}return t}),2===r[1].length?{import:function(e,r){return t.import(e,n,r)},meta:t.createContext(n)}:void 0);return o.e=i.execute||function(){},[r[0],i.setters||[],r[2]||[]]}),(function(e){throw o.e=null,o.er=e,l(t,o,e,!0),e})),a=c.then((function(e){return Promise.all(e[0].map((function(r,i){var o=e[1][i],s=e[2][i];return Promise.resolve(t.resolve(r,n)).then((function(e){var r=d(t,e,n,s);return Promise.resolve(r.I).then((function(){return o&&(r.i.push(o),!r.h&&r.I||o(r.n)),r}))}))}))).then((function(e){o.d=e}))}));return o=t[M][n]={id:n,i:s,n:u,m:i,I:c,L:a,h:!1,d:void 0,e:void 0,er:void 0,E:void 0,C:void 0,p:void 0}}function h(e,t,n,r){if(!r[t.id])return r[t.id]=!0,Promise.resolve(t.L).then((function(){return t.p&&null!==t.p.e||(t.p=n),Promise.all(t.d.map((function(t){return h(e,t,n,r)})))})).catch((function(n){if(t.er)throw n;throw t.e=null,l(e,t,n,!1),n}))}function p(e,t){return t.C=h(e,t,t,{}).then((function(){return v(e,t,{})})).then((function(){return t.n}))}function v(e,t,n){function r(){try{var n=o.call(L);if(n)return n=n.then((function(){t.C=t.n,t.E=null,l(e,t,null,!0)}),(function(n){throw t.er=n,t.E=null,l(e,t,n,!0),n})),t.E=n;t.C=t.n,t.L=t.I=void 0}catch(r){throw t.er=r,r}finally{l(e,t,t.er,!0)}}if(!n[t.id]){if(n[t.id]=!0,!t.e){if(t.er)throw t.er;return t.E?t.E:void 0}var i,o=t.e;return t.e=null,t.d.forEach((function(r){try{var o=v(e,r,n);o&&(i=i||[]).push(o)}catch(s){throw t.er=s,l(e,t,s,!1),s}})),i?Promise.all(i).then(r):r()}}function m(){[].forEach.call(document.querySelectorAll("script"),(function(t){if(!t.sp)if("systemjs-module"===t.type){if(t.sp=!0,!t.src)return;System.import("import:"===t.src.slice(0,7)?t.src.slice(7):n(t.src,g)).catch((function(e){if(e.message.indexOf("https://github.com/systemjs/systemjs/blob/main/docs/errors.md#3")>-1){var n=document.createEvent("Event");n.initEvent("error",!1,!1),t.dispatchEvent(n)}return Promise.reject(e)}))}else if("systemjs-importmap"===t.type){t.sp=!0;var r=t.src?(System.fetch||fetch)(t.src,{integrity:t.integrity,priority:t.fetchPriority,passThrough:!0}).then((function(e){if(!e.ok)throw Error("Invalid status code: "+e.status);return e.text()})).catch((function(n){return n.message=e("W4","Error fetching systemjs-import map "+t.src)+"\n"+n.message,console.warn(n),"function"==typeof t.onerror&&t.onerror(),"{}"})):t.innerHTML;W=W.then((function(){return r})).then((function(n){!function(t,n,r){var o={};try{o=JSON.parse(n)}catch(s){console.warn(Error(e("W5","systemjs-importmap contains invalid JSON")+"\n\n"+n+"\n"))}i(o,r,t)}(N,n,t.src||g)}))}}))}var g,y="undefined"!=typeof Symbol,b="undefined"!=typeof self,S="undefined"!=typeof document,w=b?self:global;if(S){var O=document.querySelector("base[href]");O&&(g=O.href)}if(!g&&"undefined"!=typeof location){var E=(g=location.href.split("#")[0].split("?")[0]).lastIndexOf("/");-1!==E&&(g=g.slice(0,E+1))}var x,j=/\\/g,P=y&&Symbol.toStringTag,M=y?Symbol():"@",I=a.prototype;I.import=function(e,t,n){var r=this;return t&&"object"==typeof t&&(n=t,t=void 0),Promise.resolve(r.prepareImport()).then((function(){return r.resolve(e,t,n)})).then((function(e){var t=d(r,e,void 0,n);return t.C||p(r,t)}))},I.createContext=function(e){var t=this;return{url:e,resolve:function(n,r){return Promise.resolve(t.resolve(n,r||e))}}},I.onload=function(){},I.register=function(e,t,n){x=[e,t,n]},I.getRegister=function(){var e=x;return x=void 0,e};var L=Object.freeze(Object.create(null));w.System=new a;var C,R,W=Promise.resolve(),N={imports:{},scopes:{},depcache:{},integrity:{}},T=S;if(I.prepareImport=function(e){return(T||e)&&(m(),T=!1),W},I.getImportMap=function(){return JSON.parse(JSON.stringify(N))},S&&(m(),window.addEventListener("DOMContentLoaded",m)),I.addImportMap=function(e,t){i(e,t||g,N)},S){window.addEventListener("error",(function(e){J=e.filename,_=e.error}));var A=location.origin}I.createScript=function(e){var t=document.createElement("script");t.async=!0,e.indexOf(A+"/")&&(t.crossOrigin="anonymous");var n=N.integrity[e];return n&&(t.integrity=n),t.src=e,t};var J,_,k={},U=I.register;I.register=function(e,t){if(S&&"loading"===document.readyState&&"string"!=typeof e){var n=document.querySelectorAll("script[src]"),r=n[n.length-1];if(r){C=e;var i=this;R=setTimeout((function(){k[r.src]=[e,t],i.import(r.src)}))}}else C=void 0;return U.call(this,e,t)},I.instantiate=function(t,n){var r=k[t];if(r)return delete k[t],r;var i=this;return Promise.resolve(I.createScript(t)).then((function(r){return new Promise((function(o,s){r.addEventListener("error",(function(){s(Error(e(3,"Error loading "+t+(n?" from "+n:""))))})),r.addEventListener("load",(function(){if(document.head.removeChild(r),J===t)s(_);else{var e=i.getRegister(t);e&&e[0]===C&&clearTimeout(R),o(e)}})),document.head.appendChild(r)}))}))},I.shouldFetch=function(){return!1},"undefined"!=typeof fetch&&(I.fetch=fetch);var $=I.instantiate,B=/^(text|application)\/(x-)?javascript(;|$)/;I.instantiate=function(t,n,r){var i=this;return this.shouldFetch(t,n,r)?this.fetch(t,{credentials:"same-origin",integrity:N.integrity[t],meta:r}).then((function(r){if(!r.ok)throw Error(e(7,r.status+" "+r.statusText+", loading "+t+(n?" from "+n:"")));var o=r.headers.get("content-type");if(!o||!B.test(o))throw Error(e(4,'Unknown Content-Type "'+o+'", loading '+t+(n?" from "+n:"")));return r.text().then((function(e){return e.indexOf("//# sourceURL=")<0&&(e+="\n//# sourceURL="+t),(0,eval)(e),i.getRegister(t)}))})):$.apply(this,arguments)},I.resolve=function(n,r){return c(N,t(n,r=r||g)||n,r)||function(t,n){throw Error(e(8,"Unable to resolve bare specifier '"+t+(n?"' from "+n:"'")))}(n,r)};var F=I.instantiate;I.instantiate=function(e,t,n){var r=N.depcache[e];if(r)for(var i=0;i<r.length;i++)d(this,this.resolve(r[i],e),e);return F.call(this,e,t,n)},b&&"function"==typeof importScripts&&(I.instantiate=function(e){var t=this;return Promise.resolve().then((function(){return importScripts(e),t.getRegister(e)}))}),function(e){function t(t){return!e.hasOwnProperty(t)||!isNaN(t)&&t<e.length||a&&e[t]&&"undefined"!=typeof window&&e[t].parent===window}var n,r,i,o=e.System.constructor.prototype,s=o.import;o.import=function(o,u,c){return function(){for(var o in n=r=void 0,e)t(o)||(n?r||(r=o):n=o,i=o)}(),s.call(this,o,u,c)};var u=[[],function(){return{}}],c=o.getRegister;o.getRegister=function(){var o=c.call(this);if(o)return o;var s,a=function(o){var s,u,c=0;for(var a in e)if(!t(a)){if(0===c&&a!==n||1===c&&a!==r)return a;s?(i=a,u=o&&u||a):s=a===i,c++}return u}(this.firstGlobalProp);if(!a)return u;try{s=e[a]}catch(f){return u}return[[],function(e){return{execute:function(){e(s),e({default:s,__useDefault:!0})}}}]};var a="undefined"!=typeof navigator&&-1!==navigator.userAgent.indexOf("Trident")}("undefined"!=typeof self?self:global),function(e){var t=e.System.constructor.prototype,r=/^[^#?]+\.(css|html|json|wasm)([?#].*)?$/,i=t.shouldFetch.bind(t);t.shouldFetch=function(e){return i(e)||r.test(e)};var o=/^application\/json(;|$)/,s=/^text\/css(;|$)/,u=/^application\/wasm(;|$)/,c=t.fetch;t.fetch=function(t,r){return c(t,r).then((function(i){if(r.passThrough)return i;if(!i.ok)return i;var c=i.headers.get("content-type");return o.test(c)?i.json().then((function(e){return new Response(new Blob(['System.register([],function(e){return{execute:function(){e("default",'+JSON.stringify(e)+")}}})"],{type:"application/javascript"}))})):s.test(c)?i.text().then((function(e){return e=e.replace(/url\(\s*(?:(["'])((?:\\.|[^\n\\"'])+)\1|((?:\\.|[^\s,"'()\\])+))\s*\)/g,(function(e,r,i,o){return["url(",r,n(i||o,t),r,")"].join("")})),new Response(new Blob(["System.register([],function(e){return{execute:function(){var s=new CSSStyleSheet();s.replaceSync("+JSON.stringify(e)+');e("default",s)}}})'],{type:"application/javascript"}))})):u.test(c)?(WebAssembly.compileStreaming?WebAssembly.compileStreaming(i):i.arrayBuffer().then(WebAssembly.compile)).then((function(n){e.System.wasmModules||(e.System.wasmModules=Object.create(null)),e.System.wasmModules[t]=n;var r=[],i=[];return WebAssembly.Module.imports&&WebAssembly.Module.imports(n).forEach((function(e){var t=JSON.stringify(e.module);-1===r.indexOf(t)&&(r.push(t),i.push("function(m){i["+t+"]=m}"))})),new Response(new Blob(["System.register(["+r.join(",")+"],function(e){var i={};return{setters:["+i.join(",")+"],execute:function(){return WebAssembly.instantiate(System.wasmModules["+JSON.stringify(t)+"],i).then(function(m){e(m.exports)})}}})"],{type:"application/javascript"}))})):i}))}}("undefined"!=typeof self?self:global);var q="undefined"!=typeof Symbol&&Symbol.toStringTag;I.get=function(e){var t=this[M][e];if(t&&null===t.e&&!t.E)return t.er?null:t.n},I.set=function(t,n){try{new URL(t)}catch(s){console.warn(Error(e("W3",'"'+t+'" is not a valid URL to set in the module registry')))}var r;q&&"Module"===n[q]?r=n:(r=Object.assign(Object.create(null),n),q&&Object.defineProperty(r,q,{value:"Module"}));var i=Promise.resolve(r),o=this[M][t]||(this[M][t]={id:t,i:[],h:!1,d:[],e:null,er:void 0,E:void 0});return!o.e&&!o.E&&(Object.assign(o,{n:r,I:void 0,L:void 0,C:i}),r)},I.has=function(e){return!!this[M][e]},I.delete=function(e){var t=this[M],n=t[e];if(!n||n.p&&null!==n.p.e||n.E)return!1;var r=n.i;return n.d&&n.d.forEach((function(e){var t=e.i.indexOf(n);-1!==t&&e.i.splice(t,1)})),delete t[e],function(){var n=t[e];if(!n||!r||null!==n.e||n.E)return!1;r.forEach((function(e){n.i.push(e),e(n.n)})),r=null}};var D="undefined"!=typeof Symbol&&Symbol.iterator;I.entries=function(){var e,t,n=this,r=Object.keys(n[M]),i=0,o={next:function(){for(;void 0!==(t=r[i++])&&void 0===(e=n.get(t)););return{done:void 0===t,value:void 0!==t&&[t,e]}}};return o[D]=function(){return this},o}}();
  37. !function(t){function e(t){t.registerRegistry=Object.create(null),t.namedRegisterAliases=Object.create(null)}var r=t.System;e(r);var i,s,n=r.constructor.prototype,l=r.constructor,a=function(){l.call(this),e(this)};a.prototype=n,r.constructor=a;var o=n.register;n.register=function(t,e,r,n){if("string"!=typeof t)return o.apply(this,arguments);var l=[e,r,n];return this.registerRegistry[t]=l,i||(i=l,s=t),Promise.resolve().then((function(){i=null,s=null})),o.apply(this,[e,r,n])};var u=n.resolve;n.resolve=function(t,e){try{return u.call(this,t,e)}catch(r){if(t in this.registerRegistry)return this.namedRegisterAliases[t]||t;throw r}};var c=n.instantiate;n.instantiate=function(t,e,r){var i=this.registerRegistry[t];return i?(this.registerRegistry[t]=null,i):c.call(this,t,e,r)};var g=n.getRegister;n.getRegister=function(t){var e=g.call(this,t);s&&t&&(this.namedRegisterAliases[s]=t);var r=i||e;return i=null,s=null,r}}("undefined"!=typeof self?self:global);
  38. ;(typeof System!='undefined')&&(System=new System.constructor());
  39. System.addImportMap({ imports: {"highlight.js":"user:highlight.js","beautifier":"user:beautifier","jsmind":"user:jsmind","dom-to-image":"user:dom-to-image"} });
  40. System.set("user:highlight.js", (()=>{const _=hljs;('default' in _)||(_.default=_);return _})());
  41. System.set("user:beautifier", (()=>{const _=beautifier;('default' in _)||(_.default=_);return _})());
  42. System.set("user:jsmind", (()=>{const _=jsmind;('default' in _)||(_.default=_);return _})());
  43. System.set("user:dom-to-image", (()=>{const _=domtoimage;('default' in _)||(_.default=_);return _})());
  44.  
  45. System.register("./__entry.js", ['./__monkey.entry-D53wEhWR.js'], (function (exports, module) {
  46. 'use strict';
  47. return {
  48. setters: [null],
  49. execute: (function () {
  50.  
  51.  
  52.  
  53. })
  54. };
  55. }));
  56.  
  57. System.register("./__monkey.entry-D53wEhWR.js", [], (function (exports, module) {
  58. 'use strict';
  59. return {
  60. execute: (function () {
  61.  
  62. const scriptRel = function detectScriptRel() {
  63. const relList = typeof document !== "undefined" && document.createElement("link").relList;
  64. return relList && relList.supports && relList.supports("modulepreload") ? "modulepreload" : "preload";
  65. }();
  66. const assetsURL = function(dep) {
  67. return "/" + dep;
  68. };
  69. const seen = {};
  70. const __vitePreload = function preload(baseModule, deps, importerUrl) {
  71. let promise = Promise.resolve();
  72. if (deps && deps.length > 0) {
  73. document.getElementsByTagName("link");
  74. const cspNonceMeta = document.querySelector(
  75. "meta[property=csp-nonce]"
  76. );
  77. const cspNonce = cspNonceMeta?.nonce || cspNonceMeta?.getAttribute("nonce");
  78. promise = Promise.allSettled(
  79. deps.map((dep) => {
  80. dep = assetsURL(dep);
  81. if (dep in seen) return;
  82. seen[dep] = true;
  83. const isCss = dep.endsWith(".css");
  84. const cssSelector = isCss ? '[rel="stylesheet"]' : "";
  85. if (document.querySelector(`link[href="${dep}"]${cssSelector}`)) {
  86. return;
  87. }
  88. const link = document.createElement("link");
  89. link.rel = isCss ? "stylesheet" : scriptRel;
  90. if (!isCss) {
  91. link.as = "script";
  92. }
  93. link.crossOrigin = "";
  94. link.href = dep;
  95. if (cspNonce) {
  96. link.setAttribute("nonce", cspNonce);
  97. }
  98. document.head.appendChild(link);
  99. if (isCss) {
  100. return new Promise((res, rej) => {
  101. link.addEventListener("load", res);
  102. link.addEventListener(
  103. "error",
  104. () => rej(new Error(`Unable to preload CSS for ${dep}`))
  105. );
  106. });
  107. }
  108. })
  109. );
  110. }
  111. function handlePreloadError(err) {
  112. const e = new Event("vite:preloadError", {
  113. cancelable: true
  114. });
  115. e.payload = err;
  116. window.dispatchEvent(e);
  117. if (!e.defaultPrevented) {
  118. throw err;
  119. }
  120. }
  121. return promise.then((res) => {
  122. for (const item of res || []) {
  123. if (item.status !== "rejected") continue;
  124. handlePreloadError(item.reason);
  125. }
  126. return baseModule().catch(handlePreloadError);
  127. });
  128. };
  129. var jsonBigintNative = {};
  130. var stringify = { exports: {} };
  131. (function(module) {
  132. var JSON = module.exports;
  133. (function() {
  134. var escapable = /[\\\"\x00-\x1f\x7f-\x9f\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g, gap, indent, meta = {
  135. // table of character substitutions
  136. "\b": "\\b",
  137. " ": "\\t",
  138. "\n": "\\n",
  139. "\f": "\\f",
  140. "\r": "\\r",
  141. '"': '\\"',
  142. "\\": "\\\\"
  143. }, rep;
  144. function quote(string) {
  145. escapable.lastIndex = 0;
  146. return escapable.test(string) ? '"' + string.replace(escapable, function(a) {
  147. var c = meta[a];
  148. return typeof c === "string" ? c : "\\u" + ("0000" + a.charCodeAt(0).toString(16)).slice(-4);
  149. }) + '"' : '"' + string + '"';
  150. }
  151. function str(key, holder) {
  152. var i, k, v, length, mind = gap, partial, value = holder[key];
  153. if (value && typeof value === "object" && typeof value.toJSON === "function") {
  154. value = value.toJSON(key);
  155. }
  156. if (typeof rep === "function") {
  157. value = rep.call(holder, key, value);
  158. }
  159. switch (typeof value) {
  160. case "string":
  161. return quote(value);
  162. case "number":
  163. return isFinite(value) ? String(value) : "null";
  164. case "boolean":
  165. case "null":
  166. case "bigint":
  167. return String(value);
  168. case "object":
  169. if (!value) {
  170. return "null";
  171. }
  172. gap += indent;
  173. partial = [];
  174. if (Object.prototype.toString.apply(value) === "[object Array]") {
  175. length = value.length;
  176. for (i = 0; i < length; i += 1) {
  177. partial[i] = str(i, value) || "null";
  178. }
  179. v = partial.length === 0 ? "[]" : gap ? "[\n" + gap + partial.join(",\n" + gap) + "\n" + mind + "]" : "[" + partial.join(",") + "]";
  180. gap = mind;
  181. return v;
  182. }
  183. if (rep && typeof rep === "object") {
  184. length = rep.length;
  185. for (i = 0; i < length; i += 1) {
  186. if (typeof rep[i] === "string") {
  187. k = rep[i];
  188. v = str(k, value);
  189. if (v) {
  190. partial.push(quote(k) + (gap ? ": " : ":") + v);
  191. }
  192. }
  193. }
  194. } else {
  195. Object.keys(value).forEach(function(k2) {
  196. var v2 = str(k2, value);
  197. if (v2) {
  198. partial.push(quote(k2) + (gap ? ": " : ":") + v2);
  199. }
  200. });
  201. }
  202. v = partial.length === 0 ? "{}" : gap ? "{\n" + gap + partial.join(",\n" + gap) + "\n" + mind + "}" : "{" + partial.join(",") + "}";
  203. gap = mind;
  204. return v;
  205. }
  206. }
  207. if (typeof JSON.stringify !== "function") {
  208. JSON.stringify = function(value, replacer, space) {
  209. var i;
  210. gap = "";
  211. indent = "";
  212. if (typeof space === "number") {
  213. for (i = 0; i < space; i += 1) {
  214. indent += " ";
  215. }
  216. } else if (typeof space === "string") {
  217. indent = space;
  218. }
  219. rep = replacer;
  220. if (replacer && typeof replacer !== "function" && (typeof replacer !== "object" || typeof replacer.length !== "number")) {
  221. throw new Error("JSON.stringify");
  222. }
  223. return str("", { "": value });
  224. };
  225. }
  226. })();
  227. })(stringify);
  228. var stringifyExports = stringify.exports;
  229. var json_parse$1 = function(options) {
  230. var _options;
  231. var at, ch, escapee = {
  232. '"': '"',
  233. "\\": "\\",
  234. "/": "/",
  235. b: "\b",
  236. f: "\f",
  237. n: "\n",
  238. r: "\r",
  239. t: " "
  240. }, text, error = function(m) {
  241. throw {
  242. name: "SyntaxError",
  243. message: m,
  244. at,
  245. text
  246. };
  247. }, next = function(c) {
  248. if (c && c !== ch) {
  249. error("Expected '" + c + "' instead of '" + ch + "'");
  250. }
  251. ch = text.charAt(at);
  252. at += 1;
  253. return ch;
  254. }, number = function() {
  255. var number2, string2 = "";
  256. if (ch === "-") {
  257. string2 = "-";
  258. next("-");
  259. }
  260. while (ch >= "0" && ch <= "9") {
  261. string2 += ch;
  262. next();
  263. }
  264. if (ch === ".") {
  265. string2 += ".";
  266. while (next() && ch >= "0" && ch <= "9") {
  267. string2 += ch;
  268. }
  269. }
  270. if (ch === "e" || ch === "E") {
  271. string2 += ch;
  272. next();
  273. if (ch === "-" || ch === "+") {
  274. string2 += ch;
  275. next();
  276. }
  277. while (ch >= "0" && ch <= "9") {
  278. string2 += ch;
  279. next();
  280. }
  281. }
  282. number2 = +string2;
  283. if (!isFinite(number2)) {
  284. error("Bad number");
  285. } else {
  286. if (string2.length > 15 && string2.indexOf(".") === -1) {
  287. try {
  288. return BigInt(string2);
  289. } catch (e) {
  290. switch (_options.fallbackTo) {
  291. case "number":
  292. return number2;
  293. case "string":
  294. return string2;
  295. default:
  296. throw e;
  297. }
  298. }
  299. } else {
  300. return number2;
  301. }
  302. }
  303. }, string = function() {
  304. var hex, i, string2 = "", uffff;
  305. if (ch === '"') {
  306. var startAt = at;
  307. while (next()) {
  308. if (ch === '"') {
  309. if (at - 1 > startAt) string2 += text.substring(startAt, at - 1);
  310. next();
  311. return string2;
  312. }
  313. if (ch === "\\") {
  314. if (at - 1 > startAt) string2 += text.substring(startAt, at - 1);
  315. next();
  316. if (ch === "u") {
  317. uffff = 0;
  318. for (i = 0; i < 4; i += 1) {
  319. hex = parseInt(next(), 16);
  320. if (!isFinite(hex)) {
  321. break;
  322. }
  323. uffff = uffff * 16 + hex;
  324. }
  325. string2 += String.fromCharCode(uffff);
  326. } else if (typeof escapee[ch] === "string") {
  327. string2 += escapee[ch];
  328. } else {
  329. break;
  330. }
  331. startAt = at;
  332. }
  333. }
  334. }
  335. error("Bad string");
  336. }, white = function() {
  337. while (ch && ch <= " ") {
  338. next();
  339. }
  340. }, word = function() {
  341. switch (ch) {
  342. case "t":
  343. next("t");
  344. next("r");
  345. next("u");
  346. next("e");
  347. return true;
  348. case "f":
  349. next("f");
  350. next("a");
  351. next("l");
  352. next("s");
  353. next("e");
  354. return false;
  355. case "n":
  356. next("n");
  357. next("u");
  358. next("l");
  359. next("l");
  360. return null;
  361. }
  362. error("Unexpected '" + ch + "'");
  363. }, value, array = function() {
  364. var array2 = [];
  365. if (ch === "[") {
  366. next("[");
  367. white();
  368. if (ch === "]") {
  369. next("]");
  370. return array2;
  371. }
  372. while (ch) {
  373. array2.push(value());
  374. white();
  375. if (ch === "]") {
  376. next("]");
  377. return array2;
  378. }
  379. next(",");
  380. white();
  381. }
  382. }
  383. error("Bad array");
  384. }, object = function() {
  385. var key, object2 = {};
  386. if (ch === "{") {
  387. next("{");
  388. white();
  389. if (ch === "}") {
  390. next("}");
  391. return object2;
  392. }
  393. while (ch) {
  394. key = string();
  395. white();
  396. next(":");
  397. if (_options.strict === true && Object.hasOwnProperty.call(object2, key)) {
  398. error('Duplicate key "' + key + '"');
  399. }
  400. Object.defineProperty(object2, key, {
  401. value: value(),
  402. writable: true,
  403. enumerable: true,
  404. configurable: true
  405. });
  406. white();
  407. if (ch === "}") {
  408. next("}");
  409. return object2;
  410. }
  411. next(",");
  412. white();
  413. }
  414. }
  415. error("Bad object");
  416. };
  417. value = function() {
  418. white();
  419. switch (ch) {
  420. case "{":
  421. return object();
  422. case "[":
  423. return array();
  424. case '"':
  425. return string();
  426. case "-":
  427. return number();
  428. default:
  429. return ch >= "0" && ch <= "9" ? number() : word();
  430. }
  431. };
  432. return function(source, reviver, options2) {
  433. _options = {
  434. strict: false,
  435. // not being strict means do not generate syntax errors for "duplicate key"
  436. fallbackTo: "number"
  437. // toggles whether the values should be stored as BigInt (default) or a string
  438. };
  439. if (options2 !== void 0 && options2 !== null) {
  440. if (options2.strict === true) {
  441. _options.strict = true;
  442. }
  443. if (typeof options2.fallbackTo !== "undefined") {
  444. if (options2.fallbackTo === "number" || options2.fallbackTo === "string" || options2.fallbackTo === "error") {
  445. _options.fallbackTo = options2.fallbackTo;
  446. } else {
  447. throw new Error(
  448. 'Incorrect value for fallbackTo option, must be "number", "string", "error" or undefined but passed ' + options2.fallbackTo
  449. );
  450. }
  451. }
  452. }
  453. var result;
  454. text = source + "";
  455. at = 0;
  456. ch = " ";
  457. result = value();
  458. white();
  459. if (ch) {
  460. error("Syntax error");
  461. }
  462. return typeof reviver === "function" ? function walk(holder, key) {
  463. var v, value2 = holder[key];
  464. if (value2 && typeof value2 === "object") {
  465. Object.keys(value2).forEach(function(k) {
  466. v = walk(value2, k);
  467. if (v !== void 0) {
  468. value2[k] = v;
  469. } else {
  470. delete value2[k];
  471. }
  472. });
  473. }
  474. return reviver.call(holder, key, value2);
  475. }({ "": result }, "") : result;
  476. };
  477. };
  478. var parse = json_parse$1();
  479. var json_stringify = stringifyExports.stringify;
  480. var json_parse = parse;
  481. jsonBigintNative.parse = json_parse;
  482. jsonBigintNative.stringify = json_stringify;
  483. var _GM_getValue = exports("a", /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)());
  484. var _GM_openInTab = /* @__PURE__ */ (() => typeof GM_openInTab != "undefined" ? GM_openInTab : void 0)();
  485. var _GM_registerMenuCommand = /* @__PURE__ */ (() => typeof GM_registerMenuCommand != "undefined" ? GM_registerMenuCommand : void 0)();
  486. var _GM_setClipboard = exports("c", /* @__PURE__ */ (() => typeof GM_setClipboard != "undefined" ? GM_setClipboard : void 0)());
  487. var _GM_setValue = exports("b", /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)());
  488. var _unsafeWindow = exports("_", /* @__PURE__ */ (() => typeof unsafeWindow != "undefined" ? unsafeWindow : void 0)());
  489. NodeList.prototype.filter = Array.prototype.filter;
  490. NodeList.prototype.some = Array.prototype.some;
  491. NodeList.prototype.map = Array.prototype.map;
  492. function getDefaultDisplay(ele) {
  493. let display = ele.defaultDisplay;
  494. const doc = ele.ownerDocument;
  495. if (display) return display;
  496. const temp = doc.body.appendChild(doc.createElement(ele.nodeName));
  497. display = getComputedStyle(temp).display;
  498. temp.parentNode.removeChild(temp);
  499. if (display === "none") display = "block";
  500. ele.defaultDisplay = display;
  501. return display;
  502. }
  503. function getMaxKeysAndDepthObject(list) {
  504. function getObjectDepth(obj) {
  505. if (typeof obj !== "object" || obj === null) return 0;
  506. let maxDepth2 = 0;
  507. for (let key in obj) {
  508. if (Object.prototype.hasOwnProperty.call(obj, key)) {
  509. const depth = getObjectDepth(obj[key]);
  510. maxDepth2 = Math.max(maxDepth2, depth);
  511. }
  512. }
  513. return maxDepth2 + 1;
  514. }
  515. function countKeys(obj) {
  516. if (typeof obj !== "object" || obj === null) return 0;
  517. let keyCount = Object.keys(obj).length;
  518. for (let key in obj) {
  519. if (Object.prototype.hasOwnProperty.call(obj, key)) {
  520. keyCount += countKeys(obj[key]);
  521. }
  522. }
  523. return keyCount;
  524. }
  525. let maxKeys = 0;
  526. let maxDepth = 0;
  527. let result = null;
  528. for (let item of list) {
  529. const keys = countKeys(item);
  530. const depth = getObjectDepth(item);
  531. if (keys > maxKeys || keys === maxKeys && depth > maxDepth) {
  532. maxKeys = keys;
  533. maxDepth = depth;
  534. result = item;
  535. }
  536. }
  537. return result;
  538. }
  539. const Utils = exports("U", {
  540. getMaxKeysAndDepthObject,
  541. isImg(str) {
  542. const regexp = /(ico|bmp|gif|jpg|jpeg|png|svg|webp|ICO|BMP|GIF|JPG|JPEG|PNG|WEBP|SVG)([\w#!:.?+=&%@!\-\/])?/i;
  543. return regexp.test(str);
  544. },
  545. isJSON(str) {
  546. try {
  547. jsonBigintNative.parse(str);
  548. return true;
  549. } catch (e) {
  550. return false;
  551. }
  552. },
  553. parse(text, reviver) {
  554. return jsonBigintNative.parse(text, reviver);
  555. },
  556. stringify(value, replacer, space) {
  557. return jsonBigintNative.stringify(value, replacer, space);
  558. },
  559. isObject(o) {
  560. return Object.is(typeof o, "object");
  561. },
  562. getType(o) {
  563. return this.getPropType(o).toLowerCase();
  564. },
  565. getPropType(o) {
  566. return Object.prototype.toString.call(o).match(/\s(.+)]/)[1];
  567. },
  568. random(len = 10) {
  569. let array = new Uint8Array(len);
  570. window.crypto.getRandomValues(array);
  571. const characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
  572. const count = characters.length;
  573. let randomStr = "";
  574. for (let i = 0; i < len; i++) {
  575. randomStr += characters[array[i] % count];
  576. }
  577. return randomStr;
  578. },
  579. downloadText(content, filename) {
  580. const blob = new Blob([content], { type: "application/json;charset=utf-8" });
  581. const url = URL.createObjectURL(blob);
  582. this.createElement("a", { href: url, download: filename }).click();
  583. URL.revokeObjectURL(url);
  584. },
  585. matchJsonp(rawText) {
  586. const tokens = rawText.match(/^([^\s(]*)\s*\(([\s\S]*)\)\s*;?$/);
  587. if (tokens && tokens[1] && tokens[2]) {
  588. return { rawText: tokens[2], jsonpFun: tokens[1] };
  589. }
  590. return { rawText, jsonpFun: null };
  591. },
  592. debounce(fn, delay = 300) {
  593. let timer;
  594. return function() {
  595. if (timer) clearTimeout(timer);
  596. timer = setTimeout(() => fn.apply(this, arguments), delay);
  597. };
  598. },
  599. setClipboard(text) {
  600. if (_GM_setClipboard) {
  601. _GM_setClipboard(text);
  602. } else if (navigator.clipboard) {
  603. navigator.clipboard.writeText(text);
  604. } else {
  605. console.error("复制内容失败");
  606. }
  607. },
  608. addEvent(eventType, selector, callback) {
  609. const types = eventType.split(" ");
  610. types.forEach((type) => {
  611. function handler(event) {
  612. let target = event.target;
  613. if (!target.matches) return;
  614. while (!target.matches(selector)) {
  615. target = target.parentNode;
  616. if (!target || !target.matches) return;
  617. }
  618. Object.defineProperty(event, "currentTarget", {
  619. configurable: true,
  620. get() {
  621. return target;
  622. }
  623. });
  624. const returnValue = callback.call(target, event);
  625. if (returnValue === false) {
  626. event.preventDefault();
  627. event.stopPropagation();
  628. }
  629. event.stopImmediatePropagation();
  630. }
  631. document.addEventListener(type, handler, true);
  632. });
  633. },
  634. isVisible(ele) {
  635. return !!(ele.offsetWidth || ele.offsetHeight || ele.getClientRects().length);
  636. },
  637. createElement(name, attrs, text) {
  638. const element = document.createElement(name);
  639. if (text) element.textContent = text;
  640. if (attrs) this.attr(element, attrs);
  641. return element;
  642. },
  643. attr(ele, attrs, value) {
  644. if (!ele) return;
  645. if (typeof attrs === "object") {
  646. for (const name in attrs) ele.setAttribute(name, attrs[name]);
  647. return;
  648. }
  649. if (value === void 0) return ele.getAttribute(attrs);
  650. if (value === false || value === null) return ele.removeAttribute(attrs);
  651. ele.setAttribute(attrs, value);
  652. },
  653. query(selector, context) {
  654. const ctx = context || document;
  655. if (selector instanceof HTMLElement) return selector;
  656. return ctx.querySelector(selector);
  657. },
  658. queryAll(selector, context) {
  659. const ctx = context || document;
  660. if (selector instanceof HTMLElement) return new NodeList(selector);
  661. if (selector instanceof NodeList) return selector;
  662. return ctx.querySelectorAll(selector);
  663. },
  664. closest(element, selector) {
  665. while (element) {
  666. if (element.matches(selector)) return element;
  667. element = element.parentElement;
  668. }
  669. return null;
  670. },
  671. addClass(ele, className) {
  672. if (!ele) return;
  673. if (ele instanceof HTMLElement) return ele.classList.add(className);
  674. if (ele instanceof NodeList || ele instanceof Array) {
  675. ele.forEach((el) => this.addClass(el, className));
  676. }
  677. },
  678. removeClass(ele, className) {
  679. if (!ele) return;
  680. if (ele instanceof HTMLElement) {
  681. const classList = ele.classList;
  682. if (className === void 0) {
  683. while (classList.length > 0) {
  684. classList.remove(classList.item(0));
  685. }
  686. return;
  687. }
  688. return classList.remove(className);
  689. }
  690. if (ele instanceof NodeList || ele instanceof Array) {
  691. ele.forEach((el) => this.removeClass(el, className));
  692. }
  693. },
  694. toggleClass(ele, className) {
  695. if (!ele) return;
  696. this.hasClass(ele, className) ? this.removeClass(ele, className) : this.addClass(ele, className);
  697. },
  698. hasClass(ele, className) {
  699. if (!ele) return false;
  700. if (ele instanceof HTMLElement) return ele.classList.contains(className);
  701. if (ele instanceof NodeList) {
  702. return ele.some((el) => this.hasClass(el, className));
  703. }
  704. },
  705. show(ele) {
  706. if (!ele) return;
  707. const style = ele.style;
  708. const display = getComputedStyle(ele).display;
  709. if (style.display === "none") style.display = "";
  710. if (style.display === "" && display === "none") {
  711. style.display = getDefaultDisplay(ele);
  712. }
  713. },
  714. hide(ele) {
  715. if (ele.defaultDisplay === void 0) {
  716. const computedDisplay = getComputedStyle(ele).display;
  717. if (!Object.is(computedDisplay, "none")) {
  718. ele.defaultDisplay = computedDisplay;
  719. }
  720. }
  721. ele.style.display = "none";
  722. }
  723. });
  724. const URL$1 = exports("d", {
  725. JSON_CRACK_WIDGET: "https://jsoncrack.feny.ink/widget",
  726. EXAMPLE_JSON: "https://fetch-api.feny.ink/example.json",
  727. ONLINE_REQUEST: "https://fetch-api.feny.ink/httpRequest",
  728. LAYUI_JS: "https://unpkg.com/layui@2.7.6/dist/layui.js"
  729. });
  730. const layout = `
  731. <template data-for="viewFormater">
  732. <div class="toolbar-item btn" id="saveJson">保存</div>
  733. <div class="toolbar-item btn" id="copyJson">复制</div>
  734. <div class="toolbar-item btn" id="sorted">排序</div>
  735. <div class="toolbar-item btn" id="collapseAll">全部折叠</div>
  736. <div class="toolbar-item btn" id="expandAll">全部展开</div>
  737. <div class="searchbox">
  738. <input class="filter" type="text" placeholder="JSON 过滤" />
  739. <button class="clear" hidden></button>
  740. </div>
  741. </template>
  742. <template data-for="viewMind">
  743. <div class="toolbar-item btn" id="saveJson">保存</div>
  744. <div class="toolbar-item btn" id="collapseAll">全部折叠</div>
  745. <div class="toolbar-item btn" id="expandAll">全部展开</div>
  746. <div class="toolbar-item btn" id="jsoncrack">JSON Crack</div>
  747. </template>
  748. <template data-for="viewRawText">
  749. <div class="toolbar-item btn" id="saveJson">保存</div>
  750. <div class="toolbar-item btn" id="copyJson">复制</div>
  751. <div class="toolbar-item btn" id="beautify">美化输出</div>
  752. </template>
  753. <div class="json-viewer-layout">
  754. <div class="panel">
  755. <div class="tabs">
  756. <div class="tabs-item btn active" id="viewFormater">JSON 格式化</div>
  757. <div class="tabs-item btn" id="viewMind">JSON 脑图</div>
  758. <div class="tabs-item btn" id="viewRawText">原始数据</div>
  759. </div>
  760. <div class="toolbar"></div>
  761. <div class="rightbox">
  762. <div class="style">
  763. <span>风格</span>
  764. <template data-type="style">
  765. <ul>
  766. <li data-type="style" data-value="default">默认</li>
  767. <li data-type="style" data-value="table">表格</li>
  768. </ul>
  769. </template>
  770. </div>
  771. <div class="theme">
  772. <span>主题</span>
  773. <template data-type="theme">
  774. <ul>
  775. <li data-type="theme" data-value="default">默认</li>
  776. <li data-type="theme" data-value="light">浅色</li>
  777. <li data-type="theme" data-value="dark">暗黑</li>
  778. <li data-type="theme" data-value="dark-plus">暗黑+</li>
  779. </ul>
  780. </template>
  781. </div>
  782. <div class="tools">
  783. <span>工具</span>
  784. <template data-type="tools">
  785. <ul>
  786. <li data-type="tools" data-value="inputJson">JSON 输入</li>
  787. <li data-type="tools" data-value="fetchJson">HTTP 请求</li>
  788. </ul>
  789. </template>
  790. </div>
  791. </div>
  792. </div>
  793. <div class="container">
  794. <div class="active" data-for="viewFormater" id="formatBox"></div>
  795. <div data-for="viewMind" id="mindBox"></div>
  796. <div data-for="viewRawText" id="rawTextBox">
  797. <pre></pre>
  798. </div>
  799. </div>
  800. </div>
  801. `;
  802. const { EXAMPLE_JSON, LAYUI_JS } = URL$1;
  803. (function() {
  804. const openInTab = () => _GM_openInTab(EXAMPLE_JSON);
  805. _GM_registerMenuCommand("JSON示例 ( Alt + J )", openInTab);
  806. window.addEventListener("keydown", ({ code, altKey }) => altKey && code === "KeyJ" && openInTab());
  807. const innerText = document.body.innerText;
  808. const { rawText, jsonpFun } = Utils.matchJsonp(innerText);
  809. if (!Utils.isJSON(rawText)) return __vitePreload(() => module.import('./index-oBU1o6se-nCngTgYo.js'), void 0 );
  810. _unsafeWindow.RAW_TEXT = rawText;
  811. _unsafeWindow.GLOBAL_JSONP_FUN = jsonpFun;
  812. _unsafeWindow.GLOBAL_JSON = Utils.parse(_unsafeWindow.RAW_TEXT);
  813. Utils.hide(Utils.query("pre"));
  814. window.postMessage({ addStyle: true });
  815. const meta = Utils.createElement("meta", { name: "viewport", content: "width=device-width, initial-scale=1.0" });
  816. document.head.appendChild(meta);
  817. const script = Utils.createElement("script", { src: LAYUI_JS, type: "text/javascript" });
  818. document.head.appendChild(script);
  819. setTimeout(async () => {
  820. document.body.insertAdjacentHTML("afterbegin", layout);
  821. const temp = Utils.query('template[data-for="viewFormater"]');
  822. Utils.query(".toolbar").innerHTML = temp.innerHTML;
  823. await __vitePreload(() => module.import('./index-CIny2Zmg-Bc50vzGI.js'), void 0 );
  824. __vitePreload(() => module.import('./index-Lp3uvp-B-C24lrmW9.js'), void 0 );
  825. __vitePreload(() => module.import('./index-7SRjeOqa-CiimRmMH.js'), void 0 );
  826. });
  827. })();
  828.  
  829. })
  830. };
  831. }));
  832.  
  833. System.register("./index-oBU1o6se-nCngTgYo.js", ['highlight.js', 'beautifier', './__monkey.entry-D53wEhWR.js'], (function (exports, module) {
  834. 'use strict';
  835. var hljs, css_beautify, js_beautify, Utils;
  836. return {
  837. setters: [module => {
  838. hljs = module.default;
  839. }, module => {
  840. css_beautify = module.css_beautify;
  841. js_beautify = module.js_beautify;
  842. }, module => {
  843. Utils = module.U;
  844. }],
  845. execute: (function () {
  846.  
  847. const layout = `
  848. <div class="beautify_checkbox">
  849. <input type="checkbox" id="beautify" />
  850. <label for="beautify">美化输出</label>
  851. </div>
  852. `;
  853. (function() {
  854. const docType = ["application/x-javascript", "application/javascript", "text/javascript", "text/css"];
  855. const contentType = document.contentType;
  856. if (!docType.includes(contentType)) return;
  857. const preElement = Utils.query("pre");
  858. if (!preElement) return;
  859. window.postMessage({ addStyle: true });
  860. Utils.addClass(Utils.query("html"), "monkey-js-css-beautify");
  861. setTimeout(() => {
  862. const rawText = preElement.innerText;
  863. document.body.insertAdjacentHTML("afterbegin", layout);
  864. const checkbox = Utils.query(".beautify_checkbox input");
  865. checkbox.addEventListener("click", function() {
  866. if (this.checked) {
  867. beautifyCode(contentType, preElement, rawText);
  868. } else {
  869. preElement.innerText = rawText;
  870. }
  871. });
  872. });
  873. })();
  874. function beautifyCode(contentType, element, rawText) {
  875. const language = contentType.substring(contentType.indexOf("/") + 1);
  876. if (!["css", "javascript", "x-javascript"].includes(language)) return;
  877. let beautifyCode2;
  878. if ("css" === language) {
  879. const cssBeautify = css_beautify ? css_beautify : window.css_beautify;
  880. beautifyCode2 = hljs.highlight(cssBeautify(rawText), { language }).value;
  881. } else {
  882. const jsBeautify = js_beautify ? js_beautify : window.js_beautify;
  883. beautifyCode2 = hljs.highlight(jsBeautify(rawText), { language: "javascript" }).value;
  884. }
  885. element.innerHTML = `<code>${beautifyCode2}</code>`;
  886. }
  887.  
  888. })
  889. };
  890. }));
  891.  
  892. System.register("./index-CIny2Zmg-Bc50vzGI.js", ['./__monkey.entry-D53wEhWR.js', './tippy.esm-D1eoMe9a-Bn9PjR6Y.js'], (function (exports, module) {
  893. 'use strict';
  894. var Utils, _unsafeWindow, _GM_getValue, _GM_setValue, _GM_setClipboard, tippy;
  895. return {
  896. setters: [module => {
  897. Utils = module.U;
  898. _unsafeWindow = module._;
  899. _GM_getValue = module.a;
  900. _GM_setValue = module.b;
  901. _GM_setClipboard = module.c;
  902. }, module => {
  903. tippy = module.t;
  904. }],
  905. execute: (function () {
  906.  
  907. var __defProp = Object.defineProperty;
  908. var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
  909. var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
  910. const STYLE = Object.freeze({ TABLE: "table", VIEWER: "viewer" });
  911. const SORTED = Object.freeze({ NONE: "none", ASC: "ASC", DESC: "DESC" });
  912. class JsonFormat {
  913. constructor(options, tag, clazz) {
  914. __publicField(this, "Root", "Root");
  915. __publicField(this, "DEFAULTS", { json: null, style: null, container: null, theme: "default", sort: SORTED.NONE });
  916. // 括号
  917. __publicField(this, "BRACKET", Object.freeze({
  918. array: { START: "[", END: "]", FULL: "[]" },
  919. object: { START: "{", END: "}", FULL: "{}" }
  920. }));
  921. // 排序枚举
  922. __publicField(this, "SORT_ENUM", Object.freeze({
  923. [SORTED.NONE]: { value: SORTED.ASC, text: "升序" },
  924. [SORTED.ASC]: { value: SORTED.DESC, text: "降序" },
  925. [SORTED.DESC]: { value: SORTED.NONE, text: "排序" }
  926. }));
  927. this.tag = tag;
  928. this.clazz = clazz;
  929. this.options = Object.assign(this.DEFAULTS, options);
  930. if (!options.container) throw new Error("Container is required");
  931. if (!options.json) throw new Error("json is required");
  932. this.container = Utils.query(options.container);
  933. this.setTheme(this.options.theme);
  934. this.render(tag, clazz);
  935. }
  936. render(tag, clazz) {
  937. this.container.innerHTML = "";
  938. const wrapper = Utils.createElement(tag, { class: clazz });
  939. const fragment = document.createDocumentFragment();
  940. this.buildNode(fragment, this.options.json);
  941. wrapper.appendChild(fragment);
  942. this.container.appendChild(wrapper);
  943. this.bindEvent();
  944. }
  945. buildNode() {
  946. throw new Error("此方法必须由子类实现具体功能");
  947. }
  948. setTheme(theme) {
  949. const classList = document.body.classList;
  950. classList.forEach((clas) => {
  951. if (clas.includes("theme")) classList.remove(clas);
  952. });
  953. classList.add(`${theme}-theme`);
  954. }
  955. keySort(json) {
  956. const { sort } = this.options;
  957. if (Array.isArray(json)) return json;
  958. if (sort === SORTED.NONE) return json;
  959. const entries = Object.entries(json);
  960. const asc = ([prev], [next]) => prev.localeCompare(next);
  961. const desc = ([prev], [next]) => next.localeCompare(prev);
  962. const result = Object.is(SORTED.ASC, sort) ? entries.sort(asc) : entries.sort(desc);
  963. return Object.fromEntries(result);
  964. }
  965. sorted() {
  966. const sort = this.SORT_ENUM[this.options.sort];
  967. this.options.sort = sort.value;
  968. this.render(this.tag, this.clazz);
  969. return sort.text;
  970. }
  971. iterateJson(json, parentId, parentPath, tagName, callback) {
  972. const entries = Object.entries(this.keySort(json));
  973. const entryCount = entries.length;
  974. const lastIndex = entryCount - 1;
  975. for (let index = 0; index < entryCount; index++) {
  976. const id = Utils.random();
  977. const [key, value] = entries[index];
  978. const type = Utils.getType(value);
  979. const hasNext = this.hasNext(value);
  980. const notLast = !Object.is(index, lastIndex);
  981. const path = this.spliceJsonPath(parentPath, key);
  982. const element = Utils.createElement(tagName, { path, "data-node-id": id, "data-node-pid": parentId });
  983. if (hasNext) element.setAttribute("class", "collapsible expanded");
  984. callback.call(this, { id, key, value, type, path, hasNext, element, notLast });
  985. }
  986. }
  987. creatValueNode(type, value) {
  988. if (this.isIterator(value)) return this.createBracket(type);
  989. const node = Utils.createElement("span", { class: `json-${type}` });
  990. if (this.isUrl(value)) {
  991. const link = Utils.createElement("a", { target: "_blank", href: value }, `"${value}"`);
  992. node.appendChild(link);
  993. return node;
  994. }
  995. node.textContent = Object.is("string", type) ? Utils.stringify(value) : `${value}`;
  996. if (this.isColor(value)) {
  997. const span = Utils.createElement("span", { class: "json-color", style: `background-color: ${value}` });
  998. node.prepend(span);
  999. }
  1000. return node;
  1001. }
  1002. creatExtraNodes(node, json) {
  1003. if (!this.hasNext(json)) return;
  1004. node.prepend(this.creatArrowNode());
  1005. node.appendChild(this.creatCopyNode(json));
  1006. node.appendChild(this.creatDescNode(json));
  1007. }
  1008. creatArrowNode() {
  1009. return Utils.createElement("span", { class: "json-arrow" });
  1010. }
  1011. creatCopyNode(json) {
  1012. const copy = Utils.createElement("span", { title: "复制", class: "json-copy" });
  1013. copy.json = json;
  1014. return copy;
  1015. }
  1016. creatDescNode(json) {
  1017. const type = Utils.getType(json);
  1018. const desc = Utils.createElement("span", { class: "json-desc" });
  1019. const count = Object.keys(json).length;
  1020. const span = Utils.createElement("span");
  1021. span.textContent = `${count} ${type === "object" ? count > 1 ? "keys" : "key" : count > 1 ? "items" : "item"}`;
  1022. desc.appendChild(span);
  1023. if (STYLE.TABLE === this.options.style) {
  1024. desc.insertAdjacentText("afterbegin", this.BRACKET[type].START);
  1025. desc.insertAdjacentText("beforeend", this.BRACKET[type].END);
  1026. }
  1027. return desc;
  1028. }
  1029. createBracket(type) {
  1030. return Utils.createElement("span", { type, class: `json-bracket` }, this.BRACKET[type].FULL);
  1031. }
  1032. bindEvent() {
  1033. this.addEvent("click", ".json-copy", ({ target }) => {
  1034. const className = "success";
  1035. if (!target.json || Utils.hasClass(target, className)) return;
  1036. Utils.setClipboard(Utils.stringify(target.json, null, 2));
  1037. setTimeout(() => Utils.removeClass(target, className), 1500);
  1038. Utils.addClass(target, className);
  1039. });
  1040. this.addEvent("click", ".json-arrow", ({ target }) => {
  1041. const node = Utils.closest(target, ".collapsible");
  1042. Utils.hasClass(node, "expanded") ? this.collapse(node) : this.expand(node);
  1043. });
  1044. this.addEvent("click", ".json-desc", ({ target }) => this.expand(Utils.closest(target, ".collapsible")));
  1045. }
  1046. expandAll() {
  1047. this.nodes().forEach((node) => this.expand(node));
  1048. }
  1049. collapseAll() {
  1050. this.nodes().forEach((node) => this.collapse(node));
  1051. }
  1052. expand(node) {
  1053. this.toggleDescs(node, false);
  1054. Utils.hide(this.descNode(node));
  1055. Utils.addClass(node, "expanded");
  1056. Utils.removeClass(node, "collapsed");
  1057. }
  1058. collapse(node) {
  1059. this.toggleDescs(node, true);
  1060. Utils.show(this.descNode(node));
  1061. Utils.addClass(node, "collapsed");
  1062. Utils.removeClass(node, "expanded");
  1063. }
  1064. toggleDescs(node, hidden) {
  1065. const target = Utils.query(`#${node.dataset.nodeId}`);
  1066. hidden ? Utils.addClass(target, "hidden") : Utils.removeClass(target, "hidden");
  1067. }
  1068. descNode(node) {
  1069. return Utils.query(`*[data-node-id="${node.dataset.nodeId}"] .json-desc`, node);
  1070. }
  1071. findChildren(node) {
  1072. return Utils.queryAll(`*[data-node-pid="${node.dataset.nodeId}"]`, this.container);
  1073. }
  1074. findByID(id) {
  1075. return Utils.query(`*[data-node-id="${id}"]`, this.container);
  1076. }
  1077. expandByID(id) {
  1078. this.expand(this.findByID(id));
  1079. }
  1080. collapseByID(id) {
  1081. this.collapse(this.findByID(id));
  1082. }
  1083. nodes() {
  1084. return Utils.queryAll(".collapsible", this.container);
  1085. }
  1086. addEvent(type, selector, fn) {
  1087. Utils.queryAll(selector).forEach((el) => el.addEventListener(type, fn));
  1088. }
  1089. spliceJsonPath(path, key) {
  1090. if (this.isNumber(key)) return `${path}[${key}]`;
  1091. if (key.includes(".")) return `${path}["${key}"]`;
  1092. return `${path}.${key}`;
  1093. }
  1094. isNumber(str) {
  1095. return /^\d+$/.test(str);
  1096. }
  1097. isIterator(data) {
  1098. return ["array", "object"].includes(Utils.getType(data));
  1099. }
  1100. hasNext(data) {
  1101. return this.isIterator(data) ? Object.keys(data).length > 0 : false;
  1102. }
  1103. isUrl(str) {
  1104. const regexp = /^(ftp|http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/]))?/;
  1105. return regexp.test(str);
  1106. }
  1107. isColor(str) {
  1108. const rgbRegex = /^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/;
  1109. const hexRegex = /^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;
  1110. const rgbaRegex = /^rgba\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*,\s*(0|1|0\.\d+)\s*\)$/;
  1111. return hexRegex.test(str) || rgbRegex.test(str) || rgbaRegex.test(str);
  1112. }
  1113. }
  1114. __publicField(JsonFormat, "STYLE", STYLE);
  1115. class JsonViewer extends JsonFormat {
  1116. constructor(options) {
  1117. options.style = JsonFormat.STYLE.VIEWER;
  1118. super(options, "div", "json-viewer");
  1119. }
  1120. buildNode(fragment, json, parentPath = this.Root, parentId = this.Root) {
  1121. const type = Utils.getType(json);
  1122. fragment.appendChild(Utils.createElement("span", { type, class: `json-bracket` }, this.BRACKET[type].START));
  1123. if (this.Root !== parentId) this.creatExtraNodes(fragment, json);
  1124. this.iterateNodes(fragment, json, parentPath, parentId);
  1125. fragment.appendChild(Utils.createElement("span", { type, class: `json-bracket` }, this.BRACKET[type].END));
  1126. }
  1127. iterateNodes(fragment, json, parentPath, parentId) {
  1128. const wrapper = Utils.createElement("ul", { id: parentId });
  1129. this.iterateJson(json, parentId, parentPath, "li", (data) => {
  1130. const { id, key, value, type, path, hasNext, element, notLast } = data;
  1131. this.createKeyNode(element, key);
  1132. if (hasNext) this.buildNode(element, value, path, id);
  1133. if (!hasNext) element.appendChild(this.creatValueNode(type, value));
  1134. if (notLast) element.appendChild(Utils.createElement("span", { class: "json-comma" }, ","));
  1135. wrapper.appendChild(element);
  1136. });
  1137. fragment.appendChild(wrapper);
  1138. }
  1139. createKeyNode(node, key) {
  1140. if (this.isNumber(key)) return;
  1141. node.appendChild(Utils.createElement("span", { class: "json-key" }, `"${key}"`));
  1142. node.appendChild(Utils.createElement("span", { class: "json-colon" }, ":"));
  1143. }
  1144. }
  1145. class JsonToTable extends JsonFormat {
  1146. constructor(options) {
  1147. options.style = JsonFormat.STYLE.TABLE;
  1148. super(options, "table", "json-tree-table");
  1149. }
  1150. buildNode(fragment, json, parentPath = this.Root, parentId = this.Root, nodeDepth = 1) {
  1151. const wrapper = Utils.createElement("wrapper", { id: parentId });
  1152. this.iterateJson(json, parentId, parentPath, "tr", (data) => {
  1153. const { id, key, value, type, path, hasNext, element } = data;
  1154. element.appendChild(this.createKeyNode(key, value, nodeDepth, hasNext));
  1155. if (!hasNext) {
  1156. const td = Utils.createElement("td");
  1157. td.appendChild(this.creatValueNode(type, value));
  1158. element.appendChild(td);
  1159. }
  1160. wrapper.appendChild(element);
  1161. if (hasNext) this.buildNode(wrapper, value, path, id, nodeDepth + 1);
  1162. });
  1163. fragment.appendChild(wrapper);
  1164. }
  1165. createKeyNode(key, value, nodeDepth, hasNext) {
  1166. const paddingLeft = nodeDepth * 20;
  1167. const node = Utils.createElement("td", { style: `padding-left: ${paddingLeft}px` });
  1168. if (hasNext) node.setAttribute("colspan", 2);
  1169. node.appendChild(Utils.createElement("span", { class: "json-key" }, `${key}`));
  1170. node.appendChild(Utils.createElement("span", { class: "json-colon" }, ":"));
  1171. this.creatExtraNodes(node, value);
  1172. return node;
  1173. }
  1174. bindEvent() {
  1175. super.bindEvent();
  1176. Utils.addEvent("mousedown", "table tr", function({ ctrlKey, target }) {
  1177. const { tagName, className } = target;
  1178. if (ctrlKey || tagName === "A" || tagName === "SPAN" && className !== "json-key") return;
  1179. const filter = Utils.queryAll(".selected").filter((el) => el !== this);
  1180. Utils.removeClass(filter, "selected");
  1181. Utils.toggleClass(this, "selected");
  1182. });
  1183. }
  1184. }
  1185. class FormaterFactory {
  1186. static getInstance(options) {
  1187. return Object.is(JsonToTable.STYLE.TABLE, options.style) ? new JsonToTable(options) : new JsonViewer(options);
  1188. }
  1189. }
  1190. const evnet = {
  1191. urlHover() {
  1192. Utils.addEvent("mouseenter", "a[href]", function() {
  1193. const href = Utils.attr(this, "href");
  1194. if (!Utils.isImg(href)) return;
  1195. const content = `<img style="width:100%" src="${href}" />`;
  1196. tippy(this, { maxWidth: 500, duration: 800, allowHTML: true, theme: "imagebox", content }).show();
  1197. });
  1198. return this;
  1199. },
  1200. eventPath() {
  1201. Utils.addEvent("click mouseenter", ".json-key", ({ type, ctrlKey, target }) => {
  1202. const path = Utils.closest(target, "[path]").getAttribute("path");
  1203. if (ctrlKey && type === "click") return _GM_setClipboard(path) & layer.msg("复制成功", { time: 1500 });
  1204. const content = `<i>ctrlclick 复制</i><br/><b>路径:</b>${path}`;
  1205. tippy(target, { duration: 800, theme: "layer", allowHTML: true, maxWidth: "none", content }).show();
  1206. });
  1207. return this;
  1208. },
  1209. init() {
  1210. this.urlHover().eventPath();
  1211. }
  1212. };
  1213. const format = exports("default", {
  1214. changeStyle(style) {
  1215. _GM_setValue("style", style) & this.setStyle();
  1216. return this;
  1217. },
  1218. setStyle() {
  1219. _unsafeWindow.FILTER_VALUE = "";
  1220. Utils.query(".filter").value = "";
  1221. Utils.attr(Utils.query(".clear"), "hidden", true);
  1222. this.render(_unsafeWindow.GLOBAL_JSON);
  1223. return this;
  1224. },
  1225. render(json) {
  1226. const container = Utils.query("#formatBox");
  1227. const style = _GM_getValue("style") || "default";
  1228. const theme = _GM_getValue("theme") || "default";
  1229. const options = { json, style, theme, container };
  1230. _unsafeWindow.JSON_FORMATER = FormaterFactory.getInstance(options);
  1231. if (_unsafeWindow.GLOBAL_JSONP_FUN) {
  1232. const start = Utils.createElement("div", { class: "jsonp" });
  1233. start.textContent = `${_unsafeWindow.GLOBAL_JSONP_FUN}(`;
  1234. container.prepend(start);
  1235. const end = start.cloneNode(true);
  1236. end.textContent = ")";
  1237. container.append(end);
  1238. }
  1239. return this;
  1240. },
  1241. filter(json, text) {
  1242. text = text.toLowerCase();
  1243. function match(json2, text2) {
  1244. const newJson = Array.isArray(json2) ? new Array() : new Object();
  1245. const entries = Object.entries(json2);
  1246. for (const [key, value] of entries) {
  1247. const type = Utils.getType(value);
  1248. const _key = key.toLowerCase();
  1249. const _value = Utils.stringify(value).toLowerCase();
  1250. if (!_key.includes(text2) && !_value.includes(text2)) continue;
  1251. if (["array", "object"].includes(type)) {
  1252. const result = match(value, text2);
  1253. const _result = Utils.stringify(result).toLowerCase();
  1254. if (_key.includes(text2) || _result.includes(text2)) {
  1255. newJson[key] = result;
  1256. }
  1257. } else {
  1258. newJson[key] = value;
  1259. }
  1260. }
  1261. return newJson;
  1262. }
  1263. return match(json, text);
  1264. },
  1265. input() {
  1266. const debounceInput = Utils.debounce((event) => {
  1267. const value = event.target.value;
  1268. _unsafeWindow.FILTER_VALUE = value;
  1269. const clear = Utils.query(".clear");
  1270. Utils.attr(clear, "hidden", !value);
  1271. const newJson = this.filter(_unsafeWindow.GLOBAL_JSON, value);
  1272. this.render(newJson);
  1273. }, 400);
  1274. Utils.addEvent("input", ".filter", debounceInput);
  1275. return this;
  1276. },
  1277. clear() {
  1278. Utils.addEvent("click", ".clear", () => this.setStyle());
  1279. return this;
  1280. },
  1281. init() {
  1282. this.setStyle().input().clear();
  1283. evnet.init();
  1284. }
  1285. });
  1286. window.addEventListener("message", function({ data }) {
  1287. if (data?.reload) return format.setStyle();
  1288. if (Object.is(data?.type, "style")) format.changeStyle(data?.value);
  1289. });
  1290. format.init();
  1291.  
  1292. })
  1293. };
  1294. }));
  1295.  
  1296. System.register("./index-Lp3uvp-B-C24lrmW9.js", ['./tippy.esm-D1eoMe9a-Bn9PjR6Y.js', './__monkey.entry-D53wEhWR.js'], (function (exports, module) {
  1297. 'use strict';
  1298. var tippy, Utils;
  1299. return {
  1300. setters: [module => {
  1301. tippy = module.t;
  1302. }, module => {
  1303. Utils = module.U;
  1304. }],
  1305. execute: (function () {
  1306.  
  1307. const scroll = Utils.createElement("div", { class: "scroll-top" });
  1308. document.body.appendChild(scroll);
  1309. tippy(scroll, { theme: "scroll", placement: "left", content: "返回顶部" });
  1310. const $container = Utils.query(".container");
  1311. $container.addEventListener("scroll", ({ target }) => target.scrollTop > 500 ? Utils.show(scroll) : Utils.hide(scroll));
  1312. scroll.addEventListener("click", () => $container.scrollTop = 0);
  1313.  
  1314. })
  1315. };
  1316. }));
  1317.  
  1318. System.register("./index-7SRjeOqa-CiimRmMH.js", ['./tippy.esm-D1eoMe9a-Bn9PjR6Y.js', 'jsmind', 'dom-to-image', './__monkey.entry-D53wEhWR.js'], (function (exports, module) {
  1319. 'use strict';
  1320. var tippy, require$$0, require$$1, Utils, _unsafeWindow, _GM_getValue, URL$1, _GM_setClipboard, _GM_setValue;
  1321. return {
  1322. setters: [module => {
  1323. tippy = module.t;
  1324. }, module => {
  1325. require$$0 = module.default;
  1326. }, module => {
  1327. require$$1 = module.default;
  1328. }, module => {
  1329. Utils = module.U;
  1330. _unsafeWindow = module._;
  1331. _GM_getValue = module.a;
  1332. URL$1 = module.d;
  1333. _GM_setClipboard = module.c;
  1334. _GM_setValue = module.b;
  1335. }],
  1336. execute: (function () {
  1337.  
  1338. var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
  1339. /**
  1340. * @license BSD-3-Clause
  1341. * @copyright 2014-2025 hizzgdev@163.com
  1342. *
  1343. * Project Home:
  1344. * https://github.com/hizzgdev/jsmind/
  1345. */
  1346. (function(module, exports) {
  1347. !function(e, t) {
  1348. t(require$$0, require$$1);
  1349. }(commonjsGlobal, function(e, t) {
  1350. function i(e2) {
  1351. return e2 && "object" == typeof e2 && "default" in e2 ? e2 : { default: e2 };
  1352. }
  1353. var n = i(e), o = i(t);
  1354. if (!n.default) throw new Error("jsMind is not defined");
  1355. if (!o.default) throw new Error("dom-to-image is required");
  1356. const r = n.default.$, s = { filename: null, watermark: { left: r.w.location, right: "https://github.com/hizzgdev/jsmind" }, background: "transparent" };
  1357. class a {
  1358. constructor(e2, t2) {
  1359. var i2 = {};
  1360. n.default.util.json.merge(i2, s), n.default.util.json.merge(i2, t2), this.version = "0.2.0", this.jm = e2, this.options = i2, this.dpr = e2.view.device_pixel_ratio;
  1361. }
  1362. shoot() {
  1363. let e2 = this.create_canvas(), t2 = e2.getContext("2d");
  1364. t2.scale(this.dpr, this.dpr), Promise.resolve(t2).then(() => this.draw_background(t2)).then(() => this.draw_lines(t2)).then(() => this.draw_nodes(t2)).then(() => this.draw_watermark(e2, t2)).then(() => this.download(e2)).then(() => this.clear(e2));
  1365. }
  1366. create_canvas() {
  1367. let e2 = r.c("canvas");
  1368. const t2 = this.jm.view.size.w, i2 = this.jm.view.size.h;
  1369. return e2.width = t2 * this.dpr, e2.height = i2 * this.dpr, e2.style.width = t2 + "px", e2.style.height = i2 + "px", e2.style.visibility = "hidden", this.jm.view.e_panel.appendChild(e2), e2;
  1370. }
  1371. clear(e2) {
  1372. e2.parentNode.removeChild(e2);
  1373. }
  1374. draw_background(e2) {
  1375. return new Promise(function(t2, i2) {
  1376. const n2 = this.options.background;
  1377. n2 && "transparent" !== n2 && (e2.fillStyle = this.options.background, e2.fillRect(0, 0, this.jm.view.size.w, this.jm.view.size.h)), t2(e2);
  1378. }.bind(this));
  1379. }
  1380. draw_lines(e2) {
  1381. return new Promise(function(t2, i2) {
  1382. this.jm.view.graph.copy_to(e2, function() {
  1383. t2(e2);
  1384. });
  1385. }.bind(this));
  1386. }
  1387. draw_nodes(e2) {
  1388. return o.default.toSvg(this.jm.view.e_nodes, { style: { zoom: 1 } }).then(this.load_image).then(function(t2) {
  1389. return e2.drawImage(t2, 0, 0), e2;
  1390. });
  1391. }
  1392. draw_watermark(e2, t2) {
  1393. return t2.textBaseline = "bottom", t2.fillStyle = "#000", t2.font = "11px Verdana,Arial,Helvetica,sans-serif", this.options.watermark.left && (t2.textAlign = "left", t2.fillText(this.options.watermark.left, 5.5, e2.height - 2.5)), this.options.watermark.right && (t2.textAlign = "right", t2.fillText(this.options.watermark.right, e2.width - 5.5, e2.height - 2.5)), t2;
  1394. }
  1395. load_image(e2) {
  1396. return new Promise(function(t2, i2) {
  1397. let n2 = new Image();
  1398. n2.onload = function() {
  1399. t2(n2);
  1400. }, n2.onerror = i2, n2.src = e2;
  1401. });
  1402. }
  1403. download(e2) {
  1404. var t2 = (this.options.filename || this.jm.mind.name) + ".png";
  1405. if (navigator.msSaveBlob && e2.msToBlob) {
  1406. var i2 = e2.msToBlob();
  1407. navigator.msSaveBlob(i2, t2);
  1408. } else {
  1409. var n2 = e2.toDataURL(), o2 = r.c("a");
  1410. if ("download" in o2) {
  1411. o2.style.visibility = "hidden", o2.href = n2, o2.download = t2, r.d.body.appendChild(o2);
  1412. var s2 = r.d.createEvent("MouseEvents");
  1413. s2.initEvent("click", true, true), o2.dispatchEvent(s2), r.d.body.removeChild(o2);
  1414. } else location.href = n2;
  1415. }
  1416. }
  1417. }
  1418. let d = new n.default.plugin("screenshot", function(e2, t2) {
  1419. var i2 = new a(e2, t2);
  1420. e2.screenshot = i2, e2.shoot = function() {
  1421. i2.shoot();
  1422. };
  1423. });
  1424. n.default.register_plugin(d);
  1425. });
  1426. })();
  1427. const jsonMind = {
  1428. isFirst: true,
  1429. transform(json) {
  1430. const result = [];
  1431. if (Utils.isObject(json)) {
  1432. for (const key in json) {
  1433. let value = json[key];
  1434. const isArray = Array.isArray(value);
  1435. const type = Utils.getPropType(value);
  1436. if (isArray && value.length > 0) value = Utils.getMaxKeysAndDepthObject(value);
  1437. const isObject = Object.is(Utils.getType(value), "object");
  1438. const keys = isObject ? Object.keys(value) : null;
  1439. const children = this.transform(value);
  1440. const topic = `${key}<span class="datatype">${type}</span>`;
  1441. result.push({ keys, topic, isArray, children, chain: key, id: Utils.random() });
  1442. }
  1443. }
  1444. return result;
  1445. },
  1446. getChain(node) {
  1447. let chain = node?.data?.chain;
  1448. if (!node?.parent) return chain;
  1449. const parent = node.parent;
  1450. const parentChain = this.getChain(parent);
  1451. if (parent.data.isArray) return `${parentChain}[i].${chain}`;
  1452. if (chain.includes(".")) return `${parentChain}["${chain}"]`;
  1453. return `${parentChain}.${chain}`;
  1454. },
  1455. show(json) {
  1456. let isArray = Array.isArray(json);
  1457. if (isArray) {
  1458. if (typeof json[0] !== "object") {
  1459. layer.msg("无法生成脑图", { time: 1e3 });
  1460. return this;
  1461. }
  1462. json = Utils.getMaxKeysAndDepthObject(json);
  1463. }
  1464. if (!this.isFirst) return this;
  1465. const children = this.transform(json);
  1466. _unsafeWindow.GLOBAL_JSMIND.show({
  1467. format: "node_tree",
  1468. meta: { version: "1.0", name: "JSON脑图", author: "1220301855@qq.com" },
  1469. data: { isArray, children, id: "root", chain: "Root", topic: "Root", direction: "left", keys: Object.keys(json) }
  1470. });
  1471. this.isFirst = false;
  1472. return this;
  1473. },
  1474. event() {
  1475. Utils.addEvent("click mouseover", "jmnode", ({ type, ctrlKey, target }) => {
  1476. const nodeid = Utils.attr(target, "nodeid");
  1477. const node = _unsafeWindow.GLOBAL_JSMIND.get_node(nodeid);
  1478. const chain = this.getChain(node);
  1479. if (!chain) return;
  1480. if (type === "click") {
  1481. if (ctrlKey) return _GM_setClipboard(chain), layer.msg("复制成功", { time: 1500 });
  1482. if (node?.data?.keys?.length > 0) this.popup(chain, node?.data?.keys);
  1483. } else {
  1484. const content = `<i>ctrlclick 复制</i><br/><b>路径:</b>${chain}`;
  1485. tippy(target, { content, duration: 800, theme: "layer", allowHTML: true, maxWidth: "none" }).show();
  1486. }
  1487. });
  1488. return this;
  1489. },
  1490. popup(chain, keys) {
  1491. layer.open({
  1492. type: 1,
  1493. move: false,
  1494. shadeClose: true,
  1495. title: " 节点",
  1496. content: function() {
  1497. const chain2 = Utils.createElement("div");
  1498. const chainCon = Utils.createElement("div");
  1499. chain2.appendChild(chainCon);
  1500. const content = Utils.createElement("div", { class: "js-mind-child-node" });
  1501. const copy = Utils.createElement("div", { title: "复制", class: "js-mind-copy" });
  1502. content.appendChild(copy);
  1503. keys.forEach((i) => {
  1504. const child = Utils.createElement("div");
  1505. child.textContent = i;
  1506. content.appendChild(child);
  1507. });
  1508. return content.outerHTML;
  1509. }(),
  1510. success(layero) {
  1511. layero.on("click", ".js-mind-copy", function() {
  1512. _GM_setClipboard(chain + "\n\n" + keys.join("\n"));
  1513. layer.msg("复制成功", { time: 1500 });
  1514. });
  1515. }
  1516. });
  1517. },
  1518. init(json) {
  1519. if (_unsafeWindow.GLOBAL_JSMIND) return;
  1520. _unsafeWindow.GLOBAL_JSMIND = new require$$0({
  1521. mode: "side",
  1522. editable: false,
  1523. container: "mindBox",
  1524. view: { hmargin: 50, vmargin: 50, engine: "svg", draggable: true, support_html: false, line_color: "#C4C9D0" },
  1525. layout: { vspace: 5, hspace: 130 }
  1526. });
  1527. this.show(json).event();
  1528. }
  1529. };
  1530. const mindBox = Utils.query("#mindBox");
  1531. const formatBox = Utils.query("#formatBox");
  1532. const rawTextBox = Utils.query("#rawTextBox");
  1533. const rawTextPre = Utils.query("pre", rawTextBox);
  1534. const tabs = {
  1535. viewFormater() {
  1536. const value = _unsafeWindow.FILTER_VALUE || "";
  1537. Utils.query(".filter").value = value;
  1538. Utils.attr(Utils.query(".clear"), "hidden", !value);
  1539. },
  1540. saveJson() {
  1541. if (Utils.isVisible(mindBox)) return _unsafeWindow.GLOBAL_JSMIND.shoot();
  1542. const content = rawTextPre.textContent || _unsafeWindow.RAW_TEXT;
  1543. const filename = (/* @__PURE__ */ new Date()).getTime() + ".json";
  1544. Utils.downloadText(content, filename);
  1545. },
  1546. copyJson() {
  1547. _GM_setClipboard(rawTextPre.textContent || _unsafeWindow.RAW_TEXT);
  1548. layer.msg("复制成功", { time: 1500 });
  1549. },
  1550. sorted(el) {
  1551. el.textContent = _unsafeWindow.JSON_FORMATER.sorted();
  1552. },
  1553. collapseAll() {
  1554. Utils.isVisible(formatBox) ? _unsafeWindow.JSON_FORMATER.collapseAll() : _unsafeWindow.GLOBAL_JSMIND.collapse_all();
  1555. },
  1556. expandAll() {
  1557. if (Utils.isVisible(formatBox)) return _unsafeWindow.JSON_FORMATER.expandAll();
  1558. _unsafeWindow.GLOBAL_JSMIND.expand_all();
  1559. _unsafeWindow.GLOBAL_JSMIND.scroll_node_to_center(_unsafeWindow.GLOBAL_JSMIND?.get_root());
  1560. },
  1561. viewMind() {
  1562. jsonMind.init(_unsafeWindow.GLOBAL_JSON);
  1563. _unsafeWindow.GLOBAL_JSMIND.scroll_node_to_center(_unsafeWindow.GLOBAL_JSMIND.get_root());
  1564. },
  1565. jsoncrack() {
  1566. const theme2 = (_GM_getValue("theme") || "light").replace(/-.*/, "");
  1567. layer.closeAll();
  1568. layer.open({
  1569. type: 1,
  1570. move: false,
  1571. title: false,
  1572. area: ["100vw", "100vh"],
  1573. content: `<iframe id="jsoncrackEmbed" src="${URL$1.JSON_CRACK_WIDGET}"></iframe>`,
  1574. success() {
  1575. const jsonCrackEmbed = Utils.query("#jsoncrackEmbed");
  1576. window?.addEventListener("message", () => {
  1577. const msg = { options: { theme: theme2 }, json: _unsafeWindow.RAW_TEXT };
  1578. jsonCrackEmbed?.contentWindow?.postMessage(msg, "*");
  1579. });
  1580. }
  1581. });
  1582. },
  1583. _setRawText() {
  1584. let rawText = _unsafeWindow.RAW_TEXT;
  1585. if (_unsafeWindow.GLOBAL_JSONP_FUN) {
  1586. rawText = `${_unsafeWindow.GLOBAL_JSONP_FUN}(${rawText})`;
  1587. }
  1588. rawTextPre.textContent = rawText;
  1589. },
  1590. firstFormat: true,
  1591. viewRawText() {
  1592. if (!this.firstFormat) return;
  1593. this.firstFormat = false;
  1594. this._setRawText();
  1595. },
  1596. isBeautify: false,
  1597. beautify() {
  1598. this.isBeautify = !this.isBeautify;
  1599. if (!this.isBeautify) return this._setRawText();
  1600. let str = Utils.stringify(_unsafeWindow.GLOBAL_JSON, null, 2);
  1601. if (_unsafeWindow.GLOBAL_JSONP_FUN) {
  1602. str = `${_unsafeWindow.GLOBAL_JSONP_FUN}(${str})`;
  1603. }
  1604. rawTextPre.textContent = str;
  1605. },
  1606. init() {
  1607. Utils.addEvent("click", ".btn", ({ target }) => {
  1608. const id = target.id;
  1609. if (Utils.hasClass(target, "tabs-item")) {
  1610. const clas = "active";
  1611. Utils.removeClass(Utils.queryAll(".tabs-item"), clas);
  1612. Utils.addClass(target, clas);
  1613. Utils.removeClass(Utils.queryAll("div[data-for]"), clas);
  1614. Utils.addClass(Utils.query(`div[data-for="${id}"]`), clas);
  1615. const template = Utils.query(`template[data-for='${id}']`);
  1616. Utils.query(".toolbar").innerHTML = template.innerHTML;
  1617. }
  1618. this[id](target);
  1619. });
  1620. }
  1621. };
  1622. window.addEventListener("message", function({ data }) {
  1623. if (!data?.reload) return;
  1624. mindBox.innerHTML = "";
  1625. jsonMind.isFirst = true;
  1626. tabs.isBeautify = false;
  1627. tabs.firstFormat = true;
  1628. _unsafeWindow.GLOBAL_JSMIND = void 0;
  1629. if (Utils.isVisible(rawTextBox)) return tabs.viewRawText();
  1630. if (Utils.isVisible(mindBox)) return jsonMind.init(_unsafeWindow.GLOBAL_JSON);
  1631. });
  1632. const theme = {
  1633. changeTheme(theme2) {
  1634. _GM_setValue("theme", theme2) & this.setTheme();
  1635. },
  1636. setTheme() {
  1637. const theme2 = _GM_getValue("theme") || "default";
  1638. _unsafeWindow.JSON_FORMATER.setTheme(theme2);
  1639. }
  1640. };
  1641. const http_form = `
  1642. <form class="httpRequest">
  1643. <div class="requestbox">
  1644. <select name="method">
  1645. <option value="POST">POST</option>
  1646. <option value="GET">GET</option>
  1647. <option value="PUT">PUT</option>
  1648. <option value="DELETE">DELETE</option>
  1649. </select>
  1650. <input name="url" placeholder="请求地址" />
  1651. <select name="contentType">
  1652. <option value="application/x-www-form-urlencoded;charset=UTF-8">urlencoded</option>
  1653. <option value="application/json;charset=UTF-8">application/json</option>
  1654. </select>
  1655. <button type="submit">发送</button>
  1656. </div>
  1657. <div class="textarea">
  1658. <input name="headers" placeholder='请求头 {"token": "test"}' />
  1659. <input name="params" placeholder='请求参数 {"id": "test", ""name": "test"}' />
  1660. </div>
  1661. </form>
  1662. `;
  1663. const tools = {
  1664. inputJson() {
  1665. layer.prompt(
  1666. {
  1667. move: false,
  1668. formType: 2,
  1669. btn: ["确认"],
  1670. shadeClose: true,
  1671. title: "JSON 输入",
  1672. area: ["400px", "300px"],
  1673. maxlength: Number.MAX_VALUE
  1674. },
  1675. (text) => {
  1676. if (!text) return layer.msg("内容不能为空", { time: 1500 });
  1677. const { rawText, jsonpFun } = Utils.matchJsonp(text);
  1678. try {
  1679. const json = Utils.parse(rawText);
  1680. this.reload(json, rawText, jsonpFun);
  1681. } catch (e) {
  1682. layer.msg("JSON格式不正确", { time: 1500 });
  1683. console.log("格式化异常: ", e);
  1684. }
  1685. }
  1686. );
  1687. return this;
  1688. },
  1689. fetchJson() {
  1690. const success = () => {
  1691. const formElem = Utils.query("form");
  1692. formElem.addEventListener("submit", (event) => {
  1693. event.preventDefault();
  1694. const formData = new FormData(formElem);
  1695. const submitData = {};
  1696. for (const [name, value] of formData) {
  1697. submitData[name] = value;
  1698. }
  1699. this._submit(submitData);
  1700. });
  1701. };
  1702. layer.open({
  1703. success,
  1704. type: 1,
  1705. shadeClose: true,
  1706. title: "HTTP 请求",
  1707. content: http_form
  1708. });
  1709. return this;
  1710. },
  1711. async _submit(submitData) {
  1712. if (!submitData.url) return layer.msg("请求地址不能为空");
  1713. let params = submitData.params;
  1714. let headers = submitData.headers;
  1715. if (headers && !(headers.startsWith("{") && headers.endsWith("}"))) {
  1716. return layer.msg("请求头 格式不合法");
  1717. }
  1718. if (params && !(params.startsWith("{") && params.endsWith("}"))) {
  1719. return layer.msg("请求参数 格式不合法");
  1720. }
  1721. try {
  1722. layer.load();
  1723. const response = await fetch(URL$1.ONLINE_REQUEST, {
  1724. timeout: 5e3,
  1725. method: "POST",
  1726. body: Utils.stringify(submitData),
  1727. headers: { "Content-Type": "application/json" }
  1728. });
  1729. let result = await response.json();
  1730. if (Utils.isObject(result)) result = Utils.stringify(result);
  1731. const { rawText, jsonpFun } = Utils.matchJsonp(result);
  1732. const json = Utils.parse(rawText);
  1733. this.reload(json, rawText, jsonpFun);
  1734. } catch (e) {
  1735. layer.closeAll();
  1736. layer.msg("请求异常:" + e.message);
  1737. console.log("HTTP 请求异常:", e);
  1738. }
  1739. },
  1740. reload(json, rawText, jsonpFun) {
  1741. layer.closeAll();
  1742. _unsafeWindow.RAW_TEXT = rawText;
  1743. _unsafeWindow.GLOBAL_JSON = json;
  1744. _unsafeWindow.GLOBAL_JSONP_FUN = jsonpFun;
  1745. window.postMessage({ reload: true });
  1746. }
  1747. };
  1748. const active = "active";
  1749. const handleBar = {
  1750. currentTippy: null,
  1751. handle() {
  1752. const tagName = "span";
  1753. [".style", ".theme", ".tools"].forEach((selector) => {
  1754. tippy(selector, {
  1755. duration: 500,
  1756. allowHTML: true,
  1757. interactive: true,
  1758. trigger: "click",
  1759. appendTo: Utils.query(selector).parentNode,
  1760. onTrigger: (instance) => {
  1761. this.currentTippy = instance;
  1762. const target = instance.reference;
  1763. Utils.addClass(Utils.query(tagName, target), active);
  1764. const template = Utils.query("template", target);
  1765. const ul = template.content.cloneNode(true);
  1766. const type = template.dataset.type;
  1767. const value = _GM_getValue(type) || "default";
  1768. const current = Utils.query(`li[data-value=${value}]`, ul);
  1769. Utils.addClass(current, active);
  1770. const tempDiv = Utils.createElement("div");
  1771. while (ul.firstChild) tempDiv.appendChild(ul.firstChild);
  1772. instance.setContent(tempDiv.innerHTML);
  1773. },
  1774. onHide(instance) {
  1775. Utils.removeClass(Utils.query(tagName, instance.reference));
  1776. }
  1777. });
  1778. });
  1779. return this;
  1780. },
  1781. checked() {
  1782. const selector = ".rightbox li";
  1783. Utils.addEvent("click", selector, ({ target }) => {
  1784. if (Utils.hasClass(target, active)) return;
  1785. const type = target.dataset.type;
  1786. const value = target.dataset.value;
  1787. window.postMessage({ type, value });
  1788. if (Object.is(type, "tools")) return this.currentTippy.hide();
  1789. Utils.removeClass(Utils.queryAll(selector));
  1790. Utils.addClass(target, active);
  1791. });
  1792. return this;
  1793. },
  1794. init() {
  1795. this.handle().checked();
  1796. }
  1797. };
  1798. tabs.init();
  1799. theme.setTheme();
  1800. handleBar.init();
  1801. window.addEventListener("message", function({ data }) {
  1802. if (Object.is(data?.type, "tools")) return tools[data?.value]();
  1803. if (Object.is(data?.type, "theme")) return theme.changeTheme(data?.value);
  1804. });
  1805.  
  1806. })
  1807. };
  1808. }));
  1809.  
  1810. System.register("./tippy.esm-D1eoMe9a-Bn9PjR6Y.js", [], (function (exports, module) {
  1811. 'use strict';
  1812. return {
  1813. execute: (function () {
  1814.  
  1815. exports("t", tippy);
  1816.  
  1817. var top = "top";
  1818. var bottom = "bottom";
  1819. var right = "right";
  1820. var left = "left";
  1821. var auto = "auto";
  1822. var basePlacements = [top, bottom, right, left];
  1823. var start = "start";
  1824. var end = "end";
  1825. var clippingParents = "clippingParents";
  1826. var viewport = "viewport";
  1827. var popper = "popper";
  1828. var reference = "reference";
  1829. var variationPlacements = /* @__PURE__ */ basePlacements.reduce(function(acc, placement) {
  1830. return acc.concat([placement + "-" + start, placement + "-" + end]);
  1831. }, []);
  1832. var placements = /* @__PURE__ */ [].concat(basePlacements, [auto]).reduce(function(acc, placement) {
  1833. return acc.concat([placement, placement + "-" + start, placement + "-" + end]);
  1834. }, []);
  1835. var beforeRead = "beforeRead";
  1836. var read = "read";
  1837. var afterRead = "afterRead";
  1838. var beforeMain = "beforeMain";
  1839. var main = "main";
  1840. var afterMain = "afterMain";
  1841. var beforeWrite = "beforeWrite";
  1842. var write = "write";
  1843. var afterWrite = "afterWrite";
  1844. var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite];
  1845. function getNodeName(element) {
  1846. return element ? (element.nodeName || "").toLowerCase() : null;
  1847. }
  1848. function getWindow(node) {
  1849. if (node == null) {
  1850. return window;
  1851. }
  1852. if (node.toString() !== "[object Window]") {
  1853. var ownerDocument = node.ownerDocument;
  1854. return ownerDocument ? ownerDocument.defaultView || window : window;
  1855. }
  1856. return node;
  1857. }
  1858. function isElement$1(node) {
  1859. var OwnElement = getWindow(node).Element;
  1860. return node instanceof OwnElement || node instanceof Element;
  1861. }
  1862. function isHTMLElement(node) {
  1863. var OwnElement = getWindow(node).HTMLElement;
  1864. return node instanceof OwnElement || node instanceof HTMLElement;
  1865. }
  1866. function isShadowRoot(node) {
  1867. if (typeof ShadowRoot === "undefined") {
  1868. return false;
  1869. }
  1870. var OwnElement = getWindow(node).ShadowRoot;
  1871. return node instanceof OwnElement || node instanceof ShadowRoot;
  1872. }
  1873. function applyStyles(_ref) {
  1874. var state = _ref.state;
  1875. Object.keys(state.elements).forEach(function(name) {
  1876. var style = state.styles[name] || {};
  1877. var attributes = state.attributes[name] || {};
  1878. var element = state.elements[name];
  1879. if (!isHTMLElement(element) || !getNodeName(element)) {
  1880. return;
  1881. }
  1882. Object.assign(element.style, style);
  1883. Object.keys(attributes).forEach(function(name2) {
  1884. var value = attributes[name2];
  1885. if (value === false) {
  1886. element.removeAttribute(name2);
  1887. } else {
  1888. element.setAttribute(name2, value === true ? "" : value);
  1889. }
  1890. });
  1891. });
  1892. }
  1893. function effect$2(_ref2) {
  1894. var state = _ref2.state;
  1895. var initialStyles = {
  1896. popper: {
  1897. position: state.options.strategy,
  1898. left: "0",
  1899. top: "0",
  1900. margin: "0"
  1901. },
  1902. arrow: {
  1903. position: "absolute"
  1904. },
  1905. reference: {}
  1906. };
  1907. Object.assign(state.elements.popper.style, initialStyles.popper);
  1908. state.styles = initialStyles;
  1909. if (state.elements.arrow) {
  1910. Object.assign(state.elements.arrow.style, initialStyles.arrow);
  1911. }
  1912. return function() {
  1913. Object.keys(state.elements).forEach(function(name) {
  1914. var element = state.elements[name];
  1915. var attributes = state.attributes[name] || {};
  1916. var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]);
  1917. var style = styleProperties.reduce(function(style2, property) {
  1918. style2[property] = "";
  1919. return style2;
  1920. }, {});
  1921. if (!isHTMLElement(element) || !getNodeName(element)) {
  1922. return;
  1923. }
  1924. Object.assign(element.style, style);
  1925. Object.keys(attributes).forEach(function(attribute) {
  1926. element.removeAttribute(attribute);
  1927. });
  1928. });
  1929. };
  1930. }
  1931. const applyStyles$1 = {
  1932. name: "applyStyles",
  1933. enabled: true,
  1934. phase: "write",
  1935. fn: applyStyles,
  1936. effect: effect$2,
  1937. requires: ["computeStyles"]
  1938. };
  1939. function getBasePlacement$1(placement) {
  1940. return placement.split("-")[0];
  1941. }
  1942. var max = Math.max;
  1943. var min = Math.min;
  1944. var round = Math.round;
  1945. function getUAString() {
  1946. var uaData = navigator.userAgentData;
  1947. if (uaData != null && uaData.brands && Array.isArray(uaData.brands)) {
  1948. return uaData.brands.map(function(item) {
  1949. return item.brand + "/" + item.version;
  1950. }).join(" ");
  1951. }
  1952. return navigator.userAgent;
  1953. }
  1954. function isLayoutViewport() {
  1955. return !/^((?!chrome|android).)*safari/i.test(getUAString());
  1956. }
  1957. function getBoundingClientRect(element, includeScale, isFixedStrategy) {
  1958. if (includeScale === void 0) {
  1959. includeScale = false;
  1960. }
  1961. if (isFixedStrategy === void 0) {
  1962. isFixedStrategy = false;
  1963. }
  1964. var clientRect = element.getBoundingClientRect();
  1965. var scaleX = 1;
  1966. var scaleY = 1;
  1967. if (includeScale && isHTMLElement(element)) {
  1968. scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;
  1969. scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;
  1970. }
  1971. var _ref = isElement$1(element) ? getWindow(element) : window, visualViewport = _ref.visualViewport;
  1972. var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;
  1973. var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;
  1974. var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;
  1975. var width = clientRect.width / scaleX;
  1976. var height = clientRect.height / scaleY;
  1977. return {
  1978. width,
  1979. height,
  1980. top: y,
  1981. right: x + width,
  1982. bottom: y + height,
  1983. left: x,
  1984. x,
  1985. y
  1986. };
  1987. }
  1988. function getLayoutRect(element) {
  1989. var clientRect = getBoundingClientRect(element);
  1990. var width = element.offsetWidth;
  1991. var height = element.offsetHeight;
  1992. if (Math.abs(clientRect.width - width) <= 1) {
  1993. width = clientRect.width;
  1994. }
  1995. if (Math.abs(clientRect.height - height) <= 1) {
  1996. height = clientRect.height;
  1997. }
  1998. return {
  1999. x: element.offsetLeft,
  2000. y: element.offsetTop,
  2001. width,
  2002. height
  2003. };
  2004. }
  2005. function contains(parent, child) {
  2006. var rootNode = child.getRootNode && child.getRootNode();
  2007. if (parent.contains(child)) {
  2008. return true;
  2009. } else if (rootNode && isShadowRoot(rootNode)) {
  2010. var next = child;
  2011. do {
  2012. if (next && parent.isSameNode(next)) {
  2013. return true;
  2014. }
  2015. next = next.parentNode || next.host;
  2016. } while (next);
  2017. }
  2018. return false;
  2019. }
  2020. function getComputedStyle(element) {
  2021. return getWindow(element).getComputedStyle(element);
  2022. }
  2023. function isTableElement(element) {
  2024. return ["table", "td", "th"].indexOf(getNodeName(element)) >= 0;
  2025. }
  2026. function getDocumentElement(element) {
  2027. return ((isElement$1(element) ? element.ownerDocument : (
  2028. // $FlowFixMe[prop-missing]
  2029. element.document
  2030. )) || window.document).documentElement;
  2031. }
  2032. function getParentNode(element) {
  2033. if (getNodeName(element) === "html") {
  2034. return element;
  2035. }
  2036. return (
  2037. // this is a quicker (but less type safe) way to save quite some bytes from the bundle
  2038. // $FlowFixMe[incompatible-return]
  2039. // $FlowFixMe[prop-missing]
  2040. element.assignedSlot || // step into the shadow DOM of the parent of a slotted node
  2041. element.parentNode || // DOM Element detected
  2042. (isShadowRoot(element) ? element.host : null) || // ShadowRoot detected
  2043. // $FlowFixMe[incompatible-call]: HTMLElement is a Node
  2044. getDocumentElement(element)
  2045. );
  2046. }
  2047. function getTrueOffsetParent(element) {
  2048. if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837
  2049. getComputedStyle(element).position === "fixed") {
  2050. return null;
  2051. }
  2052. return element.offsetParent;
  2053. }
  2054. function getContainingBlock(element) {
  2055. var isFirefox = /firefox/i.test(getUAString());
  2056. var isIE = /Trident/i.test(getUAString());
  2057. if (isIE && isHTMLElement(element)) {
  2058. var elementCss = getComputedStyle(element);
  2059. if (elementCss.position === "fixed") {
  2060. return null;
  2061. }
  2062. }
  2063. var currentNode = getParentNode(element);
  2064. if (isShadowRoot(currentNode)) {
  2065. currentNode = currentNode.host;
  2066. }
  2067. while (isHTMLElement(currentNode) && ["html", "body"].indexOf(getNodeName(currentNode)) < 0) {
  2068. var css = getComputedStyle(currentNode);
  2069. if (css.transform !== "none" || css.perspective !== "none" || css.contain === "paint" || ["transform", "perspective"].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === "filter" || isFirefox && css.filter && css.filter !== "none") {
  2070. return currentNode;
  2071. } else {
  2072. currentNode = currentNode.parentNode;
  2073. }
  2074. }
  2075. return null;
  2076. }
  2077. function getOffsetParent(element) {
  2078. var window2 = getWindow(element);
  2079. var offsetParent = getTrueOffsetParent(element);
  2080. while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === "static") {
  2081. offsetParent = getTrueOffsetParent(offsetParent);
  2082. }
  2083. if (offsetParent && (getNodeName(offsetParent) === "html" || getNodeName(offsetParent) === "body" && getComputedStyle(offsetParent).position === "static")) {
  2084. return window2;
  2085. }
  2086. return offsetParent || getContainingBlock(element) || window2;
  2087. }
  2088. function getMainAxisFromPlacement(placement) {
  2089. return ["top", "bottom"].indexOf(placement) >= 0 ? "x" : "y";
  2090. }
  2091. function within(min$1, value, max$1) {
  2092. return max(min$1, min(value, max$1));
  2093. }
  2094. function withinMaxClamp(min2, value, max2) {
  2095. var v = within(min2, value, max2);
  2096. return v > max2 ? max2 : v;
  2097. }
  2098. function getFreshSideObject() {
  2099. return {
  2100. top: 0,
  2101. right: 0,
  2102. bottom: 0,
  2103. left: 0
  2104. };
  2105. }
  2106. function mergePaddingObject(paddingObject) {
  2107. return Object.assign({}, getFreshSideObject(), paddingObject);
  2108. }
  2109. function expandToHashMap(value, keys) {
  2110. return keys.reduce(function(hashMap, key) {
  2111. hashMap[key] = value;
  2112. return hashMap;
  2113. }, {});
  2114. }
  2115. var toPaddingObject = function toPaddingObject2(padding, state) {
  2116. padding = typeof padding === "function" ? padding(Object.assign({}, state.rects, {
  2117. placement: state.placement
  2118. })) : padding;
  2119. return mergePaddingObject(typeof padding !== "number" ? padding : expandToHashMap(padding, basePlacements));
  2120. };
  2121. function arrow(_ref) {
  2122. var _state$modifiersData$;
  2123. var state = _ref.state, name = _ref.name, options = _ref.options;
  2124. var arrowElement = state.elements.arrow;
  2125. var popperOffsets2 = state.modifiersData.popperOffsets;
  2126. var basePlacement = getBasePlacement$1(state.placement);
  2127. var axis = getMainAxisFromPlacement(basePlacement);
  2128. var isVertical = [left, right].indexOf(basePlacement) >= 0;
  2129. var len = isVertical ? "height" : "width";
  2130. if (!arrowElement || !popperOffsets2) {
  2131. return;
  2132. }
  2133. var paddingObject = toPaddingObject(options.padding, state);
  2134. var arrowRect = getLayoutRect(arrowElement);
  2135. var minProp = axis === "y" ? top : left;
  2136. var maxProp = axis === "y" ? bottom : right;
  2137. var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets2[axis] - state.rects.popper[len];
  2138. var startDiff = popperOffsets2[axis] - state.rects.reference[axis];
  2139. var arrowOffsetParent = getOffsetParent(arrowElement);
  2140. var clientSize = arrowOffsetParent ? axis === "y" ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;
  2141. var centerToReference = endDiff / 2 - startDiff / 2;
  2142. var min2 = paddingObject[minProp];
  2143. var max2 = clientSize - arrowRect[len] - paddingObject[maxProp];
  2144. var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;
  2145. var offset2 = within(min2, center, max2);
  2146. var axisProp = axis;
  2147. state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset2, _state$modifiersData$.centerOffset = offset2 - center, _state$modifiersData$);
  2148. }
  2149. function effect$1(_ref2) {
  2150. var state = _ref2.state, options = _ref2.options;
  2151. var _options$element = options.element, arrowElement = _options$element === void 0 ? "[data-popper-arrow]" : _options$element;
  2152. if (arrowElement == null) {
  2153. return;
  2154. }
  2155. if (typeof arrowElement === "string") {
  2156. arrowElement = state.elements.popper.querySelector(arrowElement);
  2157. if (!arrowElement) {
  2158. return;
  2159. }
  2160. }
  2161. if (!contains(state.elements.popper, arrowElement)) {
  2162. return;
  2163. }
  2164. state.elements.arrow = arrowElement;
  2165. }
  2166. const arrow$1 = {
  2167. name: "arrow",
  2168. enabled: true,
  2169. phase: "main",
  2170. fn: arrow,
  2171. effect: effect$1,
  2172. requires: ["popperOffsets"],
  2173. requiresIfExists: ["preventOverflow"]
  2174. };
  2175. function getVariation(placement) {
  2176. return placement.split("-")[1];
  2177. }
  2178. var unsetSides = {
  2179. top: "auto",
  2180. right: "auto",
  2181. bottom: "auto",
  2182. left: "auto"
  2183. };
  2184. function roundOffsetsByDPR(_ref, win) {
  2185. var x = _ref.x, y = _ref.y;
  2186. var dpr = win.devicePixelRatio || 1;
  2187. return {
  2188. x: round(x * dpr) / dpr || 0,
  2189. y: round(y * dpr) / dpr || 0
  2190. };
  2191. }
  2192. function mapToStyles(_ref2) {
  2193. var _Object$assign2;
  2194. var popper2 = _ref2.popper, popperRect = _ref2.popperRect, placement = _ref2.placement, variation = _ref2.variation, offsets = _ref2.offsets, position = _ref2.position, gpuAcceleration = _ref2.gpuAcceleration, adaptive = _ref2.adaptive, roundOffsets = _ref2.roundOffsets, isFixed = _ref2.isFixed;
  2195. var _offsets$x = offsets.x, x = _offsets$x === void 0 ? 0 : _offsets$x, _offsets$y = offsets.y, y = _offsets$y === void 0 ? 0 : _offsets$y;
  2196. var _ref3 = typeof roundOffsets === "function" ? roundOffsets({
  2197. x,
  2198. y
  2199. }) : {
  2200. x,
  2201. y
  2202. };
  2203. x = _ref3.x;
  2204. y = _ref3.y;
  2205. var hasX = offsets.hasOwnProperty("x");
  2206. var hasY = offsets.hasOwnProperty("y");
  2207. var sideX = left;
  2208. var sideY = top;
  2209. var win = window;
  2210. if (adaptive) {
  2211. var offsetParent = getOffsetParent(popper2);
  2212. var heightProp = "clientHeight";
  2213. var widthProp = "clientWidth";
  2214. if (offsetParent === getWindow(popper2)) {
  2215. offsetParent = getDocumentElement(popper2);
  2216. if (getComputedStyle(offsetParent).position !== "static" && position === "absolute") {
  2217. heightProp = "scrollHeight";
  2218. widthProp = "scrollWidth";
  2219. }
  2220. }
  2221. offsetParent = offsetParent;
  2222. if (placement === top || (placement === left || placement === right) && variation === end) {
  2223. sideY = bottom;
  2224. var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : (
  2225. // $FlowFixMe[prop-missing]
  2226. offsetParent[heightProp]
  2227. );
  2228. y -= offsetY - popperRect.height;
  2229. y *= gpuAcceleration ? 1 : -1;
  2230. }
  2231. if (placement === left || (placement === top || placement === bottom) && variation === end) {
  2232. sideX = right;
  2233. var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : (
  2234. // $FlowFixMe[prop-missing]
  2235. offsetParent[widthProp]
  2236. );
  2237. x -= offsetX - popperRect.width;
  2238. x *= gpuAcceleration ? 1 : -1;
  2239. }
  2240. }
  2241. var commonStyles = Object.assign({
  2242. position
  2243. }, adaptive && unsetSides);
  2244. var _ref4 = roundOffsets === true ? roundOffsetsByDPR({
  2245. x,
  2246. y
  2247. }, getWindow(popper2)) : {
  2248. x,
  2249. y
  2250. };
  2251. x = _ref4.x;
  2252. y = _ref4.y;
  2253. if (gpuAcceleration) {
  2254. var _Object$assign;
  2255. return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? "0" : "", _Object$assign[sideX] = hasX ? "0" : "", _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? "translate(" + x + "px, " + y + "px)" : "translate3d(" + x + "px, " + y + "px, 0)", _Object$assign));
  2256. }
  2257. return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + "px" : "", _Object$assign2[sideX] = hasX ? x + "px" : "", _Object$assign2.transform = "", _Object$assign2));
  2258. }
  2259. function computeStyles(_ref5) {
  2260. var state = _ref5.state, options = _ref5.options;
  2261. var _options$gpuAccelerat = options.gpuAcceleration, gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat, _options$adaptive = options.adaptive, adaptive = _options$adaptive === void 0 ? true : _options$adaptive, _options$roundOffsets = options.roundOffsets, roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;
  2262. var commonStyles = {
  2263. placement: getBasePlacement$1(state.placement),
  2264. variation: getVariation(state.placement),
  2265. popper: state.elements.popper,
  2266. popperRect: state.rects.popper,
  2267. gpuAcceleration,
  2268. isFixed: state.options.strategy === "fixed"
  2269. };
  2270. if (state.modifiersData.popperOffsets != null) {
  2271. state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {
  2272. offsets: state.modifiersData.popperOffsets,
  2273. position: state.options.strategy,
  2274. adaptive,
  2275. roundOffsets
  2276. })));
  2277. }
  2278. if (state.modifiersData.arrow != null) {
  2279. state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {
  2280. offsets: state.modifiersData.arrow,
  2281. position: "absolute",
  2282. adaptive: false,
  2283. roundOffsets
  2284. })));
  2285. }
  2286. state.attributes.popper = Object.assign({}, state.attributes.popper, {
  2287. "data-popper-placement": state.placement
  2288. });
  2289. }
  2290. const computeStyles$1 = {
  2291. name: "computeStyles",
  2292. enabled: true,
  2293. phase: "beforeWrite",
  2294. fn: computeStyles,
  2295. data: {}
  2296. };
  2297. var passive = {
  2298. passive: true
  2299. };
  2300. function effect(_ref) {
  2301. var state = _ref.state, instance = _ref.instance, options = _ref.options;
  2302. var _options$scroll = options.scroll, scroll = _options$scroll === void 0 ? true : _options$scroll, _options$resize = options.resize, resize = _options$resize === void 0 ? true : _options$resize;
  2303. var window2 = getWindow(state.elements.popper);
  2304. var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);
  2305. if (scroll) {
  2306. scrollParents.forEach(function(scrollParent) {
  2307. scrollParent.addEventListener("scroll", instance.update, passive);
  2308. });
  2309. }
  2310. if (resize) {
  2311. window2.addEventListener("resize", instance.update, passive);
  2312. }
  2313. return function() {
  2314. if (scroll) {
  2315. scrollParents.forEach(function(scrollParent) {
  2316. scrollParent.removeEventListener("scroll", instance.update, passive);
  2317. });
  2318. }
  2319. if (resize) {
  2320. window2.removeEventListener("resize", instance.update, passive);
  2321. }
  2322. };
  2323. }
  2324. const eventListeners = {
  2325. name: "eventListeners",
  2326. enabled: true,
  2327. phase: "write",
  2328. fn: function fn() {
  2329. },
  2330. effect,
  2331. data: {}
  2332. };
  2333. var hash$1 = {
  2334. left: "right",
  2335. right: "left",
  2336. bottom: "top",
  2337. top: "bottom"
  2338. };
  2339. function getOppositePlacement(placement) {
  2340. return placement.replace(/left|right|bottom|top/g, function(matched) {
  2341. return hash$1[matched];
  2342. });
  2343. }
  2344. var hash = {
  2345. start: "end",
  2346. end: "start"
  2347. };
  2348. function getOppositeVariationPlacement(placement) {
  2349. return placement.replace(/start|end/g, function(matched) {
  2350. return hash[matched];
  2351. });
  2352. }
  2353. function getWindowScroll(node) {
  2354. var win = getWindow(node);
  2355. var scrollLeft = win.pageXOffset;
  2356. var scrollTop = win.pageYOffset;
  2357. return {
  2358. scrollLeft,
  2359. scrollTop
  2360. };
  2361. }
  2362. function getWindowScrollBarX(element) {
  2363. return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;
  2364. }
  2365. function getViewportRect(element, strategy) {
  2366. var win = getWindow(element);
  2367. var html = getDocumentElement(element);
  2368. var visualViewport = win.visualViewport;
  2369. var width = html.clientWidth;
  2370. var height = html.clientHeight;
  2371. var x = 0;
  2372. var y = 0;
  2373. if (visualViewport) {
  2374. width = visualViewport.width;
  2375. height = visualViewport.height;
  2376. var layoutViewport = isLayoutViewport();
  2377. if (layoutViewport || !layoutViewport && strategy === "fixed") {
  2378. x = visualViewport.offsetLeft;
  2379. y = visualViewport.offsetTop;
  2380. }
  2381. }
  2382. return {
  2383. width,
  2384. height,
  2385. x: x + getWindowScrollBarX(element),
  2386. y
  2387. };
  2388. }
  2389. function getDocumentRect(element) {
  2390. var _element$ownerDocumen;
  2391. var html = getDocumentElement(element);
  2392. var winScroll = getWindowScroll(element);
  2393. var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;
  2394. var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);
  2395. var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);
  2396. var x = -winScroll.scrollLeft + getWindowScrollBarX(element);
  2397. var y = -winScroll.scrollTop;
  2398. if (getComputedStyle(body || html).direction === "rtl") {
  2399. x += max(html.clientWidth, body ? body.clientWidth : 0) - width;
  2400. }
  2401. return {
  2402. width,
  2403. height,
  2404. x,
  2405. y
  2406. };
  2407. }
  2408. function isScrollParent(element) {
  2409. var _getComputedStyle = getComputedStyle(element), overflow = _getComputedStyle.overflow, overflowX = _getComputedStyle.overflowX, overflowY = _getComputedStyle.overflowY;
  2410. return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);
  2411. }
  2412. function getScrollParent(node) {
  2413. if (["html", "body", "#document"].indexOf(getNodeName(node)) >= 0) {
  2414. return node.ownerDocument.body;
  2415. }
  2416. if (isHTMLElement(node) && isScrollParent(node)) {
  2417. return node;
  2418. }
  2419. return getScrollParent(getParentNode(node));
  2420. }
  2421. function listScrollParents(element, list) {
  2422. var _element$ownerDocumen;
  2423. if (list === void 0) {
  2424. list = [];
  2425. }
  2426. var scrollParent = getScrollParent(element);
  2427. var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);
  2428. var win = getWindow(scrollParent);
  2429. var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;
  2430. var updatedList = list.concat(target);
  2431. return isBody ? updatedList : (
  2432. // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here
  2433. updatedList.concat(listScrollParents(getParentNode(target)))
  2434. );
  2435. }
  2436. function rectToClientRect(rect) {
  2437. return Object.assign({}, rect, {
  2438. left: rect.x,
  2439. top: rect.y,
  2440. right: rect.x + rect.width,
  2441. bottom: rect.y + rect.height
  2442. });
  2443. }
  2444. function getInnerBoundingClientRect(element, strategy) {
  2445. var rect = getBoundingClientRect(element, false, strategy === "fixed");
  2446. rect.top = rect.top + element.clientTop;
  2447. rect.left = rect.left + element.clientLeft;
  2448. rect.bottom = rect.top + element.clientHeight;
  2449. rect.right = rect.left + element.clientWidth;
  2450. rect.width = element.clientWidth;
  2451. rect.height = element.clientHeight;
  2452. rect.x = rect.left;
  2453. rect.y = rect.top;
  2454. return rect;
  2455. }
  2456. function getClientRectFromMixedType(element, clippingParent, strategy) {
  2457. return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement$1(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));
  2458. }
  2459. function getClippingParents(element) {
  2460. var clippingParents2 = listScrollParents(getParentNode(element));
  2461. var canEscapeClipping = ["absolute", "fixed"].indexOf(getComputedStyle(element).position) >= 0;
  2462. var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;
  2463. if (!isElement$1(clipperElement)) {
  2464. return [];
  2465. }
  2466. return clippingParents2.filter(function(clippingParent) {
  2467. return isElement$1(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== "body";
  2468. });
  2469. }
  2470. function getClippingRect(element, boundary, rootBoundary, strategy) {
  2471. var mainClippingParents = boundary === "clippingParents" ? getClippingParents(element) : [].concat(boundary);
  2472. var clippingParents2 = [].concat(mainClippingParents, [rootBoundary]);
  2473. var firstClippingParent = clippingParents2[0];
  2474. var clippingRect = clippingParents2.reduce(function(accRect, clippingParent) {
  2475. var rect = getClientRectFromMixedType(element, clippingParent, strategy);
  2476. accRect.top = max(rect.top, accRect.top);
  2477. accRect.right = min(rect.right, accRect.right);
  2478. accRect.bottom = min(rect.bottom, accRect.bottom);
  2479. accRect.left = max(rect.left, accRect.left);
  2480. return accRect;
  2481. }, getClientRectFromMixedType(element, firstClippingParent, strategy));
  2482. clippingRect.width = clippingRect.right - clippingRect.left;
  2483. clippingRect.height = clippingRect.bottom - clippingRect.top;
  2484. clippingRect.x = clippingRect.left;
  2485. clippingRect.y = clippingRect.top;
  2486. return clippingRect;
  2487. }
  2488. function computeOffsets(_ref) {
  2489. var reference2 = _ref.reference, element = _ref.element, placement = _ref.placement;
  2490. var basePlacement = placement ? getBasePlacement$1(placement) : null;
  2491. var variation = placement ? getVariation(placement) : null;
  2492. var commonX = reference2.x + reference2.width / 2 - element.width / 2;
  2493. var commonY = reference2.y + reference2.height / 2 - element.height / 2;
  2494. var offsets;
  2495. switch (basePlacement) {
  2496. case top:
  2497. offsets = {
  2498. x: commonX,
  2499. y: reference2.y - element.height
  2500. };
  2501. break;
  2502. case bottom:
  2503. offsets = {
  2504. x: commonX,
  2505. y: reference2.y + reference2.height
  2506. };
  2507. break;
  2508. case right:
  2509. offsets = {
  2510. x: reference2.x + reference2.width,
  2511. y: commonY
  2512. };
  2513. break;
  2514. case left:
  2515. offsets = {
  2516. x: reference2.x - element.width,
  2517. y: commonY
  2518. };
  2519. break;
  2520. default:
  2521. offsets = {
  2522. x: reference2.x,
  2523. y: reference2.y
  2524. };
  2525. }
  2526. var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;
  2527. if (mainAxis != null) {
  2528. var len = mainAxis === "y" ? "height" : "width";
  2529. switch (variation) {
  2530. case start:
  2531. offsets[mainAxis] = offsets[mainAxis] - (reference2[len] / 2 - element[len] / 2);
  2532. break;
  2533. case end:
  2534. offsets[mainAxis] = offsets[mainAxis] + (reference2[len] / 2 - element[len] / 2);
  2535. break;
  2536. }
  2537. }
  2538. return offsets;
  2539. }
  2540. function detectOverflow(state, options) {
  2541. if (options === void 0) {
  2542. options = {};
  2543. }
  2544. var _options = options, _options$placement = _options.placement, placement = _options$placement === void 0 ? state.placement : _options$placement, _options$strategy = _options.strategy, strategy = _options$strategy === void 0 ? state.strategy : _options$strategy, _options$boundary = _options.boundary, boundary = _options$boundary === void 0 ? clippingParents : _options$boundary, _options$rootBoundary = _options.rootBoundary, rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary, _options$elementConte = _options.elementContext, elementContext = _options$elementConte === void 0 ? popper : _options$elementConte, _options$altBoundary = _options.altBoundary, altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary, _options$padding = _options.padding, padding = _options$padding === void 0 ? 0 : _options$padding;
  2545. var paddingObject = mergePaddingObject(typeof padding !== "number" ? padding : expandToHashMap(padding, basePlacements));
  2546. var altContext = elementContext === popper ? reference : popper;
  2547. var popperRect = state.rects.popper;
  2548. var element = state.elements[altBoundary ? altContext : elementContext];
  2549. var clippingClientRect = getClippingRect(isElement$1(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);
  2550. var referenceClientRect = getBoundingClientRect(state.elements.reference);
  2551. var popperOffsets2 = computeOffsets({
  2552. reference: referenceClientRect,
  2553. element: popperRect,
  2554. placement
  2555. });
  2556. var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets2));
  2557. var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect;
  2558. var overflowOffsets = {
  2559. top: clippingClientRect.top - elementClientRect.top + paddingObject.top,
  2560. bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,
  2561. left: clippingClientRect.left - elementClientRect.left + paddingObject.left,
  2562. right: elementClientRect.right - clippingClientRect.right + paddingObject.right
  2563. };
  2564. var offsetData = state.modifiersData.offset;
  2565. if (elementContext === popper && offsetData) {
  2566. var offset2 = offsetData[placement];
  2567. Object.keys(overflowOffsets).forEach(function(key) {
  2568. var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;
  2569. var axis = [top, bottom].indexOf(key) >= 0 ? "y" : "x";
  2570. overflowOffsets[key] += offset2[axis] * multiply;
  2571. });
  2572. }
  2573. return overflowOffsets;
  2574. }
  2575. function computeAutoPlacement(state, options) {
  2576. if (options === void 0) {
  2577. options = {};
  2578. }
  2579. var _options = options, placement = _options.placement, boundary = _options.boundary, rootBoundary = _options.rootBoundary, padding = _options.padding, flipVariations = _options.flipVariations, _options$allowedAutoP = _options.allowedAutoPlacements, allowedAutoPlacements = _options$allowedAutoP === void 0 ? placements : _options$allowedAutoP;
  2580. var variation = getVariation(placement);
  2581. var placements$1 = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function(placement2) {
  2582. return getVariation(placement2) === variation;
  2583. }) : basePlacements;
  2584. var allowedPlacements = placements$1.filter(function(placement2) {
  2585. return allowedAutoPlacements.indexOf(placement2) >= 0;
  2586. });
  2587. if (allowedPlacements.length === 0) {
  2588. allowedPlacements = placements$1;
  2589. }
  2590. var overflows = allowedPlacements.reduce(function(acc, placement2) {
  2591. acc[placement2] = detectOverflow(state, {
  2592. placement: placement2,
  2593. boundary,
  2594. rootBoundary,
  2595. padding
  2596. })[getBasePlacement$1(placement2)];
  2597. return acc;
  2598. }, {});
  2599. return Object.keys(overflows).sort(function(a, b) {
  2600. return overflows[a] - overflows[b];
  2601. });
  2602. }
  2603. function getExpandedFallbackPlacements(placement) {
  2604. if (getBasePlacement$1(placement) === auto) {
  2605. return [];
  2606. }
  2607. var oppositePlacement = getOppositePlacement(placement);
  2608. return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];
  2609. }
  2610. function flip(_ref) {
  2611. var state = _ref.state, options = _ref.options, name = _ref.name;
  2612. if (state.modifiersData[name]._skip) {
  2613. return;
  2614. }
  2615. var _options$mainAxis = options.mainAxis, checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, _options$altAxis = options.altAxis, checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis, specifiedFallbackPlacements = options.fallbackPlacements, padding = options.padding, boundary = options.boundary, rootBoundary = options.rootBoundary, altBoundary = options.altBoundary, _options$flipVariatio = options.flipVariations, flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio, allowedAutoPlacements = options.allowedAutoPlacements;
  2616. var preferredPlacement = state.options.placement;
  2617. var basePlacement = getBasePlacement$1(preferredPlacement);
  2618. var isBasePlacement = basePlacement === preferredPlacement;
  2619. var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));
  2620. var placements2 = [preferredPlacement].concat(fallbackPlacements).reduce(function(acc, placement2) {
  2621. return acc.concat(getBasePlacement$1(placement2) === auto ? computeAutoPlacement(state, {
  2622. placement: placement2,
  2623. boundary,
  2624. rootBoundary,
  2625. padding,
  2626. flipVariations,
  2627. allowedAutoPlacements
  2628. }) : placement2);
  2629. }, []);
  2630. var referenceRect = state.rects.reference;
  2631. var popperRect = state.rects.popper;
  2632. var checksMap = /* @__PURE__ */ new Map();
  2633. var makeFallbackChecks = true;
  2634. var firstFittingPlacement = placements2[0];
  2635. for (var i = 0; i < placements2.length; i++) {
  2636. var placement = placements2[i];
  2637. var _basePlacement = getBasePlacement$1(placement);
  2638. var isStartVariation = getVariation(placement) === start;
  2639. var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;
  2640. var len = isVertical ? "width" : "height";
  2641. var overflow = detectOverflow(state, {
  2642. placement,
  2643. boundary,
  2644. rootBoundary,
  2645. altBoundary,
  2646. padding
  2647. });
  2648. var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;
  2649. if (referenceRect[len] > popperRect[len]) {
  2650. mainVariationSide = getOppositePlacement(mainVariationSide);
  2651. }
  2652. var altVariationSide = getOppositePlacement(mainVariationSide);
  2653. var checks = [];
  2654. if (checkMainAxis) {
  2655. checks.push(overflow[_basePlacement] <= 0);
  2656. }
  2657. if (checkAltAxis) {
  2658. checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);
  2659. }
  2660. if (checks.every(function(check) {
  2661. return check;
  2662. })) {
  2663. firstFittingPlacement = placement;
  2664. makeFallbackChecks = false;
  2665. break;
  2666. }
  2667. checksMap.set(placement, checks);
  2668. }
  2669. if (makeFallbackChecks) {
  2670. var numberOfChecks = flipVariations ? 3 : 1;
  2671. var _loop = function _loop2(_i2) {
  2672. var fittingPlacement = placements2.find(function(placement2) {
  2673. var checks2 = checksMap.get(placement2);
  2674. if (checks2) {
  2675. return checks2.slice(0, _i2).every(function(check) {
  2676. return check;
  2677. });
  2678. }
  2679. });
  2680. if (fittingPlacement) {
  2681. firstFittingPlacement = fittingPlacement;
  2682. return "break";
  2683. }
  2684. };
  2685. for (var _i = numberOfChecks; _i > 0; _i--) {
  2686. var _ret = _loop(_i);
  2687. if (_ret === "break") break;
  2688. }
  2689. }
  2690. if (state.placement !== firstFittingPlacement) {
  2691. state.modifiersData[name]._skip = true;
  2692. state.placement = firstFittingPlacement;
  2693. state.reset = true;
  2694. }
  2695. }
  2696. const flip$1 = {
  2697. name: "flip",
  2698. enabled: true,
  2699. phase: "main",
  2700. fn: flip,
  2701. requiresIfExists: ["offset"],
  2702. data: {
  2703. _skip: false
  2704. }
  2705. };
  2706. function getSideOffsets(overflow, rect, preventedOffsets) {
  2707. if (preventedOffsets === void 0) {
  2708. preventedOffsets = {
  2709. x: 0,
  2710. y: 0
  2711. };
  2712. }
  2713. return {
  2714. top: overflow.top - rect.height - preventedOffsets.y,
  2715. right: overflow.right - rect.width + preventedOffsets.x,
  2716. bottom: overflow.bottom - rect.height + preventedOffsets.y,
  2717. left: overflow.left - rect.width - preventedOffsets.x
  2718. };
  2719. }
  2720. function isAnySideFullyClipped(overflow) {
  2721. return [top, right, bottom, left].some(function(side) {
  2722. return overflow[side] >= 0;
  2723. });
  2724. }
  2725. function hide(_ref) {
  2726. var state = _ref.state, name = _ref.name;
  2727. var referenceRect = state.rects.reference;
  2728. var popperRect = state.rects.popper;
  2729. var preventedOffsets = state.modifiersData.preventOverflow;
  2730. var referenceOverflow = detectOverflow(state, {
  2731. elementContext: "reference"
  2732. });
  2733. var popperAltOverflow = detectOverflow(state, {
  2734. altBoundary: true
  2735. });
  2736. var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);
  2737. var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);
  2738. var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);
  2739. var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);
  2740. state.modifiersData[name] = {
  2741. referenceClippingOffsets,
  2742. popperEscapeOffsets,
  2743. isReferenceHidden,
  2744. hasPopperEscaped
  2745. };
  2746. state.attributes.popper = Object.assign({}, state.attributes.popper, {
  2747. "data-popper-reference-hidden": isReferenceHidden,
  2748. "data-popper-escaped": hasPopperEscaped
  2749. });
  2750. }
  2751. const hide$1 = {
  2752. name: "hide",
  2753. enabled: true,
  2754. phase: "main",
  2755. requiresIfExists: ["preventOverflow"],
  2756. fn: hide
  2757. };
  2758. function distanceAndSkiddingToXY(placement, rects, offset2) {
  2759. var basePlacement = getBasePlacement$1(placement);
  2760. var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;
  2761. var _ref = typeof offset2 === "function" ? offset2(Object.assign({}, rects, {
  2762. placement
  2763. })) : offset2, skidding = _ref[0], distance = _ref[1];
  2764. skidding = skidding || 0;
  2765. distance = (distance || 0) * invertDistance;
  2766. return [left, right].indexOf(basePlacement) >= 0 ? {
  2767. x: distance,
  2768. y: skidding
  2769. } : {
  2770. x: skidding,
  2771. y: distance
  2772. };
  2773. }
  2774. function offset(_ref2) {
  2775. var state = _ref2.state, options = _ref2.options, name = _ref2.name;
  2776. var _options$offset = options.offset, offset2 = _options$offset === void 0 ? [0, 0] : _options$offset;
  2777. var data = placements.reduce(function(acc, placement) {
  2778. acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset2);
  2779. return acc;
  2780. }, {});
  2781. var _data$state$placement = data[state.placement], x = _data$state$placement.x, y = _data$state$placement.y;
  2782. if (state.modifiersData.popperOffsets != null) {
  2783. state.modifiersData.popperOffsets.x += x;
  2784. state.modifiersData.popperOffsets.y += y;
  2785. }
  2786. state.modifiersData[name] = data;
  2787. }
  2788. const offset$1 = {
  2789. name: "offset",
  2790. enabled: true,
  2791. phase: "main",
  2792. requires: ["popperOffsets"],
  2793. fn: offset
  2794. };
  2795. function popperOffsets(_ref) {
  2796. var state = _ref.state, name = _ref.name;
  2797. state.modifiersData[name] = computeOffsets({
  2798. reference: state.rects.reference,
  2799. element: state.rects.popper,
  2800. placement: state.placement
  2801. });
  2802. }
  2803. const popperOffsets$1 = {
  2804. name: "popperOffsets",
  2805. enabled: true,
  2806. phase: "read",
  2807. fn: popperOffsets,
  2808. data: {}
  2809. };
  2810. function getAltAxis(axis) {
  2811. return axis === "x" ? "y" : "x";
  2812. }
  2813. function preventOverflow(_ref) {
  2814. var state = _ref.state, options = _ref.options, name = _ref.name;
  2815. var _options$mainAxis = options.mainAxis, checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, _options$altAxis = options.altAxis, checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis, boundary = options.boundary, rootBoundary = options.rootBoundary, altBoundary = options.altBoundary, padding = options.padding, _options$tether = options.tether, tether = _options$tether === void 0 ? true : _options$tether, _options$tetherOffset = options.tetherOffset, tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;
  2816. var overflow = detectOverflow(state, {
  2817. boundary,
  2818. rootBoundary,
  2819. padding,
  2820. altBoundary
  2821. });
  2822. var basePlacement = getBasePlacement$1(state.placement);
  2823. var variation = getVariation(state.placement);
  2824. var isBasePlacement = !variation;
  2825. var mainAxis = getMainAxisFromPlacement(basePlacement);
  2826. var altAxis = getAltAxis(mainAxis);
  2827. var popperOffsets2 = state.modifiersData.popperOffsets;
  2828. var referenceRect = state.rects.reference;
  2829. var popperRect = state.rects.popper;
  2830. var tetherOffsetValue = typeof tetherOffset === "function" ? tetherOffset(Object.assign({}, state.rects, {
  2831. placement: state.placement
  2832. })) : tetherOffset;
  2833. var normalizedTetherOffsetValue = typeof tetherOffsetValue === "number" ? {
  2834. mainAxis: tetherOffsetValue,
  2835. altAxis: tetherOffsetValue
  2836. } : Object.assign({
  2837. mainAxis: 0,
  2838. altAxis: 0
  2839. }, tetherOffsetValue);
  2840. var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;
  2841. var data = {
  2842. x: 0,
  2843. y: 0
  2844. };
  2845. if (!popperOffsets2) {
  2846. return;
  2847. }
  2848. if (checkMainAxis) {
  2849. var _offsetModifierState$;
  2850. var mainSide = mainAxis === "y" ? top : left;
  2851. var altSide = mainAxis === "y" ? bottom : right;
  2852. var len = mainAxis === "y" ? "height" : "width";
  2853. var offset2 = popperOffsets2[mainAxis];
  2854. var min$1 = offset2 + overflow[mainSide];
  2855. var max$1 = offset2 - overflow[altSide];
  2856. var additive = tether ? -popperRect[len] / 2 : 0;
  2857. var minLen = variation === start ? referenceRect[len] : popperRect[len];
  2858. var maxLen = variation === start ? -popperRect[len] : -referenceRect[len];
  2859. var arrowElement = state.elements.arrow;
  2860. var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {
  2861. width: 0,
  2862. height: 0
  2863. };
  2864. var arrowPaddingObject = state.modifiersData["arrow#persistent"] ? state.modifiersData["arrow#persistent"].padding : getFreshSideObject();
  2865. var arrowPaddingMin = arrowPaddingObject[mainSide];
  2866. var arrowPaddingMax = arrowPaddingObject[altSide];
  2867. var arrowLen = within(0, referenceRect[len], arrowRect[len]);
  2868. var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;
  2869. var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;
  2870. var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);
  2871. var clientOffset = arrowOffsetParent ? mainAxis === "y" ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;
  2872. var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;
  2873. var tetherMin = offset2 + minOffset - offsetModifierValue - clientOffset;
  2874. var tetherMax = offset2 + maxOffset - offsetModifierValue;
  2875. var preventedOffset = within(tether ? min(min$1, tetherMin) : min$1, offset2, tether ? max(max$1, tetherMax) : max$1);
  2876. popperOffsets2[mainAxis] = preventedOffset;
  2877. data[mainAxis] = preventedOffset - offset2;
  2878. }
  2879. if (checkAltAxis) {
  2880. var _offsetModifierState$2;
  2881. var _mainSide = mainAxis === "x" ? top : left;
  2882. var _altSide = mainAxis === "x" ? bottom : right;
  2883. var _offset = popperOffsets2[altAxis];
  2884. var _len = altAxis === "y" ? "height" : "width";
  2885. var _min = _offset + overflow[_mainSide];
  2886. var _max = _offset - overflow[_altSide];
  2887. var isOriginSide = [top, left].indexOf(basePlacement) !== -1;
  2888. var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;
  2889. var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;
  2890. var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;
  2891. var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);
  2892. popperOffsets2[altAxis] = _preventedOffset;
  2893. data[altAxis] = _preventedOffset - _offset;
  2894. }
  2895. state.modifiersData[name] = data;
  2896. }
  2897. const preventOverflow$1 = {
  2898. name: "preventOverflow",
  2899. enabled: true,
  2900. phase: "main",
  2901. fn: preventOverflow,
  2902. requiresIfExists: ["offset"]
  2903. };
  2904. function getHTMLElementScroll(element) {
  2905. return {
  2906. scrollLeft: element.scrollLeft,
  2907. scrollTop: element.scrollTop
  2908. };
  2909. }
  2910. function getNodeScroll(node) {
  2911. if (node === getWindow(node) || !isHTMLElement(node)) {
  2912. return getWindowScroll(node);
  2913. } else {
  2914. return getHTMLElementScroll(node);
  2915. }
  2916. }
  2917. function isElementScaled(element) {
  2918. var rect = element.getBoundingClientRect();
  2919. var scaleX = round(rect.width) / element.offsetWidth || 1;
  2920. var scaleY = round(rect.height) / element.offsetHeight || 1;
  2921. return scaleX !== 1 || scaleY !== 1;
  2922. }
  2923. function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {
  2924. if (isFixed === void 0) {
  2925. isFixed = false;
  2926. }
  2927. var isOffsetParentAnElement = isHTMLElement(offsetParent);
  2928. var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);
  2929. var documentElement = getDocumentElement(offsetParent);
  2930. var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);
  2931. var scroll = {
  2932. scrollLeft: 0,
  2933. scrollTop: 0
  2934. };
  2935. var offsets = {
  2936. x: 0,
  2937. y: 0
  2938. };
  2939. if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {
  2940. if (getNodeName(offsetParent) !== "body" || // https://github.com/popperjs/popper-core/issues/1078
  2941. isScrollParent(documentElement)) {
  2942. scroll = getNodeScroll(offsetParent);
  2943. }
  2944. if (isHTMLElement(offsetParent)) {
  2945. offsets = getBoundingClientRect(offsetParent, true);
  2946. offsets.x += offsetParent.clientLeft;
  2947. offsets.y += offsetParent.clientTop;
  2948. } else if (documentElement) {
  2949. offsets.x = getWindowScrollBarX(documentElement);
  2950. }
  2951. }
  2952. return {
  2953. x: rect.left + scroll.scrollLeft - offsets.x,
  2954. y: rect.top + scroll.scrollTop - offsets.y,
  2955. width: rect.width,
  2956. height: rect.height
  2957. };
  2958. }
  2959. function order(modifiers) {
  2960. var map = /* @__PURE__ */ new Map();
  2961. var visited = /* @__PURE__ */ new Set();
  2962. var result = [];
  2963. modifiers.forEach(function(modifier) {
  2964. map.set(modifier.name, modifier);
  2965. });
  2966. function sort(modifier) {
  2967. visited.add(modifier.name);
  2968. var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);
  2969. requires.forEach(function(dep) {
  2970. if (!visited.has(dep)) {
  2971. var depModifier = map.get(dep);
  2972. if (depModifier) {
  2973. sort(depModifier);
  2974. }
  2975. }
  2976. });
  2977. result.push(modifier);
  2978. }
  2979. modifiers.forEach(function(modifier) {
  2980. if (!visited.has(modifier.name)) {
  2981. sort(modifier);
  2982. }
  2983. });
  2984. return result;
  2985. }
  2986. function orderModifiers(modifiers) {
  2987. var orderedModifiers = order(modifiers);
  2988. return modifierPhases.reduce(function(acc, phase) {
  2989. return acc.concat(orderedModifiers.filter(function(modifier) {
  2990. return modifier.phase === phase;
  2991. }));
  2992. }, []);
  2993. }
  2994. function debounce$1(fn2) {
  2995. var pending;
  2996. return function() {
  2997. if (!pending) {
  2998. pending = new Promise(function(resolve) {
  2999. Promise.resolve().then(function() {
  3000. pending = void 0;
  3001. resolve(fn2());
  3002. });
  3003. });
  3004. }
  3005. return pending;
  3006. };
  3007. }
  3008. function mergeByName(modifiers) {
  3009. var merged = modifiers.reduce(function(merged2, current) {
  3010. var existing = merged2[current.name];
  3011. merged2[current.name] = existing ? Object.assign({}, existing, current, {
  3012. options: Object.assign({}, existing.options, current.options),
  3013. data: Object.assign({}, existing.data, current.data)
  3014. }) : current;
  3015. return merged2;
  3016. }, {});
  3017. return Object.keys(merged).map(function(key) {
  3018. return merged[key];
  3019. });
  3020. }
  3021. var DEFAULT_OPTIONS = {
  3022. placement: "bottom",
  3023. modifiers: [],
  3024. strategy: "absolute"
  3025. };
  3026. function areValidElements() {
  3027. for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
  3028. args[_key] = arguments[_key];
  3029. }
  3030. return !args.some(function(element) {
  3031. return !(element && typeof element.getBoundingClientRect === "function");
  3032. });
  3033. }
  3034. function popperGenerator(generatorOptions) {
  3035. if (generatorOptions === void 0) {
  3036. generatorOptions = {};
  3037. }
  3038. var _generatorOptions = generatorOptions, _generatorOptions$def = _generatorOptions.defaultModifiers, defaultModifiers2 = _generatorOptions$def === void 0 ? [] : _generatorOptions$def, _generatorOptions$def2 = _generatorOptions.defaultOptions, defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;
  3039. return function createPopper2(reference2, popper2, options) {
  3040. if (options === void 0) {
  3041. options = defaultOptions;
  3042. }
  3043. var state = {
  3044. placement: "bottom",
  3045. orderedModifiers: [],
  3046. options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),
  3047. modifiersData: {},
  3048. elements: {
  3049. reference: reference2,
  3050. popper: popper2
  3051. },
  3052. attributes: {},
  3053. styles: {}
  3054. };
  3055. var effectCleanupFns = [];
  3056. var isDestroyed = false;
  3057. var instance = {
  3058. state,
  3059. setOptions: function setOptions(setOptionsAction) {
  3060. var options2 = typeof setOptionsAction === "function" ? setOptionsAction(state.options) : setOptionsAction;
  3061. cleanupModifierEffects();
  3062. state.options = Object.assign({}, defaultOptions, state.options, options2);
  3063. state.scrollParents = {
  3064. reference: isElement$1(reference2) ? listScrollParents(reference2) : reference2.contextElement ? listScrollParents(reference2.contextElement) : [],
  3065. popper: listScrollParents(popper2)
  3066. };
  3067. var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers2, state.options.modifiers)));
  3068. state.orderedModifiers = orderedModifiers.filter(function(m) {
  3069. return m.enabled;
  3070. });
  3071. runModifierEffects();
  3072. return instance.update();
  3073. },
  3074. // Sync update – it will always be executed, even if not necessary. This
  3075. // is useful for low frequency updates where sync behavior simplifies the
  3076. // logic.
  3077. // For high frequency updates (e.g. `resize` and `scroll` events), always
  3078. // prefer the async Popper#update method
  3079. forceUpdate: function forceUpdate() {
  3080. if (isDestroyed) {
  3081. return;
  3082. }
  3083. var _state$elements = state.elements, reference3 = _state$elements.reference, popper3 = _state$elements.popper;
  3084. if (!areValidElements(reference3, popper3)) {
  3085. return;
  3086. }
  3087. state.rects = {
  3088. reference: getCompositeRect(reference3, getOffsetParent(popper3), state.options.strategy === "fixed"),
  3089. popper: getLayoutRect(popper3)
  3090. };
  3091. state.reset = false;
  3092. state.placement = state.options.placement;
  3093. state.orderedModifiers.forEach(function(modifier) {
  3094. return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);
  3095. });
  3096. for (var index = 0; index < state.orderedModifiers.length; index++) {
  3097. if (state.reset === true) {
  3098. state.reset = false;
  3099. index = -1;
  3100. continue;
  3101. }
  3102. var _state$orderedModifie = state.orderedModifiers[index], fn2 = _state$orderedModifie.fn, _state$orderedModifie2 = _state$orderedModifie.options, _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2, name = _state$orderedModifie.name;
  3103. if (typeof fn2 === "function") {
  3104. state = fn2({
  3105. state,
  3106. options: _options,
  3107. name,
  3108. instance
  3109. }) || state;
  3110. }
  3111. }
  3112. },
  3113. // Async and optimistically optimized update – it will not be executed if
  3114. // not necessary (debounced to run at most once-per-tick)
  3115. update: debounce$1(function() {
  3116. return new Promise(function(resolve) {
  3117. instance.forceUpdate();
  3118. resolve(state);
  3119. });
  3120. }),
  3121. destroy: function destroy() {
  3122. cleanupModifierEffects();
  3123. isDestroyed = true;
  3124. }
  3125. };
  3126. if (!areValidElements(reference2, popper2)) {
  3127. return instance;
  3128. }
  3129. instance.setOptions(options).then(function(state2) {
  3130. if (!isDestroyed && options.onFirstUpdate) {
  3131. options.onFirstUpdate(state2);
  3132. }
  3133. });
  3134. function runModifierEffects() {
  3135. state.orderedModifiers.forEach(function(_ref) {
  3136. var name = _ref.name, _ref$options = _ref.options, options2 = _ref$options === void 0 ? {} : _ref$options, effect3 = _ref.effect;
  3137. if (typeof effect3 === "function") {
  3138. var cleanupFn = effect3({
  3139. state,
  3140. name,
  3141. instance,
  3142. options: options2
  3143. });
  3144. var noopFn = function noopFn2() {
  3145. };
  3146. effectCleanupFns.push(cleanupFn || noopFn);
  3147. }
  3148. });
  3149. }
  3150. function cleanupModifierEffects() {
  3151. effectCleanupFns.forEach(function(fn2) {
  3152. return fn2();
  3153. });
  3154. effectCleanupFns = [];
  3155. }
  3156. return instance;
  3157. };
  3158. }
  3159. var defaultModifiers = [eventListeners, popperOffsets$1, computeStyles$1, applyStyles$1, offset$1, flip$1, preventOverflow$1, arrow$1, hide$1];
  3160. var createPopper = /* @__PURE__ */ popperGenerator({
  3161. defaultModifiers
  3162. });
  3163. var BOX_CLASS = "tippy-box";
  3164. var CONTENT_CLASS = "tippy-content";
  3165. var BACKDROP_CLASS = "tippy-backdrop";
  3166. var ARROW_CLASS = "tippy-arrow";
  3167. var SVG_ARROW_CLASS = "tippy-svg-arrow";
  3168. var TOUCH_OPTIONS = {
  3169. passive: true,
  3170. capture: true
  3171. };
  3172. var TIPPY_DEFAULT_APPEND_TO = function TIPPY_DEFAULT_APPEND_TO2() {
  3173. return document.body;
  3174. };
  3175. function getValueAtIndexOrReturn(value, index, defaultValue) {
  3176. if (Array.isArray(value)) {
  3177. var v = value[index];
  3178. return v == null ? Array.isArray(defaultValue) ? defaultValue[index] : defaultValue : v;
  3179. }
  3180. return value;
  3181. }
  3182. function isType(value, type) {
  3183. var str = {}.toString.call(value);
  3184. return str.indexOf("[object") === 0 && str.indexOf(type + "]") > -1;
  3185. }
  3186. function invokeWithArgsOrReturn(value, args) {
  3187. return typeof value === "function" ? value.apply(void 0, args) : value;
  3188. }
  3189. function debounce(fn5, ms) {
  3190. if (ms === 0) {
  3191. return fn5;
  3192. }
  3193. var timeout;
  3194. return function(arg) {
  3195. clearTimeout(timeout);
  3196. timeout = setTimeout(function() {
  3197. fn5(arg);
  3198. }, ms);
  3199. };
  3200. }
  3201. function splitBySpaces(value) {
  3202. return value.split(/\s+/).filter(Boolean);
  3203. }
  3204. function normalizeToArray(value) {
  3205. return [].concat(value);
  3206. }
  3207. function pushIfUnique(arr, value) {
  3208. if (arr.indexOf(value) === -1) {
  3209. arr.push(value);
  3210. }
  3211. }
  3212. function unique(arr) {
  3213. return arr.filter(function(item, index) {
  3214. return arr.indexOf(item) === index;
  3215. });
  3216. }
  3217. function getBasePlacement(placement) {
  3218. return placement.split("-")[0];
  3219. }
  3220. function arrayFrom(value) {
  3221. return [].slice.call(value);
  3222. }
  3223. function removeUndefinedProps(obj) {
  3224. return Object.keys(obj).reduce(function(acc, key) {
  3225. if (obj[key] !== void 0) {
  3226. acc[key] = obj[key];
  3227. }
  3228. return acc;
  3229. }, {});
  3230. }
  3231. function div() {
  3232. return document.createElement("div");
  3233. }
  3234. function isElement(value) {
  3235. return ["Element", "Fragment"].some(function(type) {
  3236. return isType(value, type);
  3237. });
  3238. }
  3239. function isNodeList(value) {
  3240. return isType(value, "NodeList");
  3241. }
  3242. function isMouseEvent(value) {
  3243. return isType(value, "MouseEvent");
  3244. }
  3245. function isReferenceElement(value) {
  3246. return !!(value && value._tippy && value._tippy.reference === value);
  3247. }
  3248. function getArrayOfElements(value) {
  3249. if (isElement(value)) {
  3250. return [value];
  3251. }
  3252. if (isNodeList(value)) {
  3253. return arrayFrom(value);
  3254. }
  3255. if (Array.isArray(value)) {
  3256. return value;
  3257. }
  3258. return arrayFrom(document.querySelectorAll(value));
  3259. }
  3260. function setTransitionDuration(els, value) {
  3261. els.forEach(function(el) {
  3262. if (el) {
  3263. el.style.transitionDuration = value + "ms";
  3264. }
  3265. });
  3266. }
  3267. function setVisibilityState(els, state) {
  3268. els.forEach(function(el) {
  3269. if (el) {
  3270. el.setAttribute("data-state", state);
  3271. }
  3272. });
  3273. }
  3274. function getOwnerDocument(elementOrElements) {
  3275. var _element$ownerDocumen;
  3276. var _normalizeToArray = normalizeToArray(elementOrElements), element = _normalizeToArray[0];
  3277. return element != null && (_element$ownerDocumen = element.ownerDocument) != null && _element$ownerDocumen.body ? element.ownerDocument : document;
  3278. }
  3279. function isCursorOutsideInteractiveBorder(popperTreeData, event) {
  3280. var clientX = event.clientX, clientY = event.clientY;
  3281. return popperTreeData.every(function(_ref) {
  3282. var popperRect = _ref.popperRect, popperState = _ref.popperState, props = _ref.props;
  3283. var interactiveBorder = props.interactiveBorder;
  3284. var basePlacement = getBasePlacement(popperState.placement);
  3285. var offsetData = popperState.modifiersData.offset;
  3286. if (!offsetData) {
  3287. return true;
  3288. }
  3289. var topDistance = basePlacement === "bottom" ? offsetData.top.y : 0;
  3290. var bottomDistance = basePlacement === "top" ? offsetData.bottom.y : 0;
  3291. var leftDistance = basePlacement === "right" ? offsetData.left.x : 0;
  3292. var rightDistance = basePlacement === "left" ? offsetData.right.x : 0;
  3293. var exceedsTop = popperRect.top - clientY + topDistance > interactiveBorder;
  3294. var exceedsBottom = clientY - popperRect.bottom - bottomDistance > interactiveBorder;
  3295. var exceedsLeft = popperRect.left - clientX + leftDistance > interactiveBorder;
  3296. var exceedsRight = clientX - popperRect.right - rightDistance > interactiveBorder;
  3297. return exceedsTop || exceedsBottom || exceedsLeft || exceedsRight;
  3298. });
  3299. }
  3300. function updateTransitionEndListener(box, action, listener) {
  3301. var method = action + "EventListener";
  3302. ["transitionend", "webkitTransitionEnd"].forEach(function(event) {
  3303. box[method](event, listener);
  3304. });
  3305. }
  3306. function actualContains(parent, child) {
  3307. var target = child;
  3308. while (target) {
  3309. var _target$getRootNode;
  3310. if (parent.contains(target)) {
  3311. return true;
  3312. }
  3313. target = target.getRootNode == null ? void 0 : (_target$getRootNode = target.getRootNode()) == null ? void 0 : _target$getRootNode.host;
  3314. }
  3315. return false;
  3316. }
  3317. var currentInput = {
  3318. isTouch: false
  3319. };
  3320. var lastMouseMoveTime = 0;
  3321. function onDocumentTouchStart() {
  3322. if (currentInput.isTouch) {
  3323. return;
  3324. }
  3325. currentInput.isTouch = true;
  3326. if (window.performance) {
  3327. document.addEventListener("mousemove", onDocumentMouseMove);
  3328. }
  3329. }
  3330. function onDocumentMouseMove() {
  3331. var now = performance.now();
  3332. if (now - lastMouseMoveTime < 20) {
  3333. currentInput.isTouch = false;
  3334. document.removeEventListener("mousemove", onDocumentMouseMove);
  3335. }
  3336. lastMouseMoveTime = now;
  3337. }
  3338. function onWindowBlur() {
  3339. var activeElement = document.activeElement;
  3340. if (isReferenceElement(activeElement)) {
  3341. var instance = activeElement._tippy;
  3342. if (activeElement.blur && !instance.state.isVisible) {
  3343. activeElement.blur();
  3344. }
  3345. }
  3346. }
  3347. function bindGlobalEventListeners() {
  3348. document.addEventListener("touchstart", onDocumentTouchStart, TOUCH_OPTIONS);
  3349. window.addEventListener("blur", onWindowBlur);
  3350. }
  3351. var isBrowser = typeof window !== "undefined" && typeof document !== "undefined";
  3352. var isIE11 = isBrowser ? (
  3353. // @ts-ignore
  3354. !!window.msCrypto
  3355. ) : false;
  3356. var pluginProps = {
  3357. animateFill: false,
  3358. followCursor: false,
  3359. inlinePositioning: false,
  3360. sticky: false
  3361. };
  3362. var renderProps = {
  3363. allowHTML: false,
  3364. animation: "fade",
  3365. arrow: true,
  3366. content: "",
  3367. inertia: false,
  3368. maxWidth: 350,
  3369. role: "tooltip",
  3370. theme: "",
  3371. zIndex: 9999
  3372. };
  3373. var defaultProps = Object.assign({
  3374. appendTo: TIPPY_DEFAULT_APPEND_TO,
  3375. aria: {
  3376. content: "auto",
  3377. expanded: "auto"
  3378. },
  3379. delay: 0,
  3380. duration: [300, 250],
  3381. getReferenceClientRect: null,
  3382. hideOnClick: true,
  3383. ignoreAttributes: false,
  3384. interactive: false,
  3385. interactiveBorder: 2,
  3386. interactiveDebounce: 0,
  3387. moveTransition: "",
  3388. offset: [0, 10],
  3389. onAfterUpdate: function onAfterUpdate() {
  3390. },
  3391. onBeforeUpdate: function onBeforeUpdate() {
  3392. },
  3393. onCreate: function onCreate() {
  3394. },
  3395. onDestroy: function onDestroy() {
  3396. },
  3397. onHidden: function onHidden() {
  3398. },
  3399. onHide: function onHide() {
  3400. },
  3401. onMount: function onMount() {
  3402. },
  3403. onShow: function onShow() {
  3404. },
  3405. onShown: function onShown() {
  3406. },
  3407. onTrigger: function onTrigger() {
  3408. },
  3409. onUntrigger: function onUntrigger() {
  3410. },
  3411. onClickOutside: function onClickOutside() {
  3412. },
  3413. placement: "top",
  3414. plugins: [],
  3415. popperOptions: {},
  3416. render: null,
  3417. showOnCreate: false,
  3418. touch: true,
  3419. trigger: "mouseenter focus",
  3420. triggerTarget: null
  3421. }, pluginProps, renderProps);
  3422. var defaultKeys = Object.keys(defaultProps);
  3423. var setDefaultProps = function setDefaultProps2(partialProps) {
  3424. var keys = Object.keys(partialProps);
  3425. keys.forEach(function(key) {
  3426. defaultProps[key] = partialProps[key];
  3427. });
  3428. };
  3429. function getExtendedPassedProps(passedProps) {
  3430. var plugins = passedProps.plugins || [];
  3431. var pluginProps2 = plugins.reduce(function(acc, plugin) {
  3432. var name = plugin.name, defaultValue = plugin.defaultValue;
  3433. if (name) {
  3434. var _name;
  3435. acc[name] = passedProps[name] !== void 0 ? passedProps[name] : (_name = defaultProps[name]) != null ? _name : defaultValue;
  3436. }
  3437. return acc;
  3438. }, {});
  3439. return Object.assign({}, passedProps, pluginProps2);
  3440. }
  3441. function getDataAttributeProps(reference2, plugins) {
  3442. var propKeys = plugins ? Object.keys(getExtendedPassedProps(Object.assign({}, defaultProps, {
  3443. plugins
  3444. }))) : defaultKeys;
  3445. var props = propKeys.reduce(function(acc, key) {
  3446. var valueAsString = (reference2.getAttribute("data-tippy-" + key) || "").trim();
  3447. if (!valueAsString) {
  3448. return acc;
  3449. }
  3450. if (key === "content") {
  3451. acc[key] = valueAsString;
  3452. } else {
  3453. try {
  3454. acc[key] = JSON.parse(valueAsString);
  3455. } catch (e) {
  3456. acc[key] = valueAsString;
  3457. }
  3458. }
  3459. return acc;
  3460. }, {});
  3461. return props;
  3462. }
  3463. function evaluateProps(reference2, props) {
  3464. var out = Object.assign({}, props, {
  3465. content: invokeWithArgsOrReturn(props.content, [reference2])
  3466. }, props.ignoreAttributes ? {} : getDataAttributeProps(reference2, props.plugins));
  3467. out.aria = Object.assign({}, defaultProps.aria, out.aria);
  3468. out.aria = {
  3469. expanded: out.aria.expanded === "auto" ? props.interactive : out.aria.expanded,
  3470. content: out.aria.content === "auto" ? props.interactive ? null : "describedby" : out.aria.content
  3471. };
  3472. return out;
  3473. }
  3474. var innerHTML = function innerHTML2() {
  3475. return "innerHTML";
  3476. };
  3477. function dangerouslySetInnerHTML(element, html) {
  3478. element[innerHTML()] = html;
  3479. }
  3480. function createArrowElement(value) {
  3481. var arrow2 = div();
  3482. if (value === true) {
  3483. arrow2.className = ARROW_CLASS;
  3484. } else {
  3485. arrow2.className = SVG_ARROW_CLASS;
  3486. if (isElement(value)) {
  3487. arrow2.appendChild(value);
  3488. } else {
  3489. dangerouslySetInnerHTML(arrow2, value);
  3490. }
  3491. }
  3492. return arrow2;
  3493. }
  3494. function setContent(content, props) {
  3495. if (isElement(props.content)) {
  3496. dangerouslySetInnerHTML(content, "");
  3497. content.appendChild(props.content);
  3498. } else if (typeof props.content !== "function") {
  3499. if (props.allowHTML) {
  3500. dangerouslySetInnerHTML(content, props.content);
  3501. } else {
  3502. content.textContent = props.content;
  3503. }
  3504. }
  3505. }
  3506. function getChildren(popper2) {
  3507. var box = popper2.firstElementChild;
  3508. var boxChildren = arrayFrom(box.children);
  3509. return {
  3510. box,
  3511. content: boxChildren.find(function(node) {
  3512. return node.classList.contains(CONTENT_CLASS);
  3513. }),
  3514. arrow: boxChildren.find(function(node) {
  3515. return node.classList.contains(ARROW_CLASS) || node.classList.contains(SVG_ARROW_CLASS);
  3516. }),
  3517. backdrop: boxChildren.find(function(node) {
  3518. return node.classList.contains(BACKDROP_CLASS);
  3519. })
  3520. };
  3521. }
  3522. function render(instance) {
  3523. var popper2 = div();
  3524. var box = div();
  3525. box.className = BOX_CLASS;
  3526. box.setAttribute("data-state", "hidden");
  3527. box.setAttribute("tabindex", "-1");
  3528. var content = div();
  3529. content.className = CONTENT_CLASS;
  3530. content.setAttribute("data-state", "hidden");
  3531. setContent(content, instance.props);
  3532. popper2.appendChild(box);
  3533. box.appendChild(content);
  3534. onUpdate(instance.props, instance.props);
  3535. function onUpdate(prevProps, nextProps) {
  3536. var _getChildren = getChildren(popper2), box2 = _getChildren.box, content2 = _getChildren.content, arrow2 = _getChildren.arrow;
  3537. if (nextProps.theme) {
  3538. box2.setAttribute("data-theme", nextProps.theme);
  3539. } else {
  3540. box2.removeAttribute("data-theme");
  3541. }
  3542. if (typeof nextProps.animation === "string") {
  3543. box2.setAttribute("data-animation", nextProps.animation);
  3544. } else {
  3545. box2.removeAttribute("data-animation");
  3546. }
  3547. if (nextProps.inertia) {
  3548. box2.setAttribute("data-inertia", "");
  3549. } else {
  3550. box2.removeAttribute("data-inertia");
  3551. }
  3552. box2.style.maxWidth = typeof nextProps.maxWidth === "number" ? nextProps.maxWidth + "px" : nextProps.maxWidth;
  3553. if (nextProps.role) {
  3554. box2.setAttribute("role", nextProps.role);
  3555. } else {
  3556. box2.removeAttribute("role");
  3557. }
  3558. if (prevProps.content !== nextProps.content || prevProps.allowHTML !== nextProps.allowHTML) {
  3559. setContent(content2, instance.props);
  3560. }
  3561. if (nextProps.arrow) {
  3562. if (!arrow2) {
  3563. box2.appendChild(createArrowElement(nextProps.arrow));
  3564. } else if (prevProps.arrow !== nextProps.arrow) {
  3565. box2.removeChild(arrow2);
  3566. box2.appendChild(createArrowElement(nextProps.arrow));
  3567. }
  3568. } else if (arrow2) {
  3569. box2.removeChild(arrow2);
  3570. }
  3571. }
  3572. return {
  3573. popper: popper2,
  3574. onUpdate
  3575. };
  3576. }
  3577. render.$$tippy = true;
  3578. var idCounter = 1;
  3579. var mouseMoveListeners = [];
  3580. var mountedInstances = [];
  3581. function createTippy(reference2, passedProps) {
  3582. var props = evaluateProps(reference2, Object.assign({}, defaultProps, getExtendedPassedProps(removeUndefinedProps(passedProps))));
  3583. var showTimeout;
  3584. var hideTimeout;
  3585. var scheduleHideAnimationFrame;
  3586. var isVisibleFromClick = false;
  3587. var didHideDueToDocumentMouseDown = false;
  3588. var didTouchMove = false;
  3589. var ignoreOnFirstUpdate = false;
  3590. var lastTriggerEvent;
  3591. var currentTransitionEndListener;
  3592. var onFirstUpdate;
  3593. var listeners = [];
  3594. var debouncedOnMouseMove = debounce(onMouseMove, props.interactiveDebounce);
  3595. var currentTarget;
  3596. var id = idCounter++;
  3597. var popperInstance = null;
  3598. var plugins = unique(props.plugins);
  3599. var state = {
  3600. // Is the instance currently enabled?
  3601. isEnabled: true,
  3602. // Is the tippy currently showing and not transitioning out?
  3603. isVisible: false,
  3604. // Has the instance been destroyed?
  3605. isDestroyed: false,
  3606. // Is the tippy currently mounted to the DOM?
  3607. isMounted: false,
  3608. // Has the tippy finished transitioning in?
  3609. isShown: false
  3610. };
  3611. var instance = {
  3612. // properties
  3613. id,
  3614. reference: reference2,
  3615. popper: div(),
  3616. popperInstance,
  3617. props,
  3618. state,
  3619. plugins,
  3620. // methods
  3621. clearDelayTimeouts,
  3622. setProps,
  3623. setContent: setContent2,
  3624. show,
  3625. hide: hide2,
  3626. hideWithInteractivity,
  3627. enable,
  3628. disable,
  3629. unmount,
  3630. destroy
  3631. };
  3632. if (!props.render) {
  3633. return instance;
  3634. }
  3635. var _props$render = props.render(instance), popper2 = _props$render.popper, onUpdate = _props$render.onUpdate;
  3636. popper2.setAttribute("data-tippy-root", "");
  3637. popper2.id = "tippy-" + instance.id;
  3638. instance.popper = popper2;
  3639. reference2._tippy = instance;
  3640. popper2._tippy = instance;
  3641. var pluginsHooks = plugins.map(function(plugin) {
  3642. return plugin.fn(instance);
  3643. });
  3644. var hasAriaExpanded = reference2.hasAttribute("aria-expanded");
  3645. addListeners();
  3646. handleAriaExpandedAttribute();
  3647. handleStyles();
  3648. invokeHook("onCreate", [instance]);
  3649. if (props.showOnCreate) {
  3650. scheduleShow();
  3651. }
  3652. popper2.addEventListener("mouseenter", function() {
  3653. if (instance.props.interactive && instance.state.isVisible) {
  3654. instance.clearDelayTimeouts();
  3655. }
  3656. });
  3657. popper2.addEventListener("mouseleave", function() {
  3658. if (instance.props.interactive && instance.props.trigger.indexOf("mouseenter") >= 0) {
  3659. getDocument().addEventListener("mousemove", debouncedOnMouseMove);
  3660. }
  3661. });
  3662. return instance;
  3663. function getNormalizedTouchSettings() {
  3664. var touch = instance.props.touch;
  3665. return Array.isArray(touch) ? touch : [touch, 0];
  3666. }
  3667. function getIsCustomTouchBehavior() {
  3668. return getNormalizedTouchSettings()[0] === "hold";
  3669. }
  3670. function getIsDefaultRenderFn() {
  3671. var _instance$props$rende;
  3672. return !!((_instance$props$rende = instance.props.render) != null && _instance$props$rende.$$tippy);
  3673. }
  3674. function getCurrentTarget() {
  3675. return currentTarget || reference2;
  3676. }
  3677. function getDocument() {
  3678. var parent = getCurrentTarget().parentNode;
  3679. return parent ? getOwnerDocument(parent) : document;
  3680. }
  3681. function getDefaultTemplateChildren() {
  3682. return getChildren(popper2);
  3683. }
  3684. function getDelay(isShow) {
  3685. if (instance.state.isMounted && !instance.state.isVisible || currentInput.isTouch || lastTriggerEvent && lastTriggerEvent.type === "focus") {
  3686. return 0;
  3687. }
  3688. return getValueAtIndexOrReturn(instance.props.delay, isShow ? 0 : 1, defaultProps.delay);
  3689. }
  3690. function handleStyles(fromHide) {
  3691. if (fromHide === void 0) {
  3692. fromHide = false;
  3693. }
  3694. popper2.style.pointerEvents = instance.props.interactive && !fromHide ? "" : "none";
  3695. popper2.style.zIndex = "" + instance.props.zIndex;
  3696. }
  3697. function invokeHook(hook, args, shouldInvokePropsHook) {
  3698. if (shouldInvokePropsHook === void 0) {
  3699. shouldInvokePropsHook = true;
  3700. }
  3701. pluginsHooks.forEach(function(pluginHooks) {
  3702. if (pluginHooks[hook]) {
  3703. pluginHooks[hook].apply(pluginHooks, args);
  3704. }
  3705. });
  3706. if (shouldInvokePropsHook) {
  3707. var _instance$props;
  3708. (_instance$props = instance.props)[hook].apply(_instance$props, args);
  3709. }
  3710. }
  3711. function handleAriaContentAttribute() {
  3712. var aria = instance.props.aria;
  3713. if (!aria.content) {
  3714. return;
  3715. }
  3716. var attr = "aria-" + aria.content;
  3717. var id2 = popper2.id;
  3718. var nodes = normalizeToArray(instance.props.triggerTarget || reference2);
  3719. nodes.forEach(function(node) {
  3720. var currentValue = node.getAttribute(attr);
  3721. if (instance.state.isVisible) {
  3722. node.setAttribute(attr, currentValue ? currentValue + " " + id2 : id2);
  3723. } else {
  3724. var nextValue = currentValue && currentValue.replace(id2, "").trim();
  3725. if (nextValue) {
  3726. node.setAttribute(attr, nextValue);
  3727. } else {
  3728. node.removeAttribute(attr);
  3729. }
  3730. }
  3731. });
  3732. }
  3733. function handleAriaExpandedAttribute() {
  3734. if (hasAriaExpanded || !instance.props.aria.expanded) {
  3735. return;
  3736. }
  3737. var nodes = normalizeToArray(instance.props.triggerTarget || reference2);
  3738. nodes.forEach(function(node) {
  3739. if (instance.props.interactive) {
  3740. node.setAttribute("aria-expanded", instance.state.isVisible && node === getCurrentTarget() ? "true" : "false");
  3741. } else {
  3742. node.removeAttribute("aria-expanded");
  3743. }
  3744. });
  3745. }
  3746. function cleanupInteractiveMouseListeners() {
  3747. getDocument().removeEventListener("mousemove", debouncedOnMouseMove);
  3748. mouseMoveListeners = mouseMoveListeners.filter(function(listener) {
  3749. return listener !== debouncedOnMouseMove;
  3750. });
  3751. }
  3752. function onDocumentPress(event) {
  3753. if (currentInput.isTouch) {
  3754. if (didTouchMove || event.type === "mousedown") {
  3755. return;
  3756. }
  3757. }
  3758. var actualTarget = event.composedPath && event.composedPath()[0] || event.target;
  3759. if (instance.props.interactive && actualContains(popper2, actualTarget)) {
  3760. return;
  3761. }
  3762. if (normalizeToArray(instance.props.triggerTarget || reference2).some(function(el) {
  3763. return actualContains(el, actualTarget);
  3764. })) {
  3765. if (currentInput.isTouch) {
  3766. return;
  3767. }
  3768. if (instance.state.isVisible && instance.props.trigger.indexOf("click") >= 0) {
  3769. return;
  3770. }
  3771. } else {
  3772. invokeHook("onClickOutside", [instance, event]);
  3773. }
  3774. if (instance.props.hideOnClick === true) {
  3775. instance.clearDelayTimeouts();
  3776. instance.hide();
  3777. didHideDueToDocumentMouseDown = true;
  3778. setTimeout(function() {
  3779. didHideDueToDocumentMouseDown = false;
  3780. });
  3781. if (!instance.state.isMounted) {
  3782. removeDocumentPress();
  3783. }
  3784. }
  3785. }
  3786. function onTouchMove() {
  3787. didTouchMove = true;
  3788. }
  3789. function onTouchStart() {
  3790. didTouchMove = false;
  3791. }
  3792. function addDocumentPress() {
  3793. var doc = getDocument();
  3794. doc.addEventListener("mousedown", onDocumentPress, true);
  3795. doc.addEventListener("touchend", onDocumentPress, TOUCH_OPTIONS);
  3796. doc.addEventListener("touchstart", onTouchStart, TOUCH_OPTIONS);
  3797. doc.addEventListener("touchmove", onTouchMove, TOUCH_OPTIONS);
  3798. }
  3799. function removeDocumentPress() {
  3800. var doc = getDocument();
  3801. doc.removeEventListener("mousedown", onDocumentPress, true);
  3802. doc.removeEventListener("touchend", onDocumentPress, TOUCH_OPTIONS);
  3803. doc.removeEventListener("touchstart", onTouchStart, TOUCH_OPTIONS);
  3804. doc.removeEventListener("touchmove", onTouchMove, TOUCH_OPTIONS);
  3805. }
  3806. function onTransitionedOut(duration, callback) {
  3807. onTransitionEnd(duration, function() {
  3808. if (!instance.state.isVisible && popper2.parentNode && popper2.parentNode.contains(popper2)) {
  3809. callback();
  3810. }
  3811. });
  3812. }
  3813. function onTransitionedIn(duration, callback) {
  3814. onTransitionEnd(duration, callback);
  3815. }
  3816. function onTransitionEnd(duration, callback) {
  3817. var box = getDefaultTemplateChildren().box;
  3818. function listener(event) {
  3819. if (event.target === box) {
  3820. updateTransitionEndListener(box, "remove", listener);
  3821. callback();
  3822. }
  3823. }
  3824. if (duration === 0) {
  3825. return callback();
  3826. }
  3827. updateTransitionEndListener(box, "remove", currentTransitionEndListener);
  3828. updateTransitionEndListener(box, "add", listener);
  3829. currentTransitionEndListener = listener;
  3830. }
  3831. function on(eventType, handler, options) {
  3832. if (options === void 0) {
  3833. options = false;
  3834. }
  3835. var nodes = normalizeToArray(instance.props.triggerTarget || reference2);
  3836. nodes.forEach(function(node) {
  3837. node.addEventListener(eventType, handler, options);
  3838. listeners.push({
  3839. node,
  3840. eventType,
  3841. handler,
  3842. options
  3843. });
  3844. });
  3845. }
  3846. function addListeners() {
  3847. if (getIsCustomTouchBehavior()) {
  3848. on("touchstart", onTrigger2, {
  3849. passive: true
  3850. });
  3851. on("touchend", onMouseLeave, {
  3852. passive: true
  3853. });
  3854. }
  3855. splitBySpaces(instance.props.trigger).forEach(function(eventType) {
  3856. if (eventType === "manual") {
  3857. return;
  3858. }
  3859. on(eventType, onTrigger2);
  3860. switch (eventType) {
  3861. case "mouseenter":
  3862. on("mouseleave", onMouseLeave);
  3863. break;
  3864. case "focus":
  3865. on(isIE11 ? "focusout" : "blur", onBlurOrFocusOut);
  3866. break;
  3867. case "focusin":
  3868. on("focusout", onBlurOrFocusOut);
  3869. break;
  3870. }
  3871. });
  3872. }
  3873. function removeListeners() {
  3874. listeners.forEach(function(_ref) {
  3875. var node = _ref.node, eventType = _ref.eventType, handler = _ref.handler, options = _ref.options;
  3876. node.removeEventListener(eventType, handler, options);
  3877. });
  3878. listeners = [];
  3879. }
  3880. function onTrigger2(event) {
  3881. var _lastTriggerEvent;
  3882. var shouldScheduleClickHide = false;
  3883. if (!instance.state.isEnabled || isEventListenerStopped(event) || didHideDueToDocumentMouseDown) {
  3884. return;
  3885. }
  3886. var wasFocused = ((_lastTriggerEvent = lastTriggerEvent) == null ? void 0 : _lastTriggerEvent.type) === "focus";
  3887. lastTriggerEvent = event;
  3888. currentTarget = event.currentTarget;
  3889. handleAriaExpandedAttribute();
  3890. if (!instance.state.isVisible && isMouseEvent(event)) {
  3891. mouseMoveListeners.forEach(function(listener) {
  3892. return listener(event);
  3893. });
  3894. }
  3895. if (event.type === "click" && (instance.props.trigger.indexOf("mouseenter") < 0 || isVisibleFromClick) && instance.props.hideOnClick !== false && instance.state.isVisible) {
  3896. shouldScheduleClickHide = true;
  3897. } else {
  3898. scheduleShow(event);
  3899. }
  3900. if (event.type === "click") {
  3901. isVisibleFromClick = !shouldScheduleClickHide;
  3902. }
  3903. if (shouldScheduleClickHide && !wasFocused) {
  3904. scheduleHide(event);
  3905. }
  3906. }
  3907. function onMouseMove(event) {
  3908. var target = event.target;
  3909. var isCursorOverReferenceOrPopper = getCurrentTarget().contains(target) || popper2.contains(target);
  3910. if (event.type === "mousemove" && isCursorOverReferenceOrPopper) {
  3911. return;
  3912. }
  3913. var popperTreeData = getNestedPopperTree().concat(popper2).map(function(popper22) {
  3914. var _instance$popperInsta;
  3915. var instance2 = popper22._tippy;
  3916. var state2 = (_instance$popperInsta = instance2.popperInstance) == null ? void 0 : _instance$popperInsta.state;
  3917. if (state2) {
  3918. return {
  3919. popperRect: popper22.getBoundingClientRect(),
  3920. popperState: state2,
  3921. props
  3922. };
  3923. }
  3924. return null;
  3925. }).filter(Boolean);
  3926. if (isCursorOutsideInteractiveBorder(popperTreeData, event)) {
  3927. cleanupInteractiveMouseListeners();
  3928. scheduleHide(event);
  3929. }
  3930. }
  3931. function onMouseLeave(event) {
  3932. var shouldBail = isEventListenerStopped(event) || instance.props.trigger.indexOf("click") >= 0 && isVisibleFromClick;
  3933. if (shouldBail) {
  3934. return;
  3935. }
  3936. if (instance.props.interactive) {
  3937. instance.hideWithInteractivity(event);
  3938. return;
  3939. }
  3940. scheduleHide(event);
  3941. }
  3942. function onBlurOrFocusOut(event) {
  3943. if (instance.props.trigger.indexOf("focusin") < 0 && event.target !== getCurrentTarget()) {
  3944. return;
  3945. }
  3946. if (instance.props.interactive && event.relatedTarget && popper2.contains(event.relatedTarget)) {
  3947. return;
  3948. }
  3949. scheduleHide(event);
  3950. }
  3951. function isEventListenerStopped(event) {
  3952. return currentInput.isTouch ? getIsCustomTouchBehavior() !== event.type.indexOf("touch") >= 0 : false;
  3953. }
  3954. function createPopperInstance() {
  3955. destroyPopperInstance();
  3956. var _instance$props2 = instance.props, popperOptions = _instance$props2.popperOptions, placement = _instance$props2.placement, offset2 = _instance$props2.offset, getReferenceClientRect = _instance$props2.getReferenceClientRect, moveTransition = _instance$props2.moveTransition;
  3957. var arrow2 = getIsDefaultRenderFn() ? getChildren(popper2).arrow : null;
  3958. var computedReference = getReferenceClientRect ? {
  3959. getBoundingClientRect: getReferenceClientRect,
  3960. contextElement: getReferenceClientRect.contextElement || getCurrentTarget()
  3961. } : reference2;
  3962. var tippyModifier = {
  3963. name: "$$tippy",
  3964. enabled: true,
  3965. phase: "beforeWrite",
  3966. requires: ["computeStyles"],
  3967. fn: function fn5(_ref2) {
  3968. var state2 = _ref2.state;
  3969. if (getIsDefaultRenderFn()) {
  3970. var _getDefaultTemplateCh = getDefaultTemplateChildren(), box = _getDefaultTemplateCh.box;
  3971. ["placement", "reference-hidden", "escaped"].forEach(function(attr) {
  3972. if (attr === "placement") {
  3973. box.setAttribute("data-placement", state2.placement);
  3974. } else {
  3975. if (state2.attributes.popper["data-popper-" + attr]) {
  3976. box.setAttribute("data-" + attr, "");
  3977. } else {
  3978. box.removeAttribute("data-" + attr);
  3979. }
  3980. }
  3981. });
  3982. state2.attributes.popper = {};
  3983. }
  3984. }
  3985. };
  3986. var modifiers = [{
  3987. name: "offset",
  3988. options: {
  3989. offset: offset2
  3990. }
  3991. }, {
  3992. name: "preventOverflow",
  3993. options: {
  3994. padding: {
  3995. top: 2,
  3996. bottom: 2,
  3997. left: 5,
  3998. right: 5
  3999. }
  4000. }
  4001. }, {
  4002. name: "flip",
  4003. options: {
  4004. padding: 5
  4005. }
  4006. }, {
  4007. name: "computeStyles",
  4008. options: {
  4009. adaptive: !moveTransition
  4010. }
  4011. }, tippyModifier];
  4012. if (getIsDefaultRenderFn() && arrow2) {
  4013. modifiers.push({
  4014. name: "arrow",
  4015. options: {
  4016. element: arrow2,
  4017. padding: 3
  4018. }
  4019. });
  4020. }
  4021. modifiers.push.apply(modifiers, (popperOptions == null ? void 0 : popperOptions.modifiers) || []);
  4022. instance.popperInstance = createPopper(computedReference, popper2, Object.assign({}, popperOptions, {
  4023. placement,
  4024. onFirstUpdate,
  4025. modifiers
  4026. }));
  4027. }
  4028. function destroyPopperInstance() {
  4029. if (instance.popperInstance) {
  4030. instance.popperInstance.destroy();
  4031. instance.popperInstance = null;
  4032. }
  4033. }
  4034. function mount() {
  4035. var appendTo = instance.props.appendTo;
  4036. var parentNode;
  4037. var node = getCurrentTarget();
  4038. if (instance.props.interactive && appendTo === TIPPY_DEFAULT_APPEND_TO || appendTo === "parent") {
  4039. parentNode = node.parentNode;
  4040. } else {
  4041. parentNode = invokeWithArgsOrReturn(appendTo, [node]);
  4042. }
  4043. if (!parentNode.contains(popper2)) {
  4044. parentNode.appendChild(popper2);
  4045. }
  4046. instance.state.isMounted = true;
  4047. createPopperInstance();
  4048. }
  4049. function getNestedPopperTree() {
  4050. return arrayFrom(popper2.querySelectorAll("[data-tippy-root]"));
  4051. }
  4052. function scheduleShow(event) {
  4053. instance.clearDelayTimeouts();
  4054. if (event) {
  4055. invokeHook("onTrigger", [instance, event]);
  4056. }
  4057. addDocumentPress();
  4058. var delay = getDelay(true);
  4059. var _getNormalizedTouchSe = getNormalizedTouchSettings(), touchValue = _getNormalizedTouchSe[0], touchDelay = _getNormalizedTouchSe[1];
  4060. if (currentInput.isTouch && touchValue === "hold" && touchDelay) {
  4061. delay = touchDelay;
  4062. }
  4063. if (delay) {
  4064. showTimeout = setTimeout(function() {
  4065. instance.show();
  4066. }, delay);
  4067. } else {
  4068. instance.show();
  4069. }
  4070. }
  4071. function scheduleHide(event) {
  4072. instance.clearDelayTimeouts();
  4073. invokeHook("onUntrigger", [instance, event]);
  4074. if (!instance.state.isVisible) {
  4075. removeDocumentPress();
  4076. return;
  4077. }
  4078. if (instance.props.trigger.indexOf("mouseenter") >= 0 && instance.props.trigger.indexOf("click") >= 0 && ["mouseleave", "mousemove"].indexOf(event.type) >= 0 && isVisibleFromClick) {
  4079. return;
  4080. }
  4081. var delay = getDelay(false);
  4082. if (delay) {
  4083. hideTimeout = setTimeout(function() {
  4084. if (instance.state.isVisible) {
  4085. instance.hide();
  4086. }
  4087. }, delay);
  4088. } else {
  4089. scheduleHideAnimationFrame = requestAnimationFrame(function() {
  4090. instance.hide();
  4091. });
  4092. }
  4093. }
  4094. function enable() {
  4095. instance.state.isEnabled = true;
  4096. }
  4097. function disable() {
  4098. instance.hide();
  4099. instance.state.isEnabled = false;
  4100. }
  4101. function clearDelayTimeouts() {
  4102. clearTimeout(showTimeout);
  4103. clearTimeout(hideTimeout);
  4104. cancelAnimationFrame(scheduleHideAnimationFrame);
  4105. }
  4106. function setProps(partialProps) {
  4107. if (instance.state.isDestroyed) {
  4108. return;
  4109. }
  4110. invokeHook("onBeforeUpdate", [instance, partialProps]);
  4111. removeListeners();
  4112. var prevProps = instance.props;
  4113. var nextProps = evaluateProps(reference2, Object.assign({}, prevProps, removeUndefinedProps(partialProps), {
  4114. ignoreAttributes: true
  4115. }));
  4116. instance.props = nextProps;
  4117. addListeners();
  4118. if (prevProps.interactiveDebounce !== nextProps.interactiveDebounce) {
  4119. cleanupInteractiveMouseListeners();
  4120. debouncedOnMouseMove = debounce(onMouseMove, nextProps.interactiveDebounce);
  4121. }
  4122. if (prevProps.triggerTarget && !nextProps.triggerTarget) {
  4123. normalizeToArray(prevProps.triggerTarget).forEach(function(node) {
  4124. node.removeAttribute("aria-expanded");
  4125. });
  4126. } else if (nextProps.triggerTarget) {
  4127. reference2.removeAttribute("aria-expanded");
  4128. }
  4129. handleAriaExpandedAttribute();
  4130. handleStyles();
  4131. if (onUpdate) {
  4132. onUpdate(prevProps, nextProps);
  4133. }
  4134. if (instance.popperInstance) {
  4135. createPopperInstance();
  4136. getNestedPopperTree().forEach(function(nestedPopper) {
  4137. requestAnimationFrame(nestedPopper._tippy.popperInstance.forceUpdate);
  4138. });
  4139. }
  4140. invokeHook("onAfterUpdate", [instance, partialProps]);
  4141. }
  4142. function setContent2(content) {
  4143. instance.setProps({
  4144. content
  4145. });
  4146. }
  4147. function show() {
  4148. var isAlreadyVisible = instance.state.isVisible;
  4149. var isDestroyed = instance.state.isDestroyed;
  4150. var isDisabled = !instance.state.isEnabled;
  4151. var isTouchAndTouchDisabled = currentInput.isTouch && !instance.props.touch;
  4152. var duration = getValueAtIndexOrReturn(instance.props.duration, 0, defaultProps.duration);
  4153. if (isAlreadyVisible || isDestroyed || isDisabled || isTouchAndTouchDisabled) {
  4154. return;
  4155. }
  4156. if (getCurrentTarget().hasAttribute("disabled")) {
  4157. return;
  4158. }
  4159. invokeHook("onShow", [instance], false);
  4160. if (instance.props.onShow(instance) === false) {
  4161. return;
  4162. }
  4163. instance.state.isVisible = true;
  4164. if (getIsDefaultRenderFn()) {
  4165. popper2.style.visibility = "visible";
  4166. }
  4167. handleStyles();
  4168. addDocumentPress();
  4169. if (!instance.state.isMounted) {
  4170. popper2.style.transition = "none";
  4171. }
  4172. if (getIsDefaultRenderFn()) {
  4173. var _getDefaultTemplateCh2 = getDefaultTemplateChildren(), box = _getDefaultTemplateCh2.box, content = _getDefaultTemplateCh2.content;
  4174. setTransitionDuration([box, content], 0);
  4175. }
  4176. onFirstUpdate = function onFirstUpdate2() {
  4177. var _instance$popperInsta2;
  4178. if (!instance.state.isVisible || ignoreOnFirstUpdate) {
  4179. return;
  4180. }
  4181. ignoreOnFirstUpdate = true;
  4182. void popper2.offsetHeight;
  4183. popper2.style.transition = instance.props.moveTransition;
  4184. if (getIsDefaultRenderFn() && instance.props.animation) {
  4185. var _getDefaultTemplateCh3 = getDefaultTemplateChildren(), _box = _getDefaultTemplateCh3.box, _content = _getDefaultTemplateCh3.content;
  4186. setTransitionDuration([_box, _content], duration);
  4187. setVisibilityState([_box, _content], "visible");
  4188. }
  4189. handleAriaContentAttribute();
  4190. handleAriaExpandedAttribute();
  4191. pushIfUnique(mountedInstances, instance);
  4192. (_instance$popperInsta2 = instance.popperInstance) == null ? void 0 : _instance$popperInsta2.forceUpdate();
  4193. invokeHook("onMount", [instance]);
  4194. if (instance.props.animation && getIsDefaultRenderFn()) {
  4195. onTransitionedIn(duration, function() {
  4196. instance.state.isShown = true;
  4197. invokeHook("onShown", [instance]);
  4198. });
  4199. }
  4200. };
  4201. mount();
  4202. }
  4203. function hide2() {
  4204. var isAlreadyHidden = !instance.state.isVisible;
  4205. var isDestroyed = instance.state.isDestroyed;
  4206. var isDisabled = !instance.state.isEnabled;
  4207. var duration = getValueAtIndexOrReturn(instance.props.duration, 1, defaultProps.duration);
  4208. if (isAlreadyHidden || isDestroyed || isDisabled) {
  4209. return;
  4210. }
  4211. invokeHook("onHide", [instance], false);
  4212. if (instance.props.onHide(instance) === false) {
  4213. return;
  4214. }
  4215. instance.state.isVisible = false;
  4216. instance.state.isShown = false;
  4217. ignoreOnFirstUpdate = false;
  4218. isVisibleFromClick = false;
  4219. if (getIsDefaultRenderFn()) {
  4220. popper2.style.visibility = "hidden";
  4221. }
  4222. cleanupInteractiveMouseListeners();
  4223. removeDocumentPress();
  4224. handleStyles(true);
  4225. if (getIsDefaultRenderFn()) {
  4226. var _getDefaultTemplateCh4 = getDefaultTemplateChildren(), box = _getDefaultTemplateCh4.box, content = _getDefaultTemplateCh4.content;
  4227. if (instance.props.animation) {
  4228. setTransitionDuration([box, content], duration);
  4229. setVisibilityState([box, content], "hidden");
  4230. }
  4231. }
  4232. handleAriaContentAttribute();
  4233. handleAriaExpandedAttribute();
  4234. if (instance.props.animation) {
  4235. if (getIsDefaultRenderFn()) {
  4236. onTransitionedOut(duration, instance.unmount);
  4237. }
  4238. } else {
  4239. instance.unmount();
  4240. }
  4241. }
  4242. function hideWithInteractivity(event) {
  4243. getDocument().addEventListener("mousemove", debouncedOnMouseMove);
  4244. pushIfUnique(mouseMoveListeners, debouncedOnMouseMove);
  4245. debouncedOnMouseMove(event);
  4246. }
  4247. function unmount() {
  4248. if (instance.state.isVisible) {
  4249. instance.hide();
  4250. }
  4251. if (!instance.state.isMounted) {
  4252. return;
  4253. }
  4254. destroyPopperInstance();
  4255. getNestedPopperTree().forEach(function(nestedPopper) {
  4256. nestedPopper._tippy.unmount();
  4257. });
  4258. if (popper2.parentNode) {
  4259. popper2.parentNode.removeChild(popper2);
  4260. }
  4261. mountedInstances = mountedInstances.filter(function(i) {
  4262. return i !== instance;
  4263. });
  4264. instance.state.isMounted = false;
  4265. invokeHook("onHidden", [instance]);
  4266. }
  4267. function destroy() {
  4268. if (instance.state.isDestroyed) {
  4269. return;
  4270. }
  4271. instance.clearDelayTimeouts();
  4272. instance.unmount();
  4273. removeListeners();
  4274. delete reference2._tippy;
  4275. instance.state.isDestroyed = true;
  4276. invokeHook("onDestroy", [instance]);
  4277. }
  4278. }
  4279. function tippy(targets, optionalProps) {
  4280. if (optionalProps === void 0) {
  4281. optionalProps = {};
  4282. }
  4283. var plugins = defaultProps.plugins.concat(optionalProps.plugins || []);
  4284. bindGlobalEventListeners();
  4285. var passedProps = Object.assign({}, optionalProps, {
  4286. plugins
  4287. });
  4288. var elements = getArrayOfElements(targets);
  4289. var instances = elements.reduce(function(acc, reference2) {
  4290. var instance = reference2 && createTippy(reference2, passedProps);
  4291. if (instance) {
  4292. acc.push(instance);
  4293. }
  4294. return acc;
  4295. }, []);
  4296. return isElement(targets) ? instances[0] : instances;
  4297. }
  4298. tippy.defaultProps = defaultProps;
  4299. tippy.setDefaultProps = setDefaultProps;
  4300. tippy.currentInput = currentInput;
  4301. Object.assign({}, applyStyles$1, {
  4302. effect: function effect2(_ref) {
  4303. var state = _ref.state;
  4304. var initialStyles = {
  4305. popper: {
  4306. position: state.options.strategy,
  4307. left: "0",
  4308. top: "0",
  4309. margin: "0"
  4310. },
  4311. arrow: {
  4312. position: "absolute"
  4313. },
  4314. reference: {}
  4315. };
  4316. Object.assign(state.elements.popper.style, initialStyles.popper);
  4317. state.styles = initialStyles;
  4318. if (state.elements.arrow) {
  4319. Object.assign(state.elements.arrow.style, initialStyles.arrow);
  4320. }
  4321. }
  4322. });
  4323. tippy.setDefaultProps({
  4324. render
  4325. });
  4326.  
  4327. })
  4328. };
  4329. }));
  4330.  
  4331. System.import("./__entry.js", "./");