0.5.1 β€’ Published 2 years ago

react-resizable-layout-mobile v0.5.1

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

react-resizable-layout

npm version MIT License minziggped size dependencies count tree shaking code style: prettier

Lightweight, accessible headless React component and hook for drag-and-drop resizable layouts.

Hero Image

Edit react-resizable-layout

Storybook Demo

Features

  • πŸ“¦ Lightweight
  • πŸ•³ Headless
  • 🫢🏽 Accessible
  • 🀏 Drag and Drop Support
  • ⌨️ Keyboard Support
  • πŸ«™ Zero Dependencies

Installation

Install from npm:

# Using npm
npm install react-resizable-layout

# Using Yarn
yarn add react-resizable-layout

Usage

Resizable component

import Resizable from 'react-resizable-layout';

<Resizable axis={'x'}>
  {({ position, separatorProps }) => (
    <div className="wrapper">
      <div className="left-block" style={{ width: position }} />
      <YourSeparatorComponent {...separatorProps} />
      <div className="right-block" />
    </div>
  )}
</Resizable>

useResizable hook

import { useResizable } from 'react-resizable-layout';

const Component = () => {
  const { position, separatorProps } = useResizable({
    axis: 'x',
  })

  return (
    <div className="wrapper">
      <div className="left-block" style={{ width: position }} />
      <YourSeparatorComponent {...separatorProps} />
      <div className="right-block" />
    </div>
  )
}

Aria Props

The following attributes have been added to separatorProps in accordance with W3C.
https://www.w3.org/TR/wai-aria-1.2/#separator

AttributeValue
role'separator'
aria-valuenowposition
aria-valueminprops.min
aria-valuemaxprops.max
aria-orientation'vertical' or 'horizontal'
aria-disabledprops.disabled

Configuration

Common Props

NameTypeDefaultRequiredDescription
axis'x' or 'y'-β—―Resize direction
containerRefReactRef--Reference to container for calculating position
disabledbooleanfalse-Disable resize
initialnumber0-Initial size
minnumber0-Minimum size
maxnumberInfinity-Maximum size
reversebooleanfalse-If true, returns position of the opposite side
stepnumber10-Pixel steps when operating with keyboard
shiftStepnumber50-Pixel steps when operating with keyboard while holding down the shift key
onResizeStartfunction--Callback on resize start
onResizeEndfunction--Callback on resize end

Resizable component children args

useResizable hook returns same.

NameTypeDescription
positionnumberSeparator's position (Width for 'x' axis, height for 'y' axis)
isDraggingbooleanIf dragging then true
separatorPropsobjectSeparator's props like onMouseDown

About keyboard support

The following keyboard operations are supported.

KeyOperation
Arrow (↑,β†’,↓,←)Move the separator by 10px (default)
Shift + Arrow (↑,β†’,↓,←)Move the separator by 50px (default)
EnterReset the separator to the initial position

About mouse support

Double-click on the separator to return it to its initial position.

Contribution

Please feel free to open an issue or make a pull request.

License

Distributed under the MIT License. See LICENSE for more information.