* feat(member-group): Team (#2616) * feat: member-group schema define * feat(fe): create group * feat: add group edit modal * feat(fe): add avatar group component * feat: edit group fix: permission select menu style * feat: bio-mode support for select-member component * fix: avatar group key unique * feat: group manage * feat: divide member into group and clbs * feat: finish team permission * chore: adjust * fix: get clbs * perf: groups code * pref: member group for team (#2706) * chore: fe adjust fix: remove the member from groups when removing from team feat: change the groups avatar when updating the team's avatar * chore: DefaultGroupName as a constant string '' * fix: create default group when create team for root * feat: comment * feat: 4811 init * pref: member group for team (#2732) * chore: default group name * feat: get default group when get by tmbid * feat(fe): adjust * member ui * fix: delete group (#2736) * perf: init4811 * pref: member group (#2818) * fix: update clb per then refetch clb list * fix: calculate group permission * feat(fe): group tag * refactor(fe): team and group manage * feat: manage group member * feat: add group transfer owner modal * feat: group manage member * chore: adjust the file structure * pref: member group * chore: adjust fe style * fix: ts error * chore: fe adjust * chore: fe adjust * chore: adjust * chore: adjust the code * perf: i18n and schema name * pref: member-group (#2862) * feat: group list ordered by updateTime * fix: transfer ownership of group when deleting member * fix: i18n fix * feat: can not set member as admin/owner when user is not active * fix: GroupInfoModal hover input do not change color * fix(fe): searchinput do not scroll * perf: team group ui * doc * remove enum --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
73 lines
3.5 KiB
TypeScript
73 lines
3.5 KiB
TypeScript
import { GET, POST, PUT, DELETE } from '@/web/common/api/request';
|
|
import { UpdatePermissionBody } from '@fastgpt/global/support/permission/collaborator';
|
|
import {
|
|
CreateTeamProps,
|
|
InviteMemberProps,
|
|
InviteMemberResponse,
|
|
UpdateInviteProps,
|
|
UpdateTeamProps
|
|
} from '@fastgpt/global/support/user/team/controller.d';
|
|
import type { TeamTagItemType, TeamTagSchema } from '@fastgpt/global/support/user/team/type';
|
|
import {
|
|
TeamTmbItemType,
|
|
TeamMemberItemType,
|
|
TeamMemberSchema
|
|
} from '@fastgpt/global/support/user/team/type.d';
|
|
import { FeTeamPlanStatusType, TeamSubSchema } from '@fastgpt/global/support/wallet/sub/type';
|
|
import { TeamInvoiceHeaderType } from '@fastgpt/global/support/user/team/type';
|
|
import { ResourcePermissionType } from '@fastgpt/global/support/permission/type';
|
|
|
|
/* --------------- team ---------------- */
|
|
export const getTeamList = (status: `${TeamMemberSchema['status']}`) =>
|
|
GET<TeamTmbItemType[]>(`/proApi/support/user/team/list`, { status });
|
|
export const postCreateTeam = (data: CreateTeamProps) =>
|
|
POST<string>(`/proApi/support/user/team/create`, data);
|
|
export const putUpdateTeam = (data: UpdateTeamProps) => PUT(`/support/user/team/update`, data);
|
|
export const putSwitchTeam = (teamId: string) =>
|
|
PUT<string>(`/proApi/support/user/team/switch`, { teamId });
|
|
|
|
/* --------------- team member ---------------- */
|
|
export const getTeamMembers = () =>
|
|
GET<TeamMemberItemType[]>(`/proApi/support/user/team/member/list`);
|
|
export const postInviteTeamMember = (data: InviteMemberProps) =>
|
|
POST<InviteMemberResponse>(`/proApi/support/user/team/member/invite`, data);
|
|
export const putUpdateMemberName = (name: string) =>
|
|
PUT(`/proApi/support/user/team/member/updateName`, { name });
|
|
export const delRemoveMember = (tmbId: string) =>
|
|
DELETE(`/proApi/support/user/team/member/delete`, { tmbId });
|
|
export const updateInviteResult = (data: UpdateInviteProps) =>
|
|
PUT('/proApi/support/user/team/member/updateInvite', data);
|
|
export const delLeaveTeam = (teamId: string) =>
|
|
DELETE('/proApi/support/user/team/member/leave', { teamId });
|
|
|
|
export const getTeamClbs = () =>
|
|
GET<ResourcePermissionType[]>(`/proApi/support/user/team/collaborator/list`);
|
|
|
|
/* -------------- team collaborator -------------------- */
|
|
export const updateMemberPermission = (data: UpdatePermissionBody) =>
|
|
PUT('/proApi/support/user/team/collaborator/updatePermission', data);
|
|
|
|
/* --------------- team tags ---------------- */
|
|
export const getTeamsTags = () => GET<TeamTagSchema[]>(`/proApi/support/user/team/tag/list`);
|
|
export const loadTeamTagsByDomain = (domain: string) =>
|
|
GET<TeamTagItemType[]>(`/proApi/support/user/team/tag/async`, { domain });
|
|
|
|
/* team limit */
|
|
export const checkTeamExportDatasetLimit = (datasetId: string) =>
|
|
GET(`/support/user/team/limit/exportDatasetLimit`, { datasetId });
|
|
export const checkTeamWebSyncLimit = () => GET(`/support/user/team/limit/webSyncLimit`);
|
|
export const checkTeamDatasetSizeLimit = (size: number) =>
|
|
GET(`/support/user/team/limit/datasetSizeLimit`, { size });
|
|
|
|
/* plans */
|
|
export const getTeamPlanStatus = () =>
|
|
GET<FeTeamPlanStatusType>(`/support/user/team/plan/getTeamPlanStatus`, { maxQuantity: 1 });
|
|
export const getTeamPlans = () =>
|
|
GET<TeamSubSchema[]>(`/proApi/support/user/team/plan/getTeamPlans`);
|
|
|
|
export const getTeamInvoiceHeader = () =>
|
|
GET<TeamInvoiceHeaderType>(`/proApi/support/user/team/invoiceAccount/getTeamInvoiceHeader`);
|
|
|
|
export const updateTeamInvoiceHeader = (data: TeamInvoiceHeaderType) =>
|
|
POST(`/proApi/support/user/team/invoiceAccount/update`, data);
|