// ==UserScript==
// @name ast explorer助手
// @namespace https://github.com/CC11001100/ast-explorer-helper
// @version 0.3.0
// @description 用于分析ast时辅助提高效率,支持复制和右键菜单,以及元素高亮
// @author CC11001100
// @match https://astexplorer.net/
// @grant none
// @license MIT
// @supportURL https://github.com/CC11001100/ast-explorer-helper/issues
// @homepageURL https://github.com/CC11001100/ast-explorer-helper
// ==/UserScript==
// /**
// * _ ____ _____ _____ _ _ _ _
// * / \ / ___|_ _| | ____|_ ___ __ | | ___ _ __ ___ _ __| | | | ___| |_ __ ___ _ __
// * / _ \ \___ \ | | | _| \ \/ / '_ \| |/ _ \| '__/ _ \ '__| |_| |/ _ \ | '_ \ / _ \ '__|
// * / ___ \ ___) || | | |___ > <| |_) | | (_) | | | __/ | | _ | __/ | |_) | __/ |
// */_/ \_\____/ |_| |_____/_/\_\ .__/|_|\___/|_| \___|_| |_| |_|\___|_| .__/ \___|_|
// * |_| |_|
// *
// * ast-explorer-helper v0.3.0 - 用于分析ast时辅助提高效率,支持复制和右键菜单,以及元素高亮
// *
// */
/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
/******/ (() => { // webpackBootstrap
/******/ "use strict";
/******/ var __webpack_modules__ = ({
/***/ 18:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ collectSettingsFromForm: () => (/* reexport safe */ _settings_tab_component__WEBPACK_IMPORTED_MODULE_0__.collectSettingsFromForm),\n/* harmony export */ createSettingsTabContent: () => (/* reexport safe */ _settings_tab_component__WEBPACK_IMPORTED_MODULE_0__.createSettingsTabContent),\n/* harmony export */ getSettingsTabStyles: () => (/* reexport safe */ _settings_tab_component__WEBPACK_IMPORTED_MODULE_0__.getSettingsTabStyles)\n/* harmony export */ });\n/* harmony import */ var _settings_tab_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(974);\n/**\n * 设置标签页组件 - 入口文件\n */\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTguanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztHQUVHO0FBTStCIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYXN0LWV4cGxvcmVyLWhlbHBlci8uL3NyYy91aS9zZXR0aW5ncy10YWIvaW5kZXgudHM/NzMxOCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIOiuvue9ruagh+etvumhtee7hOS7tiAtIOWFpeWPo+aWh+S7tlxuICovXG5cbmV4cG9ydCB7IFxuICAgIGNvbGxlY3RTZXR0aW5nc0Zyb21Gb3JtLFxuICAgIGdldFNldHRpbmdzVGFiU3R5bGVzLFxuICAgIGNyZWF0ZVNldHRpbmdzVGFiQ29udGVudFxufSBmcm9tICcuL3NldHRpbmdzLXRhYi5jb21wb25lbnQnOyAiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///18\n");
/***/ }),
/***/ 55:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createModalTemplate: () => (/* binding */ createModalTemplate),\n/* harmony export */ createSettingsButtonTemplate: () => (/* binding */ createSettingsButtonTemplate),\n/* harmony export */ createToastTemplate: () => (/* binding */ createToastTemplate)\n/* harmony export */ });\n/**\n * 设置UI组件 - 模板文件\n */\n/**\n * 创建设置按钮模板\n * @returns 设置按钮HTML\n */\nfunction createSettingsButtonTemplate() {\n return `\n <div class=\"settings-button-inner\">\n <svg width=\"22\" height=\"22\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path class=\"gear-path\" d=\"M12 15C13.6569 15 15 13.6569 15 12C15 10.3431 13.6569 9 12 9C10.3431 9 9 10.3431 9 12C9 13.6569 10.3431 15 12 15Z\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path class=\"gear-path\" d=\"M19.4 15C19.2669 15.3016 19.2272 15.6362 19.286 15.9606C19.3448 16.285 19.4995 16.5843 19.73 16.82L19.79 16.88C19.976 17.0657 20.1235 17.2863 20.2241 17.5291C20.3248 17.7719 20.3766 18.0322 20.3766 18.295C20.3766 18.5578 20.3248 18.8181 20.2241 19.0609C20.1235 19.3037 19.976 19.5243 19.79 19.71C19.6043 19.896 19.3837 20.0435 19.1409 20.1441C18.8981 20.2448 18.6378 20.2966 18.375 20.2966C18.1122 20.2966 17.8519 20.2448 17.6091 20.1441C17.3663 20.0435 17.1457 19.896 16.96 19.71L16.9 19.65C16.6643 19.4195 16.365 19.2648 16.0406 19.206C15.7162 19.1472 15.3816 19.1869 15.08 19.32C14.7842 19.4468 14.532 19.6572 14.3543 19.9255C14.1766 20.1938 14.0813 20.5082 14.08 20.83V21C14.08 21.5304 13.8693 22.0391 13.4942 22.4142C13.1191 22.7893 12.6104 23 12.08 23C11.5496 23 11.0409 22.7893 10.6658 22.4142C10.2907 22.0391 10.08 21.5304 10.08 21V20.91C10.0723 20.579 9.96512 20.258 9.77251 19.9887C9.5799 19.7194 9.31074 19.5143 9 19.4C8.69838 19.2669 8.36381 19.2272 8.03941 19.286C7.71502 19.3448 7.41568 19.4995 7.18 19.73L7.12 19.79C6.93425 19.976 6.71368 20.1235 6.47088 20.2241C6.22808 20.3248 5.96783 20.3766 5.705 20.3766C5.44217 20.3766 5.18192 20.3248 4.93912 20.2241C4.69632 20.1235 4.47575 19.976 4.29 19.79C4.10405 19.6043 3.95653 19.3837 3.85588 19.1409C3.75523 18.8981 3.70343 18.6378 3.70343 18.375C3.70343 18.1122 3.75523 17.8519 3.85588 17.6091C3.95653 17.3663 4.10405 17.1457 4.29 16.96L4.35 16.9C4.58054 16.6643 4.73519 16.365 4.794 16.0406C4.85282 15.7162 4.81312 15.3816 4.68 15.08C4.55324 14.7842 4.34276 14.532 4.07447 14.3543C3.80618 14.1766 3.49179 14.0813 3.17 14.08H3C2.46957 14.08 1.96086 13.8693 1.58579 13.4942C1.21071 13.1191 1 12.6104 1 12.08C1 11.5496 1.21071 11.0409 1.58579 10.6658C1.96086 10.2907 2.46957 10.08 3 10.08H3.09C3.42099 10.0723 3.742 9.96512 4.0113 9.77251C4.28059 9.5799 4.48572 9.31074 4.6 9C4.73312 8.69838 4.77282 8.36381 4.714 8.03941C4.65519 7.71502 4.50054 7.41568 4.27 7.18L4.21 7.12C4.02405 6.93425 3.87653 6.71368 3.77588 6.47088C3.67523 6.22808 3.62343 5.96783 3.62343 5.705C3.62343 5.44217 3.67523 5.18192 3.77588 4.93912C3.87653 4.69632 4.02405 4.47575 4.21 4.29C4.39575 4.10405 4.61632 3.95653 4.85912 3.85588C5.10192 3.75523 5.36217 3.70343 5.625 3.70343C5.88783 3.70343 6.14808 3.75523 6.39088 3.85588C6.63368 3.95653 6.85425 4.10405 7.04 4.29L7.1 4.35C7.33568 4.58054 7.63502 4.73519 7.95941 4.794C8.28381 4.85282 8.61838 4.81312 8.92 4.68H9C9.29577 4.55324 9.54802 4.34276 9.72569 4.07447C9.90337 3.80618 9.99872 3.49179 10 3.17V3C10 2.46957 10.2107 1.96086 10.5858 1.58579C10.9609 1.21071 11.4696 1 12 1C12.5304 1 13.0391 1.21071 13.4142 1.58579C13.7893 1.96086 14 2.46957 14 3V3.09C14.0013 3.41179 14.0966 3.72618 14.2743 3.99447C14.452 4.26276 14.7042 4.47324 15 4.6C15.3016 4.73312 15.6362 4.77282 15.9606 4.714C16.285 4.65519 16.5843 4.50054 16.82 4.27L16.88 4.21C17.0657 4.02405 17.2863 3.87653 17.5291 3.77588C17.7719 3.67523 18.0322 3.62343 18.295 3.62343C18.5578 3.62343 18.8181 3.67523 19.0609 3.77588C19.3037 3.87653 19.5243 4.02405 19.71 4.21C19.896 4.39575 20.0435 4.61632 20.1441 4.85912C20.2448 5.10192 20.2966 5.36217 20.2966 5.625C20.2966 5.88783 20.2448 6.14808 20.1441 6.39088C20.0435 6.63368 19.896 6.85425 19.71 7.04L19.65 7.1C19.4195 7.33568 19.2648 7.63502 19.206 7.95941C19.1472 8.28381 19.1869 8.61838 19.32 8.92V9C19.4468 9.29577 19.6572 9.54802 19.9255 9.72569C20.1938 9.90337 20.5082 9.99872 20.83 10H21C21.5304 10 22.0391 10.2107 22.4142 10.5858C22.7893 10.9609 23 11.4696 23 12C23 12.5304 22.7893 13.0391 22.4142 13.4142C22.0391 13.7893 21.5304 14 21 14H20.91C20.5882 14.0013 20.2738 14.0966 20.0055 14.2743C19.7372 14.452 19.5268 14.7042 19.4 15Z\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n <div class=\"ripple-effect\"></div>\n </div>\n `;\n}\n/**\n * 创建模态框模板\n * @returns 模态框HTML结构\n */\nfunction createModalTemplate() {\n return `\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <h3>AST Explorer 助手</h3>\n <button class=\"close-button\">×</button>\n </div>\n <!-- 标签页导航将在这里插入 -->\n <div class=\"modal-body\">\n <!-- 标签页内容将在这里插入 -->\n </div>\n <div class=\"modal-footer\">\n <button id=\"save-settings\" class=\"only-settings-tab\">保存设置</button>\n </div>\n </div>\n `;\n}\n/**\n * 创建成功提示模板\n * @returns 提示HTML\n */\nfunction createToastTemplate() {\n return `\n <div class=\"settings-toast\">设置已保存</div>\n `;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTUuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7O0dBRUc7QUFFSDs7O0dBR0c7QUFDSSxTQUFTLDRCQUE0QjtJQUN4QyxPQUFPOzs7Ozs7OztLQVFOLENBQUM7QUFDTixDQUFDO0FBRUQ7OztHQUdHO0FBQ0ksU0FBUyxtQkFBbUI7SUFDL0IsT0FBTzs7Ozs7Ozs7Ozs7Ozs7S0FjTixDQUFDO0FBQ04sQ0FBQztBQUVEOzs7R0FHRztBQUNJLFNBQVMsbUJBQW1CO0lBQy9CLE9BQU87O0tBRU4sQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL3VpL3NldHRpbmdzLXVpL3NldHRpbmdzLXVpLnRlbXBsYXRlLnRzP2E4OWQiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDorr7nva5VSee7hOS7tiAtIOaooeadv+aWh+S7tlxuICovXG5cbi8qKlxuICog5Yib5bu66K6+572u5oyJ6ZKu5qih5p2/XG4gKiBAcmV0dXJucyDorr7nva7mjInpkq5IVE1MXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXR0aW5nc0J1dHRvblRlbXBsYXRlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBcbiAgICAgICAgPGRpdiBjbGFzcz1cInNldHRpbmdzLWJ1dHRvbi1pbm5lclwiPlxuICAgICAgICAgICAgPHN2ZyB3aWR0aD1cIjIyXCIgaGVpZ2h0PVwiMjJcIiB2aWV3Qm94PVwiMCAwIDI0IDI0XCIgZmlsbD1cIm5vbmVcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCI+XG4gICAgICAgICAgICAgICAgPHBhdGggY2xhc3M9XCJnZWFyLXBhdGhcIiBkPVwiTTEyIDE1QzEzLjY1NjkgMTUgMTUgMTMuNjU2OSAxNSAxMkMxNSAxMC4zNDMxIDEzLjY1NjkgOSAxMiA5QzEwLjM0MzEgOSA5IDEwLjM0MzEgOSAxMkM5IDEzLjY1NjkgMTAuMzQzMSAxNSAxMiAxNVpcIiBzdHJva2U9XCJjdXJyZW50Q29sb3JcIiBzdHJva2Utd2lkdGg9XCIxLjVcIiBzdHJva2UtbGluZWNhcD1cInJvdW5kXCIgc3Ryb2tlLWxpbmVqb2luPVwicm91bmRcIi8+XG4gICAgICAgICAgICAgICAgPHBhdGggY2xhc3M9XCJnZWFyLXBhdGhcIiBkPVwiTTE5LjQgMTVDMTkuMjY2OSAxNS4zMDE2IDE5LjIyNzIgMTUuNjM2MiAxOS4yODYgMTUuOTYwNkMxOS4zNDQ4IDE2LjI4NSAxOS40OTk1IDE2LjU4NDMgMTkuNzMgMTYuODJMMTkuNzkgMTYuODhDMTkuOTc2IDE3LjA2NTcgMjAuMTIzNSAxNy4yODYzIDIwLjIyNDEgMTcuNTI5MUMyMC4zMjQ4IDE3Ljc3MTkgMjAuMzc2NiAxOC4wMzIyIDIwLjM3NjYgMTguMjk1QzIwLjM3NjYgMTguNTU3OCAyMC4zMjQ4IDE4LjgxODEgMjAuMjI0MSAxOS4wNjA5QzIwLjEyMzUgMTkuMzAzNyAxOS45NzYgMTkuNTI0MyAxOS43OSAxOS43MUMxOS42MDQzIDE5Ljg5NiAxOS4zODM3IDIwLjA0MzUgMTkuMTQwOSAyMC4xNDQxQzE4Ljg5ODEgMjAuMjQ0OCAxOC42Mzc4IDIwLjI5NjYgMTguMzc1IDIwLjI5NjZDMTguMTEyMiAyMC4yOTY2IDE3Ljg1MTkgMjAuMjQ0OCAxNy42MDkxIDIwLjE0NDFDMTcuMzY2MyAyMC4wNDM1IDE3LjE0NTcgMTkuODk2IDE2Ljk2IDE5LjcxTDE2LjkgMTkuNjVDMTYuNjY0MyAxOS40MTk1IDE2LjM2NSAxOS4yNjQ4IDE2LjA0MDYgMTkuMjA2QzE1LjcxNjIgMTkuMTQ3MiAxNS4zODE2IDE5LjE4NjkgMTUuMDggMTkuMzJDMTQuNzg0MiAxOS40NDY4IDE0LjUzMiAxOS42NTcyIDE0LjM1NDMgMTkuOTI1NUMxNC4xNzY2IDIwLjE5MzggMTQuMDgxMyAyMC41MDgyIDE0LjA4IDIwLjgzVjIxQzE0LjA4IDIxLjUzMDQgMTMuODY5MyAyMi4wMzkxIDEzLjQ5NDIgMjIuNDE0MkMxMy4xMTkxIDIyLjc4OTMgMTIuNjEwNCAyMyAxMi4wOCAyM0MxMS41NDk2IDIzIDExLjA0MDkgMjIuNzg5MyAxMC42NjU4IDIyLjQxNDJDMTAuMjkwNyAyMi4wMzkxIDEwLjA4IDIxLjUzMDQgMTAuMDggMjFWMjAuOTFDMTAuMDcyMyAyMC41NzkgOS45NjUxMiAyMC4yNTggOS43NzI1MSAxOS45ODg3QzkuNTc5OSAxOS43MTk0IDkuMzEwNzQgMTkuNTE0MyA5IDE5LjRDOC42OTgzOCAxOS4yNjY5IDguMzYzODEgMTkuMjI3MiA4LjAzOTQxIDE5LjI4NkM3LjcxNTAyIDE5LjM0NDggNy40MTU2OCAxOS40OTk1IDcuMTggMTkuNzNMNy4xMiAxOS43OUM2LjkzNDI1IDE5Ljk3NiA2LjcxMzY4IDIwLjEyMzUgNi40NzA4OCAyMC4yMjQxQzYuMjI4MDggMjAuMzI0OCA1Ljk2NzgzIDIwLjM3NjYgNS43MDUgMjAuMzc2NkM1LjQ0MjE3IDIwLjM3NjYgNS4xODE5MiAyMC4zMjQ4IDQuOTM5MTIgMjAuMjI0MUM0LjY5NjMyIDIwLjEyMzUgNC40NzU3NSAxOS45NzYgNC4yOSAxOS43OUM0LjEwNDA1IDE5LjYwNDMgMy45NTY1MyAxOS4zODM3IDMuODU1ODggMTkuMTQwOUMzLjc1NTIzIDE4Ljg5ODEgMy43MDM0MyAxOC42Mzc4IDMuNzAzNDMgMTguMzc1QzMuNzAzNDMgMTguMTEyMiAzLjc1NTIzIDE3Ljg1MTkgMy44NTU4OCAxNy42MDkxQzMuOTU2NTMgMTcuMzY2MyA0LjEwNDA1IDE3LjE0NTcgNC4yOSAxNi45Nkw0LjM1IDE2LjlDNC41ODA1NCAxNi42NjQzIDQuNzM1MTkgMTYuMzY1IDQuNzk0IDE2LjA0MDZDNC44NTI4MiAxNS43MTYyIDQuODEzMTIgMTUuMzgxNiA0LjY4IDE1LjA4QzQuNTUzMjQgMTQuNzg0MiA0LjM0Mjc2IDE0LjUzMiA0LjA3NDQ3IDE0LjM1NDNDMy44MDYxOCAxNC4xNzY2IDMuNDkxNzkgMTQuMDgxMyAzLjE3IDE0LjA4SDNDMi40Njk1NyAxNC4wOCAxLjk2MDg2IDEzLjg2OTMgMS41ODU3OSAxMy40OTQyQzEuMjEwNzEgMTMuMTE5MSAxIDEyLjYxMDQgMSAxMi4wOEMxIDExLjU0OTYgMS4yMTA3MSAxMS4wNDA5IDEuNTg1NzkgMTAuNjY1OEMxLjk2MDg2IDEwLjI5MDcgMi40Njk1NyAxMC4wOCAzIDEwLjA4SDMuMDlDMy40MjA5OSAxMC4wNzIzIDMuNzQyIDkuOTY1MTIgNC4wMTEzIDkuNzcyNTFDNC4yODA1OSA5LjU3OTkgNC40ODU3MiA5LjMxMDc0IDQuNiA5QzQuNzMzMTIgOC42OTgzOCA0Ljc3MjgyIDguMzYzODEgNC43MTQgOC4wMzk0MUM0LjY1NTE5IDcuNzE1MDIgNC41MDA1NCA3LjQxNTY4IDQuMjcgNy4xOEw0LjIxIDcuMTJDNC4wMjQwNSA2LjkzNDI1IDMuODc2NTMgNi43MTM2OCAzLjc3NTg4IDYuNDcwODhDMy42NzUyMyA2LjIyODA4IDMuNjIzNDMgNS45Njc4MyAzLjYyMzQzIDUuNzA1QzMuNjIzNDMgNS40NDIxNyAzLjY3NTIzIDUuMTgxOTIgMy43NzU4OCA0LjkzOTEyQzMuODc2NTMgNC42OTYzMiA0LjAyNDA1IDQuNDc1NzUgNC4yMSA0LjI5QzQuMzk1NzUgNC4xMDQwNSA0LjYxNjMyIDMuOTU2NTMgNC44NTkxMiAzLjg1NTg4QzUuMTAxOTIgMy43NTUyMyA1LjM2MjE3IDMuNzAzNDMgNS42MjUgMy43MDM0M0M1Ljg4NzgzIDMuNzAzNDMgNi4xNDgwOCAzLjc1NTIzIDYuMzkwODggMy44NTU4OEM2LjYzMzY4IDMuOTU2NTMgNi44NTQyNSA0LjEwNDA1IDcuMDQgNC4yOUw3LjEgNC4zNUM3LjMzNTY4IDQuNTgwNTQgNy42MzUwMiA0LjczNTE5IDcuOTU5NDEgNC43OTRDOC4yODM4MSA0Ljg1MjgyIDguNjE4MzggNC44MTMxMiA4LjkyIDQuNjhIOUM5LjI5NTc3IDQuNTUzMjQgOS41NDgwMiA0LjM0Mjc2IDkuNzI1NjkgNC4wNzQ0N0M5LjkwMzM3IDMuODA2MTggOS45OTg3MiAzLjQ5MTc5IDEwIDMuMTdWM0MxMCAyLjQ2OTU3IDEwLjIxMDcgMS45NjA4NiAxMC41ODU4IDEuNTg1NzlDMTAuOTYwOSAxLjIxMDcxIDExLjQ2OTYgMSAxMiAxQzEyLjUzMDQgMSAxMy4wMzkxIDEuMjEwNzEgMTMuNDE0MiAxLjU4NTc5QzEzLjc4OTMgMS45NjA4NiAxNCAyLjQ2OTU3IDE0IDNWMy4wOUMxNC4wMDEzIDMuNDExNzkgMTQuMDk2NiAzLjcyNjE4IDE0LjI3NDMgMy45OTQ0N0MxNC40NTIgNC4yNjI3NiAxNC43MDQyIDQuNDczMjQgMTUgNC42QzE1LjMwMTYgNC43MzMxMiAxNS42MzYyIDQuNzcyODIgMTUuOTYwNiA0LjcxNEMxNi4yODUgNC42NTUxOSAxNi41ODQzIDQuNTAwNTQgMTYuODIgNC4yN0wxNi44OCA0LjIxQzE3LjA2NTcgNC4wMjQwNSAxNy4yODYzIDMuODc2NTMgMTcuNTI5MSAzLjc3NTg4QzE3Ljc3MTkgMy42NzUyMyAxOC4wMzIyIDMuNjIzNDMgMTguMjk1IDMuNjIzNDNDMTguNTU3OCAzLjYyMzQzIDE4LjgxODEgMy42NzUyMyAxOS4wNjA5IDMuNzc1ODhDMTkuMzAzNyAzLjg3NjUzIDE5LjUyNDMgNC4wMjQwNSAxOS43MSA0LjIxQzE5Ljg5NiA0LjM5NTc1IDIwLjA0MzUgNC42MTYzMiAyMC4xNDQxIDQuODU5MTJDMjAuMjQ0OCA1LjEwMTkyIDIwLjI5NjYgNS4zNjIxNyAyMC4yOTY2IDUuNjI1QzIwLjI5NjYgNS44ODc4MyAyMC4yNDQ4IDYuMTQ4MDggMjAuMTQ0MSA2LjM5MDg4QzIwLjA0MzUgNi42MzM2OCAxOS44OTYgNi44NTQyNSAxOS43MSA3LjA0TDE5LjY1IDcuMUMxOS40MTk1IDcuMzM1NjggMTkuMjY0OCA3LjYzNTAyIDE5LjIwNiA3Ljk1OTQxQzE5LjE0NzIgOC4yODM4MSAxOS4xODY5IDguNjE4MzggMTkuMzIgOC45MlY5QzE5LjQ0NjggOS4yOTU3NyAxOS42NTcyIDkuNTQ4MDIgMTkuOTI1NSA5LjcyNTY5QzIwLjE5MzggOS45MDMzNyAyMC41MDgyIDkuOTk4NzIgMjAuODMgMTBIMjFDMjEuNTMwNCAxMCAyMi4wMzkxIDEwLjIxMDcgMjIuNDE0MiAxMC41ODU4QzIyLjc4OTMgMTAuOTYwOSAyMyAxMS40Njk2IDIzIDEyQzIzIDEyLjUzMDQgMjIuNzg5MyAxMy4wMzkxIDIyLjQxNDIgMTMuNDE0MkMyMi4wMzkxIDEzLjc4OTMgMjEuNTMwNCAxNCAyMSAxNEgyMC45MUMyMC41ODgyIDE0LjAwMTMgMjAuMjczOCAxNC4wOTY2IDIwLjAwNTUgMTQuMjc0M0MxOS43MzcyIDE0LjQ1MiAxOS41MjY4IDE0LjcwNDIgMTkuNCAxNVpcIiBzdHJva2U9XCJjdXJyZW50Q29sb3JcIiBzdHJva2Utd2lkdGg9XCIxLjVcIiBzdHJva2UtbGluZWNhcD1cInJvdW5kXCIgc3Ryb2tlLWxpbmVqb2luPVwicm91bmRcIi8+XG4gICAgICAgICAgICA8L3N2Zz5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyaXBwbGUtZWZmZWN0XCI+PC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgIGA7XG59XG5cbi8qKlxuICog5Yib5bu65qih5oCB5qGG5qih5p2/XG4gKiBAcmV0dXJucyDmqKHmgIHmoYZIVE1M57uT5p6EXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVNb2RhbFRlbXBsYXRlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBcbiAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWNvbnRlbnRcIj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJtb2RhbC1oZWFkZXJcIj5cbiAgICAgICAgICAgICAgICA8aDM+QVNUIEV4cGxvcmVyIOWKqeaJizwvaDM+XG4gICAgICAgICAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImNsb3NlLWJ1dHRvblwiPiZ0aW1lczs8L2J1dHRvbj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPCEtLSDmoIfnrb7pobXlr7zoiKrlsIblnKjov5nph4zmj5LlhaUgLS0+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwibW9kYWwtYm9keVwiPlxuICAgICAgICAgICAgICAgIDwhLS0g5qCH562+6aG15YaF5a655bCG5Zyo6L+Z6YeM5o+S5YWlIC0tPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwibW9kYWwtZm9vdGVyXCI+XG4gICAgICAgICAgICAgICAgPGJ1dHRvbiBpZD1cInNhdmUtc2V0dGluZ3NcIiBjbGFzcz1cIm9ubHktc2V0dGluZ3MtdGFiXCI+5L+d5a2Y6K6+572uPC9idXR0b24+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgYDtcbn1cblxuLyoqXG4gKiDliJvlu7rmiJDlip/mj5DnpLrmqKHmnb9cbiAqIEByZXR1cm5zIOaPkOekukhUTUxcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRvYXN0VGVtcGxhdGUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYFxuICAgICAgICA8ZGl2IGNsYXNzPVwic2V0dGluZ3MtdG9hc3RcIj7orr7nva7lt7Lkv53lrZg8L2Rpdj5cbiAgICBgO1xufSAiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///55\n");
/***/ }),
/***/ 126:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createAboutTabContent: () => (/* reexport safe */ _about_tab_template__WEBPACK_IMPORTED_MODULE_2__.createAboutTabContent),\n/* harmony export */ getAboutTabStyles: () => (/* reexport safe */ _about_tab_styles__WEBPACK_IMPORTED_MODULE_1__.getAboutTabStyles),\n/* harmony export */ getRepoStatsFromCache: () => (/* reexport safe */ _about_tab_template__WEBPACK_IMPORTED_MODULE_2__.getRepoStatsFromCache)\n/* harmony export */ });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(610);\n/* harmony import */ var _about_tab_styles__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(379);\n/* harmony import */ var _about_tab_template__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(707);\n/**\n * 关于标签页组件 - 逻辑文件\n */\n\n// 导出公共API\n\n\n_logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('已加载关于标签页组件');\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTI2LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztHQUVHO0FBRW1DO0FBSXRDLFVBQVU7QUFDNkM7QUFDNkI7QUFFcEYsMkNBQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL3VpL2Fib3V0LXRhYi9hYm91dC10YWIuY29tcG9uZW50LnRzP2JiYWYiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDlhbPkuo7moIfnrb7pobXnu4Tku7YgLSDpgLvovpHmlofku7ZcbiAqL1xuXG5pbXBvcnQgeyBsb2dnZXIgfSBmcm9tICcuLi8uLi9sb2dnZXInO1xuaW1wb3J0IHsgZ2V0QWJvdXRUYWJTdHlsZXMgfSBmcm9tICcuL2Fib3V0LXRhYi5zdHlsZXMnO1xuaW1wb3J0IHsgY3JlYXRlQWJvdXRUYWJDb250ZW50LCBnZXRSZXBvU3RhdHNGcm9tQ2FjaGUgfSBmcm9tICcuL2Fib3V0LXRhYi50ZW1wbGF0ZSc7XG5cbi8vIOWvvOWHuuWFrOWFsUFQSVxuZXhwb3J0IHsgZ2V0QWJvdXRUYWJTdHlsZXMgfSBmcm9tICcuL2Fib3V0LXRhYi5zdHlsZXMnO1xuZXhwb3J0IHsgY3JlYXRlQWJvdXRUYWJDb250ZW50LCBnZXRSZXBvU3RhdHNGcm9tQ2FjaGUgfSBmcm9tICcuL2Fib3V0LXRhYi50ZW1wbGF0ZSc7XG5cbmxvZ2dlci5kZWJ1Zygn5bey5Yqg6L295YWz5LqO5qCH562+6aG157uE5Lu2Jyk7ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///126\n");
/***/ }),
/***/ 135:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getModalStyles: () => (/* binding */ getModalStyles),\n/* harmony export */ getSettingsButtonStyles: () => (/* binding */ getSettingsButtonStyles),\n/* harmony export */ getToastStyles: () => (/* binding */ getToastStyles)\n/* harmony export */ });\n/**\n * 设置UI组件 - 样式文件\n */\n/**\n * 获取设置按钮的样式\n * @returns 按钮CSS样式\n */\nfunction getSettingsButtonStyles() {\n return `\n #ast-settings-button .settings-button-inner {\n width: 100%;\n height: 100%;\n border-radius: 50%;\n display: flex;\n align-items: center;\n justify-content: center;\n position: relative;\n background: linear-gradient(145deg, #ffffff, #f0f0f0);\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.1),\n -5px -5px 10px rgba(255, 255, 255, 0.8);\n color: #4a90e2;\n transition: all 0.3s ease;\n overflow: hidden;\n }\n \n #ast-settings-button:hover .settings-button-inner {\n box-shadow: 4px 4px 8px rgba(0, 0, 0, 0.15),\n -4px -4px 8px rgba(255, 255, 255, 0.9);\n color: #2563eb;\n }\n \n #ast-settings-button:active .settings-button-inner {\n background: linear-gradient(135deg, #e6e6e6, #ffffff);\n box-shadow: inset 2px 2px 5px rgba(0, 0, 0, 0.1),\n inset -2px -2px 5px rgba(255, 255, 255, 0.8);\n }\n \n #ast-settings-button .gear-path {\n transform-origin: center;\n transition: transform 0.5s ease;\n }\n \n #ast-settings-button:hover .gear-path {\n animation: rotate-gear 3s linear infinite;\n }\n \n @keyframes rotate-gear {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n }\n \n /* 涟漪效果 */\n #ast-settings-button .ripple-effect {\n position: absolute;\n background: rgba(255, 255, 255, 0.7);\n border-radius: 50%;\n transform: scale(0);\n opacity: 0;\n pointer-events: none;\n width: 100%;\n height: 100%;\n }\n \n #ast-settings-button .ripple-effect.active {\n animation: ripple 0.6s ease-out;\n }\n \n @keyframes ripple {\n 0% {\n transform: scale(0);\n opacity: 0.5;\n }\n 100% {\n transform: scale(2);\n opacity: 0;\n }\n }\n `;\n}\n/**\n * 获取模态框的样式\n * @returns 模态框CSS样式\n */\nfunction getModalStyles() {\n return `\n #ast-settings-modal .modal-content {\n background-color: #fff;\n border-radius: 8px;\n width: 900px;\n max-width: 90%;\n box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);\n overflow: hidden;\n transform: translateY(20px);\n transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);\n opacity: 0;\n }\n \n #ast-settings-modal.visible .modal-content {\n transform: translateY(0);\n opacity: 1;\n }\n \n #ast-settings-modal .modal-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 16px 20px;\n border-bottom: 1px solid #eee;\n background: linear-gradient(to right, #4a90e2, #63b3ed);\n }\n \n #ast-settings-modal .modal-header h3 {\n margin: 0;\n font-size: 18px;\n color: white;\n font-weight: 500;\n }\n \n #ast-settings-modal .close-button {\n background: none;\n border: none;\n font-size: 24px;\n cursor: pointer;\n padding: 0;\n line-height: 1;\n color: white;\n opacity: 0.8;\n transition: opacity 0.2s, transform 0.2s;\n }\n \n #ast-settings-modal .close-button:hover {\n opacity: 1;\n transform: scale(1.1);\n }\n \n #ast-settings-modal .modal-body {\n padding: 20px;\n max-height: 60vh;\n overflow-y: auto;\n }\n \n #ast-settings-modal .modal-footer {\n padding: 16px 20px;\n border-top: 1px solid #eee;\n text-align: right;\n background-color: #f9fafb;\n }\n \n #ast-settings-modal button#save-settings {\n background-color: #4a90e2;\n color: white;\n border: none;\n padding: 8px 20px;\n border-radius: 6px;\n cursor: pointer;\n font-size: 14px;\n font-weight: 500;\n transition: all 0.2s;\n }\n \n #ast-settings-modal button#save-settings:hover {\n background-color: #3b7fce;\n transform: translateY(-1px);\n box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);\n }\n \n #ast-settings-modal button#save-settings:active {\n transform: translateY(1px);\n box-shadow: none;\n }\n `;\n}\n/**\n * 获取成功提示的样式\n * @returns 提示框CSS样式\n */\nfunction getToastStyles() {\n return `\n .settings-toast {\n position: fixed;\n bottom: 30px;\n left: 50%;\n transform: translateX(-50%) translateY(20px);\n background-color: #4CAF50;\n color: white;\n padding: 10px 20px;\n border-radius: 6px;\n z-index: 10001;\n font-size: 14px;\n font-weight: 500;\n box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);\n opacity: 0;\n transition: opacity 0.3s ease, transform 0.3s ease;\n }\n `;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"135.js","mappings":";;;;;;AAAA;;GAEG;AAEH;;;GAGG;AACI,SAAS,uBAAuB;IACnC,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAyEN,CAAC;AACN,CAAC;AAED;;;GAGG;AACI,SAAS,cAAc;IAC1B,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAsFN,CAAC;AACN,CAAC;AAED;;;GAGG;AACI,SAAS,cAAc;IAC1B,OAAO;;;;;;;;;;;;;;;;;KAiBN,CAAC;AACN,CAAC","sources":["webpack://ast-explorer-helper/./src/ui/settings-ui/settings-ui.styles.ts?ae9a"],"sourcesContent":["/**\n * 设置UI组件 - 样式文件\n */\n\n/**\n * 获取设置按钮的样式\n * @returns 按钮CSS样式\n */\nexport function getSettingsButtonStyles(): string {\n    return `\n        #ast-settings-button .settings-button-inner {\n            width: 100%;\n            height: 100%;\n            border-radius: 50%;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n            position: relative;\n            background: linear-gradient(145deg, #ffffff, #f0f0f0);\n            box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.1),\n                        -5px -5px 10px rgba(255, 255, 255, 0.8);\n            color: #4a90e2;\n            transition: all 0.3s ease;\n            overflow: hidden;\n        }\n        \n        #ast-settings-button:hover .settings-button-inner {\n            box-shadow: 4px 4px 8px rgba(0, 0, 0, 0.15),\n                        -4px -4px 8px rgba(255, 255, 255, 0.9);\n            color: #2563eb;\n        }\n        \n        #ast-settings-button:active .settings-button-inner {\n            background: linear-gradient(135deg, #e6e6e6, #ffffff);\n            box-shadow: inset 2px 2px 5px rgba(0, 0, 0, 0.1),\n                        inset -2px -2px 5px rgba(255, 255, 255, 0.8);\n        }\n        \n        #ast-settings-button .gear-path {\n            transform-origin: center;\n            transition: transform 0.5s ease;\n        }\n        \n        #ast-settings-button:hover .gear-path {\n            animation: rotate-gear 3s linear infinite;\n        }\n        \n        @keyframes rotate-gear {\n            0% {\n                transform: rotate(0deg);\n            }\n            100% {\n                transform: rotate(360deg);\n            }\n        }\n        \n        /* 涟漪效果 */\n        #ast-settings-button .ripple-effect {\n            position: absolute;\n            background: rgba(255, 255, 255, 0.7);\n            border-radius: 50%;\n            transform: scale(0);\n            opacity: 0;\n            pointer-events: none;\n            width: 100%;\n            height: 100%;\n        }\n        \n        #ast-settings-button .ripple-effect.active {\n            animation: ripple 0.6s ease-out;\n        }\n        \n        @keyframes ripple {\n            0% {\n                transform: scale(0);\n                opacity: 0.5;\n            }\n            100% {\n                transform: scale(2);\n                opacity: 0;\n            }\n        }\n    `;\n}\n\n/**\n * 获取模态框的样式\n * @returns 模态框CSS样式\n */\nexport function getModalStyles(): string {\n    return `\n        #ast-settings-modal .modal-content {\n            background-color: #fff;\n            border-radius: 8px;\n            width: 900px;\n            max-width: 90%;\n            box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);\n            overflow: hidden;\n            transform: translateY(20px);\n            transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);\n            opacity: 0;\n        }\n        \n        #ast-settings-modal.visible .modal-content {\n            transform: translateY(0);\n            opacity: 1;\n        }\n        \n        #ast-settings-modal .modal-header {\n            display: flex;\n            justify-content: space-between;\n            align-items: center;\n            padding: 16px 20px;\n            border-bottom: 1px solid #eee;\n            background: linear-gradient(to right, #4a90e2, #63b3ed);\n        }\n        \n        #ast-settings-modal .modal-header h3 {\n            margin: 0;\n            font-size: 18px;\n            color: white;\n            font-weight: 500;\n        }\n        \n        #ast-settings-modal .close-button {\n            background: none;\n            border: none;\n            font-size: 24px;\n            cursor: pointer;\n            padding: 0;\n            line-height: 1;\n            color: white;\n            opacity: 0.8;\n            transition: opacity 0.2s, transform 0.2s;\n        }\n        \n        #ast-settings-modal .close-button:hover {\n            opacity: 1;\n            transform: scale(1.1);\n        }\n        \n        #ast-settings-modal .modal-body {\n            padding: 20px;\n            max-height: 60vh;\n            overflow-y: auto;\n        }\n        \n        #ast-settings-modal .modal-footer {\n            padding: 16px 20px;\n            border-top: 1px solid #eee;\n            text-align: right;\n            background-color: #f9fafb;\n        }\n        \n        #ast-settings-modal button#save-settings {\n            background-color: #4a90e2;\n            color: white;\n            border: none;\n            padding: 8px 20px;\n            border-radius: 6px;\n            cursor: pointer;\n            font-size: 14px;\n            font-weight: 500;\n            transition: all 0.2s;\n        }\n        \n        #ast-settings-modal button#save-settings:hover {\n            background-color: #3b7fce;\n            transform: translateY(-1px);\n            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);\n        }\n        \n        #ast-settings-modal button#save-settings:active {\n            transform: translateY(1px);\n            box-shadow: none;\n        }\n    `;\n}\n\n/**\n * 获取成功提示的样式\n * @returns 提示框CSS样式\n */\nexport function getToastStyles(): string {\n    return `\n        .settings-toast {\n            position: fixed;\n            bottom: 30px;\n            left: 50%;\n            transform: translateX(-50%) translateY(20px);\n            background-color: #4CAF50;\n            color: white;\n            padding: 10px 20px;\n            border-radius: 6px;\n            z-index: 10001;\n            font-size: 14px;\n            font-weight: 500;\n            box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);\n            opacity: 0;\n            transition: opacity 0.3s ease, transform 0.3s ease;\n        }\n    `;\n} "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///135\n");
/***/ }),
/***/ 361:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ LogLevel: () => (/* binding */ LogLevel),\n/* harmony export */ Logger: () => (/* binding */ Logger),\n/* harmony export */ logger: () => (/* binding */ logger)\n/* harmony export */ });\n/**\n * 日志服务模块\n * 提供带颜色的日志输出功能,带有插件前缀\n */\n// 日志级别枚举\nvar LogLevel;\n(function (LogLevel) {\n LogLevel[LogLevel[\"DEBUG\"] = 0] = \"DEBUG\";\n LogLevel[LogLevel[\"INFO\"] = 1] = \"INFO\";\n LogLevel[LogLevel[\"WARN\"] = 2] = \"WARN\";\n LogLevel[LogLevel[\"ERROR\"] = 3] = \"ERROR\";\n})(LogLevel || (LogLevel = {}));\n// 默认配置\nconst DEFAULT_CONFIG = {\n level: LogLevel.DEBUG,\n prefix: '🧩 AST Explorer助手',\n showTime: true,\n enabled: true\n};\n// 检查URL参数是否启用调试模式\nfunction checkDebugMode() {\n try {\n const urlParams = new URLSearchParams(window.location.search);\n return urlParams.has('ast_debug') || urlParams.has('debug');\n }\n catch (e) {\n return false;\n }\n}\n// 配置初始日志级别\nfunction getInitialLogLevel() {\n // 默认使用DEBUG级别\n return LogLevel.DEBUG;\n}\n/**\n * 日志服务类\n */\nclass Logger {\n /**\n * 创建一个日志服务实例\n * @param config 可选的日志配置\n */\n constructor(config) {\n this.config = Object.assign(Object.assign({}, DEFAULT_CONFIG), config);\n // 输出初始状态日志\n if (this.config.level === LogLevel.DEBUG) {\n console.debug('🔍 调试模式已启用 - 日志级别:', this.config.level);\n }\n }\n /**\n * 更新日志配置\n * @param config 新配置\n */\n updateConfig(config) {\n const oldLevel = this.config.level;\n this.config = Object.assign(Object.assign({}, this.config), config);\n if (oldLevel !== this.config.level) {\n if (this.config.level === LogLevel.DEBUG) {\n this.debug('🔍 调试模式已启用');\n }\n else if (oldLevel === LogLevel.DEBUG) {\n this.info('🔍 调试模式已关闭');\n }\n }\n }\n /**\n * 启用调试级别日志\n */\n enableDebug() {\n if (this.config.level !== LogLevel.DEBUG) {\n this.updateConfig({ level: LogLevel.DEBUG });\n }\n }\n /**\n * 禁用调试级别日志\n */\n disableDebug() {\n if (this.config.level === LogLevel.DEBUG) {\n this.updateConfig({ level: LogLevel.INFO });\n }\n }\n /**\n * 格式化日志消息\n * @param level 日志级别\n * @param args 日志参数\n * @returns 格式化后的消息\n */\n formatMessage(level, args) {\n const formattedArgs = [...args];\n // 添加时间前缀\n let prefix = this.config.prefix ? `${this.config.prefix}` : '';\n // 添加时间\n if (this.config.showTime) {\n const now = new Date();\n const timeStr = `${now.getHours().toString().padStart(2, '0')}:${now.getMinutes().toString().padStart(2, '0')}:${now.getSeconds().toString().padStart(2, '0')}.${now.getMilliseconds().toString().padStart(3, '0')}`;\n prefix = `${prefix} [${timeStr}]`;\n }\n // 添加日志级别\n prefix = `${prefix} [${level}]`;\n // 如果第一个参数是字符串,拼接前缀,否则作为单独的参数\n if (typeof formattedArgs[0] === 'string') {\n formattedArgs[0] = `${prefix} ${formattedArgs[0]}`;\n }\n else {\n formattedArgs.unshift(prefix);\n }\n return formattedArgs;\n }\n /**\n * 调试日志\n * @param args 日志参数\n */\n debug(...args) {\n if (!this.config.enabled || this.config.level > LogLevel.DEBUG) {\n return;\n }\n const formattedArgs = this.formatMessage('DEBUG', args);\n console.debug('%c' + formattedArgs[0], 'color: #9e9e9e; font-weight: bold;', ...formattedArgs.slice(1));\n }\n /**\n * 信息日志\n * @param args 日志参数\n */\n info(...args) {\n if (!this.config.enabled || this.config.level > LogLevel.INFO)\n return;\n const formattedArgs = this.formatMessage('INFO', args);\n console.log('%c' + formattedArgs[0], 'color: #2196f3; font-weight: bold;', ...formattedArgs.slice(1));\n }\n /**\n * 警告日志\n * @param args 日志参数\n */\n warn(...args) {\n if (!this.config.enabled || this.config.level > LogLevel.WARN)\n return;\n const formattedArgs = this.formatMessage('WARN', args);\n console.warn('%c' + formattedArgs[0], 'color: #ff9800; font-weight: bold;', ...formattedArgs.slice(1));\n }\n /**\n * 错误日志\n * @param args 日志参数\n */\n error(...args) {\n if (!this.config.enabled || this.config.level > LogLevel.ERROR)\n return;\n const formattedArgs = this.formatMessage('ERROR', args);\n console.error('%c' + formattedArgs[0], 'color: #f44336; font-weight: bold;', ...formattedArgs.slice(1));\n }\n /**\n * 输出分组日志的开始\n * @param title 分组标题\n * @param collapsed 是否默认折叠\n */\n group(title, collapsed = false) {\n if (!this.config.enabled)\n return;\n const formattedTitle = this.formatMessage('GROUP', [title])[0];\n if (collapsed) {\n console.groupCollapsed('%c' + formattedTitle, 'color: #4caf50; font-weight: bold;');\n }\n else {\n console.group('%c' + formattedTitle, 'color: #4caf50; font-weight: bold;');\n }\n }\n /**\n * 输出折叠的分组日志开始\n * @param title 分组标题\n */\n groupCollapsed(title) {\n this.group(title, true);\n }\n /**\n * 结束当前分组\n */\n groupEnd() {\n if (!this.config.enabled)\n return;\n console.groupEnd();\n }\n /**\n * 输出表格数据\n * @param data 表格数据\n */\n table(data) {\n if (!this.config.enabled)\n return;\n console.table(data);\n }\n}\n// 创建默认日志实例\nconst logger = new Logger();\nlogger.debug('热编译测试 - ' + new Date().toISOString());\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"361.js","mappings":"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","sources":["webpack://ast-explorer-helper/./src/logger/logger.service.ts?8106"],"sourcesContent":["/**\n * 日志服务模块\n * 提供带颜色的日志输出功能，带有插件前缀\n */\n\n// 日志级别枚举\nexport enum LogLevel {\n    DEBUG = 0,\n    INFO = 1,\n    WARN = 2,\n    ERROR = 3\n}\n\n// 日志配置接口\nexport interface LoggerConfig {\n    level: LogLevel;        // 日志级别\n    prefix: string;         // 日志前缀\n    showTime: boolean;      // 是否显示时间\n    enabled: boolean;       // 是否启用日志\n}\n\n// 默认配置\nconst DEFAULT_CONFIG: LoggerConfig = {\n    level: LogLevel.DEBUG,\n    prefix: '🧩 AST Explorer助手',\n    showTime: true,\n    enabled: true\n};\n\n// 检查URL参数是否启用调试模式\nfunction checkDebugMode(): boolean {\n    try {\n        const urlParams = new URLSearchParams(window.location.search);\n        return urlParams.has('ast_debug') || urlParams.has('debug');\n    } catch (e) {\n        return false;\n    }\n}\n\n// 配置初始日志级别\nfunction getInitialLogLevel(): LogLevel {\n    // 默认使用DEBUG级别\n    return LogLevel.DEBUG;\n}\n\n/**\n * 日志服务类\n */\nexport class Logger {\n    private config: LoggerConfig;\n\n    /**\n     * 创建一个日志服务实例\n     * @param config 可选的日志配置\n     */\n    constructor(config?: Partial<LoggerConfig>) {\n        this.config = { \n            ...DEFAULT_CONFIG,\n            ...config \n        };\n        \n        // 输出初始状态日志\n        if (this.config.level === LogLevel.DEBUG) {\n            console.debug('🔍 调试模式已启用 - 日志级别:', this.config.level);\n        }\n    }\n\n    /**\n     * 更新日志配置\n     * @param config 新配置\n     */\n    updateConfig(config: Partial<LoggerConfig>): void {\n        const oldLevel = this.config.level;\n        this.config = { ...this.config, ...config };\n        \n        if (oldLevel !== this.config.level) {\n            if (this.config.level === LogLevel.DEBUG) {\n                this.debug('🔍 调试模式已启用');\n            } else if (oldLevel === LogLevel.DEBUG) {\n                this.info('🔍 调试模式已关闭');\n            }\n        }\n    }\n    \n    /**\n     * 启用调试级别日志\n     */\n    enableDebug(): void {\n        if (this.config.level !== LogLevel.DEBUG) {\n            this.updateConfig({ level: LogLevel.DEBUG });\n        }\n    }\n    \n    /**\n     * 禁用调试级别日志\n     */\n    disableDebug(): void {\n        if (this.config.level === LogLevel.DEBUG) {\n            this.updateConfig({ level: LogLevel.INFO });\n        }\n    }\n\n    /**\n     * 格式化日志消息\n     * @param level 日志级别\n     * @param args 日志参数\n     * @returns 格式化后的消息\n     */\n    private formatMessage(level: string, args: any[]): string[] {\n        const formattedArgs = [...args];\n        \n        // 添加时间前缀\n        let prefix = this.config.prefix ? `${this.config.prefix}` : '';\n        \n        // 添加时间\n        if (this.config.showTime) {\n            const now = new Date();\n            const timeStr = `${now.getHours().toString().padStart(2, '0')}:${now.getMinutes().toString().padStart(2, '0')}:${now.getSeconds().toString().padStart(2, '0')}.${now.getMilliseconds().toString().padStart(3, '0')}`;\n            prefix = `${prefix} [${timeStr}]`;\n        }\n        \n        // 添加日志级别\n        prefix = `${prefix} [${level}]`;\n        \n        // 如果第一个参数是字符串，拼接前缀，否则作为单独的参数\n        if (typeof formattedArgs[0] === 'string') {\n            formattedArgs[0] = `${prefix} ${formattedArgs[0]}`;\n        } else {\n            formattedArgs.unshift(prefix);\n        }\n        \n        return formattedArgs;\n    }\n\n    /**\n     * 调试日志\n     * @param args 日志参数\n     */\n    debug(...args: any[]): void {\n        if (!this.config.enabled || this.config.level > LogLevel.DEBUG) {\n            return;\n        }\n        const formattedArgs = this.formatMessage('DEBUG', args);\n        console.debug('%c' + formattedArgs[0], 'color: #9e9e9e; font-weight: bold;', ...formattedArgs.slice(1));\n    }\n\n    /**\n     * 信息日志\n     * @param args 日志参数\n     */\n    info(...args: any[]): void {\n        if (!this.config.enabled || this.config.level > LogLevel.INFO) return;\n        const formattedArgs = this.formatMessage('INFO', args);\n        console.log('%c' + formattedArgs[0], 'color: #2196f3; font-weight: bold;', ...formattedArgs.slice(1));\n    }\n\n    /**\n     * 警告日志\n     * @param args 日志参数\n     */\n    warn(...args: any[]): void {\n        if (!this.config.enabled || this.config.level > LogLevel.WARN) return;\n        const formattedArgs = this.formatMessage('WARN', args);\n        console.warn('%c' + formattedArgs[0], 'color: #ff9800; font-weight: bold;', ...formattedArgs.slice(1));\n    }\n\n    /**\n     * 错误日志\n     * @param args 日志参数\n     */\n    error(...args: any[]): void {\n        if (!this.config.enabled || this.config.level > LogLevel.ERROR) return;\n        const formattedArgs = this.formatMessage('ERROR', args);\n        console.error('%c' + formattedArgs[0], 'color: #f44336; font-weight: bold;', ...formattedArgs.slice(1));\n    }\n    \n    /**\n     * 输出分组日志的开始\n     * @param title 分组标题\n     * @param collapsed 是否默认折叠\n     */\n    group(title: string, collapsed: boolean = false): void {\n        if (!this.config.enabled) return;\n        \n        const formattedTitle = this.formatMessage('GROUP', [title])[0];\n        if (collapsed) {\n            console.groupCollapsed('%c' + formattedTitle, 'color: #4caf50; font-weight: bold;');\n        } else {\n            console.group('%c' + formattedTitle, 'color: #4caf50; font-weight: bold;');\n        }\n    }\n    \n    /**\n     * 输出折叠的分组日志开始\n     * @param title 分组标题\n     */\n    groupCollapsed(title: string): void {\n        this.group(title, true);\n    }\n    \n    /**\n     * 结束当前分组\n     */\n    groupEnd(): void {\n        if (!this.config.enabled) return;\n        console.groupEnd();\n    }\n    \n    /**\n     * 输出表格数据\n     * @param data 表格数据\n     */\n    table(data: any): void {\n        if (!this.config.enabled) return;\n        console.table(data);\n    }\n}\n\n// 创建默认日志实例\nexport const logger = new Logger();\n\nlogger.debug('热编译测试 - ' + new Date().toISOString()); "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///361\n");
/***/ }),
/***/ 379:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getAboutTabStyles: () => (/* binding */ getAboutTabStyles)\n/* harmony export */ });\n/**\n * 关于标签页组件 - 样式文件\n */\n/**\n * 获取关于标签页的样式\n * @returns 关于标签页的CSS样式\n */\nfunction getAboutTabStyles() {\n return `\n /* 关于标签页的整体样式 */\n #about-tab {\n padding: 20px;\n overflow-y: auto;\n height: 100%;\n background-color: #f8f9fa;\n }\n \n #ast-settings-modal .about-content {\n max-width: 700px;\n margin: 0 auto;\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif;\n }\n \n #ast-settings-modal .about-content p {\n margin: 10px 0;\n color: #555;\n line-height: 1.5;\n }\n \n #ast-settings-modal .about-content a {\n color: #4a90e2;\n text-decoration: none;\n font-weight: 500;\n }\n \n #ast-settings-modal .about-content a:hover {\n text-decoration: underline;\n }\n \n /* 统一卡片基础样式 */\n #ast-settings-modal .repo-info-section, \n #ast-settings-modal .org-info-section, \n #ast-settings-modal .community-section {\n margin-bottom: 30px;\n }\n \n #ast-settings-modal .repo-card, \n #ast-settings-modal .org-card, \n #ast-settings-modal .community-card {\n background: linear-gradient(135deg, #ffffff, #f8f9fa);\n border-radius: 12px;\n box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);\n padding: 22px;\n max-width: 600px;\n margin: 0 auto;\n transition: transform 0.3s ease, box-shadow 0.3s ease;\n position: relative;\n overflow: hidden;\n }\n \n #ast-settings-modal .repo-card:hover, \n #ast-settings-modal .org-card:hover, \n #ast-settings-modal .community-card:hover {\n transform: translateY(-5px);\n box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);\n }\n \n /* 卡片顶部渐变条 */\n #ast-settings-modal .repo-card:before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n height: 4px;\n background: linear-gradient(90deg, #4a90e2, #6a3de8);\n border-radius: 3px 3px 0 0;\n }\n \n #ast-settings-modal .org-card:before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n height: 4px;\n background: linear-gradient(90deg, #f7df1e, #e34c26);\n border-radius: 3px 3px 0 0;\n }\n \n #ast-settings-modal .community-card:before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n height: 4px;\n background: linear-gradient(90deg, #25D366, #0088cc);\n border-radius: 3px 3px 0 0;\n }\n \n /* 统一卡片头部样式 */\n #ast-settings-modal .repo-header, \n #ast-settings-modal .org-header, \n #ast-settings-modal .community-header {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-direction: column;\n margin-bottom: 15px;\n position: relative;\n border-bottom: none;\n padding: 0;\n }\n \n /* 图标/Logo统一样式 */\n #ast-settings-modal .repo-logo, \n #ast-settings-modal .community-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 60px;\n height: 60px;\n background: linear-gradient(135deg, #6e8efb, #a777e3);\n border-radius: 50%;\n margin-bottom: 15px;\n box-shadow: 0 3px 8px rgba(0, 0, 0, 0.1);\n color: white;\n transition: transform 0.3s ease;\n }\n \n #ast-settings-modal .repo-logo:hover, \n #ast-settings-modal .community-icon:hover {\n transform: rotate(10deg);\n }\n \n #ast-settings-modal .repo-logo svg, \n #ast-settings-modal .community-icon svg {\n width: 32px;\n height: 32px;\n filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.1));\n }\n \n /* 组织Logo特殊样式 */\n #ast-settings-modal .org-logo {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-direction: column;\n margin-bottom: 10px;\n }\n \n /* JSREI组织logo样式 */\n #ast-settings-modal .jsrei-logo {\n width: 64px;\n height: 64px;\n border: 1px solid #e0e0e0;\n border-radius: 10px;\n background-color: white;\n padding: 4px;\n box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);\n transition: transform 0.3s ease, box-shadow 0.3s ease;\n animation: float 5s ease-in-out infinite;\n }\n \n #ast-settings-modal .jsrei-logo:hover {\n border-color: #4a90e2;\n box-shadow: 0 4px 12px rgba(74, 144, 226, 0.2);\n transform: scale(1.05);\n }\n \n /* 徽章样式统一 */\n #ast-settings-modal .repo-badge, \n #ast-settings-modal .org-badge {\n display: inline-block;\n padding: 3px 8px;\n border-radius: 12px;\n font-size: 11px;\n font-weight: 500;\n margin-top: 8px;\n text-transform: uppercase;\n letter-spacing: 0.5px;\n box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);\n }\n \n #ast-settings-modal .repo-badge {\n background-color: #4a90e2;\n color: white;\n }\n \n #ast-settings-modal .org-badge {\n background-color: #4caf50;\n color: white;\n }\n \n /* 标题统一样式 */\n #ast-settings-modal .repo-header h4, \n #ast-settings-modal .org-header h4, \n #ast-settings-modal .community-header h4,\n #ast-settings-modal .section-title {\n margin: 10px 0 5px;\n font-size: 1.25rem;\n font-weight: 600;\n color: #333;\n }\n \n #ast-settings-modal .repo-header p, \n #ast-settings-modal .community-header p {\n margin: 5px 0 0;\n color: #666;\n font-size: 0.9rem;\n text-align: center;\n }\n \n /* 仓库统计相关样式 - 增强版 */\n #ast-settings-modal .repo-stats {\n margin: 15px auto;\n max-width: 500px;\n padding: 15px 0;\n background-color: transparent;\n }\n \n #ast-settings-modal .repo-link-wrapper {\n display: flex;\n justify-content: center;\n gap: 15px;\n margin-bottom: 15px;\n }\n \n #ast-settings-modal .repo-link, \n #ast-settings-modal .star-button {\n display: inline-flex;\n align-items: center;\n gap: 6px;\n padding: 8px 16px;\n border-radius: 8px;\n font-size: 14px;\n font-weight: 500;\n text-decoration: none;\n transition: all 0.2s ease;\n box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);\n }\n \n #ast-settings-modal .repo-link {\n background-color: #24292e;\n color: white !important;\n }\n \n #ast-settings-modal .repo-link:hover {\n background-color: #000;\n text-decoration: none !important;\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);\n }\n \n #ast-settings-modal .star-button {\n background-color: #f3f4f6;\n color: #24292e !important;\n border: 1px solid #d0d7de;\n }\n \n #ast-settings-modal .star-button:hover {\n background-color: #e6ebf1;\n text-decoration: none !important;\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);\n }\n \n #ast-settings-modal .github-icon, \n #ast-settings-modal .star-icon {\n margin-right: 6px;\n }\n \n /* 改进的统计数据项样式 */\n #ast-settings-modal .github-stats {\n display: flex;\n justify-content: center;\n flex-wrap: wrap;\n gap: 12px;\n margin-top: 20px;\n }\n \n #ast-settings-modal .stat-item {\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 12px 8px;\n border-radius: 8px;\n min-width: 80px;\n text-decoration: none;\n position: relative;\n overflow: hidden;\n transition: all 0.3s ease;\n }\n \n /* 鼠标悬停效果 */\n #ast-settings-modal .stat-item:hover {\n transform: translateY(-3px);\n box-shadow: 0 4px 8px rgba(0,0,0,0.1);\n text-decoration: none !important;\n }\n \n /* 为每种类型的统计添加独特颜色 */\n #ast-settings-modal .star-stat {\n background-color: #fff8e1;\n color: #ff8f00 !important;\n border: 1px solid #ffe082;\n }\n \n #ast-settings-modal .star-stat:hover {\n background-color: #ffecb3;\n }\n \n #ast-settings-modal .star-stat .stat-icon {\n fill: #ff8f00;\n }\n \n #ast-settings-modal .fork-stat {\n background-color: #e8f5e9;\n color: #388e3c !important;\n border: 1px solid #c8e6c9;\n }\n \n #ast-settings-modal .fork-stat:hover {\n background-color: #c8e6c9;\n }\n \n #ast-settings-modal .fork-stat .stat-icon {\n fill: #388e3c;\n }\n \n #ast-settings-modal .issue-stat {\n background-color: #e3f2fd;\n color: #1976d2 !important;\n border: 1px solid #bbdefb;\n }\n \n #ast-settings-modal .issue-stat:hover {\n background-color: #bbdefb;\n }\n \n #ast-settings-modal .issue-stat .stat-icon {\n fill: #1976d2;\n }\n \n #ast-settings-modal .update-stat {\n background-color: #f3e5f5;\n color: #7b1fa2 !important;\n border: 1px solid #e1bee7;\n }\n \n #ast-settings-modal .update-stat:hover {\n background-color: #e1bee7;\n }\n \n #ast-settings-modal .update-stat .stat-icon {\n fill: #7b1fa2;\n }\n \n #ast-settings-modal .stat-icon {\n width: 20px;\n height: 20px;\n margin-bottom: 5px;\n }\n \n #ast-settings-modal .stat-item span {\n font-size: 16px;\n font-weight: 600;\n white-space: nowrap;\n }\n \n /* 新增:统计标签样式 */\n #ast-settings-modal .stat-label {\n font-size: 12px !important;\n font-weight: 400 !important;\n color: rgba(0, 0, 0, 0.6);\n margin-top: 3px;\n }\n\n /* 展示类似徽章的效果 */\n #ast-settings-modal .stat-item::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 3px;\n background: currentColor;\n opacity: 0.5;\n }\n \n /* 组织信息部分样式 */\n #ast-settings-modal .org-content {\n margin: 15px 0;\n }\n \n #ast-settings-modal .org-description {\n margin-bottom: 20px;\n }\n \n #ast-settings-modal .org-description p {\n text-align: center;\n }\n \n #ast-settings-modal .org-features {\n display: flex;\n justify-content: space-around;\n margin: 20px 0;\n flex-wrap: wrap;\n }\n \n #ast-settings-modal .feature-item {\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 12px;\n min-width: 100px;\n border-radius: 8px;\n transition: all 0.2s ease;\n cursor: default;\n }\n \n #ast-settings-modal .feature-item:hover {\n background-color: #f0f4f9;\n transform: translateY(-3px);\n }\n \n #ast-settings-modal .feature-item:nth-child(1):hover .feature-icon {\n color: #ff9800;\n }\n \n #ast-settings-modal .feature-item:nth-child(2):hover .feature-icon {\n color: #4caf50;\n }\n \n #ast-settings-modal .feature-item:nth-child(3):hover .feature-icon {\n color: #2196f3;\n }\n \n #ast-settings-modal .feature-icon {\n margin-bottom: 8px;\n color: #555;\n transition: color 0.2s ease;\n }\n \n #ast-settings-modal .feature-text {\n font-size: 14px;\n font-weight: 500;\n }\n \n #ast-settings-modal .org-actions {\n margin-top: 20px;\n display: flex;\n justify-content: center;\n }\n \n /* GitHub按钮样式 */\n #ast-settings-modal .org-action-button {\n display: inline-flex;\n align-items: center;\n gap: 8px;\n padding: 10px 20px;\n background-color: #4a90e2;\n color: white;\n border-radius: 8px;\n font-weight: 500;\n transition: all 0.2s ease;\n box-shadow: 0 3px 10px rgba(74, 144, 226, 0.3);\n text-align: center;\n justify-content: center;\n min-width: 200px;\n }\n \n #ast-settings-modal .org-action-button .button-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n color: white;\n }\n \n #ast-settings-modal .org-action-button .button-text {\n display: inline-block;\n color: white;\n white-space: nowrap;\n }\n \n #ast-settings-modal .org-action-button.fixed-button {\n width: auto;\n min-width: 200px;\n max-width: 100%;\n overflow: visible;\n }\n \n #ast-settings-modal .org-action-button.fixed-button .github-icon {\n color: white;\n }\n \n #ast-settings-modal .org-action-button:hover {\n background-color: #3a80d2;\n box-shadow: 0 5px 15px rgba(74, 144, 226, 0.4);\n transform: translateY(-2px);\n text-decoration: none;\n }\n \n #ast-settings-modal .org-action-button:active {\n transform: translateY(0);\n box-shadow: 0 2px 5px rgba(74, 144, 226, 0.3);\n }\n \n /* 交流群样式 */\n @keyframes float {\n 0% {\n transform: translateY(0);\n }\n 50% {\n transform: translateY(-5px);\n }\n 100% {\n transform: translateY(0);\n }\n }\n \n #ast-settings-modal .community-section h4.section-title {\n display: inline-block;\n margin: 0 0 5px 0;\n font-size: 18px;\n color: #333;\n position: relative;\n }\n\n #ast-settings-modal .community-section h4.section-title:after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 25%;\n width: 50%;\n height: 2px;\n background: linear-gradient(90deg, #25D366, #0088cc);\n border-radius: 2px;\n }\n \n /* 二维码横向布局样式 - 增强版 */\n #ast-settings-modal .qr-code-container {\n display: flex;\n flex-direction: column;\n gap: 20px;\n margin-top: 15px;\n }\n \n #ast-settings-modal .qr-section {\n display: flex;\n justify-content: center;\n flex-wrap: wrap;\n gap: 20px;\n margin-bottom: 10px;\n }\n \n #ast-settings-modal .qr-section:first-child {\n position: relative;\n }\n \n #ast-settings-modal .qr-section-title {\n width: 100%;\n text-align: left;\n margin: 5px 0 15px 5px;\n font-weight: 500;\n color: #555;\n display: flex;\n align-items: center;\n gap: 8px;\n }\n \n #ast-settings-modal .qr-section-title svg {\n width: 20px;\n height: 20px;\n }\n \n #ast-settings-modal .qr-section-title.wechat {\n color: #25D366;\n }\n \n #ast-settings-modal .qr-section-title.telegram {\n color: #0088cc;\n }\n \n #ast-settings-modal .qr-section-title.qq {\n color: #12B7F5;\n }\n \n #ast-settings-modal .qr-item {\n flex: 1;\n min-width: 200px;\n max-width: 260px;\n margin: 0 auto;\n padding: 15px;\n background-color: rgba(255, 255, 255, 0.6);\n border-radius: 10px;\n transition: all 0.3s ease;\n border: 1px solid #f0f0f0;\n text-align: center;\n }\n \n #ast-settings-modal .qr-item:hover {\n transform: translateY(-3px);\n box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);\n background-color: white;\n border-color: #e0e0e0;\n }\n \n #ast-settings-modal .qr-item p {\n font-size: 14px;\n margin: 0 0 10px 0;\n color: #666;\n text-align: center;\n }\n \n #ast-settings-modal .qr-code {\n margin: 10px auto;\n display: block;\n padding: 8px;\n background-color: white;\n border: 1px solid #eee;\n border-radius: 8px;\n transition: all 0.3s ease;\n text-align: center;\n width: fit-content;\n }\n \n #ast-settings-modal .qr-item:hover .qr-code {\n box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);\n border-color: #ddd;\n }\n \n #ast-settings-modal .qr-code img {\n width: 150px;\n border-radius: 4px;\n transition: transform 0.3s, box-shadow 0.3s;\n }\n \n #ast-settings-modal .qr-code img:hover {\n transform: scale(1.05);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);\n }\n \n #ast-settings-modal .tg-link {\n display: inline-flex;\n align-items: center;\n gap: 5px;\n margin: 5px 0;\n font-weight: 500;\n color: #0088cc;\n transition: all 0.2s;\n }\n \n #ast-settings-modal .tg-link:hover {\n color: #005580;\n transform: translateX(2px);\n }\n \n #ast-settings-modal .qq-link {\n display: inline-flex;\n align-items: center;\n gap: 5px;\n margin: 5px 0;\n font-weight: 500;\n color: #12B7F5;\n transition: all 0.2s;\n }\n \n #ast-settings-modal .qq-link:hover {\n color: #0091D7;\n transform: translateX(2px);\n }\n `;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"379.js","mappings":";;;;AAAA;;GAEG;AAEH;;;GAGG;AACI,SAAS,iBAAiB;IAC7B,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAypBN,CAAC;AACN,CAAC","sources":["webpack://ast-explorer-helper/./src/ui/about-tab/about-tab.styles.ts?a0b9"],"sourcesContent":["/**\n * 关于标签页组件 - 样式文件\n */\n\n/**\n * 获取关于标签页的样式\n * @returns 关于标签页的CSS样式\n */\nexport function getAboutTabStyles(): string {\n    return `\n        /* 关于标签页的整体样式 */\n        #about-tab {\n            padding: 20px;\n            overflow-y: auto;\n            height: 100%;\n            background-color: #f8f9fa;\n        }\n        \n        #ast-settings-modal .about-content {\n            max-width: 700px;\n            margin: 0 auto;\n            font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif;\n        }\n        \n        #ast-settings-modal .about-content p {\n            margin: 10px 0;\n            color: #555;\n            line-height: 1.5;\n        }\n        \n        #ast-settings-modal .about-content a {\n            color: #4a90e2;\n            text-decoration: none;\n            font-weight: 500;\n        }\n        \n        #ast-settings-modal .about-content a:hover {\n            text-decoration: underline;\n        }\n        \n        /* 统一卡片基础样式 */\n        #ast-settings-modal .repo-info-section, \n        #ast-settings-modal .org-info-section, \n        #ast-settings-modal .community-section {\n            margin-bottom: 30px;\n        }\n        \n        #ast-settings-modal .repo-card, \n        #ast-settings-modal .org-card, \n        #ast-settings-modal .community-card {\n            background: linear-gradient(135deg, #ffffff, #f8f9fa);\n            border-radius: 12px;\n            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);\n            padding: 22px;\n            max-width: 600px;\n            margin: 0 auto;\n            transition: transform 0.3s ease, box-shadow 0.3s ease;\n            position: relative;\n            overflow: hidden;\n        }\n        \n        #ast-settings-modal .repo-card:hover, \n        #ast-settings-modal .org-card:hover, \n        #ast-settings-modal .community-card:hover {\n            transform: translateY(-5px);\n            box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);\n        }\n        \n        /* 卡片顶部渐变条 */\n        #ast-settings-modal .repo-card:before {\n            content: '';\n            position: absolute;\n            top: 0;\n            left: 0;\n            right: 0;\n            height: 4px;\n            background: linear-gradient(90deg, #4a90e2, #6a3de8);\n            border-radius: 3px 3px 0 0;\n        }\n        \n        #ast-settings-modal .org-card:before {\n            content: '';\n            position: absolute;\n            top: 0;\n            left: 0;\n            right: 0;\n            height: 4px;\n            background: linear-gradient(90deg, #f7df1e, #e34c26);\n            border-radius: 3px 3px 0 0;\n        }\n        \n        #ast-settings-modal .community-card:before {\n            content: '';\n            position: absolute;\n            top: 0;\n            left: 0;\n            right: 0;\n            height: 4px;\n            background: linear-gradient(90deg, #25D366, #0088cc);\n            border-radius: 3px 3px 0 0;\n        }\n        \n        /* 统一卡片头部样式 */\n        #ast-settings-modal .repo-header, \n        #ast-settings-modal .org-header, \n        #ast-settings-modal .community-header {\n            display: flex;\n            align-items: center;\n            justify-content: center;\n            flex-direction: column;\n            margin-bottom: 15px;\n            position: relative;\n            border-bottom: none;\n            padding: 0;\n        }\n        \n        /* 图标/Logo统一样式 */\n        #ast-settings-modal .repo-logo, \n        #ast-settings-modal .community-icon {\n            display: flex;\n            align-items: center;\n            justify-content: center;\n            width: 60px;\n            height: 60px;\n            background: linear-gradient(135deg, #6e8efb, #a777e3);\n            border-radius: 50%;\n            margin-bottom: 15px;\n            box-shadow: 0 3px 8px rgba(0, 0, 0, 0.1);\n            color: white;\n            transition: transform 0.3s ease;\n        }\n        \n        #ast-settings-modal .repo-logo:hover, \n        #ast-settings-modal .community-icon:hover {\n            transform: rotate(10deg);\n        }\n        \n        #ast-settings-modal .repo-logo svg, \n        #ast-settings-modal .community-icon svg {\n            width: 32px;\n            height: 32px;\n            filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.1));\n        }\n        \n        /* 组织Logo特殊样式 */\n        #ast-settings-modal .org-logo {\n            display: flex;\n            align-items: center;\n            justify-content: center;\n            flex-direction: column;\n            margin-bottom: 10px;\n        }\n        \n        /* JSREI组织logo样式 */\n        #ast-settings-modal .jsrei-logo {\n            width: 64px;\n            height: 64px;\n            border: 1px solid #e0e0e0;\n            border-radius: 10px;\n            background-color: white;\n            padding: 4px;\n            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);\n            transition: transform 0.3s ease, box-shadow 0.3s ease;\n            animation: float 5s ease-in-out infinite;\n        }\n        \n        #ast-settings-modal .jsrei-logo:hover {\n            border-color: #4a90e2;\n            box-shadow: 0 4px 12px rgba(74, 144, 226, 0.2);\n            transform: scale(1.05);\n        }\n        \n        /* 徽章样式统一 */\n        #ast-settings-modal .repo-badge, \n        #ast-settings-modal .org-badge {\n            display: inline-block;\n            padding: 3px 8px;\n            border-radius: 12px;\n            font-size: 11px;\n            font-weight: 500;\n            margin-top: 8px;\n            text-transform: uppercase;\n            letter-spacing: 0.5px;\n            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);\n        }\n        \n        #ast-settings-modal .repo-badge {\n            background-color: #4a90e2;\n            color: white;\n        }\n        \n        #ast-settings-modal .org-badge {\n            background-color: #4caf50;\n            color: white;\n        }\n        \n        /* 标题统一样式 */\n        #ast-settings-modal .repo-header h4, \n        #ast-settings-modal .org-header h4, \n        #ast-settings-modal .community-header h4,\n        #ast-settings-modal .section-title {\n            margin: 10px 0 5px;\n            font-size: 1.25rem;\n            font-weight: 600;\n            color: #333;\n        }\n        \n        #ast-settings-modal .repo-header p, \n        #ast-settings-modal .community-header p {\n            margin: 5px 0 0;\n            color: #666;\n            font-size: 0.9rem;\n            text-align: center;\n        }\n        \n        /* 仓库统计相关样式 - 增强版 */\n        #ast-settings-modal .repo-stats {\n            margin: 15px auto;\n            max-width: 500px;\n            padding: 15px 0;\n            background-color: transparent;\n        }\n        \n        #ast-settings-modal .repo-link-wrapper {\n            display: flex;\n            justify-content: center;\n            gap: 15px;\n            margin-bottom: 15px;\n        }\n        \n        #ast-settings-modal .repo-link, \n        #ast-settings-modal .star-button {\n            display: inline-flex;\n            align-items: center;\n            gap: 6px;\n            padding: 8px 16px;\n            border-radius: 8px;\n            font-size: 14px;\n            font-weight: 500;\n            text-decoration: none;\n            transition: all 0.2s ease;\n            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);\n        }\n        \n        #ast-settings-modal .repo-link {\n            background-color: #24292e;\n            color: white !important;\n        }\n        \n        #ast-settings-modal .repo-link:hover {\n            background-color: #000;\n            text-decoration: none !important;\n            transform: translateY(-2px);\n            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);\n        }\n        \n        #ast-settings-modal .star-button {\n            background-color: #f3f4f6;\n            color: #24292e !important;\n            border: 1px solid #d0d7de;\n        }\n        \n        #ast-settings-modal .star-button:hover {\n            background-color: #e6ebf1;\n            text-decoration: none !important;\n            transform: translateY(-2px);\n            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);\n        }\n        \n        #ast-settings-modal .github-icon, \n        #ast-settings-modal .star-icon {\n            margin-right: 6px;\n        }\n        \n        /* 改进的统计数据项样式 */\n        #ast-settings-modal .github-stats {\n            display: flex;\n            justify-content: center;\n            flex-wrap: wrap;\n            gap: 12px;\n            margin-top: 20px;\n        }\n        \n        #ast-settings-modal .stat-item {\n            display: flex;\n            flex-direction: column;\n            align-items: center;\n            padding: 12px 8px;\n            border-radius: 8px;\n            min-width: 80px;\n            text-decoration: none;\n            position: relative;\n            overflow: hidden;\n            transition: all 0.3s ease;\n        }\n        \n        /* 鼠标悬停效果 */\n        #ast-settings-modal .stat-item:hover {\n            transform: translateY(-3px);\n            box-shadow: 0 4px 8px rgba(0,0,0,0.1);\n            text-decoration: none !important;\n        }\n        \n        /* 为每种类型的统计添加独特颜色 */\n        #ast-settings-modal .star-stat {\n            background-color: #fff8e1;\n            color: #ff8f00 !important;\n            border: 1px solid #ffe082;\n        }\n        \n        #ast-settings-modal .star-stat:hover {\n            background-color: #ffecb3;\n        }\n        \n        #ast-settings-modal .star-stat .stat-icon {\n            fill: #ff8f00;\n        }\n        \n        #ast-settings-modal .fork-stat {\n            background-color: #e8f5e9;\n            color: #388e3c !important;\n            border: 1px solid #c8e6c9;\n        }\n        \n        #ast-settings-modal .fork-stat:hover {\n            background-color: #c8e6c9;\n        }\n        \n        #ast-settings-modal .fork-stat .stat-icon {\n            fill: #388e3c;\n        }\n        \n        #ast-settings-modal .issue-stat {\n            background-color: #e3f2fd;\n            color: #1976d2 !important;\n            border: 1px solid #bbdefb;\n        }\n        \n        #ast-settings-modal .issue-stat:hover {\n            background-color: #bbdefb;\n        }\n        \n        #ast-settings-modal .issue-stat .stat-icon {\n            fill: #1976d2;\n        }\n        \n        #ast-settings-modal .update-stat {\n            background-color: #f3e5f5;\n            color: #7b1fa2 !important;\n            border: 1px solid #e1bee7;\n        }\n        \n        #ast-settings-modal .update-stat:hover {\n            background-color: #e1bee7;\n        }\n        \n        #ast-settings-modal .update-stat .stat-icon {\n            fill: #7b1fa2;\n        }\n        \n        #ast-settings-modal .stat-icon {\n            width: 20px;\n            height: 20px;\n            margin-bottom: 5px;\n        }\n        \n        #ast-settings-modal .stat-item span {\n            font-size: 16px;\n            font-weight: 600;\n            white-space: nowrap;\n        }\n        \n        /* 新增：统计标签样式 */\n        #ast-settings-modal .stat-label {\n            font-size: 12px !important;\n            font-weight: 400 !important;\n            color: rgba(0, 0, 0, 0.6);\n            margin-top: 3px;\n        }\n\n        /* 展示类似徽章的效果 */\n        #ast-settings-modal .stat-item::before {\n            content: '';\n            position: absolute;\n            top: 0;\n            left: 0;\n            width: 100%;\n            height: 3px;\n            background: currentColor;\n            opacity: 0.5;\n        }\n        \n        /* 组织信息部分样式 */\n        #ast-settings-modal .org-content {\n            margin: 15px 0;\n        }\n        \n        #ast-settings-modal .org-description {\n            margin-bottom: 20px;\n        }\n        \n        #ast-settings-modal .org-description p {\n            text-align: center;\n        }\n        \n        #ast-settings-modal .org-features {\n            display: flex;\n            justify-content: space-around;\n            margin: 20px 0;\n            flex-wrap: wrap;\n        }\n        \n        #ast-settings-modal .feature-item {\n            display: flex;\n            flex-direction: column;\n            align-items: center;\n            padding: 12px;\n            min-width: 100px;\n            border-radius: 8px;\n            transition: all 0.2s ease;\n            cursor: default;\n        }\n        \n        #ast-settings-modal .feature-item:hover {\n            background-color: #f0f4f9;\n            transform: translateY(-3px);\n        }\n        \n        #ast-settings-modal .feature-item:nth-child(1):hover .feature-icon {\n            color: #ff9800;\n        }\n        \n        #ast-settings-modal .feature-item:nth-child(2):hover .feature-icon {\n            color: #4caf50;\n        }\n        \n        #ast-settings-modal .feature-item:nth-child(3):hover .feature-icon {\n            color: #2196f3;\n        }\n        \n        #ast-settings-modal .feature-icon {\n            margin-bottom: 8px;\n            color: #555;\n            transition: color 0.2s ease;\n        }\n        \n        #ast-settings-modal .feature-text {\n            font-size: 14px;\n            font-weight: 500;\n        }\n        \n        #ast-settings-modal .org-actions {\n            margin-top: 20px;\n            display: flex;\n            justify-content: center;\n        }\n        \n        /* GitHub按钮样式 */\n        #ast-settings-modal .org-action-button {\n            display: inline-flex;\n            align-items: center;\n            gap: 8px;\n            padding: 10px 20px;\n            background-color: #4a90e2;\n            color: white;\n            border-radius: 8px;\n            font-weight: 500;\n            transition: all 0.2s ease;\n            box-shadow: 0 3px 10px rgba(74, 144, 226, 0.3);\n            text-align: center;\n            justify-content: center;\n            min-width: 200px;\n        }\n        \n        #ast-settings-modal .org-action-button .button-icon {\n            display: flex;\n            align-items: center;\n            justify-content: center;\n            color: white;\n        }\n        \n        #ast-settings-modal .org-action-button .button-text {\n            display: inline-block;\n            color: white;\n            white-space: nowrap;\n        }\n        \n        #ast-settings-modal .org-action-button.fixed-button {\n            width: auto;\n            min-width: 200px;\n            max-width: 100%;\n            overflow: visible;\n        }\n        \n        #ast-settings-modal .org-action-button.fixed-button .github-icon {\n            color: white;\n        }\n        \n        #ast-settings-modal .org-action-button:hover {\n            background-color: #3a80d2;\n            box-shadow: 0 5px 15px rgba(74, 144, 226, 0.4);\n            transform: translateY(-2px);\n            text-decoration: none;\n        }\n        \n        #ast-settings-modal .org-action-button:active {\n            transform: translateY(0);\n            box-shadow: 0 2px 5px rgba(74, 144, 226, 0.3);\n        }\n        \n        /* 交流群样式 */\n        @keyframes float {\n            0% {\n                transform: translateY(0);\n            }\n            50% {\n                transform: translateY(-5px);\n            }\n            100% {\n                transform: translateY(0);\n            }\n        }\n        \n        #ast-settings-modal .community-section h4.section-title {\n            display: inline-block;\n            margin: 0 0 5px 0;\n            font-size: 18px;\n            color: #333;\n            position: relative;\n        }\n\n        #ast-settings-modal .community-section h4.section-title:after {\n            content: '';\n            position: absolute;\n            bottom: -4px;\n            left: 25%;\n            width: 50%;\n            height: 2px;\n            background: linear-gradient(90deg, #25D366, #0088cc);\n            border-radius: 2px;\n        }\n        \n        /* 二维码横向布局样式 - 增强版 */\n        #ast-settings-modal .qr-code-container {\n            display: flex;\n            flex-direction: column;\n            gap: 20px;\n            margin-top: 15px;\n        }\n        \n        #ast-settings-modal .qr-section {\n            display: flex;\n            justify-content: center;\n            flex-wrap: wrap;\n            gap: 20px;\n            margin-bottom: 10px;\n        }\n        \n        #ast-settings-modal .qr-section:first-child {\n            position: relative;\n        }\n        \n        #ast-settings-modal .qr-section-title {\n            width: 100%;\n            text-align: left;\n            margin: 5px 0 15px 5px;\n            font-weight: 500;\n            color: #555;\n            display: flex;\n            align-items: center;\n            gap: 8px;\n        }\n        \n        #ast-settings-modal .qr-section-title svg {\n            width: 20px;\n            height: 20px;\n        }\n        \n        #ast-settings-modal .qr-section-title.wechat {\n            color: #25D366;\n        }\n        \n        #ast-settings-modal .qr-section-title.telegram {\n            color: #0088cc;\n        }\n        \n        #ast-settings-modal .qr-section-title.qq {\n            color: #12B7F5;\n        }\n        \n        #ast-settings-modal .qr-item {\n            flex: 1;\n            min-width: 200px;\n            max-width: 260px;\n            margin: 0 auto;\n            padding: 15px;\n            background-color: rgba(255, 255, 255, 0.6);\n            border-radius: 10px;\n            transition: all 0.3s ease;\n            border: 1px solid #f0f0f0;\n            text-align: center;\n        }\n        \n        #ast-settings-modal .qr-item:hover {\n            transform: translateY(-3px);\n            box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);\n            background-color: white;\n            border-color: #e0e0e0;\n        }\n        \n        #ast-settings-modal .qr-item p {\n            font-size: 14px;\n            margin: 0 0 10px 0;\n            color: #666;\n            text-align: center;\n        }\n        \n        #ast-settings-modal .qr-code {\n            margin: 10px auto;\n            display: block;\n            padding: 8px;\n            background-color: white;\n            border: 1px solid #eee;\n            border-radius: 8px;\n            transition: all 0.3s ease;\n            text-align: center;\n            width: fit-content;\n        }\n        \n        #ast-settings-modal .qr-item:hover .qr-code {\n            box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);\n            border-color: #ddd;\n        }\n        \n        #ast-settings-modal .qr-code img {\n            width: 150px;\n            border-radius: 4px;\n            transition: transform 0.3s, box-shadow 0.3s;\n        }\n        \n        #ast-settings-modal .qr-code img:hover {\n            transform: scale(1.05);\n            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);\n        }\n        \n        #ast-settings-modal .tg-link {\n            display: inline-flex;\n            align-items: center;\n            gap: 5px;\n            margin: 5px 0;\n            font-weight: 500;\n            color: #0088cc;\n            transition: all 0.2s;\n        }\n        \n        #ast-settings-modal .tg-link:hover {\n            color: #005580;\n            transform: translateX(2px);\n        }\n        \n        #ast-settings-modal .qq-link {\n            display: inline-flex;\n            align-items: center;\n            gap: 5px;\n            margin: 5px 0;\n            font-weight: 500;\n            color: #12B7F5;\n            transition: all 0.2s;\n        }\n        \n        #ast-settings-modal .qq-link:hover {\n            color: #0091D7;\n            transform: translateX(2px);\n        }\n    `;\n} "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///379\n");
/***/ }),
/***/ 402:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _dom_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(494);\n/* harmony reexport (unknown) */ var __WEBPACK_REEXPORT_OBJECT__ = {};\n/* harmony reexport (unknown) */ for(const __WEBPACK_IMPORT_KEY__ in _dom_utils__WEBPACK_IMPORTED_MODULE_0__) if(__WEBPACK_IMPORT_KEY__ !== \"default\") __WEBPACK_REEXPORT_OBJECT__[__WEBPACK_IMPORT_KEY__] = () => _dom_utils__WEBPACK_IMPORTED_MODULE_0__[__WEBPACK_IMPORT_KEY__]\n/* harmony reexport (unknown) */ __webpack_require__.d(__webpack_exports__, __WEBPACK_REEXPORT_OBJECT__);\n/**\n * DOM 操作相关的工具函数\n */\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDAyLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0dBRUc7QUFDeUIiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL2RvbS1oZWxwZXJzL2luZGV4LnRzP2M3ZWUiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBET00g5pON5L2c55u45YWz55qE5bel5YW35Ye95pWwXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vZG9tLXV0aWxzJzsgIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///402\n");
/***/ }),
/***/ 458:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createModalTemplate: () => (/* reexport safe */ _settings_ui_template__WEBPACK_IMPORTED_MODULE_6__.createModalTemplate),\n/* harmony export */ createSettingsButtonTemplate: () => (/* reexport safe */ _settings_ui_template__WEBPACK_IMPORTED_MODULE_6__.createSettingsButtonTemplate),\n/* harmony export */ createSettingsUI: () => (/* binding */ createSettingsUI),\n/* harmony export */ createToastTemplate: () => (/* reexport safe */ _settings_ui_template__WEBPACK_IMPORTED_MODULE_6__.createToastTemplate),\n/* harmony export */ getModalStyles: () => (/* reexport safe */ _settings_ui_styles__WEBPACK_IMPORTED_MODULE_5__.getModalStyles),\n/* harmony export */ getSettingsButtonStyles: () => (/* reexport safe */ _settings_ui_styles__WEBPACK_IMPORTED_MODULE_5__.getSettingsButtonStyles),\n/* harmony export */ getToastStyles: () => (/* reexport safe */ _settings_ui_styles__WEBPACK_IMPORTED_MODULE_5__.getToastStyles)\n/* harmony export */ });\n/* harmony import */ var _settings_settings_service__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(663);\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(610);\n/* harmony import */ var _tabs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(481);\n/* harmony import */ var _settings_tab__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(18);\n/* harmony import */ var _about_tab__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(920);\n/* harmony import */ var _settings_ui_styles__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(135);\n/* harmony import */ var _settings_ui_template__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(55);\n/**\n * 设置UI组件 - 逻辑文件\n */\n\n\n\n\n\n\n\n// 导出公共API\n\n\n/**\n * 创建设置界面\n */\nfunction createSettingsUI() {\n // 添加设置按钮\n createSettingsButton();\n // 创建设置模态框\n createSettingsModal();\n // 监听设置变更事件\n document.addEventListener('ast-explorer-helper-settings-changed', handleSettingsChanged);\n}\n/**\n * 创建设置按钮\n */\nfunction createSettingsButton() {\n const button = document.createElement('div');\n button.id = 'ast-settings-button';\n // 使用模板生成按钮内容\n button.innerHTML = (0,_settings_ui_template__WEBPACK_IMPORTED_MODULE_6__.createSettingsButtonTemplate)();\n // 基础样式\n button.style.cssText = `\n position: fixed;\n bottom: 20px;\n right: 20px;\n width: 48px;\n height: 48px;\n border-radius: 50%;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n z-index: 9999;\n transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);\n `;\n // 添加CSS样式\n const style = document.createElement('style');\n style.textContent = (0,_settings_ui_styles__WEBPACK_IMPORTED_MODULE_5__.getSettingsButtonStyles)();\n document.head.appendChild(style);\n // 悬停效果\n button.addEventListener('mouseenter', () => {\n button.style.transform = 'scale(1.1)';\n });\n button.addEventListener('mouseleave', () => {\n button.style.transform = 'scale(1)';\n });\n // 点击动画效果\n button.addEventListener('click', (e) => {\n const rect = button.getBoundingClientRect();\n const x = e.clientX - rect.left;\n const y = e.clientY - rect.top;\n const ripple = button.querySelector('.ripple-effect');\n if (ripple) {\n ripple.classList.remove('active');\n // 触发重排以便动画可以重新开始\n // 使用括号避免TypeScript错误\n (() => ripple.offsetWidth)();\n ripple.classList.add('active');\n }\n setTimeout(() => {\n showSettingsModal();\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('设置按钮被点击,显示设置面板');\n }, 150);\n });\n document.body.appendChild(button);\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('设置按钮已创建并添加到页面');\n}\n/**\n * 创建设置模态框\n */\nfunction createSettingsModal() {\n const modal = document.createElement('div');\n modal.id = 'ast-settings-modal';\n // 加载当前设置\n const settings = (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.loadSettings)();\n console.log('🔍 创建设置模态框时加载的设置:', settings);\n console.log('🔍 hideToolbar当前值:', settings.hideToolbar);\n // 基本模态框结构\n modal.innerHTML = (0,_settings_ui_template__WEBPACK_IMPORTED_MODULE_6__.createModalTemplate)();\n // 获取内部元素\n const modalContent = modal.querySelector('.modal-content');\n const headerDiv = modalContent.querySelector('.modal-header');\n const bodyDiv = modalContent.querySelector('.modal-body');\n // 插入标签页导航\n headerDiv.insertAdjacentHTML('afterend', (0,_tabs__WEBPACK_IMPORTED_MODULE_2__.createTabsNavigation)());\n // 插入标签页内容\n bodyDiv.innerHTML = (0,_settings_tab__WEBPACK_IMPORTED_MODULE_3__.createSettingsTabContent)(settings) + (0,_about_tab__WEBPACK_IMPORTED_MODULE_4__.createAboutTabContent)();\n // 添加样式\n modal.style.cssText = `\n display: none;\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.5);\n z-index: 10000;\n align-items: center;\n justify-content: center;\n opacity: 0;\n transition: opacity 0.3s ease;\n `;\n // 添加所有组件的样式\n const style = document.createElement('style');\n style.textContent = `\n ${(0,_settings_ui_styles__WEBPACK_IMPORTED_MODULE_5__.getModalStyles)()}\n ${(0,_tabs__WEBPACK_IMPORTED_MODULE_2__.getTabsStyles)()}\n ${(0,_settings_tab__WEBPACK_IMPORTED_MODULE_3__.getSettingsTabStyles)()}\n ${(0,_about_tab__WEBPACK_IMPORTED_MODULE_4__.getAboutTabStyles)()}\n ${(0,_settings_ui_styles__WEBPACK_IMPORTED_MODULE_5__.getToastStyles)()}\n `;\n document.head.appendChild(style);\n document.body.appendChild(modal);\n // 添加事件监听\n setupModalEvents();\n // 确认复选框状态与设置一致\n setTimeout(() => {\n const hideToolbarCheckbox = document.getElementById('hide-toolbar');\n if (hideToolbarCheckbox) {\n console.log('🔍 确认隐藏工具栏复选框状态:', hideToolbarCheckbox.checked);\n console.log('🔍 与设置中的值对比:', settings.hideToolbar);\n // 如果复选框状态与设置不一致,则更正\n if (hideToolbarCheckbox.checked !== settings.hideToolbar) {\n console.log('⚠️ 复选框状态与设置不一致,进行更正');\n hideToolbarCheckbox.checked = settings.hideToolbar;\n }\n }\n }, 100);\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('设置模态框已创建并添加到页面');\n}\n/**\n * 设置模态框事件\n */\nfunction setupModalEvents() {\n const modal = document.getElementById('ast-settings-modal');\n if (!modal) {\n console.error('❌ 无法找到设置模态框元素');\n return;\n }\n // 关闭按钮 - 修正为.close-button选择器\n const closeBtn = modal.querySelector('.close-button');\n if (closeBtn) {\n closeBtn.addEventListener('click', () => {\n hideSettingsModal();\n });\n }\n else {\n console.warn('⚠️ 无法找到关闭按钮元素 (.close-button)');\n }\n // 保存按钮 - 修正为#save-settings选择器\n const saveBtn = modal.querySelector('#save-settings');\n if (saveBtn) {\n saveBtn.addEventListener('click', () => {\n saveSettingsFromModal();\n });\n }\n else {\n console.warn('⚠️ 无法找到保存按钮元素 (#save-settings)');\n }\n // 标签页切换\n setupTabsEvents();\n // 设置复选框实时响应\n setupRealTimeCheckboxEvents();\n // 点击模态框外部关闭\n modal.addEventListener('click', (e) => {\n if (e.target === modal) {\n hideSettingsModal();\n }\n });\n // 按ESC键关闭\n document.addEventListener('keydown', (e) => {\n if (e.key === 'Escape' && modal.style.display === 'flex') {\n hideSettingsModal();\n }\n });\n}\n/**\n * 设置复选框实时响应事件\n */\nfunction setupRealTimeCheckboxEvents() {\n try {\n const hideToolbarCheckbox = document.getElementById('hide-toolbar');\n console.log('🔍 设置复选框实时响应 - 隐藏工具栏复选框:', hideToolbarCheckbox);\n if (hideToolbarCheckbox) {\n hideToolbarCheckbox.addEventListener('change', (e) => {\n const isChecked = e.target.checked;\n console.log(`🔄 隐藏工具栏复选框状态已更改为: ${isChecked}`);\n // 实时更新设置\n const currentSettings = (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.loadSettings)();\n currentSettings.hideToolbar = isChecked;\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.saveSettings)(currentSettings);\n // 立即应用设置\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.applyToolbarSetting)(isChecked);\n // 简化提示信息,不提及具体功能\n showToast(`设置已更新`);\n });\n }\n else {\n console.warn('⚠️ 无法找到隐藏工具栏复选框元素');\n }\n }\n catch (error) {\n console.error('❌ 设置复选框实时响应事件出错:', error);\n }\n}\n/**\n * 从模态框表单中保存设置\n */\nfunction saveSettingsFromModal() {\n console.log('🔍 开始保存设置...');\n // 收集当前设置表单中的值\n const newSettings = (0,_settings_tab__WEBPACK_IMPORTED_MODULE_3__.collectSettingsFromForm)();\n console.log('🔍 收集到的设置:', newSettings);\n // 保存到本地存储\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.saveSettings)(newSettings);\n const savedSettings = (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.loadSettings)();\n console.log('✅ 确认保存后的设置:', savedSettings);\n console.log('✅ 保存后的hideToolbar值为:', savedSettings.hideToolbar);\n // 先查找Toolbar元素\n const toolbar = document.getElementById('Toolbar');\n console.log('🔍 查找Toolbar元素:', toolbar);\n // 立即应用工具栏设置 - 直接调用\n console.log('🔍 准备直接应用工具栏设置...');\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.applyToolbarSetting)(newSettings.hideToolbar === true);\n console.log('✅ 工具栏设置已直接应用');\n // 应用其他设置\n console.log('✅ 设置保存流程完成');\n // 发送变更通知\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.notifySettingsChanged)();\n // 隐藏设置模态框\n hideSettingsModal();\n // 简单提示,不包含敏感词汇\n const toast = document.createElement('div');\n toast.textContent = '设置已保存';\n toast.style.cssText = 'position:fixed;bottom:120px;left:50%;transform:translateX(-50%);background:rgba(76,175,80,0.9);color:white;padding:8px 16px;border-radius:4px;z-index:10000;';\n document.body.appendChild(toast);\n // 延迟后移除提示\n setTimeout(() => {\n toast.style.opacity = '0';\n toast.style.transition = 'opacity 0.5s ease';\n setTimeout(() => {\n if (toast.parentNode) {\n toast.parentNode.removeChild(toast);\n }\n }, 1000);\n }, 1500);\n // 强制多次应用工具栏设置,确保它生效(仅在控制台日志中保留,不显示给用户)\n setTimeout(() => {\n console.log('🔍 立即再次应用工具栏设置...');\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.applyToolbarSetting)(newSettings.hideToolbar === true);\n }, 100);\n setTimeout(() => {\n console.log('🔍 延迟500ms后再次应用工具栏设置...');\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.applyToolbarSetting)(newSettings.hideToolbar === true);\n }, 500);\n setTimeout(() => {\n console.log('🔍 延迟1000ms后最后应用工具栏设置...');\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.applyToolbarSetting)(newSettings.hideToolbar === true);\n console.log('✅ 工具栏设置已多次应用完成');\n }, 1000);\n}\n/**\n * 显示保存成功提示\n */\nfunction showSaveSuccess() {\n const toastContainer = document.createElement('div');\n toastContainer.innerHTML = createToastTemplate();\n const toast = toastContainer.firstElementChild;\n document.body.appendChild(toast);\n // 触发重排以强制应用过渡效果\n // 使用括号避免TypeScript错误\n (() => toast.offsetWidth)();\n // 显示toast\n toast.style.opacity = '1';\n toast.style.transform = 'translateX(-50%) translateY(0)';\n setTimeout(() => {\n toast.style.opacity = '0';\n toast.style.transform = 'translateX(-50%) translateY(20px)';\n setTimeout(() => {\n if (toast.parentNode) {\n toast.parentNode.removeChild(toast);\n }\n }, 300);\n }, 2000);\n}\n/**\n * 显示设置模态框\n */\nfunction showSettingsModal() {\n const modal = document.getElementById('ast-settings-modal');\n if (modal) {\n modal.style.display = 'flex';\n // 触发重排以强制应用过渡效果\n // 使用括号避免TypeScript错误\n (() => modal.offsetWidth)();\n // 显示模态框\n modal.style.opacity = '1';\n modal.classList.add('visible');\n }\n}\n/**\n * 隐藏设置模态框\n */\nfunction hideSettingsModal() {\n const modal = document.getElementById('ast-settings-modal');\n if (modal) {\n console.log('🔍 关闭设置模态框,自动保存当前设置...');\n // 在关闭前自动保存当前设置\n try {\n // 收集当前设置\n const currentSettings = (0,_settings_tab__WEBPACK_IMPORTED_MODULE_3__.collectSettingsFromForm)();\n console.log('✅ 关闭时收集的设置:', currentSettings);\n // 保存设置\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.saveSettings)(currentSettings);\n console.log('✅ 关闭时设置已保存');\n // 确保设置被应用\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.applyAllSettings)(currentSettings);\n console.log('✅ 关闭时设置已应用');\n }\n catch (error) {\n console.error('❌ 关闭模态框时保存设置出错:', error);\n }\n // 淡出动画\n modal.style.opacity = '0';\n modal.classList.remove('visible');\n // 等待过渡完成后隐藏\n setTimeout(() => {\n modal.style.display = 'none';\n // 重置标签页状态为设置标签页\n (0,_tabs__WEBPACK_IMPORTED_MODULE_2__.resetTabsState)(modal);\n }, 300);\n }\n}\n/**\n * 处理设置变更事件\n */\nfunction handleSettingsChanged(event) {\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('接收到设置变更事件');\n const settings = event.detail;\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('从事件中提取的设置:', settings);\n if (settings) {\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('准备应用变更后的设置...');\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('hideToolbar值为:', settings.hideToolbar);\n // 应用所有设置\n (0,_settings_settings_service__WEBPACK_IMPORTED_MODULE_0__.applyAllSettings)(settings);\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('设置变更事件处理完成');\n }\n else {\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.warn('设置变更事件中没有包含有效的设置数据');\n }\n}\n/**\n * 显示临时Toast消息\n * @param message 消息内容\n * @param duration 显示时间(毫秒)\n */\nfunction showToast(message = \"设置已更新\", duration = 2000) {\n // 不论传入什么消息,都只显示\"设置已更新\"\n const toast = document.createElement('div');\n toast.className = 'ast-toast';\n toast.textContent = \"设置已更新\";\n toast.style.cssText = `\n position: fixed;\n bottom: 120px;\n left: 50%;\n transform: translateX(-50%);\n background: rgba(76, 175, 80, 0.9);\n color: white;\n padding: 8px 16px;\n border-radius: 4px;\n z-index: 10001;\n opacity: 1;\n transition: opacity 0.5s ease;\n `;\n document.body.appendChild(toast);\n // 延迟后淡出并移除\n setTimeout(() => {\n toast.style.opacity = '0';\n setTimeout(() => {\n if (toast.parentNode) {\n toast.parentNode.removeChild(toast);\n }\n }, 500);\n }, duration);\n}\n/**\n * 设置标签页切换事件\n */\nfunction setupTabsEvents() {\n const modal = document.getElementById('ast-settings-modal');\n if (!modal) {\n console.error('❌ 无法找到设置模态框元素');\n return;\n }\n // 范围限定在modal内部查找\n const tabButtons = modal.querySelectorAll('.modal-tabs .tab-button');\n const tabContents = modal.querySelectorAll('.modal-body .tab-content');\n console.log('🔍 找到', tabButtons.length, '个标签按钮和', tabContents.length, '个标签内容区域');\n // 详细检查标签页状态\n const settingsTab = modal.querySelector('#settings-tab');\n const aboutTab = modal.querySelector('#about-tab');\n console.log('🔍 设置标签:', settingsTab ? '已找到' : '未找到', settingsTab);\n console.log('🔍 关于标签:', aboutTab ? '已找到' : '未找到', aboutTab);\n // 检查标签按钮的data-tab属性\n tabButtons.forEach((btn, index) => {\n console.log(`🔍 标签按钮 ${index}:`, btn.dataset.tab, btn);\n });\n // 检查标签内容的id属性\n tabContents.forEach((content, index) => {\n console.log(`🔍 标签内容 ${index}:`, content.id, content);\n });\n // 为每个标签按钮添加点击事件\n tabButtons.forEach(button => {\n button.addEventListener('click', () => {\n const tabId = button.dataset.tab;\n console.log('🔍 标签按钮被点击:', tabId);\n if (!tabId) {\n console.error('❌ 标签按钮没有data-tab属性');\n return;\n }\n // 移除所有激活状态\n tabButtons.forEach(btn => btn.classList.remove('active'));\n tabContents.forEach(content => content.classList.remove('active'));\n // 添加当前标签页的激活状态\n button.classList.add('active');\n // 查找对应的内容元素并激活\n const tabContent = modal.querySelector(`#${tabId}-tab`);\n if (tabContent) {\n tabContent.classList.add('active');\n console.log('✅ 已激活标签页:', tabId);\n }\n else {\n console.error('❌ 无法找到标签内容:', tabId);\n }\n });\n });\n // 确保默认标签页处于激活状态\n const defaultTab = modal.querySelector('.tab-button[data-tab=\"settings\"]');\n if (defaultTab) {\n // 手动触发一次点击事件,确保正确激活\n defaultTab.click();\n console.log('✅ 已激活默认标签页');\n }\n else {\n console.error('❌ 无法找到默认标签按钮');\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"458.js","mappings":"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","sources":["webpack://ast-explorer-helper/./src/ui/settings-ui/settings-ui.component.ts?3c41"],"sourcesContent":["/**\n * 设置UI组件 - 逻辑文件\n */\n\nimport { \n    loadSettings, \n    saveSettings, \n    applyAllSettings,\n    applyToolbarSetting,\n    notifySettingsChanged, \n    Settings \n} from '../../settings/settings.service';\nimport { logger } from '../../logger';\n\nimport { createTabsNavigation, getTabsStyles, resetTabsState } from '../tabs';\nimport { createSettingsTabContent, collectSettingsFromForm, getSettingsTabStyles } from '../settings-tab';\nimport { createAboutTabContent, getAboutTabStyles } from '../about-tab';\n\nimport { \n    getSettingsButtonStyles,\n    getModalStyles, \n    getToastStyles \n} from './settings-ui.styles';\nimport { \n    createSettingsButtonTemplate,\n    createModalTemplate,\n    createToastTemplate \n} from './settings-ui.template';\n\n// 导出公共API\nexport { \n    getSettingsButtonStyles,\n    getModalStyles, \n    getToastStyles \n} from './settings-ui.styles';\nexport { \n    createSettingsButtonTemplate,\n    createModalTemplate,\n    createToastTemplate \n} from './settings-ui.template';\n\n/**\n * 创建设置界面\n */\nexport function createSettingsUI(): void {\n    // 添加设置按钮\n    createSettingsButton();\n    \n    // 创建设置模态框\n    createSettingsModal();\n    \n    // 监听设置变更事件\n    document.addEventListener('ast-explorer-helper-settings-changed', handleSettingsChanged);\n}\n\n/**\n * 创建设置按钮\n */\nfunction createSettingsButton(): void {\n    const button = document.createElement('div');\n    button.id = 'ast-settings-button';\n    \n    // 使用模板生成按钮内容\n    button.innerHTML = createSettingsButtonTemplate();\n    \n    // 基础样式\n    button.style.cssText = `\n        position: fixed;\n        bottom: 20px;\n        right: 20px;\n        width: 48px;\n        height: 48px;\n        border-radius: 50%;\n        display: flex;\n        align-items: center;\n        justify-content: center;\n        cursor: pointer;\n        z-index: 9999;\n        transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);\n    `;\n    \n    // 添加CSS样式\n    const style = document.createElement('style');\n    style.textContent = getSettingsButtonStyles();\n    document.head.appendChild(style);\n    \n    // 悬停效果\n    button.addEventListener('mouseenter', () => {\n        button.style.transform = 'scale(1.1)';\n    });\n    \n    button.addEventListener('mouseleave', () => {\n        button.style.transform = 'scale(1)';\n    });\n    \n    // 点击动画效果\n    button.addEventListener('click', (e) => {\n        const rect = button.getBoundingClientRect();\n        const x = e.clientX - rect.left;\n        const y = e.clientY - rect.top;\n        \n        const ripple = button.querySelector('.ripple-effect') as HTMLElement;\n        if (ripple) {\n            ripple.classList.remove('active');\n            \n            // 触发重排以便动画可以重新开始\n            // 使用括号避免TypeScript错误\n            (() => ripple.offsetWidth)();\n            \n            ripple.classList.add('active');\n        }\n        \n        setTimeout(() => {\n            showSettingsModal();\n            logger.debug('设置按钮被点击，显示设置面板');\n        }, 150);\n    });\n    \n    document.body.appendChild(button);\n    logger.debug('设置按钮已创建并添加到页面');\n}\n\n/**\n * 创建设置模态框\n */\nfunction createSettingsModal(): void {\n    const modal = document.createElement('div');\n    modal.id = 'ast-settings-modal';\n    \n    // 加载当前设置\n    const settings = loadSettings();\n    console.log('🔍 创建设置模态框时加载的设置:', settings);\n    console.log('🔍 hideToolbar当前值:', settings.hideToolbar);\n    \n    // 基本模态框结构\n    modal.innerHTML = createModalTemplate();\n    \n    // 获取内部元素\n    const modalContent = modal.querySelector('.modal-content') as HTMLElement;\n    const headerDiv = modalContent.querySelector('.modal-header') as HTMLElement;\n    const bodyDiv = modalContent.querySelector('.modal-body') as HTMLElement;\n    \n    // 插入标签页导航\n    headerDiv.insertAdjacentHTML('afterend', createTabsNavigation());\n    \n    // 插入标签页内容\n    bodyDiv.innerHTML = createSettingsTabContent(settings) + createAboutTabContent();\n    \n    // 添加样式\n    modal.style.cssText = `\n        display: none;\n        position: fixed;\n        top: 0;\n        left: 0;\n        width: 100%;\n        height: 100%;\n        background-color: rgba(0, 0, 0, 0.5);\n        z-index: 10000;\n        align-items: center;\n        justify-content: center;\n        opacity: 0;\n        transition: opacity 0.3s ease;\n    `;\n    \n    // 添加所有组件的样式\n    const style = document.createElement('style');\n    style.textContent = `\n        ${getModalStyles()}\n        ${getTabsStyles()}\n        ${getSettingsTabStyles()}\n        ${getAboutTabStyles()}\n        ${getToastStyles()}\n    `;\n    document.head.appendChild(style);\n    document.body.appendChild(modal);\n    \n    // 添加事件监听\n    setupModalEvents();\n    \n    // 确认复选框状态与设置一致\n    setTimeout(() => {\n        const hideToolbarCheckbox = document.getElementById('hide-toolbar') as HTMLInputElement;\n        if (hideToolbarCheckbox) {\n            console.log('🔍 确认隐藏工具栏复选框状态:', hideToolbarCheckbox.checked);\n            console.log('🔍 与设置中的值对比:', settings.hideToolbar);\n            \n            // 如果复选框状态与设置不一致，则更正\n            if (hideToolbarCheckbox.checked !== settings.hideToolbar) {\n                console.log('⚠️ 复选框状态与设置不一致，进行更正');\n                hideToolbarCheckbox.checked = settings.hideToolbar;\n            }\n        }\n    }, 100);\n    \n    logger.debug('设置模态框已创建并添加到页面');\n}\n\n/**\n * 设置模态框事件\n */\nfunction setupModalEvents(): void {\n    const modal = document.getElementById('ast-settings-modal');\n    if (!modal) {\n        console.error('❌ 无法找到设置模态框元素');\n        return;\n    }\n    \n    // 关闭按钮 - 修正为.close-button选择器\n    const closeBtn = modal.querySelector('.close-button');\n    if (closeBtn) {\n        closeBtn.addEventListener('click', () => {\n            hideSettingsModal();\n        });\n    } else {\n        console.warn('⚠️ 无法找到关闭按钮元素 (.close-button)');\n    }\n    \n    // 保存按钮 - 修正为#save-settings选择器\n    const saveBtn = modal.querySelector('#save-settings');\n    if (saveBtn) {\n        saveBtn.addEventListener('click', () => {\n            saveSettingsFromModal();\n        });\n    } else {\n        console.warn('⚠️ 无法找到保存按钮元素 (#save-settings)');\n    }\n    \n    // 标签页切换\n    setupTabsEvents();\n    \n    // 设置复选框实时响应\n    setupRealTimeCheckboxEvents();\n    \n    // 点击模态框外部关闭\n    modal.addEventListener('click', (e) => {\n        if (e.target === modal) {\n            hideSettingsModal();\n        }\n    });\n\n    // 按ESC键关闭\n    document.addEventListener('keydown', (e) => {\n        if (e.key === 'Escape' && modal.style.display === 'flex') {\n            hideSettingsModal();\n        }\n    });\n}\n\n/**\n * 设置复选框实时响应事件\n */\nfunction setupRealTimeCheckboxEvents(): void {\n    try {\n        const hideToolbarCheckbox = document.getElementById('hide-toolbar') as HTMLInputElement;\n        \n        console.log('🔍 设置复选框实时响应 - 隐藏工具栏复选框:', hideToolbarCheckbox);\n        \n        if (hideToolbarCheckbox) {\n            hideToolbarCheckbox.addEventListener('change', (e) => {\n                const isChecked = (e.target as HTMLInputElement).checked;\n                console.log(`🔄 隐藏工具栏复选框状态已更改为: ${isChecked}`);\n                \n                // 实时更新设置\n                const currentSettings = loadSettings();\n                currentSettings.hideToolbar = isChecked;\n                saveSettings(currentSettings);\n                \n                // 立即应用设置\n                applyToolbarSetting(isChecked);\n                \n                // 简化提示信息，不提及具体功能\n                showToast(`设置已更新`);\n            });\n        } else {\n            console.warn('⚠️ 无法找到隐藏工具栏复选框元素');\n        }\n    } catch (error) {\n        console.error('❌ 设置复选框实时响应事件出错:', error);\n    }\n}\n\n/**\n * 从模态框表单中保存设置\n */\nfunction saveSettingsFromModal(): void {\n    console.log('🔍 开始保存设置...');\n    \n    // 收集当前设置表单中的值\n    const newSettings = collectSettingsFromForm() as Settings;\n    console.log('🔍 收集到的设置:', newSettings);\n    \n    // 保存到本地存储\n    saveSettings(newSettings);\n    const savedSettings = loadSettings();\n    console.log('✅ 确认保存后的设置:', savedSettings);\n    console.log('✅ 保存后的hideToolbar值为:', savedSettings.hideToolbar);\n    \n    // 先查找Toolbar元素\n    const toolbar = document.getElementById('Toolbar');\n    console.log('🔍 查找Toolbar元素:', toolbar);\n    \n    // 立即应用工具栏设置 - 直接调用\n    console.log('🔍 准备直接应用工具栏设置...');\n    applyToolbarSetting(newSettings.hideToolbar === true);\n    console.log('✅ 工具栏设置已直接应用');\n    \n    // 应用其他设置\n    console.log('✅ 设置保存流程完成');\n    \n    // 发送变更通知\n    notifySettingsChanged();\n    \n    // 隐藏设置模态框\n    hideSettingsModal();\n    \n    // 简单提示，不包含敏感词汇\n    const toast = document.createElement('div');\n    toast.textContent = '设置已保存';\n    toast.style.cssText = 'position:fixed;bottom:120px;left:50%;transform:translateX(-50%);background:rgba(76,175,80,0.9);color:white;padding:8px 16px;border-radius:4px;z-index:10000;';\n    document.body.appendChild(toast);\n    \n    // 延迟后移除提示\n    setTimeout(() => {\n        toast.style.opacity = '0';\n        toast.style.transition = 'opacity 0.5s ease';\n        setTimeout(() => {\n            if (toast.parentNode) {\n                toast.parentNode.removeChild(toast);\n            }\n        }, 1000);\n    }, 1500);\n    \n    // 强制多次应用工具栏设置，确保它生效（仅在控制台日志中保留，不显示给用户）\n    setTimeout(() => {\n        console.log('🔍 立即再次应用工具栏设置...');\n        applyToolbarSetting(newSettings.hideToolbar === true);\n    }, 100);\n    \n    setTimeout(() => {\n        console.log('🔍 延迟500ms后再次应用工具栏设置...');\n        applyToolbarSetting(newSettings.hideToolbar === true);\n    }, 500);\n    \n    setTimeout(() => {\n        console.log('🔍 延迟1000ms后最后应用工具栏设置...');\n        applyToolbarSetting(newSettings.hideToolbar === true);\n        console.log('✅ 工具栏设置已多次应用完成');\n    }, 1000);\n}\n\n/**\n * 显示保存成功提示\n */\nfunction showSaveSuccess(): void {\n    const toastContainer = document.createElement('div');\n    toastContainer.innerHTML = createToastTemplate();\n    const toast = toastContainer.firstElementChild as HTMLElement;\n    \n    document.body.appendChild(toast);\n    \n    // 触发重排以强制应用过渡效果\n    // 使用括号避免TypeScript错误\n    (() => toast.offsetWidth)();\n    \n    // 显示toast\n    toast.style.opacity = '1';\n    toast.style.transform = 'translateX(-50%) translateY(0)';\n    \n    setTimeout(() => {\n        toast.style.opacity = '0';\n        toast.style.transform = 'translateX(-50%) translateY(20px)';\n        \n        setTimeout(() => {\n            if (toast.parentNode) {\n                toast.parentNode.removeChild(toast);\n            }\n        }, 300);\n    }, 2000);\n}\n\n/**\n * 显示设置模态框\n */\nfunction showSettingsModal(): void {\n    const modal = document.getElementById('ast-settings-modal') as HTMLElement;\n    if (modal) {\n        modal.style.display = 'flex';\n        \n        // 触发重排以强制应用过渡效果\n        // 使用括号避免TypeScript错误\n        (() => modal.offsetWidth)();\n        \n        // 显示模态框\n        modal.style.opacity = '1';\n        modal.classList.add('visible');\n    }\n}\n\n/**\n * 隐藏设置模态框\n */\nfunction hideSettingsModal(): void {\n    const modal = document.getElementById('ast-settings-modal') as HTMLElement;\n    if (modal) {\n        console.log('🔍 关闭设置模态框，自动保存当前设置...');\n        \n        // 在关闭前自动保存当前设置\n        try {\n            // 收集当前设置\n            const currentSettings = collectSettingsFromForm();\n            console.log('✅ 关闭时收集的设置:', currentSettings);\n            \n            // 保存设置\n            saveSettings(currentSettings as Settings);\n            console.log('✅ 关闭时设置已保存');\n            \n            // 确保设置被应用\n            applyAllSettings(currentSettings as Settings);\n            console.log('✅ 关闭时设置已应用');\n        } catch (error) {\n            console.error('❌ 关闭模态框时保存设置出错:', error);\n        }\n        \n        // 淡出动画\n        modal.style.opacity = '0';\n        modal.classList.remove('visible');\n        \n        // 等待过渡完成后隐藏\n        setTimeout(() => {\n            modal.style.display = 'none';\n            \n            // 重置标签页状态为设置标签页\n            resetTabsState(modal);\n        }, 300);\n    }\n}\n\n/**\n * 处理设置变更事件\n */\nfunction handleSettingsChanged(event: Event): void {\n    logger.debug('接收到设置变更事件');\n    \n    const settings = (event as CustomEvent).detail as Settings;\n    logger.debug('从事件中提取的设置:', settings);\n    \n    if (settings) {\n        logger.debug('准备应用变更后的设置...');\n        logger.debug('hideToolbar值为:', settings.hideToolbar);\n        \n        // 应用所有设置\n        applyAllSettings(settings);\n        logger.debug('设置变更事件处理完成');\n    } else {\n        logger.warn('设置变更事件中没有包含有效的设置数据');\n    }\n}\n\n/**\n * 显示临时Toast消息\n * @param message 消息内容\n * @param duration 显示时间（毫秒）\n */\nfunction showToast(message: string = \"设置已更新\", duration = 2000): void {\n    // 不论传入什么消息，都只显示\"设置已更新\"\n    const toast = document.createElement('div');\n    toast.className = 'ast-toast';\n    toast.textContent = \"设置已更新\";\n    toast.style.cssText = `\n        position: fixed;\n        bottom: 120px;\n        left: 50%;\n        transform: translateX(-50%);\n        background: rgba(76, 175, 80, 0.9);\n        color: white;\n        padding: 8px 16px;\n        border-radius: 4px;\n        z-index: 10001;\n        opacity: 1;\n        transition: opacity 0.5s ease;\n    `;\n    \n    document.body.appendChild(toast);\n    \n    // 延迟后淡出并移除\n    setTimeout(() => {\n        toast.style.opacity = '0';\n        setTimeout(() => {\n            if (toast.parentNode) {\n                toast.parentNode.removeChild(toast);\n            }\n        }, 500);\n    }, duration);\n}\n\n/**\n * 设置标签页切换事件\n */\nfunction setupTabsEvents(): void {\n    const modal = document.getElementById('ast-settings-modal');\n    if (!modal) {\n        console.error('❌ 无法找到设置模态框元素');\n        return;\n    }\n    \n    // 范围限定在modal内部查找\n    const tabButtons = modal.querySelectorAll('.modal-tabs .tab-button');\n    const tabContents = modal.querySelectorAll('.modal-body .tab-content');\n    \n    console.log('🔍 找到', tabButtons.length, '个标签按钮和', tabContents.length, '个标签内容区域');\n    \n    // 详细检查标签页状态\n    const settingsTab = modal.querySelector('#settings-tab');\n    const aboutTab = modal.querySelector('#about-tab');\n    console.log('🔍 设置标签:', settingsTab ? '已找到' : '未找到', settingsTab);\n    console.log('🔍 关于标签:', aboutTab ? '已找到' : '未找到', aboutTab);\n    \n    // 检查标签按钮的data-tab属性\n    tabButtons.forEach((btn, index) => {\n        console.log(`🔍 标签按钮 ${index}:`, (btn as HTMLElement).dataset.tab, btn);\n    });\n    \n    // 检查标签内容的id属性\n    tabContents.forEach((content, index) => {\n        console.log(`🔍 标签内容 ${index}:`, content.id, content);\n    });\n    \n    // 为每个标签按钮添加点击事件\n    tabButtons.forEach(button => {\n        button.addEventListener('click', () => {\n            const tabId = (button as HTMLElement).dataset.tab;\n            console.log('🔍 标签按钮被点击:', tabId);\n            \n            if (!tabId) {\n                console.error('❌ 标签按钮没有data-tab属性');\n                return;\n            }\n            \n            // 移除所有激活状态\n            tabButtons.forEach(btn => btn.classList.remove('active'));\n            tabContents.forEach(content => content.classList.remove('active'));\n            \n            // 添加当前标签页的激活状态\n            button.classList.add('active');\n            \n            // 查找对应的内容元素并激活\n            const tabContent = modal.querySelector(`#${tabId}-tab`);\n            if (tabContent) {\n                tabContent.classList.add('active');\n                console.log('✅ 已激活标签页:', tabId);\n            } else {\n                console.error('❌ 无法找到标签内容:', tabId);\n            }\n        });\n    });\n    \n    // 确保默认标签页处于激活状态\n    const defaultTab = modal.querySelector('.tab-button[data-tab=\"settings\"]');\n    if (defaultTab) {\n        // 手动触发一次点击事件，确保正确激活\n        (defaultTab as HTMLElement).click();\n        console.log('✅ 已激活默认标签页');\n    } else {\n        console.error('❌ 无法找到默认标签按钮');\n    }\n} "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///458\n");
/***/ }),
/***/ 481:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createTabsNavigation: () => (/* reexport safe */ _tabs_component__WEBPACK_IMPORTED_MODULE_0__.createTabsNavigation),\n/* harmony export */ getTabsStyles: () => (/* reexport safe */ _tabs_component__WEBPACK_IMPORTED_MODULE_0__.getTabsStyles),\n/* harmony export */ initTabEvents: () => (/* reexport safe */ _tabs_component__WEBPACK_IMPORTED_MODULE_0__.initTabEvents),\n/* harmony export */ resetTabsState: () => (/* reexport safe */ _tabs_component__WEBPACK_IMPORTED_MODULE_0__.resetTabsState)\n/* harmony export */ });\n/* harmony import */ var _tabs_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(792);\n/**\n * 标签页组件 - 入口文件\n */\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDgxLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7O0dBRUc7QUFPdUIiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL3VpL3RhYnMvaW5kZXgudHM/MjhhYSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIOagh+etvumhtee7hOS7tiAtIOWFpeWPo+aWh+S7tlxuICovXG5cbmV4cG9ydCB7IFxuICAgIGluaXRUYWJFdmVudHMsIFxuICAgIHJlc2V0VGFic1N0YXRlLFxuICAgIGdldFRhYnNTdHlsZXMsXG4gICAgY3JlYXRlVGFic05hdmlnYXRpb25cbn0gZnJvbSAnLi90YWJzLmNvbXBvbmVudCc7ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///481\n");
/***/ }),
/***/ 494:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ handleRightClick: () => (/* binding */ handleRightClick),\n/* harmony export */ setSelectable: () => (/* binding */ setSelectable),\n/* harmony export */ sleep: () => (/* binding */ sleep)\n/* harmony export */ });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(610);\n/**\n * DOM 操作相关的工具函数\n */\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n/**\n * 使节点内容可选\n * @param doneKey 标记属性名\n */\nfunction setSelectable() {\n return __awaiter(this, arguments, void 0, function* (doneKey = \"cc11001100_select_enable\") {\n const elements = document.querySelectorAll(\".tree-visualization > ul *\");\n let newElementsCount = 0;\n elements.forEach(element => {\n if (element.getAttribute(doneKey)) {\n return;\n }\n element.style.cssText = \"; user-select: text !important; -webkit-user-select: text !important; \";\n element.setAttribute(doneKey, \"true\");\n // 添加右键菜单事件\n element.addEventListener('contextmenu', handleRightClick);\n newElementsCount++;\n });\n if (newElementsCount > 0) {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug(`处理了 ${newElementsCount} 个新节点,使其内容可选`);\n }\n });\n}\n/**\n * 处理右键点击事件\n * @param e 鼠标事件\n */\nfunction handleRightClick(e) {\n var _a;\n e.preventDefault();\n e.stopPropagation();\n const menu = document.getElementById(\"ast-context-menu\");\n if (!menu) {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.warn('未找到右键菜单元素');\n return;\n }\n // 保存当前目标节点\n menu.targetNode = this;\n // 设置菜单位置\n menu.style.left = `${e.pageX}px`;\n menu.style.top = `${e.pageY}px`;\n menu.style.display = 'block';\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('显示右键菜单,目标节点:', this.tagName, (_a = this.textContent) === null || _a === void 0 ? void 0 : _a.trim().substring(0, 30));\n}\n/**\n * 延迟函数\n * @param mils 延迟毫秒数\n */\nfunction sleep(mils) {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise(resolve => setTimeout(resolve, mils));\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDk0LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7R0FFRzs7Ozs7Ozs7OztBQUVnQztBQVNuQzs7O0dBR0c7QUFDSSxTQUFlLGFBQWE7eURBQUMsVUFBa0IsMEJBQTBCO1FBQzVFLE1BQU0sUUFBUSxHQUFHLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBYyw0QkFBNEIsQ0FBQyxDQUFDO1FBQ3RGLElBQUksZ0JBQWdCLEdBQUcsQ0FBQyxDQUFDO1FBRXpCLFFBQVEsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDdkIsSUFBSSxPQUFPLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7Z0JBQ2hDLE9BQU87WUFDWCxDQUFDO1lBQ0QsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsd0VBQXdFLENBQUM7WUFDakcsT0FBTyxDQUFDLFlBQVksQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7WUFFdEMsV0FBVztZQUNYLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztZQUUxRCxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxnQkFBZ0IsR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUN2QiwyQ0FBTSxDQUFDLEtBQUssQ0FBQyxPQUFPLGdCQUFnQixjQUFjLENBQUMsQ0FBQztRQUN4RCxDQUFDO0lBQ0wsQ0FBQztDQUFBO0FBRUQ7OztHQUdHO0FBQ0ksU0FBUyxnQkFBZ0IsQ0FBb0IsQ0FBYTs7SUFDN0QsQ0FBQyxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ25CLENBQUMsQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUVwQixNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLGtCQUFrQixDQUE4QixDQUFDO0lBQ3RGLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNSLDJDQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3pCLE9BQU87SUFDWCxDQUFDO0lBRUQsV0FBVztJQUNYLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO0lBRXZCLFNBQVM7SUFDVCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxHQUFHLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQztJQUNqQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQztJQUNoQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFFN0IsMkNBQU0sQ0FBQyxLQUFLLENBQUMsY0FBYyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsVUFBSSxDQUFDLFdBQVcsMENBQUUsSUFBSSxHQUFHLFNBQVMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUMxRixDQUFDO0FBRUQ7OztHQUdHO0FBQ0ksU0FBZSxLQUFLLENBQUMsSUFBWTs7UUFDcEMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUM3RCxDQUFDO0NBQUEiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL2RvbS1oZWxwZXJzL2RvbS11dGlscy50cz80NDAyIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRE9NIOaTjeS9nOebuOWFs+eahOW3peWFt+WHveaVsFxuICovXG5cbmltcG9ydCB7IGxvZ2dlciB9IGZyb20gJy4uL2xvZ2dlcic7XG5cbi8qKlxuICog6Ieq5a6a5LmJ57G75Z6L77yM5omp5bGVSFRNTEVsZW1lbnRcbiAqL1xuaW50ZXJmYWNlIENvbnRleHRNZW51RWxlbWVudCBleHRlbmRzIEhUTUxFbGVtZW50IHtcbiAgICB0YXJnZXROb2RlPzogSFRNTEVsZW1lbnQ7XG59XG5cbi8qKlxuICog5L2/6IqC54K55YaF5a655Y+v6YCJXG4gKiBAcGFyYW0gZG9uZUtleSDmoIforrDlsZ7mgKflkI1cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNldFNlbGVjdGFibGUoZG9uZUtleTogc3RyaW5nID0gXCJjYzExMDAxMTAwX3NlbGVjdF9lbmFibGVcIik6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGVsZW1lbnRzID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbDxIVE1MRWxlbWVudD4oXCIudHJlZS12aXN1YWxpemF0aW9uID4gdWwgKlwiKTtcbiAgICBsZXQgbmV3RWxlbWVudHNDb3VudCA9IDA7XG5cbiAgICBlbGVtZW50cy5mb3JFYWNoKGVsZW1lbnQgPT4ge1xuICAgICAgICBpZiAoZWxlbWVudC5nZXRBdHRyaWJ1dGUoZG9uZUtleSkpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBlbGVtZW50LnN0eWxlLmNzc1RleHQgPSBcIjsgdXNlci1zZWxlY3Q6IHRleHQgIWltcG9ydGFudDsgLXdlYmtpdC11c2VyLXNlbGVjdDogdGV4dCAhaW1wb3J0YW50OyBcIjtcbiAgICAgICAgZWxlbWVudC5zZXRBdHRyaWJ1dGUoZG9uZUtleSwgXCJ0cnVlXCIpO1xuICAgICAgICBcbiAgICAgICAgLy8g5re75Yqg5Y+z6ZSu6I+c5Y2V5LqL5Lu2XG4gICAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignY29udGV4dG1lbnUnLCBoYW5kbGVSaWdodENsaWNrKTtcbiAgICAgICAgXG4gICAgICAgIG5ld0VsZW1lbnRzQ291bnQrKztcbiAgICB9KTtcblxuICAgIGlmIChuZXdFbGVtZW50c0NvdW50ID4gMCkge1xuICAgICAgICBsb2dnZXIuZGVidWcoYOWkhOeQhuS6hiAke25ld0VsZW1lbnRzQ291bnR9IOS4quaWsOiKgueCue+8jOS9v+WFtuWGheWuueWPr+mAiWApO1xuICAgIH1cbn1cblxuLyoqXG4gKiDlpITnkIblj7PplK7ngrnlh7vkuovku7ZcbiAqIEBwYXJhbSBlIOm8oOagh+S6i+S7tlxuICovXG5leHBvcnQgZnVuY3Rpb24gaGFuZGxlUmlnaHRDbGljayh0aGlzOiBIVE1MRWxlbWVudCwgZTogTW91c2VFdmVudCk6IHZvaWQge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIFxuICAgIGNvbnN0IG1lbnUgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcImFzdC1jb250ZXh0LW1lbnVcIikgYXMgQ29udGV4dE1lbnVFbGVtZW50IHwgbnVsbDtcbiAgICBpZiAoIW1lbnUpIHtcbiAgICAgICAgbG9nZ2VyLndhcm4oJ+acquaJvuWIsOWPs+mUruiPnOWNleWFg+e0oCcpO1xuICAgICAgICByZXR1cm47XG4gICAgfVxuICAgIFxuICAgIC8vIOS/neWtmOW9k+WJjeebruagh+iKgueCuVxuICAgIG1lbnUudGFyZ2V0Tm9kZSA9IHRoaXM7XG4gICAgXG4gICAgLy8g6K6+572u6I+c5Y2V5L2N572uXG4gICAgbWVudS5zdHlsZS5sZWZ0ID0gYCR7ZS5wYWdlWH1weGA7XG4gICAgbWVudS5zdHlsZS50b3AgPSBgJHtlLnBhZ2VZfXB4YDtcbiAgICBtZW51LnN0eWxlLmRpc3BsYXkgPSAnYmxvY2snO1xuXG4gICAgbG9nZ2VyLmRlYnVnKCfmmL7npLrlj7PplK7oj5zljZXvvIznm67moIfoioLngrk6JywgdGhpcy50YWdOYW1lLCB0aGlzLnRleHRDb250ZW50Py50cmltKCkuc3Vic3RyaW5nKDAsIDMwKSk7XG59XG5cbi8qKlxuICog5bu26L+f5Ye95pWwXG4gKiBAcGFyYW0gbWlscyDlu7bov5/mr6vnp5LmlbBcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNsZWVwKG1pbHM6IG51bWJlcik6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiBuZXcgUHJvbWlzZShyZXNvbHZlID0+IHNldFRpbWVvdXQocmVzb2x2ZSwgbWlscykpO1xufSAiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///494\n");
/***/ }),
/***/ 533:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getTabsStyles: () => (/* binding */ getTabsStyles)\n/* harmony export */ });\n/**\n * 标签页组件 - 样式文件\n */\n/**\n * 获取标签页样式\n * @returns 标签页通用CSS样式\n */\nfunction getTabsStyles() {\n return `\n #ast-settings-modal .modal-tabs {\n display: flex;\n background-color: #f5f7fa;\n border-bottom: 1px solid #eee;\n }\n \n #ast-settings-modal .tab-button {\n flex: 1;\n background: none;\n border: none;\n padding: 12px;\n font-size: 15px;\n cursor: pointer;\n position: relative;\n color: #666;\n font-weight: 500;\n transition: all 0.2s;\n }\n \n #ast-settings-modal .tab-button:hover {\n color: #4a90e2;\n background-color: #f0f4f9;\n }\n \n #ast-settings-modal .tab-button.active {\n color: #4a90e2;\n }\n \n #ast-settings-modal .tab-button.active::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n height: 3px;\n background-color: #4a90e2;\n }\n \n #ast-settings-modal .tab-content {\n display: none;\n }\n \n #ast-settings-modal .tab-content.active {\n display: block;\n }\n \n /* 根据当前标签页显示/隐藏元素 */\n #ast-settings-modal .only-settings-tab {\n display: none;\n }\n \n #ast-settings-modal .tab-button[data-tab=\"settings\"].active ~ .modal-body ~ .modal-footer .only-settings-tab {\n display: inline-block;\n }\n `;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTMzLmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7R0FFRztBQUVIOzs7R0FHRztBQUNJLFNBQVMsYUFBYTtJQUN6QixPQUFPOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBdUROLENBQUM7QUFDTixDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYXN0LWV4cGxvcmVyLWhlbHBlci8uL3NyYy91aS90YWJzL3RhYnMuc3R5bGVzLnRzPzZlNWMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDmoIfnrb7pobXnu4Tku7YgLSDmoLflvI/mlofku7ZcbiAqL1xuXG4vKipcbiAqIOiOt+WPluagh+etvumhteagt+W8j1xuICogQHJldHVybnMg5qCH562+6aG16YCa55SoQ1NT5qC35byPXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRUYWJzU3R5bGVzKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBcbiAgICAgICAgI2FzdC1zZXR0aW5ncy1tb2RhbCAubW9kYWwtdGFicyB7XG4gICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogI2Y1ZjdmYTtcbiAgICAgICAgICAgIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAjZWVlO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICAjYXN0LXNldHRpbmdzLW1vZGFsIC50YWItYnV0dG9uIHtcbiAgICAgICAgICAgIGZsZXg6IDE7XG4gICAgICAgICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgICAgICAgICAgYm9yZGVyOiBub25lO1xuICAgICAgICAgICAgcGFkZGluZzogMTJweDtcbiAgICAgICAgICAgIGZvbnQtc2l6ZTogMTVweDtcbiAgICAgICAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgICAgICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICAgICAgICAgIGNvbG9yOiAjNjY2O1xuICAgICAgICAgICAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgICAgICAgICAgIHRyYW5zaXRpb246IGFsbCAwLjJzO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICAjYXN0LXNldHRpbmdzLW1vZGFsIC50YWItYnV0dG9uOmhvdmVyIHtcbiAgICAgICAgICAgIGNvbG9yOiAjNGE5MGUyO1xuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogI2YwZjRmOTtcbiAgICAgICAgfVxuICAgICAgICBcbiAgICAgICAgI2FzdC1zZXR0aW5ncy1tb2RhbCAudGFiLWJ1dHRvbi5hY3RpdmUge1xuICAgICAgICAgICAgY29sb3I6ICM0YTkwZTI7XG4gICAgICAgIH1cbiAgICAgICAgXG4gICAgICAgICNhc3Qtc2V0dGluZ3MtbW9kYWwgLnRhYi1idXR0b24uYWN0aXZlOjphZnRlciB7XG4gICAgICAgICAgICBjb250ZW50OiAnJztcbiAgICAgICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgICAgIGxlZnQ6IDA7XG4gICAgICAgICAgICByaWdodDogMDtcbiAgICAgICAgICAgIGhlaWdodDogM3B4O1xuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogIzRhOTBlMjtcbiAgICAgICAgfVxuICAgICAgICBcbiAgICAgICAgI2FzdC1zZXR0aW5ncy1tb2RhbCAudGFiLWNvbnRlbnQge1xuICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgfVxuICAgICAgICBcbiAgICAgICAgI2FzdC1zZXR0aW5ncy1tb2RhbCAudGFiLWNvbnRlbnQuYWN0aXZlIHtcbiAgICAgICAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICAvKiDmoLnmja7lvZPliY3moIfnrb7pobXmmL7npLov6ZqQ6JeP5YWD57SgICovXG4gICAgICAgICNhc3Qtc2V0dGluZ3MtbW9kYWwgLm9ubHktc2V0dGluZ3MtdGFiIHtcbiAgICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgIH1cbiAgICAgICAgXG4gICAgICAgICNhc3Qtc2V0dGluZ3MtbW9kYWwgLnRhYi1idXR0b25bZGF0YS10YWI9XCJzZXR0aW5nc1wiXS5hY3RpdmUgfiAubW9kYWwtYm9keSB+IC5tb2RhbC1mb290ZXIgLm9ubHktc2V0dGluZ3MtdGFiIHtcbiAgICAgICAgICAgIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgICAgICAgfVxuICAgIGA7XG59ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///533\n");
/***/ }),
/***/ 536:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createContextMenu: () => (/* reexport safe */ _context_menu_component__WEBPACK_IMPORTED_MODULE_0__.createContextMenu),\n/* harmony export */ createSettingsUI: () => (/* reexport safe */ _settings_ui__WEBPACK_IMPORTED_MODULE_1__.createSettingsUI)\n/* harmony export */ });\n/* harmony import */ var _context_menu_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(562);\n/* harmony import */ var _settings_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(629);\n/**\n * UI组件模块入口\n */\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTM2LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7R0FFRztBQUUwRDtBQUNaIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYXN0LWV4cGxvcmVyLWhlbHBlci8uL3NyYy91aS9pbmRleC50cz9mNzliIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVUnnu4Tku7bmqKHlnZflhaXlj6NcbiAqL1xuXG5leHBvcnQgeyBjcmVhdGVDb250ZXh0TWVudSB9IGZyb20gJy4vY29udGV4dC1tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgeyBjcmVhdGVTZXR0aW5nc1VJIH0gZnJvbSAnLi9zZXR0aW5ncy11aSc7ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///536\n");
/***/ }),
/***/ 562:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createContextMenu: () => (/* binding */ createContextMenu),\n/* harmony export */ expandAllNodes: () => (/* binding */ expandAllNodes),\n/* harmony export */ setupKeyboardShortcuts: () => (/* binding */ setupKeyboardShortcuts)\n/* harmony export */ });\n/* harmony import */ var _clipboard_clipboard_service__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(879);\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(610);\n/**\n * 右键菜单组件\n */\n\n\n/**\n * 递归展开指定节点下的所有子节点\n * @param node 要展开的节点\n */\nfunction expandAllNodes(node) {\n var _a;\n // 首先找到包含当前节点的可折叠节点\n let targetNode = node;\n while (targetNode && !targetNode.classList.contains('entry')) {\n targetNode = targetNode.parentElement;\n }\n if (!targetNode) {\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.info('未找到可折叠节点');\n return;\n }\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.info('找到可折叠节点:', {\n tagName: targetNode.tagName,\n className: targetNode.className,\n textContent: (_a = targetNode.textContent) === null || _a === void 0 ? void 0 : _a.substring(0, 50)\n });\n // 递归展开节点的函数\n function expandNodes(currentNode) {\n var _a;\n // 如果当前节点未展开,先展开它\n if (!currentNode.classList.contains('open')) {\n const expandIcon = currentNode.querySelector('.disclosure-arrow') ||\n currentNode.querySelector('.arrow') ||\n currentNode.querySelector('[class*=\"arrow\"]');\n if (expandIcon && expandIcon instanceof HTMLElement) {\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.info('点击展开节点:', (_a = currentNode.textContent) === null || _a === void 0 ? void 0 : _a.substring(0, 50));\n expandIcon.click();\n }\n }\n // 等待一小段时间让DOM更新\n setTimeout(() => {\n // 查找所有未展开的子节点\n const childNodes = Array.from(currentNode.querySelectorAll('.entry:not(.open)'));\n if (childNodes.length > 0) {\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.info(`找到 ${childNodes.length} 个未展开的子节点`);\n // 递归展开每个子节点\n childNodes.forEach((child, index) => {\n setTimeout(() => {\n expandNodes(child);\n }, index * 50); // 每个节点间隔 50ms 展开,避免一次性点击太多\n });\n }\n }, 100);\n }\n // 开始递归展开\n expandNodes(targetNode);\n}\n/**\n * 创建自定义右键菜单\n */\nfunction createContextMenu() {\n // 检查菜单是否已经存在\n if (document.getElementById(\"ast-context-menu\")) {\n return;\n }\n // 创建菜单HTML\n const menuHtml = `\n <div id=\"ast-context-menu\" style=\"display:none; position:fixed; z-index:10000; background:#fff; border:1px solid #ccc; box-shadow:2px 2px 5px rgba(0,0,0,0.3); border-radius:4px; padding:5px 0;\">\n <div class=\"menu-item\" data-action=\"copy\">复制</div>\n </div>\n `;\n document.body.insertAdjacentHTML('beforeend', menuHtml);\n // 添加菜单样式\n const style = document.createElement('style');\n style.textContent = `\n #ast-context-menu .menu-item {\n padding: 8px 15px;\n cursor: pointer;\n font-size: 14px;\n min-width: 120px;\n }\n #ast-context-menu .menu-item:hover {\n background: #f0f0f0;\n }\n `;\n document.head.appendChild(style);\n // 点击其他地方隐藏菜单\n document.addEventListener('click', function (e) {\n const menu = document.getElementById('ast-context-menu');\n if (menu && menu.style.display === 'block') {\n menu.style.display = 'none';\n }\n });\n // 处理菜单项点击\n const menuElement = document.getElementById('ast-context-menu');\n if (menuElement) {\n menuElement.addEventListener('click', function (e) {\n var _a;\n e.stopPropagation();\n const target = e.target;\n const action = target.dataset.action;\n if (!action)\n return;\n const targetNode = this.targetNode;\n if (!targetNode)\n return;\n // 添加日志记录用户选择的菜单项\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('用户选择了菜单项:', action);\n switch (action) {\n case 'copy':\n // 复制纯文本内容\n const content = ((_a = targetNode.textContent) === null || _a === void 0 ? void 0 : _a.trim()) || '';\n _logger__WEBPACK_IMPORTED_MODULE_1__.logger.debug('复制内容:', content.substring(0, 50) + (content.length > 50 ? '...' : ''));\n (0,_clipboard_clipboard_service__WEBPACK_IMPORTED_MODULE_0__.copyToClipboard)(content);\n break;\n }\n this.style.display = 'none';\n });\n }\n}\n/**\n * 为ESC键添加事件监听器\n */\nfunction setupKeyboardShortcuts() {\n document.addEventListener('keydown', function (e) {\n if (e.key === 'Escape') {\n const menu = document.getElementById('ast-context-menu');\n if (menu && menu.style.display === 'block') {\n menu.style.display = 'none';\n }\n }\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"562.js","mappings":"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","sources":["webpack://ast-explorer-helper/./src/ui/context-menu.component.ts?afaa"],"sourcesContent":["/**\n * 右键菜单组件\n */\n\nimport { copyToClipboard } from '../clipboard/clipboard.service';\nimport { logger } from '../logger';\nimport { treeExpander } from './tree-expander.service';\n\n// 自定义类型，扩展HTMLElement\ninterface ContextMenuElement extends HTMLElement {\n    targetNode?: HTMLElement;\n}\n\n/**\n * 递归展开指定节点下的所有子节点\n * @param node 要展开的节点\n */\nexport function expandAllNodes(node: HTMLElement): void {\n    // 首先找到包含当前节点的可折叠节点\n    let targetNode = node;\n    while (targetNode && !targetNode.classList.contains('entry')) {\n        targetNode = targetNode.parentElement as HTMLElement;\n    }\n    \n    if (!targetNode) {\n        logger.info('未找到可折叠节点');\n        return;\n    }\n    \n    logger.info('找到可折叠节点:', {\n        tagName: targetNode.tagName,\n        className: targetNode.className,\n        textContent: targetNode.textContent?.substring(0, 50)\n    });\n    \n    // 递归展开节点的函数\n    function expandNodes(currentNode: HTMLElement) {\n        // 如果当前节点未展开，先展开它\n        if (!currentNode.classList.contains('open')) {\n            const expandIcon = currentNode.querySelector('.disclosure-arrow') || \n                             currentNode.querySelector('.arrow') || \n                             currentNode.querySelector('[class*=\"arrow\"]');\n            \n            if (expandIcon && expandIcon instanceof HTMLElement) {\n                logger.info('点击展开节点:', currentNode.textContent?.substring(0, 50));\n                expandIcon.click();\n            }\n        }\n        \n        // 等待一小段时间让DOM更新\n        setTimeout(() => {\n            // 查找所有未展开的子节点\n            const childNodes = Array.from(currentNode.querySelectorAll('.entry:not(.open)'));\n            \n            if (childNodes.length > 0) {\n                logger.info(`找到 ${childNodes.length} 个未展开的子节点`);\n                // 递归展开每个子节点\n                childNodes.forEach((child, index) => {\n                    setTimeout(() => {\n                        expandNodes(child as HTMLElement);\n                    }, index * 50); // 每个节点间隔 50ms 展开，避免一次性点击太多\n                });\n            }\n        }, 100);\n    }\n    \n    // 开始递归展开\n    expandNodes(targetNode);\n}\n\n/**\n * 创建自定义右键菜单\n */\nexport function createContextMenu(): void {\n    // 检查菜单是否已经存在\n    if (document.getElementById(\"ast-context-menu\")) {\n        return;\n    }\n\n    // 创建菜单HTML\n    const menuHtml = `\n        <div id=\"ast-context-menu\" style=\"display:none; position:fixed; z-index:10000; background:#fff; border:1px solid #ccc; box-shadow:2px 2px 5px rgba(0,0,0,0.3); border-radius:4px; padding:5px 0;\">\n            <div class=\"menu-item\" data-action=\"copy\">复制</div>\n        </div>\n    `;\n    document.body.insertAdjacentHTML('beforeend', menuHtml);\n    \n    // 添加菜单样式\n    const style = document.createElement('style');\n    style.textContent = `\n        #ast-context-menu .menu-item {\n            padding: 8px 15px;\n            cursor: pointer;\n            font-size: 14px;\n            min-width: 120px;\n        }\n        #ast-context-menu .menu-item:hover {\n            background: #f0f0f0;\n        }\n    `;\n    document.head.appendChild(style);\n\n    // 点击其他地方隐藏菜单\n    document.addEventListener('click', function(e: MouseEvent) {\n        const menu = document.getElementById('ast-context-menu') as ContextMenuElement | null;\n        if (menu && menu.style.display === 'block') {\n            menu.style.display = 'none';\n        }\n    });\n    \n    // 处理菜单项点击\n    const menuElement = document.getElementById('ast-context-menu') as ContextMenuElement;\n    if (menuElement) {\n        menuElement.addEventListener('click', function(this: ContextMenuElement, e: MouseEvent) {\n            e.stopPropagation();\n            \n            const target = e.target as HTMLElement;\n            const action = target.dataset.action;\n            if (!action) return;\n            \n            const targetNode = this.targetNode;\n            if (!targetNode) return;\n            \n            // 添加日志记录用户选择的菜单项\n            logger.debug('用户选择了菜单项:', action);\n            \n            switch(action) {\n                case 'copy':\n                    // 复制纯文本内容\n                    const content = targetNode.textContent?.trim() || '';\n                    logger.debug('复制内容:', content.substring(0, 50) + (content.length > 50 ? '...' : ''));\n                    copyToClipboard(content);\n                    break;\n            }\n            \n            this.style.display = 'none';\n        });\n    }\n}\n\n/**\n * 为ESC键添加事件监听器\n */\nexport function setupKeyboardShortcuts(): void {\n    document.addEventListener('keydown', function(e: KeyboardEvent) {\n        if (e.key === 'Escape') {\n            const menu = document.getElementById('ast-context-menu') as ContextMenuElement | null;\n            if (menu && menu.style.display === 'block') {\n                menu.style.display = 'none';\n            }\n        }\n    });\n} "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///562\n");
/***/ }),
/***/ 610:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _logger_service__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(361);\n/* harmony reexport (unknown) */ var __WEBPACK_REEXPORT_OBJECT__ = {};\n/* harmony reexport (unknown) */ for(const __WEBPACK_IMPORT_KEY__ in _logger_service__WEBPACK_IMPORTED_MODULE_0__) if(__WEBPACK_IMPORT_KEY__ !== \"default\") __WEBPACK_REEXPORT_OBJECT__[__WEBPACK_IMPORT_KEY__] = () => _logger_service__WEBPACK_IMPORTED_MODULE_0__[__WEBPACK_IMPORT_KEY__]\n/* harmony reexport (unknown) */ __webpack_require__.d(__webpack_exports__, __WEBPACK_REEXPORT_OBJECT__);\n/**\n * 日志模块入口\n */\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjEwLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0dBRUc7QUFFOEIiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL2xvZ2dlci9pbmRleC50cz9hNDg0Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICog5pel5b+X5qih5Z2X5YWl5Y+jXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9sb2dnZXIuc2VydmljZSc7ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///610\n");
/***/ }),
/***/ 629:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createSettingsUI: () => (/* reexport safe */ _settings_ui_component__WEBPACK_IMPORTED_MODULE_0__.createSettingsUI)\n/* harmony export */ });\n/* harmony import */ var _settings_ui_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(458);\n/**\n * 设置UI组件 - 入口文件\n */\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjI5LmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0dBRUc7QUFFd0QiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL3VpL3NldHRpbmdzLXVpL2luZGV4LnRzPzA3YzciXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDorr7nva5VSee7hOS7tiAtIOWFpeWPo+aWh+S7tlxuICovXG5cbmV4cG9ydCB7IGNyZWF0ZVNldHRpbmdzVUkgfSBmcm9tICcuL3NldHRpbmdzLXVpLmNvbXBvbmVudCc7ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///629\n");
/***/ }),
/***/ 635:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getSettingsTabStyles: () => (/* binding */ getSettingsTabStyles)\n/* harmony export */ });\n/**\n * 设置标签页组件 - 样式文件\n */\n/**\n * 获取设置标签页的样式\n * @returns 设置标签页的CSS样式\n */\nfunction getSettingsTabStyles() {\n return `\n #ast-settings-modal .setting-item {\n margin-bottom: 16px;\n padding-bottom: 16px;\n border-bottom: 1px solid #f0f0f0;\n }\n \n #ast-settings-modal .setting-item:last-child {\n border-bottom: none;\n margin-bottom: 0;\n padding-bottom: 0;\n }\n \n #ast-settings-modal .setting-item label {\n display: flex;\n align-items: center;\n font-weight: 500;\n cursor: pointer;\n color: #333;\n }\n \n #ast-settings-modal .setting-item input[type=\"checkbox\"] {\n margin-right: 10px;\n width: 18px;\n height: 18px;\n accent-color: #4a90e2;\n }\n \n #ast-settings-modal .description {\n margin: 6px 0 0 28px;\n color: #666;\n font-size: 14px;\n line-height: 1.4;\n }\n `;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjM1LmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7R0FFRztBQUVIOzs7R0FHRztBQUNJLFNBQVMsb0JBQW9CO0lBQ2hDLE9BQU87Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FrQ04sQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL3VpL3NldHRpbmdzLXRhYi9zZXR0aW5ncy10YWIuc3R5bGVzLnRzPzViNGEiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDorr7nva7moIfnrb7pobXnu4Tku7YgLSDmoLflvI/mlofku7ZcbiAqL1xuXG4vKipcbiAqIOiOt+WPluiuvue9ruagh+etvumhteeahOagt+W8j1xuICogQHJldHVybnMg6K6+572u5qCH562+6aG155qEQ1NT5qC35byPXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRTZXR0aW5nc1RhYlN0eWxlcygpOiBzdHJpbmcge1xuICAgIHJldHVybiBgXG4gICAgICAgICNhc3Qtc2V0dGluZ3MtbW9kYWwgLnNldHRpbmctaXRlbSB7XG4gICAgICAgICAgICBtYXJnaW4tYm90dG9tOiAxNnB4O1xuICAgICAgICAgICAgcGFkZGluZy1ib3R0b206IDE2cHg7XG4gICAgICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgI2YwZjBmMDtcbiAgICAgICAgfVxuICAgICAgICBcbiAgICAgICAgI2FzdC1zZXR0aW5ncy1tb2RhbCAuc2V0dGluZy1pdGVtOmxhc3QtY2hpbGQge1xuICAgICAgICAgICAgYm9yZGVyLWJvdHRvbTogbm9uZTtcbiAgICAgICAgICAgIG1hcmdpbi1ib3R0b206IDA7XG4gICAgICAgICAgICBwYWRkaW5nLWJvdHRvbTogMDtcbiAgICAgICAgfVxuICAgICAgICBcbiAgICAgICAgI2FzdC1zZXR0aW5ncy1tb2RhbCAuc2V0dGluZy1pdGVtIGxhYmVsIHtcbiAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgICAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgICAgICAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgICAgICAgIGNvbG9yOiAjMzMzO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICAjYXN0LXNldHRpbmdzLW1vZGFsIC5zZXR0aW5nLWl0ZW0gaW5wdXRbdHlwZT1cImNoZWNrYm94XCJdIHtcbiAgICAgICAgICAgIG1hcmdpbi1yaWdodDogMTBweDtcbiAgICAgICAgICAgIHdpZHRoOiAxOHB4O1xuICAgICAgICAgICAgaGVpZ2h0OiAxOHB4O1xuICAgICAgICAgICAgYWNjZW50LWNvbG9yOiAjNGE5MGUyO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICAjYXN0LXNldHRpbmdzLW1vZGFsIC5kZXNjcmlwdGlvbiB7XG4gICAgICAgICAgICBtYXJnaW46IDZweCAwIDAgMjhweDtcbiAgICAgICAgICAgIGNvbG9yOiAjNjY2O1xuICAgICAgICAgICAgZm9udC1zaXplOiAxNHB4O1xuICAgICAgICAgICAgbGluZS1oZWlnaHQ6IDEuNDtcbiAgICAgICAgfVxuICAgIGA7XG59ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///635\n");
/***/ }),
/***/ 661:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createTabsNavigation: () => (/* binding */ createTabsNavigation)\n/* harmony export */ });\n/**\n * 标签页组件 - 模板文件\n */\n/**\n * 创建标签页导航\n * @returns 标签页导航HTML\n */\nfunction createTabsNavigation() {\n return `\n <div class=\"modal-tabs\">\n <button class=\"tab-button active\" data-tab=\"settings\">设置</button>\n <button class=\"tab-button\" data-tab=\"about\">关于</button>\n </div>\n `;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjYxLmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7R0FFRztBQUVIOzs7R0FHRztBQUNJLFNBQVMsb0JBQW9CO0lBQ2hDLE9BQU87Ozs7O0tBS04sQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL3VpL3RhYnMvdGFicy50ZW1wbGF0ZS50cz9iMzg4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICog5qCH562+6aG157uE5Lu2IC0g5qih5p2/5paH5Lu2XG4gKi9cblxuLyoqXG4gKiDliJvlu7rmoIfnrb7pobXlr7zoiKpcbiAqIEByZXR1cm5zIOagh+etvumhteWvvOiIqkhUTUxcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRhYnNOYXZpZ2F0aW9uKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBcbiAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLXRhYnNcIj5cbiAgICAgICAgICAgIDxidXR0b24gY2xhc3M9XCJ0YWItYnV0dG9uIGFjdGl2ZVwiIGRhdGEtdGFiPVwic2V0dGluZ3NcIj7orr7nva48L2J1dHRvbj5cbiAgICAgICAgICAgIDxidXR0b24gY2xhc3M9XCJ0YWItYnV0dG9uXCIgZGF0YS10YWI9XCJhYm91dFwiPuWFs+S6jjwvYnV0dG9uPlxuICAgICAgICA8L2Rpdj5cbiAgICBgO1xufSAiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///661\n");
/***/ }),
/***/ 663:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DEFAULT_SETTINGS: () => (/* binding */ DEFAULT_SETTINGS),\n/* harmony export */ applyAllSettings: () => (/* binding */ applyAllSettings),\n/* harmony export */ applyNodeSelectionSetting: () => (/* binding */ applyNodeSelectionSetting),\n/* harmony export */ applyToolbarSetting: () => (/* binding */ applyToolbarSetting),\n/* harmony export */ loadSettings: () => (/* binding */ loadSettings),\n/* harmony export */ notifySettingsChanged: () => (/* binding */ notifySettingsChanged),\n/* harmony export */ saveSettings: () => (/* binding */ saveSettings)\n/* harmony export */ });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(610);\n/**\n * 设置管理服务\n */\n\n// 默认设置\nconst DEFAULT_SETTINGS = {\n hideToolbar: true\n};\n// 存储键名\nconst STORAGE_KEY = 'JSREI_ast_explorer_helper_settings';\n/**\n * 加载保存的设置\n * @returns 合并后的设置对象\n */\nfunction loadSettings() {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('开始加载设置...');\n try {\n const savedSettings = localStorage.getItem(STORAGE_KEY);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('从localStorage获取的原始设置数据:', savedSettings);\n if (savedSettings) {\n const parsedSettings = JSON.parse(savedSettings);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('从本地存储加载的设置对象:', parsedSettings);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('hideToolbar值为:', parsedSettings.hideToolbar);\n const mergedSettings = Object.assign(Object.assign({}, DEFAULT_SETTINGS), parsedSettings);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('合并后的最终设置:', mergedSettings);\n return mergedSettings;\n }\n }\n catch (error) {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.error('加载设置失败:', error);\n }\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('未找到有效的存储设置,使用默认设置:', DEFAULT_SETTINGS);\n return Object.assign({}, DEFAULT_SETTINGS);\n}\n/**\n * 保存设置到localStorage\n * @param settings 要保存的设置\n */\nfunction saveSettings(settings) {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('准备保存设置:', settings);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('hideToolbar值为:', settings.hideToolbar);\n try {\n const settingsJSON = JSON.stringify(settings);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('序列化后的设置:', settingsJSON);\n localStorage.setItem(STORAGE_KEY, settingsJSON);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('设置已保存到本地存储,键名:', STORAGE_KEY);\n }\n catch (error) {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.error('保存设置失败:', error);\n }\n}\n/**\n * 应用隐藏工具栏设置\n * @param hide 是否隐藏\n */\nfunction applyToolbarSetting(hide) {\n try {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('开始应用工具栏设置, 是否隐藏:', hide);\n // 查找 Toolbar 元素\n // 不再显示调试信息在界面上,仅保留控制台日志\n console.log('🔍 开始应用工具栏设置, 是否隐藏:', hide);\n const waitForToolbar = () => {\n // 首先按ID精确查找(区分大小写)\n const toolbar = document.getElementById('Toolbar');\n console.log('🔍 查找ID为Toolbar的元素结果:', toolbar);\n if (toolbar) {\n console.log('✅ 成功找到Toolbar元素');\n // 操作前记录状态\n console.log('🔍 操作前Toolbar状态:', {\n display: window.getComputedStyle(toolbar).display,\n visibility: window.getComputedStyle(toolbar).visibility\n });\n // 根据设置显示/隐藏\n if (hide) {\n toolbar.style.display = 'none';\n console.log('✅ 已设置Toolbar为隐藏');\n }\n else {\n toolbar.style.display = '';\n console.log('✅ 已设置Toolbar为显示');\n }\n // 操作后记录状态\n console.log('🔍 操作后Toolbar状态:', {\n display: window.getComputedStyle(toolbar).display,\n visibility: window.getComputedStyle(toolbar).visibility\n });\n return true;\n }\n // 查找任何包含\"toolbar\"的元素(不区分大小写)\n const toolbarElements = document.querySelectorAll('[id*=\"toolbar\" i], [class*=\"toolbar\" i]');\n console.log('🔍 查找包含toolbar的元素结果:', toolbarElements.length);\n if (toolbarElements.length > 0) {\n console.log('⚠️ 找到可能的工具栏元素,但ID不是Toolbar');\n Array.from(toolbarElements).forEach((el, index) => {\n const element = el;\n console.log(`🔍 可能的工具栏 ${index}:`, element.tagName, element.id, element.className);\n if (hide) {\n element.style.display = 'none';\n }\n else {\n element.style.display = '';\n }\n });\n return true;\n }\n return false;\n };\n // 如果Toolbar元素立即可用,则直接操作\n if (waitForToolbar()) {\n return;\n }\n // 如果Toolbar不立即可用,则等待一段时间后再次尝试\n console.log('⚠️ Toolbar元素不立即可用,将在200ms后重试');\n // 设置延迟定时器等待DOM可能的变化\n setTimeout(() => {\n console.log('🔍 开始第二次尝试查找Toolbar');\n if (!waitForToolbar()) {\n console.log('❌ 在第二次尝试后仍未找到Toolbar元素');\n // 最后一次尝试 - 查找页面顶部的任何固定元素\n const fixedTopElements = Array.from(document.querySelectorAll('*')).filter(el => {\n try {\n const style = window.getComputedStyle(el);\n return style.position === 'fixed' &&\n (style.top === '0px' || parseInt(style.top || '100') < 10) &&\n parseInt(style.height || '0') < 100;\n }\n catch (e) {\n return false;\n }\n });\n console.log('🔍 找到的顶部固定元素:', fixedTopElements.length);\n if (fixedTopElements.length > 0) {\n fixedTopElements.forEach((el, i) => {\n const element = el;\n console.log(`🔍 顶部固定元素 ${i}:`, element.tagName, element.id, element.className);\n if (hide) {\n element.style.display = 'none';\n }\n else {\n element.style.display = '';\n }\n });\n }\n }\n }, 200);\n }\n catch (error) {\n console.error('❌ 应用工具栏设置时出错:', error);\n }\n}\n/**\n * 启用节点选择功能 (现在始终启用)\n */\nfunction applyNodeSelectionSetting() {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('节点选择功能已内置,无需额外启用');\n}\n/**\n * 应用所有设置\n */\nfunction applyAllSettings(settings) {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('准备应用所有设置:', settings);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('hideToolbar设置值:', settings.hideToolbar);\n applyToolbarSetting(settings.hideToolbar);\n // 始终启用节点选择功能\n applyNodeSelectionSetting();\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('所有设置已应用完成');\n}\n/**\n * 发布设置变更事件\n */\nfunction notifySettingsChanged() {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('准备发布设置变更事件...');\n const settings = loadSettings();\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('当前加载的设置:', settings);\n const event = new CustomEvent('ast-explorer-helper-settings-changed', {\n detail: settings\n });\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('创建自定义事件, detail:', event.detail);\n document.dispatchEvent(event);\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.info('设置已变更,已发布通知事件', settings);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"663.js","mappings":"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","sources":["webpack://ast-explorer-helper/./src/settings/settings.service.ts?e4b0"],"sourcesContent":["/**\n * 设置管理服务\n */\n\nimport { logger } from '../logger';\n\n// 定义设置项及其默认值\nexport interface Settings {\n    hideToolbar: boolean;\n}\n\n// 默认设置\nexport const DEFAULT_SETTINGS: Settings = {\n    hideToolbar: true\n};\n\n// 存储键名\nconst STORAGE_KEY = 'JSREI_ast_explorer_helper_settings';\n\n/**\n * 加载保存的设置\n * @returns 合并后的设置对象\n */\nexport function loadSettings(): Settings {\n    logger.debug('开始加载设置...');\n    try {\n        const savedSettings = localStorage.getItem(STORAGE_KEY);\n        logger.debug('从localStorage获取的原始设置数据:', savedSettings);\n        \n        if (savedSettings) {\n            const parsedSettings = JSON.parse(savedSettings);\n            logger.debug('从本地存储加载的设置对象:', parsedSettings);\n            logger.debug('hideToolbar值为:', parsedSettings.hideToolbar);\n            \n            const mergedSettings = { ...DEFAULT_SETTINGS, ...parsedSettings };\n            logger.debug('合并后的最终设置:', mergedSettings);\n            return mergedSettings;\n        }\n    } catch (error) {\n        logger.error('加载设置失败:', error);\n    }\n    \n    logger.debug('未找到有效的存储设置，使用默认设置:', DEFAULT_SETTINGS);\n    return { ...DEFAULT_SETTINGS };\n}\n\n/**\n * 保存设置到localStorage\n * @param settings 要保存的设置\n */\nexport function saveSettings(settings: Settings): void {\n    logger.debug('准备保存设置:', settings);\n    logger.debug('hideToolbar值为:', settings.hideToolbar);\n    \n    try {\n        const settingsJSON = JSON.stringify(settings);\n        logger.debug('序列化后的设置:', settingsJSON);\n        \n        localStorage.setItem(STORAGE_KEY, settingsJSON);\n        logger.debug('设置已保存到本地存储，键名:', STORAGE_KEY);\n    } catch (error) {\n        logger.error('保存设置失败:', error);\n    }\n}\n\n/**\n * 应用隐藏工具栏设置\n * @param hide 是否隐藏\n */\nexport function applyToolbarSetting(hide: boolean): void {\n    try {\n        logger.debug('开始应用工具栏设置, 是否隐藏:', hide);\n        \n        // 查找 Toolbar 元素\n        // 不再显示调试信息在界面上，仅保留控制台日志\n        console.log('🔍 开始应用工具栏设置, 是否隐藏:', hide);\n        \n        const waitForToolbar = () => {\n            // 首先按ID精确查找（区分大小写）\n            const toolbar = document.getElementById('Toolbar');\n            console.log('🔍 查找ID为Toolbar的元素结果:', toolbar);\n            \n            if (toolbar) {\n                console.log('✅ 成功找到Toolbar元素');\n                \n                // 操作前记录状态\n                console.log('🔍 操作前Toolbar状态:', {\n                    display: window.getComputedStyle(toolbar).display,\n                    visibility: window.getComputedStyle(toolbar).visibility\n                });\n                \n                // 根据设置显示/隐藏\n                if (hide) {\n                    toolbar.style.display = 'none';\n                    console.log('✅ 已设置Toolbar为隐藏');\n                } else {\n                    toolbar.style.display = '';\n                    console.log('✅ 已设置Toolbar为显示');\n                }\n                \n                // 操作后记录状态\n                console.log('🔍 操作后Toolbar状态:', {\n                    display: window.getComputedStyle(toolbar).display,\n                    visibility: window.getComputedStyle(toolbar).visibility\n                });\n                \n                return true;\n            }\n            \n            // 查找任何包含\"toolbar\"的元素（不区分大小写）\n            const toolbarElements = document.querySelectorAll('[id*=\"toolbar\" i], [class*=\"toolbar\" i]');\n            console.log('🔍 查找包含toolbar的元素结果:', toolbarElements.length);\n            \n            if (toolbarElements.length > 0) {\n                console.log('⚠️ 找到可能的工具栏元素，但ID不是Toolbar');\n                \n                Array.from(toolbarElements).forEach((el, index) => {\n                    const element = el as HTMLElement;\n                    console.log(`🔍 可能的工具栏 ${index}:`, element.tagName, element.id, element.className);\n                    \n                    if (hide) {\n                        element.style.display = 'none';\n                    } else {\n                        element.style.display = '';\n                    }\n                });\n                \n                return true;\n            }\n            \n            return false;\n        };\n        \n        // 如果Toolbar元素立即可用，则直接操作\n        if (waitForToolbar()) {\n            return;\n        }\n        \n        // 如果Toolbar不立即可用，则等待一段时间后再次尝试\n        console.log('⚠️ Toolbar元素不立即可用，将在200ms后重试');\n        \n        // 设置延迟定时器等待DOM可能的变化\n        setTimeout(() => {\n            console.log('🔍 开始第二次尝试查找Toolbar');\n            \n            if (!waitForToolbar()) {\n                console.log('❌ 在第二次尝试后仍未找到Toolbar元素');\n                \n                // 最后一次尝试 - 查找页面顶部的任何固定元素\n                const fixedTopElements = Array.from(document.querySelectorAll('*')).filter(el => {\n                    try {\n                        const style = window.getComputedStyle(el);\n                        return style.position === 'fixed' && \n                               (style.top === '0px' || parseInt(style.top || '100') < 10) &&\n                               parseInt(style.height || '0') < 100;\n                    } catch (e) {\n                        return false;\n                    }\n                });\n                \n                console.log('🔍 找到的顶部固定元素:', fixedTopElements.length);\n                \n                if (fixedTopElements.length > 0) {\n                    fixedTopElements.forEach((el, i) => {\n                        const element = el as HTMLElement;\n                        console.log(`🔍 顶部固定元素 ${i}:`, element.tagName, element.id, element.className);\n                        \n                        if (hide) {\n                            element.style.display = 'none';\n                        } else {\n                            element.style.display = '';\n                        }\n                    });\n                }\n            }\n        }, 200);\n        \n    } catch (error) {\n        console.error('❌ 应用工具栏设置时出错:', error);\n    }\n}\n\n/**\n * 启用节点选择功能 (现在始终启用)\n */\nexport function applyNodeSelectionSetting(): void {\n    logger.debug('节点选择功能已内置，无需额外启用');\n}\n\n/**\n * 应用所有设置\n */\nexport function applyAllSettings(settings: Settings): void {\n    logger.debug('准备应用所有设置:', settings);\n    logger.debug('hideToolbar设置值:', settings.hideToolbar);\n    \n    applyToolbarSetting(settings.hideToolbar);\n    // 始终启用节点选择功能\n    applyNodeSelectionSetting();\n    \n    logger.debug('所有设置已应用完成');\n}\n\n/**\n * 发布设置变更事件\n */\nexport function notifySettingsChanged(): void {\n    logger.debug('准备发布设置变更事件...');\n    \n    const settings = loadSettings();\n    logger.debug('当前加载的设置:', settings);\n    \n    const event = new CustomEvent('ast-explorer-helper-settings-changed', {\n        detail: settings\n    });\n    \n    logger.debug('创建自定义事件, detail:', event.detail);\n    document.dispatchEvent(event);\n    \n    logger.info('设置已变更，已发布通知事件', settings);\n} "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///663\n");
/***/ }),
/***/ 707:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createAboutTabContent: () => (/* binding */ createAboutTabContent),\n/* harmony export */ getRepoStatsFromCache: () => (/* binding */ getRepoStatsFromCache)\n/* harmony export */ });\n/**\n * 关于标签页组件 - 模板文件\n */\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n/**\n * 创建关于标签页内容\n * @returns 关于标签页的HTML内容\n */\nfunction createAboutTabContent() {\n // 获取缓存的仓库数据\n const repoStats = getRepoStatsFromCache();\n return `\n <div class=\"tab-content\" id=\"about-tab\">\n <div class=\"about-content\">\n <!-- 仓库信息部分 - 增强卡片版 -->\n <section class=\"repo-info-section\">\n <div class=\"repo-card\">\n <div class=\"repo-header\">\n <div class=\"repo-logo\">\n <svg viewBox=\"0 0 24 24\" width=\"24\" height=\"24\">\n <path fill=\"currentColor\" d=\"M20.59 12l-3.3-3.3a1 1 0 1 1 1.42-1.4l4 4a1 1 0 0 1 0 1.4l-4 4a1 1 0 0 1-1.42-1.4l3.3-3.3zM3.4 12l3.3 3.3a1 1 0 0 1-1.42 1.4l-4-4a1 1 0 0 1 0-1.4l4-4a1 1 0 0 1 1.42 1.4L3.4 12z\"/>\n </svg>\n </div>\n \n <h4>AST Explorer 助手</h4>\n <span class=\"repo-badge\">增强工具</span>\n <p>一款提升AST Explorer使用体验的增强工具</p>\n </div>\n \n <div class=\"repo-stats\">\n <div class=\"repo-link-wrapper\">\n <a href=\"https://github.com/JSREI/ast-explorer-helper\" target=\"_blank\" class=\"repo-link\">\n <svg class=\"github-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n <path fill-rule=\"evenodd\" d=\"M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0016 8c0-4.42-3.58-8-8-8z\"></path>\n </svg>\n GitHub 仓库\n </a>\n <a href=\"https://github.com/JSREI/ast-explorer-helper/stargazers\" target=\"_blank\" class=\"star-button\">\n <svg class=\"star-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n <path fill-rule=\"evenodd\" d=\"M8 .25a.75.75 0 01.673.418l1.882 3.815 4.21.612a.75.75 0 01.416 1.279l-3.046 2.97.719 4.192a.75.75 0 01-1.088.791L8 12.347l-3.766 1.98a.75.75 0 01-1.088-.79l.72-4.194L.818 6.374a.75.75 0 01.416-1.28l4.21-.611L7.327.668A.75.75 0 018 .25z\"></path>\n </svg>\n 支持一下\n </a>\n </div>\n \n <div class=\"github-stats\">\n <a href=\"https://github.com/JSREI/ast-explorer-helper/stargazers\" target=\"_blank\" class=\"stat-item star-stat\" title=\"GitHub Star数 - 点击查看详情\">\n <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n <path fill-rule=\"evenodd\" d=\"M8 .25a.75.75 0 01.673.418l1.882 3.815 4.21.612a.75.75 0 01.416 1.279l-3.046 2.97.719 4.192a.75.75 0 01-1.088.791L8 12.347l-3.766 1.98a.75.75 0 01-1.088-.79l.72-4.194L.818 6.374a.75.75 0 01.416-1.28l4.21-.611L7.327.668A.75.75 0 018 .25z\"></path>\n </svg>\n <span>${repoStats.stars || '暂未获取'}</span>\n <span class=\"stat-label\">Stars</span>\n </a>\n <a href=\"https://github.com/JSREI/ast-explorer-helper/forks\" target=\"_blank\" class=\"stat-item fork-stat\" title=\"GitHub Fork数 - 点击查看详情\">\n <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n <path fill-rule=\"evenodd\" d=\"M5 3.25a.75.75 0 11-1.5 0 .75.75 0 011.5 0zm0 2.122a2.25 2.25 0 10-1.5 0v.878A2.25 2.25 0 005.75 8.5h1.5v2.128a2.251 2.251 0 101.5 0V8.5h1.5a2.25 2.25 0 002.25-2.25v-.878a2.25 2.25 0 10-1.5 0v.878a.75.75 0 01-.75.75h-4.5A.75.75 0 015 6.25v-.878zm3.75 7.378a.75.75 0 11-1.5 0 .75.75 0 011.5 0zm3-8.75a.75.75 0 100-1.5.75.75 0 000 1.5z\"></path>\n </svg>\n <span>${repoStats.forks || '暂未获取'}</span>\n <span class=\"stat-label\">Forks</span>\n </a>\n <a href=\"https://github.com/JSREI/ast-explorer-helper/issues\" target=\"_blank\" class=\"stat-item issue-stat\" title=\"GitHub Issue数 - 点击查看详情\">\n <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n <path fill-rule=\"evenodd\" d=\"M8 1.5a6.5 6.5 0 100 13 6.5 6.5 0 000-13zM0 8a8 8 0 1116 0A8 8 0 010 8zm9 3a1 1 0 11-2 0 1 1 0 012 0zm-.25-6.25a.75.75 0 00-1.5 0v3.5a.75.75 0 001.5 0v-3.5z\"></path>\n </svg>\n <span>${repoStats.issues || '暂未获取'}</span>\n <span class=\"stat-label\">Issues</span>\n </a>\n <a href=\"https://github.com/JSREI/ast-explorer-helper/commits/main\" target=\"_blank\" class=\"stat-item update-stat\" title=\"最近更新时间 - 点击查看提交历史\">\n <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n <path fill-rule=\"evenodd\" d=\"M1.643 3.143L.427 1.927A.25.25 0 000 2.104V5.75c0 .138.112.25.25.25h3.646a.25.25 0 00.177-.427L2.715 4.215a6.5 6.5 0 11-1.18 4.458.75.75 0 10-1.493.154 8.001 8.001 0 101.6-5.684zM7.75 4a.75.75 0 01.75.75v2.992l2.028.812a.75.75 0 01-.557 1.392l-2.5-1A.75.75 0 017 8.25v-3.5A.75.75 0 017.75 4z\"></path>\n </svg>\n <span>${repoStats.updatedAt || '暂未获取'}</span>\n <span class=\"stat-label\">更新于</span>\n </a>\n </div>\n </div>\n </div>\n </section>\n \n <!-- 组织信息部分 - 增强版 -->\n <section class=\"org-info-section\">\n <div class=\"org-card\">\n <div class=\"org-header\">\n <div class=\"org-logo\">\n <img src=\"https://avatars.githubusercontent.com/u/118125754?s=200&v=4\" alt=\"JSREI组织Logo\" class=\"jsrei-logo\" width=\"64\" height=\"64\">\n <span class=\"org-badge\">开源组织</span>\n </div>\n <h4 class=\"section-title\">关于JSREI</h4>\n </div>\n \n <div class=\"org-content\">\n <div class=\"org-description\">\n <p>JSREI (JavaScript Reverse Engineering Initiative) 是一个专注于JavaScript逆向工程的开源组织,致力于提供优质的逆向工程工具和教程,帮助开发者更好地理解和分析JavaScript代码。</p>\n </div>\n \n <div class=\"org-features\">\n <div class=\"feature-item\">\n <div class=\"feature-icon\">\n <svg viewBox=\"0 0 24 24\" width=\"20\" height=\"20\">\n <path fill=\"currentColor\" d=\"M12 2L1 21h22L12 2zm0 4l7.53 13H4.47L12 6zm-1 3v4h2V9h-2zm0 6v2h2v-2h-2z\"/>\n </svg>\n </div>\n <div class=\"feature-text\">逆向工具</div>\n </div>\n \n <div class=\"feature-item\">\n <div class=\"feature-icon\">\n <svg viewBox=\"0 0 24 24\" width=\"20\" height=\"20\">\n <path fill=\"currentColor\" d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-5 14H7v-2h7v2zm3-4H7v-2h10v2zm0-4H7V7h10v2z\"/>\n </svg>\n </div>\n <div class=\"feature-text\">技术教程</div>\n </div>\n \n <div class=\"feature-item\">\n <div class=\"feature-icon\">\n <svg viewBox=\"0 0 24 24\" width=\"20\" height=\"20\">\n <path fill=\"currentColor\" d=\"M9.4 16.6L4.8 12l4.6-4.6L8 6l-6 6 6 6 1.4-1.4zm5.2 0l4.6-4.6-4.6-4.6L16 6l6 6-6 6-1.4-1.4z\"/>\n </svg>\n </div>\n <div class=\"feature-text\">代码分析</div>\n </div>\n </div>\n </div>\n \n <div class=\"org-actions\">\n <a href=\"https://github.com/JSREI\" target=\"_blank\" class=\"org-action-button fixed-button\">\n <span class=\"button-icon\">\n <svg class=\"github-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n <path fill-rule=\"evenodd\" d=\"M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0016 8c0-4.42-3.58-8-8-8z\"></path>\n </svg>\n </span>\n <span class=\"button-text\">查看更多JSREI项目</span>\n </a>\n </div>\n </div>\n </section>\n \n <!-- 交流群信息部分 - 卡片式设计 -->\n <section class=\"community-section\">\n <div class=\"community-card\">\n <div class=\"community-header\">\n <div class=\"community-icon\">\n <svg viewBox=\"0 0 24 24\" width=\"24\" height=\"24\">\n <path fill=\"currentColor\" d=\"M12 2c1.35 0 2.6.45 3.6 1.2L12 7.8 8.4 3.2C9.4 2.45 10.65 2 12 2m9 15c0 1.66-1.34 3-3 3H6c-1.66 0-3-1.34-3-3v-4.85c0-.3.15-.57.4-.74L12 5l8.6 6.41c.25.17.4.44.4.74V17z\"/>\n </svg>\n </div>\n \n <h4 class=\"section-title\">逆向技术交流群</h4>\n <p>加入我们的技术交流社区,分享经验与知识</p>\n </div>\n \n <div class=\"qr-code-container\">\n <!-- 微信部分 -->\n <div class=\"qr-section\">\n <div class=\"qr-section-title wechat\">\n <svg viewBox=\"0 0 24 24\" width=\"18\" height=\"18\">\n <path fill=\"currentColor\" d=\"M8.2 13.3c-.5 0-.9-.4-.9-.9s.4-.9.9-.9.9.4.9.9-.4.9-.9.9m4.9 0c-.5 0-.9-.4-.9-.9s.4-.9.9-.9.9.4.9.9-.4.9-.9.9m3-6.5c-3.6 0-6.5 2.4-6.5 5.4 0 .5.1 1 .2 1.5-2.3-.1-4.6-1.2-6-2.9a1.61 1.61 0 0 0-.2.8c0 1 .9 1.9 2.2 2.4-.8 0-1.5-.1-2.1-.4 0 1.4 2 2.5 3.6 2.8-.4.1-.9.2-1.4.2-.3 0-.5 0-.8-.1.4 1.1 1.4 1.9 2.6 2-1 .7-2.2 1.1-3.6 1.1H3c1.3.8 2.8 1.3 4.4 1.3 5.3 0 8.2-4.1 8.2-7.6v-.3c.6-.4 1-1 1.4-1.6-.5.2-1 .4-1.6.5.6-.4 1-1 1.2-1.7-.6.3-1.2.6-1.9.7\"/></path>\n </svg>\n 微信交流群\n </div>\n \n <div class=\"qr-item\">\n <p>扫码加入逆向技术微信交流群:</p>\n <div class=\"qr-code\">\n <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/image-20241016230653669.png\" alt=\"逆向技术微信交流群二维码\">\n </div>\n </div>\n \n <div class=\"qr-item\">\n <p>如群二维码过期,可以加我个人微信,发送【逆向群】拉你进群:</p>\n <div class=\"qr-code\">\n <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/image-20231030132026541-7614065.png\" alt=\"个人微信二维码\">\n </div>\n </div>\n </div>\n \n <!-- QQ群部分 -->\n <div class=\"qr-section\">\n <div class=\"qr-section-title qq\">\n <svg viewBox=\"0 0 24 24\" width=\"18\" height=\"18\">\n <path fill=\"currentColor\" d=\"M12.003 2c-5.514 0-9.998 4.484-9.998 9.997 0 5.515 4.484 10 9.998 10 5.515 0 10-4.485 10-10 0-5.513-4.485-9.997-10-9.997zm0 1.5c4.69 0 8.5 3.807 8.5 8.497 0 4.691-3.81 8.5-8.5 8.5-4.689 0-8.498-3.809-8.498-8.5 0-4.69 3.809-8.497 8.498-8.497zm-0.747 4.562v-0.002c-0.325 0.038-0.913 0.197-1.707 1.063-0.895 0.978-0.845 2.032-0.845 2.032s-1.289 0.184-1.677 1.904c-0.388 1.721-0.123 2.094-0.123 2.094s-0.214 1.577 0.735 0.587c0.303-0.316 0.499-1.153 0.499-1.153l0.789 1.781c-0.881 1.86-0.789 2.299-0.789 2.299s-0.123 0.883 0.643 0.205c0.766-0.678 1.219-1.977 1.219-1.977l0.214 0.92c-0.123 1.565 0.152 1.721 0.152 1.721s0.245 0.431 0.583-0.147c0.338-0.577 0.245-1.351 0.245-1.351l0.797-0.059c0.919 1.644 1.676 0.92 1.676 0.92s0.367-0.516-0.275-1.433l0.613-0.489c1.188 0.82 1.92-0.059 1.92-0.059s0.275-0.723-1.188-1.062l0.183-0.723c1.554-0.147 1.432-1.062 1.432-1.062s-0.061-0.75-1.432-0.75l-0.245-0.791c1.31-0.489 1.127-1.202 1.127-1.202s-0.214-0.606-1.188-0.518l-0.735-1.202c0.919-0.577 0.674-1.202 0.674-1.202s-0.367-0.518-1.188 0.059l-1.188-1.202c0.613-0.82 0.214-1.202 0.214-1.202s-0.521-0.321-1.127 0.518l-0.919-0.791c0.306-0.82-0.152-1.062-0.152-1.062s-0.583-0.205-0.766 0.791l-0.919-0.518c0.214-0.978-0.367-1.062-0.367-1.062z\"/>\n </svg>\n QQ交流群\n </div>\n \n <div class=\"qr-item\">\n <p><a href=\"https://qm.qq.com/q/YfdB3w3OEY\" target=\"_blank\" class=\"qq-link\">\n <svg viewBox=\"0 0 24 24\" width=\"14\" height=\"14\">\n <path fill=\"currentColor\" d=\"M14 3v2h3.59l-9.83 9.83-1.41-1.41L16.17 3H14V1h6v6h-2V3.41l-9.83 9.83 1.41 1.41L20.41 4H24v2h2V0h-6v2h-6z\"/>\n </svg>\n 点此直接加入\n </a> 或扫码加入QQ交流群:</p>\n <div class=\"qr-code\">\n <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/jsrei-qq-group.jpg\" alt=\"QQ交流群二维码\">\n </div>\n </div>\n </div>\n \n <!-- Telegram部分 -->\n <div class=\"qr-section\">\n <div class=\"qr-section-title telegram\">\n <svg viewBox=\"0 0 24 24\" width=\"18\" height=\"18\">\n <path fill=\"currentColor\" d=\"M9.78 18.65l.28-4.23 7.68-6.92c.34-.31-.07-.46-.52-.19L7.74 13.3 3.64 12c-.88-.25-.89-.86.2-1.3l15.97-6.16c.73-.33 1.43.18 1.15 1.3l-2.72 12.81c-.19.91-.74 1.13-1.5.71L12.6 16.3l-1.99 1.93c-.23.23-.42.42-.83.42z\"></path>\n </svg>\n Telegram 交流群\n </div>\n \n <div class=\"qr-item\">\n <p><a href=\"https://t.me/jsreijsrei\" target=\"_blank\" class=\"tg-link\">\n <svg viewBox=\"0 0 24 24\" width=\"14\" height=\"14\">\n <path fill=\"currentColor\" d=\"M14 3v2h3.59l-9.83 9.83-1.41-1.41L16.17 3H14V1h6v6h-2V3.41l-9.83 9.83 1.41 1.41L20.41 4H24v2h2V0h-6v2h-6z\"/>\n </svg>\n 点此直接加入\n </a> 或扫码加入 TG 交流群:</p>\n <div class=\"qr-code\">\n <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/image-20241016231143315.png\" alt=\"TG交流群二维码\">\n </div>\n </div>\n </div>\n </div>\n </div>\n </section>\n </div>\n </div>\n `;\n}\n/**\n * 获取仓库统计信息的缓存数据\n * 如果缓存不存在或已过期,则返回空数据并触发异步更新\n */\nfunction getRepoStatsFromCache() {\n const CACHE_KEY = 'JSREI_repo_stats';\n const CACHE_EXPIRY = 60 * 60 * 1000; // 1小时缓存\n // 空数据对象,表示未获取到\n const emptyStats = {\n stars: null,\n forks: null,\n issues: null,\n updatedAt: null\n };\n // 尝试从localStorage获取缓存数据\n const cachedData = localStorage.getItem(CACHE_KEY);\n let repoStats = Object.assign({}, emptyStats);\n if (cachedData) {\n try {\n const parsedData = JSON.parse(cachedData);\n const now = new Date().getTime();\n // 检查缓存是否有效\n if (parsedData && parsedData.timestamp && (now - parsedData.timestamp) < CACHE_EXPIRY) {\n repoStats = parsedData.data;\n return repoStats;\n }\n }\n catch (error) {\n console.error('解析仓库统计缓存数据失败:', error);\n return emptyStats; // 返回空数据\n }\n }\n // 如果没有有效缓存,异步获取新数据\n try {\n fetchRepoStats().then(data => {\n if (data) {\n // 缓存新数据\n localStorage.setItem(CACHE_KEY, JSON.stringify({\n timestamp: new Date().getTime(),\n data: data\n }));\n // 如果页面已加载,更新DOM\n updateRepoStatsInDOM(data);\n }\n else {\n // API返回空数据,更新DOM显示未获取状态\n updateRepoStatsInDOM(emptyStats);\n }\n }).catch(err => {\n console.error('获取仓库统计数据失败:', err);\n // API调用出错,更新DOM显示未获取状态\n updateRepoStatsInDOM(emptyStats);\n });\n }\n catch (error) {\n console.error('启动仓库统计更新失败:', error);\n return emptyStats; // 返回空数据\n }\n return repoStats;\n}\n/**\n * 从GitHub API获取仓库统计数据\n */\nfunction fetchRepoStats() {\n return __awaiter(this, void 0, void 0, function* () {\n try {\n // 给API请求添加超时限制\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), 5000); // 5秒超时\n const response = yield fetch('https://api.github.com/repos/JSREI/ast-explorer-helper', {\n signal: controller.signal,\n headers: {\n 'Accept': 'application/vnd.github.v3+json'\n }\n });\n clearTimeout(timeoutId);\n if (!response.ok) {\n throw new Error(`GitHub API错误: ${response.status}`);\n }\n const data = yield response.json();\n // 格式化日期\n const updatedDate = new Date(data.updated_at);\n const formattedDate = `${updatedDate.getFullYear()}-${String(updatedDate.getMonth() + 1).padStart(2, '0')}-${String(updatedDate.getDate()).padStart(2, '0')}`;\n return {\n stars: data.stargazers_count,\n forks: data.forks_count,\n issues: data.open_issues_count,\n updatedAt: formattedDate\n };\n }\n catch (error) {\n console.error('获取仓库统计数据失败:', error);\n // 返回null表示获取失败\n return null;\n }\n });\n}\n/**\n * 更新DOM中的仓库统计数据\n */\nfunction updateRepoStatsInDOM(data) {\n var _a, _b, _c;\n try {\n const aboutTab = document.getElementById('about-tab');\n if (!aboutTab)\n return;\n // 更新各个统计数据\n const statItems = aboutTab.querySelectorAll('.github-stats .stat-item span');\n if (statItems.length >= 4) {\n statItems[0].textContent = ((_a = data.stars) === null || _a === void 0 ? void 0 : _a.toString()) || '暂未获取';\n statItems[2].textContent = ((_b = data.forks) === null || _b === void 0 ? void 0 : _b.toString()) || '暂未获取';\n statItems[4].textContent = ((_c = data.issues) === null || _c === void 0 ? void 0 : _c.toString()) || '暂未获取';\n statItems[6].textContent = data.updatedAt || '暂未获取';\n }\n }\n catch (error) {\n console.error('更新DOM中的仓库统计数据失败:', error);\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"707.js","mappings":";;;;;AAAA;;GAEG;;;;;;;;;;AAEH;;;GAGG;AACI,SAAS,qBAAqB;IACjC,YAAY;IACZ,MAAM,SAAS,GAAG,qBAAqB,EAAE,CAAC;IAE1C,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAuCiC,SAAS,CAAC,KAAK,IAAI,MAAM;;;;;;;4CAOzB,SAAS,CAAC,KAAK,IAAI,MAAM;;;;;;;4CAOzB,SAAS,CAAC,MAAM,IAAI,MAAM;;;;;;;4CAO1B,SAAS,CAAC,SAAS,IAAI,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA0JpE,CAAC;AACN,CAAC;AAED;;;GAGG;AACI,SAAS,qBAAqB;IACjC,MAAM,SAAS,GAAG,kBAAkB,CAAC;IACrC,MAAM,YAAY,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,QAAQ;IAE7C,eAAe;IACf,MAAM,UAAU,GAAG;QACf,KAAK,EAAE,IAAI;QACX,KAAK,EAAE,IAAI;QACX,MAAM,EAAE,IAAI;QACZ,SAAS,EAAE,IAAI;KAClB,CAAC;IAEF,wBAAwB;IACxB,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACnD,IAAI,SAAS,qBAAQ,UAAU,CAAE,CAAC;IAElC,IAAI,UAAU,EAAE,CAAC;QACb,IAAI,CAAC;YACD,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YAC1C,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;YAEjC,WAAW;YACX,IAAI,UAAU,IAAI,UAAU,CAAC,SAAS,IAAI,CAAC,GAAG,GAAG,UAAU,CAAC,SAAS,CAAC,GAAG,YAAY,EAAE,CAAC;gBACpF,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC;gBAC5B,OAAO,SAAS,CAAC;YACrB,CAAC;QACL,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;YACtC,OAAO,UAAU,CAAC,CAAC,QAAQ;QAC/B,CAAC;IACL,CAAC;IAED,mBAAmB;IACnB,IAAI,CAAC;QACD,cAAc,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;YACzB,IAAI,IAAI,EAAE,CAAC;gBACP,QAAQ;gBACR,YAAY,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC;oBAC3C,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE;oBAC/B,IAAI,EAAE,IAAI;iBACb,CAAC,CAAC,CAAC;gBAEJ,gBAAgB;gBAChB,oBAAoB,CAAC,IAAI,CAAC,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACJ,wBAAwB;gBACxB,oBAAoB,CAAC,UAAU,CAAC,CAAC;YACrC,CAAC;QACL,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;YACX,OAAO,CAAC,KAAK,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;YAClC,uBAAuB;YACvB,oBAAoB,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;QACpC,OAAO,UAAU,CAAC,CAAC,QAAQ;IAC/B,CAAC;IAED,OAAO,SAAS,CAAC;AACrB,CAAC;AAED;;GAEG;AACH,SAAe,cAAc;;QACzB,IAAI,CAAC;YACD,eAAe;YACf,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAC;YACzC,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO;YAErE,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,wDAAwD,EAAE;gBACnF,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,OAAO,EAAE;oBACL,QAAQ,EAAE,gCAAgC;iBAC7C;aACJ,CAAC,CAAC;YAEH,YAAY,CAAC,SAAS,CAAC,CAAC;YAExB,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;gBACf,MAAM,IAAI,KAAK,CAAC,iBAAiB,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;YACxD,CAAC;YAED,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YAEnC,QAAQ;YACR,MAAM,WAAW,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC9C,MAAM,aAAa,GAAG,GAAG,WAAW,CAAC,WAAW,EAAE,IAAI,MAAM,CAAC,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;YAE9J,OAAO;gBACH,KAAK,EAAE,IAAI,CAAC,gBAAgB;gBAC5B,KAAK,EAAE,IAAI,CAAC,WAAW;gBACvB,MAAM,EAAE,IAAI,CAAC,iBAAiB;gBAC9B,SAAS,EAAE,aAAa;aAC3B,CAAC;QACN,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;YACpC,eAAe;YACf,OAAO,IAAI,CAAC;QAChB,CAAC;IACL,CAAC;CAAA;AAED;;GAEG;AACH,SAAS,oBAAoB,CAAC,IAAS;;IACnC,IAAI,CAAC;QACD,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;QACtD,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,WAAW;QACX,MAAM,SAAS,GAAG,QAAQ,CAAC,gBAAgB,CAAC,+BAA+B,CAAC,CAAC;QAC7E,IAAI,SAAS,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YACxB,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,WAAI,CAAC,KAAK,0CAAE,QAAQ,EAAE,KAAI,MAAM,CAAC;YAC5D,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,WAAI,CAAC,KAAK,0CAAE,QAAQ,EAAE,KAAI,MAAM,CAAC;YAC5D,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,WAAI,CAAC,MAAM,0CAAE,QAAQ,EAAE,KAAI,MAAM,CAAC;YAC7D,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,IAAI,MAAM,CAAC;QACxD,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC,CAAC;IAC7C,CAAC;AACL,CAAC","sources":["webpack://ast-explorer-helper/./src/ui/about-tab/about-tab.template.ts?058c"],"sourcesContent":["/**\n * 关于标签页组件 - 模板文件\n */\n\n/**\n * 创建关于标签页内容\n * @returns 关于标签页的HTML内容\n */\nexport function createAboutTabContent(): string {\n    // 获取缓存的仓库数据\n    const repoStats = getRepoStatsFromCache();\n    \n    return `\n        <div class=\"tab-content\" id=\"about-tab\">\n            <div class=\"about-content\">\n                <!-- 仓库信息部分 - 增强卡片版 -->\n                <section class=\"repo-info-section\">\n                    <div class=\"repo-card\">\n                        <div class=\"repo-header\">\n                            <div class=\"repo-logo\">\n                                <svg viewBox=\"0 0 24 24\" width=\"24\" height=\"24\">\n                                    <path fill=\"currentColor\" d=\"M20.59 12l-3.3-3.3a1 1 0 1 1 1.42-1.4l4 4a1 1 0 0 1 0 1.4l-4 4a1 1 0 0 1-1.42-1.4l3.3-3.3zM3.4 12l3.3 3.3a1 1 0 0 1-1.42 1.4l-4-4a1 1 0 0 1 0-1.4l4-4a1 1 0 0 1 1.42 1.4L3.4 12z\"/>\n                                </svg>\n                            </div>\n                            \n                            <h4>AST Explorer 助手</h4>\n                            <span class=\"repo-badge\">增强工具</span>\n                            <p>一款提升AST Explorer使用体验的增强工具</p>\n                        </div>\n                        \n                        <div class=\"repo-stats\">\n                            <div class=\"repo-link-wrapper\">\n                                <a href=\"https://github.com/JSREI/ast-explorer-helper\" target=\"_blank\" class=\"repo-link\">\n                                    <svg class=\"github-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n                                        <path fill-rule=\"evenodd\" d=\"M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0016 8c0-4.42-3.58-8-8-8z\"></path>\n                                    </svg>\n                                    GitHub 仓库\n                                </a>\n                                <a href=\"https://github.com/JSREI/ast-explorer-helper/stargazers\" target=\"_blank\" class=\"star-button\">\n                                    <svg class=\"star-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n                                        <path fill-rule=\"evenodd\" d=\"M8 .25a.75.75 0 01.673.418l1.882 3.815 4.21.612a.75.75 0 01.416 1.279l-3.046 2.97.719 4.192a.75.75 0 01-1.088.791L8 12.347l-3.766 1.98a.75.75 0 01-1.088-.79l.72-4.194L.818 6.374a.75.75 0 01.416-1.28l4.21-.611L7.327.668A.75.75 0 018 .25z\"></path>\n                                    </svg>\n                                    支持一下\n                                </a>\n                            </div>\n                            \n                            <div class=\"github-stats\">\n                                <a href=\"https://github.com/JSREI/ast-explorer-helper/stargazers\" target=\"_blank\" class=\"stat-item star-stat\" title=\"GitHub Star数 - 点击查看详情\">\n                                    <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n                                        <path fill-rule=\"evenodd\" d=\"M8 .25a.75.75 0 01.673.418l1.882 3.815 4.21.612a.75.75 0 01.416 1.279l-3.046 2.97.719 4.192a.75.75 0 01-1.088.791L8 12.347l-3.766 1.98a.75.75 0 01-1.088-.79l.72-4.194L.818 6.374a.75.75 0 01.416-1.28l4.21-.611L7.327.668A.75.75 0 018 .25z\"></path>\n                                    </svg>\n                                    <span>${repoStats.stars || '暂未获取'}</span>\n                                    <span class=\"stat-label\">Stars</span>\n                                </a>\n                                <a href=\"https://github.com/JSREI/ast-explorer-helper/forks\" target=\"_blank\" class=\"stat-item fork-stat\" title=\"GitHub Fork数 - 点击查看详情\">\n                                    <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n                                        <path fill-rule=\"evenodd\" d=\"M5 3.25a.75.75 0 11-1.5 0 .75.75 0 011.5 0zm0 2.122a2.25 2.25 0 10-1.5 0v.878A2.25 2.25 0 005.75 8.5h1.5v2.128a2.251 2.251 0 101.5 0V8.5h1.5a2.25 2.25 0 002.25-2.25v-.878a2.25 2.25 0 10-1.5 0v.878a.75.75 0 01-.75.75h-4.5A.75.75 0 015 6.25v-.878zm3.75 7.378a.75.75 0 11-1.5 0 .75.75 0 011.5 0zm3-8.75a.75.75 0 100-1.5.75.75 0 000 1.5z\"></path>\n                                    </svg>\n                                    <span>${repoStats.forks || '暂未获取'}</span>\n                                    <span class=\"stat-label\">Forks</span>\n                                </a>\n                                <a href=\"https://github.com/JSREI/ast-explorer-helper/issues\" target=\"_blank\" class=\"stat-item issue-stat\" title=\"GitHub Issue数 - 点击查看详情\">\n                                    <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n                                        <path fill-rule=\"evenodd\" d=\"M8 1.5a6.5 6.5 0 100 13 6.5 6.5 0 000-13zM0 8a8 8 0 1116 0A8 8 0 010 8zm9 3a1 1 0 11-2 0 1 1 0 012 0zm-.25-6.25a.75.75 0 00-1.5 0v3.5a.75.75 0 001.5 0v-3.5z\"></path>\n                                    </svg>\n                                    <span>${repoStats.issues || '暂未获取'}</span>\n                                    <span class=\"stat-label\">Issues</span>\n                                </a>\n                                <a href=\"https://github.com/JSREI/ast-explorer-helper/commits/main\" target=\"_blank\" class=\"stat-item update-stat\" title=\"最近更新时间 - 点击查看提交历史\">\n                                    <svg class=\"stat-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n                                        <path fill-rule=\"evenodd\" d=\"M1.643 3.143L.427 1.927A.25.25 0 000 2.104V5.75c0 .138.112.25.25.25h3.646a.25.25 0 00.177-.427L2.715 4.215a6.5 6.5 0 11-1.18 4.458.75.75 0 10-1.493.154 8.001 8.001 0 101.6-5.684zM7.75 4a.75.75 0 01.75.75v2.992l2.028.812a.75.75 0 01-.557 1.392l-2.5-1A.75.75 0 017 8.25v-3.5A.75.75 0 017.75 4z\"></path>\n                                    </svg>\n                                    <span>${repoStats.updatedAt || '暂未获取'}</span>\n                                    <span class=\"stat-label\">更新于</span>\n                                </a>\n                            </div>\n                        </div>\n                    </div>\n                </section>\n                \n                <!-- 组织信息部分 - 增强版 -->\n                <section class=\"org-info-section\">\n                    <div class=\"org-card\">\n                        <div class=\"org-header\">\n                            <div class=\"org-logo\">\n                                <img src=\"https://avatars.githubusercontent.com/u/118125754?s=200&v=4\" alt=\"JSREI组织Logo\" class=\"jsrei-logo\" width=\"64\" height=\"64\">\n                                <span class=\"org-badge\">开源组织</span>\n                            </div>\n                            <h4 class=\"section-title\">关于JSREI</h4>\n                        </div>\n                        \n                        <div class=\"org-content\">\n                            <div class=\"org-description\">\n                                <p>JSREI (JavaScript Reverse Engineering Initiative) 是一个专注于JavaScript逆向工程的开源组织，致力于提供优质的逆向工程工具和教程，帮助开发者更好地理解和分析JavaScript代码。</p>\n                            </div>\n                            \n                            <div class=\"org-features\">\n                                <div class=\"feature-item\">\n                                    <div class=\"feature-icon\">\n                                        <svg viewBox=\"0 0 24 24\" width=\"20\" height=\"20\">\n                                            <path fill=\"currentColor\" d=\"M12 2L1 21h22L12 2zm0 4l7.53 13H4.47L12 6zm-1 3v4h2V9h-2zm0 6v2h2v-2h-2z\"/>\n                                        </svg>\n                                    </div>\n                                    <div class=\"feature-text\">逆向工具</div>\n                                </div>\n                                \n                                <div class=\"feature-item\">\n                                    <div class=\"feature-icon\">\n                                        <svg viewBox=\"0 0 24 24\" width=\"20\" height=\"20\">\n                                            <path fill=\"currentColor\" d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-5 14H7v-2h7v2zm3-4H7v-2h10v2zm0-4H7V7h10v2z\"/>\n                                        </svg>\n                                    </div>\n                                    <div class=\"feature-text\">技术教程</div>\n                                </div>\n                                \n                                <div class=\"feature-item\">\n                                    <div class=\"feature-icon\">\n                                        <svg viewBox=\"0 0 24 24\" width=\"20\" height=\"20\">\n                                            <path fill=\"currentColor\" d=\"M9.4 16.6L4.8 12l4.6-4.6L8 6l-6 6 6 6 1.4-1.4zm5.2 0l4.6-4.6-4.6-4.6L16 6l6 6-6 6-1.4-1.4z\"/>\n                                        </svg>\n                                    </div>\n                                    <div class=\"feature-text\">代码分析</div>\n                                </div>\n                            </div>\n                        </div>\n                        \n                        <div class=\"org-actions\">\n                            <a href=\"https://github.com/JSREI\" target=\"_blank\" class=\"org-action-button fixed-button\">\n                                <span class=\"button-icon\">\n                                    <svg class=\"github-icon\" viewBox=\"0 0 16 16\" width=\"16\" height=\"16\">\n                                        <path fill-rule=\"evenodd\" d=\"M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0016 8c0-4.42-3.58-8-8-8z\"></path>\n                                    </svg>\n                                </span>\n                                <span class=\"button-text\">查看更多JSREI项目</span>\n                            </a>\n                        </div>\n                    </div>\n                </section>\n                \n                <!-- 交流群信息部分 - 卡片式设计 -->\n                <section class=\"community-section\">\n                    <div class=\"community-card\">\n                        <div class=\"community-header\">\n                            <div class=\"community-icon\">\n                                <svg viewBox=\"0 0 24 24\" width=\"24\" height=\"24\">\n                                    <path fill=\"currentColor\" d=\"M12 2c1.35 0 2.6.45 3.6 1.2L12 7.8 8.4 3.2C9.4 2.45 10.65 2 12 2m9 15c0 1.66-1.34 3-3 3H6c-1.66 0-3-1.34-3-3v-4.85c0-.3.15-.57.4-.74L12 5l8.6 6.41c.25.17.4.44.4.74V17z\"/>\n                                </svg>\n                            </div>\n                            \n                            <h4 class=\"section-title\">逆向技术交流群</h4>\n                            <p>加入我们的技术交流社区，分享经验与知识</p>\n                        </div>\n                        \n                        <div class=\"qr-code-container\">\n                            <!-- 微信部分 -->\n                            <div class=\"qr-section\">\n                                <div class=\"qr-section-title wechat\">\n                                    <svg viewBox=\"0 0 24 24\" width=\"18\" height=\"18\">\n                                        <path fill=\"currentColor\" d=\"M8.2 13.3c-.5 0-.9-.4-.9-.9s.4-.9.9-.9.9.4.9.9-.4.9-.9.9m4.9 0c-.5 0-.9-.4-.9-.9s.4-.9.9-.9.9.4.9.9-.4.9-.9.9m3-6.5c-3.6 0-6.5 2.4-6.5 5.4 0 .5.1 1 .2 1.5-2.3-.1-4.6-1.2-6-2.9a1.61 1.61 0 0 0-.2.8c0 1 .9 1.9 2.2 2.4-.8 0-1.5-.1-2.1-.4 0 1.4 2 2.5 3.6 2.8-.4.1-.9.2-1.4.2-.3 0-.5 0-.8-.1.4 1.1 1.4 1.9 2.6 2-1 .7-2.2 1.1-3.6 1.1H3c1.3.8 2.8 1.3 4.4 1.3 5.3 0 8.2-4.1 8.2-7.6v-.3c.6-.4 1-1 1.4-1.6-.5.2-1 .4-1.6.5.6-.4 1-1 1.2-1.7-.6.3-1.2.6-1.9.7\"/></path>\n                                    </svg>\n                                    微信交流群\n                                </div>\n                                \n                                <div class=\"qr-item\">\n                                    <p>扫码加入逆向技术微信交流群：</p>\n                                    <div class=\"qr-code\">\n                                        <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/image-20241016230653669.png\" alt=\"逆向技术微信交流群二维码\">\n                                    </div>\n                                </div>\n                                \n                                <div class=\"qr-item\">\n                                    <p>如群二维码过期，可以加我个人微信，发送【逆向群】拉你进群：</p>\n                                    <div class=\"qr-code\">\n                                        <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/image-20231030132026541-7614065.png\" alt=\"个人微信二维码\">\n                                    </div>\n                                </div>\n                            </div>\n                            \n                            <!-- QQ群部分 -->\n                            <div class=\"qr-section\">\n                                <div class=\"qr-section-title qq\">\n                                    <svg viewBox=\"0 0 24 24\" width=\"18\" height=\"18\">\n                                        <path fill=\"currentColor\" d=\"M12.003 2c-5.514 0-9.998 4.484-9.998 9.997 0 5.515 4.484 10 9.998 10 5.515 0 10-4.485 10-10 0-5.513-4.485-9.997-10-9.997zm0 1.5c4.69 0 8.5 3.807 8.5 8.497 0 4.691-3.81 8.5-8.5 8.5-4.689 0-8.498-3.809-8.498-8.5 0-4.69 3.809-8.497 8.498-8.497zm-0.747 4.562v-0.002c-0.325 0.038-0.913 0.197-1.707 1.063-0.895 0.978-0.845 2.032-0.845 2.032s-1.289 0.184-1.677 1.904c-0.388 1.721-0.123 2.094-0.123 2.094s-0.214 1.577 0.735 0.587c0.303-0.316 0.499-1.153 0.499-1.153l0.789 1.781c-0.881 1.86-0.789 2.299-0.789 2.299s-0.123 0.883 0.643 0.205c0.766-0.678 1.219-1.977 1.219-1.977l0.214 0.92c-0.123 1.565 0.152 1.721 0.152 1.721s0.245 0.431 0.583-0.147c0.338-0.577 0.245-1.351 0.245-1.351l0.797-0.059c0.919 1.644 1.676 0.92 1.676 0.92s0.367-0.516-0.275-1.433l0.613-0.489c1.188 0.82 1.92-0.059 1.92-0.059s0.275-0.723-1.188-1.062l0.183-0.723c1.554-0.147 1.432-1.062 1.432-1.062s-0.061-0.75-1.432-0.75l-0.245-0.791c1.31-0.489 1.127-1.202 1.127-1.202s-0.214-0.606-1.188-0.518l-0.735-1.202c0.919-0.577 0.674-1.202 0.674-1.202s-0.367-0.518-1.188 0.059l-1.188-1.202c0.613-0.82 0.214-1.202 0.214-1.202s-0.521-0.321-1.127 0.518l-0.919-0.791c0.306-0.82-0.152-1.062-0.152-1.062s-0.583-0.205-0.766 0.791l-0.919-0.518c0.214-0.978-0.367-1.062-0.367-1.062z\"/>\n                                    </svg>\n                                    QQ交流群\n                                </div>\n                                \n                                <div class=\"qr-item\">\n                                    <p><a href=\"https://qm.qq.com/q/YfdB3w3OEY\" target=\"_blank\" class=\"qq-link\">\n                                        <svg viewBox=\"0 0 24 24\" width=\"14\" height=\"14\">\n                                            <path fill=\"currentColor\" d=\"M14 3v2h3.59l-9.83 9.83-1.41-1.41L16.17 3H14V1h6v6h-2V3.41l-9.83 9.83 1.41 1.41L20.41 4H24v2h2V0h-6v2h-6z\"/>\n                                        </svg>\n                                        点此直接加入\n                                    </a> 或扫码加入QQ交流群：</p>\n                                    <div class=\"qr-code\">\n                                        <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/jsrei-qq-group.jpg\" alt=\"QQ交流群二维码\">\n                                    </div>\n                                </div>\n                            </div>\n                            \n                            <!-- Telegram部分 -->\n                            <div class=\"qr-section\">\n                                <div class=\"qr-section-title telegram\">\n                                    <svg viewBox=\"0 0 24 24\" width=\"18\" height=\"18\">\n                                        <path fill=\"currentColor\" d=\"M9.78 18.65l.28-4.23 7.68-6.92c.34-.31-.07-.46-.52-.19L7.74 13.3 3.64 12c-.88-.25-.89-.86.2-1.3l15.97-6.16c.73-.33 1.43.18 1.15 1.3l-2.72 12.81c-.19.91-.74 1.13-1.5.71L12.6 16.3l-1.99 1.93c-.23.23-.42.42-.83.42z\"></path>\n                                    </svg>\n                                    Telegram 交流群\n                                </div>\n                                \n                                <div class=\"qr-item\">\n                                    <p><a href=\"https://t.me/jsreijsrei\" target=\"_blank\" class=\"tg-link\">\n                                        <svg viewBox=\"0 0 24 24\" width=\"14\" height=\"14\">\n                                            <path fill=\"currentColor\" d=\"M14 3v2h3.59l-9.83 9.83-1.41-1.41L16.17 3H14V1h6v6h-2V3.41l-9.83 9.83 1.41 1.41L20.41 4H24v2h2V0h-6v2h-6z\"/>\n                                        </svg>\n                                        点此直接加入\n                                    </a> 或扫码加入 TG 交流群：</p>\n                                    <div class=\"qr-code\">\n                                        <img src=\"https://cdn.jsdelivr.net/gh/JSREI/.github/profile/README.assets/image-20241016231143315.png\" alt=\"TG交流群二维码\">\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                </section>\n            </div>\n        </div>\n    `;\n}\n\n/**\n * 获取仓库统计信息的缓存数据\n * 如果缓存不存在或已过期，则返回空数据并触发异步更新\n */\nexport function getRepoStatsFromCache(): any {\n    const CACHE_KEY = 'JSREI_repo_stats';\n    const CACHE_EXPIRY = 60 * 60 * 1000; // 1小时缓存\n    \n    // 空数据对象，表示未获取到\n    const emptyStats = { \n        stars: null, \n        forks: null, \n        issues: null, \n        updatedAt: null \n    };\n    \n    // 尝试从localStorage获取缓存数据\n    const cachedData = localStorage.getItem(CACHE_KEY);\n    let repoStats = { ...emptyStats };\n    \n    if (cachedData) {\n        try {\n            const parsedData = JSON.parse(cachedData);\n            const now = new Date().getTime();\n            \n            // 检查缓存是否有效\n            if (parsedData && parsedData.timestamp && (now - parsedData.timestamp) < CACHE_EXPIRY) {\n                repoStats = parsedData.data;\n                return repoStats;\n            }\n        } catch (error) {\n            console.error('解析仓库统计缓存数据失败:', error);\n            return emptyStats; // 返回空数据\n        }\n    }\n    \n    // 如果没有有效缓存，异步获取新数据\n    try {\n        fetchRepoStats().then(data => {\n            if (data) {\n                // 缓存新数据\n                localStorage.setItem(CACHE_KEY, JSON.stringify({\n                    timestamp: new Date().getTime(),\n                    data: data\n                }));\n                \n                // 如果页面已加载，更新DOM\n                updateRepoStatsInDOM(data);\n            } else {\n                // API返回空数据，更新DOM显示未获取状态\n                updateRepoStatsInDOM(emptyStats);\n            }\n        }).catch(err => {\n            console.error('获取仓库统计数据失败:', err);\n            // API调用出错，更新DOM显示未获取状态\n            updateRepoStatsInDOM(emptyStats);\n        });\n    } catch (error) {\n        console.error('启动仓库统计更新失败:', error);\n        return emptyStats; // 返回空数据\n    }\n    \n    return repoStats;\n}\n\n/**\n * 从GitHub API获取仓库统计数据\n */\nasync function fetchRepoStats(): Promise<any> {\n    try {\n        // 给API请求添加超时限制\n        const controller = new AbortController();\n        const timeoutId = setTimeout(() => controller.abort(), 5000); // 5秒超时\n        \n        const response = await fetch('https://api.github.com/repos/JSREI/ast-explorer-helper', {\n            signal: controller.signal,\n            headers: {\n                'Accept': 'application/vnd.github.v3+json'\n            }\n        });\n        \n        clearTimeout(timeoutId);\n        \n        if (!response.ok) {\n            throw new Error(`GitHub API错误: ${response.status}`);\n        }\n        \n        const data = await response.json();\n        \n        // 格式化日期\n        const updatedDate = new Date(data.updated_at);\n        const formattedDate = `${updatedDate.getFullYear()}-${String(updatedDate.getMonth() + 1).padStart(2, '0')}-${String(updatedDate.getDate()).padStart(2, '0')}`;\n        \n        return {\n            stars: data.stargazers_count,\n            forks: data.forks_count,\n            issues: data.open_issues_count,\n            updatedAt: formattedDate\n        };\n    } catch (error) {\n        console.error('获取仓库统计数据失败:', error);\n        // 返回null表示获取失败\n        return null;\n    }\n}\n\n/**\n * 更新DOM中的仓库统计数据\n */\nfunction updateRepoStatsInDOM(data: any): void {\n    try {\n        const aboutTab = document.getElementById('about-tab');\n        if (!aboutTab) return;\n        \n        // 更新各个统计数据\n        const statItems = aboutTab.querySelectorAll('.github-stats .stat-item span');\n        if (statItems.length >= 4) {\n            statItems[0].textContent = data.stars?.toString() || '暂未获取';\n            statItems[2].textContent = data.forks?.toString() || '暂未获取';\n            statItems[4].textContent = data.issues?.toString() || '暂未获取';\n            statItems[6].textContent = data.updatedAt || '暂未获取';\n        }\n    } catch (error) {\n        console.error('更新DOM中的仓库统计数据失败:', error);\n    }\n} "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///707\n");
/***/ }),
/***/ 729:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _dom_helpers__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(402);\n/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(536);\n/* harmony import */ var _settings__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(983);\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(610);\n/**\n * AST Explorer助手 - 主入口文件\n *\n * 用于分析ast时辅助提高效率,支持复制和右键菜单,以及元素高亮\n * @author CC11001100\n */\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n/**\n * 主函数,用于初始化和运行脚本\n */\nfunction main() {\n return __awaiter(this, void 0, void 0, function* () {\n 'use strict';\n // 强制启用调试级别的日志\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.enableDebug();\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.info('AST Explorer助手启动中...');\n // 记录当前版本信息\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.group('版本信息');\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.info('版本: 0.4.0');\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.info('环境: ' + (\"production\" || 0));\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.groupEnd();\n // 分组显示初始化过程\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.group('初始化过程');\n // 等待DOM完全加载\n if (document.readyState !== 'complete') {\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('等待页面完全加载...');\n yield new Promise(resolve => {\n window.addEventListener('load', () => resolve());\n });\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('页面完全加载完成');\n }\n else {\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('页面已经完全加载');\n }\n // 增加一个较长的延迟,确保页面元素已完全渲染\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('等待500ms以确保页面元素已完全渲染...');\n yield (0,_dom_helpers__WEBPACK_IMPORTED_MODULE_0__.sleep)(500);\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('延迟等待完成');\n // 加载设置\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('开始加载设置...');\n const settings = (0,_settings__WEBPACK_IMPORTED_MODULE_2__.loadSettings)();\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('设置已加载:', settings);\n console.log('✅ 加载的设置:', settings);\n console.log('✅ hideToolbar值为:', settings.hideToolbar);\n // 确保Toolbar元素存在或等待它出现\n const ensureToolbarAndApplySettings = (...args_1) => __awaiter(this, [...args_1], void 0, function* (retryCount = 0, maxRetries = 3) {\n // 尝试查找Toolbar元素\n const toolbar = document.getElementById('Toolbar');\n console.log(`🔍 [尝试 ${retryCount + 1}/${maxRetries + 1}] 查找Toolbar元素:`, toolbar);\n if (toolbar) {\n console.log('✅ 成功找到Toolbar元素,准备应用设置');\n // 应用所有设置\n console.log('🔍 准备应用所有设置...');\n (0,_settings__WEBPACK_IMPORTED_MODULE_2__.applyAllSettings)(settings);\n console.log('✅ 所有设置已应用');\n return true;\n }\n else if (retryCount < maxRetries) {\n // 如果没找到且未达到最大重试次数,等待后重试\n console.log(`⚠️ 未找到Toolbar元素,${retryCount + 1}/${maxRetries + 1}次尝试`);\n yield (0,_dom_helpers__WEBPACK_IMPORTED_MODULE_0__.sleep)(300); // 每次等待300ms\n return ensureToolbarAndApplySettings(retryCount + 1, maxRetries);\n }\n else {\n // 达到最大重试次数,直接应用设置\n console.log('⚠️ 达到最大重试次数,仍未找到Toolbar元素');\n console.log('🔍 将直接应用设置...');\n (0,_settings__WEBPACK_IMPORTED_MODULE_2__.applyAllSettings)(settings);\n console.log('✅ 所有设置已强制应用');\n return false;\n }\n });\n // 尝试确保Toolbar元素存在并应用设置\n yield ensureToolbarAndApplySettings();\n // 创建设置UI\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('开始创建设置UI...');\n (0,_ui__WEBPACK_IMPORTED_MODULE_1__.createSettingsUI)();\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('设置界面已创建完成');\n // 创建右键菜单\n (0,_ui__WEBPACK_IMPORTED_MODULE_1__.createContextMenu)();\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('右键菜单已创建');\n // 添加设置变更事件监听\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('添加设置变更事件监听器...');\n document.addEventListener('ast-explorer-helper-settings-changed', (e) => {\n console.log('🔔 设置变更事件触发');\n const updatedSettings = e.detail;\n if (updatedSettings) {\n console.log('✅ 接收到的更新设置:', updatedSettings);\n console.log('✅ hideToolbar值为:', updatedSettings.hideToolbar);\n // 应用更新的设置\n console.log('🔍 准备应用更新后的设置...');\n (0,_settings__WEBPACK_IMPORTED_MODULE_2__.applyAllSettings)(updatedSettings);\n console.log('✅ 更新的设置已应用');\n // 延迟500ms后再次应用,确保设置生效\n setTimeout(() => {\n console.log('🔍 延迟500ms后再次应用设置...');\n (0,_settings__WEBPACK_IMPORTED_MODULE_2__.applyToolbarSetting)(updatedSettings.hideToolbar);\n console.log('✅ 设置已再次应用');\n }, 500);\n }\n else {\n console.warn('⚠️ 设置变更事件中没有包含有效的设置数据');\n }\n });\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.debug('设置变更事件监听器已添加');\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.groupEnd(); // 结束初始化过程分组\n _logger__WEBPACK_IMPORTED_MODULE_3__.logger.info('AST Explorer助手已启动完成');\n // 定期更新可选择性和右键菜单\n while (true) {\n yield (0,_dom_helpers__WEBPACK_IMPORTED_MODULE_0__.setSelectable)();\n yield (0,_dom_helpers__WEBPACK_IMPORTED_MODULE_0__.sleep)(300);\n }\n });\n}\n// 运行主函数\nmain().catch(error => _logger__WEBPACK_IMPORTED_MODULE_3__.logger.error(\"AST Explorer助手运行出错:\", error));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"729.js","mappings":"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","sources":["webpack://ast-explorer-helper/./src/index.ts?ffb4"],"sourcesContent":["/**\n * AST Explorer助手 - 主入口文件\n * \n * 用于分析ast时辅助提高效率，支持复制和右键菜单，以及元素高亮\n * @author CC11001100\n */\n\nimport { setSelectable, sleep } from './dom-helpers';\nimport { createContextMenu, createSettingsUI } from './ui';\nimport { loadSettings, applyAllSettings, applyToolbarSetting, applyNodeSelectionSetting } from './settings';\nimport { logger, LogLevel } from './logger';\n\n/**\n * 主函数，用于初始化和运行脚本\n */\nasync function main(): Promise<void> {\n    'use strict';\n\n    // 强制启用调试级别的日志\n    logger.enableDebug();\n\n    logger.info('AST Explorer助手启动中...');\n\n    // 记录当前版本信息\n    logger.group('版本信息');\n    logger.info('版本: 0.4.0');\n    logger.info('环境: ' + (process.env.NODE_ENV || 'development'));\n    logger.groupEnd();\n\n    // 分组显示初始化过程\n    logger.group('初始化过程');\n\n    // 等待DOM完全加载\n    if (document.readyState !== 'complete') {\n        logger.debug('等待页面完全加载...');\n        await new Promise<void>(resolve => {\n            window.addEventListener('load', () => resolve());\n        });\n        logger.debug('页面完全加载完成');\n    } else {\n        logger.debug('页面已经完全加载');\n    }\n    \n    // 增加一个较长的延迟，确保页面元素已完全渲染\n    logger.debug('等待500ms以确保页面元素已完全渲染...');\n    await sleep(500);\n    logger.debug('延迟等待完成');\n\n    // 加载设置\n    logger.debug('开始加载设置...');\n    const settings = loadSettings();\n    logger.debug('设置已加载:', settings);\n    console.log('✅ 加载的设置:', settings);\n    console.log('✅ hideToolbar值为:', settings.hideToolbar);\n    \n    // 确保Toolbar元素存在或等待它出现\n    const ensureToolbarAndApplySettings = async (retryCount = 0, maxRetries = 3) => {\n        // 尝试查找Toolbar元素\n        const toolbar = document.getElementById('Toolbar');\n        console.log(`🔍 [尝试 ${retryCount+1}/${maxRetries+1}] 查找Toolbar元素:`, toolbar);\n        \n        if (toolbar) {\n            console.log('✅ 成功找到Toolbar元素，准备应用设置');\n            \n            // 应用所有设置\n            console.log('🔍 准备应用所有设置...');\n            applyAllSettings(settings);\n            console.log('✅ 所有设置已应用');\n            \n            return true;\n        } else if (retryCount < maxRetries) {\n            // 如果没找到且未达到最大重试次数，等待后重试\n            console.log(`⚠️ 未找到Toolbar元素，${retryCount+1}/${maxRetries+1}次尝试`);\n            await sleep(300); // 每次等待300ms\n            return ensureToolbarAndApplySettings(retryCount + 1, maxRetries);\n        } else {\n            // 达到最大重试次数，直接应用设置\n            console.log('⚠️ 达到最大重试次数，仍未找到Toolbar元素');\n            console.log('🔍 将直接应用设置...');\n            applyAllSettings(settings);\n            console.log('✅ 所有设置已强制应用');\n            \n            return false;\n        }\n    };\n    \n    // 尝试确保Toolbar元素存在并应用设置\n    await ensureToolbarAndApplySettings();\n\n    // 创建设置UI\n    logger.debug('开始创建设置UI...');\n    createSettingsUI();\n    logger.debug('设置界面已创建完成');\n\n    // 创建右键菜单\n    createContextMenu();\n    logger.debug('右键菜单已创建');\n    \n    // 添加设置变更事件监听\n    logger.debug('添加设置变更事件监听器...');\n    document.addEventListener('ast-explorer-helper-settings-changed', (e) => {\n        console.log('🔔 设置变更事件触发');\n        const updatedSettings = (e as CustomEvent).detail;\n        if (updatedSettings) {\n            console.log('✅ 接收到的更新设置:', updatedSettings);\n            console.log('✅ hideToolbar值为:', updatedSettings.hideToolbar);\n            \n            // 应用更新的设置\n            console.log('🔍 准备应用更新后的设置...');\n            applyAllSettings(updatedSettings);\n            console.log('✅ 更新的设置已应用');\n            \n            // 延迟500ms后再次应用，确保设置生效\n            setTimeout(() => {\n                console.log('🔍 延迟500ms后再次应用设置...');\n                applyToolbarSetting(updatedSettings.hideToolbar);\n                console.log('✅ 设置已再次应用');\n            }, 500);\n        } else {\n            console.warn('⚠️ 设置变更事件中没有包含有效的设置数据');\n        }\n    });\n    logger.debug('设置变更事件监听器已添加');\n    \n    logger.groupEnd(); // 结束初始化过程分组\n    \n    logger.info('AST Explorer助手已启动完成');\n    \n    // 定期更新可选择性和右键菜单\n    while (true) {\n        await setSelectable();\n        await sleep(300);\n    }\n}\n\n// 运行主函数\nmain().catch(error => logger.error(\"AST Explorer助手运行出错:\", error)); "],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///729\n");
/***/ }),
/***/ 792:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createTabsNavigation: () => (/* reexport safe */ _tabs_template__WEBPACK_IMPORTED_MODULE_2__.createTabsNavigation),\n/* harmony export */ getTabsStyles: () => (/* reexport safe */ _tabs_styles__WEBPACK_IMPORTED_MODULE_1__.getTabsStyles),\n/* harmony export */ initTabEvents: () => (/* binding */ initTabEvents),\n/* harmony export */ resetTabsState: () => (/* binding */ resetTabsState)\n/* harmony export */ });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(610);\n/* harmony import */ var _tabs_styles__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(533);\n/* harmony import */ var _tabs_template__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(661);\n/**\n * 标签页组件 - 逻辑文件\n */\n\n// 导出公共API\n\n\n/**\n * 初始化标签页切换事件\n * @param modalElement 模态框元素\n */\nfunction initTabEvents(modalElement) {\n const tabButtons = modalElement.querySelectorAll('.tab-button');\n tabButtons.forEach(button => {\n button.addEventListener('click', () => {\n const tabName = button.dataset.tab;\n // 更新按钮激活状态\n tabButtons.forEach(btn => {\n btn.classList.remove('active');\n });\n button.classList.add('active');\n // 更新内容区域显示\n const allTabContents = modalElement.querySelectorAll('.tab-content');\n allTabContents.forEach(tab => {\n tab.classList.remove('active');\n });\n const activeTab = modalElement.querySelector(`#${tabName}-tab`);\n if (activeTab) {\n activeTab.classList.add('active');\n }\n });\n });\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('已初始化标签页切换事件');\n}\n/**\n * 重置标签页状态为默认\n * @param modalElement 模态框元素\n */\nfunction resetTabsState(modalElement) {\n // 重置标签页状态为设置标签页\n const tabButtons = modalElement.querySelectorAll('.tab-button');\n tabButtons.forEach(btn => {\n btn.classList.remove('active');\n if (btn.dataset.tab === 'settings') {\n btn.classList.add('active');\n }\n });\n const tabContents = modalElement.querySelectorAll('.tab-content');\n tabContents.forEach(tab => {\n tab.classList.remove('active');\n if (tab.id === 'settings-tab') {\n tab.classList.add('active');\n }\n });\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('已重置标签页状态为默认');\n}\n_logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('已加载标签页组件');\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzkyLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFBQTs7R0FFRztBQUVtQztBQUl0QyxVQUFVO0FBQ29DO0FBQ1M7QUFFdkQ7OztHQUdHO0FBQ0ksU0FBUyxhQUFhLENBQUMsWUFBeUI7SUFDbkQsTUFBTSxVQUFVLEdBQUcsWUFBWSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBRWhFLFVBQVUsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDeEIsTUFBTSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUU7WUFDbEMsTUFBTSxPQUFPLEdBQUksTUFBc0IsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDO1lBRXBELFdBQVc7WUFDWCxVQUFVLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO2dCQUNyQixHQUFHLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUNuQyxDQUFDLENBQUMsQ0FBQztZQUNILE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBRS9CLFdBQVc7WUFDWCxNQUFNLGNBQWMsR0FBRyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxDQUFDLENBQUM7WUFDckUsY0FBYyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtnQkFDekIsR0FBRyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDbkMsQ0FBQyxDQUFDLENBQUM7WUFFSCxNQUFNLFNBQVMsR0FBRyxZQUFZLENBQUMsYUFBYSxDQUFDLElBQUksT0FBTyxNQUFNLENBQUMsQ0FBQztZQUNoRSxJQUFJLFNBQVMsRUFBRSxDQUFDO2dCQUNaLFNBQVMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3RDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUMsQ0FBQyxDQUFDO0lBRUgsMkNBQU0sQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7QUFDaEMsQ0FBQztBQUVEOzs7R0FHRztBQUNJLFNBQVMsY0FBYyxDQUFDLFlBQXlCO0lBQ3BELGdCQUFnQjtJQUNoQixNQUFNLFVBQVUsR0FBRyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDaEUsVUFBVSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNyQixHQUFHLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvQixJQUFLLEdBQW1CLENBQUMsT0FBTyxDQUFDLEdBQUcsS0FBSyxVQUFVLEVBQUUsQ0FBQztZQUNsRCxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNoQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7SUFFSCxNQUFNLFdBQVcsR0FBRyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDbEUsV0FBVyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUN0QixHQUFHLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvQixJQUFJLEdBQUcsQ0FBQyxFQUFFLEtBQUssY0FBYyxFQUFFLENBQUM7WUFDNUIsR0FBRyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDaEMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0lBRUgsMkNBQU0sQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7QUFDaEMsQ0FBQztBQUVELDJDQUFNLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYXN0LWV4cGxvcmVyLWhlbHBlci8uL3NyYy91aS90YWJzL3RhYnMuY29tcG9uZW50LnRzP2QyNDgiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDmoIfnrb7pobXnu4Tku7YgLSDpgLvovpHmlofku7ZcbiAqL1xuXG5pbXBvcnQgeyBsb2dnZXIgfSBmcm9tICcuLi8uLi9sb2dnZXInO1xuaW1wb3J0IHsgZ2V0VGFic1N0eWxlcyB9IGZyb20gJy4vdGFicy5zdHlsZXMnO1xuaW1wb3J0IHsgY3JlYXRlVGFic05hdmlnYXRpb24gfSBmcm9tICcuL3RhYnMudGVtcGxhdGUnO1xuXG4vLyDlr7zlh7rlhazlhbFBUElcbmV4cG9ydCB7IGdldFRhYnNTdHlsZXMgfSBmcm9tICcuL3RhYnMuc3R5bGVzJztcbmV4cG9ydCB7IGNyZWF0ZVRhYnNOYXZpZ2F0aW9uIH0gZnJvbSAnLi90YWJzLnRlbXBsYXRlJztcblxuLyoqXG4gKiDliJ3lp4vljJbmoIfnrb7pobXliIfmjaLkuovku7ZcbiAqIEBwYXJhbSBtb2RhbEVsZW1lbnQg5qih5oCB5qGG5YWD57SgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbml0VGFiRXZlbnRzKG1vZGFsRWxlbWVudDogSFRNTEVsZW1lbnQpOiB2b2lkIHtcbiAgICBjb25zdCB0YWJCdXR0b25zID0gbW9kYWxFbGVtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy50YWItYnV0dG9uJyk7XG4gICAgXG4gICAgdGFiQnV0dG9ucy5mb3JFYWNoKGJ1dHRvbiA9PiB7XG4gICAgICAgIGJ1dHRvbi5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsICgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHRhYk5hbWUgPSAoYnV0dG9uIGFzIEhUTUxFbGVtZW50KS5kYXRhc2V0LnRhYjtcbiAgICAgICAgICAgIFxuICAgICAgICAgICAgLy8g5pu05paw5oyJ6ZKu5r+A5rS754q25oCBXG4gICAgICAgICAgICB0YWJCdXR0b25zLmZvckVhY2goYnRuID0+IHtcbiAgICAgICAgICAgICAgICBidG4uY2xhc3NMaXN0LnJlbW92ZSgnYWN0aXZlJyk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIGJ1dHRvbi5jbGFzc0xpc3QuYWRkKCdhY3RpdmUnKTtcbiAgICAgICAgICAgIFxuICAgICAgICAgICAgLy8g5pu05paw5YaF5a655Yy65Z+f5pi+56S6XG4gICAgICAgICAgICBjb25zdCBhbGxUYWJDb250ZW50cyA9IG1vZGFsRWxlbWVudC5xdWVyeVNlbGVjdG9yQWxsKCcudGFiLWNvbnRlbnQnKTtcbiAgICAgICAgICAgIGFsbFRhYkNvbnRlbnRzLmZvckVhY2godGFiID0+IHtcbiAgICAgICAgICAgICAgICB0YWIuY2xhc3NMaXN0LnJlbW92ZSgnYWN0aXZlJyk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIFxuICAgICAgICAgICAgY29uc3QgYWN0aXZlVGFiID0gbW9kYWxFbGVtZW50LnF1ZXJ5U2VsZWN0b3IoYCMke3RhYk5hbWV9LXRhYmApO1xuICAgICAgICAgICAgaWYgKGFjdGl2ZVRhYikge1xuICAgICAgICAgICAgICAgIGFjdGl2ZVRhYi5jbGFzc0xpc3QuYWRkKCdhY3RpdmUnKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfSk7XG4gICAgXG4gICAgbG9nZ2VyLmRlYnVnKCflt7LliJ3lp4vljJbmoIfnrb7pobXliIfmjaLkuovku7YnKTtcbn1cblxuLyoqXG4gKiDph43nva7moIfnrb7pobXnirbmgIHkuLrpu5jorqRcbiAqIEBwYXJhbSBtb2RhbEVsZW1lbnQg5qih5oCB5qGG5YWD57SgIFxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVzZXRUYWJzU3RhdGUobW9kYWxFbGVtZW50OiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgIC8vIOmHjee9ruagh+etvumhteeKtuaAgeS4uuiuvue9ruagh+etvumhtVxuICAgIGNvbnN0IHRhYkJ1dHRvbnMgPSBtb2RhbEVsZW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLnRhYi1idXR0b24nKTtcbiAgICB0YWJCdXR0b25zLmZvckVhY2goYnRuID0+IHtcbiAgICAgICAgYnRuLmNsYXNzTGlzdC5yZW1vdmUoJ2FjdGl2ZScpO1xuICAgICAgICBpZiAoKGJ0biBhcyBIVE1MRWxlbWVudCkuZGF0YXNldC50YWIgPT09ICdzZXR0aW5ncycpIHtcbiAgICAgICAgICAgIGJ0bi5jbGFzc0xpc3QuYWRkKCdhY3RpdmUnKTtcbiAgICAgICAgfVxuICAgIH0pO1xuICAgIFxuICAgIGNvbnN0IHRhYkNvbnRlbnRzID0gbW9kYWxFbGVtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy50YWItY29udGVudCcpO1xuICAgIHRhYkNvbnRlbnRzLmZvckVhY2godGFiID0+IHtcbiAgICAgICAgdGFiLmNsYXNzTGlzdC5yZW1vdmUoJ2FjdGl2ZScpO1xuICAgICAgICBpZiAodGFiLmlkID09PSAnc2V0dGluZ3MtdGFiJykge1xuICAgICAgICAgICAgdGFiLmNsYXNzTGlzdC5hZGQoJ2FjdGl2ZScpO1xuICAgICAgICB9XG4gICAgfSk7XG4gICAgXG4gICAgbG9nZ2VyLmRlYnVnKCflt7Lph43nva7moIfnrb7pobXnirbmgIHkuLrpu5jorqQnKTtcbn1cblxubG9nZ2VyLmRlYnVnKCflt7LliqDovb3moIfnrb7pobXnu4Tku7YnKTsgIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///792\n");
/***/ }),
/***/ 879:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ copyToClipboard: () => (/* binding */ copyToClipboard)\n/* harmony export */ });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(610);\n/**\n * 剪贴板工具服务\n */\n\n/**\n * 复制文本到剪贴板\n * @param text 要复制的文本\n * @returns 是否成功复制\n */\nfunction copyToClipboard(text) {\n try {\n // 创建一个辅助的文本域\n const textarea = document.createElement('textarea');\n textarea.value = text;\n textarea.style.position = 'fixed'; // 避免滚动到底部\n textarea.style.opacity = '0';\n document.body.appendChild(textarea);\n // 选择文本并复制\n textarea.select();\n const success = document.execCommand('copy');\n document.body.removeChild(textarea);\n // 显示复制成功提示\n if (success) {\n showCopySuccessToast(text);\n }\n return success;\n }\n catch (error) {\n _logger__WEBPACK_IMPORTED_MODULE_0__.logger.error('复制到剪贴板失败:', error);\n return false;\n }\n}\n/**\n * 显示复制成功的提示\n * @param text 复制的内容\n */\nfunction showCopySuccessToast(text) {\n // 检查是否已有提示框\n let toast = document.getElementById('copy-toast');\n if (!toast) {\n // 创建提示框\n toast = document.createElement('div');\n toast.id = 'copy-toast';\n toast.style.cssText = `\n position: fixed;\n bottom: 20px;\n right: 20px;\n background-color: rgba(0, 0, 0, 0.7);\n color: white;\n padding: 10px 15px;\n border-radius: 4px;\n font-size: 14px;\n max-width: 80%;\n z-index: 10001;\n opacity: 0;\n transition: opacity 0.3s ease;\n `;\n document.body.appendChild(toast);\n }\n // 裁剪显示的内容\n const displayText = text.length > 50 ? text.substring(0, 47) + '...' : text;\n toast.textContent = `已复制: ${displayText}`;\n toast.style.opacity = '1';\n // 设置定时器让提示消失\n setTimeout(() => {\n if (toast) {\n toast.style.opacity = '0';\n // 提示消失后删除元素\n setTimeout(() => {\n if (toast && toast.parentNode) {\n toast.parentNode.removeChild(toast);\n }\n }, 300);\n }\n }, 2000);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODc5LmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0dBRUc7QUFFZ0M7QUFFbkM7Ozs7R0FJRztBQUNJLFNBQVMsZUFBZSxDQUFDLElBQVk7SUFDeEMsSUFBSSxDQUFDO1FBQ0QsYUFBYTtRQUNiLE1BQU0sUUFBUSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDcEQsUUFBUSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDdEIsUUFBUSxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsT0FBTyxDQUFDLENBQUUsVUFBVTtRQUM5QyxRQUFRLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7UUFDN0IsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFcEMsVUFBVTtRQUNWLFFBQVEsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNsQixNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzdDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXBDLFdBQVc7UUFDWCxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1Ysb0JBQW9CLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0IsQ0FBQztRQUVELE9BQU8sT0FBTyxDQUFDO0lBQ25CLENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2IsMkNBQU0sQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pDLE9BQU8sS0FBSyxDQUFDO0lBQ2pCLENBQUM7QUFDTCxDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsU0FBUyxvQkFBb0IsQ0FBQyxJQUFZO0lBQ3RDLFlBQVk7SUFDWixJQUFJLEtBQUssR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2xELElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNULFFBQVE7UUFDUixLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN0QyxLQUFLLENBQUMsRUFBRSxHQUFHLFlBQVksQ0FBQztRQUN4QixLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRzs7Ozs7Ozs7Ozs7OztTQWFyQixDQUFDO1FBQ0YsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELFVBQVU7SUFDVixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDNUUsS0FBSyxDQUFDLFdBQVcsR0FBRyxRQUFRLFdBQVcsRUFBRSxDQUFDO0lBQzFDLEtBQUssQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLEdBQUcsQ0FBQztJQUUxQixhQUFhO0lBQ2IsVUFBVSxDQUFDLEdBQUcsRUFBRTtRQUNaLElBQUksS0FBSyxFQUFFLENBQUM7WUFDUixLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7WUFFMUIsWUFBWTtZQUNaLFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osSUFBSSxLQUFLLElBQUksS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO29CQUM1QixLQUFLLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDeEMsQ0FBQztZQUNMLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUNaLENBQUM7SUFDTCxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDYixDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYXN0LWV4cGxvcmVyLWhlbHBlci8uL3NyYy9jbGlwYm9hcmQvY2xpcGJvYXJkLnNlcnZpY2UudHM/M2U1MSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIOWJqui0tOadv+W3peWFt+acjeWKoVxuICovXG5cbmltcG9ydCB7IGxvZ2dlciB9IGZyb20gJy4uL2xvZ2dlcic7XG5cbi8qKlxuICog5aSN5Yi25paH5pys5Yiw5Ymq6LS05p2/XG4gKiBAcGFyYW0gdGV4dCDopoHlpI3liLbnmoTmlofmnKxcbiAqIEByZXR1cm5zIOaYr+WQpuaIkOWKn+WkjeWItlxuICovXG5leHBvcnQgZnVuY3Rpb24gY29weVRvQ2xpcGJvYXJkKHRleHQ6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHRyeSB7XG4gICAgICAgIC8vIOWIm+W7uuS4gOS4qui+heWKqeeahOaWh+acrOWfn1xuICAgICAgICBjb25zdCB0ZXh0YXJlYSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3RleHRhcmVhJyk7XG4gICAgICAgIHRleHRhcmVhLnZhbHVlID0gdGV4dDtcbiAgICAgICAgdGV4dGFyZWEuc3R5bGUucG9zaXRpb24gPSAnZml4ZWQnOyAgLy8g6YG/5YWN5rua5Yqo5Yiw5bqV6YOoXG4gICAgICAgIHRleHRhcmVhLnN0eWxlLm9wYWNpdHkgPSAnMCc7XG4gICAgICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQodGV4dGFyZWEpO1xuICAgICAgICBcbiAgICAgICAgLy8g6YCJ5oup5paH5pys5bm25aSN5Yi2XG4gICAgICAgIHRleHRhcmVhLnNlbGVjdCgpO1xuICAgICAgICBjb25zdCBzdWNjZXNzID0gZG9jdW1lbnQuZXhlY0NvbW1hbmQoJ2NvcHknKTtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5yZW1vdmVDaGlsZCh0ZXh0YXJlYSk7XG4gICAgICAgIFxuICAgICAgICAvLyDmmL7npLrlpI3liLbmiJDlip/mj5DnpLpcbiAgICAgICAgaWYgKHN1Y2Nlc3MpIHtcbiAgICAgICAgICAgIHNob3dDb3B5U3VjY2Vzc1RvYXN0KHRleHQpO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICByZXR1cm4gc3VjY2VzcztcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICBsb2dnZXIuZXJyb3IoJ+WkjeWItuWIsOWJqui0tOadv+Wksei0pTonLCBlcnJvcik7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59XG5cbi8qKlxuICog5pi+56S65aSN5Yi25oiQ5Yqf55qE5o+Q56S6XG4gKiBAcGFyYW0gdGV4dCDlpI3liLbnmoTlhoXlrrlcbiAqL1xuZnVuY3Rpb24gc2hvd0NvcHlTdWNjZXNzVG9hc3QodGV4dDogc3RyaW5nKTogdm9pZCB7XG4gICAgLy8g5qOA5p+l5piv5ZCm5bey5pyJ5o+Q56S65qGGXG4gICAgbGV0IHRvYXN0ID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2NvcHktdG9hc3QnKTtcbiAgICBpZiAoIXRvYXN0KSB7XG4gICAgICAgIC8vIOWIm+W7uuaPkOekuuahhlxuICAgICAgICB0b2FzdCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2RpdicpO1xuICAgICAgICB0b2FzdC5pZCA9ICdjb3B5LXRvYXN0JztcbiAgICAgICAgdG9hc3Quc3R5bGUuY3NzVGV4dCA9IGBcbiAgICAgICAgICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICAgICAgICAgIGJvdHRvbTogMjBweDtcbiAgICAgICAgICAgIHJpZ2h0OiAyMHB4O1xuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgwLCAwLCAwLCAwLjcpO1xuICAgICAgICAgICAgY29sb3I6IHdoaXRlO1xuICAgICAgICAgICAgcGFkZGluZzogMTBweCAxNXB4O1xuICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogNHB4O1xuICAgICAgICAgICAgZm9udC1zaXplOiAxNHB4O1xuICAgICAgICAgICAgbWF4LXdpZHRoOiA4MCU7XG4gICAgICAgICAgICB6LWluZGV4OiAxMDAwMTtcbiAgICAgICAgICAgIG9wYWNpdHk6IDA7XG4gICAgICAgICAgICB0cmFuc2l0aW9uOiBvcGFjaXR5IDAuM3MgZWFzZTtcbiAgICAgICAgYDtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZCh0b2FzdCk7XG4gICAgfVxuICAgIFxuICAgIC8vIOijgeWJquaYvuekuueahOWGheWuuVxuICAgIGNvbnN0IGRpc3BsYXlUZXh0ID0gdGV4dC5sZW5ndGggPiA1MCA/IHRleHQuc3Vic3RyaW5nKDAsIDQ3KSArICcuLi4nIDogdGV4dDtcbiAgICB0b2FzdC50ZXh0Q29udGVudCA9IGDlt7LlpI3liLY6ICR7ZGlzcGxheVRleHR9YDtcbiAgICB0b2FzdC5zdHlsZS5vcGFjaXR5ID0gJzEnO1xuICAgIFxuICAgIC8vIOiuvue9ruWumuaXtuWZqOiuqeaPkOekuua2iOWksVxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICBpZiAodG9hc3QpIHtcbiAgICAgICAgICAgIHRvYXN0LnN0eWxlLm9wYWNpdHkgPSAnMCc7XG4gICAgICAgICAgICBcbiAgICAgICAgICAgIC8vIOaPkOekuua2iOWkseWQjuWIoOmZpOWFg+e0oFxuICAgICAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKHRvYXN0ICYmIHRvYXN0LnBhcmVudE5vZGUpIHtcbiAgICAgICAgICAgICAgICAgICAgdG9hc3QucGFyZW50Tm9kZS5yZW1vdmVDaGlsZCh0b2FzdCk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSwgMzAwKTtcbiAgICAgICAgfVxuICAgIH0sIDIwMDApO1xufSAiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///879\n");
/***/ }),
/***/ 920:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createAboutTabContent: () => (/* reexport safe */ _about_tab_component__WEBPACK_IMPORTED_MODULE_0__.createAboutTabContent),\n/* harmony export */ getAboutTabStyles: () => (/* reexport safe */ _about_tab_component__WEBPACK_IMPORTED_MODULE_0__.getAboutTabStyles),\n/* harmony export */ getRepoStatsFromCache: () => (/* reexport safe */ _about_tab_component__WEBPACK_IMPORTED_MODULE_0__.getRepoStatsFromCache)\n/* harmony export */ });\n/* harmony import */ var _about_tab_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(126);\n/**\n * 关于标签页组件 - 入口文件\n */\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTIwLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7R0FFRztBQU00QiIsInNvdXJjZXMiOlsid2VicGFjazovL2FzdC1leHBsb3Jlci1oZWxwZXIvLi9zcmMvdWkvYWJvdXQtdGFiL2luZGV4LnRzP2FiNDIiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDlhbPkuo7moIfnrb7pobXnu4Tku7YgLSDlhaXlj6Pmlofku7ZcbiAqL1xuXG5leHBvcnQgeyBcbiAgICBnZXRBYm91dFRhYlN0eWxlcyxcbiAgICBjcmVhdGVBYm91dFRhYkNvbnRlbnQsXG4gICAgZ2V0UmVwb1N0YXRzRnJvbUNhY2hlXG59IGZyb20gJy4vYWJvdXQtdGFiLmNvbXBvbmVudCc7ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///920\n");
/***/ }),
/***/ 963:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createSettingsTabContent: () => (/* binding */ createSettingsTabContent)\n/* harmony export */ });\n/**\n * 设置标签页组件 - 模板文件\n */\n/**\n * 创建设置标签页内容\n * @param settings 当前设置\n * @returns 设置标签页的HTML内容\n */\nfunction createSettingsTabContent(settings) {\n return `\n <div class=\"tab-content active\" id=\"settings-tab\">\n <div class=\"setting-item\">\n <label>\n <input type=\"checkbox\" id=\"hide-toolbar\" ${settings.hideToolbar ? 'checked' : ''}>\n 隐藏工具栏\n </label>\n <p class=\"description\">隐藏AST Explorer顶部工具栏,增大视图空间</p>\n </div>\n </div>\n `;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTYzLmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7R0FFRztBQUlIOzs7O0dBSUc7QUFDSSxTQUFTLHdCQUF3QixDQUFDLFFBQWtCO0lBQ3ZELE9BQU87Ozs7K0RBSW9ELFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRTs7Ozs7O0tBTS9GLENBQUM7QUFDTixDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYXN0LWV4cGxvcmVyLWhlbHBlci8uL3NyYy91aS9zZXR0aW5ncy10YWIvc2V0dGluZ3MtdGFiLnRlbXBsYXRlLnRzPzFkY2EiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDorr7nva7moIfnrb7pobXnu4Tku7YgLSDmqKHmnb/mlofku7ZcbiAqL1xuXG5pbXBvcnQgeyBTZXR0aW5ncyB9IGZyb20gJy4uLy4uL3NldHRpbmdzL3NldHRpbmdzLnNlcnZpY2UnO1xuXG4vKipcbiAqIOWIm+W7uuiuvue9ruagh+etvumhteWGheWuuVxuICogQHBhcmFtIHNldHRpbmdzIOW9k+WJjeiuvue9rlxuICogQHJldHVybnMg6K6+572u5qCH562+6aG155qESFRNTOWGheWuuVxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU2V0dGluZ3NUYWJDb250ZW50KHNldHRpbmdzOiBTZXR0aW5ncyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBcbiAgICAgICAgPGRpdiBjbGFzcz1cInRhYi1jb250ZW50IGFjdGl2ZVwiIGlkPVwic2V0dGluZ3MtdGFiXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwic2V0dGluZy1pdGVtXCI+XG4gICAgICAgICAgICAgICAgPGxhYmVsPlxuICAgICAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT1cImNoZWNrYm94XCIgaWQ9XCJoaWRlLXRvb2xiYXJcIiAke3NldHRpbmdzLmhpZGVUb29sYmFyID8gJ2NoZWNrZWQnIDogJyd9PlxuICAgICAgICAgICAgICAgICAgICDpmpDol4/lt6XlhbfmoI9cbiAgICAgICAgICAgICAgICA8L2xhYmVsPlxuICAgICAgICAgICAgICAgIDxwIGNsYXNzPVwiZGVzY3JpcHRpb25cIj7pmpDol49BU1QgRXhwbG9yZXLpobbpg6jlt6XlhbfmoI/vvIzlop7lpKfop4blm77nqbrpl7Q8L3A+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgYDtcbn0gIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///963\n");
/***/ }),
/***/ 974:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ collectSettingsFromForm: () => (/* binding */ collectSettingsFromForm),\n/* harmony export */ createSettingsTabContent: () => (/* reexport safe */ _settings_tab_template__WEBPACK_IMPORTED_MODULE_2__.createSettingsTabContent),\n/* harmony export */ getSettingsTabStyles: () => (/* reexport safe */ _settings_tab_styles__WEBPACK_IMPORTED_MODULE_1__.getSettingsTabStyles)\n/* harmony export */ });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(610);\n/* harmony import */ var _settings_tab_styles__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(635);\n/* harmony import */ var _settings_tab_template__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(963);\n/**\n * 设置标签页组件 - 逻辑文件\n */\n\n// 导出公共API\n\n\n/**\n * 从表单中收集设置数据\n * @returns 更新的设置对象\n */\nfunction collectSettingsFromForm() {\n var _a;\n const hideToolbarElement = document.getElementById('hide-toolbar');\n console.log('🔍 隐藏工具栏复选框元素:', hideToolbarElement);\n // 移除视觉反馈,避免用户误解\n // 仅在控制台打印日志,不在界面显示信息\n console.log('🔍 正在读取设置选项状态...');\n // 确保即使元素不存在也能获取到默认值\n const hideToolbar = (_a = hideToolbarElement === null || hideToolbarElement === void 0 ? void 0 : hideToolbarElement.checked) !== null && _a !== void 0 ? _a : true;\n console.log('✅ 收集到的hideToolbar值:', hideToolbar);\n return {\n hideToolbar\n };\n}\n_logger__WEBPACK_IMPORTED_MODULE_0__.logger.debug('已加载设置标签页组件');\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTc0LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztHQUVHO0FBR21DO0FBSXRDLFVBQVU7QUFDbUQ7QUFDTTtBQUVuRTs7O0dBR0c7QUFDSSxTQUFTLHVCQUF1Qjs7SUFFbkMsTUFBTSxrQkFBa0IsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBcUIsQ0FBQztJQUN2RixPQUFPLENBQUMsR0FBRyxDQUFDLGdCQUFnQixFQUFFLGtCQUFrQixDQUFDLENBQUM7SUFFbEQsZ0JBQWdCO0lBQ2hCLHFCQUFxQjtJQUNyQixPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFFaEMsb0JBQW9CO0lBQ3BCLE1BQU0sV0FBVyxHQUFHLHdCQUFrQixhQUFsQixrQkFBa0IsdUJBQWxCLGtCQUFrQixDQUFFLE9BQU8sbUNBQUksSUFBSSxDQUFDO0lBRXhELE9BQU8sQ0FBQyxHQUFHLENBQUMscUJBQXFCLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFFaEQsT0FBTztRQUNILFdBQVc7S0FDZCxDQUFDO0FBQ04sQ0FBQztBQUVELDJDQUFNLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYXN0LWV4cGxvcmVyLWhlbHBlci8uL3NyYy91aS9zZXR0aW5ncy10YWIvc2V0dGluZ3MtdGFiLmNvbXBvbmVudC50cz85MWZlIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICog6K6+572u5qCH562+6aG157uE5Lu2IC0g6YC76L6R5paH5Lu2XG4gKi9cblxuaW1wb3J0IHsgU2V0dGluZ3MgfSBmcm9tICcuLi8uLi9zZXR0aW5ncy9zZXR0aW5ncy5zZXJ2aWNlJztcbmltcG9ydCB7IGxvZ2dlciB9IGZyb20gJy4uLy4uL2xvZ2dlcic7XG5pbXBvcnQgeyBnZXRTZXR0aW5nc1RhYlN0eWxlcyB9IGZyb20gJy4vc2V0dGluZ3MtdGFiLnN0eWxlcyc7XG5pbXBvcnQgeyBjcmVhdGVTZXR0aW5nc1RhYkNvbnRlbnQgfSBmcm9tICcuL3NldHRpbmdzLXRhYi50ZW1wbGF0ZSc7XG5cbi8vIOWvvOWHuuWFrOWFsUFQSVxuZXhwb3J0IHsgZ2V0U2V0dGluZ3NUYWJTdHlsZXMgfSBmcm9tICcuL3NldHRpbmdzLXRhYi5zdHlsZXMnO1xuZXhwb3J0IHsgY3JlYXRlU2V0dGluZ3NUYWJDb250ZW50IH0gZnJvbSAnLi9zZXR0aW5ncy10YWIudGVtcGxhdGUnO1xuXG4vKipcbiAqIOS7juihqOWNleS4reaUtumbhuiuvue9ruaVsOaNrlxuICogQHJldHVybnMg5pu05paw55qE6K6+572u5a+56LGhXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb2xsZWN0U2V0dGluZ3NGcm9tRm9ybSgpOiBQYXJ0aWFsPFNldHRpbmdzPiB7XG4gICAgXG4gICAgY29uc3QgaGlkZVRvb2xiYXJFbGVtZW50ID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2hpZGUtdG9vbGJhcicpIGFzIEhUTUxJbnB1dEVsZW1lbnQ7XG4gICAgY29uc29sZS5sb2coJ/CflI0g6ZqQ6JeP5bel5YW35qCP5aSN6YCJ5qGG5YWD57SgOicsIGhpZGVUb29sYmFyRWxlbWVudCk7XG4gICAgXG4gICAgLy8g56e76Zmk6KeG6KeJ5Y+N6aaI77yM6YG/5YWN55So5oi36K+v6KejXG4gICAgLy8g5LuF5Zyo5o6n5Yi25Y+w5omT5Y2w5pel5b+X77yM5LiN5Zyo55WM6Z2i5pi+56S65L+h5oGvXG4gICAgY29uc29sZS5sb2coJ/CflI0g5q2j5Zyo6K+75Y+W6K6+572u6YCJ6aG554q25oCBLi4uJyk7XG4gICAgXG4gICAgLy8g56Gu5L+d5Y2z5L2/5YWD57Sg5LiN5a2Y5Zyo5Lmf6IO96I635Y+W5Yiw6buY6K6k5YC8XG4gICAgY29uc3QgaGlkZVRvb2xiYXIgPSBoaWRlVG9vbGJhckVsZW1lbnQ/LmNoZWNrZWQgPz8gdHJ1ZTtcbiAgICBcbiAgICBjb25zb2xlLmxvZygn4pyFIOaUtumbhuWIsOeahGhpZGVUb29sYmFy5YC8OicsIGhpZGVUb29sYmFyKTtcbiAgICBcbiAgICByZXR1cm4ge1xuICAgICAgICBoaWRlVG9vbGJhclxuICAgIH07XG59XG5cbmxvZ2dlci5kZWJ1Zygn5bey5Yqg6L296K6+572u5qCH562+6aG157uE5Lu2Jyk7ICJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///974\n");
/***/ }),
/***/ 983:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _settings_service__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(663);\n/* harmony reexport (unknown) */ var __WEBPACK_REEXPORT_OBJECT__ = {};\n/* harmony reexport (unknown) */ for(const __WEBPACK_IMPORT_KEY__ in _settings_service__WEBPACK_IMPORTED_MODULE_0__) if(__WEBPACK_IMPORT_KEY__ !== \"default\") __WEBPACK_REEXPORT_OBJECT__[__WEBPACK_IMPORT_KEY__] = () => _settings_service__WEBPACK_IMPORTED_MODULE_0__[__WEBPACK_IMPORT_KEY__]\n/* harmony reexport (unknown) */ __webpack_require__.d(__webpack_exports__, __WEBPACK_REEXPORT_OBJECT__);\n/**\n * 设置模块入口\n */\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTgzLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0dBRUc7QUFFZ0MiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9hc3QtZXhwbG9yZXItaGVscGVyLy4vc3JjL3NldHRpbmdzL2luZGV4LnRzPzFkOGEiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiDorr7nva7mqKHlnZflhaXlj6NcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3NldHRpbmdzLnNlcnZpY2UnOyAiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///983\n");
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/************************************************************************/
/******/
/******/ // startup
/******/ // Load entry module and return exports
/******/ // This entry module can't be inlined because the eval-source-map devtool is used.
/******/ var __webpack_exports__ = __webpack_require__(729);
/******/
/******/ })()
;