From 2e43a50107156009861fc383bac6f065e69b8914 Mon Sep 17 00:00:00 2001 From: Yaohaixiao Date: Mon, 14 Aug 2023 17:53:25 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=B7=BB=E5=8A=A0=20print=20=E9=85=8D?= =?UTF-8?q?=E7=BD=AE=EF=BC=8C=E6=94=AF=E6=8C=81=20print=20=E5=9F=BA?= =?UTF-8?q?=E7=A1=80=E6=89=93=E5=8D=B0=E6=A0=B7=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 29 ++++++++++++-- api/less/example.less | 3 +- api/pug/flex.pug | 4 ++ api/pug/methods.pug | 2 + api/pug/options/print.pug | 38 ++++++++++++++++++ api/pug/options/section.pug | 1 + api/pug/properties/defaults.pug | 36 ++++++++++------- docs/css/example.css | 40 ++++++++++++++++++- docs/css/example.min.css | 4 +- docs/fixed.html | 53 +++++++++++++++++------- docs/flex.html | 57 +++++++++++++++++++------- docs/index.html | 55 +++++++++++++++++-------- docs/js/outline.min.js | 2 +- docs/js/outline.min.js.map | 2 +- docs/relative.html | 53 +++++++++++++++++------- docs/sticky.html | 53 +++++++++++++++++------- gulpfile.js | 2 +- outline.css | 40 ++++++++++++++++++- outline.min.css | 4 +- outline.min.js | 2 +- outline.min.js.map | 2 +- package.json | 5 ++- src/outline.js | 32 ++++++++++++++- src/print.js | 71 +++++++++++++++++++++++++++++++++ src/theme/colors.less | 2 + src/theme/outline.less | 1 + src/theme/print.less | 45 +++++++++++++++++++++ 27 files changed, 529 insertions(+), 109 deletions(-) create mode 100644 api/pug/options/print.pug create mode 100644 src/print.js create mode 100644 src/theme/print.less diff --git a/README.md b/README.md index 981a6f8b..f1e7e0ec 100644 --- a/README.md +++ b/README.md @@ -201,7 +201,7 @@ const outline = new Outline({ // ltr - 菜单位置在窗口左侧,滑动动画为:left to right // ttb - 菜单位置在窗口上方,滑动动画为:top to bottom // btt - 菜单位置在窗口下方,滑动动画为:bottom to top - placement: '', + placement: 'rtl', // 页面中其它 sticky 或者模拟 skicky 的 fiexed 定位的 DOM 元素的高度。例如 wordpress 系统中, // 就会有 sticky 定位的导航菜单。这些 sticky 元素脱离了正常的流布局后,原来 h1~h6 标题标签的 // offsetTop 计算会出现偏差。sticky 元素会遮挡标题,因此针对页面中有其它 sticky 元素会遮挡标题, @@ -224,10 +224,24 @@ const outline = new Outline({ tags: '', // 指定git仓库中的 issues 地址 issues: '', + // 自定义按钮配置 + tools: [], + // 为文章页添加基础的打印样式 + // 如果您的页面已经有打印样式,就无需设置了 + print: { + element: '', + title: '' + }, // DIYer的福利 // 独立侧滑菜单时,customClass 会追加到 drawer 侧滑窗口组件 // 在文章中显示导航菜单时,customClass 会追加到 chapters 导航菜单 - customClass + customClass, + // position: fixed,当导航菜单样式进入 fixed 定位后,触发的回调函数 + afterSticky: null, + // 当导航菜单隐藏或者显示后,触发的回调函数 + afterToggle: null, + // 当点击上下滚动按钮,导航菜单或者文章中的 # 图标,滚动结束后触发的回调函数 + afterScroll: null }); // 可以在创建导航后,重置配置信息,重新生成新的导航 @@ -442,11 +456,20 @@ Outline.DEFAULTS = { placement: 'rtl', showCode: true, anchorURL: '', + stickyHeight: 0, homepage: '', git: '', tags: '', issues: '', - customClass: '' + tools: [], + print: { + element: '', + title: '' + }, + customClass: '', + afterSticky: null, + afterToggle: null, + afterScroll: null } ``` diff --git a/api/less/example.less b/api/less/example.less index b5c337cd..9937dda1 100644 --- a/api/less/example.less +++ b/api/less/example.less @@ -9,5 +9,4 @@ @import '../../src/theme/anchors'; @import '../../src/theme/chapters'; @import '../../src/theme/toolbar'; - - +@import '../../src/theme/print'; diff --git a/api/pug/flex.pug b/api/pug/flex.pug index ff22207e..ffb525cd 100644 --- a/api/pug/flex.pug +++ b/api/pug/flex.pug @@ -41,4 +41,8 @@ html(lang='en') defaults.git = 'https://github.com/yaohaixiao/outline.js' defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags' defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues' + defaults.print = { + element: '#article', + title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具' + } outline = new Outline(Outline.DEFAULTS) diff --git a/api/pug/methods.pug b/api/pug/methods.pug index 2103663a..b37083f1 100644 --- a/api/pug/methods.pug +++ b/api/pug/methods.pug @@ -30,6 +30,8 @@ ul.aside__list a.aside__anchor(href="#option-issues") issues li.aside__item a.aside__anchor(href="#option-tools") tools + li.aside__item + a.aside__anchor(href="#option-print") print li.aside__item a.aside__anchor(href="#option-customClass") customClass li.aside__item diff --git a/api/pug/options/print.pug b/api/pug/options/print.pug new file mode 100644 index 00000000..df80faae --- /dev/null +++ b/api/pug/options/print.pug @@ -0,0 +1,38 @@ +section.section + header.section__header + h3#option-print.section__h3 print + div.section__content + h4.section__h4 Description + dl.section__dl + dt.section__dt Type: + dd.section__dd Object + dl.section__dl + dt.section__dt Default: + dd.section__dd {element: '', title: ''} + p 可选,自定义的是否自动为文章页面创建打印样式。 + dl.section__dl + dt.section__dt element: + dd.section__dd (必须)要打印的文章区域,DOM 元素或者选择器字符串。 + dl.section__dl + dt.section__dt title: + dd.section__dd (可选)要打印的文章标题。如果 element 区域有 h1 标签则无需设置。 + pre.section__pre + code.section__code. + const defaults = Outline.DEFAULTS + let outline + + defaults.position = 'sticky' + defaults.stickyHeight = 86 + defaults.parentElement = '#aside' + defaults.scrollElement = '#main' + defaults.homepage = './index.html' + defaults.git = 'https://github.com/yaohaixiao/outline.js' + defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags' + defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues' + defaults.print = { + element: '#article', + title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具' + } + outline = new Outline(Outline.DEFAULTS) + p 演示地址: + a(target="_blank" href="https://yaohaixiao.github.io/outline.js/flex.html") https://yaohaixiao.github.io/outline.js/flex.html diff --git a/api/pug/options/section.pug b/api/pug/options/section.pug index 2f4476fe..7818876c 100644 --- a/api/pug/options/section.pug +++ b/api/pug/options/section.pug @@ -17,6 +17,7 @@ section.section include tags include issues include tools + include print include customClass include afterScroll include afterSticky diff --git a/api/pug/properties/defaults.pug b/api/pug/properties/defaults.pug index d7cd2771..2024620d 100644 --- a/api/pug/properties/defaults.pug +++ b/api/pug/properties/defaults.pug @@ -11,18 +11,26 @@ section.section code.section__code. Outline.DEFAULTS = { articleElement: '#article', - selector: 'h2,h3,h4,h5,h6', - title: '目录', - scrollElement: 'html,body', - position: 'relative', - parentElement: '#aside', - placement: 'rtl', - stickyHeight: 0, - showCode: true, - anchorURL: '', - homepage: '', - git: '', - tags: '', - issues: '', - customClass: '' + selector: 'h2,h3,h4,h5,h6', + title: '目录', + scrollElement: 'html,body', + position: 'relative', + parentElement: '#aside', + placement: 'rtl', + showCode: true, + anchorURL: '', + stickyHeight: 0, + homepage: '', + git: '', + tags: '', + issues: '', + tools: [], + print: { + element: '', + title: '' + }, + customClass: '', + afterSticky: null, + afterToggle: null, + afterScroll: null } diff --git a/docs/css/example.css b/docs/css/example.css index 5e3c35de..0485fa04 100644 --- a/docs/css/example.css +++ b/docs/css/example.css @@ -995,5 +995,43 @@ code, .outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden { display: none; } +.outline-print { + display: none; +} +@media print { + html, + body { + height: initial !important; + } + .outline-print { + display: block !important; + overflow: hidden; + } + .outline-print h1 { + text-align: center; + font-size: 20pt; + font-family: 'Microsoft YaHei UI', Arial, sans-serif; + font-weight: normal; + } + .outline-print pre { + padding: 1em !important; + border: 1px solid #ddd !important; + border-radius: 4px !important; + } + .outline-print pre, + .outline-print code { + background-color: #fff !important; + } + .outline-print table, + .outline-print img, + .outline-print svg { + -webkit-column-break-inside: avoid; + -moz-column-break-inside: avoid; + break-inside: avoid; + } + .outline-print_sibling { + display: none !important; + } +} -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../<input css 2>","scrollbar.less","section.less","case.less","pager.less","../../src/theme/shadow.less","../../src/theme/icons.less","../../src/theme/variables.less","../../src/theme/drawer.less","../../src/theme/anchors.less","../../src/theme/chapters.less","../../src/theme/ellipsis.less","../../src/theme/toolbar.less"],"names":[],"mappings":"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","file":"example.css","sourcesContent":["/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/* ====== 阴影样式设置函数 ====== */\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n}\n.section__header,\n.section__content,\n.section__footer {\n  margin: 0 3em;\n  overflow: hidden;\n}\n.section__title {\n  color: #666;\n}\n.section__h3 {\n  color: #1f8dd6;\n  font-size: 1.35em;\n}\n.section__h4 {\n  font-size: 1.1em;\n  color: #666;\n}\n.section__h5 {\n  font-size: 1em;\n  color: #999;\n}\n.section__dl,\n.section__dt,\n.section__dd {\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.section__dl {\n  position: relative;\n  z-index: 1;\n}\n.section__dt {\n  display: inline-block;\n}\n.section__dd {\n  display: inline-block;\n  color: #058942;\n}\n.section__pre {\n  margin: 2em 0;\n  padding: 1em;\n  font-size: 14px;\n  line-height: 150%;\n  text-align: left;\n  background-color: #fafafa;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  color: #666;\n  overflow: auto;\n}\n.section__code {\n  display: block;\n  margin: 0 auto;\n  overflow: hidden;\n}\n.section__footer {\n  border-top: 1px solid #ddd;\n  margin-top: 3em;\n  background-color: #fafafa;\n  color: #999;\n}\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  overflow: hidden;\n}\n.case:after {\n  content: '';\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 50%;\n  height: 100%;\n  width: 0;\n  border-left: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__pre,\n.case__textarea {\n  font-size: 13px;\n  line-height: 150%;\n}\n.case__pre,\n.case__code,\n.case__textarea {\n  font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n}\n.case__pre {\n  margin: 0;\n  padding: 1em;\n  background-color: #fafafa;\n  height: 100%;\n  border-radius: 4px;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__toolbar {\n  margin: 0 auto;\n  height: 36px;\n  line-height: 36px;\n  font-size: 14px;\n  padding: 0 16px;\n  text-align: right;\n  overflow: hidden;\n}\n.case__action,\n.case__remove {\n  cursor: pointer;\n  color: #058942;\n  user-select: none;\n}\n.case__action {\n  font-size: 13px;\n  padding-left: 10px;\n}\n.case__action:first-child {\n  padding-left: 0;\n}\n.case__remove {\n  float: right;\n}\n.case__console {\n  margin: 0 auto;\n  height: 180px;\n  border: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__textarea {\n  margin: 0 auto;\n  width: 100%;\n  height: 100%;\n  border: none;\n  outline: none;\n  padding: 1em;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__list,\n.case__item {\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.case__list {\n  height: 360px;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  font-size: 13px;\n  overflow: auto;\n}\n.case__item {\n  height: 36px;\n  line-height: 36px;\n  cursor: pointer;\n  padding: 0 16px;\n}\n.case__item:hover {\n  background-color: #f7f8f9;\n}\n.paper {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  margin: 2em auto;\n  max-width: 1200px;\n  padding: 2em;\n  background-color: #fff;\n  box-sizing: border-box;\n}\n.paper.flex {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  margin: 0;\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  padding: 0;\n  overflow: hidden;\n}\n.paper.flex .article {\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n}\n.paper.flex .article__main {\n  height: 100%;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.paper.flex .article__aside {\n  border-right: 1px solid #dcdfe6;\n}\n.header {\n  position: sticky;\n  z-index: 3;\n  top: 0;\n  margin: 0 auto;\n  border-bottom: 1px solid #ddd;\n  background-color: #fff;\n  text-align: center;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.header_sticky {\n  padding-left: 260px;\n}\n.article {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  padding: 2em 0;\n  font-size: 16px;\n  line-height: 150%;\n}\n.article__main {\n  flex: 1;\n  padding: 0 2em;\n  overflow: hidden;\n}\n.article__main .section {\n  overflow: visible;\n}\n.article__main .section__content,\n.article__main .section__footer,\n.article__main .section__header {\n  overflow: visible;\n}\n.article__main .section__header,\n.article__main .section__content {\n  margin: 0;\n}\n.article__aside {\n  flex-shrink: 0;\n  width: 240px;\n  border-left: 1px solid #ddd;\n  transition-duration: 0.3s;\n}\n.article__aside.ltr {\n  border-right: 1px solid #ddd;\n  border-left: none;\n}\n.article__aside .outline-chapters {\n  background-color: #fff;\n}\npre,\n.section__pre {\n  padding: 2em;\n  font-family: \"Courier New\", Arial, sans-serif;\n  background-color: #fafafa;\n  overflow: auto;\n}\ncode,\n.section__code {\n  font-family: \"Courier New\", Arial, sans-serif;\n  font-size: 16px;\n}\n.footer {\n  border-top: 1px solid #dcdfe6;\n  padding: 3em 0;\n  text-align: center;\n}\n.footer a:link,\n.footer a:visited,\n.footer a:hover {\n  text-decoration: none;\n  color: #058942;\n}\n.footer a:hover {\n  text-decoration: underline;\n}\n.utils-border-right {\n  border-right: 1px solid #dcdfe6;\n}\n.hidden {\n  display: none;\n}\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n:root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","@import 'colors';\n\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n\n  &__header,\n  &__content,\n  &__footer {\n    margin: 0 3em;\n    overflow: hidden;\n  }\n\n  &__title {\n    color: @third_text_color;\n  }\n\n  &__h3 {\n    color: @primary_color;\n    font-size: 1.35em;\n  }\n\n  &__h4 {\n    font-size: 1.1em;\n    color: @third_text_color;\n  }\n\n  &__h5 {\n    font-size: 1em;\n    color: @fourth_text_color;\n  }\n\n  &__dl,\n  &__dt,\n  &__dd {\n    margin: 0;\n    padding: 0;\n    overflow: hidden;\n  }\n\n  &__dl {\n    position: relative;\n    z-index: 1;\n  }\n\n  &__dt {\n    display:inline-block;\n  }\n\n  &__dd {\n    display:inline-block;\n    color: @success_color;\n  }\n\n  &__pre {\n    margin: 2em 0;\n    padding: 1em;\n    font-size: 14px;\n    line-height: 150%;\n    text-align: left;\n    background-color: @bg_color;\n    border: 1px solid @border_color;\n    border-radius: 4px;\n    color: @third_text_color;\n    overflow: auto;\n  }\n\n  &__code {\n    display: block;\n    margin: 0 auto;\n    overflow: hidden;\n  }\n\n  &__footer {\n    border-top: 1px solid @border_color;\n    margin-top: 3em;\n    background-color: @bg_color;\n    color: @fourth_text_color;\n  }\n}\n","@import './colors';\n\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top:1px solid @border_color;\n  border-bottom:1px solid @border_color;\n  overflow: hidden;\n\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 2;\n    top: 0;\n    left: 50%;\n    height: 100%;\n    width: 0;\n    border-left: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__pre,\n  &__textarea {\n    font-size: 13px;\n    line-height: 150%;\n  }\n\n  &__pre,\n  &__code,\n  &__textarea {\n    font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n  }\n\n  &__pre {\n    margin: 0;\n    padding: 1em;\n    background-color: @bg_color;\n    height: 100%;\n    border-radius: 4px;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__toolbar {\n    margin: 0 auto;\n    height: 36px;\n    line-height: 36px;\n    font-size: 14px;\n    padding: 0 16px;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__action,\n  &__remove {\n    cursor: pointer;\n    color: @success_color;\n    user-select: none;\n  }\n\n  &__action {\n    font-size: 13px;\n    padding-left: 10px;\n\n    &:first-child {\n      padding-left: 0;\n    }\n  }\n\n  &__remove {\n    float: right;\n  }\n\n  &__console {\n    margin: 0 auto;\n    height: 180px;\n    border: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__textarea {\n    margin: 0 auto;\n    width: 100%;\n    height: 100%;\n    border: none;\n    outline: none;\n    padding: 1em;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__list,\n  &__item {\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    height: 360px;\n    border-top: 1px solid @border_color;\n    border-bottom: 1px solid @border_color;\n    font-size: 13px;\n    overflow: auto;\n  }\n\n  &__item {\n    height: 36px;\n    line-height: 36px;\n    cursor: pointer;\n    padding: 0 16px;\n\n    &:hover {\n      background-color: @hover_bg_color;\n    }\n  }\n}\n",".paper {\r\n  .shadow_light_regular();\r\n  margin: 2em auto;\r\n  max-width: 1200px;\r\n  padding: 2em;\r\n  background-color: @white;\r\n  box-sizing: border-box;\r\n\r\n  &.flex {\r\n    display: flex;\r\n    flex-direction: row;\r\n    flex-wrap: nowrap;\r\n    margin: 0;\r\n    width: 100%;\r\n    max-width: 100%;\r\n    height: 100%;\r\n    padding: 0;\r\n    overflow: hidden;\r\n\r\n    .article {\r\n      flex-direction: column;\r\n      width: 100%;\r\n      box-sizing: border-box;\r\n\r\n      &__main {\r\n        height: 100%;\r\n        box-sizing: border-box;\r\n        overflow: auto;\r\n      }\r\n\r\n      &__aside {\r\n        border-right: 1px solid @primary_border_color;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n.header {\r\n  position: sticky;\r\n  z-index: 3;\r\n  top: 0;\r\n  margin: 0 auto;\r\n  border-bottom: 1px solid @border_color;\r\n  background-color: @white;\r\n  text-align: center;\r\n  transition-duration: 0.3s;\r\n  overflow: hidden;\r\n\r\n  &_sticky {\r\n    padding-left: 260px;\r\n  }\r\n}\r\n\r\n.article {\r\n  display: flex;\r\n  flex-direction: row;\r\n  flex-wrap: nowrap;\r\n  padding: 2em 0;\r\n  font-size: 16px;\r\n  line-height: 150%;\r\n\r\n  &__main {\r\n    flex: 1;\r\n    padding: 0 2em;\r\n    overflow: hidden;\r\n\r\n    .section {\r\n      overflow: visible;\r\n\r\n      &__content,\r\n      &__footer,\r\n      &__header {\r\n        overflow: visible;\r\n      }\r\n\r\n      &__header,\r\n      &__content {\r\n        margin: 0;\r\n      }\r\n    }\r\n  }\r\n\r\n  &__aside {\r\n    flex-shrink: 0;\r\n    width: 240px;\r\n    border-left: 1px solid @border_color;\r\n    transition-duration: 0.3s;\r\n\r\n    &.ltr {\r\n      border-right: 1px solid @border_color;\r\n      border-left: none;\r\n    }\r\n\r\n    .outline-chapters {\r\n      background-color: @white;\r\n    }\r\n  }\r\n}\r\n\r\npre,\r\n.section__pre {\r\n  padding: 2em;\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  background-color: @bg_color;\r\n  overflow: auto;\r\n}\r\n\r\ncode,\r\n.section__code {\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  font-size: 16px;\r\n}\r\n\r\n.footer {\r\n  border-top: 1px solid @primary_border_color;\r\n  padding: 3em 0;\r\n  text-align: center;\r\n\r\n  a {\r\n    &:link,\r\n    &:visited,\r\n    &:hover {\r\n      text-decoration: none;\r\n      color: @success_color;\r\n    }\r\n\r\n    &:hover {\r\n      text-decoration: underline;\r\n    }\r\n  }\r\n}\r\n\r\n.utils-border-right {\r\n  border-right: 1px solid @primary_border_color;\r\n}\r\n\r\n.hidden {\r\n  display: none;\r\n}\r\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n"]} */ +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../<input css 2>","scrollbar.less","section.less","case.less","pager.less","../../src/theme/shadow.less","../../src/theme/icons.less","../../src/theme/variables.less","../../src/theme/drawer.less","../../src/theme/anchors.less","../../src/theme/chapters.less","../../src/theme/ellipsis.less","../../src/theme/toolbar.less","../../src/theme/print.less"],"names":[],"mappings":"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","file":"example.css","sourcesContent":["/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/* ====== 阴影样式设置函数 ====== */\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n}\n.section__header,\n.section__content,\n.section__footer {\n  margin: 0 3em;\n  overflow: hidden;\n}\n.section__title {\n  color: #666;\n}\n.section__h3 {\n  color: #1f8dd6;\n  font-size: 1.35em;\n}\n.section__h4 {\n  font-size: 1.1em;\n  color: #666;\n}\n.section__h5 {\n  font-size: 1em;\n  color: #999;\n}\n.section__dl,\n.section__dt,\n.section__dd {\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.section__dl {\n  position: relative;\n  z-index: 1;\n}\n.section__dt {\n  display: inline-block;\n}\n.section__dd {\n  display: inline-block;\n  color: #058942;\n}\n.section__pre {\n  margin: 2em 0;\n  padding: 1em;\n  font-size: 14px;\n  line-height: 150%;\n  text-align: left;\n  background-color: #fafafa;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  color: #666;\n  overflow: auto;\n}\n.section__code {\n  display: block;\n  margin: 0 auto;\n  overflow: hidden;\n}\n.section__footer {\n  border-top: 1px solid #ddd;\n  margin-top: 3em;\n  background-color: #fafafa;\n  color: #999;\n}\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  overflow: hidden;\n}\n.case:after {\n  content: '';\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 50%;\n  height: 100%;\n  width: 0;\n  border-left: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__pre,\n.case__textarea {\n  font-size: 13px;\n  line-height: 150%;\n}\n.case__pre,\n.case__code,\n.case__textarea {\n  font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n}\n.case__pre {\n  margin: 0;\n  padding: 1em;\n  background-color: #fafafa;\n  height: 100%;\n  border-radius: 4px;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__toolbar {\n  margin: 0 auto;\n  height: 36px;\n  line-height: 36px;\n  font-size: 14px;\n  padding: 0 16px;\n  text-align: right;\n  overflow: hidden;\n}\n.case__action,\n.case__remove {\n  cursor: pointer;\n  color: #058942;\n  user-select: none;\n}\n.case__action {\n  font-size: 13px;\n  padding-left: 10px;\n}\n.case__action:first-child {\n  padding-left: 0;\n}\n.case__remove {\n  float: right;\n}\n.case__console {\n  margin: 0 auto;\n  height: 180px;\n  border: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__textarea {\n  margin: 0 auto;\n  width: 100%;\n  height: 100%;\n  border: none;\n  outline: none;\n  padding: 1em;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__list,\n.case__item {\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.case__list {\n  height: 360px;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  font-size: 13px;\n  overflow: auto;\n}\n.case__item {\n  height: 36px;\n  line-height: 36px;\n  cursor: pointer;\n  padding: 0 16px;\n}\n.case__item:hover {\n  background-color: #f7f8f9;\n}\n.paper {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  margin: 2em auto;\n  max-width: 1200px;\n  padding: 2em;\n  background-color: #fff;\n  box-sizing: border-box;\n}\n.paper.flex {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  margin: 0;\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  padding: 0;\n  overflow: hidden;\n}\n.paper.flex .article {\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n}\n.paper.flex .article__main {\n  height: 100%;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.paper.flex .article__aside {\n  border-right: 1px solid #dcdfe6;\n}\n.header {\n  position: sticky;\n  z-index: 3;\n  top: 0;\n  margin: 0 auto;\n  border-bottom: 1px solid #ddd;\n  background-color: #fff;\n  text-align: center;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.header_sticky {\n  padding-left: 260px;\n}\n.article {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  padding: 2em 0;\n  font-size: 16px;\n  line-height: 150%;\n}\n.article__main {\n  flex: 1;\n  padding: 0 2em;\n  overflow: hidden;\n}\n.article__main .section {\n  overflow: visible;\n}\n.article__main .section__content,\n.article__main .section__footer,\n.article__main .section__header {\n  overflow: visible;\n}\n.article__main .section__header,\n.article__main .section__content {\n  margin: 0;\n}\n.article__aside {\n  flex-shrink: 0;\n  width: 240px;\n  border-left: 1px solid #ddd;\n  transition-duration: 0.3s;\n}\n.article__aside.ltr {\n  border-right: 1px solid #ddd;\n  border-left: none;\n}\n.article__aside .outline-chapters {\n  background-color: #fff;\n}\npre,\n.section__pre {\n  padding: 2em;\n  font-family: \"Courier New\", Arial, sans-serif;\n  background-color: #fafafa;\n  overflow: auto;\n}\ncode,\n.section__code {\n  font-family: \"Courier New\", Arial, sans-serif;\n  font-size: 16px;\n}\n.footer {\n  border-top: 1px solid #dcdfe6;\n  padding: 3em 0;\n  text-align: center;\n}\n.footer a:link,\n.footer a:visited,\n.footer a:hover {\n  text-decoration: none;\n  color: #058942;\n}\n.footer a:hover {\n  text-decoration: underline;\n}\n.utils-border-right {\n  border-right: 1px solid #dcdfe6;\n}\n.hidden {\n  display: none;\n}\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n:root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n.outline-print {\n  display: none;\n}\n@media print {\n  html,\n  body {\n    height: initial !important;\n  }\n  .outline-print {\n    display: block !important;\n    overflow: hidden;\n  }\n  .outline-print h1 {\n    text-align: center;\n    font-size: 20pt;\n    font-family: 'Microsoft YaHei UI', Arial, sans-serif;\n    font-weight: normal;\n  }\n  .outline-print pre {\n    padding: 1em !important;\n    border: 1px solid #ddd !important;\n    border-radius: 4px !important;\n  }\n  .outline-print pre,\n  .outline-print code {\n    background-color: #fff !important;\n  }\n  .outline-print table,\n  .outline-print img,\n  .outline-print svg {\n    break-inside: avoid;\n  }\n  .outline-print_sibling {\n    display: none !important;\n  }\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","@import 'colors';\n\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n\n  &__header,\n  &__content,\n  &__footer {\n    margin: 0 3em;\n    overflow: hidden;\n  }\n\n  &__title {\n    color: @third_text_color;\n  }\n\n  &__h3 {\n    color: @primary_color;\n    font-size: 1.35em;\n  }\n\n  &__h4 {\n    font-size: 1.1em;\n    color: @third_text_color;\n  }\n\n  &__h5 {\n    font-size: 1em;\n    color: @fourth_text_color;\n  }\n\n  &__dl,\n  &__dt,\n  &__dd {\n    margin: 0;\n    padding: 0;\n    overflow: hidden;\n  }\n\n  &__dl {\n    position: relative;\n    z-index: 1;\n  }\n\n  &__dt {\n    display:inline-block;\n  }\n\n  &__dd {\n    display:inline-block;\n    color: @success_color;\n  }\n\n  &__pre {\n    margin: 2em 0;\n    padding: 1em;\n    font-size: 14px;\n    line-height: 150%;\n    text-align: left;\n    background-color: @bg_color;\n    border: 1px solid @border_color;\n    border-radius: 4px;\n    color: @third_text_color;\n    overflow: auto;\n  }\n\n  &__code {\n    display: block;\n    margin: 0 auto;\n    overflow: hidden;\n  }\n\n  &__footer {\n    border-top: 1px solid @border_color;\n    margin-top: 3em;\n    background-color: @bg_color;\n    color: @fourth_text_color;\n  }\n}\n","@import './colors';\n\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top:1px solid @border_color;\n  border-bottom:1px solid @border_color;\n  overflow: hidden;\n\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 2;\n    top: 0;\n    left: 50%;\n    height: 100%;\n    width: 0;\n    border-left: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__pre,\n  &__textarea {\n    font-size: 13px;\n    line-height: 150%;\n  }\n\n  &__pre,\n  &__code,\n  &__textarea {\n    font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n  }\n\n  &__pre {\n    margin: 0;\n    padding: 1em;\n    background-color: @bg_color;\n    height: 100%;\n    border-radius: 4px;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__toolbar {\n    margin: 0 auto;\n    height: 36px;\n    line-height: 36px;\n    font-size: 14px;\n    padding: 0 16px;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__action,\n  &__remove {\n    cursor: pointer;\n    color: @success_color;\n    user-select: none;\n  }\n\n  &__action {\n    font-size: 13px;\n    padding-left: 10px;\n\n    &:first-child {\n      padding-left: 0;\n    }\n  }\n\n  &__remove {\n    float: right;\n  }\n\n  &__console {\n    margin: 0 auto;\n    height: 180px;\n    border: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__textarea {\n    margin: 0 auto;\n    width: 100%;\n    height: 100%;\n    border: none;\n    outline: none;\n    padding: 1em;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__list,\n  &__item {\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    height: 360px;\n    border-top: 1px solid @border_color;\n    border-bottom: 1px solid @border_color;\n    font-size: 13px;\n    overflow: auto;\n  }\n\n  &__item {\n    height: 36px;\n    line-height: 36px;\n    cursor: pointer;\n    padding: 0 16px;\n\n    &:hover {\n      background-color: @hover_bg_color;\n    }\n  }\n}\n",".paper {\r\n  .shadow_light_regular();\r\n  margin: 2em auto;\r\n  max-width: 1200px;\r\n  padding: 2em;\r\n  background-color: @white;\r\n  box-sizing: border-box;\r\n\r\n  &.flex {\r\n    display: flex;\r\n    flex-direction: row;\r\n    flex-wrap: nowrap;\r\n    margin: 0;\r\n    width: 100%;\r\n    max-width: 100%;\r\n    height: 100%;\r\n    padding: 0;\r\n    overflow: hidden;\r\n\r\n    .article {\r\n      flex-direction: column;\r\n      width: 100%;\r\n      box-sizing: border-box;\r\n\r\n      &__main {\r\n        height: 100%;\r\n        box-sizing: border-box;\r\n        overflow: auto;\r\n      }\r\n\r\n      &__aside {\r\n        border-right: 1px solid @primary_border_color;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n.header {\r\n  position: sticky;\r\n  z-index: 3;\r\n  top: 0;\r\n  margin: 0 auto;\r\n  border-bottom: 1px solid @border_color;\r\n  background-color: @white;\r\n  text-align: center;\r\n  transition-duration: 0.3s;\r\n  overflow: hidden;\r\n\r\n  &_sticky {\r\n    padding-left: 260px;\r\n  }\r\n}\r\n\r\n.article {\r\n  display: flex;\r\n  flex-direction: row;\r\n  flex-wrap: nowrap;\r\n  padding: 2em 0;\r\n  font-size: 16px;\r\n  line-height: 150%;\r\n\r\n  &__main {\r\n    flex: 1;\r\n    padding: 0 2em;\r\n    overflow: hidden;\r\n\r\n    .section {\r\n      overflow: visible;\r\n\r\n      &__content,\r\n      &__footer,\r\n      &__header {\r\n        overflow: visible;\r\n      }\r\n\r\n      &__header,\r\n      &__content {\r\n        margin: 0;\r\n      }\r\n    }\r\n  }\r\n\r\n  &__aside {\r\n    flex-shrink: 0;\r\n    width: 240px;\r\n    border-left: 1px solid @border_color;\r\n    transition-duration: 0.3s;\r\n\r\n    &.ltr {\r\n      border-right: 1px solid @border_color;\r\n      border-left: none;\r\n    }\r\n\r\n    .outline-chapters {\r\n      background-color: @white;\r\n    }\r\n  }\r\n}\r\n\r\npre,\r\n.section__pre {\r\n  padding: 2em;\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  background-color: @bg_color;\r\n  overflow: auto;\r\n}\r\n\r\ncode,\r\n.section__code {\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  font-size: 16px;\r\n}\r\n\r\n.footer {\r\n  border-top: 1px solid @primary_border_color;\r\n  padding: 3em 0;\r\n  text-align: center;\r\n\r\n  a {\r\n    &:link,\r\n    &:visited,\r\n    &:hover {\r\n      text-decoration: none;\r\n      color: @success_color;\r\n    }\r\n\r\n    &:hover {\r\n      text-decoration: underline;\r\n    }\r\n  }\r\n}\r\n\r\n.utils-border-right {\r\n  border-right: 1px solid @primary_border_color;\r\n}\r\n\r\n.hidden {\r\n  display: none;\r\n}\r\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n","@import './colors';\r\n\r\n.outline-print {\r\n  display: none;\r\n}\r\n\r\n@media print {\r\n  html,\r\n  body {\r\n    height: initial !important;\r\n  }\r\n\r\n  .outline-print {\r\n    display: block !important;\r\n    overflow: hidden;\r\n\r\n    h1 {\r\n      text-align: center;\r\n      font-size: 20pt;\r\n      font-family: 'Microsoft YaHei UI', Arial, sans-serif;\r\n      font-weight: normal;\r\n    }\r\n\r\n    pre {\r\n      padding: 1em !important;\r\n      border: 1px solid @border_color !important;\r\n      border-radius: 4px !important;\r\n    }\r\n\r\n    pre,\r\n    code {\r\n      background-color: @white !important;\r\n    }\r\n\r\n    table,\r\n    img,\r\n    svg {\r\n      break-inside: avoid;\r\n    }\r\n\r\n    &_sibling {\r\n      display: none !important;\r\n    }\r\n  }\r\n}\r\n"]} */ diff --git a/docs/css/example.min.css b/docs/css/example.min.css index ed3bf5bc..afdf97a5 100644 --- a/docs/css/example.min.css +++ b/docs/css/example.min.css @@ -1,2 +1,2 @@ -.section__dd,.section__dt{display:inline-block}.case,.section__dl{position:relative;z-index:1}.case:after,.outline-drawer__overlay{content:''}.case,.section__footer{border-top:1px solid #ddd}::-webkit-scrollbar{width:7px;height:7px;-webkit-border-radius:5px}::-webkit-scrollbar-track-piece{-webkit-border-radius:5px}::-webkit-scrollbar-thumb:vertical{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar-thumb:horizontal{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar:hover{background-color:rgba(0,0,0,.15)}::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.35)}.section{margin:1em 0;overflow:hidden}.section__content,.section__footer,.section__header{margin:0 3em;overflow:hidden}.section__title{color:#666}.section__h3{color:#1f8dd6;font-size:1.35em}.section__h4{font-size:1.1em;color:#666}.section__h5{font-size:1em;color:#999}.section__dd,.section__dl,.section__dt{margin:0;padding:0;overflow:hidden}.section__dd{color:#058942}.section__pre{margin:2em 0;font-size:14px;line-height:150%;text-align:left;border:1px solid #ddd;border-radius:4px;color:#666}.section__code{display:block;margin:0 auto;overflow:hidden}.section__footer{margin-top:3em;background-color:#fafafa;color:#999}.case{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;padding:1em;border-bottom:1px solid #ddd;overflow:hidden}.case:after{position:absolute;z-index:2;top:0;left:50%;height:100%;width:0;border-left:1px solid #ddd;overflow:hidden}.case__pre,.case__textarea{font-size:13px;line-height:150%}.case__code,.case__pre,.case__textarea{font-family:"Courier New",Consolas,Georgia,Arial,sans-serif}.case__pre{margin:0;padding:1em;background-color:#fafafa;height:100%;border-radius:4px;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:auto}.case__textarea,.paper,.paper.flex .article{-webkit-box-sizing:border-box}.case__toolbar{margin:0 auto;height:36px;line-height:36px;font-size:14px;padding:0 16px;text-align:right;overflow:hidden}.case__action,.case__remove{cursor:pointer;color:#058942;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.case__action{font-size:13px;padding-left:10px}.case__action:first-child{padding-left:0}.case__remove{float:right}.case__console{margin:0 auto;height:180px;border:1px solid #ddd;overflow:hidden}.case__textarea{margin:0 auto;width:100%;height:100%;border:none;outline:0;padding:1em;box-sizing:border-box;overflow:auto}.case__list,.header{border-bottom:1px solid #ddd}.case__item,.case__list{margin:0;padding:0;list-style-type:none;overflow:hidden}.case__list{height:360px;border-top:1px solid #ddd;font-size:13px;overflow:auto}.footer,.outline-drawer_btt{border-top:1px solid #dcdfe6}.case__item{height:36px;line-height:36px;cursor:pointer;padding:0 16px}.case__item:hover{background-color:#f7f8f9}.article__aside .outline-chapters,.header,.outline-drawer__modal,.outline-drawer__overlay,.paper{background-color:#fff}.paper{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;margin:2em auto;max-width:1200px;padding:2em;box-sizing:border-box}.paper.flex{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-ms-flex-wrap:nowrap;flex-wrap:nowrap;margin:0;width:100%;max-width:100%;height:100%;padding:0;overflow:hidden}.outline-chapters_fixed,.outline-chapters_sticky,.outline-drawer__modal,.paper.flex .article{-webkit-box-orient:vertical;-webkit-box-direction:normal}.paper.flex .article{-ms-flex-direction:column;flex-direction:column;width:100%;box-sizing:border-box}.paper.flex .article__main{height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:auto}.paper.flex .article__aside{border-right:1px solid #dcdfe6}.header{position:sticky;z-index:3;top:0;margin:0 auto;text-align:center;-webkit-transition-duration:.3s;transition-duration:.3s;overflow:hidden}.header_sticky{padding-left:260px}.article{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-ms-flex-wrap:nowrap;flex-wrap:nowrap;padding:2em 0;font-size:16px;line-height:150%}.hidden,.outline-heading__anchor{display:none}.article__main{-webkit-box-flex:1;-ms-flex:1;flex:1;padding:0 2em;overflow:hidden}.article__main .section,.article__main .section__content,.article__main .section__footer,.article__main .section__header{overflow:visible}.article__main .section__content,.article__main .section__header{margin:0}.article__aside{-ms-flex-negative:0;flex-shrink:0;width:240px;border-left:1px solid #ddd;-webkit-transition-duration:.3s;transition-duration:.3s}.article__aside.ltr{border-right:1px solid #ddd;border-left:none}.outline-drawer_ltr,.utils-border-right{border-right:1px solid #dcdfe6}.section__pre,pre{padding:2em;font-family:"Courier New",Arial,sans-serif;background-color:#fafafa;overflow:auto}.section__code,code{font-family:"Courier New",Arial,sans-serif;font-size:16px}.footer{padding:3em 0;text-align:center}.footer a:hover,.footer a:link,.footer a:visited{text-decoration:none;color:#058942}.footer a:hover{text-decoration:underline}.outline-icon{position:relative;z-index:1;display:inline-block;vertical-align:middle;width:1em;height:1em;overflow:hidden}.outline-icon__svg{position:absolute;z-index:2;top:50%;left:50%;width:1em;height:1em;fill:currentcolor;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);overflow:hidden}:root{--outline-zIndex:2000;--outline-sticky-height:100%;--outline-chapters-width:100%}.outline-drawer{position:relative;z-index:-1;top:0;left:0;margin:0;width:100%;height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;visibility:hidden;overflow:hidden}.outline-drawer__modal{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-wrap:nowrap;flex-wrap:nowrap;position:absolute;z-index:21;height:100%;-webkit-transition-duration:.4s;transition-duration:.4s;overflow:hidden}.outline-drawer__footer,.outline-drawer__header,.outline-drawer__main{width:100%;-webkit-box-sizing:border-box;box-sizing:border-box}.outline-drawer__footer,.outline-drawer__header{-ms-flex-negative:0;flex-shrink:0}.outline-drawer__footer,.outline-drawer__main,.outline-drawer__title{padding:0 16px}.outline-drawer__header,.outline-drawer__title{position:relative;z-index:1;margin:0 auto;height:52px;line-height:52px;overflow:hidden}.outline-drawer__title{font-size:16px;font-weight:400;margin:0 16px;-webkit-box-sizing:border-box;box-sizing:border-box;border-bottom:1px solid #dcdfe6}.outline-drawer__close{position:absolute;z-index:2;top:50%;right:12px;width:20px;height:20px;line-height:20px;color:#999;font-size:20px;text-align:center;cursor:pointer;-webkit-transform:translateY(-50%);transform:translateY(-50%);overflow:hidden}.outline-drawer__close .outline-icon{position:absolute;z-index:2;top:0;left:0}.outline-drawer__close:hover{color:#666}.outline-drawer__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-drawer__footer{margin:0 auto;text-align:right;overflow:hidden}.outline-drawer__overlay{position:relative;z-index:1;top:0;left:0;width:100%;height:100%;opacity:.1;overflow:hidden}.outline-drawer_ltr.outline-drawer_tiny,.outline-drawer_rtl.outline-drawer_tiny{width:280px}.outline-drawer_ltr.outline-drawer_mini,.outline-drawer_rtl.outline-drawer_mini{width:480px}.outline-drawer_ltr.outline-drawer_small,.outline-drawer_rtl.outline-drawer_small{width:540px}.outline-drawer_ltr.outline-drawer_regular,.outline-drawer_rtl.outline-drawer_regular{width:680px}.outline-drawer_ltr.outline-drawer_medium,.outline-drawer_rtl.outline-drawer_medium{width:720px}.outline-drawer_ltr.outline-drawer_large,.outline-drawer_rtl.outline-drawer_large{width:960px}.outline-drawer_rtl{border-left:1px solid #dcdfe6}.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed{right:-290px}.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed{right:-490px}.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed{right:-550px}.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed{right:-690px}.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed{right:-730px}.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed{right:-970px}.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed{left:-290px}.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed{left:-490px}.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed{left:-550px}.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed{left:-690px}.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed{left:-730px}.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed{left:-970px}.outline-drawer_btt,.outline-drawer_ttb{left:0;width:100%}.outline-drawer_btt.outline-drawer_tiny,.outline-drawer_ttb.outline-drawer_tiny{height:240px}.outline-drawer_btt.outline-drawer_mini,.outline-drawer_ttb.outline-drawer_mini{height:320px}.outline-drawer_btt.outline-drawer_small,.outline-drawer_ttb.outline-drawer_small{height:360px}.outline-drawer_btt.outline-drawer_regular,.outline-drawer_ttb.outline-drawer_regular{height:400px}.outline-drawer_btt.outline-drawer_medium,.outline-drawer_ttb.outline-drawer_medium{height:440px}.outline-drawer_btt.outline-drawer_large,.outline-drawer_ttb.outline-drawer_large{height:480px}.outline-drawer_ttb{border-bottom:1px solid #dcdfe6}.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed{top:-250px}.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed{top:-330px}.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed{top:-370px}.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed{top:-410px}.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed{top:-450px}.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed{top:-490px}.outline-drawer_btt{top:initial}.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed{bottom:-250px}.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed{bottom:-330px}.outline-drawer_btt.outline-drawer_small.outline-drawer_closed{bottom:-370px}.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed{bottom:-410px}.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed{bottom:-450px}.outline-drawer_btt.outline-drawer_large.outline-drawer_closed{bottom:-490px}.outline-drawer_opened{visibility:visible;z-index:var(--outline-zIndex)}.outline-drawer_opened.outline-drawer{position:fixed}.outline-drawer_opened.outline-drawer_rtl{right:0}.outline-drawer_opened.outline-drawer_ltr{left:0}.outline-drawer_opened.outline-drawer_ttb{top:0}.outline-drawer_opened.outline-drawer_btt{bottom:0}.outline-drawer_offset.outline-drawer_ltr,.outline-drawer_offset.outline-drawer_rtl{height:calc(100% - 4em);top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.outline-drawer_offset.outline-drawer_btt,.outline-drawer_offset.outline-drawer_ttb{width:calc(100% - 4em);left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl{right:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr{left:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb{top:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt{bottom:2em}.outline-drawer_auto.outline-drawer_ltr,.outline-drawer_auto.outline-drawer_rtl{height:auto;max-height:calc(100% - 4em)}.outline-drawer_full{padding:0}.outline-heading{position:relative;z-index:1;overflow:hidden}.outline-heading__anchor:hover,.outline-heading__anchor:link,.outline-heading__anchor:visited{color:#999;text-decoration:none}.outline-heading__anchor:hover{color:#1f8dd6}.outline-heading:hover .outline-heading__anchor{display:inline-block}.outline-heading_start:hover{overflow:visible}.outline-heading_start .outline-heading__anchor{position:absolute;z-index:2;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);left:-1em}.outline-chapters{position:relative;z-index:1;margin:0;width:var(--outline-chapters-width);-webkit-transition-duration:.3s;transition-duration:.3s;overflow:auto}.outline-chapters__title{margin:0 16px;height:40px;line-height:40px;padding:0 16px;border-bottom:1px solid #dcdfe6;font-size:16px;font-weight:400;overflow:hidden}.outline-chapters__main{position:relative;z-index:1;margin:0;overflow:hidden}.outline-chapters__item,.outline-chapters__list,.outline-chapters__subject{position:relative;z-index:2;margin:0;padding:0;list-style-type:none;overflow:hidden}.outline-chapters__list{padding:.5em 0}.outline-chapters__subject{padding-left:1em}.outline-chapters__item{margin:0;line-height:30px;font-size:13px;overflow:hidden}.outline-chapters__placeholder{position:absolute;z-index:1;top:0;left:0;width:100%;height:30px;background-color:#f7f8f9;border-left:2px solid #058942;-webkit-transition-duration:.2s;transition-duration:.2s;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.outline-chapters__anchor{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:block;padding:0 1.5em}.outline-chapters__anchor:hover,.outline-chapters__anchor:link,.outline-chapters__anchor:visited{text-decoration:none;color:#555}.outline-chapters__anchor:hover{color:#058942}.outline-chapters__code{padding-right:.5em}.outline-chapters_active.outline-chapters__anchor:hover,.outline-chapters_active.outline-chapters__anchor:link,.outline-chapters_active.outline-chapters__anchor:visited{color:#058942;font-weight:400}.outline-chapters_fixed,.outline-chapters_sticky{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-ms-flex-direction:column;flex-direction:column;z-index:var(--outline-zIndex);top:0;overflow:hidden}.outline-chapters_hidden,.outline-toolbar__button.hide{display:none}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__main,.outline-chapters_sticky .outline-chapters__title{-webkit-box-sizing:border-box;box-sizing:border-box}.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__title{-ms-flex-negative:0;flex-shrink:0}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_sticky .outline-chapters__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-chapters_sticky{position:sticky;max-height:var(--outline-sticky-height)}.outline-chapters_fixed{position:fixed;max-height:100%}.outline-chapters_folded{width:0}.outline-toolbar{position:fixed;z-index:99999;margin:0;-webkit-transition-duration:.3s;transition-duration:.3s;overflow:hidden}.outline-toolbar__button{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;position:relative;z-index:1;margin:10px;width:36px;height:36px;border:1px solid #dcdfe6;border-radius:3px;-webkit-box-sizing:border-box;box-sizing:border-box;background-color:#fff;cursor:pointer;text-align:center;color:#555;overflow:hidden}.outline-toolbar__button:hover{color:#058942;border-color:#058942}.outline-toolbar__anchor:hover,.outline-toolbar__anchor:link,.outline-toolbar__anchor:visited{color:#999;text-decoration:none}.outline-toolbar__anchor:hover{color:#058942}.outline-toolbar__icon{position:absolute;z-index:2;top:50%;left:50%;width:20px;height:20px;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);fill:currentcolor;overflow:hidden}.outline-toolbar_active.outline-toolbar__button{color:#fff;background-color:#058942;border-color:#058942}.outline-toolbar_active .outline-toolbar__anchor:hover,.outline-toolbar_active .outline-toolbar__anchor:link,.outline-toolbar_active .outline-toolbar__anchor:visited,.outline-toolbar_active.outline-toolbar__button:hover{color:#fff}.outline-toolbar_rounded.outline-toolbar__button{border-radius:18px}.outline-toolbar_disabled .outline-toolbar__anchor:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link,.outline-toolbar_disabled .outline-toolbar__anchor:visited,.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__anchor:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link,.outline-toolbar_disabled.outline-toolbar__anchor:visited,.outline-toolbar_disabled.outline-toolbar__button{cursor:not-allowed;color:#999}.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled .outline-toolbar__button:hover,.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled.outline-toolbar__button:hover{color:#999}.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__button{background-color:#f5f5f5}.outline-toolbar_btt,.outline-toolbar_ttb{left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-toolbar_btt .outline-toolbar__button,.outline-toolbar_ttb .outline-toolbar__button{display:inline-block}.outline-toolbar_ttb{top:12px}.outline-toolbar_ttb.outline-toolbar_hidden{top:-56px}.outline-toolbar_btt{bottom:12px}.outline-toolbar_btt.outline-toolbar_hidden{bottom:-56px}.outline-toolbar_ltr,.outline-toolbar_rtl{-webkit-transform:translateY(-50%);transform:translateY(-50%);width:56px}.outline-toolbar_rtl{top:50%;right:12px}.outline-toolbar_rtl.outline-toolbar_hidden{right:-86px}.outline-toolbar_ltr{top:50%;left:12px}.outline-toolbar_ltr.outline-toolbar_hidden{left:-86px}.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden{display:none} -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"names":[],"mappings":"","sources":["css/example.css"],"sourcesContent":["/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/* ====== 阴影样式设置函数 ====== */\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n}\n.section__header,\n.section__content,\n.section__footer {\n  margin: 0 3em;\n  overflow: hidden;\n}\n.section__title {\n  color: #666;\n}\n.section__h3 {\n  color: #1f8dd6;\n  font-size: 1.35em;\n}\n.section__h4 {\n  font-size: 1.1em;\n  color: #666;\n}\n.section__h5 {\n  font-size: 1em;\n  color: #999;\n}\n.section__dl,\n.section__dt,\n.section__dd {\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.section__dl {\n  position: relative;\n  z-index: 1;\n}\n.section__dt {\n  display: inline-block;\n}\n.section__dd {\n  display: inline-block;\n  color: #058942;\n}\n.section__pre {\n  margin: 2em 0;\n  padding: 1em;\n  font-size: 14px;\n  line-height: 150%;\n  text-align: left;\n  background-color: #fafafa;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  color: #666;\n  overflow: auto;\n}\n.section__code {\n  display: block;\n  margin: 0 auto;\n  overflow: hidden;\n}\n.section__footer {\n  border-top: 1px solid #ddd;\n  margin-top: 3em;\n  background-color: #fafafa;\n  color: #999;\n}\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  overflow: hidden;\n}\n.case:after {\n  content: '';\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 50%;\n  height: 100%;\n  width: 0;\n  border-left: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__pre,\n.case__textarea {\n  font-size: 13px;\n  line-height: 150%;\n}\n.case__pre,\n.case__code,\n.case__textarea {\n  font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n}\n.case__pre {\n  margin: 0;\n  padding: 1em;\n  background-color: #fafafa;\n  height: 100%;\n  border-radius: 4px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: auto;\n}\n.case__toolbar {\n  margin: 0 auto;\n  height: 36px;\n  line-height: 36px;\n  font-size: 14px;\n  padding: 0 16px;\n  text-align: right;\n  overflow: hidden;\n}\n.case__action,\n.case__remove {\n  cursor: pointer;\n  color: #058942;\n  -webkit-user-select: none;\n     -moz-user-select: none;\n      -ms-user-select: none;\n          user-select: none;\n}\n.case__action {\n  font-size: 13px;\n  padding-left: 10px;\n}\n.case__action:first-child {\n  padding-left: 0;\n}\n.case__remove {\n  float: right;\n}\n.case__console {\n  margin: 0 auto;\n  height: 180px;\n  border: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__textarea {\n  margin: 0 auto;\n  width: 100%;\n  height: 100%;\n  border: none;\n  outline: none;\n  padding: 1em;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: auto;\n}\n.case__list,\n.case__item {\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.case__list {\n  height: 360px;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  font-size: 13px;\n  overflow: auto;\n}\n.case__item {\n  height: 36px;\n  line-height: 36px;\n  cursor: pointer;\n  padding: 0 16px;\n}\n.case__item:hover {\n  background-color: #f7f8f9;\n}\n.paper {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  margin: 2em auto;\n  max-width: 1200px;\n  padding: 2em;\n  background-color: #fff;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.paper.flex {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: row;\n          flex-direction: row;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  margin: 0;\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  padding: 0;\n  overflow: hidden;\n}\n.paper.flex .article {\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  width: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.paper.flex .article__main {\n  height: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: auto;\n}\n.paper.flex .article__aside {\n  border-right: 1px solid #dcdfe6;\n}\n.header {\n  position: sticky;\n  z-index: 3;\n  top: 0;\n  margin: 0 auto;\n  border-bottom: 1px solid #ddd;\n  background-color: #fff;\n  text-align: center;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: hidden;\n}\n.header_sticky {\n  padding-left: 260px;\n}\n.article {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: row;\n          flex-direction: row;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  padding: 2em 0;\n  font-size: 16px;\n  line-height: 150%;\n}\n.article__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  padding: 0 2em;\n  overflow: hidden;\n}\n.article__main .section {\n  overflow: visible;\n}\n.article__main .section__content,\n.article__main .section__footer,\n.article__main .section__header {\n  overflow: visible;\n}\n.article__main .section__header,\n.article__main .section__content {\n  margin: 0;\n}\n.article__aside {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n  width: 240px;\n  border-left: 1px solid #ddd;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n}\n.article__aside.ltr {\n  border-right: 1px solid #ddd;\n  border-left: none;\n}\n.article__aside .outline-chapters {\n  background-color: #fff;\n}\npre,\n.section__pre {\n  padding: 2em;\n  font-family: \"Courier New\", Arial, sans-serif;\n  background-color: #fafafa;\n  overflow: auto;\n}\ncode,\n.section__code {\n  font-family: \"Courier New\", Arial, sans-serif;\n  font-size: 16px;\n}\n.footer {\n  border-top: 1px solid #dcdfe6;\n  padding: 3em 0;\n  text-align: center;\n}\n.footer a:link,\n.footer a:visited,\n.footer a:hover {\n  text-decoration: none;\n  color: #058942;\n}\n.footer a:hover {\n  text-decoration: underline;\n}\n.utils-border-right {\n  border-right: 1px solid #dcdfe6;\n}\n.hidden {\n  display: none;\n}\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n:root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  -webkit-transition-duration: 0.4s;\n          transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  left: -1em;\n}\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  -webkit-transition-duration: 0.2s;\n          transition-duration: 0.2s;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../<input css 2>","scrollbar.less","section.less","case.less","pager.less","../../src/theme/shadow.less","../../src/theme/icons.less","../../src/theme/variables.less","../../src/theme/drawer.less","../../src/theme/anchors.less","../../src/theme/chapters.less","../../src/theme/ellipsis.less","../../src/theme/toolbar.less"],"names":[],"mappings":"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","file":"example.css","sourcesContent":["/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/* ====== 阴影样式设置函数 ====== */\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n}\n.section__header,\n.section__content,\n.section__footer {\n  margin: 0 3em;\n  overflow: hidden;\n}\n.section__title {\n  color: #666;\n}\n.section__h3 {\n  color: #1f8dd6;\n  font-size: 1.35em;\n}\n.section__h4 {\n  font-size: 1.1em;\n  color: #666;\n}\n.section__h5 {\n  font-size: 1em;\n  color: #999;\n}\n.section__dl,\n.section__dt,\n.section__dd {\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.section__dl {\n  position: relative;\n  z-index: 1;\n}\n.section__dt {\n  display: inline-block;\n}\n.section__dd {\n  display: inline-block;\n  color: #058942;\n}\n.section__pre {\n  margin: 2em 0;\n  padding: 1em;\n  font-size: 14px;\n  line-height: 150%;\n  text-align: left;\n  background-color: #fafafa;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  color: #666;\n  overflow: auto;\n}\n.section__code {\n  display: block;\n  margin: 0 auto;\n  overflow: hidden;\n}\n.section__footer {\n  border-top: 1px solid #ddd;\n  margin-top: 3em;\n  background-color: #fafafa;\n  color: #999;\n}\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  overflow: hidden;\n}\n.case:after {\n  content: '';\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 50%;\n  height: 100%;\n  width: 0;\n  border-left: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__pre,\n.case__textarea {\n  font-size: 13px;\n  line-height: 150%;\n}\n.case__pre,\n.case__code,\n.case__textarea {\n  font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n}\n.case__pre {\n  margin: 0;\n  padding: 1em;\n  background-color: #fafafa;\n  height: 100%;\n  border-radius: 4px;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__toolbar {\n  margin: 0 auto;\n  height: 36px;\n  line-height: 36px;\n  font-size: 14px;\n  padding: 0 16px;\n  text-align: right;\n  overflow: hidden;\n}\n.case__action,\n.case__remove {\n  cursor: pointer;\n  color: #058942;\n  user-select: none;\n}\n.case__action {\n  font-size: 13px;\n  padding-left: 10px;\n}\n.case__action:first-child {\n  padding-left: 0;\n}\n.case__remove {\n  float: right;\n}\n.case__console {\n  margin: 0 auto;\n  height: 180px;\n  border: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__textarea {\n  margin: 0 auto;\n  width: 100%;\n  height: 100%;\n  border: none;\n  outline: none;\n  padding: 1em;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__list,\n.case__item {\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.case__list {\n  height: 360px;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  font-size: 13px;\n  overflow: auto;\n}\n.case__item {\n  height: 36px;\n  line-height: 36px;\n  cursor: pointer;\n  padding: 0 16px;\n}\n.case__item:hover {\n  background-color: #f7f8f9;\n}\n.paper {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  margin: 2em auto;\n  max-width: 1200px;\n  padding: 2em;\n  background-color: #fff;\n  box-sizing: border-box;\n}\n.paper.flex {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  margin: 0;\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  padding: 0;\n  overflow: hidden;\n}\n.paper.flex .article {\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n}\n.paper.flex .article__main {\n  height: 100%;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.paper.flex .article__aside {\n  border-right: 1px solid #dcdfe6;\n}\n.header {\n  position: sticky;\n  z-index: 3;\n  top: 0;\n  margin: 0 auto;\n  border-bottom: 1px solid #ddd;\n  background-color: #fff;\n  text-align: center;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.header_sticky {\n  padding-left: 260px;\n}\n.article {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  padding: 2em 0;\n  font-size: 16px;\n  line-height: 150%;\n}\n.article__main {\n  flex: 1;\n  padding: 0 2em;\n  overflow: hidden;\n}\n.article__main .section {\n  overflow: visible;\n}\n.article__main .section__content,\n.article__main .section__footer,\n.article__main .section__header {\n  overflow: visible;\n}\n.article__main .section__header,\n.article__main .section__content {\n  margin: 0;\n}\n.article__aside {\n  flex-shrink: 0;\n  width: 240px;\n  border-left: 1px solid #ddd;\n  transition-duration: 0.3s;\n}\n.article__aside.ltr {\n  border-right: 1px solid #ddd;\n  border-left: none;\n}\n.article__aside .outline-chapters {\n  background-color: #fff;\n}\npre,\n.section__pre {\n  padding: 2em;\n  font-family: \"Courier New\", Arial, sans-serif;\n  background-color: #fafafa;\n  overflow: auto;\n}\ncode,\n.section__code {\n  font-family: \"Courier New\", Arial, sans-serif;\n  font-size: 16px;\n}\n.footer {\n  border-top: 1px solid #dcdfe6;\n  padding: 3em 0;\n  text-align: center;\n}\n.footer a:link,\n.footer a:visited,\n.footer a:hover {\n  text-decoration: none;\n  color: #058942;\n}\n.footer a:hover {\n  text-decoration: underline;\n}\n.utils-border-right {\n  border-right: 1px solid #dcdfe6;\n}\n.hidden {\n  display: none;\n}\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n:root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","@import 'colors';\n\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n\n  &__header,\n  &__content,\n  &__footer {\n    margin: 0 3em;\n    overflow: hidden;\n  }\n\n  &__title {\n    color: @third_text_color;\n  }\n\n  &__h3 {\n    color: @primary_color;\n    font-size: 1.35em;\n  }\n\n  &__h4 {\n    font-size: 1.1em;\n    color: @third_text_color;\n  }\n\n  &__h5 {\n    font-size: 1em;\n    color: @fourth_text_color;\n  }\n\n  &__dl,\n  &__dt,\n  &__dd {\n    margin: 0;\n    padding: 0;\n    overflow: hidden;\n  }\n\n  &__dl {\n    position: relative;\n    z-index: 1;\n  }\n\n  &__dt {\n    display:inline-block;\n  }\n\n  &__dd {\n    display:inline-block;\n    color: @success_color;\n  }\n\n  &__pre {\n    margin: 2em 0;\n    padding: 1em;\n    font-size: 14px;\n    line-height: 150%;\n    text-align: left;\n    background-color: @bg_color;\n    border: 1px solid @border_color;\n    border-radius: 4px;\n    color: @third_text_color;\n    overflow: auto;\n  }\n\n  &__code {\n    display: block;\n    margin: 0 auto;\n    overflow: hidden;\n  }\n\n  &__footer {\n    border-top: 1px solid @border_color;\n    margin-top: 3em;\n    background-color: @bg_color;\n    color: @fourth_text_color;\n  }\n}\n","@import './colors';\n\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top:1px solid @border_color;\n  border-bottom:1px solid @border_color;\n  overflow: hidden;\n\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 2;\n    top: 0;\n    left: 50%;\n    height: 100%;\n    width: 0;\n    border-left: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__pre,\n  &__textarea {\n    font-size: 13px;\n    line-height: 150%;\n  }\n\n  &__pre,\n  &__code,\n  &__textarea {\n    font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n  }\n\n  &__pre {\n    margin: 0;\n    padding: 1em;\n    background-color: @bg_color;\n    height: 100%;\n    border-radius: 4px;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__toolbar {\n    margin: 0 auto;\n    height: 36px;\n    line-height: 36px;\n    font-size: 14px;\n    padding: 0 16px;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__action,\n  &__remove {\n    cursor: pointer;\n    color: @success_color;\n    user-select: none;\n  }\n\n  &__action {\n    font-size: 13px;\n    padding-left: 10px;\n\n    &:first-child {\n      padding-left: 0;\n    }\n  }\n\n  &__remove {\n    float: right;\n  }\n\n  &__console {\n    margin: 0 auto;\n    height: 180px;\n    border: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__textarea {\n    margin: 0 auto;\n    width: 100%;\n    height: 100%;\n    border: none;\n    outline: none;\n    padding: 1em;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__list,\n  &__item {\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    height: 360px;\n    border-top: 1px solid @border_color;\n    border-bottom: 1px solid @border_color;\n    font-size: 13px;\n    overflow: auto;\n  }\n\n  &__item {\n    height: 36px;\n    line-height: 36px;\n    cursor: pointer;\n    padding: 0 16px;\n\n    &:hover {\n      background-color: @hover_bg_color;\n    }\n  }\n}\n",".paper {\r\n  .shadow_light_regular();\r\n  margin: 2em auto;\r\n  max-width: 1200px;\r\n  padding: 2em;\r\n  background-color: @white;\r\n  box-sizing: border-box;\r\n\r\n  &.flex {\r\n    display: flex;\r\n    flex-direction: row;\r\n    flex-wrap: nowrap;\r\n    margin: 0;\r\n    width: 100%;\r\n    max-width: 100%;\r\n    height: 100%;\r\n    padding: 0;\r\n    overflow: hidden;\r\n\r\n    .article {\r\n      flex-direction: column;\r\n      width: 100%;\r\n      box-sizing: border-box;\r\n\r\n      &__main {\r\n        height: 100%;\r\n        box-sizing: border-box;\r\n        overflow: auto;\r\n      }\r\n\r\n      &__aside {\r\n        border-right: 1px solid @primary_border_color;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n.header {\r\n  position: sticky;\r\n  z-index: 3;\r\n  top: 0;\r\n  margin: 0 auto;\r\n  border-bottom: 1px solid @border_color;\r\n  background-color: @white;\r\n  text-align: center;\r\n  transition-duration: 0.3s;\r\n  overflow: hidden;\r\n\r\n  &_sticky {\r\n    padding-left: 260px;\r\n  }\r\n}\r\n\r\n.article {\r\n  display: flex;\r\n  flex-direction: row;\r\n  flex-wrap: nowrap;\r\n  padding: 2em 0;\r\n  font-size: 16px;\r\n  line-height: 150%;\r\n\r\n  &__main {\r\n    flex: 1;\r\n    padding: 0 2em;\r\n    overflow: hidden;\r\n\r\n    .section {\r\n      overflow: visible;\r\n\r\n      &__content,\r\n      &__footer,\r\n      &__header {\r\n        overflow: visible;\r\n      }\r\n\r\n      &__header,\r\n      &__content {\r\n        margin: 0;\r\n      }\r\n    }\r\n  }\r\n\r\n  &__aside {\r\n    flex-shrink: 0;\r\n    width: 240px;\r\n    border-left: 1px solid @border_color;\r\n    transition-duration: 0.3s;\r\n\r\n    &.ltr {\r\n      border-right: 1px solid @border_color;\r\n      border-left: none;\r\n    }\r\n\r\n    .outline-chapters {\r\n      background-color: @white;\r\n    }\r\n  }\r\n}\r\n\r\npre,\r\n.section__pre {\r\n  padding: 2em;\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  background-color: @bg_color;\r\n  overflow: auto;\r\n}\r\n\r\ncode,\r\n.section__code {\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  font-size: 16px;\r\n}\r\n\r\n.footer {\r\n  border-top: 1px solid @primary_border_color;\r\n  padding: 3em 0;\r\n  text-align: center;\r\n\r\n  a {\r\n    &:link,\r\n    &:visited,\r\n    &:hover {\r\n      text-decoration: none;\r\n      color: @success_color;\r\n    }\r\n\r\n    &:hover {\r\n      text-decoration: underline;\r\n    }\r\n  }\r\n}\r\n\r\n.utils-border-right {\r\n  border-right: 1px solid @primary_border_color;\r\n}\r\n\r\n.hidden {\r\n  display: none;\r\n}\r\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n"]} */\n"],"file":"css/example.min.css"} */ +.section__dd,.section__dt{display:inline-block}.case,.section__dl{position:relative;z-index:1}.case:after,.outline-drawer__overlay{content:''}.case,.section__footer{border-top:1px solid #ddd}::-webkit-scrollbar{width:7px;height:7px;-webkit-border-radius:5px}::-webkit-scrollbar-track-piece{-webkit-border-radius:5px}::-webkit-scrollbar-thumb:vertical{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar-thumb:horizontal{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar:hover{background-color:rgba(0,0,0,.15)}::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.35)}.section{margin:1em 0;overflow:hidden}.section__content,.section__footer,.section__header{margin:0 3em;overflow:hidden}.section__title{color:#666}.section__h3{color:#1f8dd6;font-size:1.35em}.section__h4{font-size:1.1em;color:#666}.section__h5{font-size:1em;color:#999}.section__dd,.section__dl,.section__dt{margin:0;padding:0;overflow:hidden}.section__dd{color:#058942}.section__pre{margin:2em 0;font-size:14px;line-height:150%;text-align:left;border:1px solid #ddd;border-radius:4px;color:#666}.section__code{display:block;margin:0 auto;overflow:hidden}.section__footer{margin-top:3em;background-color:#fafafa;color:#999}.case{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;padding:1em;border-bottom:1px solid #ddd;overflow:hidden}.case:after{position:absolute;z-index:2;top:0;left:50%;height:100%;width:0;border-left:1px solid #ddd;overflow:hidden}.case__pre,.case__textarea{font-size:13px;line-height:150%}.case__code,.case__pre,.case__textarea{font-family:"Courier New",Consolas,Georgia,Arial,sans-serif}.case__pre{margin:0;padding:1em;background-color:#fafafa;height:100%;border-radius:4px;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:auto}.case__textarea,.paper,.paper.flex .article{-webkit-box-sizing:border-box}.case__toolbar{margin:0 auto;height:36px;line-height:36px;font-size:14px;padding:0 16px;text-align:right;overflow:hidden}.case__action,.case__remove{cursor:pointer;color:#058942;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.case__action{font-size:13px;padding-left:10px}.case__action:first-child{padding-left:0}.case__remove{float:right}.case__console{margin:0 auto;height:180px;border:1px solid #ddd;overflow:hidden}.case__textarea{margin:0 auto;width:100%;height:100%;border:none;outline:0;padding:1em;box-sizing:border-box;overflow:auto}.case__list,.header{border-bottom:1px solid #ddd}.case__item,.case__list{margin:0;padding:0;list-style-type:none;overflow:hidden}.case__list{height:360px;border-top:1px solid #ddd;font-size:13px;overflow:auto}.footer,.outline-drawer_btt{border-top:1px solid #dcdfe6}.case__item{height:36px;line-height:36px;cursor:pointer;padding:0 16px}.case__item:hover{background-color:#f7f8f9}.article__aside .outline-chapters,.header,.outline-drawer__modal,.outline-drawer__overlay,.paper{background-color:#fff}.paper{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;margin:2em auto;max-width:1200px;padding:2em;box-sizing:border-box}.paper.flex{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-ms-flex-wrap:nowrap;flex-wrap:nowrap;margin:0;width:100%;max-width:100%;height:100%;padding:0;overflow:hidden}.outline-chapters_fixed,.outline-chapters_sticky,.outline-drawer__modal,.paper.flex .article{-webkit-box-orient:vertical;-webkit-box-direction:normal}.paper.flex .article{-ms-flex-direction:column;flex-direction:column;width:100%;box-sizing:border-box}.paper.flex .article__main{height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:auto}.paper.flex .article__aside{border-right:1px solid #dcdfe6}.header{position:sticky;z-index:3;top:0;margin:0 auto;text-align:center;-webkit-transition-duration:.3s;transition-duration:.3s;overflow:hidden}.header_sticky{padding-left:260px}.article{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-ms-flex-wrap:nowrap;flex-wrap:nowrap;padding:2em 0;font-size:16px;line-height:150%}.hidden,.outline-heading__anchor{display:none}.article__main{-webkit-box-flex:1;-ms-flex:1;flex:1;padding:0 2em;overflow:hidden}.article__main .section,.article__main .section__content,.article__main .section__footer,.article__main .section__header{overflow:visible}.article__main .section__content,.article__main .section__header{margin:0}.article__aside{-ms-flex-negative:0;flex-shrink:0;width:240px;border-left:1px solid #ddd;-webkit-transition-duration:.3s;transition-duration:.3s}.article__aside.ltr{border-right:1px solid #ddd;border-left:none}.outline-drawer_ltr,.utils-border-right{border-right:1px solid #dcdfe6}.section__pre,pre{padding:2em;font-family:"Courier New",Arial,sans-serif;background-color:#fafafa;overflow:auto}.section__code,code{font-family:"Courier New",Arial,sans-serif;font-size:16px}.footer{padding:3em 0;text-align:center}.footer a:hover,.footer a:link,.footer a:visited{text-decoration:none;color:#058942}.footer a:hover{text-decoration:underline}.outline-icon{position:relative;z-index:1;display:inline-block;vertical-align:middle;width:1em;height:1em;overflow:hidden}.outline-icon__svg{position:absolute;z-index:2;top:50%;left:50%;width:1em;height:1em;fill:currentcolor;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);overflow:hidden}:root{--outline-zIndex:2000;--outline-sticky-height:100%;--outline-chapters-width:100%}.outline-drawer{position:relative;z-index:-1;top:0;left:0;margin:0;width:100%;height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;visibility:hidden;overflow:hidden}.outline-drawer__modal{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-wrap:nowrap;flex-wrap:nowrap;position:absolute;z-index:21;height:100%;-webkit-transition-duration:.4s;transition-duration:.4s;overflow:hidden}.outline-drawer__footer,.outline-drawer__header,.outline-drawer__main{width:100%;-webkit-box-sizing:border-box;box-sizing:border-box}.outline-drawer__footer,.outline-drawer__header{-ms-flex-negative:0;flex-shrink:0}.outline-drawer__footer,.outline-drawer__main,.outline-drawer__title{padding:0 16px}.outline-drawer__header,.outline-drawer__title{position:relative;z-index:1;margin:0 auto;height:52px;line-height:52px;overflow:hidden}.outline-drawer__title{font-size:16px;font-weight:400;margin:0 16px;-webkit-box-sizing:border-box;box-sizing:border-box;border-bottom:1px solid #dcdfe6}.outline-drawer__close{position:absolute;z-index:2;top:50%;right:12px;width:20px;height:20px;line-height:20px;color:#999;font-size:20px;text-align:center;cursor:pointer;-webkit-transform:translateY(-50%);transform:translateY(-50%);overflow:hidden}.outline-drawer__close .outline-icon{position:absolute;z-index:2;top:0;left:0}.outline-drawer__close:hover{color:#666}.outline-drawer__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-drawer__footer{margin:0 auto;text-align:right;overflow:hidden}.outline-drawer__overlay{position:relative;z-index:1;top:0;left:0;width:100%;height:100%;opacity:.1;overflow:hidden}.outline-drawer_ltr.outline-drawer_tiny,.outline-drawer_rtl.outline-drawer_tiny{width:280px}.outline-drawer_ltr.outline-drawer_mini,.outline-drawer_rtl.outline-drawer_mini{width:480px}.outline-drawer_ltr.outline-drawer_small,.outline-drawer_rtl.outline-drawer_small{width:540px}.outline-drawer_ltr.outline-drawer_regular,.outline-drawer_rtl.outline-drawer_regular{width:680px}.outline-drawer_ltr.outline-drawer_medium,.outline-drawer_rtl.outline-drawer_medium{width:720px}.outline-drawer_ltr.outline-drawer_large,.outline-drawer_rtl.outline-drawer_large{width:960px}.outline-drawer_rtl{border-left:1px solid #dcdfe6}.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed{right:-290px}.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed{right:-490px}.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed{right:-550px}.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed{right:-690px}.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed{right:-730px}.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed{right:-970px}.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed{left:-290px}.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed{left:-490px}.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed{left:-550px}.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed{left:-690px}.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed{left:-730px}.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed{left:-970px}.outline-drawer_btt,.outline-drawer_ttb{left:0;width:100%}.outline-drawer_btt.outline-drawer_tiny,.outline-drawer_ttb.outline-drawer_tiny{height:240px}.outline-drawer_btt.outline-drawer_mini,.outline-drawer_ttb.outline-drawer_mini{height:320px}.outline-drawer_btt.outline-drawer_small,.outline-drawer_ttb.outline-drawer_small{height:360px}.outline-drawer_btt.outline-drawer_regular,.outline-drawer_ttb.outline-drawer_regular{height:400px}.outline-drawer_btt.outline-drawer_medium,.outline-drawer_ttb.outline-drawer_medium{height:440px}.outline-drawer_btt.outline-drawer_large,.outline-drawer_ttb.outline-drawer_large{height:480px}.outline-drawer_ttb{border-bottom:1px solid #dcdfe6}.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed{top:-250px}.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed{top:-330px}.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed{top:-370px}.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed{top:-410px}.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed{top:-450px}.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed{top:-490px}.outline-drawer_btt{top:initial}.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed{bottom:-250px}.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed{bottom:-330px}.outline-drawer_btt.outline-drawer_small.outline-drawer_closed{bottom:-370px}.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed{bottom:-410px}.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed{bottom:-450px}.outline-drawer_btt.outline-drawer_large.outline-drawer_closed{bottom:-490px}.outline-drawer_opened{visibility:visible;z-index:var(--outline-zIndex)}.outline-drawer_opened.outline-drawer{position:fixed}.outline-drawer_opened.outline-drawer_rtl{right:0}.outline-drawer_opened.outline-drawer_ltr{left:0}.outline-drawer_opened.outline-drawer_ttb{top:0}.outline-drawer_opened.outline-drawer_btt{bottom:0}.outline-drawer_offset.outline-drawer_ltr,.outline-drawer_offset.outline-drawer_rtl{height:calc(100% - 4em);top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.outline-drawer_offset.outline-drawer_btt,.outline-drawer_offset.outline-drawer_ttb{width:calc(100% - 4em);left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl{right:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr{left:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb{top:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt{bottom:2em}.outline-drawer_auto.outline-drawer_ltr,.outline-drawer_auto.outline-drawer_rtl{height:auto;max-height:calc(100% - 4em)}.outline-drawer_full{padding:0}.outline-heading{position:relative;z-index:1;overflow:hidden}.outline-heading__anchor:hover,.outline-heading__anchor:link,.outline-heading__anchor:visited{color:#999;text-decoration:none}.outline-heading__anchor:hover{color:#1f8dd6}.outline-heading:hover .outline-heading__anchor{display:inline-block}.outline-heading_start:hover{overflow:visible}.outline-heading_start .outline-heading__anchor{position:absolute;z-index:2;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);left:-1em}.outline-chapters{position:relative;z-index:1;margin:0;width:var(--outline-chapters-width);-webkit-transition-duration:.3s;transition-duration:.3s;overflow:auto}.outline-chapters__title{margin:0 16px;height:40px;line-height:40px;padding:0 16px;border-bottom:1px solid #dcdfe6;font-size:16px;font-weight:400;overflow:hidden}.outline-chapters__main{position:relative;z-index:1;margin:0;overflow:hidden}.outline-chapters__item,.outline-chapters__list,.outline-chapters__subject{position:relative;z-index:2;margin:0;padding:0;list-style-type:none;overflow:hidden}.outline-chapters__list{padding:.5em 0}.outline-chapters__subject{padding-left:1em}.outline-chapters__item{margin:0;line-height:30px;font-size:13px;overflow:hidden}.outline-chapters__placeholder{position:absolute;z-index:1;top:0;left:0;width:100%;height:30px;background-color:#f7f8f9;border-left:2px solid #058942;-webkit-transition-duration:.2s;transition-duration:.2s;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.outline-chapters__anchor{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:block;padding:0 1.5em}.outline-chapters__anchor:hover,.outline-chapters__anchor:link,.outline-chapters__anchor:visited{text-decoration:none;color:#555}.outline-chapters__anchor:hover{color:#058942}.outline-chapters__code{padding-right:.5em}.outline-chapters_active.outline-chapters__anchor:hover,.outline-chapters_active.outline-chapters__anchor:link,.outline-chapters_active.outline-chapters__anchor:visited{color:#058942;font-weight:400}.outline-chapters_fixed,.outline-chapters_sticky{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-ms-flex-direction:column;flex-direction:column;z-index:var(--outline-zIndex);top:0;overflow:hidden}.outline-chapters_hidden,.outline-toolbar__button.hide{display:none}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__main,.outline-chapters_sticky .outline-chapters__title{-webkit-box-sizing:border-box;box-sizing:border-box}.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__title{-ms-flex-negative:0;flex-shrink:0}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_sticky .outline-chapters__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-chapters_sticky{position:sticky;max-height:var(--outline-sticky-height)}.outline-chapters_fixed{position:fixed;max-height:100%}.outline-chapters_folded{width:0}.outline-toolbar{position:fixed;z-index:99999;margin:0;-webkit-transition-duration:.3s;transition-duration:.3s;overflow:hidden}.outline-toolbar__button{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;position:relative;z-index:1;margin:10px;width:36px;height:36px;border:1px solid #dcdfe6;border-radius:3px;-webkit-box-sizing:border-box;box-sizing:border-box;background-color:#fff;cursor:pointer;text-align:center;color:#555;overflow:hidden}.outline-toolbar__button:hover{color:#058942;border-color:#058942}.outline-toolbar__anchor:hover,.outline-toolbar__anchor:link,.outline-toolbar__anchor:visited{color:#999;text-decoration:none}.outline-toolbar__anchor:hover{color:#058942}.outline-toolbar__icon{position:absolute;z-index:2;top:50%;left:50%;width:20px;height:20px;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);fill:currentcolor;overflow:hidden}.outline-toolbar_active.outline-toolbar__button{color:#fff;background-color:#058942;border-color:#058942}.outline-toolbar_active .outline-toolbar__anchor:hover,.outline-toolbar_active .outline-toolbar__anchor:link,.outline-toolbar_active .outline-toolbar__anchor:visited,.outline-toolbar_active.outline-toolbar__button:hover{color:#fff}.outline-toolbar_rounded.outline-toolbar__button{border-radius:18px}.outline-toolbar_disabled .outline-toolbar__anchor:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link,.outline-toolbar_disabled .outline-toolbar__anchor:visited,.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__anchor:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link,.outline-toolbar_disabled.outline-toolbar__anchor:visited,.outline-toolbar_disabled.outline-toolbar__button{cursor:not-allowed;color:#999}.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled .outline-toolbar__button:hover,.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled.outline-toolbar__button:hover{color:#999}.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__button{background-color:#f5f5f5}.outline-toolbar_btt,.outline-toolbar_ttb{left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-toolbar_btt .outline-toolbar__button,.outline-toolbar_ttb .outline-toolbar__button{display:inline-block}.outline-toolbar_ttb{top:12px}.outline-toolbar_ttb.outline-toolbar_hidden{top:-56px}.outline-toolbar_btt{bottom:12px}.outline-toolbar_btt.outline-toolbar_hidden{bottom:-56px}.outline-toolbar_ltr,.outline-toolbar_rtl{-webkit-transform:translateY(-50%);transform:translateY(-50%);width:56px}.outline-toolbar_rtl{top:50%;right:12px}.outline-toolbar_rtl.outline-toolbar_hidden{right:-86px}.outline-toolbar_ltr{top:50%;left:12px}.outline-toolbar_ltr.outline-toolbar_hidden{left:-86px}.outline-print,.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden{display:none}@media print{body,html{height:initial!important}.outline-print{display:block!important;overflow:hidden}.outline-print h1{text-align:center;font-size:20pt;font-family:'Microsoft YaHei UI',Arial,sans-serif;font-weight:400}.outline-print pre{padding:1em!important;border:1px solid #ddd!important;border-radius:4px!important}.outline-print code,.outline-print pre{background-color:#fff!important}.outline-print img,.outline-print svg,.outline-print table{-webkit-column-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.outline-print_sibling{display:none!important}} +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"names":[],"mappings":"","sources":["css/example.css"],"sourcesContent":["/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/* ====== 阴影样式设置函数 ====== */\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n}\n.section__header,\n.section__content,\n.section__footer {\n  margin: 0 3em;\n  overflow: hidden;\n}\n.section__title {\n  color: #666;\n}\n.section__h3 {\n  color: #1f8dd6;\n  font-size: 1.35em;\n}\n.section__h4 {\n  font-size: 1.1em;\n  color: #666;\n}\n.section__h5 {\n  font-size: 1em;\n  color: #999;\n}\n.section__dl,\n.section__dt,\n.section__dd {\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.section__dl {\n  position: relative;\n  z-index: 1;\n}\n.section__dt {\n  display: inline-block;\n}\n.section__dd {\n  display: inline-block;\n  color: #058942;\n}\n.section__pre {\n  margin: 2em 0;\n  padding: 1em;\n  font-size: 14px;\n  line-height: 150%;\n  text-align: left;\n  background-color: #fafafa;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  color: #666;\n  overflow: auto;\n}\n.section__code {\n  display: block;\n  margin: 0 auto;\n  overflow: hidden;\n}\n.section__footer {\n  border-top: 1px solid #ddd;\n  margin-top: 3em;\n  background-color: #fafafa;\n  color: #999;\n}\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  overflow: hidden;\n}\n.case:after {\n  content: '';\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 50%;\n  height: 100%;\n  width: 0;\n  border-left: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__pre,\n.case__textarea {\n  font-size: 13px;\n  line-height: 150%;\n}\n.case__pre,\n.case__code,\n.case__textarea {\n  font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n}\n.case__pre {\n  margin: 0;\n  padding: 1em;\n  background-color: #fafafa;\n  height: 100%;\n  border-radius: 4px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: auto;\n}\n.case__toolbar {\n  margin: 0 auto;\n  height: 36px;\n  line-height: 36px;\n  font-size: 14px;\n  padding: 0 16px;\n  text-align: right;\n  overflow: hidden;\n}\n.case__action,\n.case__remove {\n  cursor: pointer;\n  color: #058942;\n  -webkit-user-select: none;\n     -moz-user-select: none;\n      -ms-user-select: none;\n          user-select: none;\n}\n.case__action {\n  font-size: 13px;\n  padding-left: 10px;\n}\n.case__action:first-child {\n  padding-left: 0;\n}\n.case__remove {\n  float: right;\n}\n.case__console {\n  margin: 0 auto;\n  height: 180px;\n  border: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__textarea {\n  margin: 0 auto;\n  width: 100%;\n  height: 100%;\n  border: none;\n  outline: none;\n  padding: 1em;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: auto;\n}\n.case__list,\n.case__item {\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.case__list {\n  height: 360px;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  font-size: 13px;\n  overflow: auto;\n}\n.case__item {\n  height: 36px;\n  line-height: 36px;\n  cursor: pointer;\n  padding: 0 16px;\n}\n.case__item:hover {\n  background-color: #f7f8f9;\n}\n.paper {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  margin: 2em auto;\n  max-width: 1200px;\n  padding: 2em;\n  background-color: #fff;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.paper.flex {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: row;\n          flex-direction: row;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  margin: 0;\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  padding: 0;\n  overflow: hidden;\n}\n.paper.flex .article {\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  width: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.paper.flex .article__main {\n  height: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: auto;\n}\n.paper.flex .article__aside {\n  border-right: 1px solid #dcdfe6;\n}\n.header {\n  position: sticky;\n  z-index: 3;\n  top: 0;\n  margin: 0 auto;\n  border-bottom: 1px solid #ddd;\n  background-color: #fff;\n  text-align: center;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: hidden;\n}\n.header_sticky {\n  padding-left: 260px;\n}\n.article {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: row;\n          flex-direction: row;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  padding: 2em 0;\n  font-size: 16px;\n  line-height: 150%;\n}\n.article__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  padding: 0 2em;\n  overflow: hidden;\n}\n.article__main .section {\n  overflow: visible;\n}\n.article__main .section__content,\n.article__main .section__footer,\n.article__main .section__header {\n  overflow: visible;\n}\n.article__main .section__header,\n.article__main .section__content {\n  margin: 0;\n}\n.article__aside {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n  width: 240px;\n  border-left: 1px solid #ddd;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n}\n.article__aside.ltr {\n  border-right: 1px solid #ddd;\n  border-left: none;\n}\n.article__aside .outline-chapters {\n  background-color: #fff;\n}\npre,\n.section__pre {\n  padding: 2em;\n  font-family: \"Courier New\", Arial, sans-serif;\n  background-color: #fafafa;\n  overflow: auto;\n}\ncode,\n.section__code {\n  font-family: \"Courier New\", Arial, sans-serif;\n  font-size: 16px;\n}\n.footer {\n  border-top: 1px solid #dcdfe6;\n  padding: 3em 0;\n  text-align: center;\n}\n.footer a:link,\n.footer a:visited,\n.footer a:hover {\n  text-decoration: none;\n  color: #058942;\n}\n.footer a:hover {\n  text-decoration: underline;\n}\n.utils-border-right {\n  border-right: 1px solid #dcdfe6;\n}\n.hidden {\n  display: none;\n}\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n:root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  -webkit-transition-duration: 0.4s;\n          transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  left: -1em;\n}\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  -webkit-transition-duration: 0.2s;\n          transition-duration: 0.2s;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n.outline-print {\n  display: none;\n}\n@media print {\n  html,\n  body {\n    height: initial !important;\n  }\n  .outline-print {\n    display: block !important;\n    overflow: hidden;\n  }\n  .outline-print h1 {\n    text-align: center;\n    font-size: 20pt;\n    font-family: 'Microsoft YaHei UI', Arial, sans-serif;\n    font-weight: normal;\n  }\n  .outline-print pre {\n    padding: 1em !important;\n    border: 1px solid #ddd !important;\n    border-radius: 4px !important;\n  }\n  .outline-print pre,\n  .outline-print code {\n    background-color: #fff !important;\n  }\n  .outline-print table,\n  .outline-print img,\n  .outline-print svg {\n    -webkit-column-break-inside: avoid;\n       -moz-column-break-inside: avoid;\n            break-inside: avoid;\n  }\n  .outline-print_sibling {\n    display: none !important;\n  }\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../<input css 2>","scrollbar.less","section.less","case.less","pager.less","../../src/theme/shadow.less","../../src/theme/icons.less","../../src/theme/variables.less","../../src/theme/drawer.less","../../src/theme/anchors.less","../../src/theme/chapters.less","../../src/theme/ellipsis.less","../../src/theme/toolbar.less","../../src/theme/print.less"],"names":[],"mappings":"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","file":"example.css","sourcesContent":["/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/* ====== 阴影样式设置函数 ====== */\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n}\n.section__header,\n.section__content,\n.section__footer {\n  margin: 0 3em;\n  overflow: hidden;\n}\n.section__title {\n  color: #666;\n}\n.section__h3 {\n  color: #1f8dd6;\n  font-size: 1.35em;\n}\n.section__h4 {\n  font-size: 1.1em;\n  color: #666;\n}\n.section__h5 {\n  font-size: 1em;\n  color: #999;\n}\n.section__dl,\n.section__dt,\n.section__dd {\n  margin: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.section__dl {\n  position: relative;\n  z-index: 1;\n}\n.section__dt {\n  display: inline-block;\n}\n.section__dd {\n  display: inline-block;\n  color: #058942;\n}\n.section__pre {\n  margin: 2em 0;\n  padding: 1em;\n  font-size: 14px;\n  line-height: 150%;\n  text-align: left;\n  background-color: #fafafa;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  color: #666;\n  overflow: auto;\n}\n.section__code {\n  display: block;\n  margin: 0 auto;\n  overflow: hidden;\n}\n.section__footer {\n  border-top: 1px solid #ddd;\n  margin-top: 3em;\n  background-color: #fafafa;\n  color: #999;\n}\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  overflow: hidden;\n}\n.case:after {\n  content: '';\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 50%;\n  height: 100%;\n  width: 0;\n  border-left: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__pre,\n.case__textarea {\n  font-size: 13px;\n  line-height: 150%;\n}\n.case__pre,\n.case__code,\n.case__textarea {\n  font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n}\n.case__pre {\n  margin: 0;\n  padding: 1em;\n  background-color: #fafafa;\n  height: 100%;\n  border-radius: 4px;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__toolbar {\n  margin: 0 auto;\n  height: 36px;\n  line-height: 36px;\n  font-size: 14px;\n  padding: 0 16px;\n  text-align: right;\n  overflow: hidden;\n}\n.case__action,\n.case__remove {\n  cursor: pointer;\n  color: #058942;\n  user-select: none;\n}\n.case__action {\n  font-size: 13px;\n  padding-left: 10px;\n}\n.case__action:first-child {\n  padding-left: 0;\n}\n.case__remove {\n  float: right;\n}\n.case__console {\n  margin: 0 auto;\n  height: 180px;\n  border: 1px solid #ddd;\n  overflow: hidden;\n}\n.case__textarea {\n  margin: 0 auto;\n  width: 100%;\n  height: 100%;\n  border: none;\n  outline: none;\n  padding: 1em;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.case__list,\n.case__item {\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.case__list {\n  height: 360px;\n  border-top: 1px solid #ddd;\n  border-bottom: 1px solid #ddd;\n  font-size: 13px;\n  overflow: auto;\n}\n.case__item {\n  height: 36px;\n  line-height: 36px;\n  cursor: pointer;\n  padding: 0 16px;\n}\n.case__item:hover {\n  background-color: #f7f8f9;\n}\n.paper {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  margin: 2em auto;\n  max-width: 1200px;\n  padding: 2em;\n  background-color: #fff;\n  box-sizing: border-box;\n}\n.paper.flex {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  margin: 0;\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  padding: 0;\n  overflow: hidden;\n}\n.paper.flex .article {\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n}\n.paper.flex .article__main {\n  height: 100%;\n  box-sizing: border-box;\n  overflow: auto;\n}\n.paper.flex .article__aside {\n  border-right: 1px solid #dcdfe6;\n}\n.header {\n  position: sticky;\n  z-index: 3;\n  top: 0;\n  margin: 0 auto;\n  border-bottom: 1px solid #ddd;\n  background-color: #fff;\n  text-align: center;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.header_sticky {\n  padding-left: 260px;\n}\n.article {\n  display: flex;\n  flex-direction: row;\n  flex-wrap: nowrap;\n  padding: 2em 0;\n  font-size: 16px;\n  line-height: 150%;\n}\n.article__main {\n  flex: 1;\n  padding: 0 2em;\n  overflow: hidden;\n}\n.article__main .section {\n  overflow: visible;\n}\n.article__main .section__content,\n.article__main .section__footer,\n.article__main .section__header {\n  overflow: visible;\n}\n.article__main .section__header,\n.article__main .section__content {\n  margin: 0;\n}\n.article__aside {\n  flex-shrink: 0;\n  width: 240px;\n  border-left: 1px solid #ddd;\n  transition-duration: 0.3s;\n}\n.article__aside.ltr {\n  border-right: 1px solid #ddd;\n  border-left: none;\n}\n.article__aside .outline-chapters {\n  background-color: #fff;\n}\npre,\n.section__pre {\n  padding: 2em;\n  font-family: \"Courier New\", Arial, sans-serif;\n  background-color: #fafafa;\n  overflow: auto;\n}\ncode,\n.section__code {\n  font-family: \"Courier New\", Arial, sans-serif;\n  font-size: 16px;\n}\n.footer {\n  border-top: 1px solid #dcdfe6;\n  padding: 3em 0;\n  text-align: center;\n}\n.footer a:link,\n.footer a:visited,\n.footer a:hover {\n  text-decoration: none;\n  color: #058942;\n}\n.footer a:hover {\n  text-decoration: underline;\n}\n.utils-border-right {\n  border-right: 1px solid #dcdfe6;\n}\n.hidden {\n  display: none;\n}\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n:root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n.outline-print {\n  display: none;\n}\n@media print {\n  html,\n  body {\n    height: initial !important;\n  }\n  .outline-print {\n    display: block !important;\n    overflow: hidden;\n  }\n  .outline-print h1 {\n    text-align: center;\n    font-size: 20pt;\n    font-family: 'Microsoft YaHei UI', Arial, sans-serif;\n    font-weight: normal;\n  }\n  .outline-print pre {\n    padding: 1em !important;\n    border: 1px solid #ddd !important;\n    border-radius: 4px !important;\n  }\n  .outline-print pre,\n  .outline-print code {\n    background-color: #fff !important;\n  }\n  .outline-print table,\n  .outline-print img,\n  .outline-print svg {\n    break-inside: avoid;\n  }\n  .outline-print_sibling {\n    display: none !important;\n  }\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","@import 'colors';\n\n.section {\n  margin: 1em 0;\n  overflow: hidden;\n\n  &__header,\n  &__content,\n  &__footer {\n    margin: 0 3em;\n    overflow: hidden;\n  }\n\n  &__title {\n    color: @third_text_color;\n  }\n\n  &__h3 {\n    color: @primary_color;\n    font-size: 1.35em;\n  }\n\n  &__h4 {\n    font-size: 1.1em;\n    color: @third_text_color;\n  }\n\n  &__h5 {\n    font-size: 1em;\n    color: @fourth_text_color;\n  }\n\n  &__dl,\n  &__dt,\n  &__dd {\n    margin: 0;\n    padding: 0;\n    overflow: hidden;\n  }\n\n  &__dl {\n    position: relative;\n    z-index: 1;\n  }\n\n  &__dt {\n    display:inline-block;\n  }\n\n  &__dd {\n    display:inline-block;\n    color: @success_color;\n  }\n\n  &__pre {\n    margin: 2em 0;\n    padding: 1em;\n    font-size: 14px;\n    line-height: 150%;\n    text-align: left;\n    background-color: @bg_color;\n    border: 1px solid @border_color;\n    border-radius: 4px;\n    color: @third_text_color;\n    overflow: auto;\n  }\n\n  &__code {\n    display: block;\n    margin: 0 auto;\n    overflow: hidden;\n  }\n\n  &__footer {\n    border-top: 1px solid @border_color;\n    margin-top: 3em;\n    background-color: @bg_color;\n    color: @fourth_text_color;\n  }\n}\n","@import './colors';\n\n.case {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: repeat(2, 1fr);\n  gap: 40px;\n  padding: 1em;\n  border-top:1px solid @border_color;\n  border-bottom:1px solid @border_color;\n  overflow: hidden;\n\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 2;\n    top: 0;\n    left: 50%;\n    height: 100%;\n    width: 0;\n    border-left: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__pre,\n  &__textarea {\n    font-size: 13px;\n    line-height: 150%;\n  }\n\n  &__pre,\n  &__code,\n  &__textarea {\n    font-family: \"Courier New\", Consolas, Georgia, Arial, sans-serif;\n  }\n\n  &__pre {\n    margin: 0;\n    padding: 1em;\n    background-color: @bg_color;\n    height: 100%;\n    border-radius: 4px;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__toolbar {\n    margin: 0 auto;\n    height: 36px;\n    line-height: 36px;\n    font-size: 14px;\n    padding: 0 16px;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__action,\n  &__remove {\n    cursor: pointer;\n    color: @success_color;\n    user-select: none;\n  }\n\n  &__action {\n    font-size: 13px;\n    padding-left: 10px;\n\n    &:first-child {\n      padding-left: 0;\n    }\n  }\n\n  &__remove {\n    float: right;\n  }\n\n  &__console {\n    margin: 0 auto;\n    height: 180px;\n    border: 1px solid @border_color;\n    overflow: hidden;\n  }\n\n  &__textarea {\n    margin: 0 auto;\n    width: 100%;\n    height: 100%;\n    border: none;\n    outline: none;\n    padding: 1em;\n    box-sizing: border-box;\n    overflow: auto;\n  }\n\n  &__list,\n  &__item {\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    height: 360px;\n    border-top: 1px solid @border_color;\n    border-bottom: 1px solid @border_color;\n    font-size: 13px;\n    overflow: auto;\n  }\n\n  &__item {\n    height: 36px;\n    line-height: 36px;\n    cursor: pointer;\n    padding: 0 16px;\n\n    &:hover {\n      background-color: @hover_bg_color;\n    }\n  }\n}\n",".paper {\r\n  .shadow_light_regular();\r\n  margin: 2em auto;\r\n  max-width: 1200px;\r\n  padding: 2em;\r\n  background-color: @white;\r\n  box-sizing: border-box;\r\n\r\n  &.flex {\r\n    display: flex;\r\n    flex-direction: row;\r\n    flex-wrap: nowrap;\r\n    margin: 0;\r\n    width: 100%;\r\n    max-width: 100%;\r\n    height: 100%;\r\n    padding: 0;\r\n    overflow: hidden;\r\n\r\n    .article {\r\n      flex-direction: column;\r\n      width: 100%;\r\n      box-sizing: border-box;\r\n\r\n      &__main {\r\n        height: 100%;\r\n        box-sizing: border-box;\r\n        overflow: auto;\r\n      }\r\n\r\n      &__aside {\r\n        border-right: 1px solid @primary_border_color;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n.header {\r\n  position: sticky;\r\n  z-index: 3;\r\n  top: 0;\r\n  margin: 0 auto;\r\n  border-bottom: 1px solid @border_color;\r\n  background-color: @white;\r\n  text-align: center;\r\n  transition-duration: 0.3s;\r\n  overflow: hidden;\r\n\r\n  &_sticky {\r\n    padding-left: 260px;\r\n  }\r\n}\r\n\r\n.article {\r\n  display: flex;\r\n  flex-direction: row;\r\n  flex-wrap: nowrap;\r\n  padding: 2em 0;\r\n  font-size: 16px;\r\n  line-height: 150%;\r\n\r\n  &__main {\r\n    flex: 1;\r\n    padding: 0 2em;\r\n    overflow: hidden;\r\n\r\n    .section {\r\n      overflow: visible;\r\n\r\n      &__content,\r\n      &__footer,\r\n      &__header {\r\n        overflow: visible;\r\n      }\r\n\r\n      &__header,\r\n      &__content {\r\n        margin: 0;\r\n      }\r\n    }\r\n  }\r\n\r\n  &__aside {\r\n    flex-shrink: 0;\r\n    width: 240px;\r\n    border-left: 1px solid @border_color;\r\n    transition-duration: 0.3s;\r\n\r\n    &.ltr {\r\n      border-right: 1px solid @border_color;\r\n      border-left: none;\r\n    }\r\n\r\n    .outline-chapters {\r\n      background-color: @white;\r\n    }\r\n  }\r\n}\r\n\r\npre,\r\n.section__pre {\r\n  padding: 2em;\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  background-color: @bg_color;\r\n  overflow: auto;\r\n}\r\n\r\ncode,\r\n.section__code {\r\n  font-family: \"Courier New\", Arial, sans-serif;\r\n  font-size: 16px;\r\n}\r\n\r\n.footer {\r\n  border-top: 1px solid @primary_border_color;\r\n  padding: 3em 0;\r\n  text-align: center;\r\n\r\n  a {\r\n    &:link,\r\n    &:visited,\r\n    &:hover {\r\n      text-decoration: none;\r\n      color: @success_color;\r\n    }\r\n\r\n    &:hover {\r\n      text-decoration: underline;\r\n    }\r\n  }\r\n}\r\n\r\n.utils-border-right {\r\n  border-right: 1px solid @primary_border_color;\r\n}\r\n\r\n.hidden {\r\n  display: none;\r\n}\r\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n","@import './colors';\r\n\r\n.outline-print {\r\n  display: none;\r\n}\r\n\r\n@media print {\r\n  html,\r\n  body {\r\n    height: initial !important;\r\n  }\r\n\r\n  .outline-print {\r\n    display: block !important;\r\n    overflow: hidden;\r\n\r\n    h1 {\r\n      text-align: center;\r\n      font-size: 20pt;\r\n      font-family: 'Microsoft YaHei UI', Arial, sans-serif;\r\n      font-weight: normal;\r\n    }\r\n\r\n    pre {\r\n      padding: 1em !important;\r\n      border: 1px solid @border_color !important;\r\n      border-radius: 4px !important;\r\n    }\r\n\r\n    pre,\r\n    code {\r\n      background-color: @white !important;\r\n    }\r\n\r\n    table,\r\n    img,\r\n    svg {\r\n      break-inside: avoid;\r\n    }\r\n\r\n    &_sibling {\r\n      display: none !important;\r\n    }\r\n  }\r\n}\r\n"]} */\n"],"file":"css/example.min.css"} */ diff --git a/docs/fixed.html b/docs/fixed.html index 09e8dec8..29eb0273 100644 --- a/docs/fixed.html +++ b/docs/fixed.html @@ -150,7 +150,22 @@ } } ] -})

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
+})

print

Description

Type:
Object
Default:
{element: '', title: ''}

可选,自定义的是否自动为文章页面创建打印样式。

element:
(必须)要打印的文章区域,DOM 元素或者选择器字符串。
title:
(可选)要打印的文章标题。如果 element 区域有 h1 标签则无需设置。
const defaults = Outline.DEFAULTS
+let outline
+
+defaults.position = 'sticky'
+defaults.stickyHeight = 86
+defaults.parentElement = '#aside'
+defaults.scrollElement = '#main'
+defaults.homepage = './index.html'
+defaults.git = 'https://github.com/yaohaixiao/outline.js'
+defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags'
+defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues'
+defaults.print = {
+  element: '#article',
+  title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具'
+}
+outline = new Outline(Outline.DEFAULTS)

演示地址:https://yaohaixiao.github.io/outline.js/flex.html

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
 new Outline(Outline.DEFAULTS)
 
 // Customized
@@ -256,20 +271,28 @@
 }
 outline = new Outline(Outline.DEFAULTS)

Properties

outline.js 重构后,对外放 4 个重要的属性:anchors、drawer、chapters 和 toolbar。它们都是独立的对象实例,提供了 outline.js 所有的能力(属性和方法)。

DEFAULTS

Description

Type:
Object

静态属性,存储的是 Outline 对象默认配置选项:

Outline.DEFAULTS = {
   articleElement: '#article',
-  selector: 'h2,h3,h4,h5,h6',
-  title: '目录',
-  scrollElement: 'html,body',
-  position: 'relative',
-  parentElement: '#aside',
-  placement: 'rtl',
-  stickyHeight: 0,
-  showCode: true,
-  anchorURL: '',
-  homepage: '',
-  git: '',
-  tags: '',
-  issues: '',
-  customClass: ''
+    selector: 'h2,h3,h4,h5,h6',
+    title: '目录',
+    scrollElement: 'html,body',
+    position: 'relative',
+    parentElement: '#aside',
+    placement: 'rtl',
+    showCode: true,
+    anchorURL: '',
+    stickyHeight: 0,
+    homepage: '',
+    git: '',
+    tags: '',
+    issues: '',
+    tools: [],
+    print: {
+      element: '',
+      title: ''
+    },
+    customClass: '',
+    afterSticky: null,
+    afterToggle: null,
+    afterScroll: null
 }

attrs

Description

Type:
Object

存储的是 Outline 对象当前使用中的配置选项:

说明:建议使用 attr(prop) 方法来获取属性,避免直接调用属性。

// 设置默认配置项
 const outline = new Outline(Outline.DEFAULTS)
 
diff --git a/docs/flex.html b/docs/flex.html
index c508b161..ab1dce2d 100644
--- a/docs/flex.html
+++ b/docs/flex.html
@@ -156,7 +156,22 @@
       }
     }
   ]
-})

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
+})

print

Description

Type:
Object
Default:
{element: '', title: ''}

可选,自定义的是否自动为文章页面创建打印样式。

element:
(必须)要打印的文章区域,DOM 元素或者选择器字符串。
title:
(可选)要打印的文章标题。如果 element 区域有 h1 标签则无需设置。
const defaults = Outline.DEFAULTS
+let outline
+
+defaults.position = 'sticky'
+defaults.stickyHeight = 86
+defaults.parentElement = '#aside'
+defaults.scrollElement = '#main'
+defaults.homepage = './index.html'
+defaults.git = 'https://github.com/yaohaixiao/outline.js'
+defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags'
+defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues'
+defaults.print = {
+  element: '#article',
+  title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具'
+}
+outline = new Outline(Outline.DEFAULTS)

演示地址:https://yaohaixiao.github.io/outline.js/flex.html

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
 new Outline(Outline.DEFAULTS)
 
 // Customized
@@ -262,20 +277,28 @@
 }
 outline = new Outline(Outline.DEFAULTS)

Properties

outline.js 重构后,对外放 4 个重要的属性:anchors、drawer、chapters 和 toolbar。它们都是独立的对象实例,提供了 outline.js 所有的能力(属性和方法)。

DEFAULTS

Description

Type:
Object

静态属性,存储的是 Outline 对象默认配置选项:

Outline.DEFAULTS = {
   articleElement: '#article',
-  selector: 'h2,h3,h4,h5,h6',
-  title: '目录',
-  scrollElement: 'html,body',
-  position: 'relative',
-  parentElement: '#aside',
-  placement: 'rtl',
-  stickyHeight: 0,
-  showCode: true,
-  anchorURL: '',
-  homepage: '',
-  git: '',
-  tags: '',
-  issues: '',
-  customClass: ''
+    selector: 'h2,h3,h4,h5,h6',
+    title: '目录',
+    scrollElement: 'html,body',
+    position: 'relative',
+    parentElement: '#aside',
+    placement: 'rtl',
+    showCode: true,
+    anchorURL: '',
+    stickyHeight: 0,
+    homepage: '',
+    git: '',
+    tags: '',
+    issues: '',
+    tools: [],
+    print: {
+      element: '',
+      title: ''
+    },
+    customClass: '',
+    afterSticky: null,
+    afterToggle: null,
+    afterScroll: null
 }

attrs

Description

Type:
Object

存储的是 Outline 对象当前使用中的配置选项:

说明:建议使用 attr(prop) 方法来获取属性,避免直接调用属性。

// 设置默认配置项
 const outline = new Outline(Outline.DEFAULTS)
 
@@ -938,4 +961,8 @@
 defaults.git = 'https://github.com/yaohaixiao/outline.js'
 defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags'
 defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues'
+defaults.print = {
+  element: '#article',
+  title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具'
+}
 outline = new Outline(Outline.DEFAULTS)
\ No newline at end of file
diff --git a/docs/index.html b/docs/index.html
index 8f1f9782..b127fb08 100644
--- a/docs/index.html
+++ b/docs/index.html
@@ -1,4 +1,4 @@
-outline.js | 自动生成文章导读(Table of Contents)导航的 JavaScript 工具。
<script src="https://cdn.jsdelivr.net/gh/yaohaixiao/outline.js/outline.min.js"></script>

Options

outline.js 有者丰富的配置选项,以便适应不同的展示方式。

articleElement

Description

Type:
String|HTMLElement
Default:
'#article'
String:
选择器字符串,默认值:html,body(即 window 窗口);
HTMLElement:
'DOM 元素;

可选,用来指定页面中显示文章正文的 DOM 节点或者选择器字符串。

// Default Selector
+outline.js | 自动生成文章导读(Table of Contents)导航的 JavaScript 工具。
<script src="https://cdn.jsdelivr.net/gh/yaohaixiao/outline.js/outline.min.js"></script>

Options

outline.js 有者丰富的配置选项,以便适应不同的展示方式。

articleElement

Description

Type:
String|HTMLElement
Default:
'#article'
String:
选择器字符串,默认值:html,body(即 window 窗口);
HTMLElement:
'DOM 元素;

可选,用来指定页面中显示文章正文的 DOM 节点或者选择器字符串。

// Default Selector
 const outline = new Outline(Outline.DEFAULTS)
 
 // Customize Selector
@@ -93,7 +93,22 @@
       }
     }
   ]
-})

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
+})

print

Description

Type:
Object
Default:
{element: '', title: ''}

可选,自定义的是否自动为文章页面创建打印样式。

element:
(必须)要打印的文章区域,DOM 元素或者选择器字符串。
title:
(可选)要打印的文章标题。如果 element 区域有 h1 标签则无需设置。
const defaults = Outline.DEFAULTS
+let outline
+
+defaults.position = 'sticky'
+defaults.stickyHeight = 86
+defaults.parentElement = '#aside'
+defaults.scrollElement = '#main'
+defaults.homepage = './index.html'
+defaults.git = 'https://github.com/yaohaixiao/outline.js'
+defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags'
+defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues'
+defaults.print = {
+  element: '#article',
+  title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具'
+}
+outline = new Outline(Outline.DEFAULTS)

演示地址:https://yaohaixiao.github.io/outline.js/flex.html

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
 new Outline(Outline.DEFAULTS)
 
 // Customized
@@ -199,20 +214,28 @@
 }
 outline = new Outline(Outline.DEFAULTS)

Properties

outline.js 重构后,对外放 4 个重要的属性:anchors、drawer、chapters 和 toolbar。它们都是独立的对象实例,提供了 outline.js 所有的能力(属性和方法)。

DEFAULTS

Description

Type:
Object

静态属性,存储的是 Outline 对象默认配置选项:

Outline.DEFAULTS = {
   articleElement: '#article',
-  selector: 'h2,h3,h4,h5,h6',
-  title: '目录',
-  scrollElement: 'html,body',
-  position: 'relative',
-  parentElement: '#aside',
-  placement: 'rtl',
-  stickyHeight: 0,
-  showCode: true,
-  anchorURL: '',
-  homepage: '',
-  git: '',
-  tags: '',
-  issues: '',
-  customClass: ''
+    selector: 'h2,h3,h4,h5,h6',
+    title: '目录',
+    scrollElement: 'html,body',
+    position: 'relative',
+    parentElement: '#aside',
+    placement: 'rtl',
+    showCode: true,
+    anchorURL: '',
+    stickyHeight: 0,
+    homepage: '',
+    git: '',
+    tags: '',
+    issues: '',
+    tools: [],
+    print: {
+      element: '',
+      title: ''
+    },
+    customClass: '',
+    afterSticky: null,
+    afterToggle: null,
+    afterScroll: null
 }

attrs

Description

Type:
Object

存储的是 Outline 对象当前使用中的配置选项:

说明:建议使用 attr(prop) 方法来获取属性,避免直接调用属性。

// 设置默认配置项
 const outline = new Outline(Outline.DEFAULTS)
 
diff --git a/docs/js/outline.min.js b/docs/js/outline.min.js
index 2f08e993..689f90ee 100644
--- a/docs/js/outline.min.js
+++ b/docs/js/outline.min.js
@@ -1,2 +1,2 @@
-!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).Outline=e()}(this,(function(){"use strict";const t=t=>"string"==typeof t,e=(t,e)=>{const s=Object.prototype.hasOwnProperty;return t&&s.call(t,e)},s=t=>Object.prototype.toString.apply(t),i=t=>"function"==typeof t||"[object Function]"===s(t),r=t=>("[object Object]"===s(t)||"object"==typeof t||i(t))&&null!==t;class l{constructor(t){this.attrs={},t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}attr(s,i){const l=this.attrs;return t(s)?i&&e(l,s)?(l[s]=i,this):l[s]:r(s)?(o=l,n=s,Object.keys(n).forEach((t=>{e(n,t)&&(o[t]=n[t])})),this):0===arguments.length?l:this;var o,n}render(){return this}destroy(){return this.removeListeners(),this}reload(t){return this.destroy().initialize(this.attr(t)),this}addListeners(){return this}removeListeners(){return this}}const o=t=>!!(r(t)&&t.nodeName&&t.tagName&&1===t.nodeType),n=(t,e=300)=>!!i(t)&&setTimeout((()=>{t()}),e),h=t=>t*t,a=(e=null)=>{let s,i;return e?t(e)?i=document.querySelector(e):o(e)&&(i=e):(s=document.querySelectorAll("html,body"),i=s[0].scrollTop-s[1].scrollTop>=0?s[0]:s[1]),i},c=(t,e,s)=>{const r=a(t);let l=r.scrollTop,o=0;const n=e-l,c=r.scrollHeight,d=e-c<=0?e:c,u=t=>(i(s)&&s(t),!1),p=()=>{if(o+=1,n<0){if(l-=h(o),r.scrollTop=l,l<=e)return r.scrollTop=e,u(e)}else if(l+=h(o),r.scrollTop=l,l>=d)return r.scrollTop=d,u(d);requestAnimationFrame(p)};requestAnimationFrame(p)},d=t=>{let e=t.offsetTop;return null!==t.offsetParent&&(e+=d(t.offsetParent)),e},u=(t,e="")=>{const s=e.replace(/^>/i,"");return!!(e&&s&&t)&&(t.matches?t.matches(s):!!t.msMatchesSelector&&t.msMatchesSelector(s))},p=t=>t.host&&t!==document&&t.host.nodeType?t.host:t.parentNode,m=["focusout","blur","focusin","focus","load","unload","mouseenter","mouseleave"],f=(t,e,s)=>{const i=m.indexOf(e)>-1;s._delegateListener&&delete(s=s._delegateListener)._delegateListener,function(t,e,s){const i=t._listeners;let r=-1;if(i.length<1)return!1;i.forEach(((t,i)=>{const l=t.fn;e===t.type&&(r=i,l===s&&(r=i))})),r>-1&&i.splice(r,1)}(t,e,s),t.removeEventListener(e,s,i)},g=function(e,s,i=!1){const r=t(e)?document.querySelector(e):e,l=r.childNodes,n=((e,s)=>{let i=e._listeners||[];return t(s)&&s&&(i=i.filter((t=>t.type===s))),i})(r,s);n.forEach((t=>{f(r,t.type,t.fn)})),(i||!0===s||1===arguments.length)&&r&&l&&l.forEach((t=>{o(t)&&g(t,s,i)}))},b=(t,e,s)=>{if(!i(s))return g(t,e);f(t,e,s)},y=(t,e,s,i,r,l,o=!1)=>{const n=m.indexOf(s)>-1,h=function(n){const a=function(t){const e=t.target;return(s=e)&&3===s.nodeType?s.parentNode:s;var s}(n),c=((t,e,s,i)=>{const r=s||document;if(!t)return null;do{if(null!=e&&(e.startsWith(">")?t.parentNode===r&&u(t,e):u(t,e))||i&&t===r)return t;if(t===r)break}while(t=p(t))})(a,e,t);let d=l||t;n.delegateTarget=c,!0===l&&(d=r),c&&(!0===o&&b(t,s,h),i.call(d,n,r))};t._listeners||(t._listeners=[]),t._listeners.push({el:t,selector:e,type:s,fn:h,data:r,context:l,capture:n}),i._delegateListener=h,t.addEventListener(s,h,n)},$=function(t){t.stopPropagation(),t.preventDefault()},v={},E=t=>e(v,t)&&v[t].length>0,_=(t,e=!0)=>e?E(t):(t=>{let e=E(t),s=t.lastIndexOf(".");for(;!e&&-1!==s;)s=(t=t.substring(0,s)).lastIndexOf("."),e=E(t);return e})(t),w=(t,e,i=!0)=>{const r=t=>{if(!E(t))return!1;v[t].forEach((t=>{const i=["[object Int8Array]","[object Uint8Array]","[object Uint8ClampedArray]","[object Int16Array]","[object Uint16Array]","[object Int32Array]","[object Uint32Array]","[object Float32Array]","[object Float64Array]","[object BigInt64Array]","[object BigUint64Array]"].indexOf(s(e))>-1?e.toString():e;t.callback.call(t.context||t,i)}))},l=()=>{let e=t,s=t.lastIndexOf(".");for(;-1!==s;)e=e.substring(0,s),s=e.lastIndexOf("."),r(e);r(t),r("*")};if(!_(t))return!1;i?setTimeout(l,10):l()},T=t=>Array.isArray?Array.isArray(t):"[object Array]"===s(t),S=['','','','','','','','',''],L=(e,s="icon")=>t(e)?((t,e="icon")=>{const s=/id="(.*?)"/,i=/^(\w+)-/;return S.find((r=>{const l=s.exec(r)[1];return i.exec(l)[1]===e&&l===("icon"===e?`${e}-${t}`:`${e}-icon-${t}`)}))})(e,s):[...S],x=(e="")=>{const s=document.body;let i=document.querySelector("#outline-icons"),r=[];(e=>{if(!e)return!1;T(e)&&e.length>0?e.forEach((e=>{-1===S.indexOf(e)&&t(e)&&S.push(e)})):t(e)&&S.push(e)})(e),r=L(),i?i.innerHTML=r.join(""):(i=document.createElement("div"),i.innerHTML=``,s.insertBefore(i.firstChild,s.firstChild))},C=e=>!!t(e)&&e.replace(/(^\s+)|(\s+$)/g,""),z=t=>{return!(!r(t)||!(o(t)||(t=>!(!r(t)||"[object NodeList]"!==s(t)))(t)||(e=t,r(e)&&"[object DocumentFragment]"===s(e))||(t=>!(!r(t)||!("[object Text]"===s(t)||t.tagName&&3===t.nodeType)))(t)));var e},k=(t,e,s)=>{let i=t.tagName.toLowerCase();switch(e){case"style":t.style.cssText=s;break;case"value":"input"===i||"textarea"===i?t.value=s:t.setAttribute(e,s);break;case"className":t.className=s;break;default:t.setAttribute(e,s)}},A=(s,i,l)=>{const o=document.createDocumentFragment(),n=document.createElement(s),h=e=>z(e)||t(e),a=e=>{let s;if(!h(e))return!1;z(e)?s=e:t(e)&&(s=document.createTextNode(e)),o.appendChild(s)};return r(i)?Object.keys(i).forEach((t=>{e(i,t)&&k(n,t,i[t])})):T(i)&&i.every((t=>h(t)))&&i.forEach((t=>{a(t)})),T(l)?l.forEach((t=>{a(t)})):a(l),n.appendChild(o),n},N=e=>{const s=new RegExp("^\\s*(?:<\\?xml[^>]*>\\s*)?(?:<\\!doctype svg[^>]*\\s*(?:\\[?(?:\\s*]*>\\s*)*\\]?)*[^>]*>\\s*)?]*>[^]*<\\/svg>\\s*$\\s*$","i");return t(e)&&s.test(e)},O=(e,s={})=>((e,s={})=>{const i=s.size||0,r=s.color||"",l=s.iconSet||"",o=T(i)?i[0]:i,n=T(i)?i[1]:i,h=i?`width:${o}px;height:${n}px;`:"",a=r?h+`color:${r}`:h,c=document.createElement("i");let d,u="",p="";return t(e)?(N(e)?p=e:(u=l&&"icon"!==l?`xlink:href="#${l}-icon-${e}"`:`xlink:href="#icon-${e}"`,p=``),c.className="outline-icon",c.innerHTML=p,N(e)&&(d=c.querySelector("svg"),d.setAttribute("aria-hidden","true"),d.setAttribute("xmlns","http://www.w3.org/2000/svg"),d.setAttribute("class","outline-icon__svg"),d.setAttribute("width","200"),d.setAttribute("height","200"),d.style=a),c):null})(e,s),M=(t,e)=>{const s=new RegExp("(\\s|^)"+e+"(\\s|$)");let i,r;return!!o(t)&&(i=t.className,!!i&&(r=t.classList,r?.contains?t.classList.contains(e):!!s.exec(i)))},D=(t,e)=>{let s,i=t.className;if(!i||!M(t,e))return!1;s=t.classList,s?.remove?s.remove(e):(i=C(i.replace(e,"")),t.className=i)},H=(e,s=!0,i=!0)=>{const r="outline-heading",l=e.innerHTML;let o;if(e.innerHTML=l.replace(/^\d+(\.?\d+)*\s?/gi,""),e.removeAttribute("id"),e.removeAttribute("data-id"),D(e,r),!s)return!1;var n;o=e.querySelector(`.${r}__anchor`),i&&D(e,`${r}_start`),n=C(e.className),t(n)&&""===n&&e.removeAttribute("class"),e.removeChild(o)},j=(e,s=!0)=>{let i=1,r=0;const l=[];return e.forEach(((e,s)=>{const o=e.tagName.replace(/h/i,"");let n=parseInt(o,10),h=-1;var a;n>i?(r+=1,h=1===r?-1:s-1):n===i||nr?1===n?(r=1,h=-1):h=l[s-1].pid:n<=r&&(1===n?r=1:(r-=i-n,r<=1&&(r=1)),h=1===r?-1:((t,e,s)=>{let i,r,l=t[s-1];for(r=0;r]+(>|$)/g,""):"")})})),s?(t=>{const e={};return t.forEach((t=>{const s=JSON.stringify((t=>[t.pid])(t));e[s]=e[s]||[],e[s].push(t),t.index=e[s].length,-1===t.pid&&(t.code=String(t.index))})),Object.keys(e).forEach((s=>{e[s].forEach((e=>{t.filter((t=>t.pid===e.id)).forEach((t=>{t.code=e.code+"."+t.index}))}))})),t})(l):l};class F extends l{constructor(t){super(),this.attrs=F.DEFAULTS,this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],t&&this.initialize(t)}initialize(e){let s,r,l,n,h;return this.attr(e),h=this.attr("articleElement"),r=this.attr("scrollElement"),l=this.attr("selector"),s=this.attr("created"),t(h)?n=document.querySelector(h):o(h)&&(n=h),n?(this.$articleElement=n,this.$scrollElement=a(r),this.$headings=[...n.querySelectorAll(l)],this.$headings.length<1||(this.chapters=j(this.$headings),i(s)&&s.call(this),this.render().addListeners()),this):this}getChapters(t=!1){const e=this.chapters;return t?((t,e,s)=>{const i={},r=[];return t.forEach(((t,s)=>{i[t[e]]=s,t.children=[]})),t.forEach((e=>{const l=t[i[e[s]]];-1!==e[s]?l.children.push(e):r.push(e)})),r})(e,"id","pid"):e}count(){return this.chapters.length}render(){const t=this.attr("mounted"),e=this.attr("hasAnchor"),s=this.attr("isAtStart"),r=this.attr("showCode"),l=this.attr("anchorURL"),o=this.$headings,n=this.getChapters();return x(),o.forEach(((t,i)=>{const o=n[i].code;((t,e,s)=>{const i=document.createDocumentFragment(),r="outline-heading",l=s.hasAnchor||!0,o=s.isAtStart||!0,n=s.showCode||!1,h=s.chapterCode||"",a=s.anchorURL||"",c=`heading-${e}`,d={id:c,className:o?`${r} ${r}_start`:r,"data-id":e},u=Object.keys(d),p=C(t.innerHTML);let m,f;if(u.forEach((e=>{k(t,e,d[e])})),n&&(t.innerHTML=h+" "+p),!l)return!1;f=O("hash",{iconSet:"outline"}),m=A("a",{id:`anchor-${e}`,className:`${r}__anchor anchor-${e}`,href:a||`#${c}`,target:a?"_blank":"self","data-id":e},[f]),i.appendChild(m),t.appendChild(i)})(t,i,{hasAnchor:e,isAtStart:s,showCode:r,chapterCode:o,anchorURL:l})})),i(t)&&t.call(this),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}destroy(){const t=this.attr("hasAnchor"),e=this.attr("isAtStart"),s=this.attr("beforeDestroy"),r=this.attr("afterDestroy"),l=this.$headings;return i(s)&&s.call(this),this.removeListeners(),l.forEach((s=>{H(s,t,e)})),this.attr(F.DEFAULTS),this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],i(r)&&r.call(this),this}onAnchorTrigger(t){const e=this.attr("anchorURL"),s=this.attr("afterScroll"),r=this.attr("stickyHeight"),l=t.delegateTarget.parentNode,o=d(l)-(r+10),h=this.$scrollElement,a=h.scrollHeight-h.clientHeight;return this.scrollTo(o,(()=>{i(s)&&s.call(this,"anchor"),n((()=>{w("toolbar:update",{top:o,min:0,max:a})}))})),e||$(t),this}addListeners(){const t=this.$articleElement;return y(t,".outline-heading__anchor","click",this.onAnchorTrigger,this,!0),this}removeListeners(){const t=this.$articleElement;return b(t,"click",this.onAnchorTrigger),this}}F.DEFAULTS={scrollElement:"html,body",articleElement:"#article",selector:"h1,h2,h3,h4,h5,h6",stickyHeight:0,anchorURL:"",hasAnchor:!0,isAtStart:!0,showCode:!1,created:null,mounted:null,afterScroll:null,beforeDestroy:null,afterDestroy:null};const U=(t,e)=>{let s,i;if(M(t,e))return!1;s=t.classList,s?.add?s.add(e):(i=t.className,i+=i.length>0?" "+e:e,t.className=i)},I=(t,e)=>{document.documentElement.style.setProperty(t,e)};let q=2e3;const B=t=>(t?q=t:q+=1,I("--outline-zIndex",`${q}`),q);class R extends l{constructor(t){super(),this.attrs=R.DEFAULTS,this.title="",this.closed=!0,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,this.zIndex=0,t&&this.initialize(t)}initialize(t){let e;return this.attr(t),this.title=this.attr("title"),e=this.attr("created"),i(e)&&e.call(this),this.render().addListeners(),this}setTitle(t){return this.attr("title",t),this.title=t,this.$title.innerHTML=t,this}isClosed(){return this.closed}render(){const t=this.attr("mounted"),e=this.attr("size"),s=this.attr("placement"),r=this.attr("hasClose"),l=this.attr("hasOverlay"),o=this.attr("hasOffset"),n=this.attr("hasPadding"),h=this.attr("autoHeight"),a=this.attr("customClass");let c,d,u,p,m,f,g,b;return x(),this.zIndex=B(),p=A("h2",{className:"outline-drawer__title"},[this.title]),this.$title=p,r&&(m=A("div",{className:"outline-drawer__close"},[O("close",{size:20})]),this.$close=m),u=A("header",{className:"outline-drawer__header"},[p,m]),this.$header=u,f=A("div",{className:"outline-drawer__main"},[""]),this.$main=f,n||U(f,"outline-drawer_full"),g=A("footer",{className:"outline-drawer__footer"},[""]),this.$footer=g,d=A("div",{className:`outline-drawer__modal outline-drawer_${s} outline-drawer_${e} outline-drawer_closed`},[u,f,g]),this.$modal=d,o&&U(d,"outline-drawer_offset"),h&&U(d,"outline-drawer_auto"),a&&U(d,a),l&&(b=A("div",{className:"outline-drawer__overlay"},[""]),this.$overlay=b),c=A("div",{className:"outline-drawer"},[d,b]),this.$el=c,document.body.appendChild(c),i(t)&&t.call(this),this}open(){const t=this.attr("afterOpened"),e=this.$modal;return U(this.$el,"outline-drawer_opened"),D(e,"outline-drawer_closed"),U(e,"outline-drawer_opened"),n((()=>{this.closed=!1,i(t)&&t.call(this)})),this}close(){const t=this.attr("afterClosed"),e=this.$modal;return D(e,"outline-drawer_opened"),U(e,"outline-drawer_closed"),n((()=>{D(this.$el,"outline-drawer_opened"),this.closed=!0,i(t)&&t.call(this)})),this}toggle(){const t=this.attr("afterToggle"),e=this.isClosed();return e?this.open():this.close(),i(t)&&n((()=>{t.call(this,e)})),this}destroy(){const t=this.attr("afterDestroy"),e=this.attr("beforeDestroy");let s=this.zIndex;return i(e)&&e.call(this),this.removeListeners(),this.attrs=R.DEFAULTS,this.title="",this.closed=!1,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,s-=1,B(s),this.zIndex=0,i(t)&&t.call(this),this}addListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t&&y(s,".outline-drawer__close","click",this.onClose,this,!0),e&&y(s,".outline-drawer__overlay","click",this.onClose,this,!0),this}removeListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t||e?(b(s,"click",this.onClose),this):this}onClose(){return this.close(),this}}R.DEFAULTS={placement:"rtl",title:"标题",size:"regular",hasClose:!0,hasOverlay:!0,hasOffset:!1,hasPadding:!0,autoHeight:!0,created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterToggle:null};const P=(t,e,s,r,l,o=!1)=>{const n=m.indexOf(e)>-1,h=function(i){let n=l||t;!0===l&&(n=r),!0===o&&b(t,e,h),s.call(n,i,r)};if(!i(s))return!1;t._listeners||(t._listeners=[]),t._listeners.push({el:t,type:e,fn:h,data:r,context:l,capture:n}),s._delegateListener=h,t.addEventListener(e,h,n)},Q=(t,e)=>getComputedStyle(t)[e];class W extends l{constructor(t){super(),this.attrs=W.DEFAULTS,this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.closed=!1,this.active=0,this.offsetTop=0,this.offsetWidth=0,this.$active=null,this.scrollTimer=null,this.resizeTimer=null,this.playing=!1,this.Observer=null,t&&this.initialize(t)}initialize(e){let s,r,l,n;return this.attr(e),s=this.attr("created"),r=this.attr("parentElement"),l=this.attr("scrollElement"),t(r)?n=document.querySelector(r):o(r)&&(n=r),this.$parentElement=n,this.$scrollElement=a(l),this.chapters=this.attr("chapters"),this.closed=this.attr("closed"),this.active=this.attr("active"),i(s)&&s.call(this),this.chapters.length<1||(this.render().addListeners(),this.$active=document.querySelector(`#chapter-${this.active}`)),this}isClosed(){return this.closed}isSticky(){return"sticky"===this.attr("position")}isFixed(){return"fixed"===this.attr("position")}isInside(){return this.isFixed()||this.isSticky()}isOutside(){return!this.isInside()}_paintEdge(){const t=document.createDocumentFragment(),e=this.attr("title"),s=this.attr("customClass"),i=this.$parentElement,r=[];let l,o,n,h,a=null;return i?(this.isInside()&&(a=A("h2",{className:"outline-chapters__title"},[e]),this.$title=a,r.push(a)),n=A("ul",{className:"outline-chapters__list"},[""]),this.$list=n,h=A("div",{className:"outline-chapters__placeholder"},[""]),this.$placeholder=h,o=A("div",{className:"outline-chapters__main"},[n,h]),this.$main=o,r.push(o),l=A("nav",{id:"outline-chapters",className:"outline-chapters outline-chapters_hidden"},r),this.$el=l,this.isSticky()&&(this.calculateStickyHeight(),U(l,"outline-chapters_sticky")),s&&U(l,s),t.appendChild(l),i.appendChild(t),this):this}render(){const t=this.attr("showCode"),e=this.attr("mounted"),s=this.$parentElement,r=this.chapters;let l,o;return!s||r.length<1||(this._paintEdge(),l=this.$el,o=this.$list,((t,e,s=!1)=>{const i=t=>document.querySelector(`#${t}`);e.forEach((e=>{const r=e.pid,l=e.id,o=e.rel,n=A("span",{className:"outline-chapters__text"},[e.text]),h=A("a",{id:`chapter__anchor-${l}`,className:"outline-chapters__anchor",href:"#"+o,rel:o,"data-id":l},[n]);let a,c,d,u;s&&(a=A("span",{className:"outline-chapters__code","data-id":l},[e.code]),h.insertBefore(a,h.firstChild)),c=A("li",{id:`chapter-${l}`,className:"outline-chapters__item","data-id":l},[h]),-1===r?t.appendChild(c):(u=i(`chapter-${r}`),d=i(`subject-${r}`),d?d.appendChild(c):(d=A("ul",{id:"subject-"+r,className:"outline-chapters__subject"},[c]),u.appendChild(d)))}))})(o,r,t),D(l,"outline-chapters_hidden"),this.positionPlaceholder(this.active),this.offsetTop=d(l),this.offsetWidth=l.offsetWidth,this.isFixed()&&(this.sticky(),I("--outline-chapters-width",`${this.offsetWidth}px`)),i(e)&&e.call(this),this.onObserver()),this}positionPlaceholder(t){const e=this.$main,s=this.$list,i=this.$placeholder,r=s.querySelector(".outline-chapters__anchor"),l=parseInt(Q(e,"padding-top"),10),o=parseInt(Q(e,"border-top-width"),10),n=parseInt(Q(s,"padding-top"),10),h=parseInt(Q(s,"margin-top"),10),a=parseInt(Q(s,"border-top-width"),10);let c,d=r.offsetHeight,u=0;return l&&(u+=l),n&&(u+=n),h&&(u+=h),o&&(u+=o),a&&(u+=a),c=d*t,i.style.cssText=`transform: translateY(${u+c}px);height:${d}px;`,this}highlight(t){const e=this.$el.querySelector(`#chapter__anchor-${t}`),s="outline-chapters_active";return e?(this.$active&&D(this.$active,s),this.active=parseInt(e.getAttribute("data-id"),10),this.$active=e,U(this.$active,s),this.positionPlaceholder(this.active),this):this}sticky(){const t=this.attr("afterSticky"),e="outline-chapters_fixed",s=this.$el,r=this.offsetTop,l=this.$scrollElement.scrollTop;let o;return this.isFixed()?(o=l>=r,o?U(s,e):D(s,e),i(t)&&t.call(this,this.isClosed(),o),this):this}calculateStickyHeight(){const t=document.documentElement,e=Math.max(t.clientHeight||0,window.innerHeight||0);return I("--outline-sticky-height",`${e}px`),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}show(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterOpened"),r=this.$el,l=this.$parentElement;return this.isInside()?(D(l,e),D(r,e),n((()=>{D(l,t),D(r,t)}),30)):D(r,e),this.closed=!1,i(s)&&s.call(this),this}hide(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterClosed"),r=this.$el,l=this.$parentElement;return this.isInside()?(U(l,t),U(r,t),n((()=>{U(l,e),U(r,e)}))):U(r,e),this.closed=!0,i(s)&&s.call(this),this}toggle(){const t=this.attr("afterToggle"),e=this.offsetTop,s=this.$scrollElement.scrollTop;let r;return this.isClosed()?this.show():this.hide(),i(t)&&n((()=>{r=s>=e,t.call(this,this.isClosed(),r)})),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");return i(t)&&t.call(this),this.removeListeners(),this.$parentElement.removeChild(this.$el),this.attr(W.DEFAULTS),this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.active=0,this.offsetTop=0,this.$active=null,this.closed=!1,this.scrollTimer&&(clearTimeout(this.scrollTimer),this.scrollTimer=null),this.resizeTimer&&(clearTimeout(this.resizeTimer),this.resizeTimer=null),i(e)&&e.call(this),this.Observer&&(this.Observer=null),this}onObserver(){const t=this.attr("selector");let e=null;return this.Observer=((t,e={})=>{const s=e.root||null,r=e.selector||".outline-heading",l=e.context||null,n={rootMargin:e.rootMargin||"0px 0px -90% 0px"},h=new IntersectionObserver((e=>{e.forEach((e=>{e.intersectionRatio>0&&i(t)&&t.call(l||e.target,e.target)}))}),n),a=o(s)?s:document;return s&&(n.root=s),a.querySelectorAll(r).forEach((t=>{h.observe(t)})),h})((t=>{const s=t.getAttribute("data-id");if(this.playing)return!1;e&&clearTimeout(e),e=n((()=>{this.highlight(s)}),100)}),{selector:t,context:this}),this}onSelect(t){const e=this.attr("stickyHeight"),s=t.delegateTarget,r=s.getAttribute("data-id"),l=s.href.split("#")[1],o=document.querySelector(`#${l}`),h=d(o)-(e+10),a=this.$scrollElement.scrollHeight,c=this.attr("afterScroll"),u=()=>{i(c)&&c.call(this,"chapter"),n((()=>{this.playing=!1,w("toolbar:update",{top:h,min:0,max:a})}))};return this.playing=!0,this.isFixed()?(this.sticky(),n((()=>{this.scrollTo(h,u),this.highlight(r)}),10)):(this.scrollTo(h,u),this.highlight(r)),$(t),this}onScroll(){const t=this.$scrollElement;return this.scrollTimer&&clearTimeout(this.scrollTimer),this.scrollTimer=n((()=>{const e=t.scrollTop,s=t.scrollHeight-t.clientHeight;this.isFixed()&&this.sticky(),w("toolbar:update",{top:e,min:0,max:s})}),100),this}onResize(){return this.resizeTimer&&clearTimeout(this.resizeTimer),this.resizeTimer=n((()=>{this.calculateStickyHeight()})),this}addListeners(){const t=this.$el,e=this.$scrollElement,s=e.tagName.toLowerCase();let i=e;return"html"!==s&&"body"!==s||(i=window),y(t,".outline-chapters__anchor","click",this.onSelect,this,!0),P(i,"scroll",this.onScroll,this,!0),this.isSticky()&&P(i,"resize",this.onResize,this,!0),this}removeListeners(){const t=this.attr("selector"),e=this.$el,s=this.$scrollElement,i=s.tagName.toLowerCase();let r=s;return"html"!==i&&"body"!==i||(r=window),b(e,"click",this.onSelect),b(r,"scroll",this.onScroll),this.isSticky()&&P(r,"resize",this.onResize),this.Observer&&document.querySelectorAll(t).forEach((t=>{this.Observer.unobserve(t)})),this}}W.DEFAULTS={parentElement:"",scrollElement:"",selector:".outline-heading",active:0,closed:!1,showCode:!0,position:"relative",stickyHeight:0,chapters:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterSticky:null};const V=(t,e=!0)=>{const s=O(t.icon,{iconSet:t.iconSet||"outline",color:t.color||"",size:t.size}),i=A("a",{className:"outline-toolbar__anchor",href:t.link},[s]),r=A("div",{className:`outline-toolbar__button ${t.name}`},[t.link?i:s]);return U(s,"outline-toolbar__icon"),e&&U(r,"outline-toolbar_rounded"),t.disabled&&U(r,"outline-toolbar_disabled"),r},J="outline-toolbar_disabled",Y="outline-toolbar_hidden";class G extends l{constructor(t){super(),this.attrs=G.DEFAULTS,this.$el=null,this.disabled=!1,this.closed=!1,this.buttons=[],t&&this.initialize(t)}initialize(t){let e;return this.attr(t),e=this.attr("created"),this.disabled=this.attr("disabled"),this.closed=this.attr("closed"),i(e)&&e.call(this),this.render().addListeners(),this}isDisabled(t){const e=this.attr("buttons");let s;return t?(s=e.find((e=>e.name===t)),s?.disabled):this.disabled}isClosed(){return this.closed}highlight(t){const e=this.buttons.find((e=>e.name===t)),s="outline-toolbar_active";let i;return i||(i=e.$el,M(i,s)?D(i,s):U(i,s)),this}render(){const t=this.attr("mounted"),e=this.attr("buttons")||[],s=this.attr("rounded"),r=this.attr("placement"),l=document.createDocumentFragment(),o=document.createDocumentFragment();return x(),e.forEach((t=>{const e=V(t,s);l.appendChild(e),this.buttons.push({name:t.name,$el:e})})),this.$el=A("div",{id:"outline-toolbar",className:`outline-toolbar outline-toolbar_${r}`},[l]),o.appendChild(this.$el),document.body.appendChild(o),this.closed&&this.hide(),this.disabled&&this.disable(),i(t)&&t.call(this),this}add(t){const e=this.$el,s=this.attr("buttons"),l=t.action,o=document.createDocumentFragment();let n;return r(t)?(s.push(t),o.appendChild(V(t))):T(t)&&t.forEach((t=>{o.appendChild(V(t))})),e.appendChild(o),l&&i(l.handler)&&(n=l.type||"click",y(e,`.${t.name}`,n,l.handler)),this}remove(t){const e=this.$el,s=this.attr("buttons"),i=s.find((e=>e.name===t));let r,l=-1;return i?(s.forEach(((e,s)=>{e.name===t&&(l=s)})),l>-1&&this.attr().buttons.splice(l,1),r=e.querySelector(`.${t}`),this.switch(t,!1),e.removeChild(r),this):this}switch(t,e){const s=this.$el,i=this.attr("buttons"),r=i.find((e=>e.name===t));let l,o,n,h;return r?(i.forEach((s=>{s.name===t&&(r.disabled=!e)})),l=r.action,h=s.querySelector(`.${t}`),l&&(o=l.type||"click",n=l.handler),e?(D(h,J),o&&n&&y(s,`.${t}`,o,n)):(U(h,J),o&&n&&b(s,o,n)),this):this}disable(t){const e=this.attr("afterDisabled");return t?this.switch(t,!1):(U(this.$el,J),this.removeListeners(),this.disabled=!0,i(e)&&e.call(this)),this}enable(t){const e=this.attr("afterEnabled");return t?this.switch(t,!0):(this.disabled=!1,D(this.$el,J),this.addListeners(),i(e)&&e.call(this)),this}show(t){const e=this.attr("afterOpened"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),D(l,Y)}else D(r,Y),this.closed=!1,i(e)&&n((()=>{e.call(this)}),310);return this}hide(t){const e=this.attr("afterClosed"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),U(l,Y)}else U(r,Y),this.closed=!0,i(e)&&n((()=>{e.call(this)}),310);return this}toggle(){return this.isClosed()?this.show():this.hide(),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");let s=this.$el;return i(t)&&t.call(this),this.removeListeners(),document.body.removeChild(s),s=null,this.attr(G.DEFAULTS),this.disabled=!1,this.closed=!1,this.buttons=[],i(e)&&e.call(this),this}refresh(){const t=this.$el,e=this.attr("buttons")||[];return this.removeListeners(),t.innerHTML="",e.forEach((t=>{this.$el.appendChild(V(t))})),this.addListeners(),this}addListeners(){const e=this.attr("buttons"),s=this.$el;return!e||e.length<1||e.forEach((e=>{const r=e.action;let l,o,n,h;if(this.disabled)return!1;r&&(o=r.handler,t(o)&&(h=o,r.handler=function(){w(h,e.name)},o=r.handler),l=r.type||"click",n=r.context),i(o)&&y(s,`.${e.name}`,l,o,n||this,!0)})),this}removeListeners(){const t=this.attr("buttons"),e=this.$el;return!t||t.length<1||t.forEach((t=>{const s=t.action;let r,l;if(this.disabled)return!1;s&&(l=s.handler,r=s.type||"click"),i(l)&&b(e,r,l)})),this}}G.DEFAULTS={placement:"ltr",closed:!1,disabled:!1,rounded:!0,buttons:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterDisabled:null,afterEnabled:null,beforeDestroy:null,afterDestroy:null};const K=(()=>{let t=0;return e=>(t+=1,e?e+"-"+t:"guid-"+t)})(),X=(t,e,s=null)=>{const r=K();let l="symbol"==typeof t?t.toString():t;return i(e)?(v[l]||(v[l]=[]),v[l].push({topic:l,callback:e,context:s,token:r}),r):""},Z=t=>{if(!e(v,t))return!1;delete v[t]},tt=(t,e)=>{if(!_(t))return!1;e?(t=>{const e=Object.keys(v);if(!t||e.length<1)return!1;e.forEach((e=>{const s=v[e];let i;s.forEach(((e,r)=>{e.callback!==t&&e.token!==t||(i=e.topic,s.splice(-1,r))})),s.length<1&&Z(i)}))})(e):Z(t)};class et extends l{constructor(t){super(),this.attrs=et.DEFAULTS,this.anchors=null,this.drawer=null,this.chapters=null,this.toolbar=null,this.buttons=[],t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}getChapters(t=!1){return this.anchors.getChapters(t)}count(){return this.anchors.count()}render(){const t=this.attr("scrollElement"),e=document.querySelector(t)||document.getElementById(t);return this._renderAnchors()._renderChapters()._renderToolbar(),e&&this.onToolbarUpdate({top:e.scrollTop,min:0,max:e.scrollHeight}),this}_renderAnchors(){const t=this.attr("articleElement"),e=this.attr("selector"),s=this.attr("stickyHeight"),i=this.attr("scrollElement"),r=this.attr("showCode"),l=this.attr("anchorURL"),o=this.attr("afterScroll");return this.anchors=new F({articleElement:t,stickyHeight:s,scrollElement:i,selector:e,showCode:r,anchorURL:l,afterScroll:o}),this}_renderChapters(){const t=this.attr("title"),e=this.attr("stickyHeight"),s=this.attr("scrollElement"),i=this.attr("customClass"),r=this.attr("showCode"),l=this.attr("position"),o=this.attr("placement"),n=this.attr("afterSticky"),h=this.attr("afterToggle"),a=this.attr("afterScroll"),c=this.count();let d,u=this.attr("parentElement");return c<1||(d={scrollElement:s,showCode:r,position:l,title:t,stickyHeight:e,chapters:this.getChapters(),afterSticky:n,afterToggle:h,afterScroll:a},"relative"===l?(this.drawer=new R({placement:o,title:t,size:"tiny",hasOffset:!0,hasPadding:!1,customClass:i,afterClosed:()=>{this.toolbar.toggle()}}),u=this.drawer.$main):d.customClass=i,d.parentElement=u,this.chapters=new W(d)),this}_renderToolbar(){const t=this.attr("placement"),e=this.attr("homepage"),s=this.attr("git"),i=this.attr("tags"),r=this.attr("issues"),l=this.attr("tools"),o=this.count(),n={name:"homepage",icon:"homepage",size:20,link:e},h={name:"github",icon:"github",size:20,link:s},a={name:"tags",icon:"tags",size:20,link:i},c={name:"issues",icon:"issues",size:20,link:r},d={name:"menu",icon:"menu",size:18,action:{type:"click",handler:"toolbar:action:toggle"}},u=[];return u.push({name:"up",icon:"up",size:20,action:{type:"click",handler:"toolbar:action:up"}}),e&&u.push(n),o>0&&u.push(d),s&&u.push(h),i&&u.push(a),r&&u.push(c),l?.length>0&&u.push(...l),u.push({name:"down",icon:"down",size:20,action:{type:"click",handler:"toolbar:action:down"}}),this.buttons=[...u],this.toolbar=new G({placement:t,buttons:u}),this}addButton(t){const e=this.toolbar,s=this.buttons;return s.splice(-1,0,t),e.attr({buttons:s}),e.refresh(),this}removeButton(t){return this.toolbar.remove(t),this}toTop(){const t=this.attr("afterScroll"),e=this.toolbar,s=this.chapters,r=this.count();return r>0&&(s.playing=!0),this.scrollTo(0,(()=>{e.hide("up"),e.show("down"),r>0&&(s.highlight(0),s.playing=!1),i(t)&&t.call(e,"up")})),this}toBottom(){const t=this.attr("afterScroll"),e=a(this.attr("scrollElement")),s=this.toolbar,r=this.chapters,l=this.count(),o=Math.floor(e.scrollHeight-e.clientHeight);return l>0&&(r.playing=!0),this.scrollTo(o,(()=>{s.hide("down"),s.show("up"),l>0&&(r.highlight(l-1),r.playing=!1),i(t)&&t.call(s,"bottom")})),this}scrollTo(t,e){const s=this.attr("scrollElement");return c(s,t,e),this}toggle(){const t=this.attr("position"),e=this.toolbar,s=this.drawer,i=this.chapters;return this.count()<1||("relative"!==t?(i.toggle(),e.highlight("menu")):(e.toggle(),n((()=>{i.isInside()?i.toggle():s.toggle()})))),this}destroy(){let t=this.anchors,e=this.chapters,s=this.drawer,i=this.toolbar,r=!1;const l=this.count();return this.removeListeners(),l>0&&(r=e.isOutside(),e.destroy(),e=null,r&&(s.destroy(),s=null)),i.destroy(),i=null,t.destroy(),t=null,this.attr(et.DEFAULTS),this}onToggle(){return this.toggle(),this}onScrollTop(){return this.toTop(),this}onScrollBottom(){return this.toBottom(),this}onToolbarUpdate({top:t,min:e,max:s}){const i=this.toolbar,r=Math.ceil(t);return r<=e?(i.hide("up"),i.show("down")):r>=s?(i.hide("down"),i.show("up")):r>e&&r"string"==typeof t,e=(t,e)=>{const s=Object.prototype.hasOwnProperty;return t&&s.call(t,e)},s=t=>Object.prototype.toString.apply(t),i=t=>"function"==typeof t||"[object Function]"===s(t),r=t=>("[object Object]"===s(t)||"object"==typeof t||i(t))&&null!==t;class l{constructor(t){this.attrs={},t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}attr(s,i){const l=this.attrs;return t(s)?i&&e(l,s)?(l[s]=i,this):l[s]:r(s)?(n=l,o=s,Object.keys(o).forEach((t=>{e(o,t)&&(n[t]=o[t])})),this):0===arguments.length?l:this;var n,o}render(){return this}destroy(){return this.removeListeners(),this}reload(t){return this.destroy().initialize(this.attr(t)),this}addListeners(){return this}removeListeners(){return this}}const n=t=>!!(r(t)&&t.nodeName&&t.tagName&&1===t.nodeType),o=(t,e=300)=>!!i(t)&&setTimeout((()=>{t()}),e),h=t=>t*t,a=(e=null)=>{let s,i;return e?t(e)?i=document.querySelector(e):n(e)&&(i=e):(s=document.querySelectorAll("html,body"),i=s[0].scrollTop-s[1].scrollTop>=0?s[0]:s[1]),i},c=(t,e,s)=>{const r=a(t);let l=r.scrollTop,n=0;const o=e-l,c=r.scrollHeight,d=e-c<=0?e:c,u=t=>(i(s)&&s(t),!1),p=()=>{if(n+=1,o<0){if(l-=h(n),r.scrollTop=l,l<=e)return r.scrollTop=e,u(e)}else if(l+=h(n),r.scrollTop=l,l>=d)return r.scrollTop=d,u(d);requestAnimationFrame(p)};requestAnimationFrame(p)},d=t=>{let e=t.offsetTop;return null!==t.offsetParent&&(e+=d(t.offsetParent)),e},u=(t,e="")=>{const s=e.replace(/^>/i,"");return!!(e&&s&&t)&&(t.matches?t.matches(s):!!t.msMatchesSelector&&t.msMatchesSelector(s))},p=t=>t.host&&t!==document&&t.host.nodeType?t.host:t.parentNode,m=["focusout","blur","focusin","focus","load","unload","mouseenter","mouseleave"],f=(t,e,s)=>{const i=m.indexOf(e)>-1;s._delegateListener&&delete(s=s._delegateListener)._delegateListener,function(t,e,s){const i=t._listeners;let r=-1;if(i.length<1)return!1;i.forEach(((t,i)=>{const l=t.fn;e===t.type&&(r=i,l===s&&(r=i))})),r>-1&&i.splice(r,1)}(t,e,s),t.removeEventListener(e,s,i)},g=function(e,s,i=!1){const r=t(e)?document.querySelector(e):e,l=r.childNodes,o=((e,s)=>{let i=e._listeners||[];return t(s)&&s&&(i=i.filter((t=>t.type===s))),i})(r,s);o.forEach((t=>{f(r,t.type,t.fn)})),(i||!0===s||1===arguments.length)&&r&&l&&l.forEach((t=>{n(t)&&g(t,s,i)}))},b=(t,e,s)=>{if(!i(s))return g(t,e);f(t,e,s)},y=(t,e,s,i,r,l,n=!1)=>{const o=m.indexOf(s)>-1,h=function(o){const a=function(t){const e=t.target;return(s=e)&&3===s.nodeType?s.parentNode:s;var s}(o),c=((t,e,s,i)=>{const r=s||document;if(!t)return null;do{if(null!=e&&(e.startsWith(">")?t.parentNode===r&&u(t,e):u(t,e))||i&&t===r)return t;if(t===r)break}while(t=p(t))})(a,e,t);let d=l||t;o.delegateTarget=c,!0===l&&(d=r),c&&(!0===n&&b(t,s,h),i.call(d,o,r))};t._listeners||(t._listeners=[]),t._listeners.push({el:t,selector:e,type:s,fn:h,data:r,context:l,capture:o}),i._delegateListener=h,t.addEventListener(s,h,o)},$=function(t){t.stopPropagation(),t.preventDefault()},v={},E=t=>e(v,t)&&v[t].length>0,_=(t,e=!0)=>e?E(t):(t=>{let e=E(t),s=t.lastIndexOf(".");for(;!e&&-1!==s;)s=(t=t.substring(0,s)).lastIndexOf("."),e=E(t);return e})(t),w=(t,e,i=!0)=>{const r=t=>{if(!E(t))return!1;v[t].forEach((t=>{const i=["[object Int8Array]","[object Uint8Array]","[object Uint8ClampedArray]","[object Int16Array]","[object Uint16Array]","[object Int32Array]","[object Uint32Array]","[object Float32Array]","[object Float64Array]","[object BigInt64Array]","[object BigUint64Array]"].indexOf(s(e))>-1?e.toString():e;t.callback.call(t.context||t,i)}))},l=()=>{let e=t,s=t.lastIndexOf(".");for(;-1!==s;)e=e.substring(0,s),s=e.lastIndexOf("."),r(e);r(t),r("*")};if(!_(t))return!1;i?setTimeout(l,10):l()},T=t=>Array.isArray?Array.isArray(t):"[object Array]"===s(t),S=['','','','','','','','',''],L=(e,s="icon")=>t(e)?((t,e="icon")=>{const s=/id="(.*?)"/,i=/^(\w+)-/;return S.find((r=>{const l=s.exec(r)[1];return i.exec(l)[1]===e&&l===("icon"===e?`${e}-${t}`:`${e}-icon-${t}`)}))})(e,s):[...S],x=(e="")=>{const s=document.body;let i=document.querySelector("#outline-icons"),r=[];(e=>{if(!e)return!1;T(e)&&e.length>0?e.forEach((e=>{-1===S.indexOf(e)&&t(e)&&S.push(e)})):t(e)&&S.push(e)})(e),r=L(),i?i.innerHTML=r.join(""):(i=document.createElement("div"),i.innerHTML=``,s.insertBefore(i.firstChild,s.firstChild))},C=e=>!!t(e)&&e.replace(/(^\s+)|(\s+$)/g,""),z=t=>{return!(!r(t)||!(n(t)||(t=>!(!r(t)||"[object NodeList]"!==s(t)))(t)||(e=t,r(e)&&"[object DocumentFragment]"===s(e))||(t=>!(!r(t)||!("[object Text]"===s(t)||t.tagName&&3===t.nodeType)))(t)));var e},k=(t,e,s)=>{let i=t.tagName.toLowerCase();switch(e){case"style":t.style.cssText=s;break;case"value":"input"===i||"textarea"===i?t.value=s:t.setAttribute(e,s);break;case"className":t.className=s;break;default:t.setAttribute(e,s)}},A=(s,i,l)=>{const n=document.createDocumentFragment(),o=document.createElement(s),h=e=>z(e)||t(e),a=e=>{let s;if(!h(e))return!1;z(e)?s=e:t(e)&&(s=document.createTextNode(e)),n.appendChild(s)};return r(i)?Object.keys(i).forEach((t=>{e(i,t)&&k(o,t,i[t])})):T(i)&&i.every((t=>h(t)))&&i.forEach((t=>{a(t)})),T(l)?l.forEach((t=>{a(t)})):a(l),o.appendChild(n),o},N=e=>{const s=new RegExp("^\\s*(?:<\\?xml[^>]*>\\s*)?(?:<\\!doctype svg[^>]*\\s*(?:\\[?(?:\\s*]*>\\s*)*\\]?)*[^>]*>\\s*)?]*>[^]*<\\/svg>\\s*$\\s*$","i");return t(e)&&s.test(e)},M=(e,s={})=>((e,s={})=>{const i=s.size||0,r=s.color||"",l=s.iconSet||"",n=T(i)?i[0]:i,o=T(i)?i[1]:i,h=i?`width:${n}px;height:${o}px;`:"",a=r?h+`color:${r}`:h,c=document.createElement("i");let d,u="",p="";return t(e)?(N(e)?p=e:(u=l&&"icon"!==l?`xlink:href="#${l}-icon-${e}"`:`xlink:href="#icon-${e}"`,p=``),c.className="outline-icon",c.innerHTML=p,N(e)&&(d=c.querySelector("svg"),d.setAttribute("aria-hidden","true"),d.setAttribute("xmlns","http://www.w3.org/2000/svg"),d.setAttribute("class","outline-icon__svg"),d.setAttribute("width","200"),d.setAttribute("height","200"),d.style=a),c):null})(e,s),H=(t,e)=>{const s=new RegExp("(\\s|^)"+e+"(\\s|$)");let i,r;return!!n(t)&&(i=t.className,!!i&&(r=t.classList,r?.contains?t.classList.contains(e):!!s.exec(i)))},O=(t,e)=>{let s,i=t.className;if(!i||!H(t,e))return!1;s=t.classList,s?.remove?s.remove(e):(i=C(i.replace(e,"")),t.className=i)},D=(e,s=!0,i=!0)=>{const r="outline-heading",l=e.innerHTML;let n;if(e.innerHTML=l.replace(/^\d+(\.?\d+)*\s?/gi,""),e.removeAttribute("id"),e.removeAttribute("data-id"),O(e,r),!s)return!1;var o;n=e.querySelector(`.${r}__anchor`),i&&O(e,`${r}_start`),o=C(e.className),t(o)&&""===o&&e.removeAttribute("class"),e.removeChild(n)},j=(e,s=!0)=>{let i=1,r=0;const l=[];return e.forEach(((e,s)=>{const n=e.tagName.replace(/h/i,"");let o=parseInt(n,10),h=-1;var a;o>i?(r+=1,h=1===r?-1:s-1):o===i||or?1===o?(r=1,h=-1):h=l[s-1].pid:o<=r&&(1===o?r=1:(r-=i-o,r<=1&&(r=1)),h=1===r?-1:((t,e,s)=>{let i,r,l=t[s-1];for(r=0;r]+(>|$)/g,""):"")})})),s?(t=>{const e={};return t.forEach((t=>{const s=JSON.stringify((t=>[t.pid])(t));e[s]=e[s]||[],e[s].push(t),t.index=e[s].length,-1===t.pid&&(t.code=String(t.index))})),Object.keys(e).forEach((s=>{e[s].forEach((e=>{t.filter((t=>t.pid===e.id)).forEach((t=>{t.code=e.code+"."+t.index}))}))})),t})(l):l};class F extends l{constructor(t){super(),this.attrs=F.DEFAULTS,this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],t&&this.initialize(t)}initialize(e){let s,r,l,o,h;return this.attr(e),h=this.attr("articleElement"),r=this.attr("scrollElement"),l=this.attr("selector"),s=this.attr("created"),t(h)?o=document.querySelector(h):n(h)&&(o=h),o?(this.$articleElement=o,this.$scrollElement=a(r),this.$headings=[...o.querySelectorAll(l)],this.$headings.length<1||(this.chapters=j(this.$headings),i(s)&&s.call(this),this.render().addListeners()),this):this}getChapters(t=!1){const e=this.chapters;return t?((t,e,s)=>{const i={},r=[];return t.forEach(((t,s)=>{i[t[e]]=s,t.children=[]})),t.forEach((e=>{const l=t[i[e[s]]];-1!==e[s]?l.children.push(e):r.push(e)})),r})(e,"id","pid"):e}count(){return this.chapters.length}render(){const t=this.attr("mounted"),e=this.attr("hasAnchor"),s=this.attr("isAtStart"),r=this.attr("showCode"),l=this.attr("anchorURL"),n=this.$headings,o=this.getChapters();return x(),n.forEach(((t,i)=>{const n=o[i].code;((t,e,s)=>{const i=document.createDocumentFragment(),r="outline-heading",l=s.hasAnchor||!0,n=s.isAtStart||!0,o=s.showCode||!1,h=s.chapterCode||"",a=s.anchorURL||"",c=`heading-${e}`,d={id:c,className:n?`${r} ${r}_start`:r,"data-id":e},u=Object.keys(d),p=C(t.innerHTML);let m,f;if(u.forEach((e=>{k(t,e,d[e])})),o&&(t.innerHTML=h+" "+p),!l)return!1;f=M("hash",{iconSet:"outline"}),m=A("a",{id:`anchor-${e}`,className:`${r}__anchor anchor-${e}`,href:a||`#${c}`,target:a?"_blank":"self","data-id":e},[f]),i.appendChild(m),t.appendChild(i)})(t,i,{hasAnchor:e,isAtStart:s,showCode:r,chapterCode:n,anchorURL:l})})),i(t)&&t.call(this),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}destroy(){const t=this.attr("hasAnchor"),e=this.attr("isAtStart"),s=this.attr("beforeDestroy"),r=this.attr("afterDestroy"),l=this.$headings;return i(s)&&s.call(this),this.removeListeners(),l.forEach((s=>{D(s,t,e)})),this.attr(F.DEFAULTS),this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],i(r)&&r.call(this),this}onAnchorTrigger(t){const e=this.attr("anchorURL"),s=this.attr("afterScroll"),r=this.attr("stickyHeight"),l=t.delegateTarget.parentNode,n=d(l)-(r+10),h=this.$scrollElement,a=h.scrollHeight-h.clientHeight;return this.scrollTo(n,(()=>{i(s)&&s.call(this,"anchor"),o((()=>{w("toolbar:update",{top:n,min:0,max:a})}))})),e||$(t),this}addListeners(){const t=this.$articleElement;return y(t,".outline-heading__anchor","click",this.onAnchorTrigger,this,!0),this}removeListeners(){const t=this.$articleElement;return b(t,"click",this.onAnchorTrigger),this}}F.DEFAULTS={scrollElement:"html,body",articleElement:"#article",selector:"h1,h2,h3,h4,h5,h6",stickyHeight:0,anchorURL:"",hasAnchor:!0,isAtStart:!0,showCode:!1,created:null,mounted:null,afterScroll:null,beforeDestroy:null,afterDestroy:null};const U=(t,e)=>{let s,i;if(H(t,e))return!1;s=t.classList,s?.add?s.add(e):(i=t.className,i+=i.length>0?" "+e:e,t.className=i)},I=(t,e)=>{document.documentElement.style.setProperty(t,e)};let q=2e3;const B=t=>(t?q=t:q+=1,I("--outline-zIndex",`${q}`),q);class R extends l{constructor(t){super(),this.attrs=R.DEFAULTS,this.title="",this.closed=!0,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,this.zIndex=0,t&&this.initialize(t)}initialize(t){let e;return this.attr(t),this.title=this.attr("title"),e=this.attr("created"),i(e)&&e.call(this),this.render().addListeners(),this}setTitle(t){return this.attr("title",t),this.title=t,this.$title.innerHTML=t,this}isClosed(){return this.closed}render(){const t=this.attr("mounted"),e=this.attr("size"),s=this.attr("placement"),r=this.attr("hasClose"),l=this.attr("hasOverlay"),n=this.attr("hasOffset"),o=this.attr("hasPadding"),h=this.attr("autoHeight"),a=this.attr("customClass");let c,d,u,p,m,f,g,b;return x(),this.zIndex=B(),p=A("h2",{className:"outline-drawer__title"},[this.title]),this.$title=p,r&&(m=A("div",{className:"outline-drawer__close"},[M("close",{size:20})]),this.$close=m),u=A("header",{className:"outline-drawer__header"},[p,m]),this.$header=u,f=A("div",{className:"outline-drawer__main"},[""]),this.$main=f,o||U(f,"outline-drawer_full"),g=A("footer",{className:"outline-drawer__footer"},[""]),this.$footer=g,d=A("div",{className:`outline-drawer__modal outline-drawer_${s} outline-drawer_${e} outline-drawer_closed`},[u,f,g]),this.$modal=d,n&&U(d,"outline-drawer_offset"),h&&U(d,"outline-drawer_auto"),a&&U(d,a),l&&(b=A("div",{className:"outline-drawer__overlay"},[""]),this.$overlay=b),c=A("div",{className:"outline-drawer"},[d,b]),this.$el=c,document.body.appendChild(c),i(t)&&t.call(this),this}open(){const t=this.attr("afterOpened"),e=this.$modal;return U(this.$el,"outline-drawer_opened"),O(e,"outline-drawer_closed"),U(e,"outline-drawer_opened"),o((()=>{this.closed=!1,i(t)&&t.call(this)})),this}close(){const t=this.attr("afterClosed"),e=this.$modal;return O(e,"outline-drawer_opened"),U(e,"outline-drawer_closed"),o((()=>{O(this.$el,"outline-drawer_opened"),this.closed=!0,i(t)&&t.call(this)})),this}toggle(){const t=this.attr("afterToggle"),e=this.isClosed();return e?this.open():this.close(),i(t)&&o((()=>{t.call(this,e)})),this}destroy(){const t=this.attr("afterDestroy"),e=this.attr("beforeDestroy");let s=this.zIndex;return i(e)&&e.call(this),this.removeListeners(),this.attrs=R.DEFAULTS,this.title="",this.closed=!1,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,s-=1,B(s),this.zIndex=0,i(t)&&t.call(this),this}addListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t&&y(s,".outline-drawer__close","click",this.onClose,this,!0),e&&y(s,".outline-drawer__overlay","click",this.onClose,this,!0),this}removeListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t||e?(b(s,"click",this.onClose),this):this}onClose(){return this.close(),this}}R.DEFAULTS={placement:"rtl",title:"标题",size:"regular",hasClose:!0,hasOverlay:!0,hasOffset:!1,hasPadding:!0,autoHeight:!0,created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterToggle:null};const P=(t,e,s,r,l,n=!1)=>{const o=m.indexOf(e)>-1,h=function(i){let o=l||t;!0===l&&(o=r),!0===n&&b(t,e,h),s.call(o,i,r)};if(!i(s))return!1;t._listeners||(t._listeners=[]),t._listeners.push({el:t,type:e,fn:h,data:r,context:l,capture:o}),s._delegateListener=h,t.addEventListener(e,h,o)},Q=(t,e)=>getComputedStyle(t)[e];class W extends l{constructor(t){super(),this.attrs=W.DEFAULTS,this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.closed=!1,this.active=0,this.offsetTop=0,this.offsetWidth=0,this.$active=null,this.scrollTimer=null,this.resizeTimer=null,this.playing=!1,this.Observer=null,t&&this.initialize(t)}initialize(e){let s,r,l,o;return this.attr(e),s=this.attr("created"),r=this.attr("parentElement"),l=this.attr("scrollElement"),t(r)?o=document.querySelector(r):n(r)&&(o=r),this.$parentElement=o,this.$scrollElement=a(l),this.chapters=this.attr("chapters"),this.closed=this.attr("closed"),this.active=this.attr("active"),i(s)&&s.call(this),this.chapters.length<1||(this.render().addListeners(),this.$active=document.querySelector(`#chapter-${this.active}`)),this}isClosed(){return this.closed}isSticky(){return"sticky"===this.attr("position")}isFixed(){return"fixed"===this.attr("position")}isInside(){return this.isFixed()||this.isSticky()}isOutside(){return!this.isInside()}_paintEdge(){const t=document.createDocumentFragment(),e=this.attr("title"),s=this.attr("customClass"),i=this.$parentElement,r=[];let l,n,o,h,a=null;return i?(this.isInside()&&(a=A("h2",{className:"outline-chapters__title"},[e]),this.$title=a,r.push(a)),o=A("ul",{className:"outline-chapters__list"},[""]),this.$list=o,h=A("div",{className:"outline-chapters__placeholder"},[""]),this.$placeholder=h,n=A("div",{className:"outline-chapters__main"},[o,h]),this.$main=n,r.push(n),l=A("nav",{id:"outline-chapters",className:"outline-chapters outline-chapters_hidden"},r),this.$el=l,this.isSticky()&&(this.calculateStickyHeight(),U(l,"outline-chapters_sticky")),s&&U(l,s),t.appendChild(l),i.appendChild(t),this):this}render(){const t=this.attr("showCode"),e=this.attr("mounted"),s=this.$parentElement,r=this.chapters;let l,n;return!s||r.length<1||(this._paintEdge(),l=this.$el,n=this.$list,((t,e,s=!1)=>{const i=t=>document.querySelector(`#${t}`);e.forEach((e=>{const r=e.pid,l=e.id,n=e.rel,o=A("span",{className:"outline-chapters__text"},[e.text]),h=A("a",{id:`chapter__anchor-${l}`,className:"outline-chapters__anchor",href:"#"+n,rel:n,"data-id":l},[o]);let a,c,d,u;s&&(a=A("span",{className:"outline-chapters__code","data-id":l},[e.code]),h.insertBefore(a,h.firstChild)),c=A("li",{id:`chapter-${l}`,className:"outline-chapters__item","data-id":l},[h]),-1===r?t.appendChild(c):(u=i(`chapter-${r}`),d=i(`subject-${r}`),d?d.appendChild(c):(d=A("ul",{id:"subject-"+r,className:"outline-chapters__subject"},[c]),u.appendChild(d)))}))})(n,r,t),O(l,"outline-chapters_hidden"),this.positionPlaceholder(this.active),this.offsetTop=d(l),this.offsetWidth=l.offsetWidth,this.isFixed()&&(this.sticky(),I("--outline-chapters-width",`${this.offsetWidth}px`)),i(e)&&e.call(this),this.onObserver()),this}positionPlaceholder(t){const e=this.$main,s=this.$list,i=this.$placeholder,r=s.querySelector(".outline-chapters__anchor"),l=parseInt(Q(e,"padding-top"),10),n=parseInt(Q(e,"border-top-width"),10),o=parseInt(Q(s,"padding-top"),10),h=parseInt(Q(s,"margin-top"),10),a=parseInt(Q(s,"border-top-width"),10);let c,d=r.offsetHeight,u=0;return l&&(u+=l),o&&(u+=o),h&&(u+=h),n&&(u+=n),a&&(u+=a),c=d*t,i.style.cssText=`transform: translateY(${u+c}px);height:${d}px;`,this}highlight(t){const e=this.$el.querySelector(`#chapter__anchor-${t}`),s="outline-chapters_active";return e?(this.$active&&O(this.$active,s),this.active=parseInt(e.getAttribute("data-id"),10),this.$active=e,U(this.$active,s),this.positionPlaceholder(this.active),this):this}sticky(){const t=this.attr("afterSticky"),e="outline-chapters_fixed",s=this.$el,r=this.offsetTop,l=this.$scrollElement.scrollTop;let n;return this.isFixed()?(n=l>=r,n?U(s,e):O(s,e),i(t)&&t.call(this,this.isClosed(),n),this):this}calculateStickyHeight(){const t=document.documentElement,e=Math.max(t.clientHeight||0,window.innerHeight||0);return I("--outline-sticky-height",`${e}px`),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}show(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterOpened"),r=this.$el,l=this.$parentElement;return this.isInside()?(O(l,e),O(r,e),o((()=>{O(l,t),O(r,t)}),30)):O(r,e),this.closed=!1,i(s)&&s.call(this),this}hide(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterClosed"),r=this.$el,l=this.$parentElement;return this.isInside()?(U(l,t),U(r,t),o((()=>{U(l,e),U(r,e)}))):U(r,e),this.closed=!0,i(s)&&s.call(this),this}toggle(){const t=this.attr("afterToggle"),e=this.offsetTop,s=this.$scrollElement.scrollTop;let r;return this.isClosed()?this.show():this.hide(),i(t)&&o((()=>{r=s>=e,t.call(this,this.isClosed(),r)})),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");return i(t)&&t.call(this),this.removeListeners(),this.$parentElement.removeChild(this.$el),this.attr(W.DEFAULTS),this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.active=0,this.offsetTop=0,this.$active=null,this.closed=!1,this.scrollTimer&&(clearTimeout(this.scrollTimer),this.scrollTimer=null),this.resizeTimer&&(clearTimeout(this.resizeTimer),this.resizeTimer=null),i(e)&&e.call(this),this.Observer&&(this.Observer=null),this}onObserver(){const t=this.attr("selector");let e=null;return this.Observer=((t,e={})=>{const s=e.root||null,r=e.selector||".outline-heading",l=e.context||null,o={rootMargin:e.rootMargin||"0px 0px -90% 0px"},h=new IntersectionObserver((e=>{e.forEach((e=>{e.intersectionRatio>0&&i(t)&&t.call(l||e.target,e.target)}))}),o),a=n(s)?s:document;return s&&(o.root=s),a.querySelectorAll(r).forEach((t=>{h.observe(t)})),h})((t=>{const s=t.getAttribute("data-id");if(this.playing)return!1;e&&clearTimeout(e),e=o((()=>{this.highlight(s)}),100)}),{selector:t,context:this}),this}onSelect(t){const e=this.attr("stickyHeight"),s=t.delegateTarget,r=s.getAttribute("data-id"),l=s.href.split("#")[1],n=document.querySelector(`#${l}`),h=d(n)-(e+10),a=this.$scrollElement.scrollHeight,c=this.attr("afterScroll"),u=()=>{i(c)&&c.call(this,"chapter"),o((()=>{this.playing=!1,w("toolbar:update",{top:h,min:0,max:a})}))};return this.playing=!0,this.isFixed()?(this.sticky(),o((()=>{this.scrollTo(h,u),this.highlight(r)}),10)):(this.scrollTo(h,u),this.highlight(r)),$(t),this}onScroll(){const t=this.$scrollElement;return this.scrollTimer&&clearTimeout(this.scrollTimer),this.scrollTimer=o((()=>{const e=t.scrollTop,s=t.scrollHeight-t.clientHeight;this.isFixed()&&this.sticky(),w("toolbar:update",{top:e,min:0,max:s})}),100),this}onResize(){return this.resizeTimer&&clearTimeout(this.resizeTimer),this.resizeTimer=o((()=>{this.calculateStickyHeight()})),this}addListeners(){const t=this.$el,e=this.$scrollElement,s=e.tagName.toLowerCase();let i=e;return"html"!==s&&"body"!==s||(i=window),y(t,".outline-chapters__anchor","click",this.onSelect,this,!0),P(i,"scroll",this.onScroll,this,!0),this.isSticky()&&P(i,"resize",this.onResize,this,!0),this}removeListeners(){const t=this.attr("selector"),e=this.$el,s=this.$scrollElement,i=s.tagName.toLowerCase();let r=s;return"html"!==i&&"body"!==i||(r=window),b(e,"click",this.onSelect),b(r,"scroll",this.onScroll),this.isSticky()&&P(r,"resize",this.onResize),this.Observer&&document.querySelectorAll(t).forEach((t=>{this.Observer.unobserve(t)})),this}}W.DEFAULTS={parentElement:"",scrollElement:"",selector:".outline-heading",active:0,closed:!1,showCode:!0,position:"relative",stickyHeight:0,chapters:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterSticky:null};const V=(t,e=!0)=>{const s=M(t.icon,{iconSet:t.iconSet||"outline",color:t.color||"",size:t.size}),i=A("a",{className:"outline-toolbar__anchor",href:t.link},[s]),r=A("div",{className:`outline-toolbar__button ${t.name}`},[t.link?i:s]);return U(s,"outline-toolbar__icon"),e&&U(r,"outline-toolbar_rounded"),t.disabled&&U(r,"outline-toolbar_disabled"),r},J="outline-toolbar_disabled",Y="outline-toolbar_hidden";class G extends l{constructor(t){super(),this.attrs=G.DEFAULTS,this.$el=null,this.disabled=!1,this.closed=!1,this.buttons=[],t&&this.initialize(t)}initialize(t){let e;return this.attr(t),e=this.attr("created"),this.disabled=this.attr("disabled"),this.closed=this.attr("closed"),i(e)&&e.call(this),this.render().addListeners(),this}isDisabled(t){const e=this.attr("buttons");let s;return t?(s=e.find((e=>e.name===t)),s?.disabled):this.disabled}isClosed(){return this.closed}highlight(t){const e=this.buttons.find((e=>e.name===t)),s="outline-toolbar_active";let i;return i||(i=e.$el,H(i,s)?O(i,s):U(i,s)),this}render(){const t=this.attr("mounted"),e=this.attr("buttons")||[],s=this.attr("rounded"),r=this.attr("placement"),l=document.createDocumentFragment(),n=document.createDocumentFragment();return x(),e.forEach((t=>{const e=V(t,s);l.appendChild(e),this.buttons.push({name:t.name,$el:e})})),this.$el=A("div",{id:"outline-toolbar",className:`outline-toolbar outline-toolbar_${r}`},[l]),n.appendChild(this.$el),document.body.appendChild(n),this.closed&&this.hide(),this.disabled&&this.disable(),i(t)&&t.call(this),this}add(t){const e=this.$el,s=this.attr("buttons"),l=t.action,n=document.createDocumentFragment();let o;return r(t)?(s.push(t),n.appendChild(V(t))):T(t)&&t.forEach((t=>{n.appendChild(V(t))})),e.appendChild(n),l&&i(l.handler)&&(o=l.type||"click",y(e,`.${t.name}`,o,l.handler)),this}remove(t){const e=this.$el,s=this.attr("buttons"),i=s.find((e=>e.name===t));let r,l=-1;return i?(s.forEach(((e,s)=>{e.name===t&&(l=s)})),l>-1&&this.attr().buttons.splice(l,1),r=e.querySelector(`.${t}`),this.switch(t,!1),e.removeChild(r),this):this}switch(t,e){const s=this.$el,i=this.attr("buttons"),r=i.find((e=>e.name===t));let l,n,o,h;return r?(i.forEach((s=>{s.name===t&&(r.disabled=!e)})),l=r.action,h=s.querySelector(`.${t}`),l&&(n=l.type||"click",o=l.handler),e?(O(h,J),n&&o&&y(s,`.${t}`,n,o)):(U(h,J),n&&o&&b(s,n,o)),this):this}disable(t){const e=this.attr("afterDisabled");return t?this.switch(t,!1):(U(this.$el,J),this.removeListeners(),this.disabled=!0,i(e)&&e.call(this)),this}enable(t){const e=this.attr("afterEnabled");return t?this.switch(t,!0):(this.disabled=!1,O(this.$el,J),this.addListeners(),i(e)&&e.call(this)),this}show(t){const e=this.attr("afterOpened"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),O(l,Y)}else O(r,Y),this.closed=!1,i(e)&&o((()=>{e.call(this)}),310);return this}hide(t){const e=this.attr("afterClosed"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),U(l,Y)}else U(r,Y),this.closed=!0,i(e)&&o((()=>{e.call(this)}),310);return this}toggle(){return this.isClosed()?this.show():this.hide(),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");let s=this.$el;return i(t)&&t.call(this),this.removeListeners(),document.body.removeChild(s),s=null,this.attr(G.DEFAULTS),this.disabled=!1,this.closed=!1,this.buttons=[],i(e)&&e.call(this),this}refresh(){const t=this.$el,e=this.attr("buttons")||[];return this.removeListeners(),t.innerHTML="",e.forEach((t=>{this.$el.appendChild(V(t))})),this.addListeners(),this}addListeners(){const e=this.attr("buttons"),s=this.$el;return!e||e.length<1||e.forEach((e=>{const r=e.action;let l,n,o,h;if(this.disabled)return!1;r&&(n=r.handler,t(n)&&(h=n,r.handler=function(){w(h,e.name)},n=r.handler),l=r.type||"click",o=r.context),i(n)&&y(s,`.${e.name}`,l,n,o||this,!0)})),this}removeListeners(){const t=this.attr("buttons"),e=this.$el;return!t||t.length<1||t.forEach((t=>{const s=t.action;let r,l;if(this.disabled)return!1;s&&(l=s.handler,r=s.type||"click"),i(l)&&b(e,r,l)})),this}}G.DEFAULTS={placement:"ltr",closed:!1,disabled:!1,rounded:!0,buttons:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterDisabled:null,afterEnabled:null,beforeDestroy:null,afterDestroy:null};const K=(()=>{let t=0;return e=>(t+=1,e?e+"-"+t:"guid-"+t)})(),X=(t,e,s=null)=>{const r=K();let l="symbol"==typeof t?t.toString():t;return i(e)?(v[l]||(v[l]=[]),v[l].push({topic:l,callback:e,context:s,token:r}),r):""},Z=t=>{if(!e(v,t))return!1;delete v[t]},tt=(t,e)=>{if(!_(t))return!1;e?(t=>{const e=Object.keys(v);if(!t||e.length<1)return!1;e.forEach((e=>{const s=v[e];let i;s.forEach(((e,r)=>{e.callback!==t&&e.token!==t||(i=e.topic,s.splice(-1,r))})),s.length<1&&Z(i)}))})(e):Z(t)};class et extends l{constructor(t){super(),this.attrs=et.DEFAULTS,this.anchors=null,this.drawer=null,this.chapters=null,this.toolbar=null,this.buttons=[],t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}getChapters(t=!1){return this.anchors.getChapters(t)}count(){return this.anchors.count()}render(){const t=this.attr("scrollElement"),e=document.querySelector(t)||document.getElementById(t);return this._renderPrint()._renderAnchors()._renderChapters()._renderToolbar(),e&&this.onToolbarUpdate({top:e.scrollTop,min:0,max:e.scrollHeight}),this}_renderPrint(){const e=this.attr("print"),s=this.attr("articleElement");let i;return e.element?(t(s)?i=document.querySelector(s):n(s)&&(i=s),U(i,"outline-article"),((e,s)=>{let i,r,l,h,a;t(e)?i=document.querySelector(e)||document.getElementById(e):n(e)&&(i=e),r=i.querySelector("h1"),l=A("article",{className:"outline-print"},[""]),l.innerHTML=i.innerHTML,t(s)&&!r&&(r=A("h1",{className:"outline-print__title"},[s]),l.insertBefore(r,l.firstChild)),document.body.appendChild(l),o((()=>{for(h=l.previousElementSibling;h;)a=h.tagName.toLowerCase(),"script"!==a&&"style"!==a&&U(h,"outline-print_sibling"),h=h.previousElementSibling;for(h=l.nextElementSibling;h;)a=h.tagName.toLowerCase(),"script"!==a&&"style"!==a&&U(h,"outline-print_sibling"),h=h.nextElementSibling}),500)})(e.element,e.title),this):this}_renderAnchors(){const t=this.attr("articleElement"),e=this.attr("selector"),s=this.attr("stickyHeight"),i=this.attr("scrollElement"),r=this.attr("showCode"),l=this.attr("anchorURL"),n=this.attr("afterScroll");return this.anchors=new F({articleElement:t,stickyHeight:s,scrollElement:i,selector:e,showCode:r,anchorURL:l,afterScroll:n}),this}_renderChapters(){const t=this.attr("title"),e=this.attr("stickyHeight"),s=this.attr("scrollElement"),i=this.attr("customClass"),r=this.attr("showCode"),l=this.attr("position"),n=this.attr("placement"),o=this.attr("afterSticky"),h=this.attr("afterToggle"),a=this.attr("afterScroll"),c=this.count();let d,u=this.attr("parentElement");return c<1||(d={scrollElement:s,showCode:r,position:l,title:t,stickyHeight:e,chapters:this.getChapters(),afterSticky:o,afterToggle:h,afterScroll:a},"relative"===l?(this.drawer=new R({placement:n,title:t,size:"tiny",hasOffset:!0,hasPadding:!1,customClass:i,afterClosed:()=>{this.toolbar.toggle()}}),u=this.drawer.$main):d.customClass=i,d.parentElement=u,this.chapters=new W(d)),this}_renderToolbar(){const t=this.attr("placement"),e=this.attr("homepage"),s=this.attr("git"),i=this.attr("tags"),r=this.attr("issues"),l=this.attr("tools"),n=this.count(),o={name:"homepage",icon:"homepage",size:20,link:e},h={name:"github",icon:"github",size:20,link:s},a={name:"tags",icon:"tags",size:20,link:i},c={name:"issues",icon:"issues",size:20,link:r},d={name:"menu",icon:"menu",size:18,action:{type:"click",handler:"toolbar:action:toggle"}},u=[];return u.push({name:"up",icon:"up",size:20,action:{type:"click",handler:"toolbar:action:up"}}),e&&u.push(o),n>0&&u.push(d),s&&u.push(h),i&&u.push(a),r&&u.push(c),l?.length>0&&u.push(...l),u.push({name:"down",icon:"down",size:20,action:{type:"click",handler:"toolbar:action:down"}}),this.buttons=[...u],this.toolbar=new G({placement:t,buttons:u}),this}addButton(t){const e=this.toolbar,s=this.buttons;return s.splice(-1,0,t),e.attr({buttons:s}),e.refresh(),this}removeButton(t){return this.toolbar.remove(t),this}toTop(){const t=this.attr("afterScroll"),e=this.toolbar,s=this.chapters,r=this.count();return r>0&&(s.playing=!0),this.scrollTo(0,(()=>{e.hide("up"),e.show("down"),r>0&&(s.highlight(0),s.playing=!1),i(t)&&t.call(e,"up")})),this}toBottom(){const t=this.attr("afterScroll"),e=a(this.attr("scrollElement")),s=this.toolbar,r=this.chapters,l=this.count(),n=Math.floor(e.scrollHeight-e.clientHeight);return l>0&&(r.playing=!0),this.scrollTo(n,(()=>{s.hide("down"),s.show("up"),l>0&&(r.highlight(l-1),r.playing=!1),i(t)&&t.call(s,"bottom")})),this}scrollTo(t,e){const s=this.attr("scrollElement");return c(s,t,e),this}toggle(){const t=this.attr("position"),e=this.toolbar,s=this.drawer,i=this.chapters;return this.count()<1||("relative"!==t?(i.toggle(),e.highlight("menu")):(e.toggle(),o((()=>{i.isInside()?i.toggle():s.toggle()})))),this}destroy(){let t=this.anchors,e=this.chapters,s=this.drawer,i=this.toolbar,r=!1;const l=this.count();return this.removeListeners(),l>0&&(r=e.isOutside(),e.destroy(),e=null,r&&(s.destroy(),s=null)),i.destroy(),i=null,t.destroy(),t=null,this.attr(et.DEFAULTS),this}onToggle(){return this.toggle(),this}onScrollTop(){return this.toTop(),this}onScrollBottom(){return this.toBottom(),this}onToolbarUpdate({top:t,min:e,max:s}){const i=this.toolbar,r=Math.ceil(t);return r<=e?(i.hide("up"),i.show("down")):r>=s?(i.hide("down"),i.show("up")):r>e&&r {\n  return typeof str === 'string'\n}\n\nexport default isString\n","/**\n * 检测对象自身属性中是否具有指定的属性。\n * ========================================================================\n * @method hasOwn\n * @param {Object} obj - (必须)检测的目标对象\n * @param {String} prop - (必须)属性名\n * @returns {Boolean}\n */\nconst hasOwn = (obj, prop) => {\n  const hasOwnProperty = Object.prototype.hasOwnProperty\n  return obj && hasOwnProperty.call(obj, prop)\n}\n\nexport default hasOwn\n","/**\n * Object 对象原型上的 toString 方法\n * ========================================================================\n * @method toString\n * @param {*} val\n * @returns {string}\n */\nconst toString = (val) => {\n  return Object.prototype.toString.apply(val)\n}\n\nexport default toString\n","import toString from '../lang/toString'\n\n/**\n * 检测测试数据是否为 Function 类型\n * ========================================================================\n * @method isFunction\n * @param {*} val - (必须)待检测的数据\n * @returns {boolean} 'val' 是 Function 类型返回 true,否则返回 false\n */\nconst isFunction = (val) => {\n  return typeof val === 'function' || toString(val) === '[object Function]'\n}\n\nexport default isFunction\n","import toString from '../lang/toString'\nimport isFunction from '../types/isFunction'\n\n/**\n * 检测数据是否为 Object 类型\n * ========================================================================\n * @method isObject\n * @param {*} o\n * @returns {boolean}\n */\nconst isObject = (o) => {\n  return (\n    (toString(o) === '[object Object]' ||\n      typeof o === 'object' ||\n      isFunction(o)) &&\n    o !== null\n  )\n}\n\nexport default isObject\n","import isString from './utils/types/isString'\r\nimport hasOwn from './utils/lang/hasOwn'\r\nimport isObject from './utils/types/isObject'\r\nimport extend from './utils/lang/extend'\r\n\r\nclass Base {\r\n  constructor(options) {\r\n    this.attrs = {}\r\n\r\n    if (options) {\r\n      this.initialize(options)\r\n    }\r\n  }\r\n\r\n  initialize(options) {\r\n    this.attr(options).render().addListeners()\r\n    return this\r\n  }\r\n\r\n  attr(prop, value) {\r\n    const attrs = this.attrs\r\n\r\n    if (isString(prop)) {\r\n      // 只能扩展 attrs 中已有的属性\r\n      if (value && hasOwn(attrs, prop)) {\r\n        // 更新单个配置信息\r\n        attrs[prop] = value\r\n        return this\r\n      }\r\n\r\n      // 只传递 prop 参数,则返回对应的属性值\r\n      return attrs[prop]\r\n    } else if (isObject(prop)) {\r\n      // 批量更新配置信息\r\n      extend(attrs, prop)\r\n\r\n      return this\r\n    } else if (arguments.length === 0) {\r\n      // 不传递参数,直接返回整个\r\n      return attrs\r\n    }\r\n\r\n    return this\r\n  }\r\n\r\n  render() {\r\n    return this\r\n  }\r\n\r\n  destroy() {\r\n    this.removeListeners()\r\n    return this\r\n  }\r\n\r\n  reload(options) {\r\n    this.destroy().initialize(this.attr(options))\r\n    return this\r\n  }\r\n\r\n  addListeners() {\r\n    return this\r\n  }\r\n\r\n  removeListeners() {\r\n    return this\r\n  }\r\n}\r\n\r\nexport default Base\r\n","import hasOwn from './hasOwn'\n\n/**\n * 扩展对象\n * ========================================================================\n * @method extend\n * @param {Object} origin\n * @param {Object} source\n */\nconst extend = (origin, source) => {\n  const keys = Object.keys(source)\n\n  keys.forEach((prop) => {\n    if (hasOwn(source, prop)) {\n      origin[prop] = source[prop]\n    }\n  })\n}\n\nexport default extend\n","import isObject from './isObject'\n\n/**\n * 检测数据是否为 HTMLElement DOM 节点\n * ========================================================================\n * @method isElement\n * @param {*} o\n * @returns {boolean}\n */\nconst isElement = (o) => {\n  return !!(isObject(o) && o.nodeName && o.tagName && o.nodeType === 1)\n}\n\nexport default isElement\n","import isFunction from '../types/isFunction'\n\n/**\n * later - 延迟执行方法\n * ========================================================================\n * @method later\n * @param {Function} fn\n * @param {Number} [delay]\n * @returns {number|boolean}\n */\nconst later = (fn, delay = 300) => {\n  if (!isFunction(fn)) {\n    return false\n  }\n\n  return setTimeout(() => {\n    fn()\n  }, delay)\n}\n\nexport default later\n","/**\n * 返回给定值的平方值\n * ========================================================================\n * @method easeInQuad\n * @param {Number} x\n * @returns {number}\n */\nconst easeInQuad = (x) => {\n  return x * x\n}\n\nexport default easeInQuad\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\n\n/**\n * 通过给的 scrollElement 参数,获取滚动 DOM 元素\n * ========================================================================\n * @method _getScrollElement\n * @param {String|HTMLElement} scrollElement\n * @returns {Element}\n * @private\n */\nconst _getScrollElement = (scrollElement = null) => {\n  let $rootElements\n  let $scrollElement\n\n  if (!scrollElement) {\n    $rootElements = document.querySelectorAll('html,body')\n    $scrollElement =\n      $rootElements[0].scrollTop - $rootElements[1].scrollTop >= 0\n        ? $rootElements[0]\n        : $rootElements[1]\n  } else {\n    if (isString(scrollElement)) {\n      $scrollElement = document.querySelector(scrollElement)\n    } else if (isElement(scrollElement)) {\n      $scrollElement = scrollElement\n    }\n  }\n\n  return $scrollElement\n}\n\nexport default _getScrollElement\n","import easeInQuad from '../lang/easeInQuad'\nimport isFunction from '../types/isFunction'\nimport _getScrollElement from './_getScrollElement'\n\n/**\n * 指定 rootElement DOM 节点滚动到指定 top 位置\n * ========================================================================\n * @method scrollTo\n * @param {HTMLElement|Object} [scrollElement] - (必须)要滚动的 DOM 节点\n * @param {Number} top - (必须)滚动的 scrollTop 数值\n * @param {Function} [afterStop] - (可选)滚动完成的回调函数\n */\nconst scrollTo = (scrollElement, top, afterStop) => {\n  const $scrollElement = _getScrollElement(scrollElement)\n  let scrollTop = $scrollElement.scrollTop\n  let step = 0\n  const distance = top - scrollTop\n  const MAX_HEIGHT = $scrollElement.scrollHeight\n  const MAX_TOP = top - MAX_HEIGHT <= 0 ? top : MAX_HEIGHT\n  const stop = (top) => {\n    if (isFunction(afterStop)) {\n      afterStop(top)\n    }\n\n    return false\n  }\n  const play = () => {\n    step += 1\n\n    // 向上滚动\n    if (distance < 0) {\n      scrollTop -= easeInQuad(step)\n      $scrollElement.scrollTop = scrollTop\n\n      if (scrollTop <= top) {\n        $scrollElement.scrollTop = top\n        return stop(top)\n      }\n    } else {\n      scrollTop += easeInQuad(step)\n      $scrollElement.scrollTop = scrollTop\n\n      if (scrollTop >= MAX_TOP) {\n        $scrollElement.scrollTop = MAX_TOP\n        return stop(MAX_TOP)\n      }\n    }\n\n    requestAnimationFrame(play)\n  }\n\n  requestAnimationFrame(play)\n}\n\nexport default scrollTo\n","/**\n * 获取 DOM 节点相对于窗口的 left (纵坐标)值\n * ========================================================================\n * @method offsetTop\n * @param {HTMLElement} el - DOM 节点\n * @returns {Number}\n */\nconst offsetTop = (el) => {\n  let top = el.offsetTop\n\n  if (el.offsetParent !== null) {\n    top += offsetTop(el.offsetParent)\n  }\n\n  return top\n}\n\nexport default offsetTop\n","/**\n * 获取 options 节点下匹配 selector 选择器的 DOM 节点\n * ========================================================================\n * Element.matches() 方法可以用来判断 DOM 元素是否与给定的选择器匹配,事件代理判断是\n * 否触发绑定的代理事件回调函数,关键就是使用 Element.matches() 辨别当前事件触发的目\n * 标 DOM 元素是否为事件代理所期望触发的目标。\n * ========================================================================\n * @method matches\n * @see https://developer.mozilla.org/en-US/docs/web/api/element/matches\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)匹配 DOM 元素的选择器\n * @returns {Boolean}\n */\nconst matches = (el, selector = '') => {\n  const sel = selector.replace(/^>/i, '')\n\n  if (!selector || !sel || !el) {\n    return false\n  }\n\n  /* istanbul ignore else */\n  if (el.matches) {\n    return el.matches(sel)\n  } else if (el.msMatchesSelector) {\n    return el.msMatchesSelector(sel)\n  } else {\n    return false\n  }\n}\n\nexport default matches\n","/**\n * 获取 DOM 元素的父节点\n * ========================================================================\n * @method getParentOrHost\n * @param {*|HTMLElement} el - (必须)要获取父节点的 DOM 元素\n * @returns {*|HTMLElement}\n */\nconst getParentOrHost = (el) => {\n  return el.host && el !== document && el.host.nodeType\n    ? el.host\n    : el.parentNode\n}\n\nexport default getParentOrHost\n","export const CAPTURE_EVENTS = [\n  'focusout',\n  'blur',\n  'focusin',\n  'focus',\n  'load',\n  'unload',\n  'mouseenter',\n  'mouseleave'\n]\n","import { CAPTURE_EVENTS } from './enum'\nimport _delete from './_delete'\n\n/**\n * (私有方法)取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method _off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} fn - (必须)事件处理器回调函数\n * @private\n */\nconst _off = (el, type, fn) => {\n  const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n  /* istanbul ignore else */\n  if (fn._delegateListener) {\n    fn = fn._delegateListener\n    delete fn._delegateListener\n  }\n\n  // 移除缓存的 _listeners 数据\n  _delete(el, type, fn)\n\n  el.removeEventListener(type, fn, capture)\n}\n\nexport default _off\n","/**\n * 删除 DOM 元素缓存的 _listeners 数据\n * ========================================================================\n * @method _delete\n * @param {HTMLElement} el - 要删除 listener 的 DOM 元素\n * @param {String} type - 事件类型(名称)\n * @param {Function} [fn] - 事件处理器回调函数\n */\nconst _delete = function (el, type, fn) {\n  const listeners = el._listeners\n  let index = -1\n\n  if (listeners.length < 1) {\n    return false\n  }\n\n  // 移除缓存的 _listeners 数据\n  listeners.forEach((listener, i) => {\n    const handler = listener.fn\n\n    if (type === listener.type) {\n      index = i\n\n      if (handler === fn) {\n        index = i\n      }\n    }\n  })\n\n  /* istanbul ignore else */\n  if (index > -1) {\n    listeners.splice(index, 1)\n  }\n}\n\nexport default _delete\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\nimport getListeners from './getListeners'\nimport _off from './_off'\n\n/**\n * 销毁(type 类型的)代理事件绑定\n * ========================================================================\n * 1. 设置了事件类型 type,则销毁指定类型的事件绑定,否则清除所有代理事件绑定\n * 2. recurse 设置为 true,递归销毁子节点全部事件绑定\n * ========================================================================\n * @method purgeElement\n * @param {HTMLElement|String} el - (必须)DOM 元素或者其选择器\n * @param {String|Boolean} type - (必须)事件类型\n * @param {Boolean} [recurse] - (可选)是否递归销毁子节点所有事件绑定\n */\nconst purgeElement = function (el, type, recurse = false) {\n  const $element = isString(el) ? document.querySelector(el) : el\n  const $children = $element.childNodes\n  const listeners = getListeners($element, type)\n\n  listeners.forEach((listener) => {\n    _off($element, listener.type, listener.fn)\n  })\n\n  if (\n    (recurse || type === true || arguments.length === 1) &&\n    $element &&\n    $children\n  ) {\n    $children.forEach(($child) => {\n      if (isElement($child)) {\n        purgeElement($child, type, recurse)\n      }\n    })\n  }\n}\n\nexport default purgeElement\n","import isString from '../types/isString'\n\n/**\n * 获取 DOM 元素(type 事件类型)事件绑定信息\n * ========================================================================\n * 如果设置了事件类型 type, 则返回指定类型的事件绑定信息,否则返回所有事件绑定信息\n * ========================================================================\n * @methods getListeners\n * @param {HTMLElement} el - (必须)要获取事件绑定信息的 DOM 元素\n * @param {String} [type] - (可选)事件类型\n * @returns {Array} - 已绑定的事件信息\n */\nconst getListeners = (el, type) => {\n  let listeners = el._listeners || []\n\n  if (isString(type) && type) {\n    listeners = listeners.filter((listener) => {\n      return listener.type === type\n    })\n  }\n\n  return listeners\n}\n\nexport default getListeners\n","import purgeElement from './purgeElement'\nimport isFunction from '../types/isFunction'\nimport _off from './_off'\n\n/**\n * 取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} [fn] - (可选)事件处理器回调函数\n */\nconst off = (el, type, fn) => {\n  // 如果不设置 fn 参数,默认清除 el 元素上绑定的所有事件处理器\n  if (!isFunction(fn)) {\n    return purgeElement(el, type)\n  }\n\n  _off(el, type, fn)\n}\n\nexport default off\n","import closest from '../dom/closest'\nimport off from './off'\nimport getTarget from './getTarget'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定代理事件\n * ========================================================================\n * @method on\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String} selector - (必须)事件代理目标 DOM 元素的选择器\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (可选) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst on = (el, selector, type, fn, data, context, once = false) => {\n  // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n  const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n  const listener = function (evt) {\n    const target = getTarget(evt)\n    // 通过 Element.matches 方法获得点击的目标元素\n    const delegateTarget = closest(target, selector, el)\n    let overrideContext = context || el\n\n    evt.delegateTarget = delegateTarget\n\n    // 当设置为 true 时,则事件处理器回调函数的\n    // this 上下文指向为 data 对象\n    if (context === true) {\n      overrideContext = data\n    }\n\n    /* istanbul ignore else */\n    if (delegateTarget) {\n      // 仅触发一次\n      /* istanbul ignore else */\n      if (once === true) {\n        off(el, type, listener)\n      }\n\n      fn.call(overrideContext, evt, data)\n    }\n  }\n\n  if (!el._listeners) {\n    el._listeners = []\n  }\n\n  // 缓存 options 元素绑定的事件处理器\n  el._listeners.push({\n    el,\n    selector,\n    type,\n    fn: listener,\n    data,\n    context,\n    capture\n  })\n\n  // 缓存包装后的事件处理器\n  fn._delegateListener = listener\n\n  el.addEventListener(type, listener, capture)\n}\n\nexport default on\n","import resolveTextNode from '../dom/resolveTextNode'\n\n/**\n * 返回触发事件的 target DOM 元素\n * ========================================================================\n * @method getTarget\n * @param {Event} evt - Event 对象\n * @return {HTMLElement} - Event 对象的 target DOM 元素\n */\nconst getTarget = function (evt) {\n  const target = evt.target\n\n  return resolveTextNode(target)\n}\n\nexport default getTarget\n","/**\n * 在某些情况下,某些浏览器(例如:Safari 浏览器)会返回实际的目标元素内部的文本节点。\n * resolveTextNode() 方法则会返回实际的目标节点。\n * ========================================================================\n * @method resolveTextNode\n * @param {HTMLElement|Text} el - 要解析的节点\n * @return {*|HTMLElement} - 实际的目标 DOM 节点\n */\nconst resolveTextNode = function (el) {\n  if (el && el.nodeType === 3) {\n    return el.parentNode\n  }\n\n  return el\n}\n\nexport default resolveTextNode\n","import matches from './matches'\nimport getParentOrHost from './getParentOrHost'\n\n/**\n * 获取 options 元素父元素最近的包含 selector 选择器的元素\n * ========================================================================\n * @method closest\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)DOM 元素的选择其\n * @param {HTMLElement} [ctx] - (必须)比对的 DOM 元素\n * @param {Boolean} [includeCTX] - (必须)是否包含 context DOM 元素\n * @returns {null|HTMLElement} - 返回最接近的 DOM 元素\n */\nconst closest = (el, selector, ctx, includeCTX) => {\n  const context = ctx || document\n\n  if (!el) {\n    return null\n  }\n\n  do {\n    /* istanbul ignore else */\n    if (\n      (selector != null &&\n        (selector.startsWith('>')\n          ? el.parentNode === context && matches(el, selector)\n          : matches(el, selector))) ||\n      (includeCTX && el === context)\n    ) {\n      return el\n    }\n\n    /* istanbul ignore else */\n    if (el === context) {\n      break\n    }\n\n    /* jshint boss:true */\n  } while ((el = getParentOrHost(el)))\n}\n\nexport default closest\n","/**\n * 停止事件(阻止默认行为和阻止事件的捕获或冒泡)\n * ========================================================================\n * @method stop\n * @param {Event} evt - 事件对象\n *\n * @example\n * 
\n * Service\n * Help\n *
\n *\n * const $nav = document.querySelector('#nav')\n * const $service = document.querySelector('.anchor')\n *\n * on($nav, 'click', function(evt) {\n * console.log('你点击了导航栏')\n * })\n *\n * on($anchor, 'click', function(evt) {\n * console.log('tagName', this.tagName)\n *\n * // 工作台输出:'a'\n * // 不会触发事件冒泡,输出:'你点击了导航栏'\n * // 也不会切换到 href 属性的页面,阻止了点击链接的默认行为\n * stopEvent(evt)\n * })\n */\nconst stop = function (evt) {\n evt.stopPropagation()\n evt.preventDefault()\n}\n\nexport default stop\n","/**\n * 存储订阅者(主题和处理器的)私有对象\n * ========================================================================\n * @type {{}}\n * @private\n */\nconst _subscribers = {}\n\nexport default _subscribers\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 判断是否存在与给定 topic 完全匹配的订阅者信息\n * ========================================================================\n * @method _hasDirectSubscribersFor\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasDirectSubscribersFor = (topic) => {\n return hasOwn(_subscribers, topic) && _subscribers[topic].length > 0\n}\n\nexport default _hasDirectSubscribersFor\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\nimport _hasSubscribers from './_hasSubscribers'\n\n/**\n * 判断是否存在包含 topic 指定的订阅者信息\n * ========================================================================\n * @method has\n * @param {String} topic - (必须)主题名称\n * @param {Boolean} [isDirect] - (可选)是否为直接的主题,默认值:true\n * @returns {Boolean}\n */\nconst has = (topic, isDirect = true) => {\n return isDirect ? _hasDirectSubscribersFor(topic) : _hasSubscribers(topic)\n}\n\nexport default has\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * 判断是否存在包含给定 topic 相关的订阅者信息\n * ========================================================================\n * @method _hasSubscribers\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasSubscribers = (topic) => {\n let found = _hasDirectSubscribersFor(topic)\n let position = topic.lastIndexOf('.')\n\n while (!found && position !== -1) {\n topic = topic.substring(0, position)\n position = topic.lastIndexOf('.')\n found = _hasDirectSubscribersFor(topic)\n }\n\n return found\n}\n\nexport default _hasSubscribers\n","import isTypedArray from '../types/isTypedArray'\nimport _subscribers from './_subscribers'\nimport has from './has'\nimport _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * (异步)发布订阅主题信息\n * ========================================================================\n * 主题默认是异步发布的。确保在消费者处理主题时,主题的发起者不会被阻止。\n * ========================================================================\n * @method emit\n * @param {String} topic - (必须)主题名称\n * @param {Object} data - (必须)数据对象\n * @param {Boolean} async - (可选) 是否异步发布\n */\nconst emit = (topic, data, async = true) => {\n const execute = (topic) => {\n if (!_hasDirectSubscribersFor(topic)) {\n return false\n }\n\n _subscribers[topic].forEach((subscriber) => {\n // 针对 mqtt 消息服务返回的 Uint8Array 类似的 typed arrays 格式的数据\n // 采用 toString() 方法转化为普通(JSON)字符串\n const message = isTypedArray(data) ? data.toString() : data\n\n subscriber.callback.call(subscriber.context || subscriber, message)\n })\n }\n const deliver = () => {\n let subscriber = topic\n let position = topic.lastIndexOf('.')\n\n while (position !== -1) {\n subscriber = subscriber.substring(0, position)\n position = subscriber.lastIndexOf('.')\n\n execute(subscriber)\n }\n\n // 执行 topic 对应的处理器\n execute(topic)\n // 执行特殊 topic:'*'(监听全部消息的发布)\n execute('*')\n }\n\n if (!has(topic)) {\n return false\n }\n\n if (async) {\n setTimeout(deliver, 10)\n } else {\n deliver()\n }\n}\n\nexport default emit\n","import toString from '../lang/toString'\n/**\n * 判断检测数据是否为 Typed Arrays 类型的数据\n * ========================================================================\n * @param {*} val\n * @returns {boolean}\n */\nconst isTypedArray = (val) => {\n const TYPES = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]',\n '[object BigInt64Array]',\n '[object BigUint64Array]'\n ]\n\n return TYPES.indexOf(toString(val)) > -1\n}\n\nexport default isTypedArray\n","import toString from '../lang/toString'\n\n/**\n * 检测数据是否为 Array 类型\n * ========================================================================\n * @method isArray\n * @param {*} o\n * @returns {boolean}\n */\nconst isArray = (o) => {\n if (Array.isArray) {\n return Array.isArray(o)\n } else {\n return toString(o) === '[object Array]'\n }\n}\n\nexport default isArray\n","import DEFAULTS from './defaults'\n\nconst SYMBOLS = [...DEFAULTS]\n\nexport default SYMBOLS\n","const DEFAULTS = [\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n ''\n]\n\nexport default DEFAULTS\n","import isString from '../types/isString'\nimport getSymbol from './getSymbol'\nimport SYMBOLS from './symbols'\n\n/**\n *\n * @method getSymbols\n * @param {String} [name]\n * @param {String} [iconSet]\n * @returns {string[]|*}\n */\nconst getSymbols = (name, iconSet = 'icon') => {\n if (isString(name)) {\n return getSymbol(name, iconSet)\n }\n\n return [...SYMBOLS]\n}\n\nexport default getSymbols\n","import SYMBOLS from './symbols'\n\n/**\n * @method getSymbol\n * @param {String} name\n * @param {String} [iconSet]\n * @returns {String}\n */\nconst getSymbol = (name, iconSet = 'icon') => {\n const patternName = /id=\"(.*?)\"/\n const patternSet = /^(\\w+)-/\n const symbols = SYMBOLS\n\n return symbols.find((symbol) => {\n const names = patternName.exec(symbol)\n const fullName = names[1]\n const sets = patternSet.exec(fullName)\n const setName = sets[1]\n const iconName =\n iconSet === 'icon' ? `${iconSet}-${name}` : `${iconSet}-icon-${name}`\n\n return setName === iconSet && fullName === iconName\n })\n}\n\nexport default getSymbol\n","import add from './add'\nimport getSymbols from './getSymbols'\n\n/**\n * 绘制 SVG 图标集\n * ========================================================================\n * @method paint\n * @param {String|Array} symbol\n */\nconst paint = (symbol = '') => {\n const $body = document.body\n let $icons = document.querySelector('#outline-icons')\n let symbols = []\n\n add(symbol)\n symbols = getSymbols()\n\n if ($icons) {\n $icons.innerHTML = symbols.join('')\n } else {\n $icons = document.createElement('div')\n $icons.innerHTML =\n ``\n $body.insertBefore($icons.firstChild, $body.firstChild)\n }\n}\n\nexport default paint\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport SYMBOLS from './symbols'\n\n/**\n * @method add\n * @param {Array|String} symbols\n * @return {Boolean}\n */\nconst add = (symbols) => {\n if (!symbols) {\n return false\n }\n\n if (isArray(symbols) && symbols.length > 0) {\n symbols.forEach((symbol) => {\n /* istanbul ignore else */\n if (SYMBOLS.indexOf(symbol) === -1 && isString(symbol)) {\n SYMBOLS.push(symbol)\n }\n })\n } else {\n /* istanbul ignore else */\n if (isString(symbols)) {\n SYMBOLS.push(symbols)\n }\n }\n}\n\nexport default add\n","import isString from '../types/isString'\n\n/**\n * 清楚字符串起始位置所有的空格\n * ========================================================================\n * @method trim\n * @param {string} str\n * @returns {string|Boolean}\n */\nconst trim = (str) => {\n if (!isString(str)) {\n return false\n }\n return str.replace(/(^\\s+)|(\\s+$)/g, '')\n}\n\nexport default trim\n","import isObject from './isObject'\r\nimport isElement from './isElement'\r\nimport isHTMLCollection from './isHTMLCollection'\r\nimport isFragment from './isFragment'\r\nimport isTextNode from './isTextNode'\r\n\r\nconst isDOM = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (isElement(el) || isHTMLCollection(el) || isFragment(el) || isTextNode(el))\r\n )\r\n}\r\n\r\nexport default isDOM\r\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isHTMLCollection = (el) => {\r\n return !!(isObject(el) && toString(el) === '[object NodeList]')\r\n}\r\n\r\nexport default isHTMLCollection\r\n","import toString from '../lang/toString'\nimport isObject from './isObject'\n\nconst isFragment = (fragment) => {\n return !!(\n isObject(fragment) && toString(fragment) === '[object DocumentFragment]'\n )\n}\n\nexport default isFragment\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isTextNode = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (toString(el) === '[object Text]' || (el.tagName && el.nodeType === 3))\r\n )\r\n}\r\n\r\nexport default isTextNode\r\n","/**\n * 给 DOM 节点设置属性/值\n * ========================================================================\n * @method setAttribute\n * @param {HTMLElement} el - DOM 节点\n * @param {String} attr - 属性名称\n * @param {String|Number|Boolean} value - 属性值\n */\nconst setAttribute = (el, attr, value) => {\n let tagName = el.tagName.toLowerCase()\n\n switch (attr) {\n case 'style':\n el.style.cssText = value\n break\n case 'value':\n if (tagName === 'input' || tagName === 'textarea') {\n el.value = value\n } else {\n el.setAttribute(attr, value)\n }\n break\n case 'className':\n el.className = value\n break\n default:\n el.setAttribute(attr, value)\n break\n }\n}\n\nexport default setAttribute\n","import hasOwn from '../lang/hasOwn'\nimport isObject from '../types/isObject'\nimport isString from '../types/isString'\nimport isArray from '../types/isArray'\nimport isDOM from '../types/isDOM'\nimport setAttribute from './setAttribute'\n\n/**\n * 创建 DOM 节点,并添加属性和子节点\n * ========================================================================\n * @method createElement\n * @param {String} tagName - 标签名称\n * @param {Object|Array} attrs - 属性对象或者子节点\n * @param {Array} [children] - 子节点数组\n * @returns {HTMLElement}\n */\nconst createElement = (tagName, attrs, children) => {\n const $fragment = document.createDocumentFragment()\n const $el = document.createElement(tagName)\n const isValidChild = (child) => {\n return isDOM(child) || isString(child)\n }\n const append = (child) => {\n let $child\n\n if (!isValidChild(child)) {\n return false\n }\n\n if (isDOM(child)) {\n $child = child\n } else if (isString(child)) {\n $child = document.createTextNode(child)\n }\n\n $fragment.appendChild($child)\n }\n\n if (isObject(attrs)) {\n Object.keys(attrs).forEach((attr) => {\n if (hasOwn(attrs, attr)) {\n setAttribute($el, attr, attrs[attr])\n }\n })\n } else if (isArray(attrs) && attrs.every((attr) => isValidChild(attr))) {\n attrs.forEach((child) => {\n append(child)\n })\n }\n\n if (isArray(children)) {\n children.forEach((child) => {\n append(child)\n })\n } else {\n append(children)\n }\n\n $el.appendChild($fragment)\n\n return $el\n}\n\nexport default createElement\n","import isString from './isString'\n\nconst isSVG = (str) => {\n const declaration = '(?:<\\\\?xml[^>]*>\\\\s*)?'\n const doctype =\n '(?:<\\\\!doctype svg[^>]*\\\\s*(?:\\\\[?(?:\\\\s*]*>\\\\s*)*\\\\]?)*[^>]*>\\\\s*)?'\n const content = ']*>[^]*<\\\\/svg>\\\\s*$'\n const svg = `^\\\\s*${declaration}${doctype}${content}\\\\s*$`\n const pattern = new RegExp(svg, 'i')\n\n return isString(str) && pattern.test(str)\n}\n\nexport default isSVG\n","import createElement from './createElement'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method icon\n * @alias createElement\n * @see createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst icon = (name, options = {}) => {\n return createElement(name, options)\n}\n\nexport default icon\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport isSVG from '../types/isSVG'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst createElement = (name, options = {}) => {\n const size = options.size || 0\n const color = options.color || ''\n const iconSet = options.iconSet || ''\n const width = isArray(size) ? size[0] : size\n const height = isArray(size) ? size[1] : size\n const defaultRules = size ? `width:${width}px;height:${height}px;` : ''\n const cssRules = color ? defaultRules + `color:${color}` : defaultRules\n const $icon = document.createElement('i')\n let binds = ''\n let svg = ''\n let $svg\n\n if (!isString(name)) {\n return null\n }\n\n if (isSVG(name)) {\n svg = name\n } else {\n binds =\n iconSet && iconSet !== 'icon'\n ? `xlink:href=\"#${iconSet}-icon-${name}\"`\n : `xlink:href=\"#icon-${name}\"`\n svg =\n `` +\n `` +\n ``\n }\n\n $icon.className = 'outline-icon'\n $icon.innerHTML = svg\n\n if (isSVG(name)) {\n $svg = $icon.querySelector('svg')\n $svg.setAttribute('aria-hidden', 'true')\n $svg.setAttribute('xmlns', 'http://www.w3.org/2000/svg')\n $svg.setAttribute('class', 'outline-icon__svg')\n $svg.setAttribute('width', '200')\n $svg.setAttribute('height', '200')\n $svg.style = cssRules\n }\n\n return $icon\n}\n\nexport default createElement\n","import isElement from '../types/isElement'\n/**\n * 检测 DOM 节点是否包含名为 className 的样式\n * ========================================================================\n * @method hasClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst hasClass = (el, className) => {\n const pattern = new RegExp('(\\\\s|^)' + className + '(\\\\s|$)')\n let allClass\n let classList\n\n if (!isElement(el)) {\n return false\n }\n\n allClass = el.className\n\n if (!allClass) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.contains) {\n return el.classList.contains(className)\n }\n\n return !!pattern.exec(allClass)\n}\n\nexport default hasClass\n","import trim from '../lang/trim'\nimport hasClass from './hasClass'\n\n/**\n * 移除 DOM 节点的 className 样式\n * ========================================================================\n * @method removeClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst removeClass = (el, className) => {\n let allClass = el.className\n let classList\n\n if (!allClass || !hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.remove) {\n classList.remove(className)\n } else {\n allClass = trim(allClass.replace(className, ''))\n el.className = allClass\n }\n}\n\nexport default removeClass\n","import removeClass from './utils/dom/removeClass'\nimport isEmpty from './utils/types/isEmpty'\nimport trim from './utils/lang/trim'\n\nconst _resetHeading = ($heading, hasAnchor = true, isAtStart = true) => {\n const CLS_HEADING = 'outline-heading'\n const text = $heading.innerHTML\n const pattern = /^\\d+(\\.?\\d+)*\\s?/gi\n let $anchor\n\n $heading.innerHTML = text.replace(pattern, '')\n $heading.removeAttribute('id')\n $heading.removeAttribute('data-id')\n\n removeClass($heading, CLS_HEADING)\n\n if (!hasAnchor) {\n return false\n }\n\n $anchor = $heading.querySelector(`.${CLS_HEADING}__anchor`)\n\n if (isAtStart) {\n removeClass($heading, `${CLS_HEADING}_start`)\n }\n\n if (isEmpty(trim($heading.className))) {\n $heading.removeAttribute('class')\n }\n\n $heading.removeChild($anchor)\n}\n\nexport default _resetHeading\n","import isString from './isString'\n/**\n * 检测数据是否为空字符串\n * ========================================================================\n * @method isEmpty\n * @param {String} str\n * @returns {boolean}\n */\nconst isEmpty = (str) => {\n return isString(str) && str === ''\n}\n\nexport default isEmpty\n","import trim from './utils/lang/trim'\nimport stripTags from './utils/lang/stripTags'\n\nimport _getChapterParentIdByDiffer from './_getChapterParentIdByDiffer'\nimport _getChaptersWithCode from './_getChaptersWithCode'\n\nconst getChapters = (headings, showCode = true) => {\n let previous = 1\n let level = 0\n const chapters = []\n\n headings.forEach((heading, i) => {\n const headingLevel = heading.tagName.replace(/h/i, '')\n let current = parseInt(headingLevel, 10)\n let pid = -1\n\n // 场景1:当前标题是前一个标题的子标题\n // 当前标题的(标题标签)序号 > 前一个标题的序号:两个相连的标题是父标题 -> 子标题关系;\n // h2 (前一个标题)\n // h3 (当前标题)\n if (current > previous) {\n level += 1\n\n // 第一层级的 pid 是 -1\n if (level === 1) {\n pid = -1\n } else {\n pid = i - 1\n }\n }\n // 场景2:当前标题和前一个标题层级相同\n // 当前标题的(标题标签)序号 = 前一个标题的序号\n // h2 (前一个标题)\n // h2 (当前标题)\n // 当前标题的(标题标签)序号 < 前一个标题的序号,并且当前标题序号 > 当前的级别\n // h2\n // h4 (前一个标题)\n // h3 (当前标题:这种情况我们还是任务 h3 是 h2 的下一级章节)\n else if (current === previous || (current < previous && current > level)) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n pid = -1\n } else {\n pid = chapters[i - 1].pid\n }\n }\n // 场景3:当前标题比前一个标题层级高\n else if (current <= level) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n } else {\n level = level - (previous - current)\n\n if (level <= 1) {\n level = 1\n }\n }\n\n // 第一级的标题\n if (level === 1) {\n pid = -1\n } else {\n // 通过当前标题和前一个标题之间的等级差,获得当前标题的父标题ID\n pid = _getChapterParentIdByDiffer(chapters, previous - current, i)\n }\n }\n\n previous = current\n\n chapters.push({\n id: i,\n pid: pid,\n level: level,\n rel: `heading-${i}`,\n text: stripTags(trim(heading.innerHTML))\n })\n })\n\n return showCode ? _getChaptersWithCode(chapters) : chapters\n}\n\nexport default getChapters\n","import isString from '../types/isString'\n\n/**\n * 过滤所有 HTML 标签\n * ========================================================================\n * @method stripTags\n * @param {string} str\n * @returns {string}\n */\nconst stripTags = (str) => {\n if (!isString(str)) {\n return ''\n }\n return str.replace(/<\\/?[^>]+(>|$)/g, '')\n}\n\nexport default stripTags\n","const _getChapterParentIdByDiffer = (chapters, differ, index) => {\n let previous = chapters[index - 1]\n let pid\n let i\n\n for (i = 0; i < differ; i += 1) {\n pid = previous.pid\n previous = chapters[pid]\n }\n\n pid = previous.pid\n\n return pid\n}\n\nexport default _getChapterParentIdByDiffer\n","const _getChaptersWithCode = (chapters) => {\n const groups = {}\n const cb = (o) => {\n return [o.pid]\n }\n\n chapters.forEach((o) => {\n const group = JSON.stringify(cb(o))\n\n groups[group] = groups[group] || []\n groups[group].push(o)\n\n o.index = groups[group].length\n if (o.pid === -1) {\n o.code = String(o.index)\n }\n })\n\n Object.keys(groups).forEach((group) => {\n groups[group].forEach((c) => {\n const subjects = chapters.filter((b) => b.pid === c.id)\n subjects.forEach((o) => {\n o.code = c.code + '.' + o.index\n })\n })\n })\n\n return chapters\n}\n\nexport default _getChaptersWithCode\n","import Base from './base'\n\n// 在文章的标题生成 anchor 链接\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport toTree from './utils/lang/toTree'\nimport later from './utils/lang/later'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport offsetTop from './utils/dom/offsetTop'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _updateHeading from './_updateHeading'\nimport _resetHeading from './_resetHeading'\nimport getChapters from './getChapters'\n\nclass Anchors extends Base {\n constructor(options) {\n super()\n\n this.attrs = Anchors.DEFAULTS\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n\n this.chapters = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let scrollElement\n let selector\n let $articleElement\n let articleElement\n\n this.attr(options)\n articleElement = this.attr('articleElement')\n scrollElement = this.attr('scrollElement')\n selector = this.attr('selector')\n created = this.attr('created')\n\n if (isString(articleElement)) {\n $articleElement = document.querySelector(articleElement)\n } else if (isElement(articleElement)) {\n $articleElement = articleElement\n }\n\n if (!$articleElement) {\n return this\n }\n\n this.$articleElement = $articleElement\n this.$scrollElement = _getScrollElement(scrollElement)\n this.$headings = [...$articleElement.querySelectorAll(selector)]\n\n if (this.$headings.length < 1) {\n return this\n }\n\n this.chapters = getChapters(this.$headings)\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n getChapters(isTreeStructured = false) {\n const chapters = this.chapters\n return isTreeStructured ? toTree(chapters, 'id', 'pid') : chapters\n }\n\n count() {\n return this.chapters.length\n }\n\n render() {\n const mounted = this.attr('mounted')\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const $headings = this.$headings\n const chapters = this.getChapters()\n\n paint()\n\n $headings.forEach(($heading, i) => {\n const chapterCode = chapters[i].code\n _updateHeading($heading, i, {\n hasAnchor,\n isAtStart,\n showCode,\n chapterCode,\n anchorURL\n })\n })\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n destroy() {\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n const $headings = this.$headings\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n $headings.forEach(($heading) => {\n _resetHeading($heading, hasAnchor, isAtStart)\n })\n\n this.attr(Anchors.DEFAULTS)\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n this.chapters = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n onAnchorTrigger(evt) {\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const $heading = $anchor.parentNode\n const top = offsetTop($heading) - (stickyHeight + 10)\n const $scrollElement = this.$scrollElement\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'anchor')\n }\n\n later(() => {\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.scrollTo(top, after)\n\n if (!anchorURL) {\n stop(evt)\n }\n\n return this\n }\n\n addListeners() {\n const $articleElement = this.$articleElement\n\n on(\n $articleElement,\n '.outline-heading__anchor',\n 'click',\n this.onAnchorTrigger,\n this,\n true\n )\n\n return this\n }\n\n removeListeners() {\n const $articleElement = this.$articleElement\n\n off($articleElement, 'click', this.onAnchorTrigger)\n\n return this\n }\n}\n\nAnchors.DEFAULTS = {\n scrollElement: 'html,body',\n articleElement: '#article',\n selector: 'h1,h2,h3,h4,h5,h6',\n stickyHeight: 0,\n anchorURL: '',\n hasAnchor: true,\n isAtStart: true,\n showCode: false,\n created: null,\n mounted: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Anchors\n","const toTree = (list, nodeKey, parentKey) => {\r\n const map = {}\r\n const roots = []\r\n\r\n list.forEach((item, i) => {\r\n // initialize the map\r\n map[item[nodeKey]] = i\r\n // initialize the children\r\n item.children = []\r\n })\r\n\r\n list.forEach((item) => {\r\n const node = list[map[item[parentKey]]]\r\n\r\n if (item[parentKey] !== -1) {\r\n // if you have dangling branches check that map[node.parentId] exists\r\n node.children.push(item)\r\n } else {\r\n roots.push(item)\r\n }\r\n })\r\n\r\n return roots\r\n}\r\n\r\nexport default toTree\r\n","import trim from './utils/lang/trim'\nimport createElement from './utils/dom/createElement'\nimport setAttribute from './utils/dom/setAttribute'\n\nimport icon from './utils/icons/icon'\n\nconst _updateHeading = ($heading, i, options) => {\n const $fragment = document.createDocumentFragment()\n const CLS_HEADING = 'outline-heading'\n const hasAnchor = options.hasAnchor || true\n const isAtStart = options.isAtStart || true\n const showCode = options.showCode || false\n const chapterCode = options.chapterCode || ''\n const anchorURL = options.anchorURL || ''\n const headingId = `heading-${i}`\n const attrs = {\n id: headingId,\n className: isAtStart ? `${CLS_HEADING} ${CLS_HEADING}_start` : CLS_HEADING,\n 'data-id': i\n }\n const keys = Object.keys(attrs)\n const text = trim($heading.innerHTML)\n let $anchor\n let $icon\n\n keys.forEach((prop) => {\n setAttribute($heading, prop, attrs[prop])\n })\n\n if (showCode) {\n $heading.innerHTML = chapterCode + ' ' + text\n }\n\n if (!hasAnchor) {\n return false\n }\n\n $icon = icon('hash', { iconSet: 'outline' })\n $anchor = createElement(\n 'a',\n {\n id: `anchor-${i}`,\n className: `${CLS_HEADING}__anchor anchor-${i}`,\n href: anchorURL || `#${headingId}`,\n target: anchorURL ? '_blank' : 'self',\n 'data-id': i\n },\n [$icon]\n )\n $fragment.appendChild($anchor)\n $heading.appendChild($fragment)\n}\n\nexport default _updateHeading\n","import hasClass from './hasClass'\n\n/**\n * 给 DOM 节点添加名为 className 的样式\n * ========================================================================\n * @method addClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst addClass = (el, className) => {\n let classList\n let allClass\n\n if (hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.add) {\n classList.add(className)\n } else {\n allClass = el.className\n allClass += allClass.length > 0 ? ' ' + className : className\n el.className = allClass\n }\n}\n\nexport default addClass\n","const setProperty = (prop, value) => {\r\n const documentElement = document.documentElement\r\n documentElement.style.setProperty(prop, value)\r\n}\r\n\r\nexport default setProperty\r\n","import setProperty from './utils/dom/setProperty'\n\nlet index = 2000\n\nconst zIndex = (idx) => {\n if (idx) {\n index = idx\n } else {\n index += 1\n }\n\n setProperty('--outline-zIndex', `${index}`)\n\n return index\n}\n\nexport default zIndex\n","import Base from './base'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport addClass from './utils/dom/addClass'\nimport removeClass from './utils/dom/removeClass'\nimport createElement from './utils/dom/createElement'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\n\nimport paint from './utils/icons/paint'\nimport icon from './utils/icons/icon'\nimport zIndex from './zIndex'\n\nclass Drawer extends Base {\n constructor(options) {\n super()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = true\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n this.zIndex = 0\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n\n this.title = this.attr('title')\n created = this.attr('created')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n return this\n }\n\n setTitle(title) {\n this.attr('title', title)\n this.title = title\n this.$title.innerHTML = title\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n render() {\n const mounted = this.attr('mounted')\n const size = this.attr('size')\n const placement = this.attr('placement')\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const hasOffset = this.attr('hasOffset')\n const hasPadding = this.attr('hasPadding')\n const autoHeight = this.attr('autoHeight')\n const customClass = this.attr('customClass')\n let $el\n let $modal\n let $header\n let $title\n let $close\n let $main\n let $footer\n let $overlay\n\n paint()\n this.zIndex = zIndex()\n\n $title = createElement(\n 'h2',\n {\n className: 'outline-drawer__title'\n },\n [this.title]\n )\n this.$title = $title\n\n if (hasClose) {\n $close = createElement(\n 'div',\n {\n className: 'outline-drawer__close'\n },\n [icon('close', { size: 20 })]\n )\n this.$close = $close\n }\n\n $header = createElement(\n 'header',\n {\n className: 'outline-drawer__header'\n },\n [$title, $close]\n )\n this.$header = $header\n\n $main = createElement(\n 'div',\n {\n className: 'outline-drawer__main'\n },\n ['']\n )\n this.$main = $main\n\n if (!hasPadding) {\n addClass($main, 'outline-drawer_full')\n }\n\n $footer = createElement(\n 'footer',\n {\n className: 'outline-drawer__footer'\n },\n ['']\n )\n this.$footer = $footer\n\n $modal = createElement(\n 'div',\n {\n className: `outline-drawer__modal outline-drawer_${placement} outline-drawer_${size} outline-drawer_closed`\n },\n [$header, $main, $footer]\n )\n this.$modal = $modal\n\n if (hasOffset) {\n addClass($modal, 'outline-drawer_offset')\n }\n\n if (autoHeight) {\n addClass($modal, 'outline-drawer_auto')\n }\n\n if (customClass) {\n addClass($modal, customClass)\n }\n\n if (hasOverlay) {\n $overlay = createElement(\n 'div',\n {\n className: 'outline-drawer__overlay'\n },\n ['']\n )\n this.$overlay = $overlay\n }\n\n $el = createElement(\n 'div',\n {\n className: `outline-drawer`\n },\n [$modal, $overlay]\n )\n this.$el = $el\n document.body.appendChild($el)\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n open() {\n const opened = this.attr('afterOpened')\n const $modal = this.$modal\n\n addClass(this.$el, 'outline-drawer_opened')\n removeClass($modal, 'outline-drawer_closed')\n addClass($modal, 'outline-drawer_opened')\n\n later(() => {\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n })\n\n return this\n }\n\n close() {\n const closed = this.attr('afterClosed')\n const $modal = this.$modal\n\n removeClass($modal, 'outline-drawer_opened')\n addClass($modal, 'outline-drawer_closed')\n\n later(() => {\n removeClass(this.$el, 'outline-drawer_opened')\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n })\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const closed = this.isClosed()\n\n if (closed) {\n this.open()\n } else {\n this.close()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n afterToggle.call(this, closed)\n })\n }\n\n return this\n }\n\n destroy() {\n const afterDestroy = this.attr('afterDestroy')\n const beforeDestroy = this.attr('beforeDestroy')\n let index = this.zIndex\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = false\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n\n index -= 1\n zIndex(index)\n this.zIndex = 0\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n addListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (hasClose) {\n on($el, '.outline-drawer__close', 'click', this.onClose, this, true)\n }\n\n if (hasOverlay) {\n on($el, '.outline-drawer__overlay', 'click', this.onClose, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (!hasClose && !hasOverlay) {\n return this\n }\n\n off($el, 'click', this.onClose)\n\n return this\n }\n\n onClose() {\n this.close()\n return this\n }\n}\n\nDrawer.DEFAULTS = {\n placement: 'rtl',\n title: '标题',\n size: 'regular',\n hasClose: true,\n hasOverlay: true,\n hasOffset: false,\n hasPadding: true,\n autoHeight: true,\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterToggle: null\n}\n\nexport default Drawer\n","import isFunction from '../types/isFunction'\nimport off from './off'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定事件\n * ========================================================================\n * @method at\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (必须) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst at = (el, type, fn, data, context, once = false) => {\n // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n const listener = function (evt) {\n let overrideContext = context || el\n\n // 当设置为 true 时,则事件处理器回调函数的\n // this 上下文指向为 data 对象\n if (context === true) {\n overrideContext = data\n }\n\n // 仅触发一次\n /* istanbul ignore else */\n if (once === true) {\n off(el, type, listener)\n }\n\n fn.call(overrideContext, evt, data)\n }\n\n if (!isFunction(fn)) {\n return false\n }\n\n if (!el._listeners) {\n el._listeners = []\n }\n\n // 缓存 options 元素绑定的事件处理器\n el._listeners.push({\n el,\n type,\n fn: listener,\n data,\n context,\n capture\n })\n\n // 缓存包装后的事件处理器\n fn._delegateListener = listener\n\n el.addEventListener(type, listener, capture)\n}\n\nexport default at\n","/**\r\n * 获取HTML元素的某个CSS样式值\r\n * ====================================================\r\n * @param el\r\n * @param ruleName\r\n * @returns {*}\r\n */\r\nconst getStyle = (el, ruleName) => {\r\n return getComputedStyle(el)[ruleName]\r\n}\r\n\r\nexport default getStyle\r\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport later from './utils/lang/later'\nimport at from './utils/event/at'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport createElement from './utils/dom/createElement'\nimport scrollTo from './utils/dom/scrollTo'\nimport addClass from './utils/dom/addClass'\nimport intersection from './utils/dom/intersection'\nimport removeClass from './utils/dom/removeClass'\nimport offsetTop from './utils/dom/offsetTop'\nimport getStyle from './utils/dom/getStyle'\nimport setProperty from './utils/dom/setProperty'\nimport publish from './utils/observer/emit'\n\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport _paintChapters from './_paintChapters'\n\nclass Chapters extends Base {\n constructor(options) {\n super()\n\n this.attrs = Chapters.DEFAULTS\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.closed = false\n this.active = 0\n this.offsetTop = 0\n this.offsetWidth = 0\n this.$active = null\n this.scrollTimer = null\n this.resizeTimer = null\n this.playing = false\n this.Observer = null\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let parentElement\n let scrollElement\n let $parent\n\n this.attr(options)\n created = this.attr('created')\n parentElement = this.attr('parentElement')\n scrollElement = this.attr('scrollElement')\n\n if (isString(parentElement)) {\n $parent = document.querySelector(parentElement)\n } else if (isElement(parentElement)) {\n $parent = parentElement\n }\n this.$parentElement = $parent\n this.$scrollElement = _getScrollElement(scrollElement)\n\n this.chapters = this.attr('chapters')\n this.closed = this.attr('closed')\n this.active = this.attr('active')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n if (this.chapters.length < 1) {\n return this\n }\n\n this.render().addListeners()\n\n this.$active = document.querySelector(`#chapter-${this.active}`)\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n isSticky() {\n const position = this.attr('position')\n return position === 'sticky'\n }\n\n isFixed() {\n const position = this.attr('position')\n return position === 'fixed'\n }\n\n isInside() {\n return this.isFixed() || this.isSticky()\n }\n\n isOutside() {\n return !this.isInside()\n }\n\n _paintEdge() {\n const $fragment = document.createDocumentFragment()\n const STICKY = 'outline-chapters_sticky'\n const HIDDEN = 'outline-chapters_hidden'\n const title = this.attr('title')\n const customClass = this.attr('customClass')\n const $parentElement = this.$parentElement\n const contents = []\n let $title = null\n let $el\n let $main\n let $list\n let $placeholder\n\n if (!$parentElement) {\n return this\n }\n\n if (this.isInside()) {\n $title = createElement(\n 'h2',\n {\n className: 'outline-chapters__title'\n },\n [title]\n )\n this.$title = $title\n contents.push($title)\n }\n\n $list = createElement(\n 'ul',\n {\n // 为优化性能,添加了 _fixed 和 _hidden\n // fixed 为了让 $list 脱离流布局\n // hidden 让 $list 不可见\n className: `outline-chapters__list`\n },\n ['']\n )\n this.$list = $list\n\n $placeholder = createElement(\n 'div',\n {\n className: 'outline-chapters__placeholder'\n },\n ['']\n )\n this.$placeholder = $placeholder\n\n $main = createElement(\n 'div',\n {\n className: 'outline-chapters__main'\n },\n [$list, $placeholder]\n )\n this.$main = $main\n contents.push($main)\n\n $el = createElement(\n 'nav',\n {\n id: 'outline-chapters',\n className: `outline-chapters ${HIDDEN}`\n },\n contents\n )\n this.$el = $el\n\n if (this.isSticky()) {\n this.calculateStickyHeight()\n addClass($el, STICKY)\n }\n\n if (customClass) {\n addClass($el, customClass)\n }\n $fragment.appendChild($el)\n $parentElement.appendChild($fragment)\n\n return this\n }\n\n render() {\n const HIDDEN = 'outline-chapters_hidden'\n const showCode = this.attr('showCode')\n const mounted = this.attr('mounted')\n const $parentElement = this.$parentElement\n const chapters = this.chapters\n let $el\n let $list\n\n if (!$parentElement || chapters.length < 1) {\n return this\n }\n\n this._paintEdge()\n\n $el = this.$el\n $list = this.$list\n _paintChapters($list, chapters, showCode)\n removeClass($el, HIDDEN)\n this.positionPlaceholder(this.active)\n\n this.offsetTop = offsetTop($el)\n this.offsetWidth = $el.offsetWidth\n\n if (this.isFixed()) {\n this.sticky()\n setProperty('--outline-chapters-width', `${this.offsetWidth}px`)\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n this.onObserver()\n\n return this\n }\n\n positionPlaceholder(index) {\n const $main = this.$main\n const $list = this.$list\n const $placeholder = this.$placeholder\n const $anchor = $list.querySelector('.outline-chapters__anchor')\n const mainPaddingTop = parseInt(getStyle($main, 'padding-top'), 10)\n const mainBorderTop = parseInt(getStyle($main, 'border-top-width'), 10)\n const placeholderPaddingTop = parseInt(getStyle($list, 'padding-top'), 10)\n const placeholderMarginTop = parseInt(getStyle($list, 'margin-top'), 10)\n const placeholderBorderTop = parseInt(\n getStyle($list, 'border-top-width'),\n 10\n )\n let height = $anchor.offsetHeight\n let offsetTop = 0\n let top\n\n if (mainPaddingTop) {\n offsetTop += mainPaddingTop\n }\n\n if (placeholderPaddingTop) {\n offsetTop += placeholderPaddingTop\n }\n\n if (placeholderMarginTop) {\n offsetTop += placeholderMarginTop\n }\n\n if (mainBorderTop) {\n offsetTop += mainBorderTop\n }\n\n if (placeholderBorderTop) {\n offsetTop += placeholderBorderTop\n }\n\n top = height * index\n // top:calc(${offsetTop}px + ${top}px);\n $placeholder.style.cssText = `transform: translateY(${\n offsetTop + top\n }px);height:${height}px;`\n\n return this\n }\n\n highlight(id) {\n const $anchor = this.$el.querySelector(`#chapter__anchor-${id}`)\n const HIGHLIGHT = 'outline-chapters_active'\n\n if (!$anchor) {\n return this\n }\n\n if (this.$active) {\n removeClass(this.$active, HIGHLIGHT)\n }\n\n this.active = parseInt($anchor.getAttribute('data-id'), 10)\n this.$active = $anchor\n addClass(this.$active, HIGHLIGHT)\n\n this.positionPlaceholder(this.active)\n\n return this\n }\n\n sticky() {\n const afterSticky = this.attr('afterSticky')\n const FIXED = 'outline-chapters_fixed'\n const $el = this.$el\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (!this.isFixed()) {\n return this\n }\n\n isStickying = scrollTop >= top\n\n if (isStickying) {\n addClass($el, FIXED)\n } else {\n removeClass($el, FIXED)\n }\n\n if (isFunction(afterSticky)) {\n afterSticky.call(this, this.isClosed(), isStickying)\n }\n\n return this\n }\n\n calculateStickyHeight() {\n const documentElement = document.documentElement\n const height = Math.max(\n documentElement.clientHeight || 0,\n window.innerHeight || 0\n )\n setProperty('--outline-sticky-height', `${height}px`)\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n show() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const opened = this.attr('afterOpened')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n removeClass($parent, HIDDEN)\n removeClass($el, HIDDEN)\n later(() => {\n removeClass($parent, FOLDED)\n removeClass($el, FOLDED)\n }, 30)\n } else {\n removeClass($el, HIDDEN)\n }\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n\n return this\n }\n\n hide() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const closed = this.attr('afterClosed')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n addClass($parent, FOLDED)\n addClass($el, FOLDED)\n later(() => {\n addClass($parent, HIDDEN)\n addClass($el, HIDDEN)\n })\n } else {\n addClass($el, HIDDEN)\n }\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n isStickying = scrollTop >= top\n afterToggle.call(this, this.isClosed(), isStickying)\n })\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n this.$parentElement.removeChild(this.$el)\n\n this.attr(Chapters.DEFAULTS)\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.active = 0\n this.offsetTop = 0\n this.$active = null\n this.closed = false\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n this.scrollTimer = null\n }\n\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n this.resizeTimer = null\n }\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n if (this.Observer) {\n this.Observer = null\n }\n\n return this\n }\n\n onObserver() {\n const selector = this.attr('selector')\n let timer = null\n\n this.Observer = intersection(\n ($heading) => {\n const id = $heading.getAttribute('data-id')\n\n if (this.playing) {\n return false\n }\n\n if (timer) {\n clearTimeout(timer)\n }\n\n timer = later(() => {\n this.highlight(id)\n }, 100)\n },\n {\n selector,\n context: this\n }\n )\n\n return this\n }\n\n onSelect(evt) {\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const id = $anchor.getAttribute('data-id')\n const headingId = $anchor.href.split('#')[1]\n const $heading = document.querySelector(`#${headingId}`)\n const top = offsetTop($heading) - (stickyHeight + 10)\n const min = 0\n const max = this.$scrollElement.scrollHeight\n const afterScroll = this.attr('afterScroll')\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'chapter')\n }\n\n later(() => {\n this.playing = false\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.playing = true\n if (this.isFixed()) {\n this.sticky()\n later(() => {\n this.scrollTo(top, after)\n this.highlight(id)\n }, 10)\n } else {\n this.scrollTo(top, after)\n this.highlight(id)\n }\n\n stop(evt)\n\n return this\n }\n\n onScroll() {\n const $scrollElement = this.$scrollElement\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n }\n\n this.scrollTimer = later(() => {\n const top = $scrollElement.scrollTop\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n\n if (this.isFixed()) {\n this.sticky()\n }\n\n publish('toolbar:update', {\n top,\n min,\n max\n })\n }, 100)\n\n return this\n }\n\n onResize() {\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n }\n\n this.resizeTimer = later(() => {\n this.calculateStickyHeight()\n })\n\n return this\n }\n\n addListeners() {\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n on($el, '.outline-chapters__anchor', 'click', this.onSelect, this, true)\n at($element, 'scroll', this.onScroll, this, true)\n if (this.isSticky()) {\n at($element, 'resize', this.onResize, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const selector = this.attr('selector')\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n off($el, 'click', this.onSelect)\n off($element, 'scroll', this.onScroll)\n\n if (this.isSticky()) {\n at($element, 'resize', this.onResize)\n }\n\n if (this.Observer) {\n document.querySelectorAll(selector).forEach((section) => {\n this.Observer.unobserve(section)\n })\n }\n\n return this\n }\n}\n\nChapters.DEFAULTS = {\n parentElement: '',\n scrollElement: '',\n selector: '.outline-heading',\n active: 0,\n closed: false,\n showCode: true,\n position: 'relative',\n stickyHeight: 0,\n chapters: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterSticky: null\n}\n\nexport default Chapters\n","import createElement from './utils/dom/createElement'\n\nconst _paintChapters = ($list, chapters, showCode = false) => {\n const byId = (id) => document.querySelector(`#${id}`)\n\n chapters.forEach((chapter) => {\n const pid = chapter.pid\n const id = chapter.id\n const rel = chapter.rel\n const $text = createElement(\n 'span',\n {\n className: 'outline-chapters__text'\n },\n [chapter.text]\n )\n const $link = createElement(\n 'a',\n {\n id: `chapter__anchor-${id}`,\n className: 'outline-chapters__anchor',\n href: '#' + rel,\n rel: rel,\n 'data-id': id\n },\n [$text]\n )\n let $code\n let $li\n let $ul\n let $parent\n\n if (showCode) {\n $code = createElement(\n 'span',\n {\n className: 'outline-chapters__code',\n 'data-id': id\n },\n [chapter.code]\n )\n\n $link.insertBefore($code, $link.firstChild)\n }\n\n $li = createElement(\n 'li',\n {\n id: `chapter-${id}`,\n className: 'outline-chapters__item',\n 'data-id': id\n },\n [$link]\n )\n\n if (pid === -1) {\n $list.appendChild($li)\n } else {\n $parent = byId(`chapter-${pid}`)\n $ul = byId(`subject-${pid}`)\n\n if (!$ul) {\n $ul = createElement(\n 'ul',\n {\n id: 'subject-' + pid,\n className: 'outline-chapters__subject'\n },\n [$li]\n )\n\n $parent.appendChild($ul)\n } else {\n $ul.appendChild($li)\n }\n }\n })\n}\n\nexport default _paintChapters\n","import isFunction from '../types/isFunction'\nimport isElement from '../types/isElement'\n\n/**\n * 通用的 IntersectionObserver 观察者处理器\n * ========================================================================\n * @method intersection\n * @param {Function} fn\n * @param {Object} [props]\n * @param {Object|HTMLElement} [props.root]\n * @param {String} [props.selector]\n * @param {Object} [props.context]\n * @param {String} [props.attr]\n * @param {String} [props.rootMargin]\n */\nconst intersection = (fn, props = {}) => {\n const root = props.root || null\n const selector = props.selector || '.outline-heading'\n const context = props.context || null\n const rootMargin = props.rootMargin || '0px 0px -90% 0px'\n const options = {\n rootMargin: rootMargin\n }\n const Observer = new IntersectionObserver((entries) => {\n entries.forEach((entry) => {\n if (entry.intersectionRatio > 0) {\n if (isFunction(fn)) {\n fn.call(context || entry.target, entry.target)\n }\n }\n })\n }, options)\n const $root = isElement(root) ? root : document\n\n if (root) {\n options.root = root\n }\n\n $root.querySelectorAll(selector).forEach((section) => {\n Observer.observe(section)\n })\n\n return Observer\n}\n\nexport default intersection\n","import icon from './utils/icons/icon'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\n\nconst _createButton = (button, rounded = true) => {\n const $icon = icon(button.icon, {\n iconSet: button.iconSet || 'outline',\n color: button.color || '',\n size: button.size\n })\n const $anchor = createElement(\n 'a',\n {\n className: `outline-toolbar__anchor`,\n href: button.link\n },\n [$icon]\n )\n const $button = createElement(\n 'div',\n {\n className: `outline-toolbar__button ${button.name}`\n },\n [button.link ? $anchor : $icon]\n )\n\n addClass($icon, 'outline-toolbar__icon')\n\n if (rounded) {\n addClass($button, 'outline-toolbar_rounded')\n }\n\n if (button.disabled) {\n addClass($button, 'outline-toolbar_disabled')\n }\n\n return $button\n}\n\nexport default _createButton\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isObject from './utils/types/isObject'\nimport isArray from './utils/types/isArray'\nimport later from './utils/lang/later'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\nimport hasClass from './utils/dom/hasClass'\nimport removeClass from './utils/dom/removeClass'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _createButton from './_createButton'\n\nconst DISABLED = 'outline-toolbar_disabled'\nconst HIDDEN = 'outline-toolbar_hidden'\n\nclass Toolbar extends Base {\n constructor(options) {\n super()\n\n this.attrs = Toolbar.DEFAULTS\n this.$el = null\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n created = this.attr('created')\n this.disabled = this.attr('disabled')\n this.closed = this.attr('closed')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n isDisabled(name) {\n const buttons = this.attr('buttons')\n let button\n\n if (name) {\n button = buttons.find((option) => option.name === name)\n\n return button?.disabled\n }\n\n return this.disabled\n }\n\n isClosed() {\n return this.closed\n }\n\n highlight(name) {\n const button = this.buttons.find((item) => item.name === name)\n const ACTIVE = 'outline-toolbar_active'\n let $button\n\n if ($button) {\n return this\n }\n\n $button = button.$el\n\n if (hasClass($button, ACTIVE)) {\n removeClass($button, ACTIVE)\n } else {\n addClass($button, ACTIVE)\n }\n\n return this\n }\n\n render() {\n const mounted = this.attr('mounted')\n const buttons = this.attr('buttons') || []\n const rounded = this.attr('rounded')\n const placement = this.attr('placement')\n const $buttons = document.createDocumentFragment()\n const $fragment = document.createDocumentFragment()\n\n paint()\n\n buttons.forEach((button) => {\n const $button = _createButton(button, rounded)\n\n $buttons.appendChild($button)\n this.buttons.push({\n name: button.name,\n $el: $button\n })\n })\n\n this.$el = createElement(\n 'div',\n {\n id: 'outline-toolbar',\n className: `outline-toolbar outline-toolbar_${placement}`\n },\n [$buttons]\n )\n $fragment.appendChild(this.$el)\n document.body.appendChild($fragment)\n\n if (this.closed) {\n this.hide()\n }\n\n if (this.disabled) {\n this.disable()\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n add(button) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const action = button.action\n const $fragment = document.createDocumentFragment()\n let type\n\n if (isObject(button)) {\n buttons.push(button)\n $fragment.appendChild(_createButton(button))\n } else if (isArray(button)) {\n button.forEach((item) => {\n $fragment.appendChild(_createButton(item))\n })\n }\n $el.appendChild($fragment)\n\n if (action && isFunction(action.handler)) {\n type = action.type || 'click'\n on($el, `.${button.name}`, type, action.handler)\n }\n\n return this\n }\n\n remove(name) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let index = -1\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((button, i) => {\n if (button.name === name) {\n index = i\n }\n })\n\n if (index > -1) {\n this.attr().buttons.splice(index, 1)\n }\n\n $button = $el.querySelector(`.${name}`)\n this.switch(name, false)\n $el.removeChild($button)\n\n return this\n }\n\n switch(name, enabled) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let action\n let type\n let listener\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((option) => {\n if (option.name === name) {\n button.disabled = !enabled\n }\n })\n\n action = button.action\n $button = $el.querySelector(`.${name}`)\n\n if (action) {\n type = action.type || 'click'\n listener = action.handler\n }\n\n if (enabled) {\n removeClass($button, DISABLED)\n\n if (type && listener) {\n on($el, `.${name}`, type, listener)\n }\n } else {\n addClass($button, DISABLED)\n\n if (type && listener) {\n off($el, type, listener)\n }\n }\n\n return this\n }\n\n disable(name) {\n const disabled = this.attr('afterDisabled')\n\n if (name) {\n this.switch(name, false)\n } else {\n addClass(this.$el, DISABLED)\n this.removeListeners()\n this.disabled = true\n\n if (isFunction(disabled)) {\n disabled.call(this)\n }\n }\n\n return this\n }\n\n enable(name) {\n const enabled = this.attr('afterEnabled')\n\n if (name) {\n this.switch(name, true)\n } else {\n this.disabled = false\n removeClass(this.$el, DISABLED)\n this.addListeners()\n\n if (isFunction(enabled)) {\n enabled.call(this)\n }\n }\n\n return this\n }\n\n show(name) {\n const opened = this.attr('afterOpened')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n\n $button = $el.querySelector(`.${name}`)\n removeClass($button, HIDDEN)\n } else {\n removeClass($el, HIDDEN)\n this.closed = false\n\n if (isFunction(opened)) {\n later(() => {\n opened.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n hide(name) {\n const closed = this.attr('afterClosed')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n $button = $el.querySelector(`.${name}`)\n addClass($button, HIDDEN)\n } else {\n addClass($el, HIDDEN)\n this.closed = true\n\n if (isFunction(closed)) {\n later(() => {\n closed.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n toggle() {\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n let $el = this.$el\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n document.body.removeChild($el)\n $el = null\n\n this.attr(Toolbar.DEFAULTS)\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n refresh() {\n const $el = this.$el\n const buttons = this.attr('buttons') || []\n\n this.removeListeners()\n $el.innerHTML = ''\n\n buttons.forEach((button) => {\n this.$el.appendChild(_createButton(button))\n })\n\n this.addListeners()\n\n return this\n }\n\n addListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n let context\n let command\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n if (isString(listener)) {\n command = listener\n action.handler = function () {\n publish(command, button.name)\n }\n listener = action.handler\n }\n\n type = action.type || 'click'\n context = action.context\n }\n\n if (isFunction(listener)) {\n on($el, `.${button.name}`, type, listener, context || this, true)\n }\n })\n\n return this\n }\n\n removeListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n type = action.type || 'click'\n }\n\n if (isFunction(listener)) {\n off($el, type, listener)\n }\n })\n\n return this\n }\n}\n\nToolbar.DEFAULTS = {\n placement: 'ltr',\n closed: false,\n disabled: false,\n rounded: true,\n buttons: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterDisabled: null,\n afterEnabled: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Toolbar\n","/**\n * 生成唯一 id 字符串的函数\n * ========================================================================\n * @method guid\n * @param {String} [prefix] - 生成 id 的前缀字符串\n * @return {String} 返回一个表示唯一 id 的字符串\n */\nconst guid = (() => {\n let uuid = 0\n\n return (prefix) => {\n uuid += 1\n\n return prefix ? prefix + '-' + uuid : 'guid-' + uuid\n }\n})()\n\nexport default guid\n","import _subscribers from './_subscribers'\nimport isFunction from '../types/isFunction'\nimport guid from '../lang/guid'\n\n/**\n * 订阅主题,并给出处理器函数\n * ========================================================================\n * @method on\n * @param {String} topic - (必须)主题名称\n * @param {Function} handler - (必须)主题的处理器函数\n * @param {Object} [context] - (可选)指定 this 执行上下文\n * @return {String} - 唯一的 token 字符串,例如:'guid-1'。\n */\nconst on = (topic, handler, context = null) => {\n const token = guid()\n let subject = typeof topic === 'symbol' ? topic.toString() : topic\n\n if (!isFunction(handler)) {\n return ''\n }\n\n /* istanbul ignore else */\n if (!_subscribers[subject]) {\n _subscribers[subject] = []\n }\n\n _subscribers[subject].push({\n topic: subject,\n callback: handler,\n context,\n token\n })\n\n return token\n}\n\nexport default on\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 删除与给定 topic 相同的订阅者信息\n * ========================================================================\n * @method _removeSubscriber\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _removeSubscriber = (topic) => {\n if (!hasOwn(_subscribers, topic)) {\n return false\n }\n\n delete _subscribers[topic]\n}\n\nexport default _removeSubscriber\n","import has from './has'\nimport _removeSubscriber from './_removeSubscriber'\nimport _removeSubscriberByToken from './_removeSubscriberByToken'\n\n/**\n * 取消订阅主题\n * ========================================================================\n * @method off\n * @param {String} topic - (必须)订阅的主题\n * @param {Function|String} [token] - (可选)订阅主题的处理器函数或者唯一 Id 值\n */\nconst off = (topic, token) => {\n if (!has(topic)) {\n return false\n }\n\n if (token) {\n _removeSubscriberByToken(token)\n } else {\n _removeSubscriber(topic)\n }\n}\n\nexport default off\n","import _subscribers from './_subscribers'\nimport _removeSubscriber from './_removeSubscriber'\n\n/**\n * 通过订阅者 token 值删除订阅者信息\n * ========================================================================\n * @method _removeSubscriberByToken\n * @param {String} token - 订阅者 token 字符串\n * @returns {boolean}\n * @private\n */\nconst _removeSubscriberByToken = (token) => {\n const keys = Object.keys(_subscribers)\n let index = -1\n\n if (!token || keys.length < 1) {\n return false\n }\n\n keys.forEach((subject) => {\n const subscriber = _subscribers[subject]\n let topic\n\n subscriber.forEach((execution, j) => {\n if (execution.callback === token || execution.token === token) {\n topic = execution.topic\n subscriber.splice(index, j)\n }\n })\n\n /* istanbul ignore else */\n if (subscriber.length < 1) {\n _removeSubscriber(topic)\n }\n })\n}\n\nexport default _removeSubscriberByToken\n","import Base from './base'\nimport Anchors from './anchors'\nimport Drawer from './drawer'\nimport Chapters from './chapters'\nimport Toolbar from './toolbar'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport subscribe from './utils/observer/on'\nimport unsubscribe from './utils/observer/off'\n\nclass Outline extends Base {\n constructor(options) {\n super()\n\n this.attrs = Outline.DEFAULTS\n this.anchors = null\n this.drawer = null\n this.chapters = null\n this.toolbar = null\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n this.attr(options).render().addListeners()\n return this\n }\n\n getChapters(isTreeStructured = false) {\n return this.anchors.getChapters(isTreeStructured)\n }\n\n count() {\n return this.anchors.count()\n }\n\n render() {\n const scrollElement = this.attr('scrollElement')\n const $scrollElement = document.querySelector(scrollElement) || document.getElementById(scrollElement)\n\n this._renderAnchors()._renderChapters()._renderToolbar()\n\n if ($scrollElement) {\n this.onToolbarUpdate({\n top: $scrollElement.scrollTop,\n min: 0,\n max: $scrollElement.scrollHeight\n })\n }\n\n return this\n }\n\n _renderAnchors() {\n const articleElement = this.attr('articleElement')\n const selector = this.attr('selector')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n\n this.anchors = new Anchors({\n articleElement,\n stickyHeight,\n scrollElement,\n selector,\n showCode,\n anchorURL,\n afterScroll\n })\n\n return this\n }\n\n _renderChapters() {\n const title = this.attr('title')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const customClass = this.attr('customClass')\n const showCode = this.attr('showCode')\n const position = this.attr('position')\n const placement = this.attr('placement')\n const afterSticky = this.attr('afterSticky')\n const afterToggle = this.attr('afterToggle')\n const afterScroll = this.attr('afterScroll')\n const count = this.count()\n let parentElement = this.attr('parentElement')\n let CHAPTERS_OPTIONS\n\n if (count < 1) {\n return this\n }\n\n CHAPTERS_OPTIONS = {\n scrollElement,\n showCode,\n position,\n title,\n stickyHeight,\n chapters: this.getChapters(),\n afterSticky,\n afterToggle,\n afterScroll\n }\n\n if (position === 'relative') {\n this.drawer = new Drawer({\n placement,\n title,\n size: 'tiny',\n hasOffset: true,\n hasPadding: false,\n customClass,\n afterClosed: () => {\n const toolbar = this.toolbar\n toolbar.toggle()\n }\n })\n parentElement = this.drawer.$main\n } else {\n CHAPTERS_OPTIONS.customClass = customClass\n }\n\n CHAPTERS_OPTIONS.parentElement = parentElement\n this.chapters = new Chapters(CHAPTERS_OPTIONS)\n\n return this\n }\n\n _renderToolbar() {\n const placement = this.attr('placement')\n const homepage = this.attr('homepage')\n const git = this.attr('git')\n const tags = this.attr('tags')\n const issues = this.attr('issues')\n const tools = this.attr('tools')\n const count = this.count()\n const UP = {\n name: 'up',\n icon: 'up',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:up'\n }\n }\n const HOME = {\n name: 'homepage',\n icon: 'homepage',\n size: 20,\n link: homepage\n }\n const GIT = {\n name: 'github',\n icon: 'github',\n size: 20,\n link: git\n }\n const TAGS = {\n name: 'tags',\n icon: 'tags',\n size: 20,\n link: tags\n }\n const ISSUES = {\n name: 'issues',\n icon: 'issues',\n size: 20,\n link: issues\n }\n const MENU = {\n name: 'menu',\n icon: 'menu',\n size: 18,\n action: {\n type: 'click',\n handler: 'toolbar:action:toggle'\n }\n }\n const DOWN = {\n name: 'down',\n icon: 'down',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:down'\n }\n }\n const buttons = []\n\n buttons.push(UP)\n if (homepage) {\n buttons.push(HOME)\n }\n if (count > 0) {\n buttons.push(MENU)\n }\n if (git) {\n buttons.push(GIT)\n }\n if (tags) {\n buttons.push(TAGS)\n }\n if (issues) {\n buttons.push(ISSUES)\n }\n if (tools?.length > 0) {\n buttons.push(...tools)\n }\n buttons.push(DOWN)\n this.buttons = [...buttons]\n\n this.toolbar = new Toolbar({\n placement,\n buttons: buttons\n })\n\n return this\n }\n\n addButton(button) {\n const toolbar = this.toolbar\n const buttons = this.buttons\n buttons.splice(-1, 0, button)\n toolbar.attr({\n buttons\n })\n toolbar.refresh()\n return this\n }\n\n removeButton(name) {\n this.toolbar.remove(name)\n return this\n }\n\n toTop() {\n const afterScroll = this.attr('afterScroll')\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const afterTop = () => {\n toolbar.hide('up')\n toolbar.show('down')\n\n if (count > 0) {\n chapters.highlight(0)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'up')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(0, afterTop)\n\n return this\n }\n\n toBottom() {\n const afterScroll = this.attr('afterScroll')\n const $scrollElement = _getScrollElement(this.attr('scrollElement'))\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const top = Math.floor(\n $scrollElement.scrollHeight - $scrollElement.clientHeight\n )\n const afterDown = () => {\n toolbar.hide('down')\n toolbar.show('up')\n\n if (count > 0) {\n chapters.highlight(count - 1)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'bottom')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(top, afterDown)\n\n return this\n }\n\n scrollTo(top, afterScroll) {\n const scrollElement = this.attr('scrollElement')\n scrollTo(scrollElement, top, afterScroll)\n return this\n }\n\n toggle() {\n const position = this.attr('position')\n const toolbar = this.toolbar\n const drawer = this.drawer\n const chapters = this.chapters\n const count = this.count()\n\n if (count < 1) {\n return this\n }\n\n if (position !== 'relative') {\n chapters.toggle()\n toolbar.highlight('menu')\n } else {\n toolbar.toggle()\n\n later(() => {\n if (chapters.isInside()) {\n chapters.toggle()\n } else {\n drawer.toggle()\n }\n })\n }\n\n return this\n }\n\n destroy() {\n let anchors = this.anchors\n let chapters = this.chapters\n let drawer = this.drawer\n let toolbar = this.toolbar\n let isOutside = false\n const count = this.count()\n\n this.removeListeners()\n\n if (count > 0) {\n isOutside = chapters.isOutside()\n\n chapters.destroy()\n chapters = null\n\n if (isOutside) {\n drawer.destroy()\n drawer = null\n }\n }\n\n toolbar.destroy()\n toolbar = null\n\n anchors.destroy()\n anchors = null\n\n this.attr(Outline.DEFAULTS)\n\n return this\n }\n\n onToggle() {\n this.toggle()\n return this\n }\n\n onScrollTop() {\n this.toTop()\n return this\n }\n\n onScrollBottom() {\n this.toBottom()\n return this\n }\n\n onToolbarUpdate({ top, min, max }) {\n const toolbar = this.toolbar\n const current = Math.ceil(top)\n\n if (current <= min) {\n toolbar.hide('up')\n toolbar.show('down')\n } else if (current >= max) {\n toolbar.hide('down')\n toolbar.show('up')\n } else if (current > min && current < max) {\n toolbar.show('up')\n toolbar.show('down')\n }\n\n return this\n }\n\n addListeners() {\n subscribe('toolbar:update', this.onToolbarUpdate, this)\n subscribe('toolbar:action:up', this.onScrollTop, this)\n subscribe('toolbar:action:toggle', this.onToggle, this)\n subscribe('toolbar:action:down', this.onScrollBottom, this)\n return this\n }\n\n removeListeners() {\n unsubscribe('toolbar:update')\n unsubscribe('toolbar:action:up')\n unsubscribe('toolbar:action:toggle')\n unsubscribe('toolbar:action:down')\n return this\n }\n}\n\nOutline.DEFAULTS = {\n articleElement: '#article',\n selector: 'h2,h3,h4,h5,h6',\n title: '目录',\n scrollElement: 'html,body',\n position: 'relative',\n parentElement: '#aside',\n placement: 'rtl',\n showCode: true,\n anchorURL: '',\n stickyHeight: 0,\n homepage: '',\n git: '',\n tags: '',\n issues: '',\n tools: [],\n customClass: '',\n afterSticky: null,\n afterToggle: null,\n afterScroll: null\n}\n\nif (window.jQuery) {\n // 将 Outline 扩展为一个 jquery 插件\n // eslint-disable-next-line no-undef\n jQuery.extend(jQuery.fn, {\n outline: function (options) {\n // eslint-disable-next-line no-undef\n let $article = jQuery(this)\n\n return new Outline(\n // eslint-disable-next-line no-undef\n jQuery.extend({}, options, {\n articleElement: $article\n })\n )\n }\n })\n}\n\nexport default Outline\n"],"names":["isString","str","hasOwn","obj","prop","hasOwnProperty","Object","prototype","call","toString","val","apply","isFunction","isObject","o","Base","constructor","options","this","attrs","initialize","attr","render","addListeners","value","origin","source","keys","forEach","arguments","length","destroy","removeListeners","reload","isElement","nodeName","tagName","nodeType","later","fn","delay","setTimeout","easeInQuad","x","_getScrollElement","scrollElement","$rootElements","$scrollElement","document","querySelector","querySelectorAll","scrollTop","scrollTo","top","afterStop","step","distance","MAX_HEIGHT","scrollHeight","MAX_TOP","stop","play","requestAnimationFrame","offsetTop","el","offsetParent","matches","selector","sel","replace","msMatchesSelector","getParentOrHost","host","parentNode","CAPTURE_EVENTS","_off","type","capture","indexOf","_delegateListener","listeners","_listeners","index","listener","i","handler","splice","_delete","removeEventListener","purgeElement","recurse","$element","$children","childNodes","filter","getListeners","$child","off","on","data","context","once","evt","target","getTarget","delegateTarget","ctx","includeCTX","startsWith","closest","overrideContext","push","addEventListener","stopPropagation","preventDefault","_subscribers","_hasDirectSubscribersFor","topic","has","isDirect","found","position","lastIndexOf","substring","_hasSubscribers","emit","async","execute","subscriber","message","callback","deliver","isArray","Array","SYMBOLS","getSymbols","name","iconSet","patternName","patternSet","find","symbol","fullName","exec","iconName","getSymbol","paint","$body","body","$icons","symbols","add","innerHTML","join","createElement","insertBefore","firstChild","trim","isDOM","isHTMLCollection","fragment","isTextNode","setAttribute","toLowerCase","style","cssText","className","children","$fragment","createDocumentFragment","$el","isValidChild","child","append","createTextNode","appendChild","every","isSVG","pattern","RegExp","test","icon","size","color","width","height","defaultRules","cssRules","$icon","$svg","binds","svg","hasClass","allClass","classList","contains","removeClass","remove","_resetHeading","$heading","hasAnchor","isAtStart","CLS_HEADING","text","$anchor","removeAttribute","removeChild","getChapters","headings","showCode","previous","level","chapters","heading","headingLevel","current","parseInt","pid","differ","_getChapterParentIdByDiffer","id","rel","groups","group","JSON","stringify","cb","code","String","c","b","_getChaptersWithCode","Anchors","super","DEFAULTS","$articleElement","$headings","created","articleElement","isTreeStructured","list","nodeKey","parentKey","map","roots","item","node","toTree","count","mounted","anchorURL","chapterCode","headingId","href","_updateHeading","after","beforeDestroy","afterDestroy","onAnchorTrigger","afterScroll","stickyHeight","max","clientHeight","publish","min","addClass","setProperty","documentElement","zIndex","idx","Drawer","title","closed","$modal","$header","$title","$close","$main","$footer","$overlay","setTitle","isClosed","placement","hasClose","hasOverlay","hasOffset","hasPadding","autoHeight","customClass","open","opened","close","toggle","afterToggle","onClose","afterClosed","afterOpened","at","getStyle","ruleName","getComputedStyle","Chapters","$list","$placeholder","$parentElement","active","offsetWidth","$active","scrollTimer","resizeTimer","playing","Observer","parentElement","$parent","isSticky","isFixed","isInside","isOutside","_paintEdge","contents","calculateStickyHeight","byId","chapter","$text","$link","$code","$li","$ul","_paintChapters","positionPlaceholder","sticky","onObserver","mainPaddingTop","mainBorderTop","placeholderPaddingTop","placeholderMarginTop","placeholderBorderTop","offsetHeight","highlight","HIGHLIGHT","getAttribute","afterSticky","FIXED","isStickying","Math","window","innerHeight","show","FOLDED","HIDDEN","hide","clearTimeout","timer","props","root","rootMargin","IntersectionObserver","entries","entry","intersectionRatio","$root","section","observe","intersection","onSelect","split","onScroll","onResize","unobserve","_createButton","button","rounded","link","$button","disabled","DISABLED","Toolbar","buttons","isDisabled","option","ACTIVE","$buttons","disable","action","switch","enabled","enable","refresh","command","afterDisabled","afterEnabled","guid","uuid","prefix","token","subject","_removeSubscriber","execution","j","_removeSubscriberByToken","Outline","anchors","drawer","toolbar","getElementById","_renderAnchors","_renderChapters","_renderToolbar","onToolbarUpdate","CHAPTERS_OPTIONS","homepage","git","tags","issues","tools","HOME","GIT","TAGS","ISSUES","MENU","addButton","removeButton","toTop","toBottom","floor","onToggle","onScrollTop","onScrollBottom","ceil","subscribe","unsubscribe","jQuery","extend","outline","$article"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"outline.min.js","sources":["../../src/utils/types/isString.js","../../src/utils/lang/hasOwn.js","../../src/utils/lang/toString.js","../../src/utils/types/isFunction.js","../../src/utils/types/isObject.js","../../src/base.js","../../src/utils/lang/extend.js","../../src/utils/types/isElement.js","../../src/utils/lang/later.js","../../src/utils/lang/easeInQuad.js","../../src/utils/dom/_getScrollElement.js","../../src/utils/dom/scrollTo.js","../../src/utils/dom/offsetTop.js","../../src/utils/dom/matches.js","../../src/utils/dom/getParentOrHost.js","../../src/utils/event/enum.js","../../src/utils/event/_off.js","../../src/utils/event/_delete.js","../../src/utils/event/purgeElement.js","../../src/utils/event/getListeners.js","../../src/utils/event/off.js","../../src/utils/event/on.js","../../src/utils/event/getTarget.js","../../src/utils/dom/resolveTextNode.js","../../src/utils/dom/closest.js","../../src/utils/event/stop.js","../../src/utils/observer/_subscribers.js","../../src/utils/observer/_hasDirectSubscribersFor.js","../../src/utils/observer/has.js","../../src/utils/observer/_hasSubscribers.js","../../src/utils/observer/emit.js","../../src/utils/types/isTypedArray.js","../../src/utils/types/isArray.js","../../src/utils/icons/symbols.js","../../src/utils/icons/defaults.js","../../src/utils/icons/getSymbols.js","../../src/utils/icons/getSymbol.js","../../src/utils/icons/paint.js","../../src/utils/icons/add.js","../../src/utils/lang/trim.js","../../src/utils/types/isDOM.js","../../src/utils/types/isHTMLCollection.js","../../src/utils/types/isFragment.js","../../src/utils/types/isTextNode.js","../../src/utils/dom/setAttribute.js","../../src/utils/dom/createElement.js","../../src/utils/types/isSVG.js","../../src/utils/icons/icon.js","../../src/utils/icons/createElement.js","../../src/utils/dom/hasClass.js","../../src/utils/dom/removeClass.js","../../src/_resetHeading.js","../../src/utils/types/isEmpty.js","../../src/getChapters.js","../../src/utils/lang/stripTags.js","../../src/_getChapterParentIdByDiffer.js","../../src/_getChaptersWithCode.js","../../src/anchors.js","../../src/utils/lang/toTree.js","../../src/_updateHeading.js","../../src/utils/dom/addClass.js","../../src/utils/dom/setProperty.js","../../src/zIndex.js","../../src/drawer.js","../../src/utils/event/at.js","../../src/utils/dom/getStyle.js","../../src/chapters.js","../../src/_paintChapters.js","../../src/utils/dom/intersection.js","../../src/_createButton.js","../../src/toolbar.js","../../src/utils/lang/guid.js","../../src/utils/observer/on.js","../../src/utils/observer/_removeSubscriber.js","../../src/utils/observer/off.js","../../src/utils/observer/_removeSubscriberByToken.js","../../src/outline.js","../../src/print.js"],"sourcesContent":["/**\n * 检测数据是否为 String 类型\n * ========================================================================\n * @method isArray\n * @param {*} str\n * @returns {boolean}\n */\nconst isString = (str) => {\n return typeof str === 'string'\n}\n\nexport default isString\n","/**\n * 检测对象自身属性中是否具有指定的属性。\n * ========================================================================\n * @method hasOwn\n * @param {Object} obj - (必须)检测的目标对象\n * @param {String} prop - (必须)属性名\n * @returns {Boolean}\n */\nconst hasOwn = (obj, prop) => {\n const hasOwnProperty = Object.prototype.hasOwnProperty\n return obj && hasOwnProperty.call(obj, prop)\n}\n\nexport default hasOwn\n","/**\n * Object 对象原型上的 toString 方法\n * ========================================================================\n * @method toString\n * @param {*} val\n * @returns {string}\n */\nconst toString = (val) => {\n return Object.prototype.toString.apply(val)\n}\n\nexport default toString\n","import toString from '../lang/toString'\n\n/**\n * 检测测试数据是否为 Function 类型\n * ========================================================================\n * @method isFunction\n * @param {*} val - (必须)待检测的数据\n * @returns {boolean} 'val' 是 Function 类型返回 true,否则返回 false\n */\nconst isFunction = (val) => {\n return typeof val === 'function' || toString(val) === '[object Function]'\n}\n\nexport default isFunction\n","import toString from '../lang/toString'\nimport isFunction from '../types/isFunction'\n\n/**\n * 检测数据是否为 Object 类型\n * ========================================================================\n * @method isObject\n * @param {*} o\n * @returns {boolean}\n */\nconst isObject = (o) => {\n return (\n (toString(o) === '[object Object]' ||\n typeof o === 'object' ||\n isFunction(o)) &&\n o !== null\n )\n}\n\nexport default isObject\n","import isString from './utils/types/isString'\r\nimport hasOwn from './utils/lang/hasOwn'\r\nimport isObject from './utils/types/isObject'\r\nimport extend from './utils/lang/extend'\r\n\r\nclass Base {\r\n constructor(options) {\r\n this.attrs = {}\r\n\r\n if (options) {\r\n this.initialize(options)\r\n }\r\n }\r\n\r\n initialize(options) {\r\n this.attr(options).render().addListeners()\r\n return this\r\n }\r\n\r\n attr(prop, value) {\r\n const attrs = this.attrs\r\n\r\n if (isString(prop)) {\r\n // 只能扩展 attrs 中已有的属性\r\n if (value && hasOwn(attrs, prop)) {\r\n // 更新单个配置信息\r\n attrs[prop] = value\r\n return this\r\n }\r\n\r\n // 只传递 prop 参数,则返回对应的属性值\r\n return attrs[prop]\r\n } else if (isObject(prop)) {\r\n // 批量更新配置信息\r\n extend(attrs, prop)\r\n\r\n return this\r\n } else if (arguments.length === 0) {\r\n // 不传递参数,直接返回整个\r\n return attrs\r\n }\r\n\r\n return this\r\n }\r\n\r\n render() {\r\n return this\r\n }\r\n\r\n destroy() {\r\n this.removeListeners()\r\n return this\r\n }\r\n\r\n reload(options) {\r\n this.destroy().initialize(this.attr(options))\r\n return this\r\n }\r\n\r\n addListeners() {\r\n return this\r\n }\r\n\r\n removeListeners() {\r\n return this\r\n }\r\n}\r\n\r\nexport default Base\r\n","import hasOwn from './hasOwn'\n\n/**\n * 扩展对象\n * ========================================================================\n * @method extend\n * @param {Object} origin\n * @param {Object} source\n */\nconst extend = (origin, source) => {\n const keys = Object.keys(source)\n\n keys.forEach((prop) => {\n if (hasOwn(source, prop)) {\n origin[prop] = source[prop]\n }\n })\n}\n\nexport default extend\n","import isObject from './isObject'\n\n/**\n * 检测数据是否为 HTMLElement DOM 节点\n * ========================================================================\n * @method isElement\n * @param {*} o\n * @returns {boolean}\n */\nconst isElement = (o) => {\n return !!(isObject(o) && o.nodeName && o.tagName && o.nodeType === 1)\n}\n\nexport default isElement\n","import isFunction from '../types/isFunction'\n\n/**\n * later - 延迟执行方法\n * ========================================================================\n * @method later\n * @param {Function} fn\n * @param {Number} [delay]\n * @returns {number|boolean}\n */\nconst later = (fn, delay = 300) => {\n if (!isFunction(fn)) {\n return false\n }\n\n return setTimeout(() => {\n fn()\n }, delay)\n}\n\nexport default later\n","/**\n * 返回给定值的平方值\n * ========================================================================\n * @method easeInQuad\n * @param {Number} x\n * @returns {number}\n */\nconst easeInQuad = (x) => {\n return x * x\n}\n\nexport default easeInQuad\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\n\n/**\n * 通过给的 scrollElement 参数,获取滚动 DOM 元素\n * ========================================================================\n * @method _getScrollElement\n * @param {String|HTMLElement} scrollElement\n * @returns {Element}\n * @private\n */\nconst _getScrollElement = (scrollElement = null) => {\n let $rootElements\n let $scrollElement\n\n if (!scrollElement) {\n $rootElements = document.querySelectorAll('html,body')\n $scrollElement =\n $rootElements[0].scrollTop - $rootElements[1].scrollTop >= 0\n ? $rootElements[0]\n : $rootElements[1]\n } else {\n if (isString(scrollElement)) {\n $scrollElement = document.querySelector(scrollElement)\n } else if (isElement(scrollElement)) {\n $scrollElement = scrollElement\n }\n }\n\n return $scrollElement\n}\n\nexport default _getScrollElement\n","import easeInQuad from '../lang/easeInQuad'\nimport isFunction from '../types/isFunction'\nimport _getScrollElement from './_getScrollElement'\n\n/**\n * 指定 rootElement DOM 节点滚动到指定 top 位置\n * ========================================================================\n * @method scrollTo\n * @param {HTMLElement|Object} [scrollElement] - (必须)要滚动的 DOM 节点\n * @param {Number} top - (必须)滚动的 scrollTop 数值\n * @param {Function} [afterStop] - (可选)滚动完成的回调函数\n */\nconst scrollTo = (scrollElement, top, afterStop) => {\n const $scrollElement = _getScrollElement(scrollElement)\n let scrollTop = $scrollElement.scrollTop\n let step = 0\n const distance = top - scrollTop\n const MAX_HEIGHT = $scrollElement.scrollHeight\n const MAX_TOP = top - MAX_HEIGHT <= 0 ? top : MAX_HEIGHT\n const stop = (top) => {\n if (isFunction(afterStop)) {\n afterStop(top)\n }\n\n return false\n }\n const play = () => {\n step += 1\n\n // 向上滚动\n if (distance < 0) {\n scrollTop -= easeInQuad(step)\n $scrollElement.scrollTop = scrollTop\n\n if (scrollTop <= top) {\n $scrollElement.scrollTop = top\n return stop(top)\n }\n } else {\n scrollTop += easeInQuad(step)\n $scrollElement.scrollTop = scrollTop\n\n if (scrollTop >= MAX_TOP) {\n $scrollElement.scrollTop = MAX_TOP\n return stop(MAX_TOP)\n }\n }\n\n requestAnimationFrame(play)\n }\n\n requestAnimationFrame(play)\n}\n\nexport default scrollTo\n","/**\n * 获取 DOM 节点相对于窗口的 left (纵坐标)值\n * ========================================================================\n * @method offsetTop\n * @param {HTMLElement} el - DOM 节点\n * @returns {Number}\n */\nconst offsetTop = (el) => {\n let top = el.offsetTop\n\n if (el.offsetParent !== null) {\n top += offsetTop(el.offsetParent)\n }\n\n return top\n}\n\nexport default offsetTop\n","/**\n * 获取 options 节点下匹配 selector 选择器的 DOM 节点\n * ========================================================================\n * Element.matches() 方法可以用来判断 DOM 元素是否与给定的选择器匹配,事件代理判断是\n * 否触发绑定的代理事件回调函数,关键就是使用 Element.matches() 辨别当前事件触发的目\n * 标 DOM 元素是否为事件代理所期望触发的目标。\n * ========================================================================\n * @method matches\n * @see https://developer.mozilla.org/en-US/docs/web/api/element/matches\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)匹配 DOM 元素的选择器\n * @returns {Boolean}\n */\nconst matches = (el, selector = '') => {\n const sel = selector.replace(/^>/i, '')\n\n if (!selector || !sel || !el) {\n return false\n }\n\n /* istanbul ignore else */\n if (el.matches) {\n return el.matches(sel)\n } else if (el.msMatchesSelector) {\n return el.msMatchesSelector(sel)\n } else {\n return false\n }\n}\n\nexport default matches\n","/**\n * 获取 DOM 元素的父节点\n * ========================================================================\n * @method getParentOrHost\n * @param {*|HTMLElement} el - (必须)要获取父节点的 DOM 元素\n * @returns {*|HTMLElement}\n */\nconst getParentOrHost = (el) => {\n return el.host && el !== document && el.host.nodeType\n ? el.host\n : el.parentNode\n}\n\nexport default getParentOrHost\n","export const CAPTURE_EVENTS = [\n 'focusout',\n 'blur',\n 'focusin',\n 'focus',\n 'load',\n 'unload',\n 'mouseenter',\n 'mouseleave'\n]\n","import { CAPTURE_EVENTS } from './enum'\nimport _delete from './_delete'\n\n/**\n * (私有方法)取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method _off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} fn - (必须)事件处理器回调函数\n * @private\n */\nconst _off = (el, type, fn) => {\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n /* istanbul ignore else */\n if (fn._delegateListener) {\n fn = fn._delegateListener\n delete fn._delegateListener\n }\n\n // 移除缓存的 _listeners 数据\n _delete(el, type, fn)\n\n el.removeEventListener(type, fn, capture)\n}\n\nexport default _off\n","/**\n * 删除 DOM 元素缓存的 _listeners 数据\n * ========================================================================\n * @method _delete\n * @param {HTMLElement} el - 要删除 listener 的 DOM 元素\n * @param {String} type - 事件类型(名称)\n * @param {Function} [fn] - 事件处理器回调函数\n */\nconst _delete = function (el, type, fn) {\n const listeners = el._listeners\n let index = -1\n\n if (listeners.length < 1) {\n return false\n }\n\n // 移除缓存的 _listeners 数据\n listeners.forEach((listener, i) => {\n const handler = listener.fn\n\n if (type === listener.type) {\n index = i\n\n if (handler === fn) {\n index = i\n }\n }\n })\n\n /* istanbul ignore else */\n if (index > -1) {\n listeners.splice(index, 1)\n }\n}\n\nexport default _delete\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\nimport getListeners from './getListeners'\nimport _off from './_off'\n\n/**\n * 销毁(type 类型的)代理事件绑定\n * ========================================================================\n * 1. 设置了事件类型 type,则销毁指定类型的事件绑定,否则清除所有代理事件绑定\n * 2. recurse 设置为 true,递归销毁子节点全部事件绑定\n * ========================================================================\n * @method purgeElement\n * @param {HTMLElement|String} el - (必须)DOM 元素或者其选择器\n * @param {String|Boolean} type - (必须)事件类型\n * @param {Boolean} [recurse] - (可选)是否递归销毁子节点所有事件绑定\n */\nconst purgeElement = function (el, type, recurse = false) {\n const $element = isString(el) ? document.querySelector(el) : el\n const $children = $element.childNodes\n const listeners = getListeners($element, type)\n\n listeners.forEach((listener) => {\n _off($element, listener.type, listener.fn)\n })\n\n if (\n (recurse || type === true || arguments.length === 1) &&\n $element &&\n $children\n ) {\n $children.forEach(($child) => {\n if (isElement($child)) {\n purgeElement($child, type, recurse)\n }\n })\n }\n}\n\nexport default purgeElement\n","import isString from '../types/isString'\n\n/**\n * 获取 DOM 元素(type 事件类型)事件绑定信息\n * ========================================================================\n * 如果设置了事件类型 type, 则返回指定类型的事件绑定信息,否则返回所有事件绑定信息\n * ========================================================================\n * @methods getListeners\n * @param {HTMLElement} el - (必须)要获取事件绑定信息的 DOM 元素\n * @param {String} [type] - (可选)事件类型\n * @returns {Array} - 已绑定的事件信息\n */\nconst getListeners = (el, type) => {\n let listeners = el._listeners || []\n\n if (isString(type) && type) {\n listeners = listeners.filter((listener) => {\n return listener.type === type\n })\n }\n\n return listeners\n}\n\nexport default getListeners\n","import purgeElement from './purgeElement'\nimport isFunction from '../types/isFunction'\nimport _off from './_off'\n\n/**\n * 取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} [fn] - (可选)事件处理器回调函数\n */\nconst off = (el, type, fn) => {\n // 如果不设置 fn 参数,默认清除 el 元素上绑定的所有事件处理器\n if (!isFunction(fn)) {\n return purgeElement(el, type)\n }\n\n _off(el, type, fn)\n}\n\nexport default off\n","import closest from '../dom/closest'\nimport off from './off'\nimport getTarget from './getTarget'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定代理事件\n * ========================================================================\n * @method on\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String} selector - (必须)事件代理目标 DOM 元素的选择器\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (可选) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst on = (el, selector, type, fn, data, context, once = false) => {\n // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n const listener = function (evt) {\n const target = getTarget(evt)\n // 通过 Element.matches 方法获得点击的目标元素\n const delegateTarget = closest(target, selector, el)\n let overrideContext = context || el\n\n evt.delegateTarget = delegateTarget\n\n // 当设置为 true 时,则事件处理器回调函数的\n // this 上下文指向为 data 对象\n if (context === true) {\n overrideContext = data\n }\n\n /* istanbul ignore else */\n if (delegateTarget) {\n // 仅触发一次\n /* istanbul ignore else */\n if (once === true) {\n off(el, type, listener)\n }\n\n fn.call(overrideContext, evt, data)\n }\n }\n\n if (!el._listeners) {\n el._listeners = []\n }\n\n // 缓存 options 元素绑定的事件处理器\n el._listeners.push({\n el,\n selector,\n type,\n fn: listener,\n data,\n context,\n capture\n })\n\n // 缓存包装后的事件处理器\n fn._delegateListener = listener\n\n el.addEventListener(type, listener, capture)\n}\n\nexport default on\n","import resolveTextNode from '../dom/resolveTextNode'\n\n/**\n * 返回触发事件的 target DOM 元素\n * ========================================================================\n * @method getTarget\n * @param {Event} evt - Event 对象\n * @return {HTMLElement} - Event 对象的 target DOM 元素\n */\nconst getTarget = function (evt) {\n const target = evt.target\n\n return resolveTextNode(target)\n}\n\nexport default getTarget\n","/**\n * 在某些情况下,某些浏览器(例如:Safari 浏览器)会返回实际的目标元素内部的文本节点。\n * resolveTextNode() 方法则会返回实际的目标节点。\n * ========================================================================\n * @method resolveTextNode\n * @param {HTMLElement|Text} el - 要解析的节点\n * @return {*|HTMLElement} - 实际的目标 DOM 节点\n */\nconst resolveTextNode = function (el) {\n if (el && el.nodeType === 3) {\n return el.parentNode\n }\n\n return el\n}\n\nexport default resolveTextNode\n","import matches from './matches'\nimport getParentOrHost from './getParentOrHost'\n\n/**\n * 获取 options 元素父元素最近的包含 selector 选择器的元素\n * ========================================================================\n * @method closest\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)DOM 元素的选择其\n * @param {HTMLElement} [ctx] - (必须)比对的 DOM 元素\n * @param {Boolean} [includeCTX] - (必须)是否包含 context DOM 元素\n * @returns {null|HTMLElement} - 返回最接近的 DOM 元素\n */\nconst closest = (el, selector, ctx, includeCTX) => {\n const context = ctx || document\n\n if (!el) {\n return null\n }\n\n do {\n /* istanbul ignore else */\n if (\n (selector != null &&\n (selector.startsWith('>')\n ? el.parentNode === context && matches(el, selector)\n : matches(el, selector))) ||\n (includeCTX && el === context)\n ) {\n return el\n }\n\n /* istanbul ignore else */\n if (el === context) {\n break\n }\n\n /* jshint boss:true */\n } while ((el = getParentOrHost(el)))\n}\n\nexport default closest\n","/**\n * 停止事件(阻止默认行为和阻止事件的捕获或冒泡)\n * ========================================================================\n * @method stop\n * @param {Event} evt - 事件对象\n *\n * @example\n *
\n * Service\n * Help\n *
\n *\n * const $nav = document.querySelector('#nav')\n * const $service = document.querySelector('.anchor')\n *\n * on($nav, 'click', function(evt) {\n * console.log('你点击了导航栏')\n * })\n *\n * on($anchor, 'click', function(evt) {\n * console.log('tagName', this.tagName)\n *\n * // 工作台输出:'a'\n * // 不会触发事件冒泡,输出:'你点击了导航栏'\n * // 也不会切换到 href 属性的页面,阻止了点击链接的默认行为\n * stopEvent(evt)\n * })\n */\nconst stop = function (evt) {\n evt.stopPropagation()\n evt.preventDefault()\n}\n\nexport default stop\n","/**\n * 存储订阅者(主题和处理器的)私有对象\n * ========================================================================\n * @type {{}}\n * @private\n */\nconst _subscribers = {}\n\nexport default _subscribers\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 判断是否存在与给定 topic 完全匹配的订阅者信息\n * ========================================================================\n * @method _hasDirectSubscribersFor\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasDirectSubscribersFor = (topic) => {\n return hasOwn(_subscribers, topic) && _subscribers[topic].length > 0\n}\n\nexport default _hasDirectSubscribersFor\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\nimport _hasSubscribers from './_hasSubscribers'\n\n/**\n * 判断是否存在包含 topic 指定的订阅者信息\n * ========================================================================\n * @method has\n * @param {String} topic - (必须)主题名称\n * @param {Boolean} [isDirect] - (可选)是否为直接的主题,默认值:true\n * @returns {Boolean}\n */\nconst has = (topic, isDirect = true) => {\n return isDirect ? _hasDirectSubscribersFor(topic) : _hasSubscribers(topic)\n}\n\nexport default has\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * 判断是否存在包含给定 topic 相关的订阅者信息\n * ========================================================================\n * @method _hasSubscribers\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasSubscribers = (topic) => {\n let found = _hasDirectSubscribersFor(topic)\n let position = topic.lastIndexOf('.')\n\n while (!found && position !== -1) {\n topic = topic.substring(0, position)\n position = topic.lastIndexOf('.')\n found = _hasDirectSubscribersFor(topic)\n }\n\n return found\n}\n\nexport default _hasSubscribers\n","import isTypedArray from '../types/isTypedArray'\nimport _subscribers from './_subscribers'\nimport has from './has'\nimport _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * (异步)发布订阅主题信息\n * ========================================================================\n * 主题默认是异步发布的。确保在消费者处理主题时,主题的发起者不会被阻止。\n * ========================================================================\n * @method emit\n * @param {String} topic - (必须)主题名称\n * @param {Object} data - (必须)数据对象\n * @param {Boolean} async - (可选) 是否异步发布\n */\nconst emit = (topic, data, async = true) => {\n const execute = (topic) => {\n if (!_hasDirectSubscribersFor(topic)) {\n return false\n }\n\n _subscribers[topic].forEach((subscriber) => {\n // 针对 mqtt 消息服务返回的 Uint8Array 类似的 typed arrays 格式的数据\n // 采用 toString() 方法转化为普通(JSON)字符串\n const message = isTypedArray(data) ? data.toString() : data\n\n subscriber.callback.call(subscriber.context || subscriber, message)\n })\n }\n const deliver = () => {\n let subscriber = topic\n let position = topic.lastIndexOf('.')\n\n while (position !== -1) {\n subscriber = subscriber.substring(0, position)\n position = subscriber.lastIndexOf('.')\n\n execute(subscriber)\n }\n\n // 执行 topic 对应的处理器\n execute(topic)\n // 执行特殊 topic:'*'(监听全部消息的发布)\n execute('*')\n }\n\n if (!has(topic)) {\n return false\n }\n\n if (async) {\n setTimeout(deliver, 10)\n } else {\n deliver()\n }\n}\n\nexport default emit\n","import toString from '../lang/toString'\n/**\n * 判断检测数据是否为 Typed Arrays 类型的数据\n * ========================================================================\n * @param {*} val\n * @returns {boolean}\n */\nconst isTypedArray = (val) => {\n const TYPES = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]',\n '[object BigInt64Array]',\n '[object BigUint64Array]'\n ]\n\n return TYPES.indexOf(toString(val)) > -1\n}\n\nexport default isTypedArray\n","import toString from '../lang/toString'\n\n/**\n * 检测数据是否为 Array 类型\n * ========================================================================\n * @method isArray\n * @param {*} o\n * @returns {boolean}\n */\nconst isArray = (o) => {\n if (Array.isArray) {\n return Array.isArray(o)\n } else {\n return toString(o) === '[object Array]'\n }\n}\n\nexport default isArray\n","import DEFAULTS from './defaults'\n\nconst SYMBOLS = [...DEFAULTS]\n\nexport default SYMBOLS\n","const DEFAULTS = [\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n ''\n]\n\nexport default DEFAULTS\n","import isString from '../types/isString'\nimport getSymbol from './getSymbol'\nimport SYMBOLS from './symbols'\n\n/**\n *\n * @method getSymbols\n * @param {String} [name]\n * @param {String} [iconSet]\n * @returns {string[]|*}\n */\nconst getSymbols = (name, iconSet = 'icon') => {\n if (isString(name)) {\n return getSymbol(name, iconSet)\n }\n\n return [...SYMBOLS]\n}\n\nexport default getSymbols\n","import SYMBOLS from './symbols'\n\n/**\n * @method getSymbol\n * @param {String} name\n * @param {String} [iconSet]\n * @returns {String}\n */\nconst getSymbol = (name, iconSet = 'icon') => {\n const patternName = /id=\"(.*?)\"/\n const patternSet = /^(\\w+)-/\n const symbols = SYMBOLS\n\n return symbols.find((symbol) => {\n const names = patternName.exec(symbol)\n const fullName = names[1]\n const sets = patternSet.exec(fullName)\n const setName = sets[1]\n const iconName =\n iconSet === 'icon' ? `${iconSet}-${name}` : `${iconSet}-icon-${name}`\n\n return setName === iconSet && fullName === iconName\n })\n}\n\nexport default getSymbol\n","import add from './add'\nimport getSymbols from './getSymbols'\n\n/**\n * 绘制 SVG 图标集\n * ========================================================================\n * @method paint\n * @param {String|Array} symbol\n */\nconst paint = (symbol = '') => {\n const $body = document.body\n let $icons = document.querySelector('#outline-icons')\n let symbols = []\n\n add(symbol)\n symbols = getSymbols()\n\n if ($icons) {\n $icons.innerHTML = symbols.join('')\n } else {\n $icons = document.createElement('div')\n $icons.innerHTML =\n ``\n $body.insertBefore($icons.firstChild, $body.firstChild)\n }\n}\n\nexport default paint\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport SYMBOLS from './symbols'\n\n/**\n * @method add\n * @param {Array|String} symbols\n * @return {Boolean}\n */\nconst add = (symbols) => {\n if (!symbols) {\n return false\n }\n\n if (isArray(symbols) && symbols.length > 0) {\n symbols.forEach((symbol) => {\n /* istanbul ignore else */\n if (SYMBOLS.indexOf(symbol) === -1 && isString(symbol)) {\n SYMBOLS.push(symbol)\n }\n })\n } else {\n /* istanbul ignore else */\n if (isString(symbols)) {\n SYMBOLS.push(symbols)\n }\n }\n}\n\nexport default add\n","import isString from '../types/isString'\n\n/**\n * 清楚字符串起始位置所有的空格\n * ========================================================================\n * @method trim\n * @param {string} str\n * @returns {string|Boolean}\n */\nconst trim = (str) => {\n if (!isString(str)) {\n return false\n }\n return str.replace(/(^\\s+)|(\\s+$)/g, '')\n}\n\nexport default trim\n","import isObject from './isObject'\r\nimport isElement from './isElement'\r\nimport isHTMLCollection from './isHTMLCollection'\r\nimport isFragment from './isFragment'\r\nimport isTextNode from './isTextNode'\r\n\r\nconst isDOM = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (isElement(el) || isHTMLCollection(el) || isFragment(el) || isTextNode(el))\r\n )\r\n}\r\n\r\nexport default isDOM\r\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isHTMLCollection = (el) => {\r\n return !!(isObject(el) && toString(el) === '[object NodeList]')\r\n}\r\n\r\nexport default isHTMLCollection\r\n","import toString from '../lang/toString'\nimport isObject from './isObject'\n\nconst isFragment = (fragment) => {\n return !!(\n isObject(fragment) && toString(fragment) === '[object DocumentFragment]'\n )\n}\n\nexport default isFragment\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isTextNode = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (toString(el) === '[object Text]' || (el.tagName && el.nodeType === 3))\r\n )\r\n}\r\n\r\nexport default isTextNode\r\n","/**\n * 给 DOM 节点设置属性/值\n * ========================================================================\n * @method setAttribute\n * @param {HTMLElement} el - DOM 节点\n * @param {String} attr - 属性名称\n * @param {String|Number|Boolean} value - 属性值\n */\nconst setAttribute = (el, attr, value) => {\n let tagName = el.tagName.toLowerCase()\n\n switch (attr) {\n case 'style':\n el.style.cssText = value\n break\n case 'value':\n if (tagName === 'input' || tagName === 'textarea') {\n el.value = value\n } else {\n el.setAttribute(attr, value)\n }\n break\n case 'className':\n el.className = value\n break\n default:\n el.setAttribute(attr, value)\n break\n }\n}\n\nexport default setAttribute\n","import hasOwn from '../lang/hasOwn'\nimport isObject from '../types/isObject'\nimport isString from '../types/isString'\nimport isArray from '../types/isArray'\nimport isDOM from '../types/isDOM'\nimport setAttribute from './setAttribute'\n\n/**\n * 创建 DOM 节点,并添加属性和子节点\n * ========================================================================\n * @method createElement\n * @param {String} tagName - 标签名称\n * @param {Object|Array} attrs - 属性对象或者子节点\n * @param {Array} [children] - 子节点数组\n * @returns {HTMLElement}\n */\nconst createElement = (tagName, attrs, children) => {\n const $fragment = document.createDocumentFragment()\n const $el = document.createElement(tagName)\n const isValidChild = (child) => {\n return isDOM(child) || isString(child)\n }\n const append = (child) => {\n let $child\n\n if (!isValidChild(child)) {\n return false\n }\n\n if (isDOM(child)) {\n $child = child\n } else if (isString(child)) {\n $child = document.createTextNode(child)\n }\n\n $fragment.appendChild($child)\n }\n\n if (isObject(attrs)) {\n Object.keys(attrs).forEach((attr) => {\n if (hasOwn(attrs, attr)) {\n setAttribute($el, attr, attrs[attr])\n }\n })\n } else if (isArray(attrs) && attrs.every((attr) => isValidChild(attr))) {\n attrs.forEach((child) => {\n append(child)\n })\n }\n\n if (isArray(children)) {\n children.forEach((child) => {\n append(child)\n })\n } else {\n append(children)\n }\n\n $el.appendChild($fragment)\n\n return $el\n}\n\nexport default createElement\n","import isString from './isString'\n\nconst isSVG = (str) => {\n const declaration = '(?:<\\\\?xml[^>]*>\\\\s*)?'\n const doctype =\n '(?:<\\\\!doctype svg[^>]*\\\\s*(?:\\\\[?(?:\\\\s*]*>\\\\s*)*\\\\]?)*[^>]*>\\\\s*)?'\n const content = ']*>[^]*<\\\\/svg>\\\\s*$'\n const svg = `^\\\\s*${declaration}${doctype}${content}\\\\s*$`\n const pattern = new RegExp(svg, 'i')\n\n return isString(str) && pattern.test(str)\n}\n\nexport default isSVG\n","import createElement from './createElement'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method icon\n * @alias createElement\n * @see createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst icon = (name, options = {}) => {\n return createElement(name, options)\n}\n\nexport default icon\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport isSVG from '../types/isSVG'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst createElement = (name, options = {}) => {\n const size = options.size || 0\n const color = options.color || ''\n const iconSet = options.iconSet || ''\n const width = isArray(size) ? size[0] : size\n const height = isArray(size) ? size[1] : size\n const defaultRules = size ? `width:${width}px;height:${height}px;` : ''\n const cssRules = color ? defaultRules + `color:${color}` : defaultRules\n const $icon = document.createElement('i')\n let binds = ''\n let svg = ''\n let $svg\n\n if (!isString(name)) {\n return null\n }\n\n if (isSVG(name)) {\n svg = name\n } else {\n binds =\n iconSet && iconSet !== 'icon'\n ? `xlink:href=\"#${iconSet}-icon-${name}\"`\n : `xlink:href=\"#icon-${name}\"`\n svg =\n `` +\n `` +\n ``\n }\n\n $icon.className = 'outline-icon'\n $icon.innerHTML = svg\n\n if (isSVG(name)) {\n $svg = $icon.querySelector('svg')\n $svg.setAttribute('aria-hidden', 'true')\n $svg.setAttribute('xmlns', 'http://www.w3.org/2000/svg')\n $svg.setAttribute('class', 'outline-icon__svg')\n $svg.setAttribute('width', '200')\n $svg.setAttribute('height', '200')\n $svg.style = cssRules\n }\n\n return $icon\n}\n\nexport default createElement\n","import isElement from '../types/isElement'\n/**\n * 检测 DOM 节点是否包含名为 className 的样式\n * ========================================================================\n * @method hasClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst hasClass = (el, className) => {\n const pattern = new RegExp('(\\\\s|^)' + className + '(\\\\s|$)')\n let allClass\n let classList\n\n if (!isElement(el)) {\n return false\n }\n\n allClass = el.className\n\n if (!allClass) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.contains) {\n return el.classList.contains(className)\n }\n\n return !!pattern.exec(allClass)\n}\n\nexport default hasClass\n","import trim from '../lang/trim'\nimport hasClass from './hasClass'\n\n/**\n * 移除 DOM 节点的 className 样式\n * ========================================================================\n * @method removeClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst removeClass = (el, className) => {\n let allClass = el.className\n let classList\n\n if (!allClass || !hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.remove) {\n classList.remove(className)\n } else {\n allClass = trim(allClass.replace(className, ''))\n el.className = allClass\n }\n}\n\nexport default removeClass\n","import removeClass from './utils/dom/removeClass'\nimport isEmpty from './utils/types/isEmpty'\nimport trim from './utils/lang/trim'\n\nconst _resetHeading = ($heading, hasAnchor = true, isAtStart = true) => {\n const CLS_HEADING = 'outline-heading'\n const text = $heading.innerHTML\n const pattern = /^\\d+(\\.?\\d+)*\\s?/gi\n let $anchor\n\n $heading.innerHTML = text.replace(pattern, '')\n $heading.removeAttribute('id')\n $heading.removeAttribute('data-id')\n\n removeClass($heading, CLS_HEADING)\n\n if (!hasAnchor) {\n return false\n }\n\n $anchor = $heading.querySelector(`.${CLS_HEADING}__anchor`)\n\n if (isAtStart) {\n removeClass($heading, `${CLS_HEADING}_start`)\n }\n\n if (isEmpty(trim($heading.className))) {\n $heading.removeAttribute('class')\n }\n\n $heading.removeChild($anchor)\n}\n\nexport default _resetHeading\n","import isString from './isString'\n/**\n * 检测数据是否为空字符串\n * ========================================================================\n * @method isEmpty\n * @param {String} str\n * @returns {boolean}\n */\nconst isEmpty = (str) => {\n return isString(str) && str === ''\n}\n\nexport default isEmpty\n","import trim from './utils/lang/trim'\nimport stripTags from './utils/lang/stripTags'\n\nimport _getChapterParentIdByDiffer from './_getChapterParentIdByDiffer'\nimport _getChaptersWithCode from './_getChaptersWithCode'\n\nconst getChapters = (headings, showCode = true) => {\n let previous = 1\n let level = 0\n const chapters = []\n\n headings.forEach((heading, i) => {\n const headingLevel = heading.tagName.replace(/h/i, '')\n let current = parseInt(headingLevel, 10)\n let pid = -1\n\n // 场景1:当前标题是前一个标题的子标题\n // 当前标题的(标题标签)序号 > 前一个标题的序号:两个相连的标题是父标题 -> 子标题关系;\n // h2 (前一个标题)\n // h3 (当前标题)\n if (current > previous) {\n level += 1\n\n // 第一层级的 pid 是 -1\n if (level === 1) {\n pid = -1\n } else {\n pid = i - 1\n }\n }\n // 场景2:当前标题和前一个标题层级相同\n // 当前标题的(标题标签)序号 = 前一个标题的序号\n // h2 (前一个标题)\n // h2 (当前标题)\n // 当前标题的(标题标签)序号 < 前一个标题的序号,并且当前标题序号 > 当前的级别\n // h2\n // h4 (前一个标题)\n // h3 (当前标题:这种情况我们还是任务 h3 是 h2 的下一级章节)\n else if (current === previous || (current < previous && current > level)) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n pid = -1\n } else {\n pid = chapters[i - 1].pid\n }\n }\n // 场景3:当前标题比前一个标题层级高\n else if (current <= level) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n } else {\n level = level - (previous - current)\n\n if (level <= 1) {\n level = 1\n }\n }\n\n // 第一级的标题\n if (level === 1) {\n pid = -1\n } else {\n // 通过当前标题和前一个标题之间的等级差,获得当前标题的父标题ID\n pid = _getChapterParentIdByDiffer(chapters, previous - current, i)\n }\n }\n\n previous = current\n\n chapters.push({\n id: i,\n pid: pid,\n level: level,\n rel: `heading-${i}`,\n text: stripTags(trim(heading.innerHTML))\n })\n })\n\n return showCode ? _getChaptersWithCode(chapters) : chapters\n}\n\nexport default getChapters\n","import isString from '../types/isString'\n\n/**\n * 过滤所有 HTML 标签\n * ========================================================================\n * @method stripTags\n * @param {string} str\n * @returns {string}\n */\nconst stripTags = (str) => {\n if (!isString(str)) {\n return ''\n }\n return str.replace(/<\\/?[^>]+(>|$)/g, '')\n}\n\nexport default stripTags\n","const _getChapterParentIdByDiffer = (chapters, differ, index) => {\n let previous = chapters[index - 1]\n let pid\n let i\n\n for (i = 0; i < differ; i += 1) {\n pid = previous.pid\n previous = chapters[pid]\n }\n\n pid = previous.pid\n\n return pid\n}\n\nexport default _getChapterParentIdByDiffer\n","const _getChaptersWithCode = (chapters) => {\n const groups = {}\n const cb = (o) => {\n return [o.pid]\n }\n\n chapters.forEach((o) => {\n const group = JSON.stringify(cb(o))\n\n groups[group] = groups[group] || []\n groups[group].push(o)\n\n o.index = groups[group].length\n if (o.pid === -1) {\n o.code = String(o.index)\n }\n })\n\n Object.keys(groups).forEach((group) => {\n groups[group].forEach((c) => {\n const subjects = chapters.filter((b) => b.pid === c.id)\n subjects.forEach((o) => {\n o.code = c.code + '.' + o.index\n })\n })\n })\n\n return chapters\n}\n\nexport default _getChaptersWithCode\n","import Base from './base'\n\n// 在文章的标题生成 anchor 链接\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport toTree from './utils/lang/toTree'\nimport later from './utils/lang/later'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport offsetTop from './utils/dom/offsetTop'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _updateHeading from './_updateHeading'\nimport _resetHeading from './_resetHeading'\nimport getChapters from './getChapters'\n\nclass Anchors extends Base {\n constructor(options) {\n super()\n\n this.attrs = Anchors.DEFAULTS\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n\n this.chapters = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let scrollElement\n let selector\n let $articleElement\n let articleElement\n\n this.attr(options)\n articleElement = this.attr('articleElement')\n scrollElement = this.attr('scrollElement')\n selector = this.attr('selector')\n created = this.attr('created')\n\n if (isString(articleElement)) {\n $articleElement = document.querySelector(articleElement)\n } else if (isElement(articleElement)) {\n $articleElement = articleElement\n }\n\n if (!$articleElement) {\n return this\n }\n\n this.$articleElement = $articleElement\n this.$scrollElement = _getScrollElement(scrollElement)\n this.$headings = [...$articleElement.querySelectorAll(selector)]\n\n if (this.$headings.length < 1) {\n return this\n }\n\n this.chapters = getChapters(this.$headings)\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n getChapters(isTreeStructured = false) {\n const chapters = this.chapters\n return isTreeStructured ? toTree(chapters, 'id', 'pid') : chapters\n }\n\n count() {\n return this.chapters.length\n }\n\n render() {\n const mounted = this.attr('mounted')\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const $headings = this.$headings\n const chapters = this.getChapters()\n\n paint()\n\n $headings.forEach(($heading, i) => {\n const chapterCode = chapters[i].code\n _updateHeading($heading, i, {\n hasAnchor,\n isAtStart,\n showCode,\n chapterCode,\n anchorURL\n })\n })\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n destroy() {\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n const $headings = this.$headings\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n $headings.forEach(($heading) => {\n _resetHeading($heading, hasAnchor, isAtStart)\n })\n\n this.attr(Anchors.DEFAULTS)\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n this.chapters = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n onAnchorTrigger(evt) {\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const $heading = $anchor.parentNode\n const top = offsetTop($heading) - (stickyHeight + 10)\n const $scrollElement = this.$scrollElement\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'anchor')\n }\n\n later(() => {\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.scrollTo(top, after)\n\n if (!anchorURL) {\n stop(evt)\n }\n\n return this\n }\n\n addListeners() {\n const $articleElement = this.$articleElement\n\n on(\n $articleElement,\n '.outline-heading__anchor',\n 'click',\n this.onAnchorTrigger,\n this,\n true\n )\n\n return this\n }\n\n removeListeners() {\n const $articleElement = this.$articleElement\n\n off($articleElement, 'click', this.onAnchorTrigger)\n\n return this\n }\n}\n\nAnchors.DEFAULTS = {\n scrollElement: 'html,body',\n articleElement: '#article',\n selector: 'h1,h2,h3,h4,h5,h6',\n stickyHeight: 0,\n anchorURL: '',\n hasAnchor: true,\n isAtStart: true,\n showCode: false,\n created: null,\n mounted: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Anchors\n","const toTree = (list, nodeKey, parentKey) => {\r\n const map = {}\r\n const roots = []\r\n\r\n list.forEach((item, i) => {\r\n // initialize the map\r\n map[item[nodeKey]] = i\r\n // initialize the children\r\n item.children = []\r\n })\r\n\r\n list.forEach((item) => {\r\n const node = list[map[item[parentKey]]]\r\n\r\n if (item[parentKey] !== -1) {\r\n // if you have dangling branches check that map[node.parentId] exists\r\n node.children.push(item)\r\n } else {\r\n roots.push(item)\r\n }\r\n })\r\n\r\n return roots\r\n}\r\n\r\nexport default toTree\r\n","import trim from './utils/lang/trim'\nimport createElement from './utils/dom/createElement'\nimport setAttribute from './utils/dom/setAttribute'\n\nimport icon from './utils/icons/icon'\n\nconst _updateHeading = ($heading, i, options) => {\n const $fragment = document.createDocumentFragment()\n const CLS_HEADING = 'outline-heading'\n const hasAnchor = options.hasAnchor || true\n const isAtStart = options.isAtStart || true\n const showCode = options.showCode || false\n const chapterCode = options.chapterCode || ''\n const anchorURL = options.anchorURL || ''\n const headingId = `heading-${i}`\n const attrs = {\n id: headingId,\n className: isAtStart ? `${CLS_HEADING} ${CLS_HEADING}_start` : CLS_HEADING,\n 'data-id': i\n }\n const keys = Object.keys(attrs)\n const text = trim($heading.innerHTML)\n let $anchor\n let $icon\n\n keys.forEach((prop) => {\n setAttribute($heading, prop, attrs[prop])\n })\n\n if (showCode) {\n $heading.innerHTML = chapterCode + ' ' + text\n }\n\n if (!hasAnchor) {\n return false\n }\n\n $icon = icon('hash', { iconSet: 'outline' })\n $anchor = createElement(\n 'a',\n {\n id: `anchor-${i}`,\n className: `${CLS_HEADING}__anchor anchor-${i}`,\n href: anchorURL || `#${headingId}`,\n target: anchorURL ? '_blank' : 'self',\n 'data-id': i\n },\n [$icon]\n )\n $fragment.appendChild($anchor)\n $heading.appendChild($fragment)\n}\n\nexport default _updateHeading\n","import hasClass from './hasClass'\n\n/**\n * 给 DOM 节点添加名为 className 的样式\n * ========================================================================\n * @method addClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst addClass = (el, className) => {\n let classList\n let allClass\n\n if (hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.add) {\n classList.add(className)\n } else {\n allClass = el.className\n allClass += allClass.length > 0 ? ' ' + className : className\n el.className = allClass\n }\n}\n\nexport default addClass\n","const setProperty = (prop, value) => {\r\n const documentElement = document.documentElement\r\n documentElement.style.setProperty(prop, value)\r\n}\r\n\r\nexport default setProperty\r\n","import setProperty from './utils/dom/setProperty'\n\nlet index = 2000\n\nconst zIndex = (idx) => {\n if (idx) {\n index = idx\n } else {\n index += 1\n }\n\n setProperty('--outline-zIndex', `${index}`)\n\n return index\n}\n\nexport default zIndex\n","import Base from './base'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport addClass from './utils/dom/addClass'\nimport removeClass from './utils/dom/removeClass'\nimport createElement from './utils/dom/createElement'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\n\nimport paint from './utils/icons/paint'\nimport icon from './utils/icons/icon'\nimport zIndex from './zIndex'\n\nclass Drawer extends Base {\n constructor(options) {\n super()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = true\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n this.zIndex = 0\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n\n this.title = this.attr('title')\n created = this.attr('created')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n return this\n }\n\n setTitle(title) {\n this.attr('title', title)\n this.title = title\n this.$title.innerHTML = title\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n render() {\n const mounted = this.attr('mounted')\n const size = this.attr('size')\n const placement = this.attr('placement')\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const hasOffset = this.attr('hasOffset')\n const hasPadding = this.attr('hasPadding')\n const autoHeight = this.attr('autoHeight')\n const customClass = this.attr('customClass')\n let $el\n let $modal\n let $header\n let $title\n let $close\n let $main\n let $footer\n let $overlay\n\n paint()\n this.zIndex = zIndex()\n\n $title = createElement(\n 'h2',\n {\n className: 'outline-drawer__title'\n },\n [this.title]\n )\n this.$title = $title\n\n if (hasClose) {\n $close = createElement(\n 'div',\n {\n className: 'outline-drawer__close'\n },\n [icon('close', { size: 20 })]\n )\n this.$close = $close\n }\n\n $header = createElement(\n 'header',\n {\n className: 'outline-drawer__header'\n },\n [$title, $close]\n )\n this.$header = $header\n\n $main = createElement(\n 'div',\n {\n className: 'outline-drawer__main'\n },\n ['']\n )\n this.$main = $main\n\n if (!hasPadding) {\n addClass($main, 'outline-drawer_full')\n }\n\n $footer = createElement(\n 'footer',\n {\n className: 'outline-drawer__footer'\n },\n ['']\n )\n this.$footer = $footer\n\n $modal = createElement(\n 'div',\n {\n className: `outline-drawer__modal outline-drawer_${placement} outline-drawer_${size} outline-drawer_closed`\n },\n [$header, $main, $footer]\n )\n this.$modal = $modal\n\n if (hasOffset) {\n addClass($modal, 'outline-drawer_offset')\n }\n\n if (autoHeight) {\n addClass($modal, 'outline-drawer_auto')\n }\n\n if (customClass) {\n addClass($modal, customClass)\n }\n\n if (hasOverlay) {\n $overlay = createElement(\n 'div',\n {\n className: 'outline-drawer__overlay'\n },\n ['']\n )\n this.$overlay = $overlay\n }\n\n $el = createElement(\n 'div',\n {\n className: `outline-drawer`\n },\n [$modal, $overlay]\n )\n this.$el = $el\n document.body.appendChild($el)\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n open() {\n const opened = this.attr('afterOpened')\n const $modal = this.$modal\n\n addClass(this.$el, 'outline-drawer_opened')\n removeClass($modal, 'outline-drawer_closed')\n addClass($modal, 'outline-drawer_opened')\n\n later(() => {\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n })\n\n return this\n }\n\n close() {\n const closed = this.attr('afterClosed')\n const $modal = this.$modal\n\n removeClass($modal, 'outline-drawer_opened')\n addClass($modal, 'outline-drawer_closed')\n\n later(() => {\n removeClass(this.$el, 'outline-drawer_opened')\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n })\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const closed = this.isClosed()\n\n if (closed) {\n this.open()\n } else {\n this.close()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n afterToggle.call(this, closed)\n })\n }\n\n return this\n }\n\n destroy() {\n const afterDestroy = this.attr('afterDestroy')\n const beforeDestroy = this.attr('beforeDestroy')\n let index = this.zIndex\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = false\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n\n index -= 1\n zIndex(index)\n this.zIndex = 0\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n addListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (hasClose) {\n on($el, '.outline-drawer__close', 'click', this.onClose, this, true)\n }\n\n if (hasOverlay) {\n on($el, '.outline-drawer__overlay', 'click', this.onClose, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (!hasClose && !hasOverlay) {\n return this\n }\n\n off($el, 'click', this.onClose)\n\n return this\n }\n\n onClose() {\n this.close()\n return this\n }\n}\n\nDrawer.DEFAULTS = {\n placement: 'rtl',\n title: '标题',\n size: 'regular',\n hasClose: true,\n hasOverlay: true,\n hasOffset: false,\n hasPadding: true,\n autoHeight: true,\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterToggle: null\n}\n\nexport default Drawer\n","import isFunction from '../types/isFunction'\nimport off from './off'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定事件\n * ========================================================================\n * @method at\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (必须) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst at = (el, type, fn, data, context, once = false) => {\n // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n const listener = function (evt) {\n let overrideContext = context || el\n\n // 当设置为 true 时,则事件处理器回调函数的\n // this 上下文指向为 data 对象\n if (context === true) {\n overrideContext = data\n }\n\n // 仅触发一次\n /* istanbul ignore else */\n if (once === true) {\n off(el, type, listener)\n }\n\n fn.call(overrideContext, evt, data)\n }\n\n if (!isFunction(fn)) {\n return false\n }\n\n if (!el._listeners) {\n el._listeners = []\n }\n\n // 缓存 options 元素绑定的事件处理器\n el._listeners.push({\n el,\n type,\n fn: listener,\n data,\n context,\n capture\n })\n\n // 缓存包装后的事件处理器\n fn._delegateListener = listener\n\n el.addEventListener(type, listener, capture)\n}\n\nexport default at\n","/**\r\n * 获取HTML元素的某个CSS样式值\r\n * ====================================================\r\n * @param el\r\n * @param ruleName\r\n * @returns {*}\r\n */\r\nconst getStyle = (el, ruleName) => {\r\n return getComputedStyle(el)[ruleName]\r\n}\r\n\r\nexport default getStyle\r\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport later from './utils/lang/later'\nimport at from './utils/event/at'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport createElement from './utils/dom/createElement'\nimport scrollTo from './utils/dom/scrollTo'\nimport addClass from './utils/dom/addClass'\nimport intersection from './utils/dom/intersection'\nimport removeClass from './utils/dom/removeClass'\nimport offsetTop from './utils/dom/offsetTop'\nimport getStyle from './utils/dom/getStyle'\nimport setProperty from './utils/dom/setProperty'\nimport publish from './utils/observer/emit'\n\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport _paintChapters from './_paintChapters'\n\nclass Chapters extends Base {\n constructor(options) {\n super()\n\n this.attrs = Chapters.DEFAULTS\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.closed = false\n this.active = 0\n this.offsetTop = 0\n this.offsetWidth = 0\n this.$active = null\n this.scrollTimer = null\n this.resizeTimer = null\n this.playing = false\n this.Observer = null\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let parentElement\n let scrollElement\n let $parent\n\n this.attr(options)\n created = this.attr('created')\n parentElement = this.attr('parentElement')\n scrollElement = this.attr('scrollElement')\n\n if (isString(parentElement)) {\n $parent = document.querySelector(parentElement)\n } else if (isElement(parentElement)) {\n $parent = parentElement\n }\n this.$parentElement = $parent\n this.$scrollElement = _getScrollElement(scrollElement)\n\n this.chapters = this.attr('chapters')\n this.closed = this.attr('closed')\n this.active = this.attr('active')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n if (this.chapters.length < 1) {\n return this\n }\n\n this.render().addListeners()\n\n this.$active = document.querySelector(`#chapter-${this.active}`)\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n isSticky() {\n const position = this.attr('position')\n return position === 'sticky'\n }\n\n isFixed() {\n const position = this.attr('position')\n return position === 'fixed'\n }\n\n isInside() {\n return this.isFixed() || this.isSticky()\n }\n\n isOutside() {\n return !this.isInside()\n }\n\n _paintEdge() {\n const $fragment = document.createDocumentFragment()\n const STICKY = 'outline-chapters_sticky'\n const HIDDEN = 'outline-chapters_hidden'\n const title = this.attr('title')\n const customClass = this.attr('customClass')\n const $parentElement = this.$parentElement\n const contents = []\n let $title = null\n let $el\n let $main\n let $list\n let $placeholder\n\n if (!$parentElement) {\n return this\n }\n\n if (this.isInside()) {\n $title = createElement(\n 'h2',\n {\n className: 'outline-chapters__title'\n },\n [title]\n )\n this.$title = $title\n contents.push($title)\n }\n\n $list = createElement(\n 'ul',\n {\n // 为优化性能,添加了 _fixed 和 _hidden\n // fixed 为了让 $list 脱离流布局\n // hidden 让 $list 不可见\n className: `outline-chapters__list`\n },\n ['']\n )\n this.$list = $list\n\n $placeholder = createElement(\n 'div',\n {\n className: 'outline-chapters__placeholder'\n },\n ['']\n )\n this.$placeholder = $placeholder\n\n $main = createElement(\n 'div',\n {\n className: 'outline-chapters__main'\n },\n [$list, $placeholder]\n )\n this.$main = $main\n contents.push($main)\n\n $el = createElement(\n 'nav',\n {\n id: 'outline-chapters',\n className: `outline-chapters ${HIDDEN}`\n },\n contents\n )\n this.$el = $el\n\n if (this.isSticky()) {\n this.calculateStickyHeight()\n addClass($el, STICKY)\n }\n\n if (customClass) {\n addClass($el, customClass)\n }\n $fragment.appendChild($el)\n $parentElement.appendChild($fragment)\n\n return this\n }\n\n render() {\n const HIDDEN = 'outline-chapters_hidden'\n const showCode = this.attr('showCode')\n const mounted = this.attr('mounted')\n const $parentElement = this.$parentElement\n const chapters = this.chapters\n let $el\n let $list\n\n if (!$parentElement || chapters.length < 1) {\n return this\n }\n\n this._paintEdge()\n\n $el = this.$el\n $list = this.$list\n _paintChapters($list, chapters, showCode)\n removeClass($el, HIDDEN)\n this.positionPlaceholder(this.active)\n\n this.offsetTop = offsetTop($el)\n this.offsetWidth = $el.offsetWidth\n\n if (this.isFixed()) {\n this.sticky()\n setProperty('--outline-chapters-width', `${this.offsetWidth}px`)\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n this.onObserver()\n\n return this\n }\n\n positionPlaceholder(index) {\n const $main = this.$main\n const $list = this.$list\n const $placeholder = this.$placeholder\n const $anchor = $list.querySelector('.outline-chapters__anchor')\n const mainPaddingTop = parseInt(getStyle($main, 'padding-top'), 10)\n const mainBorderTop = parseInt(getStyle($main, 'border-top-width'), 10)\n const placeholderPaddingTop = parseInt(getStyle($list, 'padding-top'), 10)\n const placeholderMarginTop = parseInt(getStyle($list, 'margin-top'), 10)\n const placeholderBorderTop = parseInt(\n getStyle($list, 'border-top-width'),\n 10\n )\n let height = $anchor.offsetHeight\n let offsetTop = 0\n let top\n\n if (mainPaddingTop) {\n offsetTop += mainPaddingTop\n }\n\n if (placeholderPaddingTop) {\n offsetTop += placeholderPaddingTop\n }\n\n if (placeholderMarginTop) {\n offsetTop += placeholderMarginTop\n }\n\n if (mainBorderTop) {\n offsetTop += mainBorderTop\n }\n\n if (placeholderBorderTop) {\n offsetTop += placeholderBorderTop\n }\n\n top = height * index\n // top:calc(${offsetTop}px + ${top}px);\n $placeholder.style.cssText = `transform: translateY(${\n offsetTop + top\n }px);height:${height}px;`\n\n return this\n }\n\n highlight(id) {\n const $anchor = this.$el.querySelector(`#chapter__anchor-${id}`)\n const HIGHLIGHT = 'outline-chapters_active'\n\n if (!$anchor) {\n return this\n }\n\n if (this.$active) {\n removeClass(this.$active, HIGHLIGHT)\n }\n\n this.active = parseInt($anchor.getAttribute('data-id'), 10)\n this.$active = $anchor\n addClass(this.$active, HIGHLIGHT)\n\n this.positionPlaceholder(this.active)\n\n return this\n }\n\n sticky() {\n const afterSticky = this.attr('afterSticky')\n const FIXED = 'outline-chapters_fixed'\n const $el = this.$el\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (!this.isFixed()) {\n return this\n }\n\n isStickying = scrollTop >= top\n\n if (isStickying) {\n addClass($el, FIXED)\n } else {\n removeClass($el, FIXED)\n }\n\n if (isFunction(afterSticky)) {\n afterSticky.call(this, this.isClosed(), isStickying)\n }\n\n return this\n }\n\n calculateStickyHeight() {\n const documentElement = document.documentElement\n const height = Math.max(\n documentElement.clientHeight || 0,\n window.innerHeight || 0\n )\n setProperty('--outline-sticky-height', `${height}px`)\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n show() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const opened = this.attr('afterOpened')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n removeClass($parent, HIDDEN)\n removeClass($el, HIDDEN)\n later(() => {\n removeClass($parent, FOLDED)\n removeClass($el, FOLDED)\n }, 30)\n } else {\n removeClass($el, HIDDEN)\n }\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n\n return this\n }\n\n hide() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const closed = this.attr('afterClosed')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n addClass($parent, FOLDED)\n addClass($el, FOLDED)\n later(() => {\n addClass($parent, HIDDEN)\n addClass($el, HIDDEN)\n })\n } else {\n addClass($el, HIDDEN)\n }\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n isStickying = scrollTop >= top\n afterToggle.call(this, this.isClosed(), isStickying)\n })\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n this.$parentElement.removeChild(this.$el)\n\n this.attr(Chapters.DEFAULTS)\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.active = 0\n this.offsetTop = 0\n this.$active = null\n this.closed = false\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n this.scrollTimer = null\n }\n\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n this.resizeTimer = null\n }\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n if (this.Observer) {\n this.Observer = null\n }\n\n return this\n }\n\n onObserver() {\n const selector = this.attr('selector')\n let timer = null\n\n this.Observer = intersection(\n ($heading) => {\n const id = $heading.getAttribute('data-id')\n\n if (this.playing) {\n return false\n }\n\n if (timer) {\n clearTimeout(timer)\n }\n\n timer = later(() => {\n this.highlight(id)\n }, 100)\n },\n {\n selector,\n context: this\n }\n )\n\n return this\n }\n\n onSelect(evt) {\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const id = $anchor.getAttribute('data-id')\n const headingId = $anchor.href.split('#')[1]\n const $heading = document.querySelector(`#${headingId}`)\n const top = offsetTop($heading) - (stickyHeight + 10)\n const min = 0\n const max = this.$scrollElement.scrollHeight\n const afterScroll = this.attr('afterScroll')\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'chapter')\n }\n\n later(() => {\n this.playing = false\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.playing = true\n if (this.isFixed()) {\n this.sticky()\n later(() => {\n this.scrollTo(top, after)\n this.highlight(id)\n }, 10)\n } else {\n this.scrollTo(top, after)\n this.highlight(id)\n }\n\n stop(evt)\n\n return this\n }\n\n onScroll() {\n const $scrollElement = this.$scrollElement\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n }\n\n this.scrollTimer = later(() => {\n const top = $scrollElement.scrollTop\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n\n if (this.isFixed()) {\n this.sticky()\n }\n\n publish('toolbar:update', {\n top,\n min,\n max\n })\n }, 100)\n\n return this\n }\n\n onResize() {\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n }\n\n this.resizeTimer = later(() => {\n this.calculateStickyHeight()\n })\n\n return this\n }\n\n addListeners() {\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n on($el, '.outline-chapters__anchor', 'click', this.onSelect, this, true)\n at($element, 'scroll', this.onScroll, this, true)\n if (this.isSticky()) {\n at($element, 'resize', this.onResize, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const selector = this.attr('selector')\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n off($el, 'click', this.onSelect)\n off($element, 'scroll', this.onScroll)\n\n if (this.isSticky()) {\n at($element, 'resize', this.onResize)\n }\n\n if (this.Observer) {\n document.querySelectorAll(selector).forEach((section) => {\n this.Observer.unobserve(section)\n })\n }\n\n return this\n }\n}\n\nChapters.DEFAULTS = {\n parentElement: '',\n scrollElement: '',\n selector: '.outline-heading',\n active: 0,\n closed: false,\n showCode: true,\n position: 'relative',\n stickyHeight: 0,\n chapters: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterSticky: null\n}\n\nexport default Chapters\n","import createElement from './utils/dom/createElement'\n\nconst _paintChapters = ($list, chapters, showCode = false) => {\n const byId = (id) => document.querySelector(`#${id}`)\n\n chapters.forEach((chapter) => {\n const pid = chapter.pid\n const id = chapter.id\n const rel = chapter.rel\n const $text = createElement(\n 'span',\n {\n className: 'outline-chapters__text'\n },\n [chapter.text]\n )\n const $link = createElement(\n 'a',\n {\n id: `chapter__anchor-${id}`,\n className: 'outline-chapters__anchor',\n href: '#' + rel,\n rel: rel,\n 'data-id': id\n },\n [$text]\n )\n let $code\n let $li\n let $ul\n let $parent\n\n if (showCode) {\n $code = createElement(\n 'span',\n {\n className: 'outline-chapters__code',\n 'data-id': id\n },\n [chapter.code]\n )\n\n $link.insertBefore($code, $link.firstChild)\n }\n\n $li = createElement(\n 'li',\n {\n id: `chapter-${id}`,\n className: 'outline-chapters__item',\n 'data-id': id\n },\n [$link]\n )\n\n if (pid === -1) {\n $list.appendChild($li)\n } else {\n $parent = byId(`chapter-${pid}`)\n $ul = byId(`subject-${pid}`)\n\n if (!$ul) {\n $ul = createElement(\n 'ul',\n {\n id: 'subject-' + pid,\n className: 'outline-chapters__subject'\n },\n [$li]\n )\n\n $parent.appendChild($ul)\n } else {\n $ul.appendChild($li)\n }\n }\n })\n}\n\nexport default _paintChapters\n","import isFunction from '../types/isFunction'\nimport isElement from '../types/isElement'\n\n/**\n * 通用的 IntersectionObserver 观察者处理器\n * ========================================================================\n * @method intersection\n * @param {Function} fn\n * @param {Object} [props]\n * @param {Object|HTMLElement} [props.root]\n * @param {String} [props.selector]\n * @param {Object} [props.context]\n * @param {String} [props.attr]\n * @param {String} [props.rootMargin]\n */\nconst intersection = (fn, props = {}) => {\n const root = props.root || null\n const selector = props.selector || '.outline-heading'\n const context = props.context || null\n const rootMargin = props.rootMargin || '0px 0px -90% 0px'\n const options = {\n rootMargin: rootMargin\n }\n const Observer = new IntersectionObserver((entries) => {\n entries.forEach((entry) => {\n if (entry.intersectionRatio > 0) {\n if (isFunction(fn)) {\n fn.call(context || entry.target, entry.target)\n }\n }\n })\n }, options)\n const $root = isElement(root) ? root : document\n\n if (root) {\n options.root = root\n }\n\n $root.querySelectorAll(selector).forEach((section) => {\n Observer.observe(section)\n })\n\n return Observer\n}\n\nexport default intersection\n","import icon from './utils/icons/icon'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\n\nconst _createButton = (button, rounded = true) => {\n const $icon = icon(button.icon, {\n iconSet: button.iconSet || 'outline',\n color: button.color || '',\n size: button.size\n })\n const $anchor = createElement(\n 'a',\n {\n className: `outline-toolbar__anchor`,\n href: button.link\n },\n [$icon]\n )\n const $button = createElement(\n 'div',\n {\n className: `outline-toolbar__button ${button.name}`\n },\n [button.link ? $anchor : $icon]\n )\n\n addClass($icon, 'outline-toolbar__icon')\n\n if (rounded) {\n addClass($button, 'outline-toolbar_rounded')\n }\n\n if (button.disabled) {\n addClass($button, 'outline-toolbar_disabled')\n }\n\n return $button\n}\n\nexport default _createButton\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isObject from './utils/types/isObject'\nimport isArray from './utils/types/isArray'\nimport later from './utils/lang/later'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\nimport hasClass from './utils/dom/hasClass'\nimport removeClass from './utils/dom/removeClass'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _createButton from './_createButton'\n\nconst DISABLED = 'outline-toolbar_disabled'\nconst HIDDEN = 'outline-toolbar_hidden'\n\nclass Toolbar extends Base {\n constructor(options) {\n super()\n\n this.attrs = Toolbar.DEFAULTS\n this.$el = null\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n created = this.attr('created')\n this.disabled = this.attr('disabled')\n this.closed = this.attr('closed')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n isDisabled(name) {\n const buttons = this.attr('buttons')\n let button\n\n if (name) {\n button = buttons.find((option) => option.name === name)\n\n return button?.disabled\n }\n\n return this.disabled\n }\n\n isClosed() {\n return this.closed\n }\n\n highlight(name) {\n const button = this.buttons.find((item) => item.name === name)\n const ACTIVE = 'outline-toolbar_active'\n let $button\n\n if ($button) {\n return this\n }\n\n $button = button.$el\n\n if (hasClass($button, ACTIVE)) {\n removeClass($button, ACTIVE)\n } else {\n addClass($button, ACTIVE)\n }\n\n return this\n }\n\n render() {\n const mounted = this.attr('mounted')\n const buttons = this.attr('buttons') || []\n const rounded = this.attr('rounded')\n const placement = this.attr('placement')\n const $buttons = document.createDocumentFragment()\n const $fragment = document.createDocumentFragment()\n\n paint()\n\n buttons.forEach((button) => {\n const $button = _createButton(button, rounded)\n\n $buttons.appendChild($button)\n this.buttons.push({\n name: button.name,\n $el: $button\n })\n })\n\n this.$el = createElement(\n 'div',\n {\n id: 'outline-toolbar',\n className: `outline-toolbar outline-toolbar_${placement}`\n },\n [$buttons]\n )\n $fragment.appendChild(this.$el)\n document.body.appendChild($fragment)\n\n if (this.closed) {\n this.hide()\n }\n\n if (this.disabled) {\n this.disable()\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n add(button) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const action = button.action\n const $fragment = document.createDocumentFragment()\n let type\n\n if (isObject(button)) {\n buttons.push(button)\n $fragment.appendChild(_createButton(button))\n } else if (isArray(button)) {\n button.forEach((item) => {\n $fragment.appendChild(_createButton(item))\n })\n }\n $el.appendChild($fragment)\n\n if (action && isFunction(action.handler)) {\n type = action.type || 'click'\n on($el, `.${button.name}`, type, action.handler)\n }\n\n return this\n }\n\n remove(name) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let index = -1\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((button, i) => {\n if (button.name === name) {\n index = i\n }\n })\n\n if (index > -1) {\n this.attr().buttons.splice(index, 1)\n }\n\n $button = $el.querySelector(`.${name}`)\n this.switch(name, false)\n $el.removeChild($button)\n\n return this\n }\n\n switch(name, enabled) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let action\n let type\n let listener\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((option) => {\n if (option.name === name) {\n button.disabled = !enabled\n }\n })\n\n action = button.action\n $button = $el.querySelector(`.${name}`)\n\n if (action) {\n type = action.type || 'click'\n listener = action.handler\n }\n\n if (enabled) {\n removeClass($button, DISABLED)\n\n if (type && listener) {\n on($el, `.${name}`, type, listener)\n }\n } else {\n addClass($button, DISABLED)\n\n if (type && listener) {\n off($el, type, listener)\n }\n }\n\n return this\n }\n\n disable(name) {\n const disabled = this.attr('afterDisabled')\n\n if (name) {\n this.switch(name, false)\n } else {\n addClass(this.$el, DISABLED)\n this.removeListeners()\n this.disabled = true\n\n if (isFunction(disabled)) {\n disabled.call(this)\n }\n }\n\n return this\n }\n\n enable(name) {\n const enabled = this.attr('afterEnabled')\n\n if (name) {\n this.switch(name, true)\n } else {\n this.disabled = false\n removeClass(this.$el, DISABLED)\n this.addListeners()\n\n if (isFunction(enabled)) {\n enabled.call(this)\n }\n }\n\n return this\n }\n\n show(name) {\n const opened = this.attr('afterOpened')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n\n $button = $el.querySelector(`.${name}`)\n removeClass($button, HIDDEN)\n } else {\n removeClass($el, HIDDEN)\n this.closed = false\n\n if (isFunction(opened)) {\n later(() => {\n opened.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n hide(name) {\n const closed = this.attr('afterClosed')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n $button = $el.querySelector(`.${name}`)\n addClass($button, HIDDEN)\n } else {\n addClass($el, HIDDEN)\n this.closed = true\n\n if (isFunction(closed)) {\n later(() => {\n closed.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n toggle() {\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n let $el = this.$el\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n document.body.removeChild($el)\n $el = null\n\n this.attr(Toolbar.DEFAULTS)\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n refresh() {\n const $el = this.$el\n const buttons = this.attr('buttons') || []\n\n this.removeListeners()\n $el.innerHTML = ''\n\n buttons.forEach((button) => {\n this.$el.appendChild(_createButton(button))\n })\n\n this.addListeners()\n\n return this\n }\n\n addListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n let context\n let command\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n if (isString(listener)) {\n command = listener\n action.handler = function () {\n publish(command, button.name)\n }\n listener = action.handler\n }\n\n type = action.type || 'click'\n context = action.context\n }\n\n if (isFunction(listener)) {\n on($el, `.${button.name}`, type, listener, context || this, true)\n }\n })\n\n return this\n }\n\n removeListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n type = action.type || 'click'\n }\n\n if (isFunction(listener)) {\n off($el, type, listener)\n }\n })\n\n return this\n }\n}\n\nToolbar.DEFAULTS = {\n placement: 'ltr',\n closed: false,\n disabled: false,\n rounded: true,\n buttons: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterDisabled: null,\n afterEnabled: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Toolbar\n","/**\n * 生成唯一 id 字符串的函数\n * ========================================================================\n * @method guid\n * @param {String} [prefix] - 生成 id 的前缀字符串\n * @return {String} 返回一个表示唯一 id 的字符串\n */\nconst guid = (() => {\n let uuid = 0\n\n return (prefix) => {\n uuid += 1\n\n return prefix ? prefix + '-' + uuid : 'guid-' + uuid\n }\n})()\n\nexport default guid\n","import _subscribers from './_subscribers'\nimport isFunction from '../types/isFunction'\nimport guid from '../lang/guid'\n\n/**\n * 订阅主题,并给出处理器函数\n * ========================================================================\n * @method on\n * @param {String} topic - (必须)主题名称\n * @param {Function} handler - (必须)主题的处理器函数\n * @param {Object} [context] - (可选)指定 this 执行上下文\n * @return {String} - 唯一的 token 字符串,例如:'guid-1'。\n */\nconst on = (topic, handler, context = null) => {\n const token = guid()\n let subject = typeof topic === 'symbol' ? topic.toString() : topic\n\n if (!isFunction(handler)) {\n return ''\n }\n\n /* istanbul ignore else */\n if (!_subscribers[subject]) {\n _subscribers[subject] = []\n }\n\n _subscribers[subject].push({\n topic: subject,\n callback: handler,\n context,\n token\n })\n\n return token\n}\n\nexport default on\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 删除与给定 topic 相同的订阅者信息\n * ========================================================================\n * @method _removeSubscriber\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _removeSubscriber = (topic) => {\n if (!hasOwn(_subscribers, topic)) {\n return false\n }\n\n delete _subscribers[topic]\n}\n\nexport default _removeSubscriber\n","import has from './has'\nimport _removeSubscriber from './_removeSubscriber'\nimport _removeSubscriberByToken from './_removeSubscriberByToken'\n\n/**\n * 取消订阅主题\n * ========================================================================\n * @method off\n * @param {String} topic - (必须)订阅的主题\n * @param {Function|String} [token] - (可选)订阅主题的处理器函数或者唯一 Id 值\n */\nconst off = (topic, token) => {\n if (!has(topic)) {\n return false\n }\n\n if (token) {\n _removeSubscriberByToken(token)\n } else {\n _removeSubscriber(topic)\n }\n}\n\nexport default off\n","import _subscribers from './_subscribers'\nimport _removeSubscriber from './_removeSubscriber'\n\n/**\n * 通过订阅者 token 值删除订阅者信息\n * ========================================================================\n * @method _removeSubscriberByToken\n * @param {String} token - 订阅者 token 字符串\n * @returns {boolean}\n * @private\n */\nconst _removeSubscriberByToken = (token) => {\n const keys = Object.keys(_subscribers)\n let index = -1\n\n if (!token || keys.length < 1) {\n return false\n }\n\n keys.forEach((subject) => {\n const subscriber = _subscribers[subject]\n let topic\n\n subscriber.forEach((execution, j) => {\n if (execution.callback === token || execution.token === token) {\n topic = execution.topic\n subscriber.splice(index, j)\n }\n })\n\n /* istanbul ignore else */\n if (subscriber.length < 1) {\n _removeSubscriber(topic)\n }\n })\n}\n\nexport default _removeSubscriberByToken\n","import Base from './base'\nimport Anchors from './anchors'\nimport Drawer from './drawer'\nimport Chapters from './chapters'\nimport Toolbar from './toolbar'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport isString from './utils/types/isString'\nimport isElement from './utils/types/isElement'\nimport addClass from './utils/dom/addClass'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport subscribe from './utils/observer/on'\nimport unsubscribe from './utils/observer/off'\n\nimport print from './print'\n\nclass Outline extends Base {\n constructor(options) {\n super()\n\n this.attrs = Outline.DEFAULTS\n this.anchors = null\n this.drawer = null\n this.chapters = null\n this.toolbar = null\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n this.attr(options).render().addListeners()\n return this\n }\n\n getChapters(isTreeStructured = false) {\n return this.anchors.getChapters(isTreeStructured)\n }\n\n count() {\n return this.anchors.count()\n }\n\n render() {\n const scrollElement = this.attr('scrollElement')\n const $scrollElement =\n document.querySelector(scrollElement) ||\n document.getElementById(scrollElement)\n\n this._renderPrint()._renderAnchors()._renderChapters()._renderToolbar()\n\n if ($scrollElement) {\n this.onToolbarUpdate({\n top: $scrollElement.scrollTop,\n min: 0,\n max: $scrollElement.scrollHeight\n })\n }\n\n return this\n }\n\n _renderPrint() {\n const option = this.attr('print')\n const articleElement = this.attr('articleElement')\n let $articleElement\n\n if (!option.element) {\n return this\n }\n\n if (isString(articleElement)) {\n $articleElement = document.querySelector(articleElement)\n } else if (isElement(articleElement)) {\n $articleElement = articleElement\n }\n\n addClass($articleElement, 'outline-article')\n print(option.element, option.title)\n\n return this\n }\n\n _renderAnchors() {\n const articleElement = this.attr('articleElement')\n const selector = this.attr('selector')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n\n this.anchors = new Anchors({\n articleElement,\n stickyHeight,\n scrollElement,\n selector,\n showCode,\n anchorURL,\n afterScroll\n })\n\n return this\n }\n\n _renderChapters() {\n const title = this.attr('title')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const customClass = this.attr('customClass')\n const showCode = this.attr('showCode')\n const position = this.attr('position')\n const placement = this.attr('placement')\n const afterSticky = this.attr('afterSticky')\n const afterToggle = this.attr('afterToggle')\n const afterScroll = this.attr('afterScroll')\n const count = this.count()\n let parentElement = this.attr('parentElement')\n let CHAPTERS_OPTIONS\n\n if (count < 1) {\n return this\n }\n\n CHAPTERS_OPTIONS = {\n scrollElement,\n showCode,\n position,\n title,\n stickyHeight,\n chapters: this.getChapters(),\n afterSticky,\n afterToggle,\n afterScroll\n }\n\n if (position === 'relative') {\n this.drawer = new Drawer({\n placement,\n title,\n size: 'tiny',\n hasOffset: true,\n hasPadding: false,\n customClass,\n afterClosed: () => {\n const toolbar = this.toolbar\n toolbar.toggle()\n }\n })\n parentElement = this.drawer.$main\n } else {\n CHAPTERS_OPTIONS.customClass = customClass\n }\n\n CHAPTERS_OPTIONS.parentElement = parentElement\n this.chapters = new Chapters(CHAPTERS_OPTIONS)\n\n return this\n }\n\n _renderToolbar() {\n const placement = this.attr('placement')\n const homepage = this.attr('homepage')\n const git = this.attr('git')\n const tags = this.attr('tags')\n const issues = this.attr('issues')\n const tools = this.attr('tools')\n const count = this.count()\n const UP = {\n name: 'up',\n icon: 'up',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:up'\n }\n }\n const HOME = {\n name: 'homepage',\n icon: 'homepage',\n size: 20,\n link: homepage\n }\n const GIT = {\n name: 'github',\n icon: 'github',\n size: 20,\n link: git\n }\n const TAGS = {\n name: 'tags',\n icon: 'tags',\n size: 20,\n link: tags\n }\n const ISSUES = {\n name: 'issues',\n icon: 'issues',\n size: 20,\n link: issues\n }\n const MENU = {\n name: 'menu',\n icon: 'menu',\n size: 18,\n action: {\n type: 'click',\n handler: 'toolbar:action:toggle'\n }\n }\n const DOWN = {\n name: 'down',\n icon: 'down',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:down'\n }\n }\n const buttons = []\n\n buttons.push(UP)\n if (homepage) {\n buttons.push(HOME)\n }\n if (count > 0) {\n buttons.push(MENU)\n }\n if (git) {\n buttons.push(GIT)\n }\n if (tags) {\n buttons.push(TAGS)\n }\n if (issues) {\n buttons.push(ISSUES)\n }\n if (tools?.length > 0) {\n buttons.push(...tools)\n }\n buttons.push(DOWN)\n this.buttons = [...buttons]\n\n this.toolbar = new Toolbar({\n placement,\n buttons: buttons\n })\n\n return this\n }\n\n addButton(button) {\n const toolbar = this.toolbar\n const buttons = this.buttons\n buttons.splice(-1, 0, button)\n toolbar.attr({\n buttons\n })\n toolbar.refresh()\n return this\n }\n\n removeButton(name) {\n this.toolbar.remove(name)\n return this\n }\n\n toTop() {\n const afterScroll = this.attr('afterScroll')\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const afterTop = () => {\n toolbar.hide('up')\n toolbar.show('down')\n\n if (count > 0) {\n chapters.highlight(0)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'up')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(0, afterTop)\n\n return this\n }\n\n toBottom() {\n const afterScroll = this.attr('afterScroll')\n const $scrollElement = _getScrollElement(this.attr('scrollElement'))\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const top = Math.floor(\n $scrollElement.scrollHeight - $scrollElement.clientHeight\n )\n const afterDown = () => {\n toolbar.hide('down')\n toolbar.show('up')\n\n if (count > 0) {\n chapters.highlight(count - 1)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'bottom')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(top, afterDown)\n\n return this\n }\n\n scrollTo(top, afterScroll) {\n const scrollElement = this.attr('scrollElement')\n scrollTo(scrollElement, top, afterScroll)\n return this\n }\n\n toggle() {\n const position = this.attr('position')\n const toolbar = this.toolbar\n const drawer = this.drawer\n const chapters = this.chapters\n const count = this.count()\n\n if (count < 1) {\n return this\n }\n\n if (position !== 'relative') {\n chapters.toggle()\n toolbar.highlight('menu')\n } else {\n toolbar.toggle()\n\n later(() => {\n if (chapters.isInside()) {\n chapters.toggle()\n } else {\n drawer.toggle()\n }\n })\n }\n\n return this\n }\n\n destroy() {\n let anchors = this.anchors\n let chapters = this.chapters\n let drawer = this.drawer\n let toolbar = this.toolbar\n let isOutside = false\n const count = this.count()\n\n this.removeListeners()\n\n if (count > 0) {\n isOutside = chapters.isOutside()\n\n chapters.destroy()\n chapters = null\n\n if (isOutside) {\n drawer.destroy()\n drawer = null\n }\n }\n\n toolbar.destroy()\n toolbar = null\n\n anchors.destroy()\n anchors = null\n\n this.attr(Outline.DEFAULTS)\n\n return this\n }\n\n onToggle() {\n this.toggle()\n return this\n }\n\n onScrollTop() {\n this.toTop()\n return this\n }\n\n onScrollBottom() {\n this.toBottom()\n return this\n }\n\n onToolbarUpdate({ top, min, max }) {\n const toolbar = this.toolbar\n const current = Math.ceil(top)\n\n if (current <= min) {\n toolbar.hide('up')\n toolbar.show('down')\n } else if (current >= max) {\n toolbar.hide('down')\n toolbar.show('up')\n } else if (current > min && current < max) {\n toolbar.show('up')\n toolbar.show('down')\n }\n\n return this\n }\n\n addListeners() {\n subscribe('toolbar:update', this.onToolbarUpdate, this)\n subscribe('toolbar:action:up', this.onScrollTop, this)\n subscribe('toolbar:action:toggle', this.onToggle, this)\n subscribe('toolbar:action:down', this.onScrollBottom, this)\n return this\n }\n\n removeListeners() {\n unsubscribe('toolbar:update')\n unsubscribe('toolbar:action:up')\n unsubscribe('toolbar:action:toggle')\n unsubscribe('toolbar:action:down')\n return this\n }\n}\n\nOutline.DEFAULTS = {\n articleElement: '#article',\n selector: 'h2,h3,h4,h5,h6',\n title: '目录',\n scrollElement: 'html,body',\n position: 'relative',\n parentElement: '#aside',\n placement: 'rtl',\n showCode: true,\n anchorURL: '',\n stickyHeight: 0,\n homepage: '',\n git: '',\n tags: '',\n issues: '',\n tools: [],\n print: {\n element: '',\n title: ''\n },\n customClass: '',\n afterSticky: null,\n afterToggle: null,\n afterScroll: null\n}\n\nif (window.jQuery) {\n // 将 Outline 扩展为一个 jquery 插件\n // eslint-disable-next-line no-undef\n jQuery.extend(jQuery.fn, {\n outline: function (options) {\n // eslint-disable-next-line no-undef\n let $article = jQuery(this)\n\n return new Outline(\n // eslint-disable-next-line no-undef\n jQuery.extend({}, options, {\n articleElement: $article\n })\n )\n }\n })\n}\n\nexport default Outline\n","import isString from './utils/types/isString'\r\nimport isElement from './utils/types/isElement'\r\nimport createElement from './utils/dom/createElement'\r\nimport addClass from './utils/dom/addClass'\r\nimport later from './utils/lang/later'\r\n\r\nconst print = (origins, title) => {\r\n let $origins\r\n let $title\r\n let $article\r\n let $sibling\r\n let tagName\r\n\r\n if (isString(origins)) {\r\n $origins =\r\n document.querySelector(origins) || document.getElementById(origins)\r\n } else {\r\n if (isElement(origins)) {\r\n $origins = origins\r\n }\r\n }\r\n\r\n $title = $origins.querySelector('h1')\r\n\r\n $article = createElement(\r\n 'article',\r\n {\r\n className: 'outline-print'\r\n },\r\n ['']\r\n )\r\n $article.innerHTML = $origins.innerHTML\r\n\r\n if (isString(title) && !$title) {\r\n $title = createElement(\r\n 'h1',\r\n {\r\n className: 'outline-print__title'\r\n },\r\n [title]\r\n )\r\n\r\n $article.insertBefore($title, $article.firstChild)\r\n }\r\n\r\n document.body.appendChild($article)\r\n\r\n later(() => {\r\n $sibling = $article.previousElementSibling\r\n\r\n while ($sibling) {\r\n tagName = $sibling.tagName.toLowerCase()\r\n if (tagName !== 'script' && tagName !== 'style') {\r\n addClass($sibling, 'outline-print_sibling')\r\n }\r\n $sibling = $sibling.previousElementSibling\r\n }\r\n\r\n $sibling = $article.nextElementSibling\r\n\r\n while ($sibling) {\r\n tagName = $sibling.tagName.toLowerCase()\r\n if (tagName !== 'script' && tagName !== 'style') {\r\n addClass($sibling, 'outline-print_sibling')\r\n }\r\n $sibling = $sibling.nextElementSibling\r\n }\r\n }, 500)\r\n}\r\n\r\nexport default print\r\n"],"names":["isString","str","hasOwn","obj","prop","hasOwnProperty","Object","prototype","call","toString","val","apply","isFunction","isObject","o","Base","constructor","options","this","attrs","initialize","attr","render","addListeners","value","origin","source","keys","forEach","arguments","length","destroy","removeListeners","reload","isElement","nodeName","tagName","nodeType","later","fn","delay","setTimeout","easeInQuad","x","_getScrollElement","scrollElement","$rootElements","$scrollElement","document","querySelector","querySelectorAll","scrollTop","scrollTo","top","afterStop","step","distance","MAX_HEIGHT","scrollHeight","MAX_TOP","stop","play","requestAnimationFrame","offsetTop","el","offsetParent","matches","selector","sel","replace","msMatchesSelector","getParentOrHost","host","parentNode","CAPTURE_EVENTS","_off","type","capture","indexOf","_delegateListener","listeners","_listeners","index","listener","i","handler","splice","_delete","removeEventListener","purgeElement","recurse","$element","$children","childNodes","filter","getListeners","$child","off","on","data","context","once","evt","target","getTarget","delegateTarget","ctx","includeCTX","startsWith","closest","overrideContext","push","addEventListener","stopPropagation","preventDefault","_subscribers","_hasDirectSubscribersFor","topic","has","isDirect","found","position","lastIndexOf","substring","_hasSubscribers","emit","async","execute","subscriber","message","callback","deliver","isArray","Array","SYMBOLS","getSymbols","name","iconSet","patternName","patternSet","find","symbol","fullName","exec","iconName","getSymbol","paint","$body","body","$icons","symbols","add","innerHTML","join","createElement","insertBefore","firstChild","trim","isDOM","isHTMLCollection","fragment","isTextNode","setAttribute","toLowerCase","style","cssText","className","children","$fragment","createDocumentFragment","$el","isValidChild","child","append","createTextNode","appendChild","every","isSVG","pattern","RegExp","test","icon","size","color","width","height","defaultRules","cssRules","$icon","$svg","binds","svg","hasClass","allClass","classList","contains","removeClass","remove","_resetHeading","$heading","hasAnchor","isAtStart","CLS_HEADING","text","$anchor","removeAttribute","removeChild","getChapters","headings","showCode","previous","level","chapters","heading","headingLevel","current","parseInt","pid","differ","_getChapterParentIdByDiffer","id","rel","groups","group","JSON","stringify","cb","code","String","c","b","_getChaptersWithCode","Anchors","super","DEFAULTS","$articleElement","$headings","created","articleElement","isTreeStructured","list","nodeKey","parentKey","map","roots","item","node","toTree","count","mounted","anchorURL","chapterCode","headingId","href","_updateHeading","after","beforeDestroy","afterDestroy","onAnchorTrigger","afterScroll","stickyHeight","max","clientHeight","publish","min","addClass","setProperty","documentElement","zIndex","idx","Drawer","title","closed","$modal","$header","$title","$close","$main","$footer","$overlay","setTitle","isClosed","placement","hasClose","hasOverlay","hasOffset","hasPadding","autoHeight","customClass","open","opened","close","toggle","afterToggle","onClose","afterClosed","afterOpened","at","getStyle","ruleName","getComputedStyle","Chapters","$list","$placeholder","$parentElement","active","offsetWidth","$active","scrollTimer","resizeTimer","playing","Observer","parentElement","$parent","isSticky","isFixed","isInside","isOutside","_paintEdge","contents","calculateStickyHeight","byId","chapter","$text","$link","$code","$li","$ul","_paintChapters","positionPlaceholder","sticky","onObserver","mainPaddingTop","mainBorderTop","placeholderPaddingTop","placeholderMarginTop","placeholderBorderTop","offsetHeight","highlight","HIGHLIGHT","getAttribute","afterSticky","FIXED","isStickying","Math","window","innerHeight","show","FOLDED","HIDDEN","hide","clearTimeout","timer","props","root","rootMargin","IntersectionObserver","entries","entry","intersectionRatio","$root","section","observe","intersection","onSelect","split","onScroll","onResize","unobserve","_createButton","button","rounded","link","$button","disabled","DISABLED","Toolbar","buttons","isDisabled","option","ACTIVE","$buttons","disable","action","switch","enabled","enable","refresh","command","afterDisabled","afterEnabled","guid","uuid","prefix","token","subject","_removeSubscriber","execution","j","_removeSubscriberByToken","Outline","anchors","drawer","toolbar","getElementById","_renderPrint","_renderAnchors","_renderChapters","_renderToolbar","onToolbarUpdate","element","origins","$origins","$article","$sibling","previousElementSibling","nextElementSibling","print","CHAPTERS_OPTIONS","homepage","git","tags","issues","tools","HOME","GIT","TAGS","ISSUES","MENU","addButton","removeButton","toTop","toBottom","floor","onToggle","onScrollTop","onScrollBottom","ceil","subscribe","unsubscribe","jQuery","extend","outline"],"mappings":"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"} \ No newline at end of file diff --git a/docs/relative.html b/docs/relative.html index 43192c90..78d81667 100644 --- a/docs/relative.html +++ b/docs/relative.html @@ -150,7 +150,22 @@ } } ] -})

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
+})

print

Description

Type:
Object
Default:
{element: '', title: ''}

可选,自定义的是否自动为文章页面创建打印样式。

element:
(必须)要打印的文章区域,DOM 元素或者选择器字符串。
title:
(可选)要打印的文章标题。如果 element 区域有 h1 标签则无需设置。
const defaults = Outline.DEFAULTS
+let outline
+
+defaults.position = 'sticky'
+defaults.stickyHeight = 86
+defaults.parentElement = '#aside'
+defaults.scrollElement = '#main'
+defaults.homepage = './index.html'
+defaults.git = 'https://github.com/yaohaixiao/outline.js'
+defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags'
+defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues'
+defaults.print = {
+  element: '#article',
+  title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具'
+}
+outline = new Outline(Outline.DEFAULTS)

演示地址:https://yaohaixiao.github.io/outline.js/flex.html

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
 new Outline(Outline.DEFAULTS)
 
 // Customized
@@ -256,20 +271,28 @@
 }
 outline = new Outline(Outline.DEFAULTS)

Properties

outline.js 重构后,对外放 4 个重要的属性:anchors、drawer、chapters 和 toolbar。它们都是独立的对象实例,提供了 outline.js 所有的能力(属性和方法)。

DEFAULTS

Description

Type:
Object

静态属性,存储的是 Outline 对象默认配置选项:

Outline.DEFAULTS = {
   articleElement: '#article',
-  selector: 'h2,h3,h4,h5,h6',
-  title: '目录',
-  scrollElement: 'html,body',
-  position: 'relative',
-  parentElement: '#aside',
-  placement: 'rtl',
-  stickyHeight: 0,
-  showCode: true,
-  anchorURL: '',
-  homepage: '',
-  git: '',
-  tags: '',
-  issues: '',
-  customClass: ''
+    selector: 'h2,h3,h4,h5,h6',
+    title: '目录',
+    scrollElement: 'html,body',
+    position: 'relative',
+    parentElement: '#aside',
+    placement: 'rtl',
+    showCode: true,
+    anchorURL: '',
+    stickyHeight: 0,
+    homepage: '',
+    git: '',
+    tags: '',
+    issues: '',
+    tools: [],
+    print: {
+      element: '',
+      title: ''
+    },
+    customClass: '',
+    afterSticky: null,
+    afterToggle: null,
+    afterScroll: null
 }

attrs

Description

Type:
Object

存储的是 Outline 对象当前使用中的配置选项:

说明:建议使用 attr(prop) 方法来获取属性,避免直接调用属性。

// 设置默认配置项
 const outline = new Outline(Outline.DEFAULTS)
 
diff --git a/docs/sticky.html b/docs/sticky.html
index 58502046..d8e2146b 100644
--- a/docs/sticky.html
+++ b/docs/sticky.html
@@ -150,7 +150,22 @@
       }
     }
   ]
-})

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
+})

print

Description

Type:
Object
Default:
{element: '', title: ''}

可选,自定义的是否自动为文章页面创建打印样式。

element:
(必须)要打印的文章区域,DOM 元素或者选择器字符串。
title:
(可选)要打印的文章标题。如果 element 区域有 h1 标签则无需设置。
const defaults = Outline.DEFAULTS
+let outline
+
+defaults.position = 'sticky'
+defaults.stickyHeight = 86
+defaults.parentElement = '#aside'
+defaults.scrollElement = '#main'
+defaults.homepage = './index.html'
+defaults.git = 'https://github.com/yaohaixiao/outline.js'
+defaults.tags = 'https://github.com/yaohaixiao/outline.js/tags'
+defaults.issues = 'https://github.com/yaohaixiao/outline.js/issues'
+defaults.print = {
+  element: '#article',
+  title: 'Outline.js 自动生成文章导读(Table of Contents)导航的 JavaScript 工具'
+}
+outline = new Outline(Outline.DEFAULTS)

演示地址:https://yaohaixiao.github.io/outline.js/flex.html

customClass

Description

Type:
String
Default:
''

可选,(DIYer福利)设置自定义样式的 class 名称:

  • '' - 采用默认 outline.js 的 UI 界面(默认值);
  • 设置自定义样式 - 自己根据需求设置个性化的 UI 界面;
// Default UI
 new Outline(Outline.DEFAULTS)
 
 // Customized
@@ -256,20 +271,28 @@
 }
 outline = new Outline(Outline.DEFAULTS)

Properties

outline.js 重构后,对外放 4 个重要的属性:anchors、drawer、chapters 和 toolbar。它们都是独立的对象实例,提供了 outline.js 所有的能力(属性和方法)。

DEFAULTS

Description

Type:
Object

静态属性,存储的是 Outline 对象默认配置选项:

Outline.DEFAULTS = {
   articleElement: '#article',
-  selector: 'h2,h3,h4,h5,h6',
-  title: '目录',
-  scrollElement: 'html,body',
-  position: 'relative',
-  parentElement: '#aside',
-  placement: 'rtl',
-  stickyHeight: 0,
-  showCode: true,
-  anchorURL: '',
-  homepage: '',
-  git: '',
-  tags: '',
-  issues: '',
-  customClass: ''
+    selector: 'h2,h3,h4,h5,h6',
+    title: '目录',
+    scrollElement: 'html,body',
+    position: 'relative',
+    parentElement: '#aside',
+    placement: 'rtl',
+    showCode: true,
+    anchorURL: '',
+    stickyHeight: 0,
+    homepage: '',
+    git: '',
+    tags: '',
+    issues: '',
+    tools: [],
+    print: {
+      element: '',
+      title: ''
+    },
+    customClass: '',
+    afterSticky: null,
+    afterToggle: null,
+    afterScroll: null
 }

attrs

Description

Type:
Object

存储的是 Outline 对象当前使用中的配置选项:

说明:建议使用 attr(prop) 方法来获取属性,避免直接调用属性。

// 设置默认配置项
 const outline = new Outline(Outline.DEFAULTS)
 
diff --git a/gulpfile.js b/gulpfile.js
index 8a4ba018..c64ad1bf 100644
--- a/gulpfile.js
+++ b/gulpfile.js
@@ -93,7 +93,7 @@ const minifySourcesStyle = () => {
       './chapters.css',
       './drawer.css',
       './toolbar.css',
-      './outline.css'
+      './outline.css',
     ], {
       allowEmpty: true
     })
diff --git a/outline.css b/outline.css
index 48f8ed64..a5fdffaa 100644
--- a/outline.css
+++ b/outline.css
@@ -679,5 +679,43 @@
 ::-webkit-scrollbar-thumb:hover {
   background-color: rgba(0, 0, 0, 0.35);
 }
+.outline-print {
+  display: none;
+}
+@media print {
+  html,
+  body {
+    height: initial !important;
+  }
+  .outline-print {
+    display: block !important;
+    overflow: hidden;
+  }
+  .outline-print h1 {
+    text-align: center;
+    font-size: 20pt;
+    font-family: 'Microsoft YaHei UI', Arial, sans-serif;
+    font-weight: normal;
+  }
+  .outline-print pre {
+    padding: 1em !important;
+    border: 1px solid #ddd !important;
+    border-radius: 4px !important;
+  }
+  .outline-print pre,
+  .outline-print code {
+    background-color: #fff !important;
+  }
+  .outline-print table,
+  .outline-print img,
+  .outline-print svg {
+    -webkit-column-break-inside: avoid;
+       -moz-column-break-inside: avoid;
+            break-inside: avoid;
+  }
+  .outline-print_sibling {
+    display: none !important;
+  }
+}
 
-/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["variables.less","../../<input css 5>","icons.less","anchors.less","drawer.less","shadow.less","chapters.less","ellipsis.less","toolbar.less","scrollbar.less"],"names":[],"mappings":"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","file":"outline.css","sourcesContent":[":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ====== 阴影样式设置函数 ====== */\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n"]} */
+/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["variables.less","../../<input css 5>","icons.less","anchors.less","drawer.less","shadow.less","chapters.less","ellipsis.less","toolbar.less","scrollbar.less","print.less"],"names":[],"mappings":"AAAA;EACE,uBAAA;EACA,8BAAA;EACA,+BAAA;CCCD;AACD,mDAAmD;AACnD;;;;;GAKG;AACH,0BAA0B;AAC1B;;;;;GAKG;AACH,4BAA4B;AAC5B,kDAAkD;ACnBlD;EACE,mBAAA;EACA,WAAA;EACA,sBAAA;EACA,uBAAA;EACA,WAAA;EACA,YAAA;EACA,iBAAA;CDqBD;ACnBC;EACE,mBAAA;EACA,WAAA;EACA,SAAA;EACA,UAAA;EACA,WAAA;EACA,YAAA;EACA,mBAAA;EACA,yCAAA;UAAA,iCAAA;EACA,iBAAA;CDqBH;AEtCD;EACE,mBAAA;EACA,WAAA;EACA,iBAAA;CFwCD;AEtCC;EACE,cAAA;CFwCH;AEtCG;;;EAGE,YAAA;EACA,sBAAA;CFwCL;AErCG;EACE,eAAA;CFuCL;AEnCC;EAEI,sBAAA;CFoCL;AE/BG;EACE,kBAAA;CFiCL;AEnCC;EAMI,mBAAA;EACA,WAAA;EACA,SAAA;EACA,oCAAA;UAAA,4BAAA;EACA,WAAA;CFgCL;AGlED;EACE,mBAAA;EACA,YAAA;EACA,OAAA;EACA,QAAA;EACA,UAAA;EACA,YAAA;EACA,aAAA;EACA,+BAAA;UAAA,uBAAA;EACA,mBAAA;EACA,iBAAA;CHoED;AGlEC;ECNA,wCAAA;UAAA,gCAAA;EDQE,qBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,6BAAA;EAAA,8BAAA;MAAA,2BAAA;UAAA,uBAAA;EACA,sBAAA;MAAA,kBAAA;EACA,mBAAA;EACA,YAAA;EACA,aAAA;EACA,uBAAA;EACA,kCAAA;UAAA,0BAAA;EACA,iBAAA;CHoEH;AGjEC;;;EAGE,YAAA;EACA,+BAAA;UAAA,uBAAA;CHmEH;AGhEC;;EAEE,qBAAA;MAAA,eAAA;CHkEH;AG/DC;;;EAGE,gBAAA;CHiEH;AG9DC;;EAEE,mBAAA;EACA,WAAA;EACA,eAAA;EACA,aAAA;EACA,kBAAA;EACA,iBAAA;CHgEH;AG7DC;EACE,gBAAA;EACA,iBAAA;EACA,eAAA;EACA,+BAAA;UAAA,uBAAA;EACA,iCAAA;CH+DH;AG5DC;EACE,mBAAA;EACA,WAAA;EACA,SAAA;EACA,YAAA;EACA,YAAA;EACA,aAAA;EACA,kBAAA;EACA,YAAA;EACA,gBAAA;EACA,mBAAA;EACA,gBAAA;EACA,oCAAA;UAAA,4BAAA;EACA,iBAAA;CH8DH;AG3EC;EAgBI,mBAAA;EACA,WAAA;EACA,OAAA;EACA,QAAA;CH8DL;AG3DG;EACE,YAAA;CH6DL;AGzDC;EACE,oBAAA;MAAA,YAAA;UAAA,QAAA;EACA,eAAA;CH2DH;AGxDC;EACE,eAAA;EACA,kBAAA;EACA,iBAAA;CH0DH;AGvDC;EACE,YAAA;EACA,mBAAA;EACA,WAAA;EACA,OAAA;EACA,QAAA;EACA,YAAA;EACA,aAAA;EACA,uBAAA;EACA,aAAA;EACA,iBAAA;CHyDH;AGnDK;;EACE,aAAA;CHsDP;AGnDK;;EACE,aAAA;CHsDP;AGnDK;;EACE,aAAA;CHsDP;AGnDK;;EACE,aAAA;CHsDP;AGnDK;;EACE,aAAA;CHsDP;AGnDK;;EACE,aAAA;CHsDP;AGjDC;EACE,+BAAA;CHmDH;AG/CO;EACE,cAAA;CHiDT;AG5CO;EACE,cAAA;CH8CT;AGzCO;EACE,cAAA;CH2CT;AGtCO;EACE,cAAA;CHwCT;AGnCO;EACE,cAAA;CHqCT;AGhCO;EACE,cAAA;CHkCT;AG5BC;EACE,gCAAA;CH8BH;AG1BO;EACE,aAAA;CH4BT;AGvBO;EACE,aAAA;CHyBT;AGpBO;EACE,aAAA;CHsBT;AGjBO;EACE,aAAA;CHmBT;AGdO;EACE,aAAA;CHgBT;AGXO;EACE,aAAA;CHaT;AGPC;;EAEE,QAAA;EACA,YAAA;CHSH;AGNK;;EACE,cAAA;CHSP;AGNK;;EACE,cAAA;CHSP;AGNK;;EACE,cAAA;CHSP;AGNK;;EACE,cAAA;CHSP;AGNK;;EACE,cAAA;CHSP;AGNK;;EACE,cAAA;CHSP;AGJC;EACE,iCAAA;CHMH;AGFO;EACE,YAAA;CHIT;AGCO;EACE,YAAA;CHCT;AGIO;EACE,YAAA;CHFT;AGOO;EACE,YAAA;CHLT;AGUO;EACE,YAAA;CHRT;AGaO;EACE,YAAA;CHXT;AGiBC;EACE,aAAA;EACA,8BAAA;CHfH;AGmBO;EACE,eAAA;CHjBT;AGsBO;EACE,eAAA;CHpBT;AGyBO;EACE,eAAA;CHvBT;AG4BO;EACE,eAAA;CH1BT;AG+BO;EACE,eAAA;CH7BT;AGkCO;EACE,eAAA;CHhCT;AGsCC;EACE,oBAAA;EACA,+BAAA;CHpCH;AGsCG;EACE,gBAAA;CHpCL;AGsCK;EACE,SAAA;CHpCP;AGuCK;EACE,QAAA;CHrCP;AGwCK;EACE,OAAA;CHtCP;AGyCK;EACE,UAAA;CHvCP;AG8CK;;EAEE,yBAAA;EACA,SAAA;EACA,oCAAA;UAAA,4BAAA;CH5CP;AG+CK;;EAEE,wBAAA;EACA,UAAA;EACA,oCAAA;UAAA,4BAAA;CH7CP;AGkDS;EACE,WAAA;CHhDX;AGmDS;EACE,UAAA;CHjDX;AGoDS;EACE,SAAA;CHlDX;AGqDS;EACE,YAAA;CHnDX;AG4DK;;EAEE,aAAA;EACA,6BAAA;CH1DP;AG+DC;EACE,WAAA;CH7DH;AKnWD;EACE,mBAAA;EACA,WAAA;EACA,UAAA;EACA,qCAAA;EACA,kCAAA;UAAA,0BAAA;EACA,eAAA;CLqWD;AKnWC;EACE,eAAA;EACA,aAAA;EACA,kBAAA;EACA,gBAAA;EACA,iCAAA;EACA,gBAAA;EACA,iBAAA;EACA,iBAAA;CLqWH;AKlWC;EACE,mBAAA;EACA,WAAA;EACA,UAAA;EACA,iBAAA;CLoWH;AKjWC;;;EAGE,mBAAA;EACA,WAAA;EACA,UAAA;EACA,WAAA;EACA,sBAAA;EACA,iBAAA;CLmWH;AKhWC;EACE,iBAAA;CLkWH;AK/VC;EACE,kBAAA;CLiWH;AK9VC;EACE,UAAA;EACA,kBAAA;EACA,gBAAA;EACA,iBAAA;CLgWH;AK7VC;EACE,mBAAA;EACA,WAAA;EACA,OAAA;EACA,QAAA;EACA,YAAA;EACA,aAAA;EACA,0BAAA;EACA,+BAAA;EACA,kCAAA;UAAA,0BAAA;EACA,+BAAA;UAAA,uBAAA;EACA,iBAAA;CL+VH;AK5VC;EC7DA,oBAAA;EACA,wBAAA;EACA,iBAAA;ED6DE,eAAA;EACA,iBAAA;CLgWH;AK9VG;;;EAGE,sBAAA;EACA,YAAA;CLgWL;AK7VG;EACE,eAAA;CL+VL;AK3VC;EACE,qBAAA;CL6VH;AKxVK;;;EAGE,eAAA;EACA,iBAAA;CL0VP;AKrVC;;EAEE,qBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,sBAAA;MAAA,kBAAA;EACA,6BAAA;EAAA,8BAAA;MAAA,2BAAA;UAAA,uBAAA;EACA,+BAAA;EACA,OAAA;EACA,iBAAA;CLuVH;AKpVK;;;;EAEE,+BAAA;UAAA,uBAAA;CLwVP;AKrVK;;EACE,qBAAA;MAAA,eAAA;CLwVP;AKrVK;;EACE,oBAAA;MAAA,YAAA;UAAA,QAAA;EACA,eAAA;CLwVP;AKnVC;EACE,iBAAA;EACA,yCAAA;CLqVH;AKlVC;EACE,gBAAA;EACA,iBAAA;CLoVH;AKjVC;EACE,cAAA;CLmVH;AKhVC;EACE,SAAA;CLkVH;AACD,kDAAkD;AO9dlD;EACE,gBAAA;EACA,eAAA;EACA,UAAA;EACA,kCAAA;UAAA,0BAAA;EACA,iBAAA;CPgeD;AO9dC;EHDA,wCAAA;UAAA,gCAAA;EGGE,mBAAA;EACA,WAAA;EACA,aAAA;EACA,YAAA;EACA,aAAA;EACA,0BAAA;EACA,mBAAA;EACA,+BAAA;UAAA,uBAAA;EACA,uBAAA;EACA,gBAAA;EACA,mBAAA;EACA,YAAA;EACA,iBAAA;CPgeH;AO9dG;EACE,eAAA;EACA,sBAAA;CPgeL;AO7dG;EACE,cAAA;CP+dL;AO1dG;;;EAGE,YAAA;EACA,sBAAA;CP4dL;AOzdG;EACE,eAAA;CP2dL;AOvdC;EACE,mBAAA;EACA,WAAA;EACA,SAAA;EACA,UAAA;EACA,YAAA;EACA,aAAA;EACA,yCAAA;UAAA,iCAAA;EACA,mBAAA;EACA,iBAAA;CPydH;AOpdK;EACE,YAAA;EACA,0BAAA;EACA,sBAAA;CPsdP;AOpdO;EACE,YAAA;CPsdT;AOhdK;;;EAGE,YAAA;CPkdP;AO5cG;EACE,oBAAA;CP8cL;AOvcK;;;;;;;;EAIE,oBAAA;EACA,YAAA;CP6cP;AO3cO;;;;;;;;EACE,YAAA;CPodT;AOhdK;;EACE,0BAAA;CPmdP;AO9cC;;EAEE,UAAA;EACA,oCAAA;UAAA,4BAAA;CPgdH;AOndC;;EAMI,sBAAA;CPidL;AO7cC;EACE,UAAA;CP+cH;AO7cG;EACE,WAAA;CP+cL;AO3cC;EACE,aAAA;CP6cH;AO3cG;EACE,cAAA;CP6cL;AOzcC;;EAEE,oCAAA;UAAA,4BAAA;EACA,YAAA;CP2cH;AOxcC;EACE,SAAA;EACA,YAAA;CP0cH;AOxcG;EACE,aAAA;CP0cL;AOtcC;EACE,SAAA;EACA,WAAA;CPwcH;AOtcG;EACE,YAAA;CPwcL;AO/bK;;;;EACE,cAAA;CPocP;AACD,2BAA2B;AQ3mB3B;EACE,WAAA;EACA,YAAA;EACA,2BAAA;CR6mBD;AQ1mBD;EACE,2BAAA;CR4mBD;AQzmBD;EACE,sCAAA;EACA,2BAAA;CR2mBD;AQxmBD;EACE,sCAAA;EACA,2BAAA;CR0mBD;AQvmBD;EACE,sCAAA;CRymBD;AQtmBD;EACE,sCAAA;CRwmBD;AShoBD;EACE,cAAA;CTkoBD;AS/nBD;EACE;;IAEE,2BAAA;GTioBD;ES9nBD;IACE,0BAAA;IACA,iBAAA;GTgoBD;ESloBD;IAKI,mBAAA;IACA,gBAAA;IACA,qDAAA;IACA,oBAAA;GTgoBH;ESxoBD;IAYI,wBAAA;IACA,kCAAA;IACA,8BAAA;GT+nBH;ES7oBD;;IAmBI,kCAAA;GT8nBH;ESjpBD;;;IAyBI,mCAAA;OAAA,gCAAA;YAAA,oBAAA;GT6nBH;ES1nBC;IACE,yBAAA;GT4nBH;CACF","file":"outline.css","sourcesContent":[":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ====== 阴影样式设置函数 ====== */\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.outline-print {\n  display: none;\n}\n@media print {\n  html,\n  body {\n    height: initial !important;\n  }\n  .outline-print {\n    display: block !important;\n    overflow: hidden;\n  }\n  .outline-print h1 {\n    text-align: center;\n    font-size: 20pt;\n    font-family: 'Microsoft YaHei UI', Arial, sans-serif;\n    font-weight: normal;\n  }\n  .outline-print pre {\n    padding: 1em !important;\n    border: 1px solid #ddd !important;\n    border-radius: 4px !important;\n  }\n  .outline-print pre,\n  .outline-print code {\n    background-color: #fff !important;\n  }\n  .outline-print table,\n  .outline-print img,\n  .outline-print svg {\n    break-inside: avoid;\n  }\n  .outline-print_sibling {\n    display: none !important;\n  }\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","@import './colors';\r\n\r\n.outline-print {\r\n  display: none;\r\n}\r\n\r\n@media print {\r\n  html,\r\n  body {\r\n    height: initial !important;\r\n  }\r\n\r\n  .outline-print {\r\n    display: block !important;\r\n    overflow: hidden;\r\n\r\n    h1 {\r\n      text-align: center;\r\n      font-size: 20pt;\r\n      font-family: 'Microsoft YaHei UI', Arial, sans-serif;\r\n      font-weight: normal;\r\n    }\r\n\r\n    pre {\r\n      padding: 1em !important;\r\n      border: 1px solid @border_color !important;\r\n      border-radius: 4px !important;\r\n    }\r\n\r\n    pre,\r\n    code {\r\n      background-color: @white !important;\r\n    }\r\n\r\n    table,\r\n    img,\r\n    svg {\r\n      break-inside: avoid;\r\n    }\r\n\r\n    &_sibling {\r\n      display: none !important;\r\n    }\r\n  }\r\n}\r\n"]} */
diff --git a/outline.min.css b/outline.min.css
index c87e800a..464c26d8 100644
--- a/outline.min.css
+++ b/outline.min.css
@@ -1,2 +1,2 @@
-.outline-icon,.outline-icon__svg{width:1em;height:1em;overflow:hidden}.outline-icon__svg,.outline-toolbar__icon{-webkit-transform:translate(-50%,-50%);fill:currentcolor}.outline-chapters__title,.outline-drawer__title,.outline-drawer_ttb{border-bottom:1px solid #dcdfe6}:root{--outline-zIndex:2000;--outline-sticky-height:100%;--outline-chapters-width:100%}.outline-icon{position:relative;z-index:1;display:inline-block;vertical-align:middle}.outline-icon__svg{position:absolute;z-index:2;top:50%;left:50%;transform:translate(-50%,-50%)}.outline-heading{position:relative;z-index:1;overflow:hidden}.outline-heading__anchor{display:none}.outline-heading__anchor:hover,.outline-heading__anchor:link,.outline-heading__anchor:visited{color:#999;text-decoration:none}.outline-heading__anchor:hover{color:#1f8dd6}.outline-heading:hover .outline-heading__anchor{display:inline-block}.outline-heading_start:hover{overflow:visible}.outline-heading_start .outline-heading__anchor{position:absolute;z-index:2;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);left:-1em}.outline-drawer{position:relative;z-index:-1;top:0;left:0;margin:0;width:100%;height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;visibility:hidden;overflow:hidden}.outline-drawer__modal{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-ms-flex-wrap:nowrap;flex-wrap:nowrap;position:absolute;z-index:21;height:100%;background-color:#fff;-webkit-transition-duration:.4s;transition-duration:.4s;overflow:hidden}.outline-drawer__footer,.outline-drawer__header,.outline-drawer__main{width:100%;-webkit-box-sizing:border-box;box-sizing:border-box}.outline-drawer__footer,.outline-drawer__header{-ms-flex-negative:0;flex-shrink:0}.outline-drawer__footer,.outline-drawer__main,.outline-drawer__title{padding:0 16px}.outline-drawer__header,.outline-drawer__title{position:relative;z-index:1;margin:0 auto;height:52px;line-height:52px;overflow:hidden}.outline-drawer__title{font-size:16px;font-weight:400;margin:0 16px;-webkit-box-sizing:border-box;box-sizing:border-box}.outline-drawer__close{position:absolute;z-index:2;top:50%;right:12px;width:20px;height:20px;line-height:20px;color:#999;font-size:20px;text-align:center;cursor:pointer;-webkit-transform:translateY(-50%);transform:translateY(-50%);overflow:hidden}.outline-drawer__close .outline-icon{position:absolute;z-index:2;top:0;left:0}.outline-drawer__close:hover{color:#666}.outline-drawer__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-drawer__footer{margin:0 auto;text-align:right;overflow:hidden}.outline-drawer__overlay{content:'';position:relative;z-index:1;top:0;left:0;width:100%;height:100%;background-color:#fff;opacity:.1;overflow:hidden}.outline-drawer_ltr.outline-drawer_tiny,.outline-drawer_rtl.outline-drawer_tiny{width:280px}.outline-drawer_ltr.outline-drawer_mini,.outline-drawer_rtl.outline-drawer_mini{width:480px}.outline-drawer_ltr.outline-drawer_small,.outline-drawer_rtl.outline-drawer_small{width:540px}.outline-drawer_ltr.outline-drawer_regular,.outline-drawer_rtl.outline-drawer_regular{width:680px}.outline-drawer_ltr.outline-drawer_medium,.outline-drawer_rtl.outline-drawer_medium{width:720px}.outline-drawer_ltr.outline-drawer_large,.outline-drawer_rtl.outline-drawer_large{width:960px}.outline-drawer_rtl{border-left:1px solid #dcdfe6}.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed{right:-290px}.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed{right:-490px}.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed{right:-550px}.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed{right:-690px}.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed{right:-730px}.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed{right:-970px}.outline-drawer_ltr{border-right:1px solid #dcdfe6}.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed{left:-290px}.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed{left:-490px}.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed{left:-550px}.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed{left:-690px}.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed{left:-730px}.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed{left:-970px}.outline-drawer_btt,.outline-drawer_ttb{left:0;width:100%}.outline-drawer_btt.outline-drawer_tiny,.outline-drawer_ttb.outline-drawer_tiny{height:240px}.outline-drawer_btt.outline-drawer_mini,.outline-drawer_ttb.outline-drawer_mini{height:320px}.outline-drawer_btt.outline-drawer_small,.outline-drawer_ttb.outline-drawer_small{height:360px}.outline-drawer_btt.outline-drawer_regular,.outline-drawer_ttb.outline-drawer_regular{height:400px}.outline-drawer_btt.outline-drawer_medium,.outline-drawer_ttb.outline-drawer_medium{height:440px}.outline-drawer_btt.outline-drawer_large,.outline-drawer_ttb.outline-drawer_large{height:480px}.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed{top:-250px}.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed{top:-330px}.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed{top:-370px}.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed{top:-410px}.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed{top:-450px}.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed{top:-490px}.outline-drawer_btt{top:initial;border-top:1px solid #dcdfe6}.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed{bottom:-250px}.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed{bottom:-330px}.outline-drawer_btt.outline-drawer_small.outline-drawer_closed{bottom:-370px}.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed{bottom:-410px}.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed{bottom:-450px}.outline-drawer_btt.outline-drawer_large.outline-drawer_closed{bottom:-490px}.outline-drawer_opened{visibility:visible;z-index:var(--outline-zIndex)}.outline-drawer_opened.outline-drawer{position:fixed}.outline-drawer_opened.outline-drawer_rtl{right:0}.outline-drawer_opened.outline-drawer_ltr{left:0}.outline-drawer_opened.outline-drawer_ttb{top:0}.outline-drawer_opened.outline-drawer_btt{bottom:0}.outline-drawer_offset.outline-drawer_ltr,.outline-drawer_offset.outline-drawer_rtl{height:calc(100% - 4em);top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.outline-drawer_offset.outline-drawer_btt,.outline-drawer_offset.outline-drawer_ttb{width:calc(100% - 4em);left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl{right:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr{left:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb{top:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt{bottom:2em}.outline-drawer_auto.outline-drawer_ltr,.outline-drawer_auto.outline-drawer_rtl{height:auto;max-height:calc(100% - 4em)}.outline-drawer_full{padding:0}.outline-chapters{position:relative;z-index:1;margin:0;width:var(--outline-chapters-width);-webkit-transition-duration:.3s;transition-duration:.3s;overflow:auto}.outline-chapters__title{margin:0 16px;height:40px;line-height:40px;padding:0 16px;font-size:16px;font-weight:400;overflow:hidden}.outline-chapters__main{position:relative;z-index:1;margin:0;overflow:hidden}.outline-chapters__item,.outline-chapters__list,.outline-chapters__subject{position:relative;z-index:2;margin:0;padding:0;list-style-type:none;overflow:hidden}.outline-chapters__list{padding:.5em 0}.outline-chapters__subject{padding-left:1em}.outline-chapters__item{margin:0;line-height:30px;font-size:13px;overflow:hidden}.outline-chapters__placeholder{position:absolute;z-index:1;top:0;left:0;width:100%;height:30px;background-color:#f7f8f9;border-left:2px solid #058942;-webkit-transition-duration:.2s;transition-duration:.2s;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.outline-chapters__anchor{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:block;padding:0 1.5em}.outline-chapters__anchor:hover,.outline-chapters__anchor:link,.outline-chapters__anchor:visited{text-decoration:none;color:#555}.outline-chapters__anchor:hover{color:#058942}.outline-chapters__code{padding-right:.5em}.outline-chapters_active.outline-chapters__anchor:hover,.outline-chapters_active.outline-chapters__anchor:link,.outline-chapters_active.outline-chapters__anchor:visited{color:#058942;font-weight:400}.outline-chapters_fixed,.outline-chapters_sticky{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;z-index:var(--outline-zIndex);top:0;overflow:hidden}.outline-chapters_hidden,.outline-toolbar__button.hide{display:none}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__main,.outline-chapters_sticky .outline-chapters__title{-webkit-box-sizing:border-box;box-sizing:border-box}.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__title{-ms-flex-negative:0;flex-shrink:0}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_sticky .outline-chapters__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-chapters_sticky{position:sticky;max-height:var(--outline-sticky-height)}.outline-chapters_fixed{position:fixed;max-height:100%}.outline-chapters_folded{width:0}.outline-toolbar{position:fixed;z-index:99999;margin:0;-webkit-transition-duration:.3s;transition-duration:.3s;overflow:hidden}.outline-toolbar__button{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;position:relative;z-index:1;margin:10px;width:36px;height:36px;border:1px solid #dcdfe6;border-radius:3px;-webkit-box-sizing:border-box;box-sizing:border-box;background-color:#fff;cursor:pointer;text-align:center;color:#555;overflow:hidden}.outline-toolbar__button:hover{color:#058942;border-color:#058942}.outline-toolbar__anchor:hover,.outline-toolbar__anchor:link,.outline-toolbar__anchor:visited{color:#999;text-decoration:none}.outline-toolbar__anchor:hover{color:#058942}.outline-toolbar__icon{position:absolute;z-index:2;top:50%;left:50%;width:20px;height:20px;transform:translate(-50%,-50%);overflow:hidden}.outline-toolbar_active.outline-toolbar__button{color:#fff;background-color:#058942;border-color:#058942}.outline-toolbar_active .outline-toolbar__anchor:hover,.outline-toolbar_active .outline-toolbar__anchor:link,.outline-toolbar_active .outline-toolbar__anchor:visited,.outline-toolbar_active.outline-toolbar__button:hover{color:#fff}.outline-toolbar_rounded.outline-toolbar__button{border-radius:18px}.outline-toolbar_disabled .outline-toolbar__anchor:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link,.outline-toolbar_disabled .outline-toolbar__anchor:visited,.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__anchor:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link,.outline-toolbar_disabled.outline-toolbar__anchor:visited,.outline-toolbar_disabled.outline-toolbar__button{cursor:not-allowed;color:#999}.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled .outline-toolbar__button:hover,.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled.outline-toolbar__button:hover{color:#999}.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__button{background-color:#f5f5f5}.outline-toolbar_btt,.outline-toolbar_ttb{left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-toolbar_btt .outline-toolbar__button,.outline-toolbar_ttb .outline-toolbar__button{display:inline-block}.outline-toolbar_ttb{top:12px}.outline-toolbar_ttb.outline-toolbar_hidden{top:-56px}.outline-toolbar_btt{bottom:12px}.outline-toolbar_btt.outline-toolbar_hidden{bottom:-56px}.outline-toolbar_ltr,.outline-toolbar_rtl{-webkit-transform:translateY(-50%);transform:translateY(-50%);width:56px}.outline-toolbar_rtl{top:50%;right:12px}.outline-toolbar_rtl.outline-toolbar_hidden{right:-86px}.outline-toolbar_ltr{top:50%;left:12px}.outline-toolbar_ltr.outline-toolbar_hidden{left:-86px}.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden{display:none}::-webkit-scrollbar{width:7px;height:7px;-webkit-border-radius:5px}::-webkit-scrollbar-track-piece{-webkit-border-radius:5px}::-webkit-scrollbar-thumb:vertical{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar-thumb:horizontal{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar:hover{background-color:rgba(0,0,0,.15)}::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.35)}
-/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"names":[],"mappings":"","sources":["outline.css"],"sourcesContent":[":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ====== 阴影样式设置函数 ====== */\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  left: -1em;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  -webkit-transition-duration: 0.4s;\n          transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  -webkit-transition-duration: 0.2s;\n          transition-duration: 0.2s;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["variables.less","../../<input css 5>","icons.less","anchors.less","drawer.less","shadow.less","chapters.less","ellipsis.less","toolbar.less","scrollbar.less"],"names":[],"mappings":"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","file":"outline.css","sourcesContent":[":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ====== 阴影样式设置函数 ====== */\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n"]} */\n"],"file":"outline.min.css"} */
+.outline-icon,.outline-icon__svg{width:1em;height:1em;overflow:hidden}.outline-icon__svg,.outline-toolbar__icon{-webkit-transform:translate(-50%,-50%);fill:currentcolor}.outline-chapters__title,.outline-drawer__title,.outline-drawer_ttb{border-bottom:1px solid #dcdfe6}:root{--outline-zIndex:2000;--outline-sticky-height:100%;--outline-chapters-width:100%}.outline-icon{position:relative;z-index:1;display:inline-block;vertical-align:middle}.outline-icon__svg{position:absolute;z-index:2;top:50%;left:50%;transform:translate(-50%,-50%)}.outline-heading{position:relative;z-index:1;overflow:hidden}.outline-heading__anchor{display:none}.outline-heading__anchor:hover,.outline-heading__anchor:link,.outline-heading__anchor:visited{color:#999;text-decoration:none}.outline-heading__anchor:hover{color:#1f8dd6}.outline-heading:hover .outline-heading__anchor{display:inline-block}.outline-heading_start:hover{overflow:visible}.outline-heading_start .outline-heading__anchor{position:absolute;z-index:2;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);left:-1em}.outline-drawer{position:relative;z-index:-1;top:0;left:0;margin:0;width:100%;height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;visibility:hidden;overflow:hidden}.outline-drawer__modal{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-ms-flex-wrap:nowrap;flex-wrap:nowrap;position:absolute;z-index:21;height:100%;background-color:#fff;-webkit-transition-duration:.4s;transition-duration:.4s;overflow:hidden}.outline-drawer__footer,.outline-drawer__header,.outline-drawer__main{width:100%;-webkit-box-sizing:border-box;box-sizing:border-box}.outline-drawer__footer,.outline-drawer__header{-ms-flex-negative:0;flex-shrink:0}.outline-drawer__footer,.outline-drawer__main,.outline-drawer__title{padding:0 16px}.outline-drawer__header,.outline-drawer__title{position:relative;z-index:1;margin:0 auto;height:52px;line-height:52px;overflow:hidden}.outline-drawer__title{font-size:16px;font-weight:400;margin:0 16px;-webkit-box-sizing:border-box;box-sizing:border-box}.outline-drawer__close{position:absolute;z-index:2;top:50%;right:12px;width:20px;height:20px;line-height:20px;color:#999;font-size:20px;text-align:center;cursor:pointer;-webkit-transform:translateY(-50%);transform:translateY(-50%);overflow:hidden}.outline-drawer__close .outline-icon{position:absolute;z-index:2;top:0;left:0}.outline-drawer__close:hover{color:#666}.outline-drawer__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-drawer__footer{margin:0 auto;text-align:right;overflow:hidden}.outline-drawer__overlay{content:'';position:relative;z-index:1;top:0;left:0;width:100%;height:100%;background-color:#fff;opacity:.1;overflow:hidden}.outline-drawer_ltr.outline-drawer_tiny,.outline-drawer_rtl.outline-drawer_tiny{width:280px}.outline-drawer_ltr.outline-drawer_mini,.outline-drawer_rtl.outline-drawer_mini{width:480px}.outline-drawer_ltr.outline-drawer_small,.outline-drawer_rtl.outline-drawer_small{width:540px}.outline-drawer_ltr.outline-drawer_regular,.outline-drawer_rtl.outline-drawer_regular{width:680px}.outline-drawer_ltr.outline-drawer_medium,.outline-drawer_rtl.outline-drawer_medium{width:720px}.outline-drawer_ltr.outline-drawer_large,.outline-drawer_rtl.outline-drawer_large{width:960px}.outline-drawer_rtl{border-left:1px solid #dcdfe6}.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed{right:-290px}.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed{right:-490px}.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed{right:-550px}.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed{right:-690px}.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed{right:-730px}.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed{right:-970px}.outline-drawer_ltr{border-right:1px solid #dcdfe6}.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed{left:-290px}.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed{left:-490px}.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed{left:-550px}.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed{left:-690px}.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed{left:-730px}.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed{left:-970px}.outline-drawer_btt,.outline-drawer_ttb{left:0;width:100%}.outline-drawer_btt.outline-drawer_tiny,.outline-drawer_ttb.outline-drawer_tiny{height:240px}.outline-drawer_btt.outline-drawer_mini,.outline-drawer_ttb.outline-drawer_mini{height:320px}.outline-drawer_btt.outline-drawer_small,.outline-drawer_ttb.outline-drawer_small{height:360px}.outline-drawer_btt.outline-drawer_regular,.outline-drawer_ttb.outline-drawer_regular{height:400px}.outline-drawer_btt.outline-drawer_medium,.outline-drawer_ttb.outline-drawer_medium{height:440px}.outline-drawer_btt.outline-drawer_large,.outline-drawer_ttb.outline-drawer_large{height:480px}.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed{top:-250px}.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed{top:-330px}.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed{top:-370px}.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed{top:-410px}.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed{top:-450px}.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed{top:-490px}.outline-drawer_btt{top:initial;border-top:1px solid #dcdfe6}.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed{bottom:-250px}.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed{bottom:-330px}.outline-drawer_btt.outline-drawer_small.outline-drawer_closed{bottom:-370px}.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed{bottom:-410px}.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed{bottom:-450px}.outline-drawer_btt.outline-drawer_large.outline-drawer_closed{bottom:-490px}.outline-drawer_opened{visibility:visible;z-index:var(--outline-zIndex)}.outline-drawer_opened.outline-drawer{position:fixed}.outline-drawer_opened.outline-drawer_rtl{right:0}.outline-drawer_opened.outline-drawer_ltr{left:0}.outline-drawer_opened.outline-drawer_ttb{top:0}.outline-drawer_opened.outline-drawer_btt{bottom:0}.outline-drawer_offset.outline-drawer_ltr,.outline-drawer_offset.outline-drawer_rtl{height:calc(100% - 4em);top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.outline-drawer_offset.outline-drawer_btt,.outline-drawer_offset.outline-drawer_ttb{width:calc(100% - 4em);left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl{right:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr{left:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb{top:2em}.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt{bottom:2em}.outline-drawer_auto.outline-drawer_ltr,.outline-drawer_auto.outline-drawer_rtl{height:auto;max-height:calc(100% - 4em)}.outline-drawer_full{padding:0}.outline-chapters{position:relative;z-index:1;margin:0;width:var(--outline-chapters-width);-webkit-transition-duration:.3s;transition-duration:.3s;overflow:auto}.outline-chapters__title{margin:0 16px;height:40px;line-height:40px;padding:0 16px;font-size:16px;font-weight:400;overflow:hidden}.outline-chapters__main{position:relative;z-index:1;margin:0;overflow:hidden}.outline-chapters__item,.outline-chapters__list,.outline-chapters__subject{position:relative;z-index:2;margin:0;padding:0;list-style-type:none;overflow:hidden}.outline-chapters__list{padding:.5em 0}.outline-chapters__subject{padding-left:1em}.outline-chapters__item{margin:0;line-height:30px;font-size:13px;overflow:hidden}.outline-chapters__placeholder{position:absolute;z-index:1;top:0;left:0;width:100%;height:30px;background-color:#f7f8f9;border-left:2px solid #058942;-webkit-transition-duration:.2s;transition-duration:.2s;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.outline-chapters__anchor{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:block;padding:0 1.5em}.outline-chapters__anchor:hover,.outline-chapters__anchor:link,.outline-chapters__anchor:visited{text-decoration:none;color:#555}.outline-chapters__anchor:hover{color:#058942}.outline-chapters__code{padding-right:.5em}.outline-chapters_active.outline-chapters__anchor:hover,.outline-chapters_active.outline-chapters__anchor:link,.outline-chapters_active.outline-chapters__anchor:visited{color:#058942;font-weight:400}.outline-chapters_fixed,.outline-chapters_sticky{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;z-index:var(--outline-zIndex);top:0;overflow:hidden}.outline-chapters_hidden,.outline-toolbar__button.hide{display:none}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__main,.outline-chapters_sticky .outline-chapters__title{-webkit-box-sizing:border-box;box-sizing:border-box}.outline-chapters_fixed .outline-chapters__title,.outline-chapters_sticky .outline-chapters__title{-ms-flex-negative:0;flex-shrink:0}.outline-chapters_fixed .outline-chapters__main,.outline-chapters_sticky .outline-chapters__main{-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:auto}.outline-chapters_sticky{position:sticky;max-height:var(--outline-sticky-height)}.outline-chapters_fixed{position:fixed;max-height:100%}.outline-chapters_folded{width:0}.outline-toolbar{position:fixed;z-index:99999;margin:0;-webkit-transition-duration:.3s;transition-duration:.3s;overflow:hidden}.outline-toolbar__button{-webkit-box-shadow:0 0 6px 1px #dcdfe6;box-shadow:0 0 6px 1px #dcdfe6;position:relative;z-index:1;margin:10px;width:36px;height:36px;border:1px solid #dcdfe6;border-radius:3px;-webkit-box-sizing:border-box;box-sizing:border-box;background-color:#fff;cursor:pointer;text-align:center;color:#555;overflow:hidden}.outline-toolbar__button:hover{color:#058942;border-color:#058942}.outline-toolbar__anchor:hover,.outline-toolbar__anchor:link,.outline-toolbar__anchor:visited{color:#999;text-decoration:none}.outline-toolbar__anchor:hover{color:#058942}.outline-toolbar__icon{position:absolute;z-index:2;top:50%;left:50%;width:20px;height:20px;transform:translate(-50%,-50%);overflow:hidden}.outline-toolbar_active.outline-toolbar__button{color:#fff;background-color:#058942;border-color:#058942}.outline-toolbar_active .outline-toolbar__anchor:hover,.outline-toolbar_active .outline-toolbar__anchor:link,.outline-toolbar_active .outline-toolbar__anchor:visited,.outline-toolbar_active.outline-toolbar__button:hover{color:#fff}.outline-toolbar_rounded.outline-toolbar__button{border-radius:18px}.outline-toolbar_disabled .outline-toolbar__anchor:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link,.outline-toolbar_disabled .outline-toolbar__anchor:visited,.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__anchor:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link,.outline-toolbar_disabled.outline-toolbar__anchor:visited,.outline-toolbar_disabled.outline-toolbar__button{cursor:not-allowed;color:#999}.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled .outline-toolbar__button:hover,.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,.outline-toolbar_disabled.outline-toolbar__button:hover{color:#999}.outline-toolbar_disabled .outline-toolbar__button,.outline-toolbar_disabled.outline-toolbar__button{background-color:#f5f5f5}.outline-toolbar_btt,.outline-toolbar_ttb{left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.outline-toolbar_btt .outline-toolbar__button,.outline-toolbar_ttb .outline-toolbar__button{display:inline-block}.outline-print,.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden{display:none}.outline-toolbar_ttb{top:12px}.outline-toolbar_ttb.outline-toolbar_hidden{top:-56px}.outline-toolbar_btt{bottom:12px}.outline-toolbar_btt.outline-toolbar_hidden{bottom:-56px}.outline-toolbar_ltr,.outline-toolbar_rtl{-webkit-transform:translateY(-50%);transform:translateY(-50%);width:56px}.outline-toolbar_rtl{top:50%;right:12px}.outline-toolbar_rtl.outline-toolbar_hidden{right:-86px}.outline-toolbar_ltr{top:50%;left:12px}.outline-toolbar_ltr.outline-toolbar_hidden{left:-86px}::-webkit-scrollbar{width:7px;height:7px;-webkit-border-radius:5px}::-webkit-scrollbar-track-piece{-webkit-border-radius:5px}::-webkit-scrollbar-thumb:vertical{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar-thumb:horizontal{background-color:rgba(0,0,0,.25);-webkit-border-radius:5px}::-webkit-scrollbar:hover{background-color:rgba(0,0,0,.15)}::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.35)}@media print{body,html{height:initial!important}.outline-print{display:block!important;overflow:hidden}.outline-print h1{text-align:center;font-size:20pt;font-family:'Microsoft YaHei UI',Arial,sans-serif;font-weight:400}.outline-print pre{padding:1em!important;border:1px solid #ddd!important;border-radius:4px!important}.outline-print code,.outline-print pre{background-color:#fff!important}.outline-print img,.outline-print svg,.outline-print table{-webkit-column-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.outline-print_sibling{display:none!important}}
+/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"names":[],"mappings":"","sources":["outline.css"],"sourcesContent":[":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ====== 阴影样式设置函数 ====== */\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  left: -1em;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  -webkit-transition-duration: 0.4s;\n          transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  -webkit-transition-duration: 0.2s;\n          transition-duration: 0.2s;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  -ms-flex-negative: 0;\n      flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  -webkit-box-flex: 1;\n      -ms-flex: 1;\n          flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  -webkit-transition-duration: 0.3s;\n          transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  -webkit-box-shadow: 0 0 6px 1px #dcdfe6;\n          box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  -webkit-transform: translate(-50%, -50%);\n          transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  -webkit-transform: translateX(-50%);\n          transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  -webkit-transform: translateY(-50%);\n          transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.outline-print {\n  display: none;\n}\n@media print {\n  html,\n  body {\n    height: initial !important;\n  }\n  .outline-print {\n    display: block !important;\n    overflow: hidden;\n  }\n  .outline-print h1 {\n    text-align: center;\n    font-size: 20pt;\n    font-family: 'Microsoft YaHei UI', Arial, sans-serif;\n    font-weight: normal;\n  }\n  .outline-print pre {\n    padding: 1em !important;\n    border: 1px solid #ddd !important;\n    border-radius: 4px !important;\n  }\n  .outline-print pre,\n  .outline-print code {\n    background-color: #fff !important;\n  }\n  .outline-print table,\n  .outline-print img,\n  .outline-print svg {\n    -webkit-column-break-inside: avoid;\n       -moz-column-break-inside: avoid;\n            break-inside: avoid;\n  }\n  .outline-print_sibling {\n    display: none !important;\n  }\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["variables.less","../../<input css 5>","icons.less","anchors.less","drawer.less","shadow.less","chapters.less","ellipsis.less","toolbar.less","scrollbar.less","print.less"],"names":[],"mappings":"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","file":"outline.css","sourcesContent":[":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n",":root {\n  --outline-zIndex: 2000;\n  --outline-sticky-height: 100%;\n  --outline-chapters-width: 100%;\n}\n/* ========== colors.theme - 基础颜色变量集合 ========== */\n/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n/* ====== 文本省略函数 ====== */\n/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n/* ====== 阴影样式设置函数 ====== */\n/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n}\n.outline-icon__svg {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 1em;\n  height: 1em;\n  fill: currentcolor;\n  transform: translate(-50%, -50%);\n  overflow: hidden;\n}\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n}\n.outline-heading__anchor {\n  display: none;\n}\n.outline-heading__anchor:link,\n.outline-heading__anchor:visited,\n.outline-heading__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-heading__anchor:hover {\n  color: #1f8dd6;\n}\n.outline-heading:hover .outline-heading__anchor {\n  display: inline-block;\n}\n.outline-heading_start:hover {\n  overflow: visible;\n}\n.outline-heading_start .outline-heading__anchor {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  transform: translateY(-50%);\n  left: -1em;\n}\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n}\n.outline-drawer__modal {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  display: flex;\n  flex-direction: column;\n  flex-wrap: nowrap;\n  position: absolute;\n  z-index: 21;\n  height: 100%;\n  background-color: #fff;\n  transition-duration: 0.4s;\n  overflow: hidden;\n}\n.outline-drawer__header,\n.outline-drawer__main,\n.outline-drawer__footer {\n  width: 100%;\n  box-sizing: border-box;\n}\n.outline-drawer__header,\n.outline-drawer__footer {\n  flex-shrink: 0;\n}\n.outline-drawer__title,\n.outline-drawer__main,\n.outline-drawer__footer {\n  padding: 0 16px;\n}\n.outline-drawer__header,\n.outline-drawer__title {\n  position: relative;\n  z-index: 1;\n  margin: 0 auto;\n  height: 52px;\n  line-height: 52px;\n  overflow: hidden;\n}\n.outline-drawer__title {\n  font-size: 16px;\n  font-weight: 400;\n  margin: 0 16px;\n  box-sizing: border-box;\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer__close {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  right: 12px;\n  width: 20px;\n  height: 20px;\n  line-height: 20px;\n  color: #999;\n  font-size: 20px;\n  text-align: center;\n  cursor: pointer;\n  transform: translateY(-50%);\n  overflow: hidden;\n}\n.outline-drawer__close .outline-icon {\n  position: absolute;\n  z-index: 2;\n  top: 0;\n  left: 0;\n}\n.outline-drawer__close:hover {\n  color: #666;\n}\n.outline-drawer__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-drawer__footer {\n  margin: 0 auto;\n  text-align: right;\n  overflow: hidden;\n}\n.outline-drawer__overlay {\n  content: '';\n  position: relative;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  background-color: #fff;\n  opacity: 0.1;\n  overflow: hidden;\n}\n.outline-drawer_rtl.outline-drawer_tiny,\n.outline-drawer_ltr.outline-drawer_tiny {\n  width: 280px;\n}\n.outline-drawer_rtl.outline-drawer_mini,\n.outline-drawer_ltr.outline-drawer_mini {\n  width: 480px;\n}\n.outline-drawer_rtl.outline-drawer_small,\n.outline-drawer_ltr.outline-drawer_small {\n  width: 540px;\n}\n.outline-drawer_rtl.outline-drawer_regular,\n.outline-drawer_ltr.outline-drawer_regular {\n  width: 680px;\n}\n.outline-drawer_rtl.outline-drawer_medium,\n.outline-drawer_ltr.outline-drawer_medium {\n  width: 720px;\n}\n.outline-drawer_rtl.outline-drawer_large,\n.outline-drawer_ltr.outline-drawer_large {\n  width: 960px;\n}\n.outline-drawer_rtl {\n  border-left: 1px solid #dcdfe6;\n}\n.outline-drawer_rtl.outline-drawer_tiny.outline-drawer_closed {\n  right: -290px;\n}\n.outline-drawer_rtl.outline-drawer_mini.outline-drawer_closed {\n  right: -490px;\n}\n.outline-drawer_rtl.outline-drawer_small.outline-drawer_closed {\n  right: -550px;\n}\n.outline-drawer_rtl.outline-drawer_regular.outline-drawer_closed {\n  right: -690px;\n}\n.outline-drawer_rtl.outline-drawer_medium.outline-drawer_closed {\n  right: -730px;\n}\n.outline-drawer_rtl.outline-drawer_large.outline-drawer_closed {\n  right: -970px;\n}\n.outline-drawer_ltr {\n  border-right: 1px solid #dcdfe6;\n}\n.outline-drawer_ltr.outline-drawer_tiny.outline-drawer_closed {\n  left: -290px;\n}\n.outline-drawer_ltr.outline-drawer_mini.outline-drawer_closed {\n  left: -490px;\n}\n.outline-drawer_ltr.outline-drawer_small.outline-drawer_closed {\n  left: -550px;\n}\n.outline-drawer_ltr.outline-drawer_regular.outline-drawer_closed {\n  left: -690px;\n}\n.outline-drawer_ltr.outline-drawer_medium.outline-drawer_closed {\n  left: -730px;\n}\n.outline-drawer_ltr.outline-drawer_large.outline-drawer_closed {\n  left: -970px;\n}\n.outline-drawer_ttb,\n.outline-drawer_btt {\n  left: 0;\n  width: 100%;\n}\n.outline-drawer_ttb.outline-drawer_tiny,\n.outline-drawer_btt.outline-drawer_tiny {\n  height: 240px;\n}\n.outline-drawer_ttb.outline-drawer_mini,\n.outline-drawer_btt.outline-drawer_mini {\n  height: 320px;\n}\n.outline-drawer_ttb.outline-drawer_small,\n.outline-drawer_btt.outline-drawer_small {\n  height: 360px;\n}\n.outline-drawer_ttb.outline-drawer_regular,\n.outline-drawer_btt.outline-drawer_regular {\n  height: 400px;\n}\n.outline-drawer_ttb.outline-drawer_medium,\n.outline-drawer_btt.outline-drawer_medium {\n  height: 440px;\n}\n.outline-drawer_ttb.outline-drawer_large,\n.outline-drawer_btt.outline-drawer_large {\n  height: 480px;\n}\n.outline-drawer_ttb {\n  border-bottom: 1px solid #dcdfe6;\n}\n.outline-drawer_ttb.outline-drawer_tiny.outline-drawer_closed {\n  top: -250px;\n}\n.outline-drawer_ttb.outline-drawer_mini.outline-drawer_closed {\n  top: -330px;\n}\n.outline-drawer_ttb.outline-drawer_small.outline-drawer_closed {\n  top: -370px;\n}\n.outline-drawer_ttb.outline-drawer_regular.outline-drawer_closed {\n  top: -410px;\n}\n.outline-drawer_ttb.outline-drawer_medium.outline-drawer_closed {\n  top: -450px;\n}\n.outline-drawer_ttb.outline-drawer_large.outline-drawer_closed {\n  top: -490px;\n}\n.outline-drawer_btt {\n  top: initial;\n  border-top: 1px solid #dcdfe6;\n}\n.outline-drawer_btt.outline-drawer_tiny.outline-drawer_closed {\n  bottom: -250px;\n}\n.outline-drawer_btt.outline-drawer_mini.outline-drawer_closed {\n  bottom: -330px;\n}\n.outline-drawer_btt.outline-drawer_small.outline-drawer_closed {\n  bottom: -370px;\n}\n.outline-drawer_btt.outline-drawer_regular.outline-drawer_closed {\n  bottom: -410px;\n}\n.outline-drawer_btt.outline-drawer_medium.outline-drawer_closed {\n  bottom: -450px;\n}\n.outline-drawer_btt.outline-drawer_large.outline-drawer_closed {\n  bottom: -490px;\n}\n.outline-drawer_opened {\n  visibility: visible;\n  z-index: var(--outline-zIndex);\n}\n.outline-drawer_opened.outline-drawer {\n  position: fixed;\n}\n.outline-drawer_opened.outline-drawer_rtl {\n  right: 0;\n}\n.outline-drawer_opened.outline-drawer_ltr {\n  left: 0;\n}\n.outline-drawer_opened.outline-drawer_ttb {\n  top: 0;\n}\n.outline-drawer_opened.outline-drawer_btt {\n  bottom: 0;\n}\n.outline-drawer_offset.outline-drawer_rtl,\n.outline-drawer_offset.outline-drawer_ltr {\n  height: calc(100% - 4em);\n  top: 50%;\n  transform: translateY(-50%);\n}\n.outline-drawer_offset.outline-drawer_ttb,\n.outline-drawer_offset.outline-drawer_btt {\n  width: calc(100% - 4em);\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_rtl {\n  right: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ltr {\n  left: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_ttb {\n  top: 2em;\n}\n.outline-drawer_offset.outline-drawer_opened.outline-drawer_btt {\n  bottom: 2em;\n}\n.outline-drawer_auto.outline-drawer_rtl,\n.outline-drawer_auto.outline-drawer_ltr {\n  height: auto;\n  max-height: calc(100% - 4em);\n}\n.outline-drawer_full {\n  padding: 0;\n}\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n}\n.outline-chapters__title {\n  margin: 0 16px;\n  height: 40px;\n  line-height: 40px;\n  padding: 0 16px;\n  border-bottom: 1px solid #dcdfe6;\n  font-size: 16px;\n  font-weight: 400;\n  overflow: hidden;\n}\n.outline-chapters__main {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  overflow: hidden;\n}\n.outline-chapters__list,\n.outline-chapters__subject,\n.outline-chapters__item {\n  position: relative;\n  z-index: 2;\n  margin: 0;\n  padding: 0;\n  list-style-type: none;\n  overflow: hidden;\n}\n.outline-chapters__list {\n  padding: 0.5em 0;\n}\n.outline-chapters__subject {\n  padding-left: 1em;\n}\n.outline-chapters__item {\n  margin: 0;\n  line-height: 30px;\n  font-size: 13px;\n  overflow: hidden;\n}\n.outline-chapters__placeholder {\n  position: absolute;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 30px;\n  background-color: #f7f8f9;\n  border-left: 2px solid #058942;\n  transition-duration: 0.2s;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n.outline-chapters__anchor {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  display: block;\n  padding: 0 1.5em;\n}\n.outline-chapters__anchor:link,\n.outline-chapters__anchor:visited,\n.outline-chapters__anchor:hover {\n  text-decoration: none;\n  color: #555;\n}\n.outline-chapters__anchor:hover {\n  color: #058942;\n}\n.outline-chapters__code {\n  padding-right: 0.5em;\n}\n.outline-chapters_active.outline-chapters__anchor:link,\n.outline-chapters_active.outline-chapters__anchor:visited,\n.outline-chapters_active.outline-chapters__anchor:hover {\n  color: #058942;\n  font-weight: 400;\n}\n.outline-chapters_sticky,\n.outline-chapters_fixed {\n  display: flex;\n  flex-wrap: nowrap;\n  flex-direction: column;\n  z-index: var(--outline-zIndex);\n  top: 0;\n  overflow: hidden;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title,\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  box-sizing: border-box;\n}\n.outline-chapters_sticky .outline-chapters__title,\n.outline-chapters_fixed .outline-chapters__title {\n  flex-shrink: 0;\n}\n.outline-chapters_sticky .outline-chapters__main,\n.outline-chapters_fixed .outline-chapters__main {\n  flex: 1;\n  overflow: auto;\n}\n.outline-chapters_sticky {\n  position: sticky;\n  max-height: var(--outline-sticky-height);\n}\n.outline-chapters_fixed {\n  position: fixed;\n  max-height: 100%;\n}\n.outline-chapters_hidden {\n  display: none;\n}\n.outline-chapters_folded {\n  width: 0;\n}\n/* ========== buttons.theme - 按钮导航样式 ========== */\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n}\n.outline-toolbar__button {\n  box-shadow: 0 0 6px 1px #dcdfe6;\n  position: relative;\n  z-index: 1;\n  margin: 10px;\n  width: 36px;\n  height: 36px;\n  border: 1px solid #dcdfe6;\n  border-radius: 3px;\n  box-sizing: border-box;\n  background-color: #fff;\n  cursor: pointer;\n  text-align: center;\n  color: #555;\n  overflow: hidden;\n}\n.outline-toolbar__button:hover {\n  color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar__button.hide {\n  display: none;\n}\n.outline-toolbar__anchor:link,\n.outline-toolbar__anchor:visited,\n.outline-toolbar__anchor:hover {\n  color: #999;\n  text-decoration: none;\n}\n.outline-toolbar__anchor:hover {\n  color: #058942;\n}\n.outline-toolbar__icon {\n  position: absolute;\n  z-index: 2;\n  top: 50%;\n  left: 50%;\n  width: 20px;\n  height: 20px;\n  transform: translate(-50%, -50%);\n  fill: currentcolor;\n  overflow: hidden;\n}\n.outline-toolbar_active.outline-toolbar__button {\n  color: #fff;\n  background-color: #058942;\n  border-color: #058942;\n}\n.outline-toolbar_active.outline-toolbar__button:hover {\n  color: #fff;\n}\n.outline-toolbar_active .outline-toolbar__anchor:link,\n.outline-toolbar_active .outline-toolbar__anchor:visited,\n.outline-toolbar_active .outline-toolbar__anchor:hover {\n  color: #fff;\n}\n.outline-toolbar_rounded.outline-toolbar__button {\n  border-radius: 18px;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link,\n.outline-toolbar_disabled .outline-toolbar__anchor:link,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover,\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  cursor: not-allowed;\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:link:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:visited:hover,\n.outline-toolbar_disabled.outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled .outline-toolbar__anchor:hover:hover,\n.outline-toolbar_disabled.outline-toolbar__button:hover,\n.outline-toolbar_disabled .outline-toolbar__button:hover {\n  color: #999;\n}\n.outline-toolbar_disabled.outline-toolbar__button,\n.outline-toolbar_disabled .outline-toolbar__button {\n  background-color: #f5f5f5;\n}\n.outline-toolbar_ttb,\n.outline-toolbar_btt {\n  left: 50%;\n  transform: translateX(-50%);\n}\n.outline-toolbar_ttb .outline-toolbar__button,\n.outline-toolbar_btt .outline-toolbar__button {\n  display: inline-block;\n}\n.outline-toolbar_ttb {\n  top: 12px;\n}\n.outline-toolbar_ttb.outline-toolbar_hidden {\n  top: -56px;\n}\n.outline-toolbar_btt {\n  bottom: 12px;\n}\n.outline-toolbar_btt.outline-toolbar_hidden {\n  bottom: -56px;\n}\n.outline-toolbar_rtl,\n.outline-toolbar_ltr {\n  transform: translateY(-50%);\n  width: 56px;\n}\n.outline-toolbar_rtl {\n  top: 50%;\n  right: 12px;\n}\n.outline-toolbar_rtl.outline-toolbar_hidden {\n  right: -86px;\n}\n.outline-toolbar_ltr {\n  top: 50%;\n  left: 12px;\n}\n.outline-toolbar_ltr.outline-toolbar_hidden {\n  left: -86px;\n}\n.outline-toolbar_ttb .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_rtl .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_btt .outline-toolbar__button.outline-toolbar_hidden,\n.outline-toolbar_ltr .outline-toolbar__button.outline-toolbar_hidden {\n  display: none;\n}\n/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n.outline-print {\n  display: none;\n}\n@media print {\n  html,\n  body {\n    height: initial !important;\n  }\n  .outline-print {\n    display: block !important;\n    overflow: hidden;\n  }\n  .outline-print h1 {\n    text-align: center;\n    font-size: 20pt;\n    font-family: 'Microsoft YaHei UI', Arial, sans-serif;\n    font-weight: normal;\n  }\n  .outline-print pre {\n    padding: 1em !important;\n    border: 1px solid #ddd !important;\n    border-radius: 4px !important;\n  }\n  .outline-print pre,\n  .outline-print code {\n    background-color: #fff !important;\n  }\n  .outline-print table,\n  .outline-print img,\n  .outline-print svg {\n    break-inside: avoid;\n  }\n  .outline-print_sibling {\n    display: none !important;\n  }\n}\n","/* ========== icon.theme - svg 图标的样式 ========== */\n.outline-icon {\n  position: relative;\n  z-index: 1;\n  display: inline-block;\n  vertical-align: middle;\n  width: 1em;\n  height: 1em;\n  overflow: hidden;\n\n  &__svg {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 1em;\n    height: 1em;\n    fill: currentcolor;\n    transform: translate(-50%, -50%);\n    overflow: hidden;\n  }\n}\n","@import './colors';\n\n.outline-heading {\n  position: relative;\n  z-index: 1;\n  overflow: hidden;\n\n  &__anchor {\n    display: none;\n\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @primary_color;\n    }\n  }\n\n  &:hover {\n    .outline-heading__anchor {\n      display: inline-block;\n    }\n  }\n\n  &_start {\n    &:hover {\n      overflow: visible;\n    }\n\n    .outline-heading__anchor {\n      position: absolute;\n      z-index: 2;\n      top: 50%;\n      transform: translateY(-50%);\n      left: -1em;\n    }\n  }\n}\n","@import './variables';\n@import './colors';\n@import './shadow';\n\n.outline-drawer {\n  position: relative;\n  z-index: -1;\n  top: 0;\n  left: 0;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  box-sizing: border-box;\n  visibility: hidden;\n  overflow: hidden;\n\n  &__modal {\n    .shadow_light_regular();\n    display: flex;\n    flex-direction: column;\n    flex-wrap: nowrap;\n    position: absolute;\n    z-index: 21;\n    height: 100%;\n    background-color: @white;\n    transition-duration: 0.4s;\n    overflow: hidden;\n  }\n\n  &__header,\n  &__main,\n  &__footer {\n    width: 100%;\n    box-sizing: border-box;\n  }\n\n  &__header,\n  &__footer {\n    flex-shrink: 0;\n  }\n\n  &__title,\n  &__main,\n  &__footer {\n    padding: 0 16px;\n  }\n\n  &__header,\n  &__title {\n    position: relative;\n    z-index: 1;\n    margin: 0 auto;\n    height: 52px;\n    line-height: 52px;\n    overflow: hidden;\n  }\n\n  &__title {\n    font-size: 16px;\n    font-weight: 400;\n    margin: 0 16px;\n    box-sizing: border-box;\n    border-bottom: 1px solid @primary_border_color;\n  }\n\n  &__close {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    right: 12px;\n    width: 20px;\n    height: 20px;\n    line-height: 20px;\n    color: @fourth_text_color;\n    font-size: 20px;\n    text-align: center;\n    cursor: pointer;\n    transform: translateY(-50%);\n    overflow: hidden;\n\n    .outline-icon {\n      position: absolute;\n      z-index: 2;\n      top: 0;\n      left: 0;\n    }\n\n    &:hover {\n      color: @third_text_color;\n    }\n  }\n\n  &__main {\n    flex: 1;\n    overflow: auto;\n  }\n\n  &__footer {\n    margin: 0 auto;\n    text-align: right;\n    overflow: hidden;\n  }\n\n  &__overlay {\n    content: '';\n    position: relative;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: @white;\n    opacity: 0.1;\n    overflow: hidden;\n  }\n\n  &_rtl,\n  &_ltr {\n    &.outline-drawer {\n      &_tiny {\n        width: 280px;\n      }\n\n      &_mini {\n        width: 480px;\n      }\n\n      &_small {\n        width: 540px;\n      }\n\n      &_regular {\n        width: 680px;\n      }\n\n      &_medium {\n        width: 720px;\n      }\n\n      &_large {\n        width: 960px;\n      }\n    }\n  }\n\n  &_rtl {\n    border-left: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          right: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          right: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          right: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          right: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          right: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          right: -970px;\n        }\n      }\n    }\n  }\n\n  &_ltr {\n    border-right: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          left: -290px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          left: -490px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          left: -550px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          left: -690px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          left: -730px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          left: -970px;\n        }\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 0;\n    width: 100%;\n\n    &.outline-drawer {\n      &_tiny {\n        height: 240px;\n      }\n\n      &_mini {\n        height: 320px;\n      }\n\n      &_small {\n        height: 360px;\n      }\n\n      &_regular {\n        height: 400px;\n      }\n\n      &_medium {\n        height: 440px;\n      }\n\n      &_large {\n        height: 480px;\n      }\n    }\n  }\n\n  &_ttb {\n    border-bottom: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          top: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          top: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          top: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          top: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          top: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          top: -490px;\n        }\n      }\n    }\n  }\n\n  &_btt {\n    top: initial;\n    border-top: 1px solid @primary_border_color;\n\n    &.outline-drawer {\n      &_tiny {\n        &.outline-drawer_closed {\n          bottom: -250px;\n        }\n      }\n\n      &_mini {\n        &.outline-drawer_closed {\n          bottom: -330px;\n        }\n      }\n\n      &_small {\n        &.outline-drawer_closed {\n          bottom: -370px;\n        }\n      }\n\n      &_regular {\n        &.outline-drawer_closed {\n          bottom: -410px;\n        }\n      }\n\n      &_medium {\n        &.outline-drawer_closed {\n          bottom: -450px;\n        }\n      }\n\n      &_large {\n        &.outline-drawer_closed {\n          bottom: -490px;\n        }\n      }\n    }\n  }\n\n  &_opened {\n    visibility: visible;\n    z-index: var(--outline-zIndex);\n\n    &.outline-drawer {\n      position: fixed;\n\n      &_rtl {\n        right: 0;\n      }\n\n      &_ltr {\n        left: 0;\n      }\n\n      &_ttb {\n        top: 0;\n      }\n\n      &_btt {\n        bottom: 0;\n      }\n    }\n  }\n\n  &_offset {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: calc(100% - 4em);\n        top: 50%;\n        transform: translateY(-50%);\n      }\n\n      &_ttb,\n      &_btt {\n        width: calc(100% - 4em);\n        left: 50%;\n        transform: translateX(-50%);\n      }\n\n      &_opened {\n        &.outline-drawer {\n          &_rtl {\n            right: 2em;\n          }\n\n          &_ltr {\n            left: 2em;\n          }\n\n          &_ttb {\n            top: 2em;\n          }\n\n          &_btt {\n            bottom: 2em;\n          }\n        }\n      }\n    }\n  }\n\n  &_auto {\n    &.outline-drawer {\n      &_rtl,\n      &_ltr {\n        height: auto;\n        max-height: calc(100% - 4em);\n      }\n    }\n  }\n\n  &_full {\n    padding: 0;\n  }\n}\n","/**\n * shadow.less - 阴影样式设置 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.20\n */\n@import './colors';\n\n/* ====== 阴影样式设置函数 ====== */\n.shadow(@offset: 0 0 6px 1px, @color: @primary_border_color) {\n  box-shadow: @offset @color;\n}\n\n.shadow_regular(@color: @primary_border_color) {\n  .shadow(0 0 6px 1px, @color);\n}\n\n.shadow_large(@color: @primary_border_color) {\n  .shadow(0 0 12px 1px, @color);\n}\n\n.shadow_light_regular() {\n  .shadow_regular();\n}\n\n.shadow_light_large() {\n  .shadow_large();\n}\n\n.shadow_dark_regular() {\n  .shadow_regular(@secondary_border_color);\n}\n\n.shadow_dark_large() {\n  .shadow_large(@secondary_border_color);\n}\n","@import './variables';\n@import './colors';\n@import './ellipsis';\n\n.outline-chapters {\n  position: relative;\n  z-index: 1;\n  margin: 0;\n  width: var(--outline-chapters-width);\n  transition-duration: 0.3s;\n  overflow: auto;\n\n  &__title {\n    margin: 0 16px;\n    height: 40px;\n    line-height: 40px;\n    padding: 0 16px;\n    border-bottom: 1px solid @primary_border_color;\n    font-size: 16px;\n    font-weight: 400;\n    overflow: hidden;\n  }\n\n  &__main {\n    position: relative;\n    z-index: 1;\n    margin: 0;\n    overflow: hidden;\n  }\n\n  &__list,\n  &__subject,\n  &__item {\n    position: relative;\n    z-index: 2;\n    margin: 0;\n    padding: 0;\n    list-style-type: none;\n    overflow: hidden;\n  }\n\n  &__list {\n    padding: 0.5em 0;\n  }\n\n  &__subject {\n    padding-left: 1em;\n  }\n\n  &__item {\n    margin: 0;\n    line-height: 30px;\n    font-size: 13px;\n    overflow: hidden;\n  }\n\n  &__placeholder {\n    position: absolute;\n    z-index: 1;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 30px;\n    background-color: @hover_bg_color;\n    border-left: 2px solid @success_color;\n    transition-duration: 0.2s;\n    box-sizing: border-box;\n    overflow: hidden;\n  }\n\n  &__anchor {\n    .ellipsis(1);\n    display: block;\n    padding: 0 1.5em;\n\n    &:link,\n    &:visited,\n    &:hover {\n      text-decoration: none;\n      color: @secondary_text_color;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__code {\n    padding-right: 0.5em;\n  }\n\n  &_active {\n    &.outline-chapters__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @success_color;\n        font-weight: 400;\n      }\n    }\n  }\n\n  &_sticky,\n  &_fixed {\n    display: flex;\n    flex-wrap: nowrap;\n    flex-direction: column;\n    z-index: var(--outline-zIndex);\n    top: 0;\n    overflow: hidden;\n\n    .outline-chapters {\n      &__title,\n      &__main {\n        box-sizing: border-box;\n      }\n\n      &__title {\n        flex-shrink: 0;\n      }\n\n      &__main {\n        flex: 1;\n        overflow: auto;\n      }\n    }\n  }\n\n  &_sticky {\n    position: sticky;\n    max-height: var(--outline-sticky-height);\n  }\n\n  &_fixed {\n    position: fixed;\n    max-height: 100%;\n  }\n\n  &_hidden {\n    display: none;\n  }\n\n  &_folded {\n    width: 0;\n  }\n}\n","/**\n * ellipsis.less - 文本省略 mixinx 函数\n * =============================================================\n * Created By: Yaohaixiao\n * Update: 2022.3.11\n */\n\n/* ====== 文本省略函数 ====== */\n.ellipsis (@lines) when (@lines=1) {\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n\n.ellipsis (@lines) when (@lines>=2) {\n  -webkit-line-clamp: @lines;\n  display: box;\n  -webkit-box-orient: vertical;\n  text-overflow: ellipsis;\n  overflow: hidden;\n}\n","/* ========== buttons.theme - 按钮导航样式 ========== */\n@import './colors';\n@import './shadow';\n\n.outline-toolbar {\n  position: fixed;\n  z-index: 99999;\n  margin: 0;\n  transition-duration: 0.3s;\n  overflow: hidden;\n\n  &__button {\n    .shadow_light_regular();\n    position: relative;\n    z-index: 1;\n    margin: 10px;\n    width: 36px;\n    height: 36px;\n    border: 1px solid @primary_border_color;\n    border-radius: 3px;\n    box-sizing: border-box;\n    background-color: @white;\n    cursor: pointer;\n    text-align: center;\n    color: @secondary_text_color;\n    overflow: hidden;\n\n    &:hover {\n      color: @success_color;\n      border-color: @success_color;\n    }\n\n    &.hide {\n      display: none;\n    }\n  }\n\n  &__anchor {\n    &:link,\n    &:visited,\n    &:hover {\n      color: @fourth_text_color;\n      text-decoration: none;\n    }\n\n    &:hover {\n      color: @success_color;\n    }\n  }\n\n  &__icon {\n    position: absolute;\n    z-index: 2;\n    top: 50%;\n    left: 50%;\n    width: 20px;\n    height: 20px;\n    transform: translate(-50%, -50%);\n    fill: currentcolor;\n    overflow: hidden;\n  }\n\n  &_active {\n    &.outline-toolbar {\n      &__button {\n        color: @white;\n        background-color: @success_color;\n        border-color: @success_color;\n\n        &:hover {\n          color: @white;\n        }\n      }\n    }\n\n    .outline-toolbar__anchor {\n      &:link,\n      &:visited,\n      &:hover {\n        color: @white;\n      }\n    }\n  }\n\n  &_rounded {\n    &.outline-toolbar__button {\n      border-radius: 18px;\n    }\n  }\n\n  &_disabled {\n    &.outline-toolbar,\n    .outline-toolbar {\n      &__anchor:link,\n      &__anchor:visited,\n      &__anchor:hover,\n      &__button {\n        cursor: not-allowed;\n        color: @fourth_text_color;\n\n        &:hover {\n          color: @fourth_text_color;\n        }\n      }\n\n      &__button {\n        background-color: @disabled_bg_color;\n      }\n    }\n  }\n\n  &_ttb,\n  &_btt {\n    left: 50%;\n    transform: translateX(-50%);\n\n    .outline-toolbar__button {\n      display: inline-block;\n    }\n  }\n\n  &_ttb {\n    top: 12px;\n\n    &.outline-toolbar_hidden {\n      top: -56px;\n    }\n  }\n\n  &_btt {\n    bottom: 12px;\n\n    &.outline-toolbar_hidden {\n      bottom: -56px;\n    }\n  }\n\n  &_rtl,\n  &_ltr {\n    transform: translateY(-50%);\n    width: 56px;\n  }\n\n  &_rtl {\n    top: 50%;\n    right: 12px;\n\n    &.outline-toolbar_hidden {\n      right: -86px;\n    }\n  }\n\n  &_ltr {\n    top: 50%;\n    left: 12px;\n\n    &.outline-toolbar_hidden {\n      left: -86px;\n    }\n  }\n\n  &_ttb,\n  &_rtl,\n  &_btt,\n  &_ltr {\n    .outline-toolbar__button {\n      &.outline-toolbar_hidden {\n        display: none;\n      }\n    }\n  }\n}\n","/* ===== Scrollbar ===== */\n::-webkit-scrollbar {\n  width: 7px;\n  height: 7px;\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-track-piece {\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:vertical {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar-thumb:horizontal {\n  background-color: rgba(0, 0, 0, 0.25);\n  -webkit-border-radius: 5px;\n}\n\n::-webkit-scrollbar:hover {\n  background-color: rgba(0, 0, 0, 0.15);\n}\n\n::-webkit-scrollbar-thumb:hover {\n  background-color: rgba(0, 0, 0, 0.35);\n}\n","@import './colors';\r\n\r\n.outline-print {\r\n  display: none;\r\n}\r\n\r\n@media print {\r\n  html,\r\n  body {\r\n    height: initial !important;\r\n  }\r\n\r\n  .outline-print {\r\n    display: block !important;\r\n    overflow: hidden;\r\n\r\n    h1 {\r\n      text-align: center;\r\n      font-size: 20pt;\r\n      font-family: 'Microsoft YaHei UI', Arial, sans-serif;\r\n      font-weight: normal;\r\n    }\r\n\r\n    pre {\r\n      padding: 1em !important;\r\n      border: 1px solid @border_color !important;\r\n      border-radius: 4px !important;\r\n    }\r\n\r\n    pre,\r\n    code {\r\n      background-color: @white !important;\r\n    }\r\n\r\n    table,\r\n    img,\r\n    svg {\r\n      break-inside: avoid;\r\n    }\r\n\r\n    &_sibling {\r\n      display: none !important;\r\n    }\r\n  }\r\n}\r\n"]} */\n"],"file":"outline.min.css"} */
diff --git a/outline.min.js b/outline.min.js
index 2f08e993..689f90ee 100644
--- a/outline.min.js
+++ b/outline.min.js
@@ -1,2 +1,2 @@
-!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).Outline=e()}(this,(function(){"use strict";const t=t=>"string"==typeof t,e=(t,e)=>{const s=Object.prototype.hasOwnProperty;return t&&s.call(t,e)},s=t=>Object.prototype.toString.apply(t),i=t=>"function"==typeof t||"[object Function]"===s(t),r=t=>("[object Object]"===s(t)||"object"==typeof t||i(t))&&null!==t;class l{constructor(t){this.attrs={},t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}attr(s,i){const l=this.attrs;return t(s)?i&&e(l,s)?(l[s]=i,this):l[s]:r(s)?(o=l,n=s,Object.keys(n).forEach((t=>{e(n,t)&&(o[t]=n[t])})),this):0===arguments.length?l:this;var o,n}render(){return this}destroy(){return this.removeListeners(),this}reload(t){return this.destroy().initialize(this.attr(t)),this}addListeners(){return this}removeListeners(){return this}}const o=t=>!!(r(t)&&t.nodeName&&t.tagName&&1===t.nodeType),n=(t,e=300)=>!!i(t)&&setTimeout((()=>{t()}),e),h=t=>t*t,a=(e=null)=>{let s,i;return e?t(e)?i=document.querySelector(e):o(e)&&(i=e):(s=document.querySelectorAll("html,body"),i=s[0].scrollTop-s[1].scrollTop>=0?s[0]:s[1]),i},c=(t,e,s)=>{const r=a(t);let l=r.scrollTop,o=0;const n=e-l,c=r.scrollHeight,d=e-c<=0?e:c,u=t=>(i(s)&&s(t),!1),p=()=>{if(o+=1,n<0){if(l-=h(o),r.scrollTop=l,l<=e)return r.scrollTop=e,u(e)}else if(l+=h(o),r.scrollTop=l,l>=d)return r.scrollTop=d,u(d);requestAnimationFrame(p)};requestAnimationFrame(p)},d=t=>{let e=t.offsetTop;return null!==t.offsetParent&&(e+=d(t.offsetParent)),e},u=(t,e="")=>{const s=e.replace(/^>/i,"");return!!(e&&s&&t)&&(t.matches?t.matches(s):!!t.msMatchesSelector&&t.msMatchesSelector(s))},p=t=>t.host&&t!==document&&t.host.nodeType?t.host:t.parentNode,m=["focusout","blur","focusin","focus","load","unload","mouseenter","mouseleave"],f=(t,e,s)=>{const i=m.indexOf(e)>-1;s._delegateListener&&delete(s=s._delegateListener)._delegateListener,function(t,e,s){const i=t._listeners;let r=-1;if(i.length<1)return!1;i.forEach(((t,i)=>{const l=t.fn;e===t.type&&(r=i,l===s&&(r=i))})),r>-1&&i.splice(r,1)}(t,e,s),t.removeEventListener(e,s,i)},g=function(e,s,i=!1){const r=t(e)?document.querySelector(e):e,l=r.childNodes,n=((e,s)=>{let i=e._listeners||[];return t(s)&&s&&(i=i.filter((t=>t.type===s))),i})(r,s);n.forEach((t=>{f(r,t.type,t.fn)})),(i||!0===s||1===arguments.length)&&r&&l&&l.forEach((t=>{o(t)&&g(t,s,i)}))},b=(t,e,s)=>{if(!i(s))return g(t,e);f(t,e,s)},y=(t,e,s,i,r,l,o=!1)=>{const n=m.indexOf(s)>-1,h=function(n){const a=function(t){const e=t.target;return(s=e)&&3===s.nodeType?s.parentNode:s;var s}(n),c=((t,e,s,i)=>{const r=s||document;if(!t)return null;do{if(null!=e&&(e.startsWith(">")?t.parentNode===r&&u(t,e):u(t,e))||i&&t===r)return t;if(t===r)break}while(t=p(t))})(a,e,t);let d=l||t;n.delegateTarget=c,!0===l&&(d=r),c&&(!0===o&&b(t,s,h),i.call(d,n,r))};t._listeners||(t._listeners=[]),t._listeners.push({el:t,selector:e,type:s,fn:h,data:r,context:l,capture:n}),i._delegateListener=h,t.addEventListener(s,h,n)},$=function(t){t.stopPropagation(),t.preventDefault()},v={},E=t=>e(v,t)&&v[t].length>0,_=(t,e=!0)=>e?E(t):(t=>{let e=E(t),s=t.lastIndexOf(".");for(;!e&&-1!==s;)s=(t=t.substring(0,s)).lastIndexOf("."),e=E(t);return e})(t),w=(t,e,i=!0)=>{const r=t=>{if(!E(t))return!1;v[t].forEach((t=>{const i=["[object Int8Array]","[object Uint8Array]","[object Uint8ClampedArray]","[object Int16Array]","[object Uint16Array]","[object Int32Array]","[object Uint32Array]","[object Float32Array]","[object Float64Array]","[object BigInt64Array]","[object BigUint64Array]"].indexOf(s(e))>-1?e.toString():e;t.callback.call(t.context||t,i)}))},l=()=>{let e=t,s=t.lastIndexOf(".");for(;-1!==s;)e=e.substring(0,s),s=e.lastIndexOf("."),r(e);r(t),r("*")};if(!_(t))return!1;i?setTimeout(l,10):l()},T=t=>Array.isArray?Array.isArray(t):"[object Array]"===s(t),S=['','','','','','','','',''],L=(e,s="icon")=>t(e)?((t,e="icon")=>{const s=/id="(.*?)"/,i=/^(\w+)-/;return S.find((r=>{const l=s.exec(r)[1];return i.exec(l)[1]===e&&l===("icon"===e?`${e}-${t}`:`${e}-icon-${t}`)}))})(e,s):[...S],x=(e="")=>{const s=document.body;let i=document.querySelector("#outline-icons"),r=[];(e=>{if(!e)return!1;T(e)&&e.length>0?e.forEach((e=>{-1===S.indexOf(e)&&t(e)&&S.push(e)})):t(e)&&S.push(e)})(e),r=L(),i?i.innerHTML=r.join(""):(i=document.createElement("div"),i.innerHTML=``,s.insertBefore(i.firstChild,s.firstChild))},C=e=>!!t(e)&&e.replace(/(^\s+)|(\s+$)/g,""),z=t=>{return!(!r(t)||!(o(t)||(t=>!(!r(t)||"[object NodeList]"!==s(t)))(t)||(e=t,r(e)&&"[object DocumentFragment]"===s(e))||(t=>!(!r(t)||!("[object Text]"===s(t)||t.tagName&&3===t.nodeType)))(t)));var e},k=(t,e,s)=>{let i=t.tagName.toLowerCase();switch(e){case"style":t.style.cssText=s;break;case"value":"input"===i||"textarea"===i?t.value=s:t.setAttribute(e,s);break;case"className":t.className=s;break;default:t.setAttribute(e,s)}},A=(s,i,l)=>{const o=document.createDocumentFragment(),n=document.createElement(s),h=e=>z(e)||t(e),a=e=>{let s;if(!h(e))return!1;z(e)?s=e:t(e)&&(s=document.createTextNode(e)),o.appendChild(s)};return r(i)?Object.keys(i).forEach((t=>{e(i,t)&&k(n,t,i[t])})):T(i)&&i.every((t=>h(t)))&&i.forEach((t=>{a(t)})),T(l)?l.forEach((t=>{a(t)})):a(l),n.appendChild(o),n},N=e=>{const s=new RegExp("^\\s*(?:<\\?xml[^>]*>\\s*)?(?:<\\!doctype svg[^>]*\\s*(?:\\[?(?:\\s*]*>\\s*)*\\]?)*[^>]*>\\s*)?]*>[^]*<\\/svg>\\s*$\\s*$","i");return t(e)&&s.test(e)},O=(e,s={})=>((e,s={})=>{const i=s.size||0,r=s.color||"",l=s.iconSet||"",o=T(i)?i[0]:i,n=T(i)?i[1]:i,h=i?`width:${o}px;height:${n}px;`:"",a=r?h+`color:${r}`:h,c=document.createElement("i");let d,u="",p="";return t(e)?(N(e)?p=e:(u=l&&"icon"!==l?`xlink:href="#${l}-icon-${e}"`:`xlink:href="#icon-${e}"`,p=``),c.className="outline-icon",c.innerHTML=p,N(e)&&(d=c.querySelector("svg"),d.setAttribute("aria-hidden","true"),d.setAttribute("xmlns","http://www.w3.org/2000/svg"),d.setAttribute("class","outline-icon__svg"),d.setAttribute("width","200"),d.setAttribute("height","200"),d.style=a),c):null})(e,s),M=(t,e)=>{const s=new RegExp("(\\s|^)"+e+"(\\s|$)");let i,r;return!!o(t)&&(i=t.className,!!i&&(r=t.classList,r?.contains?t.classList.contains(e):!!s.exec(i)))},D=(t,e)=>{let s,i=t.className;if(!i||!M(t,e))return!1;s=t.classList,s?.remove?s.remove(e):(i=C(i.replace(e,"")),t.className=i)},H=(e,s=!0,i=!0)=>{const r="outline-heading",l=e.innerHTML;let o;if(e.innerHTML=l.replace(/^\d+(\.?\d+)*\s?/gi,""),e.removeAttribute("id"),e.removeAttribute("data-id"),D(e,r),!s)return!1;var n;o=e.querySelector(`.${r}__anchor`),i&&D(e,`${r}_start`),n=C(e.className),t(n)&&""===n&&e.removeAttribute("class"),e.removeChild(o)},j=(e,s=!0)=>{let i=1,r=0;const l=[];return e.forEach(((e,s)=>{const o=e.tagName.replace(/h/i,"");let n=parseInt(o,10),h=-1;var a;n>i?(r+=1,h=1===r?-1:s-1):n===i||nr?1===n?(r=1,h=-1):h=l[s-1].pid:n<=r&&(1===n?r=1:(r-=i-n,r<=1&&(r=1)),h=1===r?-1:((t,e,s)=>{let i,r,l=t[s-1];for(r=0;r]+(>|$)/g,""):"")})})),s?(t=>{const e={};return t.forEach((t=>{const s=JSON.stringify((t=>[t.pid])(t));e[s]=e[s]||[],e[s].push(t),t.index=e[s].length,-1===t.pid&&(t.code=String(t.index))})),Object.keys(e).forEach((s=>{e[s].forEach((e=>{t.filter((t=>t.pid===e.id)).forEach((t=>{t.code=e.code+"."+t.index}))}))})),t})(l):l};class F extends l{constructor(t){super(),this.attrs=F.DEFAULTS,this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],t&&this.initialize(t)}initialize(e){let s,r,l,n,h;return this.attr(e),h=this.attr("articleElement"),r=this.attr("scrollElement"),l=this.attr("selector"),s=this.attr("created"),t(h)?n=document.querySelector(h):o(h)&&(n=h),n?(this.$articleElement=n,this.$scrollElement=a(r),this.$headings=[...n.querySelectorAll(l)],this.$headings.length<1||(this.chapters=j(this.$headings),i(s)&&s.call(this),this.render().addListeners()),this):this}getChapters(t=!1){const e=this.chapters;return t?((t,e,s)=>{const i={},r=[];return t.forEach(((t,s)=>{i[t[e]]=s,t.children=[]})),t.forEach((e=>{const l=t[i[e[s]]];-1!==e[s]?l.children.push(e):r.push(e)})),r})(e,"id","pid"):e}count(){return this.chapters.length}render(){const t=this.attr("mounted"),e=this.attr("hasAnchor"),s=this.attr("isAtStart"),r=this.attr("showCode"),l=this.attr("anchorURL"),o=this.$headings,n=this.getChapters();return x(),o.forEach(((t,i)=>{const o=n[i].code;((t,e,s)=>{const i=document.createDocumentFragment(),r="outline-heading",l=s.hasAnchor||!0,o=s.isAtStart||!0,n=s.showCode||!1,h=s.chapterCode||"",a=s.anchorURL||"",c=`heading-${e}`,d={id:c,className:o?`${r} ${r}_start`:r,"data-id":e},u=Object.keys(d),p=C(t.innerHTML);let m,f;if(u.forEach((e=>{k(t,e,d[e])})),n&&(t.innerHTML=h+" "+p),!l)return!1;f=O("hash",{iconSet:"outline"}),m=A("a",{id:`anchor-${e}`,className:`${r}__anchor anchor-${e}`,href:a||`#${c}`,target:a?"_blank":"self","data-id":e},[f]),i.appendChild(m),t.appendChild(i)})(t,i,{hasAnchor:e,isAtStart:s,showCode:r,chapterCode:o,anchorURL:l})})),i(t)&&t.call(this),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}destroy(){const t=this.attr("hasAnchor"),e=this.attr("isAtStart"),s=this.attr("beforeDestroy"),r=this.attr("afterDestroy"),l=this.$headings;return i(s)&&s.call(this),this.removeListeners(),l.forEach((s=>{H(s,t,e)})),this.attr(F.DEFAULTS),this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],i(r)&&r.call(this),this}onAnchorTrigger(t){const e=this.attr("anchorURL"),s=this.attr("afterScroll"),r=this.attr("stickyHeight"),l=t.delegateTarget.parentNode,o=d(l)-(r+10),h=this.$scrollElement,a=h.scrollHeight-h.clientHeight;return this.scrollTo(o,(()=>{i(s)&&s.call(this,"anchor"),n((()=>{w("toolbar:update",{top:o,min:0,max:a})}))})),e||$(t),this}addListeners(){const t=this.$articleElement;return y(t,".outline-heading__anchor","click",this.onAnchorTrigger,this,!0),this}removeListeners(){const t=this.$articleElement;return b(t,"click",this.onAnchorTrigger),this}}F.DEFAULTS={scrollElement:"html,body",articleElement:"#article",selector:"h1,h2,h3,h4,h5,h6",stickyHeight:0,anchorURL:"",hasAnchor:!0,isAtStart:!0,showCode:!1,created:null,mounted:null,afterScroll:null,beforeDestroy:null,afterDestroy:null};const U=(t,e)=>{let s,i;if(M(t,e))return!1;s=t.classList,s?.add?s.add(e):(i=t.className,i+=i.length>0?" "+e:e,t.className=i)},I=(t,e)=>{document.documentElement.style.setProperty(t,e)};let q=2e3;const B=t=>(t?q=t:q+=1,I("--outline-zIndex",`${q}`),q);class R extends l{constructor(t){super(),this.attrs=R.DEFAULTS,this.title="",this.closed=!0,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,this.zIndex=0,t&&this.initialize(t)}initialize(t){let e;return this.attr(t),this.title=this.attr("title"),e=this.attr("created"),i(e)&&e.call(this),this.render().addListeners(),this}setTitle(t){return this.attr("title",t),this.title=t,this.$title.innerHTML=t,this}isClosed(){return this.closed}render(){const t=this.attr("mounted"),e=this.attr("size"),s=this.attr("placement"),r=this.attr("hasClose"),l=this.attr("hasOverlay"),o=this.attr("hasOffset"),n=this.attr("hasPadding"),h=this.attr("autoHeight"),a=this.attr("customClass");let c,d,u,p,m,f,g,b;return x(),this.zIndex=B(),p=A("h2",{className:"outline-drawer__title"},[this.title]),this.$title=p,r&&(m=A("div",{className:"outline-drawer__close"},[O("close",{size:20})]),this.$close=m),u=A("header",{className:"outline-drawer__header"},[p,m]),this.$header=u,f=A("div",{className:"outline-drawer__main"},[""]),this.$main=f,n||U(f,"outline-drawer_full"),g=A("footer",{className:"outline-drawer__footer"},[""]),this.$footer=g,d=A("div",{className:`outline-drawer__modal outline-drawer_${s} outline-drawer_${e} outline-drawer_closed`},[u,f,g]),this.$modal=d,o&&U(d,"outline-drawer_offset"),h&&U(d,"outline-drawer_auto"),a&&U(d,a),l&&(b=A("div",{className:"outline-drawer__overlay"},[""]),this.$overlay=b),c=A("div",{className:"outline-drawer"},[d,b]),this.$el=c,document.body.appendChild(c),i(t)&&t.call(this),this}open(){const t=this.attr("afterOpened"),e=this.$modal;return U(this.$el,"outline-drawer_opened"),D(e,"outline-drawer_closed"),U(e,"outline-drawer_opened"),n((()=>{this.closed=!1,i(t)&&t.call(this)})),this}close(){const t=this.attr("afterClosed"),e=this.$modal;return D(e,"outline-drawer_opened"),U(e,"outline-drawer_closed"),n((()=>{D(this.$el,"outline-drawer_opened"),this.closed=!0,i(t)&&t.call(this)})),this}toggle(){const t=this.attr("afterToggle"),e=this.isClosed();return e?this.open():this.close(),i(t)&&n((()=>{t.call(this,e)})),this}destroy(){const t=this.attr("afterDestroy"),e=this.attr("beforeDestroy");let s=this.zIndex;return i(e)&&e.call(this),this.removeListeners(),this.attrs=R.DEFAULTS,this.title="",this.closed=!1,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,s-=1,B(s),this.zIndex=0,i(t)&&t.call(this),this}addListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t&&y(s,".outline-drawer__close","click",this.onClose,this,!0),e&&y(s,".outline-drawer__overlay","click",this.onClose,this,!0),this}removeListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t||e?(b(s,"click",this.onClose),this):this}onClose(){return this.close(),this}}R.DEFAULTS={placement:"rtl",title:"标题",size:"regular",hasClose:!0,hasOverlay:!0,hasOffset:!1,hasPadding:!0,autoHeight:!0,created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterToggle:null};const P=(t,e,s,r,l,o=!1)=>{const n=m.indexOf(e)>-1,h=function(i){let n=l||t;!0===l&&(n=r),!0===o&&b(t,e,h),s.call(n,i,r)};if(!i(s))return!1;t._listeners||(t._listeners=[]),t._listeners.push({el:t,type:e,fn:h,data:r,context:l,capture:n}),s._delegateListener=h,t.addEventListener(e,h,n)},Q=(t,e)=>getComputedStyle(t)[e];class W extends l{constructor(t){super(),this.attrs=W.DEFAULTS,this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.closed=!1,this.active=0,this.offsetTop=0,this.offsetWidth=0,this.$active=null,this.scrollTimer=null,this.resizeTimer=null,this.playing=!1,this.Observer=null,t&&this.initialize(t)}initialize(e){let s,r,l,n;return this.attr(e),s=this.attr("created"),r=this.attr("parentElement"),l=this.attr("scrollElement"),t(r)?n=document.querySelector(r):o(r)&&(n=r),this.$parentElement=n,this.$scrollElement=a(l),this.chapters=this.attr("chapters"),this.closed=this.attr("closed"),this.active=this.attr("active"),i(s)&&s.call(this),this.chapters.length<1||(this.render().addListeners(),this.$active=document.querySelector(`#chapter-${this.active}`)),this}isClosed(){return this.closed}isSticky(){return"sticky"===this.attr("position")}isFixed(){return"fixed"===this.attr("position")}isInside(){return this.isFixed()||this.isSticky()}isOutside(){return!this.isInside()}_paintEdge(){const t=document.createDocumentFragment(),e=this.attr("title"),s=this.attr("customClass"),i=this.$parentElement,r=[];let l,o,n,h,a=null;return i?(this.isInside()&&(a=A("h2",{className:"outline-chapters__title"},[e]),this.$title=a,r.push(a)),n=A("ul",{className:"outline-chapters__list"},[""]),this.$list=n,h=A("div",{className:"outline-chapters__placeholder"},[""]),this.$placeholder=h,o=A("div",{className:"outline-chapters__main"},[n,h]),this.$main=o,r.push(o),l=A("nav",{id:"outline-chapters",className:"outline-chapters outline-chapters_hidden"},r),this.$el=l,this.isSticky()&&(this.calculateStickyHeight(),U(l,"outline-chapters_sticky")),s&&U(l,s),t.appendChild(l),i.appendChild(t),this):this}render(){const t=this.attr("showCode"),e=this.attr("mounted"),s=this.$parentElement,r=this.chapters;let l,o;return!s||r.length<1||(this._paintEdge(),l=this.$el,o=this.$list,((t,e,s=!1)=>{const i=t=>document.querySelector(`#${t}`);e.forEach((e=>{const r=e.pid,l=e.id,o=e.rel,n=A("span",{className:"outline-chapters__text"},[e.text]),h=A("a",{id:`chapter__anchor-${l}`,className:"outline-chapters__anchor",href:"#"+o,rel:o,"data-id":l},[n]);let a,c,d,u;s&&(a=A("span",{className:"outline-chapters__code","data-id":l},[e.code]),h.insertBefore(a,h.firstChild)),c=A("li",{id:`chapter-${l}`,className:"outline-chapters__item","data-id":l},[h]),-1===r?t.appendChild(c):(u=i(`chapter-${r}`),d=i(`subject-${r}`),d?d.appendChild(c):(d=A("ul",{id:"subject-"+r,className:"outline-chapters__subject"},[c]),u.appendChild(d)))}))})(o,r,t),D(l,"outline-chapters_hidden"),this.positionPlaceholder(this.active),this.offsetTop=d(l),this.offsetWidth=l.offsetWidth,this.isFixed()&&(this.sticky(),I("--outline-chapters-width",`${this.offsetWidth}px`)),i(e)&&e.call(this),this.onObserver()),this}positionPlaceholder(t){const e=this.$main,s=this.$list,i=this.$placeholder,r=s.querySelector(".outline-chapters__anchor"),l=parseInt(Q(e,"padding-top"),10),o=parseInt(Q(e,"border-top-width"),10),n=parseInt(Q(s,"padding-top"),10),h=parseInt(Q(s,"margin-top"),10),a=parseInt(Q(s,"border-top-width"),10);let c,d=r.offsetHeight,u=0;return l&&(u+=l),n&&(u+=n),h&&(u+=h),o&&(u+=o),a&&(u+=a),c=d*t,i.style.cssText=`transform: translateY(${u+c}px);height:${d}px;`,this}highlight(t){const e=this.$el.querySelector(`#chapter__anchor-${t}`),s="outline-chapters_active";return e?(this.$active&&D(this.$active,s),this.active=parseInt(e.getAttribute("data-id"),10),this.$active=e,U(this.$active,s),this.positionPlaceholder(this.active),this):this}sticky(){const t=this.attr("afterSticky"),e="outline-chapters_fixed",s=this.$el,r=this.offsetTop,l=this.$scrollElement.scrollTop;let o;return this.isFixed()?(o=l>=r,o?U(s,e):D(s,e),i(t)&&t.call(this,this.isClosed(),o),this):this}calculateStickyHeight(){const t=document.documentElement,e=Math.max(t.clientHeight||0,window.innerHeight||0);return I("--outline-sticky-height",`${e}px`),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}show(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterOpened"),r=this.$el,l=this.$parentElement;return this.isInside()?(D(l,e),D(r,e),n((()=>{D(l,t),D(r,t)}),30)):D(r,e),this.closed=!1,i(s)&&s.call(this),this}hide(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterClosed"),r=this.$el,l=this.$parentElement;return this.isInside()?(U(l,t),U(r,t),n((()=>{U(l,e),U(r,e)}))):U(r,e),this.closed=!0,i(s)&&s.call(this),this}toggle(){const t=this.attr("afterToggle"),e=this.offsetTop,s=this.$scrollElement.scrollTop;let r;return this.isClosed()?this.show():this.hide(),i(t)&&n((()=>{r=s>=e,t.call(this,this.isClosed(),r)})),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");return i(t)&&t.call(this),this.removeListeners(),this.$parentElement.removeChild(this.$el),this.attr(W.DEFAULTS),this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.active=0,this.offsetTop=0,this.$active=null,this.closed=!1,this.scrollTimer&&(clearTimeout(this.scrollTimer),this.scrollTimer=null),this.resizeTimer&&(clearTimeout(this.resizeTimer),this.resizeTimer=null),i(e)&&e.call(this),this.Observer&&(this.Observer=null),this}onObserver(){const t=this.attr("selector");let e=null;return this.Observer=((t,e={})=>{const s=e.root||null,r=e.selector||".outline-heading",l=e.context||null,n={rootMargin:e.rootMargin||"0px 0px -90% 0px"},h=new IntersectionObserver((e=>{e.forEach((e=>{e.intersectionRatio>0&&i(t)&&t.call(l||e.target,e.target)}))}),n),a=o(s)?s:document;return s&&(n.root=s),a.querySelectorAll(r).forEach((t=>{h.observe(t)})),h})((t=>{const s=t.getAttribute("data-id");if(this.playing)return!1;e&&clearTimeout(e),e=n((()=>{this.highlight(s)}),100)}),{selector:t,context:this}),this}onSelect(t){const e=this.attr("stickyHeight"),s=t.delegateTarget,r=s.getAttribute("data-id"),l=s.href.split("#")[1],o=document.querySelector(`#${l}`),h=d(o)-(e+10),a=this.$scrollElement.scrollHeight,c=this.attr("afterScroll"),u=()=>{i(c)&&c.call(this,"chapter"),n((()=>{this.playing=!1,w("toolbar:update",{top:h,min:0,max:a})}))};return this.playing=!0,this.isFixed()?(this.sticky(),n((()=>{this.scrollTo(h,u),this.highlight(r)}),10)):(this.scrollTo(h,u),this.highlight(r)),$(t),this}onScroll(){const t=this.$scrollElement;return this.scrollTimer&&clearTimeout(this.scrollTimer),this.scrollTimer=n((()=>{const e=t.scrollTop,s=t.scrollHeight-t.clientHeight;this.isFixed()&&this.sticky(),w("toolbar:update",{top:e,min:0,max:s})}),100),this}onResize(){return this.resizeTimer&&clearTimeout(this.resizeTimer),this.resizeTimer=n((()=>{this.calculateStickyHeight()})),this}addListeners(){const t=this.$el,e=this.$scrollElement,s=e.tagName.toLowerCase();let i=e;return"html"!==s&&"body"!==s||(i=window),y(t,".outline-chapters__anchor","click",this.onSelect,this,!0),P(i,"scroll",this.onScroll,this,!0),this.isSticky()&&P(i,"resize",this.onResize,this,!0),this}removeListeners(){const t=this.attr("selector"),e=this.$el,s=this.$scrollElement,i=s.tagName.toLowerCase();let r=s;return"html"!==i&&"body"!==i||(r=window),b(e,"click",this.onSelect),b(r,"scroll",this.onScroll),this.isSticky()&&P(r,"resize",this.onResize),this.Observer&&document.querySelectorAll(t).forEach((t=>{this.Observer.unobserve(t)})),this}}W.DEFAULTS={parentElement:"",scrollElement:"",selector:".outline-heading",active:0,closed:!1,showCode:!0,position:"relative",stickyHeight:0,chapters:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterSticky:null};const V=(t,e=!0)=>{const s=O(t.icon,{iconSet:t.iconSet||"outline",color:t.color||"",size:t.size}),i=A("a",{className:"outline-toolbar__anchor",href:t.link},[s]),r=A("div",{className:`outline-toolbar__button ${t.name}`},[t.link?i:s]);return U(s,"outline-toolbar__icon"),e&&U(r,"outline-toolbar_rounded"),t.disabled&&U(r,"outline-toolbar_disabled"),r},J="outline-toolbar_disabled",Y="outline-toolbar_hidden";class G extends l{constructor(t){super(),this.attrs=G.DEFAULTS,this.$el=null,this.disabled=!1,this.closed=!1,this.buttons=[],t&&this.initialize(t)}initialize(t){let e;return this.attr(t),e=this.attr("created"),this.disabled=this.attr("disabled"),this.closed=this.attr("closed"),i(e)&&e.call(this),this.render().addListeners(),this}isDisabled(t){const e=this.attr("buttons");let s;return t?(s=e.find((e=>e.name===t)),s?.disabled):this.disabled}isClosed(){return this.closed}highlight(t){const e=this.buttons.find((e=>e.name===t)),s="outline-toolbar_active";let i;return i||(i=e.$el,M(i,s)?D(i,s):U(i,s)),this}render(){const t=this.attr("mounted"),e=this.attr("buttons")||[],s=this.attr("rounded"),r=this.attr("placement"),l=document.createDocumentFragment(),o=document.createDocumentFragment();return x(),e.forEach((t=>{const e=V(t,s);l.appendChild(e),this.buttons.push({name:t.name,$el:e})})),this.$el=A("div",{id:"outline-toolbar",className:`outline-toolbar outline-toolbar_${r}`},[l]),o.appendChild(this.$el),document.body.appendChild(o),this.closed&&this.hide(),this.disabled&&this.disable(),i(t)&&t.call(this),this}add(t){const e=this.$el,s=this.attr("buttons"),l=t.action,o=document.createDocumentFragment();let n;return r(t)?(s.push(t),o.appendChild(V(t))):T(t)&&t.forEach((t=>{o.appendChild(V(t))})),e.appendChild(o),l&&i(l.handler)&&(n=l.type||"click",y(e,`.${t.name}`,n,l.handler)),this}remove(t){const e=this.$el,s=this.attr("buttons"),i=s.find((e=>e.name===t));let r,l=-1;return i?(s.forEach(((e,s)=>{e.name===t&&(l=s)})),l>-1&&this.attr().buttons.splice(l,1),r=e.querySelector(`.${t}`),this.switch(t,!1),e.removeChild(r),this):this}switch(t,e){const s=this.$el,i=this.attr("buttons"),r=i.find((e=>e.name===t));let l,o,n,h;return r?(i.forEach((s=>{s.name===t&&(r.disabled=!e)})),l=r.action,h=s.querySelector(`.${t}`),l&&(o=l.type||"click",n=l.handler),e?(D(h,J),o&&n&&y(s,`.${t}`,o,n)):(U(h,J),o&&n&&b(s,o,n)),this):this}disable(t){const e=this.attr("afterDisabled");return t?this.switch(t,!1):(U(this.$el,J),this.removeListeners(),this.disabled=!0,i(e)&&e.call(this)),this}enable(t){const e=this.attr("afterEnabled");return t?this.switch(t,!0):(this.disabled=!1,D(this.$el,J),this.addListeners(),i(e)&&e.call(this)),this}show(t){const e=this.attr("afterOpened"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),D(l,Y)}else D(r,Y),this.closed=!1,i(e)&&n((()=>{e.call(this)}),310);return this}hide(t){const e=this.attr("afterClosed"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),U(l,Y)}else U(r,Y),this.closed=!0,i(e)&&n((()=>{e.call(this)}),310);return this}toggle(){return this.isClosed()?this.show():this.hide(),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");let s=this.$el;return i(t)&&t.call(this),this.removeListeners(),document.body.removeChild(s),s=null,this.attr(G.DEFAULTS),this.disabled=!1,this.closed=!1,this.buttons=[],i(e)&&e.call(this),this}refresh(){const t=this.$el,e=this.attr("buttons")||[];return this.removeListeners(),t.innerHTML="",e.forEach((t=>{this.$el.appendChild(V(t))})),this.addListeners(),this}addListeners(){const e=this.attr("buttons"),s=this.$el;return!e||e.length<1||e.forEach((e=>{const r=e.action;let l,o,n,h;if(this.disabled)return!1;r&&(o=r.handler,t(o)&&(h=o,r.handler=function(){w(h,e.name)},o=r.handler),l=r.type||"click",n=r.context),i(o)&&y(s,`.${e.name}`,l,o,n||this,!0)})),this}removeListeners(){const t=this.attr("buttons"),e=this.$el;return!t||t.length<1||t.forEach((t=>{const s=t.action;let r,l;if(this.disabled)return!1;s&&(l=s.handler,r=s.type||"click"),i(l)&&b(e,r,l)})),this}}G.DEFAULTS={placement:"ltr",closed:!1,disabled:!1,rounded:!0,buttons:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterDisabled:null,afterEnabled:null,beforeDestroy:null,afterDestroy:null};const K=(()=>{let t=0;return e=>(t+=1,e?e+"-"+t:"guid-"+t)})(),X=(t,e,s=null)=>{const r=K();let l="symbol"==typeof t?t.toString():t;return i(e)?(v[l]||(v[l]=[]),v[l].push({topic:l,callback:e,context:s,token:r}),r):""},Z=t=>{if(!e(v,t))return!1;delete v[t]},tt=(t,e)=>{if(!_(t))return!1;e?(t=>{const e=Object.keys(v);if(!t||e.length<1)return!1;e.forEach((e=>{const s=v[e];let i;s.forEach(((e,r)=>{e.callback!==t&&e.token!==t||(i=e.topic,s.splice(-1,r))})),s.length<1&&Z(i)}))})(e):Z(t)};class et extends l{constructor(t){super(),this.attrs=et.DEFAULTS,this.anchors=null,this.drawer=null,this.chapters=null,this.toolbar=null,this.buttons=[],t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}getChapters(t=!1){return this.anchors.getChapters(t)}count(){return this.anchors.count()}render(){const t=this.attr("scrollElement"),e=document.querySelector(t)||document.getElementById(t);return this._renderAnchors()._renderChapters()._renderToolbar(),e&&this.onToolbarUpdate({top:e.scrollTop,min:0,max:e.scrollHeight}),this}_renderAnchors(){const t=this.attr("articleElement"),e=this.attr("selector"),s=this.attr("stickyHeight"),i=this.attr("scrollElement"),r=this.attr("showCode"),l=this.attr("anchorURL"),o=this.attr("afterScroll");return this.anchors=new F({articleElement:t,stickyHeight:s,scrollElement:i,selector:e,showCode:r,anchorURL:l,afterScroll:o}),this}_renderChapters(){const t=this.attr("title"),e=this.attr("stickyHeight"),s=this.attr("scrollElement"),i=this.attr("customClass"),r=this.attr("showCode"),l=this.attr("position"),o=this.attr("placement"),n=this.attr("afterSticky"),h=this.attr("afterToggle"),a=this.attr("afterScroll"),c=this.count();let d,u=this.attr("parentElement");return c<1||(d={scrollElement:s,showCode:r,position:l,title:t,stickyHeight:e,chapters:this.getChapters(),afterSticky:n,afterToggle:h,afterScroll:a},"relative"===l?(this.drawer=new R({placement:o,title:t,size:"tiny",hasOffset:!0,hasPadding:!1,customClass:i,afterClosed:()=>{this.toolbar.toggle()}}),u=this.drawer.$main):d.customClass=i,d.parentElement=u,this.chapters=new W(d)),this}_renderToolbar(){const t=this.attr("placement"),e=this.attr("homepage"),s=this.attr("git"),i=this.attr("tags"),r=this.attr("issues"),l=this.attr("tools"),o=this.count(),n={name:"homepage",icon:"homepage",size:20,link:e},h={name:"github",icon:"github",size:20,link:s},a={name:"tags",icon:"tags",size:20,link:i},c={name:"issues",icon:"issues",size:20,link:r},d={name:"menu",icon:"menu",size:18,action:{type:"click",handler:"toolbar:action:toggle"}},u=[];return u.push({name:"up",icon:"up",size:20,action:{type:"click",handler:"toolbar:action:up"}}),e&&u.push(n),o>0&&u.push(d),s&&u.push(h),i&&u.push(a),r&&u.push(c),l?.length>0&&u.push(...l),u.push({name:"down",icon:"down",size:20,action:{type:"click",handler:"toolbar:action:down"}}),this.buttons=[...u],this.toolbar=new G({placement:t,buttons:u}),this}addButton(t){const e=this.toolbar,s=this.buttons;return s.splice(-1,0,t),e.attr({buttons:s}),e.refresh(),this}removeButton(t){return this.toolbar.remove(t),this}toTop(){const t=this.attr("afterScroll"),e=this.toolbar,s=this.chapters,r=this.count();return r>0&&(s.playing=!0),this.scrollTo(0,(()=>{e.hide("up"),e.show("down"),r>0&&(s.highlight(0),s.playing=!1),i(t)&&t.call(e,"up")})),this}toBottom(){const t=this.attr("afterScroll"),e=a(this.attr("scrollElement")),s=this.toolbar,r=this.chapters,l=this.count(),o=Math.floor(e.scrollHeight-e.clientHeight);return l>0&&(r.playing=!0),this.scrollTo(o,(()=>{s.hide("down"),s.show("up"),l>0&&(r.highlight(l-1),r.playing=!1),i(t)&&t.call(s,"bottom")})),this}scrollTo(t,e){const s=this.attr("scrollElement");return c(s,t,e),this}toggle(){const t=this.attr("position"),e=this.toolbar,s=this.drawer,i=this.chapters;return this.count()<1||("relative"!==t?(i.toggle(),e.highlight("menu")):(e.toggle(),n((()=>{i.isInside()?i.toggle():s.toggle()})))),this}destroy(){let t=this.anchors,e=this.chapters,s=this.drawer,i=this.toolbar,r=!1;const l=this.count();return this.removeListeners(),l>0&&(r=e.isOutside(),e.destroy(),e=null,r&&(s.destroy(),s=null)),i.destroy(),i=null,t.destroy(),t=null,this.attr(et.DEFAULTS),this}onToggle(){return this.toggle(),this}onScrollTop(){return this.toTop(),this}onScrollBottom(){return this.toBottom(),this}onToolbarUpdate({top:t,min:e,max:s}){const i=this.toolbar,r=Math.ceil(t);return r<=e?(i.hide("up"),i.show("down")):r>=s?(i.hide("down"),i.show("up")):r>e&&r"string"==typeof t,e=(t,e)=>{const s=Object.prototype.hasOwnProperty;return t&&s.call(t,e)},s=t=>Object.prototype.toString.apply(t),i=t=>"function"==typeof t||"[object Function]"===s(t),r=t=>("[object Object]"===s(t)||"object"==typeof t||i(t))&&null!==t;class l{constructor(t){this.attrs={},t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}attr(s,i){const l=this.attrs;return t(s)?i&&e(l,s)?(l[s]=i,this):l[s]:r(s)?(n=l,o=s,Object.keys(o).forEach((t=>{e(o,t)&&(n[t]=o[t])})),this):0===arguments.length?l:this;var n,o}render(){return this}destroy(){return this.removeListeners(),this}reload(t){return this.destroy().initialize(this.attr(t)),this}addListeners(){return this}removeListeners(){return this}}const n=t=>!!(r(t)&&t.nodeName&&t.tagName&&1===t.nodeType),o=(t,e=300)=>!!i(t)&&setTimeout((()=>{t()}),e),h=t=>t*t,a=(e=null)=>{let s,i;return e?t(e)?i=document.querySelector(e):n(e)&&(i=e):(s=document.querySelectorAll("html,body"),i=s[0].scrollTop-s[1].scrollTop>=0?s[0]:s[1]),i},c=(t,e,s)=>{const r=a(t);let l=r.scrollTop,n=0;const o=e-l,c=r.scrollHeight,d=e-c<=0?e:c,u=t=>(i(s)&&s(t),!1),p=()=>{if(n+=1,o<0){if(l-=h(n),r.scrollTop=l,l<=e)return r.scrollTop=e,u(e)}else if(l+=h(n),r.scrollTop=l,l>=d)return r.scrollTop=d,u(d);requestAnimationFrame(p)};requestAnimationFrame(p)},d=t=>{let e=t.offsetTop;return null!==t.offsetParent&&(e+=d(t.offsetParent)),e},u=(t,e="")=>{const s=e.replace(/^>/i,"");return!!(e&&s&&t)&&(t.matches?t.matches(s):!!t.msMatchesSelector&&t.msMatchesSelector(s))},p=t=>t.host&&t!==document&&t.host.nodeType?t.host:t.parentNode,m=["focusout","blur","focusin","focus","load","unload","mouseenter","mouseleave"],f=(t,e,s)=>{const i=m.indexOf(e)>-1;s._delegateListener&&delete(s=s._delegateListener)._delegateListener,function(t,e,s){const i=t._listeners;let r=-1;if(i.length<1)return!1;i.forEach(((t,i)=>{const l=t.fn;e===t.type&&(r=i,l===s&&(r=i))})),r>-1&&i.splice(r,1)}(t,e,s),t.removeEventListener(e,s,i)},g=function(e,s,i=!1){const r=t(e)?document.querySelector(e):e,l=r.childNodes,o=((e,s)=>{let i=e._listeners||[];return t(s)&&s&&(i=i.filter((t=>t.type===s))),i})(r,s);o.forEach((t=>{f(r,t.type,t.fn)})),(i||!0===s||1===arguments.length)&&r&&l&&l.forEach((t=>{n(t)&&g(t,s,i)}))},b=(t,e,s)=>{if(!i(s))return g(t,e);f(t,e,s)},y=(t,e,s,i,r,l,n=!1)=>{const o=m.indexOf(s)>-1,h=function(o){const a=function(t){const e=t.target;return(s=e)&&3===s.nodeType?s.parentNode:s;var s}(o),c=((t,e,s,i)=>{const r=s||document;if(!t)return null;do{if(null!=e&&(e.startsWith(">")?t.parentNode===r&&u(t,e):u(t,e))||i&&t===r)return t;if(t===r)break}while(t=p(t))})(a,e,t);let d=l||t;o.delegateTarget=c,!0===l&&(d=r),c&&(!0===n&&b(t,s,h),i.call(d,o,r))};t._listeners||(t._listeners=[]),t._listeners.push({el:t,selector:e,type:s,fn:h,data:r,context:l,capture:o}),i._delegateListener=h,t.addEventListener(s,h,o)},$=function(t){t.stopPropagation(),t.preventDefault()},v={},E=t=>e(v,t)&&v[t].length>0,_=(t,e=!0)=>e?E(t):(t=>{let e=E(t),s=t.lastIndexOf(".");for(;!e&&-1!==s;)s=(t=t.substring(0,s)).lastIndexOf("."),e=E(t);return e})(t),w=(t,e,i=!0)=>{const r=t=>{if(!E(t))return!1;v[t].forEach((t=>{const i=["[object Int8Array]","[object Uint8Array]","[object Uint8ClampedArray]","[object Int16Array]","[object Uint16Array]","[object Int32Array]","[object Uint32Array]","[object Float32Array]","[object Float64Array]","[object BigInt64Array]","[object BigUint64Array]"].indexOf(s(e))>-1?e.toString():e;t.callback.call(t.context||t,i)}))},l=()=>{let e=t,s=t.lastIndexOf(".");for(;-1!==s;)e=e.substring(0,s),s=e.lastIndexOf("."),r(e);r(t),r("*")};if(!_(t))return!1;i?setTimeout(l,10):l()},T=t=>Array.isArray?Array.isArray(t):"[object Array]"===s(t),S=['','','','','','','','',''],L=(e,s="icon")=>t(e)?((t,e="icon")=>{const s=/id="(.*?)"/,i=/^(\w+)-/;return S.find((r=>{const l=s.exec(r)[1];return i.exec(l)[1]===e&&l===("icon"===e?`${e}-${t}`:`${e}-icon-${t}`)}))})(e,s):[...S],x=(e="")=>{const s=document.body;let i=document.querySelector("#outline-icons"),r=[];(e=>{if(!e)return!1;T(e)&&e.length>0?e.forEach((e=>{-1===S.indexOf(e)&&t(e)&&S.push(e)})):t(e)&&S.push(e)})(e),r=L(),i?i.innerHTML=r.join(""):(i=document.createElement("div"),i.innerHTML=``,s.insertBefore(i.firstChild,s.firstChild))},C=e=>!!t(e)&&e.replace(/(^\s+)|(\s+$)/g,""),z=t=>{return!(!r(t)||!(n(t)||(t=>!(!r(t)||"[object NodeList]"!==s(t)))(t)||(e=t,r(e)&&"[object DocumentFragment]"===s(e))||(t=>!(!r(t)||!("[object Text]"===s(t)||t.tagName&&3===t.nodeType)))(t)));var e},k=(t,e,s)=>{let i=t.tagName.toLowerCase();switch(e){case"style":t.style.cssText=s;break;case"value":"input"===i||"textarea"===i?t.value=s:t.setAttribute(e,s);break;case"className":t.className=s;break;default:t.setAttribute(e,s)}},A=(s,i,l)=>{const n=document.createDocumentFragment(),o=document.createElement(s),h=e=>z(e)||t(e),a=e=>{let s;if(!h(e))return!1;z(e)?s=e:t(e)&&(s=document.createTextNode(e)),n.appendChild(s)};return r(i)?Object.keys(i).forEach((t=>{e(i,t)&&k(o,t,i[t])})):T(i)&&i.every((t=>h(t)))&&i.forEach((t=>{a(t)})),T(l)?l.forEach((t=>{a(t)})):a(l),o.appendChild(n),o},N=e=>{const s=new RegExp("^\\s*(?:<\\?xml[^>]*>\\s*)?(?:<\\!doctype svg[^>]*\\s*(?:\\[?(?:\\s*]*>\\s*)*\\]?)*[^>]*>\\s*)?]*>[^]*<\\/svg>\\s*$\\s*$","i");return t(e)&&s.test(e)},M=(e,s={})=>((e,s={})=>{const i=s.size||0,r=s.color||"",l=s.iconSet||"",n=T(i)?i[0]:i,o=T(i)?i[1]:i,h=i?`width:${n}px;height:${o}px;`:"",a=r?h+`color:${r}`:h,c=document.createElement("i");let d,u="",p="";return t(e)?(N(e)?p=e:(u=l&&"icon"!==l?`xlink:href="#${l}-icon-${e}"`:`xlink:href="#icon-${e}"`,p=``),c.className="outline-icon",c.innerHTML=p,N(e)&&(d=c.querySelector("svg"),d.setAttribute("aria-hidden","true"),d.setAttribute("xmlns","http://www.w3.org/2000/svg"),d.setAttribute("class","outline-icon__svg"),d.setAttribute("width","200"),d.setAttribute("height","200"),d.style=a),c):null})(e,s),H=(t,e)=>{const s=new RegExp("(\\s|^)"+e+"(\\s|$)");let i,r;return!!n(t)&&(i=t.className,!!i&&(r=t.classList,r?.contains?t.classList.contains(e):!!s.exec(i)))},O=(t,e)=>{let s,i=t.className;if(!i||!H(t,e))return!1;s=t.classList,s?.remove?s.remove(e):(i=C(i.replace(e,"")),t.className=i)},D=(e,s=!0,i=!0)=>{const r="outline-heading",l=e.innerHTML;let n;if(e.innerHTML=l.replace(/^\d+(\.?\d+)*\s?/gi,""),e.removeAttribute("id"),e.removeAttribute("data-id"),O(e,r),!s)return!1;var o;n=e.querySelector(`.${r}__anchor`),i&&O(e,`${r}_start`),o=C(e.className),t(o)&&""===o&&e.removeAttribute("class"),e.removeChild(n)},j=(e,s=!0)=>{let i=1,r=0;const l=[];return e.forEach(((e,s)=>{const n=e.tagName.replace(/h/i,"");let o=parseInt(n,10),h=-1;var a;o>i?(r+=1,h=1===r?-1:s-1):o===i||or?1===o?(r=1,h=-1):h=l[s-1].pid:o<=r&&(1===o?r=1:(r-=i-o,r<=1&&(r=1)),h=1===r?-1:((t,e,s)=>{let i,r,l=t[s-1];for(r=0;r]+(>|$)/g,""):"")})})),s?(t=>{const e={};return t.forEach((t=>{const s=JSON.stringify((t=>[t.pid])(t));e[s]=e[s]||[],e[s].push(t),t.index=e[s].length,-1===t.pid&&(t.code=String(t.index))})),Object.keys(e).forEach((s=>{e[s].forEach((e=>{t.filter((t=>t.pid===e.id)).forEach((t=>{t.code=e.code+"."+t.index}))}))})),t})(l):l};class F extends l{constructor(t){super(),this.attrs=F.DEFAULTS,this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],t&&this.initialize(t)}initialize(e){let s,r,l,o,h;return this.attr(e),h=this.attr("articleElement"),r=this.attr("scrollElement"),l=this.attr("selector"),s=this.attr("created"),t(h)?o=document.querySelector(h):n(h)&&(o=h),o?(this.$articleElement=o,this.$scrollElement=a(r),this.$headings=[...o.querySelectorAll(l)],this.$headings.length<1||(this.chapters=j(this.$headings),i(s)&&s.call(this),this.render().addListeners()),this):this}getChapters(t=!1){const e=this.chapters;return t?((t,e,s)=>{const i={},r=[];return t.forEach(((t,s)=>{i[t[e]]=s,t.children=[]})),t.forEach((e=>{const l=t[i[e[s]]];-1!==e[s]?l.children.push(e):r.push(e)})),r})(e,"id","pid"):e}count(){return this.chapters.length}render(){const t=this.attr("mounted"),e=this.attr("hasAnchor"),s=this.attr("isAtStart"),r=this.attr("showCode"),l=this.attr("anchorURL"),n=this.$headings,o=this.getChapters();return x(),n.forEach(((t,i)=>{const n=o[i].code;((t,e,s)=>{const i=document.createDocumentFragment(),r="outline-heading",l=s.hasAnchor||!0,n=s.isAtStart||!0,o=s.showCode||!1,h=s.chapterCode||"",a=s.anchorURL||"",c=`heading-${e}`,d={id:c,className:n?`${r} ${r}_start`:r,"data-id":e},u=Object.keys(d),p=C(t.innerHTML);let m,f;if(u.forEach((e=>{k(t,e,d[e])})),o&&(t.innerHTML=h+" "+p),!l)return!1;f=M("hash",{iconSet:"outline"}),m=A("a",{id:`anchor-${e}`,className:`${r}__anchor anchor-${e}`,href:a||`#${c}`,target:a?"_blank":"self","data-id":e},[f]),i.appendChild(m),t.appendChild(i)})(t,i,{hasAnchor:e,isAtStart:s,showCode:r,chapterCode:n,anchorURL:l})})),i(t)&&t.call(this),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}destroy(){const t=this.attr("hasAnchor"),e=this.attr("isAtStart"),s=this.attr("beforeDestroy"),r=this.attr("afterDestroy"),l=this.$headings;return i(s)&&s.call(this),this.removeListeners(),l.forEach((s=>{D(s,t,e)})),this.attr(F.DEFAULTS),this.$articleElement=null,this.$scrollElement=null,this.$headings=[],this.chapters=[],i(r)&&r.call(this),this}onAnchorTrigger(t){const e=this.attr("anchorURL"),s=this.attr("afterScroll"),r=this.attr("stickyHeight"),l=t.delegateTarget.parentNode,n=d(l)-(r+10),h=this.$scrollElement,a=h.scrollHeight-h.clientHeight;return this.scrollTo(n,(()=>{i(s)&&s.call(this,"anchor"),o((()=>{w("toolbar:update",{top:n,min:0,max:a})}))})),e||$(t),this}addListeners(){const t=this.$articleElement;return y(t,".outline-heading__anchor","click",this.onAnchorTrigger,this,!0),this}removeListeners(){const t=this.$articleElement;return b(t,"click",this.onAnchorTrigger),this}}F.DEFAULTS={scrollElement:"html,body",articleElement:"#article",selector:"h1,h2,h3,h4,h5,h6",stickyHeight:0,anchorURL:"",hasAnchor:!0,isAtStart:!0,showCode:!1,created:null,mounted:null,afterScroll:null,beforeDestroy:null,afterDestroy:null};const U=(t,e)=>{let s,i;if(H(t,e))return!1;s=t.classList,s?.add?s.add(e):(i=t.className,i+=i.length>0?" "+e:e,t.className=i)},I=(t,e)=>{document.documentElement.style.setProperty(t,e)};let q=2e3;const B=t=>(t?q=t:q+=1,I("--outline-zIndex",`${q}`),q);class R extends l{constructor(t){super(),this.attrs=R.DEFAULTS,this.title="",this.closed=!0,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,this.zIndex=0,t&&this.initialize(t)}initialize(t){let e;return this.attr(t),this.title=this.attr("title"),e=this.attr("created"),i(e)&&e.call(this),this.render().addListeners(),this}setTitle(t){return this.attr("title",t),this.title=t,this.$title.innerHTML=t,this}isClosed(){return this.closed}render(){const t=this.attr("mounted"),e=this.attr("size"),s=this.attr("placement"),r=this.attr("hasClose"),l=this.attr("hasOverlay"),n=this.attr("hasOffset"),o=this.attr("hasPadding"),h=this.attr("autoHeight"),a=this.attr("customClass");let c,d,u,p,m,f,g,b;return x(),this.zIndex=B(),p=A("h2",{className:"outline-drawer__title"},[this.title]),this.$title=p,r&&(m=A("div",{className:"outline-drawer__close"},[M("close",{size:20})]),this.$close=m),u=A("header",{className:"outline-drawer__header"},[p,m]),this.$header=u,f=A("div",{className:"outline-drawer__main"},[""]),this.$main=f,o||U(f,"outline-drawer_full"),g=A("footer",{className:"outline-drawer__footer"},[""]),this.$footer=g,d=A("div",{className:`outline-drawer__modal outline-drawer_${s} outline-drawer_${e} outline-drawer_closed`},[u,f,g]),this.$modal=d,n&&U(d,"outline-drawer_offset"),h&&U(d,"outline-drawer_auto"),a&&U(d,a),l&&(b=A("div",{className:"outline-drawer__overlay"},[""]),this.$overlay=b),c=A("div",{className:"outline-drawer"},[d,b]),this.$el=c,document.body.appendChild(c),i(t)&&t.call(this),this}open(){const t=this.attr("afterOpened"),e=this.$modal;return U(this.$el,"outline-drawer_opened"),O(e,"outline-drawer_closed"),U(e,"outline-drawer_opened"),o((()=>{this.closed=!1,i(t)&&t.call(this)})),this}close(){const t=this.attr("afterClosed"),e=this.$modal;return O(e,"outline-drawer_opened"),U(e,"outline-drawer_closed"),o((()=>{O(this.$el,"outline-drawer_opened"),this.closed=!0,i(t)&&t.call(this)})),this}toggle(){const t=this.attr("afterToggle"),e=this.isClosed();return e?this.open():this.close(),i(t)&&o((()=>{t.call(this,e)})),this}destroy(){const t=this.attr("afterDestroy"),e=this.attr("beforeDestroy");let s=this.zIndex;return i(e)&&e.call(this),this.removeListeners(),this.attrs=R.DEFAULTS,this.title="",this.closed=!1,this.$el=null,this.$modal=null,this.$header=null,this.$title=null,this.$close=null,this.$main=null,this.$footer=null,this.$overlay=null,s-=1,B(s),this.zIndex=0,i(t)&&t.call(this),this}addListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t&&y(s,".outline-drawer__close","click",this.onClose,this,!0),e&&y(s,".outline-drawer__overlay","click",this.onClose,this,!0),this}removeListeners(){const t=this.attr("hasClose"),e=this.attr("hasOverlay"),s=this.$el;return t||e?(b(s,"click",this.onClose),this):this}onClose(){return this.close(),this}}R.DEFAULTS={placement:"rtl",title:"标题",size:"regular",hasClose:!0,hasOverlay:!0,hasOffset:!1,hasPadding:!0,autoHeight:!0,created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterToggle:null};const P=(t,e,s,r,l,n=!1)=>{const o=m.indexOf(e)>-1,h=function(i){let o=l||t;!0===l&&(o=r),!0===n&&b(t,e,h),s.call(o,i,r)};if(!i(s))return!1;t._listeners||(t._listeners=[]),t._listeners.push({el:t,type:e,fn:h,data:r,context:l,capture:o}),s._delegateListener=h,t.addEventListener(e,h,o)},Q=(t,e)=>getComputedStyle(t)[e];class W extends l{constructor(t){super(),this.attrs=W.DEFAULTS,this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.closed=!1,this.active=0,this.offsetTop=0,this.offsetWidth=0,this.$active=null,this.scrollTimer=null,this.resizeTimer=null,this.playing=!1,this.Observer=null,t&&this.initialize(t)}initialize(e){let s,r,l,o;return this.attr(e),s=this.attr("created"),r=this.attr("parentElement"),l=this.attr("scrollElement"),t(r)?o=document.querySelector(r):n(r)&&(o=r),this.$parentElement=o,this.$scrollElement=a(l),this.chapters=this.attr("chapters"),this.closed=this.attr("closed"),this.active=this.attr("active"),i(s)&&s.call(this),this.chapters.length<1||(this.render().addListeners(),this.$active=document.querySelector(`#chapter-${this.active}`)),this}isClosed(){return this.closed}isSticky(){return"sticky"===this.attr("position")}isFixed(){return"fixed"===this.attr("position")}isInside(){return this.isFixed()||this.isSticky()}isOutside(){return!this.isInside()}_paintEdge(){const t=document.createDocumentFragment(),e=this.attr("title"),s=this.attr("customClass"),i=this.$parentElement,r=[];let l,n,o,h,a=null;return i?(this.isInside()&&(a=A("h2",{className:"outline-chapters__title"},[e]),this.$title=a,r.push(a)),o=A("ul",{className:"outline-chapters__list"},[""]),this.$list=o,h=A("div",{className:"outline-chapters__placeholder"},[""]),this.$placeholder=h,n=A("div",{className:"outline-chapters__main"},[o,h]),this.$main=n,r.push(n),l=A("nav",{id:"outline-chapters",className:"outline-chapters outline-chapters_hidden"},r),this.$el=l,this.isSticky()&&(this.calculateStickyHeight(),U(l,"outline-chapters_sticky")),s&&U(l,s),t.appendChild(l),i.appendChild(t),this):this}render(){const t=this.attr("showCode"),e=this.attr("mounted"),s=this.$parentElement,r=this.chapters;let l,n;return!s||r.length<1||(this._paintEdge(),l=this.$el,n=this.$list,((t,e,s=!1)=>{const i=t=>document.querySelector(`#${t}`);e.forEach((e=>{const r=e.pid,l=e.id,n=e.rel,o=A("span",{className:"outline-chapters__text"},[e.text]),h=A("a",{id:`chapter__anchor-${l}`,className:"outline-chapters__anchor",href:"#"+n,rel:n,"data-id":l},[o]);let a,c,d,u;s&&(a=A("span",{className:"outline-chapters__code","data-id":l},[e.code]),h.insertBefore(a,h.firstChild)),c=A("li",{id:`chapter-${l}`,className:"outline-chapters__item","data-id":l},[h]),-1===r?t.appendChild(c):(u=i(`chapter-${r}`),d=i(`subject-${r}`),d?d.appendChild(c):(d=A("ul",{id:"subject-"+r,className:"outline-chapters__subject"},[c]),u.appendChild(d)))}))})(n,r,t),O(l,"outline-chapters_hidden"),this.positionPlaceholder(this.active),this.offsetTop=d(l),this.offsetWidth=l.offsetWidth,this.isFixed()&&(this.sticky(),I("--outline-chapters-width",`${this.offsetWidth}px`)),i(e)&&e.call(this),this.onObserver()),this}positionPlaceholder(t){const e=this.$main,s=this.$list,i=this.$placeholder,r=s.querySelector(".outline-chapters__anchor"),l=parseInt(Q(e,"padding-top"),10),n=parseInt(Q(e,"border-top-width"),10),o=parseInt(Q(s,"padding-top"),10),h=parseInt(Q(s,"margin-top"),10),a=parseInt(Q(s,"border-top-width"),10);let c,d=r.offsetHeight,u=0;return l&&(u+=l),o&&(u+=o),h&&(u+=h),n&&(u+=n),a&&(u+=a),c=d*t,i.style.cssText=`transform: translateY(${u+c}px);height:${d}px;`,this}highlight(t){const e=this.$el.querySelector(`#chapter__anchor-${t}`),s="outline-chapters_active";return e?(this.$active&&O(this.$active,s),this.active=parseInt(e.getAttribute("data-id"),10),this.$active=e,U(this.$active,s),this.positionPlaceholder(this.active),this):this}sticky(){const t=this.attr("afterSticky"),e="outline-chapters_fixed",s=this.$el,r=this.offsetTop,l=this.$scrollElement.scrollTop;let n;return this.isFixed()?(n=l>=r,n?U(s,e):O(s,e),i(t)&&t.call(this,this.isClosed(),n),this):this}calculateStickyHeight(){const t=document.documentElement,e=Math.max(t.clientHeight||0,window.innerHeight||0);return I("--outline-sticky-height",`${e}px`),this}scrollTo(t,e){const s=this.$scrollElement;return c(s,t,e),this}show(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterOpened"),r=this.$el,l=this.$parentElement;return this.isInside()?(O(l,e),O(r,e),o((()=>{O(l,t),O(r,t)}),30)):O(r,e),this.closed=!1,i(s)&&s.call(this),this}hide(){const t="outline-chapters_folded",e="outline-chapters_hidden",s=this.attr("afterClosed"),r=this.$el,l=this.$parentElement;return this.isInside()?(U(l,t),U(r,t),o((()=>{U(l,e),U(r,e)}))):U(r,e),this.closed=!0,i(s)&&s.call(this),this}toggle(){const t=this.attr("afterToggle"),e=this.offsetTop,s=this.$scrollElement.scrollTop;let r;return this.isClosed()?this.show():this.hide(),i(t)&&o((()=>{r=s>=e,t.call(this,this.isClosed(),r)})),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");return i(t)&&t.call(this),this.removeListeners(),this.$parentElement.removeChild(this.$el),this.attr(W.DEFAULTS),this.$el=null,this.$title=null,this.$main=null,this.$list=null,this.$placeholder=null,this.$parentElement=null,this.$scrollElement=null,this.chapters=[],this.active=0,this.offsetTop=0,this.$active=null,this.closed=!1,this.scrollTimer&&(clearTimeout(this.scrollTimer),this.scrollTimer=null),this.resizeTimer&&(clearTimeout(this.resizeTimer),this.resizeTimer=null),i(e)&&e.call(this),this.Observer&&(this.Observer=null),this}onObserver(){const t=this.attr("selector");let e=null;return this.Observer=((t,e={})=>{const s=e.root||null,r=e.selector||".outline-heading",l=e.context||null,o={rootMargin:e.rootMargin||"0px 0px -90% 0px"},h=new IntersectionObserver((e=>{e.forEach((e=>{e.intersectionRatio>0&&i(t)&&t.call(l||e.target,e.target)}))}),o),a=n(s)?s:document;return s&&(o.root=s),a.querySelectorAll(r).forEach((t=>{h.observe(t)})),h})((t=>{const s=t.getAttribute("data-id");if(this.playing)return!1;e&&clearTimeout(e),e=o((()=>{this.highlight(s)}),100)}),{selector:t,context:this}),this}onSelect(t){const e=this.attr("stickyHeight"),s=t.delegateTarget,r=s.getAttribute("data-id"),l=s.href.split("#")[1],n=document.querySelector(`#${l}`),h=d(n)-(e+10),a=this.$scrollElement.scrollHeight,c=this.attr("afterScroll"),u=()=>{i(c)&&c.call(this,"chapter"),o((()=>{this.playing=!1,w("toolbar:update",{top:h,min:0,max:a})}))};return this.playing=!0,this.isFixed()?(this.sticky(),o((()=>{this.scrollTo(h,u),this.highlight(r)}),10)):(this.scrollTo(h,u),this.highlight(r)),$(t),this}onScroll(){const t=this.$scrollElement;return this.scrollTimer&&clearTimeout(this.scrollTimer),this.scrollTimer=o((()=>{const e=t.scrollTop,s=t.scrollHeight-t.clientHeight;this.isFixed()&&this.sticky(),w("toolbar:update",{top:e,min:0,max:s})}),100),this}onResize(){return this.resizeTimer&&clearTimeout(this.resizeTimer),this.resizeTimer=o((()=>{this.calculateStickyHeight()})),this}addListeners(){const t=this.$el,e=this.$scrollElement,s=e.tagName.toLowerCase();let i=e;return"html"!==s&&"body"!==s||(i=window),y(t,".outline-chapters__anchor","click",this.onSelect,this,!0),P(i,"scroll",this.onScroll,this,!0),this.isSticky()&&P(i,"resize",this.onResize,this,!0),this}removeListeners(){const t=this.attr("selector"),e=this.$el,s=this.$scrollElement,i=s.tagName.toLowerCase();let r=s;return"html"!==i&&"body"!==i||(r=window),b(e,"click",this.onSelect),b(r,"scroll",this.onScroll),this.isSticky()&&P(r,"resize",this.onResize),this.Observer&&document.querySelectorAll(t).forEach((t=>{this.Observer.unobserve(t)})),this}}W.DEFAULTS={parentElement:"",scrollElement:"",selector:".outline-heading",active:0,closed:!1,showCode:!0,position:"relative",stickyHeight:0,chapters:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterScroll:null,beforeDestroy:null,afterDestroy:null,afterSticky:null};const V=(t,e=!0)=>{const s=M(t.icon,{iconSet:t.iconSet||"outline",color:t.color||"",size:t.size}),i=A("a",{className:"outline-toolbar__anchor",href:t.link},[s]),r=A("div",{className:`outline-toolbar__button ${t.name}`},[t.link?i:s]);return U(s,"outline-toolbar__icon"),e&&U(r,"outline-toolbar_rounded"),t.disabled&&U(r,"outline-toolbar_disabled"),r},J="outline-toolbar_disabled",Y="outline-toolbar_hidden";class G extends l{constructor(t){super(),this.attrs=G.DEFAULTS,this.$el=null,this.disabled=!1,this.closed=!1,this.buttons=[],t&&this.initialize(t)}initialize(t){let e;return this.attr(t),e=this.attr("created"),this.disabled=this.attr("disabled"),this.closed=this.attr("closed"),i(e)&&e.call(this),this.render().addListeners(),this}isDisabled(t){const e=this.attr("buttons");let s;return t?(s=e.find((e=>e.name===t)),s?.disabled):this.disabled}isClosed(){return this.closed}highlight(t){const e=this.buttons.find((e=>e.name===t)),s="outline-toolbar_active";let i;return i||(i=e.$el,H(i,s)?O(i,s):U(i,s)),this}render(){const t=this.attr("mounted"),e=this.attr("buttons")||[],s=this.attr("rounded"),r=this.attr("placement"),l=document.createDocumentFragment(),n=document.createDocumentFragment();return x(),e.forEach((t=>{const e=V(t,s);l.appendChild(e),this.buttons.push({name:t.name,$el:e})})),this.$el=A("div",{id:"outline-toolbar",className:`outline-toolbar outline-toolbar_${r}`},[l]),n.appendChild(this.$el),document.body.appendChild(n),this.closed&&this.hide(),this.disabled&&this.disable(),i(t)&&t.call(this),this}add(t){const e=this.$el,s=this.attr("buttons"),l=t.action,n=document.createDocumentFragment();let o;return r(t)?(s.push(t),n.appendChild(V(t))):T(t)&&t.forEach((t=>{n.appendChild(V(t))})),e.appendChild(n),l&&i(l.handler)&&(o=l.type||"click",y(e,`.${t.name}`,o,l.handler)),this}remove(t){const e=this.$el,s=this.attr("buttons"),i=s.find((e=>e.name===t));let r,l=-1;return i?(s.forEach(((e,s)=>{e.name===t&&(l=s)})),l>-1&&this.attr().buttons.splice(l,1),r=e.querySelector(`.${t}`),this.switch(t,!1),e.removeChild(r),this):this}switch(t,e){const s=this.$el,i=this.attr("buttons"),r=i.find((e=>e.name===t));let l,n,o,h;return r?(i.forEach((s=>{s.name===t&&(r.disabled=!e)})),l=r.action,h=s.querySelector(`.${t}`),l&&(n=l.type||"click",o=l.handler),e?(O(h,J),n&&o&&y(s,`.${t}`,n,o)):(U(h,J),n&&o&&b(s,n,o)),this):this}disable(t){const e=this.attr("afterDisabled");return t?this.switch(t,!1):(U(this.$el,J),this.removeListeners(),this.disabled=!0,i(e)&&e.call(this)),this}enable(t){const e=this.attr("afterEnabled");return t?this.switch(t,!0):(this.disabled=!1,O(this.$el,J),this.addListeners(),i(e)&&e.call(this)),this}show(t){const e=this.attr("afterOpened"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),O(l,Y)}else O(r,Y),this.closed=!1,i(e)&&o((()=>{e.call(this)}),310);return this}hide(t){const e=this.attr("afterClosed"),s=this.attr("buttons").find((e=>e.name===t)),r=this.$el;let l;if(t){if(!s)return this;l=r.querySelector(`.${t}`),U(l,Y)}else U(r,Y),this.closed=!0,i(e)&&o((()=>{e.call(this)}),310);return this}toggle(){return this.isClosed()?this.show():this.hide(),this}destroy(){const t=this.attr("beforeDestroy"),e=this.attr("afterDestroy");let s=this.$el;return i(t)&&t.call(this),this.removeListeners(),document.body.removeChild(s),s=null,this.attr(G.DEFAULTS),this.disabled=!1,this.closed=!1,this.buttons=[],i(e)&&e.call(this),this}refresh(){const t=this.$el,e=this.attr("buttons")||[];return this.removeListeners(),t.innerHTML="",e.forEach((t=>{this.$el.appendChild(V(t))})),this.addListeners(),this}addListeners(){const e=this.attr("buttons"),s=this.$el;return!e||e.length<1||e.forEach((e=>{const r=e.action;let l,n,o,h;if(this.disabled)return!1;r&&(n=r.handler,t(n)&&(h=n,r.handler=function(){w(h,e.name)},n=r.handler),l=r.type||"click",o=r.context),i(n)&&y(s,`.${e.name}`,l,n,o||this,!0)})),this}removeListeners(){const t=this.attr("buttons"),e=this.$el;return!t||t.length<1||t.forEach((t=>{const s=t.action;let r,l;if(this.disabled)return!1;s&&(l=s.handler,r=s.type||"click"),i(l)&&b(e,r,l)})),this}}G.DEFAULTS={placement:"ltr",closed:!1,disabled:!1,rounded:!0,buttons:[],created:null,mounted:null,afterClosed:null,afterOpened:null,afterDisabled:null,afterEnabled:null,beforeDestroy:null,afterDestroy:null};const K=(()=>{let t=0;return e=>(t+=1,e?e+"-"+t:"guid-"+t)})(),X=(t,e,s=null)=>{const r=K();let l="symbol"==typeof t?t.toString():t;return i(e)?(v[l]||(v[l]=[]),v[l].push({topic:l,callback:e,context:s,token:r}),r):""},Z=t=>{if(!e(v,t))return!1;delete v[t]},tt=(t,e)=>{if(!_(t))return!1;e?(t=>{const e=Object.keys(v);if(!t||e.length<1)return!1;e.forEach((e=>{const s=v[e];let i;s.forEach(((e,r)=>{e.callback!==t&&e.token!==t||(i=e.topic,s.splice(-1,r))})),s.length<1&&Z(i)}))})(e):Z(t)};class et extends l{constructor(t){super(),this.attrs=et.DEFAULTS,this.anchors=null,this.drawer=null,this.chapters=null,this.toolbar=null,this.buttons=[],t&&this.initialize(t)}initialize(t){return this.attr(t).render().addListeners(),this}getChapters(t=!1){return this.anchors.getChapters(t)}count(){return this.anchors.count()}render(){const t=this.attr("scrollElement"),e=document.querySelector(t)||document.getElementById(t);return this._renderPrint()._renderAnchors()._renderChapters()._renderToolbar(),e&&this.onToolbarUpdate({top:e.scrollTop,min:0,max:e.scrollHeight}),this}_renderPrint(){const e=this.attr("print"),s=this.attr("articleElement");let i;return e.element?(t(s)?i=document.querySelector(s):n(s)&&(i=s),U(i,"outline-article"),((e,s)=>{let i,r,l,h,a;t(e)?i=document.querySelector(e)||document.getElementById(e):n(e)&&(i=e),r=i.querySelector("h1"),l=A("article",{className:"outline-print"},[""]),l.innerHTML=i.innerHTML,t(s)&&!r&&(r=A("h1",{className:"outline-print__title"},[s]),l.insertBefore(r,l.firstChild)),document.body.appendChild(l),o((()=>{for(h=l.previousElementSibling;h;)a=h.tagName.toLowerCase(),"script"!==a&&"style"!==a&&U(h,"outline-print_sibling"),h=h.previousElementSibling;for(h=l.nextElementSibling;h;)a=h.tagName.toLowerCase(),"script"!==a&&"style"!==a&&U(h,"outline-print_sibling"),h=h.nextElementSibling}),500)})(e.element,e.title),this):this}_renderAnchors(){const t=this.attr("articleElement"),e=this.attr("selector"),s=this.attr("stickyHeight"),i=this.attr("scrollElement"),r=this.attr("showCode"),l=this.attr("anchorURL"),n=this.attr("afterScroll");return this.anchors=new F({articleElement:t,stickyHeight:s,scrollElement:i,selector:e,showCode:r,anchorURL:l,afterScroll:n}),this}_renderChapters(){const t=this.attr("title"),e=this.attr("stickyHeight"),s=this.attr("scrollElement"),i=this.attr("customClass"),r=this.attr("showCode"),l=this.attr("position"),n=this.attr("placement"),o=this.attr("afterSticky"),h=this.attr("afterToggle"),a=this.attr("afterScroll"),c=this.count();let d,u=this.attr("parentElement");return c<1||(d={scrollElement:s,showCode:r,position:l,title:t,stickyHeight:e,chapters:this.getChapters(),afterSticky:o,afterToggle:h,afterScroll:a},"relative"===l?(this.drawer=new R({placement:n,title:t,size:"tiny",hasOffset:!0,hasPadding:!1,customClass:i,afterClosed:()=>{this.toolbar.toggle()}}),u=this.drawer.$main):d.customClass=i,d.parentElement=u,this.chapters=new W(d)),this}_renderToolbar(){const t=this.attr("placement"),e=this.attr("homepage"),s=this.attr("git"),i=this.attr("tags"),r=this.attr("issues"),l=this.attr("tools"),n=this.count(),o={name:"homepage",icon:"homepage",size:20,link:e},h={name:"github",icon:"github",size:20,link:s},a={name:"tags",icon:"tags",size:20,link:i},c={name:"issues",icon:"issues",size:20,link:r},d={name:"menu",icon:"menu",size:18,action:{type:"click",handler:"toolbar:action:toggle"}},u=[];return u.push({name:"up",icon:"up",size:20,action:{type:"click",handler:"toolbar:action:up"}}),e&&u.push(o),n>0&&u.push(d),s&&u.push(h),i&&u.push(a),r&&u.push(c),l?.length>0&&u.push(...l),u.push({name:"down",icon:"down",size:20,action:{type:"click",handler:"toolbar:action:down"}}),this.buttons=[...u],this.toolbar=new G({placement:t,buttons:u}),this}addButton(t){const e=this.toolbar,s=this.buttons;return s.splice(-1,0,t),e.attr({buttons:s}),e.refresh(),this}removeButton(t){return this.toolbar.remove(t),this}toTop(){const t=this.attr("afterScroll"),e=this.toolbar,s=this.chapters,r=this.count();return r>0&&(s.playing=!0),this.scrollTo(0,(()=>{e.hide("up"),e.show("down"),r>0&&(s.highlight(0),s.playing=!1),i(t)&&t.call(e,"up")})),this}toBottom(){const t=this.attr("afterScroll"),e=a(this.attr("scrollElement")),s=this.toolbar,r=this.chapters,l=this.count(),n=Math.floor(e.scrollHeight-e.clientHeight);return l>0&&(r.playing=!0),this.scrollTo(n,(()=>{s.hide("down"),s.show("up"),l>0&&(r.highlight(l-1),r.playing=!1),i(t)&&t.call(s,"bottom")})),this}scrollTo(t,e){const s=this.attr("scrollElement");return c(s,t,e),this}toggle(){const t=this.attr("position"),e=this.toolbar,s=this.drawer,i=this.chapters;return this.count()<1||("relative"!==t?(i.toggle(),e.highlight("menu")):(e.toggle(),o((()=>{i.isInside()?i.toggle():s.toggle()})))),this}destroy(){let t=this.anchors,e=this.chapters,s=this.drawer,i=this.toolbar,r=!1;const l=this.count();return this.removeListeners(),l>0&&(r=e.isOutside(),e.destroy(),e=null,r&&(s.destroy(),s=null)),i.destroy(),i=null,t.destroy(),t=null,this.attr(et.DEFAULTS),this}onToggle(){return this.toggle(),this}onScrollTop(){return this.toTop(),this}onScrollBottom(){return this.toBottom(),this}onToolbarUpdate({top:t,min:e,max:s}){const i=this.toolbar,r=Math.ceil(t);return r<=e?(i.hide("up"),i.show("down")):r>=s?(i.hide("down"),i.show("up")):r>e&&r {\n  return typeof str === 'string'\n}\n\nexport default isString\n","/**\n * 检测对象自身属性中是否具有指定的属性。\n * ========================================================================\n * @method hasOwn\n * @param {Object} obj - (必须)检测的目标对象\n * @param {String} prop - (必须)属性名\n * @returns {Boolean}\n */\nconst hasOwn = (obj, prop) => {\n  const hasOwnProperty = Object.prototype.hasOwnProperty\n  return obj && hasOwnProperty.call(obj, prop)\n}\n\nexport default hasOwn\n","/**\n * Object 对象原型上的 toString 方法\n * ========================================================================\n * @method toString\n * @param {*} val\n * @returns {string}\n */\nconst toString = (val) => {\n  return Object.prototype.toString.apply(val)\n}\n\nexport default toString\n","import toString from '../lang/toString'\n\n/**\n * 检测测试数据是否为 Function 类型\n * ========================================================================\n * @method isFunction\n * @param {*} val - (必须)待检测的数据\n * @returns {boolean} 'val' 是 Function 类型返回 true,否则返回 false\n */\nconst isFunction = (val) => {\n  return typeof val === 'function' || toString(val) === '[object Function]'\n}\n\nexport default isFunction\n","import toString from '../lang/toString'\nimport isFunction from '../types/isFunction'\n\n/**\n * 检测数据是否为 Object 类型\n * ========================================================================\n * @method isObject\n * @param {*} o\n * @returns {boolean}\n */\nconst isObject = (o) => {\n  return (\n    (toString(o) === '[object Object]' ||\n      typeof o === 'object' ||\n      isFunction(o)) &&\n    o !== null\n  )\n}\n\nexport default isObject\n","import isString from './utils/types/isString'\r\nimport hasOwn from './utils/lang/hasOwn'\r\nimport isObject from './utils/types/isObject'\r\nimport extend from './utils/lang/extend'\r\n\r\nclass Base {\r\n  constructor(options) {\r\n    this.attrs = {}\r\n\r\n    if (options) {\r\n      this.initialize(options)\r\n    }\r\n  }\r\n\r\n  initialize(options) {\r\n    this.attr(options).render().addListeners()\r\n    return this\r\n  }\r\n\r\n  attr(prop, value) {\r\n    const attrs = this.attrs\r\n\r\n    if (isString(prop)) {\r\n      // 只能扩展 attrs 中已有的属性\r\n      if (value && hasOwn(attrs, prop)) {\r\n        // 更新单个配置信息\r\n        attrs[prop] = value\r\n        return this\r\n      }\r\n\r\n      // 只传递 prop 参数,则返回对应的属性值\r\n      return attrs[prop]\r\n    } else if (isObject(prop)) {\r\n      // 批量更新配置信息\r\n      extend(attrs, prop)\r\n\r\n      return this\r\n    } else if (arguments.length === 0) {\r\n      // 不传递参数,直接返回整个\r\n      return attrs\r\n    }\r\n\r\n    return this\r\n  }\r\n\r\n  render() {\r\n    return this\r\n  }\r\n\r\n  destroy() {\r\n    this.removeListeners()\r\n    return this\r\n  }\r\n\r\n  reload(options) {\r\n    this.destroy().initialize(this.attr(options))\r\n    return this\r\n  }\r\n\r\n  addListeners() {\r\n    return this\r\n  }\r\n\r\n  removeListeners() {\r\n    return this\r\n  }\r\n}\r\n\r\nexport default Base\r\n","import hasOwn from './hasOwn'\n\n/**\n * 扩展对象\n * ========================================================================\n * @method extend\n * @param {Object} origin\n * @param {Object} source\n */\nconst extend = (origin, source) => {\n  const keys = Object.keys(source)\n\n  keys.forEach((prop) => {\n    if (hasOwn(source, prop)) {\n      origin[prop] = source[prop]\n    }\n  })\n}\n\nexport default extend\n","import isObject from './isObject'\n\n/**\n * 检测数据是否为 HTMLElement DOM 节点\n * ========================================================================\n * @method isElement\n * @param {*} o\n * @returns {boolean}\n */\nconst isElement = (o) => {\n  return !!(isObject(o) && o.nodeName && o.tagName && o.nodeType === 1)\n}\n\nexport default isElement\n","import isFunction from '../types/isFunction'\n\n/**\n * later - 延迟执行方法\n * ========================================================================\n * @method later\n * @param {Function} fn\n * @param {Number} [delay]\n * @returns {number|boolean}\n */\nconst later = (fn, delay = 300) => {\n  if (!isFunction(fn)) {\n    return false\n  }\n\n  return setTimeout(() => {\n    fn()\n  }, delay)\n}\n\nexport default later\n","/**\n * 返回给定值的平方值\n * ========================================================================\n * @method easeInQuad\n * @param {Number} x\n * @returns {number}\n */\nconst easeInQuad = (x) => {\n  return x * x\n}\n\nexport default easeInQuad\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\n\n/**\n * 通过给的 scrollElement 参数,获取滚动 DOM 元素\n * ========================================================================\n * @method _getScrollElement\n * @param {String|HTMLElement} scrollElement\n * @returns {Element}\n * @private\n */\nconst _getScrollElement = (scrollElement = null) => {\n  let $rootElements\n  let $scrollElement\n\n  if (!scrollElement) {\n    $rootElements = document.querySelectorAll('html,body')\n    $scrollElement =\n      $rootElements[0].scrollTop - $rootElements[1].scrollTop >= 0\n        ? $rootElements[0]\n        : $rootElements[1]\n  } else {\n    if (isString(scrollElement)) {\n      $scrollElement = document.querySelector(scrollElement)\n    } else if (isElement(scrollElement)) {\n      $scrollElement = scrollElement\n    }\n  }\n\n  return $scrollElement\n}\n\nexport default _getScrollElement\n","import easeInQuad from '../lang/easeInQuad'\nimport isFunction from '../types/isFunction'\nimport _getScrollElement from './_getScrollElement'\n\n/**\n * 指定 rootElement DOM 节点滚动到指定 top 位置\n * ========================================================================\n * @method scrollTo\n * @param {HTMLElement|Object} [scrollElement] - (必须)要滚动的 DOM 节点\n * @param {Number} top - (必须)滚动的 scrollTop 数值\n * @param {Function} [afterStop] - (可选)滚动完成的回调函数\n */\nconst scrollTo = (scrollElement, top, afterStop) => {\n  const $scrollElement = _getScrollElement(scrollElement)\n  let scrollTop = $scrollElement.scrollTop\n  let step = 0\n  const distance = top - scrollTop\n  const MAX_HEIGHT = $scrollElement.scrollHeight\n  const MAX_TOP = top - MAX_HEIGHT <= 0 ? top : MAX_HEIGHT\n  const stop = (top) => {\n    if (isFunction(afterStop)) {\n      afterStop(top)\n    }\n\n    return false\n  }\n  const play = () => {\n    step += 1\n\n    // 向上滚动\n    if (distance < 0) {\n      scrollTop -= easeInQuad(step)\n      $scrollElement.scrollTop = scrollTop\n\n      if (scrollTop <= top) {\n        $scrollElement.scrollTop = top\n        return stop(top)\n      }\n    } else {\n      scrollTop += easeInQuad(step)\n      $scrollElement.scrollTop = scrollTop\n\n      if (scrollTop >= MAX_TOP) {\n        $scrollElement.scrollTop = MAX_TOP\n        return stop(MAX_TOP)\n      }\n    }\n\n    requestAnimationFrame(play)\n  }\n\n  requestAnimationFrame(play)\n}\n\nexport default scrollTo\n","/**\n * 获取 DOM 节点相对于窗口的 left (纵坐标)值\n * ========================================================================\n * @method offsetTop\n * @param {HTMLElement} el - DOM 节点\n * @returns {Number}\n */\nconst offsetTop = (el) => {\n  let top = el.offsetTop\n\n  if (el.offsetParent !== null) {\n    top += offsetTop(el.offsetParent)\n  }\n\n  return top\n}\n\nexport default offsetTop\n","/**\n * 获取 options 节点下匹配 selector 选择器的 DOM 节点\n * ========================================================================\n * Element.matches() 方法可以用来判断 DOM 元素是否与给定的选择器匹配,事件代理判断是\n * 否触发绑定的代理事件回调函数,关键就是使用 Element.matches() 辨别当前事件触发的目\n * 标 DOM 元素是否为事件代理所期望触发的目标。\n * ========================================================================\n * @method matches\n * @see https://developer.mozilla.org/en-US/docs/web/api/element/matches\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)匹配 DOM 元素的选择器\n * @returns {Boolean}\n */\nconst matches = (el, selector = '') => {\n  const sel = selector.replace(/^>/i, '')\n\n  if (!selector || !sel || !el) {\n    return false\n  }\n\n  /* istanbul ignore else */\n  if (el.matches) {\n    return el.matches(sel)\n  } else if (el.msMatchesSelector) {\n    return el.msMatchesSelector(sel)\n  } else {\n    return false\n  }\n}\n\nexport default matches\n","/**\n * 获取 DOM 元素的父节点\n * ========================================================================\n * @method getParentOrHost\n * @param {*|HTMLElement} el - (必须)要获取父节点的 DOM 元素\n * @returns {*|HTMLElement}\n */\nconst getParentOrHost = (el) => {\n  return el.host && el !== document && el.host.nodeType\n    ? el.host\n    : el.parentNode\n}\n\nexport default getParentOrHost\n","export const CAPTURE_EVENTS = [\n  'focusout',\n  'blur',\n  'focusin',\n  'focus',\n  'load',\n  'unload',\n  'mouseenter',\n  'mouseleave'\n]\n","import { CAPTURE_EVENTS } from './enum'\nimport _delete from './_delete'\n\n/**\n * (私有方法)取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method _off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} fn - (必须)事件处理器回调函数\n * @private\n */\nconst _off = (el, type, fn) => {\n  const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n  /* istanbul ignore else */\n  if (fn._delegateListener) {\n    fn = fn._delegateListener\n    delete fn._delegateListener\n  }\n\n  // 移除缓存的 _listeners 数据\n  _delete(el, type, fn)\n\n  el.removeEventListener(type, fn, capture)\n}\n\nexport default _off\n","/**\n * 删除 DOM 元素缓存的 _listeners 数据\n * ========================================================================\n * @method _delete\n * @param {HTMLElement} el - 要删除 listener 的 DOM 元素\n * @param {String} type - 事件类型(名称)\n * @param {Function} [fn] - 事件处理器回调函数\n */\nconst _delete = function (el, type, fn) {\n  const listeners = el._listeners\n  let index = -1\n\n  if (listeners.length < 1) {\n    return false\n  }\n\n  // 移除缓存的 _listeners 数据\n  listeners.forEach((listener, i) => {\n    const handler = listener.fn\n\n    if (type === listener.type) {\n      index = i\n\n      if (handler === fn) {\n        index = i\n      }\n    }\n  })\n\n  /* istanbul ignore else */\n  if (index > -1) {\n    listeners.splice(index, 1)\n  }\n}\n\nexport default _delete\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\nimport getListeners from './getListeners'\nimport _off from './_off'\n\n/**\n * 销毁(type 类型的)代理事件绑定\n * ========================================================================\n * 1. 设置了事件类型 type,则销毁指定类型的事件绑定,否则清除所有代理事件绑定\n * 2. recurse 设置为 true,递归销毁子节点全部事件绑定\n * ========================================================================\n * @method purgeElement\n * @param {HTMLElement|String} el - (必须)DOM 元素或者其选择器\n * @param {String|Boolean} type - (必须)事件类型\n * @param {Boolean} [recurse] - (可选)是否递归销毁子节点所有事件绑定\n */\nconst purgeElement = function (el, type, recurse = false) {\n  const $element = isString(el) ? document.querySelector(el) : el\n  const $children = $element.childNodes\n  const listeners = getListeners($element, type)\n\n  listeners.forEach((listener) => {\n    _off($element, listener.type, listener.fn)\n  })\n\n  if (\n    (recurse || type === true || arguments.length === 1) &&\n    $element &&\n    $children\n  ) {\n    $children.forEach(($child) => {\n      if (isElement($child)) {\n        purgeElement($child, type, recurse)\n      }\n    })\n  }\n}\n\nexport default purgeElement\n","import isString from '../types/isString'\n\n/**\n * 获取 DOM 元素(type 事件类型)事件绑定信息\n * ========================================================================\n * 如果设置了事件类型 type, 则返回指定类型的事件绑定信息,否则返回所有事件绑定信息\n * ========================================================================\n * @methods getListeners\n * @param {HTMLElement} el - (必须)要获取事件绑定信息的 DOM 元素\n * @param {String} [type] - (可选)事件类型\n * @returns {Array} - 已绑定的事件信息\n */\nconst getListeners = (el, type) => {\n  let listeners = el._listeners || []\n\n  if (isString(type) && type) {\n    listeners = listeners.filter((listener) => {\n      return listener.type === type\n    })\n  }\n\n  return listeners\n}\n\nexport default getListeners\n","import purgeElement from './purgeElement'\nimport isFunction from '../types/isFunction'\nimport _off from './_off'\n\n/**\n * 取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} [fn] - (可选)事件处理器回调函数\n */\nconst off = (el, type, fn) => {\n  // 如果不设置 fn 参数,默认清除 el 元素上绑定的所有事件处理器\n  if (!isFunction(fn)) {\n    return purgeElement(el, type)\n  }\n\n  _off(el, type, fn)\n}\n\nexport default off\n","import closest from '../dom/closest'\nimport off from './off'\nimport getTarget from './getTarget'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定代理事件\n * ========================================================================\n * @method on\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String} selector - (必须)事件代理目标 DOM 元素的选择器\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (可选) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst on = (el, selector, type, fn, data, context, once = false) => {\n  // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n  const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n  const listener = function (evt) {\n    const target = getTarget(evt)\n    // 通过 Element.matches 方法获得点击的目标元素\n    const delegateTarget = closest(target, selector, el)\n    let overrideContext = context || el\n\n    evt.delegateTarget = delegateTarget\n\n    // 当设置为 true 时,则事件处理器回调函数的\n    // this 上下文指向为 data 对象\n    if (context === true) {\n      overrideContext = data\n    }\n\n    /* istanbul ignore else */\n    if (delegateTarget) {\n      // 仅触发一次\n      /* istanbul ignore else */\n      if (once === true) {\n        off(el, type, listener)\n      }\n\n      fn.call(overrideContext, evt, data)\n    }\n  }\n\n  if (!el._listeners) {\n    el._listeners = []\n  }\n\n  // 缓存 options 元素绑定的事件处理器\n  el._listeners.push({\n    el,\n    selector,\n    type,\n    fn: listener,\n    data,\n    context,\n    capture\n  })\n\n  // 缓存包装后的事件处理器\n  fn._delegateListener = listener\n\n  el.addEventListener(type, listener, capture)\n}\n\nexport default on\n","import resolveTextNode from '../dom/resolveTextNode'\n\n/**\n * 返回触发事件的 target DOM 元素\n * ========================================================================\n * @method getTarget\n * @param {Event} evt - Event 对象\n * @return {HTMLElement} - Event 对象的 target DOM 元素\n */\nconst getTarget = function (evt) {\n  const target = evt.target\n\n  return resolveTextNode(target)\n}\n\nexport default getTarget\n","/**\n * 在某些情况下,某些浏览器(例如:Safari 浏览器)会返回实际的目标元素内部的文本节点。\n * resolveTextNode() 方法则会返回实际的目标节点。\n * ========================================================================\n * @method resolveTextNode\n * @param {HTMLElement|Text} el - 要解析的节点\n * @return {*|HTMLElement} - 实际的目标 DOM 节点\n */\nconst resolveTextNode = function (el) {\n  if (el && el.nodeType === 3) {\n    return el.parentNode\n  }\n\n  return el\n}\n\nexport default resolveTextNode\n","import matches from './matches'\nimport getParentOrHost from './getParentOrHost'\n\n/**\n * 获取 options 元素父元素最近的包含 selector 选择器的元素\n * ========================================================================\n * @method closest\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)DOM 元素的选择其\n * @param {HTMLElement} [ctx] - (必须)比对的 DOM 元素\n * @param {Boolean} [includeCTX] - (必须)是否包含 context DOM 元素\n * @returns {null|HTMLElement} - 返回最接近的 DOM 元素\n */\nconst closest = (el, selector, ctx, includeCTX) => {\n  const context = ctx || document\n\n  if (!el) {\n    return null\n  }\n\n  do {\n    /* istanbul ignore else */\n    if (\n      (selector != null &&\n        (selector.startsWith('>')\n          ? el.parentNode === context && matches(el, selector)\n          : matches(el, selector))) ||\n      (includeCTX && el === context)\n    ) {\n      return el\n    }\n\n    /* istanbul ignore else */\n    if (el === context) {\n      break\n    }\n\n    /* jshint boss:true */\n  } while ((el = getParentOrHost(el)))\n}\n\nexport default closest\n","/**\n * 停止事件(阻止默认行为和阻止事件的捕获或冒泡)\n * ========================================================================\n * @method stop\n * @param {Event} evt - 事件对象\n *\n * @example\n * 
\n * Service\n * Help\n *
\n *\n * const $nav = document.querySelector('#nav')\n * const $service = document.querySelector('.anchor')\n *\n * on($nav, 'click', function(evt) {\n * console.log('你点击了导航栏')\n * })\n *\n * on($anchor, 'click', function(evt) {\n * console.log('tagName', this.tagName)\n *\n * // 工作台输出:'a'\n * // 不会触发事件冒泡,输出:'你点击了导航栏'\n * // 也不会切换到 href 属性的页面,阻止了点击链接的默认行为\n * stopEvent(evt)\n * })\n */\nconst stop = function (evt) {\n evt.stopPropagation()\n evt.preventDefault()\n}\n\nexport default stop\n","/**\n * 存储订阅者(主题和处理器的)私有对象\n * ========================================================================\n * @type {{}}\n * @private\n */\nconst _subscribers = {}\n\nexport default _subscribers\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 判断是否存在与给定 topic 完全匹配的订阅者信息\n * ========================================================================\n * @method _hasDirectSubscribersFor\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasDirectSubscribersFor = (topic) => {\n return hasOwn(_subscribers, topic) && _subscribers[topic].length > 0\n}\n\nexport default _hasDirectSubscribersFor\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\nimport _hasSubscribers from './_hasSubscribers'\n\n/**\n * 判断是否存在包含 topic 指定的订阅者信息\n * ========================================================================\n * @method has\n * @param {String} topic - (必须)主题名称\n * @param {Boolean} [isDirect] - (可选)是否为直接的主题,默认值:true\n * @returns {Boolean}\n */\nconst has = (topic, isDirect = true) => {\n return isDirect ? _hasDirectSubscribersFor(topic) : _hasSubscribers(topic)\n}\n\nexport default has\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * 判断是否存在包含给定 topic 相关的订阅者信息\n * ========================================================================\n * @method _hasSubscribers\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasSubscribers = (topic) => {\n let found = _hasDirectSubscribersFor(topic)\n let position = topic.lastIndexOf('.')\n\n while (!found && position !== -1) {\n topic = topic.substring(0, position)\n position = topic.lastIndexOf('.')\n found = _hasDirectSubscribersFor(topic)\n }\n\n return found\n}\n\nexport default _hasSubscribers\n","import isTypedArray from '../types/isTypedArray'\nimport _subscribers from './_subscribers'\nimport has from './has'\nimport _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * (异步)发布订阅主题信息\n * ========================================================================\n * 主题默认是异步发布的。确保在消费者处理主题时,主题的发起者不会被阻止。\n * ========================================================================\n * @method emit\n * @param {String} topic - (必须)主题名称\n * @param {Object} data - (必须)数据对象\n * @param {Boolean} async - (可选) 是否异步发布\n */\nconst emit = (topic, data, async = true) => {\n const execute = (topic) => {\n if (!_hasDirectSubscribersFor(topic)) {\n return false\n }\n\n _subscribers[topic].forEach((subscriber) => {\n // 针对 mqtt 消息服务返回的 Uint8Array 类似的 typed arrays 格式的数据\n // 采用 toString() 方法转化为普通(JSON)字符串\n const message = isTypedArray(data) ? data.toString() : data\n\n subscriber.callback.call(subscriber.context || subscriber, message)\n })\n }\n const deliver = () => {\n let subscriber = topic\n let position = topic.lastIndexOf('.')\n\n while (position !== -1) {\n subscriber = subscriber.substring(0, position)\n position = subscriber.lastIndexOf('.')\n\n execute(subscriber)\n }\n\n // 执行 topic 对应的处理器\n execute(topic)\n // 执行特殊 topic:'*'(监听全部消息的发布)\n execute('*')\n }\n\n if (!has(topic)) {\n return false\n }\n\n if (async) {\n setTimeout(deliver, 10)\n } else {\n deliver()\n }\n}\n\nexport default emit\n","import toString from '../lang/toString'\n/**\n * 判断检测数据是否为 Typed Arrays 类型的数据\n * ========================================================================\n * @param {*} val\n * @returns {boolean}\n */\nconst isTypedArray = (val) => {\n const TYPES = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]',\n '[object BigInt64Array]',\n '[object BigUint64Array]'\n ]\n\n return TYPES.indexOf(toString(val)) > -1\n}\n\nexport default isTypedArray\n","import toString from '../lang/toString'\n\n/**\n * 检测数据是否为 Array 类型\n * ========================================================================\n * @method isArray\n * @param {*} o\n * @returns {boolean}\n */\nconst isArray = (o) => {\n if (Array.isArray) {\n return Array.isArray(o)\n } else {\n return toString(o) === '[object Array]'\n }\n}\n\nexport default isArray\n","import DEFAULTS from './defaults'\n\nconst SYMBOLS = [...DEFAULTS]\n\nexport default SYMBOLS\n","const DEFAULTS = [\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n ''\n]\n\nexport default DEFAULTS\n","import isString from '../types/isString'\nimport getSymbol from './getSymbol'\nimport SYMBOLS from './symbols'\n\n/**\n *\n * @method getSymbols\n * @param {String} [name]\n * @param {String} [iconSet]\n * @returns {string[]|*}\n */\nconst getSymbols = (name, iconSet = 'icon') => {\n if (isString(name)) {\n return getSymbol(name, iconSet)\n }\n\n return [...SYMBOLS]\n}\n\nexport default getSymbols\n","import SYMBOLS from './symbols'\n\n/**\n * @method getSymbol\n * @param {String} name\n * @param {String} [iconSet]\n * @returns {String}\n */\nconst getSymbol = (name, iconSet = 'icon') => {\n const patternName = /id=\"(.*?)\"/\n const patternSet = /^(\\w+)-/\n const symbols = SYMBOLS\n\n return symbols.find((symbol) => {\n const names = patternName.exec(symbol)\n const fullName = names[1]\n const sets = patternSet.exec(fullName)\n const setName = sets[1]\n const iconName =\n iconSet === 'icon' ? `${iconSet}-${name}` : `${iconSet}-icon-${name}`\n\n return setName === iconSet && fullName === iconName\n })\n}\n\nexport default getSymbol\n","import add from './add'\nimport getSymbols from './getSymbols'\n\n/**\n * 绘制 SVG 图标集\n * ========================================================================\n * @method paint\n * @param {String|Array} symbol\n */\nconst paint = (symbol = '') => {\n const $body = document.body\n let $icons = document.querySelector('#outline-icons')\n let symbols = []\n\n add(symbol)\n symbols = getSymbols()\n\n if ($icons) {\n $icons.innerHTML = symbols.join('')\n } else {\n $icons = document.createElement('div')\n $icons.innerHTML =\n ``\n $body.insertBefore($icons.firstChild, $body.firstChild)\n }\n}\n\nexport default paint\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport SYMBOLS from './symbols'\n\n/**\n * @method add\n * @param {Array|String} symbols\n * @return {Boolean}\n */\nconst add = (symbols) => {\n if (!symbols) {\n return false\n }\n\n if (isArray(symbols) && symbols.length > 0) {\n symbols.forEach((symbol) => {\n /* istanbul ignore else */\n if (SYMBOLS.indexOf(symbol) === -1 && isString(symbol)) {\n SYMBOLS.push(symbol)\n }\n })\n } else {\n /* istanbul ignore else */\n if (isString(symbols)) {\n SYMBOLS.push(symbols)\n }\n }\n}\n\nexport default add\n","import isString from '../types/isString'\n\n/**\n * 清楚字符串起始位置所有的空格\n * ========================================================================\n * @method trim\n * @param {string} str\n * @returns {string|Boolean}\n */\nconst trim = (str) => {\n if (!isString(str)) {\n return false\n }\n return str.replace(/(^\\s+)|(\\s+$)/g, '')\n}\n\nexport default trim\n","import isObject from './isObject'\r\nimport isElement from './isElement'\r\nimport isHTMLCollection from './isHTMLCollection'\r\nimport isFragment from './isFragment'\r\nimport isTextNode from './isTextNode'\r\n\r\nconst isDOM = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (isElement(el) || isHTMLCollection(el) || isFragment(el) || isTextNode(el))\r\n )\r\n}\r\n\r\nexport default isDOM\r\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isHTMLCollection = (el) => {\r\n return !!(isObject(el) && toString(el) === '[object NodeList]')\r\n}\r\n\r\nexport default isHTMLCollection\r\n","import toString from '../lang/toString'\nimport isObject from './isObject'\n\nconst isFragment = (fragment) => {\n return !!(\n isObject(fragment) && toString(fragment) === '[object DocumentFragment]'\n )\n}\n\nexport default isFragment\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isTextNode = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (toString(el) === '[object Text]' || (el.tagName && el.nodeType === 3))\r\n )\r\n}\r\n\r\nexport default isTextNode\r\n","/**\n * 给 DOM 节点设置属性/值\n * ========================================================================\n * @method setAttribute\n * @param {HTMLElement} el - DOM 节点\n * @param {String} attr - 属性名称\n * @param {String|Number|Boolean} value - 属性值\n */\nconst setAttribute = (el, attr, value) => {\n let tagName = el.tagName.toLowerCase()\n\n switch (attr) {\n case 'style':\n el.style.cssText = value\n break\n case 'value':\n if (tagName === 'input' || tagName === 'textarea') {\n el.value = value\n } else {\n el.setAttribute(attr, value)\n }\n break\n case 'className':\n el.className = value\n break\n default:\n el.setAttribute(attr, value)\n break\n }\n}\n\nexport default setAttribute\n","import hasOwn from '../lang/hasOwn'\nimport isObject from '../types/isObject'\nimport isString from '../types/isString'\nimport isArray from '../types/isArray'\nimport isDOM from '../types/isDOM'\nimport setAttribute from './setAttribute'\n\n/**\n * 创建 DOM 节点,并添加属性和子节点\n * ========================================================================\n * @method createElement\n * @param {String} tagName - 标签名称\n * @param {Object|Array} attrs - 属性对象或者子节点\n * @param {Array} [children] - 子节点数组\n * @returns {HTMLElement}\n */\nconst createElement = (tagName, attrs, children) => {\n const $fragment = document.createDocumentFragment()\n const $el = document.createElement(tagName)\n const isValidChild = (child) => {\n return isDOM(child) || isString(child)\n }\n const append = (child) => {\n let $child\n\n if (!isValidChild(child)) {\n return false\n }\n\n if (isDOM(child)) {\n $child = child\n } else if (isString(child)) {\n $child = document.createTextNode(child)\n }\n\n $fragment.appendChild($child)\n }\n\n if (isObject(attrs)) {\n Object.keys(attrs).forEach((attr) => {\n if (hasOwn(attrs, attr)) {\n setAttribute($el, attr, attrs[attr])\n }\n })\n } else if (isArray(attrs) && attrs.every((attr) => isValidChild(attr))) {\n attrs.forEach((child) => {\n append(child)\n })\n }\n\n if (isArray(children)) {\n children.forEach((child) => {\n append(child)\n })\n } else {\n append(children)\n }\n\n $el.appendChild($fragment)\n\n return $el\n}\n\nexport default createElement\n","import isString from './isString'\n\nconst isSVG = (str) => {\n const declaration = '(?:<\\\\?xml[^>]*>\\\\s*)?'\n const doctype =\n '(?:<\\\\!doctype svg[^>]*\\\\s*(?:\\\\[?(?:\\\\s*]*>\\\\s*)*\\\\]?)*[^>]*>\\\\s*)?'\n const content = ']*>[^]*<\\\\/svg>\\\\s*$'\n const svg = `^\\\\s*${declaration}${doctype}${content}\\\\s*$`\n const pattern = new RegExp(svg, 'i')\n\n return isString(str) && pattern.test(str)\n}\n\nexport default isSVG\n","import createElement from './createElement'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method icon\n * @alias createElement\n * @see createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst icon = (name, options = {}) => {\n return createElement(name, options)\n}\n\nexport default icon\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport isSVG from '../types/isSVG'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst createElement = (name, options = {}) => {\n const size = options.size || 0\n const color = options.color || ''\n const iconSet = options.iconSet || ''\n const width = isArray(size) ? size[0] : size\n const height = isArray(size) ? size[1] : size\n const defaultRules = size ? `width:${width}px;height:${height}px;` : ''\n const cssRules = color ? defaultRules + `color:${color}` : defaultRules\n const $icon = document.createElement('i')\n let binds = ''\n let svg = ''\n let $svg\n\n if (!isString(name)) {\n return null\n }\n\n if (isSVG(name)) {\n svg = name\n } else {\n binds =\n iconSet && iconSet !== 'icon'\n ? `xlink:href=\"#${iconSet}-icon-${name}\"`\n : `xlink:href=\"#icon-${name}\"`\n svg =\n `` +\n `` +\n ``\n }\n\n $icon.className = 'outline-icon'\n $icon.innerHTML = svg\n\n if (isSVG(name)) {\n $svg = $icon.querySelector('svg')\n $svg.setAttribute('aria-hidden', 'true')\n $svg.setAttribute('xmlns', 'http://www.w3.org/2000/svg')\n $svg.setAttribute('class', 'outline-icon__svg')\n $svg.setAttribute('width', '200')\n $svg.setAttribute('height', '200')\n $svg.style = cssRules\n }\n\n return $icon\n}\n\nexport default createElement\n","import isElement from '../types/isElement'\n/**\n * 检测 DOM 节点是否包含名为 className 的样式\n * ========================================================================\n * @method hasClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst hasClass = (el, className) => {\n const pattern = new RegExp('(\\\\s|^)' + className + '(\\\\s|$)')\n let allClass\n let classList\n\n if (!isElement(el)) {\n return false\n }\n\n allClass = el.className\n\n if (!allClass) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.contains) {\n return el.classList.contains(className)\n }\n\n return !!pattern.exec(allClass)\n}\n\nexport default hasClass\n","import trim from '../lang/trim'\nimport hasClass from './hasClass'\n\n/**\n * 移除 DOM 节点的 className 样式\n * ========================================================================\n * @method removeClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst removeClass = (el, className) => {\n let allClass = el.className\n let classList\n\n if (!allClass || !hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.remove) {\n classList.remove(className)\n } else {\n allClass = trim(allClass.replace(className, ''))\n el.className = allClass\n }\n}\n\nexport default removeClass\n","import removeClass from './utils/dom/removeClass'\nimport isEmpty from './utils/types/isEmpty'\nimport trim from './utils/lang/trim'\n\nconst _resetHeading = ($heading, hasAnchor = true, isAtStart = true) => {\n const CLS_HEADING = 'outline-heading'\n const text = $heading.innerHTML\n const pattern = /^\\d+(\\.?\\d+)*\\s?/gi\n let $anchor\n\n $heading.innerHTML = text.replace(pattern, '')\n $heading.removeAttribute('id')\n $heading.removeAttribute('data-id')\n\n removeClass($heading, CLS_HEADING)\n\n if (!hasAnchor) {\n return false\n }\n\n $anchor = $heading.querySelector(`.${CLS_HEADING}__anchor`)\n\n if (isAtStart) {\n removeClass($heading, `${CLS_HEADING}_start`)\n }\n\n if (isEmpty(trim($heading.className))) {\n $heading.removeAttribute('class')\n }\n\n $heading.removeChild($anchor)\n}\n\nexport default _resetHeading\n","import isString from './isString'\n/**\n * 检测数据是否为空字符串\n * ========================================================================\n * @method isEmpty\n * @param {String} str\n * @returns {boolean}\n */\nconst isEmpty = (str) => {\n return isString(str) && str === ''\n}\n\nexport default isEmpty\n","import trim from './utils/lang/trim'\nimport stripTags from './utils/lang/stripTags'\n\nimport _getChapterParentIdByDiffer from './_getChapterParentIdByDiffer'\nimport _getChaptersWithCode from './_getChaptersWithCode'\n\nconst getChapters = (headings, showCode = true) => {\n let previous = 1\n let level = 0\n const chapters = []\n\n headings.forEach((heading, i) => {\n const headingLevel = heading.tagName.replace(/h/i, '')\n let current = parseInt(headingLevel, 10)\n let pid = -1\n\n // 场景1:当前标题是前一个标题的子标题\n // 当前标题的(标题标签)序号 > 前一个标题的序号:两个相连的标题是父标题 -> 子标题关系;\n // h2 (前一个标题)\n // h3 (当前标题)\n if (current > previous) {\n level += 1\n\n // 第一层级的 pid 是 -1\n if (level === 1) {\n pid = -1\n } else {\n pid = i - 1\n }\n }\n // 场景2:当前标题和前一个标题层级相同\n // 当前标题的(标题标签)序号 = 前一个标题的序号\n // h2 (前一个标题)\n // h2 (当前标题)\n // 当前标题的(标题标签)序号 < 前一个标题的序号,并且当前标题序号 > 当前的级别\n // h2\n // h4 (前一个标题)\n // h3 (当前标题:这种情况我们还是任务 h3 是 h2 的下一级章节)\n else if (current === previous || (current < previous && current > level)) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n pid = -1\n } else {\n pid = chapters[i - 1].pid\n }\n }\n // 场景3:当前标题比前一个标题层级高\n else if (current <= level) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n } else {\n level = level - (previous - current)\n\n if (level <= 1) {\n level = 1\n }\n }\n\n // 第一级的标题\n if (level === 1) {\n pid = -1\n } else {\n // 通过当前标题和前一个标题之间的等级差,获得当前标题的父标题ID\n pid = _getChapterParentIdByDiffer(chapters, previous - current, i)\n }\n }\n\n previous = current\n\n chapters.push({\n id: i,\n pid: pid,\n level: level,\n rel: `heading-${i}`,\n text: stripTags(trim(heading.innerHTML))\n })\n })\n\n return showCode ? _getChaptersWithCode(chapters) : chapters\n}\n\nexport default getChapters\n","import isString from '../types/isString'\n\n/**\n * 过滤所有 HTML 标签\n * ========================================================================\n * @method stripTags\n * @param {string} str\n * @returns {string}\n */\nconst stripTags = (str) => {\n if (!isString(str)) {\n return ''\n }\n return str.replace(/<\\/?[^>]+(>|$)/g, '')\n}\n\nexport default stripTags\n","const _getChapterParentIdByDiffer = (chapters, differ, index) => {\n let previous = chapters[index - 1]\n let pid\n let i\n\n for (i = 0; i < differ; i += 1) {\n pid = previous.pid\n previous = chapters[pid]\n }\n\n pid = previous.pid\n\n return pid\n}\n\nexport default _getChapterParentIdByDiffer\n","const _getChaptersWithCode = (chapters) => {\n const groups = {}\n const cb = (o) => {\n return [o.pid]\n }\n\n chapters.forEach((o) => {\n const group = JSON.stringify(cb(o))\n\n groups[group] = groups[group] || []\n groups[group].push(o)\n\n o.index = groups[group].length\n if (o.pid === -1) {\n o.code = String(o.index)\n }\n })\n\n Object.keys(groups).forEach((group) => {\n groups[group].forEach((c) => {\n const subjects = chapters.filter((b) => b.pid === c.id)\n subjects.forEach((o) => {\n o.code = c.code + '.' + o.index\n })\n })\n })\n\n return chapters\n}\n\nexport default _getChaptersWithCode\n","import Base from './base'\n\n// 在文章的标题生成 anchor 链接\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport toTree from './utils/lang/toTree'\nimport later from './utils/lang/later'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport offsetTop from './utils/dom/offsetTop'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _updateHeading from './_updateHeading'\nimport _resetHeading from './_resetHeading'\nimport getChapters from './getChapters'\n\nclass Anchors extends Base {\n constructor(options) {\n super()\n\n this.attrs = Anchors.DEFAULTS\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n\n this.chapters = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let scrollElement\n let selector\n let $articleElement\n let articleElement\n\n this.attr(options)\n articleElement = this.attr('articleElement')\n scrollElement = this.attr('scrollElement')\n selector = this.attr('selector')\n created = this.attr('created')\n\n if (isString(articleElement)) {\n $articleElement = document.querySelector(articleElement)\n } else if (isElement(articleElement)) {\n $articleElement = articleElement\n }\n\n if (!$articleElement) {\n return this\n }\n\n this.$articleElement = $articleElement\n this.$scrollElement = _getScrollElement(scrollElement)\n this.$headings = [...$articleElement.querySelectorAll(selector)]\n\n if (this.$headings.length < 1) {\n return this\n }\n\n this.chapters = getChapters(this.$headings)\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n getChapters(isTreeStructured = false) {\n const chapters = this.chapters\n return isTreeStructured ? toTree(chapters, 'id', 'pid') : chapters\n }\n\n count() {\n return this.chapters.length\n }\n\n render() {\n const mounted = this.attr('mounted')\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const $headings = this.$headings\n const chapters = this.getChapters()\n\n paint()\n\n $headings.forEach(($heading, i) => {\n const chapterCode = chapters[i].code\n _updateHeading($heading, i, {\n hasAnchor,\n isAtStart,\n showCode,\n chapterCode,\n anchorURL\n })\n })\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n destroy() {\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n const $headings = this.$headings\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n $headings.forEach(($heading) => {\n _resetHeading($heading, hasAnchor, isAtStart)\n })\n\n this.attr(Anchors.DEFAULTS)\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n this.chapters = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n onAnchorTrigger(evt) {\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const $heading = $anchor.parentNode\n const top = offsetTop($heading) - (stickyHeight + 10)\n const $scrollElement = this.$scrollElement\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'anchor')\n }\n\n later(() => {\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.scrollTo(top, after)\n\n if (!anchorURL) {\n stop(evt)\n }\n\n return this\n }\n\n addListeners() {\n const $articleElement = this.$articleElement\n\n on(\n $articleElement,\n '.outline-heading__anchor',\n 'click',\n this.onAnchorTrigger,\n this,\n true\n )\n\n return this\n }\n\n removeListeners() {\n const $articleElement = this.$articleElement\n\n off($articleElement, 'click', this.onAnchorTrigger)\n\n return this\n }\n}\n\nAnchors.DEFAULTS = {\n scrollElement: 'html,body',\n articleElement: '#article',\n selector: 'h1,h2,h3,h4,h5,h6',\n stickyHeight: 0,\n anchorURL: '',\n hasAnchor: true,\n isAtStart: true,\n showCode: false,\n created: null,\n mounted: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Anchors\n","const toTree = (list, nodeKey, parentKey) => {\r\n const map = {}\r\n const roots = []\r\n\r\n list.forEach((item, i) => {\r\n // initialize the map\r\n map[item[nodeKey]] = i\r\n // initialize the children\r\n item.children = []\r\n })\r\n\r\n list.forEach((item) => {\r\n const node = list[map[item[parentKey]]]\r\n\r\n if (item[parentKey] !== -1) {\r\n // if you have dangling branches check that map[node.parentId] exists\r\n node.children.push(item)\r\n } else {\r\n roots.push(item)\r\n }\r\n })\r\n\r\n return roots\r\n}\r\n\r\nexport default toTree\r\n","import trim from './utils/lang/trim'\nimport createElement from './utils/dom/createElement'\nimport setAttribute from './utils/dom/setAttribute'\n\nimport icon from './utils/icons/icon'\n\nconst _updateHeading = ($heading, i, options) => {\n const $fragment = document.createDocumentFragment()\n const CLS_HEADING = 'outline-heading'\n const hasAnchor = options.hasAnchor || true\n const isAtStart = options.isAtStart || true\n const showCode = options.showCode || false\n const chapterCode = options.chapterCode || ''\n const anchorURL = options.anchorURL || ''\n const headingId = `heading-${i}`\n const attrs = {\n id: headingId,\n className: isAtStart ? `${CLS_HEADING} ${CLS_HEADING}_start` : CLS_HEADING,\n 'data-id': i\n }\n const keys = Object.keys(attrs)\n const text = trim($heading.innerHTML)\n let $anchor\n let $icon\n\n keys.forEach((prop) => {\n setAttribute($heading, prop, attrs[prop])\n })\n\n if (showCode) {\n $heading.innerHTML = chapterCode + ' ' + text\n }\n\n if (!hasAnchor) {\n return false\n }\n\n $icon = icon('hash', { iconSet: 'outline' })\n $anchor = createElement(\n 'a',\n {\n id: `anchor-${i}`,\n className: `${CLS_HEADING}__anchor anchor-${i}`,\n href: anchorURL || `#${headingId}`,\n target: anchorURL ? '_blank' : 'self',\n 'data-id': i\n },\n [$icon]\n )\n $fragment.appendChild($anchor)\n $heading.appendChild($fragment)\n}\n\nexport default _updateHeading\n","import hasClass from './hasClass'\n\n/**\n * 给 DOM 节点添加名为 className 的样式\n * ========================================================================\n * @method addClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst addClass = (el, className) => {\n let classList\n let allClass\n\n if (hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.add) {\n classList.add(className)\n } else {\n allClass = el.className\n allClass += allClass.length > 0 ? ' ' + className : className\n el.className = allClass\n }\n}\n\nexport default addClass\n","const setProperty = (prop, value) => {\r\n const documentElement = document.documentElement\r\n documentElement.style.setProperty(prop, value)\r\n}\r\n\r\nexport default setProperty\r\n","import setProperty from './utils/dom/setProperty'\n\nlet index = 2000\n\nconst zIndex = (idx) => {\n if (idx) {\n index = idx\n } else {\n index += 1\n }\n\n setProperty('--outline-zIndex', `${index}`)\n\n return index\n}\n\nexport default zIndex\n","import Base from './base'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport addClass from './utils/dom/addClass'\nimport removeClass from './utils/dom/removeClass'\nimport createElement from './utils/dom/createElement'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\n\nimport paint from './utils/icons/paint'\nimport icon from './utils/icons/icon'\nimport zIndex from './zIndex'\n\nclass Drawer extends Base {\n constructor(options) {\n super()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = true\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n this.zIndex = 0\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n\n this.title = this.attr('title')\n created = this.attr('created')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n return this\n }\n\n setTitle(title) {\n this.attr('title', title)\n this.title = title\n this.$title.innerHTML = title\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n render() {\n const mounted = this.attr('mounted')\n const size = this.attr('size')\n const placement = this.attr('placement')\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const hasOffset = this.attr('hasOffset')\n const hasPadding = this.attr('hasPadding')\n const autoHeight = this.attr('autoHeight')\n const customClass = this.attr('customClass')\n let $el\n let $modal\n let $header\n let $title\n let $close\n let $main\n let $footer\n let $overlay\n\n paint()\n this.zIndex = zIndex()\n\n $title = createElement(\n 'h2',\n {\n className: 'outline-drawer__title'\n },\n [this.title]\n )\n this.$title = $title\n\n if (hasClose) {\n $close = createElement(\n 'div',\n {\n className: 'outline-drawer__close'\n },\n [icon('close', { size: 20 })]\n )\n this.$close = $close\n }\n\n $header = createElement(\n 'header',\n {\n className: 'outline-drawer__header'\n },\n [$title, $close]\n )\n this.$header = $header\n\n $main = createElement(\n 'div',\n {\n className: 'outline-drawer__main'\n },\n ['']\n )\n this.$main = $main\n\n if (!hasPadding) {\n addClass($main, 'outline-drawer_full')\n }\n\n $footer = createElement(\n 'footer',\n {\n className: 'outline-drawer__footer'\n },\n ['']\n )\n this.$footer = $footer\n\n $modal = createElement(\n 'div',\n {\n className: `outline-drawer__modal outline-drawer_${placement} outline-drawer_${size} outline-drawer_closed`\n },\n [$header, $main, $footer]\n )\n this.$modal = $modal\n\n if (hasOffset) {\n addClass($modal, 'outline-drawer_offset')\n }\n\n if (autoHeight) {\n addClass($modal, 'outline-drawer_auto')\n }\n\n if (customClass) {\n addClass($modal, customClass)\n }\n\n if (hasOverlay) {\n $overlay = createElement(\n 'div',\n {\n className: 'outline-drawer__overlay'\n },\n ['']\n )\n this.$overlay = $overlay\n }\n\n $el = createElement(\n 'div',\n {\n className: `outline-drawer`\n },\n [$modal, $overlay]\n )\n this.$el = $el\n document.body.appendChild($el)\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n open() {\n const opened = this.attr('afterOpened')\n const $modal = this.$modal\n\n addClass(this.$el, 'outline-drawer_opened')\n removeClass($modal, 'outline-drawer_closed')\n addClass($modal, 'outline-drawer_opened')\n\n later(() => {\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n })\n\n return this\n }\n\n close() {\n const closed = this.attr('afterClosed')\n const $modal = this.$modal\n\n removeClass($modal, 'outline-drawer_opened')\n addClass($modal, 'outline-drawer_closed')\n\n later(() => {\n removeClass(this.$el, 'outline-drawer_opened')\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n })\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const closed = this.isClosed()\n\n if (closed) {\n this.open()\n } else {\n this.close()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n afterToggle.call(this, closed)\n })\n }\n\n return this\n }\n\n destroy() {\n const afterDestroy = this.attr('afterDestroy')\n const beforeDestroy = this.attr('beforeDestroy')\n let index = this.zIndex\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = false\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n\n index -= 1\n zIndex(index)\n this.zIndex = 0\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n addListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (hasClose) {\n on($el, '.outline-drawer__close', 'click', this.onClose, this, true)\n }\n\n if (hasOverlay) {\n on($el, '.outline-drawer__overlay', 'click', this.onClose, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (!hasClose && !hasOverlay) {\n return this\n }\n\n off($el, 'click', this.onClose)\n\n return this\n }\n\n onClose() {\n this.close()\n return this\n }\n}\n\nDrawer.DEFAULTS = {\n placement: 'rtl',\n title: '标题',\n size: 'regular',\n hasClose: true,\n hasOverlay: true,\n hasOffset: false,\n hasPadding: true,\n autoHeight: true,\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterToggle: null\n}\n\nexport default Drawer\n","import isFunction from '../types/isFunction'\nimport off from './off'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定事件\n * ========================================================================\n * @method at\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (必须) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst at = (el, type, fn, data, context, once = false) => {\n // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n const listener = function (evt) {\n let overrideContext = context || el\n\n // 当设置为 true 时,则事件处理器回调函数的\n // this 上下文指向为 data 对象\n if (context === true) {\n overrideContext = data\n }\n\n // 仅触发一次\n /* istanbul ignore else */\n if (once === true) {\n off(el, type, listener)\n }\n\n fn.call(overrideContext, evt, data)\n }\n\n if (!isFunction(fn)) {\n return false\n }\n\n if (!el._listeners) {\n el._listeners = []\n }\n\n // 缓存 options 元素绑定的事件处理器\n el._listeners.push({\n el,\n type,\n fn: listener,\n data,\n context,\n capture\n })\n\n // 缓存包装后的事件处理器\n fn._delegateListener = listener\n\n el.addEventListener(type, listener, capture)\n}\n\nexport default at\n","/**\r\n * 获取HTML元素的某个CSS样式值\r\n * ====================================================\r\n * @param el\r\n * @param ruleName\r\n * @returns {*}\r\n */\r\nconst getStyle = (el, ruleName) => {\r\n return getComputedStyle(el)[ruleName]\r\n}\r\n\r\nexport default getStyle\r\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport later from './utils/lang/later'\nimport at from './utils/event/at'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport createElement from './utils/dom/createElement'\nimport scrollTo from './utils/dom/scrollTo'\nimport addClass from './utils/dom/addClass'\nimport intersection from './utils/dom/intersection'\nimport removeClass from './utils/dom/removeClass'\nimport offsetTop from './utils/dom/offsetTop'\nimport getStyle from './utils/dom/getStyle'\nimport setProperty from './utils/dom/setProperty'\nimport publish from './utils/observer/emit'\n\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport _paintChapters from './_paintChapters'\n\nclass Chapters extends Base {\n constructor(options) {\n super()\n\n this.attrs = Chapters.DEFAULTS\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.closed = false\n this.active = 0\n this.offsetTop = 0\n this.offsetWidth = 0\n this.$active = null\n this.scrollTimer = null\n this.resizeTimer = null\n this.playing = false\n this.Observer = null\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let parentElement\n let scrollElement\n let $parent\n\n this.attr(options)\n created = this.attr('created')\n parentElement = this.attr('parentElement')\n scrollElement = this.attr('scrollElement')\n\n if (isString(parentElement)) {\n $parent = document.querySelector(parentElement)\n } else if (isElement(parentElement)) {\n $parent = parentElement\n }\n this.$parentElement = $parent\n this.$scrollElement = _getScrollElement(scrollElement)\n\n this.chapters = this.attr('chapters')\n this.closed = this.attr('closed')\n this.active = this.attr('active')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n if (this.chapters.length < 1) {\n return this\n }\n\n this.render().addListeners()\n\n this.$active = document.querySelector(`#chapter-${this.active}`)\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n isSticky() {\n const position = this.attr('position')\n return position === 'sticky'\n }\n\n isFixed() {\n const position = this.attr('position')\n return position === 'fixed'\n }\n\n isInside() {\n return this.isFixed() || this.isSticky()\n }\n\n isOutside() {\n return !this.isInside()\n }\n\n _paintEdge() {\n const $fragment = document.createDocumentFragment()\n const STICKY = 'outline-chapters_sticky'\n const HIDDEN = 'outline-chapters_hidden'\n const title = this.attr('title')\n const customClass = this.attr('customClass')\n const $parentElement = this.$parentElement\n const contents = []\n let $title = null\n let $el\n let $main\n let $list\n let $placeholder\n\n if (!$parentElement) {\n return this\n }\n\n if (this.isInside()) {\n $title = createElement(\n 'h2',\n {\n className: 'outline-chapters__title'\n },\n [title]\n )\n this.$title = $title\n contents.push($title)\n }\n\n $list = createElement(\n 'ul',\n {\n // 为优化性能,添加了 _fixed 和 _hidden\n // fixed 为了让 $list 脱离流布局\n // hidden 让 $list 不可见\n className: `outline-chapters__list`\n },\n ['']\n )\n this.$list = $list\n\n $placeholder = createElement(\n 'div',\n {\n className: 'outline-chapters__placeholder'\n },\n ['']\n )\n this.$placeholder = $placeholder\n\n $main = createElement(\n 'div',\n {\n className: 'outline-chapters__main'\n },\n [$list, $placeholder]\n )\n this.$main = $main\n contents.push($main)\n\n $el = createElement(\n 'nav',\n {\n id: 'outline-chapters',\n className: `outline-chapters ${HIDDEN}`\n },\n contents\n )\n this.$el = $el\n\n if (this.isSticky()) {\n this.calculateStickyHeight()\n addClass($el, STICKY)\n }\n\n if (customClass) {\n addClass($el, customClass)\n }\n $fragment.appendChild($el)\n $parentElement.appendChild($fragment)\n\n return this\n }\n\n render() {\n const HIDDEN = 'outline-chapters_hidden'\n const showCode = this.attr('showCode')\n const mounted = this.attr('mounted')\n const $parentElement = this.$parentElement\n const chapters = this.chapters\n let $el\n let $list\n\n if (!$parentElement || chapters.length < 1) {\n return this\n }\n\n this._paintEdge()\n\n $el = this.$el\n $list = this.$list\n _paintChapters($list, chapters, showCode)\n removeClass($el, HIDDEN)\n this.positionPlaceholder(this.active)\n\n this.offsetTop = offsetTop($el)\n this.offsetWidth = $el.offsetWidth\n\n if (this.isFixed()) {\n this.sticky()\n setProperty('--outline-chapters-width', `${this.offsetWidth}px`)\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n this.onObserver()\n\n return this\n }\n\n positionPlaceholder(index) {\n const $main = this.$main\n const $list = this.$list\n const $placeholder = this.$placeholder\n const $anchor = $list.querySelector('.outline-chapters__anchor')\n const mainPaddingTop = parseInt(getStyle($main, 'padding-top'), 10)\n const mainBorderTop = parseInt(getStyle($main, 'border-top-width'), 10)\n const placeholderPaddingTop = parseInt(getStyle($list, 'padding-top'), 10)\n const placeholderMarginTop = parseInt(getStyle($list, 'margin-top'), 10)\n const placeholderBorderTop = parseInt(\n getStyle($list, 'border-top-width'),\n 10\n )\n let height = $anchor.offsetHeight\n let offsetTop = 0\n let top\n\n if (mainPaddingTop) {\n offsetTop += mainPaddingTop\n }\n\n if (placeholderPaddingTop) {\n offsetTop += placeholderPaddingTop\n }\n\n if (placeholderMarginTop) {\n offsetTop += placeholderMarginTop\n }\n\n if (mainBorderTop) {\n offsetTop += mainBorderTop\n }\n\n if (placeholderBorderTop) {\n offsetTop += placeholderBorderTop\n }\n\n top = height * index\n // top:calc(${offsetTop}px + ${top}px);\n $placeholder.style.cssText = `transform: translateY(${\n offsetTop + top\n }px);height:${height}px;`\n\n return this\n }\n\n highlight(id) {\n const $anchor = this.$el.querySelector(`#chapter__anchor-${id}`)\n const HIGHLIGHT = 'outline-chapters_active'\n\n if (!$anchor) {\n return this\n }\n\n if (this.$active) {\n removeClass(this.$active, HIGHLIGHT)\n }\n\n this.active = parseInt($anchor.getAttribute('data-id'), 10)\n this.$active = $anchor\n addClass(this.$active, HIGHLIGHT)\n\n this.positionPlaceholder(this.active)\n\n return this\n }\n\n sticky() {\n const afterSticky = this.attr('afterSticky')\n const FIXED = 'outline-chapters_fixed'\n const $el = this.$el\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (!this.isFixed()) {\n return this\n }\n\n isStickying = scrollTop >= top\n\n if (isStickying) {\n addClass($el, FIXED)\n } else {\n removeClass($el, FIXED)\n }\n\n if (isFunction(afterSticky)) {\n afterSticky.call(this, this.isClosed(), isStickying)\n }\n\n return this\n }\n\n calculateStickyHeight() {\n const documentElement = document.documentElement\n const height = Math.max(\n documentElement.clientHeight || 0,\n window.innerHeight || 0\n )\n setProperty('--outline-sticky-height', `${height}px`)\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n show() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const opened = this.attr('afterOpened')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n removeClass($parent, HIDDEN)\n removeClass($el, HIDDEN)\n later(() => {\n removeClass($parent, FOLDED)\n removeClass($el, FOLDED)\n }, 30)\n } else {\n removeClass($el, HIDDEN)\n }\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n\n return this\n }\n\n hide() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const closed = this.attr('afterClosed')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n addClass($parent, FOLDED)\n addClass($el, FOLDED)\n later(() => {\n addClass($parent, HIDDEN)\n addClass($el, HIDDEN)\n })\n } else {\n addClass($el, HIDDEN)\n }\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n isStickying = scrollTop >= top\n afterToggle.call(this, this.isClosed(), isStickying)\n })\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n this.$parentElement.removeChild(this.$el)\n\n this.attr(Chapters.DEFAULTS)\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.active = 0\n this.offsetTop = 0\n this.$active = null\n this.closed = false\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n this.scrollTimer = null\n }\n\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n this.resizeTimer = null\n }\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n if (this.Observer) {\n this.Observer = null\n }\n\n return this\n }\n\n onObserver() {\n const selector = this.attr('selector')\n let timer = null\n\n this.Observer = intersection(\n ($heading) => {\n const id = $heading.getAttribute('data-id')\n\n if (this.playing) {\n return false\n }\n\n if (timer) {\n clearTimeout(timer)\n }\n\n timer = later(() => {\n this.highlight(id)\n }, 100)\n },\n {\n selector,\n context: this\n }\n )\n\n return this\n }\n\n onSelect(evt) {\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const id = $anchor.getAttribute('data-id')\n const headingId = $anchor.href.split('#')[1]\n const $heading = document.querySelector(`#${headingId}`)\n const top = offsetTop($heading) - (stickyHeight + 10)\n const min = 0\n const max = this.$scrollElement.scrollHeight\n const afterScroll = this.attr('afterScroll')\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'chapter')\n }\n\n later(() => {\n this.playing = false\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.playing = true\n if (this.isFixed()) {\n this.sticky()\n later(() => {\n this.scrollTo(top, after)\n this.highlight(id)\n }, 10)\n } else {\n this.scrollTo(top, after)\n this.highlight(id)\n }\n\n stop(evt)\n\n return this\n }\n\n onScroll() {\n const $scrollElement = this.$scrollElement\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n }\n\n this.scrollTimer = later(() => {\n const top = $scrollElement.scrollTop\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n\n if (this.isFixed()) {\n this.sticky()\n }\n\n publish('toolbar:update', {\n top,\n min,\n max\n })\n }, 100)\n\n return this\n }\n\n onResize() {\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n }\n\n this.resizeTimer = later(() => {\n this.calculateStickyHeight()\n })\n\n return this\n }\n\n addListeners() {\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n on($el, '.outline-chapters__anchor', 'click', this.onSelect, this, true)\n at($element, 'scroll', this.onScroll, this, true)\n if (this.isSticky()) {\n at($element, 'resize', this.onResize, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const selector = this.attr('selector')\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n off($el, 'click', this.onSelect)\n off($element, 'scroll', this.onScroll)\n\n if (this.isSticky()) {\n at($element, 'resize', this.onResize)\n }\n\n if (this.Observer) {\n document.querySelectorAll(selector).forEach((section) => {\n this.Observer.unobserve(section)\n })\n }\n\n return this\n }\n}\n\nChapters.DEFAULTS = {\n parentElement: '',\n scrollElement: '',\n selector: '.outline-heading',\n active: 0,\n closed: false,\n showCode: true,\n position: 'relative',\n stickyHeight: 0,\n chapters: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterSticky: null\n}\n\nexport default Chapters\n","import createElement from './utils/dom/createElement'\n\nconst _paintChapters = ($list, chapters, showCode = false) => {\n const byId = (id) => document.querySelector(`#${id}`)\n\n chapters.forEach((chapter) => {\n const pid = chapter.pid\n const id = chapter.id\n const rel = chapter.rel\n const $text = createElement(\n 'span',\n {\n className: 'outline-chapters__text'\n },\n [chapter.text]\n )\n const $link = createElement(\n 'a',\n {\n id: `chapter__anchor-${id}`,\n className: 'outline-chapters__anchor',\n href: '#' + rel,\n rel: rel,\n 'data-id': id\n },\n [$text]\n )\n let $code\n let $li\n let $ul\n let $parent\n\n if (showCode) {\n $code = createElement(\n 'span',\n {\n className: 'outline-chapters__code',\n 'data-id': id\n },\n [chapter.code]\n )\n\n $link.insertBefore($code, $link.firstChild)\n }\n\n $li = createElement(\n 'li',\n {\n id: `chapter-${id}`,\n className: 'outline-chapters__item',\n 'data-id': id\n },\n [$link]\n )\n\n if (pid === -1) {\n $list.appendChild($li)\n } else {\n $parent = byId(`chapter-${pid}`)\n $ul = byId(`subject-${pid}`)\n\n if (!$ul) {\n $ul = createElement(\n 'ul',\n {\n id: 'subject-' + pid,\n className: 'outline-chapters__subject'\n },\n [$li]\n )\n\n $parent.appendChild($ul)\n } else {\n $ul.appendChild($li)\n }\n }\n })\n}\n\nexport default _paintChapters\n","import isFunction from '../types/isFunction'\nimport isElement from '../types/isElement'\n\n/**\n * 通用的 IntersectionObserver 观察者处理器\n * ========================================================================\n * @method intersection\n * @param {Function} fn\n * @param {Object} [props]\n * @param {Object|HTMLElement} [props.root]\n * @param {String} [props.selector]\n * @param {Object} [props.context]\n * @param {String} [props.attr]\n * @param {String} [props.rootMargin]\n */\nconst intersection = (fn, props = {}) => {\n const root = props.root || null\n const selector = props.selector || '.outline-heading'\n const context = props.context || null\n const rootMargin = props.rootMargin || '0px 0px -90% 0px'\n const options = {\n rootMargin: rootMargin\n }\n const Observer = new IntersectionObserver((entries) => {\n entries.forEach((entry) => {\n if (entry.intersectionRatio > 0) {\n if (isFunction(fn)) {\n fn.call(context || entry.target, entry.target)\n }\n }\n })\n }, options)\n const $root = isElement(root) ? root : document\n\n if (root) {\n options.root = root\n }\n\n $root.querySelectorAll(selector).forEach((section) => {\n Observer.observe(section)\n })\n\n return Observer\n}\n\nexport default intersection\n","import icon from './utils/icons/icon'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\n\nconst _createButton = (button, rounded = true) => {\n const $icon = icon(button.icon, {\n iconSet: button.iconSet || 'outline',\n color: button.color || '',\n size: button.size\n })\n const $anchor = createElement(\n 'a',\n {\n className: `outline-toolbar__anchor`,\n href: button.link\n },\n [$icon]\n )\n const $button = createElement(\n 'div',\n {\n className: `outline-toolbar__button ${button.name}`\n },\n [button.link ? $anchor : $icon]\n )\n\n addClass($icon, 'outline-toolbar__icon')\n\n if (rounded) {\n addClass($button, 'outline-toolbar_rounded')\n }\n\n if (button.disabled) {\n addClass($button, 'outline-toolbar_disabled')\n }\n\n return $button\n}\n\nexport default _createButton\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isObject from './utils/types/isObject'\nimport isArray from './utils/types/isArray'\nimport later from './utils/lang/later'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\nimport hasClass from './utils/dom/hasClass'\nimport removeClass from './utils/dom/removeClass'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _createButton from './_createButton'\n\nconst DISABLED = 'outline-toolbar_disabled'\nconst HIDDEN = 'outline-toolbar_hidden'\n\nclass Toolbar extends Base {\n constructor(options) {\n super()\n\n this.attrs = Toolbar.DEFAULTS\n this.$el = null\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n created = this.attr('created')\n this.disabled = this.attr('disabled')\n this.closed = this.attr('closed')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n isDisabled(name) {\n const buttons = this.attr('buttons')\n let button\n\n if (name) {\n button = buttons.find((option) => option.name === name)\n\n return button?.disabled\n }\n\n return this.disabled\n }\n\n isClosed() {\n return this.closed\n }\n\n highlight(name) {\n const button = this.buttons.find((item) => item.name === name)\n const ACTIVE = 'outline-toolbar_active'\n let $button\n\n if ($button) {\n return this\n }\n\n $button = button.$el\n\n if (hasClass($button, ACTIVE)) {\n removeClass($button, ACTIVE)\n } else {\n addClass($button, ACTIVE)\n }\n\n return this\n }\n\n render() {\n const mounted = this.attr('mounted')\n const buttons = this.attr('buttons') || []\n const rounded = this.attr('rounded')\n const placement = this.attr('placement')\n const $buttons = document.createDocumentFragment()\n const $fragment = document.createDocumentFragment()\n\n paint()\n\n buttons.forEach((button) => {\n const $button = _createButton(button, rounded)\n\n $buttons.appendChild($button)\n this.buttons.push({\n name: button.name,\n $el: $button\n })\n })\n\n this.$el = createElement(\n 'div',\n {\n id: 'outline-toolbar',\n className: `outline-toolbar outline-toolbar_${placement}`\n },\n [$buttons]\n )\n $fragment.appendChild(this.$el)\n document.body.appendChild($fragment)\n\n if (this.closed) {\n this.hide()\n }\n\n if (this.disabled) {\n this.disable()\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n add(button) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const action = button.action\n const $fragment = document.createDocumentFragment()\n let type\n\n if (isObject(button)) {\n buttons.push(button)\n $fragment.appendChild(_createButton(button))\n } else if (isArray(button)) {\n button.forEach((item) => {\n $fragment.appendChild(_createButton(item))\n })\n }\n $el.appendChild($fragment)\n\n if (action && isFunction(action.handler)) {\n type = action.type || 'click'\n on($el, `.${button.name}`, type, action.handler)\n }\n\n return this\n }\n\n remove(name) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let index = -1\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((button, i) => {\n if (button.name === name) {\n index = i\n }\n })\n\n if (index > -1) {\n this.attr().buttons.splice(index, 1)\n }\n\n $button = $el.querySelector(`.${name}`)\n this.switch(name, false)\n $el.removeChild($button)\n\n return this\n }\n\n switch(name, enabled) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let action\n let type\n let listener\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((option) => {\n if (option.name === name) {\n button.disabled = !enabled\n }\n })\n\n action = button.action\n $button = $el.querySelector(`.${name}`)\n\n if (action) {\n type = action.type || 'click'\n listener = action.handler\n }\n\n if (enabled) {\n removeClass($button, DISABLED)\n\n if (type && listener) {\n on($el, `.${name}`, type, listener)\n }\n } else {\n addClass($button, DISABLED)\n\n if (type && listener) {\n off($el, type, listener)\n }\n }\n\n return this\n }\n\n disable(name) {\n const disabled = this.attr('afterDisabled')\n\n if (name) {\n this.switch(name, false)\n } else {\n addClass(this.$el, DISABLED)\n this.removeListeners()\n this.disabled = true\n\n if (isFunction(disabled)) {\n disabled.call(this)\n }\n }\n\n return this\n }\n\n enable(name) {\n const enabled = this.attr('afterEnabled')\n\n if (name) {\n this.switch(name, true)\n } else {\n this.disabled = false\n removeClass(this.$el, DISABLED)\n this.addListeners()\n\n if (isFunction(enabled)) {\n enabled.call(this)\n }\n }\n\n return this\n }\n\n show(name) {\n const opened = this.attr('afterOpened')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n\n $button = $el.querySelector(`.${name}`)\n removeClass($button, HIDDEN)\n } else {\n removeClass($el, HIDDEN)\n this.closed = false\n\n if (isFunction(opened)) {\n later(() => {\n opened.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n hide(name) {\n const closed = this.attr('afterClosed')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n $button = $el.querySelector(`.${name}`)\n addClass($button, HIDDEN)\n } else {\n addClass($el, HIDDEN)\n this.closed = true\n\n if (isFunction(closed)) {\n later(() => {\n closed.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n toggle() {\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n let $el = this.$el\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n document.body.removeChild($el)\n $el = null\n\n this.attr(Toolbar.DEFAULTS)\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n refresh() {\n const $el = this.$el\n const buttons = this.attr('buttons') || []\n\n this.removeListeners()\n $el.innerHTML = ''\n\n buttons.forEach((button) => {\n this.$el.appendChild(_createButton(button))\n })\n\n this.addListeners()\n\n return this\n }\n\n addListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n let context\n let command\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n if (isString(listener)) {\n command = listener\n action.handler = function () {\n publish(command, button.name)\n }\n listener = action.handler\n }\n\n type = action.type || 'click'\n context = action.context\n }\n\n if (isFunction(listener)) {\n on($el, `.${button.name}`, type, listener, context || this, true)\n }\n })\n\n return this\n }\n\n removeListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n type = action.type || 'click'\n }\n\n if (isFunction(listener)) {\n off($el, type, listener)\n }\n })\n\n return this\n }\n}\n\nToolbar.DEFAULTS = {\n placement: 'ltr',\n closed: false,\n disabled: false,\n rounded: true,\n buttons: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterDisabled: null,\n afterEnabled: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Toolbar\n","/**\n * 生成唯一 id 字符串的函数\n * ========================================================================\n * @method guid\n * @param {String} [prefix] - 生成 id 的前缀字符串\n * @return {String} 返回一个表示唯一 id 的字符串\n */\nconst guid = (() => {\n let uuid = 0\n\n return (prefix) => {\n uuid += 1\n\n return prefix ? prefix + '-' + uuid : 'guid-' + uuid\n }\n})()\n\nexport default guid\n","import _subscribers from './_subscribers'\nimport isFunction from '../types/isFunction'\nimport guid from '../lang/guid'\n\n/**\n * 订阅主题,并给出处理器函数\n * ========================================================================\n * @method on\n * @param {String} topic - (必须)主题名称\n * @param {Function} handler - (必须)主题的处理器函数\n * @param {Object} [context] - (可选)指定 this 执行上下文\n * @return {String} - 唯一的 token 字符串,例如:'guid-1'。\n */\nconst on = (topic, handler, context = null) => {\n const token = guid()\n let subject = typeof topic === 'symbol' ? topic.toString() : topic\n\n if (!isFunction(handler)) {\n return ''\n }\n\n /* istanbul ignore else */\n if (!_subscribers[subject]) {\n _subscribers[subject] = []\n }\n\n _subscribers[subject].push({\n topic: subject,\n callback: handler,\n context,\n token\n })\n\n return token\n}\n\nexport default on\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 删除与给定 topic 相同的订阅者信息\n * ========================================================================\n * @method _removeSubscriber\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _removeSubscriber = (topic) => {\n if (!hasOwn(_subscribers, topic)) {\n return false\n }\n\n delete _subscribers[topic]\n}\n\nexport default _removeSubscriber\n","import has from './has'\nimport _removeSubscriber from './_removeSubscriber'\nimport _removeSubscriberByToken from './_removeSubscriberByToken'\n\n/**\n * 取消订阅主题\n * ========================================================================\n * @method off\n * @param {String} topic - (必须)订阅的主题\n * @param {Function|String} [token] - (可选)订阅主题的处理器函数或者唯一 Id 值\n */\nconst off = (topic, token) => {\n if (!has(topic)) {\n return false\n }\n\n if (token) {\n _removeSubscriberByToken(token)\n } else {\n _removeSubscriber(topic)\n }\n}\n\nexport default off\n","import _subscribers from './_subscribers'\nimport _removeSubscriber from './_removeSubscriber'\n\n/**\n * 通过订阅者 token 值删除订阅者信息\n * ========================================================================\n * @method _removeSubscriberByToken\n * @param {String} token - 订阅者 token 字符串\n * @returns {boolean}\n * @private\n */\nconst _removeSubscriberByToken = (token) => {\n const keys = Object.keys(_subscribers)\n let index = -1\n\n if (!token || keys.length < 1) {\n return false\n }\n\n keys.forEach((subject) => {\n const subscriber = _subscribers[subject]\n let topic\n\n subscriber.forEach((execution, j) => {\n if (execution.callback === token || execution.token === token) {\n topic = execution.topic\n subscriber.splice(index, j)\n }\n })\n\n /* istanbul ignore else */\n if (subscriber.length < 1) {\n _removeSubscriber(topic)\n }\n })\n}\n\nexport default _removeSubscriberByToken\n","import Base from './base'\nimport Anchors from './anchors'\nimport Drawer from './drawer'\nimport Chapters from './chapters'\nimport Toolbar from './toolbar'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport subscribe from './utils/observer/on'\nimport unsubscribe from './utils/observer/off'\n\nclass Outline extends Base {\n constructor(options) {\n super()\n\n this.attrs = Outline.DEFAULTS\n this.anchors = null\n this.drawer = null\n this.chapters = null\n this.toolbar = null\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n this.attr(options).render().addListeners()\n return this\n }\n\n getChapters(isTreeStructured = false) {\n return this.anchors.getChapters(isTreeStructured)\n }\n\n count() {\n return this.anchors.count()\n }\n\n render() {\n const scrollElement = this.attr('scrollElement')\n const $scrollElement = document.querySelector(scrollElement) || document.getElementById(scrollElement)\n\n this._renderAnchors()._renderChapters()._renderToolbar()\n\n if ($scrollElement) {\n this.onToolbarUpdate({\n top: $scrollElement.scrollTop,\n min: 0,\n max: $scrollElement.scrollHeight\n })\n }\n\n return this\n }\n\n _renderAnchors() {\n const articleElement = this.attr('articleElement')\n const selector = this.attr('selector')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n\n this.anchors = new Anchors({\n articleElement,\n stickyHeight,\n scrollElement,\n selector,\n showCode,\n anchorURL,\n afterScroll\n })\n\n return this\n }\n\n _renderChapters() {\n const title = this.attr('title')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const customClass = this.attr('customClass')\n const showCode = this.attr('showCode')\n const position = this.attr('position')\n const placement = this.attr('placement')\n const afterSticky = this.attr('afterSticky')\n const afterToggle = this.attr('afterToggle')\n const afterScroll = this.attr('afterScroll')\n const count = this.count()\n let parentElement = this.attr('parentElement')\n let CHAPTERS_OPTIONS\n\n if (count < 1) {\n return this\n }\n\n CHAPTERS_OPTIONS = {\n scrollElement,\n showCode,\n position,\n title,\n stickyHeight,\n chapters: this.getChapters(),\n afterSticky,\n afterToggle,\n afterScroll\n }\n\n if (position === 'relative') {\n this.drawer = new Drawer({\n placement,\n title,\n size: 'tiny',\n hasOffset: true,\n hasPadding: false,\n customClass,\n afterClosed: () => {\n const toolbar = this.toolbar\n toolbar.toggle()\n }\n })\n parentElement = this.drawer.$main\n } else {\n CHAPTERS_OPTIONS.customClass = customClass\n }\n\n CHAPTERS_OPTIONS.parentElement = parentElement\n this.chapters = new Chapters(CHAPTERS_OPTIONS)\n\n return this\n }\n\n _renderToolbar() {\n const placement = this.attr('placement')\n const homepage = this.attr('homepage')\n const git = this.attr('git')\n const tags = this.attr('tags')\n const issues = this.attr('issues')\n const tools = this.attr('tools')\n const count = this.count()\n const UP = {\n name: 'up',\n icon: 'up',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:up'\n }\n }\n const HOME = {\n name: 'homepage',\n icon: 'homepage',\n size: 20,\n link: homepage\n }\n const GIT = {\n name: 'github',\n icon: 'github',\n size: 20,\n link: git\n }\n const TAGS = {\n name: 'tags',\n icon: 'tags',\n size: 20,\n link: tags\n }\n const ISSUES = {\n name: 'issues',\n icon: 'issues',\n size: 20,\n link: issues\n }\n const MENU = {\n name: 'menu',\n icon: 'menu',\n size: 18,\n action: {\n type: 'click',\n handler: 'toolbar:action:toggle'\n }\n }\n const DOWN = {\n name: 'down',\n icon: 'down',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:down'\n }\n }\n const buttons = []\n\n buttons.push(UP)\n if (homepage) {\n buttons.push(HOME)\n }\n if (count > 0) {\n buttons.push(MENU)\n }\n if (git) {\n buttons.push(GIT)\n }\n if (tags) {\n buttons.push(TAGS)\n }\n if (issues) {\n buttons.push(ISSUES)\n }\n if (tools?.length > 0) {\n buttons.push(...tools)\n }\n buttons.push(DOWN)\n this.buttons = [...buttons]\n\n this.toolbar = new Toolbar({\n placement,\n buttons: buttons\n })\n\n return this\n }\n\n addButton(button) {\n const toolbar = this.toolbar\n const buttons = this.buttons\n buttons.splice(-1, 0, button)\n toolbar.attr({\n buttons\n })\n toolbar.refresh()\n return this\n }\n\n removeButton(name) {\n this.toolbar.remove(name)\n return this\n }\n\n toTop() {\n const afterScroll = this.attr('afterScroll')\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const afterTop = () => {\n toolbar.hide('up')\n toolbar.show('down')\n\n if (count > 0) {\n chapters.highlight(0)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'up')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(0, afterTop)\n\n return this\n }\n\n toBottom() {\n const afterScroll = this.attr('afterScroll')\n const $scrollElement = _getScrollElement(this.attr('scrollElement'))\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const top = Math.floor(\n $scrollElement.scrollHeight - $scrollElement.clientHeight\n )\n const afterDown = () => {\n toolbar.hide('down')\n toolbar.show('up')\n\n if (count > 0) {\n chapters.highlight(count - 1)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'bottom')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(top, afterDown)\n\n return this\n }\n\n scrollTo(top, afterScroll) {\n const scrollElement = this.attr('scrollElement')\n scrollTo(scrollElement, top, afterScroll)\n return this\n }\n\n toggle() {\n const position = this.attr('position')\n const toolbar = this.toolbar\n const drawer = this.drawer\n const chapters = this.chapters\n const count = this.count()\n\n if (count < 1) {\n return this\n }\n\n if (position !== 'relative') {\n chapters.toggle()\n toolbar.highlight('menu')\n } else {\n toolbar.toggle()\n\n later(() => {\n if (chapters.isInside()) {\n chapters.toggle()\n } else {\n drawer.toggle()\n }\n })\n }\n\n return this\n }\n\n destroy() {\n let anchors = this.anchors\n let chapters = this.chapters\n let drawer = this.drawer\n let toolbar = this.toolbar\n let isOutside = false\n const count = this.count()\n\n this.removeListeners()\n\n if (count > 0) {\n isOutside = chapters.isOutside()\n\n chapters.destroy()\n chapters = null\n\n if (isOutside) {\n drawer.destroy()\n drawer = null\n }\n }\n\n toolbar.destroy()\n toolbar = null\n\n anchors.destroy()\n anchors = null\n\n this.attr(Outline.DEFAULTS)\n\n return this\n }\n\n onToggle() {\n this.toggle()\n return this\n }\n\n onScrollTop() {\n this.toTop()\n return this\n }\n\n onScrollBottom() {\n this.toBottom()\n return this\n }\n\n onToolbarUpdate({ top, min, max }) {\n const toolbar = this.toolbar\n const current = Math.ceil(top)\n\n if (current <= min) {\n toolbar.hide('up')\n toolbar.show('down')\n } else if (current >= max) {\n toolbar.hide('down')\n toolbar.show('up')\n } else if (current > min && current < max) {\n toolbar.show('up')\n toolbar.show('down')\n }\n\n return this\n }\n\n addListeners() {\n subscribe('toolbar:update', this.onToolbarUpdate, this)\n subscribe('toolbar:action:up', this.onScrollTop, this)\n subscribe('toolbar:action:toggle', this.onToggle, this)\n subscribe('toolbar:action:down', this.onScrollBottom, this)\n return this\n }\n\n removeListeners() {\n unsubscribe('toolbar:update')\n unsubscribe('toolbar:action:up')\n unsubscribe('toolbar:action:toggle')\n unsubscribe('toolbar:action:down')\n return this\n }\n}\n\nOutline.DEFAULTS = {\n articleElement: '#article',\n selector: 'h2,h3,h4,h5,h6',\n title: '目录',\n scrollElement: 'html,body',\n position: 'relative',\n parentElement: '#aside',\n placement: 'rtl',\n showCode: true,\n anchorURL: '',\n stickyHeight: 0,\n homepage: '',\n git: '',\n tags: '',\n issues: '',\n tools: [],\n customClass: '',\n afterSticky: null,\n afterToggle: null,\n afterScroll: null\n}\n\nif (window.jQuery) {\n // 将 Outline 扩展为一个 jquery 插件\n // eslint-disable-next-line no-undef\n jQuery.extend(jQuery.fn, {\n outline: function (options) {\n // eslint-disable-next-line no-undef\n let $article = jQuery(this)\n\n return new Outline(\n // eslint-disable-next-line no-undef\n jQuery.extend({}, options, {\n articleElement: $article\n })\n )\n }\n })\n}\n\nexport default Outline\n"],"names":["isString","str","hasOwn","obj","prop","hasOwnProperty","Object","prototype","call","toString","val","apply","isFunction","isObject","o","Base","constructor","options","this","attrs","initialize","attr","render","addListeners","value","origin","source","keys","forEach","arguments","length","destroy","removeListeners","reload","isElement","nodeName","tagName","nodeType","later","fn","delay","setTimeout","easeInQuad","x","_getScrollElement","scrollElement","$rootElements","$scrollElement","document","querySelector","querySelectorAll","scrollTop","scrollTo","top","afterStop","step","distance","MAX_HEIGHT","scrollHeight","MAX_TOP","stop","play","requestAnimationFrame","offsetTop","el","offsetParent","matches","selector","sel","replace","msMatchesSelector","getParentOrHost","host","parentNode","CAPTURE_EVENTS","_off","type","capture","indexOf","_delegateListener","listeners","_listeners","index","listener","i","handler","splice","_delete","removeEventListener","purgeElement","recurse","$element","$children","childNodes","filter","getListeners","$child","off","on","data","context","once","evt","target","getTarget","delegateTarget","ctx","includeCTX","startsWith","closest","overrideContext","push","addEventListener","stopPropagation","preventDefault","_subscribers","_hasDirectSubscribersFor","topic","has","isDirect","found","position","lastIndexOf","substring","_hasSubscribers","emit","async","execute","subscriber","message","callback","deliver","isArray","Array","SYMBOLS","getSymbols","name","iconSet","patternName","patternSet","find","symbol","fullName","exec","iconName","getSymbol","paint","$body","body","$icons","symbols","add","innerHTML","join","createElement","insertBefore","firstChild","trim","isDOM","isHTMLCollection","fragment","isTextNode","setAttribute","toLowerCase","style","cssText","className","children","$fragment","createDocumentFragment","$el","isValidChild","child","append","createTextNode","appendChild","every","isSVG","pattern","RegExp","test","icon","size","color","width","height","defaultRules","cssRules","$icon","$svg","binds","svg","hasClass","allClass","classList","contains","removeClass","remove","_resetHeading","$heading","hasAnchor","isAtStart","CLS_HEADING","text","$anchor","removeAttribute","removeChild","getChapters","headings","showCode","previous","level","chapters","heading","headingLevel","current","parseInt","pid","differ","_getChapterParentIdByDiffer","id","rel","groups","group","JSON","stringify","cb","code","String","c","b","_getChaptersWithCode","Anchors","super","DEFAULTS","$articleElement","$headings","created","articleElement","isTreeStructured","list","nodeKey","parentKey","map","roots","item","node","toTree","count","mounted","anchorURL","chapterCode","headingId","href","_updateHeading","after","beforeDestroy","afterDestroy","onAnchorTrigger","afterScroll","stickyHeight","max","clientHeight","publish","min","addClass","setProperty","documentElement","zIndex","idx","Drawer","title","closed","$modal","$header","$title","$close","$main","$footer","$overlay","setTitle","isClosed","placement","hasClose","hasOverlay","hasOffset","hasPadding","autoHeight","customClass","open","opened","close","toggle","afterToggle","onClose","afterClosed","afterOpened","at","getStyle","ruleName","getComputedStyle","Chapters","$list","$placeholder","$parentElement","active","offsetWidth","$active","scrollTimer","resizeTimer","playing","Observer","parentElement","$parent","isSticky","isFixed","isInside","isOutside","_paintEdge","contents","calculateStickyHeight","byId","chapter","$text","$link","$code","$li","$ul","_paintChapters","positionPlaceholder","sticky","onObserver","mainPaddingTop","mainBorderTop","placeholderPaddingTop","placeholderMarginTop","placeholderBorderTop","offsetHeight","highlight","HIGHLIGHT","getAttribute","afterSticky","FIXED","isStickying","Math","window","innerHeight","show","FOLDED","HIDDEN","hide","clearTimeout","timer","props","root","rootMargin","IntersectionObserver","entries","entry","intersectionRatio","$root","section","observe","intersection","onSelect","split","onScroll","onResize","unobserve","_createButton","button","rounded","link","$button","disabled","DISABLED","Toolbar","buttons","isDisabled","option","ACTIVE","$buttons","disable","action","switch","enabled","enable","refresh","command","afterDisabled","afterEnabled","guid","uuid","prefix","token","subject","_removeSubscriber","execution","j","_removeSubscriberByToken","Outline","anchors","drawer","toolbar","getElementById","_renderAnchors","_renderChapters","_renderToolbar","onToolbarUpdate","CHAPTERS_OPTIONS","homepage","git","tags","issues","tools","HOME","GIT","TAGS","ISSUES","MENU","addButton","removeButton","toTop","toBottom","floor","onToggle","onScrollTop","onScrollBottom","ceil","subscribe","unsubscribe","jQuery","extend","outline","$article"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"outline.min.js","sources":["src/utils/types/isString.js","src/utils/lang/hasOwn.js","src/utils/lang/toString.js","src/utils/types/isFunction.js","src/utils/types/isObject.js","src/base.js","src/utils/lang/extend.js","src/utils/types/isElement.js","src/utils/lang/later.js","src/utils/lang/easeInQuad.js","src/utils/dom/_getScrollElement.js","src/utils/dom/scrollTo.js","src/utils/dom/offsetTop.js","src/utils/dom/matches.js","src/utils/dom/getParentOrHost.js","src/utils/event/enum.js","src/utils/event/_off.js","src/utils/event/_delete.js","src/utils/event/purgeElement.js","src/utils/event/getListeners.js","src/utils/event/off.js","src/utils/event/on.js","src/utils/event/getTarget.js","src/utils/dom/resolveTextNode.js","src/utils/dom/closest.js","src/utils/event/stop.js","src/utils/observer/_subscribers.js","src/utils/observer/_hasDirectSubscribersFor.js","src/utils/observer/has.js","src/utils/observer/_hasSubscribers.js","src/utils/observer/emit.js","src/utils/types/isTypedArray.js","src/utils/types/isArray.js","src/utils/icons/symbols.js","src/utils/icons/defaults.js","src/utils/icons/getSymbols.js","src/utils/icons/getSymbol.js","src/utils/icons/paint.js","src/utils/icons/add.js","src/utils/lang/trim.js","src/utils/types/isDOM.js","src/utils/types/isHTMLCollection.js","src/utils/types/isFragment.js","src/utils/types/isTextNode.js","src/utils/dom/setAttribute.js","src/utils/dom/createElement.js","src/utils/types/isSVG.js","src/utils/icons/icon.js","src/utils/icons/createElement.js","src/utils/dom/hasClass.js","src/utils/dom/removeClass.js","src/_resetHeading.js","src/utils/types/isEmpty.js","src/getChapters.js","src/utils/lang/stripTags.js","src/_getChapterParentIdByDiffer.js","src/_getChaptersWithCode.js","src/anchors.js","src/utils/lang/toTree.js","src/_updateHeading.js","src/utils/dom/addClass.js","src/utils/dom/setProperty.js","src/zIndex.js","src/drawer.js","src/utils/event/at.js","src/utils/dom/getStyle.js","src/chapters.js","src/_paintChapters.js","src/utils/dom/intersection.js","src/_createButton.js","src/toolbar.js","src/utils/lang/guid.js","src/utils/observer/on.js","src/utils/observer/_removeSubscriber.js","src/utils/observer/off.js","src/utils/observer/_removeSubscriberByToken.js","src/outline.js","src/print.js"],"sourcesContent":["/**\n * 检测数据是否为 String 类型\n * ========================================================================\n * @method isArray\n * @param {*} str\n * @returns {boolean}\n */\nconst isString = (str) => {\n return typeof str === 'string'\n}\n\nexport default isString\n","/**\n * 检测对象自身属性中是否具有指定的属性。\n * ========================================================================\n * @method hasOwn\n * @param {Object} obj - (必须)检测的目标对象\n * @param {String} prop - (必须)属性名\n * @returns {Boolean}\n */\nconst hasOwn = (obj, prop) => {\n const hasOwnProperty = Object.prototype.hasOwnProperty\n return obj && hasOwnProperty.call(obj, prop)\n}\n\nexport default hasOwn\n","/**\n * Object 对象原型上的 toString 方法\n * ========================================================================\n * @method toString\n * @param {*} val\n * @returns {string}\n */\nconst toString = (val) => {\n return Object.prototype.toString.apply(val)\n}\n\nexport default toString\n","import toString from '../lang/toString'\n\n/**\n * 检测测试数据是否为 Function 类型\n * ========================================================================\n * @method isFunction\n * @param {*} val - (必须)待检测的数据\n * @returns {boolean} 'val' 是 Function 类型返回 true,否则返回 false\n */\nconst isFunction = (val) => {\n return typeof val === 'function' || toString(val) === '[object Function]'\n}\n\nexport default isFunction\n","import toString from '../lang/toString'\nimport isFunction from '../types/isFunction'\n\n/**\n * 检测数据是否为 Object 类型\n * ========================================================================\n * @method isObject\n * @param {*} o\n * @returns {boolean}\n */\nconst isObject = (o) => {\n return (\n (toString(o) === '[object Object]' ||\n typeof o === 'object' ||\n isFunction(o)) &&\n o !== null\n )\n}\n\nexport default isObject\n","import isString from './utils/types/isString'\r\nimport hasOwn from './utils/lang/hasOwn'\r\nimport isObject from './utils/types/isObject'\r\nimport extend from './utils/lang/extend'\r\n\r\nclass Base {\r\n constructor(options) {\r\n this.attrs = {}\r\n\r\n if (options) {\r\n this.initialize(options)\r\n }\r\n }\r\n\r\n initialize(options) {\r\n this.attr(options).render().addListeners()\r\n return this\r\n }\r\n\r\n attr(prop, value) {\r\n const attrs = this.attrs\r\n\r\n if (isString(prop)) {\r\n // 只能扩展 attrs 中已有的属性\r\n if (value && hasOwn(attrs, prop)) {\r\n // 更新单个配置信息\r\n attrs[prop] = value\r\n return this\r\n }\r\n\r\n // 只传递 prop 参数,则返回对应的属性值\r\n return attrs[prop]\r\n } else if (isObject(prop)) {\r\n // 批量更新配置信息\r\n extend(attrs, prop)\r\n\r\n return this\r\n } else if (arguments.length === 0) {\r\n // 不传递参数,直接返回整个\r\n return attrs\r\n }\r\n\r\n return this\r\n }\r\n\r\n render() {\r\n return this\r\n }\r\n\r\n destroy() {\r\n this.removeListeners()\r\n return this\r\n }\r\n\r\n reload(options) {\r\n this.destroy().initialize(this.attr(options))\r\n return this\r\n }\r\n\r\n addListeners() {\r\n return this\r\n }\r\n\r\n removeListeners() {\r\n return this\r\n }\r\n}\r\n\r\nexport default Base\r\n","import hasOwn from './hasOwn'\n\n/**\n * 扩展对象\n * ========================================================================\n * @method extend\n * @param {Object} origin\n * @param {Object} source\n */\nconst extend = (origin, source) => {\n const keys = Object.keys(source)\n\n keys.forEach((prop) => {\n if (hasOwn(source, prop)) {\n origin[prop] = source[prop]\n }\n })\n}\n\nexport default extend\n","import isObject from './isObject'\n\n/**\n * 检测数据是否为 HTMLElement DOM 节点\n * ========================================================================\n * @method isElement\n * @param {*} o\n * @returns {boolean}\n */\nconst isElement = (o) => {\n return !!(isObject(o) && o.nodeName && o.tagName && o.nodeType === 1)\n}\n\nexport default isElement\n","import isFunction from '../types/isFunction'\n\n/**\n * later - 延迟执行方法\n * ========================================================================\n * @method later\n * @param {Function} fn\n * @param {Number} [delay]\n * @returns {number|boolean}\n */\nconst later = (fn, delay = 300) => {\n if (!isFunction(fn)) {\n return false\n }\n\n return setTimeout(() => {\n fn()\n }, delay)\n}\n\nexport default later\n","/**\n * 返回给定值的平方值\n * ========================================================================\n * @method easeInQuad\n * @param {Number} x\n * @returns {number}\n */\nconst easeInQuad = (x) => {\n return x * x\n}\n\nexport default easeInQuad\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\n\n/**\n * 通过给的 scrollElement 参数,获取滚动 DOM 元素\n * ========================================================================\n * @method _getScrollElement\n * @param {String|HTMLElement} scrollElement\n * @returns {Element}\n * @private\n */\nconst _getScrollElement = (scrollElement = null) => {\n let $rootElements\n let $scrollElement\n\n if (!scrollElement) {\n $rootElements = document.querySelectorAll('html,body')\n $scrollElement =\n $rootElements[0].scrollTop - $rootElements[1].scrollTop >= 0\n ? $rootElements[0]\n : $rootElements[1]\n } else {\n if (isString(scrollElement)) {\n $scrollElement = document.querySelector(scrollElement)\n } else if (isElement(scrollElement)) {\n $scrollElement = scrollElement\n }\n }\n\n return $scrollElement\n}\n\nexport default _getScrollElement\n","import easeInQuad from '../lang/easeInQuad'\nimport isFunction from '../types/isFunction'\nimport _getScrollElement from './_getScrollElement'\n\n/**\n * 指定 rootElement DOM 节点滚动到指定 top 位置\n * ========================================================================\n * @method scrollTo\n * @param {HTMLElement|Object} [scrollElement] - (必须)要滚动的 DOM 节点\n * @param {Number} top - (必须)滚动的 scrollTop 数值\n * @param {Function} [afterStop] - (可选)滚动完成的回调函数\n */\nconst scrollTo = (scrollElement, top, afterStop) => {\n const $scrollElement = _getScrollElement(scrollElement)\n let scrollTop = $scrollElement.scrollTop\n let step = 0\n const distance = top - scrollTop\n const MAX_HEIGHT = $scrollElement.scrollHeight\n const MAX_TOP = top - MAX_HEIGHT <= 0 ? top : MAX_HEIGHT\n const stop = (top) => {\n if (isFunction(afterStop)) {\n afterStop(top)\n }\n\n return false\n }\n const play = () => {\n step += 1\n\n // 向上滚动\n if (distance < 0) {\n scrollTop -= easeInQuad(step)\n $scrollElement.scrollTop = scrollTop\n\n if (scrollTop <= top) {\n $scrollElement.scrollTop = top\n return stop(top)\n }\n } else {\n scrollTop += easeInQuad(step)\n $scrollElement.scrollTop = scrollTop\n\n if (scrollTop >= MAX_TOP) {\n $scrollElement.scrollTop = MAX_TOP\n return stop(MAX_TOP)\n }\n }\n\n requestAnimationFrame(play)\n }\n\n requestAnimationFrame(play)\n}\n\nexport default scrollTo\n","/**\n * 获取 DOM 节点相对于窗口的 left (纵坐标)值\n * ========================================================================\n * @method offsetTop\n * @param {HTMLElement} el - DOM 节点\n * @returns {Number}\n */\nconst offsetTop = (el) => {\n let top = el.offsetTop\n\n if (el.offsetParent !== null) {\n top += offsetTop(el.offsetParent)\n }\n\n return top\n}\n\nexport default offsetTop\n","/**\n * 获取 options 节点下匹配 selector 选择器的 DOM 节点\n * ========================================================================\n * Element.matches() 方法可以用来判断 DOM 元素是否与给定的选择器匹配,事件代理判断是\n * 否触发绑定的代理事件回调函数,关键就是使用 Element.matches() 辨别当前事件触发的目\n * 标 DOM 元素是否为事件代理所期望触发的目标。\n * ========================================================================\n * @method matches\n * @see https://developer.mozilla.org/en-US/docs/web/api/element/matches\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)匹配 DOM 元素的选择器\n * @returns {Boolean}\n */\nconst matches = (el, selector = '') => {\n const sel = selector.replace(/^>/i, '')\n\n if (!selector || !sel || !el) {\n return false\n }\n\n /* istanbul ignore else */\n if (el.matches) {\n return el.matches(sel)\n } else if (el.msMatchesSelector) {\n return el.msMatchesSelector(sel)\n } else {\n return false\n }\n}\n\nexport default matches\n","/**\n * 获取 DOM 元素的父节点\n * ========================================================================\n * @method getParentOrHost\n * @param {*|HTMLElement} el - (必须)要获取父节点的 DOM 元素\n * @returns {*|HTMLElement}\n */\nconst getParentOrHost = (el) => {\n return el.host && el !== document && el.host.nodeType\n ? el.host\n : el.parentNode\n}\n\nexport default getParentOrHost\n","export const CAPTURE_EVENTS = [\n 'focusout',\n 'blur',\n 'focusin',\n 'focus',\n 'load',\n 'unload',\n 'mouseenter',\n 'mouseleave'\n]\n","import { CAPTURE_EVENTS } from './enum'\nimport _delete from './_delete'\n\n/**\n * (私有方法)取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method _off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} fn - (必须)事件处理器回调函数\n * @private\n */\nconst _off = (el, type, fn) => {\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n /* istanbul ignore else */\n if (fn._delegateListener) {\n fn = fn._delegateListener\n delete fn._delegateListener\n }\n\n // 移除缓存的 _listeners 数据\n _delete(el, type, fn)\n\n el.removeEventListener(type, fn, capture)\n}\n\nexport default _off\n","/**\n * 删除 DOM 元素缓存的 _listeners 数据\n * ========================================================================\n * @method _delete\n * @param {HTMLElement} el - 要删除 listener 的 DOM 元素\n * @param {String} type - 事件类型(名称)\n * @param {Function} [fn] - 事件处理器回调函数\n */\nconst _delete = function (el, type, fn) {\n const listeners = el._listeners\n let index = -1\n\n if (listeners.length < 1) {\n return false\n }\n\n // 移除缓存的 _listeners 数据\n listeners.forEach((listener, i) => {\n const handler = listener.fn\n\n if (type === listener.type) {\n index = i\n\n if (handler === fn) {\n index = i\n }\n }\n })\n\n /* istanbul ignore else */\n if (index > -1) {\n listeners.splice(index, 1)\n }\n}\n\nexport default _delete\n","import isString from '../types/isString'\nimport isElement from '../types/isElement'\nimport getListeners from './getListeners'\nimport _off from './_off'\n\n/**\n * 销毁(type 类型的)代理事件绑定\n * ========================================================================\n * 1. 设置了事件类型 type,则销毁指定类型的事件绑定,否则清除所有代理事件绑定\n * 2. recurse 设置为 true,递归销毁子节点全部事件绑定\n * ========================================================================\n * @method purgeElement\n * @param {HTMLElement|String} el - (必须)DOM 元素或者其选择器\n * @param {String|Boolean} type - (必须)事件类型\n * @param {Boolean} [recurse] - (可选)是否递归销毁子节点所有事件绑定\n */\nconst purgeElement = function (el, type, recurse = false) {\n const $element = isString(el) ? document.querySelector(el) : el\n const $children = $element.childNodes\n const listeners = getListeners($element, type)\n\n listeners.forEach((listener) => {\n _off($element, listener.type, listener.fn)\n })\n\n if (\n (recurse || type === true || arguments.length === 1) &&\n $element &&\n $children\n ) {\n $children.forEach(($child) => {\n if (isElement($child)) {\n purgeElement($child, type, recurse)\n }\n })\n }\n}\n\nexport default purgeElement\n","import isString from '../types/isString'\n\n/**\n * 获取 DOM 元素(type 事件类型)事件绑定信息\n * ========================================================================\n * 如果设置了事件类型 type, 则返回指定类型的事件绑定信息,否则返回所有事件绑定信息\n * ========================================================================\n * @methods getListeners\n * @param {HTMLElement} el - (必须)要获取事件绑定信息的 DOM 元素\n * @param {String} [type] - (可选)事件类型\n * @returns {Array} - 已绑定的事件信息\n */\nconst getListeners = (el, type) => {\n let listeners = el._listeners || []\n\n if (isString(type) && type) {\n listeners = listeners.filter((listener) => {\n return listener.type === type\n })\n }\n\n return listeners\n}\n\nexport default getListeners\n","import purgeElement from './purgeElement'\nimport isFunction from '../types/isFunction'\nimport _off from './_off'\n\n/**\n * 取消 type 类型的代理事件绑定\n * ========================================================================\n * 如果没有设置 handler,则销毁 this.$options 绑定的所有符合 type 事件类型的事件绑定\n * ========================================================================\n * @method off\n * @param {HTMLElement} el - (必须)取消事件绑定的 DOM 元素\n * @param {String} type - (必须)事件类型\n * @param {Function} [fn] - (可选)事件处理器回调函数\n */\nconst off = (el, type, fn) => {\n // 如果不设置 fn 参数,默认清除 el 元素上绑定的所有事件处理器\n if (!isFunction(fn)) {\n return purgeElement(el, type)\n }\n\n _off(el, type, fn)\n}\n\nexport default off\n","import closest from '../dom/closest'\nimport off from './off'\nimport getTarget from './getTarget'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定代理事件\n * ========================================================================\n * @method on\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String} selector - (必须)事件代理目标 DOM 元素的选择器\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (可选) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst on = (el, selector, type, fn, data, context, once = false) => {\n // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n\n const listener = function (evt) {\n const target = getTarget(evt)\n // 通过 Element.matches 方法获得点击的目标元素\n const delegateTarget = closest(target, selector, el)\n let overrideContext = context || el\n\n evt.delegateTarget = delegateTarget\n\n // 当设置为 true 时,则事件处理器回调函数的\n // this 上下文指向为 data 对象\n if (context === true) {\n overrideContext = data\n }\n\n /* istanbul ignore else */\n if (delegateTarget) {\n // 仅触发一次\n /* istanbul ignore else */\n if (once === true) {\n off(el, type, listener)\n }\n\n fn.call(overrideContext, evt, data)\n }\n }\n\n if (!el._listeners) {\n el._listeners = []\n }\n\n // 缓存 options 元素绑定的事件处理器\n el._listeners.push({\n el,\n selector,\n type,\n fn: listener,\n data,\n context,\n capture\n })\n\n // 缓存包装后的事件处理器\n fn._delegateListener = listener\n\n el.addEventListener(type, listener, capture)\n}\n\nexport default on\n","import resolveTextNode from '../dom/resolveTextNode'\n\n/**\n * 返回触发事件的 target DOM 元素\n * ========================================================================\n * @method getTarget\n * @param {Event} evt - Event 对象\n * @return {HTMLElement} - Event 对象的 target DOM 元素\n */\nconst getTarget = function (evt) {\n const target = evt.target\n\n return resolveTextNode(target)\n}\n\nexport default getTarget\n","/**\n * 在某些情况下,某些浏览器(例如:Safari 浏览器)会返回实际的目标元素内部的文本节点。\n * resolveTextNode() 方法则会返回实际的目标节点。\n * ========================================================================\n * @method resolveTextNode\n * @param {HTMLElement|Text} el - 要解析的节点\n * @return {*|HTMLElement} - 实际的目标 DOM 节点\n */\nconst resolveTextNode = function (el) {\n if (el && el.nodeType === 3) {\n return el.parentNode\n }\n\n return el\n}\n\nexport default resolveTextNode\n","import matches from './matches'\nimport getParentOrHost from './getParentOrHost'\n\n/**\n * 获取 options 元素父元素最近的包含 selector 选择器的元素\n * ========================================================================\n * @method closest\n * @param {HTMLElement} el - (必须)DOM 元素\n * @param {String} selector - (必须)DOM 元素的选择其\n * @param {HTMLElement} [ctx] - (必须)比对的 DOM 元素\n * @param {Boolean} [includeCTX] - (必须)是否包含 context DOM 元素\n * @returns {null|HTMLElement} - 返回最接近的 DOM 元素\n */\nconst closest = (el, selector, ctx, includeCTX) => {\n const context = ctx || document\n\n if (!el) {\n return null\n }\n\n do {\n /* istanbul ignore else */\n if (\n (selector != null &&\n (selector.startsWith('>')\n ? el.parentNode === context && matches(el, selector)\n : matches(el, selector))) ||\n (includeCTX && el === context)\n ) {\n return el\n }\n\n /* istanbul ignore else */\n if (el === context) {\n break\n }\n\n /* jshint boss:true */\n } while ((el = getParentOrHost(el)))\n}\n\nexport default closest\n","/**\n * 停止事件(阻止默认行为和阻止事件的捕获或冒泡)\n * ========================================================================\n * @method stop\n * @param {Event} evt - 事件对象\n *\n * @example\n *
\n * Service\n * Help\n *
\n *\n * const $nav = document.querySelector('#nav')\n * const $service = document.querySelector('.anchor')\n *\n * on($nav, 'click', function(evt) {\n * console.log('你点击了导航栏')\n * })\n *\n * on($anchor, 'click', function(evt) {\n * console.log('tagName', this.tagName)\n *\n * // 工作台输出:'a'\n * // 不会触发事件冒泡,输出:'你点击了导航栏'\n * // 也不会切换到 href 属性的页面,阻止了点击链接的默认行为\n * stopEvent(evt)\n * })\n */\nconst stop = function (evt) {\n evt.stopPropagation()\n evt.preventDefault()\n}\n\nexport default stop\n","/**\n * 存储订阅者(主题和处理器的)私有对象\n * ========================================================================\n * @type {{}}\n * @private\n */\nconst _subscribers = {}\n\nexport default _subscribers\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 判断是否存在与给定 topic 完全匹配的订阅者信息\n * ========================================================================\n * @method _hasDirectSubscribersFor\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasDirectSubscribersFor = (topic) => {\n return hasOwn(_subscribers, topic) && _subscribers[topic].length > 0\n}\n\nexport default _hasDirectSubscribersFor\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\nimport _hasSubscribers from './_hasSubscribers'\n\n/**\n * 判断是否存在包含 topic 指定的订阅者信息\n * ========================================================================\n * @method has\n * @param {String} topic - (必须)主题名称\n * @param {Boolean} [isDirect] - (可选)是否为直接的主题,默认值:true\n * @returns {Boolean}\n */\nconst has = (topic, isDirect = true) => {\n return isDirect ? _hasDirectSubscribersFor(topic) : _hasSubscribers(topic)\n}\n\nexport default has\n","import _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * 判断是否存在包含给定 topic 相关的订阅者信息\n * ========================================================================\n * @method _hasSubscribers\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _hasSubscribers = (topic) => {\n let found = _hasDirectSubscribersFor(topic)\n let position = topic.lastIndexOf('.')\n\n while (!found && position !== -1) {\n topic = topic.substring(0, position)\n position = topic.lastIndexOf('.')\n found = _hasDirectSubscribersFor(topic)\n }\n\n return found\n}\n\nexport default _hasSubscribers\n","import isTypedArray from '../types/isTypedArray'\nimport _subscribers from './_subscribers'\nimport has from './has'\nimport _hasDirectSubscribersFor from './_hasDirectSubscribersFor'\n\n/**\n * (异步)发布订阅主题信息\n * ========================================================================\n * 主题默认是异步发布的。确保在消费者处理主题时,主题的发起者不会被阻止。\n * ========================================================================\n * @method emit\n * @param {String} topic - (必须)主题名称\n * @param {Object} data - (必须)数据对象\n * @param {Boolean} async - (可选) 是否异步发布\n */\nconst emit = (topic, data, async = true) => {\n const execute = (topic) => {\n if (!_hasDirectSubscribersFor(topic)) {\n return false\n }\n\n _subscribers[topic].forEach((subscriber) => {\n // 针对 mqtt 消息服务返回的 Uint8Array 类似的 typed arrays 格式的数据\n // 采用 toString() 方法转化为普通(JSON)字符串\n const message = isTypedArray(data) ? data.toString() : data\n\n subscriber.callback.call(subscriber.context || subscriber, message)\n })\n }\n const deliver = () => {\n let subscriber = topic\n let position = topic.lastIndexOf('.')\n\n while (position !== -1) {\n subscriber = subscriber.substring(0, position)\n position = subscriber.lastIndexOf('.')\n\n execute(subscriber)\n }\n\n // 执行 topic 对应的处理器\n execute(topic)\n // 执行特殊 topic:'*'(监听全部消息的发布)\n execute('*')\n }\n\n if (!has(topic)) {\n return false\n }\n\n if (async) {\n setTimeout(deliver, 10)\n } else {\n deliver()\n }\n}\n\nexport default emit\n","import toString from '../lang/toString'\n/**\n * 判断检测数据是否为 Typed Arrays 类型的数据\n * ========================================================================\n * @param {*} val\n * @returns {boolean}\n */\nconst isTypedArray = (val) => {\n const TYPES = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]',\n '[object BigInt64Array]',\n '[object BigUint64Array]'\n ]\n\n return TYPES.indexOf(toString(val)) > -1\n}\n\nexport default isTypedArray\n","import toString from '../lang/toString'\n\n/**\n * 检测数据是否为 Array 类型\n * ========================================================================\n * @method isArray\n * @param {*} o\n * @returns {boolean}\n */\nconst isArray = (o) => {\n if (Array.isArray) {\n return Array.isArray(o)\n } else {\n return toString(o) === '[object Array]'\n }\n}\n\nexport default isArray\n","import DEFAULTS from './defaults'\n\nconst SYMBOLS = [...DEFAULTS]\n\nexport default SYMBOLS\n","const DEFAULTS = [\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n ''\n]\n\nexport default DEFAULTS\n","import isString from '../types/isString'\nimport getSymbol from './getSymbol'\nimport SYMBOLS from './symbols'\n\n/**\n *\n * @method getSymbols\n * @param {String} [name]\n * @param {String} [iconSet]\n * @returns {string[]|*}\n */\nconst getSymbols = (name, iconSet = 'icon') => {\n if (isString(name)) {\n return getSymbol(name, iconSet)\n }\n\n return [...SYMBOLS]\n}\n\nexport default getSymbols\n","import SYMBOLS from './symbols'\n\n/**\n * @method getSymbol\n * @param {String} name\n * @param {String} [iconSet]\n * @returns {String}\n */\nconst getSymbol = (name, iconSet = 'icon') => {\n const patternName = /id=\"(.*?)\"/\n const patternSet = /^(\\w+)-/\n const symbols = SYMBOLS\n\n return symbols.find((symbol) => {\n const names = patternName.exec(symbol)\n const fullName = names[1]\n const sets = patternSet.exec(fullName)\n const setName = sets[1]\n const iconName =\n iconSet === 'icon' ? `${iconSet}-${name}` : `${iconSet}-icon-${name}`\n\n return setName === iconSet && fullName === iconName\n })\n}\n\nexport default getSymbol\n","import add from './add'\nimport getSymbols from './getSymbols'\n\n/**\n * 绘制 SVG 图标集\n * ========================================================================\n * @method paint\n * @param {String|Array} symbol\n */\nconst paint = (symbol = '') => {\n const $body = document.body\n let $icons = document.querySelector('#outline-icons')\n let symbols = []\n\n add(symbol)\n symbols = getSymbols()\n\n if ($icons) {\n $icons.innerHTML = symbols.join('')\n } else {\n $icons = document.createElement('div')\n $icons.innerHTML =\n ``\n $body.insertBefore($icons.firstChild, $body.firstChild)\n }\n}\n\nexport default paint\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport SYMBOLS from './symbols'\n\n/**\n * @method add\n * @param {Array|String} symbols\n * @return {Boolean}\n */\nconst add = (symbols) => {\n if (!symbols) {\n return false\n }\n\n if (isArray(symbols) && symbols.length > 0) {\n symbols.forEach((symbol) => {\n /* istanbul ignore else */\n if (SYMBOLS.indexOf(symbol) === -1 && isString(symbol)) {\n SYMBOLS.push(symbol)\n }\n })\n } else {\n /* istanbul ignore else */\n if (isString(symbols)) {\n SYMBOLS.push(symbols)\n }\n }\n}\n\nexport default add\n","import isString from '../types/isString'\n\n/**\n * 清楚字符串起始位置所有的空格\n * ========================================================================\n * @method trim\n * @param {string} str\n * @returns {string|Boolean}\n */\nconst trim = (str) => {\n if (!isString(str)) {\n return false\n }\n return str.replace(/(^\\s+)|(\\s+$)/g, '')\n}\n\nexport default trim\n","import isObject from './isObject'\r\nimport isElement from './isElement'\r\nimport isHTMLCollection from './isHTMLCollection'\r\nimport isFragment from './isFragment'\r\nimport isTextNode from './isTextNode'\r\n\r\nconst isDOM = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (isElement(el) || isHTMLCollection(el) || isFragment(el) || isTextNode(el))\r\n )\r\n}\r\n\r\nexport default isDOM\r\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isHTMLCollection = (el) => {\r\n return !!(isObject(el) && toString(el) === '[object NodeList]')\r\n}\r\n\r\nexport default isHTMLCollection\r\n","import toString from '../lang/toString'\nimport isObject from './isObject'\n\nconst isFragment = (fragment) => {\n return !!(\n isObject(fragment) && toString(fragment) === '[object DocumentFragment]'\n )\n}\n\nexport default isFragment\n","import toString from '../lang/toString'\r\nimport isObject from './isObject'\r\n\r\nconst isTextNode = (el) => {\r\n return !!(\r\n isObject(el) &&\r\n (toString(el) === '[object Text]' || (el.tagName && el.nodeType === 3))\r\n )\r\n}\r\n\r\nexport default isTextNode\r\n","/**\n * 给 DOM 节点设置属性/值\n * ========================================================================\n * @method setAttribute\n * @param {HTMLElement} el - DOM 节点\n * @param {String} attr - 属性名称\n * @param {String|Number|Boolean} value - 属性值\n */\nconst setAttribute = (el, attr, value) => {\n let tagName = el.tagName.toLowerCase()\n\n switch (attr) {\n case 'style':\n el.style.cssText = value\n break\n case 'value':\n if (tagName === 'input' || tagName === 'textarea') {\n el.value = value\n } else {\n el.setAttribute(attr, value)\n }\n break\n case 'className':\n el.className = value\n break\n default:\n el.setAttribute(attr, value)\n break\n }\n}\n\nexport default setAttribute\n","import hasOwn from '../lang/hasOwn'\nimport isObject from '../types/isObject'\nimport isString from '../types/isString'\nimport isArray from '../types/isArray'\nimport isDOM from '../types/isDOM'\nimport setAttribute from './setAttribute'\n\n/**\n * 创建 DOM 节点,并添加属性和子节点\n * ========================================================================\n * @method createElement\n * @param {String} tagName - 标签名称\n * @param {Object|Array} attrs - 属性对象或者子节点\n * @param {Array} [children] - 子节点数组\n * @returns {HTMLElement}\n */\nconst createElement = (tagName, attrs, children) => {\n const $fragment = document.createDocumentFragment()\n const $el = document.createElement(tagName)\n const isValidChild = (child) => {\n return isDOM(child) || isString(child)\n }\n const append = (child) => {\n let $child\n\n if (!isValidChild(child)) {\n return false\n }\n\n if (isDOM(child)) {\n $child = child\n } else if (isString(child)) {\n $child = document.createTextNode(child)\n }\n\n $fragment.appendChild($child)\n }\n\n if (isObject(attrs)) {\n Object.keys(attrs).forEach((attr) => {\n if (hasOwn(attrs, attr)) {\n setAttribute($el, attr, attrs[attr])\n }\n })\n } else if (isArray(attrs) && attrs.every((attr) => isValidChild(attr))) {\n attrs.forEach((child) => {\n append(child)\n })\n }\n\n if (isArray(children)) {\n children.forEach((child) => {\n append(child)\n })\n } else {\n append(children)\n }\n\n $el.appendChild($fragment)\n\n return $el\n}\n\nexport default createElement\n","import isString from './isString'\n\nconst isSVG = (str) => {\n const declaration = '(?:<\\\\?xml[^>]*>\\\\s*)?'\n const doctype =\n '(?:<\\\\!doctype svg[^>]*\\\\s*(?:\\\\[?(?:\\\\s*]*>\\\\s*)*\\\\]?)*[^>]*>\\\\s*)?'\n const content = ']*>[^]*<\\\\/svg>\\\\s*$'\n const svg = `^\\\\s*${declaration}${doctype}${content}\\\\s*$`\n const pattern = new RegExp(svg, 'i')\n\n return isString(str) && pattern.test(str)\n}\n\nexport default isSVG\n","import createElement from './createElement'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method icon\n * @alias createElement\n * @see createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst icon = (name, options = {}) => {\n return createElement(name, options)\n}\n\nexport default icon\n","import isArray from '../types/isArray'\nimport isString from '../types/isString'\nimport isSVG from '../types/isSVG'\n\n/**\n * 创建 SVG 图标 DOM 元素\n * ========================================================================\n * @method createElement\n * @param {String} name\n * @param {Object} [options]\n * @param {Number|Array} [options.size]\n * @param {String} [options.color]\n * @param {String} [options.iconSet]\n * @returns {HTMLElement}\n */\nconst createElement = (name, options = {}) => {\n const size = options.size || 0\n const color = options.color || ''\n const iconSet = options.iconSet || ''\n const width = isArray(size) ? size[0] : size\n const height = isArray(size) ? size[1] : size\n const defaultRules = size ? `width:${width}px;height:${height}px;` : ''\n const cssRules = color ? defaultRules + `color:${color}` : defaultRules\n const $icon = document.createElement('i')\n let binds = ''\n let svg = ''\n let $svg\n\n if (!isString(name)) {\n return null\n }\n\n if (isSVG(name)) {\n svg = name\n } else {\n binds =\n iconSet && iconSet !== 'icon'\n ? `xlink:href=\"#${iconSet}-icon-${name}\"`\n : `xlink:href=\"#icon-${name}\"`\n svg =\n `` +\n `` +\n ``\n }\n\n $icon.className = 'outline-icon'\n $icon.innerHTML = svg\n\n if (isSVG(name)) {\n $svg = $icon.querySelector('svg')\n $svg.setAttribute('aria-hidden', 'true')\n $svg.setAttribute('xmlns', 'http://www.w3.org/2000/svg')\n $svg.setAttribute('class', 'outline-icon__svg')\n $svg.setAttribute('width', '200')\n $svg.setAttribute('height', '200')\n $svg.style = cssRules\n }\n\n return $icon\n}\n\nexport default createElement\n","import isElement from '../types/isElement'\n/**\n * 检测 DOM 节点是否包含名为 className 的样式\n * ========================================================================\n * @method hasClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst hasClass = (el, className) => {\n const pattern = new RegExp('(\\\\s|^)' + className + '(\\\\s|$)')\n let allClass\n let classList\n\n if (!isElement(el)) {\n return false\n }\n\n allClass = el.className\n\n if (!allClass) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.contains) {\n return el.classList.contains(className)\n }\n\n return !!pattern.exec(allClass)\n}\n\nexport default hasClass\n","import trim from '../lang/trim'\nimport hasClass from './hasClass'\n\n/**\n * 移除 DOM 节点的 className 样式\n * ========================================================================\n * @method removeClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst removeClass = (el, className) => {\n let allClass = el.className\n let classList\n\n if (!allClass || !hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.remove) {\n classList.remove(className)\n } else {\n allClass = trim(allClass.replace(className, ''))\n el.className = allClass\n }\n}\n\nexport default removeClass\n","import removeClass from './utils/dom/removeClass'\nimport isEmpty from './utils/types/isEmpty'\nimport trim from './utils/lang/trim'\n\nconst _resetHeading = ($heading, hasAnchor = true, isAtStart = true) => {\n const CLS_HEADING = 'outline-heading'\n const text = $heading.innerHTML\n const pattern = /^\\d+(\\.?\\d+)*\\s?/gi\n let $anchor\n\n $heading.innerHTML = text.replace(pattern, '')\n $heading.removeAttribute('id')\n $heading.removeAttribute('data-id')\n\n removeClass($heading, CLS_HEADING)\n\n if (!hasAnchor) {\n return false\n }\n\n $anchor = $heading.querySelector(`.${CLS_HEADING}__anchor`)\n\n if (isAtStart) {\n removeClass($heading, `${CLS_HEADING}_start`)\n }\n\n if (isEmpty(trim($heading.className))) {\n $heading.removeAttribute('class')\n }\n\n $heading.removeChild($anchor)\n}\n\nexport default _resetHeading\n","import isString from './isString'\n/**\n * 检测数据是否为空字符串\n * ========================================================================\n * @method isEmpty\n * @param {String} str\n * @returns {boolean}\n */\nconst isEmpty = (str) => {\n return isString(str) && str === ''\n}\n\nexport default isEmpty\n","import trim from './utils/lang/trim'\nimport stripTags from './utils/lang/stripTags'\n\nimport _getChapterParentIdByDiffer from './_getChapterParentIdByDiffer'\nimport _getChaptersWithCode from './_getChaptersWithCode'\n\nconst getChapters = (headings, showCode = true) => {\n let previous = 1\n let level = 0\n const chapters = []\n\n headings.forEach((heading, i) => {\n const headingLevel = heading.tagName.replace(/h/i, '')\n let current = parseInt(headingLevel, 10)\n let pid = -1\n\n // 场景1:当前标题是前一个标题的子标题\n // 当前标题的(标题标签)序号 > 前一个标题的序号:两个相连的标题是父标题 -> 子标题关系;\n // h2 (前一个标题)\n // h3 (当前标题)\n if (current > previous) {\n level += 1\n\n // 第一层级的 pid 是 -1\n if (level === 1) {\n pid = -1\n } else {\n pid = i - 1\n }\n }\n // 场景2:当前标题和前一个标题层级相同\n // 当前标题的(标题标签)序号 = 前一个标题的序号\n // h2 (前一个标题)\n // h2 (当前标题)\n // 当前标题的(标题标签)序号 < 前一个标题的序号,并且当前标题序号 > 当前的级别\n // h2\n // h4 (前一个标题)\n // h3 (当前标题:这种情况我们还是任务 h3 是 h2 的下一级章节)\n else if (current === previous || (current < previous && current > level)) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n pid = -1\n } else {\n pid = chapters[i - 1].pid\n }\n }\n // 场景3:当前标题比前一个标题层级高\n else if (current <= level) {\n // H1 的层级肯定是 1\n if (current === 1) {\n level = 1\n } else {\n level = level - (previous - current)\n\n if (level <= 1) {\n level = 1\n }\n }\n\n // 第一级的标题\n if (level === 1) {\n pid = -1\n } else {\n // 通过当前标题和前一个标题之间的等级差,获得当前标题的父标题ID\n pid = _getChapterParentIdByDiffer(chapters, previous - current, i)\n }\n }\n\n previous = current\n\n chapters.push({\n id: i,\n pid: pid,\n level: level,\n rel: `heading-${i}`,\n text: stripTags(trim(heading.innerHTML))\n })\n })\n\n return showCode ? _getChaptersWithCode(chapters) : chapters\n}\n\nexport default getChapters\n","import isString from '../types/isString'\n\n/**\n * 过滤所有 HTML 标签\n * ========================================================================\n * @method stripTags\n * @param {string} str\n * @returns {string}\n */\nconst stripTags = (str) => {\n if (!isString(str)) {\n return ''\n }\n return str.replace(/<\\/?[^>]+(>|$)/g, '')\n}\n\nexport default stripTags\n","const _getChapterParentIdByDiffer = (chapters, differ, index) => {\n let previous = chapters[index - 1]\n let pid\n let i\n\n for (i = 0; i < differ; i += 1) {\n pid = previous.pid\n previous = chapters[pid]\n }\n\n pid = previous.pid\n\n return pid\n}\n\nexport default _getChapterParentIdByDiffer\n","const _getChaptersWithCode = (chapters) => {\n const groups = {}\n const cb = (o) => {\n return [o.pid]\n }\n\n chapters.forEach((o) => {\n const group = JSON.stringify(cb(o))\n\n groups[group] = groups[group] || []\n groups[group].push(o)\n\n o.index = groups[group].length\n if (o.pid === -1) {\n o.code = String(o.index)\n }\n })\n\n Object.keys(groups).forEach((group) => {\n groups[group].forEach((c) => {\n const subjects = chapters.filter((b) => b.pid === c.id)\n subjects.forEach((o) => {\n o.code = c.code + '.' + o.index\n })\n })\n })\n\n return chapters\n}\n\nexport default _getChaptersWithCode\n","import Base from './base'\n\n// 在文章的标题生成 anchor 链接\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport toTree from './utils/lang/toTree'\nimport later from './utils/lang/later'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport offsetTop from './utils/dom/offsetTop'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _updateHeading from './_updateHeading'\nimport _resetHeading from './_resetHeading'\nimport getChapters from './getChapters'\n\nclass Anchors extends Base {\n constructor(options) {\n super()\n\n this.attrs = Anchors.DEFAULTS\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n\n this.chapters = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let scrollElement\n let selector\n let $articleElement\n let articleElement\n\n this.attr(options)\n articleElement = this.attr('articleElement')\n scrollElement = this.attr('scrollElement')\n selector = this.attr('selector')\n created = this.attr('created')\n\n if (isString(articleElement)) {\n $articleElement = document.querySelector(articleElement)\n } else if (isElement(articleElement)) {\n $articleElement = articleElement\n }\n\n if (!$articleElement) {\n return this\n }\n\n this.$articleElement = $articleElement\n this.$scrollElement = _getScrollElement(scrollElement)\n this.$headings = [...$articleElement.querySelectorAll(selector)]\n\n if (this.$headings.length < 1) {\n return this\n }\n\n this.chapters = getChapters(this.$headings)\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n getChapters(isTreeStructured = false) {\n const chapters = this.chapters\n return isTreeStructured ? toTree(chapters, 'id', 'pid') : chapters\n }\n\n count() {\n return this.chapters.length\n }\n\n render() {\n const mounted = this.attr('mounted')\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const $headings = this.$headings\n const chapters = this.getChapters()\n\n paint()\n\n $headings.forEach(($heading, i) => {\n const chapterCode = chapters[i].code\n _updateHeading($heading, i, {\n hasAnchor,\n isAtStart,\n showCode,\n chapterCode,\n anchorURL\n })\n })\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n destroy() {\n const hasAnchor = this.attr('hasAnchor')\n const isAtStart = this.attr('isAtStart')\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n const $headings = this.$headings\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n $headings.forEach(($heading) => {\n _resetHeading($heading, hasAnchor, isAtStart)\n })\n\n this.attr(Anchors.DEFAULTS)\n this.$articleElement = null\n this.$scrollElement = null\n this.$headings = []\n this.chapters = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n onAnchorTrigger(evt) {\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const $heading = $anchor.parentNode\n const top = offsetTop($heading) - (stickyHeight + 10)\n const $scrollElement = this.$scrollElement\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'anchor')\n }\n\n later(() => {\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.scrollTo(top, after)\n\n if (!anchorURL) {\n stop(evt)\n }\n\n return this\n }\n\n addListeners() {\n const $articleElement = this.$articleElement\n\n on(\n $articleElement,\n '.outline-heading__anchor',\n 'click',\n this.onAnchorTrigger,\n this,\n true\n )\n\n return this\n }\n\n removeListeners() {\n const $articleElement = this.$articleElement\n\n off($articleElement, 'click', this.onAnchorTrigger)\n\n return this\n }\n}\n\nAnchors.DEFAULTS = {\n scrollElement: 'html,body',\n articleElement: '#article',\n selector: 'h1,h2,h3,h4,h5,h6',\n stickyHeight: 0,\n anchorURL: '',\n hasAnchor: true,\n isAtStart: true,\n showCode: false,\n created: null,\n mounted: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Anchors\n","const toTree = (list, nodeKey, parentKey) => {\r\n const map = {}\r\n const roots = []\r\n\r\n list.forEach((item, i) => {\r\n // initialize the map\r\n map[item[nodeKey]] = i\r\n // initialize the children\r\n item.children = []\r\n })\r\n\r\n list.forEach((item) => {\r\n const node = list[map[item[parentKey]]]\r\n\r\n if (item[parentKey] !== -1) {\r\n // if you have dangling branches check that map[node.parentId] exists\r\n node.children.push(item)\r\n } else {\r\n roots.push(item)\r\n }\r\n })\r\n\r\n return roots\r\n}\r\n\r\nexport default toTree\r\n","import trim from './utils/lang/trim'\nimport createElement from './utils/dom/createElement'\nimport setAttribute from './utils/dom/setAttribute'\n\nimport icon from './utils/icons/icon'\n\nconst _updateHeading = ($heading, i, options) => {\n const $fragment = document.createDocumentFragment()\n const CLS_HEADING = 'outline-heading'\n const hasAnchor = options.hasAnchor || true\n const isAtStart = options.isAtStart || true\n const showCode = options.showCode || false\n const chapterCode = options.chapterCode || ''\n const anchorURL = options.anchorURL || ''\n const headingId = `heading-${i}`\n const attrs = {\n id: headingId,\n className: isAtStart ? `${CLS_HEADING} ${CLS_HEADING}_start` : CLS_HEADING,\n 'data-id': i\n }\n const keys = Object.keys(attrs)\n const text = trim($heading.innerHTML)\n let $anchor\n let $icon\n\n keys.forEach((prop) => {\n setAttribute($heading, prop, attrs[prop])\n })\n\n if (showCode) {\n $heading.innerHTML = chapterCode + ' ' + text\n }\n\n if (!hasAnchor) {\n return false\n }\n\n $icon = icon('hash', { iconSet: 'outline' })\n $anchor = createElement(\n 'a',\n {\n id: `anchor-${i}`,\n className: `${CLS_HEADING}__anchor anchor-${i}`,\n href: anchorURL || `#${headingId}`,\n target: anchorURL ? '_blank' : 'self',\n 'data-id': i\n },\n [$icon]\n )\n $fragment.appendChild($anchor)\n $heading.appendChild($fragment)\n}\n\nexport default _updateHeading\n","import hasClass from './hasClass'\n\n/**\n * 给 DOM 节点添加名为 className 的样式\n * ========================================================================\n * @method addClass\n * @param {HTMLElement} el - DOM 节点\n * @param {String} className - 样式名称\n * @returns {Boolean}\n */\nconst addClass = (el, className) => {\n let classList\n let allClass\n\n if (hasClass(el, className)) {\n return false\n }\n\n classList = el.classList\n\n if (classList?.add) {\n classList.add(className)\n } else {\n allClass = el.className\n allClass += allClass.length > 0 ? ' ' + className : className\n el.className = allClass\n }\n}\n\nexport default addClass\n","const setProperty = (prop, value) => {\r\n const documentElement = document.documentElement\r\n documentElement.style.setProperty(prop, value)\r\n}\r\n\r\nexport default setProperty\r\n","import setProperty from './utils/dom/setProperty'\n\nlet index = 2000\n\nconst zIndex = (idx) => {\n if (idx) {\n index = idx\n } else {\n index += 1\n }\n\n setProperty('--outline-zIndex', `${index}`)\n\n return index\n}\n\nexport default zIndex\n","import Base from './base'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport addClass from './utils/dom/addClass'\nimport removeClass from './utils/dom/removeClass'\nimport createElement from './utils/dom/createElement'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\n\nimport paint from './utils/icons/paint'\nimport icon from './utils/icons/icon'\nimport zIndex from './zIndex'\n\nclass Drawer extends Base {\n constructor(options) {\n super()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = true\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n this.zIndex = 0\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n\n this.title = this.attr('title')\n created = this.attr('created')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n return this\n }\n\n setTitle(title) {\n this.attr('title', title)\n this.title = title\n this.$title.innerHTML = title\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n render() {\n const mounted = this.attr('mounted')\n const size = this.attr('size')\n const placement = this.attr('placement')\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const hasOffset = this.attr('hasOffset')\n const hasPadding = this.attr('hasPadding')\n const autoHeight = this.attr('autoHeight')\n const customClass = this.attr('customClass')\n let $el\n let $modal\n let $header\n let $title\n let $close\n let $main\n let $footer\n let $overlay\n\n paint()\n this.zIndex = zIndex()\n\n $title = createElement(\n 'h2',\n {\n className: 'outline-drawer__title'\n },\n [this.title]\n )\n this.$title = $title\n\n if (hasClose) {\n $close = createElement(\n 'div',\n {\n className: 'outline-drawer__close'\n },\n [icon('close', { size: 20 })]\n )\n this.$close = $close\n }\n\n $header = createElement(\n 'header',\n {\n className: 'outline-drawer__header'\n },\n [$title, $close]\n )\n this.$header = $header\n\n $main = createElement(\n 'div',\n {\n className: 'outline-drawer__main'\n },\n ['']\n )\n this.$main = $main\n\n if (!hasPadding) {\n addClass($main, 'outline-drawer_full')\n }\n\n $footer = createElement(\n 'footer',\n {\n className: 'outline-drawer__footer'\n },\n ['']\n )\n this.$footer = $footer\n\n $modal = createElement(\n 'div',\n {\n className: `outline-drawer__modal outline-drawer_${placement} outline-drawer_${size} outline-drawer_closed`\n },\n [$header, $main, $footer]\n )\n this.$modal = $modal\n\n if (hasOffset) {\n addClass($modal, 'outline-drawer_offset')\n }\n\n if (autoHeight) {\n addClass($modal, 'outline-drawer_auto')\n }\n\n if (customClass) {\n addClass($modal, customClass)\n }\n\n if (hasOverlay) {\n $overlay = createElement(\n 'div',\n {\n className: 'outline-drawer__overlay'\n },\n ['']\n )\n this.$overlay = $overlay\n }\n\n $el = createElement(\n 'div',\n {\n className: `outline-drawer`\n },\n [$modal, $overlay]\n )\n this.$el = $el\n document.body.appendChild($el)\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n open() {\n const opened = this.attr('afterOpened')\n const $modal = this.$modal\n\n addClass(this.$el, 'outline-drawer_opened')\n removeClass($modal, 'outline-drawer_closed')\n addClass($modal, 'outline-drawer_opened')\n\n later(() => {\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n })\n\n return this\n }\n\n close() {\n const closed = this.attr('afterClosed')\n const $modal = this.$modal\n\n removeClass($modal, 'outline-drawer_opened')\n addClass($modal, 'outline-drawer_closed')\n\n later(() => {\n removeClass(this.$el, 'outline-drawer_opened')\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n })\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const closed = this.isClosed()\n\n if (closed) {\n this.open()\n } else {\n this.close()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n afterToggle.call(this, closed)\n })\n }\n\n return this\n }\n\n destroy() {\n const afterDestroy = this.attr('afterDestroy')\n const beforeDestroy = this.attr('beforeDestroy')\n let index = this.zIndex\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n\n this.attrs = Drawer.DEFAULTS\n this.title = ''\n this.closed = false\n this.$el = null\n this.$modal = null\n this.$header = null\n this.$title = null\n this.$close = null\n this.$main = null\n this.$footer = null\n this.$overlay = null\n\n index -= 1\n zIndex(index)\n this.zIndex = 0\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n addListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (hasClose) {\n on($el, '.outline-drawer__close', 'click', this.onClose, this, true)\n }\n\n if (hasOverlay) {\n on($el, '.outline-drawer__overlay', 'click', this.onClose, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const hasClose = this.attr('hasClose')\n const hasOverlay = this.attr('hasOverlay')\n const $el = this.$el\n\n if (!hasClose && !hasOverlay) {\n return this\n }\n\n off($el, 'click', this.onClose)\n\n return this\n }\n\n onClose() {\n this.close()\n return this\n }\n}\n\nDrawer.DEFAULTS = {\n placement: 'rtl',\n title: '标题',\n size: 'regular',\n hasClose: true,\n hasOverlay: true,\n hasOffset: false,\n hasPadding: true,\n autoHeight: true,\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterToggle: null\n}\n\nexport default Drawer\n","import isFunction from '../types/isFunction'\nimport off from './off'\n\nimport { CAPTURE_EVENTS } from './enum'\n\n/**\n * 绑定事件\n * ========================================================================\n * @method at\n * @param {HTMLElement|String|Object} el - (必须)绑定代理事件的 DOM 节点\n * @param {String|Function} type - (必须)事件类型或者事件处理器回调函数\n * @param {Function|Object} fn - (必须) 事件处理器回调函数或者传递给事件处理器回调函数的数据对象\n * @param {Object|Boolean} [data] - (可选)传递给事件处理器回调函数的数据对象或者事件处理器回调函数的 this 上下文指向,\n * @param {Object|Boolean} [context] - (可选)事件处理器回调函数的 this 上下文指向,或者是否仅触发一次\n * 当设置为 true 时,则事件处理器回调函数的 this 上下文指向为 data 对象\n * @param {Boolean} once - (可选)是否仅触发一次\n */\nconst at = (el, type, fn, data, context, once = false) => {\n // CAPTURE_EVENTS 中的特殊事件,采用事件捕获模型\n const capture = CAPTURE_EVENTS.indexOf(type) > -1\n const listener = function (evt) {\n let overrideContext = context || el\n\n // 当设置为 true 时,则事件处理器回调函数的\n // this 上下文指向为 data 对象\n if (context === true) {\n overrideContext = data\n }\n\n // 仅触发一次\n /* istanbul ignore else */\n if (once === true) {\n off(el, type, listener)\n }\n\n fn.call(overrideContext, evt, data)\n }\n\n if (!isFunction(fn)) {\n return false\n }\n\n if (!el._listeners) {\n el._listeners = []\n }\n\n // 缓存 options 元素绑定的事件处理器\n el._listeners.push({\n el,\n type,\n fn: listener,\n data,\n context,\n capture\n })\n\n // 缓存包装后的事件处理器\n fn._delegateListener = listener\n\n el.addEventListener(type, listener, capture)\n}\n\nexport default at\n","/**\r\n * 获取HTML元素的某个CSS样式值\r\n * ====================================================\r\n * @param el\r\n * @param ruleName\r\n * @returns {*}\r\n */\r\nconst getStyle = (el, ruleName) => {\r\n return getComputedStyle(el)[ruleName]\r\n}\r\n\r\nexport default getStyle\r\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isElement from './utils/types/isElement'\nimport later from './utils/lang/later'\nimport at from './utils/event/at'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport stop from './utils/event/stop'\nimport createElement from './utils/dom/createElement'\nimport scrollTo from './utils/dom/scrollTo'\nimport addClass from './utils/dom/addClass'\nimport intersection from './utils/dom/intersection'\nimport removeClass from './utils/dom/removeClass'\nimport offsetTop from './utils/dom/offsetTop'\nimport getStyle from './utils/dom/getStyle'\nimport setProperty from './utils/dom/setProperty'\nimport publish from './utils/observer/emit'\n\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport _paintChapters from './_paintChapters'\n\nclass Chapters extends Base {\n constructor(options) {\n super()\n\n this.attrs = Chapters.DEFAULTS\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.closed = false\n this.active = 0\n this.offsetTop = 0\n this.offsetWidth = 0\n this.$active = null\n this.scrollTimer = null\n this.resizeTimer = null\n this.playing = false\n this.Observer = null\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n let parentElement\n let scrollElement\n let $parent\n\n this.attr(options)\n created = this.attr('created')\n parentElement = this.attr('parentElement')\n scrollElement = this.attr('scrollElement')\n\n if (isString(parentElement)) {\n $parent = document.querySelector(parentElement)\n } else if (isElement(parentElement)) {\n $parent = parentElement\n }\n this.$parentElement = $parent\n this.$scrollElement = _getScrollElement(scrollElement)\n\n this.chapters = this.attr('chapters')\n this.closed = this.attr('closed')\n this.active = this.attr('active')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n if (this.chapters.length < 1) {\n return this\n }\n\n this.render().addListeners()\n\n this.$active = document.querySelector(`#chapter-${this.active}`)\n\n return this\n }\n\n isClosed() {\n return this.closed\n }\n\n isSticky() {\n const position = this.attr('position')\n return position === 'sticky'\n }\n\n isFixed() {\n const position = this.attr('position')\n return position === 'fixed'\n }\n\n isInside() {\n return this.isFixed() || this.isSticky()\n }\n\n isOutside() {\n return !this.isInside()\n }\n\n _paintEdge() {\n const $fragment = document.createDocumentFragment()\n const STICKY = 'outline-chapters_sticky'\n const HIDDEN = 'outline-chapters_hidden'\n const title = this.attr('title')\n const customClass = this.attr('customClass')\n const $parentElement = this.$parentElement\n const contents = []\n let $title = null\n let $el\n let $main\n let $list\n let $placeholder\n\n if (!$parentElement) {\n return this\n }\n\n if (this.isInside()) {\n $title = createElement(\n 'h2',\n {\n className: 'outline-chapters__title'\n },\n [title]\n )\n this.$title = $title\n contents.push($title)\n }\n\n $list = createElement(\n 'ul',\n {\n // 为优化性能,添加了 _fixed 和 _hidden\n // fixed 为了让 $list 脱离流布局\n // hidden 让 $list 不可见\n className: `outline-chapters__list`\n },\n ['']\n )\n this.$list = $list\n\n $placeholder = createElement(\n 'div',\n {\n className: 'outline-chapters__placeholder'\n },\n ['']\n )\n this.$placeholder = $placeholder\n\n $main = createElement(\n 'div',\n {\n className: 'outline-chapters__main'\n },\n [$list, $placeholder]\n )\n this.$main = $main\n contents.push($main)\n\n $el = createElement(\n 'nav',\n {\n id: 'outline-chapters',\n className: `outline-chapters ${HIDDEN}`\n },\n contents\n )\n this.$el = $el\n\n if (this.isSticky()) {\n this.calculateStickyHeight()\n addClass($el, STICKY)\n }\n\n if (customClass) {\n addClass($el, customClass)\n }\n $fragment.appendChild($el)\n $parentElement.appendChild($fragment)\n\n return this\n }\n\n render() {\n const HIDDEN = 'outline-chapters_hidden'\n const showCode = this.attr('showCode')\n const mounted = this.attr('mounted')\n const $parentElement = this.$parentElement\n const chapters = this.chapters\n let $el\n let $list\n\n if (!$parentElement || chapters.length < 1) {\n return this\n }\n\n this._paintEdge()\n\n $el = this.$el\n $list = this.$list\n _paintChapters($list, chapters, showCode)\n removeClass($el, HIDDEN)\n this.positionPlaceholder(this.active)\n\n this.offsetTop = offsetTop($el)\n this.offsetWidth = $el.offsetWidth\n\n if (this.isFixed()) {\n this.sticky()\n setProperty('--outline-chapters-width', `${this.offsetWidth}px`)\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n this.onObserver()\n\n return this\n }\n\n positionPlaceholder(index) {\n const $main = this.$main\n const $list = this.$list\n const $placeholder = this.$placeholder\n const $anchor = $list.querySelector('.outline-chapters__anchor')\n const mainPaddingTop = parseInt(getStyle($main, 'padding-top'), 10)\n const mainBorderTop = parseInt(getStyle($main, 'border-top-width'), 10)\n const placeholderPaddingTop = parseInt(getStyle($list, 'padding-top'), 10)\n const placeholderMarginTop = parseInt(getStyle($list, 'margin-top'), 10)\n const placeholderBorderTop = parseInt(\n getStyle($list, 'border-top-width'),\n 10\n )\n let height = $anchor.offsetHeight\n let offsetTop = 0\n let top\n\n if (mainPaddingTop) {\n offsetTop += mainPaddingTop\n }\n\n if (placeholderPaddingTop) {\n offsetTop += placeholderPaddingTop\n }\n\n if (placeholderMarginTop) {\n offsetTop += placeholderMarginTop\n }\n\n if (mainBorderTop) {\n offsetTop += mainBorderTop\n }\n\n if (placeholderBorderTop) {\n offsetTop += placeholderBorderTop\n }\n\n top = height * index\n // top:calc(${offsetTop}px + ${top}px);\n $placeholder.style.cssText = `transform: translateY(${\n offsetTop + top\n }px);height:${height}px;`\n\n return this\n }\n\n highlight(id) {\n const $anchor = this.$el.querySelector(`#chapter__anchor-${id}`)\n const HIGHLIGHT = 'outline-chapters_active'\n\n if (!$anchor) {\n return this\n }\n\n if (this.$active) {\n removeClass(this.$active, HIGHLIGHT)\n }\n\n this.active = parseInt($anchor.getAttribute('data-id'), 10)\n this.$active = $anchor\n addClass(this.$active, HIGHLIGHT)\n\n this.positionPlaceholder(this.active)\n\n return this\n }\n\n sticky() {\n const afterSticky = this.attr('afterSticky')\n const FIXED = 'outline-chapters_fixed'\n const $el = this.$el\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (!this.isFixed()) {\n return this\n }\n\n isStickying = scrollTop >= top\n\n if (isStickying) {\n addClass($el, FIXED)\n } else {\n removeClass($el, FIXED)\n }\n\n if (isFunction(afterSticky)) {\n afterSticky.call(this, this.isClosed(), isStickying)\n }\n\n return this\n }\n\n calculateStickyHeight() {\n const documentElement = document.documentElement\n const height = Math.max(\n documentElement.clientHeight || 0,\n window.innerHeight || 0\n )\n setProperty('--outline-sticky-height', `${height}px`)\n return this\n }\n\n scrollTo(top, after) {\n const el = this.$scrollElement\n\n scrollTo(el, top, after)\n\n return this\n }\n\n show() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const opened = this.attr('afterOpened')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n removeClass($parent, HIDDEN)\n removeClass($el, HIDDEN)\n later(() => {\n removeClass($parent, FOLDED)\n removeClass($el, FOLDED)\n }, 30)\n } else {\n removeClass($el, HIDDEN)\n }\n this.closed = false\n\n if (isFunction(opened)) {\n opened.call(this)\n }\n\n return this\n }\n\n hide() {\n const FOLDED = 'outline-chapters_folded'\n const HIDDEN = 'outline-chapters_hidden'\n const closed = this.attr('afterClosed')\n const $el = this.$el\n const $parent = this.$parentElement\n\n if (this.isInside()) {\n addClass($parent, FOLDED)\n addClass($el, FOLDED)\n later(() => {\n addClass($parent, HIDDEN)\n addClass($el, HIDDEN)\n })\n } else {\n addClass($el, HIDDEN)\n }\n this.closed = true\n\n if (isFunction(closed)) {\n closed.call(this)\n }\n\n return this\n }\n\n toggle() {\n const afterToggle = this.attr('afterToggle')\n const top = this.offsetTop\n const scrollTop = this.$scrollElement.scrollTop\n let isStickying\n\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n if (isFunction(afterToggle)) {\n later(() => {\n isStickying = scrollTop >= top\n afterToggle.call(this, this.isClosed(), isStickying)\n })\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n this.$parentElement.removeChild(this.$el)\n\n this.attr(Chapters.DEFAULTS)\n this.$el = null\n this.$title = null\n this.$main = null\n this.$list = null\n this.$placeholder = null\n this.$parentElement = null\n this.$scrollElement = null\n this.chapters = []\n this.active = 0\n this.offsetTop = 0\n this.$active = null\n this.closed = false\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n this.scrollTimer = null\n }\n\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n this.resizeTimer = null\n }\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n if (this.Observer) {\n this.Observer = null\n }\n\n return this\n }\n\n onObserver() {\n const selector = this.attr('selector')\n let timer = null\n\n this.Observer = intersection(\n ($heading) => {\n const id = $heading.getAttribute('data-id')\n\n if (this.playing) {\n return false\n }\n\n if (timer) {\n clearTimeout(timer)\n }\n\n timer = later(() => {\n this.highlight(id)\n }, 100)\n },\n {\n selector,\n context: this\n }\n )\n\n return this\n }\n\n onSelect(evt) {\n const stickyHeight = this.attr('stickyHeight')\n const $anchor = evt.delegateTarget\n const id = $anchor.getAttribute('data-id')\n const headingId = $anchor.href.split('#')[1]\n const $heading = document.querySelector(`#${headingId}`)\n const top = offsetTop($heading) - (stickyHeight + 10)\n const min = 0\n const max = this.$scrollElement.scrollHeight\n const afterScroll = this.attr('afterScroll')\n const after = () => {\n if (isFunction(afterScroll)) {\n afterScroll.call(this, 'chapter')\n }\n\n later(() => {\n this.playing = false\n publish('toolbar:update', {\n top,\n min,\n max\n })\n })\n }\n\n this.playing = true\n if (this.isFixed()) {\n this.sticky()\n later(() => {\n this.scrollTo(top, after)\n this.highlight(id)\n }, 10)\n } else {\n this.scrollTo(top, after)\n this.highlight(id)\n }\n\n stop(evt)\n\n return this\n }\n\n onScroll() {\n const $scrollElement = this.$scrollElement\n\n if (this.scrollTimer) {\n clearTimeout(this.scrollTimer)\n }\n\n this.scrollTimer = later(() => {\n const top = $scrollElement.scrollTop\n const min = 0\n const max = $scrollElement.scrollHeight - $scrollElement.clientHeight\n\n if (this.isFixed()) {\n this.sticky()\n }\n\n publish('toolbar:update', {\n top,\n min,\n max\n })\n }, 100)\n\n return this\n }\n\n onResize() {\n if (this.resizeTimer) {\n clearTimeout(this.resizeTimer)\n }\n\n this.resizeTimer = later(() => {\n this.calculateStickyHeight()\n })\n\n return this\n }\n\n addListeners() {\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n on($el, '.outline-chapters__anchor', 'click', this.onSelect, this, true)\n at($element, 'scroll', this.onScroll, this, true)\n if (this.isSticky()) {\n at($element, 'resize', this.onResize, this, true)\n }\n\n return this\n }\n\n removeListeners() {\n const selector = this.attr('selector')\n const $el = this.$el\n const $scrollElement = this.$scrollElement\n const tagName = $scrollElement.tagName.toLowerCase()\n let $element = $scrollElement\n\n if (tagName === 'html' || tagName === 'body') {\n $element = window\n }\n\n off($el, 'click', this.onSelect)\n off($element, 'scroll', this.onScroll)\n\n if (this.isSticky()) {\n at($element, 'resize', this.onResize)\n }\n\n if (this.Observer) {\n document.querySelectorAll(selector).forEach((section) => {\n this.Observer.unobserve(section)\n })\n }\n\n return this\n }\n}\n\nChapters.DEFAULTS = {\n parentElement: '',\n scrollElement: '',\n selector: '.outline-heading',\n active: 0,\n closed: false,\n showCode: true,\n position: 'relative',\n stickyHeight: 0,\n chapters: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterScroll: null,\n beforeDestroy: null,\n afterDestroy: null,\n afterSticky: null\n}\n\nexport default Chapters\n","import createElement from './utils/dom/createElement'\n\nconst _paintChapters = ($list, chapters, showCode = false) => {\n const byId = (id) => document.querySelector(`#${id}`)\n\n chapters.forEach((chapter) => {\n const pid = chapter.pid\n const id = chapter.id\n const rel = chapter.rel\n const $text = createElement(\n 'span',\n {\n className: 'outline-chapters__text'\n },\n [chapter.text]\n )\n const $link = createElement(\n 'a',\n {\n id: `chapter__anchor-${id}`,\n className: 'outline-chapters__anchor',\n href: '#' + rel,\n rel: rel,\n 'data-id': id\n },\n [$text]\n )\n let $code\n let $li\n let $ul\n let $parent\n\n if (showCode) {\n $code = createElement(\n 'span',\n {\n className: 'outline-chapters__code',\n 'data-id': id\n },\n [chapter.code]\n )\n\n $link.insertBefore($code, $link.firstChild)\n }\n\n $li = createElement(\n 'li',\n {\n id: `chapter-${id}`,\n className: 'outline-chapters__item',\n 'data-id': id\n },\n [$link]\n )\n\n if (pid === -1) {\n $list.appendChild($li)\n } else {\n $parent = byId(`chapter-${pid}`)\n $ul = byId(`subject-${pid}`)\n\n if (!$ul) {\n $ul = createElement(\n 'ul',\n {\n id: 'subject-' + pid,\n className: 'outline-chapters__subject'\n },\n [$li]\n )\n\n $parent.appendChild($ul)\n } else {\n $ul.appendChild($li)\n }\n }\n })\n}\n\nexport default _paintChapters\n","import isFunction from '../types/isFunction'\nimport isElement from '../types/isElement'\n\n/**\n * 通用的 IntersectionObserver 观察者处理器\n * ========================================================================\n * @method intersection\n * @param {Function} fn\n * @param {Object} [props]\n * @param {Object|HTMLElement} [props.root]\n * @param {String} [props.selector]\n * @param {Object} [props.context]\n * @param {String} [props.attr]\n * @param {String} [props.rootMargin]\n */\nconst intersection = (fn, props = {}) => {\n const root = props.root || null\n const selector = props.selector || '.outline-heading'\n const context = props.context || null\n const rootMargin = props.rootMargin || '0px 0px -90% 0px'\n const options = {\n rootMargin: rootMargin\n }\n const Observer = new IntersectionObserver((entries) => {\n entries.forEach((entry) => {\n if (entry.intersectionRatio > 0) {\n if (isFunction(fn)) {\n fn.call(context || entry.target, entry.target)\n }\n }\n })\n }, options)\n const $root = isElement(root) ? root : document\n\n if (root) {\n options.root = root\n }\n\n $root.querySelectorAll(selector).forEach((section) => {\n Observer.observe(section)\n })\n\n return Observer\n}\n\nexport default intersection\n","import icon from './utils/icons/icon'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\n\nconst _createButton = (button, rounded = true) => {\n const $icon = icon(button.icon, {\n iconSet: button.iconSet || 'outline',\n color: button.color || '',\n size: button.size\n })\n const $anchor = createElement(\n 'a',\n {\n className: `outline-toolbar__anchor`,\n href: button.link\n },\n [$icon]\n )\n const $button = createElement(\n 'div',\n {\n className: `outline-toolbar__button ${button.name}`\n },\n [button.link ? $anchor : $icon]\n )\n\n addClass($icon, 'outline-toolbar__icon')\n\n if (rounded) {\n addClass($button, 'outline-toolbar_rounded')\n }\n\n if (button.disabled) {\n addClass($button, 'outline-toolbar_disabled')\n }\n\n return $button\n}\n\nexport default _createButton\n","import Base from './base'\n\nimport isString from './utils/types/isString'\nimport isFunction from './utils/types/isFunction'\nimport isObject from './utils/types/isObject'\nimport isArray from './utils/types/isArray'\nimport later from './utils/lang/later'\nimport createElement from './utils/dom/createElement'\nimport addClass from './utils/dom/addClass'\nimport hasClass from './utils/dom/hasClass'\nimport removeClass from './utils/dom/removeClass'\nimport on from './utils/event/on'\nimport off from './utils/event/off'\nimport publish from './utils/observer/emit'\nimport paint from './utils/icons/paint'\n\nimport _createButton from './_createButton'\n\nconst DISABLED = 'outline-toolbar_disabled'\nconst HIDDEN = 'outline-toolbar_hidden'\n\nclass Toolbar extends Base {\n constructor(options) {\n super()\n\n this.attrs = Toolbar.DEFAULTS\n this.$el = null\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n let created\n\n this.attr(options)\n created = this.attr('created')\n this.disabled = this.attr('disabled')\n this.closed = this.attr('closed')\n\n if (isFunction(created)) {\n created.call(this)\n }\n\n this.render().addListeners()\n\n return this\n }\n\n isDisabled(name) {\n const buttons = this.attr('buttons')\n let button\n\n if (name) {\n button = buttons.find((option) => option.name === name)\n\n return button?.disabled\n }\n\n return this.disabled\n }\n\n isClosed() {\n return this.closed\n }\n\n highlight(name) {\n const button = this.buttons.find((item) => item.name === name)\n const ACTIVE = 'outline-toolbar_active'\n let $button\n\n if ($button) {\n return this\n }\n\n $button = button.$el\n\n if (hasClass($button, ACTIVE)) {\n removeClass($button, ACTIVE)\n } else {\n addClass($button, ACTIVE)\n }\n\n return this\n }\n\n render() {\n const mounted = this.attr('mounted')\n const buttons = this.attr('buttons') || []\n const rounded = this.attr('rounded')\n const placement = this.attr('placement')\n const $buttons = document.createDocumentFragment()\n const $fragment = document.createDocumentFragment()\n\n paint()\n\n buttons.forEach((button) => {\n const $button = _createButton(button, rounded)\n\n $buttons.appendChild($button)\n this.buttons.push({\n name: button.name,\n $el: $button\n })\n })\n\n this.$el = createElement(\n 'div',\n {\n id: 'outline-toolbar',\n className: `outline-toolbar outline-toolbar_${placement}`\n },\n [$buttons]\n )\n $fragment.appendChild(this.$el)\n document.body.appendChild($fragment)\n\n if (this.closed) {\n this.hide()\n }\n\n if (this.disabled) {\n this.disable()\n }\n\n if (isFunction(mounted)) {\n mounted.call(this)\n }\n\n return this\n }\n\n add(button) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const action = button.action\n const $fragment = document.createDocumentFragment()\n let type\n\n if (isObject(button)) {\n buttons.push(button)\n $fragment.appendChild(_createButton(button))\n } else if (isArray(button)) {\n button.forEach((item) => {\n $fragment.appendChild(_createButton(item))\n })\n }\n $el.appendChild($fragment)\n\n if (action && isFunction(action.handler)) {\n type = action.type || 'click'\n on($el, `.${button.name}`, type, action.handler)\n }\n\n return this\n }\n\n remove(name) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let index = -1\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((button, i) => {\n if (button.name === name) {\n index = i\n }\n })\n\n if (index > -1) {\n this.attr().buttons.splice(index, 1)\n }\n\n $button = $el.querySelector(`.${name}`)\n this.switch(name, false)\n $el.removeChild($button)\n\n return this\n }\n\n switch(name, enabled) {\n const $el = this.$el\n const buttons = this.attr('buttons')\n const button = buttons.find((option) => option.name === name)\n let action\n let type\n let listener\n let $button\n\n if (!button) {\n return this\n }\n\n buttons.forEach((option) => {\n if (option.name === name) {\n button.disabled = !enabled\n }\n })\n\n action = button.action\n $button = $el.querySelector(`.${name}`)\n\n if (action) {\n type = action.type || 'click'\n listener = action.handler\n }\n\n if (enabled) {\n removeClass($button, DISABLED)\n\n if (type && listener) {\n on($el, `.${name}`, type, listener)\n }\n } else {\n addClass($button, DISABLED)\n\n if (type && listener) {\n off($el, type, listener)\n }\n }\n\n return this\n }\n\n disable(name) {\n const disabled = this.attr('afterDisabled')\n\n if (name) {\n this.switch(name, false)\n } else {\n addClass(this.$el, DISABLED)\n this.removeListeners()\n this.disabled = true\n\n if (isFunction(disabled)) {\n disabled.call(this)\n }\n }\n\n return this\n }\n\n enable(name) {\n const enabled = this.attr('afterEnabled')\n\n if (name) {\n this.switch(name, true)\n } else {\n this.disabled = false\n removeClass(this.$el, DISABLED)\n this.addListeners()\n\n if (isFunction(enabled)) {\n enabled.call(this)\n }\n }\n\n return this\n }\n\n show(name) {\n const opened = this.attr('afterOpened')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n\n $button = $el.querySelector(`.${name}`)\n removeClass($button, HIDDEN)\n } else {\n removeClass($el, HIDDEN)\n this.closed = false\n\n if (isFunction(opened)) {\n later(() => {\n opened.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n hide(name) {\n const closed = this.attr('afterClosed')\n const button = this.attr('buttons').find((option) => option.name === name)\n const $el = this.$el\n let $button\n\n if (name) {\n if (!button) {\n return this\n }\n $button = $el.querySelector(`.${name}`)\n addClass($button, HIDDEN)\n } else {\n addClass($el, HIDDEN)\n this.closed = true\n\n if (isFunction(closed)) {\n later(() => {\n closed.call(this)\n }, 310)\n }\n }\n\n return this\n }\n\n toggle() {\n if (this.isClosed()) {\n this.show()\n } else {\n this.hide()\n }\n\n return this\n }\n\n destroy() {\n const beforeDestroy = this.attr('beforeDestroy')\n const afterDestroy = this.attr('afterDestroy')\n let $el = this.$el\n\n if (isFunction(beforeDestroy)) {\n beforeDestroy.call(this)\n }\n\n this.removeListeners()\n document.body.removeChild($el)\n $el = null\n\n this.attr(Toolbar.DEFAULTS)\n this.disabled = false\n this.closed = false\n this.buttons = []\n\n if (isFunction(afterDestroy)) {\n afterDestroy.call(this)\n }\n\n return this\n }\n\n refresh() {\n const $el = this.$el\n const buttons = this.attr('buttons') || []\n\n this.removeListeners()\n $el.innerHTML = ''\n\n buttons.forEach((button) => {\n this.$el.appendChild(_createButton(button))\n })\n\n this.addListeners()\n\n return this\n }\n\n addListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n let context\n let command\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n if (isString(listener)) {\n command = listener\n action.handler = function () {\n publish(command, button.name)\n }\n listener = action.handler\n }\n\n type = action.type || 'click'\n context = action.context\n }\n\n if (isFunction(listener)) {\n on($el, `.${button.name}`, type, listener, context || this, true)\n }\n })\n\n return this\n }\n\n removeListeners() {\n const buttons = this.attr('buttons')\n const $el = this.$el\n\n if (!buttons || buttons.length < 1) {\n return this\n }\n\n buttons.forEach((button) => {\n const action = button.action\n const disabled = this.disabled\n let type\n let listener\n\n if (disabled) {\n return false\n }\n\n if (action) {\n listener = action.handler\n type = action.type || 'click'\n }\n\n if (isFunction(listener)) {\n off($el, type, listener)\n }\n })\n\n return this\n }\n}\n\nToolbar.DEFAULTS = {\n placement: 'ltr',\n closed: false,\n disabled: false,\n rounded: true,\n buttons: [],\n created: null,\n mounted: null,\n afterClosed: null,\n afterOpened: null,\n afterDisabled: null,\n afterEnabled: null,\n beforeDestroy: null,\n afterDestroy: null\n}\n\nexport default Toolbar\n","/**\n * 生成唯一 id 字符串的函数\n * ========================================================================\n * @method guid\n * @param {String} [prefix] - 生成 id 的前缀字符串\n * @return {String} 返回一个表示唯一 id 的字符串\n */\nconst guid = (() => {\n let uuid = 0\n\n return (prefix) => {\n uuid += 1\n\n return prefix ? prefix + '-' + uuid : 'guid-' + uuid\n }\n})()\n\nexport default guid\n","import _subscribers from './_subscribers'\nimport isFunction from '../types/isFunction'\nimport guid from '../lang/guid'\n\n/**\n * 订阅主题,并给出处理器函数\n * ========================================================================\n * @method on\n * @param {String} topic - (必须)主题名称\n * @param {Function} handler - (必须)主题的处理器函数\n * @param {Object} [context] - (可选)指定 this 执行上下文\n * @return {String} - 唯一的 token 字符串,例如:'guid-1'。\n */\nconst on = (topic, handler, context = null) => {\n const token = guid()\n let subject = typeof topic === 'symbol' ? topic.toString() : topic\n\n if (!isFunction(handler)) {\n return ''\n }\n\n /* istanbul ignore else */\n if (!_subscribers[subject]) {\n _subscribers[subject] = []\n }\n\n _subscribers[subject].push({\n topic: subject,\n callback: handler,\n context,\n token\n })\n\n return token\n}\n\nexport default on\n","import _subscribers from './_subscribers'\nimport hasOwn from '../lang/hasOwn'\n\n/**\n * 删除与给定 topic 相同的订阅者信息\n * ========================================================================\n * @method _removeSubscriber\n * @param {String} topic - (必须)订阅主题字符串\n * @returns {Boolean}\n */\nconst _removeSubscriber = (topic) => {\n if (!hasOwn(_subscribers, topic)) {\n return false\n }\n\n delete _subscribers[topic]\n}\n\nexport default _removeSubscriber\n","import has from './has'\nimport _removeSubscriber from './_removeSubscriber'\nimport _removeSubscriberByToken from './_removeSubscriberByToken'\n\n/**\n * 取消订阅主题\n * ========================================================================\n * @method off\n * @param {String} topic - (必须)订阅的主题\n * @param {Function|String} [token] - (可选)订阅主题的处理器函数或者唯一 Id 值\n */\nconst off = (topic, token) => {\n if (!has(topic)) {\n return false\n }\n\n if (token) {\n _removeSubscriberByToken(token)\n } else {\n _removeSubscriber(topic)\n }\n}\n\nexport default off\n","import _subscribers from './_subscribers'\nimport _removeSubscriber from './_removeSubscriber'\n\n/**\n * 通过订阅者 token 值删除订阅者信息\n * ========================================================================\n * @method _removeSubscriberByToken\n * @param {String} token - 订阅者 token 字符串\n * @returns {boolean}\n * @private\n */\nconst _removeSubscriberByToken = (token) => {\n const keys = Object.keys(_subscribers)\n let index = -1\n\n if (!token || keys.length < 1) {\n return false\n }\n\n keys.forEach((subject) => {\n const subscriber = _subscribers[subject]\n let topic\n\n subscriber.forEach((execution, j) => {\n if (execution.callback === token || execution.token === token) {\n topic = execution.topic\n subscriber.splice(index, j)\n }\n })\n\n /* istanbul ignore else */\n if (subscriber.length < 1) {\n _removeSubscriber(topic)\n }\n })\n}\n\nexport default _removeSubscriberByToken\n","import Base from './base'\nimport Anchors from './anchors'\nimport Drawer from './drawer'\nimport Chapters from './chapters'\nimport Toolbar from './toolbar'\n\nimport later from './utils/lang/later'\nimport isFunction from './utils/types/isFunction'\nimport isString from './utils/types/isString'\nimport isElement from './utils/types/isElement'\nimport addClass from './utils/dom/addClass'\nimport scrollTo from './utils/dom/scrollTo'\nimport _getScrollElement from './utils/dom/_getScrollElement'\nimport subscribe from './utils/observer/on'\nimport unsubscribe from './utils/observer/off'\n\nimport print from './print'\n\nclass Outline extends Base {\n constructor(options) {\n super()\n\n this.attrs = Outline.DEFAULTS\n this.anchors = null\n this.drawer = null\n this.chapters = null\n this.toolbar = null\n this.buttons = []\n\n if (options) {\n this.initialize(options)\n }\n }\n\n initialize(options) {\n this.attr(options).render().addListeners()\n return this\n }\n\n getChapters(isTreeStructured = false) {\n return this.anchors.getChapters(isTreeStructured)\n }\n\n count() {\n return this.anchors.count()\n }\n\n render() {\n const scrollElement = this.attr('scrollElement')\n const $scrollElement =\n document.querySelector(scrollElement) ||\n document.getElementById(scrollElement)\n\n this._renderPrint()._renderAnchors()._renderChapters()._renderToolbar()\n\n if ($scrollElement) {\n this.onToolbarUpdate({\n top: $scrollElement.scrollTop,\n min: 0,\n max: $scrollElement.scrollHeight\n })\n }\n\n return this\n }\n\n _renderPrint() {\n const option = this.attr('print')\n const articleElement = this.attr('articleElement')\n let $articleElement\n\n if (!option.element) {\n return this\n }\n\n if (isString(articleElement)) {\n $articleElement = document.querySelector(articleElement)\n } else if (isElement(articleElement)) {\n $articleElement = articleElement\n }\n\n addClass($articleElement, 'outline-article')\n print(option.element, option.title)\n\n return this\n }\n\n _renderAnchors() {\n const articleElement = this.attr('articleElement')\n const selector = this.attr('selector')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const showCode = this.attr('showCode')\n const anchorURL = this.attr('anchorURL')\n const afterScroll = this.attr('afterScroll')\n\n this.anchors = new Anchors({\n articleElement,\n stickyHeight,\n scrollElement,\n selector,\n showCode,\n anchorURL,\n afterScroll\n })\n\n return this\n }\n\n _renderChapters() {\n const title = this.attr('title')\n const stickyHeight = this.attr('stickyHeight')\n const scrollElement = this.attr('scrollElement')\n const customClass = this.attr('customClass')\n const showCode = this.attr('showCode')\n const position = this.attr('position')\n const placement = this.attr('placement')\n const afterSticky = this.attr('afterSticky')\n const afterToggle = this.attr('afterToggle')\n const afterScroll = this.attr('afterScroll')\n const count = this.count()\n let parentElement = this.attr('parentElement')\n let CHAPTERS_OPTIONS\n\n if (count < 1) {\n return this\n }\n\n CHAPTERS_OPTIONS = {\n scrollElement,\n showCode,\n position,\n title,\n stickyHeight,\n chapters: this.getChapters(),\n afterSticky,\n afterToggle,\n afterScroll\n }\n\n if (position === 'relative') {\n this.drawer = new Drawer({\n placement,\n title,\n size: 'tiny',\n hasOffset: true,\n hasPadding: false,\n customClass,\n afterClosed: () => {\n const toolbar = this.toolbar\n toolbar.toggle()\n }\n })\n parentElement = this.drawer.$main\n } else {\n CHAPTERS_OPTIONS.customClass = customClass\n }\n\n CHAPTERS_OPTIONS.parentElement = parentElement\n this.chapters = new Chapters(CHAPTERS_OPTIONS)\n\n return this\n }\n\n _renderToolbar() {\n const placement = this.attr('placement')\n const homepage = this.attr('homepage')\n const git = this.attr('git')\n const tags = this.attr('tags')\n const issues = this.attr('issues')\n const tools = this.attr('tools')\n const count = this.count()\n const UP = {\n name: 'up',\n icon: 'up',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:up'\n }\n }\n const HOME = {\n name: 'homepage',\n icon: 'homepage',\n size: 20,\n link: homepage\n }\n const GIT = {\n name: 'github',\n icon: 'github',\n size: 20,\n link: git\n }\n const TAGS = {\n name: 'tags',\n icon: 'tags',\n size: 20,\n link: tags\n }\n const ISSUES = {\n name: 'issues',\n icon: 'issues',\n size: 20,\n link: issues\n }\n const MENU = {\n name: 'menu',\n icon: 'menu',\n size: 18,\n action: {\n type: 'click',\n handler: 'toolbar:action:toggle'\n }\n }\n const DOWN = {\n name: 'down',\n icon: 'down',\n size: 20,\n action: {\n type: 'click',\n handler: 'toolbar:action:down'\n }\n }\n const buttons = []\n\n buttons.push(UP)\n if (homepage) {\n buttons.push(HOME)\n }\n if (count > 0) {\n buttons.push(MENU)\n }\n if (git) {\n buttons.push(GIT)\n }\n if (tags) {\n buttons.push(TAGS)\n }\n if (issues) {\n buttons.push(ISSUES)\n }\n if (tools?.length > 0) {\n buttons.push(...tools)\n }\n buttons.push(DOWN)\n this.buttons = [...buttons]\n\n this.toolbar = new Toolbar({\n placement,\n buttons: buttons\n })\n\n return this\n }\n\n addButton(button) {\n const toolbar = this.toolbar\n const buttons = this.buttons\n buttons.splice(-1, 0, button)\n toolbar.attr({\n buttons\n })\n toolbar.refresh()\n return this\n }\n\n removeButton(name) {\n this.toolbar.remove(name)\n return this\n }\n\n toTop() {\n const afterScroll = this.attr('afterScroll')\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const afterTop = () => {\n toolbar.hide('up')\n toolbar.show('down')\n\n if (count > 0) {\n chapters.highlight(0)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'up')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(0, afterTop)\n\n return this\n }\n\n toBottom() {\n const afterScroll = this.attr('afterScroll')\n const $scrollElement = _getScrollElement(this.attr('scrollElement'))\n const toolbar = this.toolbar\n const chapters = this.chapters\n const count = this.count()\n const top = Math.floor(\n $scrollElement.scrollHeight - $scrollElement.clientHeight\n )\n const afterDown = () => {\n toolbar.hide('down')\n toolbar.show('up')\n\n if (count > 0) {\n chapters.highlight(count - 1)\n chapters.playing = false\n }\n\n if (isFunction(afterScroll)) {\n afterScroll.call(toolbar, 'bottom')\n }\n }\n\n if (count > 0) {\n chapters.playing = true\n }\n this.scrollTo(top, afterDown)\n\n return this\n }\n\n scrollTo(top, afterScroll) {\n const scrollElement = this.attr('scrollElement')\n scrollTo(scrollElement, top, afterScroll)\n return this\n }\n\n toggle() {\n const position = this.attr('position')\n const toolbar = this.toolbar\n const drawer = this.drawer\n const chapters = this.chapters\n const count = this.count()\n\n if (count < 1) {\n return this\n }\n\n if (position !== 'relative') {\n chapters.toggle()\n toolbar.highlight('menu')\n } else {\n toolbar.toggle()\n\n later(() => {\n if (chapters.isInside()) {\n chapters.toggle()\n } else {\n drawer.toggle()\n }\n })\n }\n\n return this\n }\n\n destroy() {\n let anchors = this.anchors\n let chapters = this.chapters\n let drawer = this.drawer\n let toolbar = this.toolbar\n let isOutside = false\n const count = this.count()\n\n this.removeListeners()\n\n if (count > 0) {\n isOutside = chapters.isOutside()\n\n chapters.destroy()\n chapters = null\n\n if (isOutside) {\n drawer.destroy()\n drawer = null\n }\n }\n\n toolbar.destroy()\n toolbar = null\n\n anchors.destroy()\n anchors = null\n\n this.attr(Outline.DEFAULTS)\n\n return this\n }\n\n onToggle() {\n this.toggle()\n return this\n }\n\n onScrollTop() {\n this.toTop()\n return this\n }\n\n onScrollBottom() {\n this.toBottom()\n return this\n }\n\n onToolbarUpdate({ top, min, max }) {\n const toolbar = this.toolbar\n const current = Math.ceil(top)\n\n if (current <= min) {\n toolbar.hide('up')\n toolbar.show('down')\n } else if (current >= max) {\n toolbar.hide('down')\n toolbar.show('up')\n } else if (current > min && current < max) {\n toolbar.show('up')\n toolbar.show('down')\n }\n\n return this\n }\n\n addListeners() {\n subscribe('toolbar:update', this.onToolbarUpdate, this)\n subscribe('toolbar:action:up', this.onScrollTop, this)\n subscribe('toolbar:action:toggle', this.onToggle, this)\n subscribe('toolbar:action:down', this.onScrollBottom, this)\n return this\n }\n\n removeListeners() {\n unsubscribe('toolbar:update')\n unsubscribe('toolbar:action:up')\n unsubscribe('toolbar:action:toggle')\n unsubscribe('toolbar:action:down')\n return this\n }\n}\n\nOutline.DEFAULTS = {\n articleElement: '#article',\n selector: 'h2,h3,h4,h5,h6',\n title: '目录',\n scrollElement: 'html,body',\n position: 'relative',\n parentElement: '#aside',\n placement: 'rtl',\n showCode: true,\n anchorURL: '',\n stickyHeight: 0,\n homepage: '',\n git: '',\n tags: '',\n issues: '',\n tools: [],\n print: {\n element: '',\n title: ''\n },\n customClass: '',\n afterSticky: null,\n afterToggle: null,\n afterScroll: null\n}\n\nif (window.jQuery) {\n // 将 Outline 扩展为一个 jquery 插件\n // eslint-disable-next-line no-undef\n jQuery.extend(jQuery.fn, {\n outline: function (options) {\n // eslint-disable-next-line no-undef\n let $article = jQuery(this)\n\n return new Outline(\n // eslint-disable-next-line no-undef\n jQuery.extend({}, options, {\n articleElement: $article\n })\n )\n }\n })\n}\n\nexport default Outline\n","import isString from './utils/types/isString'\r\nimport isElement from './utils/types/isElement'\r\nimport createElement from './utils/dom/createElement'\r\nimport addClass from './utils/dom/addClass'\r\nimport later from './utils/lang/later'\r\n\r\nconst print = (origins, title) => {\r\n let $origins\r\n let $title\r\n let $article\r\n let $sibling\r\n let tagName\r\n\r\n if (isString(origins)) {\r\n $origins =\r\n document.querySelector(origins) || document.getElementById(origins)\r\n } else {\r\n if (isElement(origins)) {\r\n $origins = origins\r\n }\r\n }\r\n\r\n $title = $origins.querySelector('h1')\r\n\r\n $article = createElement(\r\n 'article',\r\n {\r\n className: 'outline-print'\r\n },\r\n ['']\r\n )\r\n $article.innerHTML = $origins.innerHTML\r\n\r\n if (isString(title) && !$title) {\r\n $title = createElement(\r\n 'h1',\r\n {\r\n className: 'outline-print__title'\r\n },\r\n [title]\r\n )\r\n\r\n $article.insertBefore($title, $article.firstChild)\r\n }\r\n\r\n document.body.appendChild($article)\r\n\r\n later(() => {\r\n $sibling = $article.previousElementSibling\r\n\r\n while ($sibling) {\r\n tagName = $sibling.tagName.toLowerCase()\r\n if (tagName !== 'script' && tagName !== 'style') {\r\n addClass($sibling, 'outline-print_sibling')\r\n }\r\n $sibling = $sibling.previousElementSibling\r\n }\r\n\r\n $sibling = $article.nextElementSibling\r\n\r\n while ($sibling) {\r\n tagName = $sibling.tagName.toLowerCase()\r\n if (tagName !== 'script' && tagName !== 'style') {\r\n addClass($sibling, 'outline-print_sibling')\r\n }\r\n $sibling = $sibling.nextElementSibling\r\n }\r\n }, 500)\r\n}\r\n\r\nexport default print\r\n"],"names":["isString","str","hasOwn","obj","prop","hasOwnProperty","Object","prototype","call","toString","val","apply","isFunction","isObject","o","Base","constructor","options","this","attrs","initialize","attr","render","addListeners","value","origin","source","keys","forEach","arguments","length","destroy","removeListeners","reload","isElement","nodeName","tagName","nodeType","later","fn","delay","setTimeout","easeInQuad","x","_getScrollElement","scrollElement","$rootElements","$scrollElement","document","querySelector","querySelectorAll","scrollTop","scrollTo","top","afterStop","step","distance","MAX_HEIGHT","scrollHeight","MAX_TOP","stop","play","requestAnimationFrame","offsetTop","el","offsetParent","matches","selector","sel","replace","msMatchesSelector","getParentOrHost","host","parentNode","CAPTURE_EVENTS","_off","type","capture","indexOf","_delegateListener","listeners","_listeners","index","listener","i","handler","splice","_delete","removeEventListener","purgeElement","recurse","$element","$children","childNodes","filter","getListeners","$child","off","on","data","context","once","evt","target","getTarget","delegateTarget","ctx","includeCTX","startsWith","closest","overrideContext","push","addEventListener","stopPropagation","preventDefault","_subscribers","_hasDirectSubscribersFor","topic","has","isDirect","found","position","lastIndexOf","substring","_hasSubscribers","emit","async","execute","subscriber","message","callback","deliver","isArray","Array","SYMBOLS","getSymbols","name","iconSet","patternName","patternSet","find","symbol","fullName","exec","iconName","getSymbol","paint","$body","body","$icons","symbols","add","innerHTML","join","createElement","insertBefore","firstChild","trim","isDOM","isHTMLCollection","fragment","isTextNode","setAttribute","toLowerCase","style","cssText","className","children","$fragment","createDocumentFragment","$el","isValidChild","child","append","createTextNode","appendChild","every","isSVG","pattern","RegExp","test","icon","size","color","width","height","defaultRules","cssRules","$icon","$svg","binds","svg","hasClass","allClass","classList","contains","removeClass","remove","_resetHeading","$heading","hasAnchor","isAtStart","CLS_HEADING","text","$anchor","removeAttribute","removeChild","getChapters","headings","showCode","previous","level","chapters","heading","headingLevel","current","parseInt","pid","differ","_getChapterParentIdByDiffer","id","rel","groups","group","JSON","stringify","cb","code","String","c","b","_getChaptersWithCode","Anchors","super","DEFAULTS","$articleElement","$headings","created","articleElement","isTreeStructured","list","nodeKey","parentKey","map","roots","item","node","toTree","count","mounted","anchorURL","chapterCode","headingId","href","_updateHeading","after","beforeDestroy","afterDestroy","onAnchorTrigger","afterScroll","stickyHeight","max","clientHeight","publish","min","addClass","setProperty","documentElement","zIndex","idx","Drawer","title","closed","$modal","$header","$title","$close","$main","$footer","$overlay","setTitle","isClosed","placement","hasClose","hasOverlay","hasOffset","hasPadding","autoHeight","customClass","open","opened","close","toggle","afterToggle","onClose","afterClosed","afterOpened","at","getStyle","ruleName","getComputedStyle","Chapters","$list","$placeholder","$parentElement","active","offsetWidth","$active","scrollTimer","resizeTimer","playing","Observer","parentElement","$parent","isSticky","isFixed","isInside","isOutside","_paintEdge","contents","calculateStickyHeight","byId","chapter","$text","$link","$code","$li","$ul","_paintChapters","positionPlaceholder","sticky","onObserver","mainPaddingTop","mainBorderTop","placeholderPaddingTop","placeholderMarginTop","placeholderBorderTop","offsetHeight","highlight","HIGHLIGHT","getAttribute","afterSticky","FIXED","isStickying","Math","window","innerHeight","show","FOLDED","HIDDEN","hide","clearTimeout","timer","props","root","rootMargin","IntersectionObserver","entries","entry","intersectionRatio","$root","section","observe","intersection","onSelect","split","onScroll","onResize","unobserve","_createButton","button","rounded","link","$button","disabled","DISABLED","Toolbar","buttons","isDisabled","option","ACTIVE","$buttons","disable","action","switch","enabled","enable","refresh","command","afterDisabled","afterEnabled","guid","uuid","prefix","token","subject","_removeSubscriber","execution","j","_removeSubscriberByToken","Outline","anchors","drawer","toolbar","getElementById","_renderPrint","_renderAnchors","_renderChapters","_renderToolbar","onToolbarUpdate","element","origins","$origins","$article","$sibling","previousElementSibling","nextElementSibling","print","CHAPTERS_OPTIONS","homepage","git","tags","issues","tools","HOME","GIT","TAGS","ISSUES","MENU","addButton","removeButton","toTop","toBottom","floor","onToggle","onScrollTop","onScrollBottom","ceil","subscribe","unsubscribe","jQuery","extend","outline"],"mappings":"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"} \ No newline at end of file diff --git a/package.json b/package.json index aaa4293c..567274a4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@yaohaixiao/outline.js", - "version": "3.13.2", + "version": "3.14.0", "description": "outline.js - 自动生成文章导读(Table of Contents)导航的 JavaScript 工具。", "main": "outline.min.js", "files": [ @@ -12,7 +12,8 @@ "drawer.min.css", "drawer.min.js", "toolbar.min.css", - "toolbar.min.js" + "toolbar.min.js", + "print.min.css" ], "scripts": { "start": "gulp start", diff --git a/src/outline.js b/src/outline.js index c7714b3c..b82c46b5 100644 --- a/src/outline.js +++ b/src/outline.js @@ -6,11 +6,16 @@ import Toolbar from './toolbar' import later from './utils/lang/later' import isFunction from './utils/types/isFunction' +import isString from './utils/types/isString' +import isElement from './utils/types/isElement' +import addClass from './utils/dom/addClass' import scrollTo from './utils/dom/scrollTo' import _getScrollElement from './utils/dom/_getScrollElement' import subscribe from './utils/observer/on' import unsubscribe from './utils/observer/off' +import print from './print' + class Outline extends Base { constructor(options) { super() @@ -46,7 +51,7 @@ class Outline extends Base { document.querySelector(scrollElement) || document.getElementById(scrollElement) - this._renderAnchors()._renderChapters()._renderToolbar() + this._renderPrint()._renderAnchors()._renderChapters()._renderToolbar() if ($scrollElement) { this.onToolbarUpdate({ @@ -59,6 +64,27 @@ class Outline extends Base { return this } + _renderPrint() { + const option = this.attr('print') + const articleElement = this.attr('articleElement') + let $articleElement + + if (!option.element) { + return this + } + + if (isString(articleElement)) { + $articleElement = document.querySelector(articleElement) + } else if (isElement(articleElement)) { + $articleElement = articleElement + } + + addClass($articleElement, 'outline-article') + print(option.element, option.title) + + return this + } + _renderAnchors() { const articleElement = this.attr('articleElement') const selector = this.attr('selector') @@ -435,6 +461,10 @@ Outline.DEFAULTS = { tags: '', issues: '', tools: [], + print: { + element: '', + title: '' + }, customClass: '', afterSticky: null, afterToggle: null, diff --git a/src/print.js b/src/print.js new file mode 100644 index 00000000..ec611361 --- /dev/null +++ b/src/print.js @@ -0,0 +1,71 @@ +import isString from './utils/types/isString' +import isElement from './utils/types/isElement' +import createElement from './utils/dom/createElement' +import addClass from './utils/dom/addClass' +import later from './utils/lang/later' + +const print = (origins, title) => { + let $origins + let $title + let $article + let $sibling + let tagName + + if (isString(origins)) { + $origins = + document.querySelector(origins) || document.getElementById(origins) + } else { + if (isElement(origins)) { + $origins = origins + } + } + + $title = $origins.querySelector('h1') + + $article = createElement( + 'article', + { + className: 'outline-print' + }, + [''] + ) + $article.innerHTML = $origins.innerHTML + + if (isString(title) && !$title) { + $title = createElement( + 'h1', + { + className: 'outline-print__title' + }, + [title] + ) + + $article.insertBefore($title, $article.firstChild) + } + + document.body.appendChild($article) + + later(() => { + $sibling = $article.previousElementSibling + + while ($sibling) { + tagName = $sibling.tagName.toLowerCase() + if (tagName !== 'script' && tagName !== 'style') { + addClass($sibling, 'outline-print_sibling') + } + $sibling = $sibling.previousElementSibling + } + + $sibling = $article.nextElementSibling + + while ($sibling) { + tagName = $sibling.tagName.toLowerCase() + if (tagName !== 'script' && tagName !== 'style') { + addClass($sibling, 'outline-print_sibling') + } + $sibling = $sibling.nextElementSibling + } + }, 500) +} + +export default print diff --git a/src/theme/colors.less b/src/theme/colors.less index dc8c2ce5..4336052a 100644 --- a/src/theme/colors.less +++ b/src/theme/colors.less @@ -14,3 +14,5 @@ @secondary_text_color: #555; @third_text_color: #666; @fourth_text_color: #999; + +@border_color: #ddd; diff --git a/src/theme/outline.less b/src/theme/outline.less index a8ecc711..d1b181b9 100644 --- a/src/theme/outline.less +++ b/src/theme/outline.less @@ -8,3 +8,4 @@ @import './chapters'; @import './toolbar'; @import './scrollbar'; +@import './print'; diff --git a/src/theme/print.less b/src/theme/print.less new file mode 100644 index 00000000..0f47b154 --- /dev/null +++ b/src/theme/print.less @@ -0,0 +1,45 @@ +@import './colors'; + +.outline-print { + display: none; +} + +@media print { + html, + body { + height: initial !important; + } + + .outline-print { + display: block !important; + overflow: hidden; + + h1 { + text-align: center; + font-size: 20pt; + font-family: 'Microsoft YaHei UI', Arial, sans-serif; + font-weight: normal; + } + + pre { + padding: 1em !important; + border: 1px solid @border_color !important; + border-radius: 4px !important; + } + + pre, + code { + background-color: @white !important; + } + + table, + img, + svg { + break-inside: avoid; + } + + &_sibling { + display: none !important; + } + } +}