Anna Kurylo
2018-10-16 99929e8c706aa7f6196ac4e02df1c04449feee7a
src/YearsView.js
@@ -1,19 +1,21 @@
'use strict';
var React = require('react');
var React = require('react'),
   createClass = require('create-react-class'),
   onClickOutside = require('react-onclickoutside').default
   ;
var DOM = React.DOM;
var DateTimePickerYears = React.createClass({
var DateTimePickerYears = onClickOutside( createClass({
   render: function() {
      var year = parseInt( this.props.viewDate.year() / 10, 10 ) * 10;
      return DOM.div({ className: 'rdtYears' }, [
         DOM.table({ key: 'a' }, DOM.thead({}, DOM.tr({}, [
            DOM.th({ key: 'prev', className: 'rdtPrev' }, DOM.span({ onClick: this.props.subtractTime( 10, 'years' )}, '‹' )),
            DOM.th({ key: 'year', className: 'rdtSwitch', onClick: this.props.showView( 'years' ), colSpan: 2 }, year + '-' + ( year + 9 ) ),
            DOM.th({ key: 'next', className: 'rdtNext' }, DOM.span({ onClick: this.props.addTime( 10, 'years' )}, '›' ))
            ]))),
         DOM.table({ key: 'years' }, DOM.tbody( {}, this.renderYears( year )))
      return React.createElement('div', { className: 'rdtYears' }, [
         React.createElement('table', { key: 'a' }, React.createElement('thead', {}, React.createElement('tr', {}, [
            React.createElement('th', { key: 'prev', className: 'rdtPrev', onClick: this.props.subtractTime( 10, 'years' )}, React.createElement('span', {}, '‹' )),
            React.createElement('th', { key: 'year', className: 'rdtSwitch', onClick: this.props.showView( 'years' ), colspan: 2 }, year + '-' + ( year + 9 ) ),
            React.createElement('th', { key: 'next', className: 'rdtNext', onClick: this.props.addTime( 10, 'years' )}, React.createElement('span', {}, '›' ))
         ]))),
         React.createElement('table', { key: 'years' }, React.createElement('tbody',  {}, this.renderYears( year )))
      ]);
   },
@@ -24,21 +26,22 @@
         renderer = this.props.renderYear || this.renderYear,
         selectedDate = this.props.selectedDate,
         isValid = this.props.isValidDate || this.alwaysValidDate,
         classes, props
      ;
      year--;
      var currentYear, isDisabled, noOfDaysInYear, daysInYear, validDay,
         classes, props, currentYear, isDisabled, noOfDaysInYear, daysInYear, validDay,
         // Month and date are irrelevant here because
         // we're only interested in the year
         irrelevantMonth = 0,
         irrelevantDate = 1;
         irrelevantDate = 1
         ;
      year--;
      while (i < 11) {
         classes = 'rdtYear';
         currentYear = this.props.viewDate.clone().set(
            { year: year, month: irrelevantMonth, date: irrelevantDate });
         if ( i === -1 | i === 10 )
            classes += ' rdtOld';
            { year: year, month: irrelevantMonth, date: irrelevantDate } );
         // Not sure what 'rdtOld' is for, commenting out for now as it's not working properly
         // if ( i === -1 | i === 10 )
            // classes += ' rdtOld';
         noOfDaysInYear = currentYear.endOf( 'year' ).format( 'DDD' );
         daysInYear = Array.from({ length: noOfDaysInYear }, function( e, i ) {
@@ -65,12 +68,13 @@
         };
         if ( !isDisabled )
            props.onClick = this.props.updateOn === 'years' ? this.updateSelectedYear : this.props.setDate('year');
            props.onClick = ( this.props.updateOn === 'years' ?
               this.updateSelectedYear : this.props.setDate('year') );
         years.push( renderer( props, year, selectedDate && selectedDate.clone() ));
         if ( years.length === 4 ){
            rows.push( DOM.tr({ key: i }, years ) );
         if ( years.length === 4 ) {
            rows.push( React.createElement('tr', { key: i }, years ) );
            years = [];
         }
@@ -82,16 +86,20 @@
   },
   updateSelectedYear: function( event ) {
      this.props.updateSelectedDate( event, true );
      this.props.updateSelectedDate( event );
   },
   renderYear: function( props, year ) {
      return DOM.td( props, year );
      return React.createElement('td',  props, year );
   },
   alwaysValidDate: function() {
      return 1;
   },
   handleClickOutside: function() {
      this.props.handleClickOutside();
   }
});
}));
module.exports = DateTimePickerYears;