| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- import { Link } from "react-router";
- import { useIntl } from "react-intl";
- import { Button, Popover, Tag, Space } from "antd";
- import { type ActionType, ProList } from "@ant-design/pro-components";
- import { PlusOutlined } from "@ant-design/icons";
- import { get } from "../../request";
- import { useRef, useState } from "react";
- import { getSorterUrl } from "../../utils";
- import type { IAiModel, IAiModelListResponse } from "../../api/ai";
- import AiModelCreate from "./AiModelCreate";
- import PublicityIcon from "../studio/PublicityIcon";
- import ShareModal from "../share/ShareModal";
- import { EResType } from "../share/Share";
- import User from "../auth/User";
- interface IWidget {
- studioName?: string;
- }
- const AiModelList = ({ studioName }: IWidget) => {
- const intl = useIntl(); //i18n
- const [openCreate, setOpenCreate] = useState(false);
- const ref = useRef<ActionType | null>(null);
- return (
- <>
- <ProList<IAiModel>
- actionRef={ref}
- onRow={(_record) => ({
- onClick: () => {},
- })}
- metas={{
- title: {
- dataIndex: "name",
- render(_dom, entity, _index, _action, _schema) {
- return (
- <Space>
- <PublicityIcon value={entity.privacy} />
- <Link
- to={`/studio/${studioName}/ai/models/${entity.uid}/edit`}
- >
- {entity.name}
- </Link>
- </Space>
- );
- },
- },
- description: {
- dataIndex: "url",
- },
- subTitle: {
- render(_dom, entity, _index, _action, _schema) {
- return <Tag>{entity.model}</Tag>;
- },
- },
- content: {
- render(_dom, entity, _index, _action, _schema) {
- return entity.description;
- },
- },
- avatar: {
- render(_dom, entity, _index, _action, _schema) {
- return <User {...entity.user} showName={false} />;
- },
- },
- actions: {
- render(_dom, entity, _index, _action, _schema) {
- return (
- <Space>
- <Link
- to={`/studio/${studioName}/ai/models/${entity.uid}/logs`}
- >
- logs
- </Link>
- <ShareModal
- trigger={
- <Button type="link" size="small">
- {intl.formatMessage({
- id: "buttons.share",
- })}
- </Button>
- }
- resId={entity.uid}
- resType={EResType.modal}
- />
- </Space>
- );
- },
- },
- }}
- request={async (params = {}, sorter, filter) => {
- console.log(params, sorter, filter);
- let url = `/v2/ai-model?view=studio&name=${studioName}`;
- const offset = ((params.current ?? 1) - 1) * (params.pageSize ?? 20);
- url += `&limit=${params.pageSize}&offset=${offset}`;
- url += params.keyword ? "&search=" + params.keyword : "";
- url += getSorterUrl(sorter);
- console.info("api request", url);
- const res = await get<IAiModelListResponse>(url);
- console.info("api response", res);
- return {
- total: res.data.total,
- succcess: res.ok,
- data: res.data.rows,
- };
- }}
- rowKey="id"
- bordered
- pagination={{
- showQuickJumper: true,
- showSizeChanger: true,
- }}
- search={false}
- options={{
- search: true,
- }}
- toolBarRender={() => [
- <Popover
- content={
- <AiModelCreate
- studioName={studioName}
- onCreate={() => {
- setOpenCreate(false);
- ref.current?.reload();
- }}
- />
- }
- placement="bottomRight"
- trigger="click"
- open={openCreate}
- onOpenChange={(open: boolean) => {
- setOpenCreate(open);
- }}
- >
- <Button key="button" icon={<PlusOutlined />} type="primary">
- {intl.formatMessage({ id: "buttons.create" })}
- </Button>
- </Popover>,
- ]}
- />
- </>
- );
- };
- export default AiModelList;
|