#
luxiaotao1123
2024-02-16 9589e0e1bfd14f2297563fa9a9b3bdcbc7723b74
zy-asrs-flow/src/components/TableSearch/index.jsx
@@ -1,8 +1,10 @@
import React from 'react';
import { Input, Button, Space, Select, DatePicker } from 'antd';
import Http from '@/utils/http';
import moment from 'moment';
const NONE_OPTION = -9999;
const DATE_FORMAT = 'YYYY-MM-DD HH:mm:ss';
const TextFilter = (props) => {
    return (
@@ -120,9 +122,9 @@
                        onChange={changeDates => {
                            setDates(changeDates);
                            if (changeDates && changeDates[0] && changeDates[1]) {
                                const changeStartStr = changeDates[0]?.toISOString()
                                const changeStartStr = moment(changeDates[0]).format(DATE_FORMAT);
                                setStartDate(changeStartStr);
                                const changeEndStr = changeDates[1]?.toISOString()
                                const changeEndStr = moment(changeDates[1]).format(DATE_FORMAT);
                                setEndDate(changeEndStr);
                                props.setSelectedKeys([changeStartStr + '-' + changeEndStr]);
                            }
@@ -175,25 +177,20 @@
    const [options, setOptions] = React.useState([]);
    const fetchData = async (value) => {
        const resp = await Http.doPostForm(`api/${props.name}/query`, { condition: value });
        return resp.data;
        return await Http.doPostForm(`api/${props.name}/query`, { condition: value });
    }
    async function initOptions(value) {
        const { data } = await fetchData(value);
        setOptions(data);
    }
    React.useEffect(() => {
        async function init() {
            const data = await fetchData();
            setOptions(data);
        }
        init()
        initOptions()
    }, []);
    const handleSearch = async (value) => {
        if (value) {
            const data = await fetchData(value);
            setOptions(data);
        } else {
            setOptions([]);
        }
    const handleSearch = (value) => {
        initOptions(value)
    }
    return (
@@ -208,13 +205,10 @@
                        props.setSelectedKeys(value !== undefined && value !== null ? [value] : []);
                    }}
                    onSearch={handleSearch}
                    options={options.map(item => ({ value: item.value, label: item.label }))}
                    filterOption={false}
                    showSearch={true}
                >
                    {options.map(item => (
                        <Select.Option key={item.value} value={item.value}>
                            {item.label}
                        </Select.Option>
                    ))}
                </Select>
            </div>
            <Space>
@@ -246,6 +240,7 @@
                        setCurrentOption(NONE_OPTION)
                        props.setSelectedKeys([]);
                        props.clearFilters();
                        initOptions()
                    }}
                    size="small"
                    style={{ width: 90 }}