Compare commits

...

29 Commits

Author SHA1 Message Date
liumangmang
48f04577dc feat: 更新4月待办任务状态:巡视报告配置异常补充前端修复说明,linx80 excel问题标记为已完成 2026-04-09 11:03:45 +08:00
liumangmang
2b118d7409 feat: 新增4月待办:告警阈值xml导入限制功能 2026-04-03 15:40:15 +08:00
liumangmang
8d824d12cd feat: 标记3月待办#8贵州大唐机器人告警复检需求为已完成 2026-04-03 10:26:32 +08:00
liumangmang
26a6db037a feat: 标记4月待办巡视报告配置异常任务为已完成 2026-04-03 10:11:30 +08:00
liumangmang
26f2215955 feat: 标记3月待办16、21号任务为已完成 2026-04-02 20:33:52 +08:00
liumangmang
e3bf2f6870 feat: 新增4月待办:修复现场linx80 excel打开失败问题 2026-04-02 11:26:31 +08:00
liumangmang
f90e7a6566 feat: 修复所有缺失图标,新增4月待办,更新3月待办内容 2026-04-02 10:06:09 +08:00
liumangmang
19635c9c76 docs: 新增待办任务22-优化服务调用失败异常反馈 2026-03-30 19:41:21 +08:00
liumangmang
3a2af24c94 docs: 调整任务16位置,从已完成移至待启动 2026-03-30 19:26:40 +08:00
liumangmang
9e59e1dbea docs: 完成XFCE终端快捷指令文章 2026-03-30 17:11:36 +08:00
liumangmang
6c7e911364 docs: 添加自定义配置和总结 2026-03-30 17:05:56 +08:00
liumangmang
6ac8a8c824 docs: 添加高级功能类快捷键 2026-03-30 17:04:40 +08:00
liumangmang
b4d9e15a65 docs: 添加显示调整类快捷键 2026-03-30 17:03:29 +08:00
liumangmang
5e88779532 docs: 添加编辑操作类快捷键 2026-03-30 17:02:11 +08:00
liumangmang
4738fb6c84 docs: 添加基础导航类快捷键 2026-03-30 17:01:10 +08:00
liumangmang
4b511285b9 docs: 创建XFCE终端快捷指令文章框架 2026-03-30 16:59:53 +08:00
liumangmang
d685a22b60 docs(work): 更新第20项录像回放权限问题修复为已完成 2026-03-30 15:43:39 +08:00
liumangmang
158270b3b0 docs(work): 更新第12项超期逻辑和红外温度矩阵功能同步为已完成 2026-03-30 11:22:26 +08:00
liumangmang
9b88b06e4c refactor(work): 重构待办事项为按月目录结构并更新3月待办 2026-03-30 11:10:03 +08:00
b5769edf7e docs(frontend-tools): add advanced vscode workflow and config guide 2026-03-30 02:38:04 +08:00
2068733f0d docs(frontend-tools): add vscode quick start for command palette and settings json 2026-03-30 00:41:49 +08:00
liumangmang
9b37932b46 docs(work): 新增删除点位关联阈值告警待办 2026-03-27 15:24:07 +08:00
liumangmang
7959ed9943 docs(work): 新增声纹模型模板必填项待办 2026-03-27 11:22:35 +08:00
liumangmang
cf637d29bb docs(work): 更新待办事项 2026-03-26 18:03:13 +08:00
liumangmang
dc6e69ae00 docs: update docker port and compose version 2026-03-26 17:18:19 +08:00
liumangmang
4967356f22 docs: add docker deploy instructions 2026-03-26 17:10:50 +08:00
liumangmang
1a0c14c683 feat: add make targets for docker deploy 2026-03-26 16:56:48 +08:00
liumangmang
a1bf9e1d4b feat: add compose service for production deploy 2026-03-26 16:53:17 +08:00
liumangmang
7238aa9ca5 feat: add docker build for static site 2026-03-26 16:45:03 +08:00
16 changed files with 1084 additions and 131 deletions

5
.dockerignore Normal file
View File

@@ -0,0 +1,5 @@
node_modules
dist
src/.vuepress/dist
.git
*.log

13
Dockerfile Normal file
View File

@@ -0,0 +1,13 @@
FROM node:20-alpine AS build
WORKDIR /app
COPY package.json package-lock.json ./
RUN npm ci
COPY . .
RUN npm run docs:build
FROM nginx:1.25-alpine
COPY --from=build /app/src/.vuepress/dist /usr/share/nginx/html

7
Makefile Normal file
View File

@@ -0,0 +1,7 @@
.PHONY: up down
up:
docker compose up -d --build
down:
docker compose down

View File

@@ -42,6 +42,24 @@ npm run docs:build
构建产物将生成在 `src/.vuepress/dist` 目录
### Docker 部署
需要先安装 Docker 和 Docker Compose v2。
启动服务:
```bash
make up
```
访问 `http://localhost:51888/` 即可查看站点。
停止服务:
```bash
make down
```
### 清除缓存开发
```bash

8
docker-compose.yml Normal file
View File

@@ -0,0 +1,8 @@
services:
myblog:
image: myblog:latest
build:
context: .
ports:
- '51888:80'
restart: unless-stopped

View File

@@ -0,0 +1,75 @@
# Docker deployment (make up/down)
## Context
- Project: VuePress v2 static blog (Vite).
- Goal: one-command production deployment and teardown via `make up` and `make down`.
- Hosting: root path `/`.
- Port mapping: host `6666` -> container `80`.
## Goals
- Provide a reproducible, production-grade deployment using Docker.
- Keep operator commands minimal (`make up`, `make down`).
- Ensure build failures fail fast and are visible.
## Non-goals
- No development-mode container (`vuepress-vite dev`).
- No additional runtime dependencies besides Docker.
- No advanced orchestration (k8s, swarm).
## Assumptions
- Docker Engine and Docker Compose v2 are available on the host.
- `package-lock.json` is present; builds use `npm ci`.
## Proposed architecture
- Multi-stage Docker image:
- Stage 1 (build): Node image installs dependencies and runs `docs:build`.
- Stage 2 (run): Nginx serves the generated static files.
- `docker-compose.yml` manages a single service (e.g., `myblog`).
- `Makefile` wraps compose commands for consistent UX.
## Components
### Dockerfile
- Base images: `node:20-alpine` (build), `nginx:1.25-alpine` (run).
- Stage 1:
- Workdir set to app root.
- Copy `package.json` + `package-lock.json`, run `npm ci`.
- Copy source and run `npm run docs:build`.
- Stage 2:
- Copy `src/.vuepress/dist/` to `/usr/share/nginx/html`.
- Use default Nginx config for root `/`.
### .dockerignore
- Exclude: `node_modules`, `dist`, `src/.vuepress/dist`, `.git`, `*.log`.
### docker-compose.yml
- Service name: `myblog`.
- Build context: repository root.
- Image name: `myblog:latest`.
- Port mapping: `6666:80`.
- Restart policy: `unless-stopped`.
### Makefile
- `make up`: `docker compose up -d --build`.
- `make down`: `docker compose down`.
- Optional commands (if desired later): `make logs`, `make ps`, `make rebuild`.
## Runtime flow
1. Operator runs `make up`.
2. Docker builds image (install deps -> build static site).
3. Nginx container starts and serves static files.
4. Operator runs `make down` to stop and remove the service.
## Error handling
- Build failures (dependency install or VuePress build) cause `make up` to fail and exit.
- Compose output provides the error details for diagnosis.
## Verification
- Access `http://<host>:6666/` and confirm the site loads.
- Optional: `docker compose logs -f` for runtime inspection.
## Security / operations
- No secrets are required.
- Container only exposes HTTP on port 80 inside the compose network.
## Open questions
- None. All required inputs confirmed (production mode, root path, port 6666).

View File

@@ -209,8 +209,25 @@ export default sidebar({
},
{
text: "待办事项",
icon: "mdi:checklist",
link: "/work/待办事项.md",
icon: "fa6-solid:list-check",
collapsible: true,
children: [
{
text: "待办首页",
icon: "mdi:home-outline",
link: "/work/todo/",
},
{
text: "4月待办",
icon: "mdi:calendar-month",
link: "/work/todo/2026-04.md",
},
{
text: "3月待办",
icon: "mdi:calendar-month",
link: "/work/todo/2026-03.md",
},
],
}
],
"/apps/": [
@@ -239,79 +256,88 @@ export default sidebar({
"/ai/": [
{
text: "OpenCode",
icon: "mdi:application-braces-outline",
icon: "fa6-solid:code",
collapsible: true,
children: [
{
text: "opencode-cli",
icon: "fa6-solid:terminal",
link: "opencode.md",
},
{
text: "opencode-tui",
icon: "fa6-solid:desktop",
link: "opencode-tui.md",
},
],
},
{
text: "Superpowers",
icon: "mdi:rocket-launch-outline",
icon: "fa6-solid:rocket",
collapsible: true,
prefix: "superpowers/",
children: [
{
text: "superpowers-总览",
icon: "fa6-solid:eye",
link: "opencode-superpowers-overview.md",
},
{
text: "superpowers",
icon: "fa6-solid:bolt",
link: "opencode-superpowers.md",
},
{
text: "skills-使用方案汇总",
icon: "fa6-solid:book",
link: "opencode-skills-playbook.md",
},
],
},
{
text: "Claude Code",
icon: "mdi:source-branch",
icon: "fa6-solid:code-branch",
collapsible: true,
children: [
{
text: "多分支工作流实战总结2026",
icon: "fa6-solid:code-merge",
link: "claude-code-branch-workflow-2026.md",
},
],
},
{
text: "ChatGPT",
icon: "mdi:chat-processing-outline",
icon: "fa6-solid:comments",
collapsible: true,
children: [
{
text: "chatgpt-使用记录与实践",
icon: "fa6-solid:message",
link: "chatgpt.md",
},
],
},
{
text: "OpenClaw",
icon: "mdi:robot-outline",
icon: "fa6-solid:robot",
collapsible: true,
children: [
{
text: "openclaw-24h在线部署实战",
icon: "fa6-solid:server",
link: "openclaw.md",
},
],
},
{
text: "iFlow",
icon: "mdi:sitemap-outline",
icon: "fa6-solid:diagram-project",
collapsible: true,
children: [
{
text: "iflow-流程编排实践记录",
icon: "fa6-solid:flow-chart",
link: "iflow.md",
},
],

View File

@@ -0,0 +1,210 @@
---
title: VSCode 进阶:命令面板工作流与配置治理
icon: simple-icons:visualstudiocode
date: 2026-03-30
category:
- 开发工具
- 前端
tag:
- VSCode
- 命令面板
- settings.json
- keybindings.json
- Windows
- Linux
---
# VSCode 进阶:命令面板工作流与配置治理
这篇是入门篇的下一步,目标是把 VSCode 从“会用”升级到“高效、可维护”。
重点只讲三块:
1. 命令面板的进阶工作流
2. 配置文件分层治理User / Workspace / Profile
3. 可复用的进阶 JSON 模板
<!-- more -->
## 1. 命令面板进阶:把常用动作变成肌肉记忆
命令面板入口不变:`Ctrl + Shift + P`Windows / Linux
建议只记住下面这组高频命令:
1. `>Preferences: Open User Settings (JSON)`
2. `>Preferences: Open Workspace Settings (JSON)`
3. `>Preferences: Open Keyboard Shortcuts (JSON)`
4. `>Tasks: Configure Task`
5. `>Developer: Reload Window`
6. `>Profiles: Create Profile`
7. `>Extensions: Show Installed Extensions`
实战思路:遇到任何需求,先用命令面板搜“动词 + 目标”,比如 `open settings json``create profile`
## 2. 配置治理模型:谁该放在哪里
### 2.1 User settings全局
- Windows: `%APPDATA%\\Code\\User\\settings.json`
- Linux: `~/.config/Code/User/settings.json`
放“个人偏好”:字体、自动保存、终端默认 shell、编辑体验。
### 2.2 Workspace settings项目
- 项目路径:`.vscode/settings.json`
放“项目约束”:缩进、格式化策略、特定语言规则、排除目录。
### 2.3 Profile场景
Profile 适合“多工作模式”用户,例如:
- `Frontend`:前端开发扩展 + 偏好
- `Backend`:后端开发扩展 + 偏好
- `Minimal`:低干扰写作/阅读模式
建议:
- 固定偏好放 User
- 项目规范放 Workspace
- 场景差异放 Profile
## 3. keybindings.json给命令面板加速
打开方式:
- `Ctrl + Shift + P`
- 输入 `Open Keyboard Shortcuts (JSON)`
示例Windows / Linux 通用):
```json
[
{
"key": "ctrl+alt+r",
"command": "workbench.action.reloadWindow"
},
{
"key": "ctrl+alt+,",
"command": "workbench.action.openSettingsJson"
},
{
"key": "ctrl+alt+t",
"command": "workbench.action.tasks.runTask"
}
]
```
注意如果快捷键冲突VSCode 会以后定义或更具体 `when` 条件为准。
## 4. 进阶 settings.json 模板Windows + Linux
下面模板建议放在 User 级,并按你环境微调:
```json
{
"editor.fontSize": 14,
"editor.lineHeight": 1.7,
"editor.tabSize": 2,
"editor.wordWrap": "on",
"editor.minimap.enabled": false,
"editor.bracketPairColorization.enabled": true,
"files.autoSave": "onFocusChange",
"files.trimTrailingWhitespace": true,
"files.insertFinalNewline": true,
"files.watcherExclude": {
"**/.git/objects/**": true,
"**/node_modules/**": true,
"**/dist/**": true
},
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.codeActionsOnSave": {
"source.fixAll": "explicit",
"source.organizeImports": "explicit"
},
"terminal.integrated.defaultProfile.windows": "PowerShell",
"terminal.integrated.defaultProfile.linux": "bash",
"workbench.startupEditor": "none",
"workbench.editor.enablePreview": false,
"workbench.tree.indent": 16
}
```
如果你不用 Prettier`editor.defaultFormatter` 改成你实际使用的扩展 ID。
## 5. Workspace 模板:把项目规范写死
建议每个项目都放一个最小 `.vscode/settings.json`
```json
{
"editor.tabSize": 2,
"editor.insertSpaces": true,
"editor.detectIndentation": false,
"files.eol": "\n"
}
```
这样团队成员打开项目时,基础编辑行为就能统一。
## 6. 命令面板 + Task一键执行项目动作
进阶建议:把常用命令(如构建、测试)写进 Task再通过命令面板触发。
`.vscode/tasks.json` 示例:
```json
{
"version": "2.0.0",
"tasks": [
{
"label": "docs:build",
"type": "shell",
"command": "npm run docs:build",
"group": "build",
"problemMatcher": []
}
]
}
```
触发方式:
1. `Ctrl + Shift + P`
2. 输入 `Run Task`
3. 选择 `docs:build`
## 7. 常见坑与排查
### 7.1 改了配置却没生效
先执行 `Developer: Reload Window`,再验证。
### 7.2 User 和 Workspace 打架
按“项目优先”原则,检查 `.vscode/settings.json` 是否覆盖了 User。
### 7.3 JSON 报错
确保:
- 不要尾逗号
- 全部键名和字符串使用双引号
- 文件是合法 JSON不是 JSONC 风格时不要写注释)
## 8. 进阶完成标准
- [ ] 能通过命令面板完成设置、任务、重载
- [ ] 能区分 User / Workspace / Profile 三层职责
- [ ] 有自己的 `keybindings.json` 高频快捷键
- [ ] 有项目级 `.vscode/settings.json` 规范
- [ ] 能用 `tasks.json` 一键触发常用命令
做到这 5 点VSCode 就从“编辑器”变成你的“稳定开发操作台”。

View File

@@ -0,0 +1,180 @@
---
title: VSCode 使用入门:命令面板与 settings.json
icon: simple-icons:visualstudiocode
date: 2026-03-30
category:
- 开发工具
- 前端
tag:
- VSCode
- 命令面板
- settings.json
- Windows
- Linux
---
# VSCode 使用入门:命令面板与 settings.json
这是一篇极速 15 分钟上手指南,重点只讲三件事:
1. VSCode 的基本概念
2. 命令面板怎么高频使用
3. 不进图形化设置,直接改 `settings.json`
<!-- more -->
## 1. 先认识 4 个核心概念
### 1.1 编辑器 vs 工作区
- **编辑器**:你看到和编辑代码的窗口。
- **工作区Workspace**:当前打开的项目(一个或多个文件夹)。
### 1.2 配置分层(最重要)
VSCode 的设置是分层生效的:
1. **默认设置Default**VSCode 内置。
2. **用户设置User**:你机器上的全局偏好。
3. **工作区设置Workspace**:只对当前项目生效。
如果同一个键同时存在,通常是 `Workspace` 覆盖 `User`
### 1.3 命令面板Command Palette
命令面板是 VSCode 的“统一入口”。
- Windows/Linux`Ctrl + Shift + P`
- 也可按 `F1`
你可以在这里执行几乎所有操作,包括打开 JSON 配置。
### 1.4 扩展不是“额外功能”,而是能力层
VSCode 本体很轻,很多语言能力来自扩展。
但本篇先不讲扩展安装,先把命令面板和配置体系打通。
## 2. 命令面板:先会这 6 条命令
`Ctrl + Shift + P` 后直接输入:
1. `>` + `Reload Window`:重载窗口,配置变更后常用。
2. `>Developer: Reload Window`:同上,完整命令名。
3. `>Preferences: Open User Settings (JSON)`:打开全局配置。
4. `>Preferences: Open Workspace Settings (JSON)`:打开项目配置。
5. `>Preferences: Open Default Settings (JSON)`:查看默认值(只读参考)。
6. `>Files: Auto Save`:快速切自动保存策略。
技巧:命令面板支持模糊搜索,你记不全命令名也能找到。
## 3. settings.json 到底放哪
### 3.1 用户配置(全局)
- Windows: `%APPDATA%\\Code\\User\\settings.json`
- Linux: `~/.config/Code/User/settings.json`
建议:全局偏好(字体、自动保存、格式化默认行为)放这里。
### 3.2 工作区配置(项目级)
- 项目根目录:`.vscode/settings.json`
建议:和项目强相关的配置放这里(例如某项目缩进、格式化器、排除目录)。
## 4. 用命令面板打开 JSON 配置(不进图形设置)
### 4.1 打开用户配置
1. `Ctrl + Shift + P`
2. 输入 `Open User Settings (JSON)`
3. 回车
### 4.2 打开工作区配置
1. `Ctrl + Shift + P`
2. 输入 `Open Workspace Settings (JSON)`
3. 回车
如果项目里没有 `.vscode/settings.json`VSCode 会帮你创建。
## 5. 可直接粘贴的入门模板
下面这份建议先放在 **User settings.json**,适用于 Windows + Linux。
```json
{
"editor.fontSize": 14,
"editor.tabSize": 2,
"editor.wordWrap": "on",
"editor.minimap.enabled": false,
"files.autoSave": "onFocusChange",
"files.trimTrailingWhitespace": true,
"files.insertFinalNewline": true,
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.fixAll": "explicit"
},
"terminal.integrated.defaultProfile.windows": "PowerShell",
"terminal.integrated.defaultProfile.linux": "bash",
"files.exclude": {
"**/.DS_Store": true,
"**/node_modules": true,
"**/.git": false
}
}
```
说明:
- `formatOnSave` 依赖你安装并启用对应语言的格式化扩展。
- `source.fixAll` 设为 `explicit` 更稳,避免每次保存都触发过多修复。
- `terminal.integrated.defaultProfile.*` 按你的本机实际 shell 调整。
## 6. User 与 Workspace 怎么分
推荐这套规则:
-`User`:你个人习惯,跨项目都想保留。
-`Workspace`:只在当前项目生效的规则。
示例:某项目要求 4 空格缩进,就写到该项目 `.vscode/settings.json`
```json
{
"editor.tabSize": 4,
"editor.insertSpaces": true
}
```
## 7. 常见问题JSON 配置方式)
### 7.1 配置不生效
`Ctrl + Shift + P` 执行 `Developer: Reload Window`,再验证。
### 7.2 JSON 报错(逗号、引号)
`settings.json` 必须是合法 JSON。重点检查
- 最后一项后面不要多逗号
- 键名和字符串值要用双引号
### 7.3 不确定某个键该写什么
用命令面板打开 `Default Settings (JSON)` 搜索对应键,按默认文档写。
## 8. 15 分钟上手清单
- [ ] 会用 `Ctrl + Shift + P` 打开命令面板
- [ ] 会打开 `User Settings (JSON)`
- [ ] 会打开 `Workspace Settings (JSON)`
- [ ] 能区分 User 与 Workspace 的生效范围
- [ ] 粘贴并调整一份可用的 `settings.json`
- [ ] 配置不生效时会执行 `Reload Window`
完成以上 6 项,你已经跨过 VSCode 入门阶段。

View File

@@ -0,0 +1,209 @@
---
title: Linux Mint XFCE 终端常用快捷指令完全指南
icon: simple-icons:linuxmint
date: 2026-03-30
category:
- Linux
tag:
- Linux Mint
- XFCE
- 终端
- 快捷键
- 效率提升
---
# Linux Mint XFCE 终端常用快捷指令完全指南
XFCE 终端是 Linux Mint XFCE 桌面环境默认的命令行工具,熟练掌握其快捷键可以极大提升工作效率。本文整理了最实用的 XFCE 终端快捷键,涵盖导航、编辑、显示调整等各个方面,帮助你更高效地使用终端。
<!-- more -->
## 一、基础导航类快捷键
### 1.1 标签页管理
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl+Shift+T` | 新建标签页 | 需要同时运行多个命令时 |
| `Ctrl+PgUp` / `Ctrl+PgDown` | 切换到上一个/下一个标签页 | 在多个标签页间快速切换 |
| `Alt+数字键` | 切换到指定序号标签页 | 直接跳转到特定标签页 |
| `Ctrl+Shift+W` | 关闭当前标签页 | 清理不再需要的终端会话 |
| `Ctrl+Shift+R` | 重命名当前标签页 | 为标签页设置描述性名称 |
### 1.2 窗口管理
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl+Shift+N` | 新建终端窗口 | 需要独立的终端窗口 |
| `Ctrl+Shift+O` | 水平分割窗口 | 同时查看或操作多个内容 |
| `Ctrl+Shift+E` | 垂直分割窗口 | 并排对比或操作 |
| `Ctrl+Shift+Q` | 关闭终端窗口 | 退出终端应用程序 |
### 1.3 滚动与导航
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Shift+PgUp` / `Shift+PgDown` | 向上/向下滚动页面 | 查看历史输出内容 |
| `Ctrl+Shift+K` | 清除终端内容 | 清理终端界面 |
| `Ctrl+Shift+F` | 查找文本 | 在终端输出中搜索内容 |
## 二、编辑操作类快捷键
### 2.1 基础移动快捷键
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl + A` | 回到行首 | 快速定位到命令开头修改 |
| `Ctrl + E` | 回到行尾 | 快速定位到命令结尾补充参数 |
| `Ctrl + B` / 左箭头 | 向左移动一个字符 | 字符级微调光标位置 |
| `Ctrl + F` / 右箭头 | 向右移动一个字符 | 字符级微调光标位置 |
| `Alt + B` | 向左移动一个单词 | 快速按单词跳转编辑长命令 |
| `Alt + F` | 向右移动一个单词 | 快速按单词跳转编辑长命令 |
| `Esc + B` | 向左移动一个单词 | Alt+B被终端菜单抢占时的替代方案 |
| `Esc + F` | 向右移动一个单词 | Alt+F被终端菜单抢占时的替代方案 |
### 2.2 删除快捷键
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl + U` | 删除到行首 | 快速清空当前输入的命令 |
| `Ctrl + K` | 删除到行尾 | 删除光标后面不需要的内容 |
| `Ctrl + W` | 删除前一个单词 | 快速删除最近输入的错误单词 |
| `Ctrl + D` | 删除当前字符 | 删除光标下的字符 |
| `Backspace` | 删除前一个字符 | 常规删除操作 |
### 2.3 历史命令操作
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `上/下箭头` | 浏览命令历史 | 重复执行之前的命令 |
| `Ctrl + R` | 反向搜索历史命令 | 快速查找之前执行过的命令 |
| `Ctrl + G` | 退出历史搜索模式 | 取消历史搜索返回正常输入 |
### 2.4 文本选择与操作
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl+Shift+C` | 复制选中文本 | 复制终端中的命令或输出 |
| `Ctrl+Shift+V` | 粘贴剪贴板内容 | 粘贴命令或文本到终端 |
| `Ctrl+Shift+A` | 全选当前行 | 快速复制整行内容 |
| `Ctrl+Shift+左/右箭头` | 按单词移动光标 | 快速编辑长命令 |
### 2.5 查找与替换
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl+Shift+F` | 打开查找对话框 | 在终端内容中搜索文本 |
| `F3` | 查找下一个匹配项 | 继续搜索相同内容 |
| `Shift+F3` | 查找上一个匹配项 | 反向搜索匹配项 |
## 三、显示调整类快捷键
### 3.1 字体与缩放
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl+加号 (+)` | 放大字体 | 改善可读性 |
| `Ctrl+减号 (-)` | 缩小字体 | 显示更多内容 |
| `Ctrl+0` | 重置字体大小 | 恢复默认设置 |
### 3.2 配色方案与透明度
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `F11` | 全屏切换 | 专注于终端操作 |
| `Ctrl+Shift+I` | 切换光标形状 | 适应个人偏好 |
| `Ctrl+Shift+G` | 切换全局菜单 | 节省屏幕空间 |
> 💡 **小贴士**:可以自定义配色方案,前往 "编辑" → "首选项" → "外观" 设置自己喜欢的主题颜色。
## 四、高级功能类快捷键
### 4.1 书签管理
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl+Shift+B` | 添加当前目录为书签 | 快速访问常用目录 |
| `Ctrl+B` | 打开书签管理器 | 跳转到已保存的书签 |
| `F2` | 编辑当前标签页书签 | 更新书签信息 |
### 4.2 布局与多列显示
| 快捷键 | 功能描述 | 使用场景 |
|--------|----------|----------|
| `Ctrl+Shift+O` | 水平分割标签页 | 并排查看不同内容 |
| `Ctrl+Shift+E` | 垂直分割标签页 | 对比或参考操作 |
| `Ctrl+Shift+Q` | 关闭分割窗格 | 恢复单个视图 |
> 🎯 **高效技巧**:使用 `Ctrl+Shift+T` 新建标签页后,配合 `Alt+数字键` 快速切换,可以像使用浏览器一样高效管理多个终端会话。
## 五、自定义快捷键配置
### 5.1 修改快捷键配置文件
XFCE 终端的快捷键配置文件位于:
`~/.config/xfce4/terminal/accels.scm`
可以通过编辑此文件来自定义快捷键:
```bash
# 备份原配置文件
cp ~/.config/xfce4/terminal/accels.scm ~/.config/xfce4/terminal/accels.scm.backup
# 编辑配置文件
nano ~/.config/xfce4/terminal/accels.scm
# 示例:修改新建标签页快捷键为 Ctrl+T
# 原内容: (gtk_accel_path "<Actions>/terminal-window/tab-new" "<Primary><Shift>t")
# 修改为: (gtk_accel_path "<Actions>/terminal-window/tab-new" "<Primary>t")
```
重启终端或按 `Ctrl+Shift+R` 重载配置使更改生效。
### 5.2 解决Alt快捷键被抢占问题
XFCE 终端默认会将 `Alt + 字母` 组合键作为菜单访问快捷键,会导致 Bash 的 `Alt + F``Alt + B` 等行编辑快捷键失效,可通过以下设置解决:
**推荐方案(禁用所有菜单访问键):**
1. 打开终端 → **编辑****首选项**Preferences
2. 切换到 **高级**Advanced标签
3. **勾选****禁用所有菜单访问键**Disable all menu access keys
**效果:**
- `Alt + F``Alt + B` 等 Bash 行编辑快捷键恢复正常
- 同时会禁用 `Alt + F`(文件菜单)、`Alt + E`(编辑菜单)等菜单访问快捷键
**替代方案(不关闭菜单快捷键):**
- 使用 `Esc + F` 代替 `Alt + F` 向右跳一个单词
- 使用 `Esc + B` 代替 `Alt + B` 向左跳一个单词
> 💡 **记忆技巧**
> - `Ctrl` 系列快捷键:多用于**字符**级别操作A=开头, E=结尾, B=后退, F=前进)
> - `Alt` 系列快捷键:多用于**单词**级别操作B=back, F=forward
> - `Esc` 可以代替 Alt当 Alt 被系统/应用抢占时)
## 六、总结与推荐
### 6.1 最常用快捷键(强烈建议掌握)
1. **导航类**
- `Ctrl+Shift+T` - 新建标签页
- `Ctrl+PgUp` / `Ctrl+PgDown` - 切换标签页
- `Alt+数字键` - 直接跳转标签页
2. **编辑类**
- `Ctrl+Shift+C` / `Ctrl+Shift+V` - 复制粘贴
- `Ctrl+R` - 搜索历史命令
3. **显示类**
- `Ctrl+加号/减号` - 字体缩放
- `F11` - 全屏切换
### 6.2 学习建议
1. **循序渐进**:先掌握最常用的 5-10 个快捷键
2. **结合实际**:在日常使用中刻意练习
3. **定期复习**:创建自己的快捷键备忘清单
4. **个性化**:根据个人习惯调整快捷键配置
> 📚 **扩展阅读**:可以通过 `man xfce4-terminal` 查看完整的官方手册,了解更多高级功能和配置选项。

View File

@@ -1,6 +1,6 @@
---
title: Linux 应用安装与快捷方式
icon: mdi:application-box
icon: fa6-solid:box-open
date: 2025-12-22
category:
- Linux 基础

Binary file not shown.

After

Width:  |  Height:  |  Size: 166 KiB

177
src/work/todo/2026-03.md Normal file
View File

@@ -0,0 +1,177 @@
---
icon: fa6-solid:list-check
date: 2026-03-23
pageClass: todo-page
category:
- 待办
tag:
- 任务清单
title: 3月待办2026-03
---
3月待办事项记录
<!-- more -->
# 待办清单2026-03
> 最后更新: 2026-04-02
> 统计: 已完成 17 项、已提交 0 项、待测试 0 项、部分完成 0 项、待确认 1 项、未开始 3 项、已取消 1 项
## 清单总览
- 当前优先: 13待确认、14未开始
- 本周建议推进: 7、9、14未开始
- 已归档完成: 1、2、3、4、5、8、10、11、12、15、16、17、18、19、20、21、22
## 状态说明
<Badge text="已完成" type="tip" /> <Badge text="已提交" type="tip" /> <Badge text="待测试" type="info" /> <Badge text="待提交" type="warning" /> <Badge text="部分完成" type="note" /> <Badge text="待确认" type="warning" /> <Badge text="未开始" type="danger" /> <Badge text="已取消" type="warning" />
---
## 当前优先
### 13. V2.00的250985版本是否同步至其他系统 <Badge text="待确认" type="warning" />
- **描述**: 待确认V2.00的250985版本是否需要同步至其他系统
- **下一步**: 与产品/版本负责人确认同步范围和目标版本
---
## 待启动
### 7. [全部版本] WEB端重新开发实现C++开发的桌面端算法标记功能 <Badge text="未开始" type="danger" />
- **描述**: WEB端重新开发实现算法标记功能
- **下一步**: 先产出交互方案和接口清单
### 9. [智能巡视-7950] V2.00所有版本同步至2024后问题修复 <Badge text="未开始" type="danger" />
- **描述**:
- 最新的2024未发送算法资源请求
- 其余问题待测试
- **下一步**: 先复现资源请求问题,再统一修复策略
### 14. [智慧场站-7050] 瀚高数据库适配验证 <Badge text="未开始" type="danger" />
- **创建日期**: 2026-03-23
- **描述**: 验证7050系统对瀚高数据库的兼容性与适配结果整理问题清单
- **下一步**: 明确验证范围(安装、连接、读写、迁移脚本、性能基线)并安排验证
---
## 已完成归档
<details>
<summary>展开查看已完成事项12项</summary>
### 1. 2.00适配的立即执行时间为空是否需要同步其他版本 <Badge text="已完成" type="tip" />
- **描述**: 已同步至3个版本完成
### 2. 静默监视中多个请求类型的问题 <Badge text="已完成" type="tip" />
- **描述**: 已完成并同步到3个版本
### 3. 7050历史三维打包问题 <Badge text="已完成" type="tip" />
- **描述**: 7050项目历史三维打包问题已修复已完成并归档
### 4. 2.00修复的250941版本同步到7050 <Badge text="已完成" type="tip" />
- **描述**: 2.00版本修复的250941问题已同步到7050项目
### 5. 排查/alarm/silent/query/hisSilentAlarm/list的stationAlarmStatistics为空 <Badge text="已完成" type="tip" />
- **描述**: 已完成并和其他版本同步
### 10. [智慧场站-7050] 联动新需求开发 <Badge text="已完成" type="tip" />
- **描述**: 联动新需求开发已完成
### 11. [智能巡视-7950] 打包脚本调整 <Badge text="已完成" type="tip" />
- **描述**: 3个版本都已适配打包脚本复制Common依赖目录
### 12. [智能巡视-7950] 超期逻辑和红外温度矩阵功能同步 <Badge text="已完成" type="tip" />
- **描述**: 红外温度矩阵功能已同步到V2.00版本,超期逻辑已同步
- **完成情况**: 已完成,所有功能已同步
### 15. 调整了go打包脚本的taos依赖库获取位置 <Badge text="已完成" type="tip" />
- **完成日期**: 2026-03-23
- **描述**: 已调整go打包脚本中taos依赖库的获取位置并完成验证
### 17. [智能巡视-7950] getLatestHisTask接口查询方案调整 <Badge text="已完成" type="tip" />
- **创建日期**: 2026-03-26
- **描述**: 调整`@RequestMapping(value = "/getLatestHisTask", method = RequestMethod.GET)`获取最新一条巡视任务及点位信息的查询策略3个版本需同步
- **方案调整**: 默认查询今天正在执行的任务若不存在则默认查询最新一条历史记录3个版本同步
- **完成情况**: 已完成3个版本已同步
### 18. [智慧场站-7050] 调整声纹模型模板必填项 <Badge text="已完成" type="tip" />
- **创建日期**: 2026-03-27
- **描述**: 调整7050声纹模型模板必填项
- **必填项**: 设备名称、设备编码、投运时间、设备IP、通信协议、通信端口
- **完成情况**: 已完成
### 19. [智慧场站-7050] 删除点位时同步清理关联阈值告警 <Badge text="已完成" type="tip" />
- **创建日期**: 2026-03-27
- **描述**: 删除点位时排查是否存在关联的阈值告警,如存在则需要同步删除
- **完成情况**: 已完成,已梳理点位与阈值告警关联关系,实现删除点位时同步清理关联阈值告警功能
- **需求截图**:
![删除点位关联阈值告警需求截图](../assets/Snipaste_2026-03-27_15-12-26.png)
### 20. [智慧场站-7050] 录像回放权限问题修复 <Badge text="已完成" type="tip" />
- **创建日期**: 2026-03-27
- **原话**:
- 没有录像回放这个,这里是不是修改下,默认的更新后要有的,哪个现场不需要再给他取消,要不然其它正常的现场一更新程序,全给录像回放整没了
- 给操作员配上录像回放权限后admin登录咋没有录像回放的菜单
- **完成情况**: 已完成
- **备注**: 新站默认权限包含录像回放,老站需要手动配置下录像权限
### 16. [智能巡视-7950] 超期和终止任务增加结束时间3个版本 <Badge text="已完成" type="tip" />
- **创建日期**: 2026-03-26
- **描述**: 超期任务和终止任务都需要增加任务结束时间且3个版本均需同步
- **完成情况**: 已完成3个版本数据库表结构和业务逻辑已同步更新
### 21. [智慧场站-7050] 反向联动菜单放出与联动开关灯实现 <Badge text="已完成" type="tip" />
- **创建日期**: 2026-03-27
- **描述**: 反向联动菜单放出 + 反向联动实现联动开灯关灯
- **完成情况**: 已完成,反向联动触发条件、开关灯联动逻辑与菜单权限配置已实现并验证
### 8. [智慧场站-7050] 完成贵州大唐机器人告警复检需求开发 <Badge text="已完成" type="tip" />
- **描述**: 7050项目机器人告警复检需求开发已完成等待测试
- **完成情况**: 已完成联调与回归测试,告警复检流程和边界场景验证通过
### 22. [全部版本] 优化服务调用失败异常反馈 <Badge text="已完成" type="tip" />
- **创建日期**: 2026-03-30
- **描述**: 优化服务调用失败时的异常反馈机制,在日志中附带详细的错误信息,便于快速定位问题
- **完成情况**: 已完成全版本优化日志已在ServiceClientPool、ClientManager、BusClientInterceptor等关键类中增强了异常信息包含服务名、方法名、参数、错误原因、调用链路等可快速定位问题
</details>
---
## 已取消归档
<details>
<summary>展开查看已取消事项1项</summary>
### 6. [智能巡视-7950] 巡视结果上报和确认功能优化 <Badge text="已取消" type="warning" />
- **描述**:
- 巡视结果上报需要加确认状态、确认时间、是否告警
- 巡视结果确认需要加告警相关信息
- **处理结果**: 更新已取消,无需处理
</details>

129
src/work/todo/2026-04.md Normal file
View File

@@ -0,0 +1,129 @@
---
icon: fa6-solid:list-check
date: 2026-04-01
pageClass: todo-page
category:
- 待办
tag:
- 任务清单
title: 4月待办2026-04
---
4月待办事项记录
<!-- more -->
# 待办清单2026-04
> 最后更新: 2026-04-02
> 统计: 已完成 2 项、未开始 2 项
## 清单总览
- 当前优先: 2未开始
## 状态说明
<Badge text="已完成" type="tip" /> <Badge text="已提交" type="tip" /> <Badge text="待测试" type="info" /> <Badge text="待提交" type="warning" /> <Badge text="部分完成" type="note" /> <Badge text="待确认" type="warning" /> <Badge text="未开始" type="danger" /> <Badge text="已取消" type="warning" />
---
## 当前优先
### 1. 巡视报告配置异常需要修复 <Badge text="已完成" type="tip" />
- **描述**: 巡视报告配置异常,在这里设置筛选搜索修改设置之后,同一主设备下其它点的设置就变成空的了
- **错误日志**:
```
2026-03-31 19:16:52.944 [TThreadPoolServer WorkerProcess-6] ERROR com.sunri.model.pipeline.DictatePipeline - DictatePipeline start, 处理异常 {}
java.lang.IllegalStateException: Duplicate key PatrolReportDevicePointRecord(id=37327, mainDeviceId=2198, devicePointId=104250, reportSn=1, standardValue=正常)
at java.util.stream.Collectors.lambda$throwingMerger$0(Collectors.java:133)
at java.util.HashMap.merge(HashMap.java:1254)
at java.util.stream.Collectors.lambda$toMap$58(Collectors.java:1320)
at java.util.stream.ReduceOps$3ReducingSink.accept(ReduceOps.java:169)
at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1384)
at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:482)
at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:472)
at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:566)
at com.sunri.model.supersysmodel.pipeline.PatrolReportDevicePointRecordPipeLine.handle(PatrolReportDevicePointRecordPipeLine.java:44)
at com.sunri.model.supersysmodel.pipeline.ObjectVerifyPipeline.proceed(ObjectVerifyPipeline.java:35)
at com.sunri.model.supersysmodel.pipeline.PatrolReportDevicePointRecordPipeLine.proceed(PatrolReportDevicePointRecordPipeLine.java:19)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:23)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.pipeline.DictatePipeline.skip(DictatePipeline.java:43)
at com.sunri.model.pipeline.DictatePipeline.start(DictatePipeline.java:32)
at com.sunri.model.supersysmodel.pipeline.DevicePointManager.pointImport(DevicePointManager.java:62)
at com.sunri.model.supersysmodel.SuperSysModelConfiguration.readExcelBytes(SuperSysModelConfiguration.java:2419)
at com.sunri.model.supersysmodel.SuperSysModelConfiguration.devicePointImport(SuperSysModelConfiguration.java:2495)
at com.sunri.service.impl.supersysmodel.SuperSysModelServiceImpl.devicePointImport(SuperSysModelServiceImpl.java:172)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.sunri.server.mapper.handler.ByteArrayMethodHandler.proceed(ByteArrayMethodHandler.java:108)
at com.sunri.pipeline.Pipeline.start(Pipeline.java:26)
at com.sunri.pipeline.Pipeline.skip(Pipeline.java:43)
at com.sunri.pipeline.Pipeline.start(Pipeline.java:32)
at com.sunri.server.dispatch.Func.proceed(Func.java:152)
at com.sunri.server.service.impl.RequestServiceImpl.doExec(RequestServiceImpl.java:43)
at com.sunri.server.message.handler.RequestHandler.proceed(RequestHandler.java:30)
at com.sunri.pipeline.Pipeline.start(Pipeline.java:26)
at com.sunri.pipeline.Pipeline.skip(Pipeline.java:43)
at com.sunri.pipeline.Pipeline.start(Pipeline.java:32)
at com.sunri.server.processor.ServerProcessor.doExec(ServerProcessor.java:36)
at com.sunri.server.service.RequestService$Processor$doExec.getResult(RequestService.java:155)
at com.sunri.server.service.RequestService$Processor$doExec.getResult(RequestService.java:135)
at org.apache.thrift.ProcessFunction.process(ProcessFunction.java:38)
at org.apache.thrift.TBaseProcessor.process(TBaseProcessor.java:38)
at com.sunri.server.processor.ServerProcessorFactory$RequestServiceProcessor.process(ServerProcessorFactory.java:74)
at org.apache.thrift.TMultiplexedProcessor.process(TMultiplexedProcessor.java:138)
at org.apache.thrift.server.TThreadPoolServer$WorkerProcess.run(TThreadPoolServer.java:250)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:748)
2026-03-31 19:16:52.945 [TThreadPoolServer WorkerProcess-6] INFO com.sunri.model.pipeline.DictatePipeline - [流水线完成] PatrolReportDevicePointRecordPipeLine 处理耗时: 34ms
```
- **完成方案**:
1. 后端:将 PatrolReportDevicePointRecordPipeLine 的去重与处理维度统一改为 devicePointId 全局唯一(跨主设备同点位仅保留最大 id 并删除其余),再基于保留记录更新/插入以彻底避免 Duplicate key。
2. 前端:修复筛选搜索修改设置后同主设备下其他点位配置为空的显示问题
- **完成情况**: 前后端均已修复并验证,同一主设备下多点位配置保存和显示正常
### 2. 与姬工讨论上海导出五通报表的问题 <Badge text="未开始" type="danger" />
- **描述**: 姬工安排讨论上海项目导出五通报表相关需求与问题
- **下一步**:
1. 提前梳理现有报表导出功能逻辑
2. 预约时间与姬工同步讨论细节
### 3. 修复现场linx80 excel打开失败问题 <Badge text="已完成" type="tip" />
- **描述**: 现场linx80设备导出的Excel文件打开失败
- **完成情况**: 经排查为现场系统软件版本过低导致,无需修复,建议升级系统软件版本即可解决
### 4. 告警阈值xml导入限制同一个点位统一各类型只能有一条记录 <Badge text="未开始" type="danger" />
- **描述**: 韩磊要求新增告警阈值xml导入限制同一个点位各类型阈值只能有一条记录
- **下一步**:
1. 梳理现有告警阈值xml导入逻辑
2. 新增同点位同类型阈值重复校验
3. 验证导入功能正常且限制生效

15
src/work/todo/README.md Normal file
View File

@@ -0,0 +1,15 @@
---
icon: mdi:checklist
category:
- 待办
tag:
- 任务清单
title: 待办事项
---
按月份维护待办事项。
## 月度清单
- [4月待办2026-04](./2026-04.md)
- [3月待办2026-03](./2026-03.md)

View File

@@ -1,7 +1,5 @@
---
icon: mdi:checklist
date: 2026-03-23
pageClass: todo-page
category:
- 待办
tag:
@@ -9,124 +7,7 @@ tag:
title: 待办事项
---
待办事项记录
<!-- more -->
待办事项已按月份维护。
# 待办清单
> 最后更新: 2026-03-26
> 统计: 已完成 7 项、已提交 0 项、待测试 1 项、部分完成 1 项、待确认 1 项、未开始 7 项
## 清单总览
- 当前优先: 8待测试、13待确认、12部分完成、14未开始
- 本周建议推进: 6、7、9、10、14、16、17未开始
- 已归档完成: 1、2、3、4、5、11、15
## 状态说明
<Badge text="已完成" type="tip" /> <Badge text="已提交" type="tip" /> <Badge text="待测试" type="info" /> <Badge text="待提交" type="warning" /> <Badge text="部分完成" type="note" /> <Badge text="待确认" type="warning" /> <Badge text="未开始" type="danger" />
---
## 当前优先
### 8. [智慧场站-7050] 完成贵州大唐机器人告警复检需求开发 <Badge text="待测试" type="info" />
- **描述**: 7050项目机器人告警复检需求开发已完成等待测试
- **下一步**: 安排联调与回归,确认告警复检流程和边界场景
### 13. V2.00的250985版本是否同步至其他系统 <Badge text="待确认" type="warning" />
- **描述**: 待确认V2.00的250985版本是否需要同步至其他系统
- **下一步**: 与产品/版本负责人确认同步范围和目标版本
### 12. [智能巡视-7950] 超期逻辑和红外温度矩阵功能同步 <Badge text="部分完成" type="note" />
- **描述**: 红外温度矩阵功能已同步到V2.00版本,超期逻辑待同步
- **下一步**: 对齐超期逻辑差异并补齐同步清单
---
## 待启动
### 6. [智能巡视-7950] 巡视结果上报和确认功能优化 <Badge text="未开始" type="danger" />
- **描述**:
- 巡视结果上报需要加确认状态、确认时间、是否告警
- 巡视结果确认需要加告警相关信息
- **下一步**: 先明确字段和状态流转,再拆分开发任务
### 7. [全部版本] WEB端重新开发实现C++开发的桌面端算法标记功能 <Badge text="未开始" type="danger" />
- **描述**: WEB端重新开发实现算法标记功能
- **下一步**: 先产出交互方案和接口清单
### 9. [智能巡视-7950] V2.00所有版本同步至2024后问题修复 <Badge text="未开始" type="danger" />
- **描述**:
- 最新的2024未发送算法资源请求
- 其余问题待测试
- **下一步**: 先复现资源请求问题,再统一修复策略
### 10. [智慧场站-7050] 联动新需求开发 <Badge text="未开始" type="danger" />
- **描述**: 现场需求联动新需求方案开发(已评审)
- **下一步**: 按评审结论拆分里程碑并确认排期
### 14. [智慧场站-7050] 瀚高数据库适配验证 <Badge text="未开始" type="danger" />
- **创建日期**: 2026-03-23
- **描述**: 验证7050系统对瀚高数据库的兼容性与适配结果整理问题清单
- **下一步**: 明确验证范围(安装、连接、读写、迁移脚本、性能基线)并安排验证
### 16. [智能巡视-7950] 超期和终止任务增加结束时间3个版本 <Badge text="未开始" type="danger" />
- **创建日期**: 2026-03-26
- **描述**: 超期任务和终止任务都需要增加任务结束时间且3个版本均需同步
- **下一步**: 先梳理涉及字段、接口和展示位置,再按版本拆分开发与联调计划
### 17. [智能巡视-7950] getLatestHisTask接口查询方案调整 <Badge text="未开始" type="danger" />
- **创建日期**: 2026-03-26
- **描述**: 调整`@RequestMapping(value = "/getLatestHisTask", method = RequestMethod.GET)`获取最新一条巡视任务及点位信息的查询策略
- **方案调整**: 默认查询今天正在执行的任务;若不存在,则默认查询最新一条历史记录
- **下一步**: 明确筛选条件与排序规则,评估对现有接口返回字段和调用方的影响
---
## 已完成归档
<details>
<summary>展开查看已完成事项7项</summary>
### 1. 2.00适配的立即执行时间为空是否需要同步其他版本 <Badge text="已完成" type="tip" />
- **描述**: 已同步至3个版本完成
### 2. 静默监视中多个请求类型的问题 <Badge text="已完成" type="tip" />
- **描述**: 已完成并同步到3个版本
### 3. 7050历史三维打包问题 <Badge text="已完成" type="tip" />
- **描述**: 7050项目历史三维打包问题已修复已完成并归档
### 4. 2.00修复的250941版本同步到7050 <Badge text="已完成" type="tip" />
- **描述**: 2.00版本修复的250941问题已同步到7050项目
### 5. 排查/alarm/silent/query/hisSilentAlarm/list的stationAlarmStatistics为空 <Badge text="已完成" type="tip" />
- **描述**: 已完成并和其他版本同步
### 11. [智能巡视-7950] 打包脚本调整 <Badge text="已完成" type="tip" />
- **描述**: 3个版本都已适配打包脚本复制Common依赖目录
### 15. 调整了go打包脚本的taos依赖库获取位置 <Badge text="已完成" type="tip" />
- **完成日期**: 2026-03-23
- **描述**: 已调整go打包脚本中taos依赖库的获取位置并完成验证
</details>
- 待办首页:[/work/todo/](/work/todo/)
- 3月待办[/work/todo/2026-03.md](/work/todo/2026-03.md)