focus-components-v3
Version:
Focus web components to build applications (based on Material Design)
291 lines (227 loc) • 28.1 kB
JavaScript
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"]}
;