UNPKG

focus-components-v3

Version:

Focus web components to build applications (based on Material Design)

215 lines (172 loc) 20.7 kB
'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":";;;;;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;AACA;;;;;;;;;;;;;;+eALA;;;AAMA,IAAMA,iBAAiB,gBAAvB;AACA;;;;;;AAMA,SAASC,YAAT,CAAsBC,UAAtB,EAAkCC,QAAlC,EAA4C;AACxC,QAAGH,mBAAmBG,QAAtB,EAAgC;AAC5B,eAAOC,SAAP;AACH;AAHuC,QAIjCC,IAJiC,GAIzB,KAAKC,KAJoB,CAIjCD,IAJiC;;AAKxC,WAAOA,SAAS,QAAT,GAAoB,CAACF,QAArB,GAAgCA,QAAvC;AACH;;AAGD;;;;IAGMI,M;cAAAA,M;;aAAAA,M;;;8BAAAA,M;;;;;;wJAMFC,Q,GAAW,YAAM;AAAA,8BACiB,MAAKF,KADtB;AAAA,gBACND,IADM,eACNA,IADM;AAAA,gBACAI,aADA,eACAA,aADA;;AAEb,gBAAI,kBAAOA,aAAP,KAAyB,uBAAYA,aAAZ,CAAzB,IAAuDT,mBAAmBS,aAA9E,EAA6F,OAAO,IAAP;AAC7F,mBAAOJ,SAAS,QAAT,GAAoB,CAACI,aAArB,GAAqCA,aAA5C;AACH,S,QAODC,mB,GAAsB,UAACC,GAAD,EAAS;AAAA,+BACoB,MAAKL,KADzB;AAAA,gBACpBM,QADoB,gBACpBA,QADoB;AAAA,gBACVC,WADU,gBACVA,WADU;AAAA,gBACGJ,aADH,gBACGA,aADH;AAAA,gBAEpBK,KAFoB,GAEXH,IAAII,MAFO,CAEpBD,KAFoB;;AAG3B,mBAAOF,SAASC,YAAYG,IAAZ,QAAuBP,aAAvB,EAAsCK,KAAtC,CAAT,CAAP;AACH,S;;;AAnBD;;;;;;AAUA;;;;;;;AAWA;AAvBEP,U,WAwBFU,c,iCAA8HC,Y,EAAc;AAAA,YAA5HC,YAA4H,QAA5HA,YAA4H;AAAA,YAA9GC,QAA8G,QAA9GA,QAA8G;AAAA,YAApGC,UAAoG,QAApGA,UAAoG;AAAA,YAAxFZ,aAAwF,QAAxFA,aAAwF;AAAA,+BAAzEa,MAAyE;AAAA,YAAzEA,MAAyE,+BAAhE,EAAgE;AAAA,YAA5DC,QAA4D,QAA5DA,QAA4D;AAAA,YAAlDC,gBAAkD,QAAlDA,gBAAkD;AAAA,YAAhCC,eAAgC,QAAhCA,eAAgC;;AACxI,YAAMC,uBAAuBL,eAAe,uBAAYZ,aAAZ,KAA8B,kBAAOA,aAAP,CAA7C,CAA7B;AACA,YAAGU,gBAAgBO,oBAAnB,EAAyC;AAAA;;AACrCJ,qBAAS,qBACL,qCAAGF,QAAH,EAAc,kBAAQO,CAAR,CAAUF,eAAV,CAAd,0BAA2CF,QAA3C,EAAsDvB,cAAtD,UADK,EAELsB,MAFK,CAAT;AAIH;AACD,eAAOA,OACNM,MADM,CACC;AAAA,mBAAK,uBAAYC,EAAEL,gBAAF,CAAZ,KAAoCK,EAAEL,gBAAF,MAAwB,IAAjE;AAAA,SADD,EACwE;AADxE,SAENM,GAFM,CAEF,UAACC,GAAD,EAAMC,GAAN,EAAc;AACf,gBAAMC,cAAYF,IAAIR,QAAJ,CAAlB;AACA,gBAAMW,eAAeH,IAAIX,QAAJ,CAArB;AACA,gBAAMe,WAAW,uBAAYD,YAAZ,KAA6B,kBAAOA,YAAP,CAA7B,GAAoD,kBAAQP,CAAR,CAAU,uCAAV,CAApD,GAAyGO,YAA1H;AACA,mBAAQ;AAAA;AAAA,kBAAQ,KAAKF,GAAb,EAAkB,OAAOC,MAAzB,EAAiC,UAAUF,IAAIK,cAA/C;AAAgED;AAAhE,aAAR;AACH,SAPM,CAAP;AAQH,K;;AAED;;;;;;AA1CE5B,U,WA8CF8B,M,qBAAS;AAAA,qBACoH,KAAK/B,KADzH;AAAA,YACGgC,SADH,UACGA,SADH;AAAA,YACcC,KADd,UACcA,KADd;AAAA,YACqBC,QADrB,UACqBA,QADrB;AAAA,YAC+BC,IAD/B,UAC+BA,IAD/B;AAAA,YACqCC,WADrC,UACqCA,WADrC;AAAA,YACkDC,KADlD,UACkDA,KADlD;AAAA,YACyDlC,aADzD,UACyDA,aADzD;AAAA,YACwEa,MADxE,UACwEA,MADxE;AAAA,YACgFsB,QADhF,UACgFA,QADhF;AAAA,YAC0FhC,QAD1F,UAC0FA,QAD1F;AAAA,YACoGiC,IADpG,UACoGA,IADpG;AAAA,YAC0GC,KAD1G,UAC0GA,KAD1G;;AAEL,YAAMC,cAAc,EAAET,oBAAF,EAAaM,kBAAb,EAAuBJ,kBAAvB,EAAiCK,UAAjC,EAApB;AACA,eACI;AAAA;AAAA,cAAK,cAAW,QAAhB,EAAyB,KAAI,QAA7B,EAAsC,cAAY,CAACN,KAAnD,EAA0D,OAAOI,KAAjE;AACI;AAAA;AAAA,2BAAQ,MAAMF,IAAd,EAAoB,UAAU,KAAK/B,mBAAnC,EAAwD,KAAI,YAA5D,EAAyE,OAAOD,aAAhF,IAAmGsC,WAAnG;AACK,qBAAK9B,cAAL,CAAoB,KAAKX,KAAzB;AADL,aADJ;AAIK,aAACwC,KAAD,IAAU;AAAA;AAAA,kBAAK,WAAU,aAAf,EAA6B,KAAI,OAAjC;AAA0CP;AAA1C;AAJf,SADJ;AAQH,K;;WAzDChC,M;;;AA4DN;;;AACAA,OAAOyC,WAAP,GAAqB,QAArB;AACAzC,OAAO0C,SAAP,GAAmB;AACfL,cAAU,iBAAUM,IADL;AAEfhC,kBAAc,iBAAUiC,MAFT;AAGfZ,WAAO,iBAAUa,MAHF;AAIfjC,kBAAc,iBAAU+B,IAJT;AAKf1B,sBAAkB,iBAAU4B,MALb;AAMf/B,gBAAY,iBAAU6B,IANP;AAOf9B,cAAU,iBAAUgC,MAPL;AAQfZ,cAAU,iBAAUU,IARL;AASfT,UAAM,iBAAUW,MAAV,CAAiB/B,UATR;AAUfT,cAAU,iBAAUyC,IAAV,CAAehC,UAVV;AAWfqB,iBAAa,iBAAUU,MAXR;AAYf3B,qBAAiB,iBAAU2B,MAZZ;AAaf3C,mBAAe,iBAAU6C,SAAV,CAAoB,CAC/B,iBAAUF,MADqB,EAE/B,iBAAUG,MAFqB,CAApB,CAbA;AAiBfT,WAAO,iBAAUI,IAjBF;AAkBf3B,cAAU,iBAAU6B,MAlBL;AAmBf9B,YAAQ,iBAAUkC,KAAV,CAAgBnC;AAnBT,CAAnB;AAqBAd,OAAOkD,YAAP,GAAsB;AAClBb,cAAU,KADQ;AAElBL,WAAO,6CAFW;AAGlBpB,kBAAc,IAHI;AAIlBK,sBAAkB,UAJA;AAKlBH,gBAAY,KALM;AAMlBD,cAAU,OANQ;AAOlBoB,cAAU,KAPQ;AAQlBf,qBAAiB,mBARC;AASlBqB,WAAO,IATW;AAUlBxB,YAAQ,EAVU;AAWlBC,cAAU,MAXQ;AAYlBV,iBAAaZ;AAZK,CAAtB;kBAceM,M","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"]}