mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-08 15:09:27 +08:00
82 lines
2.2 KiB
TypeScript
82 lines
2.2 KiB
TypeScript
import React from 'react';
|
|
import { Card, Descriptions, Button } from 'antd';
|
|
import { Actions } from '@/components/actions';
|
|
import api from '@/api-client';
|
|
import { useRequest } from 'umi';
|
|
import { Spin } from '@nocobase/client';
|
|
import Field from './Field';
|
|
import get from 'lodash/get';
|
|
import { useSize } from 'ahooks';
|
|
import { configResponsive, useResponsive } from 'ahooks';
|
|
configResponsive({
|
|
small: 0,
|
|
middle: 800,
|
|
large: 1200,
|
|
});
|
|
export function Details(props: any) {
|
|
const dom = document.querySelector('body');
|
|
const responsive = useResponsive();
|
|
console.log('Details.props', props)
|
|
|
|
const {
|
|
activeTab = {},
|
|
pageInfo = {},
|
|
schema,
|
|
resourceName,
|
|
associatedName,
|
|
associatedKey,
|
|
resourceKey,
|
|
} = props;
|
|
const { actions = [], actionDefaultParams = {}, fields = [] } = props.schema;
|
|
const { data = {}, loading, refresh } = useRequest(() => {
|
|
const name = associatedName ? `${associatedName}.${resourceName}` : resourceName;
|
|
return api.resource(name).get({
|
|
resourceKey,
|
|
associatedKey,
|
|
...actionDefaultParams,
|
|
});
|
|
});
|
|
let descriptionsProps: any = {
|
|
size: 'middle',
|
|
bordered: true,
|
|
}
|
|
if (responsive.small && !responsive.middle && !responsive.large) {
|
|
descriptionsProps = {
|
|
layout: 'vertical'
|
|
}
|
|
}
|
|
console.log(props);
|
|
const { displayFields = [] } = activeTab;
|
|
return (
|
|
<Card bordered={false}>
|
|
<Actions
|
|
{...props}
|
|
onFinish={() => {
|
|
refresh();
|
|
}}
|
|
style={{ marginBottom: 14 }}
|
|
actions={actions}
|
|
/>
|
|
{loading ? <Spin/> : (
|
|
<Descriptions
|
|
// layout={'vertical'}
|
|
// size={'middle'}
|
|
// bordered
|
|
{...descriptionsProps}
|
|
column={1}>
|
|
{fields.map((field: any) => {
|
|
if (Array.isArray(displayFields) && displayFields.length && displayFields.indexOf(field.id) === -1) {
|
|
return null;
|
|
}
|
|
return (
|
|
<Descriptions.Item label={field.title||field.name}>
|
|
<Field data={field} viewType={'descriptions'} schema={field} value={get(data, field.name)}/>
|
|
</Descriptions.Item>
|
|
)
|
|
})}
|
|
</Descriptions>
|
|
)}
|
|
</Card>
|
|
);
|
|
}
|