@ysmood/material-ui
Version:
Material Design UI components built with React
236 lines (198 loc) • 6.96 kB
JSX
var React = require('react');
var StylePropable = require('../mixins/style-propable');
var DateTime = require('../utils/date-time');
var Transitions = require('../styles/transitions');
var AutoPrefix = require('../styles/auto-prefix');
var SlideInTransitionGroup = require('../transition-groups/slide-in');
var DateDisplay = React.createClass({
mixins: [StylePropable],
contextTypes: {
muiTheme: React.PropTypes.object
},
propTypes: {
selectedDate: React.PropTypes.object.isRequired,
weekCount: React.PropTypes.number,
yearSelectionAvailable: React.PropTypes.bool,
monthDaySelected: React.PropTypes.bool
},
getDefaultProps: function() {
return {
weekCount: 4,
yearSelectionAvailable: true,
monthDaySelected: true
};
},
getInitialState: function() {
return {
transitionDirection: 'up',
selectedYear: !this.props.monthDaySelected
};
},
componentWillReceiveProps: function(nextProps) {
var direction;
if (nextProps.selectedDate !== this.props.selectedDate) {
direction = nextProps.selectedDate > this.props.selectedDate ? 'up' : 'down';
this.setState({
transitionDirection: direction
});
}
if (nextProps.monthDaySelected !== undefined) {
this.setState({selectedYear: !nextProps.monthDaySelected});
}
},
getTheme: function() {
return this.context.muiTheme.component.datePicker;
},
render: function() {
var {
selectedDate,
style,
...other
} = this.props;
var dayOfWeek = DateTime.getDayOfWeek(this.props.selectedDate);
var month = DateTime.getShortMonth(this.props.selectedDate);
var day = this.props.selectedDate.getDate();
var year = this.props.selectedDate.getFullYear();
var isLandscape = this.props.mode === 'landscape';
var dateYPosition = '0px';
var dayYPosition = '30px';
var yearYPosition = '95px';
if (isLandscape) {
dateYPosition = this.props.weekCount === 5 ? '14px' :
this.props.weekCount === 6 ? '34px' : '8px';
yearYPosition = this.props.weekCount === 4 ? '114px' : '150px';
if (this.props.weekCount > 4) dayYPosition = '50px';
}
var styles = {
root: {
textAlign: 'center',
position: 'relative'
},
dateContainer: {
backgroundColor: this.getTheme().color,
height: isLandscape ? this.props.weekCount * 40 + 36 + 'px' : '150px',
padding: '16px 0',
transition: Transitions.easeOut(),
boxSizing: 'border-box',
},
date: {
position: 'relative',
color: this.getTheme().textColor,
transition: Transitions.easeOut(),
transform: 'translate3d(0,' + dateYPosition + ',0)'
},
dowContainer: {
height: '32px',
backgroundColor: this.getTheme().selectColor,
borderRadius: isLandscape ? '2px 0 0 0' : '2px 2px 0 0',
paddingTop: '9px',
boxSizing: 'border-box'
},
dow: {
fontSize: '13px',
lineHeight: '13px',
height: '100%',
color: this.getTheme().selectTextColor
},
day: {
root: {
position: 'absolute',
lineHeight: isLandscape ? '76px' : '58px',
fontSize: isLandscape ? '76px' : '58px',
height: isLandscape ? '76px' : '58px',
width: '100%',
opacity: this.state.selectedYear ? '0.7' : '1.0',
transition: Transitions.easeOut(),
transform: 'translate3d(0,' + dayYPosition + ',0)'
},
title: {
width: '100px',
marginLeft: 'auto',
marginRight: 'auto',
cursor: !this.state.selectedYear ? 'default' : 'pointer'
}
},
month: {
root: {
position: 'absolute',
top: isLandscape ? '0px' : '1px',
fontSize: isLandscape ? '26px' : '22px',
lineHeight: isLandscape ? '26px' : '22px',
height: isLandscape ? '26px' : '22px',
width: '100%',
textTransform: 'uppercase',
opacity: this.state.selectedYear ? '0.7' : '1.0'
},
title: {
width: '100px',
marginLeft: 'auto',
marginRight: 'auto',
cursor: !this.state.selectedYear ? 'default' : 'pointer'
}
},
year: {
root: {
position: 'absolute',
margin: '0px',
fontSize: isLandscape ? '26px' : '22px',
lineHeight: isLandscape ? '26px' : '22px',
height: isLandscape ? '26px' : '22px',
width: '100%',
textTransform: 'uppercase',
opacity: this.state.selectedYear ? '1.0' : '0.7',
transition: Transitions.easeOut(),
transform: 'translate3d(0,' + yearYPosition + ',0)'
},
title: {
width: '100px',
marginLeft: 'auto',
marginRight: 'auto',
cursor: (!this.props.yearSelectionAvailable || this.state.selectedYear) ? 'default' : 'pointer'
}
}
};
return (
<div {...other} style={this.mergeAndPrefix(styles.root, this.props.style)}>
<div style={styles.dowContainer}>
<SlideInTransitionGroup
style={styles.dow}
direction={this.state.transitionDirection}>
<div key={dayOfWeek}>{dayOfWeek}</div>
</SlideInTransitionGroup>
</div>
<div style={AutoPrefix.all(styles.dateContainer)}>
<div style={AutoPrefix.all(styles.date)}>
<SlideInTransitionGroup
style={styles.month.root}
direction={this.state.transitionDirection}>
<div key={month} style={styles.month.title} onTouchTap={this._handleMonthDayClick}>{month}</div>
</SlideInTransitionGroup>
<SlideInTransitionGroup
style={styles.day.root}
direction={this.state.transitionDirection}>
<div key={day} style={styles.day.title} onTouchTap={this._handleMonthDayClick}>{day}</div>
</SlideInTransitionGroup>
<SlideInTransitionGroup
style={styles.year.root}
direction={this.state.transitionDirection}>
<div key={year} style={styles.year.title} onTouchTap={this._handleYearClick}>{year}</div>
</SlideInTransitionGroup>
</div>
</div>
</div>
);
},
_handleMonthDayClick: function() {
if (this.props.handleMonthDayClick && this.state.selectedYear) {
this.props.handleMonthDayClick();
}
if (this.props.yearSelectionAvailable) this.setState({selectedYear: false});
},
_handleYearClick: function() {
if (this.props.handleYearClick && !this.state.selectedYear && this.props.yearSelectionAvailable) {
this.props.handleYearClick();
}
if (this.props.yearSelectionAvailable) this.setState({selectedYear: true});
}
});
module.exports = DateDisplay;