You've already forked DataMate
- 移除 TemplateConfigurationForm 组件并引入 TemplateConfigurationTreeEditor - 使用 useTagConfig Hook 获取标签配置 - 将自定义XML状态 customXml 替换为 labelConfig - 删除模板编辑标签页和选择模板状态管理 - 更新XML解析逻辑支持更多对象和标注控件类型 - 添加配置验证功能确保至少包含数据对象和标注控件 - 在模板详情页面使用树形编辑器显示配置详情 - 更新任务创建页面集成新的树形配置编辑器 - 调整预览数据生成功能适配新的XML解析方式
136 lines
4.3 KiB
Python
136 lines
4.3 KiB
Python
"""
|
|
Annotation Template API Endpoints
|
|
"""
|
|
from typing import Optional
|
|
from fastapi import APIRouter, Depends, HTTPException, Query
|
|
from sqlalchemy.ext.asyncio import AsyncSession
|
|
|
|
from app.db.session import get_db
|
|
from app.module.shared.schema import StandardResponse
|
|
from app.module.annotation.schema import (
|
|
CreateAnnotationTemplateRequest,
|
|
UpdateAnnotationTemplateRequest,
|
|
AnnotationTemplateResponse,
|
|
AnnotationTemplateListResponse
|
|
)
|
|
from app.module.annotation.service.template import AnnotationTemplateService
|
|
|
|
router = APIRouter(prefix="/template", tags=["annotation/template"])
|
|
|
|
template_service = AnnotationTemplateService()
|
|
|
|
|
|
@router.post(
|
|
"",
|
|
response_model=StandardResponse[AnnotationTemplateResponse],
|
|
)
|
|
async def create_template(
|
|
request: CreateAnnotationTemplateRequest,
|
|
db: AsyncSession = Depends(get_db)
|
|
):
|
|
"""
|
|
创建新的标注模板
|
|
|
|
- **name**: 模板名称(必填,最多100字符)
|
|
- **description**: 模板描述(可选,最多500字符)
|
|
- **dataType**: 数据类型(必填)
|
|
- **labelingType**: 标注类型(必填)
|
|
- **labelConfig**: Label Studio XML 配置(必填)
|
|
- **style**: 样式配置(默认horizontal)
|
|
- **category**: 模板分类(默认custom)
|
|
"""
|
|
template = await template_service.create_template(db, request)
|
|
return StandardResponse(code=200, message="success", data=template)
|
|
|
|
|
|
@router.get(
|
|
"/{template_id}",
|
|
response_model=StandardResponse[AnnotationTemplateResponse],
|
|
)
|
|
async def get_template(
|
|
template_id: str,
|
|
db: AsyncSession = Depends(get_db)
|
|
):
|
|
"""
|
|
根据ID获取模板详情
|
|
"""
|
|
template = await template_service.get_template(db, template_id)
|
|
if not template:
|
|
raise HTTPException(status_code=404, detail="Template not found")
|
|
return StandardResponse(code=200, message="success", data=template)
|
|
|
|
|
|
@router.get(
|
|
"",
|
|
response_model=StandardResponse[AnnotationTemplateListResponse],
|
|
)
|
|
async def list_template(
|
|
page: int = Query(1, ge=1, description="页码"),
|
|
size: int = Query(10, ge=1, le=100, description="每页大小"),
|
|
keyword: Optional[str] = Query(None, description="关键词"),
|
|
category: Optional[str] = Query(None, description="分类筛选"),
|
|
dataType: Optional[str] = Query(None, alias="dataType", description="数据类型筛选"),
|
|
labelingType: Optional[str] = Query(None, alias="labelingType", description="标注类型筛选"),
|
|
builtIn: Optional[bool] = Query(None, alias="builtIn", description="是否内置模板"),
|
|
db: AsyncSession = Depends(get_db)
|
|
):
|
|
"""
|
|
获取模板列表,支持分页和筛选
|
|
|
|
- **page**: 页码(从1开始)
|
|
- **size**: 每页大小(1-100)
|
|
- **keyword**: 关键词(匹配名称/描述)
|
|
- **category**: 模板分类筛选
|
|
- **dataType**: 数据类型筛选
|
|
- **labelingType**: 标注类型筛选
|
|
- **builtIn**: 是否只显示内置模板
|
|
"""
|
|
templates = await template_service.list_templates(
|
|
db=db,
|
|
page=page,
|
|
size=size,
|
|
category=category,
|
|
data_type=dataType,
|
|
labeling_type=labelingType,
|
|
built_in=builtIn,
|
|
keyword=keyword
|
|
)
|
|
return StandardResponse(code=200, message="success", data=templates)
|
|
|
|
|
|
@router.put(
|
|
"/{template_id}",
|
|
response_model=StandardResponse[AnnotationTemplateResponse],
|
|
)
|
|
async def update_template(
|
|
template_id: str,
|
|
request: UpdateAnnotationTemplateRequest,
|
|
db: AsyncSession = Depends(get_db)
|
|
):
|
|
"""
|
|
更新模板信息
|
|
|
|
所有字段都是可选的,只更新提供的字段
|
|
"""
|
|
template = await template_service.update_template(db, template_id, request)
|
|
if not template:
|
|
raise HTTPException(status_code=404, detail="Template not found")
|
|
return StandardResponse(code=200, message="success", data=template)
|
|
|
|
|
|
@router.delete(
|
|
"/{template_id}",
|
|
response_model=StandardResponse[bool],
|
|
)
|
|
async def delete_template(
|
|
template_id: str,
|
|
db: AsyncSession = Depends(get_db)
|
|
):
|
|
"""
|
|
删除模板(软删除)
|
|
"""
|
|
success = await template_service.delete_template(db, template_id)
|
|
if not success:
|
|
raise HTTPException(status_code=404, detail="Template not found")
|
|
return StandardResponse(code=200, message="success", data=True)
|