SecScore 是一款现代化的教育积分管理软件,基于 Tauri + React + TypeScript + Rust 开发,采用可逆插件架构设计,用于管理学生名单、记录加/扣分、查看排行榜与结算历史,并提供权限保护、数据备份与云同步功能。
SecScore 将非核心功能设计为内置插件,默认不安装,用户可按需启用:
| 插件 | 功能描述 | 默认状态 |
|---|---|---|
| 自动评分 | 基于规则的自动评分系统,支持定时任务和条件触发 | 未安装 |
| 看板管理 | 可视化数据看板,支持自定义布局和实时数据展示 | 未安装 |
| 结算历史 | 积分结算记录管理,支持导出和统计分析 | 未安装 |
| 奖励设置 | 奖励兑换系统配置,管理奖励项目和兑换规则 | 未安装 |
| 云同步 | SECTL 云服务集成,支持数据云同步和跨设备访问 | 未安装 |
核心功能(始终可用):
- 首页(积分操作)
- 学生管理
- 排行榜
- 理由管理
- 设置
- 多级权限:管理员 / 积分操作员 / 只读
- 密码保护:支持管理密码和积分密码
- 找回机制:提供找回字符串用于密码重置
- 本地优先:所有数据本地存储,无需联网
- SECTL 云服务:支持数据云同步和跨设备访问
- 自动同步:检测到数据变化时自动同步
- 冲突解决:智能处理本地与远程数据冲突
- 添加/删除学生
- 通过 xlsx 批量导入名单(支持导入前预览与选择"姓名列")
- 支持学生头像自动生成
- 选择学生并提交加分/扣分
- 支持"预设理由"一键填充理由与分值
- 支持撤销最近的积分记录(撤销后学生积分会回滚)
- 支持沉浸模式,专注积分操作
- 维护"预设理由"(分类、理由内容、预设分值)
- 支持标签分类管理
- 支持按"今天 / 本周 / 本月"查看积分变化
- 支持导出排行榜为 XLSX
- 支持查看单个学生的操作记录(文本列表)
- "结算并重新开始":把当前未结算记录归档为一个阶段,并将所有学生当前积分清零
- 在"结算历史"查看每个阶段的排行榜(需安装插件)
- 主题切换(支持自定义主题)
- 多语言支持(10+ 语言)
- 日志查看/导出/清空
- 数据导入/导出(JSON)
- 密码保护(管理密码 / 积分密码)与找回字符串
- 数据库切换(SQLite / PostgreSQL)
- 右上角会显示当前权限:管理权限 / 积分权限 / 只读
- 若设置了密码,可通过右上角"输入密码"进行解锁
- 管理密码:全功能(学生管理、理由管理、结算、数据管理等)
- 积分密码:仅允许积分相关操作
- 点击"锁定"可切回只读状态
- 无密码时默认视为管理权限
入口:左侧菜单 → 插件管理 → 内置插件
- 浏览可用的内置插件列表
- 点击"安装"按钮安装需要的插件
- 安装后点击"启用"激活插件
- 插件功能将自动显示在侧边栏菜单中
入口:左侧菜单 → 学生管理 → 导入名单
- 通过 xlsx 导入
- 选择一个
.xlsx文件(默认读取第一个工作表) - 在预览表格里点击表头,选择"姓名列"
- 点击"导入"
- 导入完成后会提示"新增 / 跳过"数量
- 选择一个
建议:姓名列尽量只包含纯姓名文本;同名学生会被视为重复并跳过。
入口:左侧菜单 → 积分管理
- 在"姓名"选择一个学生(支持搜索)
- 选择"加分/扣分",并输入分值
- 在"理由内容"填写原因(可手动输入)
- 点击"确认提交"
快捷理由:
- 可在"快捷理由"下拉框中选择预设理由,一键填充理由内容/分值(优先尊重你当前是否已手动输入分值)
撤销最近记录:
- "最近记录"默认折叠,展开后可对记录点击"撤销"
- 撤销会回滚该条记录对学生积分的影响
入口:左侧菜单 → 排行榜
- 可切换统计范围:今天 / 本周 / 本月
- 点击"导出 XLSX"可导出当前排行榜
- 点击某个学生的"查看"可打开该学生的操作记录
入口:左侧菜单 → 系统设置 → 数据管理
- 结算并重新开始(需安装"结算历史"插件)
- 会把当前未结算的积分记录归档为一个阶段
- 会将所有学生当前积分清零
- 学生名单不变;结算后的历史在"结算历史"查看
- 导出 JSON(强烈建议定期备份)
- 导入会覆盖现有学生/理由/积分记录/设置
- 安全相关设置(密码等)不会随导入写入
- 框架:React 19 + TypeScript 5
- 构建工具:Vite 7
- UI 组件:Ant Design 5
- 状态管理:Context API + 自定义 DI 系统
- 国际化:i18next
- 框架:Tauri 2 + Rust
- 数据库:SQLite(本地)/ PostgreSQL(远程)
- ORM:自定义数据库抽象层
- 可逆插件系统:参照 Koishi 的 Disposable 设计,支持热重载
- 依赖注入:基于 ExamAware 项目的 DI 实现
- 配置管理:统一的 ConfigService,支持实时同步
- 日志系统:分级日志,支持多色打印与文件存储
- 窗口管理:统一的 WindowManager,支持多窗口
- Node.js(建议使用 LTS 版本)
- pnpm
- Rust(用于 Tauri 后端)
pnpm installpnpm devpnpm build(可选)打包:
pnpm build:win
pnpm build:unpackpnpm lint
pnpm typecheck
pnpm format欢迎提交 Issue 和 Pull Request!
Made with ❤️ by SECTL