代码拉取完成,页面将自动刷新
import { Layout, Menu, Popconfirm } from 'antd'
import { Outlet, Link, useLocation, useNavigate } from 'react-router-dom'
import { observer } from 'mobx-react-lite'
import {
HomeOutlined,
DiffOutlined,
EditOutlined,
LogoutOutlined
} from '@ant-design/icons'
import './index.scss'
import { useStore } from '@/store'
import { useEffect } from 'react'
const { Header, Sider } = Layout
const GeekLayout = () => {
const { pathname } = useLocation()
const { userStore, loginStore, channelStore } = useStore()
useEffect(() => {
userStore.getUserInfo()
channelStore.loadChannelList()
}, [userStore, channelStore])
// 确定退出
const navigate = useNavigate()
const onConfirm = () => {
// 退出登录 删除token 跳回到登录
loginStore.loginOut()
navigate('/login')
}
return (
<Layout>
<Header className="header">
<div className="logo" />
<div className="user-info">
<span className="user-name">{userStore.userInfo.name}</span>
<span className="user-logout">
<Popconfirm
onConfirm={onConfirm}
title="是否确认退出?" okText="退出" cancelText="取消">
<LogoutOutlined /> 退出
</Popconfirm>
</span>
</div>
</Header>
<Layout>
<Sider width={200} className="site-layout-background">
{/* 高亮原理:defaultSelectedKeys === item key */}
{/* 获取当前激活的path路径? */}
{/*
defaultSelectedKeys: 初始化渲染的时候生效一次
selectedKeys: 每次有值更新时都会重新渲染视图
*/}
<Menu
mode="inline"
theme="dark"
defaultSelectedKeys={pathname}
selectedKeys={pathname}
style={{ height: '100%', borderRight: 0 }}
>
<Menu.Item icon={<HomeOutlined />} key="/">
<Link to='/'>数据概览</Link>
</Menu.Item>
<Menu.Item icon={<DiffOutlined />} key="/article">
<Link to="/article">内容管理</Link>
</Menu.Item>
<Menu.Item icon={<EditOutlined />} key="/publish">
<Link to='/publish'> 发布文章</Link>
</Menu.Item>
</Menu>
</Sider>
<Layout className="layout-content" style={{ padding: 20 }}>
{/* 二级路由出口 */}
<Outlet />
</Layout>
</Layout>
</Layout>
)
}
export default observer(GeekLayout)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。