@smarthr/use-bulk-check
TypeScript icon, indicating that this package has built-in type declarations

1.0.5 • Public • Published

@smarthr/use-bulk-check

npm version

リストに対しての個別チェック・ページ内一括チェック・ページを跨いだ一括全件チェックの状態を管理するための React のカスタムフックです。
バックエンドではチェックした要素の ID 一覧(sting[])かページを跨いだ一括全件チェックのフラグ(boolean)を受け取ることを想定します。

Usage

import React from 'react'
import { useBulkCheck } from '@smarthr/use-bulk-check'

export const Component = () => {
  const users = [
    {
      id: '1',
      name: 'user-1',
    },
    {
      id: '2',
      name: 'user-2',
    },
    {
      id: '3',
      name: 'user-3',
    },
  ]
  const {
    pageItems,
    hasCheckedItemInPage,
    isPageChecked,
    isAllChecked,
    toggleChecked,
    togglePageChecked,
    toggleAllChecked,
    resetChecked,
    checkedIds,
  } = useBulkCheck({ pageItems: users, defaultCheckedIds: ['1', '3'], defaultIsAllChecked: false })

  return (
    <div>
      <ul>
        {pageItems.map(({ item, checked }) => (
          <li key={item.id}>
            <input type="checkbox" checked={checked || isPageChecked || isAllChecked} onChange={() => toggleChecked(item.id)} />
            {item.name}
          </li>
        ))}
      </ul>

      <div>
        <p>
          <input type="checkbox" checked={isPageChecked} onChange={togglePageChecked} />
          ページ内全件チェック
        </p>
        <p>
          <input type="checkbox" checked={isAllChecked} onChange={toggleAllChecked} />
          ページを跨いで全件チェック
        </p>
        <button onClick={resetChecked}>全てのチェック状態を解除</button>
      </div>

      <div>
        <p>
          {hasCheckedItemInPage
            ? '表示しているページ内にチェックされたユーザーが一人以上います'
            : '表示しているページ内のユーザーにはチェックが一つもついていません'}
        </p>
        <p>
          {isPageChecked
            ? '表示しているページ内の全てのユーザーにチェックがついています'
            : '表示しているページ内にチェックがついていないユーザーが一人以上います'}
        </p>
        <p>{isAllChecked && 'ページを跨いで全てのユーザーにチェックがついています'}</p>
      </div>

      <div>
        <p>ページ関係なくチェックされている ID の一覧です。</p>
        <ul>
          {checkedIds.map((id) => (
            <li key={id}>{id}</li>
          ))}
        </ul>
      </div>
    </div>
  )
}

License

This project is licensed under the terms of the MIT license.

Readme

Keywords

none

Package Sidebar

Install

npm i @smarthr/use-bulk-check

Weekly Downloads

1,810

Version

1.0.5

License

MIT

Unpacked Size

37.5 kB

Total Files

9

Last publish

Collaborators

  • shingo.sasaki
  • kesteer
  • yamish123
  • ackndev
  • ibulog
  • alpaca-tc
  • nabeliwo
  • atsushim
  • koba04
  • im36.123
  • smarthr-dev
  • ykarakita
  • cidermitaina
  • meganemura
  • wata727
  • wmoai
  • diescake
  • moshisora
  • tokky0425
  • hawaiiman
  • smarthr-admin
  • yamamoto-yuta
  • kgsi
  • otapo
  • kuny