新增 競賽建立、評審建立、團隊建立

This commit is contained in:
2025-09-15 13:32:30 +08:00
parent b85a9ce95e
commit 31ffaa1974
31 changed files with 5163 additions and 455 deletions

View File

@@ -0,0 +1,195 @@
// =====================================================
// 團隊成員管理 API
// =====================================================
import { NextRequest, NextResponse } from 'next/server';
import { TeamService } from '@/lib/services/database-service';
// 獲取團隊成員
export async function GET(request: NextRequest, { params }: { params: { id: string } }) {
try {
const { id } = await params;
// 檢查團隊是否存在
const team = await TeamService.getTeamById(id);
if (!team) {
return NextResponse.json({
success: false,
message: '團隊不存在',
error: '找不到指定的團隊'
}, { status: 404 });
}
const members = await TeamService.getTeamMembers(id);
return NextResponse.json({
success: true,
message: '團隊成員獲取成功',
data: members
});
} catch (error) {
console.error('獲取團隊成員失敗:', error);
return NextResponse.json({
success: false,
message: '獲取團隊成員失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}
// 添加團隊成員
export async function POST(request: NextRequest, { params }: { params: { id: string } }) {
try {
const { id } = await params;
const body = await request.json();
// 驗證必填字段
if (!body.user_id || !body.role) {
return NextResponse.json({
success: false,
message: '請提供用戶ID和角色',
error: '缺少必填字段'
}, { status: 400 });
}
// 檢查團隊是否存在
const team = await TeamService.getTeamById(id);
if (!team) {
return NextResponse.json({
success: false,
message: '團隊不存在',
error: '找不到指定的團隊'
}, { status: 404 });
}
// 添加團隊成員
const success = await TeamService.addTeamMember(id, body.user_id, body.role);
if (!success) {
return NextResponse.json({
success: false,
message: '添加團隊成員失敗',
error: '無法添加團隊成員'
}, { status: 500 });
}
return NextResponse.json({
success: true,
message: '團隊成員添加成功',
data: { team_id: id, user_id: body.user_id, role: body.role }
});
} catch (error) {
console.error('添加團隊成員失敗:', error);
return NextResponse.json({
success: false,
message: '添加團隊成員失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}
// 更新團隊成員角色
export async function PUT(request: NextRequest, { params }: { params: { id: string } }) {
try {
const { id } = await params;
const body = await request.json();
// 驗證必填字段
if (!body.user_id || !body.role) {
return NextResponse.json({
success: false,
message: '請提供用戶ID和角色',
error: '缺少必填字段'
}, { status: 400 });
}
// 檢查團隊是否存在
const team = await TeamService.getTeamById(id);
if (!team) {
return NextResponse.json({
success: false,
message: '團隊不存在',
error: '找不到指定的團隊'
}, { status: 404 });
}
// 更新團隊成員角色
const success = await TeamService.updateTeamMemberRole(id, body.user_id, body.role);
if (!success) {
return NextResponse.json({
success: false,
message: '更新團隊成員角色失敗',
error: '無法更新團隊成員角色'
}, { status: 500 });
}
return NextResponse.json({
success: true,
message: '團隊成員角色更新成功',
data: { team_id: id, user_id: body.user_id, role: body.role }
});
} catch (error) {
console.error('更新團隊成員角色失敗:', error);
return NextResponse.json({
success: false,
message: '更新團隊成員角色失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}
// 移除團隊成員
export async function DELETE(request: NextRequest, { params }: { params: { id: string } }) {
try {
const { id } = await params;
const url = new URL(request.url);
const userId = url.searchParams.get('user_id');
if (!userId) {
return NextResponse.json({
success: false,
message: '請提供用戶ID',
error: '缺少用戶ID參數'
}, { status: 400 });
}
// 檢查團隊是否存在
const team = await TeamService.getTeamById(id);
if (!team) {
return NextResponse.json({
success: false,
message: '團隊不存在',
error: '找不到指定的團隊'
}, { status: 404 });
}
// 移除團隊成員
const success = await TeamService.removeTeamMember(id, userId);
if (!success) {
return NextResponse.json({
success: false,
message: '移除團隊成員失敗',
error: '無法移除團隊成員'
}, { status: 500 });
}
return NextResponse.json({
success: true,
message: '團隊成員移除成功',
data: { team_id: id, user_id: userId }
});
} catch (error) {
console.error('移除團隊成員失敗:', error);
return NextResponse.json({
success: false,
message: '移除團隊成員失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}

View File

@@ -0,0 +1,154 @@
// =====================================================
// 團隊詳細操作 API
// =====================================================
import { NextRequest, NextResponse } from 'next/server';
import { TeamService } from '@/lib/services/database-service';
// 獲取單一團隊
export async function GET(request: NextRequest, { params }: { params: { id: string } }) {
try {
const { id } = await params;
const team = await TeamService.getTeamById(id);
if (!team) {
return NextResponse.json({
success: false,
message: '團隊不存在',
error: '找不到指定的團隊'
}, { status: 404 });
}
// 獲取團隊成員
const members = await TeamService.getTeamMembers(id);
team.members = members;
// 獲取團隊應用
const apps = await TeamService.getTeamApps(id);
team.apps = apps;
return NextResponse.json({
success: true,
message: '團隊獲取成功',
data: team
});
} catch (error) {
console.error('獲取團隊失敗:', error);
return NextResponse.json({
success: false,
message: '獲取團隊失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}
// 更新團隊
export async function PUT(request: NextRequest, { params }: { params: { id: string } }) {
try {
const { id } = await params;
const body = await request.json();
// 檢查團隊是否存在
const existingTeam = await TeamService.getTeamById(id);
if (!existingTeam) {
return NextResponse.json({
success: false,
message: '團隊不存在',
error: '找不到指定的團隊'
}, { status: 404 });
}
// 如果更新名稱,檢查是否重複
if (body.name && body.name !== existingTeam.name) {
const nameExists = await TeamService.getTeamByName(body.name);
if (nameExists) {
return NextResponse.json({
success: false,
message: '團隊名稱已存在',
error: '團隊名稱重複'
}, { status: 409 });
}
}
// 更新團隊
const success = await TeamService.updateTeam(id, body);
if (!success) {
return NextResponse.json({
success: false,
message: '更新團隊失敗',
error: '無法更新團隊'
}, { status: 500 });
}
// 獲取更新後的團隊信息
const updatedTeam = await TeamService.getTeamById(id);
return NextResponse.json({
success: true,
message: '團隊更新成功',
data: updatedTeam
});
} catch (error) {
console.error('更新團隊失敗:', error);
return NextResponse.json({
success: false,
message: '更新團隊失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}
// 刪除團隊
export async function DELETE(request: NextRequest, { params }: { params: { id: string } }) {
try {
const { id } = await params;
const url = new URL(request.url);
const hardDelete = url.searchParams.get('hard') === 'true';
// 檢查團隊是否存在
const existingTeam = await TeamService.getTeamById(id);
if (!existingTeam) {
return NextResponse.json({
success: false,
message: '團隊不存在',
error: '找不到指定的團隊'
}, { status: 404 });
}
let success: boolean;
if (hardDelete) {
// 硬刪除:從資料庫中完全移除
success = await TeamService.hardDeleteTeam(id);
} else {
// 軟刪除:將 is_active 設為 false
success = await TeamService.deleteTeam(id);
}
if (!success) {
return NextResponse.json({
success: false,
message: '刪除團隊失敗',
error: '無法刪除團隊'
}, { status: 500 });
}
return NextResponse.json({
success: true,
message: hardDelete ? '團隊已永久刪除' : '團隊已停用',
data: { hardDelete }
});
} catch (error) {
console.error('刪除團隊失敗:', error);
return NextResponse.json({
success: false,
message: '刪除團隊失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}

View File

@@ -0,0 +1,111 @@
// =====================================================
// 團隊管理 API
// =====================================================
import { NextRequest, NextResponse } from 'next/server';
import { TeamService } from '@/lib/services/database-service';
// 獲取所有團隊
export async function GET(request: NextRequest) {
try {
const { searchParams } = new URL(request.url);
const search = searchParams.get('search') || '';
const department = searchParams.get('department') || '';
let teams = await TeamService.getAllTeams();
// 應用篩選
if (search) {
teams = teams.filter(team =>
team.name.toLowerCase().includes(search.toLowerCase()) ||
team.leader_name?.toLowerCase().includes(search.toLowerCase())
);
}
if (department && department !== 'all') {
teams = teams.filter(team => team.department === department);
}
return NextResponse.json({
success: true,
message: '團隊列表獲取成功',
data: teams
});
} catch (error) {
console.error('獲取團隊列表失敗:', error);
return NextResponse.json({
success: false,
message: '獲取團隊列表失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}
// 創建團隊
export async function POST(request: NextRequest) {
try {
const body = await request.json();
// 驗證必填字段
if (!body.name || !body.leader_id || !body.department || !body.contact_email) {
return NextResponse.json({
success: false,
message: '請填寫所有必填字段',
error: '缺少必填字段'
}, { status: 400 });
}
// 檢查團隊名稱是否已存在
const existingTeam = await TeamService.getTeamByName(body.name);
if (existingTeam) {
return NextResponse.json({
success: false,
message: '團隊名稱已存在',
error: '團隊名稱重複'
}, { status: 409 });
}
// 創建團隊
const teamId = await TeamService.createTeam({
name: body.name,
leader_id: body.leader_id,
department: body.department,
contact_email: body.contact_email,
description: body.description
});
// 如果提供了成員列表,添加成員
if (body.members && Array.isArray(body.members)) {
for (const member of body.members) {
if (member.user_id && member.role) {
await TeamService.addTeamMember(teamId, member.user_id, member.role);
}
}
}
// 如果提供了應用列表,綁定應用
if (body.apps && Array.isArray(body.apps)) {
for (const appId of body.apps) {
await TeamService.bindAppToTeam(teamId, appId);
}
}
// 獲取創建後的團隊信息
const createdTeam = await TeamService.getTeamById(teamId);
return NextResponse.json({
success: true,
message: '團隊創建成功',
data: createdTeam
});
} catch (error) {
console.error('創建團隊失敗:', error);
return NextResponse.json({
success: false,
message: '創建團隊失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}

View File

@@ -0,0 +1,26 @@
// =====================================================
// 團隊統計 API
// =====================================================
import { NextResponse } from 'next/server';
import { TeamService } from '@/lib/services/database-service';
export async function GET() {
try {
const stats = await TeamService.getTeamStats();
return NextResponse.json({
success: true,
message: '團隊統計獲取成功',
data: stats
});
} catch (error) {
console.error('獲取團隊統計失敗:', error);
return NextResponse.json({
success: false,
message: '獲取團隊統計失敗',
error: error instanceof Error ? error.message : '未知錯誤'
}, { status: 500 });
}
}