diff --git a/docs/.vuepress/config.js b/docs/.vuepress/config.js index 49571b9079cd37f1b2bad11bcc47ca8f04aaf212..3fb637535c18420242a4702a71abb3592087b785 100644 --- a/docs/.vuepress/config.js +++ b/docs/.vuepress/config.js @@ -31,11 +31,11 @@ const config = { editLinks: true, editLinkText: '帮助我们改善此页面!', // smoothScroll: true, - algolia: { + /* algolia: { apiKey: 'ca67b01d14df58783e2f7dc45c79736e', indexName: 'en-uniapp-dcloud', appId: 'TZ0EGQ9J1Y' - } + } */ }, markdown: { slugify(str) { diff --git a/docs/.vuepress/theme/components/Navbar.vue b/docs/.vuepress/theme/components/Navbar.vue index cbf06ea0f63fc7768fc68393dc6999397f0d790c..bb9ea537014bf8c9843057971560a3dd934cfc7d 100644 --- a/docs/.vuepress/theme/components/Navbar.vue +++ b/docs/.vuepress/theme/components/Navbar.vue @@ -56,6 +56,7 @@ 'max-width': linksWrapMaxWidth + 'px' } : {}" > + 回到旧版 import AlgoliaSearchBox from '@AlgoliaSearchBox' -import SearchBox from '@SearchBox' +import SearchBox from './SearchBox' import SidebarButton from '@theme/components/SidebarButton.vue' import NavLinks from '@theme/components/NavLinks.vue' import MainNavbarLink from './MainNavbarLink.vue'; @@ -186,6 +187,10 @@ export default { toggleMobilePanel () { this.showMobilePanel = !this.showMobilePanel forbidScroll(this.showMobilePanel) + }, + switchVersion () { + document.cookie = '__new_version=;expires=-1' + location.reload() } }, diff --git a/docs/.vuepress/theme/components/SearchBox/index.vue b/docs/.vuepress/theme/components/SearchBox/index.vue new file mode 100644 index 0000000000000000000000000000000000000000..a434861139a32c447e4e4e3e2b3d99035cd39285 --- /dev/null +++ b/docs/.vuepress/theme/components/SearchBox/index.vue @@ -0,0 +1,330 @@ + + + + + diff --git a/docs/.vuepress/theme/components/SearchBox/match-query.js b/docs/.vuepress/theme/components/SearchBox/match-query.js new file mode 100644 index 0000000000000000000000000000000000000000..c1c41f3ba382fbf5ffb81c18a47fb9e1d9a1b35f --- /dev/null +++ b/docs/.vuepress/theme/components/SearchBox/match-query.js @@ -0,0 +1,51 @@ + +import get from 'lodash/get' + +export default (query, page, additionalStr = null) => { + let domain = get(page, 'title', '') + + if (get(page, 'frontmatter.tags')) { + domain += ` ${page.frontmatter.tags.join(' ')}` + } + + if (additionalStr) { + domain += ` ${additionalStr}` + } + + return matchTest(query, domain) +} + +const matchTest = (query, domain) => { + const escapeRegExp = str => str.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&') + + // eslint-disable-next-line no-control-regex + const nonASCIIRegExp = new RegExp('[^\x00-\x7F]') + + const words = query + .split(/\s+/g) + .map(str => str.trim()) + .filter(str => !!str) + + if (!nonASCIIRegExp.test(query)) { + // if the query only has ASCII chars, treat as English + const hasTrailingSpace = query.endsWith(' ') + const searchRegex = new RegExp( + words + .map((word, index) => { + if (words.length === index + 1 && !hasTrailingSpace) { + // The last word - ok with the word being "startswith"-like + return `(?=.*\\b${escapeRegExp(word)})` + } else { + // Not the last word - expect the whole word exactly + return `(?=.*\\b${escapeRegExp(word)}\\b)` + } + }) + .join('') + '.+', + 'gi' + ) + return searchRegex.test(domain) + } else { + // if the query has non-ASCII chars, treat as other languages + return words.some(word => domain.toLowerCase().indexOf(word) > -1) + } +} diff --git a/docs/.vuepress/theme/components/SearchBox/search.svg b/docs/.vuepress/theme/components/SearchBox/search.svg new file mode 100644 index 0000000000000000000000000000000000000000..03d83913e8280ce134efc7e8c4f38513e0f50eac --- /dev/null +++ b/docs/.vuepress/theme/components/SearchBox/search.svg @@ -0,0 +1 @@ + diff --git a/docs/.vuepress/theme/mixin/navProvider.js b/docs/.vuepress/theme/mixin/navProvider.js index 24db56990f2eeea9c62d757aaef7577a4e471c86..54cebe6aec6d109538477862dd5a613ce7ea7f73 100644 --- a/docs/.vuepress/theme/mixin/navProvider.js +++ b/docs/.vuepress/theme/mixin/navProvider.js @@ -49,7 +49,7 @@ export default { watch: { $route(after) { let navbarIndex = this.customNavBarKeys.indexOf((after.fullPath.match(/\/(\w+)+\/*/) || [])[1]) - navbarIndex === -1 && after.fullPath === '/' && (navbarIndex = 0) + navbarIndex === -1 && (navbarIndex = 0) this.navConfig.userNavIndex !== navbarIndex && navbarIndex !== -1 && (this.navConfig.userNavIndex = navbarIndex) } } diff --git a/docs/.vuepress/theme/styles/navbar.styl b/docs/.vuepress/theme/styles/navbar.styl index 6606f06a03d81366018e5bef8e9bc651f99cd253..4c14ad772c26d53cd0cc4635ea16f930d71ad374 100644 --- a/docs/.vuepress/theme/styles/navbar.styl +++ b/docs/.vuepress/theme/styles/navbar.styl @@ -70,6 +70,12 @@ $navbar-logo-height = $navbar-main-navbar-height - 2rem bottom 0 opacity 0 transform scaleX(0) + .switch-version + padding-right 20px + text-decoration underline + color inherit + &:hover + color $accentColor @media (max-width: $MQMobile) $navbar-a-color = #222; diff --git a/docs/worktile/CLI.md b/docs/worktile/CLI.md index a579291ca08c1449c1b7bc992e006a7bf678bb35..02944106c0f331a6b917c015f6b78c7ef61c5f23 100644 --- a/docs/worktile/CLI.md +++ b/docs/worktile/CLI.md @@ -329,7 +329,7 @@ yarn build:mp-360 yarn dev:mp-360 # 监听文件变化且启用压缩 -yarn cross-env NODE_ENV=production UNI_PLATFORM=mp-360 vue-cli-service uni-build --watch +yarn build:mp-360 --watch ``` 可以自定义更多条件编译平台,比如钉钉小程序,参考[package.json 文档](https://uniapp.dcloud.io/collocation/package)。