npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@rax-ui/filter

v1.0.0-beta.62

Published

--- display: @rax-ui/filter family: other ---

Downloads

4

Readme


display: @rax-ui/filter family: other

@rax-ui/filter

@rax-ui/filter 在搜索筛选场景中使用。Filter 是一个重业务属性组件,我们封装了业务中通用的交互和设计,提供了灵活的配置来做自定义,扩展性强,并制定了业务组件的书写规范,设计上解耦 业务组件

组件功能点

  • 1、搜索筛选组件包含 FilterFilter.Panel 组件,设计上解耦 业务组件,须遵守业务组件书写规范
  • 2、筛选头配置提供了三种筛选类型,并且支持点击动画
    • RelatePanel:筛选项关联Panel型(即筛选头和 Panel 是一对一关系,点击筛选头展示 Panel)
      • QuickSearch:筛选项快速搜索排序型(即筛选头没有对应 Panel,点击筛选头直接触发搜索)
      • Custom:自定义类型,UI完全自定义
  • 3、Filter.Panel 管理面板的显示隐藏,支持可配置的下拉、左滑动画
  • 4、提供两种业务面板组件(如不满足业务需求,可自行封装业务组件,查看业务组件书写规范
    • @rax-ui/filter-list-select,列表选择面板组件
    • @rax-ui/filter-multi-select,多选面板组件
    • @rax-ui/filter-combo-container,组合容器,用于将若干个@rax-ui/filter-multi-select组合使用
  • 5、提供了 @rax-ui/filter-helper 工具组件(Filter滚动吸附场景使用)

动效图

动效图

架构图

安装方法

在命令行中执行以下命令

npm install @rax-ui/filter -S

使用方式

import Filter from '@rax-ui/filter';
import ListSelect from '@rax-ui/filter-list-select';

render(
  <Filter navConfig={} onChange={}>
		<Filter.Panel>
      <ListSelect {...props} />
		</Filter.Panel>
		<Filter.Panel>
      <其他业务组件 />
		</Filter.Panel>
  </Filter>
)

API

Filter Props

| 参数 | 说明 | 类型 | 默认值(是否必填) | -------- | -------- | -------- | -------- | | navConfig | 筛选头配置 效果图 undefined | Array<Object> | - (必填) | | offsetTop | Filter组件展开面板状态下距离页面顶部的高度,有两种状态:固定位置跟随页面滚动吸附置顶 **固定位置:**状态下距离页面顶部的高度 **跟随页面滚动吸附置顶:**状态下距离页面顶部的高度 效果图 undefined | Number | -(必填) | | styles | 配置样式,Filter中所有样式都可使用styles集合对象来配置覆盖,详见CSS API | Object | {} | | clickMaskClosable | 开启 mask 背景的点击隐藏 | Boolean | true | | onPanelVisibleChange | Panel 显示隐藏回调函数 签名: Function({ visible:Boolean, triggerIndex:Number, triggerType:String }) => void 参数: visible:Boolean 显示隐藏标志量 triggerIndex:Number触发的筛选项索引值 triggerType:String 触发类型 triggerType详解 包含三种触发类型Navbar:来自筛选头的点击触发Mask:来自背景层的点击触发Panel:来自Panel 的 onChange 回调触发 | Function | | | onChange | Filter 搜索变更回调函数 签名: Function(params:Object, urlQuery: Object) => void 参数: params: Object 标准化搜索参数,必须包含{filterKey, filterText, filterValue, filterValueChanged} undefined urlQuery:Object URL query 对象| Function | |

Filter 组件 props.navConfig 数组配置详解

navConfig

| 参数 | 说明 | 类型 | 默认值(是否必填) | -------- | -------- | -------- | -------- | | type | 筛选项类型 三种类型RelatePanel: 【默认类型】筛选项关联Panel型,即筛选头和 Panel 是一对一关系,点击筛选头展示 PanelQuickSearch: 筛选项快速搜索排序型,即筛选头没有对应 Panel,点击筛选头直接触发搜索Custom: 自定义类型,UI完全自定义,通过 renderItem函数返回 JSX | String | 'RelatePanel' | | text 注意 RelatePanel类型生效 | 筛选头显示文案 文字溢出用...展示 | String | - (必填) | | icon 注意 RelatePanel类型生效 | 筛选头 icon:normal 正常态 和 active 激活态 图标 数据格式 Object类型 : undefined String类型 : undefined 效果图 undefined | Object or String | - | | options 注意 QuickSearch类型生效 | 快速搜索排序类型的数据源 数据格式 undefined | Array | (必填) | | optionsIndex 注意 QuickSearch类型生效 | 快速搜索排序类型默认选中的索引 | String | 0 | | optionsKey 注意 QuickSearch类型生效 | 指定快速搜索排序对应的搜索 key,用到 onChange 回调中| String | 不提供默认使用当前筛选项的索引 | | loop 注意 QuickSearch类型生效 | 点击是否依托options数组项循环 | Boolean | true | | formatText | 文案格式化函数 签名:Function(text:String) => text 参数: text: String 筛选头文案 | Function | (text)=>text | | disabled | 禁用筛选头点击 | Boolean | true | | highlight | 是否保持文字图标高亮 | Boolean | false | | hasSeperator | 是否展示右侧分隔符效果图 undefined | Boolean | false | | renderItem | 自定义渲染 注意 提供的配置项无法满足你的 UI 需求时使用 签名:Function(isActive:Boolean, this:Element) => Element 参数: isActive:Boolean 筛选头是否为激活状态this:Element 筛选头this实例 | Function | - | | animation | 动画配置,采用内置的动画 参数说明 undefined 注意 目前只内置了一种rotate动画类型 | Object | | | animationHook | 用户自定义动画的钩子函数,内置动画无法满足需求时使用 签名:Function(refImg:Element, isActive:Boolean) => text 参数: refImg:Element 筛选头图标的 ref 实例 isActive:Boolean 筛选头是否为激活状态 | Function | - |

Filter.Panel Props

| 参数 | 说明 | 类型 | 默认值(是否必填)| | -------- | -------- | -------- | -------- | | displayMode | Panel 展现形式:全屏、下拉 参数说明 全屏:Fullscreen下拉:Dropdown | String | 'Dropdown' | | animation | Panel 展示动画配置,内置上下左右动画 参数说明 undefined direction 控制动画方向,分别有 updownleftright | Object | | | highPerformance | 内部通过 Panel 的显示隐藏控制 panel 的 render 次数,避免不必要的 render,高性能模式下,只会在 Panel 展示 或者 展示隐藏状态变化时才会重新 render | Boolean |true| | noAnimation |禁用动画| Boolean|false |

Filter 方法

|名称 | 说明 | 类型 | 默认值 | |:---------------|:--------|:----|:----------| | reset | 重置内部选中状态 | Function 签名:Function(navConfig:Array<NavProps>) => Array<any> 参数: navConfig:Array<NavProps> 要重置 navConfig 数组 返回值: Array<any> 被重置后的搜索参数 | | | setNavConfig | 修改 navConfig(navConfig 默认是不受控的,必须通过方法来修改) | Function 签名:Function(fn: (navConfig: Array<NavProps>) => Array<NavProps>) => void 参数: fn: (navConfig: Array<NavProps>) => Array<NavProps> 接收新的 navConfig参数的回调函数 | |

CSS API

| 名称 | 说明 | |:---------------|:--------| | filter | filter 容器样式 | | filter__nav | 筛选头容器样式 | | filter__nav__item | 筛选项样式 | filter__nav__item_active | 筛选项高亮样式 | | filter__nav__text_active | 筛选项文案高亮样式 | | filter__nav__icon | 筛选项图标样式 | | filter__nav__seperator | 筛选项分隔符样式 | | filter__panel | Panel容器样式 | | filter__panel__mask | Panel Mask背景样式 |

业务组件书写规范

PanelSpec

Filter.Panel 会注入一些与 filter 相关的 props 到子组件中,详细如下

Inject Props

  • onChange:业务组件触发搜索时调用 + 函数签名Function(params:Object,showPanel:Boolean) => void + params:Object:标准化搜索参数,必须包含如下字段{filterKey, filterText, filterValue, filterValueChanged} + showPanel:Boolean:默认fasle,触发onChange 默认会隐藏 Panel,给 true 强制展示
  • onHidePanel:业务组件主动隐藏 Panel + 函数签名{Function() => void}
  • panelAttributes: 和 Filter 相关的属性
    • index{Number}:当前 Panel 索引值
    • visible{Boolean}:当前 Panel 显示隐藏状态
    • maxHeight{Number}:当前业务组件的可展示的最大高度,全屏和下拉模式高度不一样
    • displayMode{String}:当前 Panel 所处的展示模式,下拉 or 全屏
    • shouldInitialRender{Boolean}:控制首次打开页面时业务组件是否要 render(对性能有极致要求时可在业务组件中使用此变量)
    • urlQuery{Object}:URL query 对象

规范列表

  • 【规范1】必须要使用 forwardRef 包裹,Filter 需要通过 ref 调用子组件方法
  • 【规范2】Panel 会默认注入如下 prop 到业务组件中
  • 【规范3】通过 props.onChange 触发 Filter 搜索,必须传递标准化搜索参数
  • 【规范4】导出方法 rootRef reset
// 【规范1】、必须要使用 forwardRef 包裹,Filter 需要通过 ref 调用子组件方法
export const MyComp = forwardRef((props, ref)=>{
  // 【规范2】、Panel 会默认注入如下 prop 到业务组件中
  const {onChange, onHidePanel, panelAttributes} = props;
  const {maxHeight, shouldInitialRender, index, visible, displayMode, urlQuery} = panelAttributes;
  const rootRef = useRef();
  function handleChange () {
    // 【规范3】、通过 `props.onChange`触发 Filter 搜索,必须传递标准化搜索参数
    onChange({ 
      filterKey: 'orderId',
      filterText: '价格升序',
      filterValue: 100,
      filterValueChanged: 100 !== 0,
    });
  }
  // 【规范4】、导出如下两个方法 rootRef reset
  useImperativeHandle(ref, () => ({
    rootRef: rootRef,   // 导出组件根节点ref, Filter 执行动画要使用
    reset: () => {} // 重置 panel 内部状态
  }));
  return (
    <View ref={rootRef}></View>
  )
});
<!-- 在 Filter 中使用业务面板组件 -->
<Filter onChange={}>
  <Filter.Panel>
    <业务组件 />
  </Filter.Panel>
</Filter>

业务组件示例 Demo

import { createElement, forwardRef, useState, useRef, useImperativeHandle } from 'rax';
import View from 'rax-view';

// 【规范1】、必须要使用 forwardRef 包裹,Filter 需要通过 ref 调用子组件方法
export const OrderList = forwardRef((props, ref)=>{
  // 【规范2】、Panel 会默认注入如下 prop 到业务组件中
  const {onChange, onHidePanel, panelAttributes} = props;
  const {maxHeight, shouldInitialRender, index, visible, displayMode, urlQuery} = panelAttributes;

  const list = [0, 1, 2, 3, 4, 5, 6];
  const [activeIndex, setActiveIndex] = useState(0);
  const rootRef = useRef();

  function handleClick (index) {
    setActiveIndex(index);
    // 【规范3】、触发 Filter 搜索,要求必须传递标准化搜索参数,
    onChange({ 
      filterKey: 'orderId',
      filterText: '价格升序',
      filterValue: list[index],
      filterValueChanged: list[index] !== 0,
    });
  }
  // 【规范4】、导出如下两个方法 rootRef reset
  useImperativeHandle(ref, () => ({
    rootRef: rootRef,   // 导出组件根节点ref, Filter 执行动画要使用
    reset: () => { // 重置 panel 内部状态
      setActiveIndex(0);
    } 
  }));
  const activeStyle = {};
  const normalStyle = {};
  return (
    <View ref={rootRef}>
      {list.map((item, index) => {
        return (
          <View key={index} style={activeIndex ? activeStyle:normalStyle} onClick={()=>handleClick(index)}>排序项{index}</View>
        )
      })}
    </View>
  )
})

提供的通用业务面板组件

  • @rax-ui/filter-list-select,列表选择面板组件
  • @rax-ui/filter-multi-select,多选面板组件
  • @rax-ui/filter-combo-container,组合容器,用于将若干个@rax-ui/filter-multi-select组合使用