[explore-v2] control panel fixes (#1529)

* make fieldset conditions more clear

* make label required

* use render* pattern

* use slugify util for turning labels into ids

* use field rather than html

* don't need panel-title class here
This commit is contained in:
Alanna Scott
2016-11-02 21:51:56 -07:00
committed by GitHub
parent ae46561648
commit 4156ad5a30
6 changed files with 32 additions and 18 deletions

View File

@@ -3,12 +3,11 @@ import { ControlLabel } from 'react-bootstrap';
import InfoTooltipWithTrigger from '../../components/InfoTooltipWithTrigger';
const propTypes = {
label: PropTypes.string,
label: PropTypes.string.isRequired,
description: PropTypes.string,
};
const defaultProps = {
label: null,
description: null,
};

View File

@@ -16,12 +16,12 @@ const defaultProps = {
};
export default class ControlPanelSection extends React.Component {
header() {
renderHeader() {
const { label, tooltip } = this.props;
let header;
if (label) {
header = (
<div className="panel-title">
<div>
{label} &nbsp;
{tooltip && <InfoTooltipWithTrigger label={label} tooltip={tooltip} />}
</div>
@@ -32,7 +32,7 @@ export default class ControlPanelSection extends React.Component {
render() {
return (
<Panel header={this.header()}>
<Panel header={this.renderHeader()}>
{this.props.children}
</Panel>
);

View File

@@ -40,22 +40,25 @@ export default class FieldSet extends React.Component {
render() {
const type = this.props.type;
let html;
const selectTypes = [
'SelectField',
'SelectCustomMultiField',
'SelectMultipleSortableField',
'FreeFormSelectField',
];
let field;
if (type === 'CheckboxField') {
html = this.renderCheckBoxField();
} else if (type === 'SelectField' ||
type === 'SelectCustomMultiField' ||
type === 'SelectMultipleSortableField' ||
type === 'FreeFormSelectField') {
html = this.renderSelectField();
} else if (type === 'TextField' || type === 'IntegerField') {
html = this.renderTextField();
field = this.renderCheckBoxField();
} else if (selectTypes.includes(type)) {
field = this.renderSelectField();
} else if (['TextField', 'IntegerField'].includes(type)) {
field = this.renderTextField();
} else if (type === 'TextAreaField') {
this.renderTextAreaField();
field = this.renderTextAreaField();
}
return html;
return field;
}
}

View File

@@ -1,6 +1,7 @@
import React, { PropTypes } from 'react';
import { FormGroup, FormControl } from 'react-bootstrap';
import ControlLabelWithTooltip from './ControlLabelWithTooltip';
import { slugify } from '../../modules/utils';
const propTypes = {
label: PropTypes.string,
@@ -14,7 +15,7 @@ const defaultProps = {
export default function SelectField({ label, description }) {
return (
<FormGroup controlId={`formControlsSelect-${label}`}>
<FormGroup controlId={`formControlsSelect-${slugify(label)}`}>
<ControlLabelWithTooltip label={label} description={description} />
<FormControl componentClass="select" placeholder="select">
<option value="select">select</option>