@gfpacheco/redux-form-material-ui
Version:
An adapter between Redux Form and Material UI components
54 lines (41 loc) • 2.4 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
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 _AutoComplete = require('material-ui/AutoComplete');
var _AutoComplete2 = _interopRequireDefault(_AutoComplete);
var _createComponent = require('./createComponent');
var _createComponent2 = _interopRequireDefault(_createComponent);
var _mapError = require('./mapError');
var _mapError2 = _interopRequireDefault(_mapError);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
exports.default = (0, _createComponent2.default)(_AutoComplete2.default, function (_ref) {
var _ref$input = _ref.input,
onChange = _ref$input.onChange,
value = _ref$input.value,
_onNewRequest = _ref.onNewRequest,
dataSourceConfig = _ref.dataSourceConfig,
dataSource = _ref.dataSource,
props = _objectWithoutProperties(_ref, ['input', 'onNewRequest', 'dataSourceConfig', 'dataSource']);
return _extends({}, (0, _mapError2.default)(props), {
dataSourceConfig: dataSourceConfig,
dataSource: dataSource,
searchText: dataSourceConfig && dataSource ? (dataSource.find(function (item) {
return item[dataSourceConfig.value] === value;
}) || {})[dataSourceConfig.text] : value,
onNewRequest: function onNewRequest(value) {
onChange((typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object' && dataSourceConfig ? value[dataSourceConfig.value] : value);
if (_onNewRequest) {
_onNewRequest(value);
}
},
onUpdateInput: function onUpdateInput(value) {
if (!dataSourceConfig) {
onChange(value);
}
}
});
});