focus-components-v3
Version:
Focus web components to build applications (based on Material Design)
246 lines (200 loc) • 26.6 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 _find = require('lodash/find');
var _find2 = _interopRequireDefault(_find);
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) {
var returnValue = rawValue ? rawValue : propsValue;
if (UNSELECTED_KEY === rawValue) {
return null;
}
var type = this.props.type;
return type === 'number' ? +returnValue : returnValue;
}
/**
* Component standing for an HTML input.
* https://github.com/CreativeIT/getmdl-select/
*/
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 (val, value) {
var _this$props2 = _this.props,
onChange = _this$props2.onChange,
valueParser = _this$props2.valueParser,
rawInputValue = _this$props2.rawInputValue;
_reactDom2.default.findDOMNode(_this.refs["selectMenu"]).parentNode.classList.remove('is-visible');
return onChange(valueParser.call(_this, rawInputValue, value));
}, _temp), _possibleConstructorReturn(_this, _ret);
}
Select.prototype.componentDidMount = function componentDidMount() {
var selectMenu = _reactDom2.default.findDOMNode(this.refs["selectMenu"]);
componentHandler.upgradeElement(selectMenu);
};
/**
* 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) {
var _ref2,
_this2 = this;
var defaultValue = _ref.defaultValue,
labelKey = _ref.labelKey,
hasUndefined = _ref.hasUndefined,
currentValue = _ref.currentValue,
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;
values = hasUndefined ? (0, _union2.default)([(_ref2 = {}, _defineProperty(_ref2, labelKey, _i18next2.default.t(unSelectedLabel)), _defineProperty(_ref2, valueKey, UNSELECTED_KEY), _ref2)], this.props.values) : values;
return values.filter(function (v) {
return (0, _lang.isUndefined)(v[isActiveProperty]) || v[isActiveProperty] === true;
}) // Filter on the active value only
.map(function (val, idx) {
var optVal = '' + val[valueKey];
var elementValue = val[labelKey];
var isSelected = optVal === rawInputValue;
var optLabel = (0, _lang.isUndefined)(elementValue) || (0, _lang.isNull)(elementValue) ? _i18next2.default.t(unSelectedLabel) : _i18next2.default.t(elementValue);
return _react2.default.createElement(
'li',
{ key: idx, className: 'mdl-menu__item', 'data-selected': isSelected, 'data-val': optVal, onClick: function onClick() {
return _this2._handleSelectChange(val, optVal);
} },
optLabel
);
});
};
/**
* @inheritdoc
* @override
*/
Select.prototype.render = function render() {
var _props = this.props,
autoFocus = _props.autoFocus,
error = _props.error,
labelKey = _props.labelKey,
name = _props.name,
placeholder = _props.placeholder,
hasUndefined = _props.hasUndefined,
style = _props.style,
rawInputValue = _props.rawInputValue,
valueKey = _props.valueKey,
disabled = _props.disabled,
onChange = _props.onChange,
index = _props.index,
size = _props.size,
valid = _props.valid,
unSelectedLabel = _props.unSelectedLabel,
defaultValue = _props.defaultValue;
var selectProps = { autoFocus: autoFocus, disabled: disabled, size: size };
var currentValue = (0, _find2.default)(this.props.values, function (o) {
return o[valueKey] === rawInputValue;
}) || {};
var currentLabel = rawInputValue ? _i18next2.default.t(currentValue[labelKey]) : _i18next2.default.t(unSelectedLabel);
var currentDataVal = rawInputValue ? _i18next2.default.t(currentValue[labelKey]) : _i18next2.default.t(unSelectedLabel);
var cssClass = 'mdl-textfield mdl-js-textfield' + (!valid ? ' is-invalid' : '');
return _react2.default.createElement(
'div',
{ 'data-focus': 'select-mdl', ref: 'select', className: cssClass + ' getmdl-select', 'data-valid': !error, style: style },
_react2.default.createElement('input', _extends({ placeholder: placeholder, className: 'mdl-textfield__input', value: currentLabel, type: 'text', id: index ? '' + name + index : '' + name, name: index ? '' + name + index : '' + name, readOnly: true, tabIndex: index, 'data-val': currentDataVal, ref: 'htmlSelect' }, selectProps)),
!disabled && _react2.default.createElement(
'label',
{ htmlFor: index ? '' + name + index : '' + name },
_react2.default.createElement(
'i',
{ className: 'mdl-icon-toggle__label material-icons' },
'keyboard_arrow_down'
)
),
!disabled && _react2.default.createElement(
'ul',
{ className: 'mdl-menu mdl-js-menu', htmlFor: index ? '' + name + index : '' + name, ref: 'selectMenu' },
this._renderOptions(_extends({}, this.props, { currentValue: currentValue }))
),
!valid && _react2.default.createElement(
'span',
{ className: 'mdl-textfield__error', ref: 'error' },
_i18next2.default.t(error)
)
);
};
return Select;
}(_react.PureComponent);
Select.displayName = 'Select';
Select.defaultProps = {
disabled: false,
error: 'input.select-mdl.error.default',
hasUndefined: true,
isActiveProperty: 'isActive',
isRequired: false,
labelKey: 'label',
unSelectedLabel: 'select.unSelected',
valid: true,
values: [],
valueKey: 'code',
valueParser: _valueParser
};
Select.propTypes = {
defaultValue: _react.PropTypes.object,
disabled: _react.PropTypes.bool,
error: _react.PropTypes.string,
hasUndefined: _react.PropTypes.bool,
isActiveProperty: _react.PropTypes.string,
isRequired: _react.PropTypes.bool,
labelKey: _react.PropTypes.string,
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
};
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","returnValue","type","props","Select","getValue","rawInputValue","_handleSelectChange","val","value","onChange","valueParser","findDOMNode","refs","parentNode","classList","remove","call","componentDidMount","selectMenu","componentHandler","upgradeElement","_renderOptions","defaultValue","labelKey","hasUndefined","currentValue","isRequired","values","valueKey","isActiveProperty","unSelectedLabel","t","filter","v","map","idx","optVal","elementValue","isSelected","optLabel","render","autoFocus","error","name","placeholder","style","disabled","index","size","valid","selectProps","o","currentLabel","currentDataVal","cssClass","displayName","defaultProps","propTypes","object","bool","string","func","oneOfType","number","array"],"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 find from 'lodash/find';\r\nimport {isUndefined, isNull, isNumber} from 'lodash/lang';\r\nimport union from 'lodash/union';\r\n\r\nconst UNSELECTED_KEY = 'UNSELECTED_KEY';\r\n\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    const returnValue = rawValue ? rawValue : propsValue\r\n    if(UNSELECTED_KEY === rawValue) {\r\n        return null;\r\n    }\r\n    const {type} = this.props;\r\n    return type === 'number' ? +returnValue : returnValue;\r\n}\r\n\r\n\r\n/**\r\n* Component standing for an HTML input.\r\n* https://github.com/CreativeIT/getmdl-select/\r\n*/\r\nclass Select extends PureComponent {\r\n    componentDidMount() {\r\n        const selectMenu = ReactDOM.findDOMNode(this.refs[\"selectMenu\"]);\r\n        componentHandler.upgradeElement(selectMenu);\r\n    }\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 = (val, value) => {\r\n        const {onChange, valueParser, rawInputValue} = this.props;\r\n        ReactDOM.findDOMNode(this.refs[\"selectMenu\"]).parentNode.classList.remove('is-visible');\r\n        return onChange(valueParser.call(this, rawInputValue, value));\r\n    };\r\n\r\n    /** inheritdoc */\r\n    _renderOptions({defaultValue, labelKey, hasUndefined, currentValue, isRequired, rawInputValue, values = [], valueKey, isActiveProperty, unSelectedLabel}) {\r\n        values = hasUndefined  ? union([{[labelKey]: i18next.t(unSelectedLabel), [valueKey]: UNSELECTED_KEY}], this.props.values) : values;\r\n        return values.filter(v => isUndefined(v[isActiveProperty]) || v[isActiveProperty] === true) // Filter on the active value only\r\n        .map((val, idx) => {\r\n            const optVal = `${val[valueKey]}`;\r\n            const elementValue = val[labelKey];\r\n            const isSelected = optVal === rawInputValue;\r\n            const optLabel = isUndefined(elementValue) || isNull(elementValue) ? i18next.t(unSelectedLabel) : i18next.t(elementValue);\r\n            return (\r\n                <li key={idx} className='mdl-menu__item' data-selected={isSelected} data-val={optVal} onClick={() => this._handleSelectChange(val, optVal)}>{optLabel}</li>\r\n            );\r\n        });\r\n    }\r\n\r\n    /**\r\n    * @inheritdoc\r\n    * @override\r\n    */\r\n    render() {\r\n        const { autoFocus, error, labelKey, name, placeholder, hasUndefined, style, rawInputValue, valueKey, disabled, onChange,index, size, valid, unSelectedLabel, defaultValue } = this.props;\r\n        const selectProps = { autoFocus, disabled, size };\r\n        const currentValue = find(this.props.values, (o) => o[valueKey] === rawInputValue) || {};\r\n        const currentLabel = rawInputValue ? i18next.t(currentValue[labelKey]) : i18next.t(unSelectedLabel)\r\n        const currentDataVal = rawInputValue ? i18next.t(currentValue[labelKey]) : i18next.t(unSelectedLabel)\r\n        const cssClass = `mdl-textfield mdl-js-textfield${!valid ? ' is-invalid' : ''}`;\r\n        return (\r\n            <div data-focus='select-mdl' ref='select' className={`${cssClass} getmdl-select`} data-valid={!error} style={style}>\r\n                <input placeholder={placeholder} className='mdl-textfield__input' value={currentLabel} type='text' id={index ? `${name}${index}`:`${name}`} name={index ? `${name}${index}`:`${name}`} readOnly tabIndex={index} data-val={currentDataVal} ref='htmlSelect' {...selectProps} />\r\n                {!disabled &&\r\n                    <label htmlFor={index ? `${name}${index}`:`${name}`}>\r\n                        <i className='mdl-icon-toggle__label material-icons'>keyboard_arrow_down</i>\r\n                    </label>\r\n                }\r\n                {!disabled &&\r\n                    <ul className='mdl-menu mdl-js-menu' htmlFor={index ? `${name}${index}`:`${name}`} ref='selectMenu'>\r\n                        {this._renderOptions({...this.props, currentValue})}\r\n                    </ul>\r\n                }\r\n                {!valid && <span className='mdl-textfield__error' ref='error'>{i18next.t(error)}</span>}\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nSelect.displayName = 'Select';\r\nSelect.defaultProps = {\r\n    disabled: false,\r\n    error: 'input.select-mdl.error.default',\r\n    hasUndefined: true,\r\n    isActiveProperty: 'isActive',\r\n    isRequired: false,\r\n    labelKey: 'label',\r\n    unSelectedLabel: 'select.unSelected',\r\n    valid: true,\r\n    values: [],\r\n    valueKey: 'code',\r\n    valueParser: _valueParser\r\n};\r\nSelect.propTypes = {\r\n    defaultValue: PropTypes.object,\r\n    disabled: PropTypes.bool,\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    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\n\r\nexport default Select;\r\n"]}