/*
 * @Author: donghao donghao@supervision.ltd
 * @Date: 2024-04-30 10:02:29
 * @LastEditors: donghao donghao@supervision.ltd
 * @LastEditTime: 2024-05-21 15:26:02
 * @FilePath: \general-ai-platform-web\src\pages\Business\DeviceGroup\components\modelSetting.tsx
 * @Description: 业务模型部署
 * @交互说明
 * 1、业务模型部署列表的分页展示
 * 2、配置参数功能
 */
import TableActionCard from '@/components/TableActionCard';
import { getModelGroupBaseModelList } from '@/services/testApi/model';
import type { ProColumns } from '@ant-design/pro-components';
import { ProList, ProTable } from '@ant-design/pro-components';
import { FormattedMessage } from '@umijs/max';
import { Button } from 'antd';
import { useEffect, useState } from 'react';
// import CreateForm from './components/createForm';
import { isSuccessApi } from '@/utils/forApi';
import CreateModelParams from './createModelParams';

type ModelSettingProps = {
  info: Record<string, any>;
};

const ModelSetting: React.FC<ModelSettingProps> = () => {
  /**state */
  const [modelData, setModelData] = useState<Record<string, any>[]>([]); // 列表数据

  // const intl = useIntl();

  const [createModalOpen, setCreateModalOpen] = useState<boolean>(false);
  // const [categoryFkIdIds, setCategoryFkIdIds] = useState([]);
  //  动态设置每页数量
  // const [currentRow, setCurrentRow] = useState<Record<string, any>>({});

  /**配置参数 */
  const handleCreateModal = () => {
    setCreateModalOpen(!createModalOpen);
  };

  // 业务模型列表信息
  const columns: ProColumns<Record<string, any>>[] = [
    {
      title: <FormattedMessage id="base_model.table.list.name" defaultMessage="基础模型名称" />,
      dataIndex: 'name',
      hideInSearch: true,
      key: 'fixedName',
      fixed: 'left',
      width: '30%',
    },
    {
      title: <FormattedMessage id="base_model.table.list.version" defaultMessage="版本" />,
      dataIndex: 'version',
      hideInSearch: true,
      width: '20%',
    },
    {
      title: (
        <FormattedMessage id="base_model.table.list.runtimeLibFile" defaultMessage="运行库镜像" />
      ),
      dataIndex: 'runtimeLibFile',
      hideInSearch: true,
      render: (dom, record) => {
        return (
          <div>
            {record.runtimeLibFile ? (
              dom
            ) : (
              <div className={`gn_list_type_tag flex items-center justify-center active2`}>
                <span className="dot"></span>
                <span>
                  <FormattedMessage
                    id="base_model.table.list.undeployed.runtimeLibFile"
                    defaultMessage="未部署"
                  />
                </span>
              </div>
            )}
          </div>
        );
      },
    },
    {
      title: <FormattedMessage id="pages.searchTable.titleOption" defaultMessage="操作" />,
      dataIndex: 'option',
      valueType: 'option',
      fixed: 'right',
      key: 'option',
      render: () => [
        <TableActionCard
          key="TableActionCardRef"
          renderActions={[
            {
              key: 'setConfig',
              renderDom: (
                <Button
                  key="setConfig"
                  type="link"
                  size="small"
                  onClick={() => {
                    handleCreateModal();
                  }}
                >
                  <FormattedMessage
                    id="base_model.table.list.action.config"
                    defaultMessage="配置参数"
                  />
                </Button>
              ),
            },
          ]}
        ></TableActionCard>,
      ],
    },
  ];

  // 将数据组装成reactDom
  function toListDomByData(record) {
    let startList = [...record];
    let finalList = startList.map((item) => ({
      content: (
        <div>
          <div className="gn_list_card_title pb-[12px]">
            <span></span>
            <span>{item.name}</span>
          </div>
          <ProTable
            className="gn_pro_table mb-[16px]"
            // headerTitle={
            //   <div>
            //     <span></span>
            //     <span>{item.name}</span>
            //   </div>
            // }
            cardProps={{
              bodyStyle: { padding: 0, margin: 0 },
            }}
            // 标题栏
            search={false}
            options={{ fullScreen: false, setting: false, density: false, reload: false }}
            rowKey="id"
            onDataSourceChange={(data) => {
              console.log(data, 'onDataSourceChange_data');
            }}
            pagination={false}
            columnsState={{
              persistenceKey: 'algorithm_model_list',
              persistenceType: 'localStorage',
            }}
            dataSource={item.list}
            columns={columns}
          />
        </div>
      ),
    }));
    setModelData(finalList);
    console.log(finalList, 'toListDomByData_finalList');
  }

  // 基础模型列表数据api
  async function fetchData() {
    const resp = await getModelGroupBaseModelList();
    if (isSuccessApi(resp)) {
      toListDomByData(resp.data.data);
    }
  }

  function reloadList() {
    fetchData();
  }

  // 初始化加载
  useEffect(() => {
    fetchData();
  }, []);

  return (
    <div className="dg_modelSetting_page">
      <ProList<{ title: string }>
        itemLayout="vertical"
        itemCardProps={{
          ghost: true,
          bodyStyle: { padding: 0, margin: 0 },
          style: {
            width: '100%',
            border: 0,
          },
        }}
        cardProps={{
          style: { padding: 0, margin: 0 }, // 设置卡片的内外边距为 0
          bodyStyle: {
            padding: 0,
            margin: 0,
            height: 'calc(100vh - 420px)',
            overflow: 'scroll',
          },
        }}
        rowKey="id"
        dataSource={modelData}
        pagination={false}
        rowSelection={false}
        metas={{
          content: {
            style: { margin: 0, padding: 0 },
          },
        }}
      />
      <CreateModelParams
        createModalOpen={createModalOpen}
        handleModal={handleCreateModal}
        reload={reloadList}
      />
    </div>
  );
};

export default ModelSetting;