123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363 |
- /*
- * @Author: code4eat awesomedema@gmail.com
- * @Date: 2023-03-03 11:30:33
- * @LastEditors: code4eat awesomedema@gmail.com
- * @LastEditTime: 2024-09-09 10:39:38
- * @FilePath: /KC-MiddlePlatform/src/pages/platform/setting/pubDicTypeMana/index.tsx
- * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
- */
- import { createFromIconfontCN } from '@ant-design/icons';
- import { ActionType, DrawerForm, EditableFormInstance, EditableProTable, ProFormInstance, ProFormSelect } from '@ant-design/pro-components';
- import { ModalForm, ProFormDigit, ProFormText, ProFormTextArea } from '@ant-design/pro-form'
- import { ProColumns } from '@ant-design/pro-table';
- import { Input, message, Popconfirm } from 'antd';
- import { useEffect, useRef, useState } from 'react'
- import { addData, delData, editData, getData } from './service';
- import './style.less';
- import KCIMPagecontainer from '@/components/KCIMPageContainer';
- import { KCIMTable } from '@/components/KCIMTable';
- import KCIMDrawerForm from '@/components/KCIMDrawerForm';
- const IconFont = createFromIconfontCN({
- scriptUrl: '',
- });
- type TableDataResponse = {
- data: any[];
- success: boolean;
- total: number;
- pageSize: number;
- totalPage: number;
- };
- export default function FenyeTemplate() {
- const [tableDataFilterParams, set_tableDataFilterParams] = useState<any | undefined>();
- const [tableDataSearchKeywords, set_tableDataSearchKeywords] = useState<string>('');
- const tableRef = useRef<ActionType>();
- const columns: ProColumns[] = [
- {
- title: 'ID',
- dataIndex: 'id',
- },
- {
- title: '模板名称',
- dataIndex: 'name',
- },
- {
- title: '创建时间',
- dataIndex: 'date',
- },
- {
- title: '创建人',
- dataIndex: 'createUserName',
- },
- {
- title: '备注说明',
- dataIndex: 'remark',
- },
- {
- title: '操作',
- key: 'option',
- width: 120,
- valueType: 'option',
- render: (_: any, record: any) => {
- return [
- <UpDataActBtn key={'act'} record={record} type='EDIT' />,
- <Popconfirm
- title="是否确认作废?"
- key="del"
- onConfirm={() => delTableData(record)}
- >
- <a>作废</a>
- </Popconfirm>
- ]
- },
- },
- ]
- const getTableData = async (params: any):Promise<TableDataResponse|any[]> => {
- const resp = await getData(params);
- if (resp) {
- if(resp.totalCount == 0 && resp.currPage != 1){
- return getTableData({...params,current:resp.currPage - 1});
- }else{
- return {
- data: resp.list,
- success: true,
- total: resp.totalCount,
- pageSize: resp.pageSize,
- totalPage: resp.totalPage,
- }
- }
-
- }
- return []
- }
- const delTableData = async (record: any) => {
- const resp = await delData(record.id);
- if (resp) {
- message.success('操作成功!');
- tableRef.current?.reload();
- // message.success('操作成功!');
- }
- }
- const updateTable = async (formVal: any, type: 'EDIT' | "ADD") => {
- const content = formVal.table.map((a: any) => ({
- }))
- if (type == 'ADD') {
- const result = {
- name: formVal.name,
- content: JSON.stringify(formVal.table),
- remark: formVal.remark
- }
- const resp = await addData({ ...result });
- if (resp) {
- tableRef.current?.reload();
- message.success('操作成功!');
- }
- }
- if (type == 'EDIT') {
- const result = {
- id: formVal.id,
- name: formVal.name,
- content: JSON.stringify(formVal.table),
- remark: formVal.remark
- }
- const resp = await editData({ ...result });
- if (resp) {
- tableRef.current?.reload();
- message.success('操作成功!');
- }
- }
- return true;
- }
- const UpDataActBtn = ({ record, type }: { record: any, type: 'EDIT' | 'ADD' }) => {
- const editableFormRef = useRef<EditableFormInstance>();
- const formRef = useRef<ProFormInstance<any>>();
- const editorFormRef = useRef<EditableFormInstance<any>>();
-
- const editableColumns: ProColumns[] = [
- {
- title: '标题',
- dataIndex: 'title',
- editable: () => true
- },
- {
- title: '类型',
- dataIndex: 'filedType',
- editable: () => false
- },
- {
- title: '是否必填',
- dataIndex: 'required',
- request: async () => [
- {
- value: 1,
- label: '是',
- },
- {
- value: 0,
- label: '否',
- },
- ],
- fieldProps: (_, { rowIndex }) => {
- return {
- onSelect: () => {
- // 每次选中重置参数
- editableFormRef.current?.setRowData?.(rowIndex, { fraction: [] });
- },
- };
- },
- renderText(text) {
- return text ? '是' : '否'
- },
- },
- {
- title: '是否展示信息',
- dataIndex: 'showFiled',
- request: async () => [
- {
- value: 1,
- label: '是',
- },
- {
- value: 0,
- label: '否',
- },
- ],
- fieldProps: (_, { rowIndex }) => {
- return {
- onSelect: () => {
- // 每次选中重置参数
- editableFormRef.current?.setRowData?.(rowIndex, { fraction: [] });
- },
- };
- },
- renderText(text) {
- return text ? '是' : '否'
- },
- },
- {
- title: '操作',
- valueType: 'option',
- render: (text, record, _, action) => [
- <a
- key="editable"
- onClick={() => {
- console.log({record});
- action?.startEditable?.(record.tempId);
- }}
- >
- 编辑
- </a>,
- <a
- key="delete"
- onClick={() => {
- const tableDataSource = formRef.current?.getFieldValue(
- 'table',
- ) as any[];
- formRef.current?.setFieldsValue({
- table: tableDataSource.filter((item) => item.tempId !== record.tempId),
- });
- }}
- >
- 删除
- </a>,
- ],
- },
- ];
- let defaultTableData = JSON.parse(record.content ? record.content : '[]');
- defaultTableData = defaultTableData.map((a: any) => ({ ...a, tempId: (Math.random() * 1000000).toFixed(0) }));
- const [tempData, setTempData] = useState<any[]>(defaultTableData);
- // console.log({defaultTableData});
- return (
- <KCIMDrawerForm
- title={`${type == 'EDIT' ? '编辑' : '新增'}模板数据`}
- width={800}
- initialValues={type == 'EDIT' ? { ...record, table: defaultTableData, filedType: 'Text' } : { filedType: 'Text' }}
- trigger={
- type == 'EDIT' ? <a key="edit" >编辑</a> : <span className='add'>新增</span>
- }
- onFinish={(val: any) => {
- return updateTable(type == 'EDIT' ? { ...record, ...val } : { ...val }, type);
- }}
- formRef={formRef}
- drawerProps={{ destroyOnClose: true }}
- colProps={{ span: 24 }}
- grid
- >
- <ProFormText
- name="name"
- label="模板名称:"
- placeholder="请输入"
- width={300}
- rules={[{ required: true, message: '名称不能为空!' }]}
- />
- <ProFormTextArea
- name="remark"
- label="备注说明:"
- placeholder="请输入"
- />
- <EditableProTable
- className='pfm-EditableProTable'
- name='table'
- style={{margin:'0 4px'}}
- rowKey={'tempId'}
- editableFormRef={editorFormRef}
- tableStyle={{ padding: 0 }}
- columns={editableColumns}
- // controlled
- editable={{}}
- recordCreatorProps={{
- record: () => ({ tempId: (Math.random() * 1000000).toFixed(0), filedType: 'Text' }),
-
- }}
- />
- </KCIMDrawerForm>
- )
- }
- const tableDataSearchHandle = (paramName: string) => {
- set_tableDataFilterParams({
- ...tableDataFilterParams,
- [`${paramName}`]: tableDataSearchKeywords
- })
- }
- useEffect(() => {
- }, [])
- return (
- <KCIMPagecontainer className='FenyeTemplate' title={false}>
- <div className='toolBar'>
- <div className='filter'>
- <div className='filterItem' style={{ marginRight: 16, width: 205 }}>
- <span className='label' style={{ whiteSpace: 'nowrap' }}> 检索:</span>
- <Input placeholder={'请输入模板名称'} allowClear autoComplete='off'
- suffix={
- <IconFont type="iconsousuo" style={{ color: '#99A6BF' }} onClick={() => tableDataSearchHandle('filter')} />
- }
- onChange={(e) => {
- set_tableDataSearchKeywords(e.target.value);
- if (e.target.value.length == 0) {
- set_tableDataFilterParams({
- ...tableDataFilterParams,
- filter: ''
- });
- }
- }}
- onPressEnter={(e) => {
- set_tableDataFilterParams({
- ...tableDataFilterParams,
- filter: (e.target as HTMLInputElement).value
- });
- }}
- />
- </div>
- </div>
- <div className='btnGroup'>
- <UpDataActBtn record type='ADD' />
- </div>
- </div>
- <div style={{ marginTop: 16 }}>
- <KCIMTable columns={columns as ProColumns[]} actionRef={tableRef} rowKey='id' params={tableDataFilterParams} request={(params) => getTableData(params)} />
- </div>
- </KCIMPagecontainer>
- )
- }
|