Skip to main content

TableFilterGroup

<TableFilterGroup /> 은 Table 의 데이터에 필터를 적용하고자 할 때 사용할 수 있는 컴포넌트 입니다.

<TableFilterGroup /> 하위에 올 수 있는 필터의 종류는 세가지가 있으며, 필터의 타입에 따라 operatorsvalue 타입이 상이합니다.

필터의 종류별로 사용할 수 있는 속성과 예제는 각 항목에 소개되어 있습니다.

warning

1개의 필터만을 사용하기 위해서도 <TableFilterGroup /> 으로 감싸주어야 제대로 동작합니다.

이는 <TableFilterGroup /> 가 하위 필터들의 상태를 관리하는 동시에 필터의 변경사항을 테이블에 반영하는 주체이기 때문입니다.

Loading...

How to use

import { TableFilterGroup } from '@vibrant-ui/components';

Properties

TableFilterGroup

<TableFilterGroup /> 은 가장 상위에서 필터 컴포넌트들을 감싸며, 현재 상태의 필더 데이터값을 onFilterChange 함수를 통해 전달하여 테이블에 반영할 수 있습니다.

initialFilterDataKeys 에 있는 데이터키를 통해 초기에 등록되어 있으며 사용자가 삭제할 수 없는 필터를 설정할 수 있습니다.

만약, <TableFilterGroup /> 하위에 있는 모든 필터가 추가되어 있는 상태라면, 필터 추가 버튼은 등장하지 않습니다.

<TableFilterGroup /> 하위에 있는 각각의 필터들 중 하나라도 초기 상태로부터의 변경 사항이 존재한다면 초기화 버튼이 우측에 등장합니다.

PropTypeDefaultDescription
onFilterChange(filters: Filter[] => void-TableFilterGroup 하위에 있는 필터가 변경될 때마다 호출될 함수
initialFilterDataKeysstring[]-기본으로 적용된 채로 보여질 필터의 dataKey 배열
children(*)StringFilter | DateFilter | MultiSelectFilter-TableFilterGroup 에 포함될 필터 컴포넌트들

TableFilterGroup.StringFilter

<TableFilterGroup.StringFilter /> 는 문자열 타입의 필터 값과 연산자를 받는 필터칩입니다.

PropTypeDefaultDescription
dataKeystringStringFilter의 key를 지정합니다.
labelstringStringFilter의 라벨을 지정합니다. (유저가 보는 필터의 이름을 나타냅니다.)
placeholderstringStringFilter의 텍스트 입력 필드의 placeholder를 지정합니다.
operatorsStringFilterOperator[][ equals , notEquals , contains , notContains , empty , notEmpty]StringFilter의 조건을 지정합니다.
defaultValue{ value: string, operator: StringFilterOperator }StringFilter의 기본 값을 지정합니다. operator가 empty, notEmpty일 경우 value를 지정할 수 없습니다.
maxWidthnumber | stringStringFilter의 최대 가로 크기를 설정합니다.
lineLimitnumberStringFilter의 텍스트의 최대 줄 수를 설정합니다.
Loading...

TableFilterGroup.DateFilter

<TableFilterGroup.DateFilter /> 는 날짜 형식의 필터 값과 연산자를 받는 필터칩입니다.

PropTypeDefaultDescription
dataKeystringDateFilter의 key를 지정합니다.
labelstringDateFilter 라벨을 지정합니다. (유저가 보는 필터의 이름을 나타냅니다.)
placeholderstringDateFilter의 텍스트 입력 필드의 placeholder를 지정합니다.
operatorsDateFilterOperator[][equals, notEquals, before, after, onOrBefore, onOrAfter, between, empty, notEmpty]DateFilter의 조건을 지정합니다.
defaultValue{ value: Date[], operator: DateFilterOperator }DateFilter의 기본 값을 지정합니다. operator가 empty, notEmpty일 경우 value를 지정할 수 없습니다.
maxWidthnumber | stringDateFilter의 최대 가로 크기를 설정합니다.
lineLimitnumberDateFilter의 텍스트의 최대 줄 수를 설정합니다.
Loading...

TableFilterGroup.MultiSelectField

<TableFilterGroup.MultiSelectField /> 는 1개 이상의 값을 선택하여 반영할 수 있는 필터칩입니다.

PropTypeDefaultDescription
dataKeystringMultiSelectField의 key를 지정합니다.
labelstringMultiSelectField의 라벨을 지정합니다. (유저가 보는 필터의 이름을 나타냅니다.)
placeholderstringMultiSelectField의 텍스트 입력 필드의 placeholder를 지정합니다.
options{ label: string, value: string }[]MultiSelectFilter의 옵션 목록을 지정합니다.
operatorsMultiSelectFilterOperator[][equals, notEquals, empty, notEmpty]MultiSelectField의 조건을 지정합니다.
defaultValue{ value: string[], operator: MultiSelectFilterOperator }MultiSelectField의 기본 값을 지정합니다. operator가 empty, notEmpty일 경우 value를 지정할 수 없습니다.
maxWidthnumber | stringMultiSelectField의 최대 가로 크기를 설정합니다.
lineLimitnumberMultiSelectField의 텍스트의 최대 줄 수를 설정합니다.
Loading...