Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/adcentury/react-mobile-picker
An iOS like selector/picker component for web
https://github.com/adcentury/react-mobile-picker
mobile mobile-picker mobile-ui picker react react-component react-mobile-picker react-picker react-ui
Last synced: 1 day ago
JSON representation
An iOS like selector/picker component for web
- Host: GitHub
- URL: https://github.com/adcentury/react-mobile-picker
- Owner: adcentury
- License: mit
- Created: 2016-01-13T07:05:26.000Z (about 9 years ago)
- Default Branch: main
- Last Pushed: 2024-09-26T16:49:31.000Z (4 months ago)
- Last Synced: 2025-01-23T02:36:30.304Z (10 days ago)
- Topics: mobile, mobile-picker, mobile-ui, picker, react, react-component, react-mobile-picker, react-picker, react-ui
- Language: TypeScript
- Homepage: http://adcentury.github.io/react-mobile-picker
- Size: 2.94 MB
- Stars: 313
- Watchers: 5
- Forks: 121
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-react-components - react-mobile-picker - [demo](https://react-mobile-picker.vercel.app/) - An iOS like select box component. (UI Components / Form Components)
- fucking-awesome-react-components - react-mobile-picker - 🌎 [demo](react-mobile-picker.vercel.app/) - An iOS like select box component. (UI Components / Form Components)
- awesome-react-components - react-mobile-picker - [demo](https://react-mobile-picker.vercel.app/) - An iOS like select box component. (UI Components / Form Components)
- awesome-react-components - react-mobile-picker - [demo](https://react-mobile-picker.vercel.app/) - An iOS like select box component. (UI Components / Form Components)
README
# React Mobile Picker
[![version](https://img.shields.io/npm/v/react-mobile-picker)](https://www.npmjs.org/package/react-mobile-picker)
![language](https://img.shields.io/github/languages/top/adcentury/react-mobile-picker)
[![npm download](https://img.shields.io/npm/dm/react-mobile-picker.svg?style=flat-square)](https://www.npmjs.org/package/react-mobile-picker)
![npm bundle size](https://img.shields.io/bundlephobia/min/react-mobile-picker)
![npm bundle size zip](https://img.shields.io/bundlephobia/minzip/react-mobile-picker)
![license](https://img.shields.io/npm/l/react-mobile-picker)React Mobile Picker is a super simple component like iOS picker for React. It's almost unstyled, so you can easily customize it as you like.
## Preview
![qr](./examples/assets/qr.jpg)
Scan this Qr in you mobile.
Or visit (in mobile or mobile simulator): [https://react-mobile-picker.vercel.app](https://react-mobile-picker.vercel.app)
## Installation
```bash
npm install react-mobile-picker
```
or
```bash
yarn add react-mobile-picker
```## Basic usage
By design, React Mobile Picker is a [controlled component](https://react.dev/learn/sharing-state-between-components#controlled-and-uncontrolled-components), which means the selected items of the rendered element will always reflect the `value` prop. Every time you want to change the selected items, just modify the `value` prop.
```jsx
import { useState } from 'react'
import Picker from 'react-mobile-picker'const selections = {
title: ['Mr.', 'Mrs.', 'Ms.', 'Dr.'],
firstName: ['John', 'Micheal', 'Elizabeth'],
lastName: ['Lennon', 'Jackson', 'Jordan', 'Legend', 'Taylor']
}function MyPicker() {
const [pickerValue, setPickerValue] = useState({
title: 'Mr.',
firstName: 'Micheal',
lastName: 'Jordan'
})return (
{Object.keys(selections).map(name => (
{selections[name].map(option => (
{option}
))}
))}
)
}
```## Using render props
Each `Picker.Item` component exposes a `selected` state that can be used to customize the appearance of the item. This is called the [render props](https://legacy.reactjs.org/docs/render-props.html) technique.
```jsx
import { useState } from 'react'
import Picker from 'react-mobile-picker'function MyPicker() {
const [pickerValue, setPickerValue] = useState({
name1: 'item1',
/* ... */
})return (
{({ selected }) => (
/* Use the `selected` state to conditionally style the selected item */
Item 1
)}
{/* ... */}
{/* ... */}
)
}
```## Support wheel scrolling
React Mobile Picker is designed to be used on mobile devices, but it can also support wheel scrolling on desktop browsers. To enable this feature, you can set the `wheelMode` prop to either `'natural'` or `'normal'`.
```jsx
import { useState } from 'react'
import Picker from 'react-mobile-picker'function MyPicker() {
const [pickerValue, setPickerValue] = useState({
name1: 'item1',
/* ... */
})return (
{/* ... */}
)
}
```## Component API
### Picker
the main Picker container component.
| Prop | Default | Description |
| :---- | :------- | :----------- |
| value | N/A | `{ [name: string]: string }`
Selected value pairs |
| onChange | N/A | `(value: T, key: string) => void`
Callback function when the selected value changes |
| height | 216 | `number`
Height of the picker in `px` |
| itemHeight | 36 | `number`
Height of each item (that is each option) in `px` |
| wheelMode | `'off'` | `'off' \| 'natural' \| 'normal'`
Enable wheel scrolling on desktop browsers |### Picker.Column
The wrapper component for each column.
| Prop | Default | Description |
| :---- | :------- | :----------- |
| name | N/A | `string`
The name should be one of the keys of the `value` in `Picker` component |### Picker.Item
The wrapper component for each selectable option.
| Prop | Default | Description |
| :---- | :------- | :----------- |
| value | N/A | `string`
The value of the current option || Render Prop | Description |
| :----------- | :----------- |
| selected | `boolean`
Whether or not the current option is selected |## More examples
You can check out the [examples](./examples) folder for more code samples. Or run this project locally:
```bash
git clone this repo
cd react-mobile-picker
pnpm i
pnpm run dev
point your browser to http://localhost:5173
```## Author
Adcent Lei ([@adcentlei](https://twitter.com/adcentlei))
## License
MIT.