| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406 |
- import { useIntl } from "react-intl";
- import { Space, Button, Dropdown, Table, Modal } from "antd";
- import { ActionType, ProTable } from "@ant-design/pro-components";
- import {
- DeleteOutlined,
- BarChartOutlined,
- ExclamationCircleFilled,
- } from "@ant-design/icons";
- import { delete_, get, put } from "../../request";
- import { ICourseMember } from "./CourseMember";
- import AddMember from "./AddMember";
- import { useRef, useState } from "react";
- import {
- ICourseMemberData,
- ICourseMemberDeleteResponse,
- ICourseMemberListResponse,
- ICourseMemberResponse,
- TCourseMemberStatus,
- } from "../api/Course";
- import { ItemType } from "antd/lib/menu/hooks/useItems";
- const { confirm } = Modal;
- interface IWidget {
- studioName?: string;
- courseId?: string;
- }
- const Widget = ({ studioName, courseId }: IWidget) => {
- const intl = useIntl(); //i18n
- const [canDelete, setCanDelete] = useState(false);
- const ref = useRef<ActionType>();
- const ChangeStatus = (
- id: string,
- name: string,
- status: TCourseMemberStatus
- ) => {
- confirm({
- title: (
- <div>
- <div>
- {intl.formatMessage({
- id: `course.member.status.${status}.message`,
- })}
- </div>
- <div>{name}</div>
- </div>
- ),
- icon: <ExclamationCircleFilled />,
- onOk() {
- return put<ICourseMemberData, ICourseMemberResponse>(
- "/v2/course-member/" + id,
- {
- course_id: "",
- user_id: "",
- status: status,
- }
- )
- .then((json) => {
- if (json.ok) {
- console.log("delete ok");
- ref.current?.reload();
- }
- })
- .catch(() => console.log("Oops errors!"));
- },
- });
- };
- return (
- <>
- <ProTable<ICourseMember>
- actionRef={ref}
- columns={[
- {
- title: intl.formatMessage({
- id: "dict.fields.sn.label",
- }),
- dataIndex: "sn",
- key: "sn",
- width: 50,
- search: false,
- },
- {
- title: intl.formatMessage({
- id: "forms.fields.name.label",
- }),
- dataIndex: "name",
- key: "name",
- },
- {
- title: intl.formatMessage({
- id: "forms.fields.role.label",
- }),
- dataIndex: "role",
- key: "role",
- width: 100,
- search: false,
- filters: true,
- onFilter: true,
- valueEnum: {
- all: {
- text: intl.formatMessage({
- id: "tables.publicity.all",
- }),
- status: "Default",
- },
- student: {
- text: intl.formatMessage({
- id: "auth.role.student",
- }),
- status: "Default",
- },
- assistant: {
- text: intl.formatMessage({
- id: "auth.role.assistant",
- }),
- status: "Success",
- },
- },
- },
- {
- title: intl.formatMessage({
- id: "forms.fields.status.label",
- }),
- dataIndex: "status",
- key: "status",
- width: 100,
- search: false,
- filters: true,
- onFilter: true,
- valueEnum: {
- all: {
- text: intl.formatMessage({
- id: "tables.publicity.all",
- }),
- status: "Default",
- },
- progressing: {
- text: intl.formatMessage({
- id: "course.member.status.progressing.label",
- }),
- status: "Processing",
- },
- accepted: {
- text: intl.formatMessage({
- id: "course.member.status.accepted.label",
- }),
- status: "success",
- },
- rejected: {
- text: intl.formatMessage({
- id: "course.member.status.rejected.label",
- }),
- status: "warning",
- },
- left: {
- text: intl.formatMessage({
- id: "course.member.status.left.label",
- }),
- status: "warning",
- },
- blocked: {
- text: intl.formatMessage({
- id: "course.member.status.blocked.label",
- }),
- status: "warning",
- },
- },
- },
- {
- title: intl.formatMessage({
- id: "course.exp.start.label",
- }),
- dataIndex: "startExp",
- key: "startExp",
- },
- {
- title: intl.formatMessage({
- id: "course.exp.current.label",
- }),
- dataIndex: "currentExp",
- key: "currentExp",
- },
- {
- title: intl.formatMessage({
- id: "course.exp.end.label",
- }),
- dataIndex: "endExp",
- key: "endExp",
- },
- {
- title: intl.formatMessage({ id: "buttons.option" }),
- key: "option",
- width: 120,
- valueType: "option",
- render: (text, row, index, action) => {
- let items: ItemType[] = [];
- switch (row.status) {
- case "accepted":
- items = [
- {
- key: "exp",
- label: "经验值",
- icon: <BarChartOutlined />,
- },
- {
- key: "delete",
- label: "删除",
- icon: <DeleteOutlined />,
- },
- ];
- break;
- case "progressing":
- items = [
- {
- key: "accept",
- label: "接受",
- icon: <BarChartOutlined />,
- },
- {
- key: "reject",
- label: "拒绝",
- icon: <DeleteOutlined />,
- },
- ];
- break;
- default:
- break;
- }
- return [
- canDelete ? (
- <Dropdown.Button
- key={index}
- type="link"
- menu={{
- items,
- onClick: (e) => {
- console.log("click", e);
- switch (e.key) {
- case "exp":
- break;
- case "delete":
- confirm({
- title: `删除此成员吗?`,
- icon: <ExclamationCircleFilled />,
- content: "此操作不能恢复",
- okType: "danger",
- onOk() {
- return delete_<ICourseMemberDeleteResponse>(
- "/v2/course-member/" + row.id
- )
- .then((json) => {
- if (json.ok) {
- console.log("delete ok");
- ref.current?.reload();
- }
- })
- .catch(() => console.log("Oops errors!"));
- },
- });
- break;
- case "accept":
- if (row.id && row.name) {
- ChangeStatus(row.id, row.name, "accepted");
- }
- break;
- case "reject":
- if (row.id && row.name) {
- ChangeStatus(row.id, row.name, "rejected");
- }
- break;
- default:
- break;
- }
- },
- }}
- >
- <></>
- </Dropdown.Button>
- ) : (
- <></>
- ),
- ];
- },
- },
- ]}
- rowSelection={{
- // 自定义选择项参考: https://ant.design/components/table-cn/#components-table-demo-row-selection-custom
- // 注释该行则默认不显示下拉选项
- selections: [Table.SELECTION_ALL, Table.SELECTION_INVERT],
- }}
- tableAlertRender={({
- selectedRowKeys,
- selectedRows,
- onCleanSelected,
- }) => (
- <Space size={24}>
- <span>
- {intl.formatMessage({ id: "buttons.selected" })}
- {selectedRowKeys.length}
- <Button
- type="link"
- style={{ marginInlineStart: 8 }}
- onClick={onCleanSelected}
- >
- {intl.formatMessage({
- id: "buttons.unselect",
- })}
- </Button>
- </span>
- </Space>
- )}
- tableAlertOptionRender={() => {
- return (
- <Space size={16}>
- <Button type="link">
- {intl.formatMessage({
- id: "buttons.delete.all",
- })}
- </Button>
- </Space>
- );
- }}
- request={async (params = {}, sorter, filter) => {
- console.log(params, sorter, filter);
- let url = `/v2/course-member?view=course&id=${courseId}`;
- const offset =
- ((params.current ? params.current : 1) - 1) *
- (params.pageSize ? params.pageSize : 20);
- url += `&limit=${params.pageSize}&offset=${offset}`;
- if (typeof params.keyword !== "undefined") {
- url += "&search=" + (params.keyword ? params.keyword : "");
- }
- const res = await get<ICourseMemberListResponse>(url);
- if (res.ok) {
- console.log(res.data);
- switch (res.data.role) {
- case "owner":
- case "manager":
- case "assistant":
- setCanDelete(true);
- break;
- }
- const items: ICourseMember[] = res.data.rows.map((item, id) => {
- let member: ICourseMember = {
- sn: id + 1,
- id: item.id,
- userId: item.user_id,
- name: item.user?.nickName,
- role: item.role,
- status: item.status,
- tag: [],
- image: "",
- };
- member.tag.push({
- title: intl.formatMessage({
- id: "forms.fields." + item.role + ".label",
- }),
- color: "default",
- });
- return member;
- });
- console.log(items);
- return {
- total: res.data.count,
- succcess: true,
- data: items,
- };
- } else {
- console.error(res.message);
- return {
- total: 0,
- succcess: false,
- data: [],
- };
- }
- }}
- rowKey="id"
- bordered
- pagination={{
- showQuickJumper: true,
- showSizeChanger: true,
- }}
- search={false}
- options={{
- search: true,
- }}
- toolBarRender={() => [
- <AddMember
- courseId={courseId}
- onCreated={() => {
- ref.current?.reload();
- }}
- />,
- ]}
- />
- </>
- );
- };
- export default Widget;
|