admin on rest 在侧边栏中隐藏资源组件
admin on rest hide resource component in sidebar
我需要一个资源及其所有配置,但我不希望它显示在边栏中
如文档中所述,您可以使用 menu
属性将 Menu
组件提供给 Admin
组件。看
https://marmelab.com/react-admin/Admin.html#menu
请注意,此道具很快就会被弃用,取而代之的是 appLayout
,但您仍然会在自定义布局中使用此自定义菜单。
// in src/Menu.js
import React from 'react';
import { connect } from 'react-redux';
import { MenuItemLink, getResources } from 'react-admin';
import { withRouter } from 'react-router-dom';
import Responsive from '../layout/Responsive';
const Menu = ({ resources, onMenuClick, logout }) => (
<div>
{resources
.filter(resource => resource.name !== 'excluded-resource')
.map(resource => (
<MenuItemLink to={`/${resource.name}`} primaryText={resource.name} onClick={onMenuClick} />
))
}
<Responsive
small={logout}
medium={null} // Pass null to render nothing on larger devices
/>
</div>
);
const mapStateToProps = state => ({
// Rerieve all known resources
resources: getResources(state),
});
export default withRouter(connect(mapStateToProps)(Menu));
如果你想在侧边栏菜单中隐藏资源,你可以省略资源的列表属性。
<Resource name="posts" />
我发现了一种不同的“hacky”方式
您可以在 css 中添加以下内容以从菜单中隐藏资源
.MuiDrawer-root a[href^='#/resource-to-exclude'] {
display: none;
}
我需要一个资源及其所有配置,但我不希望它显示在边栏中
如文档中所述,您可以使用 menu
属性将 Menu
组件提供给 Admin
组件。看
https://marmelab.com/react-admin/Admin.html#menu
请注意,此道具很快就会被弃用,取而代之的是 appLayout
,但您仍然会在自定义布局中使用此自定义菜单。
// in src/Menu.js
import React from 'react';
import { connect } from 'react-redux';
import { MenuItemLink, getResources } from 'react-admin';
import { withRouter } from 'react-router-dom';
import Responsive from '../layout/Responsive';
const Menu = ({ resources, onMenuClick, logout }) => (
<div>
{resources
.filter(resource => resource.name !== 'excluded-resource')
.map(resource => (
<MenuItemLink to={`/${resource.name}`} primaryText={resource.name} onClick={onMenuClick} />
))
}
<Responsive
small={logout}
medium={null} // Pass null to render nothing on larger devices
/>
</div>
);
const mapStateToProps = state => ({
// Rerieve all known resources
resources: getResources(state),
});
export default withRouter(connect(mapStateToProps)(Menu));
如果你想在侧边栏菜单中隐藏资源,你可以省略资源的列表属性。
<Resource name="posts" />
我发现了一种不同的“hacky”方式 您可以在 css 中添加以下内容以从菜单中隐藏资源
.MuiDrawer-root a[href^='#/resource-to-exclude'] {
display: none;
}