此技能用于在本地启动只读 Web 面板,实时查看网文创作进度、设定词典、关系图谱、章节内容与追读力数据。面板为纯只读,不提供修改接口。
WORKSPACE_ROOT="${PWD}"
# 设置 Dashboard 目录(指向原项目 dashboard 目录,需用户配置)
DASHBOARD_DIR="C:/Users/Administrator/Desktop/ide/webnovel-writer-master/webnovel-writer/dashboard"
# 设置脚本目录
SCRIPTS_DIR="C:/Users/Administrator/Desktop/ide/webnovel-writer-master/webnovel-writer/scripts"
# 检查 Dashboard 模块是否存在
if [ ! -d "${DASHBOARD_DIR}" ]; then
echo "ERROR: 未找到 dashboard 模块: ${DASHBOARD_DIR}" >&2
exit 1
fi
> 重要:用户需要先确认 webnovel-writer-master 的 dashboard 目录路径,并配置 DASHBOARD_DIR 变量。
# 安装 Python 依赖
python -m pip install -r "${DASHBOARD_DIR}/requirements.txt" --quiet
# 解析项目根目录
PROJECT_ROOT="$(python "${SCRIPTS_DIR}/webnovel.py" --project-root "${WORKSPACE_ROOT}" where)"
echo "项目路径: ${PROJECT_ROOT}"
补充要求:
PROJECT_ROOT 必须解析成功
# 设置 PYTHONPATH 以让 Python 找到 dashboard 模块
export PYTHONPATH="${DASHBOARD_DIR}/..:${PYTHONPATH:-}"
# 检查前端构建产物是否存在
if [ ! -f "${DASHBOARD_DIR}/frontend/dist/index.html" ]; then
echo "ERROR: 缺少前端构建产物 ${DASHBOARD_DIR}/frontend/dist/index.html" >&2
echo "提示:Dashboard 前端需要预先构建,或检查插件是否完整安装" >&2
exit 1
fi
# 启动 Dashboard 服务
python -m dashboard.server --project-root "${PROJECT_ROOT}"
可选参数:
--no-browser - 不自动打开浏览器,手动访问输出的 URL
--port 9000 - 自定义端口(默认 8080)
启动后优先确认以下接口可用:
http://localhost:8080/api/story-runtime/health - Story Runtime 健康状态
http://localhost:8080/api/preflight - 预检接口
启动后,浏览器会自动打开 Dashboard 页面,主要功能包括:
.story-system/ 合同树)
PROJECT_ROOT 范围内
--port <端口号>
--no-browser 模式下 URL 可手动访问)
| 故障 | 恢复方式 |
|------|---------|
| 依赖安装失败 | 检查 Python 版本和网络,手动 pip install -r requirements.txt |
| 前端 dist/ 缺失 | 确认插件完整安装,dist 应随插件打包;或运行前端构建命令 |
| 项目根解析失败 | 检查 .webnovel/state.json 是否存在,确认 WORKSPACE_ROOT 正确 |
| 端口占用 | 使用 --port <其他端口> 或关闭占用进程 |
| 页面空白/数据缺失 | 确认 .webnovel/ 下有 state.json、index.db 等数据文件 |
PROJECT_ROOT 范围内
| 文件 | 路径 |
|------|------|
| Dashboard 服务端 | webnovel-writer/dashboard/server.py |
| Dashboard 前端 | webnovel-writer/dashboard/frontend/ |
| Dashboard 路径守卫 | webnovel-writer/dashboard/path_guard.py |
| Dashboard 文件监控 | webnovel-writer/dashboard/watcher.py |
共 1 个版本