Skip to content

Commit

Permalink
[explore-v2] control panel fixes (#1529)
Browse files Browse the repository at this point in the history
* 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
  • Loading branch information
Alanna Scott authored Nov 3, 2016
1 parent ae46561 commit 4156ad5
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 18 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import React, { PropTypes } from 'react';
import { Tooltip, OverlayTrigger } from 'react-bootstrap';
import { slugify } from '../modules/utils';

const propTypes = {
label: PropTypes.string.isRequired,
Expand All @@ -10,7 +11,7 @@ export default function InfoTooltipWithTrigger({ label, tooltip }) {
return (
<OverlayTrigger
placement="right"
overlay={<Tooltip id={`${label}-tooltip`}>{tooltip}</Tooltip>}
overlay={<Tooltip id={`${slugify(label)}-tooltip`}>{tooltip}</Tooltip>}
>
<i className="fa fa-question-circle-o" />
</OverlayTrigger>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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,
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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>
Expand All @@ -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>
);
Expand Down
25 changes: 14 additions & 11 deletions caravel/assets/javascripts/explorev2/components/FieldSet.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -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;
}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -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,
Expand All @@ -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>
Expand Down
10 changes: 10 additions & 0 deletions caravel/assets/javascripts/modules/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -142,3 +142,13 @@ export function formatSelectOptions(options) {
[opt, opt]
);
}

export function slugify(string) {
// slugify('My Neat Label! '); returns 'my-neat-label'
return string
.toString()
.toLowerCase()
.trim()
.replace(/[\s\W-]+/g, '-') // replace spaces, non-word chars, w/ a single dash (-)
.replace(/-$/, ''); // remove last floating dash
}

0 comments on commit 4156ad5

Please sign in to comment.