UNPKG

react-suggest

Version:

Pure react-based autosuggest with ajax suggestion list population

346 lines (297 loc) 29.5 kB
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'), Autosuggest = require('../../src/Autosuggest.jsx'); var App = React.createClass({displayName: "App", /** * Render the example app */ render: function() { var fixtures = [ ]; return ( React.createElement("div", null, React.createElement(Autosuggest, { fixtures: fixtures, url: "http://gd.geobytes.com/AutoCompleteCity", jsonp: "true", onSuggestSelect: this.onSuggestSelect}) ) ); }, /** * When a suggest got selected * @param {Object} suggest The suggest */ onSuggestSelect: function(suggest) { console.log(suggest); } }); React.render(React.createElement(App, null), document.getElementById('app')); },{"../../src/Autosuggest.jsx":2,"react":undefined}],2:[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":3,"react":undefined,"superagent":undefined,"superagent-jsonp":undefined}],3:[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}]},{},[1]) //# 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/example/src/app.js","/home/haribabuviswanath/react-autosuggest/src/Autosuggest.jsx","/home/haribabuviswanath/react-autosuggest/src/AutosuggestItem.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  Autosuggest = require('../../src/Autosuggest.jsx');\n\nvar App = React.createClass({\n  /**\n   * Render the example app\n   */\n  render: function() {\n    var fixtures = [\n    ];\n\n    return (\n      <div>\n        <Autosuggest\n          fixtures={fixtures}\n          url='http://gd.geobytes.com/AutoCompleteCity'\n          jsonp='true'\n          onSuggestSelect={this.onSuggestSelect} />\n      </div>\n    );\n  },\n\n  /**\n   * When a suggest got selected\n   * @param  {Object} suggest The suggest\n   */\n  onSuggestSelect: function(suggest) {\n    console.log(suggest);\n  }\n});\n\nReact.render(<App />, document.getElementById('app'));\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","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"]}