Ivan - Add formfield infotooltip and staff editor level info [skip ci]

This commit is contained in:
Ivan Diaz 2017-01-05 14:49:10 -03:00
parent f9194b1b03
commit d550e01358
7 changed files with 68 additions and 3 deletions

View File

@ -137,7 +137,7 @@ class StaffEditor extends React.Component {
<div> <div>
<span className="separator staff-editor__separator"/> <span className="separator staff-editor__separator"/>
<Form className="staff-editor__update-level" values={{level: this.state.level}} onChange={form => this.setState({level: form.level})} onSubmit={this.onSubmit.bind(this, 'LEVEL')}> <Form className="staff-editor__update-level" values={{level: this.state.level}} onChange={form => this.setState({level: form.level})} onSubmit={this.onSubmit.bind(this, 'LEVEL')}>
<FormField name="level" label={i18n('LEVEL')} field="select" fieldProps={{ <FormField name="level" label={i18n('LEVEL')} field="select" infoMessage={this.getStaffLevelInfo()} fieldProps={{
items: [{content: i18n('LEVEL_1')}, {content: i18n('LEVEL_2')}, {content: i18n('LEVEL_3')}], items: [{content: i18n('LEVEL_1')}, {content: i18n('LEVEL_2')}, {content: i18n('LEVEL_3')}],
size: 'large' size: 'large'
}} /> }} />
@ -219,6 +219,25 @@ class StaffEditor extends React.Component {
return SessionStore.getDepartments().map(department => department.name); return SessionStore.getDepartments().map(department => department.name);
} }
getStaffLevelInfo() {
return (
<div className="staff-editor__level-info">
<div className="staff-editor__level-info-box">
<span className="staff-editor__level-info-title">{i18n('LEVEL')} 1 </span>
<span className="staff-editor__level-info-description">{i18n('LEVEL_1_DESCRIPTION')}</span>
</div>
<div className="staff-editor__level-info-box">
<span className="staff-editor__level-info-title">{i18n('LEVEL')} 2 </span>
<span className="staff-editor__level-info-description">{i18n('LEVEL_2_DESCRIPTION')}</span>
</div>
<div className="staff-editor__level-info-box">
<span className="staff-editor__level-info-title">{i18n('LEVEL')} 3 </span>
<span className="staff-editor__level-info-description">{i18n('LEVEL_3_DESCRIPTION')}</span>
</div>
</div>
);
}
onSubmit(eventType, form) { onSubmit(eventType, form) {
let departments; let departments;

View File

@ -139,4 +139,21 @@
float: left; float: left;
margin-top: 11px; margin-top: 11px;
} }
&__level-info {
width: 360px;
font-size: $font-size--sm;
&-box {
margin-top: 5px;
}
&-title {
color: $secondary-blue;
}
&-description {
color: $dark-grey;
}
}
} }

View File

@ -8,6 +8,7 @@ import DropDown from 'core-components/drop-down';
import Checkbox from 'core-components/checkbox'; import Checkbox from 'core-components/checkbox';
import CheckboxGroup from 'core-components/checkbox-group'; import CheckboxGroup from 'core-components/checkbox-group';
import TextEditor from 'core-components/text-editor'; import TextEditor from 'core-components/text-editor';
import InfoTooltip from 'core-components/info-tooltip';
class FormField extends React.Component { class FormField extends React.Component {
static contextTypes = { static contextTypes = {
@ -21,6 +22,7 @@ class FormField extends React.Component {
onBlur: React.PropTypes.func, onBlur: React.PropTypes.func,
required: React.PropTypes.bool, required: React.PropTypes.bool,
error: React.PropTypes.string, error: React.PropTypes.string,
infoMessage: React.PropTypes.string,
value: React.PropTypes.any, value: React.PropTypes.any,
field: React.PropTypes.oneOf(['input', 'textarea', 'select', 'checkbox', 'checkbox-group']), field: React.PropTypes.oneOf(['input', 'textarea', 'select', 'checkbox', 'checkbox-group']),
fieldProps: React.PropTypes.object fieldProps: React.PropTypes.object
@ -51,7 +53,7 @@ class FormField extends React.Component {
render() { render() {
const Wrapper = (_.includes(this.getDivTypes(), this.props.field)) ? 'div' : 'label'; const Wrapper = (_.includes(this.getDivTypes(), this.props.field)) ? 'div' : 'label';
const fieldContent = [ const fieldContent = [
<span className="form-field__label" key="label">{this.props.label}</span>, this.renderLabel(),
this.renderField(), this.renderField(),
this.renderError() this.renderError()
]; ];
@ -59,6 +61,7 @@ class FormField extends React.Component {
if (this.props.field === 'checkbox') { if (this.props.field === 'checkbox') {
fieldContent.swap(0, 1); fieldContent.swap(0, 1);
} }
return ( return (
<Wrapper className={this.getClass()}> <Wrapper className={this.getClass()}>
{fieldContent} {fieldContent}
@ -66,6 +69,15 @@ class FormField extends React.Component {
); );
} }
renderLabel() {
return (
<span className="form-field__label" key="label">
{this.props.label}
{(this.props.infoMessage) ? <InfoTooltip text={this.props.infoMessage} className="form-field__info" /> : null}
</span>
)
}
renderField() { renderField() {
let Field = { let Field = {
'input': Input, 'input': Input,

View File

@ -12,6 +12,12 @@
text-align: left; text-align: left;
} }
&__info {
position: relative;
top: -1px;
left: 5px;
}
&_errored { &_errored {
.form-field__error { .form-field__error {
color: $primary-red; color: $primary-red;

View File

@ -8,7 +8,7 @@ import Tooltip from 'core-components/tooltip';
class InfoTooltip extends React.Component { class InfoTooltip extends React.Component {
static propTypes = { static propTypes = {
type: React.PropTypes.oneOf(['default', 'warning']), type: React.PropTypes.oneOf(['default', 'warning']),
text: React.PropTypes.string.isRequired text: React.PropTypes.node.isRequired
}; };
static defaultProps = { static defaultProps = {
@ -31,6 +31,7 @@ class InfoTooltip extends React.Component {
renderText() { renderText() {
let message = (this.props.type === 'default') ? i18n('INFO') : i18n('WARNING'); let message = (this.props.type === 'default') ? i18n('INFO') : i18n('WARNING');
return ( return (
<div className="info-tooltip__text"> <div className="info-tooltip__text">
<div className="info-tooltip__text-title"> <div className="info-tooltip__text-title">
@ -47,6 +48,8 @@ class InfoTooltip extends React.Component {
'info-tooltip_warning': (this.props.type === 'warning') 'info-tooltip_warning': (this.props.type === 'warning')
}; };
classes[this.props.className] = (this.props.className);
return classNames(classes); return classNames(classes);
} }
} }

View File

@ -1,7 +1,10 @@
@import "../scss/vars"; @import "../scss/vars";
.info-tooltip { .info-tooltip {
display: inline-block;
&__text { &__text {
&-title { &-title {
color: $secondary-blue; color: $secondary-blue;
font-size: $font-size--md; font-size: $font-size--md;
@ -10,9 +13,11 @@
&__icon { &__icon {
color: $secondary-blue; color: $secondary-blue;
font-size: $font-size--sm;
} }
&_warning { &_warning {
.info-tooltip__icon { .info-tooltip__icon {
color: $primary-red; color: $primary-red;
} }

View File

@ -107,6 +107,9 @@ export default {
'LEVEL_1': 'Level 1 (Tickets)', 'LEVEL_1': 'Level 1 (Tickets)',
'LEVEL_2': 'Level 2 (Tickets + Articles)', 'LEVEL_2': 'Level 2 (Tickets + Articles)',
'LEVEL_3': 'Level 3 (Tickets + Articles + Staff)', 'LEVEL_3': 'Level 3 (Tickets + Articles + Staff)',
'LEVEL_1_DESCRIPTION': 'can only respond tickets and manage users.',
'LEVEL_2_DESCRIPTION': 'can do every Level 1 does, can create or edit articles and it can create custom responses.',
'LEVEL_3_DESCRIPTION': 'can do every Level 2 does, can create or edit staff members and can manage the whole system.',
'UPDATE_EMAIL': 'Update email', 'UPDATE_EMAIL': 'Update email',
'UPDATE_PASSWORD': 'Update password', 'UPDATE_PASSWORD': 'Update password',
'UPDATE_LEVEL': 'Update level', 'UPDATE_LEVEL': 'Update level',