Commit Graph

129 Commits

Author SHA1 Message Date
aid
45d4ac2216 fix(leai): originalImageUrl 字段兜底同步与历史数据回填
背景:
  leai webhook 同步作品时大多只传 coverUrl 不传 originalImageUrl,
  导致前端作品库 PIP 画中画与详情页「画作原图」卡片不展示
  (v-if="work.originalImageUrl" 检查为 null/空字符串时屏蔽)。

修复:
- LeaiSyncService 三处(createWork/updateProcessing/updateStatusForward)
  加 fallback:originalImageUrl 没传但 coverUrl 有传时,用 coverUrl 兜底
- V13 migration 回填历史数据(IS NULL 条件)
- V14 force 重跑(V13 因 history 表残留同版本号脏数据被 repair 跳过)
- V15 补充:部分作品 original_image_url 是空字符串而非 NULL,
  V14 的 IS NULL 没匹配到,V15 用 (IS NULL OR = '') 兼容空串

剩余 TODO(留给后端联调):
  - leai webhook 后续若拆分独立的 cover 字段,前端 PIP 将自动展现
    "AI 封面 + 原图" 的真实区分(当前所有作品大小图相同时由
    前端 !== 检查屏蔽 PIP)
  - 详见 docs/design/public/ugc-work-status-redesign.md

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-09 20:08:38 +08:00
aid
37bd82714d feat: 作品封面引入 PIP 画中画展示原图,详情页加全屏放大查看
- 大图为 AI 生成的绘本封面(coverUrl),右下角小图为用户上传的原图(originalImageUrl),形成"创作素材→AI 成果"的视觉对比
- 草稿等无 AI 封面的作品:大图为占位图,PIP 仍展示原图

涉及文件:
- works/Index.vue 作品库列表卡片加 PIP(右下角 34% 正方形 + 白边阴影)
- Gallery.vue 发现页卡片加同款 PIP
- mine/Favorites.vue 收藏列表加 PIP,type 加 originalImageUrl 字段
- components/WorkSelector.vue 作品选择器加更小尺寸 PIP(32%)
- works/Detail.vue 详情页新增「画作原图」独立卡片(左 84px 缩略图 + 右文字描述)
  · 点击缩略图全屏 overlay 放大查看,背景毛玻璃 + 紫黑半透明
  · hover 缩略图时显示放大镜图标
- _dev-mock.ts 5 条 mock 作品都加 originalImageUrl(不同 hue 区分),id=102 (draft) 的 coverUrl 设为 null 测试占位边界

兼容性:
- v-if 检查 originalImageUrl 不为空且与 coverUrl 不同,防止字段未拆分时显示重复
- 后端 originalImageUrl 字段为 null 时 PIP 不显示,老数据自动兼容

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-09 19:29:31 +08:00
aid
8638876fa9 style: 公众端剩余页面紫粉主题清理
- Gallery.vue 编辑推荐图标 FireOutlined → CrownFilled,#f59e0b → 主色
- mine/Index.vue 我的收藏菜单图标暖黄 + 橙 → 粉色
- mine/Registrations.vue 待审核 a-tag orange → gold(更柔和的状态色)
- mine/Children.vue 受限模式 a-tag orange → purple
- ActivityDetail.vue 成果区图标 #f59e0b → 主色

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-09 19:17:00 +08:00
aid
cd8de97f79 feat: 引入未发布作品状态与状态化操作面板(前端 UI 第一阶段)
- 新增 docs/design/public/ugc-work-status-redesign.md 完整设计方案与状态流转图
- UserWork.status 类型化为 WorkStatus 联合类型,加入 unpublished 中间状态
- 作品库 Index.vue 加「未发布」tab + 紫色标签样式 + emptyDescription + dev mock 兜底
- Detail.vue 完整重写:清 emoji + 紫粉化 + 根据 status 切换 5 套操作按钮
  · draft → 继续创作
  · unpublished → 公开发布 / 编辑信息
  · pending_review → 撤回审核
  · published → 下架
  · rejected → 修改后重交(含拒绝原因卡片)
- EditInfoView 三按钮语义调整:「保存」→ unpublished、「直接发布」→ pending_review
- 删除独立 Publish.vue 与对应路由(发布功能并入 Detail.vue 公开发布按钮)
- 新建 _dev-mock.ts dev 模式数据共享文件,5 条覆盖全状态的 mock 作品 + 13 页详情
- 撤回 / 下架等接口与 leai workId 映射留 TODO,待后端第二阶段联调

详见 docs/design/public/ugc-work-status-redesign.md

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-09 18:48:14 +08:00
aid
951346a7a8 refactor: AI 创作流程 11 页界面全面重做与紫粉主题统一
- aicreate.scss 主题变量紫粉化,对齐 PublicLayout 设计语言
- 11 个创作流程 view 清理 emoji 改 antd 图标,文案去除"孩子/家长"等第三人称
- 路由调整:编排故事改到选画风之前(更顺的产品逻辑)
- WelcomeView 浮动 CTA + 完整 7 步流程引导
- CharactersView 单角色大图 / 多角色网格自适应
- StyleSelectView 预设路径 /aicreate/styles/{styleId}.jpg + SVG fallback
- CreatingView 改为异步任务式说明 + 去作品库入口
- PreviewView / DubbingView 缩略图统一为横向胶卷
- EditInfoView 底部三按钮(保存草稿 / 去配音 / 发布作品),配音改为可选
- BookReaderView 修复 dev 模式数据加载 + 紫粉封面
- DubbingView / BookReaderView 改用 page-fullscreen 布局类避免被 tabbar 遮挡
- store 新增 fillMockData / fillMockWorkDetail,支持 dev 无后端走通完整流程
- works/Index.vue 加 query.tab 双向同步,支持跳转携带 tab 参数

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-09 18:14:26 +08:00
En
87ac3b5ed9 fix: CORS 配置简化并启用 Spring Security CORS 支持;LeaiSync 作品同步封面图逻辑修复
- CorsConfig 改回允许所有来源(*),移除配置文件域名列表注入
- SecurityConfig 添加 .cors(Customizer.withDefaults()) 使 CorsFilter Bean 生效
- LeaiSyncService 修复 originalImageUrl 同时同步到 coverUrl,单独 coverUrl 优先覆盖

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-09 13:50:02 +08:00
En
f03991819d feat: 管理端全功能 E2E 测试——40 用例覆盖登录、仪表盘、活动、报名、作品、评审、用户、导航
新增 10 个管理端 E2E 测试文件和 1 个 Mock fixture:
- admin.fixture.ts: Mock 数据 + 登录注入 + 组件预热 + 兜底 API 拦截
- login/contests/dashboard/navigation/registrations/works/reviews/users 等 9 个 spec

关键修复:route.fallback() 替代 route.continue() 修正 Mock 链式传递;
review-rules/select Mock + 兜底拦截器防止未 mock 请求到达真实后端。

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-09 12:52:39 +08:00
zhonghua
f7f97c64e4 fix: 租户表单提交前去除字符串字段首尾空格
Made-with: Cursor
2026-04-09 12:05:46 +08:00
zhonghua
7a8d909df3 fix: 活动列表按阶段筛选未发布与已结束;已结束仅保留查看操作
Made-with: Cursor
2026-04-09 11:41:57 +08:00
zhonghua
d5657d8d23 feat: 表单提交前去除首尾空格;评委性别接口返回与持久化
Made-with: Cursor
2026-04-09 11:34:40 +08:00
zhonghua
c4f4613c49 fix: 活动公告列表回显活动名称并修复取消发布
Made-with: Cursor
2026-04-09 11:21:43 +08:00
zhonghua
b19acbd6d5 feat: 作品分配仅限活动评委、评委库仅启用及 UGC 调整
- 作品管理分配评委仅使用活动显式名单,assignWork 校验 t_biz_contest_judge

- 添加评委/评审进度选择评委时仅查询启用账号;接口文档与 API 注释

- UGC 作品分页与公开创作服务相关改动

Made-with: Cursor
2026-04-09 11:04:37 +08:00
zhonghua
937f0650f0 feat: 活动创建页报名审核开关与作品详情页图片布局优化
Made-with: Cursor
2026-04-09 10:16:23 +08:00
En
c1113c937c feat: 赛事→活动术语统一,AI创作嵌套路由重构,前端依赖升级
后端:
- 全局将"赛事"统一为"活动"(Swagger注解、DTO、Entity、Controller、Service)
- 评审模块DTO/Entity/Service字段调整与优化
- 新增V9迁移脚本,修改V2/V4/V6迁移脚本注释
- PublicRegisterActivityDto字段对齐

前端:
- AI绘本创作路由重构为嵌套路由(11个子路由)
- 新增依赖:@stomp/stompjs、ali-oss、crypto-js
- 环境配置(.env)更新,vite配置调整
- API接口术语统一,PublicLayout与aicreate store优化
- 新增nginx部署文档

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-08 22:58:07 +08:00
En
5bb159358f fix: Webhook同步修复——实现findUserIdByPhone,补充PROCESSING状态coverUrl同步
1. 实现 findUserIdByPhone() 方法(原为 TODO 占位),注入 SysUserMapper 按手机号查询用户
2. updateProcessing() 方法补充 coverUrl 字段同步,AI创作过程中推送的封面图不再被丢弃
3. insertNewWork 中增加 WARN 日志,记录手机号未找到用户或手机号为空的情况

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-08 22:57:03 +08:00
En
6365dd8dd0 feat: AI绘本创作H5整合——引入aicreate.scss修复样式,修复checkQuota类型参数
- 在 main.ts 中引入 aicreate.scss,解决所有 CSS 变量和共享样式类缺失的根因问题
- Index.vue 从 iframe 嵌入模式重构为壳组件+子路由渲染模式
- 修复 aicreate.scss 布局适配:height:100% 填充 PublicLayout,page-fullscreen 使用 100% 而非 100dvh
- 修复 checkQuota() 的 type 参数:'A' → 'A3',对齐乐读派后端 V4.0 接口要求
- 迁移 lesingle-aicreate-client 全部 11 个视图、2 个组件、API 层、Store、工具函数

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-08 18:09:05 +08:00
zhonghua
88ca6264a1 feat: 赛事作品多页预览解析与抽屉分页展示
Made-with: Cursor
2026-04-08 17:35:05 +08:00
zhonghua
cc5a5fb4e3 fix: 我的收藏列表与后端扁平字段对齐,修复 coverUrl 报错
Made-with: Cursor
2026-04-08 17:16:13 +08:00
zhonghua
e8da2ee3f8 调整代码 2026-04-08 16:58:55 +08:00
zhonghua
593f7977eb feat: 公众端活动成果卡片展示与公开公示接口
Made-with: Cursor
2026-04-08 16:31:48 +08:00
zhonghua
328533e805 feat: C端活动详情返回公告与附件,子女账号简化报名弹窗
Made-with: Cursor
2026-04-08 16:00:59 +08:00
zhonghua
3fa1ef95ac feat: 主站 /ai-web 嵌入 AI 创作子应用并修正路径与通信
Made-with: Cursor
2026-04-08 15:32:18 +08:00
En
b9ed5e17c6 feat: OSS 客户端直传改造(STS Token 签发 + 前端直传 + CORS 自动配置)
后端新增 OssUtils/OssTokenVo/OssCorsInitRunner,通过 STS 临时凭证实现客户端直传 OSS;
前端 upload API 适配直传流程,赛事创建/作品提交/作业/富文本编辑器均已切换;
多环境(dev/test/prod) OSS 配置补全;新增 oss-direct-upload-demo 示例项目及 E2E 测试。

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-08 15:19:43 +08:00
zhonghua
9f036eb81f fix: 成果详情搜索表单绑定 model 以触发查询
Made-with: Cursor
2026-04-08 14:47:19 +08:00
zhonghua
36cd01c585 feat: 作品编号 workNo 生成与回填(公开端/作业/Flyway V8)及评审与前端展示
Made-with: Cursor
2026-04-08 14:44:16 +08:00
zhonghua
430dce1f09 postMessage消息对接优化 2026-04-08 14:09:52 +08:00
En
1eb76979c4 Merge remote-tracking branch 'origin/master_develop' into master_develop 2026-04-08 13:39:03 +08:00
En
fa42eca339 feat: 数据库注释补全、常量枚举重构及多模块优化
- 新增 Flyway V6/V7 迁移脚本,为全部 42 张表、591 个列添加中文注释
- 抽取公共常量类(BaseEntityConstants、CacheConstants、RoleConstants、TenantConstants)
- 新增业务枚举(CommonStatus、RegistrationStatus、WorkStatus 等 11 个)
- 优化赛事/作业/评审/UGC 等模块服务层代码
- 更新乐读派(leai)模块配置与 API 客户端
- 更新 e2e 测试用例及 demo 文件

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-08 13:37:14 +08:00
zhonghua
7d7ef9820b fix: 作品分配评委移除后同步数据库并允许清空评委
Made-with: Cursor
2026-04-08 11:30:54 +08:00
zhonghua
df7eae6125 fix: 纯评委角色隐藏机构端评委管理菜单
Made-with: Cursor
2026-04-08 11:13:35 +08:00
zhonghua
197064820b feat: 评委角色权限补全与租户评委菜单合并,更新 menu-config 说明
Made-with: Cursor
2026-04-08 11:07:11 +08:00
zhonghua
180c22fe49 feat: 作品列表终分回算、评审进度详情展示对齐及评委管理优化
Made-with: Cursor
2026-04-08 10:53:50 +08:00
En
bc7c17b281 refactor: 乐读派(leai)模块规范化改造
按照项目 Java 后端规范对 leai 模块进行全面重构:

- 新增 ILeaiWebhookEventService/ILeaiSyncService 接口,遵循 IService 模式
- Controller 层通过 Service 接口调用,不再直接注入 Mapper
- 新增 LeaiTokenVO/LeaiAuthRedirectDTO,替代 Map<String,String> 入参出参
- RuntimeException 替换为 BusinessException
- 添加 @Tag/@Operation Swagger 注解
- 提取共享工具类 LeaiUtil,消除 4 处重复的 toInt/toString 方法
- LeaiWebhookEvent 实体添加 @Schema 注解

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-08 10:23:11 +08:00
En
9b5c24c49c Merge remote-tracking branch 'origin/master_develop' into master_develop 2026-04-08 09:36:50 +08:00
En
a660493cf3 修复弹窗 2026-04-08 09:36:42 +08:00
En
922f650365 feat: 添加乐读派(leai)集成模块及E2E测试基础设施
后端:
- 新增 leai 模块:认证、Webhook、数据同步、定时对账
- 新增 LeaiConfig/RestTemplateConfig/SchedulingConfig 配置
- 新增 FlywayRepairConfig 处理迁移修复
- 新增 V5__leai_integration.sql 迁移脚本
- 扩展所有实体类添加 tenantId 等字段
- 更新 SecurityConfig 放行 leai 公开接口
- 添加 application-test.yml 测试环境配置

前端:
- 添加乐读派认证 API (public.ts)
- 优化 Generating.vue 生成页
- 添加 Playwright E2E 测试配置及依赖
- 添加测试 fixtures、utils、mock-h5.html
- 添加 leai 模块完整 E2E 测试套件

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 21:52:32 +08:00
En
9ad9f5b237 fix: 创作页 iframe tab 切换状态保持
使用 v-show 始终挂载方案替代 KeepAlive,解决 iframe 内 H5 状态
在 tab 切换后丢失的问题。Vue KeepAlive 会移动 DOM 导致浏览器
重新加载 iframe 内容,v-show 只切换 CSS display 不移动 DOM。

- PublicLayout 中将 PublicCreate 渲染在 router-view 外部
- v-if 懒挂载(首次访问创建),v-show 控制显隐
- 登出时销毁组件避免数据泄漏
- 添加 RouteMeta keepAlive 类型定义
- 添加 E2E 测试覆盖 5 个 tab 切换场景

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 21:50:08 +08:00
zhonghua
2f84ac16d3 fix:添加评委选择回显 2026-04-07 19:32:44 +08:00
zhonghua
7a039e8403 fix:分配评委时应该查询租户下的+平台的评委 2026-04-07 19:16:13 +08:00
zhonghua
1d43501983 fix:修复评委打分403 2026-04-07 17:48:48 +08:00
zhonghua
f2c10d5e32 fix:添加作品编号,报名账号,评分字段 2026-04-07 17:16:40 +08:00
zhonghua
170d904081 feat: 作品管理分配状态/评委回显 + 评委管理租户隔离
Changes:
1. ContestWorkServiceImpl: findAll 返回 assignments、_count 数据 + assignStatus 搜索
2. ContestJudgeServiceImpl: 评委列表返回 assignedCount(已分配作品数)
3. JudgesManagementServiceImpl: 评委库租户隔离(查询当前租户+平台评委,创建在当前租户、平台评委只读)
4. judges/Index.vue: 增加"来源"列 + 平台评委操作限制
5. judges-management.ts: 类型增加 isPlatform/tenantId
6. WorksDetail.vue: 小修改

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 17:10:40 +08:00
zhonghua
3fd7002e2a fix:修复评审进度500错误 2026-04-07 15:31:06 +08:00
zhonghua
633e46e663 feat: 添加评审模块Flyway迁移脚本V3
使用 DROP TABLE IF EXISTS + CREATE TABLE 确保表结构完整对齐实体类:
- t_biz_contest_judge(评委表,继承BaseEntity)
- t_biz_contest_review_rule(评审规则表,继承BaseEntity)
- t_biz_contest_work_judge_assignment(分配表,独立字段)
- t_biz_contest_work_score(评分表,继承BaseEntity)
- t_biz_preset_comment(预设评语表,继承BaseEntity)
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 15:09:31 +08:00
zhonghua
2b83c9c78a revert: 撤销评审表相关两次提交,需按设计文档规范重新实现
Reverts:
- eb40939 fix: 添加评审表自动创建兜底机制
- 015f871 feat: 创建评审模块数据库表

原因:数据库变更应使用Flyway迁移脚本规范实现,需对齐设计文档
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 14:42:58 +08:00
zhonghua
eb409398f3 fix: 添加评审表自动创建兜底机制
Flyway迁移可能未执行,添加ApplicationRunner在启动时自动检测并创建评审相关5张表。
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 14:32:50 +08:00
zhonghua
015f8718c4 feat: 创建评审模块数据库表
包含5张表:评委表、评审规则表、作品评委分配表、作品评分表、预设评语表

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 14:23:39 +08:00
zhonghua
2f521c7249 添加环境变量 2026-04-07 14:13:17 +08:00
zhonghua
1c63cb21e5 feat: 活动提交联动作品库+多租户数据对齐
1. P0-12 活动提交联动:替换文件上传为 WorkSelector 作品选择器
   - 前端 ActivityDetail.vue 集成 WorkSelector 组件
   - 后端 submitWork 支持 userWorkId 快照复制(title/description/coverUrl/pages)
   - WorkSelector 支持 redirectUrl 创作后返回活动页

2. 多租户数据对齐:修复公众端报名/作品 tenantId 不一致
   - register() 使用活动的 contestTenants[0] 作为 tenantId
   - submitWork() 使用报名记录的 tenantId
   - 管理端报名/作品统计、列表数据一致

3. 前端报名状态区分:pending/passed/rejected 显示不同按钮
4. submitWork 报名状态检查:区分未报名/审核中/已拒绝提示
5. 活动列表添加 _count(报名数/作品数)用于已交/应交展示
6. 修复 PublicCreationService.submit() title 默认值缺失

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-07 14:11:59 +08:00
zhonghua
0252f25acd Merge branch 'master_develop' of http://8.148.151.56:3000/tonytech/library-picturebook-activity into master_develop 2026-04-07 13:44:48 +08:00