-
-
Notifications
You must be signed in to change notification settings - Fork 167
/
Copy path.dumirc.ts
125 lines (117 loc) · 3.13 KB
/
.dumirc.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
import { defineConfig } from 'dumi';
import type { SiteThemeConfig } from 'dumi-theme-lobehub';
import type { INavItem } from 'dumi/dist/client/theme-api/types';
import { resolve } from 'node:path';
import { description, homepage, name } from './package.json';
const isProduction = process.env.NODE_ENV === 'production';
const isWin = process.platform === 'win32';
export const packages = [
'awesome',
'brand',
'chat',
'color',
'icons',
'mdx',
'mobile',
'storybook',
];
const nav: INavItem[] = [
{ link: '/components/action-icon', title: 'Components' },
{ link: '/components/chat/chat-input-area', title: 'Chat' },
{ link: '/components/mobile/mobile-chat-input-area', title: 'Mobile' },
{ link: '/components/awesome/features', title: 'Awesome' },
{ link: '/components/brand/lobe-hub', title: 'Brand' },
{ link: '/components/mdx/callout', title: 'Mdx' },
{ link: '/components/color/color-scales', title: 'Color' },
{ link: '/changelog', title: 'Changelog' },
];
const themeConfig: SiteThemeConfig = {
actions: [
{
icon: 'Github',
link: homepage,
openExternal: true,
text: 'GitHub',
},
{
link: '/components/action-icon',
text: 'Get Started',
type: 'primary',
},
],
analytics: {
plausible: {
domain: 'ui.lobehub.com',
scriptBaseUrl: 'https://plausible.lobehub-inc.cn',
},
},
apiHeader: {
docUrl: `{github}/tree/master/src/{atomId}/index.md`,
match: ['/components'],
pkg: name,
sourceUrl: `{github}/tree/master/src/{atomId}/index.tsx`,
},
description,
giscus: {
category: 'Q&A',
categoryId: 'DIC_kwDOJloKoM4CXsCu',
repo: 'lobehub/lobe-ui',
repoId: 'R_kgDOJloKoA',
},
lastUpdated: true,
metadata: {
openGraph: {
image:
'https://repository-images.githubusercontent.com/643435168/789cab53-cae5-43fa-965d-5928c3c63c1c',
},
},
name: 'UI',
nav,
prefersColor: {
default: 'dark',
switch: false,
},
socialLinks: {
discord: 'https://discord.gg/AYFPHvv2jT',
github: homepage,
},
title: 'Lobe UI',
};
const alias: Record<string, string> = {};
for (const pkg of packages) alias[`@lobehub/ui/${pkg}`] = resolve(__dirname, `./src/${pkg}`);
export default defineConfig({
alias,
apiParser: isProduction ? {} : false,
base: '/',
define: {
'process.env': process.env,
},
exportStatic: {},
extraBabelPlugins: ['babel-plugin-antd-style'],
favicons: ['https://lobehub.com/favicon.ico'],
jsMinifier: 'swc',
locales: [{ id: 'en-US', name: 'English' }],
mako: isWin || isProduction ? false : {},
mfsu: isWin ? undefined : {},
npmClient: 'pnpm',
publicPath: '/',
resolve: {
atomDirs: [
{ dir: 'src', type: 'component' },
...packages.map((pkg) => ({ dir: `src/${pkg}`, subType: pkg, type: 'component' })),
],
entryFile: isProduction ? './src/index.ts' : undefined,
},
sitemap: {
hostname: 'https://ui.lobehub.com',
},
ssr: isProduction ? {} : false,
styles: [
`html, body { background: transparent; }
@media (prefers-color-scheme: dark) {
html, body { background: #000; }
}`,
],
themeConfig,
title: 'Lobe UI',
});