1.5.3 • Published 5 years ago
react-seat-picker v1.5.3
react-seat-picker
Component to pick seats
Demo
About
This is a fork of react-seatmap whithout dependencies and some extra properties.
Install
npm install --save react-seat-picker
Or
yarn add react-seat-picker
Usage
import React, {Component} from 'react'
import SeatPicker from 'react-seat-picker'
export default class App extends Component {
state = {
loading: false
}
addSeatCallback = ({ row, number, id }, addCb) => {
this.setState({
loading: true
}, async () => {
await new Promise(resolve => setTimeout(resolve, 1500))
console.log(`Added seat ${number}, row ${row}, id ${id}`)
const newTooltip = `tooltip for id-${id} added by callback`
addCb(row, number, id, newTooltip)
this.setState({ loading: false })
})
}
addSeatCallbackContinousCase = ({ row, number, id }, addCb, params, removeCb) => {
this.setState({
loading: true
}, async () => {
if (removeCb) {
await new Promise(resolve => setTimeout(resolve, 750))
console.log(`Removed seat ${params.number}, row ${params.row}, id ${params.id}`)
removeCb(params.row, params.number)
}
await new Promise(resolve => setTimeout(resolve, 750))
console.log(`Added seat ${number}, row ${row}, id ${id}`)
const newTooltip = `tooltip for id-${id} added by callback`
addCb(row, number, id, newTooltip)
this.setState({ loading: false })
})
}
removeSeatCallback = ({ row, number, id }, removeCb) => {
this.setState({
loading: true
}, async () => {
await new Promise(resolve => setTimeout(resolve, 1500))
console.log(`Removed seat ${number}, row ${row}, id ${id}`)
// A value of null will reset the tooltip to the original while '' will hide the tooltip
const newTooltip = ['A', 'B', 'C'].includes(row) ? null : ''
removeCb(row, number, newTooltip)
this.setState({ loading: false })
})
}
render() {
const rows = [
[{id: 1, number: 1, isSelected: true, tooltip: 'Reserved by you'}, {id: 2, number: 2, tooltip: 'Cost: 15$'}, null, {id: 3, number: '3', isReserved: true, orientation: 'east', tooltip: 'Reserved by Rogger'}, {id: 4, number: '4', orientation: 'west'}, null, {id: 5, number: 5}, {id: 6, number: 6}],
[{id: 7, number: 1, isReserved: true, tooltip: 'Reserved by Matthias Nadler'}, {id: 8, number: 2, isReserved: true}, null, {id: 9, number: '3', isReserved: true, orientation: 'east'}, {id: 10, number: '4', orientation: 'west'}, null, {id: 11, number: 5}, {id: 12, number: 6}],
[{id: 13, number: 1}, {id: 14, number: 2}, null, {id: 15, number: 3, isReserved: true, orientation: 'east'}, {id: 16, number: '4', orientation: 'west'}, null, {id: 17, number: 5}, {id: 18, number: 6}],
[{id: 19, number: 1, tooltip: 'Cost: 25$'}, {id: 20, number: 2}, null, {id: 21, number: 3, orientation: 'east'}, {id: 22, number: '4', orientation: 'west'}, null, {id: 23, number: 5}, {id: 24, number: 6}],
[{id: 25, number: 1, isReserved: true}, {id: 26, number: 2, orientation: 'east'}, null, {id: 27, number: '3', isReserved: true}, {id: 28, number: '4', orientation: 'west'}, null,{id: 29, number: 5, tooltip: 'Cost: 11$'}, {id: 30, number: 6, isReserved: true}]
]
const {loading} = this.state
return (
<div>
<h1>Seat Picker</h1>
<div style={{marginTop: '100px'}}>
<SeatPicker
addSeatCallback={this.addSeatCallback}
removeSeatCallback={this.removeSeatCallback}
rows={rows}
maxReservableSeats={3}
alpha
visible
selectedByDefault
loading={loading}
tooltipProps={{multiline: true}}
/>
</div>
<h1>Seat Picker Continuous Case</h1>
<div style={{ marginTop: '100px' }}>
<SeatPicker
addSeatCallback={this.addSeatCallbackContinousCase}
removeSeatCallback={this.removeSeatCallback}
rows={rows}
maxReservableSeats={3}
alpha
visible
selectedByDefault
loading={loading}
tooltipProps={{ multiline: true }}
continuous
/>
</div>
</div>
)
}
Props
Name | Type | Default | Required | Description |
---|---|---|---|---|
alpha | boolean | false | false | Enumerate your rows using letters (true ), otherwise using numbers (false ). |
visible | boolean | false | false | Shows the row numbers (true ), otherwise they are hidden (false ). |
loading | boolean | false | false | Shows a white mask on the seatpicker. |
continuous | boolean | false | false | Allows to continue select seats while remove previos ones if you already have max reservable seats. |
selectedByDefault | boolean | false | false | Allow to have already selected seats (true ), otherwise (false ) they aren´t going to be checked by their isSelected property. |
maxReservableSeats | number | 0 | false | Limits the number of selectable seats. |
addSeatCallback | function | ({row, number, id}, cb) => {console.log( Added seat ${number}, row ${row}, id ${id} ); addCb(row,number,id);} | false | Should be customized as you need. Remember to use addCb(row,number,id) for accepting the selection, otherwise ommit it. For continuous case see the example where should use removeCb(day,number) for previoslyselected appointment. |
removeSeatCallback | function | ({row, number, id}, removeCb) => {console.log( Removed seat ${number}, row ${row}, id ${id} ); removeCb(row,number);} | false | Should be customized as you need. Remember to use removeCb(row,number) for accepting the deselection, otherwise ommit it. |
tooltipProps | object | - | false | An object with props (options) for the react-tooltip components. |
rows | array | - | true | Array of arrays of json. (See next section). |
Seats properties
Each json in rows prop could be null
(empty seat) or has these properties.
Name | Type | Default | Required | Description |
---|---|---|---|---|
id | number or string | undefined | false | It identify a seat. |
number | number or string | undefined | false | It will be showed inside seat. |
tooltip | string | undefined | false | Text of the tooltip when hovering over the seat. |
isSelected | boolean | false | false | It will be checked in case selectedByDefault is true. |
isReserved | boolean | false | false | Disable the option of click it. |
orientation | string | north | false | Define the position of an specific seat (north, south, east, west). |
License
MIT © roggervalf