Skip to content

Commit 12d6493

Browse files
committed
fix: fixed the issue where the image preview function could not be used on some pages.
1 parent 24977c4 commit 12d6493

File tree

9 files changed

+195
-74
lines changed

9 files changed

+195
-74
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,155 @@
1+
// .vitepress/config.ts
2+
import { defineConfigWithTheme } from "file:///Users/hacxy/Projects/vitepress-theme-mild/node_modules/.pnpm/vitepress@1.6.1_@algolia+client-search@5.18.0_@types+node@20.14.9_async-validator@4.2.5_light_32gskswphm2krivmguvncrv3kq/node_modules/vitepress/dist/node/index.js";
3+
import baseConfig from "file:///Users/hacxy/Projects/vitepress-theme-mild/packages/theme/config/index.js";
4+
5+
// ../theme/package.json
6+
var package_default = {
7+
name: "vitepress-theme-mild",
8+
type: "module",
9+
version: "0.6.0",
10+
description: "A VitePress theme with rich capabilities.",
11+
author: {
12+
name: "Hacxy",
13+
email: "hacxy.js@outlook.com"
14+
},
15+
license: "MIT",
16+
homepage: "https://github.com/hacxy/vitepress-theme-mild",
17+
bugs: {
18+
url: "https://github.com/hacxy/vitepress-theme-mild/issues"
19+
},
20+
keywords: [
21+
"vitepress",
22+
"vitepress-theme"
23+
],
24+
module: "./index.js",
25+
types: "./types/index.d.ts",
26+
files: [
27+
"config",
28+
"index.ts",
29+
"src",
30+
"types"
31+
],
32+
scripts: {
33+
dev: "tsup --watch",
34+
build: "tsup",
35+
lint: "eslint .",
36+
"lint:fix": "eslint . --fix",
37+
"lint:staged": "eslint --fix",
38+
release: "node scripts/release.js",
39+
prepublishOnly: "npm run build",
40+
changelog: "conventional-changelog -p angular -i ../docs/CHANGELOG.md -s"
41+
},
42+
dependencies: {
43+
"@css-render/vue3-ssr": "^0.15.14",
44+
"@giscus/vue": "^3.1.1",
45+
"@iconify/vue": "^4.3.0",
46+
"@nanostores/vue": "^0.11.0",
47+
"@shikijs/vitepress-twoslash": "^1.24.3",
48+
"@vueuse/core": "^12.0.0",
49+
"@vueuse/motion": "^2.2.6",
50+
"directory-tree": "^3.5.2",
51+
"fs-extra": "^11.2.0",
52+
"gray-matter": "^4.0.3",
53+
"naive-ui": "^2.40.4",
54+
nanostores: "^0.11.3",
55+
nprogress: "^0.2.0",
56+
"reading-time-estimator": "^1.11.0",
57+
sass: "^1.78.0",
58+
"simple-git": "^3.27.0",
59+
tinyglobby: "^0.2.10",
60+
"typed.js": "^2.1.0",
61+
"vitepress-plugin-group-icons": "^1.3.2",
62+
"vitepress-plugin-rss": "^0.3.0",
63+
vue: "^3.4.21",
64+
"vue-easy-lightbox": "^1.19.0"
65+
},
66+
devDependencies: {
67+
"@types/fs-extra": "^11.0.4",
68+
"@types/markdown-it": "^14.1.2",
69+
"@types/node": "^20.14.9",
70+
"@types/nprogress": "^0.2.3",
71+
bumpp: "^9.9.1",
72+
tsup: "8.3.5",
73+
typescript: "^5.3.3",
74+
vitepress: "^1.6.1"
75+
}
76+
};
77+
78+
// .vitepress/config.ts
79+
var config_default = defineConfigWithTheme({
80+
title: "VitePress Mild Theme",
81+
description: "\u7B80\u7EA6\u98CE\u683C\u7684\u535A\u5BA2\u4E3B\u9898",
82+
extends: baseConfig,
83+
lang: "zh",
84+
appearance: "dark",
85+
themeConfig: {
86+
comment: {
87+
repo: "hacxy/vitepress-theme-mild",
88+
repoId: "R_kgDOLdAvmA",
89+
category: "Announcements",
90+
categoryId: "DIC_kwDOLdAvmM4Cl3ba",
91+
mapping: "title",
92+
strict: "1",
93+
reactionsEnabled: "1",
94+
inputPosition: "bottom",
95+
lang: "zh-CN",
96+
darkTheme: "catppuccin_macchiato",
97+
lightTheme: "catppuccin_latte"
98+
},
99+
progressBar: {
100+
speed: 200
101+
},
102+
rss: {
103+
title: "Hacxy",
104+
baseUrl: "https://theme.hacxy.cn",
105+
copyright: "Copyright (c) 2024-present, Hacxy"
106+
},
107+
logo: "/logo.png",
108+
search: {
109+
provider: "local",
110+
options: {
111+
detailedView: true,
112+
translations: {
113+
button: {
114+
buttonText: "\u641C\u7D22\u4E00\u4E0B"
115+
}
116+
}
117+
}
118+
},
119+
nav: [
120+
{
121+
text: "\u6307\u5357",
122+
link: "/guide/intro/",
123+
activeMatch: "/guide/"
124+
},
125+
{
126+
text: "\u53C2\u8003",
127+
link: "/config/"
128+
},
129+
{
130+
text: `v${package_default.version}`,
131+
items: [
132+
{
133+
text: "\u66F4\u65B0\u65E5\u5FD7",
134+
link: "CHANGELOG.md"
135+
}
136+
]
137+
}
138+
],
139+
socialLinks: [
140+
{ icon: "github", link: "https://github.com/hacxy/vitepress-theme-mild" }
141+
],
142+
sidebar: {
143+
"/guide/": "auto",
144+
"/config/": "auto"
145+
},
146+
footer: {
147+
message: "MIT Licensed",
148+
copyright: 'Copyright \xA9 2024-Present <a href="https://github.com/hacxy">Hacxy</a>'
149+
}
150+
}
151+
});
152+
export {
153+
config_default as default
154+
};
155+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": [".vitepress/config.ts", "../theme/package.json"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"/Users/hacxy/Projects/vitepress-theme-mild/packages/docs/.vitepress\";const __vite_injected_original_filename = \"/Users/hacxy/Projects/vitepress-theme-mild/packages/docs/.vitepress/config.ts\";const __vite_injected_original_import_meta_url = \"file:///Users/hacxy/Projects/vitepress-theme-mild/packages/docs/.vitepress/config.ts\";import type { ThemeConfig } from 'vitepress-theme-mild';\nimport { defineConfigWithTheme } from 'vitepress';\nimport baseConfig from 'vitepress-theme-mild/config';\nimport pkg from '../../theme/package.json';\n\nexport default defineConfigWithTheme<ThemeConfig>({\n  title: 'VitePress Mild Theme',\n  description: '\u7B80\u7EA6\u98CE\u683C\u7684\u535A\u5BA2\u4E3B\u9898',\n  extends: baseConfig,\n  lang: 'zh',\n  appearance: 'dark',\n  themeConfig: {\n    comment: {\n      repo: 'hacxy/vitepress-theme-mild',\n      repoId: 'R_kgDOLdAvmA',\n      category: 'Announcements',\n      categoryId: 'DIC_kwDOLdAvmM4Cl3ba',\n      mapping: 'title',\n      strict: '1',\n      reactionsEnabled: '1',\n      inputPosition: 'bottom',\n      lang: 'zh-CN',\n      darkTheme: 'catppuccin_macchiato',\n      lightTheme: 'catppuccin_latte'\n    },\n    progressBar: {\n      speed: 200\n    },\n    rss: {\n      title: 'Hacxy',\n      baseUrl: 'https://theme.hacxy.cn',\n      copyright: 'Copyright (c) 2024-present, Hacxy'\n    },\n    logo: '/logo.png',\n    search: {\n      provider: 'local',\n      options: {\n        detailedView: true,\n        translations: {\n          button: {\n            buttonText: '\u641C\u7D22\u4E00\u4E0B'\n          }\n        }\n      }\n    },\n    nav: [\n      {\n        text: '\u6307\u5357',\n        link: '/guide/intro/',\n        activeMatch: '/guide/'\n      },\n      {\n        text: '\u53C2\u8003',\n        link: '/config/',\n      },\n      {\n        text: `v${pkg.version}`,\n        items: [\n          {\n            text: '\u66F4\u65B0\u65E5\u5FD7',\n            link: 'CHANGELOG.md'\n          }\n        ]\n      }\n    ],\n    socialLinks: [\n      { icon: 'github', link: 'https://github.com/hacxy/vitepress-theme-mild' }\n    ],\n    sidebar: {\n      '/guide/': 'auto',\n      '/config/': 'auto',\n    },\n    footer: {\n      message: 'MIT Licensed',\n      copyright:\n        'Copyright \u00A9 2024-Present <a href=\"https://github.com/hacxy\">Hacxy</a>',\n    },\n  },\n});\n", "{\n  \"name\": \"vitepress-theme-mild\",\n  \"type\": \"module\",\n  \"version\": \"0.6.0\",\n  \"description\": \"A VitePress theme with rich capabilities.\",\n  \"author\": {\n    \"name\": \"Hacxy\",\n    \"email\": \"hacxy.js@outlook.com\"\n  },\n  \"license\": \"MIT\",\n  \"homepage\": \"https://github.com/hacxy/vitepress-theme-mild\",\n  \"bugs\": {\n    \"url\": \"https://github.com/hacxy/vitepress-theme-mild/issues\"\n  },\n  \"keywords\": [\n    \"vitepress\",\n    \"vitepress-theme\"\n  ],\n  \"module\": \"./index.js\",\n  \"types\": \"./types/index.d.ts\",\n  \"files\": [\n    \"config\",\n    \"index.ts\",\n    \"src\",\n    \"types\"\n  ],\n  \"scripts\": {\n    \"dev\": \"tsup --watch\",\n    \"build\": \"tsup\",\n    \"lint\": \"eslint .\",\n    \"lint:fix\": \"eslint . --fix\",\n    \"lint:staged\": \"eslint --fix\",\n    \"release\": \"node scripts/release.js\",\n    \"prepublishOnly\": \"npm run build\",\n    \"changelog\": \"conventional-changelog -p angular -i ../docs/CHANGELOG.md -s\"\n  },\n  \"dependencies\": {\n    \"@css-render/vue3-ssr\": \"^0.15.14\",\n    \"@giscus/vue\": \"^3.1.1\",\n    \"@iconify/vue\": \"^4.3.0\",\n    \"@nanostores/vue\": \"^0.11.0\",\n    \"@shikijs/vitepress-twoslash\": \"^1.24.3\",\n    \"@vueuse/core\": \"^12.0.0\",\n    \"@vueuse/motion\": \"^2.2.6\",\n    \"directory-tree\": \"^3.5.2\",\n    \"fs-extra\": \"^11.2.0\",\n    \"gray-matter\": \"^4.0.3\",\n    \"naive-ui\": \"^2.40.4\",\n    \"nanostores\": \"^0.11.3\",\n    \"nprogress\": \"^0.2.0\",\n    \"reading-time-estimator\": \"^1.11.0\",\n    \"sass\": \"^1.78.0\",\n    \"simple-git\": \"^3.27.0\",\n    \"tinyglobby\": \"^0.2.10\",\n    \"typed.js\": \"^2.1.0\",\n    \"vitepress-plugin-group-icons\": \"^1.3.2\",\n    \"vitepress-plugin-rss\": \"^0.3.0\",\n    \"vue\": \"^3.4.21\",\n    \"vue-easy-lightbox\": \"^1.19.0\"\n  },\n  \"devDependencies\": {\n    \"@types/fs-extra\": \"^11.0.4\",\n    \"@types/markdown-it\": \"^14.1.2\",\n    \"@types/node\": \"^20.14.9\",\n    \"@types/nprogress\": \"^0.2.3\",\n    \"bumpp\": \"^9.9.1\",\n    \"tsup\": \"8.3.5\",\n    \"typescript\": \"^5.3.3\",\n    \"vitepress\": \"^1.6.1\"\n  }\n}\n"],
  "mappings": "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",
  "names": []
}


packages/theme/src/client/components/ContentWrapper.vue

-8
Original file line numberDiff line numberDiff line change
@@ -1,13 +1,5 @@
11
<script lang="ts" setup>
2-
import { useImagePreview } from '../hooks/useImagePreview';
3-
4-
const props = defineProps<{
5-
imgsStr: string
6-
}>();
72
const classes = { 'slide-enter-content': !((import.meta as any).env.DEV) };
8-
const imgs = props.imgsStr.split(',');
9-
const { $images } = useImagePreview();
10-
$images.set(imgs);
113
</script>
124

135
<template>

packages/theme/src/client/components/ImagePreview.vue

+2-2
Original file line numberDiff line numberDiff line change
@@ -2,14 +2,14 @@
22
import VueEaseLightBox from 'vue-easy-lightbox';
33
import { useImagePreview } from '../hooks/useImagePreview';
44
5-
const { visible, hide, currentIndex, images } = useImagePreview();
5+
const { visible, hide, currentIndex, imgs } = useImagePreview();
66
</script>
77

88
<template>
99
<VueEaseLightBox
1010
move-disabled
1111
loop
12-
:imgs="images"
12+
:imgs="imgs"
1313
:visible="visible"
1414
:index="currentIndex"
1515
@hide="hide"

packages/theme/src/client/datas/base.data.ts

+2
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,7 @@ export interface ArticlesData {
2323
category: string
2424
order: number
2525
sidebar: boolean | SidebarFrontmatter
26+
imgs: string[]
2627
}
2728

2829
export default createBaseDataLoader({
@@ -48,6 +49,7 @@ export default createBaseDataLoader({
4849
path: item.url,
4950
description,
5051
title,
52+
imgs: item.imgs,
5153
words,
5254
minutes,
5355
date,

packages/theme/src/client/datas/base.ts

+21-15
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@ export interface ContentData {
1616
html: string | undefined
1717
frontmatter: Record<string, any>
1818
excerpt: string | undefined
19+
imgs: string[]
1920
// fileModifiedTime: number
2021
}
2122
export interface ContentOptions<T = ContentData[]> {
@@ -177,7 +178,6 @@ function handleAutoSidebar(config: SiteConfig, data: Map<string, ContentData>) {
177178
}
178179
});
179180
}
180-
181181
return autoSidebar;
182182
}
183183

@@ -199,8 +199,7 @@ export function createBaseDataLoader<T = {
199199

200200
if (!config) {
201201
throw new Error(
202-
'content loader invoked without an active vitepress process, '
203-
+ 'or before vitepress config is resolved.'
202+
'content loader invoked without an active vitepress process, ' + 'or before vitepress config is resolved.'
204203
);
205204
}
206205
const pattern = getPattern(config.srcDir);
@@ -227,7 +226,6 @@ export function createBaseDataLoader<T = {
227226
if (cached.data.frontmatter.publish !== false) {
228227
raw.push(cached.data);
229228
}
230-
231229
sidebarMapData.set(file, cached.data);
232230
}
233231
else {
@@ -254,23 +252,31 @@ export function createBaseDataLoader<T = {
254252
else {
255253
frontmatter.sticky = 0;
256254
}
257-
const url
258-
= `/${
259-
normalizePath(path.relative(config.srcDir, file))
260-
.replace(/(^|\/)index\.md$/, '$1')
261-
.replace(/\.md$/, config.cleanUrls ? '' : '.html')}`;
255+
const url = `/${normalizePath(path.relative(config.srcDir, file))
256+
.replace(/(^|\/)index\.md$/, '$1')
257+
.replace(/\.md$/, config.cleanUrls ? '' : '.html')}`;
262258

263259
const html = render ? md.render(src) : undefined;
264-
// const fileModifiedTime = timestamp;
265-
const renderedExcerpt = renderExcerpt
266-
? excerpt && md.render(excerpt)
267-
268-
: undefined;
260+
const tokens = md.parse(src, {});
261+
const imgs: string[] = [];
262+
tokens.forEach(token => {
263+
if (token.type === 'inline' && token.children) {
264+
token.children.forEach(child => {
265+
if (child.type === 'image') {
266+
const src = child.attrGet('src');
267+
if (src) {
268+
imgs.push(src);
269+
}
270+
}
271+
});
272+
}
273+
});
274+
const renderedExcerpt = renderExcerpt ? excerpt && md.render(excerpt) : undefined;
269275
const data: ContentData = {
270-
// fileModifiedTime,
271276
path: file,
272277
src: includeSrc ? src : undefined,
273278
html,
279+
imgs,
274280
frontmatter,
275281
excerpt: renderedExcerpt,
276282
url

packages/theme/src/client/hooks/useArticleData.ts

-23
This file was deleted.

packages/theme/src/client/hooks/useImagePreview.ts

+6-5
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,17 @@
11
import { useStore } from '@nanostores/vue';
22
import { atom } from 'nanostores';
3+
import { computed } from 'vue';
4+
import { useArticleListStore } from '../store/article';
35

46
const $visible = atom(false);
57
const $currentIndex = atom(0);
6-
const $images = atom<string[]>([]);
78

89
export function useImagePreview() {
910
const visible = useStore($visible);
1011
const currentIndex = useStore($currentIndex);
11-
const images = useStore($images as any);
12-
12+
const { currentArticle } = useArticleListStore();
13+
// const images = useStore($images as any);
14+
const imgs = computed(() => currentArticle.value?.imgs as string[] || []);
1315
function show(index: number) {
1416
$visible.set(true);
1517
$currentIndex.set(index);
@@ -24,7 +26,6 @@ export function useImagePreview() {
2426
currentIndex,
2527
show,
2628
hide,
27-
images,
28-
$images
29+
imgs
2930
};
3031
}
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,20 @@
11
import type { ArticlesData } from '../datas/base.data';
22
import { useStore } from '@nanostores/vue';
33
import { atom } from 'nanostores';
4+
import { useRoute } from 'vitepress';
5+
import { computed } from 'vue';
46

57
export const $articleList = atom<ArticlesData[]>([]);
68

79
export function useArticleListStore() {
810
const articleList = useStore($articleList);
11+
const route = useRoute();
12+
const currentArticle = computed(() => {
13+
return articleList.value.find(item => item.path === route.path);
14+
});
15+
916
return {
17+
currentArticle,
1018
articleList
1119
};
1220
}

0 commit comments

Comments
 (0)