2026-04-23 09:05:55 +08:00
|
|
|
|
declare namespace Api {
|
|
|
|
|
|
/**
|
|
|
|
|
|
* namespace Product
|
|
|
|
|
|
*
|
|
|
|
|
|
* backend api module: "project/product"
|
|
|
|
|
|
*/
|
|
|
|
|
|
namespace Product {
|
|
|
|
|
|
type ProductStatusCode = 'active' | 'paused' | 'archived' | 'abandoned';
|
|
|
|
|
|
|
|
|
|
|
|
type ProductStatusActionCode = 'pause' | 'resume' | 'archive' | 'abandon';
|
|
|
|
|
|
|
|
|
|
|
|
type ProductMemberStatus = 0 | 1;
|
|
|
|
|
|
|
|
|
|
|
|
interface PageParams {
|
|
|
|
|
|
pageNo: number;
|
|
|
|
|
|
pageSize: number;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface PageResult<T = any> {
|
|
|
|
|
|
total: number;
|
|
|
|
|
|
list: T[];
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface Product {
|
|
|
|
|
|
/** 产品 ID */
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
/** 产品编码 */
|
|
|
|
|
|
code: string;
|
|
|
|
|
|
/** 产品方向字典值 */
|
|
|
|
|
|
directionCode: string;
|
|
|
|
|
|
/** 产品名称 */
|
|
|
|
|
|
name: string;
|
|
|
|
|
|
/** 产品经理用户 ID */
|
|
|
|
|
|
managerUserId: string;
|
|
|
|
|
|
/** 产品描述 */
|
|
|
|
|
|
description?: string | null;
|
|
|
|
|
|
/** 产品状态编码 */
|
|
|
|
|
|
statusCode: ProductStatusCode;
|
|
|
|
|
|
/** 最近一次状态动作原因 */
|
|
|
|
|
|
lastStatusReason?: string | null;
|
|
|
|
|
|
/** 备注 */
|
|
|
|
|
|
remark?: string | null;
|
|
|
|
|
|
/** 创建时间 */
|
|
|
|
|
|
createTime: string;
|
|
|
|
|
|
/** 更新时间 */
|
|
|
|
|
|
updateTime: string;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface ProductSettingBaseInfo {
|
|
|
|
|
|
/** 产品 ID */
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
/** 产品编码 */
|
|
|
|
|
|
code: string;
|
|
|
|
|
|
/** 产品方向字典值 */
|
|
|
|
|
|
directionCode: string;
|
|
|
|
|
|
/** 产品名称 */
|
|
|
|
|
|
name: string;
|
|
|
|
|
|
/** 产品经理用户 ID */
|
|
|
|
|
|
managerUserId: string;
|
|
|
|
|
|
/** 产品经理昵称 */
|
|
|
|
|
|
managerUserNickname: string;
|
|
|
|
|
|
/** 产品描述 */
|
|
|
|
|
|
description?: string | null;
|
|
|
|
|
|
/** 当前产品状态 */
|
|
|
|
|
|
statusCode: ProductStatusCode;
|
|
|
|
|
|
/** 最近一次状态动作原因 */
|
|
|
|
|
|
lastStatusReason?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface ProductLifecycleAction {
|
|
|
|
|
|
actionCode: ProductStatusActionCode;
|
|
|
|
|
|
actionName: string;
|
|
|
|
|
|
needReason: boolean;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface ProductLifecycleInfo {
|
|
|
|
|
|
statusCode: ProductStatusCode;
|
|
|
|
|
|
lastStatusReason?: string | null;
|
|
|
|
|
|
availableActions: ProductLifecycleAction[];
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface ProductSettings {
|
|
|
|
|
|
baseInfo: ProductSettingBaseInfo;
|
|
|
|
|
|
lifecycle: ProductLifecycleInfo;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface ProductMember {
|
|
|
|
|
|
/** 团队关系 ID */
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
/** 用户 ID */
|
|
|
|
|
|
userId: string;
|
|
|
|
|
|
/** 用户昵称 */
|
|
|
|
|
|
userNickname: string;
|
|
|
|
|
|
/** 角色 ID */
|
|
|
|
|
|
roleId: string;
|
|
|
|
|
|
/** 角色名称 */
|
|
|
|
|
|
roleName: string;
|
|
|
|
|
|
/** 角色编码 */
|
|
|
|
|
|
roleCode: string;
|
|
|
|
|
|
/** 是否当前产品经理 */
|
|
|
|
|
|
managerFlag: boolean;
|
|
|
|
|
|
/** 成员状态 */
|
|
|
|
|
|
status: ProductMemberStatus;
|
|
|
|
|
|
/** 加入时间 */
|
|
|
|
|
|
joinedTime: string;
|
|
|
|
|
|
/** 退出时间 */
|
|
|
|
|
|
leftTime?: string | null;
|
|
|
|
|
|
/** 备注 */
|
|
|
|
|
|
remark?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-04-24 16:38:43 +08:00
|
|
|
|
type ProductActivityType = 'status' | 'product' | 'member';
|
|
|
|
|
|
|
|
|
|
|
|
type ProductActivityActionType =
|
|
|
|
|
|
| 'create'
|
|
|
|
|
|
| 'change_manager'
|
|
|
|
|
|
| 'pause'
|
|
|
|
|
|
| 'resume'
|
|
|
|
|
|
| 'archive'
|
|
|
|
|
|
| 'abandon'
|
|
|
|
|
|
| 'add_member'
|
|
|
|
|
|
| 'update_member'
|
|
|
|
|
|
| 'remove_member';
|
|
|
|
|
|
|
|
|
|
|
|
interface ProductActivityTimelinePageParams extends PageParams {
|
|
|
|
|
|
/** 分类 */
|
|
|
|
|
|
activityType?: ProductActivityType | null;
|
|
|
|
|
|
/** 动作编码数组,多选时按重复 query 参数传递 */
|
|
|
|
|
|
actionTypes?: ProductActivityActionType[] | null;
|
|
|
|
|
|
/** 开始时间,格式 yyyy-MM-dd HH:mm:ss */
|
|
|
|
|
|
startTime?: string | null;
|
|
|
|
|
|
/** 结束时间,格式 yyyy-MM-dd HH:mm:ss */
|
|
|
|
|
|
endTime?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface ProductActivityTimelineItem {
|
|
|
|
|
|
/** 动态唯一标识 */
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
/** 动态类型 */
|
|
|
|
|
|
type: ProductActivityType;
|
|
|
|
|
|
/** 动作编码 */
|
|
|
|
|
|
actionType: ProductActivityActionType;
|
|
|
|
|
|
/** 动作中文名称 */
|
|
|
|
|
|
actionName: string;
|
|
|
|
|
|
/** 操作人用户 ID */
|
|
|
|
|
|
operatorUserId?: string | null;
|
|
|
|
|
|
/** 操作人名称 */
|
|
|
|
|
|
operatorName: string;
|
|
|
|
|
|
/** 目标用户 ID,成员类动态使用 */
|
|
|
|
|
|
targetUserId?: string | null;
|
|
|
|
|
|
/** 目标用户名称,成员类动态使用 */
|
|
|
|
|
|
targetUserName?: string | null;
|
|
|
|
|
|
/** 动态发生时间,毫秒时间戳 */
|
|
|
|
|
|
occurredAt: number;
|
|
|
|
|
|
/** 可直接展示的摘要文案 */
|
|
|
|
|
|
summary: string;
|
|
|
|
|
|
/** 原因说明 */
|
|
|
|
|
|
reason?: string | null;
|
|
|
|
|
|
/** 原状态编码 */
|
|
|
|
|
|
fromStatus?: ProductStatusCode | null;
|
|
|
|
|
|
/** 目标状态编码 */
|
|
|
|
|
|
toStatus?: ProductStatusCode | null;
|
|
|
|
|
|
/** 补充明细,当前为 JSON 字符串 */
|
|
|
|
|
|
details?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-04-23 09:05:55 +08:00
|
|
|
|
type ProductSearchParams = CommonType.RecordNullable<
|
|
|
|
|
|
Pick<PageParams, 'pageNo' | 'pageSize'> &
|
|
|
|
|
|
Pick<Product, 'directionCode' | 'managerUserId' | 'statusCode'> & {
|
|
|
|
|
|
keyword: string;
|
|
|
|
|
|
updateTime: string[];
|
|
|
|
|
|
}
|
|
|
|
|
|
>;
|
|
|
|
|
|
|
|
|
|
|
|
type SaveProductParams = Pick<Product, 'directionCode' | 'name' | 'managerUserId'> & {
|
|
|
|
|
|
code?: string | null;
|
|
|
|
|
|
description?: string | null;
|
|
|
|
|
|
remark?: string | null;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
type UpdateProductParams = { id: string } & SaveProductParams;
|
|
|
|
|
|
|
|
|
|
|
|
interface ChangeProductStatusParams {
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
actionCode: ProductStatusActionCode;
|
|
|
|
|
|
reason?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface DeleteProductParams {
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
productName: string;
|
|
|
|
|
|
reason: string;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
type UpdateProductSettingBaseInfoParams = Pick<ProductSettingBaseInfo, 'directionCode' | 'name'> & {
|
|
|
|
|
|
description?: string | null;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
interface CreateProductMemberParams {
|
|
|
|
|
|
userId: string;
|
|
|
|
|
|
roleId: string;
|
|
|
|
|
|
remark?: string | null;
|
|
|
|
|
|
previousManagerUserId?: string | null;
|
|
|
|
|
|
previousManagerRoleId?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface UpdateProductMemberParams {
|
|
|
|
|
|
roleId: string;
|
|
|
|
|
|
remark?: string | null;
|
|
|
|
|
|
reason?: string | null;
|
|
|
|
|
|
previousManagerUserId?: string | null;
|
|
|
|
|
|
previousManagerRoleId?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface InactiveProductMemberParams {
|
|
|
|
|
|
reason?: string | null;
|
|
|
|
|
|
}
|
2026-05-06 17:50:29 +08:00
|
|
|
|
|
|
|
|
|
|
// ========== 产品需求相关类型定义 ==========
|
|
|
|
|
|
/** 需求状态编码 */
|
|
|
|
|
|
type RequirementStatusCode =
|
|
|
|
|
|
| 'pending_confirm'
|
|
|
|
|
|
| 'pending_review'
|
|
|
|
|
|
| 'pending_dispatch'
|
|
|
|
|
|
| 'implementing'
|
|
|
|
|
|
| 'accepted'
|
|
|
|
|
|
| 'closed'
|
|
|
|
|
|
| 'rejected'
|
|
|
|
|
|
| 'cancelled';
|
|
|
|
|
|
|
|
|
|
|
|
/** 需求来源类型 */
|
|
|
|
|
|
type RequirementSourceType = 'manual' | 'work_order';
|
|
|
|
|
|
|
|
|
|
|
|
/** 需求优先级 */
|
|
|
|
|
|
type RequirementPriority = 0 | 1 | 2 | 3;
|
|
|
|
|
|
|
|
|
|
|
|
/** 是否需要评审 */
|
|
|
|
|
|
type RequirementReviewRequired = 0 | 1;
|
|
|
|
|
|
|
|
|
|
|
|
// ========== 需求实体 ==========
|
|
|
|
|
|
|
|
|
|
|
|
interface Requirement {
|
|
|
|
|
|
/** 需求编号 */
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
/** 产品 ID */
|
|
|
|
|
|
productId: string;
|
|
|
|
|
|
/** 父需求编号(0表示顶级需求) */
|
|
|
|
|
|
parentId: string;
|
|
|
|
|
|
/** 所属模块编号 */
|
|
|
|
|
|
moduleId: string;
|
|
|
|
|
|
/** 是否需要评审(0不需要;1需要) */
|
|
|
|
|
|
reviewRequired: RequirementReviewRequired;
|
|
|
|
|
|
/** 需求标题 */
|
|
|
|
|
|
title: string;
|
|
|
|
|
|
/** 需求描述(富文本) */
|
|
|
|
|
|
description?: string | null;
|
|
|
|
|
|
/** 需求分类字典值 */
|
|
|
|
|
|
category: string;
|
|
|
|
|
|
/** 需求分类名称 */
|
|
|
|
|
|
categoryName?: string | null;
|
|
|
|
|
|
/** 来源类型 */
|
|
|
|
|
|
sourceType: RequirementSourceType;
|
|
|
|
|
|
/** 来源业务ID */
|
|
|
|
|
|
sourceBizId?: string | null;
|
|
|
|
|
|
/** 优先级(0低 1中 2高 3紧急) */
|
|
|
|
|
|
priority: RequirementPriority;
|
|
|
|
|
|
/** 优先级名称 */
|
|
|
|
|
|
priorityName?: string | null;
|
|
|
|
|
|
/** 当前状态编码 */
|
|
|
|
|
|
statusCode: RequirementStatusCode;
|
|
|
|
|
|
/** 当前状态名称 */
|
|
|
|
|
|
statusName?: string | null;
|
|
|
|
|
|
/** 最近一次状态动作原因 */
|
|
|
|
|
|
lastStatusReason?: string | null;
|
|
|
|
|
|
/** 提出人用户编号 */
|
|
|
|
|
|
proposerId: string;
|
|
|
|
|
|
/** 提出人用户姓名 */
|
|
|
|
|
|
proposerNickname?: string | null;
|
|
|
|
|
|
/** 当前处理人用户编号 */
|
|
|
|
|
|
currentHandlerUserId?: string | null;
|
|
|
|
|
|
/** 当前处理人姓名 */
|
|
|
|
|
|
currentHandlerUserNickname?: string | null;
|
|
|
|
|
|
/** 默认实现项目编号 */
|
|
|
|
|
|
implementProjectId?: string | null;
|
|
|
|
|
|
/** 实现项目名称 */
|
|
|
|
|
|
implementProjectName?: string | null;
|
|
|
|
|
|
/** 预期完成时间 */
|
|
|
|
|
|
completionDate: string;
|
|
|
|
|
|
/** 排序值 */
|
|
|
|
|
|
sort: number;
|
|
|
|
|
|
/** 创建时间 */
|
|
|
|
|
|
createTime: string;
|
|
|
|
|
|
/** 更新时间 */
|
|
|
|
|
|
updateTime: string;
|
|
|
|
|
|
/** 子需求列表(树形结构) */
|
|
|
|
|
|
children?: Requirement[];
|
|
|
|
|
|
/** 是否为终态 */
|
|
|
|
|
|
terminal?: boolean;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ========== 需求模块实体 ==========
|
|
|
|
|
|
|
|
|
|
|
|
interface RequirementModule {
|
|
|
|
|
|
/** 模块编号 */
|
|
|
|
|
|
id: string | undefined;
|
|
|
|
|
|
/** 父模块编号(0表示顶级) */
|
|
|
|
|
|
parentId: string | undefined;
|
|
|
|
|
|
/** 所属产品编号 */
|
|
|
|
|
|
productId: string;
|
|
|
|
|
|
/** 模块名称 */
|
|
|
|
|
|
moduleName: string;
|
|
|
|
|
|
/** 模块说明 */
|
|
|
|
|
|
remark?: string | null;
|
|
|
|
|
|
/** 图标 */
|
|
|
|
|
|
icon?: string | null;
|
|
|
|
|
|
/** 排序值 */
|
|
|
|
|
|
sort: number;
|
|
|
|
|
|
/** 子模块列表 */
|
|
|
|
|
|
children?: RequirementModule[];
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ========== 需求生命周期 ==========
|
|
|
|
|
|
|
|
|
|
|
|
interface RequirementLifecycleAction {
|
|
|
|
|
|
actionCode: string;
|
|
|
|
|
|
actionName: string;
|
|
|
|
|
|
toStatusCode: string;
|
|
|
|
|
|
toStatusName: string;
|
|
|
|
|
|
needReason: boolean;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
interface RequirementLifecycleInfo {
|
|
|
|
|
|
statusCode: RequirementStatusCode;
|
|
|
|
|
|
statusName?: string | null;
|
|
|
|
|
|
lastStatusReason?: string | null;
|
|
|
|
|
|
terminal: boolean;
|
|
|
|
|
|
allowEdit: boolean;
|
|
|
|
|
|
availableActions: RequirementLifecycleAction[];
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ========== 请求参数类型 ==========
|
|
|
|
|
|
|
|
|
|
|
|
/** 需求分页查询参数 */
|
|
|
|
|
|
type RequirementSearchParams = CommonType.RecordNullable<
|
|
|
|
|
|
Pick<PageParams, 'pageNo' | 'pageSize'> &
|
|
|
|
|
|
Pick<
|
|
|
|
|
|
Requirement,
|
|
|
|
|
|
'moduleId' | 'category' | 'priority' | 'statusCode' | 'currentHandlerUserId' | 'sourceType'
|
|
|
|
|
|
> & {
|
|
|
|
|
|
productId: string;
|
|
|
|
|
|
title?: string;
|
|
|
|
|
|
}
|
|
|
|
|
|
>;
|
|
|
|
|
|
|
|
|
|
|
|
/** 创建需求参数 */
|
|
|
|
|
|
type SaveRequirementParams = Pick<
|
|
|
|
|
|
Requirement,
|
|
|
|
|
|
| 'productId'
|
|
|
|
|
|
| 'moduleId'
|
|
|
|
|
|
| 'reviewRequired'
|
|
|
|
|
|
| 'title'
|
|
|
|
|
|
| 'description'
|
|
|
|
|
|
| 'category'
|
|
|
|
|
|
| 'priority'
|
|
|
|
|
|
| 'proposerId'
|
|
|
|
|
|
| 'currentHandlerUserId'
|
|
|
|
|
|
| 'implementProjectId'
|
|
|
|
|
|
| 'completionDate'
|
|
|
|
|
|
| 'sort'
|
|
|
|
|
|
>;
|
|
|
|
|
|
|
|
|
|
|
|
/** 更新需求参数 */
|
|
|
|
|
|
type UpdateRequirementParams = { id: string } & SaveRequirementParams;
|
|
|
|
|
|
|
|
|
|
|
|
/** 变更需求状态参数 */
|
|
|
|
|
|
interface ChangeRequirementStatusParams {
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
productId: string;
|
|
|
|
|
|
actionCode: string;
|
|
|
|
|
|
reason?: string | null;
|
|
|
|
|
|
implementProjectId?: string | null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/** 关闭需求参数 */
|
|
|
|
|
|
interface CloseRequirementParams {
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
productId: string;
|
|
|
|
|
|
reason: string;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/** 拆分需求参数 */
|
|
|
|
|
|
type SplitRequirementParams = Pick<
|
|
|
|
|
|
Requirement,
|
|
|
|
|
|
| 'parentId'
|
|
|
|
|
|
| 'productId'
|
|
|
|
|
|
| 'moduleId'
|
|
|
|
|
|
| 'reviewRequired'
|
|
|
|
|
|
| 'title'
|
|
|
|
|
|
| 'description'
|
|
|
|
|
|
| 'category'
|
|
|
|
|
|
| 'priority'
|
|
|
|
|
|
| 'proposerId'
|
|
|
|
|
|
| 'currentHandlerUserId'
|
|
|
|
|
|
| 'completionDate'
|
|
|
|
|
|
| 'sort'
|
|
|
|
|
|
>;
|
|
|
|
|
|
|
|
|
|
|
|
/** 删除需求参数 */
|
|
|
|
|
|
interface DeleteRequirementParams {
|
|
|
|
|
|
id: string;
|
|
|
|
|
|
productId: string;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ========== 模块请求参数 ==========
|
|
|
|
|
|
|
|
|
|
|
|
/** 保存模块参数 */
|
|
|
|
|
|
type SaveRequirementModuleParams = Pick<
|
|
|
|
|
|
RequirementModule,
|
|
|
|
|
|
'id' | 'productId' | 'parentId' | 'moduleName' | 'remark' | 'icon' | 'sort'
|
|
|
|
|
|
>;
|
|
|
|
|
|
|
|
|
|
|
|
/** 删除模块参数 */
|
|
|
|
|
|
interface DeleteRequirementModuleParams {
|
|
|
|
|
|
id: string | undefined;
|
|
|
|
|
|
productId: string;
|
|
|
|
|
|
}
|
2026-04-23 09:05:55 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|