refactor: adjust shared utility/types build setup

fix non-existent imports in generated dts files
pull/317/head
Evan You 4 years ago
parent 2ef033c5c2
commit 55de7ab43c

4
.gitignore vendored

@ -1,6 +1,6 @@
/coverage /coverage
/src/client/shared /src/client/shared.ts
/src/node/shared /src/node/shared.ts
*.log *.log
.DS_Store .DS_Store
.vite_opt_cache .vite_opt_cache

@ -65,6 +65,7 @@
"dependencies": { "dependencies": {
"@docsearch/css": "^1.0.0-alpha.28", "@docsearch/css": "^1.0.0-alpha.28",
"@docsearch/js": "^1.0.0-alpha.28", "@docsearch/js": "^1.0.0-alpha.28",
"@types/markdown-it": "^12.0.1",
"@vitejs/plugin-vue": "^1.2.3", "@vitejs/plugin-vue": "^1.2.3",
"@vue/compiler-sfc": "^3.1.1", "@vue/compiler-sfc": "^3.1.1",
"@vue/server-renderer": "^3.1.1", "@vue/server-renderer": "^3.1.1",
@ -97,7 +98,6 @@
"@types/koa": "^2.13.1", "@types/koa": "^2.13.1",
"@types/koa-static": "^4.0.1", "@types/koa-static": "^4.0.1",
"@types/lru-cache": "^5.1.0", "@types/lru-cache": "^5.1.0",
"@types/markdown-it": "^12.0.1",
"@types/node": "^15.6.1", "@types/node": "^15.6.1",
"@types/postcss-load-config": "^3.0.1", "@types/postcss-load-config": "^3.0.1",
"chokidar": "^3.5.1", "chokidar": "^3.5.1",

@ -2,6 +2,6 @@ const fs = require('fs-extra')
const glob = require('globby') const glob = require('globby')
glob.sync('src/shared/**/*.ts').forEach((file) => { glob.sync('src/shared/**/*.ts').forEach((file) => {
fs.copy(file, file.replace(/^src\//, 'src/node/')) fs.copy(file, file.replace(/^src\/shared\//, 'src/node/'))
fs.copy(file, file.replace(/^src\//, 'src/client/')) fs.copy(file, file.replace(/^src\/shared\//, 'src/client/'))
}) })

@ -3,11 +3,11 @@ const chokidar = require('chokidar')
function toClientAndNode(method, file) { function toClientAndNode(method, file) {
if (method === 'copy') { if (method === 'copy') {
fs.copy(file, file.replace(/^src\//, 'src/node/')) fs.copy(file, file.replace(/^src\/shared\//, 'src/node/'))
fs.copy(file, file.replace(/^src\//, 'src/client/')) fs.copy(file, file.replace(/^src\/shared\//, 'src/client/'))
} else if (method === 'remove') { } else if (method === 'remove') {
fs.remove(file.replace(/^src\//, 'src/node/')) fs.remove(file.replace(/^src\/shared\//, 'src/node/'))
fs.remove(file.replace(/^src\//, 'src/client/')) fs.remove(file.replace(/^src\/shared\//, 'src/client/'))
} }
} }

@ -1,5 +1,5 @@
import { watchEffect, Ref } from 'vue' import { watchEffect, Ref } from 'vue'
import { HeadConfig, SiteData } from '../../../../types/shared' import { HeadConfig, SiteData } from '../../shared'
import { Route } from '../router' import { Route } from '../router'
export function useUpdateHead(route: Route, siteDataByRouteRef: Ref<SiteData>) { export function useUpdateHead(route: Route, siteDataByRouteRef: Ref<SiteData>) {

@ -1,8 +1,7 @@
import { InjectionKey, Ref, ref, readonly, computed, inject } from 'vue' import { InjectionKey, Ref, ref, readonly, computed, inject } from 'vue'
import { Route } from './router' import { Route } from './router'
import { PageData, SiteData } from '/@types/shared'
import serializedSiteData from '@siteData' import serializedSiteData from '@siteData'
import { resolveSiteDataByRoute } from '../shared/config' import { resolveSiteDataByRoute, PageData, SiteData } from '../shared'
import { withBase } from './utils' import { withBase } from './utils'
export const dataSymbol: InjectionKey<VitePressData> = Symbol() export const dataSymbol: InjectionKey<VitePressData> = Symbol()

@ -1,6 +1,6 @@
import { reactive, inject, markRaw, nextTick, readonly } from 'vue' import { reactive, inject, markRaw, nextTick, readonly } from 'vue'
import type { Component, InjectionKey } from 'vue' import type { Component, InjectionKey } from 'vue'
import { PageData } from '../../../types/shared' import { PageData } from '../shared'
import { inBrowser } from './utils' import { inBrowser } from './utils'
export interface Route { export interface Route {

@ -1,6 +1,6 @@
import { App, Ref, Component } from 'vue' import { App, Ref, Component } from 'vue'
import { Router } from './router' import { Router } from './router'
import { SiteData } from '../../../types/shared' import { SiteData } from '../shared'
export interface EnhanceAppContext { export interface EnhanceAppContext {
app: App app: App

@ -1,5 +1,5 @@
import { siteDataRef } from './data' import { siteDataRef } from './data'
import { inBrowser } from '/@shared/config' import { inBrowser } from '../shared'
export { inBrowser } export { inBrowser }

@ -1,6 +1,6 @@
import { FunctionalComponent, h, VNode } from 'vue' import { FunctionalComponent, h, VNode } from 'vue'
import { useRoute, useData } from 'vitepress' import { useRoute, useData } from 'vitepress'
import { Header } from '/@types/shared' import { Header } from '../../shared'
import { DefaultTheme } from '../config' import { DefaultTheme } from '../config'
import { joinUrl, isActive } from '../utils' import { joinUrl, isActive } from '../utils'

@ -1,6 +1,6 @@
import { computed } from 'vue' import { computed } from 'vue'
import { useRoute, useData } from 'vitepress' import { useRoute, useData } from 'vitepress'
import { Header } from '/@types/shared' import { Header } from '../../shared'
import { useActiveSidebarLinks } from '../composables/activeSidebarLink' import { useActiveSidebarLinks } from '../composables/activeSidebarLink'
import { getSideBarConfig } from '../support/sideBar' import { getSideBarConfig } from '../support/sideBar'
import { DefaultTheme } from '../config' import { DefaultTheme } from '../config'

@ -8,8 +8,6 @@
"lib": ["ESNext", "DOM"], "lib": ["ESNext", "DOM"],
"types": ["vite/client"], "types": ["vite/client"],
"paths": { "paths": {
"/@shared/*": ["shared/*"],
"/@types/*": ["../../types/*"],
"/@theme/*": ["theme-default/*"], "/@theme/*": ["theme-default/*"],
"vitepress": ["index.ts"] "vitepress": ["index.ts"]
} }

@ -1,7 +1,7 @@
import path from 'path' import path from 'path'
import fs from 'fs-extra' import fs from 'fs-extra'
import { SiteConfig, resolveSiteDataByRoute } from '../config' import { SiteConfig, resolveSiteDataByRoute } from '../config'
import { HeadConfig } from '../../../types/shared' import { HeadConfig } from '../shared'
import { normalizePath } from 'vite' import { normalizePath } from 'vite'
import { RollupOutput, OutputChunk, OutputAsset } from 'rollup' import { RollupOutput, OutputChunk, OutputAsset } from 'rollup'

@ -4,11 +4,12 @@ import chalk from 'chalk'
import globby from 'globby' import globby from 'globby'
import { AliasOptions } from 'vite' import { AliasOptions } from 'vite'
import { Options as VuePluginOptions } from '@vitejs/plugin-vue' import { Options as VuePluginOptions } from '@vitejs/plugin-vue'
import { SiteData, HeadConfig, LocaleConfig } from '../../types/shared' import { SiteData, HeadConfig, LocaleConfig } from './shared'
export { resolveSiteDataByRoute } from './shared/config'
import { resolveAliases, APP_PATH, DEFAULT_THEME_PATH } from './alias' import { resolveAliases, APP_PATH, DEFAULT_THEME_PATH } from './alias'
import { MarkdownOptions } from './markdown/markdown' import { MarkdownOptions } from './markdown/markdown'
export { resolveSiteDataByRoute } from './shared'
const debug = require('debug')('vitepress:config') const debug = require('debug')('vitepress:config')
export interface UserConfig<ThemeConfig = any> { export interface UserConfig<ThemeConfig = any> {
@ -58,7 +59,10 @@ export async function resolveConfig(
root, root,
site, site,
themeDir, themeDir,
pages: await globby(['**.md'], { cwd: root, ignore: ['**/node_modules', ...userConfig.exclude || [] ] }), pages: await globby(['**.md'], {
cwd: root,
ignore: ['**/node_modules', ...(userConfig.exclude || [])]
}),
configPath: resolve(root, 'config.js'), configPath: resolve(root, 'config.js'),
outDir: resolve(root, 'dist'), outDir: resolve(root, 'dist'),
tempDir: path.resolve(APP_PATH, 'temp'), tempDir: path.resolve(APP_PATH, 'temp'),

@ -11,7 +11,7 @@ import { hoistPlugin } from './plugins/hoist'
import { preWrapperPlugin } from './plugins/preWrapper' import { preWrapperPlugin } from './plugins/preWrapper'
import { linkPlugin } from './plugins/link' import { linkPlugin } from './plugins/link'
import { extractHeaderPlugin } from './plugins/header' import { extractHeaderPlugin } from './plugins/header'
import { Header } from '../../../types/shared' import { Header } from '../shared'
const emoji = require('markdown-it-emoji') const emoji = require('markdown-it-emoji')
const anchor = require('markdown-it-anchor') const anchor = require('markdown-it-anchor')

@ -4,7 +4,7 @@ import matter from 'gray-matter'
import LRUCache from 'lru-cache' import LRUCache from 'lru-cache'
import { createMarkdownRenderer, MarkdownOptions } from './markdown/markdown' import { createMarkdownRenderer, MarkdownOptions } from './markdown/markdown'
import { deeplyParseHeader } from './utils/parseHeader' import { deeplyParseHeader } from './utils/parseHeader'
import { PageData, HeadConfig } from '../../types/shared' import { PageData, HeadConfig } from './shared'
import { slash } from './utils/slash' import { slash } from './utils/slash'
import chalk from 'chalk' import chalk from 'chalk'

@ -6,10 +6,7 @@
"outDir": "../../dist/node", "outDir": "../../dist/node",
"module": "commonjs", "module": "commonjs",
"lib": ["ESNext", "DOM"], "lib": ["ESNext", "DOM"],
"sourceMap": true, "sourceMap": true
"paths": {
"/@types/*": ["../../types/*"]
}
}, },
"include": [".", "../../types/shared.d.ts"] "include": [".", "../../types/shared.d.ts"]
} }

@ -1,4 +1,12 @@
import { SiteData } from '/@types/shared' import { SiteData } from '../../types/shared'
export type {
SiteData,
PageData,
HeadConfig,
LocaleConfig,
Header
} from '../../types/shared'
export const inBrowser = typeof window !== 'undefined' export const inBrowser = typeof window !== 'undefined'
@ -14,7 +22,7 @@ function findMatchRoot(route: string, roots: string[]) {
}) })
for (const r of roots) { for (const r of roots) {
if (route.startsWith(r)) return r if (route.startsWith(r)) return
} }
return undefined return undefined
} }

@ -1,10 +1,7 @@
{ {
"extends": "../../tsconfig.json", "extends": "../../tsconfig.json",
"compilerOptions": { "compilerOptions": {
"baseUrl": ".", "baseUrl": "."
"paths": {
"/@types/*": ["../../types/*"]
}
}, },
"include": [".", "../../types/shared.d.ts"] "include": [".", "../../types/shared.d.ts"]
} }

@ -17,7 +17,6 @@
"shared/*": ["src/shared/*"], "shared/*": ["src/shared/*"],
"tests/*": ["__tests__/*"], "tests/*": ["__tests__/*"],
"/@shared/*": ["src/client/shared/*"], "/@shared/*": ["src/client/shared/*"],
"/@types/*": ["types/*"],
"vitepress": ["src/client/index.ts"] "vitepress": ["src/client/index.ts"]
} }
}, },

Loading…
Cancel
Save