diff options
| author | Noah Loomans <noahloomans@gmail.com> | 2018-01-28 15:43:11 +0100 | 
|---|---|---|
| committer | Noah Loomans <noahloomans@gmail.com> | 2018-01-28 15:43:11 +0100 | 
| commit | 8670ada517bc8beb69d152c82f282322b9ea8d64 (patch) | |
| tree | de3d52fcdf48a69806a41e408065b7f119206610 /src/client/react/components/container | |
| parent | 0c99c0b4d84f53675cc3d42fa518879789cc86b0 (diff) | |
Implement week selector in the view
Diffstat (limited to 'src/client/react/components/container')
| -rw-r--r-- | src/client/react/components/container/View.js | 18 | 
1 files changed, 10 insertions, 8 deletions
diff --git a/src/client/react/components/container/View.js b/src/client/react/components/container/View.js index 9bac66f..be550cd 100644 --- a/src/client/react/components/container/View.js +++ b/src/client/react/components/container/View.js @@ -16,24 +16,26 @@ function cleanMeetingpointHTML(htmlStr) {  class View extends React.Component {    componentDidMount() { -    if (!this.loadingFinished(this.props.user)) { -      this.props.dispatch(fetchSchedule(this.props.user)); +    if (!this.loadingFinished(this.props.user, this.props.week)) { +      this.props.dispatch(fetchSchedule(this.props.user, this.props.week));      }    }    componentWillReceiveProps(nextProps) { -    if (nextProps.user !== this.props.user && !this.loadingFinished(nextProps.user)) { -      this.props.dispatch(fetchSchedule(nextProps.user)); +    if ((nextProps.user !== this.props.user || nextProps.week !== this.props.week) +        && !this.loadingFinished(nextProps.user, nextProps.week)) { +      this.props.dispatch(fetchSchedule(nextProps.user, nextProps.week));      }    } -  loadingFinished(user) { +  loadingFinished(user, week) {      return this.props.schedules.hasOwnProperty(user) && -      this.props.schedules[user].state === 'finished'; +      this.props.schedules[user].hasOwnProperty(week) && +      this.props.schedules[user][week].state === 'finished';    }    render() { -    if (!this.loadingFinished(this.props.user)) { +    if (!this.loadingFinished(this.props.user, this.props.week)) {        return (          <div>            Loading... @@ -41,7 +43,7 @@ class View extends React.Component {        );      } -    const cleanHTML = cleanMeetingpointHTML(this.props.schedules[this.props.user].htmlStr); +    const cleanHTML = cleanMeetingpointHTML(this.props.schedules[this.props.user][this.props.week].htmlStr);      return (        // eslint-disable-next-line react/no-danger  | 
