147 lines
4.3 KiB
JavaScript
147 lines
4.3 KiB
JavaScript
/**
|
|
* Copyright 2017 Red Hat Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
* not use this file except in compliance with the License. You may obtain
|
|
* a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
* License for the specific language governing permissions and limitations
|
|
* under the License.
|
|
*/
|
|
|
|
import { connect } from 'react-redux';
|
|
import { defineMessages, FormattedMessage, injectIntl } from 'react-intl';
|
|
import PropTypes from 'prop-types';
|
|
import React from 'react';
|
|
import { Link } from 'react-router-dom';
|
|
|
|
import PlansActions from '../../actions/PlansActions';
|
|
import Loader from '../ui/Loader';
|
|
import Modal from '../ui/Modal';
|
|
|
|
const messages = defineMessages({
|
|
exportPlanName: {
|
|
id: 'ExportPlan.exportPlanName',
|
|
defaultMessage: 'Export {planName}'
|
|
},
|
|
exportingPlanLoader: {
|
|
id: 'ExportPlan.exportingPlanLoader',
|
|
defaultMessage: 'Exporting plan...'
|
|
},
|
|
downloadPlanExport: {
|
|
id: 'ExportPlan.download',
|
|
defaultMessage: 'Download Export'
|
|
},
|
|
downloadPlanExportMessage: {
|
|
id: 'ExportPlan.downloadMessage',
|
|
defaultMessage: 'The plan export you requested is ready. Please click the button below to ' +
|
|
'download the export. You might need to right-click the button and choose ' +
|
|
'"Save link as...".'
|
|
},
|
|
exportError: {
|
|
id: 'ExportPlan.error',
|
|
defaultMessage: 'An error occurred while exporting the plan'
|
|
},
|
|
cancel: {
|
|
id: 'ExportPlan.cancel',
|
|
defaultMessage: 'Cancel'
|
|
}
|
|
});
|
|
|
|
class ExportPlan extends React.Component {
|
|
componentDidMount() {
|
|
let planName = this.getNameFromUrl();
|
|
this.props.exportPlan(planName);
|
|
}
|
|
|
|
getNameFromUrl() {
|
|
let planName = this.props.match.params.planName || '';
|
|
return planName.replace(/[^A-Za-z0-9_-]*/g, '');
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<Modal dialogClasses="modal-sm" id="ExportPlan__exportPlanModal">
|
|
<div className="modal-header">
|
|
<Link to="/plans/manage" type="button" className="close">
|
|
<span aria-hidden="true" className="pficon pficon-close" />
|
|
</Link>
|
|
<h4 className="modal-title">
|
|
<FormattedMessage
|
|
{...messages.exportPlanName}
|
|
values={{ planName: this.getNameFromUrl() }}
|
|
/>
|
|
</h4>
|
|
</div>
|
|
<div className="modal-body text-center">
|
|
<Loader
|
|
loaded={!this.props.isExportingPlan}
|
|
size="lg"
|
|
height={60}
|
|
content={this.props.intl.formatMessage(
|
|
messages.exportingPlanLoader
|
|
)}
|
|
>
|
|
{this.props.planExportUrl
|
|
? <div>
|
|
<p>
|
|
<FormattedMessage {...messages.downloadPlanExportMessage} />
|
|
</p>
|
|
<a
|
|
href={this.props.planExportUrl}
|
|
className="btn btn-success"
|
|
>
|
|
<FormattedMessage {...messages.downloadPlanExport} />
|
|
</a>
|
|
</div>
|
|
: <div>
|
|
<FormattedMessage {...messages.exportError} />
|
|
</div>}
|
|
</Loader>
|
|
</div>
|
|
<div className="modal-footer">
|
|
<Link
|
|
to="/plans/manage"
|
|
type="button"
|
|
className="btn btn-default"
|
|
id="ExportPlan__cancelExportPlanModalButton"
|
|
>
|
|
<FormattedMessage {...messages.cancel} />
|
|
</Link>
|
|
</div>
|
|
</Modal>
|
|
);
|
|
}
|
|
}
|
|
|
|
ExportPlan.propTypes = {
|
|
exportPlan: PropTypes.func,
|
|
intl: PropTypes.object,
|
|
isExportingPlan: PropTypes.bool,
|
|
match: PropTypes.object,
|
|
params: PropTypes.object,
|
|
planExportUrl: PropTypes.string
|
|
};
|
|
|
|
function mapStateToProps(state) {
|
|
return {
|
|
isExportingPlan: state.plans.isExportingPlan,
|
|
planExportUrl: state.plans.planExportUrl
|
|
};
|
|
}
|
|
|
|
function mapDispatchToProps(dispatch) {
|
|
return {
|
|
exportPlan: planName => dispatch(PlansActions.exportPlan(planName))
|
|
};
|
|
}
|
|
|
|
export default injectIntl(
|
|
connect(mapStateToProps, mapDispatchToProps)(ExportPlan)
|
|
);
|