/*
Copyright (C) 2017 Cloudbase Solutions SRL
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see .
*/
import React, { Component, PropTypes } from 'react';
import withStyles from 'isomorphic-style-loader/lib/withStyles';
import s from './CloudConnectionAuth.scss';
import Helper from '../Helper';
import LoadingIcon from "../LoadingIcon/LoadingIcon";
const title = 'connection details';
class CloudConnectionAuth extends Component {
static propTypes = {
connection: PropTypes.object
}
static contextTypes = {
onSetTitle: PropTypes.func.isRequired,
};
constructor(props) {
super(props)
let fields = this.processProps(props)
this.state = { fields: fields }
}
componentWillMount() {
this.context.onSetTitle(title);
}
processProps(props) {
let fields = []
if (props.connection.credentials) {
for (let fieldName in props.connection.credentials) {
let value = props.connection.credentials[fieldName]
if (value.value) { // if dropdown
value = value.value
}
if (value === true) value = "Yes"
if (value === false) value = "No"
fields.push({
fieldName: Helper.convertCloudFieldLabel(fieldName),
fieldValue: value
})
}
}
return fields
}
renderFields() {
if (this.state.fields.length) {
return this.state.fields.map((field, index) => (