UNPKG

focus-components-v3

Version:

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

291 lines (227 loc) 28.1 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 _dec, _class; 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 _material = require('../behaviours/material'); var _material2 = _interopRequireDefault(_material); var _inputComponent = require('../behaviours/input-component'); var _debounce = require('lodash/debounce'); var _debounce2 = _interopRequireDefault(_debounce); 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 _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); } var AutocompleteTextEdit = (_dec = (0, _material2.default)('materialInput'), _dec(_class = (0, _inputComponent.InputBehaviour)(_class = function (_Component) { _inherits(AutocompleteTextEdit, _Component); function AutocompleteTextEdit(props) { _classCallCheck(this, AutocompleteTextEdit); var _this = _possibleConstructorReturn(this, _Component.call(this, props)); _this.getValue = function () { var inputValue = _this.state.inputValue; if (inputValue !== undefined) { return inputValue; } else { return null; } }; _this._querySearcher = function (value) { var querySearcher = _this.props.querySearcher; var hasSuggestions = _this.state.hasSuggestions; querySearcher(value).then(function (_ref) { var data = _ref.data, totalCount = _ref.totalCount; if (totalCount > 0) { _this.setState({ hasSuggestions: true, suggestions: data, error: '' }); } _this.refs.loader.classList.remove('mdl-progress__indeterminate'); _this.setState({ isLoading: false }); }).catch(function (err) { _this.refs.loader.classList.remove('mdl-progress__indeterminate'); _this.setState({ error: JSON.stringify(err), isLoading: false }); _this.refs.materialInput.classList.add('is-invalid'); }); }; _this._handleonChange = function (_ref2) { var value = _ref2.target.value; var onChange = _this.props.onChange; _this.setState({ inputValue: value }); if (value.trim() == '') { _this.setState({ hasSuggestions: false }); } else { _this.refs.loader.classList.add('mdl-progress__indeterminate'); _this.setState({ isLoading: true }); _this._debouncedQuerySearcher(value); if (onChange) onChange(value); } }; _this.renderSuggestions = function () { var suggestions = _this.state.suggestions; var allSuggestions = suggestions.map(function (_ref3) { var key = _ref3.key, label = _ref3.label; return _react2.default.createElement( 'li', { key: key, onMouseDown: function onMouseDown(e) { _this.onResultClick(label);e.preventDefault(); }, 'data-focus': 'option' }, label ); }); return _react2.default.createElement( 'ul', { ref: 'suggestions', 'data-focus': 'options' }, allSuggestions ); }; _this._handleonFocus = function (e) { var _this$state = _this.state, hasSuggestions = _this$state.hasSuggestions, hasFocus = _this$state.hasFocus; var _this$props = _this.props, showAtFocus = _this$props.showAtFocus, emptyShowAll = _this$props.emptyShowAll; _this.setState({ hasFocus: !_this.state.hasFocus }); if (hasSuggestions && !showAtFocus && hasFocus === false) { _this.setState({ hasSuggestions: false }); } if (!hasSuggestions && e.target.value.trim() === '' && emptyShowAll && hasFocus === false) { // Doing a global search here _this._querySearcher(''); } return true; }; _this.state = { inputValue: _this.props.rawInputValue, suggestions: [], hasSuggestions: false, error: _this.props.error, hasFocus: false, isLoading: false }; return _this; } AutocompleteTextEdit.prototype.componentWillReceiveProps = function componentWillReceiveProps(_ref4) { var error = _ref4.error; if (error) { this.setState({ error: error }); } }; AutocompleteTextEdit.prototype.componentDidMount = function componentDidMount() { var inputTimeout = this.props.inputTimeout; this._debouncedQuerySearcher = (0, _debounce2.default)(this._querySearcher, inputTimeout); }; // Returns the state's inputValue // Gets the defined props' querySearch and returns the object given by the promise // Sets the hasSuggestions' state if the given object has a none empty array // Sets the state's inputValue when the user is typing // Sets the value input with the selected suggestion and hides the dropdown AutocompleteTextEdit.prototype.onResultClick = function onResultClick(value) { var onChange = this.props.onChange; this.refs.inputText.value = value; this.setState({ inputValue: value, hasSuggestions: false, suggestions: [] }); if (onChange) onChange(value); return value; }; // Returns an html list whith the Suggestions // Behaviour when onFocus and onBlur are triggered // Maybe give the option for the floating label AutocompleteTextEdit.prototype.render = function render() { var _state = this.state, inputValue = _state.inputValue, hasSuggestions = _state.hasSuggestions, hasFocus = _state.hasFocus, isLoading = _state.isLoading; var validInputProps = this._checkProps(this.props); var _props = this.props, inputTimeout = _props.inputTimeout, error = _props.error, placeholder = _props.placeholder; validInputProps.value = inputValue === undefined || inputValue === null ? '' : inputValue; validInputProps.onBlur = this._handleonFocus; var inputProps = _extends({}, validInputProps); return _react2.default.createElement( 'div', { 'data-focus': 'autocompleteText' }, _react2.default.createElement( 'div', { className: 'mdl-textfield mdl-js-textfield' + (error ? ' is-invalid' : ''), ref: 'materialInput' }, _react2.default.createElement('div', { 'data-focus': 'loading', 'data-loading': isLoading, className: 'mdl-progress mdl-js-progress', ref: 'loader' }), _react2.default.createElement('input', _extends({ className: 'mdl-textfield__input', type: 'text', ref: 'inputText' }, inputProps)), _react2.default.createElement( 'label', { className: 'mdl-textfield__label' }, _i18next2.default.t(placeholder) ), _react2.default.createElement( 'span', { className: 'mdl-textfield__error', ref: 'errorMessage' }, _i18next2.default.t(error) ) ), hasSuggestions && hasFocus && this.renderSuggestions() ); }; return AutocompleteTextEdit; }(_react.Component)) || _class) || _class); AutocompleteTextEdit.displayName = 'AutocompleteTextEdit'; AutocompleteTextEdit.defaultProps = { emptyShowAll: false, inputTimeout: 200, placeholder: 'Search here...', showAtFocus: false }; AutocompleteTextEdit.propTypes = { emptyShowAll: _react.PropTypes.bool, //Defines if it shows suggestions on focus when the input is empty. error: _react.PropTypes.string, //Error showed message. inputTimeout: _react.PropTypes.number.isRequired, //Timeout to execute the debounce function. onChange: _react.PropTypes.func, //Launches the querySearcher. placeholder: _react.PropTypes.string, //Placeholder field. querySearcher: _react.PropTypes.func.isRequired, //Returns a promise which is connected to the web service. rawInputValue: _react.PropTypes.string, //Field value. showAtFocus: _react.PropTypes.bool //Defines it shows suggestions on focus. }; exports.default = AutocompleteTextEdit; /* EXAMPLE const _querySearcher = query => { let data = [ { key: 'JL', label: 'Joh Lickeur' }, { key: 'GK', label: 'Guénolé Kikabou' }, { key: 'YL', label: 'Yannick Lounivis' } ]; return new Promise((resolve, reject) => { setTimeout(() => { resolve({ data, totalCount: data.length }); }, 500); }); }; <AutocompleteText isEdit={isEdit} querySearcher={_querySearcher} placeholder={'Your search...'} error{Something wrong happend. Retry please...} /> */ module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["fr-FR.js"],"names":["AutocompleteTextEdit","props","getValue","inputValue","state","undefined","_querySearcher","querySearcher","hasSuggestions","value","then","data","totalCount","setState","suggestions","error","refs","loader","classList","remove","isLoading","catch","JSON","stringify","err","materialInput","add","_handleonChange","target","onChange","trim","_debouncedQuerySearcher","renderSuggestions","allSuggestions","map","key","label","e","onResultClick","preventDefault","_handleonFocus","hasFocus","showAtFocus","emptyShowAll","rawInputValue","componentWillReceiveProps","componentDidMount","inputTimeout","inputText","render","validInputProps","_checkProps","placeholder","onBlur","inputProps","t","displayName","defaultProps","propTypes","bool","string","number","isRequired","func"],"mappings":"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","file":"fr-FR.js","sourcesContent":["import React, {Component, PropTypes} from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport i18next from 'i18next';\r\nimport MDBehaviour from '../behaviours/material';\r\nimport {InputBehaviour} from '../behaviours/input-component';\r\nimport debounce from 'lodash/debounce';\r\n\r\n@MDBehaviour('materialInput')\r\n@InputBehaviour\r\nclass AutocompleteTextEdit extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n        this.state = {\r\n            inputValue: this.props.rawInputValue,\r\n            suggestions: [],\r\n            hasSuggestions: false,\r\n            error: this.props.error,\r\n            hasFocus: false,\r\n            isLoading: false\r\n        };\r\n    }\r\n\r\n    componentWillReceiveProps({error}) {\r\n        if(error) {\r\n            this.setState({error: error});\r\n        }\r\n    }\r\n\r\n    componentDidMount() {\r\n        const {inputTimeout} = this.props;\r\n        this._debouncedQuerySearcher = debounce(this._querySearcher, inputTimeout);\r\n    }\r\n\r\n    // Returns the state's inputValue\r\n    getValue = () =>  {\r\n        const {inputValue} = this.state;\r\n        if(inputValue !== undefined) {\r\n            return inputValue;\r\n        }\r\n        else {\r\n            return null;\r\n        }\r\n    };\r\n\r\n    // Gets the defined props' querySearch and returns the object given by the promise\r\n    // Sets the hasSuggestions' state if the given object has a none empty array\r\n    _querySearcher = value => {\r\n        const {querySearcher} = this.props;\r\n        const {hasSuggestions} = this.state;\r\n\r\n        querySearcher(value).then(({data, totalCount}) => {\r\n            if(totalCount > 0) {\r\n                this.setState({hasSuggestions: true, suggestions: data, error: ''});\r\n            }\r\n            this.refs.loader.classList.remove('mdl-progress__indeterminate');\r\n            this.setState({isLoading: false});\r\n        }).catch(err => {\r\n            this.refs.loader.classList.remove('mdl-progress__indeterminate');\r\n            this.setState({error: JSON.stringify(err), isLoading: false});\r\n            this.refs.materialInput.classList.add('is-invalid');\r\n        });\r\n    };\r\n\r\n    // Sets the state's inputValue when the user is typing\r\n    _handleonChange = ({target: {value}}) => {\r\n        const {onChange} = this.props;\r\n        this.setState({inputValue: value});\r\n        if(value.trim() == '') {\r\n            this.setState({hasSuggestions: false});\r\n        }\r\n        else {\r\n            this.refs.loader.classList.add('mdl-progress__indeterminate');\r\n            this.setState({isLoading: true});\r\n            this._debouncedQuerySearcher(value);\r\n            if (onChange) onChange(value);\r\n        }\r\n    };\r\n\r\n    // Sets the value input with the selected suggestion and hides the dropdown\r\n    onResultClick(value) {\r\n        const {onChange} = this.props;\r\n        this.refs.inputText.value = value;\r\n        this.setState({inputValue: value, hasSuggestions: false, suggestions: []});\r\n        if (onChange) onChange(value);\r\n        return value;\r\n    };\r\n\r\n    // Returns an html list whith the Suggestions\r\n    renderSuggestions = () => {\r\n        const {suggestions} = this.state;\r\n        const allSuggestions = suggestions.map(({key, label}) => <li key={key} onMouseDown={(e) => {this.onResultClick(label); e.preventDefault();}} data-focus='option' >{label}</li>);\r\n        return(\r\n            <ul ref='suggestions' data-focus='options'>\r\n                {allSuggestions}\r\n            </ul>\r\n        );\r\n    };\r\n\r\n    // Behaviour when onFocus and onBlur are triggered\r\n    _handleonFocus = e => {\r\n        const {hasSuggestions, hasFocus} = this.state;\r\n        const {showAtFocus, emptyShowAll} = this.props;\r\n        this.setState({hasFocus: !this.state.hasFocus});\r\n        if(hasSuggestions && !showAtFocus && hasFocus === false) {\r\n            this.setState({hasSuggestions: false});\r\n        }\r\n\r\n        if(!hasSuggestions && e.target.value.trim() === '' && emptyShowAll && hasFocus === false) {\r\n            // Doing a global search here\r\n            this._querySearcher('');\r\n        }\r\n        return true;\r\n    };\r\n\r\n    // Maybe give the option for the floating label\r\n    render() {\r\n        const {inputValue, hasSuggestions, hasFocus, isLoading} = this.state;\r\n\r\n        const validInputProps = this._checkProps(this.props);\r\n\r\n        const {inputTimeout, error, placeholder} = this.props;\r\n\r\n        validInputProps.value = inputValue === undefined || inputValue === null  ? '' : inputValue;\r\n        validInputProps.onBlur = this._handleonFocus;\r\n        const inputProps = {...validInputProps};\r\n        return(\r\n            <div data-focus='autocompleteText'>\r\n                <div className={`mdl-textfield mdl-js-textfield${error ? ' is-invalid' : ''}`} ref='materialInput'>\r\n                    <div data-focus='loading' data-loading={isLoading} className='mdl-progress mdl-js-progress' ref='loader'/>\r\n                    <input className='mdl-textfield__input' type='text' ref='inputText' {...inputProps}/>\r\n                    <label className=\"mdl-textfield__label\">{i18next.t(placeholder)}</label>\r\n                    <span className=\"mdl-textfield__error\" ref='errorMessage'>{i18next.t(error)}</span>\r\n                </div>\r\n                {hasSuggestions && hasFocus &&\r\n                    this.renderSuggestions()\r\n                }\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nAutocompleteTextEdit.displayName = 'AutocompleteTextEdit';\r\nAutocompleteTextEdit.defaultProps = {\r\n    emptyShowAll: false,\r\n    inputTimeout: 200,\r\n    placeholder: 'Search here...',\r\n    showAtFocus: false\r\n};\r\nAutocompleteTextEdit.propTypes = {\r\n    emptyShowAll: PropTypes.bool, //Defines if it shows suggestions on focus when the input is empty.\r\n    error: PropTypes.string, //Error showed message.\r\n    inputTimeout : PropTypes.number.isRequired, //Timeout to execute the debounce function.\r\n    onChange: PropTypes.func, //Launches the querySearcher.\r\n    placeholder: PropTypes.string, //Placeholder field.\r\n    querySearcher: PropTypes.func.isRequired, //Returns a promise which is connected to the web service.\r\n    rawInputValue: PropTypes.string, //Field value.\r\n    showAtFocus: PropTypes.bool //Defines it shows suggestions on focus.\r\n};\r\nexport default AutocompleteTextEdit;\r\n\r\n\r\n/*\r\nEXAMPLE\r\nconst _querySearcher = query => {\r\nlet data = [\r\n{\r\nkey: 'JL',\r\nlabel: 'Joh Lickeur'\r\n},\r\n{\r\nkey: 'GK',\r\nlabel: 'Guénolé Kikabou'\r\n},\r\n{\r\nkey: 'YL',\r\nlabel: 'Yannick Lounivis'\r\n}\r\n];\r\nreturn new Promise((resolve, reject) => {\r\nsetTimeout(() => {\r\nresolve({\r\ndata,\r\ntotalCount: data.length\r\n});\r\n}, 500);\r\n});\r\n};\r\n\r\n<AutocompleteText\r\nisEdit={isEdit}\r\nquerySearcher={_querySearcher}\r\nplaceholder={'Your search...'}\r\nerror{Something wrong happend. Retry please...}\r\n/>\r\n*/\r\n"]}