hexo-theme-solitude 2.1.7 → 2.1.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/CONTRIBUTING.md +1 -1
  2. package/LICENSE +1 -1
  3. package/README.md +1 -1
  4. package/README_en-US.md +1 -1
  5. package/README_zh-Hant.md +1 -1
  6. package/SECURITY.md +1 -1
  7. package/_config.yml +1 -1
  8. package/layout/includes/inject/body.pug +1 -1
  9. package/layout/includes/page/default.pug +1 -1
  10. package/layout/includes/page/links.pug +1 -1
  11. package/layout/includes/page/tlink.pug +1 -1
  12. package/layout/includes/widgets/page/about/hobbies.pug +18 -17
  13. package/layout/includes/widgets/page/about/tenyear.pug +24 -25
  14. package/layout/includes/widgets/page/links/linksCard.pug +5 -2
  15. package/layout/includes/widgets/page/message/content.pug +1 -1
  16. package/layout/post.pug +1 -1
  17. package/package.json +1 -1
  18. package/plugins.yml +10 -10
  19. package/scripts/event/welcome.js +11 -7
  20. package/scripts/filter/randomPosts.js +14 -3
  21. package/scripts/tags/article.js +53 -15
  22. package/scripts/tags/tabs.js +26 -17
  23. package/source/css/_comments/comment.styl +4 -3
  24. package/source/css/_comments/twikoo.styl +4 -5
  25. package/source/css/_global/animation.styl +0 -15
  26. package/source/css/_global/index.styl +19 -19
  27. package/source/css/_highlight/prismjs/index.styl +1 -1
  28. package/source/css/_highlight/prismjs/line-number.styl +1 -1
  29. package/source/css/_layout/article-container.styl +1 -1
  30. package/source/css/_layout/console.styl +1 -0
  31. package/source/css/_page/_about/about.styl +1 -1
  32. package/source/css/_page/_about/game.styl +2 -17
  33. package/source/css/_page/error.styl +2 -3
  34. package/source/css/_page/links.styl +2 -2
  35. package/source/css/_page/other.styl +1 -0
  36. package/source/css/_page/says.styl +4 -3
  37. package/source/css/_tags/gallery.styl +1 -1
  38. package/source/css/_tags/tabs.styl +2 -2
  39. package/source/js/covercolor/local.js +9 -1
  40. package/source/js/main.js +29 -16
  41. package/source/js/right_menu.js +5 -3
  42. package/source/js/third_party/post_ai.min.js +1 -1
  43. package/source/js/tw_cn.js +2 -2
package/CONTRIBUTING.md CHANGED
@@ -12,7 +12,7 @@
12
12
 
13
13
  ### PR方式贡献代码步骤
14
14
 
15
- * 在 GitHub 上 `fork` 到自己的仓库,如 `yife68/Hexo-Theme-Solitude`,然后 `clone` 到本地Hexo主题目录,并设置用户信息。
15
+ * 在 GitHub 上 `fork` 到自己的仓库,如 `yife68/hexo-theme-solitude`,然后 `clone` 到本地Hexo主题目录,并设置用户信息。
16
16
 
17
17
  ```bash
18
18
  $ git clone git@github.com:{your-github-username}/hexo-theme-solitude.git themes/solitude
package/LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- MIT License
1
+ # MIT License
2
2
 
3
3
  Copyright (c) 2024 everfu
4
4
 
package/README.md CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  <div align="center">
4
4
 
5
- <h1 style="background: linear-gradient(to right, #76CBEC, #F7A137); -webkit-background-clip: text; color: transparent; font-size: 4.4rem">Solitude</h1>
5
+ <h1>Solitude</h1>
6
6
 
7
7
  一款优雅的 Hexo 主题,支持懒加载、PWA、Latex 以及多种评论系统。
8
8
 
package/README_en-US.md CHANGED
@@ -2,7 +2,7 @@ English丨[简体中文](README.md)丨[繁体中文](README_zh-Hant.md)
2
2
 
3
3
  <div align="center">
4
4
 
5
- <h1 style="background: linear-gradient(to right, #76CBEC, #F7A137); -webkit-background-clip: text; color: transparent; font-size: 4.4rem">Solitude</h1>
5
+ <h1">Solitude</h1>
6
6
 
7
7
  An elegant Hexo theme that supports lazy loading, PWA, Latex, and multiple commenting systems.
8
8
 
package/README_zh-Hant.md CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  <div align="center">
4
4
 
5
- <h1 style="background: linear-gradient(to right, #76CBEC, #F7A137); -webkit-background-clip: text; color: transparent; font-size: 4.4rem">Solitude</h1>
5
+ <h1>Solitude</h1>
6
6
 
7
7
  一款優雅的 Hexo 主題,支援懶載入、PWA、Latex 以及多種評論系統。
8
8
 
package/SECURITY.md CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  ## Reporting a Vulnerability
4
4
 
5
- If you discover a vulnerability, please report it privately through the [GitHub Security tab](https://github.com/everfu/hexo-theme-solitude/security/advisories/new) on the appropriate repository. For detailed instructions, refer to this [documentation](https://docs.github.com/en/code-security/security-advisories/guidance-on-reporting-and-writing-information-about-vulnerabilities/privately-reporting-a-security-vulnerability#privately-reporting-a-security-vulnerability). If you're unable to report via GitHub, you can email us at o@everfu.org.
5
+ If you discover a vulnerability, please report it privately through the [GitHub Security tab](https://github.com/everfu/hexo-theme-solitude/security/advisories/new) on the appropriate repository. For detailed instructions, refer to this [documentation](https://docs.github.com/en/code-security/security-advisories/guidance-on-reporting-and-writing-information-about-vulnerabilities/privately-reporting-a-security-vulnerability#privately-reporting-a-security-vulnerability). If you're unable to report via GitHub, you can email us at [o@everfu.cn](mailto:o@everfu.cn).
6
6
 
7
7
  We take security seriously and will verify and resolve any reported vulnerabilities promptly.
8
8
 
package/_config.yml CHANGED
@@ -702,7 +702,7 @@ memorial:
702
702
  date:
703
703
  # - 7-7
704
704
  # - 9-18
705
- # - 12-13 # 国家公祭日
705
+ # - 12-13
706
706
  # --------------------------- end ---------------------------
707
707
 
708
708
  # --------------------------- start ---------------------------
@@ -5,7 +5,7 @@ mixin katex
5
5
  script(src=url_for(theme.cdn.katex_copytex))
6
6
  script.
7
7
  (() => {
8
- document.querySelectorAll('#article-container span.katex-display').forEach(item => {
8
+ document.querySelectorAll('.article-container span.katex-display').forEach(item => {
9
9
  utils.wrap(item, 'div', {class: 'katex-wrap'})
10
10
  })
11
11
  })();
@@ -1,2 +1,2 @@
1
- #article-container
1
+ .article-container
2
2
  != page.content
@@ -1,6 +1,6 @@
1
1
  .flink#banners
2
2
  include ../widgets/page/links/banner
3
- .flink#article-container
3
+ .flink.article-container
4
4
  each data in site.data.links.links
5
5
  h2= data.class_name + " (" + data.link_list.length + ")"
6
6
  .flink-desc= data.descr
@@ -1,5 +1,5 @@
1
1
  include ../widgets/page/banner
2
- .flink#article-container
2
+ .flink.article-container
3
3
  each data in site.data.tlink.links
4
4
  h2= data.class_name + " (" + data.link_list.length + ")"
5
5
  .flink-desc= data.descr
@@ -1,24 +1,25 @@
1
- - var game1 = site.data.about.game1
2
- - var game2 = site.data.about.game2
1
+ - var games = site.data.about.game
3
2
 
4
- if game1 || game2
3
+ if games
5
4
  .author-content
6
- if game1
7
- .author-content-item.game-apex(style=`background: url(${game1.img}) no-repeat top; background-size: cover;`)
5
+ each game, index in games
6
+ style.
7
+ .game-#{index}::after {
8
+ box-shadow: #{game.box_shadow} !important;
9
+ }
10
+ .author-content-item.game(class=`game-${index}`, style=`background: url(${game.img}) no-repeat top; background-size: cover;`)
8
11
  .card-content
9
- .author-content-item-tips= game1.title
10
- span.author-content-item-title= game1.subtitle
12
+ .author-content-item-tips= game.title
13
+ span.author-content-item-title= game.subtitle
11
14
  .content-bottom
12
- .tips= game1.tips_left
13
- .tips= game1.tips_right
14
- if game2
15
- .author-content-item.game-jl(style=`background: url(${game2.img}) no-repeat top; background-size: cover;`)
16
- .card-content
17
- .author-content-item-tips= game2.title
18
- span.author-content-item-title= game2.subtitle
19
- .content-bottom
20
- .tips= game2.tips_left
21
- .tips= game2.tips_right
15
+ if game.icon_group
16
+ .icon-group
17
+ each icon in game.icon_group
18
+ i(style=`background-image: url(${icon})`)
19
+ else if game.tips_left
20
+ .tips= game.tips_left
21
+ if game.tips_right
22
+ .tips= game.tips_right
22
23
 
23
24
  if site.data.about.likes
24
25
  - const likes = site.data.about.likes
@@ -2,47 +2,46 @@
2
2
  if tenyear
3
3
  .author-content#tenyear
4
4
  .create-site-post.author-content-item.single
5
- .author-content-item-tips=tenyear.tips
6
- .author-content-item-title=tenyear.title
7
- p=tenyear.text
5
+ .author-content-item-tips= tenyear.tips
6
+ .author-content-item-title= tenyear.title
7
+ p= tenyear.text
8
8
  .tenyear-timeline
9
9
  .progress
10
10
  .past-time
11
11
  .percentage-label
12
12
  .time-labels
13
- .start-time#tenyear-start-time= tenyear.start
14
- .end-time#tenyear-end-time= tenyear.end
13
+ .start-time#tenyear-start-time= new Date(tenyear.start).toLocaleDateString()
14
+ .end-time#tenyear-end-time= new Date(tenyear.end).toLocaleDateString()
15
15
 
16
16
  script.
17
- function parseDateString(e) {
18
- return e.replace(/年|月/g, '-').replace(/日/g, '');
19
- }
17
+ const tenYear = () => {
18
+ const progressElement = document.querySelector(".progress");
19
+ const pastTimeElement = document.querySelector(".past-time");
20
+ const percentageLabelElement = document.querySelector(".percentage-label");
21
+ const startTimeElement = document.getElementById("tenyear-start-time");
22
+ const endTimeElement = document.getElementById("tenyear-end-time");
20
23
 
21
- function tenYear() {
22
- let progressElement = document.querySelector(".progress");
23
- let pastTimeElement = document.querySelector(".past-time");
24
- let percentageLabelElement = document.querySelector(".percentage-label");
25
- let startTimeElement = document.getElementById("tenyear-start-time");
26
- let endTimeElement = document.getElementById("tenyear-end-time");
24
+ const startTime = new Date(startTimeElement.textContent).getTime();
25
+ const endTime = new Date(endTimeElement.textContent).getTime();
27
26
 
28
- let startTime = new Date(parseDateString(startTimeElement.textContent)).getTime();
29
- let endTime = new Date(parseDateString(endTimeElement.textContent)).getTime();
30
-
31
- function updateProgress() {
32
- let currentTime = new Date().getTime();
33
- let progress = ((currentTime - startTime) / (endTime - startTime) * 100);
34
- let progressPercentage = progress <= 100 ? progress + "%" : "100%";
27
+ const updateProgress = () => {
28
+ const currentTime = new Date().getTime();
29
+ const progress = ((currentTime - startTime) / (endTime - startTime) * 100);
30
+ const progressPercentage = Math.min(progress, 100) + "%";
35
31
 
36
32
  pastTimeElement.style.setProperty("--past-time-percentage", progress + "%");
37
33
  progressElement.style.setProperty("--progress-percentage", progressPercentage);
38
- if(progress > 5){
34
+ if (progress > 5) {
39
35
  percentageLabelElement.textContent = `${progress.toFixed(0)}%`;
40
36
  percentageLabelElement.style.left = `calc(${progress}% - 35px)`;
41
37
  }
42
- }
38
+ };
43
39
 
44
40
  percentageLabelElement.style.visibility = "visible";
45
41
  updateProgress();
46
- }
42
+ };
47
43
 
48
- document.getElementById("tenyear") && tenYear() && window.Pjax.on('complete', tenYear)
44
+ if (document.getElementById("tenyear")) {
45
+ tenYear();
46
+ window.Pjax.on('complete', tenYear);
47
+ }
@@ -2,8 +2,11 @@
2
2
  each item in data.link_list
3
3
  .site-card
4
4
  if item.tag
5
- span.site-card-tag(class=item.color)= item.tag
6
- i.light
5
+ if item.color == 'vip' || item.color == 'speed'
6
+ span.site-card-tag(class=item.color)= item.tag
7
+ i.light
8
+ else
9
+ span.site-card-tag(style=`background-color: ${item.color};`)= item.tag
7
10
  a.img(title=item.name, href=url_for(item.link))
8
11
  img.flink-avatar(src=item.topimg + (data.topimg_suffix || ''), alt=item.name)
9
12
  a.info.cf-friends-link(title=item.name, href=url_for(item.link))
@@ -1,4 +1,4 @@
1
- #article-container
1
+ .article-container
2
2
  != page.content
3
3
  if theme.envelope.enable
4
4
  .switch_message
package/layout/post.pug CHANGED
@@ -5,7 +5,7 @@ block content
5
5
  #post
6
6
  if page.not_cover
7
7
  include includes/widgets/post/postInfo
8
- article.post-content#article-container
8
+ article.post-content.article-container
9
9
  if theme.post_ai.enable && page.ai
10
10
  include includes/widgets/post/post-ai
11
11
  != page.content
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hexo-theme-solitude",
3
- "version": "2.1.7",
3
+ "version": "2.1.8",
4
4
  "description": "A beautiful, powerful, and efficient Hexo theme developed by everfu.",
5
5
  "main": "package.json",
6
6
  "scripts": {
package/plugins.yml CHANGED
@@ -1,11 +1,11 @@
1
1
  algolia_search:
2
2
  name: algoliasearch
3
3
  file: dist/algoliasearch.umd.js
4
- version: 5.9.1
4
+ version: 5.14.2
5
5
  instantsearch:
6
6
  name: instantsearch.js
7
7
  file: dist/instantsearch.production.min.js
8
- version: 4.74.1
8
+ version: 4.75.5
9
9
  pjax:
10
10
  name: pjax
11
11
  file: pjax.min.js
@@ -13,16 +13,16 @@ pjax:
13
13
  twikoo:
14
14
  name: twikoo
15
15
  file: dist/twikoo.all.min.js
16
- version: 1.6.39
16
+ version: 1.6.40
17
17
  waline_js:
18
18
  name: '@waline/client'
19
19
  file: dist/waline.js
20
20
  other_name: waline
21
- version: 3.3.1
21
+ version: 3.3.2
22
22
  waline_css:
23
23
  name: '@waline/client'
24
24
  file: dist/waline.css
25
- version: 3.3.1
25
+ version: 3.3.2
26
26
  other_name: waline
27
27
  valine:
28
28
  name: valine
@@ -31,11 +31,11 @@ valine:
31
31
  artalk_css:
32
32
  name: artalk
33
33
  file: dist/Artalk.css
34
- version: 2.9.0
34
+ version: 2.9.1
35
35
  artalk_js:
36
36
  name: artalk
37
37
  file: dist/Artalk.js
38
- version: 2.9.0
38
+ version: 2.9.1
39
39
  katex:
40
40
  name: katex
41
41
  file: dist/katex.min.css
@@ -106,7 +106,7 @@ fancyapps_css:
106
106
  mermaid_js:
107
107
  name: mermaid
108
108
  file: dist/mermaid.js
109
- version: 10.9.1
109
+ version: 11.4.0
110
110
  chart_js:
111
111
  name: chart.js
112
112
  file: dist/chart.umd.js
@@ -115,7 +115,7 @@ chart_js:
115
115
  typeit_js:
116
116
  name: typeit
117
117
  file: index.umd.min.js
118
- version: 8.8.4
118
+ version: 8.8.7
119
119
  other_name: typeit
120
120
  blueimp_md5:
121
121
  name: blueimp-md5
@@ -129,5 +129,5 @@ qrcode:
129
129
  color_thief:
130
130
  name: colorthief
131
131
  file: color-thief.min.js
132
- version: 2.4.0
132
+ version: 2.6.0
133
133
  other_name: color-thief
@@ -1,14 +1,18 @@
1
1
  hexo.on('ready', () => {
2
- const {version} = require('../../package.json')
3
- hexo.log.info(`
4
- =====================[ Hexo Theme - Solitude ]=====================
2
+ const { version } = require('../../package.json')
3
+ const logo = `
5
4
  ##### #### # ##### ###### # # ###### ######
6
5
  # # # # # # # # # # #
7
6
  ##### # # # # # # # # # ######
8
7
  # # # # # # # # # # #
9
8
  ###### #### ##### ##### # ### ###### ######
10
- ${version}
11
- ===================================================================
12
- GitHub: https://github.com/everfu/hexo-theme-solitude
13
- `)
9
+ `.replace(/#/g, '●')
10
+ const message = `
11
+ \x1b[38;5;45m=====================[ Hexo Theme - Solitude ]=====================\x1b[0m
12
+ \x1b[38;5;45m${logo}\x1b[0m
13
+ \x1b[38;5;45m version: ${version}\x1b[0m
14
+ \x1b[38;5;45m===================================================================\x1b[0m
15
+ \x1b[38;5;45mGitHub: https://github.com/everfu/hexo-theme-solitude\x1b[0m
16
+ `
17
+ hexo.log.info(message)
14
18
  })
@@ -1,5 +1,16 @@
1
1
  hexo.extend.filter.register('after_render:html', function (data) {
2
- const posts = hexo.locals.get('posts').filter(post => post.random !== false).map(post => post.path);
3
- data += `<script>const posts=${JSON.stringify(posts)};function toRandomPost(){ pjax.loadUrl(GLOBAL_CONFIG.root+posts[Math.floor(Math.random()*posts.length)]); }</script>`;
4
- return data;
2
+ const posts = hexo.locals.get('posts')
3
+ .filter(post => post.random !== false)
4
+ .map(post => post.path);
5
+
6
+ const scriptContent = `
7
+ <script>
8
+ const posts = ${JSON.stringify(posts)};
9
+ function toRandomPost() {
10
+ const randomPost = posts[Math.floor(Math.random() * posts.length)];
11
+ pjax.loadUrl(GLOBAL_CONFIG.root + randomPost);
12
+ }
13
+ </script>`;
14
+
15
+ return data + scriptContent;
5
16
  });
@@ -1,18 +1,56 @@
1
- 'use strict'
1
+ 'use strict';
2
2
 
3
3
  const article = ([path]) => {
4
4
  const post = hexo.locals.get("posts").data.find(post => post.path === path);
5
- if (!post) {
6
- return '';
7
- }
8
- const tags = post.tags.map(tag => `<a class="article-meta__tags fancybox" href="${tag.path}" onclick="event.stopPropagation();"><span class="tags-punctuation"><i class="solitude fa-solid fa-hashtag"></i>${tag.name}</span></a>`).join('');
9
- const category = post.categories.data.length > 0 ? `<span class="article-meta sticky-warp"><span class="original">${post.categories.data[0].name}</span></span>` : '';
10
- const postCover = `<div class="post_cover"><a href="${'/' + post.path}" class="fancybox" title="${post.title}"><img class="post_bg" src="${post.cover}" alt="${post.title}"></a></div>`;
11
- const recentPostInfoTop = `<div class="recent-post-info-top"><div class="recent-post-info-top-tips">${category}</div><a class="article-title fancybox" href="${'/' + post.path}" title="${post.title}">${post.title}</a></div>`;
12
- const content = `<div class="content">${post.description ? post.description : ''}</div>`;
13
- const articleMetaWrap = `<div class="article-meta-wrap"><span class="article-meta tags">${tags}</span><span class="post-meta-date"><time datetime="${post.date}" style="display: inline;"></time></span></div>`;
14
- const recentPostInfo = `<div class="recent-post-info">${recentPostInfoTop + content + articleMetaWrap}</div>`
15
- return `<div class="recent-post-item" onclick="pjax.loadUrl('${'/' + post.path}')">${postCover + recentPostInfo}</div>`;
16
- }
17
-
18
- hexo.extend.tag.register('article', article)
5
+ if (!post) return '';
6
+
7
+ const createTagLinks = tags => tags.map(tag =>
8
+ `<a class="article-meta__tags fancybox" href="${tag.path}" onclick="event.stopPropagation();">
9
+ <span class="tags-punctuation">
10
+ <i class="solitude fa-solid fa-hashtag"></i>${tag.name}
11
+ </span>
12
+ </a>`
13
+ ).join('');
14
+
15
+ const createCategory = categories => categories.length > 0
16
+ ? `<span class="article-meta sticky-warp">
17
+ <span class="original">${categories[0].name}</span>
18
+ </span>`
19
+ : '';
20
+
21
+ const createPostCover = post =>
22
+ `<div class="post_cover">
23
+ <a href="/${post.path}" class="fancybox" title="${post.title}">
24
+ <img class="post_bg" src="${post.cover}" alt="${post.title}">
25
+ </a>
26
+ </div>`;
27
+
28
+ const createRecentPostInfoTop = (category, post) =>
29
+ `<div class="recent-post-info-top">
30
+ <div class="recent-post-info-top-tips">${category}</div>
31
+ <a class="article-title fancybox" href="/${post.path}" title="${post.title}">${post.title}</a>
32
+ </div>`;
33
+
34
+ const createContent = description =>
35
+ `<div class="content">${description || ''}</div>`;
36
+
37
+ const createArticleMetaWrap = (tags, date) =>
38
+ `<div class="article-meta-wrap">
39
+ <span class="article-meta tags">${tags}</span>
40
+ <span class="post-meta-date">
41
+ <time datetime="${date}" style="display: inline;"></time>
42
+ </span>
43
+ </div>`;
44
+
45
+ const tags = createTagLinks(post.tags);
46
+ const category = createCategory(post.categories.data);
47
+ const postCover = createPostCover(post);
48
+ const recentPostInfoTop = createRecentPostInfoTop(category, post);
49
+ const content = createContent(post.description);
50
+ const articleMetaWrap = createArticleMetaWrap(tags, post.date);
51
+ const recentPostInfo = `<div class="recent-post-info">${recentPostInfoTop + content + articleMetaWrap}</div>`;
52
+
53
+ return `<div class="recent-post-item" onclick="pjax.loadUrl('/${post.path}')">${postCover + recentPostInfo}</div>`;
54
+ };
55
+
56
+ hexo.extend.tag.register('article', article);
@@ -11,23 +11,32 @@ function postTabs([name, active], content) {
11
11
 
12
12
  active = Number(active) || 0;
13
13
 
14
- const tabItems = matches.map((match, tabId) => {
15
- const [tabCaption = '', tabIcon = ''] = match[1].split('@');
16
- const postContent = hexo.render.renderSync({ text: match[2], engine: 'markdown' }).trim();
17
- const tabHref = `${name.toLowerCase().replace(/\s+/g, '-')}-${tabId}`;
18
-
19
- const iconHtml = tabIcon ? `<i class="${tabIcon.trim()} tab solitude"></i>` : '';
20
- const isActive = active === tabId ? ' active' : '';
21
- const toTopButton = '<button type="button" class="tab-to-top" aria-label="scroll to top"><i class="solitude fas fa-arrow-up"></i></button>';
22
-
23
- return {
24
- nav: `<li class="tab${isActive}"><button type="button" data-href="#${tabHref}">${iconHtml}${tabCaption.trim() || `${name} ${tabId}`}</button></li>`,
25
- content: `<div class="tab-item-content${isActive}" id="${tabHref}">${postContent}${toTopButton}</div>`
26
- };
27
- });
28
-
29
- const tabNav = `<ul class="nav-tabs">${tabItems.map(item => item.nav).join('')}</ul>`;
30
- const tabContent = `<div class="tab-contents">${tabItems.map(item => item.content).join('')}</div>`;
14
+ const generateTabItems = (matches, name, active) => {
15
+ return matches.map((match, tabId) => {
16
+ const [tabCaption = '', tabIcon = ''] = match[1].split('@');
17
+ const postContent = hexo.render.renderSync({ text: match[2], engine: 'markdown' }).trim();
18
+ const tabHref = `${name.toLowerCase().replace(/\s+/g, '-')}-${tabId}`;
19
+
20
+ const iconHtml = tabIcon ? `<i class="${tabIcon.trim()} tab solitude"></i>` : '';
21
+ const isActive = active === tabId ? ' active' : '';
22
+ const toTopButton = '<button type="button" class="tab-to-top" aria-label="scroll to top"><i class="solitude fas fa-arrow-up"></i></button>';
23
+
24
+ return {
25
+ nav: `<li class="tab${isActive}"><button type="button" data-href="#${tabHref}">${iconHtml}${tabCaption.trim() || `${name} ${tabId}`}</button></li>`,
26
+ content: `<div class="tab-item-content${isActive}" id="${tabHref}">${postContent}${toTopButton}</div>`
27
+ };
28
+ });
29
+ };
30
+
31
+ const tabItems = generateTabItems(matches, name, active);
32
+
33
+ const createTabStructure = (tabItems) => {
34
+ const tabNav = `<ul class="nav-tabs">${tabItems.map(item => item.nav).join('')}</ul>`;
35
+ const tabContent = `<div class="tab-contents">${tabItems.map(item => item.content).join('')}</div>`;
36
+ return { tabNav, tabContent };
37
+ };
38
+
39
+ const { tabNav, tabContent } = createTabStructure(tabItems);
31
40
 
32
41
  return `<div class="tabs" id="${name.toLowerCase().replace(/\s+/g, '-')}">${tabNav}${tabContent}</div>`;
33
42
  }
@@ -3,7 +3,7 @@
3
3
  .comment-headline
4
4
  display inline-block
5
5
  vertical-align middle
6
- font-weight 700
6
+ font-weight bold
7
7
  font-size 20px
8
8
 
9
9
  #comment-switch
@@ -31,7 +31,7 @@
31
31
  background-color #307af6
32
32
  vertical-align middle
33
33
  cursor pointer
34
- transition all .4s ease 0s
34
+ transition all .4s ease
35
35
 
36
36
  &::before
37
37
  position absolute
@@ -42,7 +42,7 @@
42
42
  border-radius 50%
43
43
  background-color #fff
44
44
  content ""
45
- transition all .4s ease 0s
45
+ transition all .4s ease
46
46
 
47
47
  &.move
48
48
  background-color #ff7242
@@ -77,6 +77,7 @@
77
77
  font-size .6rem
78
78
  color var(--efu-secondtext)
79
79
  border-radius 8px
80
+
80
81
  if hexo-config('comment.use')[1] || ',' in hexo-config('comment.use')
81
82
  &.move
82
83
  if hexo-config('comment.count')
@@ -36,7 +36,7 @@
36
36
  color var(--efu-lighttext) !important
37
37
  cursor pointer
38
38
  user-select none
39
- padding 0 12px 0 12px
39
+ padding 0 12px
40
40
  transition all .3s
41
41
  border-radius 8px
42
42
  background-color var(--efu-secondbg)
@@ -49,7 +49,6 @@
49
49
  .tk-action-icon svg
50
50
  fill var(--efu-card-bg) !important
51
51
 
52
-
53
52
  .tk-action-icon
54
53
  svg
55
54
  transition all .3s
@@ -187,7 +186,7 @@
187
186
  .tk-content
188
187
  .tk-owo-emotion
189
188
  width 3em
190
- margin 0 2px 0 2px
189
+ margin 0 2px
191
190
 
192
191
  .tk-owo-emotion,
193
192
  .twikoo
@@ -302,7 +301,7 @@
302
301
  color var(--efu-secondtext)
303
302
 
304
303
  .tk-content
305
- margin-top 0!important
304
+ margin-top 0 !important
306
305
 
307
306
  .tk-meta-input
308
307
  .el-input
@@ -356,7 +355,7 @@ img.tk-avatar-img
356
355
  font-weight 700
357
356
 
358
357
  .el-input__inner
359
- background-color: var(--efu-secondbg) !important
358
+ background-color var(--efu-secondbg) !important
360
359
  border 0 !important
361
360
  color var(--efu-fontcolor) !important
362
361
  padding-left 8px
@@ -21,7 +21,6 @@
21
21
  50%
22
22
  top -16px
23
23
  opacity 1
24
- filter none
25
24
  100%
26
25
  top 0
27
26
  opacity .4
@@ -32,7 +31,6 @@
32
31
  transform translateY(-50px)
33
32
  100%
34
33
  opacity 1
35
- filter none
36
34
  transform translateY(0)
37
35
 
38
36
  @keyframes headerNoOpacity
@@ -47,7 +45,6 @@
47
45
  margin-top 50px
48
46
  100%
49
47
  opacity 1
50
- filter none
51
48
  margin-top 0
52
49
 
53
50
  @keyframes titlescale
@@ -56,7 +53,6 @@
56
53
  transform scale(.7)
57
54
  100%
58
55
  opacity 1
59
- filter none
60
56
  transform scale(1)
61
57
 
62
58
  @keyframes search_close
@@ -72,12 +68,10 @@
72
68
  opacity 0
73
69
  100%
74
70
  opacity 1
75
- filter none
76
71
 
77
72
  @keyframes to_hide
78
73
  0%
79
74
  opacity 1
80
- filter none
81
75
  100%
82
76
  opacity 0
83
77
 
@@ -99,7 +93,6 @@
99
93
  transform translateY(10px)
100
94
  100%
101
95
  opacity 1
102
- filter none
103
96
  transform translateY(0)
104
97
 
105
98
  @keyframes donate_effcet
@@ -108,13 +101,11 @@
108
101
  transform translateY(-20px)
109
102
  100%
110
103
  opacity 1
111
- filter none
112
104
  transform translateY(0)
113
105
 
114
106
  @keyframes announ_animation
115
107
  0%, 100%
116
108
  transform scale(1)
117
- filter blur(0)
118
109
  50%
119
110
  transform scale(1.2)
120
111
  filter blur(20px)
@@ -260,15 +251,9 @@
260
251
  @keyframes light_tag
261
252
  0%
262
253
  transform skewx(0)
263
- -o-transform skewx(0)
264
- -moz-transform skewx(0)
265
- -webkit-transform skewx(0)
266
254
  left -150px
267
255
  99%
268
256
  transform skewx(-25deg)
269
- -o-transform skewx(-25deg)
270
- -moz-transform skewx(-25deg)
271
- -webkit-transform skewx(-25deg)
272
257
  left 50px
273
258
 
274
259
  @keyframes floating
@@ -77,9 +77,9 @@ html
77
77
  line-height 1.15
78
78
  -webkit-text-size-adjust 100%
79
79
  text-size-adjust 100%
80
- height: 100%;
81
- font-size: 20px
82
- overflow-y: overlay
80
+ height: 100%
81
+ font-size 20px
82
+ overflow-y overlay
83
83
 
84
84
  main
85
85
  display block
@@ -146,7 +146,7 @@ hr
146
146
  box-sizing content-box
147
147
  height 0
148
148
  overflow visible
149
- display: none
149
+ display none
150
150
 
151
151
  a
152
152
  color var(--efu-fontcolor)
@@ -363,29 +363,29 @@ i.solitude
363
363
  font-synthesis style
364
364
 
365
365
  #body-wrap
366
- display: flex
367
- flex-direction: column
368
- min-height: 100vh
369
- justify-content: space-between
366
+ display flex
367
+ flex-direction column
368
+ min-height 100vh
369
+ justify-content space-between
370
370
 
371
371
  .layout
372
- display: flex
373
- margin: 0 auto
374
- padding: 0 1.5rem
372
+ display flex
373
+ margin 0 auto
374
+ padding 0 1.5rem
375
375
  width 100%
376
- max-width: 1200px
376
+ max-width 1200px
377
377
  +maxWidth768()
378
378
  padding 0
379
379
 
380
380
  &#content-inner
381
- max-width: 1400px
382
- flex-grow: 1
381
+ max-width 1400px
382
+ flex-grow 1
383
383
 
384
384
  /.hide-aside.layout
385
- max-width: 1400px
385
+ max-width 1400px
386
386
 
387
387
  > div
388
- width: 100% !important
388
+ width 100% !important
389
389
 
390
390
  > div:first-child
391
391
  width calc(100% - 300px)
@@ -419,10 +419,10 @@ i.solitude
419
419
  span.tags-punctuation
420
420
  i
421
421
  font-weight bold
422
- font-size: 12px
422
+ font-size 12px
423
423
  transition none
424
- margin-right: 2px
425
- opacity: .4
424
+ margin-right 2px
425
+ opacity .4
426
426
 
427
427
  .hide-aside #page &
428
428
  font-size 16px
@@ -3,7 +3,7 @@
3
3
  if hexo-config('highlight.enable')
4
4
  @require diff
5
5
 
6
- #article-container
6
+ .article-container
7
7
  pre[class*='language-']
8
8
  margin 0
9
9
  overflow-x auto
@@ -1,4 +1,4 @@
1
- #article-container
1
+ .article-container
2
2
  pre[class*='language-']
3
3
  &.line-numbers
4
4
  position relative
@@ -1,4 +1,4 @@
1
- .post-content
1
+ .article-container
2
2
  overflow-wrap break-word
3
3
  +maxWidth768()
4
4
  overflow hidden
@@ -118,6 +118,7 @@
118
118
  line-height 1
119
119
  display flex
120
120
  align-items center
121
+ justify-content space-between
121
122
 
122
123
  .aside-list
123
124
  display flex
@@ -30,7 +30,7 @@ if "motto" in $about
30
30
  @import "buff"
31
31
  @import "maxim"
32
32
 
33
- if "game1" in $about
33
+ if "game" in $about
34
34
  @import "game"
35
35
 
36
36
  if "personalities" in $about
@@ -1,11 +1,10 @@
1
1
  #about-page
2
- .author-content-item.game-apex
2
+ .author-content-item.game
3
3
  min-height 300px
4
4
  overflow hidden
5
5
  color var(--efu-white)
6
6
 
7
7
  &::after
8
- box-shadow 0 -69px 203px 11px #04120f inset
9
8
  position absolute
10
9
  content ''
11
10
  width 100%
@@ -22,18 +21,4 @@
22
21
  z-index 2
23
22
  display flex
24
23
  flex-direction column
25
- padding 1rem 2rem
26
-
27
- .author-content-item.game-jl
28
- min-height 300px
29
- overflow hidden
30
- color var(--efu-white)
31
-
32
- &::after
33
- box-shadow 0 -69px 203px 11px #415dc9 inset
34
- position absolute
35
- content ''
36
- width 100%
37
- height 100%
38
- top 0
39
- left 0
24
+ padding 1rem 2rem
@@ -42,10 +42,9 @@
42
42
  flex 1 1 0
43
43
  height 100%
44
44
  width 600px
45
- border-top-left-radius 8px
46
- border-bottom-left-radius 8px
45
+ border-radius 8px 0 0 8px
47
46
  background-color var(--efu-main)
48
- background-position center center
47
+ background-position center
49
48
  background-size cover
50
49
 
51
50
  +maxWidth768()
@@ -19,10 +19,10 @@
19
19
  opacity 1
20
20
  backdrop-filter saturate(180%) blur(20px)
21
21
 
22
- .flink#article-container
22
+ .flink.article-container
23
23
  margin-top 1rem
24
24
 
25
- #article-container
25
+ .article-container
26
26
 
27
27
  .flink-desc
28
28
  margin 0
@@ -214,6 +214,7 @@ div#banners
214
214
  .card-content
215
215
  position absolute
216
216
  width 100%
217
+ z-index 2
217
218
  height 100%
218
219
  top 0
219
220
  left 0
@@ -29,6 +29,7 @@ if hexo-config('says.home_mini')
29
29
  background var(--efu-background)
30
30
  border none
31
31
  padding 0 .2rem
32
+
32
33
  i.bber-logo,
33
34
  i.bber-gotobb
34
35
  transition .3s
@@ -80,9 +81,9 @@ if hexo-config('says.enable')
80
81
  opacity .6
81
82
 
82
83
  .goComment
83
- position: absolute
84
- top: 0
85
- right: 0
84
+ position absolute
85
+ top 0
86
+ right 0
86
87
 
87
88
  div
88
89
  &.bber-content
@@ -1,4 +1,4 @@
1
- #article-container
1
+ .article-container
2
2
  figure.gallery-group
3
3
  position: relative
4
4
  overflow: hidden
@@ -1,5 +1,5 @@
1
1
 
2
- #article-container .tabs
2
+ .article-container .tabs
3
3
  position relative
4
4
  border 1px solid var(--tab-border-color)
5
5
 
@@ -91,7 +91,7 @@
91
91
  .tab-item-content
92
92
  background var(--efu-card-bg)
93
93
 
94
- #article-container .tabs
94
+ .article-container .tabs
95
95
 
96
96
  > .tab-contents .tab-item-content.active
97
97
  animation tabshow 0s
@@ -23,7 +23,7 @@ const localColor = path => {
23
23
  const colorThief = new ColorThief();
24
24
  const img = new Image();
25
25
  img.crossOrigin = "Anonymous";
26
- img.onload = () => setThemeColors(rgbToHex(colorThief.getColor(img)));
26
+ img.onload = () => setThemeColors(rgbToHex(colorThief.getColor(img)), ...colorThief.getColor(img));
27
27
  img.onerror = () => console.error('Image Error');
28
28
  img.src = path;
29
29
  }
@@ -61,6 +61,14 @@ const setThemeColors = (value, r = null, g = null, b = null) => {
61
61
  initThemeColor();
62
62
  }
63
63
 
64
+ function LightenDarkenColor(col, amt) {
65
+ var usePound = false;
66
+ if (col[0] === "#") {
67
+ col = col.slice(1);
68
+ usePound = true;
69
+ }
70
+ }
71
+
64
72
  const adjustCardStyles = () => {
65
73
  const cardContents = document.getElementsByClassName('card-content');
66
74
  Array.from(cardContents).forEach(item => {
package/source/js/main.js CHANGED
@@ -29,31 +29,44 @@ const sidebarFn = () => {
29
29
  };
30
30
 
31
31
  const scrollFn = () => {
32
- let initTop = 0;
32
+ const $rightside = document.getElementById('rightside');
33
33
  const $header = document.getElementById('page-header');
34
- const $rightside = document.getElementById('rightside') || null;
35
-
36
- const throttledScroll = utils.throttle(() => {
37
- initThemeColor();
38
- const currentTop = window.scrollY || document.documentElement.scrollTop;
39
- const isDown = currentTop > initTop;
40
- initTop = currentTop;
34
+ let initTop = 0;
41
35
 
36
+ const updateHeaderAndRightside = (isDown, currentTop) => {
42
37
  if (currentTop > 0) {
43
38
  $header.classList.toggle('nav-visible', !isDown);
44
39
  $header.classList.add('nav-fixed');
45
40
  if ($rightside) {
46
- $rightside.style.cssText = 'opacity: 0.8; transform: translateX(-58px);';
41
+ $rightside.style.opacity = '0.8';
42
+ $rightside.style.transform = 'translateX(-58px)';
47
43
  }
48
44
  } else {
49
45
  $header.classList.remove('nav-fixed', 'nav-visible');
50
46
  if ($rightside) {
51
- $rightside.style.cssText = "opacity: ''; transform: ''";
47
+ $rightside.style.opacity = '';
48
+ $rightside.style.transform = '';
52
49
  }
53
50
  }
51
+ };
52
+
53
+ const throttledScroll = utils.throttle(() => {
54
+ initThemeColor();
55
+ const currentTop = window.scrollY || document.documentElement.scrollTop;
56
+ const isDown = currentTop > initTop;
57
+ initTop = currentTop;
58
+ updateHeaderAndRightside(isDown, currentTop);
54
59
  }, 200);
55
60
 
56
- window.addEventListener('scroll', throttledScroll);
61
+ window.addEventListener('scroll', (e) => {
62
+ throttledScroll(e);
63
+ if (window.scrollY === 0) {
64
+ $header.classList.remove('nav-fixed', 'nav-visible');
65
+ if ($rightside) {
66
+ $rightside.style.cssText = "opacity: ''; transform: ''";
67
+ }
68
+ }
69
+ });
57
70
  };
58
71
 
59
72
  const percent = () => {
@@ -290,7 +303,7 @@ const sco = {
290
303
  }
291
304
  },
292
305
  addPhotoFigcaption() {
293
- document.querySelectorAll('#article-container img:not(.gallery-item img)').forEach(image => {
306
+ document.querySelectorAll('.article-container img:not(.gallery-item img)').forEach(image => {
294
307
  const captionText = image.getAttribute('alt');
295
308
  if (captionText) {
296
309
  image.insertAdjacentHTML('afterend', `<div class="img-alt is-center">${utils.escapeHtml(captionText)}</div>`);
@@ -580,7 +593,7 @@ class toc {
580
593
  }
581
594
 
582
595
  static active(toc) {
583
- const $article = document.getElementById('article-container');
596
+ const $article = document.querySelector('.article-container');
584
597
  const $tocContent = document.getElementById('toc-content');
585
598
  const list = $article.querySelectorAll('h1,h2,h3,h4,h5,h6');
586
599
  let detectItem = '';
@@ -635,7 +648,7 @@ class tabs {
635
648
  }
636
649
 
637
650
  static clickFnOfTabs() {
638
- document.querySelectorAll('#article-container .tab > button').forEach((item) => {
651
+ document.querySelectorAll('.article-container .tab > button').forEach((item) => {
639
652
  item.addEventListener('click', function () {
640
653
  const $tabItem = this.parentNode;
641
654
  if (!$tabItem.classList.contains('active')) {
@@ -653,7 +666,7 @@ class tabs {
653
666
  }
654
667
 
655
668
  static backToTop() {
656
- document.querySelectorAll('#article-container .tabs .tab-to-top').forEach((item) => {
669
+ document.querySelectorAll('.article-container .tabs .tab-to-top').forEach((item) => {
657
670
  item.addEventListener('click', function () {
658
671
  utils.scrollToDest(utils.getEleTop(this.parentElement.parentElement.parentNode), 300);
659
672
  });
@@ -727,7 +740,7 @@ window.refreshFn = () => {
727
740
  runtime && sco.addRuntime();
728
741
  [scrollFn, sidebarFn, sco.addPhotoFigcaption, sco.setTimeState, sco.tagPageActive, sco.categoriesBarActive, sco.listenToPageInputPress, sco.addNavBackgroundInit, sco.refreshWaterFall].forEach(fn => fn());
729
742
  lazyload.enable && utils.lazyloadImg();
730
- lightbox && utils.lightbox(document.querySelectorAll("#article-container img:not(.flink-avatar,.gallery-group img, .no-lightbox)"));
743
+ lightbox && utils.lightbox(document.querySelectorAll(".article-container img:not(.flink-avatar,.gallery-group img, .no-lightbox)"));
731
744
  randomlink && randomLinksList();
732
745
  post_ai && is_post && ai.init();
733
746
  sco.switchComments();
@@ -101,9 +101,11 @@ function stopMaskScroll() {
101
101
 
102
102
  window.oncontextmenu = (ele) => {
103
103
  if (document.body.clientWidth <= 768) return;
104
- if (GLOBAL_CONFIG.right_menu.ctrlOriginalMenu && firstShowRightMenu) {
105
- firstShowRightMenu = false;
106
- utils.snackbarShow(GLOBAL_CONFIG.right_menu.ctrlOriginalMenu, false, 2000);
104
+ if (GLOBAL_CONFIG.right_menu.ctrlOriginalMenu) {
105
+ if (firstShowRightMenu) {
106
+ firstShowRightMenu = false;
107
+ utils.snackbarShow(GLOBAL_CONFIG.right_menu.ctrlOriginalMenu, false, 2000);
108
+ }
107
109
  if (ele.ctrlKey) return true;
108
110
  }
109
111
 
@@ -27,7 +27,7 @@ class POST_AI {
27
27
  }
28
28
 
29
29
  getTitleAndContent() {
30
- const articleContainer = document.getElementById("article-container");
30
+ const articleContainer = document.querySelector(".article-container");
31
31
  const title = document.title;
32
32
  const paragraphs = articleContainer.getElementsByTagName("p");
33
33
  const headers = articleContainer.querySelectorAll("h1, h2, h3, h4, h5");
@@ -47,11 +47,11 @@ document.addEventListener('DOMContentLoaded', function () {
47
47
  }
48
48
 
49
49
  function JTPYStr() {
50
- return '万与丑专业丛东丝丢两严丧个丬丰临为丽举么义乌乐乔习乡书买乱争于亏云亘亚产亩亲亵亸亿仅从仑仓仪们价众优伙会伛伞伟传伤伥伦伧伪伫体余佣佥侠侣侥侦侧侨侩侪侬俣俦俨俩俪俭债倾偬偻偾偿傥傧储傩儿兑兖党兰关兴兹养兽冁内冈册写军农冢冯冲决况冻净凄凉凌减凑凛几凤凫凭凯击凼凿刍划刘则刚创删别刬刭刽刿剀剂剐剑剥剧劝办务劢动励劲劳势勋勐勚匀匦匮区医华协单卖卢卤卧卫却卺厂厅历厉压厌厍厕厢厣厦厨厩厮县参叆叇双发变叙叠叶号叹叽吁后吓吕吗吣吨听启吴呒呓呕呖呗员呙呛呜咏咔咙咛咝咤咴咸哌响哑哒哓哔哕哗哙哜哝哟唛唝唠唡唢唣唤唿啧啬啭啮啰啴啸喷喽喾嗫呵嗳嘘嘤嘱噜噼嚣嚯团园囱围囵国图圆圣圹场坂坏块坚坛坜坝坞坟坠垄垅垆垒垦垧垩垫垭垯垱垲垴埘埙埚埝埯堑堕塆墙壮声壳壶壸处备复够头夸夹夺奁奂奋奖奥妆妇妈妩妪妫姗姜娄娅娆娇娈娱娲娴婳婴婵婶媪嫒嫔嫱嬷孙学孪宁宝实宠审宪宫宽宾寝对寻导寿将尔尘尧尴尸尽层屃屉届属屡屦屿岁岂岖岗岘岙岚岛岭岳岽岿峃峄峡峣峤峥峦崂崃崄崭嵘嵚嵛嵝嵴巅巩巯币帅师帏帐帘帜带帧帮帱帻帼幂幞干并广庄庆庐庑库应庙庞废庼廪开异弃张弥弪弯弹强归当录彟彦彻径徕御忆忏忧忾怀态怂怃怄怅怆怜总怼怿恋恳恶恸恹恺恻恼恽悦悫悬悭悯惊惧惨惩惫惬惭惮惯愍愠愤愦愿慑慭憷懑懒懔戆戋戏戗战戬户扎扑扦执扩扪扫扬扰抚抛抟抠抡抢护报担拟拢拣拥拦拧拨择挂挚挛挜挝挞挟挠挡挢挣挤挥挦捞损捡换捣据捻掳掴掷掸掺掼揸揽揿搀搁搂搅携摄摅摆摇摈摊撄撑撵撷撸撺擞攒敌敛数斋斓斗斩断无旧时旷旸昙昼昽显晋晒晓晔晕晖暂暧札术朴机杀杂权条来杨杩杰极构枞枢枣枥枧枨枪枫枭柜柠柽栀栅标栈栉栊栋栌栎栏树栖样栾桊桠桡桢档桤桥桦桧桨桩梦梼梾检棂椁椟椠椤椭楼榄榇榈榉槚槛槟槠横樯樱橥橱橹橼檐檩欢欤欧歼殁殇残殒殓殚殡殴毁毂毕毙毡毵氇气氢氩氲汇汉污汤汹沓沟没沣沤沥沦沧沨沩沪沵泞泪泶泷泸泺泻泼泽泾洁洒洼浃浅浆浇浈浉浊测浍济浏浐浑浒浓浔浕涂涌涛涝涞涟涠涡涢涣涤润涧涨涩淀渊渌渍渎渐渑渔渖渗温游湾湿溃溅溆溇滗滚滞滟滠满滢滤滥滦滨滩滪漤潆潇潋潍潜潴澜濑濒灏灭灯灵灾灿炀炉炖炜炝点炼炽烁烂烃烛烟烦烧烨烩烫烬热焕焖焘煅煳熘爱爷牍牦牵牺犊犟状犷犸犹狈狍狝狞独狭狮狯狰狱狲猃猎猕猡猪猫猬献獭玑玙玚玛玮环现玱玺珉珏珐珑珰珲琎琏琐琼瑶瑷璇璎瓒瓮瓯电画畅畲畴疖疗疟疠疡疬疮疯疱疴痈痉痒痖痨痪痫痴瘅瘆瘗瘘瘪瘫瘾瘿癞癣癫癯皑皱皲盏盐监盖盗盘眍眦眬着睁睐睑瞒瞩矫矶矾矿砀码砖砗砚砜砺砻砾础硁硅硕硖硗硙硚确硷碍碛碜碱碹磙礼祎祢祯祷祸禀禄禅离秃秆种积称秽秾稆税稣稳穑穷窃窍窑窜窝窥窦窭竖竞笃笋笔笕笺笼笾筑筚筛筜筝筹签简箓箦箧箨箩箪箫篑篓篮篱簖籁籴类籼粜粝粤粪粮糁糇紧絷纟纠纡红纣纤纥约级纨纩纪纫纬纭纮纯纰纱纲纳纴纵纶纷纸纹纺纻纼纽纾线绀绁绂练组绅细织终绉绊绋绌绍绎经绐绑绒结绔绕绖绗绘给绚绛络绝绞统绠绡绢绣绤绥绦继绨绩绪绫绬续绮绯绰绱绲绳维绵绶绷绸绹绺绻综绽绾绿缀缁缂缃缄缅缆缇缈缉缊缋缌缍缎缏缐缑缒缓缔缕编缗缘缙缚缛缜缝缞缟缠缡缢缣缤缥缦缧缨缩缪缫缬缭缮缯缰缱缲缳缴缵罂网罗罚罢罴羁羟羡翘翙翚耢耧耸耻聂聋职聍联聩聪肃肠肤肷肾肿胀胁胆胜胧胨胪胫胶脉脍脏脐脑脓脔脚脱脶脸腊腌腘腭腻腼腽腾膑臜舆舣舰舱舻艰艳艹艺节芈芗芜芦苁苇苈苋苌苍苎苏苘苹茎茏茑茔茕茧荆荐荙荚荛荜荞荟荠荡荣荤荥荦荧荨荩荪荫荬荭荮药莅莜莱莲莳莴莶获莸莹莺莼萚萝萤营萦萧萨葱蒇蒉蒋蒌蓝蓟蓠蓣蓥蓦蔷蔹蔺蔼蕲蕴薮藁藓虏虑虚虫虬虮虽虾虿蚀蚁蚂蚕蚝蚬蛊蛎蛏蛮蛰蛱蛲蛳蛴蜕蜗蜡蝇蝈蝉蝎蝼蝾螀螨蟏衅衔补衬衮袄袅袆袜袭袯装裆裈裢裣裤裥褛褴襁襕见观觃规觅视觇览觉觊觋觌觍觎觏觐觑觴触觯詟誉誊讠计订讣认讥讦讧讨让讪讫训议讯记讱讲讳讴讵讶讷许讹论讻讼讽设访诀证诂诃评诅识诇诈诉诊诋诌词诎诏诐译诒诓诔试诖诗诘诙诚诛诜话诞诟诠诡询诣诤该详诧诨诩诪诫诬语诮误诰诱诲诳说诵诶请诸诹诺读诼诽课诿谀谁谂调谄谅谆谇谈谊谋谌谍谎谏谐谑谒谓谔谕谖谗谘谙谚谛谜谝谞谟谠谡谢谣谤谥谦谧谨谩谪谫谬谭谮谯谰谱谲谳谴谵谶谷豮贝贞负贠贡财责贤败账货质贩贪贫贬购贮贯贰贱贲贳贴贵贶贷贸费贺贻贼贽贾贿赀赁赂赃资赅赆赇赈赉赊赋赌赍赎赏赐赑赒赓赔赕赖赗赘赙赚赛赜赝赞赟赠赡赢赣赪赵赶趋趱趸跃跄跖跞践跶跷跸跹跻踊踌踪踬踯蹑蹒蹰蹿躏躜躯车轧轨轩轪轫转轭轮软轰轱轲轳轴轵轶轷轸轹轺轻轼载轾轿辀辁辂较辄辅辆辇辈辉辊辋辌辍辎辏辐辑辒输辔辕辖辗辘辙辚辞辩辫边辽达迁过迈运还这进远违连迟迩迳迹适选逊递逦逻遗遥邓邝邬邮邹邺邻郁郄郏郐郑郓郦郧郸酝酦酱酽酾酿释里鉅鉴銮錾钆钇针钉钊钋钌钍钎钏钐钑钒钓钔钕钖钗钘钙钚钛钝钞钟钠钡钢钣钤钥钦钧钨钩钪钫钬钭钮钯钰钱钲钳钴钵钶钷钸钹钺钻钼钽钾钿铀铁铂铃铄铅铆铈铉铊铋铍铎铏铐铑铒铕铗铘铙铚铛铜铝铞铟铠铡铢铣铤铥铦铧铨铪铫铬铭铮铯铰铱铲铳铴铵银铷铸铹铺铻铼铽链铿销锁锂锃锄锅锆锇锈锉锊锋锌锍锎锏锐锑锒锓锔锕锖锗错锚锜锞锟锠锡锢锣锤锥锦锨锩锫锬锭键锯锰锱锲锳锴锵锶锷锸锹锺锻锼锽锾锿镀镁镂镃镆镇镈镉镊镌镍镎镏镐镑镒镕镖镗镙镚镛镜镝镞镟镠镡镢镣镤镥镦镧镨镩镪镫镬镭镮镯镰镱镲镳镴镶长门闩闪闫闬闭问闯闰闱闲闳间闵闶闷闸闹闺闻闼闽闾闿阀阁阂阃阄阅阆阇阈阉阊阋阌阍阎阏阐阑阒阓阔阕阖阗阘阙阚阛队阳阴阵阶际陆陇陈陉陕陧陨险随隐隶隽难雏雠雳雾霁霉霭靓静靥鞑鞒鞯鞴韦韧韨韩韪韫韬韵页顶顷顸项顺须顼顽顾顿颀颁颂颃预颅领颇颈颉颊颋颌颍颎颏颐频颒颓颔颕颖颗题颙颚颛颜额颞颟颠颡颢颣颤颥颦颧风飏飐飑飒飓飔飕飖飗飘飙飚飞飨餍饤饥饦饧饨饩饪饫饬饭饮饯饰饱饲饳饴饵饶饷饸饹饺饻饼饽饾饿馀馁馂馃馄馅馆馇馈馉馊馋馌馍馎馏馐馑馒馓馔馕马驭驮驯驰驱驲驳驴驵驶驷驸驹驺驻驼驽驾驿骀骁骂骃骄骅骆骇骈骉骊骋验骍骎骏骐骑骒骓骔骕骖骗骘骙骚骛骜骝骞骟骠骡骢骣骤骥骦骧髅髋髌鬓魇魉鱼鱽鱾鱿鲀鲁鲂鲄鲅鲆鲇鲈鲉鲊鲋鲌鲍鲎鲏鲐鲑鲒鲓鲔鲕鲖鲗鲘鲙鲚鲛鲜鲝鲞鲟鲠鲡鲢鲣鲤鲥鲦鲧鲨鲩鲪鲫鲬鲭鲮鲯鲰鲱鲲鲳鲴鲵鲶鲷鲸鲹鲺鲻鲼鲽鲾鲿鳀鳁鳂鳃鳄鳅鳆鳇鳈鳉鳊鳋鳌鳍鳎鳏鳐鳑鳒鳓鳔鳕鳖鳗鳘鳙鳛鳜鳝鳞鳟鳠鳡鳢鳣鸟鸠鸡鸢鸣鸤鸥鸦鸧鸨鸩鸪鸫鸬鸭鸮鸯鸰鸱鸲鸳鸴鸵鸶鸷鸸鸹鸺鸻鸼鸽鸾鸿鹀鹁鹂鹃鹄鹅鹆鹇鹈鹉鹊鹋鹌鹍鹎鹏鹐鹑鹒鹓鹔鹕鹖鹗鹘鹚鹛鹜鹝鹞鹟鹠鹡鹢鹣鹤鹥鹦鹧鹨鹩鹪鹫鹬鹭鹯鹰鹱鹲鹳鹴鹾麦麸黄黉黡黩黪黾龙历志制一台皋准复猛钟注范签';
50
+ return '万与丑专业丛东丝丢两严丧个丬丰临为丽举么义乌乐乔习乡书买乱争于亏云亘亚产亩亲亵亸亿仅从仑仓仪们价众优伙会伛伞伟传伤伥伦伧伪伫体余佣佥侠侣侥侦侧侨侩侪侬俣俦俨俩俪俭债倾偬偻偾偿傥傧储傩儿兑兖党兰关兴兹养兽冁内冈册写军农冢冯冲决况冻净凄凉凌减凑凛几凤凫凭凯击凼凿刍划刘则刚创删别刬刭刽刿剀剂剐剑剥剧劝办务劢动励劲劳势勋勐勚匀匦匮区医华协单卖卢卤卧卫却卺厂厅历厉压厌厍厕厢厣厦厨厩厮县参叆叇双发变叙叠叶号叹叽吁后吓吕吗吣吨听启吴呒呓呕呖呗员呙呛呜咏咔咙咛咝咤咴咸哌响哑哒哓哔哕哗哙哜哝哟唛唝唠唡唢唣唤唿啧啬啭啮啰啴啸喷喽喾嗫呵嗳嘘嘤嘱噜噼嚣嚯团园囱围囵国图圆圣圹场坂坏块坚坛坜坝坞坟坠垄垅垆垒垦垧垩垫垭垯垱垲垴埘埙埚埝埯堑堕塆墙壮声壳壶壸处备复够头夸夹夺奁奂奋奖奥妆妇妈妩妪妫姗姜娄娅娆娇娈娱娲娴婳婴婵婶媪嫒嫔嫱嬷孙学孪宁宝实宠审宪宫宽宾寝对寻导寿将尔尘尧尴尸尽层屃屉届属屡屦屿岁岂岖岗岘岙岚岛岭岳岽岿峃峄峡峣峤峥峦崂崃崄崭嵘嵚嵛嵝嵴巅巩巯币帅师帏帐帘帜带帧帮帱帻帼幂幞干并广庄庆庐庑库应庙庞废庼廪开异弃张弥弪弯弹强归当录彟彦彻径徕御忆忏忧忾怀态怂怃怄怅怆怜总怼怿恋恳恶恸恹恺恻恼恽悦悫悬悭悯惊惧惨惩惫惬惭惮惯愍愠愤愦愿慑慭憷懑懒懔戆戋戏戗战戬户扎扑扦执扩扪扫扬扰抚抛抟抠抡抢护报担拟拢拣拥拦拧拨择挂挚挛挜挝挞挟挠挡挢挣挤挥挦捞损捡换捣据捻掳掴掷掸掺掼揸揽揿搀搁搂搅携摄摅摆摇摈摊撄撑撵撷撸撺擞攒敌敛数斋斓斗斩断无旧时旷旸昙昼昽显晋晒晓晔晕晖暂暧札术朴机杀杂权条来杨杩杰极构枞枢枣枥枧枨枪枫枭柜柠柽栀栅标栈栉栊栋栌栎栏树栖样栾桊桠桡桢档桤桥桦桧桨桩梦梼梾检棂椁椟椠椤椭楼榄榇榈榉槚槛槟槠横樯樱橥橱橹橼檐檩欢欤欧歼殁殇残殒殓殚殡殴毁毂毕毙毡毵氇气氢氩氲汇汉污汤汹沓沟没沣沤沥沦沧沨沩沪沵泞泪泶泷泸泺泻泼泽泾洁洒洼浃浅浆浇浈浉浊测浍济浏浐浑浒浓浔浕涂涌涛涝涞涟涠涡涢涣涤润涧涨涩淀渊渌渍渎渐渑渔渖渗温游湾湿溃溅溆溇滗滚滞滟滠满滢滤滥滦滨滩滪漤潆潇潋潍潜潴澜濑濒灏灭灯灵灾灿炀炉炖炜炝点炼炽烁烂烃烛烟烦烧烨烩烫烬热焕焖焘煅煳熘爱爷牍牦牵牺犊犟状犷犸犹狈狍狝狞独狭狮狯狰狱狲猃猎猕猡猪猫猬献獭玑玙玚玛玮环现玱玺珉珏珐珑珰珲琎琏琐琼瑶瑷璇璎瓒瓮瓯电画畅畲畴疖疗疟疠疡疬疮疯疱疴痈痉痒痖痨痪痫痴瘅瘆瘗瘘瘪瘫瘾瘿癞癣癫癯皑皱皲盏盐监盖盗盘眍眦眬着睁睐睑瞒瞩矫矶矾矿砀码砖砗砚砜砺砻砾础硁硅硕硖硗硙硚确硷碍碛碜碱碹磙礼祎祢祯祷祸禀禄禅离秃秆种积称秽秾稆税稣稳穑穷窃窍窑窜窝窥窦窭竖竞笃笋笔笕笺笼笾筑筚筛筜筝筹签简箓箦箧箨箩箪箫篑篓篮篱簖籁籴类籼粜粝粤粪粮糁糇紧絷纟纠纡红纣纤纥约级纨纩纪纫纬纭纮纯纰纱纲纳纴纵纶纷纸纹纺纻纼纽纾线绀绁绂练组绅细织终绉绊绋绌绍绎经绐绑绒结绔绕绖绗绘给绚绛络绝绞统绠绡绢绣绤绥绦继绨绩绪绫绬续绮绯绰绱绲绳维绵绶绷绸绹绺绻综绽绾绿缀缁缂缃缄缅缆缇缈缉缊缋缌缍缎缏缐缑缒缓缔缕编缗缘缙缚缛缜缝缞缟缠缡缢缣缤缥缦缧缨缩缪缫缬缭缮缯缰缱缲缳缴缵罂网罗罚罢罴羁羟羡翘翙翚耢耧耸耻聂聋职聍联聩聪肃肠肤肷肾肿胀胁胆胜胧胨胪胫胶脉脍脏脐脑脓脔脚脱脶脸腊腌腘腭腻腼腽腾膑臜舆舣舰舱舻艰艳艹艺节芈芗芜芦苁苇苈苋苌苍苎苏苘苹茎茏茑茔茕茧荆荐荙荚荛荜荞荟荠荡荣荤荥荦荧荨荩荪荫荬荭荮药莅莜莱莲莳莴莶获莸莹莺莼萚萝萤营萦萧萨葱蒇蒉蒋蒌蓝蓟蓠蓣蓥蓦蔷蔹蔺蔼蕲蕴薮藁藓虏虑虚虫虬虮虽虾虿蚀蚁蚂蚕蚝蚬蛊蛎蛏蛮蛰蛱蛲蛳蛴蜕蜗蜡蝇蝈蝉蝎蝼蝾螀螨蟏衅衔补衬衮袄袅袆袜袭袯装裆裈裢裣裤裥褛褴襁襕见观觃规觅视觇览觉觊觋觌觍觎觏觐觑觞触觯詟誉誊讠计订讣认讥讦讧讨让讪讫训议讯记讱讲讳讴讵讶讷许讹论讻讼讽设访诀证诂诃评诅识诇诈诉诊诋诌词诎诏诐译诒诓诔试诖诗诘诙诚诛诜话诞诟诠诡询诣诤该详诧诨诩诪诫诬语诮误诰诱诲诳说诵诶请诸诹诺读诼诽课诿谀谁谂调谄谅谆谇谈谊谋谌谍谎谏谐谑谒谓谔谕谖谗谘谙谚谛谜谝谞谟谠谡谢谣谤谥谦谧谨谩谪谫谬谭谮谯谰谱谲谳谴谵谶谷豮贝贞负贠贡财责贤败账货质贩贪贫贬购贮贯贰贱贲贳贴贵贶贷贸费贺贻贼贽贾贿赀赁赂赃资赅赆赇赈赉赊赋赌赍赎赏赐赑赒赓赔赕赖赗赘赙赚赛赜赝赞赟赠赡赢赣赪赵赶趋趱趸跃跄跖跞践跶跷跸跹跻踊踌踪踬踯蹑蹒蹰蹿躏躜躯车轧轨轩轪轫转轭轮软轰轱轲轳轴轵轶轷轸轹轺轻轼载轾轿辀辁辂较辄辅辆辇辈辉辊辋辌辍辎辏辐辑辒输辔辕辖辗辘辙辚辞辩辫边辽达迁过迈运还这进远违连迟迩迳迹适选逊递逦逻遗遥邓邝邬邮邹邺邻郁郄郏郐郑郓郦郧郸酝酦酱酽酾酿释里鉅鉴銮錾钆钇针钉钊钋钌钍钎钏钐钑钒钓钔钕钖钗钘钙钚钛钝钞钟钠钡钢钣钤钥钦钧钨钩钪钫钬钭钮钯钰钱钲钳钴钵钶钷钸钹钺钻钼钽钾钿铀铁铂铃铄铅铆铈铉铊铋铍铎铏铐铑铒铕铗铘铙铚铛铜铝铞铟铠铡铢铣铤铥铦铧铨铪铫铬铭铮铯铰铱铲铳铴铵银铷铸铹铺铻铼铽链铿销锁锂锃锄锅锆锇锈锉锊锋锌锍锎锏锐锑锒锓锔锕锖锗错锚锜锞锟锠锡锢锣锤锥锦锨锩锫锬锭键锯锰锱锲锳锴锵锶锷锸锹锺锻锼锽锾锿镀镁镂镃镆镇镈镉镊镌镍镎镏镐镑镒镕镖镗镙镚镛镜镝镞镟镠镡镢镣镤镥镦镧镨镩镪镫镬镭镮镯镰镱镲镳镴镶长门闩闪闫闬闭问闯闰闱闲闳间闵闶闷闸闹闺闻闼闽闾闿阀阁阂阃阄阅阆阇阈阉阊阋阌阍阎阏阐阑阒阓阔阕阖阗阘阙阚阛队阳阴阵阶际陆陇陈陉陕陧陨险随隐隶隽难雏雠雳雾霁霉霭靓静靥鞑鞒鞯鞴韦韧韨韩韪韫韬韵页顶顷顸项顺须顼顽顾顿颀颁颂颃预颅领颇颈颉颊颋颌颍颎颏颐频颒颓颔颕颖颗题颙颚颛颜额颞颟颠颡颢颣颤颥颦颧风飏飐飑飒飓飔飕飖飗飘飙飚飞飨餍饤饥饦饧饨饩饪饫饬饭饮饯饰饱饲饳饴饵饶饷饸饹饺饻饼饽饾饿馀馁馂馃馄馅馆馇馈馉馊馋馌馍馎馏馐馑馒馓馔馕马驭驮驯驰驱驲驳驴驵驶驷驸驹驺驻驼驽驾驿骀骁骂骃骄骅骆骇骈骉骊骋验骍骎骏骐骑骒骓骔骕骖骗骘骙骚骛骜骝骞骟骠骡骢骣骤骥骦骧髅髋髌鬓魇魉鱼鱽鱾鱿鲀鲁鲂鲄鲅鲆鲇鲈鲉鲊鲋鲌鲍鲎鲏鲐鲑鲒鲓鲔鲕鲖鲗鲘鲙鲚鲛鲜鲝鲞鲟鲠鲡鲢鲣鲤鲥鲦鲧鲨鲩鲪鲫鲬鲭鲮鲯鲰鲱鲲鲳鲴鲵鲶鲷鲸鲹鲺鲻鲼鲽鲾鲿鳀鳁鳂鳃鳄鳅鳆鳇鳈鳉鳊鳋鳌鳍鳎鳏鳐鳑鳒鳓鳔鳕鳖鳗鳘鳙鳛鳜鳝鳞鳟鳠鳡鳢鳣鸟鸠鸡鸢鸣鸤鸥鸦鸧鸨鸩鸪鸫鸬鸭鸮鸯鸰鸱鸲鸳鸴鸵鸶鸷鸸鸹鸺鸻鸼鸽鸾鸿鹀鹁鹂鹃鹄鹅鹆鹇鹈鹉鹊鹋鹌鹍鹎鹏鹐鹑鹒鹓鹔鹕鹖鹗鹘鹚鹛鹜鹝鹞鹟鹠鹡鹢鹣鹤鹥鹦鹧鹨鹩鹪鹫鹬鹭鹯鹰鹱鹲鹳鹴鹾麦麸黄黉黡黩黪黾龙历志制一台皋准复猛钟注范签';
51
51
  }
52
52
 
53
53
  function FTPYStr() {
54
- return '萬與醜專業叢東絲丟兩嚴喪個爿豐臨為麗舉麼義烏樂喬習鄉書買亂爭於虧雲亙亞產畝親褻嚲億僅從侖倉儀們價眾優夥會傴傘偉傳傷倀倫傖偽佇體餘傭僉俠侶僥偵側僑儈儕儂俁儔儼倆儷儉債傾傯僂僨償儻儐儲儺兒兌兗黨蘭關興茲養獸囅內岡冊寫軍農塚馮衝決況凍淨淒涼淩減湊凜幾鳳鳧憑凱擊氹鑿芻劃劉則剛創刪別剗剄劊劌剴劑剮劍剝劇勸辦務勱動勵勁勞勢勳猛勩勻匭匱區醫華協單賣盧鹵臥衛卻巹廠廳曆厲壓厭厙廁廂厴廈廚廄廝縣參靉靆雙發變敘疊葉號歎嘰籲後嚇呂嗎唚噸聽啟吳嘸囈嘔嚦唄員咼嗆嗚詠哢嚨嚀噝吒噅鹹呱響啞噠嘵嗶噦嘩噲嚌噥喲嘜嗊嘮啢嗩唕喚呼嘖嗇囀齧囉嘽嘯噴嘍嚳囁嗬噯噓嚶囑嚕劈囂謔團園囪圍圇國圖圓聖壙場阪壞塊堅壇壢壩塢墳墜壟壟壚壘墾坰堊墊埡墶壋塏堖塒塤堝墊垵塹墮壪牆壯聲殼壺壼處備複夠頭誇夾奪奩奐奮獎奧妝婦媽嫵嫗媯姍薑婁婭嬈嬌孌娛媧嫻嫿嬰嬋嬸媼嬡嬪嬙嬤孫學孿寧寶實寵審憲宮寬賓寢對尋導壽將爾塵堯尷屍盡層屭屜屆屬屢屨嶼歲豈嶇崗峴嶴嵐島嶺嶽崠巋嶨嶧峽嶢嶠崢巒嶗崍嶮嶄嶸嶔崳嶁脊巔鞏巰幣帥師幃帳簾幟帶幀幫幬幘幗冪襆幹並廣莊慶廬廡庫應廟龐廢廎廩開異棄張彌弳彎彈強歸當錄彠彥徹徑徠禦憶懺憂愾懷態慫憮慪悵愴憐總懟懌戀懇惡慟懨愷惻惱惲悅愨懸慳憫驚懼慘懲憊愜慚憚慣湣慍憤憒願懾憖怵懣懶懍戇戔戲戧戰戩戶紮撲扡執擴捫掃揚擾撫拋摶摳掄搶護報擔擬攏揀擁攔擰撥擇掛摯攣掗撾撻挾撓擋撟掙擠揮撏撈損撿換搗據撚擄摑擲撣摻摜摣攬撳攙擱摟攪攜攝攄擺搖擯攤攖撐攆擷擼攛擻攢敵斂數齋斕鬥斬斷無舊時曠暘曇晝曨顯晉曬曉曄暈暉暫曖劄術樸機殺雜權條來楊榪傑極構樅樞棗櫪梘棖槍楓梟櫃檸檉梔柵標棧櫛櫳棟櫨櫟欄樹棲樣欒棬椏橈楨檔榿橋樺檜槳樁夢檮棶檢欞槨櫝槧欏橢樓欖櫬櫚櫸檟檻檳櫧橫檣櫻櫫櫥櫓櫞簷檁歡歟歐殲歿殤殘殞殮殫殯毆毀轂畢斃氈毿氌氣氫氬氳彙漢汙湯洶遝溝沒灃漚瀝淪滄渢溈滬濔濘淚澩瀧瀘濼瀉潑澤涇潔灑窪浹淺漿澆湞溮濁測澮濟瀏滻渾滸濃潯濜塗湧濤澇淶漣潿渦溳渙滌潤澗漲澀澱淵淥漬瀆漸澠漁瀋滲溫遊灣濕潰濺漵漊潷滾滯灩灄滿瀅濾濫灤濱灘澦濫瀠瀟瀲濰潛瀦瀾瀨瀕灝滅燈靈災燦煬爐燉煒熗點煉熾爍爛烴燭煙煩燒燁燴燙燼熱煥燜燾煆糊溜愛爺牍犛牽犧犢強狀獷獁猶狽麅獮獰獨狹獅獪猙獄猻獫獵獼玀豬貓蝟獻獺璣璵瑒瑪瑋環現瑲璽瑉玨琺瓏璫琿璡璉瑣瓊瑤璦璿瓔瓚甕甌電畫暢佘疇癤療瘧癘瘍鬁瘡瘋皰屙癰痙癢瘂癆瘓癇癡癉瘮瘞瘺癟癱癮癭癩癬癲臒皚皺皸盞鹽監蓋盜盤瞘眥矓著睜睞瞼瞞矚矯磯礬礦碭碼磚硨硯碸礪礱礫礎硜矽碩硤磽磑礄確鹼礙磧磣堿镟滾禮禕禰禎禱禍稟祿禪離禿稈種積稱穢穠穭稅穌穩穡窮竊竅窯竄窩窺竇窶豎競篤筍筆筧箋籠籩築篳篩簹箏籌簽簡籙簀篋籜籮簞簫簣簍籃籬籪籟糴類秈糶糲粵糞糧糝餱緊縶糸糾紆紅紂纖紇約級紈纊紀紉緯紜紘純紕紗綱納紝縱綸紛紙紋紡紵紖紐紓線紺絏紱練組紳細織終縐絆紼絀紹繹經紿綁絨結絝繞絰絎繪給絢絳絡絕絞統綆綃絹繡綌綏絛繼綈績緒綾緓續綺緋綽緔緄繩維綿綬繃綢綯綹綣綜綻綰綠綴緇緙緗緘緬纜緹緲緝縕繢緦綞緞緶線緱縋緩締縷編緡緣縉縛縟縝縫縗縞纏縭縊縑繽縹縵縲纓縮繆繅纈繚繕繒韁繾繰繯繳纘罌網羅罰罷羆羈羥羨翹翙翚耢耧耸耻聂聋职聍联聩聪肃肠肤肷肾肿胀胁胆胜朧胧胨胪胫胶脉脍脏脐脑脓脔脚脱脶脸腊腌腘腭腻腼腽腾膑臜舆舣舰舱舻艰艳艹艺节芈芗芜芦苁苇苈苋苌苍苎苏苘苹茎茏茑茔茕茧荆荐荙荚荛荜荞荟荠荡荣荤荥荦荧荨荩荪荫荬荭荮药莅莜莱莲莳莴莶获莸莹莺莼萚萝萤营萦萧萨葱蒇蒉蒋蒌蓝蓟蓠蓣蓥蓦蔷蔹蔺蔼蕲蕴薮藁藓虏虑虚虫虬虮虽虾虿蚀蚁蚂蚕蚝蚬蛊蛎蛏蛮蛰蛱蛲蛳蛴蜕蜗蜡蝇蝈蝉蝎蝼蝾螀螨蟏衅衔补衬衮袄袅袆袜袭袯装裆裈裢裣裤裥褛褴襁襕见观觃规觅视觇览觉觊觋觌觍觎觏觐觑觴触觯詟誉誊讠计订讣认讥讦讧讨让讪讫训议讯记讱讲讳讴讵讶讷许讹论讻讼讽设访诀证诂诃评诅识诇诈诉诊诋诌词诎诏诐译诒诓诔试诖诗诘诙诚诛诜话诞诟诠诡询诣诤该详诧诨诩诪诫诬语诮误诰诱诲诳说诵诶请诸诹诺读诼诽课诿谀谁谂调谄谅谆谇谈谊谋谌谍谎谏谐谑谒谓谔谕谖谗谘谙谚谛谜谝谞谟谠谡谢谣谤谥谦谧谨谩谪谫谬谭谮谯谰谱谲谳谴谵谶谷豮贝贞负贠贡财责贤败账货质贩贪贫贬购贮贯贰贱贲贳贴贵贶贷贸费贺贻贼贽贾贿赀赁赂赃资赅赆赇赈赉赊赋赌赍赎赏赐赑赒赓赔赕赖赗赘赙赚赛赜赝赞赟赠赡赢赣赪赵赶趋趱趸跃跄跖跞践跶跷跸跹跻踊踌踪踬踯蹑蹒蹰蹿躏躜躯车轧轨轩轪轫转轭轮软轰轱轲轳轴轵轶轷轸轹轺轻轼载轾轿辀辁辂较辄辅辆辇辈辉辊辋辌辍辎辏辐辑辒输辔辕辖辗辘辙辚辞辩辫边辽达迁过迈运还这进远违连迟迩迳迹适选逊递逦逻遗遥邓邝邬邮邹邺邻郁郄郏郐郑郓郦郧郸酝酦酱酽酾酿释里鉅鉴銮錾钆钇针钉钊钋钌钍钎钏钐钑钒钓钔钕钖钗钘钙钚钛钝钞钟钠钡钢钣钤钥钦钧钨钩钪钫钬钭钮钯钰钱钲钳钴钵钶钷钸钹钺钻钼钽钾钿铀铁铂铃铄铅铆铈铉铊铋铍铎铏铐铑铒铕铗铘铙铚铛铜铝铞铟铠铡铢铣铤铥铦铧铨铪铫铬铭铮铯铰铱铲铳铴铵银铷铸铹铺铻铼铽链铿销锁锂锃锄锅锆锇锈锉锊锋锌锍锎锏锐锑锒锓锔锕锖锗错锚锜锞锟锠锡锢锣锤锥锦锨锩锫锬锭键锯锰锱锲锳锴锵锶锷锸锹锺锻锼锽锾锿镀镁镂镃镆镇镈镉镊镌镍镎镏镐镑镒镕镖镗镙镚镛镜镝镞镟镠镡镢镣镤镥镦镧镨镩镪镫镬镭镮镯镰镱镲镳镴镶长门闩闪闫闬闭问闯闰闱闲闳间闵闶闷闸闹闺闻闼闽闾闿阀阁阂阃阄阅阆阇阈阉阊阋阌阍阎阏阐阑阒阓阔阕阖阗阘阙阚阛队阳阴阵阶际陆陇陈陉陕陧陨险随隐隶隽难雏雠雳雾霁霉霭靓静靥鞑鞒鞯鞴韦韧韨韩韪韫韬韵页顶顷顸项顺须顼顽顾顿颀颁颂颃预颅领颇颈颉颊颋颌颍颎颏颐频颒颓颔颕颖颗题颙颚颛颜额颞颟颠颡颢颣颤颥颦颧风飏飐飑飒飓飔飕飖飗飘飙飚飞飨餍饤饥饦饧饨饩饪饫饬饭饮饯饰饱饲饳饴饵饶饷饸饹饺饻饼饽饾饿馀馁馂馃馄馅馆馇馈馉馊馋馌馍馎馏馐馑馒馓馔馕马驭驮驯驰驱驲驳驴驵驶驷驸驹驺驻驼驽驾驿骀骁骂骃骄骅骆骇骈骉骊骋验骍骎骏骐骑骒骓骔骕骖骗骘骙骚骛骜骝骞骟骠骡骢骣骤骥骦骧髅髋髌鬓魇魉鱼鱽鱾鱿鲀鲁鲂鲄鲅鲆鲇鲈鲉鲊鲋鲌鲍鲎鲏鲐鲑鲒鲓鲔鲕鲖鲗鲘鲙鲚鲛鲜鲝鲞鲟鲠鲡鲢鲣鲤鲥鲦鲧鲨鲩鲪鲫鲬鲭鲮鲯鲰鲱鲲鲳鲴鲵鲶鲷鲸鲹鲺鲻鲼鲽鲾鲿鳀鳁鳂鳃鳄鳅鳆鳇鳈鳉鳊鳋鳌鳍鳎鳏鳐鳑鳒鳓鳔鳕鳖鳗鳘鳙鳛鳜鳝鳞鳟鳠鳡鳢鳣鸟鸠鸡鸢鸣鸤鸥鸦鸧鸨鸩鸪鸫鸬鸭鸮鸯鸰鸱鸲鸳鸴鸵鸶鸷鸸鸹鸺鸻鸼鸽鸾鸿鹀鹁鹂鹃鹄鹅鹆鹇鹈鹉鹊鹋鹌鹍鹎鹏鹐鹑鹒鹓鹔鹕鹖鹗鹘鹚鹛鹜鹝鹞鹟鹠鹡鹢鹣鹤鹥鹦鹧鹨鹩鹪鹫鹬鹭鹯鹰鹱鹲鹳鹴鹾麦麸黄黉黡黩黪黾龙历志制一台皋准復猛鐘注範簽';
54
+ return '萬與醜專業叢東絲丟兩嚴喪個爿豐臨為麗舉麼義烏樂喬習鄉書買亂爭於虧雲亙亞產畝親褻嚲億僅從侖倉儀們價眾優夥會傴傘偉傳傷倀倫傖偽佇體餘傭僉俠侶僥偵側僑儈儕儂俁儔儼倆儷儉債傾傯僂僨償儻儐儲儺兒兌兗黨蘭關興茲養獸囅內岡冊寫軍農塚馮衝決況凍淨淒涼淩減湊凜幾鳳鳧憑凱擊氹鑿芻劃劉則剛創刪別剗剄劊劌剴劑剮劍剝劇勸辦務勱動勵勁勞勢勳猛勩勻匭匱區醫華協單賣盧鹵臥衛卻巹廠廳曆厲壓厭厙廁廂厴廈廚廄廝縣參靉靆雙發變敘疊葉號歎嘰籲後嚇呂嗎唚噸聽啟吳嘸囈嘔嚦唄員咼嗆嗚詠哢嚨嚀噝吒噅鹹呱響啞噠嘵嗶噦嘩噲嚌噥喲嘜嗊嘮啢嗩唕喚呼嘖嗇囀齧囉嘽嘯噴嘍嚳囁嗬噯噓嚶囑嚕劈囂謔團園囪圍圇國圖圓聖壙場阪壞塊堅壇壢壩塢墳墜壟壟壚壘墾坰堊墊埡墶壋塏堖塒塤堝墊垵塹墮壪牆壯聲殼壺壼處備複夠頭誇夾奪奩奐奮獎奧妝婦媽嫵嫗媯姍薑婁婭嬈嬌孌娛媧嫻嫿嬰嬋嬸媼嬡嬪嬙嬤孫學孿寧寶實寵審憲宮寬賓寢對尋導壽將爾塵堯尷屍盡層屭屜屆屬屢屨嶼歲豈嶇崗峴嶴嵐島嶺嶽崠巋嶨嶧峽嶢嶠崢巒嶗崍嶮嶄嶸嶔崳嶁脊巔鞏巰幣帥師幃帳簾幟帶幀幫幬幘幗冪襆幹並廣莊慶廬廡庫應廟龐廢廎廩開異棄張彌弳彎彈強歸當錄彠彥徹徑徠禦憶懺憂愾懷態慫憮慪悵愴憐總懟懌戀懇惡慟懨愷惻惱惲悅愨懸慳憫驚懼慘懲憊愜慚憚慣湣慍憤憒願懾憖怵懣懶懍戇戔戲戧戰戩戶紮撲扡執擴捫掃揚擾撫拋摶摳掄搶護報擔擬攏揀擁攔擰撥擇掛摯攣掗撾撻挾撓擋撟掙擠揮撏撈損撿換搗據撚擄摑擲撣摻摜摣攬撳攙擱摟攪攜攝攄擺搖擯攤攖撐攆擷擼攛擻攢敵斂數齋斕鬥斬斷無舊時曠暘曇晝曨顯晉曬曉曄暈暉暫曖劄術樸機殺雜權條來楊榪傑極構樅樞棗櫪梘棖槍楓梟櫃檸檉梔柵標棧櫛櫳棟櫨櫟欄樹棲樣欒棬椏橈楨檔榿橋樺檜槳樁夢檮棶檢欞槨櫝槧欏橢樓欖櫬櫚櫸檟檻檳櫧橫檣櫻櫫櫥櫓櫞簷檁歡歟歐殲歿殤殘殞殮殫殯毆毀轂畢斃氈毿氌氣氫氬氳彙漢汙湯洶遝溝沒灃漚瀝淪滄渢溈滬濔濘淚澩瀧瀘濼瀉潑澤涇潔灑窪浹淺漿澆湞溮濁測澮濟瀏滻渾滸濃潯濜塗湧濤澇淶漣潿渦溳渙滌潤澗漲澀澱淵淥漬瀆漸澠漁瀋滲溫遊灣濕潰濺漵漊潷滾滯灩灄滿瀅濾濫灤濱灘澦濫瀠瀟瀲濰潛瀦瀾瀨瀕灝滅燈靈災燦煬爐燉煒熗點煉熾爍爛烴燭煙煩燒燁燴燙燼熱煥燜燾煆糊溜愛爺牘犛牽犧犢強狀獷獁猶狽麅獮獰獨狹獅獪猙獄猻獫獵獼玀豬貓蝟獻獺璣璵瑒瑪瑋環現瑲璽瑉玨琺瓏璫琿璡璉瑣瓊瑤璦璿瓔瓚甕甌電畫暢佘疇癤療瘧癘瘍鬁瘡瘋皰屙癰痙癢瘂癆瘓癇癡癉瘮瘞瘺癟癱癮癭癩癬癲臒皚皺皸盞鹽監蓋盜盤瞘眥矓著睜睞瞼瞞矚矯磯礬礦碭碼磚硨硯碸礪礱礫礎硜矽碩硤磽磑礄確鹼礙磧磣堿镟滾禮禕禰禎禱禍稟祿禪離禿稈種積稱穢穠穭稅穌穩穡窮竊竅窯竄窩窺竇窶豎競篤筍筆筧箋籠籩築篳篩簹箏籌簽簡籙簀篋籜籮簞簫簣簍籃籬籪籟糴類秈糶糲粵糞糧糝餱緊縶糸糾紆紅紂纖紇約級紈纊紀紉緯紜紘純紕紗綱納紝縱綸紛紙紋紡紵紖紐紓線紺絏紱練組紳細織終縐絆紼絀紹繹經紿綁絨結絝繞絰絎繪給絢絳絡絕絞統綆綃絹繡綌綏絛繼綈績緒綾緓續綺緋綽緔緄繩維綿綬繃綢綯綹綣綜綻綰綠綴緇緙緗緘緬纜緹緲緝縕繢緦綞緞緶線緱縋緩締縷編緡緣縉縛縟縝縫縗縞纏縭縊縑繽縹縵縲纓縮繆繅纈繚繕繒韁繾繰繯繳纘罌網羅罰罷羆羈羥羨翹翽翬耮耬聳恥聶聾職聹聯聵聰肅腸膚膁腎腫脹脅膽勝朧腖臚脛膠脈膾髒臍腦膿臠腳脫腡臉臘醃膕齶膩靦膃騰臏臢輿艤艦艙艫艱豔艸藝節羋薌蕪蘆蓯葦藶莧萇蒼苧蘇檾蘋莖蘢蔦塋煢繭荊薦薘莢蕘蓽蕎薈薺蕩榮葷滎犖熒蕁藎蓀蔭蕒葒葤藥蒞蓧萊蓮蒔萵薟獲蕕瑩鶯蓴蘀蘿螢營縈蕭薩蔥蕆蕢蔣蔞藍薊蘺蕷鎣驀薔蘞藺藹蘄蘊藪槁蘚虜慮虛蟲虯蟣雖蝦蠆蝕蟻螞蠶蠔蜆蠱蠣蟶蠻蟄蛺蟯螄蠐蛻蝸蠟蠅蟈蟬蠍螻蠑螿蟎蠨釁銜補襯袞襖嫋褘襪襲襏裝襠褌褳襝褲襇褸襤繈襴見觀覎規覓視覘覽覺覬覡覿覥覦覯覲覷觴觸觶讋譽謄訁計訂訃認譏訐訌討讓訕訖訓議訊記訒講諱謳詎訝訥許訛論訩訟諷設訪訣證詁訶評詛識詗詐訴診詆謅詞詘詔詖譯詒誆誄試詿詩詰詼誠誅詵話誕詬詮詭詢詣諍該詳詫諢詡譸誡誣語誚誤誥誘誨誑說誦誒請諸諏諾讀諑誹課諉諛誰諗調諂諒諄誶談誼謀諶諜謊諫諧謔謁謂諤諭諼讒諮諳諺諦謎諞諝謨讜謖謝謠謗諡謙謐謹謾謫譾謬譚譖譙讕譜譎讞譴譫讖穀豶貝貞負貟貢財責賢敗賬貨質販貪貧貶購貯貫貳賤賁貰貼貴貺貸貿費賀貽賊贄賈賄貲賃賂贓資賅贐賕賑賚賒賦賭齎贖賞賜贔賙賡賠賧賴賵贅賻賺賽賾贗讚贇贈贍贏贛赬趙趕趨趲躉躍蹌蹠躒踐躂蹺蹕躚躋踴躊蹤躓躑躡蹣躕躥躪躦軀車軋軌軒軑軔轉軛輪軟轟軲軻轤軸軹軼軤軫轢軺輕軾載輊轎輈輇輅較輒輔輛輦輩輝輥輞輬輟輜輳輻輯轀輸轡轅轄輾轆轍轔辭辯辮邊遼達遷過邁運還這進遠違連遲邇逕跡適選遜遞邐邏遺遙鄧鄺鄔郵鄒鄴鄰鬱郤郟鄶鄭鄆酈鄖鄲醞醱醬釅釃釀釋裏钜鑒鑾鏨釓釔針釘釗釙釕釷釺釧釤鈒釩釣鍆釹鍚釵鈃鈣鈈鈦鈍鈔鍾鈉鋇鋼鈑鈐鑰欽鈞鎢鉤鈧鈁鈥鈄鈕鈀鈺錢鉦鉗鈷缽鈳鉕鈽鈸鉞鑽鉬鉭鉀鈿鈾鐵鉑鈴鑠鉛鉚鈰鉉鉈鉍鈹鐸鉶銬銠鉺銪鋏鋣鐃銍鐺銅鋁銱銦鎧鍘銖銑鋌銩銛鏵銓鉿銚鉻銘錚銫鉸銥鏟銃鐋銨銀銣鑄鐒鋪鋙錸鋱鏈鏗銷鎖鋰鋥鋤鍋鋯鋨鏽銼鋝鋒鋅鋶鐦鐧銳銻鋃鋟鋦錒錆鍺錯錨錡錁錕錩錫錮鑼錘錐錦鍁錈錇錟錠鍵鋸錳錙鍥鍈鍇鏘鍶鍔鍤鍬鍾鍛鎪鍠鍰鎄鍍鎂鏤鎡鏌鎮鎛鎘鑷鐫鎳鎿鎦鎬鎊鎰鎔鏢鏜鏍鏰鏞鏡鏑鏃鏇鏐鐔钁鐐鏷鑥鐓鑭鐠鑹鏹鐙鑊鐳鐶鐲鐮鐿鑔鑣鑞鑲長門閂閃閆閈閉問闖閏闈閑閎間閔閌悶閘鬧閨聞闥閩閭闓閥閣閡閫鬮閱閬闍閾閹閶鬩閿閽閻閼闡闌闃闠闊闋闔闐闒闕闞闤隊陽陰陣階際陸隴陳陘陝隉隕險隨隱隸雋難雛讎靂霧霽黴靄靚靜靨韃鞽韉韝韋韌韍韓韙韞韜韻頁頂頃頇項順須頊頑顧頓頎頒頌頏預顱領頗頸頡頰頲頜潁熲頦頤頻頮頹頷頴穎顆題顒顎顓顏額顳顢顛顙顥纇顫顬顰顴風颺颭颮颯颶颸颼颻飀飄飆飆飛饗饜飣饑飥餳飩餼飪飫飭飯飲餞飾飽飼飿飴餌饒餉餄餎餃餏餅餑餖餓餘餒餕餜餛餡館餷饋餶餿饞饁饃餺餾饈饉饅饊饌饢馬馭馱馴馳驅馹駁驢駔駛駟駙駒騶駐駝駑駕驛駘驍罵駰驕驊駱駭駢驫驪騁驗騂駸駿騏騎騍騅騌驌驂騙騭騤騷騖驁騮騫騸驃騾驄驏驟驥驦驤髏髖髕鬢魘魎魚魛魢魷魨魯魴魺鮁鮃鯰鱸鮋鮓鮒鮊鮑鱟鮍鮐鮭鮚鮳鮪鮞鮦鰂鮜鱠鱭鮫鮮鮺鯗鱘鯁鱺鰱鰹鯉鰣鰷鯀鯊鯇鮶鯽鯒鯖鯪鯕鯫鯡鯤鯧鯝鯢鯰鯛鯨鯵鯴鯔鱝鰈鰏鱨鯷鰮鰃鰓鱷鰍鰒鰉鰁鱂鯿鰠鼇鰭鰨鰥鰩鰟鰜鰳鰾鱈鱉鰻鰵鱅鰼鱖鱔鱗鱒鱯鱤鱧鱣鳥鳩雞鳶鳴鳲鷗鴉鶬鴇鴆鴣鶇鸕鴨鴞鴦鴒鴟鴝鴛鴬鴕鷥鷙鴯鴰鵂鴴鵃鴿鸞鴻鵐鵓鸝鵑鵠鵝鵒鷳鵜鵡鵲鶓鵪鶤鵯鵬鵮鶉鶊鵷鷫鶘鶡鶚鶻鶿鶥鶩鷊鷂鶲鶹鶺鷁鶼鶴鷖鸚鷓鷚鷯鷦鷲鷸鷺鸇鷹鸌鸏鸛鸘鹺麥麩黃黌黶黷黲黽龍歷誌製壹臺臯準復勐鐘註範籤';
55
55
  }
56
56
 
57
57
  function Traditionalized(cc) {