mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-10 01:19:45 +08:00
115 lines
3.1 KiB
JavaScript
115 lines
3.1 KiB
JavaScript
import React, { Component } from "react";
|
|
import { connect } from "react-redux";
|
|
import PropTypes from "prop-types";
|
|
import { FormattedMessage } from "react-intl";
|
|
import { Modal, Button } from "react-bootstrap";
|
|
import _ from "lodash";
|
|
|
|
import { getActivities } from "../../actions/ActivitiesActions";
|
|
import ActivityElement from "./ActivityElement";
|
|
import ActivityDateElement from "./ActivityDateElement";
|
|
|
|
class GlobalActivitiesModal extends Component {
|
|
constructor(props) {
|
|
super(props);
|
|
this.displayActivities = this.displayActivities.bind(this);
|
|
this.addMoreActivities = this.addMoreActivities.bind(this);
|
|
}
|
|
|
|
displayActivities() {
|
|
if (this.props.activities.length === 0) {
|
|
return (
|
|
<li>
|
|
<FormattedMessage id="activities.no_data" />
|
|
</li>
|
|
);
|
|
}
|
|
return this.props.activities.map((activity, i, arr) => {
|
|
let newDate = new Date(activity.created_at);
|
|
if (i > 0) {
|
|
let prevDate = new Date(arr[i - 1].created_at);
|
|
if (prevDate < newDate) {
|
|
return [
|
|
<ActivityDateElement key={newDate} date={newDate} />,
|
|
<ActivityElement key={activity.id} activity={activity} />
|
|
];
|
|
}
|
|
} else {
|
|
return [
|
|
<ActivityDateElement key={newDate} date={newDate} />,
|
|
<ActivityElement key={activity.id} activity={activity} />
|
|
];
|
|
}
|
|
return <ActivityElement key={activity.id} activity={activity} />;
|
|
});
|
|
}
|
|
|
|
addMoreActivities() {
|
|
let last_id = _.last(this.props.activities).id;
|
|
this.props.fetchActivities(last_id);
|
|
}
|
|
|
|
addMoreButton() {
|
|
if (this.props.more) {
|
|
return (
|
|
<li>
|
|
<Button onClick={this.addMoreActivities}>
|
|
<FormattedMessage id="activities.more_activities" />
|
|
</Button>
|
|
</li>
|
|
);
|
|
}
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<Modal show={this.props.showModal} onHide={this.props.onCloseModal}>
|
|
<Modal.Header closeButton>
|
|
<Modal.Title>
|
|
<FormattedMessage id="activities.modal_title" />
|
|
</Modal.Title>
|
|
</Modal.Header>
|
|
<Modal.Body>
|
|
<ul>
|
|
{this.displayActivities()}
|
|
{this.addMoreButton()}
|
|
</ul>
|
|
</Modal.Body>
|
|
<Modal.Footer>
|
|
<Button onClick={this.props.onCloseModal}>
|
|
<FormattedMessage id="general.close" />
|
|
</Button>
|
|
</Modal.Footer>
|
|
</Modal>
|
|
);
|
|
}
|
|
}
|
|
|
|
GlobalActivitiesModal.propTypes = {
|
|
showModal: PropTypes.bool.isRequired,
|
|
onCloseModal: PropTypes.func.isRequired,
|
|
fetchActivities: PropTypes.func.isRequired,
|
|
more: PropTypes.bool.isRequired,
|
|
activities: PropTypes.arrayOf(
|
|
PropTypes.shape({
|
|
id: PropTypes.number.isRequired,
|
|
message: PropTypes.string.isRequired,
|
|
created_at: PropTypes.string.isRequired
|
|
})
|
|
).isRequired
|
|
};
|
|
|
|
const mapStateToProps = ({ global_activities }) => {
|
|
let { activities, more } = global_activities;
|
|
return { activities, more };
|
|
};
|
|
|
|
const mapDispatchToProps = dispatch => ({
|
|
fetchActivities(last_id) {
|
|
dispatch(getActivities(last_id));
|
|
}
|
|
});
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(
|
|
GlobalActivitiesModal
|
|
);
|