lrj
2 天以前 c61d4fe27c97d2ecc907756aa571a4ef14a7b9b6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
// 评委管理 API
 
const GRAPHQL_ENDPOINT = 'http://localhost:8080/api/graphql';
 
// GraphQL 查询语句
const GET_ALL_JUDGES_QUERY = `
  query GetAllJudges {
    judges {
      id
      name
      description
      title
      company
      phone
      gender
      specialties {
        id
        name
        code
      }
      avatarUrl
    }
  }
`;
 
const GET_JUDGE_QUERY = `
  query GetJudge($id: ID!) {
    judge(id: $id) {
      id
      name
      description
      title
      company
      phone
      gender
      specialties {
        id
        name
        code
      }
      avatarUrl
    }
  }
`;
 
const SAVE_JUDGE_MUTATION = `
  mutation SaveJudge($input: JudgeInput!) {
    saveJudge(input: $input) {
      id
      name
      phone
      gender
      description
    }
  }
`;
 
const DELETE_JUDGE_MUTATION = `
  mutation DeleteJudge($id: ID!) {
    deleteJudge(id: $id)
  }
`;
 
const GET_TAGS_QUERY = `
  query GetTags {
    tags {
      id
      name
      code
      category
    }
  }
`;
 
const GET_TAGS_BY_CATEGORY_QUERY = `
  query GetTagsByCategory($category: String!) {
    tagsByCategory(category: $category) {
      id
      name
      code
    }
  }
`;
 
const SAVE_MEDIA_MUTATION = `
  mutation SaveMedia($input: MediaInput!) {
    saveMedia(input: $input) {
      id
      name
      path
      fullUrl
    }
  }
`;
 
// GraphQL 请求函数
const graphqlRequest = async (query, variables = {}) => {
  const response = await fetch(GRAPHQL_ENDPOINT, {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
    },
    body: JSON.stringify({
      query,
      variables
    })
  });
 
  const result = await response.json();
  if (result.errors) {
    throw new Error(result.errors[0].message);
  }
  return result.data;
};
 
// API 函数
export const getAllJudges = async () => {
  const data = await graphqlRequest(GET_ALL_JUDGES_QUERY);
  return data.judges || [];
};
 
export const getJudge = async (id) => {
  const data = await graphqlRequest(GET_JUDGE_QUERY, { id });
  return data.judge;
};
 
// JudgeApi 对象
export const JudgeApi = {
  // 获取所有评委
  getJudges: async () => {
    const data = await graphqlRequest(GET_ALL_JUDGES_QUERY);
    return data.judges || [];
  },
 
  // 获取单个评委
  getJudge: async (id) => {
    const data = await graphqlRequest(GET_JUDGE_QUERY, { id });
    return data.judge;
  },
 
  // 搜索评委
  searchJudges: async (name) => {
    // 先获取所有评委,然后在客户端过滤(实际项目中应该在后端实现)
    const judges = await JudgeApi.getJudges();
    return judges.filter(judge => 
      judge.name && judge.name.toLowerCase().includes(name.toLowerCase())
    );
  },
 
  // 保存评委
  saveJudge: async (input) => {
    const data = await graphqlRequest(SAVE_JUDGE_MUTATION, { input });
    return data.saveJudge;
  },
 
  // 删除评委
  deleteJudge: async (id) => {
    const data = await graphqlRequest(DELETE_JUDGE_MUTATION, { id });
    return data.deleteJudge;
  },
 
  // 获取所有标签
  getTags: async () => {
    const data = await graphqlRequest(GET_TAGS_QUERY);
    return data.tags || [];
  },
 
  // 根据类别获取标签
  getTagsByCategory: async (category) => {
    const data = await graphqlRequest(GET_TAGS_BY_CATEGORY_QUERY, { category });
    return data.tagsByCategory || [];
  },
 
  // 保存媒体
  saveMedia: async (input) => {
    const data = await graphqlRequest(SAVE_MEDIA_MUTATION, { input });
    return data.saveMedia;
  }
};
 
// COS上传服务(暂时为空,可以后续实现)
export const CosUploadService = {
  uploadFile: async (file) => {
    // 这里可以实现COS上传逻辑
    throw new Error('COS上传功能暂未实现');
  }
};