focus-components-v3
Version:
Focus web components to build applications (based on Material Design)
215 lines (172 loc) • 20.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _i18next = require('i18next');
var _i18next2 = _interopRequireDefault(_i18next);
var _lang = require('lodash/lang');
var _union = require('lodash/union');
var _union2 = _interopRequireDefault(_union);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); } //dependencies
var UNSELECTED_KEY = 'UNSELECTED_KEY';
/**
* Parse the value.
* @param {string | number} propsValue - The value given as props to read the type.
* @param {string} rawValue - The raw string value.
* @return {strint | number} - The parsed value.
*/
function _valueParser(propsValue, rawValue) {
if (UNSELECTED_KEY === rawValue) {
return undefined;
}
var type = this.props.type;
return type === 'number' ? +rawValue : rawValue;
}
/**
* Component standing for an HTML input.
*/
var Select = function (_PureComponent) {
_inherits(Select, _PureComponent);
function Select() {
var _temp, _this, _ret;
_classCallCheck(this, Select);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = _possibleConstructorReturn(this, _PureComponent.call.apply(_PureComponent, [this].concat(args))), _this), _this.getValue = function () {
var _this$props = _this.props,
type = _this$props.type,
rawInputValue = _this$props.rawInputValue;
if ((0, _lang.isNull)(rawInputValue) || (0, _lang.isUndefined)(rawInputValue) || UNSELECTED_KEY === rawInputValue) return null;
return type === 'number' ? +rawInputValue : rawInputValue;
}, _this._handleSelectChange = function (evt) {
var _this$props2 = _this.props,
onChange = _this$props2.onChange,
valueParser = _this$props2.valueParser,
rawInputValue = _this$props2.rawInputValue;
var value = evt.target.value;
return onChange(valueParser.call(_this, rawInputValue, value));
}, _temp), _possibleConstructorReturn(_this, _ret);
}
/**
* Get the dom value of the component.
* @return {object} - The unformated dom value.
*/
/**
* Handle the change on the select, it only propagates the value.
* @param {object} evt - The react DOM event.
* @return {object} - The function onChange from the props, called.
*/
/** inheritdoc */
Select.prototype._renderOptions = function _renderOptions(_ref, defaultValue) {
var hasUndefined = _ref.hasUndefined,
labelKey = _ref.labelKey,
isRequired = _ref.isRequired,
rawInputValue = _ref.rawInputValue,
_ref$values = _ref.values,
values = _ref$values === undefined ? [] : _ref$values,
valueKey = _ref.valueKey,
isActiveProperty = _ref.isActiveProperty,
unSelectedLabel = _ref.unSelectedLabel;
var isRequiredAndNoValue = isRequired && ((0, _lang.isUndefined)(rawInputValue) || (0, _lang.isNull)(rawInputValue));
if (hasUndefined || isRequiredAndNoValue) {
var _ref2;
values = (0, _union2.default)([(_ref2 = {}, _defineProperty(_ref2, labelKey, _i18next2.default.t(unSelectedLabel)), _defineProperty(_ref2, valueKey, UNSELECTED_KEY), _ref2)], values);
}
return values.filter(function (v) {
return (0, _lang.isUndefined)(v[isActiveProperty]) || v[isActiveProperty] === true;
}) // Filter on the
.map(function (val, idx) {
var optVal = '' + val[valueKey];
var elementValue = val[labelKey];
var optLabel = (0, _lang.isUndefined)(elementValue) || (0, _lang.isNull)(elementValue) ? _i18next2.default.t('focus.components.input.select.noLabel') : elementValue;
return _react2.default.createElement(
'option',
{ key: idx, value: optVal, selected: val.isDefaultValue },
optLabel
);
});
};
/**
* @inheritdoc
* @override
*/
Select.prototype.render = function render() {
var _props = this.props,
autoFocus = _props.autoFocus,
error = _props.error,
multiple = _props.multiple,
name = _props.name,
placeholder = _props.placeholder,
style = _props.style,
rawInputValue = _props.rawInputValue,
values = _props.values,
disabled = _props.disabled,
onChange = _props.onChange,
size = _props.size,
valid = _props.valid;
var selectProps = { autoFocus: autoFocus, disabled: disabled, multiple: multiple, size: size };
return _react2.default.createElement(
'div',
{ 'data-focus': 'select', ref: 'select', 'data-valid': !error, style: style },
_react2.default.createElement(
'select',
_extends({ name: name, onChange: this._handleSelectChange, ref: 'htmlSelect', value: rawInputValue }, selectProps),
this._renderOptions(this.props)
),
!valid && _react2.default.createElement(
'div',
{ className: 'label-error', ref: 'error' },
error
)
);
};
return Select;
}(_react.PureComponent);
//Static props.
Select.displayName = 'Select';
Select.propTypes = {
disabled: _react.PropTypes.bool,
defaultValue: _react.PropTypes.object,
error: _react.PropTypes.string,
hasUndefined: _react.PropTypes.bool,
isActiveProperty: _react.PropTypes.string,
isRequired: _react.PropTypes.bool,
labelKey: _react.PropTypes.string,
multiple: _react.PropTypes.bool,
name: _react.PropTypes.string.isRequired,
onChange: _react.PropTypes.func.isRequired,
placeholder: _react.PropTypes.string,
unSelectedLabel: _react.PropTypes.string,
rawInputValue: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.number]),
valid: _react.PropTypes.bool,
valueKey: _react.PropTypes.string,
values: _react.PropTypes.array.isRequired
};
Select.defaultProps = {
disabled: false,
error: 'focus.components.input.select.error.default',
hasUndefined: true,
isActiveProperty: 'isActive',
isRequired: false,
labelKey: 'label',
multiple: false,
unSelectedLabel: 'select.unSelected',
valid: true,
values: [],
valueKey: 'code',
valueParser: _valueParser
};
exports.default = Select;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["fr-FR.js"],"names":["UNSELECTED_KEY","_valueParser","propsValue","rawValue","undefined","type","props","Select","getValue","rawInputValue","_handleSelectChange","evt","onChange","valueParser","value","target","call","_renderOptions","defaultValue","hasUndefined","labelKey","isRequired","values","valueKey","isActiveProperty","unSelectedLabel","isRequiredAndNoValue","t","filter","v","map","val","idx","optVal","elementValue","optLabel","isDefaultValue","render","autoFocus","error","multiple","name","placeholder","style","disabled","size","valid","selectProps","displayName","propTypes","bool","object","string","func","oneOfType","number","array","defaultProps"],"mappings":"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","file":"fr-FR.js","sourcesContent":["//dependencies\r\nimport React, {PropTypes, PureComponent} from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport i18next from 'i18next';\r\nimport {isUndefined, isNull, isNumber} from 'lodash/lang';\r\nimport union from 'lodash/union';\r\nconst UNSELECTED_KEY = 'UNSELECTED_KEY';\r\n/**\r\n* Parse the value.\r\n* @param  {string | number} propsValue - The value given as props to read the type.\r\n* @param  {string} rawValue   - The raw string value.\r\n* @return {strint | number}  - The parsed value.\r\n*/\r\nfunction _valueParser(propsValue, rawValue) {\r\n    if(UNSELECTED_KEY === rawValue) {\r\n        return undefined;\r\n    }\r\n    const {type} = this.props;\r\n    return type === 'number' ? +rawValue : rawValue;\r\n}\r\n\r\n\r\n/**\r\n* Component standing for an HTML input.\r\n*/\r\nclass Select extends PureComponent {\r\n\r\n    /**\r\n    * Get the dom value of the component.\r\n    * @return {object} - The unformated dom value.\r\n    */\r\n    getValue = () => {\r\n        const {type, rawInputValue} = this.props;\r\n        if (isNull(rawInputValue) || isUndefined(rawInputValue) || UNSELECTED_KEY === rawInputValue) return null;\r\n        return type === 'number' ? +rawInputValue : rawInputValue;\r\n    };\r\n\r\n    /**\r\n    * Handle the change on the select, it only propagates the value.\r\n    * @param  {object} evt - The react DOM event.\r\n    * @return {object} - The function onChange from the props, called.\r\n    */\r\n    _handleSelectChange = (evt) => {\r\n        const {onChange, valueParser, rawInputValue} = this.props;\r\n        const {value} = evt.target;\r\n        return onChange(valueParser.call(this, rawInputValue, value));\r\n    };\r\n\r\n    /** inheritdoc */\r\n    _renderOptions({hasUndefined, labelKey, isRequired, rawInputValue, values = [], valueKey, isActiveProperty, unSelectedLabel}, defaultValue) {\r\n        const isRequiredAndNoValue = isRequired && (isUndefined(rawInputValue) || isNull(rawInputValue));\r\n        if(hasUndefined || isRequiredAndNoValue) {\r\n            values = union(\r\n                [{[labelKey]: i18next.t(unSelectedLabel), [valueKey]: UNSELECTED_KEY}],\r\n                values\r\n            );\r\n        }\r\n        return values\r\n        .filter(v => isUndefined(v[isActiveProperty]) || v[isActiveProperty] === true) // Filter on the\r\n        .map((val, idx) => {\r\n            const optVal = `${val[valueKey]}`;\r\n            const elementValue = val[labelKey];\r\n            const optLabel = isUndefined(elementValue) || isNull(elementValue) ? i18next.t('focus.components.input.select.noLabel') : elementValue;\r\n            return (<option key={idx} value={optVal} selected={val.isDefaultValue}>{optLabel}</option>);\r\n        });\r\n    }\r\n\r\n    /**\r\n    * @inheritdoc\r\n    * @override\r\n    */\r\n    render() {\r\n        const { autoFocus, error, multiple, name, placeholder, style, rawInputValue, values, disabled, onChange, size, valid } = this.props;\r\n        const selectProps = { autoFocus, disabled, multiple, size };\r\n        return (\r\n            <div data-focus='select' ref='select' data-valid={!error} style={style}>\r\n                <select name={name} onChange={this._handleSelectChange} ref='htmlSelect' value={rawInputValue} {...selectProps}>\r\n                    {this._renderOptions(this.props)}\r\n                </select>\r\n                {!valid && <div className='label-error' ref='error'>{error}</div>}\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\n//Static props.\r\nSelect.displayName = 'Select';\r\nSelect.propTypes = {\r\n    disabled: PropTypes.bool,\r\n    defaultValue: PropTypes.object,\r\n    error: PropTypes.string,\r\n    hasUndefined: PropTypes.bool,\r\n    isActiveProperty: PropTypes.string,\r\n    isRequired: PropTypes.bool,\r\n    labelKey: PropTypes.string,\r\n    multiple: PropTypes.bool,\r\n    name: PropTypes.string.isRequired,\r\n    onChange: PropTypes.func.isRequired,\r\n    placeholder: PropTypes.string,\r\n    unSelectedLabel: PropTypes.string,\r\n    rawInputValue: PropTypes.oneOfType([\r\n        PropTypes.string,\r\n        PropTypes.number\r\n    ]),\r\n    valid: PropTypes.bool,\r\n    valueKey: PropTypes.string,\r\n    values: PropTypes.array.isRequired\r\n};\r\nSelect.defaultProps = {\r\n    disabled: false,\r\n    error: 'focus.components.input.select.error.default',\r\n    hasUndefined: true,\r\n    isActiveProperty: 'isActive',\r\n    isRequired: false,\r\n    labelKey: 'label',\r\n    multiple: false,\r\n    unSelectedLabel: 'select.unSelected',\r\n    valid: true,\r\n    values: [],\r\n    valueKey: 'code',\r\n    valueParser: _valueParser\r\n};\r\nexport default Select;\r\n"]}