|
1 | 1 | import * as React from 'react';
|
2 | 2 | import fakeRestProvider from 'ra-data-fakerest';
|
| 3 | +import { CardContent } from '@mui/material'; |
| 4 | +import { ResourceDefinitionContextProvider } from 'ra-core'; |
3 | 5 |
|
4 | 6 | import { AdminContext } from '../AdminContext';
|
5 | 7 | import { Datagrid } from '../list';
|
6 | 8 | import { ReferenceArrayField } from './ReferenceArrayField';
|
7 | 9 | import { TextField } from './TextField';
|
8 |
| -import { Show } from '../detail'; |
9 |
| -import { CardContent } from '@mui/material'; |
| 10 | +import { Show, SimpleShowLayout } from '../detail'; |
| 11 | + |
| 12 | +export default { title: 'ra-ui-materialui/fields/ReferenceArrayField' }; |
10 | 13 |
|
11 | 14 | const fakeData = {
|
12 |
| - bands: [{ id: 1, name: 'band_1', members: [1, '2', '3'] }], |
| 15 | + bands: [{ id: 1, name: 'The Beatles', members: [1, 2, 3, 4] }], |
13 | 16 | artists: [
|
14 |
| - { id: 1, name: 'artist_1' }, |
15 |
| - { id: 2, name: 'artist_2' }, |
16 |
| - { id: 3, name: 'artist_3' }, |
17 |
| - { id: 4, name: 'artist_4' }, |
| 17 | + { id: 1, name: 'John Lennon' }, |
| 18 | + { id: 2, name: 'Paul McCartney' }, |
| 19 | + { id: 3, name: 'Ringo Star' }, |
| 20 | + { id: 4, name: 'George Harrison' }, |
| 21 | + { id: 5, name: 'Mick Jagger' }, |
18 | 22 | ],
|
19 | 23 | };
|
20 |
| - |
21 |
| -export default { title: 'ra-ui-materialui/fields/ReferenceArrayField' }; |
22 |
| - |
23 | 24 | const dataProvider = fakeRestProvider(fakeData, false);
|
24 | 25 |
|
25 |
| -export const DifferentIdTypes = () => { |
26 |
| - return ( |
27 |
| - <AdminContext dataProvider={dataProvider}> |
28 |
| - <CardContent> |
29 |
| - <Show resource="bands" id={1} sx={{ width: 600 }}> |
30 |
| - <TextField source="name" fullWidth /> |
31 |
| - <ReferenceArrayField |
32 |
| - fullWidth |
33 |
| - source="members" |
34 |
| - reference="artists" |
35 |
| - > |
| 26 | +const resouceDefs = { |
| 27 | + artists: { |
| 28 | + name: 'artists', |
| 29 | + hasList: true, |
| 30 | + hasEdit: true, |
| 31 | + hasShow: true, |
| 32 | + hasCreate: true, |
| 33 | + recordRepresentation: 'name', |
| 34 | + }, |
| 35 | +}; |
| 36 | +export const Basic = () => ( |
| 37 | + <AdminContext dataProvider={dataProvider}> |
| 38 | + <ResourceDefinitionContextProvider definitions={resouceDefs}> |
| 39 | + <Show resource="bands" id={1} sx={{ width: 600 }}> |
| 40 | + <SimpleShowLayout> |
| 41 | + <TextField source="name" /> |
| 42 | + <ReferenceArrayField source="members" reference="artists" /> |
| 43 | + </SimpleShowLayout> |
| 44 | + </Show> |
| 45 | + </ResourceDefinitionContextProvider> |
| 46 | + </AdminContext> |
| 47 | +); |
| 48 | + |
| 49 | +export const Children = () => ( |
| 50 | + <AdminContext dataProvider={dataProvider}> |
| 51 | + <ResourceDefinitionContextProvider definitions={resouceDefs}> |
| 52 | + <Show resource="bands" id={1} sx={{ width: 600 }}> |
| 53 | + <SimpleShowLayout> |
| 54 | + <TextField source="name" /> |
| 55 | + <ReferenceArrayField source="members" reference="artists"> |
36 | 56 | <Datagrid bulkActionButtons={false}>
|
37 | 57 | <TextField source="id" />
|
38 | 58 | <TextField source="name" />
|
39 | 59 | </Datagrid>
|
40 | 60 | </ReferenceArrayField>
|
41 |
| - </Show> |
42 |
| - </CardContent> |
43 |
| - </AdminContext> |
44 |
| - ); |
| 61 | + </SimpleShowLayout> |
| 62 | + </Show> |
| 63 | + </ResourceDefinitionContextProvider> |
| 64 | + </AdminContext> |
| 65 | +); |
| 66 | + |
| 67 | +const fakeDataWidthDifferentIdTypes = { |
| 68 | + bands: [{ id: 1, name: 'band_1', members: [1, '2', '3'] }], |
| 69 | + artists: [ |
| 70 | + { id: 1, name: 'artist_1' }, |
| 71 | + { id: 2, name: 'artist_2' }, |
| 72 | + { id: 3, name: 'artist_3' }, |
| 73 | + { id: 4, name: 'artist_4' }, |
| 74 | + ], |
45 | 75 | };
|
| 76 | +const dataProviderWithDifferentIdTypes = fakeRestProvider( |
| 77 | + fakeDataWidthDifferentIdTypes, |
| 78 | + false |
| 79 | +); |
| 80 | + |
| 81 | +export const DifferentIdTypes = () => ( |
| 82 | + <AdminContext dataProvider={dataProviderWithDifferentIdTypes}> |
| 83 | + <CardContent> |
| 84 | + <Show resource="bands" id={1} sx={{ width: 600 }}> |
| 85 | + <TextField source="name" fullWidth /> |
| 86 | + <ReferenceArrayField |
| 87 | + fullWidth |
| 88 | + source="members" |
| 89 | + reference="artists" |
| 90 | + > |
| 91 | + <Datagrid bulkActionButtons={false}> |
| 92 | + <TextField source="id" /> |
| 93 | + <TextField source="name" /> |
| 94 | + </Datagrid> |
| 95 | + </ReferenceArrayField> |
| 96 | + </Show> |
| 97 | + </CardContent> |
| 98 | + </AdminContext> |
| 99 | +); |
46 | 100 |
|
47 | 101 | const dataProviderWithLog = {
|
48 | 102 | ...dataProvider,
|
|
0 commit comments