0.1.6 • Published 4 years ago

@rainbow_deer/layout v0.1.6

Weekly downloads
-
License
MIT
Repository
-
Last release
4 years ago

Layout

install

npm install rainbow_deer/layout
or
yarn add rainbow_deer/layout

usage

basic

import React from 'react'
import Layout from '@rainbow_deer/layout'
import { createHashHistory } from 'history'
import { HomeOutlined } from '@ant-design/icons'

export default () => {
  const routeItems = [
    {
      path: '/home',
      exact: true,
      meta: {
        tabFixed: true,
        isCache: true,
        icon: 'home',
        name: '首页',
      },
      component: () => <div>home</div>,
    },
    {
      path: '/test',
      exact: true,
      meta: {
        isCache: true,
        icon: 'success',
        name: '测试页',
      },
      component: () => <div>test</div>,
    },
  ]

  return (
    <div className='storybook__container'>
      <Layout
        proName='admin-demo'
        // aliveControl={aliveControl}
        routeItems={routeItems}
        history={createHashHistory()}
        username={'测试'}
        onClickDrop={() => {
          console.log('退出')
        }}
      >
        <div>layout</div>
      </Layout>
    </div>
  )
}

cache route

yarn add react-router-cache-route
or
npm install react-router-cache-route
import React from 'react'
import { Router, Redirect, Route } from 'react-router-dom'
import Layout from '@rainbow_deer/layout'
import { createHashHistory } from 'history'
import {
  CacheRoute,
  CacheSwitch,
  refreshByCacheKey,
  dropByCacheKey,
} from 'react-router-cache-route'

const aliveControl = {
  dropByCacheKey,
  refreshByCacheKey,
}
const Counter = () => {
  let [count, setCount] = React.useState(0)
  const handleAdd = () => setCount(++count)
  return (
    <>
      <button onClick={handleAdd}>+</button>
      {count}
    </>
  )
}

export default () => {
  const history = createHashHistory()
  const routeItems = [
    {
      path: '/home',
      exact: true,
      meta: {
        tabFixed: true,
        isCache: true,
        icon: 'home',
        name: '首页',
      },
      component: () => <div>home</div>,
    },
    {
      path: '/test',
      exact: true,
      meta: {
        isCache: true,
        icon: 'success',
        name: '测试页',
      },
      component: Counter,
    },
  ]
  const renderRoutes = () => {
    let routes = []
    const routeMap = (arr) => {
      arr.forEach((route) => {
        if (!route.meta.hidden) {
          routes.push(
            <CacheRoute // 替换Route => CacheRoute
              when={() => !!route.meta.isCache} // 是否缓存
              cacheKey={route.path} // 缓存key
              key={route.path}
              exact={route.exact}
              path={route.path}
              component={route.component}
            />
          )
        }
        if (route.routes && route.routes.length) routeMap(route.routes)
      })
    }
    routeMap(routeItems)
    return routes
  }
  return (
    <Router history={history}>
      <CacheSwitch>
        <Layout
          logo={
            ''
          }
          proName={'admin'}
          routeItems={routeItems}
          username={'admin'}
          history={history}
          aliveControl={aliveControl}
        >
          {renderRoutes()}
        </Layout>
      </CacheSwitch>
    </Router>
  )
}