V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
favori
V2EX  ›  React

React Dashboard 仪表板解决方案

  •  1
     
  •   favori · 2021-09-10 22:32:49 +08:00 · 847 次点击
    这是一个创建于 1167 天前的主题,其中的信息可能已经有所发展或是发生改变。

    React Dashboard Pro

    npm version npm version npm version npm version npm version npm version

    开箱即用的一站式仪表板解决方案

    只需简单几步即可拥有动态仪表板功能

    解决的是"千人千面"的 B 端几乎都要用到的 Dashboard + Widget 客制化需求。

    repository-open-graph-template 副本

    Repository

    https://github.com/yuanguandong/react-dashboard-pro

    Live demo

    https://yuanguandong.github.io/react-dashboard-pro/

    Install

    npm i react-dashboard-pro -S
    
    git clone https://github.com/yuanguandong/react-widgets
    

    How to use

    import React, { useState } from 'react';
    import type { LayoutsIF } from 'react-dashboard-pro';
    import Dashboard from 'react-dashboard-pro';
    import allWidgets from '../widgets';
    
    export default () => {
      const [layout, setLayout] = useState<LayoutsIF>([]);
      const onLayoutChange = (layout: LayoutsIF) => {
        setLayout(layout);
      };
      return (
        <Dashboard
          widgets={allWidgets}
          onLayoutChange={onLayoutChange}
          layout={layout}
        />
      );
    };
    

    Props

    property description type defaultValue required
    widgets 可选的小程序对象集合 { [key: string]:widget} true
    editMode 是否编辑状态 boolean false false
    defaultLayout 默认布局 layoutItem[] [] false
    widgetWrapClassName widget 容器类名 string false
    widgetWrapStyle widget 容器样式 React.CSSProperties false
    layout 布局数据 layoutItem[] null false
    minHeight 最小高度 number 300 false
    maxWidgetLength 当前仪表板最大可添加的 widget 数量 number 20 false
    toolbar 是否显示默认工具栏 {type: 'left' | 'right' | 'top' | 'bottom'; speed: number;} true false
    storageKey 本地存储唯一标识 boolean 'default' false
    onLayoutChange 布局改变的回调 (layout: LayoutsIF) => void false
    onReset 清空按钮的回调 (dirtyCurrentLayout: LayoutsIF, currentLayout: LayoutItem) => void false
    onRemoveWidget 删除小程序的回调 (widget: widgetIF,dirtyCurrentLayout: LayoutsIF,currentLayout: LayoutsIF) => void false
    onAddWidget 添加小程序的回调 (widget: widgetIF,dirtyCurrentLayout: LayoutsIF,currentLayout: LayoutsIF) => void false
    onReload 刷新按钮的回调 (currentLayout: LayoutsIF) => void false
    onCancelEdit 取消编辑的回调 (dirtyCurrentLayout: LayoutsIF,currentLayout: LayoutItem) => void false
    onEdit 进入编辑的回调 (currentLayout: LayoutsIF) => void false
    onSave 保存按钮的回调 (currentLayout: LayoutsIF) => void false
    onRevert 恢复按钮的回调 (dirtyCurrentLayout: LayoutsIF, currentLayout: LayoutItem) => void false

    Widget

    widget 可以是开放式的任何内容,可以自由扩展,入口文件需要导出一个对象来描述这个 widget, 对象格式如下,更多 widget 可以看这里

    预设的 widget 基本都依赖了 antd,使用了 less, 注意依赖的安装

    property description type defaultValue required
    name 小程序名称 string true
    description 小程序描述 string true
    tags 标签,被用作小程序选择器分类依据 string[] true
    component 小程序组件 ReactElement true
    configComponent 小程序对应的配置组件 ReactElement true
    maxLength 该小程序在当前仪表板最大可添加数量 number true
    snapShot 小程序快照图片,用于小程序选择器显示 ImageBitmapSource true
    icon 小程序图标,用于小程序选择器显示 ReactElement true
    iconBackground 小程序图标背景,用于小程序选择器显示 string true
    size 小程序尺寸信息 {defaultWidth: number;defaultHeight: number;maxWidth: number;maxHeight: number;minWidth: number;minHeight: number} true
    // todo/index.tsx
    import { CalendarOutlined } from '@ant-design/icons';
    import Panel from './component';
    import snapShot from './snapshot.png';
    
    export default {
      name: 'Todo',
      description: 'todo list',
      tags: ['all','list'],
      component: Panel,
      configComponent: null,
      maxLength: 2,
      snapShot,
      icon: <CalendarOutlined />,
      iconBackground: 'linear-gradient(-20deg, #b721ff 0%, #21d4fd 100%)',
      size: {
        defaultWidth: 3,
        defaultHeight: 11,
        maxWidth: 12,
        maxHeight: 16,
        minWidth: 2,
        minHeight: 4,
      },
    }
    // **/**.index ……
    
    // widgets/index.tsx
    import Clock from './clock';
    import Column from './column';
    import Guide from './guide';
    import Popular from './popular';
    import Ring from './ring';
    import Todo from './todo';
    
    export default{ Clock,Guide,Popular,Todo,Column,Ring };
    
    

    Layout

    布局信息一般情况下不需要太关注,只需要序列化的以字符串方式存储下来即可,若想实时获取仪表板布局数据(比如要设置默认布局时),可以聚焦(鼠标点击)到对应的仪表板,按快捷键 <Text keyboard>Ctrl</Text>+<Text keyboard>Shift</Text>+<Text keyboard>C</Text> 复制布局数据到剪切板,同时 console 面板也会打印出来布局数据

    property description type defaultValue required
    i 唯一标识, 以小程序的唯一标识加中划线开头,如 'widgetKey-1234567' string true
    w 宽度份数,总共 12 份 number true
    h 高度份数,1 份大概 30px number true
    x 横向位置,总共 12 份 number true
    y 纵向位置,1 份大概 30px number true
    minW 最小宽度 number true
    maxW 最大宽度 number true
    minH 最小高度 number true
    maxH 最大高度 number true
    export default [
      {
        w: 3,
        h: 16,
        x: 0,
        y: 0,
        i: 'Popular-81735522335293475546087951289435',
      },
      {
        w: 3,
        h: 11,
        x: 3,
        y: 5,
        i: 'Todo-53084247679600442035440807237732',
      }
    ]
    

    实例方法

    可通过 ref 获取组件实例,实例对象上挂载了一些方法和 dom 对象,可以方便拓展自定义的 Toolbar 和 WidgetSelector

    property description type
    dom DOM 对象 HTMLDivElement
    addWidget 添加小程序 (widget)=>void
    removeWidget 删除小程序 (i:widgetKey)=>void
    reload 刷新 ()=>void
    edit 进入编辑 ()=>void
    cancelEdit 取消编辑 ()=>void
    revert 重置 ()=>void
    save 保存 ()=>void
    import React,{useRef} from 'react';
    import Dashboard from 'react-dashboard-pro';
    import allWidgets from '../widgets';
    
    export default () => {
      const ref = useRef()
      const addWidget = ()=>{
        ref.current.addWidget('Todo-1234567')
      }
      return (<>
          <Dashboard
            ref={ref}
            widgets={allWidgets}
          />
          <button onClick={addWidget}>新增</button>
        </>
      );
    };
    

    Todo

    ✅ configPanel

    ☑️ gap

    ☑️ modern theme

    ☑️ dark theme

    ☑️ more widget

    ☑️ widget-cli

    ☑️ 国际化

    The End

    • 欢迎大家提 issue, 有需求我会尽力满足大家的痛点
    • 这个项目我会一直维护下去,大家放心使用

    觉得有用的话点个 star 吧 🙊,支持一下吧!

    1 条回复    2021-09-11 06:23:27 +08:00
    ericgui
        1
    ericgui  
       2021-09-11 06:23:27 +08:00   ❤️ 1
    你的贴子早出来一天就用你的了
    昨天刚决定用 ant design pro 了,本人并不喜欢这个,但(在昨天)没其他更好的选择了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2981 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 14:02 · PVG 22:02 · LAX 06:02 · JFK 09:02
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.