## MODIFIED Requirements ### Requirement: 排期队列操作函数迁移至独立模块 系统 SHALL 将内容排期队列相关函数从 `main.py` 提取至 `services/queue_ops.py`,包括:`generate_to_queue`、`_queue_publish_callback`、`queue_refresh_table`、`queue_refresh_calendar`、`queue_preview_item`、`queue_approve_item`、`queue_reject_item`、`queue_delete_item`、`queue_retry_item`、`queue_publish_now`、`queue_start_processor`、`queue_stop_processor`、`queue_get_status`、`queue_batch_approve`、`queue_generate_and_refresh`。 `generate_to_queue` SHALL 新增 `auto_schedule: bool = False` 和 `auto_approve: bool = False` 参数: - 当 `auto_schedule=True` 时,SHALL 为每篇生成的内容调用 `PublishQueue.auto_schedule_item()` 自动分配排期时间 - 当 `auto_approve=True` 时,SHALL 在入队后自动将状态从 `draft` 变为 `approved`(或 `scheduled`,如果有排期时间) #### Scenario: 模块导入成功 - **WHEN** `main.py` 执行 `from services.queue_ops import queue_generate_and_refresh, queue_refresh_table` 等导入 - **THEN** 所有函数可正常调用 #### Scenario: publish callback 在 main.py 完成注册 - **WHEN** 应用启动时 `main.py` 调用 `pub_queue.set_publish_callback(_queue_publish_callback)`(`_queue_publish_callback` 已迁移至 `queue_ops.py`) - **THEN** 队列发布回调 SHALL 正常注册并在队列处理时触发 #### Scenario: 队列操作读写 pub_queue 单例 - **WHEN** `queue_ops.py` 中的函数需要访问 `pub_queue` 或 `queue_publisher` - **THEN** 这些单例 SHALL 通过函数参数传入,不在 `queue_ops.py` 模块顶层初始化 #### Scenario: 自动排期生成 - **WHEN** 调用 `generate_to_queue(auto_schedule=True)` 生成 3 篇内容 - **THEN** 每篇内容入队后 SHALL 调用 `auto_schedule_item()` 分配排期时间,3 篇内容 SHALL 分配到不同时段 #### Scenario: 自动审核生成 - **WHEN** 调用 `generate_to_queue(auto_approve=True)` - **THEN** 入队项 SHALL 在添加后立即被审核通过,状态变为 `approved` 或 `scheduled` #### Scenario: queue_generate_and_refresh 传递新参数 - **WHEN** UI 层调用 `queue_generate_and_refresh` 且用户勾选了自动排期 - **THEN** `auto_schedule=True` SHALL 被传递到 `generate_to_queue`