2022-11-18 ant-design/pro-components基础使用

import services from '@/services/demo';

import {

ActionType,

  FooterToolbar,

  PageContainer,

  ProDescriptions,

  ProDescriptionsItemProps,

  ProTable,

}from '@ant-design/pro-components';

import {Button, Divider, Drawer, message }from 'antd';

import React, {useRef, useState }from 'react';

import CreateFormfrom './components/CreateForm';

import UpdateForm, { FormValueType }from './components/UpdateForm';

const {addUser, queryUserList, deleteUser, modifyUser } =

services.UserController;

/**

* 添加节点

* @param fields

*/

const handleAdd =async (fields: API.UserInfo) => {

const hide =message.loading('正在添加');

  try {

await addUser({ ...fields });

    hide();

    message.success('添加成功');

return true;

  }catch (error) {

hide();

    message.error('添加失败请重试!');

return false;

  }

};

/**

* 更新节点

* @param fields

*/

const handleUpdate =async (fields: FormValueType) => {

const hide =message.loading('正在配置');

  try {

await modifyUser(

{

userId: fields.id ||'',

      },

      {

name: fields.name ||'',

        nickName: fields.nickName ||'',

        email: fields.email ||'',

      },

    );

    hide();

    message.success('配置成功');

return true;

  }catch (error) {

hide();

    message.error('配置失败请重试!');

return false;

  }

};

/**

*  删除节点

* @param selectedRows

*/

const handleRemove =async (selectedRows: API.UserInfo[]) => {

const hide =message.loading('正在删除');

  if (!selectedRows)return true;

  try {

await deleteUser({

userId: selectedRows.find((row) => row.id)?.id ||'',

    });

    hide();

    message.success('删除成功,即将刷新');

return true;

  }catch (error) {

hide();

    message.error('删除失败,请重试');

return false;

  }

};

const TableList: React.FC = () => {

const [createModalVisible, handleModalVisible] =useState(false);

  const [updateModalVisible, handleUpdateModalVisible] =

useState(false);

  const [stepFormValues, setStepFormValues] =useState({});

  const actionRef =useRef();

  const [row, setRow] =useState();

  const [selectedRowsState, setSelectedRows] =useState([]);

  const columns: ProDescriptionsItemProps[] = [

{

title:'名称',

      dataIndex:'name',

      tip:'名称是唯一的 key',

      formItemProps: {

rules: [

{

required:true,

            message:'名称为必填项',

          },

        ],

      },

    },

    {

title:'昵称',

      dataIndex:'nickName',

      valueType:'text',

    },

    {

title:'性别',

      dataIndex:'gender',

      hideInForm:true,

      valueEnum: {

0: {text:'男', status:'MALE' },

        1: {text:'女', status:'FEMALE' },

      },

    },

    {

title:'操作',

      dataIndex:'option',

      valueType:'option',

      render: (_, record) => (

<>

            onClick={() => {

handleUpdateModalVisible(true);

              setStepFormValues(record);

            }}

>

            配置


          <Divider type="vertical" />

          <a href="">订阅警报

      ),

    },

  ];

  return (

      header={{

title:'CRUD 示例',

      }}

>

      <ProTable

headerTitle="查询表格"

        actionRef={actionRef}

rowKey="id"

        search={{

labelWidth:120,

        }}

toolBarRender={() => [

            key="1"

            type="primary"

            onClick={() =>handleModalVisible(true)}

>

            新建

          </Button>,

        ]}

request={async (params, sorter, filter) => {

const { data, success } =await queryUserList({

...params,

            // FIXME: remove @ts-ignore

            // @ts-ignore

            sorter,

            filter,

          });

          return {

data: data?.list || [],

            success,

          };

        }}

columns={columns}

rowSelection={{

onChange: (_, selectedRows) =>setSelectedRows(selectedRows),

        }}

/>

      {selectedRowsState?.length >0 && (

          extra={

              已选择{' '}

<a style={{fontWeight:600 }}>{selectedRowsState.length}</a>{' '}

项 


          }

>

            onClick={async () => {

await handleRemove(selectedRowsState);

              setSelectedRows([]);

              actionRef.current?.reloadAndRest?.();

            }}

>

            批量删除


          <Button type="primary">批量审批

      )}

        onCancel={() =>handleModalVisible(false)}

modalVisible={createModalVisible}

>

        <ProTable

onSubmit={async (value) => {

const success =await handleAdd(value);

            if (success) {

handleModalVisible(false);

              if (actionRef.current) {

actionRef.current.reload();

              }

}

}}

rowKey="id"

          type="form"

          columns={columns}

/>

      {stepFormValues &&Object.keys(stepFormValues).length ? (

          onSubmit={async (value) => {

const success =await handleUpdate(value);

            if (success) {

handleUpdateModalVisible(false);

              setStepFormValues({});

              if (actionRef.current) {

actionRef.current.reload();

              }

}

}}

onCancel={() => {

handleUpdateModalVisible(false);

            setStepFormValues({});

          }}

updateModalVisible={updateModalVisible}

values={stepFormValues}

/>

      ) :null}

        width={600}

visible={!!row}

onClose={() => {

setRow(undefined);

        }}

closable={false}

>

        {row?.name && (

<ProDescriptions

column={2}

title={row?.name}

request={async () => ({

data: row || {},

            })}

params={{

id:row?.name,

            }}

columns={columns}

/>

        )}

  );

};

export default TableList;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容