后端: 1. 新增课表图片识别接口,支持上传截图后返回“可编辑草稿”(success / partial / reject),并补齐大图、空图、格式不支持、识别能力未配置等错误分支。 2. 课表识别服务接入多模态 Responses 链路,完善图片请求归一化与安全校验(大小、MIME、内容探测),并对识别结果做结构化清洗、强/弱约束校验、告警去重与默认文案兜底。 3. 新增 Ark Responses 统一客户端抽象,支持文本+图片输入、JSON对象输出、usage统计透传与不完整输出识别;同时补齐模型返回 finish_reason 透传,便于定位截断问题。 4. 启动阶段增加课表识图模型与参数注入(模型名、最大图片字节、最大输出token),并将配置示例收敛为“仅保留当前代码实际读取项”。 前端: 5. 课表中心新增“导入课表”完整闭环:上传图片识别、草稿编辑校对、正式导入落库;并新增对应 API 与类型定义。 6. 导入弹窗支持识别中止、全局告警与行级告警展示、低置信度提示、行内编辑、手动新增、删除、拖拽排序、本地校验与提交前二次确认。 7. 正式导入前将草稿按“课程名+地点+是否允许嵌入”聚合为导入结构,并统一携带幂等键请求头,降低重复提交风险。 8. 周课表画板修复跨节次事件遮挡导致的网格错位问题,改进“完全遮挡/部分遮挡”渲染判定与 grid 行定位。 9. 助手流式区域优化“思考中”指示逻辑与样式,避免已有正文时仍展示回答中占位;同时补充全局组件视觉统一(弹窗/按钮)样式。 仓库: 10. 新增课表图片识别前端对接说明文档,补充主动优化能力 PRD 讨论稿,并在协作规范中新增“实现 Eino 新能力前需先查官方文档”的约束。
91 lines
1.9 KiB
CSS
91 lines
1.9 KiB
CSS
:root {
|
|
color-scheme: light;
|
|
font-family:
|
|
"Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei",
|
|
sans-serif;
|
|
line-height: 1.5;
|
|
font-weight: 400;
|
|
color: #1f2937;
|
|
background:
|
|
radial-gradient(circle at top left, rgba(119, 198, 255, 0.18), transparent 28%),
|
|
radial-gradient(circle at right center, rgba(89, 208, 160, 0.16), transparent 24%),
|
|
linear-gradient(180deg, #f6f8fb 0%, #edf2f7 100%);
|
|
font-synthesis: none;
|
|
text-rendering: optimizeLegibility;
|
|
-webkit-font-smoothing: antialiased;
|
|
-moz-osx-font-smoothing: grayscale;
|
|
--page-max-width: 1200px;
|
|
--surface: rgba(255, 255, 255, 0.92);
|
|
--surface-strong: #ffffff;
|
|
--surface-muted: #f5f7fb;
|
|
--line-soft: rgba(15, 23, 42, 0.08);
|
|
--text-main: #111827;
|
|
--text-secondary: #5b6475;
|
|
--brand: #2684ff;
|
|
--brand-strong: #1d6fe0;
|
|
--success: #11a36a;
|
|
--warning: #f59e0b;
|
|
--danger: #ef4444;
|
|
--shadow-soft: 0 18px 45px rgba(31, 41, 55, 0.08);
|
|
}
|
|
|
|
* {
|
|
box-sizing: border-box;
|
|
}
|
|
|
|
html,
|
|
body,
|
|
#app {
|
|
min-height: 100%;
|
|
margin: 0;
|
|
}
|
|
|
|
body {
|
|
min-height: 100vh;
|
|
}
|
|
|
|
button,
|
|
input,
|
|
textarea {
|
|
font: inherit;
|
|
}
|
|
|
|
a {
|
|
color: inherit;
|
|
text-decoration: none;
|
|
}
|
|
|
|
.page-shell {
|
|
width: min(var(--page-max-width), calc(100vw - 32px));
|
|
margin: 0 auto;
|
|
}
|
|
|
|
.glass-panel {
|
|
background: var(--surface);
|
|
border: 1px solid var(--line-soft);
|
|
box-shadow: var(--shadow-soft);
|
|
backdrop-filter: blur(10px);
|
|
}
|
|
|
|
/* Element Plus Overrides for Flat Modern Style */
|
|
.el-dialog, .el-message-box {
|
|
border-radius: 24px !important;
|
|
border: 1px solid rgba(15, 23, 42, 0.05) !important;
|
|
box-shadow: 0 20px 60px rgba(15, 23, 42, 0.1) !important;
|
|
}
|
|
|
|
.el-message-box__headerbtn, .el-dialog__headerbtn {
|
|
top: 16px !important;
|
|
right: 16px !important;
|
|
}
|
|
|
|
.el-button {
|
|
border-radius: 12px !important;
|
|
font-weight: 600 !important;
|
|
}
|
|
|
|
.el-button--primary {
|
|
background: #3b82f6 !important;
|
|
border-color: #3b82f6 !important;
|
|
}
|