-
Notifications
You must be signed in to change notification settings - Fork 2.2k
/
EventRowMixin.js
88 lines (79 loc) · 2.01 KB
/
EventRowMixin.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import PropTypes from 'prop-types'
import React from 'react'
import { findDOMNode } from 'react-dom'
import EventCell from './EventCell'
import getHeight from 'dom-helpers/query/height'
import { accessor, elementType } from './utils/propTypes'
import { segStyle } from './utils/eventLevels'
import { isSelected } from './utils/selection'
/* eslint-disable react/prop-types */
export default {
propTypes: {
slots: PropTypes.number.isRequired,
end: PropTypes.instanceOf(Date),
start: PropTypes.instanceOf(Date),
selected: PropTypes.object,
eventPropGetter: PropTypes.func,
titleAccessor: accessor,
allDayAccessor: accessor,
startAccessor: accessor,
endAccessor: accessor,
eventComponent: elementType,
eventWrapperComponent: elementType.isRequired,
onSelect: PropTypes.func,
onDoubleClick: PropTypes.func,
},
defaultProps: {
segments: [],
selected: {},
slots: 7,
},
renderEvent(props, event) {
let {
eventPropGetter,
selected,
start,
end,
startAccessor,
endAccessor,
titleAccessor,
allDayAccessor,
eventComponent,
eventWrapperComponent,
onSelect,
onDoubleClick,
} = props
return (
<EventCell
event={event}
eventWrapperComponent={eventWrapperComponent}
eventPropGetter={eventPropGetter}
onSelect={onSelect}
onDoubleClick={onDoubleClick}
selected={isSelected(event, selected)}
startAccessor={startAccessor}
endAccessor={endAccessor}
titleAccessor={titleAccessor}
allDayAccessor={allDayAccessor}
slotStart={start}
slotEnd={end}
eventComponent={eventComponent}
/>
)
},
renderSpan(props, len, key, content = ' ') {
let { slots } = props
return (
<div
key={key}
className="rbc-row-segment"
style={segStyle(Math.abs(len), slots)}
>
{content}
</div>
)
},
getRowHeight() {
getHeight(findDOMNode(this))
},
}