react-suggest
Version:
Pure react-based autosuggest with ajax suggestion list population
311 lines (268 loc) • 26.8 kB
JavaScript
require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
var React = require('react');
var AutosuggestItem = React.createClass({displayName: "AutosuggestItem",
/**
* Get the default props
* @return {Object} The props
*/
getDefaultProps: function() {
return {
isActive: false,
suggest: {
label: ''
},
onSuggestSelect: function() {}
};
},
/**
* When the element gets clicked
* @param {Event} event The click event
*/
onClick: function(event) {
event.preventDefault();
this.props.onSuggestSelect(this.props.suggest);
},
/**
* Render the view
*/
render: function() {
return (
React.createElement("li", {className: this.getSuggestClasses(),
onClick: this.onClick},
this.props.suggest.label
)
);
},
/**
* The classes for the suggest item
* @return {String} The classes
*/
getSuggestClasses: function() {
var classes = 'autosuggest-item';
classes += this.props.isActive ? ' autosuggest-item--active' : '';
return classes;
}
});
module.exports = AutosuggestItem;
},{"react":undefined}],"Haribabu":[function(require,module,exports){
var React = require('react'),
AutosuggestItem = require('./AutosuggestItem.jsx'),
superagent = require('superagent'),
superagentJSONP = require('superagent-jsonp');
superagentJSONP(superagent);
var Autosuggest = React.createClass({displayName: "Autosuggest",
/**
* Get the default props
* @return {Object} The state
*/
getDefaultProps: function() {
return {
fixtures: [],
placeholder: 'Search',
onSuggestSelect: function() {},
jsonp: 'false',
url:'',
minChars: 3
};
},
/**
* Get the initial state
* @return {Object} The state
*/
getInitialState: function() {
return {
isSuggestsHidden: true,
userInput: '',
activeSuggest: null,
suggests: [],
};
},
/**
* When the input got changed
*/
onInputChange: function() {
var userInput = this.refs.autosuggestInput.getDOMNode().value;
this.props.queryString = userInput;
this.setState({userInput: userInput}, function() {
if (!userInput) {
this.updateSuggests();
}
}.bind(this));
if (!userInput || userInput.length < this.props.minChars) {
return;
}
if(this.props.jsonp === 'true'){
var self = this;
superagent.get(this.props.url)
.query({'q':userInput })
.jsonp()
.end(function(response){
self.updateSuggests(response);
})
}else{
superagent.get(this.props.url)
.query({'q': userInput })
.send()
.end(function(response){
self.updateSuggests(response);
})
}
},
/**
* Update the suggests
* @param {Object} suggestsData The new suggested data
*/
updateSuggests: function(suggestsData) {
if (!suggestsData) {
suggestsData = [];
}
var suggests = [],
regex = new RegExp(this.state.userInput, 'gim'),
suggestItems;
this.props.fixtures.forEach(function(suggest) {
if (suggest.label.match(regex)) {
suggest.placeId = suggest.label;
suggests.push(suggest);
}
}.bind(this));
suggestsData.forEach(function(suggest) {
suggests.push({
label: suggest,
placeId: suggest
});
}.bind(this));
this.setState({suggests: suggests});
},
/**
* When the input gets focused
* @param {Event} event The focus event
*/
showSuggests: function(event) {
this.updateSuggests();
this.setState({isSuggestsHidden: false});
},
/**
* When the input loses focused
* @param {Event} event The focus event
*/
hideSuggests: function(event) {
setTimeout(function() {
this.setState({isSuggestsHidden: true});
}.bind(this), 100);
},
/**
* When a key gets pressed in the input
* @param {Event} event The keypress event
*/
onInputKeyDown: function(event) {
switch (event.which) {
case 40: // DOWN
event.preventDefault();
this.activateSuggest('next');
break;
case 38: // UP
event.preventDefault();
this.activateSuggest('prev');
break;
case 13: // ENTER
this.selectSuggest(this.state.activeSuggest);
break;
case 9: // TAB
this.selectSuggest(this.state.activeSuggest);
break;
case 27: // ESC
this.hideSuggests();
break;
}
},
/**
* Activate a new suggest
* @param {String} direction The direction in which to activate new suggest
*/
activateSuggest: function(direction) {
var suggestsCount = this.state.suggests.length - 1,
next = direction === ('next'),
newActiveSuggest = null,
newIndex = 0,
i = 0;
for (i; i <= suggestsCount; i++) {
if (this.state.suggests[i] === this.state.activeSuggest) {
newIndex = next ? i + 1 : i - 1;
}
}
if (!this.state.activeSuggest) {
newIndex = next ? 0 : suggestsCount;
}
if (newIndex >= 0 && newIndex <= suggestsCount) {
newActiveSuggest = this.state.suggests[newIndex];
}
this.setState({activeSuggest: newActiveSuggest});
},
/**
* When an item got selected
* @param {AutosuggestItem} suggest The selected suggest item
*/
selectSuggest: function(suggest) {
if (!suggest) {
suggest = {
label: this.state.userInput
};
}
this.setState({
isSuggestsHidden: true,
userInput: suggest.label
});
},
/**
* Render the view
*/
render: function() {
return (
React.createElement("div", {className: "autosuggest", onClick: this.onClick},
React.createElement("input", {
className: "autosuggest__input",
ref: "autosuggestInput",
type: "text",
value: this.state.userInput,
placeholder: this.props.placeholder,
onKeyDown: this.onInputKeyDown,
onChange: this.onInputChange,
onFocus: this.showSuggests,
onBlur: this.hideSuggests}),
React.createElement("ul", {className: this.getSuggestsClasses()},
this.getSuggestItems()
)
)
);
},
/**
* Get the suggest items for the list
* @return {Array} The suggestions
*/
getSuggestItems: function() {
return this.state.suggests.map(function(suggest) {
var isActive = (this.state.activeSuggest &&
suggest.placeId === this.state.activeSuggest.placeId);
return (
React.createElement(AutosuggestItem, {
key: suggest.placeId,
suggest: suggest,
isActive: isActive,
onSuggestSelect: this.selectSuggest})
);
}.bind(this));
},
/**
* The classes for the suggests list
* @return {String} The classes
*/
getSuggestsClasses: function() {
var classes = 'autosuggest__suggests'
classes += this.state.isSuggestsHidden ?
' autosuggest__suggests--hidden' : '';
return classes;
}
});
module.exports = Autosuggest;
},{"./AutosuggestItem.jsx":1,"react":undefined,"superagent":undefined,"superagent-jsonp":undefined}]},{},[])
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/react-component-gulp-tasks/node_modules/browserify/node_modules/browser-pack/_prelude.js","/home/haribabuviswanath/react-autosuggest/src/AutosuggestItem.jsx","/home/haribabuviswanath/react-autosuggest/src/Autosuggest.jsx"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","var React = require('react');\n\nvar AutosuggestItem = React.createClass({\n  /**\n   * Get the default props\n   * @return {Object} The props\n   */\n  getDefaultProps: function() {\n    return {\n      isActive: false,\n      suggest: {\n        label: ''\n      },\n      onSuggestSelect: function() {}\n    };\n  },\n\n  /**\n   * When the element gets clicked\n   * @param  {Event} event The click event\n   */\n  onClick: function(event) {\n    event.preventDefault();\n    this.props.onSuggestSelect(this.props.suggest);\n  },\n\n  /**\n   * Render the view\n   */\n  render: function() {\n    return (\n      <li className={this.getSuggestClasses()}\n        onClick={this.onClick}>\n          {this.props.suggest.label}\n      </li>\n    );\n  },\n\n  /**\n   * The classes for the suggest item\n   * @return {String} The classes\n   */\n  getSuggestClasses: function() {\n    var classes = 'autosuggest-item';\n\n    classes += this.props.isActive ? ' autosuggest-item--active' : '';\n\n    return classes;\n  }\n});\n\nmodule.exports = AutosuggestItem;\n","var React = require('react'),\n  AutosuggestItem = require('./AutosuggestItem.jsx'),\n  superagent = require('superagent'),\n  superagentJSONP = require('superagent-jsonp');\n\nsuperagentJSONP(superagent);\n  \n\nvar Autosuggest = React.createClass({\n  /**\n   * Get the default props\n   * @return {Object} The state\n   */\n  getDefaultProps: function() {\n    return {\n      fixtures: [],\n      placeholder: 'Search',\n      onSuggestSelect: function() {},\n      jsonp: 'false',\n      url:'',\n      minChars: 3\n    };\n  },\n\n  /**\n   * Get the initial state\n   * @return {Object} The state\n   */\n  getInitialState: function() {\n    return {\n      isSuggestsHidden: true,\n      userInput: '',\n      activeSuggest: null,\n      suggests: [],\n    };\n  },\n\n  /**\n   * When the input got changed\n   */\n  onInputChange: function() {\n    var userInput = this.refs.autosuggestInput.getDOMNode().value;\n    this.props.queryString = userInput;\n    this.setState({userInput: userInput}, function() {\n      if (!userInput) {\n        this.updateSuggests();\n      }\n    }.bind(this));\n\n    if (!userInput || userInput.length < this.props.minChars) {\n      return;\n    }\n\n    if(this.props.jsonp === 'true'){\n      var self = this;\n      superagent.get(this.props.url)\n        .query({'q':userInput })\n        .jsonp()\n        .end(function(response){\n          self.updateSuggests(response);\n        })\n    }else{\n       superagent.get(this.props.url)\n        .query({'q': userInput })\n        .send()\n        .end(function(response){\n          self.updateSuggests(response);\n        })\n    }\n  },\n\n  /**\n   * Update the suggests\n   * @param  {Object}  suggestsData The new suggested data\n   */\n  updateSuggests: function(suggestsData) {\n    if (!suggestsData) {\n      suggestsData = [];\n    }\n\n    var suggests = [],\n      regex = new RegExp(this.state.userInput, 'gim'),\n      suggestItems;\n\n    this.props.fixtures.forEach(function(suggest) {\n      if (suggest.label.match(regex)) {\n        suggest.placeId = suggest.label;\n        suggests.push(suggest);\n      }\n    }.bind(this));\n\n    suggestsData.forEach(function(suggest) {\n      suggests.push({\n        label: suggest,\n        placeId: suggest\n      });\n    }.bind(this));\n\n    this.setState({suggests: suggests});\n  },\n\n  /**\n   * When the input gets focused\n   * @param  {Event} event The focus event\n   */\n  showSuggests: function(event) {\n    this.updateSuggests();\n\n    this.setState({isSuggestsHidden: false});\n  },\n\n  /**\n   * When the input loses focused\n   * @param  {Event} event The focus event\n   */\n  hideSuggests: function(event) {\n    setTimeout(function() {\n      this.setState({isSuggestsHidden: true});\n    }.bind(this), 100);\n  },\n\n  /**\n   * When a key gets pressed in the input\n   * @param  {Event} event The keypress event\n   */\n  onInputKeyDown: function(event) {\n    switch (event.which) {\n      case 40: // DOWN\n        event.preventDefault();\n        this.activateSuggest('next');\n        break;\n      case 38: // UP\n        event.preventDefault();\n        this.activateSuggest('prev');\n        break;\n      case 13: // ENTER\n        this.selectSuggest(this.state.activeSuggest);\n        break;\n      case 9: // TAB\n        this.selectSuggest(this.state.activeSuggest);\n        break;\n      case 27: // ESC\n        this.hideSuggests();\n        break;\n    }\n  },\n\n  /**\n   * Activate a new suggest\n   * @param {String} direction The direction in which to activate new suggest\n   */\n  activateSuggest: function(direction) {\n    var suggestsCount = this.state.suggests.length - 1,\n      next = direction === ('next'),\n      newActiveSuggest = null,\n      newIndex = 0,\n      i = 0;\n\n    for (i; i <= suggestsCount; i++) {\n      if (this.state.suggests[i] === this.state.activeSuggest) {\n        newIndex = next ? i + 1 : i - 1;\n      }\n    }\n\n    if (!this.state.activeSuggest) {\n      newIndex = next ? 0 : suggestsCount;\n    }\n\n    if (newIndex >= 0 && newIndex <= suggestsCount) {\n      newActiveSuggest = this.state.suggests[newIndex];\n    }\n\n    this.setState({activeSuggest: newActiveSuggest});\n  },\n\n  /**\n   * When an item got selected\n   * @param {AutosuggestItem} suggest The selected suggest item\n   */\n  selectSuggest: function(suggest) {\n    if (!suggest) {\n      suggest = {\n        label: this.state.userInput\n      };\n    }\n\n    this.setState({\n      isSuggestsHidden: true,\n      userInput: suggest.label\n    });\n  },\n\n\n  /**\n   * Render the view\n   */\n  render: function() {\n    return (\n      <div className=\"autosuggest\" onClick={this.onClick}>\n        <input\n          className=\"autosuggest__input\"\n          ref=\"autosuggestInput\"\n          type=\"text\"\n          value={this.state.userInput}\n          placeholder={this.props.placeholder}\n          onKeyDown={this.onInputKeyDown}\n          onChange={this.onInputChange}\n          onFocus={this.showSuggests}\n          onBlur={this.hideSuggests} />\n        <ul className={this.getSuggestsClasses()}>\n          {this.getSuggestItems()}\n        </ul>\n      </div>\n    );\n  },\n\n  /**\n   * Get the suggest items for the list\n   * @return {Array} The suggestions\n   */\n  getSuggestItems: function() {\n    return this.state.suggests.map(function(suggest) {\n      var isActive = (this.state.activeSuggest &&\n        suggest.placeId === this.state.activeSuggest.placeId);\n\n      return (\n        <AutosuggestItem\n          key={suggest.placeId}\n          suggest={suggest}\n          isActive={isActive}\n          onSuggestSelect={this.selectSuggest} />\n      );\n    }.bind(this));\n  },\n\n  /**\n   * The classes for the suggests list\n   * @return {String} The classes\n   */\n  getSuggestsClasses: function() {\n    var classes = 'autosuggest__suggests'\n\n    classes += this.state.isSuggestsHidden ?\n      ' autosuggest__suggests--hidden' : '';\n\n    return classes;\n  }\n});\n\nmodule.exports = Autosuggest;\n"]}