fix(biji-qianduan): 优化私密笔记和回收站的访问控制
- 移除 HomePage 中重复的私密笔记提示逻辑 - 在 markdown-preview 中通过条件渲染显示私密笔记提示- 为未登录用户提供回收站访问限制 - 新增私密笔记提示内容的单独文件
This commit is contained in:
@@ -69,10 +69,7 @@
|
||||
</div>
|
||||
</el-header>
|
||||
<div v-if="!showEditor" :key="selectedFile.id" class="markdown-preview">
|
||||
<div v-if="selectedFile.isPrivate === 1 && !userStore.isLoggedIn && !selectedFile.content" class="private-note-notice">
|
||||
<el-icon><Lock /></el-icon>
|
||||
<p>这是私密笔记,请登录后查看完整内容</p>
|
||||
</div>
|
||||
<!-- 私密笔记提示区域由JS渲染 -->
|
||||
</div>
|
||||
<!-- Vditor 编辑器 -->
|
||||
<div v-show="showEditor" id="vditor" class="vditor" />
|
||||
@@ -312,6 +309,7 @@ import {
|
||||
import { Plus, Fold, Expand, Folder, Document, Search, Edit, Delete, ArrowDown, Clock, Lock, InfoFilled } from "@element-plus/icons-vue";
|
||||
import { useUserStore } from '../stores/user';
|
||||
import { useRouter } from 'vue-router';
|
||||
import { privateNoteContent } from '../utils/privateNoteContent.js';
|
||||
|
||||
const userStore = useUserStore();
|
||||
const router = useRouter();
|
||||
@@ -610,10 +608,8 @@ const previewFile = async (file) => {
|
||||
};
|
||||
showEditor.value = false; // 确保进入预览模式
|
||||
|
||||
// 如果是私密笔记且用户未登录,显示提示
|
||||
if (file.isPrivate === 1 && !userStore.isLoggedIn) {
|
||||
ElMessage.info('这是私密笔记,请登录后查看完整内容');
|
||||
}
|
||||
// 如果是私密笔记且用户未登录,内容会被后端置空,这里不需要额外提示
|
||||
// 提示信息已经在模板中通过条件渲染显示
|
||||
} catch (error) {
|
||||
ElMessage.error('获取笔记内容失败: ' + error.message);
|
||||
selectedFile.value = null;
|
||||
@@ -1054,13 +1050,26 @@ watch([selectedFile, showEditor], ([newFile, newShowEditor]) => {
|
||||
nextTick(() => {
|
||||
const previewElement = document.querySelector('.markdown-preview');
|
||||
if (previewElement) {
|
||||
Vditor.preview(previewElement, newFile.content, {
|
||||
mode: 'light',
|
||||
hljs: {
|
||||
enable: true,
|
||||
style: 'github'
|
||||
}
|
||||
});
|
||||
// 如果是私密笔记且用户未登录,显示提示内容
|
||||
if (newFile.isPrivate === 1 && !userStore.isLoggedIn) {
|
||||
// 渲染私密笔记提示内容
|
||||
Vditor.preview(previewElement, privateNoteContent, {
|
||||
mode: 'light',
|
||||
hljs: {
|
||||
enable: true,
|
||||
style: 'github'
|
||||
}
|
||||
});
|
||||
} else if (newFile.content) {
|
||||
// 只有在有内容时才渲染 Markdown
|
||||
Vditor.preview(previewElement, newFile.content, {
|
||||
mode: 'light',
|
||||
hljs: {
|
||||
enable: true,
|
||||
style: 'github'
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user