From 678b33e4520f316795632d56f1e64609ff0a4479 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pawe=C5=82=20Suwi=C5=84ski?= Date: Wed, 22 May 2024 14:47:07 +0200 Subject: [PATCH] AdminGuesserProps - add admin prop type --- src/AdminGuesser.test.tsx | 37 +++++- src/AdminGuesser.tsx | 2 + src/__snapshots__/AdminGuesser.test.tsx.snap | 125 +++++++++++++++++++ 3 files changed, 163 insertions(+), 1 deletion(-) diff --git a/src/AdminGuesser.test.tsx b/src/AdminGuesser.test.tsx index 374c4481..e34d35bb 100644 --- a/src/AdminGuesser.test.tsx +++ b/src/AdminGuesser.test.tsx @@ -1,7 +1,10 @@ import React from 'react'; +import { AdminUI, AuthContext } from 'react-admin'; +import type { AdminProps, AuthProvider } from 'react-admin'; import ReactTestRenderer from 'react-test-renderer/shallow'; -import { AdminResourcesGuesser } from './AdminGuesser.js'; +import AdminGuesser, { AdminResourcesGuesser } from './AdminGuesser.js'; import ResourceGuesser from './ResourceGuesser.js'; +import schemaAnalyzer from './hydra/schemaAnalyzer.js'; import resources from './__fixtures__/resources.js'; import { API_DATA } from './__fixtures__/parsedData.js'; import type { @@ -83,4 +86,36 @@ describe('', () => { expect(renderer.getRenderOutput()).toMatchSnapshot(); }); + + test('renders with admin element', () => { + const authProvider: AuthProvider = { + getPermissions: () => Promise.resolve(['user']), + getIdentity: () => + Promise.resolve({ + id: '/users/2', + fullName: 'Test User', + avatar: undefined, + }), + login: () => Promise.resolve(), + logout: () => Promise.resolve(), + checkAuth: () => Promise.resolve(), + checkError: () => Promise.resolve(), + }; + + const AdminEl = (props: AdminProps) => ( + + + + ); + + renderer.render( + , + ); + + expect(renderer.getRenderOutput()).toMatchSnapshot(); + }); }); diff --git a/src/AdminGuesser.tsx b/src/AdminGuesser.tsx index 1f3b42bd..f9de4564 100644 --- a/src/AdminGuesser.tsx +++ b/src/AdminGuesser.tsx @@ -30,6 +30,7 @@ import useDisplayOverrideCode from './useDisplayOverrideCode.js'; import type { ApiPlatformAdminDataProvider, SchemaAnalyzer } from './types.js'; export interface AdminGuesserProps extends AdminProps { + admin?: ComponentType; dataProvider: ApiPlatformAdminDataProvider; schemaAnalyzer: SchemaAnalyzer; includeDeprecated?: boolean; @@ -214,6 +215,7 @@ AdminGuesser.propTypes = { children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]), theme: PropTypes.object, includeDeprecated: PropTypes.bool, + admin: PropTypes.elementType, }; /* eslint-enable tree-shaking/no-side-effects-in-initialization */ diff --git a/src/__snapshots__/AdminGuesser.test.tsx.snap b/src/__snapshots__/AdminGuesser.test.tsx.snap index 85acc1f7..2dd8b754 100644 --- a/src/__snapshots__/AdminGuesser.test.tsx.snap +++ b/src/__snapshots__/AdminGuesser.test.tsx.snap @@ -2,6 +2,131 @@ exports[` renders loading 1`] = ``; +exports[` renders with admin element 1`] = ` + + + +`; + exports[` renders with custom resources 1`] = `