[
  {
    "path": ".github/ISSUE_TEMPLATE.md",
    "content": "<!---\nPlease read our Contributing Guidelines before opening this issue: https://github.com/harvesthq/chosen/blob/master/contributing.md\n\nSpecifically, please note that the issue tracker is intended for bug reports and specific feature requests.\n\nIf you have a general support or usage question, please post somewhere like StackOverflow using the `jquery-chosen` tag: http://stackoverflow.com/questions/tagged/jquery-chosen — you'll be much more likely to get a quick answer there.\n-->\n\nSummarize your issue here.\n\n### Steps to reproduce\n\nTell us how to reproduce this issue.\n\n  1. This is the first step\n\n  2. This is the second step\n\n  3. Further steps, etc.\n\nAdditionally, please link to a working demo that shows the issue so we can attempt to reproduce.  You can use [this template](https://jsfiddle.net/j7k727cp/) as a base.  Alternatively, confirm that the [Chosen demo page](http://harvesthq.github.io/chosen/) shows the issue.\n\n\n### Expected behavior\n\nTell us what should happen.\n\n\n### Actual behavior\n\nTell us what happens instead.\n\n\n### Environment\n\n  - **Chosen Version**:\n\n  - **jQuery or Prototype Version**:\n\n  - **Browser and Version**:\n\n  - **OS and Version**:\n\n\n### Additional information\n\nAny other information you want to share that is relevant to the issue being reported. This might include the lines of code that you have identified as causing the bug, or potential solutions and workarounds.\n"
  },
  {
    "path": ".github/PULL_REQUEST_TEMPLATE.md",
    "content": "<!---\nGood pull requests — patches, improvements, new features — are a fantastic help.  They should remain focused in scope and avoid containing unrelated commits.\n\nPlease review the Pull Requests section of our Contributing Guidelines before submitting your work: https://github.com/harvesthq/chosen/blob/master/contributing.md#pull-requests\n-->\n\n### Summary\n\nProvide a general description of the code changes in your pull request.\n\nPlease double-check that:\n\n  - [ ] All changes were made in CoffeeScript files, **not** JavaScript files.\n  - [ ] You used [Grunt](https://github.com/harvesthq/chosen/blob/master/contributing.md#grunt) to build the JavaScript files and tested them locally.\n  - [ ] You've updated both the jQuery *and* Prototype versions.\n  - [ ] You haven't manually updated the version number in `package.json`.\n  - [ ] If necessary, you've updated [the documentation](https://github.com/harvesthq/chosen/blob/master/public/options.html).\n\nSee the [Pull Requests section of our Contributing Guidelines](https://github.com/harvesthq/chosen/blob/master/contributing.md#pull-requests) for more details.\n\n### References\n\nIf your pull request is in reference to one or more open GitHub issues, please mention them here to keep the conversations linked together.\n"
  },
  {
    "path": ".gitignore",
    "content": ".DS_Store\nnode_modules\n.project\npublic/*.js\npublic/*.css\npublic/*.json\npublic/LICENSE.md\nchosen*.zip\n.sass-cache\n.ruby-version\n.rbenv-gemsets\n.grunt\n_SpecRunner.html\nspec/public\n"
  },
  {
    "path": ".travis.yml",
    "content": "sudo: false\n\nlanguage: node_js\n\nnode_js:\n  - 6\n\naddons:\n  apt:\n    sources:\n      - git-core\n    packages:\n      - git\n\nbefore_install: npm install -g grunt-cli\nbefore_script: grunt build package-npm package-bower\n\nafter_success: ./publish-package.sh\n\nenv:\n  global:\n    secure: \"SOYNh0YO4eLAM38FQxrg7iqytXgdjJHRkmj/1lFzGrGeuuXP6Owe/2TaMyTJXWb9nHAAtRRwQyhAUE07eKhxI6b3YNyozeRulMK4B0K8P3P1B2MslpROyvQYtZupno3dWc0tyvsQ3ucnZE25mtetH6KYcwiI+vHv6hT8HnzBnp0=\"\n"
  },
  {
    "path": "Gruntfile.coffee",
    "content": "module.exports = (grunt) ->\n  require('load-grunt-tasks')(grunt)\n  grunt.loadNpmTasks('grunt1.0-dom-munger') # the naming convention of the package does not allow auto-discovery.\n\n  grunt.initConfig\n    pkg: grunt.file.readJSON('package.json')\n    version_tag: 'v<%= pkg.version %>'\n    comments: \"\"\"\n/*!\nChosen, a Select Box Enhancer for jQuery and Prototype\nby Patrick Filler for Harvest, http://getharvest.com\n\nVersion <%= pkg.version %>\nFull source at https://github.com/harvesthq/chosen\nCopyright (c) 2011-<%= grunt.template.today('yyyy') %> Harvest http://getharvest.com\n\nMIT License, https://github.com/harvesthq/chosen/blob/master/LICENSE.md\nThis file is generated by `grunt build`, do not edit it by hand.\n*/\n\\n\n\"\"\"\n    minified_comments: \"/* Chosen <%= version_tag %> | (c) 2011-<%= grunt.template.today('yyyy') %> by Harvest | MIT License, https://github.com/harvesthq/chosen/blob/master/LICENSE.md */\\n\"\n\n    concat:\n      options:\n        banner: '<%= comments %>'\n      jquery:\n        src: ['public/chosen.jquery.js']\n        dest: 'public/chosen.jquery.js'\n      proto:\n        src: ['public/chosen.proto.js']\n        dest: 'public/chosen.proto.js'\n      css:\n        src: ['public/chosen.css']\n        dest: 'public/chosen.css'\n\n    copy:\n      main:\n        src: 'LICENSE.md'\n        dest: 'public/'\n      php:\n        src: 'composer.json'\n        dest: 'public/'\n\n    coffee:\n      options:\n        join: true\n      jquery:\n        files:\n          'public/chosen.jquery.js': ['coffee/lib/select-parser.coffee', 'coffee/lib/abstract-chosen.coffee', 'coffee/chosen.jquery.coffee']\n      proto:\n        files:\n          'public/chosen.proto.js': ['coffee/lib/select-parser.coffee', 'coffee/lib/abstract-chosen.coffee', 'coffee/chosen.proto.coffee']\n      test:\n        files:\n          'spec/public/jquery_specs.js': 'spec/jquery/*.spec.coffee'\n          'spec/public/proto_specs.js': 'spec/proto/*.spec.coffee'\n\n    uglify:\n      options:\n        banner: '<%= minified_comments %>'\n      jquery:\n        options:\n          ie8: true\n          mangle:\n            reserved: ['jQuery']\n        files:\n          'public/chosen.jquery.min.js': ['public/chosen.jquery.js']\n      proto:\n        files:\n          'public/chosen.proto.min.js': ['public/chosen.proto.js']\n\n    sass:\n      options:\n        outputStyle: 'expanded'\n      chosen_css:\n        files:\n          'public/chosen.css': 'sass/chosen.scss'\n\n    postcss:\n      options:\n        processors: [\n          require('autoprefixer')(browsers: 'last 2 versions, IE 8')\n        ]\n      main:\n        src: 'public/chosen.css'\n\n    cssmin:\n      options:\n        banner: '<%= minified_comments %>'\n        keepSpecialComments: 0\n      main:\n        src: 'public/chosen.css'\n        dest: 'public/chosen.min.css'\n\n    watch:\n      default:\n        files: ['coffee/**/*.coffee', 'sass/*.scss']\n        tasks: ['build', 'jasmine']\n      test:\n        files: ['spec/**/*.coffee']\n        tasks: ['jasmine']\n\n    jasmine:\n      jquery:\n        options:\n          vendor: [\n            'public/docsupport/jquery-3.2.1.min.js'\n          ]\n          specs: 'spec/public/jquery_specs.js'\n        src: [ 'public/chosen.jquery.js' ]\n      jquery_old:\n        options:\n          vendor: [\n            'public/docsupport/jquery-1.12.4.min.js'\n          ]\n          specs: 'spec/public/jquery_specs.js'\n        src: [ 'public/chosen.jquery.js' ]\n      proto:\n        options:\n          vendor: [\n            'public/docsupport/prototype-1.7.0.0.js'\n            'node_modules/simulant/dist/simulant.umd.js'\n          ]\n          specs: 'spec/public/proto_specs.js'\n        src: [ 'public/chosen.proto.js' ]\n\n  grunt.loadTasks 'tasks'\n\n  grunt.registerTask 'default', ['build']\n  grunt.registerTask 'build', ['coffee:jquery', 'coffee:proto', 'sass', 'concat', 'uglify', 'postcss', 'cssmin', 'copy']\n  grunt.registerTask 'test',  ['coffee', 'jasmine']\n  grunt.registerTask 'test:jquery',  ['coffee:test', 'coffee:jquery', 'jasmine:jquery', 'jasmine:jquery_old']\n  grunt.registerTask 'test:proto',  ['coffee:test', 'coffee:proto', 'jasmine:proto']\n\n\n"
  },
  {
    "path": "LICENSE.md",
    "content": "#### Chosen\n- by Patrick Filler for [Harvest](http://getharvest.com)\n- Copyright (c) 2011-2016 by Harvest\n\nAvailable for use under the [MIT License](http://en.wikipedia.org/wiki/MIT_License)\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n"
  },
  {
    "path": "README.md",
    "content": "# Deprecated\n\n#### This version of Chosen is not currently under active development while we decide on its future direction.\n\n---\n\n# Chosen\n\nChosen is a library for making long, unwieldy select boxes more user friendly.\n\n- jQuery support: 1.7+\n- Prototype support: 1.7+\n\nFor **documentation**, usage, and examples, see:\nhttp://harvesthq.github.io/chosen/\n\nFor **downloads**, see:\nhttps://github.com/harvesthq/chosen/releases/\n\n### Package managers\n\nChosen is available through [Bower](https://bower.io/), [npm](https://www.npmjs.com), and [Composer](https://getcomposer.org/), _however, the package names are not the same_.\n\nTo install with Bower:\n\n```\nbower install chosen\n```\n\nTo install with npm:\n\n```\nnpm install chosen-js\n```\n\nTo install with Composer:\n\n```\ncomposer require harvesthq/chosen\n```\n\nThe compiled files for these packages are automatically generated and stored in a [2nd Chosen repository](https://github.com/harvesthq/chosen-package). No pull requests will be accepted to that repository.\n\n### Contributing to this project\n\nWe welcome all to participate in making Chosen the best software it can be. The repository is maintained by only a few people, but has accepted contributions from over 50 authors after reviewing hundreds of pull requests related to thousands of issues. You can help reduce the maintainers' workload (and increase your chance of having an accepted contribution to Chosen) by following the\n[guidelines for contributing](contributing.md).\n\n* [Bug reports](contributing.md#bugs)\n* [Feature requests](contributing.md#features)\n* [Pull requests](contributing.md#pull-requests)\n\n### Chosen Credits\n\n- Concept and development by [Patrick Filler](http://patrickfiller.com) for [Harvest](http://getharvest.com/).\n- Design and CSS by [Matthew Lettini](http://matthewlettini.com/)\n- Repository maintained by [@pfiller](http://github.com/pfiller), [@kenearley](http://github.com/kenearley), [@stof](http://github.com/stof), [@koenpunt](http://github.com/koenpunt), and [@tjschuck](http://github.com/tjschuck).\n- Chosen includes [contributions by many fine folks](https://github.com/harvesthq/chosen/contributors).\n"
  },
  {
    "path": "coffee/chosen.jquery.coffee",
    "content": "$ = jQuery\n\n$.fn.extend({\n  chosen: (options) ->\n    # Do no harm and return as soon as possible for unsupported browsers, namely IE6 and IE7\n    # Continue on if running IE document type but in compatibility mode\n    return this unless AbstractChosen.browser_is_supported()\n    this.each (input_field) ->\n      $this = $ this\n      chosen = $this.data('chosen')\n      if options is 'destroy'\n        if chosen instanceof Chosen\n          chosen.destroy()\n        return\n      unless chosen instanceof Chosen\n        $this.data('chosen', new Chosen(this, options))\n\n      return\n\n})\n\nclass Chosen extends AbstractChosen\n\n  setup: ->\n    @form_field_jq = $ @form_field\n    @current_selectedIndex = @form_field.selectedIndex\n\n  set_up_html: ->\n    container_classes = [\"chosen-container\"]\n    container_classes.push \"chosen-container-\" + (if @is_multiple then \"multi\" else \"single\")\n    container_classes.push @form_field.className if @inherit_select_classes && @form_field.className\n    container_classes.push \"chosen-rtl\" if @is_rtl\n\n    container_props =\n      'class': container_classes.join ' '\n      'title': @form_field.title\n\n    container_props.id = @form_field.id.replace(/[^\\w]/g, '_') + \"_chosen\" if @form_field.id.length\n\n    @container = ($ \"<div />\", container_props)\n\n    # CSP without 'unsafe-inline' doesn't allow setting the style attribute directly\n    @container.width this.container_width()\n\n    if @is_multiple\n      @container.html this.get_multi_html()\n    else\n      @container.html this.get_single_html()\n\n    @form_field_jq.hide().after @container\n    @dropdown = @container.find('div.chosen-drop').first()\n\n    @search_field = @container.find('input').first()\n    @search_results = @container.find('ul.chosen-results').first()\n    this.search_field_scale()\n\n    @search_no_results = @container.find('li.no-results').first()\n\n    if @is_multiple\n      @search_choices = @container.find('ul.chosen-choices').first()\n      @search_container = @container.find('li.search-field').first()\n    else\n      @search_container = @container.find('div.chosen-search').first()\n      @selected_item = @container.find('.chosen-single').first()\n\n    this.results_build()\n    this.set_tab_index()\n    this.set_label_behavior()\n\n  on_ready: ->\n    @form_field_jq.trigger(\"chosen:ready\", {chosen: this})\n\n  register_observers: ->\n    @container.on 'touchstart.chosen', (evt) => this.container_mousedown(evt); return\n    @container.on 'touchend.chosen', (evt) => this.container_mouseup(evt); return\n\n    @container.on 'mousedown.chosen', (evt) => this.container_mousedown(evt); return\n    @container.on 'mouseup.chosen', (evt) => this.container_mouseup(evt); return\n    @container.on 'mouseenter.chosen', (evt) => this.mouse_enter(evt); return\n    @container.on 'mouseleave.chosen', (evt) => this.mouse_leave(evt); return\n\n    @search_results.on 'mouseup.chosen', (evt) => this.search_results_mouseup(evt); return\n    @search_results.on 'mouseover.chosen', (evt) => this.search_results_mouseover(evt); return\n    @search_results.on 'mouseout.chosen', (evt) => this.search_results_mouseout(evt); return\n    @search_results.on 'mousewheel.chosen DOMMouseScroll.chosen', (evt) => this.search_results_mousewheel(evt); return\n\n    @search_results.on 'touchstart.chosen', (evt) => this.search_results_touchstart(evt); return\n    @search_results.on 'touchmove.chosen', (evt) => this.search_results_touchmove(evt); return\n    @search_results.on 'touchend.chosen', (evt) => this.search_results_touchend(evt); return\n\n    @form_field_jq.on \"chosen:updated.chosen\", (evt) => this.results_update_field(evt); return\n    @form_field_jq.on \"chosen:activate.chosen\", (evt) => this.activate_field(evt); return\n    @form_field_jq.on \"chosen:open.chosen\", (evt) => this.container_mousedown(evt); return\n    @form_field_jq.on \"chosen:close.chosen\", (evt) => this.close_field(evt); return\n\n    @search_field.on 'blur.chosen', (evt) => this.input_blur(evt); return\n    @search_field.on 'keyup.chosen', (evt) => this.keyup_checker(evt); return\n    @search_field.on 'keydown.chosen', (evt) => this.keydown_checker(evt); return\n    @search_field.on 'focus.chosen', (evt) => this.input_focus(evt); return\n    @search_field.on 'cut.chosen', (evt) => this.clipboard_event_checker(evt); return\n    @search_field.on 'paste.chosen', (evt) => this.clipboard_event_checker(evt); return\n\n    if @is_multiple\n      @search_choices.on 'click.chosen', (evt) => this.choices_click(evt); return\n    else\n      @container.on 'click.chosen', (evt) -> evt.preventDefault(); return # gobble click of anchor\n\n  destroy: ->\n    $(@container[0].ownerDocument).off 'click.chosen', @click_test_action\n    @form_field_label.off 'click.chosen' if @form_field_label.length > 0\n\n    if @search_field[0].tabIndex\n      @form_field_jq[0].tabIndex = @search_field[0].tabIndex\n\n    @container.remove()\n    @form_field_jq.removeData('chosen')\n    @form_field_jq.show()\n\n  search_field_disabled: ->\n    @is_disabled = @form_field.disabled || @form_field_jq.parents('fieldset').is(':disabled')\n\n    @container.toggleClass 'chosen-disabled', @is_disabled\n    @search_field[0].disabled = @is_disabled\n\n    unless @is_multiple\n      @selected_item.off 'focus.chosen', this.activate_field\n\n    if @is_disabled\n      this.close_field()\n    else unless @is_multiple\n      @selected_item.on 'focus.chosen', this.activate_field\n\n  container_mousedown: (evt) ->\n    return if @is_disabled\n\n    if evt and evt.type in ['mousedown', 'touchstart'] and not @results_showing\n      evt.preventDefault()\n\n    if not (evt? and ($ evt.target).hasClass \"search-choice-close\")\n      if not @active_field\n        @search_field.val \"\" if @is_multiple\n        $(@container[0].ownerDocument).on 'click.chosen', @click_test_action\n        this.results_show()\n      else if not @is_multiple and evt and (($(evt.target)[0] == @selected_item[0]) || $(evt.target).parents(\"a.chosen-single\").length)\n        evt.preventDefault()\n        this.results_toggle()\n\n      this.activate_field()\n\n  container_mouseup: (evt) ->\n    this.results_reset(evt) if evt.target.nodeName is \"ABBR\" and not @is_disabled\n\n  search_results_mousewheel: (evt) ->\n    delta = evt.originalEvent.deltaY or -evt.originalEvent.wheelDelta or evt.originalEvent.detail if evt.originalEvent\n    if delta?\n      evt.preventDefault()\n      delta = delta * 40 if evt.type is 'DOMMouseScroll'\n      @search_results.scrollTop(delta + @search_results.scrollTop())\n\n  blur_test: (evt) ->\n    this.close_field() if not @active_field and @container.hasClass \"chosen-container-active\"\n\n  close_field: ->\n    $(@container[0].ownerDocument).off \"click.chosen\", @click_test_action\n\n    @active_field = false\n    this.results_hide()\n\n    @container.removeClass \"chosen-container-active\"\n    this.clear_backstroke()\n\n    this.show_search_field_default()\n    this.search_field_scale()\n    @search_field.blur()\n\n  activate_field: ->\n    return if @is_disabled\n\n    @container.addClass \"chosen-container-active\"\n    @active_field = true\n\n    @search_field.val(@search_field.val())\n    @search_field.focus()\n\n\n  test_active_click: (evt) ->\n    active_container = $(evt.target).closest('.chosen-container')\n    if active_container.length and @container[0] == active_container[0]\n      @active_field = true\n    else\n      this.close_field()\n\n  results_build: ->\n    @parsing = true\n    @selected_option_count = null\n\n    @results_data = SelectParser.select_to_array @form_field\n\n    if @is_multiple\n      @search_choices.find(\"li.search-choice\").remove()\n    else\n      this.single_set_selected_text()\n      if @disable_search or @form_field.options.length <= @disable_search_threshold\n        @search_field[0].readOnly = true\n        @container.addClass \"chosen-container-single-nosearch\"\n      else\n        @search_field[0].readOnly = false\n        @container.removeClass \"chosen-container-single-nosearch\"\n\n    this.update_results_content this.results_option_build({first:true})\n\n    this.search_field_disabled()\n    this.show_search_field_default()\n    this.search_field_scale()\n\n    @parsing = false\n\n  result_do_highlight: (el) ->\n    if el.length\n      this.result_clear_highlight()\n\n      @result_highlight = el\n      @result_highlight.addClass \"highlighted\"\n\n      maxHeight = parseInt @search_results.css(\"maxHeight\"), 10\n      visible_top = @search_results.scrollTop()\n      visible_bottom = maxHeight + visible_top\n\n      high_top = @result_highlight.position().top + @search_results.scrollTop()\n      high_bottom = high_top + @result_highlight.outerHeight()\n\n      if high_bottom >= visible_bottom\n        @search_results.scrollTop if (high_bottom - maxHeight) > 0 then (high_bottom - maxHeight) else 0\n      else if high_top < visible_top\n        @search_results.scrollTop high_top\n\n  result_clear_highlight: ->\n    @result_highlight.removeClass \"highlighted\" if @result_highlight\n    @result_highlight = null\n\n  results_show: ->\n    if @is_multiple and @max_selected_options <= this.choices_count()\n      @form_field_jq.trigger(\"chosen:maxselected\", {chosen: this})\n      return false\n\n    @container.addClass \"chosen-with-drop\"\n    @results_showing = true\n\n    @search_field.focus()\n    @search_field.val this.get_search_field_value()\n\n    this.winnow_results()\n    @form_field_jq.trigger(\"chosen:showing_dropdown\", {chosen: this})\n\n  update_results_content: (content) ->\n    @search_results.html content\n\n  results_hide: ->\n    if @results_showing\n      this.result_clear_highlight()\n\n      @container.removeClass \"chosen-with-drop\"\n      @form_field_jq.trigger(\"chosen:hiding_dropdown\", {chosen: this})\n\n    @results_showing = false\n\n\n  set_tab_index: (el) ->\n    if @form_field.tabIndex\n      ti = @form_field.tabIndex\n      @form_field.tabIndex = -1\n      @search_field[0].tabIndex = ti\n\n  set_label_behavior: ->\n    @form_field_label = @form_field_jq.parents(\"label\") # first check for a parent label\n    if not @form_field_label.length and @form_field.id.length\n      @form_field_label = $(\"label[for='#{@form_field.id}']\") #next check for a for=#{id}\n\n    if @form_field_label.length > 0\n      @form_field_label.on 'click.chosen', this.label_click_handler\n\n  show_search_field_default: ->\n    if @is_multiple and this.choices_count() < 1 and not @active_field\n      @search_field.val(@default_text)\n      @search_field.addClass \"default\"\n    else\n      @search_field.val(\"\")\n      @search_field.removeClass \"default\"\n\n  search_results_mouseup: (evt) ->\n    target = if $(evt.target).hasClass \"active-result\" then $(evt.target) else $(evt.target).parents(\".active-result\").first()\n    if target.length\n      @result_highlight = target\n      this.result_select(evt)\n      @search_field.focus()\n\n  search_results_mouseover: (evt) ->\n    target = if $(evt.target).hasClass \"active-result\" then $(evt.target) else $(evt.target).parents(\".active-result\").first()\n    this.result_do_highlight( target ) if target\n\n  search_results_mouseout: (evt) ->\n    this.result_clear_highlight() if $(evt.target).hasClass(\"active-result\") or $(evt.target).parents('.active-result').first()\n\n  choice_build: (item) ->\n    choice = $('<li />', { class: \"search-choice\" }).html(\"<span>#{this.choice_label(item)}</span>\")\n\n    if item.disabled\n      choice.addClass 'search-choice-disabled'\n    else\n      close_link = $('<a />', { class: 'search-choice-close', 'data-option-array-index': item.array_index })\n      close_link.on 'click.chosen', (evt) => this.choice_destroy_link_click(evt)\n      choice.append close_link\n\n    @search_container.before  choice\n\n  choice_destroy_link_click: (evt) ->\n    evt.preventDefault()\n    evt.stopPropagation()\n    this.choice_destroy $(evt.target) unless @is_disabled\n\n  choice_destroy: (link) ->\n    if this.result_deselect( link[0].getAttribute(\"data-option-array-index\") )\n      if @active_field\n        @search_field.focus()\n      else\n        this.show_search_field_default()\n\n      this.results_hide() if @is_multiple and this.choices_count() > 0 and this.get_search_field_value().length < 1\n\n      link.parents('li').first().remove()\n\n      this.search_field_scale()\n\n  results_reset: ->\n    this.reset_single_select_options()\n    @form_field.options[0].selected = true\n    this.single_set_selected_text()\n    this.show_search_field_default()\n    this.results_reset_cleanup()\n    this.trigger_form_field_change()\n    this.results_hide() if @active_field\n\n  results_reset_cleanup: ->\n    @current_selectedIndex = @form_field.selectedIndex\n    @selected_item.find(\"abbr\").remove()\n\n  result_select: (evt) ->\n    if @result_highlight\n      high = @result_highlight\n\n      this.result_clear_highlight()\n\n      if @is_multiple and @max_selected_options <= this.choices_count()\n        @form_field_jq.trigger(\"chosen:maxselected\", {chosen: this})\n        return false\n\n      if @is_multiple\n        high.removeClass(\"active-result\")\n      else\n        this.reset_single_select_options()\n\n      high.addClass(\"result-selected\")\n\n      item = @results_data[ high[0].getAttribute(\"data-option-array-index\") ]\n      item.selected = true\n\n      @form_field.options[item.options_index].selected = true\n      @selected_option_count = null\n\n      if @is_multiple\n        this.choice_build item\n      else\n        this.single_set_selected_text(this.choice_label(item))\n\n      if @is_multiple && (!@hide_results_on_select || (evt.metaKey or evt.ctrlKey))\n        if evt.metaKey or evt.ctrlKey\n          this.winnow_results(skip_highlight: true)\n        else\n          @search_field.val(\"\")\n          this.winnow_results()\n      else\n        this.results_hide()\n        this.show_search_field_default()\n\n      this.trigger_form_field_change selected: @form_field.options[item.options_index].value  if @is_multiple || @form_field.selectedIndex != @current_selectedIndex\n      @current_selectedIndex = @form_field.selectedIndex\n\n      evt.preventDefault()\n\n      this.search_field_scale()\n\n  single_set_selected_text: (text=@default_text) ->\n    if text is @default_text\n      @selected_item.addClass(\"chosen-default\")\n    else\n      this.single_deselect_control_build()\n      @selected_item.removeClass(\"chosen-default\")\n\n    @selected_item.find(\"span\").html(text)\n\n  result_deselect: (pos) ->\n    result_data = @results_data[pos]\n\n    if not @form_field.options[result_data.options_index].disabled\n      result_data.selected = false\n\n      @form_field.options[result_data.options_index].selected = false\n      @selected_option_count = null\n\n      this.result_clear_highlight()\n      this.winnow_results() if @results_showing\n\n      this.trigger_form_field_change deselected: @form_field.options[result_data.options_index].value\n      this.search_field_scale()\n\n      return true\n    else\n      return false\n\n  single_deselect_control_build: ->\n    return unless @allow_single_deselect\n    @selected_item.find(\"span\").first().after \"<abbr class=\\\"search-choice-close\\\"></abbr>\" unless @selected_item.find(\"abbr\").length\n    @selected_item.addClass(\"chosen-single-with-deselect\")\n\n  get_search_field_value: ->\n    @search_field.val()\n\n  get_search_text: ->\n    $.trim this.get_search_field_value()\n\n  escape_html: (text) ->\n    $('<div/>').text(text).html()\n\n  winnow_results_set_highlight: ->\n    selected_results = if not @is_multiple then @search_results.find(\".result-selected.active-result\") else []\n    do_high = if selected_results.length then selected_results.first() else @search_results.find(\".active-result\").first()\n\n    this.result_do_highlight do_high if do_high?\n\n  no_results: (terms) ->\n    no_results_html = this.get_no_results_html(terms)\n    @search_results.append no_results_html\n    @form_field_jq.trigger(\"chosen:no_results\", {chosen:this})\n\n  no_results_clear: ->\n    @search_results.find(\".no-results\").remove()\n\n  keydown_arrow: ->\n    if @results_showing and @result_highlight\n      next_sib = @result_highlight.nextAll(\"li.active-result\").first()\n      this.result_do_highlight next_sib if next_sib\n    else\n      this.results_show()\n\n  keyup_arrow: ->\n    if not @results_showing and not @is_multiple\n      this.results_show()\n    else if @result_highlight\n      prev_sibs = @result_highlight.prevAll(\"li.active-result\")\n\n      if prev_sibs.length\n        this.result_do_highlight prev_sibs.first()\n      else\n        this.results_hide() if this.choices_count() > 0\n        this.result_clear_highlight()\n\n  keydown_backstroke: ->\n    if @pending_backstroke\n      this.choice_destroy @pending_backstroke.find(\"a\").first()\n      this.clear_backstroke()\n    else\n      next_available_destroy = @search_container.siblings(\"li.search-choice\").last()\n      if next_available_destroy.length and not next_available_destroy.hasClass(\"search-choice-disabled\")\n        @pending_backstroke = next_available_destroy\n        if @single_backstroke_delete\n          @keydown_backstroke()\n        else\n          @pending_backstroke.addClass \"search-choice-focus\"\n\n  clear_backstroke: ->\n    @pending_backstroke.removeClass \"search-choice-focus\" if @pending_backstroke\n    @pending_backstroke = null\n\n  search_field_scale: ->\n    return unless @is_multiple\n\n    style_block =\n      position: 'absolute'\n      left: '-1000px'\n      top: '-1000px'\n      display: 'none'\n      whiteSpace: 'pre'\n\n    styles = ['fontSize', 'fontStyle', 'fontWeight', 'fontFamily', 'lineHeight', 'textTransform', 'letterSpacing']\n\n    for style in styles\n      style_block[style] = @search_field.css(style)\n\n    div = $('<div />').css(style_block)\n    div.text this.get_search_field_value()\n    $('body').append div\n\n    width = div.width() + 25\n    div.remove()\n\n    if @container.is(':visible')\n      width = Math.min(@container.outerWidth() - 10, width)\n\n    @search_field.width(width)\n\n  trigger_form_field_change: (extra) ->\n    @form_field_jq.trigger \"input\", extra\n    @form_field_jq.trigger \"change\", extra\n"
  },
  {
    "path": "coffee/chosen.proto.coffee",
    "content": "class @Chosen extends AbstractChosen\n\n  setup: ->\n    @current_selectedIndex = @form_field.selectedIndex\n\n  set_up_html: ->\n    container_classes = [\"chosen-container\"]\n    container_classes.push \"chosen-container-\" + (if @is_multiple then \"multi\" else \"single\")\n    container_classes.push @form_field.className if @inherit_select_classes && @form_field.className\n    container_classes.push \"chosen-rtl\" if @is_rtl\n\n    container_props =\n      'class': container_classes.join ' '\n      'title': @form_field.title\n\n    container_props.id = @form_field.id.replace(/[^\\w]/g, '_') + \"_chosen\" if @form_field.id.length\n\n    @container = new Element('div', container_props)\n\n    # CSP without 'unsafe-inline' doesn't allow setting the style attribute directly\n    @container.setStyle(width: this.container_width())\n\n    if @is_multiple\n      @container.update this.get_multi_html()\n    else\n      @container.update this.get_single_html()\n\n    @form_field.hide().insert({ after: @container })\n    @dropdown = @container.down('div.chosen-drop')\n\n    @search_field = @container.down('input')\n    @search_results = @container.down('ul.chosen-results')\n    this.search_field_scale()\n\n    @search_no_results = @container.down('li.no-results')\n\n    if @is_multiple\n      @search_choices = @container.down('ul.chosen-choices')\n      @search_container = @container.down('li.search-field')\n    else\n      @search_container = @container.down('div.chosen-search')\n      @selected_item = @container.down('.chosen-single')\n\n    this.results_build()\n    this.set_tab_index()\n    this.set_label_behavior()\n\n  on_ready: ->\n    @form_field.fire(\"chosen:ready\", {chosen: this})\n\n  register_observers: ->\n    @container.observe \"touchstart\", (evt) => this.container_mousedown(evt)\n    @container.observe \"touchend\", (evt) => this.container_mouseup(evt)\n\n    @container.observe \"mousedown\", (evt) => this.container_mousedown(evt)\n    @container.observe \"mouseup\", (evt) => this.container_mouseup(evt)\n    @container.observe \"mouseenter\", (evt) => this.mouse_enter(evt)\n    @container.observe \"mouseleave\", (evt) => this.mouse_leave(evt)\n\n    @search_results.observe \"mouseup\", (evt) => this.search_results_mouseup(evt)\n    @search_results.observe \"mouseover\", (evt) => this.search_results_mouseover(evt)\n    @search_results.observe \"mouseout\", (evt) => this.search_results_mouseout(evt)\n    @search_results.observe \"mousewheel\", (evt) => this.search_results_mousewheel(evt)\n    @search_results.observe \"DOMMouseScroll\", (evt) => this.search_results_mousewheel(evt)\n\n    @search_results.observe \"touchstart\", (evt) => this.search_results_touchstart(evt)\n    @search_results.observe \"touchmove\", (evt) => this.search_results_touchmove(evt)\n    @search_results.observe \"touchend\", (evt) => this.search_results_touchend(evt)\n\n    @form_field.observe \"chosen:updated\", (evt) => this.results_update_field(evt)\n    @form_field.observe \"chosen:activate\", (evt) => this.activate_field(evt)\n    @form_field.observe \"chosen:open\", (evt) => this.container_mousedown(evt)\n    @form_field.observe \"chosen:close\", (evt) => this.close_field(evt)\n\n    @search_field.observe \"blur\", (evt) => this.input_blur(evt)\n    @search_field.observe \"keyup\", (evt) => this.keyup_checker(evt)\n    @search_field.observe \"keydown\", (evt) => this.keydown_checker(evt)\n    @search_field.observe \"focus\", (evt) => this.input_focus(evt)\n    @search_field.observe \"cut\", (evt) => this.clipboard_event_checker(evt)\n    @search_field.observe \"paste\", (evt) => this.clipboard_event_checker(evt)\n\n    if @is_multiple\n      @search_choices.observe \"click\", (evt) => this.choices_click(evt)\n    else\n      @container.observe \"click\", (evt) => evt.preventDefault() # gobble click of anchor\n\n  destroy: ->\n    @container.ownerDocument.stopObserving \"click\", @click_test_action\n\n    for event in ['chosen:updated', 'chosen:activate', 'chosen:open', 'chosen:close']\n      @form_field.stopObserving(event)\n\n    @container.stopObserving()\n    @search_results.stopObserving()\n    @search_field.stopObserving()\n    @form_field_label.stopObserving() if @form_field_label?\n\n    if @is_multiple\n      @search_choices.stopObserving()\n      @container.select(\".search-choice-close\").each (choice) ->\n        choice.stopObserving()\n    else\n      @selected_item.stopObserving()\n\n    if @search_field.tabIndex\n      @form_field.tabIndex = @search_field.tabIndex\n\n    @container.remove()\n    @form_field.show()\n\n  search_field_disabled: ->\n    @is_disabled = @form_field.disabled || @form_field.up('fieldset')?.disabled || false\n\n    if @is_disabled\n      @container.addClassName 'chosen-disabled'\n    else\n      @container.removeClassName 'chosen-disabled'\n\n    @search_field.disabled = @is_disabled\n\n    unless @is_multiple\n      @selected_item.stopObserving 'focus', this.activate_field\n\n    if @is_disabled\n      this.close_field()\n    else unless @is_multiple\n      @selected_item.observe 'focus', this.activate_field\n\n  container_mousedown: (evt) ->\n    return if @is_disabled\n\n    if evt and evt.type in ['mousedown', 'touchstart'] and not @results_showing\n      evt.preventDefault()\n\n    if not (evt? and evt.target.hasClassName \"search-choice-close\")\n      if not @active_field\n        @search_field.clear() if @is_multiple\n        @container.ownerDocument.observe \"click\", @click_test_action\n        this.results_show()\n      else if not @is_multiple and evt and (evt.target is @selected_item || evt.target.up(\"a.chosen-single\"))\n        this.results_toggle()\n\n      this.activate_field()\n\n  container_mouseup: (evt) ->\n    this.results_reset(evt) if evt.target.nodeName is \"ABBR\" and not @is_disabled\n\n  search_results_mousewheel: (evt) ->\n    delta = evt.deltaY or -evt.wheelDelta or evt.detail\n    if delta?\n      evt.preventDefault()\n      delta = delta * 40 if evt.type is 'DOMMouseScroll'\n      @search_results.scrollTop = delta + @search_results.scrollTop\n\n  blur_test: (evt) ->\n    this.close_field() if not @active_field and @container.hasClassName(\"chosen-container-active\")\n\n  close_field: ->\n    @container.ownerDocument.stopObserving \"click\", @click_test_action\n\n    @active_field = false\n    this.results_hide()\n\n    @container.removeClassName \"chosen-container-active\"\n    this.clear_backstroke()\n\n    this.show_search_field_default()\n    this.search_field_scale()\n    @search_field.blur()\n\n  activate_field: ->\n    return if @is_disabled\n\n    @container.addClassName \"chosen-container-active\"\n    @active_field = true\n\n    @search_field.value = this.get_search_field_value()\n    @search_field.focus()\n\n  test_active_click: (evt) ->\n    if evt.target.up('.chosen-container') is @container\n      @active_field = true\n    else\n      this.close_field()\n\n  results_build: ->\n    @parsing = true\n    @selected_option_count = null\n\n    @results_data = SelectParser.select_to_array @form_field\n\n    if @is_multiple\n      @search_choices.select(\"li.search-choice\").invoke(\"remove\")\n    else\n      this.single_set_selected_text()\n      if @disable_search or @form_field.options.length <= @disable_search_threshold\n        @search_field.readOnly = true\n        @container.addClassName \"chosen-container-single-nosearch\"\n      else\n        @search_field.readOnly = false\n        @container.removeClassName \"chosen-container-single-nosearch\"\n\n    this.update_results_content this.results_option_build({first:true})\n\n    this.search_field_disabled()\n    this.show_search_field_default()\n    this.search_field_scale()\n\n    @parsing = false\n\n  result_do_highlight: (el) ->\n      this.result_clear_highlight()\n\n      @result_highlight = el\n      @result_highlight.addClassName \"highlighted\"\n\n      maxHeight = parseInt @search_results.getStyle('maxHeight'), 10\n      visible_top = @search_results.scrollTop\n      visible_bottom = maxHeight + visible_top\n\n      high_top = @result_highlight.positionedOffset().top\n      high_bottom = high_top + @result_highlight.getHeight()\n\n      if high_bottom >= visible_bottom\n        @search_results.scrollTop = if (high_bottom - maxHeight) > 0 then (high_bottom - maxHeight) else 0\n      else if high_top < visible_top\n        @search_results.scrollTop = high_top\n\n  result_clear_highlight: ->\n    @result_highlight.removeClassName('highlighted') if @result_highlight\n    @result_highlight = null\n\n  results_show: ->\n    if @is_multiple and @max_selected_options <= this.choices_count()\n      @form_field.fire(\"chosen:maxselected\", {chosen: this})\n      return false\n\n    @container.addClassName \"chosen-with-drop\"\n    @results_showing = true\n\n    @search_field.focus()\n    @search_field.value = this.get_search_field_value()\n\n    this.winnow_results()\n    @form_field.fire(\"chosen:showing_dropdown\", {chosen: this})\n\n  update_results_content: (content) ->\n    @search_results.update content\n\n  results_hide: ->\n    if @results_showing\n      this.result_clear_highlight()\n\n      @container.removeClassName \"chosen-with-drop\"\n      @form_field.fire(\"chosen:hiding_dropdown\", {chosen: this})\n\n    @results_showing = false\n\n\n  set_tab_index: (el) ->\n    if @form_field.tabIndex\n      ti = @form_field.tabIndex\n      @form_field.tabIndex = -1\n      @search_field.tabIndex = ti\n\n  set_label_behavior: ->\n    @form_field_label = @form_field.up(\"label\") # first check for a parent label\n    if not @form_field_label?\n      @form_field_label = $$(\"label[for='#{@form_field.id}']\").first() #next check for a for=#{id}\n\n    if @form_field_label?\n      @form_field_label.observe \"click\", this.label_click_handler\n\n  show_search_field_default: ->\n    if @is_multiple and this.choices_count() < 1 and not @active_field\n      @search_field.value = @default_text\n      @search_field.addClassName \"default\"\n    else\n      @search_field.value = \"\"\n      @search_field.removeClassName \"default\"\n\n  search_results_mouseup: (evt) ->\n    target = if evt.target.hasClassName(\"active-result\") then evt.target else evt.target.up(\".active-result\")\n    if target\n      @result_highlight = target\n      this.result_select(evt)\n      @search_field.focus()\n\n  search_results_mouseover: (evt) ->\n    target = if evt.target.hasClassName(\"active-result\") then evt.target else evt.target.up(\".active-result\")\n    this.result_do_highlight( target ) if target\n\n  search_results_mouseout: (evt) ->\n    this.result_clear_highlight() if evt.target.hasClassName('active-result') or evt.target.up('.active-result')\n\n  choice_build: (item) ->\n    choice = new Element('li', { class: \"search-choice\" }).update(\"<span>#{this.choice_label(item)}</span>\")\n\n    if item.disabled\n      choice.addClassName 'search-choice-disabled'\n    else\n      close_link = new Element('a', { href: '#', class: 'search-choice-close', rel: item.array_index })\n      close_link.observe \"click\", (evt) => this.choice_destroy_link_click(evt)\n      choice.insert close_link\n\n    @search_container.insert { before: choice }\n\n  choice_destroy_link_click: (evt) ->\n    evt.preventDefault()\n    evt.stopPropagation()\n    this.choice_destroy evt.target unless @is_disabled\n\n  choice_destroy: (link) ->\n    if this.result_deselect link.readAttribute(\"rel\")\n      if @active_field\n        @search_field.focus()\n      else\n        this.show_search_field_default()\n\n      this.results_hide() if @is_multiple and this.choices_count() > 0 and this.get_search_field_value().length < 1\n\n      link.up('li').remove()\n\n      this.search_field_scale()\n\n  results_reset: ->\n    this.reset_single_select_options()\n    @form_field.options[0].selected = true\n    this.single_set_selected_text()\n    this.show_search_field_default()\n    this.results_reset_cleanup()\n    this.trigger_form_field_change()\n    this.results_hide() if @active_field\n\n  results_reset_cleanup: ->\n    @current_selectedIndex = @form_field.selectedIndex\n    deselect_trigger = @selected_item.down(\"abbr\")\n    deselect_trigger.remove() if(deselect_trigger)\n\n  result_select: (evt) ->\n    if @result_highlight\n      high = @result_highlight\n      this.result_clear_highlight()\n\n      if @is_multiple and @max_selected_options <= this.choices_count()\n        @form_field.fire(\"chosen:maxselected\", {chosen: this})\n        return false\n\n      if @is_multiple\n        high.removeClassName(\"active-result\")\n      else\n        this.reset_single_select_options()\n\n      high.addClassName(\"result-selected\")\n\n      item = @results_data[ high.getAttribute(\"data-option-array-index\") ]\n      item.selected = true\n\n      @form_field.options[item.options_index].selected = true\n      @selected_option_count = null\n\n      if @is_multiple\n        this.choice_build item\n      else\n        this.single_set_selected_text(this.choice_label(item))\n\n      if @is_multiple && (!@hide_results_on_select || (evt.metaKey or evt.ctrlKey))\n        if evt.metaKey or evt.ctrlKey\n          this.winnow_results(skip_highlight: true)\n        else\n          @search_field.value = \"\"\n          this.winnow_results()\n      else\n        this.results_hide()\n        this.show_search_field_default()\n\n      this.trigger_form_field_change() if @is_multiple || @form_field.selectedIndex != @current_selectedIndex\n      @current_selectedIndex = @form_field.selectedIndex\n\n      evt.preventDefault()\n\n      this.search_field_scale()\n\n  single_set_selected_text: (text=@default_text) ->\n    if text is @default_text\n      @selected_item.addClassName(\"chosen-default\")\n    else\n      this.single_deselect_control_build()\n      @selected_item.removeClassName(\"chosen-default\")\n\n    @selected_item.down(\"span\").update(text)\n\n  result_deselect: (pos) ->\n    result_data = @results_data[pos]\n\n    if not @form_field.options[result_data.options_index].disabled\n      result_data.selected = false\n\n      @form_field.options[result_data.options_index].selected = false\n      @selected_option_count = null\n\n      this.result_clear_highlight()\n      this.winnow_results() if @results_showing\n\n      this.trigger_form_field_change()\n      this.search_field_scale()\n      return true\n    else\n      return false\n\n  single_deselect_control_build: ->\n    return unless @allow_single_deselect\n    @selected_item.down(\"span\").insert { after: \"<abbr class=\\\"search-choice-close\\\"></abbr>\" } unless @selected_item.down(\"abbr\")\n    @selected_item.addClassName(\"chosen-single-with-deselect\")\n\n  get_search_field_value: ->\n    @search_field.value\n\n  get_search_text: ->\n    this.get_search_field_value().strip()\n\n  escape_html: (text) ->\n    text.escapeHTML()\n\n  winnow_results_set_highlight: ->\n    if not @is_multiple\n      do_high = @search_results.down(\".result-selected.active-result\")\n\n    if not do_high?\n      do_high = @search_results.down(\".active-result\")\n\n    this.result_do_highlight do_high if do_high?\n\n  no_results: (terms) ->\n    @search_results.insert this.get_no_results_html(terms)\n    @form_field.fire(\"chosen:no_results\", {chosen: this})\n\n  no_results_clear: ->\n    nr = null\n    nr.remove() while nr = @search_results.down(\".no-results\")\n\n\n  keydown_arrow: ->\n    if @results_showing and @result_highlight\n      next_sib = @result_highlight.next('.active-result')\n      this.result_do_highlight next_sib if next_sib\n    else\n      this.results_show()\n\n  keyup_arrow: ->\n    if not @results_showing and not @is_multiple\n      this.results_show()\n    else if @result_highlight\n      sibs = @result_highlight.previousSiblings()\n      actives = @search_results.select(\"li.active-result\")\n      prevs = sibs.intersect(actives)\n\n      if prevs.length\n        this.result_do_highlight prevs.first()\n      else\n        this.results_hide() if this.choices_count() > 0\n        this.result_clear_highlight()\n\n  keydown_backstroke: ->\n    if @pending_backstroke\n      this.choice_destroy @pending_backstroke.down(\"a\")\n      this.clear_backstroke()\n    else\n      next_available_destroy = @search_container.siblings().last()\n      if next_available_destroy and next_available_destroy.hasClassName(\"search-choice\") and not next_available_destroy.hasClassName(\"search-choice-disabled\")\n        @pending_backstroke = next_available_destroy\n        @pending_backstroke.addClassName(\"search-choice-focus\") if @pending_backstroke\n        if @single_backstroke_delete\n          @keydown_backstroke()\n        else\n          @pending_backstroke.addClassName(\"search-choice-focus\")\n\n  clear_backstroke: ->\n    @pending_backstroke.removeClassName(\"search-choice-focus\") if @pending_backstroke\n    @pending_backstroke = null\n\n  search_field_scale: ->\n    return unless @is_multiple\n\n    style_block =\n      position: 'absolute'\n      left: '-1000px'\n      top: '-1000px'\n      display: 'none'\n      whiteSpace: 'pre'\n\n    styles = ['fontSize', 'fontStyle', 'fontWeight', 'fontFamily', 'lineHeight', 'textTransform', 'letterSpacing']\n\n    for style in styles\n      style_block[style] = @search_field.getStyle(style)\n\n    div = new Element('div').update(this.escape_html(this.get_search_field_value()))\n    # CSP without 'unsafe-inline' doesn't allow setting the style attribute directly\n    div.setStyle(style_block)\n    document.body.appendChild(div)\n\n    width = div.measure('width') + 25\n    div.remove()\n\n    if container_width = @container.getWidth()\n      width = Math.min(container_width - 10, width)\n\n    @search_field.setStyle(width: width + 'px')\n\n  trigger_form_field_change:  ->\n    triggerHtmlEvent @form_field, 'input'\n    triggerHtmlEvent @form_field, 'change'\n\n  triggerHtmlEvent = (element, eventType) ->\n    if element.dispatchEvent  # Modern way:\n      try\n        evt = new Event(eventType, bubbles: true, cancelable: true)\n      catch\n        evt = document.createEvent('HTMLEvents')\n        evt.initEvent(eventType, true, true);\n      element.dispatchEvent(evt)\n    else # Old IE:\n      element.fireEvent(\"on#{eventType}\", document.createEventObject());\n"
  },
  {
    "path": "coffee/lib/abstract-chosen.coffee",
    "content": "class AbstractChosen\n\n  constructor: (@form_field, @options={}) ->\n    return unless AbstractChosen.browser_is_supported()\n    @is_multiple = @form_field.multiple\n    this.set_default_text()\n    this.set_default_values()\n\n    this.setup()\n\n    this.set_up_html()\n    this.register_observers()\n    # instantiation done, fire ready\n    this.on_ready()\n\n  set_default_values: ->\n    @click_test_action = (evt) => this.test_active_click(evt)\n    @activate_action = (evt) => this.activate_field(evt)\n    @active_field = false\n    @mouse_on_container = false\n    @results_showing = false\n    @result_highlighted = null\n    @is_rtl = @options.rtl || /\\bchosen-rtl\\b/.test(@form_field.className)\n    @allow_single_deselect = if @options.allow_single_deselect? and @form_field.options[0]? and @form_field.options[0].text is \"\" then @options.allow_single_deselect else false\n    @disable_search_threshold = @options.disable_search_threshold || 0\n    @disable_search = @options.disable_search || false\n    @enable_split_word_search = if @options.enable_split_word_search? then @options.enable_split_word_search else true\n    @group_search = if @options.group_search? then @options.group_search else true\n    @search_contains = @options.search_contains || false\n    @single_backstroke_delete = if @options.single_backstroke_delete? then @options.single_backstroke_delete else true\n    @max_selected_options = @options.max_selected_options || Infinity\n    @inherit_select_classes = @options.inherit_select_classes || false\n    @display_selected_options = if @options.display_selected_options? then @options.display_selected_options else true\n    @display_disabled_options = if @options.display_disabled_options? then @options.display_disabled_options else true\n    @include_group_label_in_selected = @options.include_group_label_in_selected || false\n    @max_shown_results = @options.max_shown_results || Number.POSITIVE_INFINITY\n    @case_sensitive_search = @options.case_sensitive_search || false\n    @hide_results_on_select = if @options.hide_results_on_select? then @options.hide_results_on_select else true\n\n  set_default_text: ->\n    if @form_field.getAttribute(\"data-placeholder\")\n      @default_text = @form_field.getAttribute(\"data-placeholder\")\n    else if @is_multiple\n      @default_text = @options.placeholder_text_multiple || @options.placeholder_text || AbstractChosen.default_multiple_text\n    else\n      @default_text = @options.placeholder_text_single || @options.placeholder_text || AbstractChosen.default_single_text\n\n    @default_text = this.escape_html(@default_text)\n\n    @results_none_found = @form_field.getAttribute(\"data-no_results_text\") || @options.no_results_text || AbstractChosen.default_no_result_text\n\n  choice_label: (item) ->\n    if @include_group_label_in_selected and item.group_label?\n      \"<b class='group-name'>#{this.escape_html(item.group_label)}</b>#{item.html}\"\n    else\n      item.html\n\n  mouse_enter: -> @mouse_on_container = true\n  mouse_leave: -> @mouse_on_container = false\n\n  input_focus: (evt) ->\n    if @is_multiple\n      setTimeout (=> this.container_mousedown()), 50 unless @active_field\n    else\n      @activate_field() unless @active_field\n\n  input_blur: (evt) ->\n    if not @mouse_on_container\n      @active_field = false\n      setTimeout (=> this.blur_test()), 100\n\n  label_click_handler: (evt) =>\n    if @is_multiple\n      this.container_mousedown(evt)\n    else\n      this.activate_field()\n\n  results_option_build: (options) ->\n    content = ''\n    shown_results = 0\n    for data in @results_data\n      data_content = ''\n      if data.group\n        data_content = this.result_add_group data\n      else\n        data_content = this.result_add_option data\n      if data_content != ''\n        shown_results++\n        content += data_content\n\n      # this select logic pins on an awkward flag\n      # we can make it better\n      if options?.first\n        if data.selected and @is_multiple\n          this.choice_build data\n        else if data.selected and not @is_multiple\n          this.single_set_selected_text(this.choice_label(data))\n\n      if shown_results >= @max_shown_results\n        break\n\n    content\n\n  result_add_option: (option) ->\n    return '' unless option.search_match\n    return '' unless this.include_option_in_results(option)\n\n    classes = []\n    classes.push \"active-result\" if !option.disabled and !(option.selected and @is_multiple)\n    classes.push \"disabled-result\" if option.disabled and !(option.selected and @is_multiple)\n    classes.push \"result-selected\" if option.selected\n    classes.push \"group-option\" if option.group_array_index?\n    classes.push option.classes if option.classes != \"\"\n\n    option_el = document.createElement(\"li\")\n    option_el.className = classes.join(\" \")\n    option_el.style.cssText = option.style if option.style\n    option_el.setAttribute(\"data-option-array-index\", option.array_index)\n    option_el.innerHTML = option.highlighted_html or option.html\n    option_el.title = option.title if option.title\n\n    this.outerHTML(option_el)\n\n  result_add_group: (group) ->\n    return '' unless group.search_match || group.group_match\n    return '' unless group.active_options > 0\n\n    classes = []\n    classes.push \"group-result\"\n    classes.push group.classes if group.classes\n\n    group_el = document.createElement(\"li\")\n    group_el.className = classes.join(\" \")\n    group_el.innerHTML = group.highlighted_html or this.escape_html(group.label)\n    group_el.title = group.title if group.title\n\n    this.outerHTML(group_el)\n\n  results_update_field: ->\n    this.set_default_text()\n    this.results_reset_cleanup() if not @is_multiple\n    this.result_clear_highlight()\n    this.results_build()\n    this.winnow_results() if @results_showing\n\n  reset_single_select_options: () ->\n    for result in @results_data\n      result.selected = false if result.selected\n\n  results_toggle: ->\n    if @results_showing\n      this.results_hide()\n    else\n      this.results_show()\n\n  results_search: (evt) ->\n    if @results_showing\n      this.winnow_results()\n    else\n      this.results_show()\n\n  winnow_results: (options) ->\n    this.no_results_clear()\n\n    results = 0\n\n    query = this.get_search_text()\n    escapedQuery = query.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, \"\\\\$&\")\n    regex = this.get_search_regex(escapedQuery)\n\n    for option in @results_data\n\n      option.search_match = false\n      results_group = null\n      search_match = null\n      option.highlighted_html = ''\n\n      if this.include_option_in_results(option)\n\n        if option.group\n          option.group_match = false\n          option.active_options = 0\n\n        if option.group_array_index? and @results_data[option.group_array_index]\n          results_group = @results_data[option.group_array_index]\n          results += 1 if results_group.active_options is 0 and results_group.search_match\n          results_group.active_options += 1\n\n        text = if option.group then option.label else option.text\n\n        unless option.group and not @group_search\n          search_match = this.search_string_match(text, regex)\n          option.search_match = search_match?\n\n          results += 1 if option.search_match and not option.group\n\n          if option.search_match\n            if query.length\n              startpos = search_match.index\n              prefix = text.slice(0, startpos)\n              fix    = text.slice(startpos, startpos + query.length)\n              suffix = text.slice(startpos + query.length)\n              option.highlighted_html = \"#{this.escape_html(prefix)}<em>#{this.escape_html(fix)}</em>#{this.escape_html(suffix)}\"\n\n            results_group.group_match = true if results_group?\n\n          else if option.group_array_index? and @results_data[option.group_array_index].search_match\n            option.search_match = true\n\n    this.result_clear_highlight()\n\n    if results < 1 and query.length\n      this.update_results_content \"\"\n      this.no_results query\n    else\n      this.update_results_content this.results_option_build()\n      this.winnow_results_set_highlight() unless options?.skip_highlight\n\n  get_search_regex: (escaped_search_string) ->\n    regex_string = if @search_contains then escaped_search_string else \"(^|\\\\s|\\\\b)#{escaped_search_string}[^\\\\s]*\"\n    regex_string = \"^#{regex_string}\" unless @enable_split_word_search or @search_contains\n    regex_flag = if @case_sensitive_search then \"\" else \"i\"\n    new RegExp(regex_string, regex_flag)\n\n  search_string_match: (search_string, regex) ->\n    match = regex.exec(search_string)\n    match.index += 1 if !@search_contains && match?[1] # make up for lack of lookbehind operator in regex\n    match\n\n  choices_count: ->\n    return @selected_option_count if @selected_option_count?\n\n    @selected_option_count = 0\n    for option in @form_field.options\n      @selected_option_count += 1 if option.selected\n\n    return @selected_option_count\n\n  choices_click: (evt) ->\n    evt.preventDefault()\n    this.activate_field()\n    this.results_show() unless @results_showing or @is_disabled\n\n  keydown_checker: (evt) ->\n    stroke = evt.which ? evt.keyCode\n    this.search_field_scale()\n\n    this.clear_backstroke() if stroke != 8 and @pending_backstroke\n\n    switch stroke\n      when 8 # backspace\n        @backstroke_length = this.get_search_field_value().length\n        break\n      when 9 # tab\n        this.result_select(evt) if @results_showing and not @is_multiple\n        @mouse_on_container = false\n        break\n      when 13 # enter\n        evt.preventDefault() if @results_showing\n        break\n      when 27 # escape\n        evt.preventDefault() if @results_showing\n        break\n      when 32 # space\n        evt.preventDefault() if @disable_search\n        break\n      when 38 # up arrow\n        evt.preventDefault()\n        this.keyup_arrow()\n        break\n      when 40 # down arrow\n        evt.preventDefault()\n        this.keydown_arrow()\n        break\n\n  keyup_checker: (evt) ->\n    stroke = evt.which ? evt.keyCode\n    this.search_field_scale()\n\n    switch stroke\n      when 8 # backspace\n        if @is_multiple and @backstroke_length < 1 and this.choices_count() > 0\n          this.keydown_backstroke()\n        else if not @pending_backstroke\n          this.result_clear_highlight()\n          this.results_search()\n        break\n      when 13 # enter\n        evt.preventDefault()\n        this.result_select(evt) if this.results_showing\n        break\n      when 27 # escape\n        this.results_hide() if @results_showing\n        break\n      when 9, 16, 17, 18, 38, 40, 91\n        # don't do anything on these keys\n      else\n        this.results_search()\n        break\n\n  clipboard_event_checker: (evt) ->\n    return if @is_disabled\n    setTimeout (=> this.results_search()), 50\n\n  container_width: ->\n    return if @options.width? then @options.width else \"#{@form_field.offsetWidth}px\"\n\n  include_option_in_results: (option) ->\n    return false if @is_multiple and (not @display_selected_options and option.selected)\n    return false if not @display_disabled_options and option.disabled\n    return false if option.empty\n\n    return true\n\n  search_results_touchstart: (evt) ->\n    @touch_started = true\n    this.search_results_mouseover(evt)\n\n  search_results_touchmove: (evt) ->\n    @touch_started = false\n    this.search_results_mouseout(evt)\n\n  search_results_touchend: (evt) ->\n    this.search_results_mouseup(evt) if @touch_started\n\n  outerHTML: (element) ->\n    return element.outerHTML if element.outerHTML\n    tmp = document.createElement(\"div\")\n    tmp.appendChild(element)\n    tmp.innerHTML\n\n  get_single_html: ->\n    \"\"\"\n      <a class=\"chosen-single chosen-default\">\n        <span>#{@default_text}</span>\n        <div><b></b></div>\n      </a>\n      <div class=\"chosen-drop\">\n        <div class=\"chosen-search\">\n          <input class=\"chosen-search-input\" type=\"text\" autocomplete=\"off\" />\n        </div>\n        <ul class=\"chosen-results\"></ul>\n      </div>\n    \"\"\"\n\n  get_multi_html: ->\n    \"\"\"\n      <ul class=\"chosen-choices\">\n        <li class=\"search-field\">\n          <input class=\"chosen-search-input\" type=\"text\" autocomplete=\"off\" value=\"#{@default_text}\" />\n        </li>\n      </ul>\n      <div class=\"chosen-drop\">\n        <ul class=\"chosen-results\"></ul>\n      </div>\n    \"\"\"\n\n  get_no_results_html: (terms) ->\n    \"\"\"\n      <li class=\"no-results\">\n        #{@results_none_found} <span>#{this.escape_html(terms)}</span>\n      </li>\n    \"\"\"\n\n  # class methods and variables ============================================================\n\n  @browser_is_supported: ->\n    if \"Microsoft Internet Explorer\" is window.navigator.appName\n      return document.documentMode >= 8\n    if /iP(od|hone)/i.test(window.navigator.userAgent) or\n       /IEMobile/i.test(window.navigator.userAgent) or\n       /Windows Phone/i.test(window.navigator.userAgent) or\n       /BlackBerry/i.test(window.navigator.userAgent) or\n       /BB10/i.test(window.navigator.userAgent) or\n       /Android.*Mobile/i.test(window.navigator.userAgent)\n      return false\n    return true\n\n  @default_multiple_text: \"Select Some Options\"\n  @default_single_text: \"Select an Option\"\n  @default_no_result_text: \"No results match\"\n\n"
  },
  {
    "path": "coffee/lib/select-parser.coffee",
    "content": "class SelectParser\n\n  constructor: ->\n    @options_index = 0\n    @parsed = []\n\n  add_node: (child) ->\n    if child.nodeName.toUpperCase() is \"OPTGROUP\"\n      this.add_group child\n    else\n      this.add_option child\n\n  add_group: (group) ->\n    group_position = @parsed.length\n    @parsed.push\n      array_index: group_position\n      group: true\n      label: group.label\n      title: group.title if group.title\n      children: 0\n      disabled: group.disabled,\n      classes: group.className\n    this.add_option( option, group_position, group.disabled ) for option in group.childNodes\n\n  add_option: (option, group_position, group_disabled) ->\n    if option.nodeName.toUpperCase() is \"OPTION\"\n      if option.text != \"\"\n        if group_position?\n          @parsed[group_position].children += 1\n        @parsed.push\n          array_index: @parsed.length\n          options_index: @options_index\n          value: option.value\n          text: option.text\n          html: option.innerHTML\n          title: option.title if option.title\n          selected: option.selected\n          disabled: if group_disabled is true then group_disabled else option.disabled\n          group_array_index: group_position\n          group_label: if group_position? then @parsed[group_position].label else null\n          classes: option.className\n          style: option.style.cssText\n      else\n        @parsed.push\n          array_index: @parsed.length\n          options_index: @options_index\n          empty: true\n      @options_index += 1\n\nSelectParser.select_to_array = (select) ->\n  parser = new SelectParser()\n  parser.add_node( child ) for child in select.childNodes\n  parser.parsed\n"
  },
  {
    "path": "composer.json",
    "content": "{\n  \"name\": \"harvesthq/chosen\",\n  \"description\": \"Chosen is a JavaScript plugin that makes select boxes user-friendly. It is currently available in both jQuery and Prototype flavors.\",\n  \"authors\": [\n    {\n      \"name\": \"Patrick Filler\",\n      \"homepage\": \"https://github.com/pfiller\"\n    },\n    {\n      \"name\": \"Christophe Coevoet\",\n      \"homepage\": \"https://github.com/stof\"\n    },\n    {\n      \"name\": \"Ken Earley\",\n      \"homepage\": \"https://github.com/kenearley\"\n    },\n    {\n      \"name\": \"Koen Punt\",\n      \"homepage\": \"https://github.com/koenpunt\"\n    }\n  ],\n  \"keywords\": [\n    \"select\",\n    \"multiselect\",\n    \"dropdown\",\n    \"form\",\n    \"input\",\n    \"ui\"\n  ],\n  \"type\": \"library\",\n  \"license\": \"MIT\",\n  \"minimum-stability\": \"stable\",\n  \"homepage\": \"https://harvesthq.github.io/chosen/\",\n  \"require\": {\n  }\n}\n"
  },
  {
    "path": "contributing.md",
    "content": "# Contributing to this project\n\nPlease take a moment to review this document in order to make the contribution\nprocess easy and effective for everyone involved.\n\nFollowing these guidelines will help us get back to you more quickly, and will\nshow that you care about making Chosen better just like we do. In return, we'll\ndo our best to respond to your issue or pull request as soon as possible with\nthe same respect.\n\n_**Please Note:** These guidelines are adapted from [@necolas](https://github.com/necolas)'s\n[issue-guidelines](https://github.com/necolas/issue-guidelines) and serve as\nan excellent starting point for contributing to any open source project._\n\n\n## Using the issue tracker [![Open Source Helpers](https://www.codetriage.com/harvesthq/chosen/badges/users.svg)](https://www.codetriage.com/harvesthq/chosen)\n\nThe [issue tracker](https://github.com/harvesthq/chosen/issues) is the\npreferred channel for [bug reports](#bugs), [features requests](#features)\nand [submitting pull requests](#pull-requests), but please respect the\nfollowing restrictions:\n\n* Support issues or usage question that are not bugs should be posted on\n[Stack Overflow, using the `chosen.js`](http://stackoverflow.com/questions/tagged/chosen.js) tag\n(related tags: [`jquery-chosen`](http://stackoverflow.com/questions/tagged/jquery-chosen),\n[`prototype-chosen`](http://stackoverflow.com/questions/tagged/prototype-chosen)).\n\n* Please **do not** derail or troll issues. Keep the discussion on topic and\n  respect the opinions of others.\n\nYou can triage issues which may include reproducing bug reports or asking for vital information, such as version numbers or reproduction instructions. If you would like to start triaging issues, one easy way to get started is to [subscribe to chosen on CodeTriage](https://www.codetriage.com/harvesthq/chosen).\n\n<a name=\"bugs\"></a>\n## Bug reports\n\nA bug is a _demonstrable problem_ that is caused by the code in the repository.\nGood bug reports are extremely helpful &mdash; thank you!\n\nGuidelines for bug reports:\n\n1. **Use the [GitHub issue search](https://github.com/harvesthq/chosen/search?type=Issues)** &mdash; check if the issue has already been\n   reported.\n\n2. **Check if the bug has already been fixed** &mdash; try to reproduce it using the\n   repository's latest `master` changes.\n\n3. **Isolate the problem** &mdash; ideally create a [reduced test\n   case](https://css-tricks.com/reduced-test-cases/) and a live example\n   (perhaps a [fiddle](http://jsfiddle.net)).\n\nA good bug report shouldn't leave others needing to contact you for more\ninformation. Please try to be as detailed as possible in your report. What is\nyour environment? What steps will reproduce the issue? What browser(s) and OS\nexperience the problem? What outcome did you expect, and how did it differ from\nwhat you actually saw? All these details will help people to fix any potential\nbugs.\n\nExample:\n\n> Short and descriptive example bug report title\n>\n> A summary of the issue and the browser/OS environment in which it occurs. If\n> suitable, include the steps required to reproduce the bug.\n>\n> 1. This is the first step\n> 2. This is the second step\n> 3. Further steps, etc.\n>\n> `<url>` - a link to the reduced test case\n>\n> Any other information you want to share that is relevant to the issue being\n> reported. This might include the lines of code that you have identified as\n> causing the bug, and potential solutions (and your opinions on their\n> merits).\n\n**Note:** In an effort to keep open issues to a manageable number, we will close any issues\nthat do not provide enough information for us to be able to work on a solution.\nYou will be encouraged to provide the necessary details, after which we will reopen the issue.\n\n<a name=\"features\"></a>\n## Feature requests\n\nFeature requests are welcome. But take a moment to find out whether your idea\nfits with the scope and aims of the project. It's up to *you* to make a strong\ncase to convince the project's developers of the merits of this feature. Please\nprovide as much detail and context as possible.\n\nBuilding something great means choosing features carefully especially because it\nis much, much easier to add features than it is to take them away. Additions\nto Chosen will be evaluated on a combination of scope (how well it fits into the\nproject), maintenance burden and general usefulness.\n\nCreating something great often means saying no to seemingly good ideas. Don't\ndispair if your feature request isn't accepted, take action! Fork the\nrepository, build your idea and share it with others. We released Chosen under\nthe MIT License for this purpose precisely. Open source works best when smart\nand dedicated people riff off of each others' ideas to make even greater things.\n\n\n\n<a name=\"pull-requests\"></a>\n## Pull requests\n\nGood pull requests &mdash; patches, improvements, new features &mdash; are a fantastic help.\nThey should remain focused in scope and avoid containing unrelated commits.\n\n**Please ask first** before embarking on any significant pull request (e.g.\nimplementing features, refactoring code, porting to a different language),\notherwise you risk spending a lot of time working on something that the\nproject's developers might not want to merge into the project. You can solicit\nfeedback and opinions in an open feature request thread or create a new one.\n\nPlease use the [git flow for pull requests](#git-flow) and follow Chosen's\n[code conventions](#code-conventions) before submitting your work. Adhering to\nthese guidelines is the best way to get your work included in Chosen.\n\n<a name=\"git-flow\"></a>\n#### Git Flow for pull requests\n\n1. [Fork](http://help.github.com/fork-a-repo/) the project, clone your fork,\n   and configure the remotes:\n\n   ```bash\n   # Clone your fork of the repo into the current directory\n   git clone git@github.com:<YOUR_USERNAME>/chosen.git\n   # Navigate to the newly cloned directory\n   cd chosen\n   # Assign the original repo to a remote called \"upstream\"\n   git remote add upstream https://github.com/harvesthq/chosen\n   ```\n\n2. If you cloned a while ago, get the latest changes from upstream:\n\n   ```bash\n   git checkout master\n   git pull upstream master\n   ```\n\n3. Create a new topic branch (off the main project development branch) to\n   contain your feature, change, or fix:\n\n   ```bash\n   git checkout -b <topic-branch-name>\n   ```\n\n4. Commit your changes in logical chunks. Please adhere to these [git commit\n   message guidelines](http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html)\n   or your code is unlikely be merged into the main project. Use Git's\n   [interactive rebase](https://help.github.com/articles/interactive-rebase)\n   feature to tidy up your commits before making them public.\n\n5. Locally merge (or rebase) the upstream development branch into your topic branch:\n\n   ```bash\n   git pull [--rebase] upstream master\n   ```\n\n6. Push your topic branch up to your fork:\n\n   ```bash\n   git push origin <topic-branch-name>\n   ```\n\n7. [Open a Pull Request](https://help.github.com/articles/using-pull-requests/)\n    with a clear title and description.\n\n**IMPORTANT**: By submitting a patch, you agree to allow the project owner to\nlicense your work under the [MIT License](http://en.wikipedia.org/wiki/MIT_License).\n\n<a name=\"code-conventions\"></a>\n#### Chosen Code Conventions\n\n1. Make all changes in CoffeeScript files, **not** JavaScript files.\n2. Use [Grunt](#grunt) to build the JavaScript files.\n3. For feature changes, update both jQuery *and* Prototype versions\n4. Don't manually update the version number in `package.json`. This is done using a Grunt task on deployment.\n\n<a name=\"grunt\"></a>\n#### Grunt tasks: Running Tests and building Chosen\n\n\nTo install all development dependencies, in the project's root directory, run\n\n    npm install\n\nOnce you're configured, `grunt` tasks are available:\n\n    grunt test                 # run the tests in spec/\n\n    grunt build                # build Chosen from source\n\n    grunt watch                # watch coffee/ for changes and build Chosen\n\nIf you're interested, you can find the task in [Gruntfile.coffee](https://github.com/harvesthq/chosen/blob/master/Gruntfile.coffee).\n\n# Release a new version of Chosen\n\nThis documentation is for Chosen maintainers.  You must have write permissions for this repository to cut a release.\n\n1. Bump the version number in the source but _do not push it yet_. [Example commit](https://github.com/harvesthq/chosen/commit/be0a298f528ec59ce97889eaeeeb47a2dca9ca79).\n\n2. Create a tag for that commit: `git tag -m \"<tagname>\" <tagname> <SHA>`\n\n    - `<tagname>` formatted as `vX.Y.Z`\n    - `<SHA>` is the SHA of the commit from step 1\n\n3. Push the commit _and_ the tag: `git push origin --follow-tags`\n\n4. Draft a new release [on the releases page](https://github.com/harvesthq/chosen/releases).\n\n    - Title formatted as \"Version X.Y.Z\"\n    - Tagged as `<tagname>` from step 2\n    - Body of the release should contain changes included in the release. Ideally, there will already be a draft release present with a running log from contributions merged since the last release.\n\n5. Run `grunt prep-release`\n\n6. Attach the generated `chosen_vX.Y.Z.zip` file (in the Chosen root directory) to the draft release from step 4.\n\n7. Publish the release.\n\n8. Run `grunt publish-release` to publish to the `gh-pages` branch.\n\n9. Verify https://harvesthq.github.io/chosen/ is showing the new version.\n\n_Note:_ the release repository [harvesthq/chosen-package](https://github.com/harvesthq/chosen-package) is automatically built by [Travis CI](https://travis-ci.org/harvesthq/chosen). No explicit action is necessary.\n"
  },
  {
    "path": "package-travis.yml",
    "content": "sudo: false\n\nlanguage: node_js\n\nnode_js:\n  - \"node\"\n\ndeploy:\n  provider: npm\n  email: chosenjs@getharvest.com\n  api_key:\n    # This key is for automatically publishing releases to NPM,\n    # but it is encrypted for publishing publicly like this using Travis.\n    # More information about how this token is generated and encrypted here:\n    # https://docs.travis-ci.com/user/deployment/npm#NPM-auth-token\n    #\n    # Be sure to use the _package_ repo when encrypting since that is what\n    # publishes to NPM:\n    #   travis encrypt THE-API-KEY -r \"harvesthq/chosen-package\"\n    secure: \"LymcaqX4oXPmaIxaTYeMziNsr+FBi4WVZCc5XqCEeZxC/spRousJDX+oEf/gnmWtN5+sOEtct/WKALXye9MiOVkrRG87YEGXGaG5EQVm4+NJbulHpp/TNhJ61Su+NA+52rpj6zgeq15ruIaMr8OQXGkqdq1IRSlShXuaUgKByNY=\"\n  on:\n    tags: true\n    repo: harvesthq/chosen-package\n"
  },
  {
    "path": "package.json",
    "content": "{\n  \"author\": \"harvest\",\n  \"name\": \"chosen\",\n  \"version\": \"1.8.7\",\n  \"description\": \"Chosen is a JavaScript plugin that makes select boxes user-friendly. It is currently available in both jQuery and Prototype flavors.\",\n  \"keywords\": [\n    \"select\",\n    \"multiselect\",\n    \"dropdown\",\n    \"form\",\n    \"input\",\n    \"ui\"\n  ],\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"https://github.com/harvesthq/chosen.git\"\n  },\n  \"engines\": {\n    \"node\": \">=4\"\n  },\n  \"scripts\": {\n    \"test\": \"grunt test\"\n  },\n  \"dependencies\": {},\n  \"devDependencies\": {\n    \"autoprefixer\": \"^7.1.2\",\n    \"coffee-script\": \">= 1.6\",\n    \"grunt\": \"~1.0\",\n    \"grunt-contrib-coffee\": \"~1.0\",\n    \"grunt-contrib-copy\": \"^1.0.0\",\n    \"grunt-contrib-concat\": \"~1.0\",\n    \"grunt-contrib-cssmin\": \"~2.2\",\n    \"grunt-contrib-jasmine\": \"~1.1\",\n    \"grunt-contrib-uglify\": \"~3.0\",\n    \"grunt-contrib-watch\": \"~1.0\",\n    \"grunt-gh-pages\": \"~2.0\",\n    \"grunt-postcss\": \"^0.8.0\",\n    \"grunt-sass\": \"^2.0\",\n    \"grunt-zip\": \"~0.17.1\",\n    \"grunt1.0-dom-munger\": \"~3.4\",\n    \"load-grunt-tasks\": \"^3.5.2\",\n    \"simulant\": \"^0.2.2\"\n  },\n  \"contributors\": [\n    {\n      \"name\": \"Patrick Filler\",\n      \"url\": \"https://github.com/pfiller\"\n    },\n    {\n      \"name\": \"Christophe Coevoet\",\n      \"url\": \"https://github.com/stof\"\n    },\n    {\n      \"name\": \"Ken Earley\",\n      \"url\": \"https://github.com/kenearley\"\n    },\n    {\n      \"name\": \"Koen Punt\",\n      \"url\": \"https://github.com/koenpunt\"\n    }\n  ],\n  \"license\": \"MIT\",\n  \"homepage\": \"https://harvesthq.github.io/chosen/\",\n  \"bugs\": \"https://github.com/harvesthq/chosen/issues\",\n  \"_extra\": {\n    \"title\": \"Chosen\",\n    \"license\": {\n      \"type\": \"MIT\",\n      \"url\": \"https://github.com/harvesthq/chosen/blob/master/LICENSE.md\"\n    },\n    \"links\": {\n      \"download\": \"https://github.com/harvesthq/chosen/releases\",\n      \"docs\": \"https://harvesthq.github.io/chosen/\"\n    },\n    \"main\": [\n      \"chosen.jquery.js\",\n      \"chosen.css\"\n    ],\n    \"files\": [\n      \"chosen.jquery.js\",\n      \"chosen.jquery.min.js\",\n      \"chosen.proto.js\",\n      \"chosen.proto.min.js\",\n      \"chosen.css\",\n      \"chosen.min.css\",\n      \"chosen-sprite@2x.png\",\n      \"chosen-sprite.png\"\n    ]\n  }\n}\n"
  },
  {
    "path": "public/docsupport/init.js",
    "content": "var config = {\n  '.chosen-select'           : {},\n  '.chosen-select-deselect'  : { allow_single_deselect: true },\n  '.chosen-select-no-single' : { disable_search_threshold: 10 },\n  '.chosen-select-no-results': { no_results_text: 'Oops, nothing found!' },\n  '.chosen-select-rtl'       : { rtl: true },\n  '.chosen-select-width'     : { width: '95%' }\n}\nfor (var selector in config) {\n  $(selector).chosen(config[selector]);\n}\n"
  },
  {
    "path": "public/docsupport/init.proto.js",
    "content": "document.observe('dom:loaded', function(evt) {\n  var config = {\n    '.chosen-select'           : {},\n    '.chosen-select-deselect'  : { allow_single_deselect: true },\n    '.chosen-select-no-single' : { disable_search_threshold: 10 },\n    '.chosen-select-no-results': { no_results_text: 'Oops, nothing found!' },\n    '.chosen-select-rtl'       : { rtl: true },\n    '.chosen-select-width'     : { width: '95%' }\n  }\n  \n  for (var selector in config) {\n    $$(selector).each(function(element) {\n      new Chosen(element, config[selector]);\n    });\n  }\n});\n"
  },
  {
    "path": "public/docsupport/prism.css",
    "content": "/**\n * okaidia theme for JavaScript, CSS and HTML\n * Loosely based on Monokai textmate theme by http://www.monokai.nl/\n * @author ocodia\n */\n\ncode[class*=\"language-\"],\npre[class*=\"language-\"] {\n\tcolor: #f8f8f2;\n\ttext-shadow: 0 1px rgba(0,0,0,0.3);\n\tfont-family: Consolas, Monaco, 'Andale Mono', monospace;\n\tdirection: ltr;\n\ttext-align: left;\n\twhite-space: pre;\n\tword-spacing: normal;\n\t\n\t-moz-tab-size: 4;\n\t-o-tab-size: 4;\n\ttab-size: 4;\n\t\n\t-webkit-hyphens: none;\n\t-moz-hyphens: none;\n\t-ms-hyphens: none;\n\thyphens: none;\n}\n\n/* Code blocks */\npre[class*=\"language-\"] {\n\tpadding: 1em;\n\tmargin: .5em 0;\n\toverflow: auto;\t\n\tborder-radius: 0.3em;\n}\n\n:not(pre) > code[class*=\"language-\"],\npre[class*=\"language-\"] {\n\tbackground: #272822;\n}\n\n/* Inline code */\n:not(pre) > code[class*=\"language-\"] {\n\tpadding: .1em;\n\tborder-radius: .3em;\n}\n\n.token.comment,\n.token.prolog,\n.token.doctype,\n.token.cdata {\n\tcolor: slategray;\n}\n\n.token.punctuation {\n\tcolor: #f8f8f2;\n}\n\n.namespace {\n\topacity: .7;\n}\n\n.token.property,\n.token.tag {\n\tcolor: #f92672;\n}\n\n.token.boolean,\n.token.number{\n\tcolor: #ae81ff;\n}\n\n.token.selector,\n.token.attr-name,\n.token.string {\n\tcolor: #a6e22e;\n}\n\n\n.token.operator,\n.token.entity,\n.token.url,\n.language-css .token.string,\n.style .token.string {\n\tcolor: #f8f8f2;\n}\n\n.token.atrule,\n.token.attr-value\n{\n\tcolor: #e6db74;\n}\n\n\n.token.keyword{\ncolor: #66d9ef;\n}\n\n.token.regex,\n.token.important {\n\tcolor: #fd971f;\n}\n\n.token.important {\n\tfont-weight: bold;\n}\n\n.token.entity {\n\tcursor: help;\n}\n"
  },
  {
    "path": "public/docsupport/prism.js",
    "content": "/**\n * Prism: Lightweight, robust, elegant syntax highlighting\n * MIT license http://www.opensource.org/licenses/mit-license.php/\n * @author Lea Verou http://lea.verou.me\n */(function(){var e=/\\blang(?:uage)?-(?!\\*)(\\w+)\\b/i,t=self.Prism={util:{type:function(e){return Object.prototype.toString.call(e).match(/\\[object (\\w+)\\]/)[1]},clone:function(e){var n=t.util.type(e);switch(n){case\"Object\":var r={};for(var i in e)e.hasOwnProperty(i)&&(r[i]=t.util.clone(e[i]));return r;case\"Array\":return e.slice()}return e}},languages:{extend:function(e,n){var r=t.util.clone(t.languages[e]);for(var i in n)r[i]=n[i];return r},insertBefore:function(e,n,r,i){i=i||t.languages;var s=i[e],o={};for(var u in s)if(s.hasOwnProperty(u)){if(u==n)for(var a in r)r.hasOwnProperty(a)&&(o[a]=r[a]);o[u]=s[u]}return i[e]=o},DFS:function(e,n){for(var r in e){n.call(e,r,e[r]);t.util.type(e)===\"Object\"&&t.languages.DFS(e[r],n)}}},highlightAll:function(e,n){var r=document.querySelectorAll('code[class*=\"language-\"], [class*=\"language-\"] code, code[class*=\"lang-\"], [class*=\"lang-\"] code');for(var i=0,s;s=r[i++];)t.highlightElement(s,e===!0,n)},highlightElement:function(r,i,s){var o,u,a=r;while(a&&!e.test(a.className))a=a.parentNode;if(a){o=(a.className.match(e)||[,\"\"])[1];u=t.languages[o]}if(!u)return;r.className=r.className.replace(e,\"\").replace(/\\s+/g,\" \")+\" language-\"+o;a=r.parentNode;/pre/i.test(a.nodeName)&&(a.className=a.className.replace(e,\"\").replace(/\\s+/g,\" \")+\" language-\"+o);var f=r.textContent;if(!f)return;f=f.replace(/&/g,\"&amp;\").replace(/</g,\"&lt;\").replace(/\\u00a0/g,\" \");var l={element:r,language:o,grammar:u,code:f};t.hooks.run(\"before-highlight\",l);if(i&&self.Worker){var c=new Worker(t.filename);c.onmessage=function(e){l.highlightedCode=n.stringify(JSON.parse(e.data),o);t.hooks.run(\"before-insert\",l);l.element.innerHTML=l.highlightedCode;s&&s.call(l.element);t.hooks.run(\"after-highlight\",l)};c.postMessage(JSON.stringify({language:l.language,code:l.code}))}else{l.highlightedCode=t.highlight(l.code,l.grammar,l.language);t.hooks.run(\"before-insert\",l);l.element.innerHTML=l.highlightedCode;s&&s.call(r);t.hooks.run(\"after-highlight\",l)}},highlight:function(e,r,i){return n.stringify(t.tokenize(e,r),i)},tokenize:function(e,n,r){var i=t.Token,s=[e],o=n.rest;if(o){for(var u in o)n[u]=o[u];delete n.rest}e:for(var u in n){if(!n.hasOwnProperty(u)||!n[u])continue;var a=n[u],f=a.inside,l=!!a.lookbehind,c=0;a=a.pattern||a;for(var h=0;h<s.length;h++){var p=s[h];if(s.length>e.length)break e;if(p instanceof i)continue;a.lastIndex=0;var d=a.exec(p);if(d){l&&(c=d[1].length);var v=d.index-1+c,d=d[0].slice(c),m=d.length,g=v+m,y=p.slice(0,v+1),b=p.slice(g+1),w=[h,1];y&&w.push(y);var E=new i(u,f?t.tokenize(d,f):d);w.push(E);b&&w.push(b);Array.prototype.splice.apply(s,w)}}}return s},hooks:{all:{},add:function(e,n){var r=t.hooks.all;r[e]=r[e]||[];r[e].push(n)},run:function(e,n){var r=t.hooks.all[e];if(!r||!r.length)return;for(var i=0,s;s=r[i++];)s(n)}}},n=t.Token=function(e,t){this.type=e;this.content=t};n.stringify=function(e,r,i){if(typeof e==\"string\")return e;if(Object.prototype.toString.call(e)==\"[object Array]\")return e.map(function(t){return n.stringify(t,r,e)}).join(\"\");var s={type:e.type,content:n.stringify(e.content,r,i),tag:\"span\",classes:[\"token\",e.type],attributes:{},language:r,parent:i};s.type==\"comment\"&&(s.attributes.spellcheck=\"true\");t.hooks.run(\"wrap\",s);var o=\"\";for(var u in s.attributes)o+=u+'=\"'+(s.attributes[u]||\"\")+'\"';return\"<\"+s.tag+' class=\"'+s.classes.join(\" \")+'\" '+o+\">\"+s.content+\"</\"+s.tag+\">\"};if(!self.document){self.addEventListener(\"message\",function(e){var n=JSON.parse(e.data),r=n.language,i=n.code;self.postMessage(JSON.stringify(t.tokenize(i,t.languages[r])));self.close()},!1);return}var r=document.getElementsByTagName(\"script\");r=r[r.length-1];if(r){t.filename=r.src;document.addEventListener&&!r.hasAttribute(\"data-manual\")&&document.addEventListener(\"DOMContentLoaded\",t.highlightAll)}})();;\nPrism.languages.markup={comment:/&lt;!--[\\w\\W]*?-->/g,prolog:/&lt;\\?.+?\\?>/,doctype:/&lt;!DOCTYPE.+?>/,cdata:/&lt;!\\[CDATA\\[[\\w\\W]*?]]>/i,tag:{pattern:/&lt;\\/?[\\w:-]+\\s*(?:\\s+[\\w:-]+(?:=(?:(\"|')(\\\\?[\\w\\W])*?\\1|\\w+))?\\s*)*\\/?>/gi,inside:{tag:{pattern:/^&lt;\\/?[\\w:-]+/i,inside:{punctuation:/^&lt;\\/?/,namespace:/^[\\w-]+?:/}},\"attr-value\":{pattern:/=(?:('|\")[\\w\\W]*?(\\1)|[^\\s>]+)/gi,inside:{punctuation:/=|>|\"/g}},punctuation:/\\/?>/g,\"attr-name\":{pattern:/[\\w:-]+/g,inside:{namespace:/^[\\w-]+?:/}}}},entity:/&amp;#?[\\da-z]{1,8};/gi};Prism.hooks.add(\"wrap\",function(e){e.type===\"entity\"&&(e.attributes.title=e.content.replace(/&amp;/,\"&\"))});;\nPrism.languages.css={comment:/\\/\\*[\\w\\W]*?\\*\\//g,atrule:{pattern:/@[\\w-]+?.*?(;|(?=\\s*{))/gi,inside:{punctuation:/[;:]/g}},url:/url\\(([\"']?).*?\\1\\)/gi,selector:/[^\\{\\}\\s][^\\{\\};]*(?=\\s*\\{)/g,property:/(\\b|\\B)[\\w-]+(?=\\s*:)/ig,string:/(\"|')(\\\\?.)*?\\1/g,important:/\\B!important\\b/gi,ignore:/&(lt|gt|amp);/gi,punctuation:/[\\{\\};:]/g};Prism.languages.markup&&Prism.languages.insertBefore(\"markup\",\"tag\",{style:{pattern:/(&lt;|<)style[\\w\\W]*?(>|&gt;)[\\w\\W]*?(&lt;|<)\\/style(>|&gt;)/ig,inside:{tag:{pattern:/(&lt;|<)style[\\w\\W]*?(>|&gt;)|(&lt;|<)\\/style(>|&gt;)/ig,inside:Prism.languages.markup.tag.inside},rest:Prism.languages.css}}});;\nPrism.languages.clike={comment:{pattern:/(^|[^\\\\])(\\/\\*[\\w\\W]*?\\*\\/|(^|[^:])\\/\\/.*?(\\r?\\n|$))/g,lookbehind:!0},string:/(\"|')(\\\\?.)*?\\1/g,\"class-name\":{pattern:/((?:(?:class|interface|extends|implements|trait|instanceof|new)\\s+)|(?:catch\\s+\\())[a-z0-9_\\.\\\\]+/ig,lookbehind:!0,inside:{punctuation:/(\\.|\\\\)/}},keyword:/\\b(if|else|while|do|for|return|in|instanceof|function|new|try|catch|finally|null|break|continue)\\b/g,\"boolean\":/\\b(true|false)\\b/g,\"function\":{pattern:/[a-z0-9_]+\\(/ig,inside:{punctuation:/\\(/}}, number:/\\b-?(0x[\\dA-Fa-f]+|\\d*\\.?\\d+([Ee]-?\\d+)?)\\b/g,operator:/[-+]{1,2}|!|&lt;=?|>=?|={1,3}|(&amp;){1,2}|\\|?\\||\\?|\\*|\\/|\\~|\\^|\\%/g,ignore:/&(lt|gt|amp);/gi,punctuation:/[{}[\\];(),.:]/g};;\nPrism.languages.javascript=Prism.languages.extend(\"clike\",{keyword:/\\b(var|let|if|else|while|do|for|return|in|instanceof|function|new|with|typeof|try|catch|finally|null|break|continue)\\b/g,number:/\\b-?(0x[\\dA-Fa-f]+|\\d*\\.?\\d+([Ee]-?\\d+)?|NaN|-?Infinity)\\b/g});Prism.languages.insertBefore(\"javascript\",\"keyword\",{regex:{pattern:/(^|[^/])\\/(?!\\/)(\\[.+?]|\\\\.|[^/\\r\\n])+\\/[gim]{0,3}(?=\\s*($|[\\r\\n,.;})]))/g,lookbehind:!0}});Prism.languages.markup&&Prism.languages.insertBefore(\"markup\",\"tag\",{script:{pattern:/(&lt;|<)script[\\w\\W]*?(>|&gt;)[\\w\\W]*?(&lt;|<)\\/script(>|&gt;)/ig,inside:{tag:{pattern:/(&lt;|<)script[\\w\\W]*?(>|&gt;)|(&lt;|<)\\/script(>|&gt;)/ig,inside:Prism.languages.markup.tag.inside},rest:Prism.languages.javascript}}});;\n"
  },
  {
    "path": "public/docsupport/prototype-1.7.0.0.js",
    "content": "/*  Prototype JavaScript framework, version 1.7\n *  (c) 2005-2010 Sam Stephenson\n *\n *  Prototype is freely distributable under the terms of an MIT-style license.\n *  For details, see the Prototype web site: http://www.prototypejs.org/\n *\n *--------------------------------------------------------------------------*/\n\nvar Prototype = {\n\n  Version: '1.7',\n\n  Browser: (function(){\n    var ua = navigator.userAgent;\n    var isOpera = Object.prototype.toString.call(window.opera) == '[object Opera]';\n    return {\n      IE:             !!window.attachEvent && !isOpera,\n      Opera:          isOpera,\n      WebKit:         ua.indexOf('AppleWebKit/') > -1,\n      Gecko:          ua.indexOf('Gecko') > -1 && ua.indexOf('KHTML') === -1,\n      MobileSafari:   /Apple.*Mobile/.test(ua)\n    }\n  })(),\n\n  BrowserFeatures: {\n    XPath: !!document.evaluate,\n\n    SelectorsAPI: !!document.querySelector,\n\n    ElementExtensions: (function() {\n      var constructor = window.Element || window.HTMLElement;\n      return !!(constructor && constructor.prototype);\n    })(),\n    SpecificElementExtensions: (function() {\n      if (typeof window.HTMLDivElement !== 'undefined')\n        return true;\n\n      var div = document.createElement('div'),\n          form = document.createElement('form'),\n          isSupported = false;\n\n      if (div['__proto__'] && (div['__proto__'] !== form['__proto__'])) {\n        isSupported = true;\n      }\n\n      div = form = null;\n\n      return isSupported;\n    })()\n  },\n\n  ScriptFragment: '<script[^>]*>([\\\\S\\\\s]*?)<\\/script>',\n  JSONFilter: /^\\/\\*-secure-([\\s\\S]*)\\*\\/\\s*$/,\n\n  emptyFunction: function() { },\n\n  K: function(x) { return x }\n};\n\nif (Prototype.Browser.MobileSafari)\n  Prototype.BrowserFeatures.SpecificElementExtensions = false;\n\n\nvar Abstract = { };\n\n\nvar Try = {\n  these: function() {\n    var returnValue;\n\n    for (var i = 0, length = arguments.length; i < length; i++) {\n      var lambda = arguments[i];\n      try {\n        returnValue = lambda();\n        break;\n      } catch (e) { }\n    }\n\n    return returnValue;\n  }\n};\n\n/* Based on Alex Arnell's inheritance implementation. */\n\nvar Class = (function() {\n\n  var IS_DONTENUM_BUGGY = (function(){\n    for (var p in { toString: 1 }) {\n      if (p === 'toString') return false;\n    }\n    return true;\n  })();\n\n  function subclass() {};\n  function create() {\n    var parent = null, properties = $A(arguments);\n    if (Object.isFunction(properties[0]))\n      parent = properties.shift();\n\n    function klass() {\n      this.initialize.apply(this, arguments);\n    }\n\n    Object.extend(klass, Class.Methods);\n    klass.superclass = parent;\n    klass.subclasses = [];\n\n    if (parent) {\n      subclass.prototype = parent.prototype;\n      klass.prototype = new subclass;\n      parent.subclasses.push(klass);\n    }\n\n    for (var i = 0, length = properties.length; i < length; i++)\n      klass.addMethods(properties[i]);\n\n    if (!klass.prototype.initialize)\n      klass.prototype.initialize = Prototype.emptyFunction;\n\n    klass.prototype.constructor = klass;\n    return klass;\n  }\n\n  function addMethods(source) {\n    var ancestor   = this.superclass && this.superclass.prototype,\n        properties = Object.keys(source);\n\n    if (IS_DONTENUM_BUGGY) {\n      if (source.toString != Object.prototype.toString)\n        properties.push(\"toString\");\n      if (source.valueOf != Object.prototype.valueOf)\n        properties.push(\"valueOf\");\n    }\n\n    for (var i = 0, length = properties.length; i < length; i++) {\n      var property = properties[i], value = source[property];\n      if (ancestor && Object.isFunction(value) &&\n          value.argumentNames()[0] == \"$super\") {\n        var method = value;\n        value = (function(m) {\n          return function() { return ancestor[m].apply(this, arguments); };\n        })(property).wrap(method);\n\n        value.valueOf = method.valueOf.bind(method);\n        value.toString = method.toString.bind(method);\n      }\n      this.prototype[property] = value;\n    }\n\n    return this;\n  }\n\n  return {\n    create: create,\n    Methods: {\n      addMethods: addMethods\n    }\n  };\n})();\n(function() {\n\n  var _toString = Object.prototype.toString,\n      NULL_TYPE = 'Null',\n      UNDEFINED_TYPE = 'Undefined',\n      BOOLEAN_TYPE = 'Boolean',\n      NUMBER_TYPE = 'Number',\n      STRING_TYPE = 'String',\n      OBJECT_TYPE = 'Object',\n      FUNCTION_CLASS = '[object Function]',\n      BOOLEAN_CLASS = '[object Boolean]',\n      NUMBER_CLASS = '[object Number]',\n      STRING_CLASS = '[object String]',\n      ARRAY_CLASS = '[object Array]',\n      DATE_CLASS = '[object Date]',\n      NATIVE_JSON_STRINGIFY_SUPPORT = window.JSON &&\n        typeof JSON.stringify === 'function' &&\n        JSON.stringify(0) === '0' &&\n        typeof JSON.stringify(Prototype.K) === 'undefined';\n\n  function Type(o) {\n    switch(o) {\n      case null: return NULL_TYPE;\n      case (void 0): return UNDEFINED_TYPE;\n    }\n    var type = typeof o;\n    switch(type) {\n      case 'boolean': return BOOLEAN_TYPE;\n      case 'number':  return NUMBER_TYPE;\n      case 'string':  return STRING_TYPE;\n    }\n    return OBJECT_TYPE;\n  }\n\n  function extend(destination, source) {\n    for (var property in source)\n      destination[property] = source[property];\n    return destination;\n  }\n\n  function inspect(object) {\n    try {\n      if (isUndefined(object)) return 'undefined';\n      if (object === null) return 'null';\n      return object.inspect ? object.inspect() : String(object);\n    } catch (e) {\n      if (e instanceof RangeError) return '...';\n      throw e;\n    }\n  }\n\n  function toJSON(value) {\n    return Str('', { '': value }, []);\n  }\n\n  function Str(key, holder, stack) {\n    var value = holder[key],\n        type = typeof value;\n\n    if (Type(value) === OBJECT_TYPE && typeof value.toJSON === 'function') {\n      value = value.toJSON(key);\n    }\n\n    var _class = _toString.call(value);\n\n    switch (_class) {\n      case NUMBER_CLASS:\n      case BOOLEAN_CLASS:\n      case STRING_CLASS:\n        value = value.valueOf();\n    }\n\n    switch (value) {\n      case null: return 'null';\n      case true: return 'true';\n      case false: return 'false';\n    }\n\n    type = typeof value;\n    switch (type) {\n      case 'string':\n        return value.inspect(true);\n      case 'number':\n        return isFinite(value) ? String(value) : 'null';\n      case 'object':\n\n        for (var i = 0, length = stack.length; i < length; i++) {\n          if (stack[i] === value) { throw new TypeError(); }\n        }\n        stack.push(value);\n\n        var partial = [];\n        if (_class === ARRAY_CLASS) {\n          for (var i = 0, length = value.length; i < length; i++) {\n            var str = Str(i, value, stack);\n            partial.push(typeof str === 'undefined' ? 'null' : str);\n          }\n          partial = '[' + partial.join(',') + ']';\n        } else {\n          var keys = Object.keys(value);\n          for (var i = 0, length = keys.length; i < length; i++) {\n            var key = keys[i], str = Str(key, value, stack);\n            if (typeof str !== \"undefined\") {\n               partial.push(key.inspect(true)+ ':' + str);\n             }\n          }\n          partial = '{' + partial.join(',') + '}';\n        }\n        stack.pop();\n        return partial;\n    }\n  }\n\n  function stringify(object) {\n    return JSON.stringify(object);\n  }\n\n  function toQueryString(object) {\n    return $H(object).toQueryString();\n  }\n\n  function toHTML(object) {\n    return object && object.toHTML ? object.toHTML() : String.interpret(object);\n  }\n\n  function keys(object) {\n    if (Type(object) !== OBJECT_TYPE) { throw new TypeError(); }\n    var results = [];\n    for (var property in object) {\n      if (object.hasOwnProperty(property)) {\n        results.push(property);\n      }\n    }\n    return results;\n  }\n\n  function values(object) {\n    var results = [];\n    for (var property in object)\n      results.push(object[property]);\n    return results;\n  }\n\n  function clone(object) {\n    return extend({ }, object);\n  }\n\n  function isElement(object) {\n    return !!(object && object.nodeType == 1);\n  }\n\n  function isArray(object) {\n    return _toString.call(object) === ARRAY_CLASS;\n  }\n\n  var hasNativeIsArray = (typeof Array.isArray == 'function')\n    && Array.isArray([]) && !Array.isArray({});\n\n  if (hasNativeIsArray) {\n    isArray = Array.isArray;\n  }\n\n  function isHash(object) {\n    return object instanceof Hash;\n  }\n\n  function isFunction(object) {\n    return _toString.call(object) === FUNCTION_CLASS;\n  }\n\n  function isString(object) {\n    return _toString.call(object) === STRING_CLASS;\n  }\n\n  function isNumber(object) {\n    return _toString.call(object) === NUMBER_CLASS;\n  }\n\n  function isDate(object) {\n    return _toString.call(object) === DATE_CLASS;\n  }\n\n  function isUndefined(object) {\n    return typeof object === \"undefined\";\n  }\n\n  extend(Object, {\n    extend:        extend,\n    inspect:       inspect,\n    toJSON:        NATIVE_JSON_STRINGIFY_SUPPORT ? stringify : toJSON,\n    toQueryString: toQueryString,\n    toHTML:        toHTML,\n    keys:          Object.keys || keys,\n    values:        values,\n    clone:         clone,\n    isElement:     isElement,\n    isArray:       isArray,\n    isHash:        isHash,\n    isFunction:    isFunction,\n    isString:      isString,\n    isNumber:      isNumber,\n    isDate:        isDate,\n    isUndefined:   isUndefined\n  });\n})();\nObject.extend(Function.prototype, (function() {\n  var slice = Array.prototype.slice;\n\n  function update(array, args) {\n    var arrayLength = array.length, length = args.length;\n    while (length--) array[arrayLength + length] = args[length];\n    return array;\n  }\n\n  function merge(array, args) {\n    array = slice.call(array, 0);\n    return update(array, args);\n  }\n\n  function argumentNames() {\n    var names = this.toString().match(/^[\\s\\(]*function[^(]*\\(([^)]*)\\)/)[1]\n      .replace(/\\/\\/.*?[\\r\\n]|\\/\\*(?:.|[\\r\\n])*?\\*\\//g, '')\n      .replace(/\\s+/g, '').split(',');\n    return names.length == 1 && !names[0] ? [] : names;\n  }\n\n  function bind(context) {\n    if (arguments.length < 2 && Object.isUndefined(arguments[0])) return this;\n    var __method = this, args = slice.call(arguments, 1);\n    return function() {\n      var a = merge(args, arguments);\n      return __method.apply(context, a);\n    }\n  }\n\n  function bindAsEventListener(context) {\n    var __method = this, args = slice.call(arguments, 1);\n    return function(event) {\n      var a = update([event || window.event], args);\n      return __method.apply(context, a);\n    }\n  }\n\n  function curry() {\n    if (!arguments.length) return this;\n    var __method = this, args = slice.call(arguments, 0);\n    return function() {\n      var a = merge(args, arguments);\n      return __method.apply(this, a);\n    }\n  }\n\n  function delay(timeout) {\n    var __method = this, args = slice.call(arguments, 1);\n    timeout = timeout * 1000;\n    return window.setTimeout(function() {\n      return __method.apply(__method, args);\n    }, timeout);\n  }\n\n  function defer() {\n    var args = update([0.01], arguments);\n    return this.delay.apply(this, args);\n  }\n\n  function wrap(wrapper) {\n    var __method = this;\n    return function() {\n      var a = update([__method.bind(this)], arguments);\n      return wrapper.apply(this, a);\n    }\n  }\n\n  function methodize() {\n    if (this._methodized) return this._methodized;\n    var __method = this;\n    return this._methodized = function() {\n      var a = update([this], arguments);\n      return __method.apply(null, a);\n    };\n  }\n\n  return {\n    argumentNames:       argumentNames,\n    bind:                bind,\n    bindAsEventListener: bindAsEventListener,\n    curry:               curry,\n    delay:               delay,\n    defer:               defer,\n    wrap:                wrap,\n    methodize:           methodize\n  }\n})());\n\n\n\n(function(proto) {\n\n\n  function toISOString() {\n    return this.getUTCFullYear() + '-' +\n      (this.getUTCMonth() + 1).toPaddedString(2) + '-' +\n      this.getUTCDate().toPaddedString(2) + 'T' +\n      this.getUTCHours().toPaddedString(2) + ':' +\n      this.getUTCMinutes().toPaddedString(2) + ':' +\n      this.getUTCSeconds().toPaddedString(2) + 'Z';\n  }\n\n\n  function toJSON() {\n    return this.toISOString();\n  }\n\n  if (!proto.toISOString) proto.toISOString = toISOString;\n  if (!proto.toJSON) proto.toJSON = toJSON;\n\n})(Date.prototype);\n\n\nRegExp.prototype.match = RegExp.prototype.test;\n\nRegExp.escape = function(str) {\n  return String(str).replace(/([.*+?^=!:${}()|[\\]\\/\\\\])/g, '\\\\$1');\n};\nvar PeriodicalExecuter = Class.create({\n  initialize: function(callback, frequency) {\n    this.callback = callback;\n    this.frequency = frequency;\n    this.currentlyExecuting = false;\n\n    this.registerCallback();\n  },\n\n  registerCallback: function() {\n    this.timer = setInterval(this.onTimerEvent.bind(this), this.frequency * 1000);\n  },\n\n  execute: function() {\n    this.callback(this);\n  },\n\n  stop: function() {\n    if (!this.timer) return;\n    clearInterval(this.timer);\n    this.timer = null;\n  },\n\n  onTimerEvent: function() {\n    if (!this.currentlyExecuting) {\n      try {\n        this.currentlyExecuting = true;\n        this.execute();\n        this.currentlyExecuting = false;\n      } catch(e) {\n        this.currentlyExecuting = false;\n        throw e;\n      }\n    }\n  }\n});\nObject.extend(String, {\n  interpret: function(value) {\n    return value == null ? '' : String(value);\n  },\n  specialChar: {\n    '\\b': '\\\\b',\n    '\\t': '\\\\t',\n    '\\n': '\\\\n',\n    '\\f': '\\\\f',\n    '\\r': '\\\\r',\n    '\\\\': '\\\\\\\\'\n  }\n});\n\nObject.extend(String.prototype, (function() {\n  var NATIVE_JSON_PARSE_SUPPORT = window.JSON &&\n    typeof JSON.parse === 'function' &&\n    JSON.parse('{\"test\": true}').test;\n\n  function prepareReplacement(replacement) {\n    if (Object.isFunction(replacement)) return replacement;\n    var template = new Template(replacement);\n    return function(match) { return template.evaluate(match) };\n  }\n\n  function gsub(pattern, replacement) {\n    var result = '', source = this, match;\n    replacement = prepareReplacement(replacement);\n\n    if (Object.isString(pattern))\n      pattern = RegExp.escape(pattern);\n\n    if (!(pattern.length || pattern.source)) {\n      replacement = replacement('');\n      return replacement + source.split('').join(replacement) + replacement;\n    }\n\n    while (source.length > 0) {\n      if (match = source.match(pattern)) {\n        result += source.slice(0, match.index);\n        result += String.interpret(replacement(match));\n        source  = source.slice(match.index + match[0].length);\n      } else {\n        result += source, source = '';\n      }\n    }\n    return result;\n  }\n\n  function sub(pattern, replacement, count) {\n    replacement = prepareReplacement(replacement);\n    count = Object.isUndefined(count) ? 1 : count;\n\n    return this.gsub(pattern, function(match) {\n      if (--count < 0) return match[0];\n      return replacement(match);\n    });\n  }\n\n  function scan(pattern, iterator) {\n    this.gsub(pattern, iterator);\n    return String(this);\n  }\n\n  function truncate(length, truncation) {\n    length = length || 30;\n    truncation = Object.isUndefined(truncation) ? '...' : truncation;\n    return this.length > length ?\n      this.slice(0, length - truncation.length) + truncation : String(this);\n  }\n\n  function strip() {\n    return this.replace(/^\\s+/, '').replace(/\\s+$/, '');\n  }\n\n  function stripTags() {\n    return this.replace(/<\\w+(\\s+(\"[^\"]*\"|'[^']*'|[^>])+)?>|<\\/\\w+>/gi, '');\n  }\n\n  function stripScripts() {\n    return this.replace(new RegExp(Prototype.ScriptFragment, 'img'), '');\n  }\n\n  function extractScripts() {\n    var matchAll = new RegExp(Prototype.ScriptFragment, 'img'),\n        matchOne = new RegExp(Prototype.ScriptFragment, 'im');\n    return (this.match(matchAll) || []).map(function(scriptTag) {\n      return (scriptTag.match(matchOne) || ['', ''])[1];\n    });\n  }\n\n  function evalScripts() {\n    return this.extractScripts().map(function(script) { return eval(script) });\n  }\n\n  function escapeHTML() {\n    return this.replace(/&/g,'&amp;').replace(/</g,'&lt;').replace(/>/g,'&gt;');\n  }\n\n  function unescapeHTML() {\n    return this.stripTags().replace(/&lt;/g,'<').replace(/&gt;/g,'>').replace(/&amp;/g,'&');\n  }\n\n\n  function toQueryParams(separator) {\n    var match = this.strip().match(/([^?#]*)(#.*)?$/);\n    if (!match) return { };\n\n    return match[1].split(separator || '&').inject({ }, function(hash, pair) {\n      if ((pair = pair.split('='))[0]) {\n        var key = decodeURIComponent(pair.shift()),\n            value = pair.length > 1 ? pair.join('=') : pair[0];\n\n        if (value != undefined) value = decodeURIComponent(value);\n\n        if (key in hash) {\n          if (!Object.isArray(hash[key])) hash[key] = [hash[key]];\n          hash[key].push(value);\n        }\n        else hash[key] = value;\n      }\n      return hash;\n    });\n  }\n\n  function toArray() {\n    return this.split('');\n  }\n\n  function succ() {\n    return this.slice(0, this.length - 1) +\n      String.fromCharCode(this.charCodeAt(this.length - 1) + 1);\n  }\n\n  function times(count) {\n    return count < 1 ? '' : new Array(count + 1).join(this);\n  }\n\n  function camelize() {\n    return this.replace(/-+(.)?/g, function(match, chr) {\n      return chr ? chr.toUpperCase() : '';\n    });\n  }\n\n  function capitalize() {\n    return this.charAt(0).toUpperCase() + this.substring(1).toLowerCase();\n  }\n\n  function underscore() {\n    return this.replace(/::/g, '/')\n               .replace(/([A-Z]+)([A-Z][a-z])/g, '$1_$2')\n               .replace(/([a-z\\d])([A-Z])/g, '$1_$2')\n               .replace(/-/g, '_')\n               .toLowerCase();\n  }\n\n  function dasherize() {\n    return this.replace(/_/g, '-');\n  }\n\n  function inspect(useDoubleQuotes) {\n    var escapedString = this.replace(/[\\x00-\\x1f\\\\]/g, function(character) {\n      if (character in String.specialChar) {\n        return String.specialChar[character];\n      }\n      return '\\\\u00' + character.charCodeAt().toPaddedString(2, 16);\n    });\n    if (useDoubleQuotes) return '\"' + escapedString.replace(/\"/g, '\\\\\"') + '\"';\n    return \"'\" + escapedString.replace(/'/g, '\\\\\\'') + \"'\";\n  }\n\n  function unfilterJSON(filter) {\n    return this.replace(filter || Prototype.JSONFilter, '$1');\n  }\n\n  function isJSON() {\n    var str = this;\n    if (str.blank()) return false;\n    str = str.replace(/\\\\(?:[\"\\\\\\/bfnrt]|u[0-9a-fA-F]{4})/g, '@');\n    str = str.replace(/\"[^\"\\\\\\n\\r]*\"|true|false|null|-?\\d+(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/g, ']');\n    str = str.replace(/(?:^|:|,)(?:\\s*\\[)+/g, '');\n    return (/^[\\],:{}\\s]*$/).test(str);\n  }\n\n  function evalJSON(sanitize) {\n    var json = this.unfilterJSON(),\n        cx = /[\\u0000\\u00ad\\u0600-\\u0604\\u070f\\u17b4\\u17b5\\u200c-\\u200f\\u2028-\\u202f\\u2060-\\u206f\\ufeff\\ufff0-\\uffff]/g;\n    if (cx.test(json)) {\n      json = json.replace(cx, function (a) {\n        return '\\\\u' + ('0000' + a.charCodeAt(0).toString(16)).slice(-4);\n      });\n    }\n    try {\n      if (!sanitize || json.isJSON()) return eval('(' + json + ')');\n    } catch (e) { }\n    throw new SyntaxError('Badly formed JSON string: ' + this.inspect());\n  }\n\n  function parseJSON() {\n    var json = this.unfilterJSON();\n    return JSON.parse(json);\n  }\n\n  function include(pattern) {\n    return this.indexOf(pattern) > -1;\n  }\n\n  function startsWith(pattern) {\n    return this.lastIndexOf(pattern, 0) === 0;\n  }\n\n  function endsWith(pattern) {\n    var d = this.length - pattern.length;\n    return d >= 0 && this.indexOf(pattern, d) === d;\n  }\n\n  function empty() {\n    return this == '';\n  }\n\n  function blank() {\n    return /^\\s*$/.test(this);\n  }\n\n  function interpolate(object, pattern) {\n    return new Template(this, pattern).evaluate(object);\n  }\n\n  return {\n    gsub:           gsub,\n    sub:            sub,\n    scan:           scan,\n    truncate:       truncate,\n    strip:          String.prototype.trim || strip,\n    stripTags:      stripTags,\n    stripScripts:   stripScripts,\n    extractScripts: extractScripts,\n    evalScripts:    evalScripts,\n    escapeHTML:     escapeHTML,\n    unescapeHTML:   unescapeHTML,\n    toQueryParams:  toQueryParams,\n    parseQuery:     toQueryParams,\n    toArray:        toArray,\n    succ:           succ,\n    times:          times,\n    camelize:       camelize,\n    capitalize:     capitalize,\n    underscore:     underscore,\n    dasherize:      dasherize,\n    inspect:        inspect,\n    unfilterJSON:   unfilterJSON,\n    isJSON:         isJSON,\n    evalJSON:       NATIVE_JSON_PARSE_SUPPORT ? parseJSON : evalJSON,\n    include:        include,\n    startsWith:     startsWith,\n    endsWith:       endsWith,\n    empty:          empty,\n    blank:          blank,\n    interpolate:    interpolate\n  };\n})());\n\nvar Template = Class.create({\n  initialize: function(template, pattern) {\n    this.template = template.toString();\n    this.pattern = pattern || Template.Pattern;\n  },\n\n  evaluate: function(object) {\n    if (object && Object.isFunction(object.toTemplateReplacements))\n      object = object.toTemplateReplacements();\n\n    return this.template.gsub(this.pattern, function(match) {\n      if (object == null) return (match[1] + '');\n\n      var before = match[1] || '';\n      if (before == '\\\\') return match[2];\n\n      var ctx = object, expr = match[3],\n          pattern = /^([^.[]+|\\[((?:.*?[^\\\\])?)\\])(\\.|\\[|$)/;\n\n      match = pattern.exec(expr);\n      if (match == null) return before;\n\n      while (match != null) {\n        var comp = match[1].startsWith('[') ? match[2].replace(/\\\\\\\\]/g, ']') : match[1];\n        ctx = ctx[comp];\n        if (null == ctx || '' == match[3]) break;\n        expr = expr.substring('[' == match[3] ? match[1].length : match[0].length);\n        match = pattern.exec(expr);\n      }\n\n      return before + String.interpret(ctx);\n    });\n  }\n});\nTemplate.Pattern = /(^|.|\\r|\\n)(#\\{(.*?)\\})/;\n\nvar $break = { };\n\nvar Enumerable = (function() {\n  function each(iterator, context) {\n    var index = 0;\n    try {\n      this._each(function(value) {\n        iterator.call(context, value, index++);\n      });\n    } catch (e) {\n      if (e != $break) throw e;\n    }\n    return this;\n  }\n\n  function eachSlice(number, iterator, context) {\n    var index = -number, slices = [], array = this.toArray();\n    if (number < 1) return array;\n    while ((index += number) < array.length)\n      slices.push(array.slice(index, index+number));\n    return slices.collect(iterator, context);\n  }\n\n  function all(iterator, context) {\n    iterator = iterator || Prototype.K;\n    var result = true;\n    this.each(function(value, index) {\n      result = result && !!iterator.call(context, value, index);\n      if (!result) throw $break;\n    });\n    return result;\n  }\n\n  function any(iterator, context) {\n    iterator = iterator || Prototype.K;\n    var result = false;\n    this.each(function(value, index) {\n      if (result = !!iterator.call(context, value, index))\n        throw $break;\n    });\n    return result;\n  }\n\n  function collect(iterator, context) {\n    iterator = iterator || Prototype.K;\n    var results = [];\n    this.each(function(value, index) {\n      results.push(iterator.call(context, value, index));\n    });\n    return results;\n  }\n\n  function detect(iterator, context) {\n    var result;\n    this.each(function(value, index) {\n      if (iterator.call(context, value, index)) {\n        result = value;\n        throw $break;\n      }\n    });\n    return result;\n  }\n\n  function findAll(iterator, context) {\n    var results = [];\n    this.each(function(value, index) {\n      if (iterator.call(context, value, index))\n        results.push(value);\n    });\n    return results;\n  }\n\n  function grep(filter, iterator, context) {\n    iterator = iterator || Prototype.K;\n    var results = [];\n\n    if (Object.isString(filter))\n      filter = new RegExp(RegExp.escape(filter));\n\n    this.each(function(value, index) {\n      if (filter.match(value))\n        results.push(iterator.call(context, value, index));\n    });\n    return results;\n  }\n\n  function include(object) {\n    if (Object.isFunction(this.indexOf))\n      if (this.indexOf(object) != -1) return true;\n\n    var found = false;\n    this.each(function(value) {\n      if (value == object) {\n        found = true;\n        throw $break;\n      }\n    });\n    return found;\n  }\n\n  function inGroupsOf(number, fillWith) {\n    fillWith = Object.isUndefined(fillWith) ? null : fillWith;\n    return this.eachSlice(number, function(slice) {\n      while(slice.length < number) slice.push(fillWith);\n      return slice;\n    });\n  }\n\n  function inject(memo, iterator, context) {\n    this.each(function(value, index) {\n      memo = iterator.call(context, memo, value, index);\n    });\n    return memo;\n  }\n\n  function invoke(method) {\n    var args = $A(arguments).slice(1);\n    return this.map(function(value) {\n      return value[method].apply(value, args);\n    });\n  }\n\n  function max(iterator, context) {\n    iterator = iterator || Prototype.K;\n    var result;\n    this.each(function(value, index) {\n      value = iterator.call(context, value, index);\n      if (result == null || value >= result)\n        result = value;\n    });\n    return result;\n  }\n\n  function min(iterator, context) {\n    iterator = iterator || Prototype.K;\n    var result;\n    this.each(function(value, index) {\n      value = iterator.call(context, value, index);\n      if (result == null || value < result)\n        result = value;\n    });\n    return result;\n  }\n\n  function partition(iterator, context) {\n    iterator = iterator || Prototype.K;\n    var trues = [], falses = [];\n    this.each(function(value, index) {\n      (iterator.call(context, value, index) ?\n        trues : falses).push(value);\n    });\n    return [trues, falses];\n  }\n\n  function pluck(property) {\n    var results = [];\n    this.each(function(value) {\n      results.push(value[property]);\n    });\n    return results;\n  }\n\n  function reject(iterator, context) {\n    var results = [];\n    this.each(function(value, index) {\n      if (!iterator.call(context, value, index))\n        results.push(value);\n    });\n    return results;\n  }\n\n  function sortBy(iterator, context) {\n    return this.map(function(value, index) {\n      return {\n        value: value,\n        criteria: iterator.call(context, value, index)\n      };\n    }).sort(function(left, right) {\n      var a = left.criteria, b = right.criteria;\n      return a < b ? -1 : a > b ? 1 : 0;\n    }).pluck('value');\n  }\n\n  function toArray() {\n    return this.map();\n  }\n\n  function zip() {\n    var iterator = Prototype.K, args = $A(arguments);\n    if (Object.isFunction(args.last()))\n      iterator = args.pop();\n\n    var collections = [this].concat(args).map($A);\n    return this.map(function(value, index) {\n      return iterator(collections.pluck(index));\n    });\n  }\n\n  function size() {\n    return this.toArray().length;\n  }\n\n  function inspect() {\n    return '#<Enumerable:' + this.toArray().inspect() + '>';\n  }\n\n\n\n\n\n\n\n\n\n  return {\n    each:       each,\n    eachSlice:  eachSlice,\n    all:        all,\n    every:      all,\n    any:        any,\n    some:       any,\n    collect:    collect,\n    map:        collect,\n    detect:     detect,\n    findAll:    findAll,\n    select:     findAll,\n    filter:     findAll,\n    grep:       grep,\n    include:    include,\n    member:     include,\n    inGroupsOf: inGroupsOf,\n    inject:     inject,\n    invoke:     invoke,\n    max:        max,\n    min:        min,\n    partition:  partition,\n    pluck:      pluck,\n    reject:     reject,\n    sortBy:     sortBy,\n    toArray:    toArray,\n    entries:    toArray,\n    zip:        zip,\n    size:       size,\n    inspect:    inspect,\n    find:       detect\n  };\n})();\n\nfunction $A(iterable) {\n  if (!iterable) return [];\n  if ('toArray' in Object(iterable)) return iterable.toArray();\n  var length = iterable.length || 0, results = new Array(length);\n  while (length--) results[length] = iterable[length];\n  return results;\n}\n\n\nfunction $w(string) {\n  if (!Object.isString(string)) return [];\n  string = string.strip();\n  return string ? string.split(/\\s+/) : [];\n}\n\nArray.from = $A;\n\n\n(function() {\n  var arrayProto = Array.prototype,\n      slice = arrayProto.slice,\n      _each = arrayProto.forEach; // use native browser JS 1.6 implementation if available\n\n  function each(iterator, context) {\n    for (var i = 0, length = this.length >>> 0; i < length; i++) {\n      if (i in this) iterator.call(context, this[i], i, this);\n    }\n  }\n  if (!_each) _each = each;\n\n  function clear() {\n    this.length = 0;\n    return this;\n  }\n\n  function first() {\n    return this[0];\n  }\n\n  function last() {\n    return this[this.length - 1];\n  }\n\n  function compact() {\n    return this.select(function(value) {\n      return value != null;\n    });\n  }\n\n  function flatten() {\n    return this.inject([], function(array, value) {\n      if (Object.isArray(value))\n        return array.concat(value.flatten());\n      array.push(value);\n      return array;\n    });\n  }\n\n  function without() {\n    var values = slice.call(arguments, 0);\n    return this.select(function(value) {\n      return !values.include(value);\n    });\n  }\n\n  function reverse(inline) {\n    return (inline === false ? this.toArray() : this)._reverse();\n  }\n\n  function uniq(sorted) {\n    return this.inject([], function(array, value, index) {\n      if (0 == index || (sorted ? array.last() != value : !array.include(value)))\n        array.push(value);\n      return array;\n    });\n  }\n\n  function intersect(array) {\n    return this.uniq().findAll(function(item) {\n      return array.detect(function(value) { return item === value });\n    });\n  }\n\n\n  function clone() {\n    return slice.call(this, 0);\n  }\n\n  function size() {\n    return this.length;\n  }\n\n  function inspect() {\n    return '[' + this.map(Object.inspect).join(', ') + ']';\n  }\n\n  function indexOf(item, i) {\n    i || (i = 0);\n    var length = this.length;\n    if (i < 0) i = length + i;\n    for (; i < length; i++)\n      if (this[i] === item) return i;\n    return -1;\n  }\n\n  function lastIndexOf(item, i) {\n    i = isNaN(i) ? this.length : (i < 0 ? this.length + i : i) + 1;\n    var n = this.slice(0, i).reverse().indexOf(item);\n    return (n < 0) ? n : i - n - 1;\n  }\n\n  function concat() {\n    var array = slice.call(this, 0), item;\n    for (var i = 0, length = arguments.length; i < length; i++) {\n      item = arguments[i];\n      if (Object.isArray(item) && !('callee' in item)) {\n        for (var j = 0, arrayLength = item.length; j < arrayLength; j++)\n          array.push(item[j]);\n      } else {\n        array.push(item);\n      }\n    }\n    return array;\n  }\n\n  Object.extend(arrayProto, Enumerable);\n\n  if (!arrayProto._reverse)\n    arrayProto._reverse = arrayProto.reverse;\n\n  Object.extend(arrayProto, {\n    _each:     _each,\n    clear:     clear,\n    first:     first,\n    last:      last,\n    compact:   compact,\n    flatten:   flatten,\n    without:   without,\n    reverse:   reverse,\n    uniq:      uniq,\n    intersect: intersect,\n    clone:     clone,\n    toArray:   clone,\n    size:      size,\n    inspect:   inspect\n  });\n\n  var CONCAT_ARGUMENTS_BUGGY = (function() {\n    return [].concat(arguments)[0][0] !== 1;\n  })(1,2)\n\n  if (CONCAT_ARGUMENTS_BUGGY) arrayProto.concat = concat;\n\n  if (!arrayProto.indexOf) arrayProto.indexOf = indexOf;\n  if (!arrayProto.lastIndexOf) arrayProto.lastIndexOf = lastIndexOf;\n})();\nfunction $H(object) {\n  return new Hash(object);\n};\n\nvar Hash = Class.create(Enumerable, (function() {\n  function initialize(object) {\n    this._object = Object.isHash(object) ? object.toObject() : Object.clone(object);\n  }\n\n\n  function _each(iterator) {\n    for (var key in this._object) {\n      var value = this._object[key], pair = [key, value];\n      pair.key = key;\n      pair.value = value;\n      iterator(pair);\n    }\n  }\n\n  function set(key, value) {\n    return this._object[key] = value;\n  }\n\n  function get(key) {\n    if (this._object[key] !== Object.prototype[key])\n      return this._object[key];\n  }\n\n  function unset(key) {\n    var value = this._object[key];\n    delete this._object[key];\n    return value;\n  }\n\n  function toObject() {\n    return Object.clone(this._object);\n  }\n\n\n\n  function keys() {\n    return this.pluck('key');\n  }\n\n  function values() {\n    return this.pluck('value');\n  }\n\n  function index(value) {\n    var match = this.detect(function(pair) {\n      return pair.value === value;\n    });\n    return match && match.key;\n  }\n\n  function merge(object) {\n    return this.clone().update(object);\n  }\n\n  function update(object) {\n    return new Hash(object).inject(this, function(result, pair) {\n      result.set(pair.key, pair.value);\n      return result;\n    });\n  }\n\n  function toQueryPair(key, value) {\n    if (Object.isUndefined(value)) return key;\n    return key + '=' + encodeURIComponent(String.interpret(value));\n  }\n\n  function toQueryString() {\n    return this.inject([], function(results, pair) {\n      var key = encodeURIComponent(pair.key), values = pair.value;\n\n      if (values && typeof values == 'object') {\n        if (Object.isArray(values)) {\n          var queryValues = [];\n          for (var i = 0, len = values.length, value; i < len; i++) {\n            value = values[i];\n            queryValues.push(toQueryPair(key, value));\n          }\n          return results.concat(queryValues);\n        }\n      } else results.push(toQueryPair(key, values));\n      return results;\n    }).join('&');\n  }\n\n  function inspect() {\n    return '#<Hash:{' + this.map(function(pair) {\n      return pair.map(Object.inspect).join(': ');\n    }).join(', ') + '}>';\n  }\n\n  function clone() {\n    return new Hash(this);\n  }\n\n  return {\n    initialize:             initialize,\n    _each:                  _each,\n    set:                    set,\n    get:                    get,\n    unset:                  unset,\n    toObject:               toObject,\n    toTemplateReplacements: toObject,\n    keys:                   keys,\n    values:                 values,\n    index:                  index,\n    merge:                  merge,\n    update:                 update,\n    toQueryString:          toQueryString,\n    inspect:                inspect,\n    toJSON:                 toObject,\n    clone:                  clone\n  };\n})());\n\nHash.from = $H;\nObject.extend(Number.prototype, (function() {\n  function toColorPart() {\n    return this.toPaddedString(2, 16);\n  }\n\n  function succ() {\n    return this + 1;\n  }\n\n  function times(iterator, context) {\n    $R(0, this, true).each(iterator, context);\n    return this;\n  }\n\n  function toPaddedString(length, radix) {\n    var string = this.toString(radix || 10);\n    return '0'.times(length - string.length) + string;\n  }\n\n  function abs() {\n    return Math.abs(this);\n  }\n\n  function round() {\n    return Math.round(this);\n  }\n\n  function ceil() {\n    return Math.ceil(this);\n  }\n\n  function floor() {\n    return Math.floor(this);\n  }\n\n  return {\n    toColorPart:    toColorPart,\n    succ:           succ,\n    times:          times,\n    toPaddedString: toPaddedString,\n    abs:            abs,\n    round:          round,\n    ceil:           ceil,\n    floor:          floor\n  };\n})());\n\nfunction $R(start, end, exclusive) {\n  return new ObjectRange(start, end, exclusive);\n}\n\nvar ObjectRange = Class.create(Enumerable, (function() {\n  function initialize(start, end, exclusive) {\n    this.start = start;\n    this.end = end;\n    this.exclusive = exclusive;\n  }\n\n  function _each(iterator) {\n    var value = this.start;\n    while (this.include(value)) {\n      iterator(value);\n      value = value.succ();\n    }\n  }\n\n  function include(value) {\n    if (value < this.start)\n      return false;\n    if (this.exclusive)\n      return value < this.end;\n    return value <= this.end;\n  }\n\n  return {\n    initialize: initialize,\n    _each:      _each,\n    include:    include\n  };\n})());\n\n\n\nvar Ajax = {\n  getTransport: function() {\n    return Try.these(\n      function() {return new XMLHttpRequest()},\n      function() {return new ActiveXObject('Msxml2.XMLHTTP')},\n      function() {return new ActiveXObject('Microsoft.XMLHTTP')}\n    ) || false;\n  },\n\n  activeRequestCount: 0\n};\n\nAjax.Responders = {\n  responders: [],\n\n  _each: function(iterator) {\n    this.responders._each(iterator);\n  },\n\n  register: function(responder) {\n    if (!this.include(responder))\n      this.responders.push(responder);\n  },\n\n  unregister: function(responder) {\n    this.responders = this.responders.without(responder);\n  },\n\n  dispatch: function(callback, request, transport, json) {\n    this.each(function(responder) {\n      if (Object.isFunction(responder[callback])) {\n        try {\n          responder[callback].apply(responder, [request, transport, json]);\n        } catch (e) { }\n      }\n    });\n  }\n};\n\nObject.extend(Ajax.Responders, Enumerable);\n\nAjax.Responders.register({\n  onCreate:   function() { Ajax.activeRequestCount++ },\n  onComplete: function() { Ajax.activeRequestCount-- }\n});\nAjax.Base = Class.create({\n  initialize: function(options) {\n    this.options = {\n      method:       'post',\n      asynchronous: true,\n      contentType:  'application/x-www-form-urlencoded',\n      encoding:     'UTF-8',\n      parameters:   '',\n      evalJSON:     true,\n      evalJS:       true\n    };\n    Object.extend(this.options, options || { });\n\n    this.options.method = this.options.method.toLowerCase();\n\n    if (Object.isHash(this.options.parameters))\n      this.options.parameters = this.options.parameters.toObject();\n  }\n});\nAjax.Request = Class.create(Ajax.Base, {\n  _complete: false,\n\n  initialize: function($super, url, options) {\n    $super(options);\n    this.transport = Ajax.getTransport();\n    this.request(url);\n  },\n\n  request: function(url) {\n    this.url = url;\n    this.method = this.options.method;\n    var params = Object.isString(this.options.parameters) ?\n          this.options.parameters :\n          Object.toQueryString(this.options.parameters);\n\n    if (!['get', 'post'].include(this.method)) {\n      params += (params ? '&' : '') + \"_method=\" + this.method;\n      this.method = 'post';\n    }\n\n    if (params && this.method === 'get') {\n      this.url += (this.url.include('?') ? '&' : '?') + params;\n    }\n\n    this.parameters = params.toQueryParams();\n\n    try {\n      var response = new Ajax.Response(this);\n      if (this.options.onCreate) this.options.onCreate(response);\n      Ajax.Responders.dispatch('onCreate', this, response);\n\n      this.transport.open(this.method.toUpperCase(), this.url,\n        this.options.asynchronous);\n\n      if (this.options.asynchronous) this.respondToReadyState.bind(this).defer(1);\n\n      this.transport.onreadystatechange = this.onStateChange.bind(this);\n      this.setRequestHeaders();\n\n      this.body = this.method == 'post' ? (this.options.postBody || params) : null;\n      this.transport.send(this.body);\n\n      /* Force Firefox to handle ready state 4 for synchronous requests */\n      if (!this.options.asynchronous && this.transport.overrideMimeType)\n        this.onStateChange();\n\n    }\n    catch (e) {\n      this.dispatchException(e);\n    }\n  },\n\n  onStateChange: function() {\n    var readyState = this.transport.readyState;\n    if (readyState > 1 && !((readyState == 4) && this._complete))\n      this.respondToReadyState(this.transport.readyState);\n  },\n\n  setRequestHeaders: function() {\n    var headers = {\n      'X-Requested-With': 'XMLHttpRequest',\n      'X-Prototype-Version': Prototype.Version,\n      'Accept': 'text/javascript, text/html, application/xml, text/xml, */*'\n    };\n\n    if (this.method == 'post') {\n      headers['Content-type'] = this.options.contentType +\n        (this.options.encoding ? '; charset=' + this.options.encoding : '');\n\n      /* Force \"Connection: close\" for older Mozilla browsers to work\n       * around a bug where XMLHttpRequest sends an incorrect\n       * Content-length header. See Mozilla Bugzilla #246651.\n       */\n      if (this.transport.overrideMimeType &&\n          (navigator.userAgent.match(/Gecko\\/(\\d{4})/) || [0,2005])[1] < 2005)\n            headers['Connection'] = 'close';\n    }\n\n    if (typeof this.options.requestHeaders == 'object') {\n      var extras = this.options.requestHeaders;\n\n      if (Object.isFunction(extras.push))\n        for (var i = 0, length = extras.length; i < length; i += 2)\n          headers[extras[i]] = extras[i+1];\n      else\n        $H(extras).each(function(pair) { headers[pair.key] = pair.value });\n    }\n\n    for (var name in headers)\n      this.transport.setRequestHeader(name, headers[name]);\n  },\n\n  success: function() {\n    var status = this.getStatus();\n    return !status || (status >= 200 && status < 300) || status == 304;\n  },\n\n  getStatus: function() {\n    try {\n      if (this.transport.status === 1223) return 204;\n      return this.transport.status || 0;\n    } catch (e) { return 0 }\n  },\n\n  respondToReadyState: function(readyState) {\n    var state = Ajax.Request.Events[readyState], response = new Ajax.Response(this);\n\n    if (state == 'Complete') {\n      try {\n        this._complete = true;\n        (this.options['on' + response.status]\n         || this.options['on' + (this.success() ? 'Success' : 'Failure')]\n         || Prototype.emptyFunction)(response, response.headerJSON);\n      } catch (e) {\n        this.dispatchException(e);\n      }\n\n      var contentType = response.getHeader('Content-type');\n      if (this.options.evalJS == 'force'\n          || (this.options.evalJS && this.isSameOrigin() && contentType\n          && contentType.match(/^\\s*(text|application)\\/(x-)?(java|ecma)script(;.*)?\\s*$/i)))\n        this.evalResponse();\n    }\n\n    try {\n      (this.options['on' + state] || Prototype.emptyFunction)(response, response.headerJSON);\n      Ajax.Responders.dispatch('on' + state, this, response, response.headerJSON);\n    } catch (e) {\n      this.dispatchException(e);\n    }\n\n    if (state == 'Complete') {\n      this.transport.onreadystatechange = Prototype.emptyFunction;\n    }\n  },\n\n  isSameOrigin: function() {\n    var m = this.url.match(/^\\s*https?:\\/\\/[^\\/]*/);\n    return !m || (m[0] == '#{protocol}//#{domain}#{port}'.interpolate({\n      protocol: location.protocol,\n      domain: document.domain,\n      port: location.port ? ':' + location.port : ''\n    }));\n  },\n\n  getHeader: function(name) {\n    try {\n      return this.transport.getResponseHeader(name) || null;\n    } catch (e) { return null; }\n  },\n\n  evalResponse: function() {\n    try {\n      return eval((this.transport.responseText || '').unfilterJSON());\n    } catch (e) {\n      this.dispatchException(e);\n    }\n  },\n\n  dispatchException: function(exception) {\n    (this.options.onException || Prototype.emptyFunction)(this, exception);\n    Ajax.Responders.dispatch('onException', this, exception);\n  }\n});\n\nAjax.Request.Events =\n  ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];\n\n\n\n\n\n\n\n\nAjax.Response = Class.create({\n  initialize: function(request){\n    this.request = request;\n    var transport  = this.transport  = request.transport,\n        readyState = this.readyState = transport.readyState;\n\n    if ((readyState > 2 && !Prototype.Browser.IE) || readyState == 4) {\n      this.status       = this.getStatus();\n      this.statusText   = this.getStatusText();\n      this.responseText = String.interpret(transport.responseText);\n      this.headerJSON   = this._getHeaderJSON();\n    }\n\n    if (readyState == 4) {\n      var xml = transport.responseXML;\n      this.responseXML  = Object.isUndefined(xml) ? null : xml;\n      this.responseJSON = this._getResponseJSON();\n    }\n  },\n\n  status:      0,\n\n  statusText: '',\n\n  getStatus: Ajax.Request.prototype.getStatus,\n\n  getStatusText: function() {\n    try {\n      return this.transport.statusText || '';\n    } catch (e) { return '' }\n  },\n\n  getHeader: Ajax.Request.prototype.getHeader,\n\n  getAllHeaders: function() {\n    try {\n      return this.getAllResponseHeaders();\n    } catch (e) { return null }\n  },\n\n  getResponseHeader: function(name) {\n    return this.transport.getResponseHeader(name);\n  },\n\n  getAllResponseHeaders: function() {\n    return this.transport.getAllResponseHeaders();\n  },\n\n  _getHeaderJSON: function() {\n    var json = this.getHeader('X-JSON');\n    if (!json) return null;\n    json = decodeURIComponent(escape(json));\n    try {\n      return json.evalJSON(this.request.options.sanitizeJSON ||\n        !this.request.isSameOrigin());\n    } catch (e) {\n      this.request.dispatchException(e);\n    }\n  },\n\n  _getResponseJSON: function() {\n    var options = this.request.options;\n    if (!options.evalJSON || (options.evalJSON != 'force' &&\n      !(this.getHeader('Content-type') || '').include('application/json')) ||\n        this.responseText.blank())\n          return null;\n    try {\n      return this.responseText.evalJSON(options.sanitizeJSON ||\n        !this.request.isSameOrigin());\n    } catch (e) {\n      this.request.dispatchException(e);\n    }\n  }\n});\n\nAjax.Updater = Class.create(Ajax.Request, {\n  initialize: function($super, container, url, options) {\n    this.container = {\n      success: (container.success || container),\n      failure: (container.failure || (container.success ? null : container))\n    };\n\n    options = Object.clone(options);\n    var onComplete = options.onComplete;\n    options.onComplete = (function(response, json) {\n      this.updateContent(response.responseText);\n      if (Object.isFunction(onComplete)) onComplete(response, json);\n    }).bind(this);\n\n    $super(url, options);\n  },\n\n  updateContent: function(responseText) {\n    var receiver = this.container[this.success() ? 'success' : 'failure'],\n        options = this.options;\n\n    if (!options.evalScripts) responseText = responseText.stripScripts();\n\n    if (receiver = $(receiver)) {\n      if (options.insertion) {\n        if (Object.isString(options.insertion)) {\n          var insertion = { }; insertion[options.insertion] = responseText;\n          receiver.insert(insertion);\n        }\n        else options.insertion(receiver, responseText);\n      }\n      else receiver.update(responseText);\n    }\n  }\n});\n\nAjax.PeriodicalUpdater = Class.create(Ajax.Base, {\n  initialize: function($super, container, url, options) {\n    $super(options);\n    this.onComplete = this.options.onComplete;\n\n    this.frequency = (this.options.frequency || 2);\n    this.decay = (this.options.decay || 1);\n\n    this.updater = { };\n    this.container = container;\n    this.url = url;\n\n    this.start();\n  },\n\n  start: function() {\n    this.options.onComplete = this.updateComplete.bind(this);\n    this.onTimerEvent();\n  },\n\n  stop: function() {\n    this.updater.options.onComplete = undefined;\n    clearTimeout(this.timer);\n    (this.onComplete || Prototype.emptyFunction).apply(this, arguments);\n  },\n\n  updateComplete: function(response) {\n    if (this.options.decay) {\n      this.decay = (response.responseText == this.lastText ?\n        this.decay * this.options.decay : 1);\n\n      this.lastText = response.responseText;\n    }\n    this.timer = this.onTimerEvent.bind(this).delay(this.decay * this.frequency);\n  },\n\n  onTimerEvent: function() {\n    this.updater = new Ajax.Updater(this.container, this.url, this.options);\n  }\n});\n\n\nfunction $(element) {\n  if (arguments.length > 1) {\n    for (var i = 0, elements = [], length = arguments.length; i < length; i++)\n      elements.push($(arguments[i]));\n    return elements;\n  }\n  if (Object.isString(element))\n    element = document.getElementById(element);\n  return Element.extend(element);\n}\n\nif (Prototype.BrowserFeatures.XPath) {\n  document._getElementsByXPath = function(expression, parentElement) {\n    var results = [];\n    var query = document.evaluate(expression, $(parentElement) || document,\n      null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);\n    for (var i = 0, length = query.snapshotLength; i < length; i++)\n      results.push(Element.extend(query.snapshotItem(i)));\n    return results;\n  };\n}\n\n/*--------------------------------------------------------------------------*/\n\nif (!Node) var Node = { };\n\nif (!Node.ELEMENT_NODE) {\n  Object.extend(Node, {\n    ELEMENT_NODE: 1,\n    ATTRIBUTE_NODE: 2,\n    TEXT_NODE: 3,\n    CDATA_SECTION_NODE: 4,\n    ENTITY_REFERENCE_NODE: 5,\n    ENTITY_NODE: 6,\n    PROCESSING_INSTRUCTION_NODE: 7,\n    COMMENT_NODE: 8,\n    DOCUMENT_NODE: 9,\n    DOCUMENT_TYPE_NODE: 10,\n    DOCUMENT_FRAGMENT_NODE: 11,\n    NOTATION_NODE: 12\n  });\n}\n\n\n\n(function(global) {\n  function shouldUseCache(tagName, attributes) {\n    if (tagName === 'select') return false;\n    if ('type' in attributes) return false;\n    return true;\n  }\n\n  var HAS_EXTENDED_CREATE_ELEMENT_SYNTAX = (function(){\n    try {\n      var el = document.createElement('<input name=\"x\">');\n      return el.tagName.toLowerCase() === 'input' && el.name === 'x';\n    }\n    catch(err) {\n      return false;\n    }\n  })();\n\n  var element = global.Element;\n\n  global.Element = function(tagName, attributes) {\n    attributes = attributes || { };\n    tagName = tagName.toLowerCase();\n    var cache = Element.cache;\n\n    if (HAS_EXTENDED_CREATE_ELEMENT_SYNTAX && attributes.name) {\n      tagName = '<' + tagName + ' name=\"' + attributes.name + '\">';\n      delete attributes.name;\n      return Element.writeAttribute(document.createElement(tagName), attributes);\n    }\n\n    if (!cache[tagName]) cache[tagName] = Element.extend(document.createElement(tagName));\n\n    var node = shouldUseCache(tagName, attributes) ?\n     cache[tagName].cloneNode(false) : document.createElement(tagName);\n\n    return Element.writeAttribute(node, attributes);\n  };\n\n  Object.extend(global.Element, element || { });\n  if (element) global.Element.prototype = element.prototype;\n\n})(this);\n\nElement.idCounter = 1;\nElement.cache = { };\n\nElement._purgeElement = function(element) {\n  var uid = element._prototypeUID;\n  if (uid) {\n    Element.stopObserving(element);\n    element._prototypeUID = void 0;\n    delete Element.Storage[uid];\n  }\n}\n\nElement.Methods = {\n  visible: function(element) {\n    return $(element).style.display != 'none';\n  },\n\n  toggle: function(element) {\n    element = $(element);\n    Element[Element.visible(element) ? 'hide' : 'show'](element);\n    return element;\n  },\n\n  hide: function(element) {\n    element = $(element);\n    element.style.display = 'none';\n    return element;\n  },\n\n  show: function(element) {\n    element = $(element);\n    element.style.display = '';\n    return element;\n  },\n\n  remove: function(element) {\n    element = $(element);\n    element.parentNode.removeChild(element);\n    return element;\n  },\n\n  update: (function(){\n\n    var SELECT_ELEMENT_INNERHTML_BUGGY = (function(){\n      var el = document.createElement(\"select\"),\n          isBuggy = true;\n      el.innerHTML = \"<option value=\\\"test\\\">test</option>\";\n      if (el.options && el.options[0]) {\n        isBuggy = el.options[0].nodeName.toUpperCase() !== \"OPTION\";\n      }\n      el = null;\n      return isBuggy;\n    })();\n\n    var TABLE_ELEMENT_INNERHTML_BUGGY = (function(){\n      try {\n        var el = document.createElement(\"table\");\n        if (el && el.tBodies) {\n          el.innerHTML = \"<tbody><tr><td>test</td></tr></tbody>\";\n          var isBuggy = typeof el.tBodies[0] == \"undefined\";\n          el = null;\n          return isBuggy;\n        }\n      } catch (e) {\n        return true;\n      }\n    })();\n\n    var LINK_ELEMENT_INNERHTML_BUGGY = (function() {\n      try {\n        var el = document.createElement('div');\n        el.innerHTML = \"<link>\";\n        var isBuggy = (el.childNodes.length === 0);\n        el = null;\n        return isBuggy;\n      } catch(e) {\n        return true;\n      }\n    })();\n\n    var ANY_INNERHTML_BUGGY = SELECT_ELEMENT_INNERHTML_BUGGY ||\n     TABLE_ELEMENT_INNERHTML_BUGGY || LINK_ELEMENT_INNERHTML_BUGGY;\n\n    var SCRIPT_ELEMENT_REJECTS_TEXTNODE_APPENDING = (function () {\n      var s = document.createElement(\"script\"),\n          isBuggy = false;\n      try {\n        s.appendChild(document.createTextNode(\"\"));\n        isBuggy = !s.firstChild ||\n          s.firstChild && s.firstChild.nodeType !== 3;\n      } catch (e) {\n        isBuggy = true;\n      }\n      s = null;\n      return isBuggy;\n    })();\n\n\n    function update(element, content) {\n      element = $(element);\n      var purgeElement = Element._purgeElement;\n\n      var descendants = element.getElementsByTagName('*'),\n       i = descendants.length;\n      while (i--) purgeElement(descendants[i]);\n\n      if (content && content.toElement)\n        content = content.toElement();\n\n      if (Object.isElement(content))\n        return element.update().insert(content);\n\n      content = Object.toHTML(content);\n\n      var tagName = element.tagName.toUpperCase();\n\n      if (tagName === 'SCRIPT' && SCRIPT_ELEMENT_REJECTS_TEXTNODE_APPENDING) {\n        element.text = content;\n        return element;\n      }\n\n      if (ANY_INNERHTML_BUGGY) {\n        if (tagName in Element._insertionTranslations.tags) {\n          while (element.firstChild) {\n            element.removeChild(element.firstChild);\n          }\n          Element._getContentFromAnonymousElement(tagName, content.stripScripts())\n            .each(function(node) {\n              element.appendChild(node)\n            });\n        } else if (LINK_ELEMENT_INNERHTML_BUGGY && Object.isString(content) && content.indexOf('<link') > -1) {\n          while (element.firstChild) {\n            element.removeChild(element.firstChild);\n          }\n          var nodes = Element._getContentFromAnonymousElement(tagName, content.stripScripts(), true);\n          nodes.each(function(node) { element.appendChild(node) });\n        }\n        else {\n          element.innerHTML = content.stripScripts();\n        }\n      }\n      else {\n        element.innerHTML = content.stripScripts();\n      }\n\n      content.evalScripts.bind(content).defer();\n      return element;\n    }\n\n    return update;\n  })(),\n\n  replace: function(element, content) {\n    element = $(element);\n    if (content && content.toElement) content = content.toElement();\n    else if (!Object.isElement(content)) {\n      content = Object.toHTML(content);\n      var range = element.ownerDocument.createRange();\n      range.selectNode(element);\n      content.evalScripts.bind(content).defer();\n      content = range.createContextualFragment(content.stripScripts());\n    }\n    element.parentNode.replaceChild(content, element);\n    return element;\n  },\n\n  insert: function(element, insertions) {\n    element = $(element);\n\n    if (Object.isString(insertions) || Object.isNumber(insertions) ||\n        Object.isElement(insertions) || (insertions && (insertions.toElement || insertions.toHTML)))\n          insertions = {bottom:insertions};\n\n    var content, insert, tagName, childNodes;\n\n    for (var position in insertions) {\n      content  = insertions[position];\n      position = position.toLowerCase();\n      insert = Element._insertionTranslations[position];\n\n      if (content && content.toElement) content = content.toElement();\n      if (Object.isElement(content)) {\n        insert(element, content);\n        continue;\n      }\n\n      content = Object.toHTML(content);\n\n      tagName = ((position == 'before' || position == 'after')\n        ? element.parentNode : element).tagName.toUpperCase();\n\n      childNodes = Element._getContentFromAnonymousElement(tagName, content.stripScripts());\n\n      if (position == 'top' || position == 'after') childNodes.reverse();\n      childNodes.each(insert.curry(element));\n\n      content.evalScripts.bind(content).defer();\n    }\n\n    return element;\n  },\n\n  wrap: function(element, wrapper, attributes) {\n    element = $(element);\n    if (Object.isElement(wrapper))\n      $(wrapper).writeAttribute(attributes || { });\n    else if (Object.isString(wrapper)) wrapper = new Element(wrapper, attributes);\n    else wrapper = new Element('div', wrapper);\n    if (element.parentNode)\n      element.parentNode.replaceChild(wrapper, element);\n    wrapper.appendChild(element);\n    return wrapper;\n  },\n\n  inspect: function(element) {\n    element = $(element);\n    var result = '<' + element.tagName.toLowerCase();\n    $H({'id': 'id', 'className': 'class'}).each(function(pair) {\n      var property = pair.first(),\n          attribute = pair.last(),\n          value = (element[property] || '').toString();\n      if (value) result += ' ' + attribute + '=' + value.inspect(true);\n    });\n    return result + '>';\n  },\n\n  recursivelyCollect: function(element, property, maximumLength) {\n    element = $(element);\n    maximumLength = maximumLength || -1;\n    var elements = [];\n\n    while (element = element[property]) {\n      if (element.nodeType == 1)\n        elements.push(Element.extend(element));\n      if (elements.length == maximumLength)\n        break;\n    }\n\n    return elements;\n  },\n\n  ancestors: function(element) {\n    return Element.recursivelyCollect(element, 'parentNode');\n  },\n\n  descendants: function(element) {\n    return Element.select(element, \"*\");\n  },\n\n  firstDescendant: function(element) {\n    element = $(element).firstChild;\n    while (element && element.nodeType != 1) element = element.nextSibling;\n    return $(element);\n  },\n\n  immediateDescendants: function(element) {\n    var results = [], child = $(element).firstChild;\n    while (child) {\n      if (child.nodeType === 1) {\n        results.push(Element.extend(child));\n      }\n      child = child.nextSibling;\n    }\n    return results;\n  },\n\n  previousSiblings: function(element, maximumLength) {\n    return Element.recursivelyCollect(element, 'previousSibling');\n  },\n\n  nextSiblings: function(element) {\n    return Element.recursivelyCollect(element, 'nextSibling');\n  },\n\n  siblings: function(element) {\n    element = $(element);\n    return Element.previousSiblings(element).reverse()\n      .concat(Element.nextSiblings(element));\n  },\n\n  match: function(element, selector) {\n    element = $(element);\n    if (Object.isString(selector))\n      return Prototype.Selector.match(element, selector);\n    return selector.match(element);\n  },\n\n  up: function(element, expression, index) {\n    element = $(element);\n    if (arguments.length == 1) return $(element.parentNode);\n    var ancestors = Element.ancestors(element);\n    return Object.isNumber(expression) ? ancestors[expression] :\n      Prototype.Selector.find(ancestors, expression, index);\n  },\n\n  down: function(element, expression, index) {\n    element = $(element);\n    if (arguments.length == 1) return Element.firstDescendant(element);\n    return Object.isNumber(expression) ? Element.descendants(element)[expression] :\n      Element.select(element, expression)[index || 0];\n  },\n\n  previous: function(element, expression, index) {\n    element = $(element);\n    if (Object.isNumber(expression)) index = expression, expression = false;\n    if (!Object.isNumber(index)) index = 0;\n\n    if (expression) {\n      return Prototype.Selector.find(element.previousSiblings(), expression, index);\n    } else {\n      return element.recursivelyCollect(\"previousSibling\", index + 1)[index];\n    }\n  },\n\n  next: function(element, expression, index) {\n    element = $(element);\n    if (Object.isNumber(expression)) index = expression, expression = false;\n    if (!Object.isNumber(index)) index = 0;\n\n    if (expression) {\n      return Prototype.Selector.find(element.nextSiblings(), expression, index);\n    } else {\n      var maximumLength = Object.isNumber(index) ? index + 1 : 1;\n      return element.recursivelyCollect(\"nextSibling\", index + 1)[index];\n    }\n  },\n\n\n  select: function(element) {\n    element = $(element);\n    var expressions = Array.prototype.slice.call(arguments, 1).join(', ');\n    return Prototype.Selector.select(expressions, element);\n  },\n\n  adjacent: function(element) {\n    element = $(element);\n    var expressions = Array.prototype.slice.call(arguments, 1).join(', ');\n    return Prototype.Selector.select(expressions, element.parentNode).without(element);\n  },\n\n  identify: function(element) {\n    element = $(element);\n    var id = Element.readAttribute(element, 'id');\n    if (id) return id;\n    do { id = 'anonymous_element_' + Element.idCounter++ } while ($(id));\n    Element.writeAttribute(element, 'id', id);\n    return id;\n  },\n\n  readAttribute: function(element, name) {\n    element = $(element);\n    if (Prototype.Browser.IE) {\n      var t = Element._attributeTranslations.read;\n      if (t.values[name]) return t.values[name](element, name);\n      if (t.names[name]) name = t.names[name];\n      if (name.include(':')) {\n        return (!element.attributes || !element.attributes[name]) ? null :\n         element.attributes[name].value;\n      }\n    }\n    return element.getAttribute(name);\n  },\n\n  writeAttribute: function(element, name, value) {\n    element = $(element);\n    var attributes = { }, t = Element._attributeTranslations.write;\n\n    if (typeof name == 'object') attributes = name;\n    else attributes[name] = Object.isUndefined(value) ? true : value;\n\n    for (var attr in attributes) {\n      name = t.names[attr] || attr;\n      value = attributes[attr];\n      if (t.values[attr]) name = t.values[attr](element, value);\n      if (value === false || value === null)\n        element.removeAttribute(name);\n      else if (value === true)\n        element.setAttribute(name, name);\n      else element.setAttribute(name, value);\n    }\n    return element;\n  },\n\n  getHeight: function(element) {\n    return Element.getDimensions(element).height;\n  },\n\n  getWidth: function(element) {\n    return Element.getDimensions(element).width;\n  },\n\n  classNames: function(element) {\n    return new Element.ClassNames(element);\n  },\n\n  hasClassName: function(element, className) {\n    if (!(element = $(element))) return;\n    var elementClassName = element.className;\n    return (elementClassName.length > 0 && (elementClassName == className ||\n      new RegExp(\"(^|\\\\s)\" + className + \"(\\\\s|$)\").test(elementClassName)));\n  },\n\n  addClassName: function(element, className) {\n    if (!(element = $(element))) return;\n    if (!Element.hasClassName(element, className))\n      element.className += (element.className ? ' ' : '') + className;\n    return element;\n  },\n\n  removeClassName: function(element, className) {\n    if (!(element = $(element))) return;\n    element.className = element.className.replace(\n      new RegExp(\"(^|\\\\s+)\" + className + \"(\\\\s+|$)\"), ' ').strip();\n    return element;\n  },\n\n  toggleClassName: function(element, className) {\n    if (!(element = $(element))) return;\n    return Element[Element.hasClassName(element, className) ?\n      'removeClassName' : 'addClassName'](element, className);\n  },\n\n  cleanWhitespace: function(element) {\n    element = $(element);\n    var node = element.firstChild;\n    while (node) {\n      var nextNode = node.nextSibling;\n      if (node.nodeType == 3 && !/\\S/.test(node.nodeValue))\n        element.removeChild(node);\n      node = nextNode;\n    }\n    return element;\n  },\n\n  empty: function(element) {\n    return $(element).innerHTML.blank();\n  },\n\n  descendantOf: function(element, ancestor) {\n    element = $(element), ancestor = $(ancestor);\n\n    if (element.compareDocumentPosition)\n      return (element.compareDocumentPosition(ancestor) & 8) === 8;\n\n    if (ancestor.contains)\n      return ancestor.contains(element) && ancestor !== element;\n\n    while (element = element.parentNode)\n      if (element == ancestor) return true;\n\n    return false;\n  },\n\n  scrollTo: function(element) {\n    element = $(element);\n    var pos = Element.cumulativeOffset(element);\n    window.scrollTo(pos[0], pos[1]);\n    return element;\n  },\n\n  getStyle: function(element, style) {\n    element = $(element);\n    style = style == 'float' ? 'cssFloat' : style.camelize();\n    var value = element.style[style];\n    if (!value || value == 'auto') {\n      var css = document.defaultView.getComputedStyle(element, null);\n      value = css ? css[style] : null;\n    }\n    if (style == 'opacity') return value ? parseFloat(value) : 1.0;\n    return value == 'auto' ? null : value;\n  },\n\n  getOpacity: function(element) {\n    return $(element).getStyle('opacity');\n  },\n\n  setStyle: function(element, styles) {\n    element = $(element);\n    var elementStyle = element.style, match;\n    if (Object.isString(styles)) {\n      element.style.cssText += ';' + styles;\n      return styles.include('opacity') ?\n        element.setOpacity(styles.match(/opacity:\\s*(\\d?\\.?\\d*)/)[1]) : element;\n    }\n    for (var property in styles)\n      if (property == 'opacity') element.setOpacity(styles[property]);\n      else\n        elementStyle[(property == 'float' || property == 'cssFloat') ?\n          (Object.isUndefined(elementStyle.styleFloat) ? 'cssFloat' : 'styleFloat') :\n            property] = styles[property];\n\n    return element;\n  },\n\n  setOpacity: function(element, value) {\n    element = $(element);\n    element.style.opacity = (value == 1 || value === '') ? '' :\n      (value < 0.00001) ? 0 : value;\n    return element;\n  },\n\n  makePositioned: function(element) {\n    element = $(element);\n    var pos = Element.getStyle(element, 'position');\n    if (pos == 'static' || !pos) {\n      element._madePositioned = true;\n      element.style.position = 'relative';\n      if (Prototype.Browser.Opera) {\n        element.style.top = 0;\n        element.style.left = 0;\n      }\n    }\n    return element;\n  },\n\n  undoPositioned: function(element) {\n    element = $(element);\n    if (element._madePositioned) {\n      element._madePositioned = undefined;\n      element.style.position =\n        element.style.top =\n        element.style.left =\n        element.style.bottom =\n        element.style.right = '';\n    }\n    return element;\n  },\n\n  makeClipping: function(element) {\n    element = $(element);\n    if (element._overflow) return element;\n    element._overflow = Element.getStyle(element, 'overflow') || 'auto';\n    if (element._overflow !== 'hidden')\n      element.style.overflow = 'hidden';\n    return element;\n  },\n\n  undoClipping: function(element) {\n    element = $(element);\n    if (!element._overflow) return element;\n    element.style.overflow = element._overflow == 'auto' ? '' : element._overflow;\n    element._overflow = null;\n    return element;\n  },\n\n  clonePosition: function(element, source) {\n    var options = Object.extend({\n      setLeft:    true,\n      setTop:     true,\n      setWidth:   true,\n      setHeight:  true,\n      offsetTop:  0,\n      offsetLeft: 0\n    }, arguments[2] || { });\n\n    source = $(source);\n    var p = Element.viewportOffset(source), delta = [0, 0], parent = null;\n\n    element = $(element);\n\n    if (Element.getStyle(element, 'position') == 'absolute') {\n      parent = Element.getOffsetParent(element);\n      delta = Element.viewportOffset(parent);\n    }\n\n    if (parent == document.body) {\n      delta[0] -= document.body.offsetLeft;\n      delta[1] -= document.body.offsetTop;\n    }\n\n    if (options.setLeft)   element.style.left  = (p[0] - delta[0] + options.offsetLeft) + 'px';\n    if (options.setTop)    element.style.top   = (p[1] - delta[1] + options.offsetTop) + 'px';\n    if (options.setWidth)  element.style.width = source.offsetWidth + 'px';\n    if (options.setHeight) element.style.height = source.offsetHeight + 'px';\n    return element;\n  }\n};\n\nObject.extend(Element.Methods, {\n  getElementsBySelector: Element.Methods.select,\n\n  childElements: Element.Methods.immediateDescendants\n});\n\nElement._attributeTranslations = {\n  write: {\n    names: {\n      className: 'class',\n      htmlFor:   'for'\n    },\n    values: { }\n  }\n};\n\nif (Prototype.Browser.Opera) {\n  Element.Methods.getStyle = Element.Methods.getStyle.wrap(\n    function(proceed, element, style) {\n      switch (style) {\n        case 'height': case 'width':\n          if (!Element.visible(element)) return null;\n\n          var dim = parseInt(proceed(element, style), 10);\n\n          if (dim !== element['offset' + style.capitalize()])\n            return dim + 'px';\n\n          var properties;\n          if (style === 'height') {\n            properties = ['border-top-width', 'padding-top',\n             'padding-bottom', 'border-bottom-width'];\n          }\n          else {\n            properties = ['border-left-width', 'padding-left',\n             'padding-right', 'border-right-width'];\n          }\n          return properties.inject(dim, function(memo, property) {\n            var val = proceed(element, property);\n            return val === null ? memo : memo - parseInt(val, 10);\n          }) + 'px';\n        default: return proceed(element, style);\n      }\n    }\n  );\n\n  Element.Methods.readAttribute = Element.Methods.readAttribute.wrap(\n    function(proceed, element, attribute) {\n      if (attribute === 'title') return element.title;\n      return proceed(element, attribute);\n    }\n  );\n}\n\nelse if (Prototype.Browser.IE) {\n  Element.Methods.getStyle = function(element, style) {\n    element = $(element);\n    style = (style == 'float' || style == 'cssFloat') ? 'styleFloat' : style.camelize();\n    var value = element.style[style];\n    if (!value && element.currentStyle) value = element.currentStyle[style];\n\n    if (style == 'opacity') {\n      if (value = (element.getStyle('filter') || '').match(/alpha\\(opacity=(.*)\\)/))\n        if (value[1]) return parseFloat(value[1]) / 100;\n      return 1.0;\n    }\n\n    if (value == 'auto') {\n      if ((style == 'width' || style == 'height') && (element.getStyle('display') != 'none'))\n        return element['offset' + style.capitalize()] + 'px';\n      return null;\n    }\n    return value;\n  };\n\n  Element.Methods.setOpacity = function(element, value) {\n    function stripAlpha(filter){\n      return filter.replace(/alpha\\([^\\)]*\\)/gi,'');\n    }\n    element = $(element);\n    var currentStyle = element.currentStyle;\n    if ((currentStyle && !currentStyle.hasLayout) ||\n      (!currentStyle && element.style.zoom == 'normal'))\n        element.style.zoom = 1;\n\n    var filter = element.getStyle('filter'), style = element.style;\n    if (value == 1 || value === '') {\n      (filter = stripAlpha(filter)) ?\n        style.filter = filter : style.removeAttribute('filter');\n      return element;\n    } else if (value < 0.00001) value = 0;\n    style.filter = stripAlpha(filter) +\n      'alpha(opacity=' + (value * 100) + ')';\n    return element;\n  };\n\n  Element._attributeTranslations = (function(){\n\n    var classProp = 'className',\n        forProp = 'for',\n        el = document.createElement('div');\n\n    el.setAttribute(classProp, 'x');\n\n    if (el.className !== 'x') {\n      el.setAttribute('class', 'x');\n      if (el.className === 'x') {\n        classProp = 'class';\n      }\n    }\n    el = null;\n\n    el = document.createElement('label');\n    el.setAttribute(forProp, 'x');\n    if (el.htmlFor !== 'x') {\n      el.setAttribute('htmlFor', 'x');\n      if (el.htmlFor === 'x') {\n        forProp = 'htmlFor';\n      }\n    }\n    el = null;\n\n    return {\n      read: {\n        names: {\n          'class':      classProp,\n          'className':  classProp,\n          'for':        forProp,\n          'htmlFor':    forProp\n        },\n        values: {\n          _getAttr: function(element, attribute) {\n            return element.getAttribute(attribute);\n          },\n          _getAttr2: function(element, attribute) {\n            return element.getAttribute(attribute, 2);\n          },\n          _getAttrNode: function(element, attribute) {\n            var node = element.getAttributeNode(attribute);\n            return node ? node.value : \"\";\n          },\n          _getEv: (function(){\n\n            var el = document.createElement('div'), f;\n            el.onclick = Prototype.emptyFunction;\n            var value = el.getAttribute('onclick');\n\n            if (String(value).indexOf('{') > -1) {\n              f = function(element, attribute) {\n                attribute = element.getAttribute(attribute);\n                if (!attribute) return null;\n                attribute = attribute.toString();\n                attribute = attribute.split('{')[1];\n                attribute = attribute.split('}')[0];\n                return attribute.strip();\n              };\n            }\n            else if (value === '') {\n              f = function(element, attribute) {\n                attribute = element.getAttribute(attribute);\n                if (!attribute) return null;\n                return attribute.strip();\n              };\n            }\n            el = null;\n            return f;\n          })(),\n          _flag: function(element, attribute) {\n            return $(element).hasAttribute(attribute) ? attribute : null;\n          },\n          style: function(element) {\n            return element.style.cssText.toLowerCase();\n          },\n          title: function(element) {\n            return element.title;\n          }\n        }\n      }\n    }\n  })();\n\n  Element._attributeTranslations.write = {\n    names: Object.extend({\n      cellpadding: 'cellPadding',\n      cellspacing: 'cellSpacing'\n    }, Element._attributeTranslations.read.names),\n    values: {\n      checked: function(element, value) {\n        element.checked = !!value;\n      },\n\n      style: function(element, value) {\n        element.style.cssText = value ? value : '';\n      }\n    }\n  };\n\n  Element._attributeTranslations.has = {};\n\n  $w('colSpan rowSpan vAlign dateTime accessKey tabIndex ' +\n      'encType maxLength readOnly longDesc frameBorder').each(function(attr) {\n    Element._attributeTranslations.write.names[attr.toLowerCase()] = attr;\n    Element._attributeTranslations.has[attr.toLowerCase()] = attr;\n  });\n\n  (function(v) {\n    Object.extend(v, {\n      href:        v._getAttr2,\n      src:         v._getAttr2,\n      type:        v._getAttr,\n      action:      v._getAttrNode,\n      disabled:    v._flag,\n      checked:     v._flag,\n      readonly:    v._flag,\n      multiple:    v._flag,\n      onload:      v._getEv,\n      onunload:    v._getEv,\n      onclick:     v._getEv,\n      ondblclick:  v._getEv,\n      onmousedown: v._getEv,\n      onmouseup:   v._getEv,\n      onmouseover: v._getEv,\n      onmousemove: v._getEv,\n      onmouseout:  v._getEv,\n      onfocus:     v._getEv,\n      onblur:      v._getEv,\n      onkeypress:  v._getEv,\n      onkeydown:   v._getEv,\n      onkeyup:     v._getEv,\n      onsubmit:    v._getEv,\n      onreset:     v._getEv,\n      onselect:    v._getEv,\n      onchange:    v._getEv\n    });\n  })(Element._attributeTranslations.read.values);\n\n  if (Prototype.BrowserFeatures.ElementExtensions) {\n    (function() {\n      function _descendants(element) {\n        var nodes = element.getElementsByTagName('*'), results = [];\n        for (var i = 0, node; node = nodes[i]; i++)\n          if (node.tagName !== \"!\") // Filter out comment nodes.\n            results.push(node);\n        return results;\n      }\n\n      Element.Methods.down = function(element, expression, index) {\n        element = $(element);\n        if (arguments.length == 1) return element.firstDescendant();\n        return Object.isNumber(expression) ? _descendants(element)[expression] :\n          Element.select(element, expression)[index || 0];\n      }\n    })();\n  }\n\n}\n\nelse if (Prototype.Browser.Gecko && /rv:1\\.8\\.0/.test(navigator.userAgent)) {\n  Element.Methods.setOpacity = function(element, value) {\n    element = $(element);\n    element.style.opacity = (value == 1) ? 0.999999 :\n      (value === '') ? '' : (value < 0.00001) ? 0 : value;\n    return element;\n  };\n}\n\nelse if (Prototype.Browser.WebKit) {\n  Element.Methods.setOpacity = function(element, value) {\n    element = $(element);\n    element.style.opacity = (value == 1 || value === '') ? '' :\n      (value < 0.00001) ? 0 : value;\n\n    if (value == 1)\n      if (element.tagName.toUpperCase() == 'IMG' && element.width) {\n        element.width++; element.width--;\n      } else try {\n        var n = document.createTextNode(' ');\n        element.appendChild(n);\n        element.removeChild(n);\n      } catch (e) { }\n\n    return element;\n  };\n}\n\nif ('outerHTML' in document.documentElement) {\n  Element.Methods.replace = function(element, content) {\n    element = $(element);\n\n    if (content && content.toElement) content = content.toElement();\n    if (Object.isElement(content)) {\n      element.parentNode.replaceChild(content, element);\n      return element;\n    }\n\n    content = Object.toHTML(content);\n    var parent = element.parentNode, tagName = parent.tagName.toUpperCase();\n\n    if (Element._insertionTranslations.tags[tagName]) {\n      var nextSibling = element.next(),\n          fragments = Element._getContentFromAnonymousElement(tagName, content.stripScripts());\n      parent.removeChild(element);\n      if (nextSibling)\n        fragments.each(function(node) { parent.insertBefore(node, nextSibling) });\n      else\n        fragments.each(function(node) { parent.appendChild(node) });\n    }\n    else element.outerHTML = content.stripScripts();\n\n    content.evalScripts.bind(content).defer();\n    return element;\n  };\n}\n\nElement._returnOffset = function(l, t) {\n  var result = [l, t];\n  result.left = l;\n  result.top = t;\n  return result;\n};\n\nElement._getContentFromAnonymousElement = function(tagName, html, force) {\n  var div = new Element('div'),\n      t = Element._insertionTranslations.tags[tagName];\n\n  var workaround = false;\n  if (t) workaround = true;\n  else if (force) {\n    workaround = true;\n    t = ['', '', 0];\n  }\n\n  if (workaround) {\n    div.innerHTML = '&nbsp;' + t[0] + html + t[1];\n    div.removeChild(div.firstChild);\n    for (var i = t[2]; i--; ) {\n      div = div.firstChild;\n    }\n  }\n  else {\n    div.innerHTML = html;\n  }\n  return $A(div.childNodes);\n};\n\nElement._insertionTranslations = {\n  before: function(element, node) {\n    element.parentNode.insertBefore(node, element);\n  },\n  top: function(element, node) {\n    element.insertBefore(node, element.firstChild);\n  },\n  bottom: function(element, node) {\n    element.appendChild(node);\n  },\n  after: function(element, node) {\n    element.parentNode.insertBefore(node, element.nextSibling);\n  },\n  tags: {\n    TABLE:  ['<table>',                '</table>',                   1],\n    TBODY:  ['<table><tbody>',         '</tbody></table>',           2],\n    TR:     ['<table><tbody><tr>',     '</tr></tbody></table>',      3],\n    TD:     ['<table><tbody><tr><td>', '</td></tr></tbody></table>', 4],\n    SELECT: ['<select>',               '</select>',                  1]\n  }\n};\n\n(function() {\n  var tags = Element._insertionTranslations.tags;\n  Object.extend(tags, {\n    THEAD: tags.TBODY,\n    TFOOT: tags.TBODY,\n    TH:    tags.TD\n  });\n})();\n\nElement.Methods.Simulated = {\n  hasAttribute: function(element, attribute) {\n    attribute = Element._attributeTranslations.has[attribute] || attribute;\n    var node = $(element).getAttributeNode(attribute);\n    return !!(node && node.specified);\n  }\n};\n\nElement.Methods.ByTag = { };\n\nObject.extend(Element, Element.Methods);\n\n(function(div) {\n\n  if (!Prototype.BrowserFeatures.ElementExtensions && div['__proto__']) {\n    window.HTMLElement = { };\n    window.HTMLElement.prototype = div['__proto__'];\n    Prototype.BrowserFeatures.ElementExtensions = true;\n  }\n\n  div = null;\n\n})(document.createElement('div'));\n\nElement.extend = (function() {\n\n  function checkDeficiency(tagName) {\n    if (typeof window.Element != 'undefined') {\n      var proto = window.Element.prototype;\n      if (proto) {\n        var id = '_' + (Math.random()+'').slice(2),\n            el = document.createElement(tagName);\n        proto[id] = 'x';\n        var isBuggy = (el[id] !== 'x');\n        delete proto[id];\n        el = null;\n        return isBuggy;\n      }\n    }\n    return false;\n  }\n\n  function extendElementWith(element, methods) {\n    for (var property in methods) {\n      var value = methods[property];\n      if (Object.isFunction(value) && !(property in element))\n        element[property] = value.methodize();\n    }\n  }\n\n  var HTMLOBJECTELEMENT_PROTOTYPE_BUGGY = checkDeficiency('object');\n\n  if (Prototype.BrowserFeatures.SpecificElementExtensions) {\n    if (HTMLOBJECTELEMENT_PROTOTYPE_BUGGY) {\n      return function(element) {\n        if (element && typeof element._extendedByPrototype == 'undefined') {\n          var t = element.tagName;\n          if (t && (/^(?:object|applet|embed)$/i.test(t))) {\n            extendElementWith(element, Element.Methods);\n            extendElementWith(element, Element.Methods.Simulated);\n            extendElementWith(element, Element.Methods.ByTag[t.toUpperCase()]);\n          }\n        }\n        return element;\n      }\n    }\n    return Prototype.K;\n  }\n\n  var Methods = { }, ByTag = Element.Methods.ByTag;\n\n  var extend = Object.extend(function(element) {\n    if (!element || typeof element._extendedByPrototype != 'undefined' ||\n        element.nodeType != 1 || element == window) return element;\n\n    var methods = Object.clone(Methods),\n        tagName = element.tagName.toUpperCase();\n\n    if (ByTag[tagName]) Object.extend(methods, ByTag[tagName]);\n\n    extendElementWith(element, methods);\n\n    element._extendedByPrototype = Prototype.emptyFunction;\n    return element;\n\n  }, {\n    refresh: function() {\n      if (!Prototype.BrowserFeatures.ElementExtensions) {\n        Object.extend(Methods, Element.Methods);\n        Object.extend(Methods, Element.Methods.Simulated);\n      }\n    }\n  });\n\n  extend.refresh();\n  return extend;\n})();\n\nif (document.documentElement.hasAttribute) {\n  Element.hasAttribute = function(element, attribute) {\n    return element.hasAttribute(attribute);\n  };\n}\nelse {\n  Element.hasAttribute = Element.Methods.Simulated.hasAttribute;\n}\n\nElement.addMethods = function(methods) {\n  var F = Prototype.BrowserFeatures, T = Element.Methods.ByTag;\n\n  if (!methods) {\n    Object.extend(Form, Form.Methods);\n    Object.extend(Form.Element, Form.Element.Methods);\n    Object.extend(Element.Methods.ByTag, {\n      \"FORM\":     Object.clone(Form.Methods),\n      \"INPUT\":    Object.clone(Form.Element.Methods),\n      \"SELECT\":   Object.clone(Form.Element.Methods),\n      \"TEXTAREA\": Object.clone(Form.Element.Methods),\n      \"BUTTON\":   Object.clone(Form.Element.Methods)\n    });\n  }\n\n  if (arguments.length == 2) {\n    var tagName = methods;\n    methods = arguments[1];\n  }\n\n  if (!tagName) Object.extend(Element.Methods, methods || { });\n  else {\n    if (Object.isArray(tagName)) tagName.each(extend);\n    else extend(tagName);\n  }\n\n  function extend(tagName) {\n    tagName = tagName.toUpperCase();\n    if (!Element.Methods.ByTag[tagName])\n      Element.Methods.ByTag[tagName] = { };\n    Object.extend(Element.Methods.ByTag[tagName], methods);\n  }\n\n  function copy(methods, destination, onlyIfAbsent) {\n    onlyIfAbsent = onlyIfAbsent || false;\n    for (var property in methods) {\n      var value = methods[property];\n      if (!Object.isFunction(value)) continue;\n      if (!onlyIfAbsent || !(property in destination))\n        destination[property] = value.methodize();\n    }\n  }\n\n  function findDOMClass(tagName) {\n    var klass;\n    var trans = {\n      \"OPTGROUP\": \"OptGroup\", \"TEXTAREA\": \"TextArea\", \"P\": \"Paragraph\",\n      \"FIELDSET\": \"FieldSet\", \"UL\": \"UList\", \"OL\": \"OList\", \"DL\": \"DList\",\n      \"DIR\": \"Directory\", \"H1\": \"Heading\", \"H2\": \"Heading\", \"H3\": \"Heading\",\n      \"H4\": \"Heading\", \"H5\": \"Heading\", \"H6\": \"Heading\", \"Q\": \"Quote\",\n      \"INS\": \"Mod\", \"DEL\": \"Mod\", \"A\": \"Anchor\", \"IMG\": \"Image\", \"CAPTION\":\n      \"TableCaption\", \"COL\": \"TableCol\", \"COLGROUP\": \"TableCol\", \"THEAD\":\n      \"TableSection\", \"TFOOT\": \"TableSection\", \"TBODY\": \"TableSection\", \"TR\":\n      \"TableRow\", \"TH\": \"TableCell\", \"TD\": \"TableCell\", \"FRAMESET\":\n      \"FrameSet\", \"IFRAME\": \"IFrame\"\n    };\n    if (trans[tagName]) klass = 'HTML' + trans[tagName] + 'Element';\n    if (window[klass]) return window[klass];\n    klass = 'HTML' + tagName + 'Element';\n    if (window[klass]) return window[klass];\n    klass = 'HTML' + tagName.capitalize() + 'Element';\n    if (window[klass]) return window[klass];\n\n    var element = document.createElement(tagName),\n        proto = element['__proto__'] || element.constructor.prototype;\n\n    element = null;\n    return proto;\n  }\n\n  var elementPrototype = window.HTMLElement ? HTMLElement.prototype :\n   Element.prototype;\n\n  if (F.ElementExtensions) {\n    copy(Element.Methods, elementPrototype);\n    copy(Element.Methods.Simulated, elementPrototype, true);\n  }\n\n  if (F.SpecificElementExtensions) {\n    for (var tag in Element.Methods.ByTag) {\n      var klass = findDOMClass(tag);\n      if (Object.isUndefined(klass)) continue;\n      copy(T[tag], klass.prototype);\n    }\n  }\n\n  Object.extend(Element, Element.Methods);\n  delete Element.ByTag;\n\n  if (Element.extend.refresh) Element.extend.refresh();\n  Element.cache = { };\n};\n\n\ndocument.viewport = {\n\n  getDimensions: function() {\n    return { width: this.getWidth(), height: this.getHeight() };\n  },\n\n  getScrollOffsets: function() {\n    return Element._returnOffset(\n      window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft,\n      window.pageYOffset || document.documentElement.scrollTop  || document.body.scrollTop);\n  }\n};\n\n(function(viewport) {\n  var B = Prototype.Browser, doc = document, element, property = {};\n\n  function getRootElement() {\n    if (B.WebKit && !doc.evaluate)\n      return document;\n\n    if (B.Opera && window.parseFloat(window.opera.version()) < 9.5)\n      return document.body;\n\n    return document.documentElement;\n  }\n\n  function define(D) {\n    if (!element) element = getRootElement();\n\n    property[D] = 'client' + D;\n\n    viewport['get' + D] = function() { return element[property[D]] };\n    return viewport['get' + D]();\n  }\n\n  viewport.getWidth  = define.curry('Width');\n\n  viewport.getHeight = define.curry('Height');\n})(document.viewport);\n\n\nElement.Storage = {\n  UID: 1\n};\n\nElement.addMethods({\n  getStorage: function(element) {\n    if (!(element = $(element))) return;\n\n    var uid;\n    if (element === window) {\n      uid = 0;\n    } else {\n      if (typeof element._prototypeUID === \"undefined\")\n        element._prototypeUID = Element.Storage.UID++;\n      uid = element._prototypeUID;\n    }\n\n    if (!Element.Storage[uid])\n      Element.Storage[uid] = $H();\n\n    return Element.Storage[uid];\n  },\n\n  store: function(element, key, value) {\n    if (!(element = $(element))) return;\n\n    if (arguments.length === 2) {\n      Element.getStorage(element).update(key);\n    } else {\n      Element.getStorage(element).set(key, value);\n    }\n\n    return element;\n  },\n\n  retrieve: function(element, key, defaultValue) {\n    if (!(element = $(element))) return;\n    var hash = Element.getStorage(element), value = hash.get(key);\n\n    if (Object.isUndefined(value)) {\n      hash.set(key, defaultValue);\n      value = defaultValue;\n    }\n\n    return value;\n  },\n\n  clone: function(element, deep) {\n    if (!(element = $(element))) return;\n    var clone = element.cloneNode(deep);\n    clone._prototypeUID = void 0;\n    if (deep) {\n      var descendants = Element.select(clone, '*'),\n          i = descendants.length;\n      while (i--) {\n        descendants[i]._prototypeUID = void 0;\n      }\n    }\n    return Element.extend(clone);\n  },\n\n  purge: function(element) {\n    if (!(element = $(element))) return;\n    var purgeElement = Element._purgeElement;\n\n    purgeElement(element);\n\n    var descendants = element.getElementsByTagName('*'),\n     i = descendants.length;\n\n    while (i--) purgeElement(descendants[i]);\n\n    return null;\n  }\n});\n\n(function() {\n\n  function toDecimal(pctString) {\n    var match = pctString.match(/^(\\d+)%?$/i);\n    if (!match) return null;\n    return (Number(match[1]) / 100);\n  }\n\n  function getPixelValue(value, property, context) {\n    var element = null;\n    if (Object.isElement(value)) {\n      element = value;\n      value = element.getStyle(property);\n    }\n\n    if (value === null) {\n      return null;\n    }\n\n    if ((/^(?:-)?\\d+(\\.\\d+)?(px)?$/i).test(value)) {\n      return window.parseFloat(value);\n    }\n\n    var isPercentage = value.include('%'), isViewport = (context === document.viewport);\n\n    if (/\\d/.test(value) && element && element.runtimeStyle && !(isPercentage && isViewport)) {\n      var style = element.style.left, rStyle = element.runtimeStyle.left;\n      element.runtimeStyle.left = element.currentStyle.left;\n      element.style.left = value || 0;\n      value = element.style.pixelLeft;\n      element.style.left = style;\n      element.runtimeStyle.left = rStyle;\n\n      return value;\n    }\n\n    if (element && isPercentage) {\n      context = context || element.parentNode;\n      var decimal = toDecimal(value);\n      var whole = null;\n      var position = element.getStyle('position');\n\n      var isHorizontal = property.include('left') || property.include('right') ||\n       property.include('width');\n\n      var isVertical =  property.include('top') || property.include('bottom') ||\n        property.include('height');\n\n      if (context === document.viewport) {\n        if (isHorizontal) {\n          whole = document.viewport.getWidth();\n        } else if (isVertical) {\n          whole = document.viewport.getHeight();\n        }\n      } else {\n        if (isHorizontal) {\n          whole = $(context).measure('width');\n        } else if (isVertical) {\n          whole = $(context).measure('height');\n        }\n      }\n\n      return (whole === null) ? 0 : whole * decimal;\n    }\n\n    return 0;\n  }\n\n  function toCSSPixels(number) {\n    if (Object.isString(number) && number.endsWith('px')) {\n      return number;\n    }\n    return number + 'px';\n  }\n\n  function isDisplayed(element) {\n    var originalElement = element;\n    while (element && element.parentNode) {\n      var display = element.getStyle('display');\n      if (display === 'none') {\n        return false;\n      }\n      element = $(element.parentNode);\n    }\n    return true;\n  }\n\n  var hasLayout = Prototype.K;\n  if ('currentStyle' in document.documentElement) {\n    hasLayout = function(element) {\n      if (!element.currentStyle.hasLayout) {\n        element.style.zoom = 1;\n      }\n      return element;\n    };\n  }\n\n  function cssNameFor(key) {\n    if (key.include('border')) key = key + '-width';\n    return key.camelize();\n  }\n\n  Element.Layout = Class.create(Hash, {\n    initialize: function($super, element, preCompute) {\n      $super();\n      this.element = $(element);\n\n      Element.Layout.PROPERTIES.each( function(property) {\n        this._set(property, null);\n      }, this);\n\n      if (preCompute) {\n        this._preComputing = true;\n        this._begin();\n        Element.Layout.PROPERTIES.each( this._compute, this );\n        this._end();\n        this._preComputing = false;\n      }\n    },\n\n    _set: function(property, value) {\n      return Hash.prototype.set.call(this, property, value);\n    },\n\n    set: function(property, value) {\n      throw \"Properties of Element.Layout are read-only.\";\n    },\n\n    get: function($super, property) {\n      var value = $super(property);\n      return value === null ? this._compute(property) : value;\n    },\n\n    _begin: function() {\n      if (this._prepared) return;\n\n      var element = this.element;\n      if (isDisplayed(element)) {\n        this._prepared = true;\n        return;\n      }\n\n      var originalStyles = {\n        position:   element.style.position   || '',\n        width:      element.style.width      || '',\n        visibility: element.style.visibility || '',\n        display:    element.style.display    || ''\n      };\n\n      element.store('prototype_original_styles', originalStyles);\n\n      var position = element.getStyle('position'),\n       width = element.getStyle('width');\n\n      if (width === \"0px\" || width === null) {\n        element.style.display = 'block';\n        width = element.getStyle('width');\n      }\n\n      var context = (position === 'fixed') ? document.viewport :\n       element.parentNode;\n\n      element.setStyle({\n        position:   'absolute',\n        visibility: 'hidden',\n        display:    'block'\n      });\n\n      var positionedWidth = element.getStyle('width');\n\n      var newWidth;\n      if (width && (positionedWidth === width)) {\n        newWidth = getPixelValue(element, 'width', context);\n      } else if (position === 'absolute' || position === 'fixed') {\n        newWidth = getPixelValue(element, 'width', context);\n      } else {\n        var parent = element.parentNode, pLayout = $(parent).getLayout();\n\n        newWidth = pLayout.get('width') -\n         this.get('margin-left') -\n         this.get('border-left') -\n         this.get('padding-left') -\n         this.get('padding-right') -\n         this.get('border-right') -\n         this.get('margin-right');\n      }\n\n      element.setStyle({ width: newWidth + 'px' });\n\n      this._prepared = true;\n    },\n\n    _end: function() {\n      var element = this.element;\n      var originalStyles = element.retrieve('prototype_original_styles');\n      element.store('prototype_original_styles', null);\n      element.setStyle(originalStyles);\n      this._prepared = false;\n    },\n\n    _compute: function(property) {\n      var COMPUTATIONS = Element.Layout.COMPUTATIONS;\n      if (!(property in COMPUTATIONS)) {\n        throw \"Property not found.\";\n      }\n\n      return this._set(property, COMPUTATIONS[property].call(this, this.element));\n    },\n\n    toObject: function() {\n      var args = $A(arguments);\n      var keys = (args.length === 0) ? Element.Layout.PROPERTIES :\n       args.join(' ').split(' ');\n      var obj = {};\n      keys.each( function(key) {\n        if (!Element.Layout.PROPERTIES.include(key)) return;\n        var value = this.get(key);\n        if (value != null) obj[key] = value;\n      }, this);\n      return obj;\n    },\n\n    toHash: function() {\n      var obj = this.toObject.apply(this, arguments);\n      return new Hash(obj);\n    },\n\n    toCSS: function() {\n      var args = $A(arguments);\n      var keys = (args.length === 0) ? Element.Layout.PROPERTIES :\n       args.join(' ').split(' ');\n      var css = {};\n\n      keys.each( function(key) {\n        if (!Element.Layout.PROPERTIES.include(key)) return;\n        if (Element.Layout.COMPOSITE_PROPERTIES.include(key)) return;\n\n        var value = this.get(key);\n        if (value != null) css[cssNameFor(key)] = value + 'px';\n      }, this);\n      return css;\n    },\n\n    inspect: function() {\n      return \"#<Element.Layout>\";\n    }\n  });\n\n  Object.extend(Element.Layout, {\n    PROPERTIES: $w('height width top left right bottom border-left border-right border-top border-bottom padding-left padding-right padding-top padding-bottom margin-top margin-bottom margin-left margin-right padding-box-width padding-box-height border-box-width border-box-height margin-box-width margin-box-height'),\n\n    COMPOSITE_PROPERTIES: $w('padding-box-width padding-box-height margin-box-width margin-box-height border-box-width border-box-height'),\n\n    COMPUTATIONS: {\n      'height': function(element) {\n        if (!this._preComputing) this._begin();\n\n        var bHeight = this.get('border-box-height');\n        if (bHeight <= 0) {\n          if (!this._preComputing) this._end();\n          return 0;\n        }\n\n        var bTop = this.get('border-top'),\n         bBottom = this.get('border-bottom');\n\n        var pTop = this.get('padding-top'),\n         pBottom = this.get('padding-bottom');\n\n        if (!this._preComputing) this._end();\n\n        return bHeight - bTop - bBottom - pTop - pBottom;\n      },\n\n      'width': function(element) {\n        if (!this._preComputing) this._begin();\n\n        var bWidth = this.get('border-box-width');\n        if (bWidth <= 0) {\n          if (!this._preComputing) this._end();\n          return 0;\n        }\n\n        var bLeft = this.get('border-left'),\n         bRight = this.get('border-right');\n\n        var pLeft = this.get('padding-left'),\n         pRight = this.get('padding-right');\n\n        if (!this._preComputing) this._end();\n\n        return bWidth - bLeft - bRight - pLeft - pRight;\n      },\n\n      'padding-box-height': function(element) {\n        var height = this.get('height'),\n         pTop = this.get('padding-top'),\n         pBottom = this.get('padding-bottom');\n\n        return height + pTop + pBottom;\n      },\n\n      'padding-box-width': function(element) {\n        var width = this.get('width'),\n         pLeft = this.get('padding-left'),\n         pRight = this.get('padding-right');\n\n        return width + pLeft + pRight;\n      },\n\n      'border-box-height': function(element) {\n        if (!this._preComputing) this._begin();\n        var height = element.offsetHeight;\n        if (!this._preComputing) this._end();\n        return height;\n      },\n\n      'border-box-width': function(element) {\n        if (!this._preComputing) this._begin();\n        var width = element.offsetWidth;\n        if (!this._preComputing) this._end();\n        return width;\n      },\n\n      'margin-box-height': function(element) {\n        var bHeight = this.get('border-box-height'),\n         mTop = this.get('margin-top'),\n         mBottom = this.get('margin-bottom');\n\n        if (bHeight <= 0) return 0;\n\n        return bHeight + mTop + mBottom;\n      },\n\n      'margin-box-width': function(element) {\n        var bWidth = this.get('border-box-width'),\n         mLeft = this.get('margin-left'),\n         mRight = this.get('margin-right');\n\n        if (bWidth <= 0) return 0;\n\n        return bWidth + mLeft + mRight;\n      },\n\n      'top': function(element) {\n        var offset = element.positionedOffset();\n        return offset.top;\n      },\n\n      'bottom': function(element) {\n        var offset = element.positionedOffset(),\n         parent = element.getOffsetParent(),\n         pHeight = parent.measure('height');\n\n        var mHeight = this.get('border-box-height');\n\n        return pHeight - mHeight - offset.top;\n      },\n\n      'left': function(element) {\n        var offset = element.positionedOffset();\n        return offset.left;\n      },\n\n      'right': function(element) {\n        var offset = element.positionedOffset(),\n         parent = element.getOffsetParent(),\n         pWidth = parent.measure('width');\n\n        var mWidth = this.get('border-box-width');\n\n        return pWidth - mWidth - offset.left;\n      },\n\n      'padding-top': function(element) {\n        return getPixelValue(element, 'paddingTop');\n      },\n\n      'padding-bottom': function(element) {\n        return getPixelValue(element, 'paddingBottom');\n      },\n\n      'padding-left': function(element) {\n        return getPixelValue(element, 'paddingLeft');\n      },\n\n      'padding-right': function(element) {\n        return getPixelValue(element, 'paddingRight');\n      },\n\n      'border-top': function(element) {\n        return getPixelValue(element, 'borderTopWidth');\n      },\n\n      'border-bottom': function(element) {\n        return getPixelValue(element, 'borderBottomWidth');\n      },\n\n      'border-left': function(element) {\n        return getPixelValue(element, 'borderLeftWidth');\n      },\n\n      'border-right': function(element) {\n        return getPixelValue(element, 'borderRightWidth');\n      },\n\n      'margin-top': function(element) {\n        return getPixelValue(element, 'marginTop');\n      },\n\n      'margin-bottom': function(element) {\n        return getPixelValue(element, 'marginBottom');\n      },\n\n      'margin-left': function(element) {\n        return getPixelValue(element, 'marginLeft');\n      },\n\n      'margin-right': function(element) {\n        return getPixelValue(element, 'marginRight');\n      }\n    }\n  });\n\n  if ('getBoundingClientRect' in document.documentElement) {\n    Object.extend(Element.Layout.COMPUTATIONS, {\n      'right': function(element) {\n        var parent = hasLayout(element.getOffsetParent());\n        var rect = element.getBoundingClientRect(),\n         pRect = parent.getBoundingClientRect();\n\n        return (pRect.right - rect.right).round();\n      },\n\n      'bottom': function(element) {\n        var parent = hasLayout(element.getOffsetParent());\n        var rect = element.getBoundingClientRect(),\n         pRect = parent.getBoundingClientRect();\n\n        return (pRect.bottom - rect.bottom).round();\n      }\n    });\n  }\n\n  Element.Offset = Class.create({\n    initialize: function(left, top) {\n      this.left = left.round();\n      this.top  = top.round();\n\n      this[0] = this.left;\n      this[1] = this.top;\n    },\n\n    relativeTo: function(offset) {\n      return new Element.Offset(\n        this.left - offset.left,\n        this.top  - offset.top\n      );\n    },\n\n    inspect: function() {\n      return \"#<Element.Offset left: #{left} top: #{top}>\".interpolate(this);\n    },\n\n    toString: function() {\n      return \"[#{left}, #{top}]\".interpolate(this);\n    },\n\n    toArray: function() {\n      return [this.left, this.top];\n    }\n  });\n\n  function getLayout(element, preCompute) {\n    return new Element.Layout(element, preCompute);\n  }\n\n  function measure(element, property) {\n    return $(element).getLayout().get(property);\n  }\n\n  function getDimensions(element) {\n    element = $(element);\n    var display = Element.getStyle(element, 'display');\n\n    if (display && display !== 'none') {\n      return { width: element.offsetWidth, height: element.offsetHeight };\n    }\n\n    var style = element.style;\n    var originalStyles = {\n      visibility: style.visibility,\n      position:   style.position,\n      display:    style.display\n    };\n\n    var newStyles = {\n      visibility: 'hidden',\n      display:    'block'\n    };\n\n    if (originalStyles.position !== 'fixed')\n      newStyles.position = 'absolute';\n\n    Element.setStyle(element, newStyles);\n\n    var dimensions = {\n      width:  element.offsetWidth,\n      height: element.offsetHeight\n    };\n\n    Element.setStyle(element, originalStyles);\n\n    return dimensions;\n  }\n\n  function getOffsetParent(element) {\n    element = $(element);\n\n    if (isDocument(element) || isDetached(element) || isBody(element) || isHtml(element))\n      return $(document.body);\n\n    var isInline = (Element.getStyle(element, 'display') === 'inline');\n    if (!isInline && element.offsetParent) return $(element.offsetParent);\n\n    while ((element = element.parentNode) && element !== document.body) {\n      if (Element.getStyle(element, 'position') !== 'static') {\n        return isHtml(element) ? $(document.body) : $(element);\n      }\n    }\n\n    return $(document.body);\n  }\n\n\n  function cumulativeOffset(element) {\n    element = $(element);\n    var valueT = 0, valueL = 0;\n    if (element.parentNode) {\n      do {\n        valueT += element.offsetTop  || 0;\n        valueL += element.offsetLeft || 0;\n        element = element.offsetParent;\n      } while (element);\n    }\n    return new Element.Offset(valueL, valueT);\n  }\n\n  function positionedOffset(element) {\n    element = $(element);\n\n    var layout = element.getLayout();\n\n    var valueT = 0, valueL = 0;\n    do {\n      valueT += element.offsetTop  || 0;\n      valueL += element.offsetLeft || 0;\n      element = element.offsetParent;\n      if (element) {\n        if (isBody(element)) break;\n        var p = Element.getStyle(element, 'position');\n        if (p !== 'static') break;\n      }\n    } while (element);\n\n    valueL -= layout.get('margin-top');\n    valueT -= layout.get('margin-left');\n\n    return new Element.Offset(valueL, valueT);\n  }\n\n  function cumulativeScrollOffset(element) {\n    var valueT = 0, valueL = 0;\n    do {\n      valueT += element.scrollTop  || 0;\n      valueL += element.scrollLeft || 0;\n      element = element.parentNode;\n    } while (element);\n    return new Element.Offset(valueL, valueT);\n  }\n\n  function viewportOffset(forElement) {\n    element = $(element);\n    var valueT = 0, valueL = 0, docBody = document.body;\n\n    var element = forElement;\n    do {\n      valueT += element.offsetTop  || 0;\n      valueL += element.offsetLeft || 0;\n      if (element.offsetParent == docBody &&\n        Element.getStyle(element, 'position') == 'absolute') break;\n    } while (element = element.offsetParent);\n\n    element = forElement;\n    do {\n      if (element != docBody) {\n        valueT -= element.scrollTop  || 0;\n        valueL -= element.scrollLeft || 0;\n      }\n    } while (element = element.parentNode);\n    return new Element.Offset(valueL, valueT);\n  }\n\n  function absolutize(element) {\n    element = $(element);\n\n    if (Element.getStyle(element, 'position') === 'absolute') {\n      return element;\n    }\n\n    var offsetParent = getOffsetParent(element);\n    var eOffset = element.viewportOffset(),\n     pOffset = offsetParent.viewportOffset();\n\n    var offset = eOffset.relativeTo(pOffset);\n    var layout = element.getLayout();\n\n    element.store('prototype_absolutize_original_styles', {\n      left:   element.getStyle('left'),\n      top:    element.getStyle('top'),\n      width:  element.getStyle('width'),\n      height: element.getStyle('height')\n    });\n\n    element.setStyle({\n      position: 'absolute',\n      top:    offset.top + 'px',\n      left:   offset.left + 'px',\n      width:  layout.get('width') + 'px',\n      height: layout.get('height') + 'px'\n    });\n\n    return element;\n  }\n\n  function relativize(element) {\n    element = $(element);\n    if (Element.getStyle(element, 'position') === 'relative') {\n      return element;\n    }\n\n    var originalStyles =\n     element.retrieve('prototype_absolutize_original_styles');\n\n    if (originalStyles) element.setStyle(originalStyles);\n    return element;\n  }\n\n  if (Prototype.Browser.IE) {\n    getOffsetParent = getOffsetParent.wrap(\n      function(proceed, element) {\n        element = $(element);\n\n        if (isDocument(element) || isDetached(element) || isBody(element) || isHtml(element))\n          return $(document.body);\n\n        var position = element.getStyle('position');\n        if (position !== 'static') return proceed(element);\n\n        element.setStyle({ position: 'relative' });\n        var value = proceed(element);\n        element.setStyle({ position: position });\n        return value;\n      }\n    );\n\n    positionedOffset = positionedOffset.wrap(function(proceed, element) {\n      element = $(element);\n      if (!element.parentNode) return new Element.Offset(0, 0);\n      var position = element.getStyle('position');\n      if (position !== 'static') return proceed(element);\n\n      var offsetParent = element.getOffsetParent();\n      if (offsetParent && offsetParent.getStyle('position') === 'fixed')\n        hasLayout(offsetParent);\n\n      element.setStyle({ position: 'relative' });\n      var value = proceed(element);\n      element.setStyle({ position: position });\n      return value;\n    });\n  } else if (Prototype.Browser.Webkit) {\n    cumulativeOffset = function(element) {\n      element = $(element);\n      var valueT = 0, valueL = 0;\n      do {\n        valueT += element.offsetTop  || 0;\n        valueL += element.offsetLeft || 0;\n        if (element.offsetParent == document.body)\n          if (Element.getStyle(element, 'position') == 'absolute') break;\n\n        element = element.offsetParent;\n      } while (element);\n\n      return new Element.Offset(valueL, valueT);\n    };\n  }\n\n\n  Element.addMethods({\n    getLayout:              getLayout,\n    measure:                measure,\n    getDimensions:          getDimensions,\n    getOffsetParent:        getOffsetParent,\n    cumulativeOffset:       cumulativeOffset,\n    positionedOffset:       positionedOffset,\n    cumulativeScrollOffset: cumulativeScrollOffset,\n    viewportOffset:         viewportOffset,\n    absolutize:             absolutize,\n    relativize:             relativize\n  });\n\n  function isBody(element) {\n    return element.nodeName.toUpperCase() === 'BODY';\n  }\n\n  function isHtml(element) {\n    return element.nodeName.toUpperCase() === 'HTML';\n  }\n\n  function isDocument(element) {\n    return element.nodeType === Node.DOCUMENT_NODE;\n  }\n\n  function isDetached(element) {\n    return element !== document.body &&\n     !Element.descendantOf(element, document.body);\n  }\n\n  if ('getBoundingClientRect' in document.documentElement) {\n    Element.addMethods({\n      viewportOffset: function(element) {\n        element = $(element);\n        if (isDetached(element)) return new Element.Offset(0, 0);\n\n        var rect = element.getBoundingClientRect(),\n         docEl = document.documentElement;\n        return new Element.Offset(rect.left - docEl.clientLeft,\n         rect.top - docEl.clientTop);\n      }\n    });\n  }\n})();\nwindow.$$ = function() {\n  var expression = $A(arguments).join(', ');\n  return Prototype.Selector.select(expression, document);\n};\n\nPrototype.Selector = (function() {\n\n  function select() {\n    throw new Error('Method \"Prototype.Selector.select\" must be defined.');\n  }\n\n  function match() {\n    throw new Error('Method \"Prototype.Selector.match\" must be defined.');\n  }\n\n  function find(elements, expression, index) {\n    index = index || 0;\n    var match = Prototype.Selector.match, length = elements.length, matchIndex = 0, i;\n\n    for (i = 0; i < length; i++) {\n      if (match(elements[i], expression) && index == matchIndex++) {\n        return Element.extend(elements[i]);\n      }\n    }\n  }\n\n  function extendElements(elements) {\n    for (var i = 0, length = elements.length; i < length; i++) {\n      Element.extend(elements[i]);\n    }\n    return elements;\n  }\n\n\n  var K = Prototype.K;\n\n  return {\n    select: select,\n    match: match,\n    find: find,\n    extendElements: (Element.extend === K) ? K : extendElements,\n    extendElement: Element.extend\n  };\n})();\nPrototype._original_property = window.Sizzle;\n/*!\n * Sizzle CSS Selector Engine - v1.0\n *  Copyright 2009, The Dojo Foundation\n *  Released under the MIT, BSD, and GPL Licenses.\n *  More information: http://sizzlejs.com/\n */\n(function(){\n\nvar chunker = /((?:\\((?:\\([^()]+\\)|[^()]+)+\\)|\\[(?:\\[[^[\\]]*\\]|['\"][^'\"]*['\"]|[^[\\]'\"]+)+\\]|\\\\.|[^ >+~,(\\[\\\\]+)+|[>+~])(\\s*,\\s*)?((?:.|\\r|\\n)*)/g,\n\tdone = 0,\n\ttoString = Object.prototype.toString,\n\thasDuplicate = false,\n\tbaseHasDuplicate = true;\n\n[0, 0].sort(function(){\n\tbaseHasDuplicate = false;\n\treturn 0;\n});\n\nvar Sizzle = function(selector, context, results, seed) {\n\tresults = results || [];\n\tvar origContext = context = context || document;\n\n\tif ( context.nodeType !== 1 && context.nodeType !== 9 ) {\n\t\treturn [];\n\t}\n\n\tif ( !selector || typeof selector !== \"string\" ) {\n\t\treturn results;\n\t}\n\n\tvar parts = [], m, set, checkSet, check, mode, extra, prune = true, contextXML = isXML(context),\n\t\tsoFar = selector;\n\n\twhile ( (chunker.exec(\"\"), m = chunker.exec(soFar)) !== null ) {\n\t\tsoFar = m[3];\n\n\t\tparts.push( m[1] );\n\n\t\tif ( m[2] ) {\n\t\t\textra = m[3];\n\t\t\tbreak;\n\t\t}\n\t}\n\n\tif ( parts.length > 1 && origPOS.exec( selector ) ) {\n\t\tif ( parts.length === 2 && Expr.relative[ parts[0] ] ) {\n\t\t\tset = posProcess( parts[0] + parts[1], context );\n\t\t} else {\n\t\t\tset = Expr.relative[ parts[0] ] ?\n\t\t\t\t[ context ] :\n\t\t\t\tSizzle( parts.shift(), context );\n\n\t\t\twhile ( parts.length ) {\n\t\t\t\tselector = parts.shift();\n\n\t\t\t\tif ( Expr.relative[ selector ] )\n\t\t\t\t\tselector += parts.shift();\n\n\t\t\t\tset = posProcess( selector, set );\n\t\t\t}\n\t\t}\n\t} else {\n\t\tif ( !seed && parts.length > 1 && context.nodeType === 9 && !contextXML &&\n\t\t\t\tExpr.match.ID.test(parts[0]) && !Expr.match.ID.test(parts[parts.length - 1]) ) {\n\t\t\tvar ret = Sizzle.find( parts.shift(), context, contextXML );\n\t\t\tcontext = ret.expr ? Sizzle.filter( ret.expr, ret.set )[0] : ret.set[0];\n\t\t}\n\n\t\tif ( context ) {\n\t\t\tvar ret = seed ?\n\t\t\t\t{ expr: parts.pop(), set: makeArray(seed) } :\n\t\t\t\tSizzle.find( parts.pop(), parts.length === 1 && (parts[0] === \"~\" || parts[0] === \"+\") && context.parentNode ? context.parentNode : context, contextXML );\n\t\t\tset = ret.expr ? Sizzle.filter( ret.expr, ret.set ) : ret.set;\n\n\t\t\tif ( parts.length > 0 ) {\n\t\t\t\tcheckSet = makeArray(set);\n\t\t\t} else {\n\t\t\t\tprune = false;\n\t\t\t}\n\n\t\t\twhile ( parts.length ) {\n\t\t\t\tvar cur = parts.pop(), pop = cur;\n\n\t\t\t\tif ( !Expr.relative[ cur ] ) {\n\t\t\t\t\tcur = \"\";\n\t\t\t\t} else {\n\t\t\t\t\tpop = parts.pop();\n\t\t\t\t}\n\n\t\t\t\tif ( pop == null ) {\n\t\t\t\t\tpop = context;\n\t\t\t\t}\n\n\t\t\t\tExpr.relative[ cur ]( checkSet, pop, contextXML );\n\t\t\t}\n\t\t} else {\n\t\t\tcheckSet = parts = [];\n\t\t}\n\t}\n\n\tif ( !checkSet ) {\n\t\tcheckSet = set;\n\t}\n\n\tif ( !checkSet ) {\n\t\tthrow \"Syntax error, unrecognized expression: \" + (cur || selector);\n\t}\n\n\tif ( toString.call(checkSet) === \"[object Array]\" ) {\n\t\tif ( !prune ) {\n\t\t\tresults.push.apply( results, checkSet );\n\t\t} else if ( context && context.nodeType === 1 ) {\n\t\t\tfor ( var i = 0; checkSet[i] != null; i++ ) {\n\t\t\t\tif ( checkSet[i] && (checkSet[i] === true || checkSet[i].nodeType === 1 && contains(context, checkSet[i])) ) {\n\t\t\t\t\tresults.push( set[i] );\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfor ( var i = 0; checkSet[i] != null; i++ ) {\n\t\t\t\tif ( checkSet[i] && checkSet[i].nodeType === 1 ) {\n\t\t\t\t\tresults.push( set[i] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} else {\n\t\tmakeArray( checkSet, results );\n\t}\n\n\tif ( extra ) {\n\t\tSizzle( extra, origContext, results, seed );\n\t\tSizzle.uniqueSort( results );\n\t}\n\n\treturn results;\n};\n\nSizzle.uniqueSort = function(results){\n\tif ( sortOrder ) {\n\t\thasDuplicate = baseHasDuplicate;\n\t\tresults.sort(sortOrder);\n\n\t\tif ( hasDuplicate ) {\n\t\t\tfor ( var i = 1; i < results.length; i++ ) {\n\t\t\t\tif ( results[i] === results[i-1] ) {\n\t\t\t\t\tresults.splice(i--, 1);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn results;\n};\n\nSizzle.matches = function(expr, set){\n\treturn Sizzle(expr, null, null, set);\n};\n\nSizzle.find = function(expr, context, isXML){\n\tvar set, match;\n\n\tif ( !expr ) {\n\t\treturn [];\n\t}\n\n\tfor ( var i = 0, l = Expr.order.length; i < l; i++ ) {\n\t\tvar type = Expr.order[i], match;\n\n\t\tif ( (match = Expr.leftMatch[ type ].exec( expr )) ) {\n\t\t\tvar left = match[1];\n\t\t\tmatch.splice(1,1);\n\n\t\t\tif ( left.substr( left.length - 1 ) !== \"\\\\\" ) {\n\t\t\t\tmatch[1] = (match[1] || \"\").replace(/\\\\/g, \"\");\n\t\t\t\tset = Expr.find[ type ]( match, context, isXML );\n\t\t\t\tif ( set != null ) {\n\t\t\t\t\texpr = expr.replace( Expr.match[ type ], \"\" );\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tif ( !set ) {\n\t\tset = context.getElementsByTagName(\"*\");\n\t}\n\n\treturn {set: set, expr: expr};\n};\n\nSizzle.filter = function(expr, set, inplace, not){\n\tvar old = expr, result = [], curLoop = set, match, anyFound,\n\t\tisXMLFilter = set && set[0] && isXML(set[0]);\n\n\twhile ( expr && set.length ) {\n\t\tfor ( var type in Expr.filter ) {\n\t\t\tif ( (match = Expr.match[ type ].exec( expr )) != null ) {\n\t\t\t\tvar filter = Expr.filter[ type ], found, item;\n\t\t\t\tanyFound = false;\n\n\t\t\t\tif ( curLoop == result ) {\n\t\t\t\t\tresult = [];\n\t\t\t\t}\n\n\t\t\t\tif ( Expr.preFilter[ type ] ) {\n\t\t\t\t\tmatch = Expr.preFilter[ type ]( match, curLoop, inplace, result, not, isXMLFilter );\n\n\t\t\t\t\tif ( !match ) {\n\t\t\t\t\t\tanyFound = found = true;\n\t\t\t\t\t} else if ( match === true ) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif ( match ) {\n\t\t\t\t\tfor ( var i = 0; (item = curLoop[i]) != null; i++ ) {\n\t\t\t\t\t\tif ( item ) {\n\t\t\t\t\t\t\tfound = filter( item, match, i, curLoop );\n\t\t\t\t\t\t\tvar pass = not ^ !!found;\n\n\t\t\t\t\t\t\tif ( inplace && found != null ) {\n\t\t\t\t\t\t\t\tif ( pass ) {\n\t\t\t\t\t\t\t\t\tanyFound = true;\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tcurLoop[i] = false;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if ( pass ) {\n\t\t\t\t\t\t\t\tresult.push( item );\n\t\t\t\t\t\t\t\tanyFound = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif ( found !== undefined ) {\n\t\t\t\t\tif ( !inplace ) {\n\t\t\t\t\t\tcurLoop = result;\n\t\t\t\t\t}\n\n\t\t\t\t\texpr = expr.replace( Expr.match[ type ], \"\" );\n\n\t\t\t\t\tif ( !anyFound ) {\n\t\t\t\t\t\treturn [];\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif ( expr == old ) {\n\t\t\tif ( anyFound == null ) {\n\t\t\t\tthrow \"Syntax error, unrecognized expression: \" + expr;\n\t\t\t} else {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\told = expr;\n\t}\n\n\treturn curLoop;\n};\n\nvar Expr = Sizzle.selectors = {\n\torder: [ \"ID\", \"NAME\", \"TAG\" ],\n\tmatch: {\n\t\tID: /#((?:[\\w\\u00c0-\\uFFFF-]|\\\\.)+)/,\n\t\tCLASS: /\\.((?:[\\w\\u00c0-\\uFFFF-]|\\\\.)+)/,\n\t\tNAME: /\\[name=['\"]*((?:[\\w\\u00c0-\\uFFFF-]|\\\\.)+)['\"]*\\]/,\n\t\tATTR: /\\[\\s*((?:[\\w\\u00c0-\\uFFFF-]|\\\\.)+)\\s*(?:(\\S?=)\\s*(['\"]*)(.*?)\\3|)\\s*\\]/,\n\t\tTAG: /^((?:[\\w\\u00c0-\\uFFFF\\*-]|\\\\.)+)/,\n\t\tCHILD: /:(only|nth|last|first)-child(?:\\((even|odd|[\\dn+-]*)\\))?/,\n\t\tPOS: /:(nth|eq|gt|lt|first|last|even|odd)(?:\\((\\d*)\\))?(?=[^-]|$)/,\n\t\tPSEUDO: /:((?:[\\w\\u00c0-\\uFFFF-]|\\\\.)+)(?:\\((['\"]*)((?:\\([^\\)]+\\)|[^\\2\\(\\)]*)+)\\2\\))?/\n\t},\n\tleftMatch: {},\n\tattrMap: {\n\t\t\"class\": \"className\",\n\t\t\"for\": \"htmlFor\"\n\t},\n\tattrHandle: {\n\t\thref: function(elem){\n\t\t\treturn elem.getAttribute(\"href\");\n\t\t}\n\t},\n\trelative: {\n\t\t\"+\": function(checkSet, part, isXML){\n\t\t\tvar isPartStr = typeof part === \"string\",\n\t\t\t\tisTag = isPartStr && !/\\W/.test(part),\n\t\t\t\tisPartStrNotTag = isPartStr && !isTag;\n\n\t\t\tif ( isTag && !isXML ) {\n\t\t\t\tpart = part.toUpperCase();\n\t\t\t}\n\n\t\t\tfor ( var i = 0, l = checkSet.length, elem; i < l; i++ ) {\n\t\t\t\tif ( (elem = checkSet[i]) ) {\n\t\t\t\t\twhile ( (elem = elem.previousSibling) && elem.nodeType !== 1 ) {}\n\n\t\t\t\t\tcheckSet[i] = isPartStrNotTag || elem && elem.nodeName === part ?\n\t\t\t\t\t\telem || false :\n\t\t\t\t\t\telem === part;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( isPartStrNotTag ) {\n\t\t\t\tSizzle.filter( part, checkSet, true );\n\t\t\t}\n\t\t},\n\t\t\">\": function(checkSet, part, isXML){\n\t\t\tvar isPartStr = typeof part === \"string\";\n\n\t\t\tif ( isPartStr && !/\\W/.test(part) ) {\n\t\t\t\tpart = isXML ? part : part.toUpperCase();\n\n\t\t\t\tfor ( var i = 0, l = checkSet.length; i < l; i++ ) {\n\t\t\t\t\tvar elem = checkSet[i];\n\t\t\t\t\tif ( elem ) {\n\t\t\t\t\t\tvar parent = elem.parentNode;\n\t\t\t\t\t\tcheckSet[i] = parent.nodeName === part ? parent : false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor ( var i = 0, l = checkSet.length; i < l; i++ ) {\n\t\t\t\t\tvar elem = checkSet[i];\n\t\t\t\t\tif ( elem ) {\n\t\t\t\t\t\tcheckSet[i] = isPartStr ?\n\t\t\t\t\t\t\telem.parentNode :\n\t\t\t\t\t\t\telem.parentNode === part;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif ( isPartStr ) {\n\t\t\t\t\tSizzle.filter( part, checkSet, true );\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t\"\": function(checkSet, part, isXML){\n\t\t\tvar doneName = done++, checkFn = dirCheck;\n\n\t\t\tif ( !/\\W/.test(part) ) {\n\t\t\t\tvar nodeCheck = part = isXML ? part : part.toUpperCase();\n\t\t\t\tcheckFn = dirNodeCheck;\n\t\t\t}\n\n\t\t\tcheckFn(\"parentNode\", part, doneName, checkSet, nodeCheck, isXML);\n\t\t},\n\t\t\"~\": function(checkSet, part, isXML){\n\t\t\tvar doneName = done++, checkFn = dirCheck;\n\n\t\t\tif ( typeof part === \"string\" && !/\\W/.test(part) ) {\n\t\t\t\tvar nodeCheck = part = isXML ? part : part.toUpperCase();\n\t\t\t\tcheckFn = dirNodeCheck;\n\t\t\t}\n\n\t\t\tcheckFn(\"previousSibling\", part, doneName, checkSet, nodeCheck, isXML);\n\t\t}\n\t},\n\tfind: {\n\t\tID: function(match, context, isXML){\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && !isXML ) {\n\t\t\t\tvar m = context.getElementById(match[1]);\n\t\t\t\treturn m ? [m] : [];\n\t\t\t}\n\t\t},\n\t\tNAME: function(match, context, isXML){\n\t\t\tif ( typeof context.getElementsByName !== \"undefined\" ) {\n\t\t\t\tvar ret = [], results = context.getElementsByName(match[1]);\n\n\t\t\t\tfor ( var i = 0, l = results.length; i < l; i++ ) {\n\t\t\t\t\tif ( results[i].getAttribute(\"name\") === match[1] ) {\n\t\t\t\t\t\tret.push( results[i] );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn ret.length === 0 ? null : ret;\n\t\t\t}\n\t\t},\n\t\tTAG: function(match, context){\n\t\t\treturn context.getElementsByTagName(match[1]);\n\t\t}\n\t},\n\tpreFilter: {\n\t\tCLASS: function(match, curLoop, inplace, result, not, isXML){\n\t\t\tmatch = \" \" + match[1].replace(/\\\\/g, \"\") + \" \";\n\n\t\t\tif ( isXML ) {\n\t\t\t\treturn match;\n\t\t\t}\n\n\t\t\tfor ( var i = 0, elem; (elem = curLoop[i]) != null; i++ ) {\n\t\t\t\tif ( elem ) {\n\t\t\t\t\tif ( not ^ (elem.className && (\" \" + elem.className + \" \").indexOf(match) >= 0) ) {\n\t\t\t\t\t\tif ( !inplace )\n\t\t\t\t\t\t\tresult.push( elem );\n\t\t\t\t\t} else if ( inplace ) {\n\t\t\t\t\t\tcurLoop[i] = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn false;\n\t\t},\n\t\tID: function(match){\n\t\t\treturn match[1].replace(/\\\\/g, \"\");\n\t\t},\n\t\tTAG: function(match, curLoop){\n\t\t\tfor ( var i = 0; curLoop[i] === false; i++ ){}\n\t\t\treturn curLoop[i] && isXML(curLoop[i]) ? match[1] : match[1].toUpperCase();\n\t\t},\n\t\tCHILD: function(match){\n\t\t\tif ( match[1] == \"nth\" ) {\n\t\t\t\tvar test = /(-?)(\\d*)n((?:\\+|-)?\\d*)/.exec(\n\t\t\t\t\tmatch[2] == \"even\" && \"2n\" || match[2] == \"odd\" && \"2n+1\" ||\n\t\t\t\t\t!/\\D/.test( match[2] ) && \"0n+\" + match[2] || match[2]);\n\n\t\t\t\tmatch[2] = (test[1] + (test[2] || 1)) - 0;\n\t\t\t\tmatch[3] = test[3] - 0;\n\t\t\t}\n\n\t\t\tmatch[0] = done++;\n\n\t\t\treturn match;\n\t\t},\n\t\tATTR: function(match, curLoop, inplace, result, not, isXML){\n\t\t\tvar name = match[1].replace(/\\\\/g, \"\");\n\n\t\t\tif ( !isXML && Expr.attrMap[name] ) {\n\t\t\t\tmatch[1] = Expr.attrMap[name];\n\t\t\t}\n\n\t\t\tif ( match[2] === \"~=\" ) {\n\t\t\t\tmatch[4] = \" \" + match[4] + \" \";\n\t\t\t}\n\n\t\t\treturn match;\n\t\t},\n\t\tPSEUDO: function(match, curLoop, inplace, result, not){\n\t\t\tif ( match[1] === \"not\" ) {\n\t\t\t\tif ( ( chunker.exec(match[3]) || \"\" ).length > 1 || /^\\w/.test(match[3]) ) {\n\t\t\t\t\tmatch[3] = Sizzle(match[3], null, null, curLoop);\n\t\t\t\t} else {\n\t\t\t\t\tvar ret = Sizzle.filter(match[3], curLoop, inplace, true ^ not);\n\t\t\t\t\tif ( !inplace ) {\n\t\t\t\t\t\tresult.push.apply( result, ret );\n\t\t\t\t\t}\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t} else if ( Expr.match.POS.test( match[0] ) || Expr.match.CHILD.test( match[0] ) ) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\treturn match;\n\t\t},\n\t\tPOS: function(match){\n\t\t\tmatch.unshift( true );\n\t\t\treturn match;\n\t\t}\n\t},\n\tfilters: {\n\t\tenabled: function(elem){\n\t\t\treturn elem.disabled === false && elem.type !== \"hidden\";\n\t\t},\n\t\tdisabled: function(elem){\n\t\t\treturn elem.disabled === true;\n\t\t},\n\t\tchecked: function(elem){\n\t\t\treturn elem.checked === true;\n\t\t},\n\t\tselected: function(elem){\n\t\t\telem.parentNode.selectedIndex;\n\t\t\treturn elem.selected === true;\n\t\t},\n\t\tparent: function(elem){\n\t\t\treturn !!elem.firstChild;\n\t\t},\n\t\tempty: function(elem){\n\t\t\treturn !elem.firstChild;\n\t\t},\n\t\thas: function(elem, i, match){\n\t\t\treturn !!Sizzle( match[3], elem ).length;\n\t\t},\n\t\theader: function(elem){\n\t\t\treturn /h\\d/i.test( elem.nodeName );\n\t\t},\n\t\ttext: function(elem){\n\t\t\treturn \"text\" === elem.type;\n\t\t},\n\t\tradio: function(elem){\n\t\t\treturn \"radio\" === elem.type;\n\t\t},\n\t\tcheckbox: function(elem){\n\t\t\treturn \"checkbox\" === elem.type;\n\t\t},\n\t\tfile: function(elem){\n\t\t\treturn \"file\" === elem.type;\n\t\t},\n\t\tpassword: function(elem){\n\t\t\treturn \"password\" === elem.type;\n\t\t},\n\t\tsubmit: function(elem){\n\t\t\treturn \"submit\" === elem.type;\n\t\t},\n\t\timage: function(elem){\n\t\t\treturn \"image\" === elem.type;\n\t\t},\n\t\treset: function(elem){\n\t\t\treturn \"reset\" === elem.type;\n\t\t},\n\t\tbutton: function(elem){\n\t\t\treturn \"button\" === elem.type || elem.nodeName.toUpperCase() === \"BUTTON\";\n\t\t},\n\t\tinput: function(elem){\n\t\t\treturn /input|select|textarea|button/i.test(elem.nodeName);\n\t\t}\n\t},\n\tsetFilters: {\n\t\tfirst: function(elem, i){\n\t\t\treturn i === 0;\n\t\t},\n\t\tlast: function(elem, i, match, array){\n\t\t\treturn i === array.length - 1;\n\t\t},\n\t\teven: function(elem, i){\n\t\t\treturn i % 2 === 0;\n\t\t},\n\t\todd: function(elem, i){\n\t\t\treturn i % 2 === 1;\n\t\t},\n\t\tlt: function(elem, i, match){\n\t\t\treturn i < match[3] - 0;\n\t\t},\n\t\tgt: function(elem, i, match){\n\t\t\treturn i > match[3] - 0;\n\t\t},\n\t\tnth: function(elem, i, match){\n\t\t\treturn match[3] - 0 == i;\n\t\t},\n\t\teq: function(elem, i, match){\n\t\t\treturn match[3] - 0 == i;\n\t\t}\n\t},\n\tfilter: {\n\t\tPSEUDO: function(elem, match, i, array){\n\t\t\tvar name = match[1], filter = Expr.filters[ name ];\n\n\t\t\tif ( filter ) {\n\t\t\t\treturn filter( elem, i, match, array );\n\t\t\t} else if ( name === \"contains\" ) {\n\t\t\t\treturn (elem.textContent || elem.innerText || \"\").indexOf(match[3]) >= 0;\n\t\t\t} else if ( name === \"not\" ) {\n\t\t\t\tvar not = match[3];\n\n\t\t\t\tfor ( var i = 0, l = not.length; i < l; i++ ) {\n\t\t\t\t\tif ( not[i] === elem ) {\n\t\t\t\t\t\treturn false;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn true;\n\t\t\t}\n\t\t},\n\t\tCHILD: function(elem, match){\n\t\t\tvar type = match[1], node = elem;\n\t\t\tswitch (type) {\n\t\t\t\tcase 'only':\n\t\t\t\tcase 'first':\n\t\t\t\t\twhile ( (node = node.previousSibling) )  {\n\t\t\t\t\t\tif ( node.nodeType === 1 ) return false;\n\t\t\t\t\t}\n\t\t\t\t\tif ( type == 'first') return true;\n\t\t\t\t\tnode = elem;\n\t\t\t\tcase 'last':\n\t\t\t\t\twhile ( (node = node.nextSibling) )  {\n\t\t\t\t\t\tif ( node.nodeType === 1 ) return false;\n\t\t\t\t\t}\n\t\t\t\t\treturn true;\n\t\t\t\tcase 'nth':\n\t\t\t\t\tvar first = match[2], last = match[3];\n\n\t\t\t\t\tif ( first == 1 && last == 0 ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\n\t\t\t\t\tvar doneName = match[0],\n\t\t\t\t\t\tparent = elem.parentNode;\n\n\t\t\t\t\tif ( parent && (parent.sizcache !== doneName || !elem.nodeIndex) ) {\n\t\t\t\t\t\tvar count = 0;\n\t\t\t\t\t\tfor ( node = parent.firstChild; node; node = node.nextSibling ) {\n\t\t\t\t\t\t\tif ( node.nodeType === 1 ) {\n\t\t\t\t\t\t\t\tnode.nodeIndex = ++count;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tparent.sizcache = doneName;\n\t\t\t\t\t}\n\n\t\t\t\t\tvar diff = elem.nodeIndex - last;\n\t\t\t\t\tif ( first == 0 ) {\n\t\t\t\t\t\treturn diff == 0;\n\t\t\t\t\t} else {\n\t\t\t\t\t\treturn ( diff % first == 0 && diff / first >= 0 );\n\t\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\tID: function(elem, match){\n\t\t\treturn elem.nodeType === 1 && elem.getAttribute(\"id\") === match;\n\t\t},\n\t\tTAG: function(elem, match){\n\t\t\treturn (match === \"*\" && elem.nodeType === 1) || elem.nodeName === match;\n\t\t},\n\t\tCLASS: function(elem, match){\n\t\t\treturn (\" \" + (elem.className || elem.getAttribute(\"class\")) + \" \")\n\t\t\t\t.indexOf( match ) > -1;\n\t\t},\n\t\tATTR: function(elem, match){\n\t\t\tvar name = match[1],\n\t\t\t\tresult = Expr.attrHandle[ name ] ?\n\t\t\t\t\tExpr.attrHandle[ name ]( elem ) :\n\t\t\t\t\telem[ name ] != null ?\n\t\t\t\t\t\telem[ name ] :\n\t\t\t\t\t\telem.getAttribute( name ),\n\t\t\t\tvalue = result + \"\",\n\t\t\t\ttype = match[2],\n\t\t\t\tcheck = match[4];\n\n\t\t\treturn result == null ?\n\t\t\t\ttype === \"!=\" :\n\t\t\t\ttype === \"=\" ?\n\t\t\t\tvalue === check :\n\t\t\t\ttype === \"*=\" ?\n\t\t\t\tvalue.indexOf(check) >= 0 :\n\t\t\t\ttype === \"~=\" ?\n\t\t\t\t(\" \" + value + \" \").indexOf(check) >= 0 :\n\t\t\t\t!check ?\n\t\t\t\tvalue && result !== false :\n\t\t\t\ttype === \"!=\" ?\n\t\t\t\tvalue != check :\n\t\t\t\ttype === \"^=\" ?\n\t\t\t\tvalue.indexOf(check) === 0 :\n\t\t\t\ttype === \"$=\" ?\n\t\t\t\tvalue.substr(value.length - check.length) === check :\n\t\t\t\ttype === \"|=\" ?\n\t\t\t\tvalue === check || value.substr(0, check.length + 1) === check + \"-\" :\n\t\t\t\tfalse;\n\t\t},\n\t\tPOS: function(elem, match, i, array){\n\t\t\tvar name = match[2], filter = Expr.setFilters[ name ];\n\n\t\t\tif ( filter ) {\n\t\t\t\treturn filter( elem, i, match, array );\n\t\t\t}\n\t\t}\n\t}\n};\n\nvar origPOS = Expr.match.POS;\n\nfor ( var type in Expr.match ) {\n\tExpr.match[ type ] = new RegExp( Expr.match[ type ].source + /(?![^\\[]*\\])(?![^\\(]*\\))/.source );\n\tExpr.leftMatch[ type ] = new RegExp( /(^(?:.|\\r|\\n)*?)/.source + Expr.match[ type ].source );\n}\n\nvar makeArray = function(array, results) {\n\tarray = Array.prototype.slice.call( array, 0 );\n\n\tif ( results ) {\n\t\tresults.push.apply( results, array );\n\t\treturn results;\n\t}\n\n\treturn array;\n};\n\ntry {\n\tArray.prototype.slice.call( document.documentElement.childNodes, 0 );\n\n} catch(e){\n\tmakeArray = function(array, results) {\n\t\tvar ret = results || [];\n\n\t\tif ( toString.call(array) === \"[object Array]\" ) {\n\t\t\tArray.prototype.push.apply( ret, array );\n\t\t} else {\n\t\t\tif ( typeof array.length === \"number\" ) {\n\t\t\t\tfor ( var i = 0, l = array.length; i < l; i++ ) {\n\t\t\t\t\tret.push( array[i] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor ( var i = 0; array[i]; i++ ) {\n\t\t\t\t\tret.push( array[i] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn ret;\n\t};\n}\n\nvar sortOrder;\n\nif ( document.documentElement.compareDocumentPosition ) {\n\tsortOrder = function( a, b ) {\n\t\tif ( !a.compareDocumentPosition || !b.compareDocumentPosition ) {\n\t\t\tif ( a == b ) {\n\t\t\t\thasDuplicate = true;\n\t\t\t}\n\t\t\treturn 0;\n\t\t}\n\n\t\tvar ret = a.compareDocumentPosition(b) & 4 ? -1 : a === b ? 0 : 1;\n\t\tif ( ret === 0 ) {\n\t\t\thasDuplicate = true;\n\t\t}\n\t\treturn ret;\n\t};\n} else if ( \"sourceIndex\" in document.documentElement ) {\n\tsortOrder = function( a, b ) {\n\t\tif ( !a.sourceIndex || !b.sourceIndex ) {\n\t\t\tif ( a == b ) {\n\t\t\t\thasDuplicate = true;\n\t\t\t}\n\t\t\treturn 0;\n\t\t}\n\n\t\tvar ret = a.sourceIndex - b.sourceIndex;\n\t\tif ( ret === 0 ) {\n\t\t\thasDuplicate = true;\n\t\t}\n\t\treturn ret;\n\t};\n} else if ( document.createRange ) {\n\tsortOrder = function( a, b ) {\n\t\tif ( !a.ownerDocument || !b.ownerDocument ) {\n\t\t\tif ( a == b ) {\n\t\t\t\thasDuplicate = true;\n\t\t\t}\n\t\t\treturn 0;\n\t\t}\n\n\t\tvar aRange = a.ownerDocument.createRange(), bRange = b.ownerDocument.createRange();\n\t\taRange.setStart(a, 0);\n\t\taRange.setEnd(a, 0);\n\t\tbRange.setStart(b, 0);\n\t\tbRange.setEnd(b, 0);\n\t\tvar ret = aRange.compareBoundaryPoints(Range.START_TO_END, bRange);\n\t\tif ( ret === 0 ) {\n\t\t\thasDuplicate = true;\n\t\t}\n\t\treturn ret;\n\t};\n}\n\n(function(){\n\tvar form = document.createElement(\"div\"),\n\t\tid = \"script\" + (new Date).getTime();\n\tform.innerHTML = \"<a name='\" + id + \"'/>\";\n\n\tvar root = document.documentElement;\n\troot.insertBefore( form, root.firstChild );\n\n\tif ( !!document.getElementById( id ) ) {\n\t\tExpr.find.ID = function(match, context, isXML){\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && !isXML ) {\n\t\t\t\tvar m = context.getElementById(match[1]);\n\t\t\t\treturn m ? m.id === match[1] || typeof m.getAttributeNode !== \"undefined\" && m.getAttributeNode(\"id\").nodeValue === match[1] ? [m] : undefined : [];\n\t\t\t}\n\t\t};\n\n\t\tExpr.filter.ID = function(elem, match){\n\t\t\tvar node = typeof elem.getAttributeNode !== \"undefined\" && elem.getAttributeNode(\"id\");\n\t\t\treturn elem.nodeType === 1 && node && node.nodeValue === match;\n\t\t};\n\t}\n\n\troot.removeChild( form );\n\troot = form = null; // release memory in IE\n})();\n\n(function(){\n\n\tvar div = document.createElement(\"div\");\n\tdiv.appendChild( document.createComment(\"\") );\n\n\tif ( div.getElementsByTagName(\"*\").length > 0 ) {\n\t\tExpr.find.TAG = function(match, context){\n\t\t\tvar results = context.getElementsByTagName(match[1]);\n\n\t\t\tif ( match[1] === \"*\" ) {\n\t\t\t\tvar tmp = [];\n\n\t\t\t\tfor ( var i = 0; results[i]; i++ ) {\n\t\t\t\t\tif ( results[i].nodeType === 1 ) {\n\t\t\t\t\t\ttmp.push( results[i] );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tresults = tmp;\n\t\t\t}\n\n\t\t\treturn results;\n\t\t};\n\t}\n\n\tdiv.innerHTML = \"<a href='#'></a>\";\n\tif ( div.firstChild && typeof div.firstChild.getAttribute !== \"undefined\" &&\n\t\t\tdiv.firstChild.getAttribute(\"href\") !== \"#\" ) {\n\t\tExpr.attrHandle.href = function(elem){\n\t\t\treturn elem.getAttribute(\"href\", 2);\n\t\t};\n\t}\n\n\tdiv = null; // release memory in IE\n})();\n\nif ( document.querySelectorAll ) (function(){\n\tvar oldSizzle = Sizzle, div = document.createElement(\"div\");\n\tdiv.innerHTML = \"<p class='TEST'></p>\";\n\n\tif ( div.querySelectorAll && div.querySelectorAll(\".TEST\").length === 0 ) {\n\t\treturn;\n\t}\n\n\tSizzle = function(query, context, extra, seed){\n\t\tcontext = context || document;\n\n\t\tif ( !seed && context.nodeType === 9 && !isXML(context) ) {\n\t\t\ttry {\n\t\t\t\treturn makeArray( context.querySelectorAll(query), extra );\n\t\t\t} catch(e){}\n\t\t}\n\n\t\treturn oldSizzle(query, context, extra, seed);\n\t};\n\n\tfor ( var prop in oldSizzle ) {\n\t\tSizzle[ prop ] = oldSizzle[ prop ];\n\t}\n\n\tdiv = null; // release memory in IE\n})();\n\nif ( document.getElementsByClassName && document.documentElement.getElementsByClassName ) (function(){\n\tvar div = document.createElement(\"div\");\n\tdiv.innerHTML = \"<div class='test e'></div><div class='test'></div>\";\n\n\tif ( div.getElementsByClassName(\"e\").length === 0 )\n\t\treturn;\n\n\tdiv.lastChild.className = \"e\";\n\n\tif ( div.getElementsByClassName(\"e\").length === 1 )\n\t\treturn;\n\n\tExpr.order.splice(1, 0, \"CLASS\");\n\tExpr.find.CLASS = function(match, context, isXML) {\n\t\tif ( typeof context.getElementsByClassName !== \"undefined\" && !isXML ) {\n\t\t\treturn context.getElementsByClassName(match[1]);\n\t\t}\n\t};\n\n\tdiv = null; // release memory in IE\n})();\n\nfunction dirNodeCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) {\n\tvar sibDir = dir == \"previousSibling\" && !isXML;\n\tfor ( var i = 0, l = checkSet.length; i < l; i++ ) {\n\t\tvar elem = checkSet[i];\n\t\tif ( elem ) {\n\t\t\tif ( sibDir && elem.nodeType === 1 ){\n\t\t\t\telem.sizcache = doneName;\n\t\t\t\telem.sizset = i;\n\t\t\t}\n\t\t\telem = elem[dir];\n\t\t\tvar match = false;\n\n\t\t\twhile ( elem ) {\n\t\t\t\tif ( elem.sizcache === doneName ) {\n\t\t\t\t\tmatch = checkSet[elem.sizset];\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tif ( elem.nodeType === 1 && !isXML ){\n\t\t\t\t\telem.sizcache = doneName;\n\t\t\t\t\telem.sizset = i;\n\t\t\t\t}\n\n\t\t\t\tif ( elem.nodeName === cur ) {\n\t\t\t\t\tmatch = elem;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\telem = elem[dir];\n\t\t\t}\n\n\t\t\tcheckSet[i] = match;\n\t\t}\n\t}\n}\n\nfunction dirCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) {\n\tvar sibDir = dir == \"previousSibling\" && !isXML;\n\tfor ( var i = 0, l = checkSet.length; i < l; i++ ) {\n\t\tvar elem = checkSet[i];\n\t\tif ( elem ) {\n\t\t\tif ( sibDir && elem.nodeType === 1 ) {\n\t\t\t\telem.sizcache = doneName;\n\t\t\t\telem.sizset = i;\n\t\t\t}\n\t\t\telem = elem[dir];\n\t\t\tvar match = false;\n\n\t\t\twhile ( elem ) {\n\t\t\t\tif ( elem.sizcache === doneName ) {\n\t\t\t\t\tmatch = checkSet[elem.sizset];\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\tif ( !isXML ) {\n\t\t\t\t\t\telem.sizcache = doneName;\n\t\t\t\t\t\telem.sizset = i;\n\t\t\t\t\t}\n\t\t\t\t\tif ( typeof cur !== \"string\" ) {\n\t\t\t\t\t\tif ( elem === cur ) {\n\t\t\t\t\t\t\tmatch = true;\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else if ( Sizzle.filter( cur, [elem] ).length > 0 ) {\n\t\t\t\t\t\tmatch = elem;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\telem = elem[dir];\n\t\t\t}\n\n\t\t\tcheckSet[i] = match;\n\t\t}\n\t}\n}\n\nvar contains = document.compareDocumentPosition ?  function(a, b){\n\treturn a.compareDocumentPosition(b) & 16;\n} : function(a, b){\n\treturn a !== b && (a.contains ? a.contains(b) : true);\n};\n\nvar isXML = function(elem){\n\treturn elem.nodeType === 9 && elem.documentElement.nodeName !== \"HTML\" ||\n\t\t!!elem.ownerDocument && elem.ownerDocument.documentElement.nodeName !== \"HTML\";\n};\n\nvar posProcess = function(selector, context){\n\tvar tmpSet = [], later = \"\", match,\n\t\troot = context.nodeType ? [context] : context;\n\n\twhile ( (match = Expr.match.PSEUDO.exec( selector )) ) {\n\t\tlater += match[0];\n\t\tselector = selector.replace( Expr.match.PSEUDO, \"\" );\n\t}\n\n\tselector = Expr.relative[selector] ? selector + \"*\" : selector;\n\n\tfor ( var i = 0, l = root.length; i < l; i++ ) {\n\t\tSizzle( selector, root[i], tmpSet );\n\t}\n\n\treturn Sizzle.filter( later, tmpSet );\n};\n\n\nwindow.Sizzle = Sizzle;\n\n})();\n\n;(function(engine) {\n  var extendElements = Prototype.Selector.extendElements;\n\n  function select(selector, scope) {\n    return extendElements(engine(selector, scope || document));\n  }\n\n  function match(element, selector) {\n    return engine.matches(selector, [element]).length == 1;\n  }\n\n  Prototype.Selector.engine = engine;\n  Prototype.Selector.select = select;\n  Prototype.Selector.match = match;\n})(Sizzle);\n\nwindow.Sizzle = Prototype._original_property;\ndelete Prototype._original_property;\n\nvar Form = {\n  reset: function(form) {\n    form = $(form);\n    form.reset();\n    return form;\n  },\n\n  serializeElements: function(elements, options) {\n    if (typeof options != 'object') options = { hash: !!options };\n    else if (Object.isUndefined(options.hash)) options.hash = true;\n    var key, value, submitted = false, submit = options.submit, accumulator, initial;\n\n    if (options.hash) {\n      initial = {};\n      accumulator = function(result, key, value) {\n        if (key in result) {\n          if (!Object.isArray(result[key])) result[key] = [result[key]];\n          result[key].push(value);\n        } else result[key] = value;\n        return result;\n      };\n    } else {\n      initial = '';\n      accumulator = function(result, key, value) {\n        return result + (result ? '&' : '') + encodeURIComponent(key) + '=' + encodeURIComponent(value);\n      }\n    }\n\n    return elements.inject(initial, function(result, element) {\n      if (!element.disabled && element.name) {\n        key = element.name; value = $(element).getValue();\n        if (value != null && element.type != 'file' && (element.type != 'submit' || (!submitted &&\n            submit !== false && (!submit || key == submit) && (submitted = true)))) {\n          result = accumulator(result, key, value);\n        }\n      }\n      return result;\n    });\n  }\n};\n\nForm.Methods = {\n  serialize: function(form, options) {\n    return Form.serializeElements(Form.getElements(form), options);\n  },\n\n  getElements: function(form) {\n    var elements = $(form).getElementsByTagName('*'),\n        element,\n        arr = [ ],\n        serializers = Form.Element.Serializers;\n    for (var i = 0; element = elements[i]; i++) {\n      arr.push(element);\n    }\n    return arr.inject([], function(elements, child) {\n      if (serializers[child.tagName.toLowerCase()])\n        elements.push(Element.extend(child));\n      return elements;\n    })\n  },\n\n  getInputs: function(form, typeName, name) {\n    form = $(form);\n    var inputs = form.getElementsByTagName('input');\n\n    if (!typeName && !name) return $A(inputs).map(Element.extend);\n\n    for (var i = 0, matchingInputs = [], length = inputs.length; i < length; i++) {\n      var input = inputs[i];\n      if ((typeName && input.type != typeName) || (name && input.name != name))\n        continue;\n      matchingInputs.push(Element.extend(input));\n    }\n\n    return matchingInputs;\n  },\n\n  disable: function(form) {\n    form = $(form);\n    Form.getElements(form).invoke('disable');\n    return form;\n  },\n\n  enable: function(form) {\n    form = $(form);\n    Form.getElements(form).invoke('enable');\n    return form;\n  },\n\n  findFirstElement: function(form) {\n    var elements = $(form).getElements().findAll(function(element) {\n      return 'hidden' != element.type && !element.disabled;\n    });\n    var firstByIndex = elements.findAll(function(element) {\n      return element.hasAttribute('tabIndex') && element.tabIndex >= 0;\n    }).sortBy(function(element) { return element.tabIndex }).first();\n\n    return firstByIndex ? firstByIndex : elements.find(function(element) {\n      return /^(?:input|select|textarea)$/i.test(element.tagName);\n    });\n  },\n\n  focusFirstElement: function(form) {\n    form = $(form);\n    var element = form.findFirstElement();\n    if (element) element.activate();\n    return form;\n  },\n\n  request: function(form, options) {\n    form = $(form), options = Object.clone(options || { });\n\n    var params = options.parameters, action = form.readAttribute('action') || '';\n    if (action.blank()) action = window.location.href;\n    options.parameters = form.serialize(true);\n\n    if (params) {\n      if (Object.isString(params)) params = params.toQueryParams();\n      Object.extend(options.parameters, params);\n    }\n\n    if (form.hasAttribute('method') && !options.method)\n      options.method = form.method;\n\n    return new Ajax.Request(action, options);\n  }\n};\n\n/*--------------------------------------------------------------------------*/\n\n\nForm.Element = {\n  focus: function(element) {\n    $(element).focus();\n    return element;\n  },\n\n  select: function(element) {\n    $(element).select();\n    return element;\n  }\n};\n\nForm.Element.Methods = {\n\n  serialize: function(element) {\n    element = $(element);\n    if (!element.disabled && element.name) {\n      var value = element.getValue();\n      if (value != undefined) {\n        var pair = { };\n        pair[element.name] = value;\n        return Object.toQueryString(pair);\n      }\n    }\n    return '';\n  },\n\n  getValue: function(element) {\n    element = $(element);\n    var method = element.tagName.toLowerCase();\n    return Form.Element.Serializers[method](element);\n  },\n\n  setValue: function(element, value) {\n    element = $(element);\n    var method = element.tagName.toLowerCase();\n    Form.Element.Serializers[method](element, value);\n    return element;\n  },\n\n  clear: function(element) {\n    $(element).value = '';\n    return element;\n  },\n\n  present: function(element) {\n    return $(element).value != '';\n  },\n\n  activate: function(element) {\n    element = $(element);\n    try {\n      element.focus();\n      if (element.select && (element.tagName.toLowerCase() != 'input' ||\n          !(/^(?:button|reset|submit)$/i.test(element.type))))\n        element.select();\n    } catch (e) { }\n    return element;\n  },\n\n  disable: function(element) {\n    element = $(element);\n    element.disabled = true;\n    return element;\n  },\n\n  enable: function(element) {\n    element = $(element);\n    element.disabled = false;\n    return element;\n  }\n};\n\n/*--------------------------------------------------------------------------*/\n\nvar Field = Form.Element;\n\nvar $F = Form.Element.Methods.getValue;\n\n/*--------------------------------------------------------------------------*/\n\nForm.Element.Serializers = (function() {\n  function input(element, value) {\n    switch (element.type.toLowerCase()) {\n      case 'checkbox':\n      case 'radio':\n        return inputSelector(element, value);\n      default:\n        return valueSelector(element, value);\n    }\n  }\n\n  function inputSelector(element, value) {\n    if (Object.isUndefined(value))\n      return element.checked ? element.value : null;\n    else element.checked = !!value;\n  }\n\n  function valueSelector(element, value) {\n    if (Object.isUndefined(value)) return element.value;\n    else element.value = value;\n  }\n\n  function select(element, value) {\n    if (Object.isUndefined(value))\n      return (element.type === 'select-one' ? selectOne : selectMany)(element);\n\n    var opt, currentValue, single = !Object.isArray(value);\n    for (var i = 0, length = element.length; i < length; i++) {\n      opt = element.options[i];\n      currentValue = this.optionValue(opt);\n      if (single) {\n        if (currentValue == value) {\n          opt.selected = true;\n          return;\n        }\n      }\n      else opt.selected = value.include(currentValue);\n    }\n  }\n\n  function selectOne(element) {\n    var index = element.selectedIndex;\n    return index >= 0 ? optionValue(element.options[index]) : null;\n  }\n\n  function selectMany(element) {\n    var values, length = element.length;\n    if (!length) return null;\n\n    for (var i = 0, values = []; i < length; i++) {\n      var opt = element.options[i];\n      if (opt.selected) values.push(optionValue(opt));\n    }\n    return values;\n  }\n\n  function optionValue(opt) {\n    return Element.hasAttribute(opt, 'value') ? opt.value : opt.text;\n  }\n\n  return {\n    input:         input,\n    inputSelector: inputSelector,\n    textarea:      valueSelector,\n    select:        select,\n    selectOne:     selectOne,\n    selectMany:    selectMany,\n    optionValue:   optionValue,\n    button:        valueSelector\n  };\n})();\n\n/*--------------------------------------------------------------------------*/\n\n\nAbstract.TimedObserver = Class.create(PeriodicalExecuter, {\n  initialize: function($super, element, frequency, callback) {\n    $super(callback, frequency);\n    this.element   = $(element);\n    this.lastValue = this.getValue();\n  },\n\n  execute: function() {\n    var value = this.getValue();\n    if (Object.isString(this.lastValue) && Object.isString(value) ?\n        this.lastValue != value : String(this.lastValue) != String(value)) {\n      this.callback(this.element, value);\n      this.lastValue = value;\n    }\n  }\n});\n\nForm.Element.Observer = Class.create(Abstract.TimedObserver, {\n  getValue: function() {\n    return Form.Element.getValue(this.element);\n  }\n});\n\nForm.Observer = Class.create(Abstract.TimedObserver, {\n  getValue: function() {\n    return Form.serialize(this.element);\n  }\n});\n\n/*--------------------------------------------------------------------------*/\n\nAbstract.EventObserver = Class.create({\n  initialize: function(element, callback) {\n    this.element  = $(element);\n    this.callback = callback;\n\n    this.lastValue = this.getValue();\n    if (this.element.tagName.toLowerCase() == 'form')\n      this.registerFormCallbacks();\n    else\n      this.registerCallback(this.element);\n  },\n\n  onElementEvent: function() {\n    var value = this.getValue();\n    if (this.lastValue != value) {\n      this.callback(this.element, value);\n      this.lastValue = value;\n    }\n  },\n\n  registerFormCallbacks: function() {\n    Form.getElements(this.element).each(this.registerCallback, this);\n  },\n\n  registerCallback: function(element) {\n    if (element.type) {\n      switch (element.type.toLowerCase()) {\n        case 'checkbox':\n        case 'radio':\n          Event.observe(element, 'click', this.onElementEvent.bind(this));\n          break;\n        default:\n          Event.observe(element, 'change', this.onElementEvent.bind(this));\n          break;\n      }\n    }\n  }\n});\n\nForm.Element.EventObserver = Class.create(Abstract.EventObserver, {\n  getValue: function() {\n    return Form.Element.getValue(this.element);\n  }\n});\n\nForm.EventObserver = Class.create(Abstract.EventObserver, {\n  getValue: function() {\n    return Form.serialize(this.element);\n  }\n});\n(function() {\n\n  var Event = {\n    KEY_BACKSPACE: 8,\n    KEY_TAB:       9,\n    KEY_RETURN:   13,\n    KEY_ESC:      27,\n    KEY_LEFT:     37,\n    KEY_UP:       38,\n    KEY_RIGHT:    39,\n    KEY_DOWN:     40,\n    KEY_DELETE:   46,\n    KEY_HOME:     36,\n    KEY_END:      35,\n    KEY_PAGEUP:   33,\n    KEY_PAGEDOWN: 34,\n    KEY_INSERT:   45,\n\n    cache: {}\n  };\n\n  var docEl = document.documentElement;\n  var MOUSEENTER_MOUSELEAVE_EVENTS_SUPPORTED = 'onmouseenter' in docEl\n    && 'onmouseleave' in docEl;\n\n\n\n  var isIELegacyEvent = function(event) { return false; };\n\n  if (window.attachEvent) {\n    if (window.addEventListener) {\n      isIELegacyEvent = function(event) {\n        return !(event instanceof window.Event);\n      };\n    } else {\n      isIELegacyEvent = function(event) { return true; };\n    }\n  }\n\n  var _isButton;\n\n  function _isButtonForDOMEvents(event, code) {\n    return event.which ? (event.which === code + 1) : (event.button === code);\n  }\n\n  var legacyButtonMap = { 0: 1, 1: 4, 2: 2 };\n  function _isButtonForLegacyEvents(event, code) {\n    return event.button === legacyButtonMap[code];\n  }\n\n  function _isButtonForWebKit(event, code) {\n    switch (code) {\n      case 0: return event.which == 1 && !event.metaKey;\n      case 1: return event.which == 2 || (event.which == 1 && event.metaKey);\n      case 2: return event.which == 3;\n      default: return false;\n    }\n  }\n\n  if (window.attachEvent) {\n    if (!window.addEventListener) {\n      _isButton = _isButtonForLegacyEvents;\n    } else {\n      _isButton = function(event, code) {\n        return isIELegacyEvent(event) ? _isButtonForLegacyEvents(event, code) :\n         _isButtonForDOMEvents(event, code);\n      }\n    }\n  } else if (Prototype.Browser.WebKit) {\n    _isButton = _isButtonForWebKit;\n  } else {\n    _isButton = _isButtonForDOMEvents;\n  }\n\n  function isLeftClick(event)   { return _isButton(event, 0) }\n\n  function isMiddleClick(event) { return _isButton(event, 1) }\n\n  function isRightClick(event)  { return _isButton(event, 2) }\n\n  function element(event) {\n    event = Event.extend(event);\n\n    var node = event.target, type = event.type,\n     currentTarget = event.currentTarget;\n\n    if (currentTarget && currentTarget.tagName) {\n      if (type === 'load' || type === 'error' ||\n        (type === 'click' && currentTarget.tagName.toLowerCase() === 'input'\n          && currentTarget.type === 'radio'))\n            node = currentTarget;\n    }\n\n    if (node.nodeType == Node.TEXT_NODE)\n      node = node.parentNode;\n\n    return Element.extend(node);\n  }\n\n  function findElement(event, expression) {\n    var element = Event.element(event);\n\n    if (!expression) return element;\n    while (element) {\n      if (Object.isElement(element) && Prototype.Selector.match(element, expression)) {\n        return Element.extend(element);\n      }\n      element = element.parentNode;\n    }\n  }\n\n  function pointer(event) {\n    return { x: pointerX(event), y: pointerY(event) };\n  }\n\n  function pointerX(event) {\n    var docElement = document.documentElement,\n     body = document.body || { scrollLeft: 0 };\n\n    return event.pageX || (event.clientX +\n      (docElement.scrollLeft || body.scrollLeft) -\n      (docElement.clientLeft || 0));\n  }\n\n  function pointerY(event) {\n    var docElement = document.documentElement,\n     body = document.body || { scrollTop: 0 };\n\n    return  event.pageY || (event.clientY +\n       (docElement.scrollTop || body.scrollTop) -\n       (docElement.clientTop || 0));\n  }\n\n\n  function stop(event) {\n    Event.extend(event);\n    event.preventDefault();\n    event.stopPropagation();\n\n    event.stopped = true;\n  }\n\n\n  Event.Methods = {\n    isLeftClick:   isLeftClick,\n    isMiddleClick: isMiddleClick,\n    isRightClick:  isRightClick,\n\n    element:     element,\n    findElement: findElement,\n\n    pointer:  pointer,\n    pointerX: pointerX,\n    pointerY: pointerY,\n\n    stop: stop\n  };\n\n  var methods = Object.keys(Event.Methods).inject({ }, function(m, name) {\n    m[name] = Event.Methods[name].methodize();\n    return m;\n  });\n\n  if (window.attachEvent) {\n    function _relatedTarget(event) {\n      var element;\n      switch (event.type) {\n        case 'mouseover':\n        case 'mouseenter':\n          element = event.fromElement;\n          break;\n        case 'mouseout':\n        case 'mouseleave':\n          element = event.toElement;\n          break;\n        default:\n          return null;\n      }\n      return Element.extend(element);\n    }\n\n    var additionalMethods = {\n      stopPropagation: function() { this.cancelBubble = true },\n      preventDefault:  function() { this.returnValue = false },\n      inspect: function() { return '[object Event]' }\n    };\n\n    Event.extend = function(event, element) {\n      if (!event) return false;\n\n      if (!isIELegacyEvent(event)) return event;\n\n      if (event._extendedByPrototype) return event;\n      event._extendedByPrototype = Prototype.emptyFunction;\n\n      var pointer = Event.pointer(event);\n\n      Object.extend(event, {\n        target: event.srcElement || element,\n        relatedTarget: _relatedTarget(event),\n        pageX:  pointer.x,\n        pageY:  pointer.y\n      });\n\n      Object.extend(event, methods);\n      Object.extend(event, additionalMethods);\n\n      return event;\n    };\n  } else {\n    Event.extend = Prototype.K;\n  }\n\n  if (window.addEventListener) {\n    Event.prototype = window.Event.prototype || document.createEvent('HTMLEvents').__proto__;\n    Object.extend(Event.prototype, methods);\n  }\n\n  function _createResponder(element, eventName, handler) {\n    var registry = Element.retrieve(element, 'prototype_event_registry');\n\n    if (Object.isUndefined(registry)) {\n      CACHE.push(element);\n      registry = Element.retrieve(element, 'prototype_event_registry', $H());\n    }\n\n    var respondersForEvent = registry.get(eventName);\n    if (Object.isUndefined(respondersForEvent)) {\n      respondersForEvent = [];\n      registry.set(eventName, respondersForEvent);\n    }\n\n    if (respondersForEvent.pluck('handler').include(handler)) return false;\n\n    var responder;\n    if (eventName.include(\":\")) {\n      responder = function(event) {\n        if (Object.isUndefined(event.eventName))\n          return false;\n\n        if (event.eventName !== eventName)\n          return false;\n\n        Event.extend(event, element);\n        handler.call(element, event);\n      };\n    } else {\n      if (!MOUSEENTER_MOUSELEAVE_EVENTS_SUPPORTED &&\n       (eventName === \"mouseenter\" || eventName === \"mouseleave\")) {\n        if (eventName === \"mouseenter\" || eventName === \"mouseleave\") {\n          responder = function(event) {\n            Event.extend(event, element);\n\n            var parent = event.relatedTarget;\n            while (parent && parent !== element) {\n              try { parent = parent.parentNode; }\n              catch(e) { parent = element; }\n            }\n\n            if (parent === element) return;\n\n            handler.call(element, event);\n          };\n        }\n      } else {\n        responder = function(event) {\n          Event.extend(event, element);\n          handler.call(element, event);\n        };\n      }\n    }\n\n    responder.handler = handler;\n    respondersForEvent.push(responder);\n    return responder;\n  }\n\n  function _destroyCache() {\n    for (var i = 0, length = CACHE.length; i < length; i++) {\n      Event.stopObserving(CACHE[i]);\n      CACHE[i] = null;\n    }\n  }\n\n  var CACHE = [];\n\n  if (Prototype.Browser.IE)\n    window.attachEvent('onunload', _destroyCache);\n\n  if (Prototype.Browser.WebKit)\n    window.addEventListener('unload', Prototype.emptyFunction, false);\n\n\n  var _getDOMEventName = Prototype.K,\n      translations = { mouseenter: \"mouseover\", mouseleave: \"mouseout\" };\n\n  if (!MOUSEENTER_MOUSELEAVE_EVENTS_SUPPORTED) {\n    _getDOMEventName = function(eventName) {\n      return (translations[eventName] || eventName);\n    };\n  }\n\n  function observe(element, eventName, handler) {\n    element = $(element);\n\n    var responder = _createResponder(element, eventName, handler);\n\n    if (!responder) return element;\n\n    if (eventName.include(':')) {\n      if (element.addEventListener)\n        element.addEventListener(\"dataavailable\", responder, false);\n      else {\n        element.attachEvent(\"ondataavailable\", responder);\n        element.attachEvent(\"onlosecapture\", responder);\n      }\n    } else {\n      var actualEventName = _getDOMEventName(eventName);\n\n      if (element.addEventListener)\n        element.addEventListener(actualEventName, responder, false);\n      else\n        element.attachEvent(\"on\" + actualEventName, responder);\n    }\n\n    return element;\n  }\n\n  function stopObserving(element, eventName, handler) {\n    element = $(element);\n\n    var registry = Element.retrieve(element, 'prototype_event_registry');\n    if (!registry) return element;\n\n    if (!eventName) {\n      registry.each( function(pair) {\n        var eventName = pair.key;\n        stopObserving(element, eventName);\n      });\n      return element;\n    }\n\n    var responders = registry.get(eventName);\n    if (!responders) return element;\n\n    if (!handler) {\n      responders.each(function(r) {\n        stopObserving(element, eventName, r.handler);\n      });\n      return element;\n    }\n\n    var i = responders.length, responder;\n    while (i--) {\n      if (responders[i].handler === handler) {\n        responder = responders[i];\n        break;\n      }\n    }\n    if (!responder) return element;\n\n    if (eventName.include(':')) {\n      if (element.removeEventListener)\n        element.removeEventListener(\"dataavailable\", responder, false);\n      else {\n        element.detachEvent(\"ondataavailable\", responder);\n        element.detachEvent(\"onlosecapture\", responder);\n      }\n    } else {\n      var actualEventName = _getDOMEventName(eventName);\n      if (element.removeEventListener)\n        element.removeEventListener(actualEventName, responder, false);\n      else\n        element.detachEvent('on' + actualEventName, responder);\n    }\n\n    registry.set(eventName, responders.without(responder));\n\n    return element;\n  }\n\n  function fire(element, eventName, memo, bubble) {\n    element = $(element);\n\n    if (Object.isUndefined(bubble))\n      bubble = true;\n\n    if (element == document && document.createEvent && !element.dispatchEvent)\n      element = document.documentElement;\n\n    var event;\n    if (document.createEvent) {\n      event = document.createEvent('HTMLEvents');\n      event.initEvent('dataavailable', bubble, true);\n    } else {\n      event = document.createEventObject();\n      event.eventType = bubble ? 'ondataavailable' : 'onlosecapture';\n    }\n\n    event.eventName = eventName;\n    event.memo = memo || { };\n\n    if (document.createEvent)\n      element.dispatchEvent(event);\n    else\n      element.fireEvent(event.eventType, event);\n\n    return Event.extend(event);\n  }\n\n  Event.Handler = Class.create({\n    initialize: function(element, eventName, selector, callback) {\n      this.element   = $(element);\n      this.eventName = eventName;\n      this.selector  = selector;\n      this.callback  = callback;\n      this.handler   = this.handleEvent.bind(this);\n    },\n\n    start: function() {\n      Event.observe(this.element, this.eventName, this.handler);\n      return this;\n    },\n\n    stop: function() {\n      Event.stopObserving(this.element, this.eventName, this.handler);\n      return this;\n    },\n\n    handleEvent: function(event) {\n      var element = Event.findElement(event, this.selector);\n      if (element) this.callback.call(this.element, event, element);\n    }\n  });\n\n  function on(element, eventName, selector, callback) {\n    element = $(element);\n    if (Object.isFunction(selector) && Object.isUndefined(callback)) {\n      callback = selector, selector = null;\n    }\n\n    return new Event.Handler(element, eventName, selector, callback).start();\n  }\n\n  Object.extend(Event, Event.Methods);\n\n  Object.extend(Event, {\n    fire:          fire,\n    observe:       observe,\n    stopObserving: stopObserving,\n    on:            on\n  });\n\n  Element.addMethods({\n    fire:          fire,\n\n    observe:       observe,\n\n    stopObserving: stopObserving,\n\n    on:            on\n  });\n\n  Object.extend(document, {\n    fire:          fire.methodize(),\n\n    observe:       observe.methodize(),\n\n    stopObserving: stopObserving.methodize(),\n\n    on:            on.methodize(),\n\n    loaded:        false\n  });\n\n  if (window.Event) Object.extend(window.Event, Event);\n  else window.Event = Event;\n})();\n\n(function() {\n  /* Support for the DOMContentLoaded event is based on work by Dan Webb,\n     Matthias Miller, Dean Edwards, John Resig, and Diego Perini. */\n\n  var timer;\n\n  function fireContentLoadedEvent() {\n    if (document.loaded) return;\n    if (timer) window.clearTimeout(timer);\n    document.loaded = true;\n    document.fire('dom:loaded');\n  }\n\n  function checkReadyState() {\n    if (document.readyState === 'complete') {\n      document.stopObserving('readystatechange', checkReadyState);\n      fireContentLoadedEvent();\n    }\n  }\n\n  function pollDoScroll() {\n    try { document.documentElement.doScroll('left'); }\n    catch(e) {\n      timer = pollDoScroll.defer();\n      return;\n    }\n    fireContentLoadedEvent();\n  }\n\n  if (document.addEventListener) {\n    document.addEventListener('DOMContentLoaded', fireContentLoadedEvent, false);\n  } else {\n    document.observe('readystatechange', checkReadyState);\n    if (window == top)\n      timer = pollDoScroll.defer();\n  }\n\n  Event.observe(window, 'load', fireContentLoadedEvent);\n})();\n\nElement.addMethods();\n\n/*------------------------------- DEPRECATED -------------------------------*/\n\nHash.toQueryString = Object.toQueryString;\n\nvar Toggle = { display: Element.toggle };\n\nElement.Methods.childOf = Element.Methods.descendantOf;\n\nvar Insertion = {\n  Before: function(element, content) {\n    return Element.insert(element, {before:content});\n  },\n\n  Top: function(element, content) {\n    return Element.insert(element, {top:content});\n  },\n\n  Bottom: function(element, content) {\n    return Element.insert(element, {bottom:content});\n  },\n\n  After: function(element, content) {\n    return Element.insert(element, {after:content});\n  }\n};\n\nvar $continue = new Error('\"throw $continue\" is deprecated, use \"return\" instead');\n\nvar Position = {\n  includeScrollOffsets: false,\n\n  prepare: function() {\n    this.deltaX =  window.pageXOffset\n                || document.documentElement.scrollLeft\n                || document.body.scrollLeft\n                || 0;\n    this.deltaY =  window.pageYOffset\n                || document.documentElement.scrollTop\n                || document.body.scrollTop\n                || 0;\n  },\n\n  within: function(element, x, y) {\n    if (this.includeScrollOffsets)\n      return this.withinIncludingScrolloffsets(element, x, y);\n    this.xcomp = x;\n    this.ycomp = y;\n    this.offset = Element.cumulativeOffset(element);\n\n    return (y >= this.offset[1] &&\n            y <  this.offset[1] + element.offsetHeight &&\n            x >= this.offset[0] &&\n            x <  this.offset[0] + element.offsetWidth);\n  },\n\n  withinIncludingScrolloffsets: function(element, x, y) {\n    var offsetcache = Element.cumulativeScrollOffset(element);\n\n    this.xcomp = x + offsetcache[0] - this.deltaX;\n    this.ycomp = y + offsetcache[1] - this.deltaY;\n    this.offset = Element.cumulativeOffset(element);\n\n    return (this.ycomp >= this.offset[1] &&\n            this.ycomp <  this.offset[1] + element.offsetHeight &&\n            this.xcomp >= this.offset[0] &&\n            this.xcomp <  this.offset[0] + element.offsetWidth);\n  },\n\n  overlap: function(mode, element) {\n    if (!mode) return 0;\n    if (mode == 'vertical')\n      return ((this.offset[1] + element.offsetHeight) - this.ycomp) /\n        element.offsetHeight;\n    if (mode == 'horizontal')\n      return ((this.offset[0] + element.offsetWidth) - this.xcomp) /\n        element.offsetWidth;\n  },\n\n\n  cumulativeOffset: Element.Methods.cumulativeOffset,\n\n  positionedOffset: Element.Methods.positionedOffset,\n\n  absolutize: function(element) {\n    Position.prepare();\n    return Element.absolutize(element);\n  },\n\n  relativize: function(element) {\n    Position.prepare();\n    return Element.relativize(element);\n  },\n\n  realOffset: Element.Methods.cumulativeScrollOffset,\n\n  offsetParent: Element.Methods.getOffsetParent,\n\n  page: Element.Methods.viewportOffset,\n\n  clone: function(source, target, options) {\n    options = options || { };\n    return Element.clonePosition(target, source, options);\n  }\n};\n\n/*--------------------------------------------------------------------------*/\n\nif (!document.getElementsByClassName) document.getElementsByClassName = function(instanceMethods){\n  function iter(name) {\n    return name.blank() ? null : \"[contains(concat(' ', @class, ' '), ' \" + name + \" ')]\";\n  }\n\n  instanceMethods.getElementsByClassName = Prototype.BrowserFeatures.XPath ?\n  function(element, className) {\n    className = className.toString().strip();\n    var cond = /\\s/.test(className) ? $w(className).map(iter).join('') : iter(className);\n    return cond ? document._getElementsByXPath('.//*' + cond, element) : [];\n  } : function(element, className) {\n    className = className.toString().strip();\n    var elements = [], classNames = (/\\s/.test(className) ? $w(className) : null);\n    if (!classNames && !className) return elements;\n\n    var nodes = $(element).getElementsByTagName('*');\n    className = ' ' + className + ' ';\n\n    for (var i = 0, child, cn; child = nodes[i]; i++) {\n      if (child.className && (cn = ' ' + child.className + ' ') && (cn.include(className) ||\n          (classNames && classNames.all(function(name) {\n            return !name.toString().blank() && cn.include(' ' + name + ' ');\n          }))))\n        elements.push(Element.extend(child));\n    }\n    return elements;\n  };\n\n  return function(className, parentElement) {\n    return $(parentElement || document.body).getElementsByClassName(className);\n  };\n}(Element.Methods);\n\n/*--------------------------------------------------------------------------*/\n\nElement.ClassNames = Class.create();\nElement.ClassNames.prototype = {\n  initialize: function(element) {\n    this.element = $(element);\n  },\n\n  _each: function(iterator) {\n    this.element.className.split(/\\s+/).select(function(name) {\n      return name.length > 0;\n    })._each(iterator);\n  },\n\n  set: function(className) {\n    this.element.className = className;\n  },\n\n  add: function(classNameToAdd) {\n    if (this.include(classNameToAdd)) return;\n    this.set($A(this).concat(classNameToAdd).join(' '));\n  },\n\n  remove: function(classNameToRemove) {\n    if (!this.include(classNameToRemove)) return;\n    this.set($A(this).without(classNameToRemove).join(' '));\n  },\n\n  toString: function() {\n    return $A(this).join(' ');\n  }\n};\n\nObject.extend(Element.ClassNames.prototype, Enumerable);\n\n/*--------------------------------------------------------------------------*/\n\n(function() {\n  window.Selector = Class.create({\n    initialize: function(expression) {\n      this.expression = expression.strip();\n    },\n\n    findElements: function(rootElement) {\n      return Prototype.Selector.select(this.expression, rootElement);\n    },\n\n    match: function(element) {\n      return Prototype.Selector.match(element, this.expression);\n    },\n\n    toString: function() {\n      return this.expression;\n    },\n\n    inspect: function() {\n      return \"#<Selector: \" + this.expression + \">\";\n    }\n  });\n\n  Object.extend(Selector, {\n    matchElements: function(elements, expression) {\n      var match = Prototype.Selector.match,\n          results = [];\n\n      for (var i = 0, length = elements.length; i < length; i++) {\n        var element = elements[i];\n        if (match(element, expression)) {\n          results.push(Element.extend(element));\n        }\n      }\n      return results;\n    },\n\n    findElement: function(elements, expression, index) {\n      index = index || 0;\n      var matchIndex = 0, element;\n      for (var i = 0, length = elements.length; i < length; i++) {\n        element = elements[i];\n        if (Prototype.Selector.match(element, expression) && index === matchIndex++) {\n          return Element.extend(element);\n        }\n      }\n    },\n\n    findChildElements: function(element, expressions) {\n      var selector = expressions.toArray().join(', ');\n      return Prototype.Selector.select(selector, element || document);\n    }\n  });\n})();\n"
  },
  {
    "path": "public/docsupport/style.css",
    "content": "/* Reset */\nhtml, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; }\n\narticle, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }\n\nblockquote, q { quotes: none; }\nblockquote:before, blockquote:after, q:before, q:after { content: \"\"; content: none; }\nins { background-color: #ff9; color: #000; text-decoration: none; }\nmark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold; }\ndel { text-decoration: line-through; }\nabbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; }\ntable { border-collapse: collapse; border-spacing: 0; }\nhr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }\ninput, select { vertical-align: middle; }\n\nbody { font:13px/1.231 sans-serif; *font-size:small; } /* Hack retained to preserve specificity */\nselect, input, textarea, button { font:99% sans-serif; }\npre, code, kbd, samp { font-family: monospace, sans-serif; }\n\n\nbody { background: #EEE; color: #444; line-height: 1.4em; }\n\nheader h1 { color: black; font-size: 2em; line-height: 1.1em; display: inline-block; height: 27px; margin: 20px 0 25px; }\nheader h1 small { font-size: 0.6em; }\n\ndiv#content { background: white; border: 1px solid #ccc; border-width: 0 1px 1px; margin: 0 auto; padding: 40px 50px 40px; width: 738px; }\n\nfooter { color: #999; padding-top: 40px; font-size: 0.8em; text-align: center; }\n\nbody { font-family: sans-serif; font-size: 1em; }\n\np { margin: 0 0 .7em; max-width: 700px; }\ntable+p { margin-top: 1em; }\n\nh2 { border-bottom: 1px solid #ccc; font-size: 1.2em; margin: 3em 0 1em 0; font-weight: bold;}\nh3 { font-weight: bold; }\n\nh2.intro { border-bottom: none; font-size: 1em; font-weight: normal; margin-top:0; }\n\nul li { list-style: disc; margin-left: 1em; margin-bottom: 1.25em; }\nol li { margin-left: 1.25em; }\nol ul, ul ul { margin: .25em 0 0; }\nol ul li, ul ul li { list-style-type: circle; margin: 0 0 .25em 1em; }\n\nli > p { margin-top: .25em; }\n\ndiv.side-by-side { width: 100%; margin-bottom: 1em; }\ndiv.side-by-side > div { float: left; width: 49%; }\ndiv.side-by-side > div > em { margin-bottom: 10px; display: block; }\n\n.faqs em { display: block; }\n\n.clearfix:after {\n  content: \"\\0020\";\n  display: block;\n  height: 0;\n  clear: both;\n  overflow: hidden;\n  visibility: hidden;\n}\n\na { color: #F36C00; outline: none; text-decoration: none; }\na:hover { text-decoration: underline; }\n\nul.credits li { margin-bottom: .25em; }\n\nstrong { font-weight: bold; }\ni { font-style: italic; }\n\n.button {\n  background: #fafafa;\n  background: -webkit-linear-gradient(top, #ffffff, #eeeeee);\n  background: -moz-linear-gradient(top, #ffffff, #eeeeee);\n  background: -o-linear-gradient(top, #ffffff, #eeeeee);\n  background: linear-gradient(to bottom, #ffffff, #eeeeee);\n  border: 1px solid #bbbbbb;\n  border-radius: 4px;\n  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.2);\n  color: #555555;\n  cursor: pointer;\n  display: inline-block;\n  font-family: \"Helvetica Neue\", Arial, Verdana, \"Nimbus Sans L\", sans-serif;\n  font-size: 13px;\n  font-weight: 500;\n  height: 31px;\n  line-height: 28px;\n  outline: none;\n  padding: 0 13px;\n  text-shadow: 0 1px 0 white;\n  text-decoration: none;\n  vertical-align: middle;\n  white-space: nowrap;\n  -webkit-font-smoothing: antialiased;\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\n\n.button-blue {\n  background: #1385e5;\n  background: -webkit-linear-gradient(top, #53b2fc, #1385e5);\n  background: -moz-linear-gradient(top, #53b2fc, #1385e5);\n  background: -o-linear-gradient(top, #53b2fc, #1385e5);\n  background: linear-gradient(to bottom, #53b2fc, #1385e5);\n  border-color: #075fa9;\n  color: white;\n  font-weight: bold;\n  text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.4);\n}\n\n\n/* Tweak navbar brand link to be super sleek\n-------------------------------------------------- */\n.oss-bar {\n  top: 0;\n  right: 20px;\n  position: fixed;\n  z-index: 1030;\n}\n.oss-bar ul {\n  float: right;\n  margin: 0;\n  list-style: none;\n}\n.oss-bar ul li {\n  list-style: none;\n  float: left;\n  line-height: 0;\n  margin: 0;\n}\n.oss-bar ul li a {\n   -moz-box-sizing:    border-box;\n  -webkit-box-sizing: border-box;\n  -ms-box-sizing:     border-box;\n   box-sizing:        border-box;\n  border: 0;\n  margin-top: -10px;\n  display: block;\n  height: 58px;\n  background: #F36C00 url(oss-credit.png) no-repeat 20px 22px;\n  padding: 22px 20px 12px 20px;\n  text-indent: 120%; /* stupid padding */\n  white-space: nowrap;\n  overflow: hidden;\n  -webkit-transition: all 0.10s ease-in-out;\n  -moz-transition: all 0.10s ease-in-out;\n  transition: all 0.15s ease-in-out;\n}\n.oss-bar ul li a:hover {\n  margin-top: 0px;\n}\n.oss-bar a.harvest {\n  width: 196px;\n  background-color: #F36C00;\n  background-position: -142px 22px;\n  padding-right: 22px; /* optical illusion */\n}\n.oss-bar a.fork {\n  width: 162px;\n  background-color: #333333;\n}\n\n.docs-table th, .docs-table td {\n  border: 1px solid #000;\n  padding: 4px 6px;\n  white-space: nowrap;\n}\n\n.docs-table td:last-child {\n  white-space: normal;\n}\n\n.docs-table th {\n  font-weight: bold;\n  text-align: left;\n}\n\n#content pre[class*=language-] {\n  font-size: 14px;\n  margin-bottom: 20px;\n}\n\n#content pre[class*=language-] code {\n  font-size: 14px;\n  padding: 0;\n}\n\n#content code[class*=language-] {\n  font-size: 12px;\n  padding: 2px 4px;\n}\n\n.anchor {\n  color: inherit;\n  position: relative;\n}\n\n.anchor:hover {\n  background: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSI3Ij48ZyBmaWxsPSIjNDE0MDQyIj48cGF0aCBkPSJNOS44IDdoLS45bC0uOS0uMWMtLjctLjMtMS40LS43LTEuOC0xLjMtLjItLjEtLjMtLjMtLjMtLjVsLS4zLS40Yy0uMS0uNC0uMi0uOC0uMi0xLjIgMC0uNC4xLS44LjItMS4yaDEuN2MtLjMuNC0uNC44LS40IDEuMiAwIC40LjEuOC4zIDEuMS4xLjIuMi4zLjQuNC4xLjEuMi4yLjQuMy4zLjIuNy4zIDEgLjNoMy40YzEuMiAwIDIuMi0uOSAyLjItMi4xcy0xLTIuMS0yLjItMi4xaC0xLjRjLS4zLS42LS43LTEtMS4yLTEuNGgyLjZjMiAwIDMuNiAxLjYgMy42IDMuNXMtMS42IDMuNS0zLjYgMy41aC0yLjZ6TTguNCAyYy0uMS0uMS0uMi0uMy0uNC0uMy0uMy0uMi0uNy0uMy0xLS4zaC0zLjRjLTEuMiAwLTIuMi45LTIuMiAyLjEgMCAxLjIgMSAyLjEgMi4yIDIuMWgxLjRjLjMuNS43IDEgMS4yIDEuNGgtMi42Yy0yIDAtMy42LTEuNi0zLjYtMy41czEuNi0zLjUgMy42LTMuNWgzLjUwMDAwMDAwMDAwMDAwMDRsLjkuMWMuNy4yIDEuNC43IDEuOCAxLjMuMS4xLjIuMy4zLjUuMS4xLjIuMy4yLjUuMS40LjIuOC4yIDEuMiAwIC40LS4xLjgtLjIgMS4yaC0xLjZjLjMtLjUuNC0uOS40LTEuM3MtLjEtLjgtLjMtMS4xYy0uMS0uMi0uMi0uMy0uNC0uNHoiLz48L2c+PC9zdmc+) 0 50% no-repeat;\n  background-size: 21px 9px;\n  margin-left: -27px;\n  padding-left: 27px;\n  text-decoration: none;\n}\n\n.select,\n.chosen-select,\n.chosen-select-no-single,\n.chosen-select-no-results,\n.chosen-select-deselect,\n.chosen-select-rtl,\n.chosen-select-width {\n  width: 350px;\n}\n\n.jquery-version-refer {\n  margin-top: 40px;\n  font-style: italic;\n}\n"
  },
  {
    "path": "public/index.html",
    "content": "<!doctype html>\n<html lang=\"en\">\n<head>\n  <meta charset=\"utf-8\">\n  <title>Chosen: A jQuery Plugin by Harvest to Tame Unwieldy Select Boxes</title>\n  <link rel=\"stylesheet\" href=\"docsupport/style.css\">\n  <link rel=\"stylesheet\" href=\"docsupport/prism.css\">\n  <link rel=\"stylesheet\" href=\"chosen.css\">\n\n  <meta http-equiv=\"Content-Security-Policy\" content=\"default-src &apos;self&apos;; script-src &apos;self&apos; https://ajax.googleapis.com; style-src &apos;self&apos;; img-src &apos;self&apos; data:\">\n\n</head>\n<body>\n  <form>\n    <div id=\"container\">\n      <div id=\"content\">\n        <header>\n          <h1>Chosen <small>(<span id=\"latest-version\">v1.8.7</span>)</small></h1>\n        </header>\n        <p>Chosen is a jQuery plugin that makes long, unwieldy select boxes much more user-friendly.</p>\n\n        <p>\n          <a class=\"button button-blue\" href=\"https://github.com/harvesthq/chosen/releases\">Downloads</a>\n          <a class=\"button\" href=\"https://github.com/harvesthq/chosen\">Project Source</a>\n          <a class=\"button\" href=\"https://github.com/harvesthq/chosen/blob/master/contributing.md\">Contribute</a>\n        </p>\n\n        <h2><a name=\"standard-select\" class=\"anchor\" href=\"#standard-select\">Standard Select</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <div>\n          <em>Turns This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"select\" tabindex=\"1\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n        <div>\n          <em>Into This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"chosen-select\" tabindex=\"2\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"multiple-select\" class=\"anchor\" href=\"#multiple-select\">Multiple Select</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <div>\n          <em>Turns This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"select\" multiple tabindex=\"3\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n        <div>\n          <em>Into This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"chosen-select\" multiple tabindex=\"4\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"optgroup-support\" class=\"anchor\" href=\"#optgroup-support\">&lt;optgroup&gt; Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <div>\n          <em>Single Select with Groups</em>\n          <select data-placeholder=\"Your Favorite Football Team\" class=\"chosen-select\" tabindex=\"5\">\n            <option value=\"\"></option>\n            <optgroup label=\"NFC EAST\">\n              <option>Dallas Cowboys</option>\n              <option>New York Giants</option>\n              <option>Philadelphia Eagles</option>\n              <option>Washington Redskins</option>\n            </optgroup>\n            <optgroup label=\"NFC NORTH\">\n              <option>Chicago Bears</option>\n              <option>Detroit Lions</option>\n              <option>Green Bay Packers</option>\n              <option>Minnesota Vikings</option>\n            </optgroup>\n            <optgroup label=\"NFC SOUTH\">\n              <option>Atlanta Falcons</option>\n              <option>Carolina Panthers</option>\n              <option>New Orleans Saints</option>\n              <option>Tampa Bay Buccaneers</option>\n            </optgroup>\n            <optgroup label=\"NFC WEST\">\n              <option>Arizona Cardinals</option>\n              <option>St. Louis Rams</option>\n              <option>San Francisco 49ers</option>\n              <option>Seattle Seahawks</option>\n            </optgroup>\n            <optgroup label=\"AFC EAST\">\n              <option>Buffalo Bills</option>\n              <option>Miami Dolphins</option>\n              <option>New England Patriots</option>\n              <option>New York Jets</option>\n            </optgroup>\n            <optgroup label=\"AFC NORTH\">\n              <option>Baltimore Ravens</option>\n              <option>Cincinnati Bengals</option>\n              <option>Cleveland Browns</option>\n              <option>Pittsburgh Steelers</option>\n            </optgroup>\n            <optgroup label=\"AFC SOUTH\">\n              <option>Houston Texans</option>\n              <option>Indianapolis Colts</option>\n              <option>Jacksonville Jaguars</option>\n              <option>Tennessee Titans</option>\n            </optgroup>\n            <optgroup label=\"AFC WEST\">\n              <option>Denver Broncos</option>\n              <option>Kansas City Chiefs</option>\n              <option>Oakland Raiders</option>\n              <option>San Diego Chargers</option>\n            </optgroup>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select with Groups</em>\n          <select data-placeholder=\"Your Favorite Football Team\" class=\"chosen-select\" multiple tabindex=\"6\">\n            <option value=\"\"></option>\n            <optgroup label=\"NFC EAST\">\n              <option>Dallas Cowboys</option>\n              <option>New York Giants</option>\n              <option>Philadelphia Eagles</option>\n              <option>Washington Redskins</option>\n            </optgroup>\n            <optgroup label=\"NFC NORTH\">\n              <option>Chicago Bears</option>\n              <option>Detroit Lions</option>\n              <option>Green Bay Packers</option>\n              <option>Minnesota Vikings</option>\n            </optgroup>\n            <optgroup label=\"NFC SOUTH\">\n              <option>Atlanta Falcons</option>\n              <option>Carolina Panthers</option>\n              <option>New Orleans Saints</option>\n              <option>Tampa Bay Buccaneers</option>\n            </optgroup>\n            <optgroup label=\"NFC WEST\">\n              <option>Arizona Cardinals</option>\n              <option>St. Louis Rams</option>\n              <option>San Francisco 49ers</option>\n              <option>Seattle Seahawks</option>\n            </optgroup>\n            <optgroup label=\"AFC EAST\">\n              <option>Buffalo Bills</option>\n              <option>Miami Dolphins</option>\n              <option>New England Patriots</option>\n              <option>New York Jets</option>\n            </optgroup>\n            <optgroup label=\"AFC NORTH\">\n              <option>Baltimore Ravens</option>\n              <option>Cincinnati Bengals</option>\n              <option>Cleveland Browns</option>\n              <option>Pittsburgh Steelers</option>\n            </optgroup>\n            <optgroup label=\"AFC SOUTH\">\n              <option>Houston Texans</option>\n              <option>Indianapolis Colts</option>\n              <option>Jacksonville Jaguars</option>\n              <option>Tennessee Titans</option>\n            </optgroup>\n            <optgroup label=\"AFC WEST\">\n              <option>Denver Broncos</option>\n              <option>Kansas City Chiefs</option>\n              <option>Oakland Raiders</option>\n              <option>San Diego Chargers</option>\n            </optgroup>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"selected-and-disabled-support\" class=\"anchor\" href=\"#selected-and-disabled-support\">Selected and Disabled Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Chosen automatically highlights selected options and removes disabled options.</p>\n        <div>\n          <em>Single Select</em>\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select\" tabindex=\"7\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option disabled>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option disabled>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select\" tabindex=\"8\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option disabled>Sun Bear</option>\n            <option selected>Polar Bear</option>\n            <option disabled>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"hide-search-on-single-select\" class=\"anchor\" href=\"#hide-search-on-single-select\">Hide Search on Single Select</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>The <code>disable_search_threshold</code> option can be specified to hide the search input on single selects if there are <i>n</i> or fewer options.</p>\n        <pre><code class=\"language-javascript\">$(\".chosen-select\").chosen({disable_search_threshold: 10});</code></pre>\n        <p></p>\n        <div>\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select-no-single\" tabindex=\"9\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected disabled>Sloth Bear</option>\n            <option disabled>Sun Bear</option>\n            <option selected disabled>Paddington Bear</option>\n            <option selected>Polar Bear</option>\n            <option disabled>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"default-text-support\" class=\"anchor\" href=\"#default-text-support\">Default Text Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Chosen automatically sets the default field text (\"Choose a country...\") by reading the select element's data-placeholder value. If no data-placeholder value is present, it will default to \"Select an Option\" or \"Select Some Options\" depending on whether the select is single or multiple. You can change these elements in the plugin js file as you see fit.</p>\n        <pre><code class=\"language-markup\">&lt;select <strong>data-placeholder=\"Choose a country...\"</strong> multiple class=\"chosen-select\"&gt;</code></pre>\n        <p><strong>Note:</strong> on single selects, the first element is assumed to be selected by the browser. To take advantage of the default text support, you will need to include a blank option as the first element of your select list.</p>\n      </div>\n\n      <h2><a name=\"no-results-text-support\" class=\"anchor\" href=\"#no-results-text-support\">No Results Text Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Setting the \"No results\" search text is as easy as passing an option when you create Chosen:</p>\n        <pre><code class=\"language-javascript\"> $(\".chosen-select\").chosen({no_results_text: \"Oops, nothing found!\"}); </code></pre>\n        <p></p>\n        <div>\n          <em>Single Select</em>\n          <select data-placeholder=\"Type &apos;C&apos; to view\" class=\"chosen-select-no-results\" tabindex=\"10\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select</em>\n          <select data-placeholder=\"Type &apos;C&apos; to view\" multiple class=\"chosen-select-no-results\" tabindex=\"11\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"limit-selected-options-in-multiselect\" class=\"anchor\" href=\"#limit-selected-options-in-multiselect\">Limit Selected Options in Multiselect</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>You can easily limit how many options the user can select:</p>\n        <pre><code class=\"language-javascript\">$(\".chosen-select\").chosen({max_selected_options: 5});</code></pre>\n        <p>If you try to select another option with limit reached <code class=\"language-javascript\">chosen:maxselected</code> event is triggered:</p>\n        <pre><code class=\"language-javascript\"> $(\".chosen-select\").bind(\"chosen:maxselected\", function () { ... }); </code></pre>\n      </div>\n\n      <h2><a name=\"allow-deselect-on-single-selects\" class=\"anchor\" href=\"#allow-deselect-on-single-selects\">Allow Deselect on Single Selects</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>When a single select box isn't a required field, you can set <code class=\"language-javascript\">allow_single_deselect: true</code> and Chosen will add a UI element for option deselection. This will only work if the first option has blank text.</p>\n        <div class=\"side-by-side clearfix\">\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select-deselect\" tabindex=\"12\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"right-to-left-support\" class=\"anchor\" href=\"#right-to-left-support\">Right-to-Left Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>You can set right-to-left text by setting <code class=\"language-javascript\">rtl: true</code></p>\n        <pre><code class=\"language-javascript\"> $(\".chosen-select\").chosen({rtl: true}); </code></pre>\n\n        <div>\n          <em>Single Right-to-Left Select</em>\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select-rtl\" tabindex=\"13\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option>Polar Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Right-to-Left Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select-rtl\" tabindex=\"14\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option selected>Polar Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"change-update-events\" class=\"anchor\" href=\"#change-update-events\">Observing, Updating, and Destroying Chosen</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <ul>\n          <li>\n            <h3>Observing Form Field Changes</h3>\n            <p>When working with form fields, you often want to perform some behavior after a value has been selected or deselected. Whenever a user selects a field in Chosen, it triggers a \"change\" event on the original form field. That lets you do something like this:</p>\n            <pre><code class=\"language-javascript\">$(\"#form_field\").chosen().change( &hellip; );</code></pre>\n          </li>\n          <li>\n            <h3>Updating Chosen Dynamically</h3>\n            <p>If you need to update the options in your select field and want Chosen to pick up the changes, you'll need to trigger the \"chosen:updated\" event on the field. Chosen will re-build itself based on the updated content.</p>\n              <pre><code class=\"language-javascript\">$(\"#form_field\").trigger(\"chosen:updated\");</code></pre>\n          </li>\n          <li>\n            <h3>Destroying Chosen</h3>\n            <p>To destroy Chosen and revert back to the native select:</p>\n              <pre><code class=\"language-javascript\">$(\"#form_field\").chosen(\"destroy\");</code></pre>\n          </li>\n        </ul>\n      </div>\n\n      <h2><a name=\"custom-width-support\" class=\"anchor\" href=\"#custom-width-support\">Custom Width Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Using a custom width with Chosen is as easy as passing an option when you create Chosen:</p>\n        <pre><code class=\"language-javascript\"> $(\".chosen-select\").chosen({width: \"95%\"}); </code></pre>\n        <div>\n          <em>Single Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" class=\"chosen-select-width\" tabindex=\"15\">\n            <option value=\"\"></option>\n            <option selected>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select-width\" tabindex=\"16\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option selected>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"labels-work-too\" class=\"anchor\" href=\"#labels-work-too\">Labels work, too</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Use labels just like you would a standard select</p>\n        <p></p>\n        <div>\n          <em><label for=\"single-label-example\">Click to Highlight Single Select</label></em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" class=\"chosen-select\" tabindex=\"17\" id=\"single-label-example\">\n            <option value=\"\"></option>\n            <option selected>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em><label for=\"multiple-label-example\">Click to Highlight Multiple Select</label></em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select\" tabindex=\"18\" id=\"multiple-label-example\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option selected>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"setup\" class=\"anchor\" href=\"#setup\">Setup</a></h2>\n      <p>Using Chosen is easy as can be.</p>\n      <ol>\n        <li><a href=\"https://github.com/harvesthq/chosen/releases\">Download</a> the plugin and copy the chosen files to your app.</li>\n        <li>Activate the plugin on the select boxes of your choice: <code class=\"language-javascript\">$(\".chosen-select\").chosen()</code></li>\n        <li><a href=\"http://www.youtube.com/watch?feature=player_detailpage&amp;v=UkSPUDpe0U8#t=11s\">Disco</a>.</li>\n      </ol>\n\n      <h2><a name=\"faqs\" class=\"anchor\" href=\"#faqs\">FAQs</a></h2>\n      <ul class=\"faqs\">\n       <li>\n          <h3>Do you have all the available options documented somewhere?</h3>\n          <p>Yes! You can find them on <a href=\"options.html\">the options page</a>.</p>\n        </li>\n       <li>\n          <h3>Something doesn't work. Can you fix it?</h3>\n          <p>Yes! Please report all issues using the <a href=\"http://github.com/harvesthq/chosen/issues\">GitHub issue tracking tool</a>. Please include the plugin version (jQuery or Prototype), browser and OS. The more information provided, the easier it is to fix a problem.</p>\n       </li>\n       <li>\n          <h3>What browsers are supported?</h3>\n          <p>All modern desktop browsers are supported (Firefox, Chrome, Safari and IE9). Legacy support for IE8 is also enabled. Chosen is disabled on iPhone, iPod Touch, and Android mobile devices (<a href=\"https://github.com/harvesthq/chosen/pull/1388\">more information</a>).</p>\n       </li>\n       <li>\n          <h3>Didn't there used to be a Prototype version of Chosen?</h3>\n          <p><a href=\"index.proto.html\">There still is!</a></p>\n        </li>\n      </ul>\n\n      <h2><a name=\"credits\" class=\"anchor\" href=\"#credits\">Credits</a></h2>\n\n      <ul class=\"credits\">\n        <li>Concept and development by <a href=\"http://patrickfiller.com\">Patrick Filler</a> for <a href=\"https://getharvest.com\">Harvest</a>.</li>\n        <li>Design and CSS by <a href=\"http://matthewlettini.com\">Matthew Lettini</a>.</li>\n        <li>Repository maintained by <a href=\"https://github.com/pfiller\">@pfiller</a>, <a href=\"https://github.com/kenearley\">@kenearley</a>, <a href=\"https://github.com/stof\">@stof</a>, <a href=\"https://github.com/koenpunt\">@koenpunt</a>, and <a href=\"https://github.com/tjschuck\">@tjschuck</a>.</li>\n        <li>Chosen includes <a href=\"https://github.com/harvesthq/chosen/contributors\">contributions by many fine folks</a>.</li>\n      </ul>\n\n      <footer>\n        &copy; 2011&ndash;2016 <a href=\"http://www.getharvest.com/\">Harvest</a>. Chosen is licensed under the <a href=\"https://github.com/harvesthq/chosen/blob/master/LICENSE.md\">MIT license</a>.\n      </footer>\n\n    </div>\n  </div>\n  <script src=\"docsupport/jquery-3.2.1.min.js\" type=\"text/javascript\"></script>\n  <script src=\"chosen.jquery.js\" type=\"text/javascript\"></script>\n  <script src=\"docsupport/prism.js\" type=\"text/javascript\" charset=\"utf-8\"></script>\n  <script src=\"docsupport/init.js\" type=\"text/javascript\" charset=\"utf-8\"></script>\n  </form>\n  <div class=\"oss-bar\">\n    <ul>\n      <li><a class=\"fork\" href=\"https://github.com/harvesthq/chosen\">Fork on Github</a></li>\n      <li><a class=\"harvest\" href=\"http://www.getharvest.com/\">Built by Harvest</a></li>\n    </ul>\n  </div>\n</body>\n</html>\n"
  },
  {
    "path": "public/index.proto.html",
    "content": "<!doctype html>\n<html lang=\"en\">\n<head>\n  <meta charset=\"utf-8\">\n  <title>Chosen: A Prototype Plugin by Harvest to Tame Unwieldy Select Boxes</title>\n  <link rel=\"stylesheet\" href=\"docsupport/style.css\">\n  <link rel=\"stylesheet\" href=\"docsupport/prism.css\">\n  <link rel=\"stylesheet\" href=\"chosen.css\">\n\n  <meta http-equiv=\"Content-Security-Policy\" content=\"default-src &apos;self&apos;; script-src &apos;self&apos; https://ajax.googleapis.com; style-src &apos;self&apos;; img-src &apos;self&apos; data:\">\n\n</head>\n<body>\n  <div id=\"container\">\n    <div id=\"content\">\n      <header>\n        <h1>Chosen - Prototype Version <small>(<span id=\"latest-version\">v1.8.7</span>)</small></h1>\n      </header>\n      <p>Chosen is a Prototype plugin that makes long, unwieldy select boxes much more user-friendly.</p>\n\n      <p>\n        <a class=\"button button-blue\" href=\"https://github.com/harvesthq/chosen/releases\">Downloads</a>\n        <a class=\"button\" href=\"https://github.com/harvesthq/chosen\">Project Source</a>\n        <a class=\"button\" href=\"https://github.com/harvesthq/chosen/blob/master/contributing.md\">Contribute</a>\n      </p>\n\n      <p class=\"jquery-version-refer\">Looking for the <a href=\"index.html\">jQuery version?</a></p>\n\n      <h2><a name=\"standard-select\" class=\"anchor\" href=\"#standard-select\">Standard Select</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <div>\n          <em>Turns This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"select\" tabindex=\"1\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n        <div>\n          <em>Into This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"chosen-select\" tabindex=\"2\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"multiple-select\" class=\"anchor\" href=\"#multiple-select\">Multiple Select</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <div>\n          <em>Turns This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"select\" multiple tabindex=\"3\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n        <div>\n          <em>Into This</em>\n          <select data-placeholder=\"Choose a Country...\" class=\"chosen-select\" multiple tabindex=\"4\">\n            <option value=\"\"></option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"Afghanistan\">Afghanistan</option>\n            <option value=\"Aland Islands\">Aland Islands</option>\n            <option value=\"Albania\">Albania</option>\n            <option value=\"Algeria\">Algeria</option>\n            <option value=\"American Samoa\">American Samoa</option>\n            <option value=\"Andorra\">Andorra</option>\n            <option value=\"Angola\">Angola</option>\n            <option value=\"Anguilla\">Anguilla</option>\n            <option value=\"Antarctica\">Antarctica</option>\n            <option value=\"Antigua and Barbuda\">Antigua and Barbuda</option>\n            <option value=\"Argentina\">Argentina</option>\n            <option value=\"Armenia\">Armenia</option>\n            <option value=\"Aruba\">Aruba</option>\n            <option value=\"Australia\">Australia</option>\n            <option value=\"Austria\">Austria</option>\n            <option value=\"Azerbaijan\">Azerbaijan</option>\n            <option value=\"Bahamas\">Bahamas</option>\n            <option value=\"Bahrain\">Bahrain</option>\n            <option value=\"Bangladesh\">Bangladesh</option>\n            <option value=\"Barbados\">Barbados</option>\n            <option value=\"Belarus\">Belarus</option>\n            <option value=\"Belgium\">Belgium</option>\n            <option value=\"Belize\">Belize</option>\n            <option value=\"Benin\">Benin</option>\n            <option value=\"Bermuda\">Bermuda</option>\n            <option value=\"Bhutan\">Bhutan</option>\n            <option value=\"Bolivia, Plurinational State of\">Bolivia, Plurinational State of</option>\n            <option value=\"Bonaire, Sint Eustatius and Saba\">Bonaire, Sint Eustatius and Saba</option>\n            <option value=\"Bosnia and Herzegovina\">Bosnia and Herzegovina</option>\n            <option value=\"Botswana\">Botswana</option>\n            <option value=\"Bouvet Island\">Bouvet Island</option>\n            <option value=\"Brazil\">Brazil</option>\n            <option value=\"British Indian Ocean Territory\">British Indian Ocean Territory</option>\n            <option value=\"Brunei Darussalam\">Brunei Darussalam</option>\n            <option value=\"Bulgaria\">Bulgaria</option>\n            <option value=\"Burkina Faso\">Burkina Faso</option>\n            <option value=\"Burundi\">Burundi</option>\n            <option value=\"Cambodia\">Cambodia</option>\n            <option value=\"Cameroon\">Cameroon</option>\n            <option value=\"Canada\">Canada</option>\n            <option value=\"Cape Verde\">Cape Verde</option>\n            <option value=\"Cayman Islands\">Cayman Islands</option>\n            <option value=\"Central African Republic\">Central African Republic</option>\n            <option value=\"Chad\">Chad</option>\n            <option value=\"Chile\">Chile</option>\n            <option value=\"China\">China</option>\n            <option value=\"Christmas Island\">Christmas Island</option>\n            <option value=\"Cocos (Keeling) Islands\">Cocos (Keeling) Islands</option>\n            <option value=\"Colombia\">Colombia</option>\n            <option value=\"Comoros\">Comoros</option>\n            <option value=\"Congo\">Congo</option>\n            <option value=\"Congo, The Democratic Republic of The\">Congo, The Democratic Republic of The</option>\n            <option value=\"Cook Islands\">Cook Islands</option>\n            <option value=\"Costa Rica\">Costa Rica</option>\n            <option value=\"Cote D&apos;ivoire\">Cote D'ivoire</option>\n            <option value=\"Croatia\">Croatia</option>\n            <option value=\"Cuba\">Cuba</option>\n            <option value=\"Curacao\">Curacao</option>\n            <option value=\"Cyprus\">Cyprus</option>\n            <option value=\"Czech Republic\">Czech Republic</option>\n            <option value=\"Denmark\">Denmark</option>\n            <option value=\"Djibouti\">Djibouti</option>\n            <option value=\"Dominica\">Dominica</option>\n            <option value=\"Dominican Republic\">Dominican Republic</option>\n            <option value=\"Ecuador\">Ecuador</option>\n            <option value=\"Egypt\">Egypt</option>\n            <option value=\"El Salvador\">El Salvador</option>\n            <option value=\"Equatorial Guinea\">Equatorial Guinea</option>\n            <option value=\"Eritrea\">Eritrea</option>\n            <option value=\"Estonia\">Estonia</option>\n            <option value=\"Ethiopia\">Ethiopia</option>\n            <option value=\"Falkland Islands (Malvinas)\">Falkland Islands (Malvinas)</option>\n            <option value=\"Faroe Islands\">Faroe Islands</option>\n            <option value=\"Fiji\">Fiji</option>\n            <option value=\"Finland\">Finland</option>\n            <option value=\"France\">France</option>\n            <option value=\"French Guiana\">French Guiana</option>\n            <option value=\"French Polynesia\">French Polynesia</option>\n            <option value=\"French Southern Territories\">French Southern Territories</option>\n            <option value=\"Gabon\">Gabon</option>\n            <option value=\"Gambia\">Gambia</option>\n            <option value=\"Georgia\">Georgia</option>\n            <option value=\"Germany\">Germany</option>\n            <option value=\"Ghana\">Ghana</option>\n            <option value=\"Gibraltar\">Gibraltar</option>\n            <option value=\"Greece\">Greece</option>\n            <option value=\"Greenland\">Greenland</option>\n            <option value=\"Grenada\">Grenada</option>\n            <option value=\"Guadeloupe\">Guadeloupe</option>\n            <option value=\"Guam\">Guam</option>\n            <option value=\"Guatemala\">Guatemala</option>\n            <option value=\"Guernsey\">Guernsey</option>\n            <option value=\"Guinea\">Guinea</option>\n            <option value=\"Guinea-bissau\">Guinea-bissau</option>\n            <option value=\"Guyana\">Guyana</option>\n            <option value=\"Haiti\">Haiti</option>\n            <option value=\"Heard Island and Mcdonald Islands\">Heard Island and Mcdonald Islands</option>\n            <option value=\"Holy See (Vatican City State)\">Holy See (Vatican City State)</option>\n            <option value=\"Honduras\">Honduras</option>\n            <option value=\"Hong Kong\">Hong Kong</option>\n            <option value=\"Hungary\">Hungary</option>\n            <option value=\"Iceland\">Iceland</option>\n            <option value=\"India\">India</option>\n            <option value=\"Indonesia\">Indonesia</option>\n            <option value=\"Iran, Islamic Republic of\">Iran, Islamic Republic of</option>\n            <option value=\"Iraq\">Iraq</option>\n            <option value=\"Ireland\">Ireland</option>\n            <option value=\"Isle of Man\">Isle of Man</option>\n            <option value=\"Israel\">Israel</option>\n            <option value=\"Italy\">Italy</option>\n            <option value=\"Jamaica\">Jamaica</option>\n            <option value=\"Japan\">Japan</option>\n            <option value=\"Jersey\">Jersey</option>\n            <option value=\"Jordan\">Jordan</option>\n            <option value=\"Kazakhstan\">Kazakhstan</option>\n            <option value=\"Kenya\">Kenya</option>\n            <option value=\"Kiribati\">Kiribati</option>\n            <option value=\"Korea, Democratic People&apos;s Republic of\">Korea, Democratic People's Republic of</option>\n            <option value=\"Korea, Republic of\">Korea, Republic of</option>\n            <option value=\"Kuwait\">Kuwait</option>\n            <option value=\"Kyrgyzstan\">Kyrgyzstan</option>\n            <option value=\"Lao People&apos;s Democratic Republic\">Lao People's Democratic Republic</option>\n            <option value=\"Latvia\">Latvia</option>\n            <option value=\"Lebanon\">Lebanon</option>\n            <option value=\"Lesotho\">Lesotho</option>\n            <option value=\"Liberia\">Liberia</option>\n            <option value=\"Libya\">Libya</option>\n            <option value=\"Liechtenstein\">Liechtenstein</option>\n            <option value=\"Lithuania\">Lithuania</option>\n            <option value=\"Luxembourg\">Luxembourg</option>\n            <option value=\"Macao\">Macao</option>\n            <option value=\"Macedonia, The Former Yugoslav Republic of\">Macedonia, The Former Yugoslav Republic of</option>\n            <option value=\"Madagascar\">Madagascar</option>\n            <option value=\"Malawi\">Malawi</option>\n            <option value=\"Malaysia\">Malaysia</option>\n            <option value=\"Maldives\">Maldives</option>\n            <option value=\"Mali\">Mali</option>\n            <option value=\"Malta\">Malta</option>\n            <option value=\"Marshall Islands\">Marshall Islands</option>\n            <option value=\"Martinique\">Martinique</option>\n            <option value=\"Mauritania\">Mauritania</option>\n            <option value=\"Mauritius\">Mauritius</option>\n            <option value=\"Mayotte\">Mayotte</option>\n            <option value=\"Mexico\">Mexico</option>\n            <option value=\"Micronesia, Federated States of\">Micronesia, Federated States of</option>\n            <option value=\"Moldova, Republic of\">Moldova, Republic of</option>\n            <option value=\"Monaco\">Monaco</option>\n            <option value=\"Mongolia\">Mongolia</option>\n            <option value=\"Montenegro\">Montenegro</option>\n            <option value=\"Montserrat\">Montserrat</option>\n            <option value=\"Morocco\">Morocco</option>\n            <option value=\"Mozambique\">Mozambique</option>\n            <option value=\"Myanmar\">Myanmar</option>\n            <option value=\"Namibia\">Namibia</option>\n            <option value=\"Nauru\">Nauru</option>\n            <option value=\"Nepal\">Nepal</option>\n            <option value=\"Netherlands\">Netherlands</option>\n            <option value=\"New Caledonia\">New Caledonia</option>\n            <option value=\"New Zealand\">New Zealand</option>\n            <option value=\"Nicaragua\">Nicaragua</option>\n            <option value=\"Niger\">Niger</option>\n            <option value=\"Nigeria\">Nigeria</option>\n            <option value=\"Niue\">Niue</option>\n            <option value=\"Norfolk Island\">Norfolk Island</option>\n            <option value=\"Northern Mariana Islands\">Northern Mariana Islands</option>\n            <option value=\"Norway\">Norway</option>\n            <option value=\"Oman\">Oman</option>\n            <option value=\"Pakistan\">Pakistan</option>\n            <option value=\"Palau\">Palau</option>\n            <option value=\"Palestinian Territory, Occupied\">Palestinian Territory, Occupied</option>\n            <option value=\"Panama\">Panama</option>\n            <option value=\"Papua New Guinea\">Papua New Guinea</option>\n            <option value=\"Paraguay\">Paraguay</option>\n            <option value=\"Peru\">Peru</option>\n            <option value=\"Philippines\">Philippines</option>\n            <option value=\"Pitcairn\">Pitcairn</option>\n            <option value=\"Poland\">Poland</option>\n            <option value=\"Portugal\">Portugal</option>\n            <option value=\"Puerto Rico\">Puerto Rico</option>\n            <option value=\"Qatar\">Qatar</option>\n            <option value=\"Reunion\">Reunion</option>\n            <option value=\"Romania\">Romania</option>\n            <option value=\"Russian Federation\">Russian Federation</option>\n            <option value=\"Rwanda\">Rwanda</option>\n            <option value=\"Saint Barthelemy\">Saint Barthelemy</option>\n            <option value=\"Saint Helena, Ascension and Tristan da Cunha\">Saint Helena, Ascension and Tristan da Cunha</option>\n            <option value=\"Saint Kitts and Nevis\">Saint Kitts and Nevis</option>\n            <option value=\"Saint Lucia\">Saint Lucia</option>\n            <option value=\"Saint Martin (French part)\">Saint Martin (French part)</option>\n            <option value=\"Saint Pierre and Miquelon\">Saint Pierre and Miquelon</option>\n            <option value=\"Saint Vincent and The Grenadines\">Saint Vincent and The Grenadines</option>\n            <option value=\"Samoa\">Samoa</option>\n            <option value=\"San Marino\">San Marino</option>\n            <option value=\"Sao Tome and Principe\">Sao Tome and Principe</option>\n            <option value=\"Saudi Arabia\">Saudi Arabia</option>\n            <option value=\"Senegal\">Senegal</option>\n            <option value=\"Serbia\">Serbia</option>\n            <option value=\"Seychelles\">Seychelles</option>\n            <option value=\"Sierra Leone\">Sierra Leone</option>\n            <option value=\"Singapore\">Singapore</option>\n            <option value=\"Sint Maarten (Dutch part)\">Sint Maarten (Dutch part)</option>\n            <option value=\"Slovakia\">Slovakia</option>\n            <option value=\"Slovenia\">Slovenia</option>\n            <option value=\"Solomon Islands\">Solomon Islands</option>\n            <option value=\"Somalia\">Somalia</option>\n            <option value=\"South Africa\">South Africa</option>\n            <option value=\"South Georgia and The South Sandwich Islands\">South Georgia and The South Sandwich Islands</option>\n            <option value=\"South Sudan\">South Sudan</option>\n            <option value=\"Spain\">Spain</option>\n            <option value=\"Sri Lanka\">Sri Lanka</option>\n            <option value=\"Sudan\">Sudan</option>\n            <option value=\"Suriname\">Suriname</option>\n            <option value=\"Svalbard and Jan Mayen\">Svalbard and Jan Mayen</option>\n            <option value=\"Swaziland\">Swaziland</option>\n            <option value=\"Sweden\">Sweden</option>\n            <option value=\"Switzerland\">Switzerland</option>\n            <option value=\"Syrian Arab Republic\">Syrian Arab Republic</option>\n            <option value=\"Taiwan, Province of China\">Taiwan, Province of China</option>\n            <option value=\"Tajikistan\">Tajikistan</option>\n            <option value=\"Tanzania, United Republic of\">Tanzania, United Republic of</option>\n            <option value=\"Thailand\">Thailand</option>\n            <option value=\"Timor-leste\">Timor-leste</option>\n            <option value=\"Togo\">Togo</option>\n            <option value=\"Tokelau\">Tokelau</option>\n            <option value=\"Tonga\">Tonga</option>\n            <option value=\"Trinidad and Tobago\">Trinidad and Tobago</option>\n            <option value=\"Tunisia\">Tunisia</option>\n            <option value=\"Turkey\">Turkey</option>\n            <option value=\"Turkmenistan\">Turkmenistan</option>\n            <option value=\"Turks and Caicos Islands\">Turks and Caicos Islands</option>\n            <option value=\"Tuvalu\">Tuvalu</option>\n            <option value=\"Uganda\">Uganda</option>\n            <option value=\"Ukraine\">Ukraine</option>\n            <option value=\"United Arab Emirates\">United Arab Emirates</option>\n            <option value=\"United Kingdom\">United Kingdom</option>\n            <option value=\"United States\">United States</option>\n            <option value=\"United States Minor Outlying Islands\">United States Minor Outlying Islands</option>\n            <option value=\"Uruguay\">Uruguay</option>\n            <option value=\"Uzbekistan\">Uzbekistan</option>\n            <option value=\"Vanuatu\">Vanuatu</option>\n            <option value=\"Venezuela, Bolivarian Republic of\">Venezuela, Bolivarian Republic of</option>\n            <option value=\"Viet Nam\">Viet Nam</option>\n            <option value=\"Virgin Islands, British\">Virgin Islands, British</option>\n            <option value=\"Virgin Islands, U.S.\">Virgin Islands, U.S.</option>\n            <option value=\"Wallis and Futuna\">Wallis and Futuna</option>\n            <option value=\"Western Sahara\">Western Sahara</option>\n            <option value=\"Yemen\">Yemen</option>\n            <option value=\"Zambia\">Zambia</option>\n            <option value=\"Zimbabwe\">Zimbabwe</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"optgroup-support\" class=\"anchor\" href=\"#optgroup-support\">&lt;optgroup&gt; Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <div>\n          <em>Single Select with Groups</em>\n          <select data-placeholder=\"Your Favorite Football Team\" class=\"chosen-select\" tabindex=\"5\">\n            <option value=\"\"></option>\n            <optgroup label=\"NFC EAST\">\n              <option>Dallas Cowboys</option>\n              <option>New York Giants</option>\n              <option>Philadelphia Eagles</option>\n              <option>Washington Redskins</option>\n            </optgroup>\n            <optgroup label=\"NFC NORTH\">\n              <option>Chicago Bears</option>\n              <option>Detroit Lions</option>\n              <option>Green Bay Packers</option>\n              <option>Minnesota Vikings</option>\n            </optgroup>\n            <optgroup label=\"NFC SOUTH\">\n              <option>Atlanta Falcons</option>\n              <option>Carolina Panthers</option>\n              <option>New Orleans Saints</option>\n              <option>Tampa Bay Buccaneers</option>\n            </optgroup>\n            <optgroup label=\"NFC WEST\">\n              <option>Arizona Cardinals</option>\n              <option>St. Louis Rams</option>\n              <option>San Francisco 49ers</option>\n              <option>Seattle Seahawks</option>\n            </optgroup>\n            <optgroup label=\"AFC EAST\">\n              <option>Buffalo Bills</option>\n              <option>Miami Dolphins</option>\n              <option>New England Patriots</option>\n              <option>New York Jets</option>\n            </optgroup>\n            <optgroup label=\"AFC NORTH\">\n              <option>Baltimore Ravens</option>\n              <option>Cincinnati Bengals</option>\n              <option>Cleveland Browns</option>\n              <option>Pittsburgh Steelers</option>\n            </optgroup>\n            <optgroup label=\"AFC SOUTH\">\n              <option>Houston Texans</option>\n              <option>Indianapolis Colts</option>\n              <option>Jacksonville Jaguars</option>\n              <option>Tennessee Titans</option>\n            </optgroup>\n            <optgroup label=\"AFC WEST\">\n              <option>Denver Broncos</option>\n              <option>Kansas City Chiefs</option>\n              <option>Oakland Raiders</option>\n              <option>San Diego Chargers</option>\n            </optgroup>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select with Groups</em>\n          <select data-placeholder=\"Your Favorite Football Team\" class=\"chosen-select\" multiple tabindex=\"6\">\n            <option value=\"\"></option>\n            <optgroup label=\"NFC EAST\">\n              <option>Dallas Cowboys</option>\n              <option>New York Giants</option>\n              <option>Philadelphia Eagles</option>\n              <option>Washington Redskins</option>\n            </optgroup>\n            <optgroup label=\"NFC NORTH\">\n              <option>Chicago Bears</option>\n              <option>Detroit Lions</option>\n              <option>Green Bay Packers</option>\n              <option>Minnesota Vikings</option>\n            </optgroup>\n            <optgroup label=\"NFC SOUTH\">\n              <option>Atlanta Falcons</option>\n              <option>Carolina Panthers</option>\n              <option>New Orleans Saints</option>\n              <option>Tampa Bay Buccaneers</option>\n            </optgroup>\n            <optgroup label=\"NFC WEST\">\n              <option>Arizona Cardinals</option>\n              <option>St. Louis Rams</option>\n              <option>San Francisco 49ers</option>\n              <option>Seattle Seahawks</option>\n            </optgroup>\n            <optgroup label=\"AFC EAST\">\n              <option>Buffalo Bills</option>\n              <option>Miami Dolphins</option>\n              <option>New England Patriots</option>\n              <option>New York Jets</option>\n            </optgroup>\n            <optgroup label=\"AFC NORTH\">\n              <option>Baltimore Ravens</option>\n              <option>Cincinnati Bengals</option>\n              <option>Cleveland Browns</option>\n              <option>Pittsburgh Steelers</option>\n            </optgroup>\n            <optgroup label=\"AFC SOUTH\">\n              <option>Houston Texans</option>\n              <option>Indianapolis Colts</option>\n              <option>Jacksonville Jaguars</option>\n              <option>Tennessee Titans</option>\n            </optgroup>\n            <optgroup label=\"AFC WEST\">\n              <option>Denver Broncos</option>\n              <option>Kansas City Chiefs</option>\n              <option>Oakland Raiders</option>\n              <option>San Diego Chargers</option>\n            </optgroup>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"selected-and-disabled-support\" class=\"anchor\" href=\"#selected-and-disabled-support\">Selected and Disabled Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Chosen automatically highlights selected options and removes disabled options.</p>\n        <div>\n          <em>Single Select</em>\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select\" tabindex=\"7\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option disabled>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option disabled>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select\" tabindex=\"8\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option disabled>Sun Bear</option>\n            <option selected>Polar Bear</option>\n            <option disabled>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"hide-search-on-single-select\" class=\"anchor\" href=\"#hide-search-on-single-select\">Hide Search on Single Select</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>The <code>disable_search_threshold</code> option can be specified to hide the search input on single selects if there are <i>n</i> or fewer options.</p>\n        <pre><code class=\"language-javascript\"> new Chosen($(\"chosen_select_field\"),{disable_search_threshold: 10}); </code></pre>\n        <p></p>\n        <div>\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select-no-single\" tabindex=\"9\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected disabled>Sloth Bear</option>\n            <option disabled>Sun Bear</option>\n            <option selected>Paddington Bear</option>\n            <option selected>Polar Bear</option>\n            <option disabled>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"default-text-support\" class=\"anchor\" href=\"#default-text-support\">Default Text Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Chosen automatically sets the default field text (\"Choose a country...\") by reading the select element's data-placeholder value. If no data-placeholder value is present, it will default to \"Select an Option\" or \"Select Some Options\" depending on whether the select is single or multiple. You can change these elements in the plugin js file as you see fit.</p>\n        <pre><code class=\"language-markup\">&lt;select <strong>data-placeholder=\"Choose a country...\"</strong> multiple class=\"chosen-select\"&gt;</code></pre>\n        <p><strong>Note:</strong> on single selects, the first element is assumed to be selected by the browser. To take advantage of the default text support, you will need to include a blank option as the first element of your select list.</p>\n      </div>\n\n      <h2><a name=\"no-results-text-support\" class=\"anchor\" href=\"#no-results-text-support\">No Results Text Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Setting the \"No results\" search text is as easy as passing an option when you create Chosen:</p>\n        <pre><code class=\"language-javascript\">new Chosen($(\"chosen_select_field\"),{no_results_text: \"Oops, nothing found!\"}); </code></pre>\n\n        <div>\n          <em>Single Select</em>\n          <select data-placeholder=\"Type &apos;C&apos; to view\" class=\"chosen-select-no-results\" tabindex=\"10\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select</em>\n          <select data-placeholder=\"Type &apos;C&apos; to view\" multiple class=\"chosen-select-no-results\" tabindex=\"11\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"limit-selected-options-in-multiselect\" class=\"anchor\" href=\"#limit-selected-options-in-multiselect\">Limit Selected Options in Multiselect</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>You can easily limit how many options the user can select:</p>\n        <pre><code class=\"language-javascript\">new Chosen($(\"chosen_select_field\"),{max_selected_options: 5}); </code></pre>\n        <p>If you try to select another option with limit reached <code>chosen:maxselected</code> event is triggered:</p>\n        <pre><code class=\"language-javascript\">$(\"chosen_select_field\").observe(\"chosen:maxselected\", function(evt) { ... }); </code></pre>\n      </div>\n\n      <h2><a name=\"allow-deselect-on-single-selects\" class=\"anchor\" href=\"#allow-deselect-on-single-selects\">Allow Deselect on Single Selects</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>When a single select box isn't a required field, you can set <code class=\"language-javascript\">allow_single_deselect: true</code> and Chosen will add a UI element for option deselection. This will only work if the first option has blank text.</p>\n        <div class=\"side-by-side clearfix\">\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select-deselect\" tabindex=\"12\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"right-to-left-support\" class=\"anchor\" href=\"#right-to-left-support\">Right-to-Left Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>You can set right-to-left text by setting <code class=\"language-javascript\">rtl: true</code></p>\n        <pre><code class=\"language-javascript\"> $(\".chosen-select\").chosen({rtl: true}); </code></pre>\n        <div>\n          <em>Single Right-to-Left Select</em>\n          <select data-placeholder=\"Your Favorite Type of Bear\" class=\"chosen-select-rtl\" tabindex=\"13\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option>Polar Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Right-to-Left Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select-rtl\" tabindex=\"14\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option selected>Sloth Bear</option>\n            <option selected>Polar Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"change-update-events\" class=\"anchor\" href=\"#change-update-events\">Observing, Updating, and Destroying Chosen</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <ul>\n          <li>\n            <h3>Observing Form Field Changes</h3>\n            <p>When working with form fields, you often want to perform some behavior after a value has been selected or deselected. Whenever a user selects a field in Chosen, it triggers a \"change\" event on the original form field. That lets you do something like this:</p>\n            <pre><code class=\"language-javascript\">$(\"#form_field\").chosen().change( &hellip; );</code></pre>\n            <p><strong>Note:</strong> Prototype doesn't offer support for triggering standard browser events. <a href=\"https://github.com/kangax/protolicious/blob/5b56fdafcd7d7662c9d648534225039b2e78e371/event.simulate.js\">Event.simulate</a> is required to trigger the change event when using the Prototype version.</p>\n          </li>\n          <li>\n            <h3>Updating Chosen Dynamically</h3>\n            <p>If you need to update the options in your select field and want Chosen to pick up the changes, you'll need to trigger the \"chosen:updated\" event on the field. Chosen will re-build itself based on the updated content.</p>\n            <pre><code class=\"language-javascript\">Event.fire($(\"form_field\"), \"chosen:updated\");</code></pre>\n          </li>\n          <li>\n            <h3>Destroying Chosen</h3>\n            <p>To destroy Chosen and revert back to the native select, call <code class=\"language-javascript\">destroy</code> on the Chosen instance:</p>\n              <pre><code class=\"language-javascript\">chosen = new Chosen($(\"form_field\"));\n\n// ...later\nchosen.destroy();</code></pre>\n          </li>\n        </ul>\n      </div>\n\n      <h2><a name=\"custom-width-support\" class=\"anchor\" href=\"#custom-width-support\">Custom Width Support</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Using a custom width with Chosen is as easy as passing an option when you create Chosen:</p>\n        <pre><code class=\"language-javascript\">new Chosen($(\"chosen_select_field\"),{width: \"95%\"}); </code></pre>\n        <div>\n          <em>Single Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" class=\"chosen-select-width\" tabindex=\"15\">\n            <option value=\"\"></option>\n            <option selected>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em>Multiple Select</em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select-width\" tabindex=\"16\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option selected>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"labels-work-too\" class=\"anchor\" href=\"#labels-work-too\">Labels work, too</a></h2>\n      <div class=\"side-by-side clearfix\">\n        <p>Use labels just like you would a standard select</p>\n        <p></p>\n        <div>\n          <em><label for=\"single-label-example\">Click to Highlight Single Select</label></em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" class=\"chosen-select\" tabindex=\"17\" id=\"single-label-example\">\n            <option value=\"\"></option>\n            <option selected>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n        <div>\n          <em><label for=\"multiple-label-example\">Click to Highlight Multiple Select</label></em>\n          <select data-placeholder=\"Your Favorite Types of Bear\" multiple class=\"chosen-select\" tabindex=\"18\" id=\"multiple-label-example\">\n            <option value=\"\"></option>\n            <option>American Black Bear</option>\n            <option>Asiatic Black Bear</option>\n            <option>Brown Bear</option>\n            <option selected>Giant Panda</option>\n            <option>Sloth Bear</option>\n            <option>Sun Bear</option>\n            <option>Polar Bear</option>\n            <option>Spectacled Bear</option>\n          </select>\n        </div>\n      </div>\n\n      <h2><a name=\"setup\" class=\"anchor\" href=\"#setup\">Setup</a></h2>\n      <p>Using Chosen is easy as can be.</p>\n      <ol>\n        <li><a href=\"https://github.com/harvesthq/chosen/releases\">Download</a> the plugin and copy the chosen files to your app.</li>\n        <li>Activate the plugin by creating a new instance of Chosen: New Chosen(<em>some_form_field</em>,<em>some_options</em>);</li>\n        <li><a href=\"http://www.youtube.com/watch?feature=player_detailpage&amp;v=UkSPUDpe0U8#t=11s\">Disco</a>.</li>\n      </ol>\n\n      <h2><a name=\"faqs\" class=\"anchor\" href=\"#faqs\">FAQs</a></h2>\n      <ul class=\"faqs\">\n       <li>\n          <h3>Do you have all the available options documented somewhere?</h3>\n          <p>Yes! You can find them on <a href=\"options.html\">the options page</a>.</p>\n        </li>\n        <li>\n          <h3>Something doesn't work. Can you fix it?</h3>\n          <p>Yes! Please report all issues using the <a href=\"http://github.com/harvesthq/chosen/issues\">GitHub issue tracking tool</a>. Please include the plugin version (jQuery or Prototype), browser and OS. The more information provided, the easier it is to fix a problem.</p>\n        </li>\n        <li>\n          <h3>What browsers are supported?</h3>\n          <p>All modern desktop browsers are supported (Firefox, Chrome, Safari and IE9). Legacy support for IE8 is also enabled. Chosen is disabled on iPhone, iPod Touch, and Android mobile devices (<a href=\"https://github.com/harvesthq/chosen/pull/1388\">more information</a>).</p>\n        </li>\n      </ul>\n\n      <h2><a name=\"credits\" class=\"anchor\" href=\"#credits\">Credits</a></h2>\n\n      <ul class=\"credits\">\n        <li>Concept and development by <a href=\"http://patrickfiller.com\">Patrick Filler</a> for <a href=\"https://getharvest.com\">Harvest</a>.</li>\n        <li>Design and CSS by <a href=\"http://matthewlettini.com\">Matthew Lettini</a>.</li>\n        <li>Repository maintained by <a href=\"https://github.com/pfiller\">@pfiller</a>, <a href=\"https://github.com/kenearley\">@kenearley</a>, <a href=\"https://github.com/stof\">@stof</a>, <a href=\"https://github.com/koenpunt\">@koenpunt</a>, and <a href=\"https://github.com/tjschuck\">@tjschuck</a>.</li>\n        <li>Chosen includes <a href=\"https://github.com/harvesthq/chosen/contributors\">contributions by many fine folks</a>.</li>\n      </ul>\n\n      <footer>\n        &copy; 2011&ndash;2016 <a href=\"http://www.getharvest.com/\">Harvest</a>. Chosen is licensed under the <a href=\"https://github.com/harvesthq/chosen/blob/master/LICENSE.md\">MIT license</a>.\n      </footer>\n\n    </div>\n  </div>\n  <script src=\"docsupport/prototype-1.7.0.0.js\" type=\"text/javascript\"></script>\n  <script src=\"chosen.proto.js\" type=\"text/javascript\"></script>\n  <script src=\"docsupport/prism.js\" type=\"text/javascript\" charset=\"utf-8\"></script>\n  <script src=\"docsupport/init.proto.js\" type=\"text/javascript\" charset=\"utf-8\"></script>\n  <div class=\"oss-bar\">\n    <ul>\n      <li><a class=\"fork\" href=\"https://github.com/harvesthq/chosen\">Fork on Github</a></li>\n      <li><a class=\"harvest\" href=\"http://www.getharvest.com/\">Built by Harvest</a></li>\n    </ul>\n  </div>\n</body>\n</html>\n"
  },
  {
    "path": "public/options.html",
    "content": "<!doctype html>\n<html lang=\"en\">\n<head>\n  <meta charset=\"utf-8\">\n  <title>Chosen: A jQuery Plugin by Harvest to Tame Unwieldy Select Boxes</title>\n  <link rel=\"stylesheet\" href=\"docsupport/style.css\">\n  <link rel=\"stylesheet\" href=\"docsupport/prism.css\">\n  <link rel=\"stylesheet\" href=\"chosen.css\">\n  <style type=\"text/css\" media=\"all\">\n    /* fix rtl for demo */\n    .chosen-rtl .chosen-drop { left: -9000px; }\n  </style>\n</head>\n<body>\n  <div id=\"container\">\n    <div id=\"content\">\n      <header>\n        <h1>Chosen <small>(<span id=\"latest-version\">v1.8.7</span>)</small></h1>\n      </header>\n      <p>Chosen has a number of options and attributes that allow you to have full control of your select boxes.</p>\n\n      <h2><a name=\"options\" class=\"anchor\" href=\"#options\">Options</a></h2>\n      <p>The following options are available to pass into Chosen on instantiation.</p>\n\n      <h3>Example:</h3>\n<pre>\n  <code class=\"language-javascript\">$(\".my_select_box\").chosen({\n    disable_search_threshold: 10,\n    no_results_text: \"Oops, nothing found!\",\n    width: \"95%\"\n  });</code>\n</pre>\n\n      <table class=\"docs-table\">\n        <tr>\n          <th>Option</th><th>Default</th><th>Description</th>\n        </tr>\n        <tr>\n          <td>allow_single_deselect</td>\n          <td>false</td>\n          <td>When set to <code class=\"language-javascript\">true</code> on a single select, Chosen adds a UI element which selects the first element (if it is blank).</td>\n        </tr>\n        <tr>\n          <td>disable_search</td>\n          <td>false</td>\n          <td>When set to <code class=\"language-javascript\">true</code>, Chosen will not display the search field (single selects only).</td>\n        </tr>\n        <tr>\n          <td>disable_search_threshold</td>\n          <td>0</td>\n          <td>Hide the search input on single selects if there are <i>n</i> or fewer options.</td>\n        </tr>\n        <tr>\n          <td>enable_split_word_search</td>\n          <td>true</td>\n          <td>By default, searching will match on any word within an option tag. Set this option to <code class=\"language-javascript\">false</code> if you want to only match on the entire text of an option tag.</td>\n        </tr>\n        <tr>\n          <td>inherit_select_classes</td>\n          <td>false</td>\n          <td>When set to <code class=\"language-javascript\">true</code>, Chosen will grab any classes on the original select field and add them to Chosen’s container div.</td>\n        </tr>\n        <tr>\n          <td>max_selected_options</td>\n          <td>Infinity</td>\n          <td>Limits how many options the user can select. When the limit is reached, the <code class=\"language-javascript\">chosen:maxselected</code> event is triggered.</td>\n        </tr>\n        <tr>\n          <td>no_results_text</td>\n          <td>\"No results match\"</td>\n          <td>The text to be displayed when no matching results are found. The current search is shown at the end of the text (<i>e.g.</i>,\n           No results match \"Bad Search\").</td>\n        </tr>\n        <tr>\n          <td>placeholder_text_multiple</td>\n          <td>\"Select Some Options\"</td>\n          <td>The text to be displayed as a placeholder when no options are selected for a multiple select.</td>\n        </tr>\n        <tr>\n          <td>placeholder_text_single</td>\n          <td>\"Select an Option\"</td>\n          <td>The text to be displayed as a placeholder when no options are selected for a single select.</td>\n        </tr>\n        <tr>\n          <td>search_contains</td>\n          <td>false</td>\n          <td>By default, Chosen’s search matches starting at the beginning of a word. Setting this option to <code class=\"language-javascript\">true</code> allows matches starting from anywhere within a word. This is especially useful for options that include a lot of special characters or phrases in ()s and []s.</td>\n        </tr>\n        <tr>\n          <td>group_search</td>\n          <td>true</td>\n          <td>By default, Chosen will search group labels as well as options, and filter to show all options below matching groups. Set this to <code class=\"language-javascript\">false</code> to search only in the options.</td>\n        </tr>\n        <tr>\n          <td>single_backstroke_delete</td>\n          <td>true</td>\n          <td>By default, pressing delete/backspace on multiple selects will remove a selected choice. When <code class=\"language-javascript\">false</code>, pressing delete/backspace will highlight the last choice, and a second press deselects it.</td>\n        </tr>\n        <tr>\n          <td>width</td>\n          <td>Original select width.</td>\n          <td>The width of the Chosen select box. By default, Chosen attempts to match the width of the select box you are replacing. If your select is hidden when Chosen is instantiated, you must specify a width or the select will show up with a width of 0.</td>\n        </tr>\n        <tr>\n          <td>display_disabled_options</td>\n          <td>true</td>\n          <td>By default, Chosen includes disabled options in search results with a special styling. Setting this option to false will hide disabled results and exclude them from searches.</td>\n        </tr>\n        <tr>\n          <td>display_selected_options</td>\n          <td>true</td>\n          <td>\n            <p>By default, Chosen includes selected options in search results with a special styling. Setting this option to false will hide selected results and exclude them from searches.</p>\n            <p><strong>Note:</strong> this is for multiple selects only. In single selects, the selected result will always be displayed.</p>\n          </td>\n        </tr>\n        <tr>\n          <td>include_group_label_in_selected</td>\n          <td>false</td>\n          <td>\n            <p>By default, Chosen only shows the text of a selected option. Setting this option to <code class=\"language-javascript\">true</code> will show the text and group (if any) of the selected option.</p>\n          </td>\n        </tr>\n        <tr>\n          <td>max_shown_results</td>\n          <td>Infinity</td>\n          <td>\n            <p>Only show the first (n) matching options in the results. This can be used to increase performance for selects with very many options.</p>\n          </td>\n        </tr>\n        <tr>\n          <td>case_sensitive_search</td>\n          <td>false</td>\n          <td>\n            <p>By default, Chosen's search is case-insensitive. Setting this option to <code class=\"language-javascript\">true</code> makes the search case-sensitive.</p>\n          </td>\n        </tr>\n        <tr>\n          <td>hide_results_on_select</td>\n          <td>true</td>\n          <td>\n            <p>By default, Chosen's results are hidden after a option is selected. Setting this option to <code class=\"language-javascript\">false</code> will keep the results open after selection. This only applies to multiple selects.</p>\n          </td>\n        </tr>\n        <tr>\n          <td>rtl</td>\n          <td>false</td>\n          <td>\n            <p>Chosen supports right-to-left text in select boxes. Set this option to <code class=\"language-javascript\">true</code> to support right-to-left text options.</p>\n            <p><strong>Note:</strong> <a href=\"#classes\">the <code class=\"language-javascript\">chosen-rtl</code> class</a> on the select has precedence over this option. However, the classname approach is deprecated and will be removed in future versions of Chosen.</p>\n          </td>\n        </tr>\n      </table>\n\n      <h2><a name=\"attributes\" class=\"anchor\" href=\"#attributes\">Attributes</a></h2>\n      <p>Certain attributes placed on the select tag or its options can be used to configure Chosen.</p>\n\n      <h3>Example:</h3>\n\n<pre>\n  <code class=\"language-markup\">&lt;select class=\"my_select_box\" data-placeholder=\"Select Your Options\"&gt;\n    &lt;option value=\"1\"&gt;Option 1&lt;/option&gt;\n    &lt;option value=\"2\" selected&gt;Option 2&lt;/option&gt;\n    &lt;option value=\"3\" disabled&gt;Option 3&lt;/option&gt;\n  &lt;/select&gt;</code>\n</pre>\n\n      <table class=\"docs-table\">\n        <tr>\n          <th>Attribute</th><th>Description</th>\n        </tr>\n        <tr>\n          <td>data-placeholder</td>\n          <td>\n            <p>The text to be displayed as a placeholder when no options are selected for a select. Defaults to \"Select an Option\" for single selects or \"Select Some Options\" for multiple selects.</p>\n            <p><strong>Note:</strong>This attribute overrides anything set in the <code class=\"language-javascript\">placeholder_text_multiple</code> or <code class=\"language-javascript\">placeholder_text_single</code> options.</p>\n          </td>\n        </tr>\n        <tr>\n          <td>multiple</td>\n          <td>The attribute <code class=\"language-html\">multiple</code> on your select box dictates whether Chosen will render a multiple or single select.</td>\n        </tr>\n        <tr>\n          <td>selected, disabled</td>\n          <td>Chosen automatically highlights selected options and disables disabled options.</td>\n        </tr>\n      </table>\n\n      <h2><a name=\"classes\" class=\"anchor\" href=\"#classes\">Classes</a></h2>\n      <p>Classes placed on the select tag can be used to configure Chosen.</p>\n\n      <h3>Example:</h3>\n\n<pre>\n  <code class=\"language-markup\">&lt;select class=\"my_select_box chosen-rtl\"&gt;\n    &lt;option value=\"1\"&gt;Option 1&lt;/option&gt;\n    &lt;option value=\"2\"&gt;Option 2&lt;/option&gt;\n    &lt;option value=\"3\"&gt;Option 3&lt;/option&gt;\n  &lt;/select&gt;</code>\n</pre>\n\n      <table class=\"docs-table\">\n        <tr>\n          <th>Classname</th>\n          <th>Description</th>\n        </tr>\n        <tr>\n          <td>chosen-rtl</td>\n          <td>\n            <p>Chosen supports right-to-left text in select boxes. Add the class <code class=\"language-html\">chosen-rtl</code> to your select tag to support right-to-left text options.</p>\n            <p><strong>Note:</strong> The <code class=\"language-html\">chosen-rtl</code> class will pass through to the Chosen select even when the <code class=\"language-javascript\">inherit_select_classes</code> option is set to <code class=\"language-javascript\">false</code>.</p>\n            <p><strong>Note:</strong> This is deprecated in favor of using the <code class=\"language-javascript\">rtl: true</code> option (see the <a href=\"#options\">Options section</a>).</p>\n          </td>\n        </tr>\n      </table>\n\n      <h2><a name=\"triggered-events\" class=\"anchor\" href=\"#triggered-events\">Triggered Events</a></h2>\n      <p>Chosen triggers a number of standard and custom events on the original select field.</p>\n\n      <h3>Example:</h3>\n\n<pre>\n  <code class=\"language-javascript\">$('.my_select_box').on('change', function(evt, params) {\n    do_something(evt, params);\n  });</code>\n</pre>\n\n      <table class=\"docs-table\">\n        <tr>\n          <th>Event</th><th>Description</th>\n        </tr>\n        <tr>\n          <td>change</td>\n          <td>\n            <p>Chosen triggers the standard DOM event whenever a selection is made (it also sends a <code class=\"language-javascript\">selected</code> or <code class=\"language-javascript\">deselected</code> parameter that tells you which option was changed).</p>\n            <p><strong>Note:</strong> The selected and deselected parameters are not available for Prototype.</p>\n          </td>\n        </tr>\n        <tr>\n          <td>chosen:ready</td>\n          <td>Triggered after Chosen has been fully instantiated.</td>\n        </tr>\n        <tr>\n          <td>chosen:maxselected</td>\n          <td>Triggered if <code class=\"language-javascript\">max_selected_options</code> is set and that total is broken.</td>\n        </tr>\n        <tr>\n          <td>chosen:showing_dropdown</td>\n          <td>Triggered when Chosen’s dropdown is opened.</td>\n        </tr>\n        <tr>\n          <td>chosen:hiding_dropdown</td>\n          <td>Triggered when Chosen’s dropdown is closed.</td>\n        </tr>\n        <tr>\n          <td>chosen:no_results</td>\n          <td>Triggered when a search returns no matching results.</td>\n        </tr>\n      </table>\n\n      <p>\n        <strong>Note:</strong> all custom Chosen events (those that begin with <code class=\"language-javascript\">chosen:</code>) also include the <code class=\"language-javascript\">chosen</code> object as a parameter.\n      </p>\n\n      <h2><a name=\"triggerable-events\" class=\"anchor\" href=\"#triggerable-events\">Triggerable Events</a></h2>\n      <p>You can trigger several events on the original select field to invoke a behavior in Chosen.</p>\n\n      <h3>Example:</h3>\n\n<pre>\n  <code class=\"language-javascript\">// tell Chosen that a select has changed\n  $('.my_select_box').trigger('chosen:updated');</code>\n</pre>\n\n      <table class=\"docs-table\">\n        <tr>\n          <th>Event</th><th>Description</th>\n        </tr>\n        <tr>\n          <td>chosen:updated</td>\n          <td>This event should be triggered whenever Chosen’s underlying select element changes (such as a change in selected options).</td>\n        </tr>\n        <tr>\n          <td>chosen:activate</td>\n          <td>This is the equivalant of focusing a standard HTML select field. When activated, Chosen will capture keypress events as if you had clicked the field directly.</td>\n        </tr>\n        <tr>\n          <td>chosen:open</td>\n          <td>This event activates Chosen and also displays the search results.</td>\n        </tr>\n        <tr>\n          <td>chosen:close</td>\n          <td>This event deactivates Chosen and hides the search results.</td>\n        </tr>\n      </table>\n\n      <footer>\n        &copy; 2011&ndash;2016 <a href=\"http://www.getharvest.com/\">Harvest</a>. Chosen is licensed under the <a href=\"https://github.com/harvesthq/chosen/blob/master/LICENSE.md\">MIT license</a>.\n      </footer>\n\n    </div>\n  </div>\n  <div class=\"oss-bar\">\n    <ul>\n      <li><a class=\"fork\" href=\"https://github.com/harvesthq/chosen\">Fork on Github</a></li>\n      <li><a class=\"harvest\" href=\"http://www.getharvest.com/\">Built by Harvest</a></li>\n    </ul>\n  </div>\n  <script src=\"docsupport/prism.js\" type=\"text/javascript\" charset=\"utf-8\"></script>\n</body>\n</html>\n"
  },
  {
    "path": "publish-package.sh",
    "content": "#!/bin/sh\n\nset -e\n\nCURRENT_BRANCH=`git name-rev --name-only HEAD`\n\nif [ $CURRENT_BRANCH != 'master' ] ; then\n  echo \"Build not on master. Skipped pushing to chosen-package\"\n  exit 0\nfi\n\nCHOSEN_VERSION=`git tag --sort=v:refname | tail -1`\nGITHUB_URL=https://pfiller:${GH_TOKEN}@github.com/harvesthq/chosen-package.git\n\ngit clone $GITHUB_URL\nrm -rf chosen-package/*\ncp README.md public/*.json public/*.png public/*.js public/*.css public/LICENSE* chosen-package/\ncp package-travis.yml chosen-package/.travis.yml\ncd chosen-package\n\ngit config user.email \"chosen@getharvest.com\"\ngit config user.name \"chosen-package\"\n\nLATEST_VERSION=`git tag --sort=v:refname | tail -1`\n\ngit remote set-url origin $GITHUB_URL\n\ngit add -A\ngit commit -m \"Chosen build to chosen-package\"\n\nif [ \"$LATEST_VERSION\" = \"$CHOSEN_VERSION\" ] ; then\n  echo \"No Chosen version change. Skipped tagging\"\nelse\n  echo \"Chosen version changed. Tagging version ${CHOSEN_VERSION}\\n\"\n  git tag -a \"${CHOSEN_VERSION}\" -m \"Version ${CHOSEN_VERSION}\"\nfi\n\ngit push origin master\ngit push origin --tags\n\necho \"Chosen built and pushed to harvesthq/chosen-package\"\n"
  },
  {
    "path": "sass/chosen.scss",
    "content": "$chosen-sprite: url('chosen-sprite.png') !default;\n$chosen-sprite-retina: url('chosen-sprite@2x.png') !default;\n\n/* @group Base */\n.chosen-container {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  font-size: 13px;\n  user-select: none;\n  * {\n    box-sizing: border-box;\n  }\n  .chosen-drop {\n    position: absolute;\n    top: 100%;\n    z-index: 1010;\n    width: 100%;\n    border: 1px solid #aaa;\n    border-top: 0;\n    background: #fff;\n    box-shadow: 0 4px 5px rgba(#000,.15);\n    clip: rect(0,0,0,0);\n    clip-path: inset(100% 100%);\n  }\n  &.chosen-with-drop .chosen-drop {\n    clip: auto;\n    clip-path: none;\n  }\n  a{\n    cursor: pointer;\n  }\n\n  .search-choice, .chosen-single{\n    .group-name{\n      margin-right: 4px;\n      overflow: hidden;\n      white-space: nowrap;\n      text-overflow: ellipsis;\n      font-weight: normal;\n      color: #999999;\n      &:after {\n        content: \":\";\n        padding-left: 2px;\n        vertical-align: top;\n      }\n    }\n  }\n}\n/* @end */\n\n/* @group Single Chosen */\n.chosen-container-single{\n  .chosen-single {\n    position: relative;\n    display: block;\n    overflow: hidden;\n    padding: 0 0 0 8px;\n    height: 25px;\n    border: 1px solid #aaa;\n    border-radius: 5px;\n    background-color: #fff;\n    background: linear-gradient(#fff 20%, #f6f6f6 50%, #eee 52%, #f4f4f4 100%);\n    background-clip: padding-box;\n    box-shadow: 0 0 3px #fff inset, 0 1px 1px rgba(#000,.1);\n    color: #444;\n    text-decoration: none;\n    white-space: nowrap;\n    line-height: 24px;\n  }\n  .chosen-default {\n    color: #999;\n  }\n  .chosen-single span {\n    display: block;\n    overflow: hidden;\n    margin-right: 26px;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n  .chosen-single-with-deselect span {\n    margin-right: 38px;\n  }\n  .chosen-single abbr {\n    position: absolute;\n    top: 6px;\n    right: 26px;\n    display: block;\n    width: 12px;\n    height: 12px;\n    background: $chosen-sprite -42px 1px no-repeat;\n    font-size: 1px;\n    &:hover {\n      background-position: -42px -10px;\n    }\n  }\n  &.chosen-disabled .chosen-single abbr:hover {\n    background-position: -42px -10px;\n  }\n  .chosen-single div {\n    position: absolute;\n    top: 0;\n    right: 0;\n    display: block;\n    width: 18px;\n    height: 100%;\n    b {\n      display: block;\n      width: 100%;\n      height: 100%;\n      background: $chosen-sprite no-repeat 0px 2px;\n    }\n  }\n  .chosen-search {\n    position: relative;\n    z-index: 1010;\n    margin: 0;\n    padding: 3px 4px;\n    white-space: nowrap;\n\n    input[type=\"text\"] {\n      margin: 1px 0;\n      padding: 4px 20px 4px 5px;\n      width: 100%;\n      height: auto;\n      outline: 0;\n      border: 1px solid #aaa;\n      background: $chosen-sprite no-repeat 100% -20px;\n      font-size: 1em;\n      font-family: sans-serif;\n      line-height: normal;\n      border-radius: 0;\n    }\n  }\n  .chosen-drop {\n    margin-top: -1px;\n    border-radius: 0 0 4px 4px;\n    background-clip: padding-box;\n  }\n  &.chosen-container-single-nosearch .chosen-search {\n    position: absolute;\n    clip: rect(0,0,0,0);\n    clip-path: inset(100% 100%);\n  }\n}\n/* @end */\n\n/* @group Results */\n.chosen-container .chosen-results {\n  color: #444;\n  position: relative;\n  overflow-x: hidden;\n  overflow-y: auto;\n  margin: 0 4px 4px 0;\n  padding: 0 0 0 4px;\n  max-height: 240px;\n  -webkit-overflow-scrolling: touch;\n  li {\n    display: none;\n    margin: 0;\n    padding: 5px 6px;\n    list-style: none;\n    line-height: 15px;\n    word-wrap: break-word;\n    -webkit-touch-callout: none;\n    &.active-result {\n      display: list-item;\n      cursor: pointer;\n    }\n    &.disabled-result {\n      display: list-item;\n      color: #ccc;\n      cursor: default;\n    }\n    &.highlighted {\n      background-color: #3875d7;\n      background-image: linear-gradient(#3875d7 20%, #2a62bc 90%);\n      color: #fff;\n    }\n    &.no-results {\n      color: #777;\n      display: list-item;\n      background: #f4f4f4;\n    }\n    &.group-result {\n      display: list-item;\n      font-weight: bold;\n      cursor: default;\n    }\n    &.group-option {\n      padding-left: 15px;\n    }\n    em {\n      font-style: normal;\n      text-decoration: underline;\n    }\n  }\n}\n/* @end */\n\n/* @group Multi Chosen */\n.chosen-container-multi{\n  .chosen-choices {\n    position: relative;\n    overflow: hidden;\n    margin: 0;\n    padding: 0 5px;\n    width: 100%;\n    height: auto;\n    border: 1px solid #aaa;\n    background-color: #fff;\n    background-image: linear-gradient(#eee 1%, #fff 15%);\n    cursor: text;\n  }\n  .chosen-choices li {\n    float: left;\n    list-style: none;\n    &.search-field {\n      margin: 0;\n      padding: 0;\n      white-space: nowrap;\n      input[type=\"text\"] {\n        margin: 1px 0;\n        padding: 0;\n        height: 25px;\n        outline: 0;\n        border: 0 !important;\n        background: transparent !important;\n        box-shadow: none;\n        color: #999;\n        font-size: 100%;\n        font-family: sans-serif;\n        line-height: normal;\n        border-radius: 0;\n        width: 25px;\n      }\n    }\n    &.search-choice {\n      position: relative;\n      margin: 3px 5px 3px 0;\n      padding: 3px 20px 3px 5px;\n      border: 1px solid #aaa;\n      max-width: 100%;\n      border-radius: 3px;\n      background-color: #eeeeee;\n      background-image: linear-gradient(#f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eee 100%);\n      background-size: 100% 19px;\n      background-repeat: repeat-x;\n      background-clip: padding-box;\n      box-shadow: 0 0 2px #fff inset, 0 1px 0 rgba(#000,.05);\n      color: #333;\n      line-height: 13px;\n      cursor: default;\n      span {\n        word-wrap: break-word;\n      }\n      .search-choice-close {\n        position: absolute;\n        top: 4px;\n        right: 3px;\n        display: block;\n        width: 12px;\n        height: 12px;\n        background: $chosen-sprite -42px 1px no-repeat;\n        font-size: 1px;\n        &:hover {\n          background-position: -42px -10px;\n        }\n      }\n    }\n    &.search-choice-disabled {\n      padding-right: 5px;\n      border: 1px solid #ccc;\n      background-color: #e4e4e4;\n      background-image: linear-gradient(#f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eee 100%);\n      color: #666;\n    }\n    &.search-choice-focus {\n      background: #d4d4d4;\n      .search-choice-close {\n        background-position: -42px -10px;\n      }\n    }\n  }\n  .chosen-results {\n    margin: 0;\n    padding: 0;\n  }\n  .chosen-drop .result-selected {\n    display: list-item;\n    color: #ccc;\n    cursor: default;\n  }\n}\n/* @end */\n\n/* @group Active  */\n.chosen-container-active{\n  .chosen-single {\n    border: 1px solid #5897fb;\n    box-shadow: 0 0 5px rgba(#000,.3);\n  }\n  &.chosen-with-drop{\n    .chosen-single {\n      border: 1px solid #aaa;\n      -moz-border-radius-bottomright: 0;\n      border-bottom-right-radius: 0;\n      -moz-border-radius-bottomleft: 0;\n      border-bottom-left-radius: 0;\n      background-image: linear-gradient(#eee 20%, #fff 80%);\n      box-shadow: 0 1px 0 #fff inset;\n    }\n    .chosen-single div {\n      border-left: none;\n      background: transparent;\n      b {\n        background-position: -18px 2px;\n      }\n    }\n  }\n  .chosen-choices {\n    border: 1px solid #5897fb;\n    box-shadow: 0 0 5px rgba(#000,.3);\n    li.search-field input[type=\"text\"] {\n      color: #222 !important;\n    }\n  }\n}\n/* @end */\n\n/* @group Disabled Support */\n.chosen-disabled {\n  opacity: 0.5 !important;\n  cursor: default;\n  .chosen-single {\n    cursor: default;\n  }\n  .chosen-choices .search-choice .search-choice-close {\n    cursor: default;\n  }\n}\n/* @end */\n\n/* @group Right to Left */\n.chosen-rtl {\n  text-align: right;\n  .chosen-single {\n    overflow: visible;\n    padding: 0 8px 0 0;\n  }\n  .chosen-single span {\n    margin-right: 0;\n    margin-left: 26px;\n    direction: rtl;\n  }\n  .chosen-single-with-deselect span {\n    margin-left: 38px;\n  }\n  .chosen-single div {\n    right: auto;\n    left: 3px;\n  }\n  .chosen-single abbr {\n    right: auto;\n    left: 26px;\n  }\n  .chosen-choices li {\n    float: right;\n    &.search-field input[type=\"text\"] {\n      direction: rtl;\n    }\n    &.search-choice {\n      margin: 3px 5px 3px 0;\n      padding: 3px 5px 3px 19px;\n      .search-choice-close {\n        right: auto;\n        left: 4px;\n      }\n    }\n  }\n  &.chosen-container-single .chosen-results {\n    margin: 0 0 4px 4px;\n    padding: 0 4px 0 0;\n  }\n  .chosen-results li.group-option {\n    padding-right: 15px;\n    padding-left: 0;\n  }\n  &.chosen-container-active.chosen-with-drop .chosen-single div {\n    border-right: none;\n  }\n  .chosen-search input[type=\"text\"] {\n    padding: 4px 5px 4px 20px;\n    background: $chosen-sprite no-repeat -30px -20px;\n    direction: rtl;\n  }\n  &.chosen-container-single{\n    .chosen-single div b {\n      background-position: 6px 2px;\n    }\n    &.chosen-with-drop{\n      .chosen-single div b {\n        background-position: -12px 2px;\n      }\n    }\n  }\n}\n\n/* @end */\n\n/* @group Retina compatibility */\n@media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min-resolution: 144dpi), only screen and (min-resolution: 1.5dppx) {\n  .chosen-rtl .chosen-search input[type=\"text\"],\n  .chosen-container-single .chosen-single abbr,\n  .chosen-container-single .chosen-single div b,\n  .chosen-container-single .chosen-search input[type=\"text\"],\n  .chosen-container-multi .chosen-choices .search-choice .search-choice-close,\n  .chosen-container .chosen-results-scroll-down span,\n  .chosen-container .chosen-results-scroll-up span {\n    background-image: $chosen-sprite-retina !important;\n    background-size: 52px 37px !important;\n    background-repeat: no-repeat !important;\n  }\n}\n/* @end */\n"
  },
  {
    "path": "spec/jquery/basic.spec.coffee",
    "content": "describe \"Basic setup\", ->\n  it \"should add chosen to jQuery object\", ->\n    expect(jQuery.fn.chosen).toBeDefined()\n\n  it \"should create very basic chosen\", ->\n    tmpl = \"\n      <select data-placeholder='Choose a Country...'>\n        <option value=''></option>\n        <option value='United States'>United States</option>\n        <option value='United Kingdom'>United Kingdom</option>\n        <option value='Afghanistan'>Afghanistan</option>\n      </select>\n    \"\n    div = $(\"<div>\").html(tmpl)\n    select = div.find(\"select\")\n    expect(select.length).toBe(1)\n    select.chosen()\n    # very simple check that the necessary elements have been created\n    [\"container\", \"container-single\", \"single\", \"default\"].forEach (clazz)->\n      el = div.find(\".chosen-#{clazz}\")\n      expect(el.length).toBe(1)\n\n    # test a few interactions\n    expect(select.val()).toBe \"\"\n\n    container = div.find(\".chosen-container\")\n    container.trigger(\"mousedown\") # open the drop\n    expect(container.hasClass(\"chosen-container-active\")).toBe true\n    #select an item\n    container.find(\".active-result\").last().trigger(\"mouseup\")\n\n    expect(select.val()).toBe \"Afghanistan\"\n\n  describe \"data-placeholder\", ->\n\n    it \"should render\", ->\n      tmpl = \"\n        <select data-placeholder='Choose a Country...'>\n          <option value=''></option>\n          <option value='United States'>United States</option>\n          <option value='United Kingdom'>United Kingdom</option>\n          <option value='Afghanistan'>Afghanistan</option>\n        </select>\n      \"\n      div = $(\"<div>\").html(tmpl)\n      select = div.find(\"select\")\n      expect(select.length).toBe(1)\n      select.chosen()\n      placeholder = div.find(\".chosen-single > span\")\n      expect(placeholder.text()).toBe(\"Choose a Country...\")\n\n    it \"should render with special characters\", ->\n      tmpl = \"\n        <select data-placeholder='&lt;None&gt;'>\n          <option value=''></option>\n          <option value='United States'>United States</option>\n          <option value='United Kingdom'>United Kingdom</option>\n          <option value='Afghanistan'>Afghanistan</option>\n        </select>\n      \"\n      div = $(\"<div>\").html(tmpl)\n      select = div.find(\"select\")\n      expect(select.length).toBe(1)\n      select.chosen()\n      placeholder = div.find(\".chosen-single > span\")\n      expect(placeholder.text()).toBe(\"<None>\")\n\n  describe \"disabled fieldset\", ->\n\n    it \"should render as disabled\", ->\n      tmpl = \"\n        <fieldset disabled>\n          <select data-placeholder='Choose a Country...'>\n            <option value=''></option>\n            <option value='United States'>United States</option>\n            <option value='United Kingdom'>United Kingdom</option>\n            <option value='Afghanistan'>Afghanistan</option>\n          </select>\n        </fieldset>\n      \"\n      div = $(\"<div>\").html(tmpl)\n      select = div.find(\"select\")\n      expect(select.length).toBe(1)\n      select.chosen()\n\n      container = div.find(\".chosen-container\")\n      expect(container.hasClass(\"chosen-disabled\")).toBe true\n"
  },
  {
    "path": "spec/jquery/bugfixes.spec.coffee",
    "content": "describe \"Bugfixes\", ->\n  it \"https://github.com/harvesthq/chosen/issues/2996 - XSS Vulnerability with `include_group_label_in_selected: true`\", ->\n    tmpl = \"\n      <select>\n        <option value=''></option>\n        <optgroup label='</script><script>console.log(1)</script>'>\n          <option>an xss option</option>\n        </optgroup>\n      </select>\n    \"\n\n    div = $(\"<div>\").html(tmpl)\n    select = div.find(\"select\")\n\n    select.chosen\n      include_group_label_in_selected: true\n\n    # open the drop\n    container = div.find(\".chosen-container\")\n    container.trigger(\"mousedown\")\n\n    xss_option = container.find(\".active-result\").last()\n    expect(xss_option.html()).toBe \"an xss option\"\n\n    # trigger the selection of the xss option\n    xss_option.trigger(\"mouseup\")\n\n    # make sure the script tags are escaped correctly\n    label_html = container.find(\"a.chosen-single\").html()\n    expect(label_html).toContain('&lt;/script&gt;&lt;script&gt;console.log(1)&lt;/script&gt;')\n"
  },
  {
    "path": "spec/jquery/events.spec.coffee",
    "content": "describe \"Events\", ->\n  it \"chosen should fire the right events\", ->\n    tmpl = \"\n      <select data-placeholder='Choose a Country...'>\n        <option value=''></option>\n        <option value='United States'>United States</option>\n        <option value='United Kingdom'>United Kingdom</option>\n        <option value='Afghanistan'>Afghanistan</option>\n      </select>\n    \"\n    div = $(\"<div>\").html(tmpl)\n    select = div.find(\"select\")\n    expect(select.length).toBe(1)\n    select.chosen()\n    # very simple check that the necessary elements have been created\n    [\"container\", \"container-single\", \"single\", \"default\"].forEach (clazz)->\n      el = div.find(\".chosen-#{clazz}\")\n      expect(el.length).toBe(1)\n\n    # test a few interactions\n    event_sequence = []\n    div.on 'input change', (evt) -> event_sequence.push evt.type\n\n    container = div.find(\".chosen-container\")\n    container.trigger(\"mousedown\") # open the drop\n    expect(container.hasClass(\"chosen-container-active\")).toBe true\n    #select an item\n    container.find(\".active-result\").last().trigger(\"mouseup\")\n\n    expect(event_sequence).toEqual ['input', 'change']\n"
  },
  {
    "path": "spec/jquery/max_shown_results.spec.coffee",
    "content": "describe \"search\", ->\n  it \"should display only matching items when entering a search term\", ->\n    tmpl = \"\n          <select data-placeholder='Choose a Country...'>\n            <option value=''></option>\n            <option value='United States'>United States</option>\n            <option value='United Kingdom'>United Kingdom</option>\n            <option value='Afghanistan'>Afghanistan</option>\n          </select>\n        \"\n    div = $(\"<div>\").html(tmpl)\n    select = div.find(\"select\")\n    select.chosen()\n\n    container = div.find(\".chosen-container\")\n    container.trigger(\"mousedown\") # open the drop\n    # Expect all results to be shown\n    results = div.find(\".active-result\")\n    expect(results.length).toBe(3)\n\n    # Enter some text in the search field.\n    search_field = div.find(\".chosen-search input\").first()\n    search_field.val(\"Afgh\")\n    search_field.trigger('keyup')\n\n    # Expect to only have one result: 'Afghanistan'.\n    results = div.find(\".active-result\")\n    expect(results.length).toBe(1)\n    expect(results.first().text()).toBe \"Afghanistan\"\n\n  it \"should only show max_shown_results items in results\", ->\n    tmpl = \"\n          <select data-placeholder='Choose a Country...'>\n            <option value=''></option>\n            <option value='United States'>United States</option>\n            <option value='United Kingdom'>United Kingdom</option>\n            <option value='Afghanistan'>Afghanistan</option>\n          </select>\n        \"\n    div = $(\"<div>\").html(tmpl)\n    select = div.find(\"select\")\n    select.chosen({max_shown_results: 1 })\n\n    container = div.find(\".chosen-container\")\n    container.trigger(\"mousedown\") # open the drop\n    results = div.find(\".active-result\")\n    expect(results.length).toBe(1)\n\n    # Enter some text in the search field.\n    search_field = div.find(\".chosen-search input\").first()\n    search_field.val(\"United\")\n    search_field.trigger(\"keyup\")\n\n    # Showing only one result: the one that occurs first.\n    results = div.find(\".active-result\")\n    expect(results.length).toBe(1)\n    expect(results.first().text()).toBe \"United States\"\n\n    # Showing still only one result, but not the first one.\n    search_field.val(\"United Ki\")\n    search_field.trigger(\"keyup\")\n    results = div.find(\".active-result\")\n    expect(results.length).toBe(1)\n    expect(results.first().text()).toBe \"United Kingdom\"\n"
  },
  {
    "path": "spec/jquery/searching.spec.coffee",
    "content": "describe \"Searching\", ->\n  it \"should not match the actual text of HTML entities\", ->\n    tmpl = \"\n      <select data-placeholder='Choose an HTML Entity...'>\n        <option value=''></option>\n        <option value='This & That'>This &amp; That</option>\n        <option value='This < That'>This &lt; That</option>\n      </select>\n    \"\n\n    div = $(\"<div>\").html(tmpl)\n    select = div.find(\"select\")\n    select.chosen({search_contains: true})\n\n    container = div.find(\".chosen-container\")\n    container.trigger(\"mousedown\") # open the drop\n\n    # Both options should be active\n    results = div.find(\".active-result\")\n    expect(results.length).toBe(2)\n\n    # Search for the html entity by name\n    search_field = div.find(\".chosen-search input\").first()\n    search_field.val(\"mp\")\n    search_field.trigger(\"keyup\")\n\n    results = div.find(\".active-result\")\n    expect(results.length).toBe(0)\n\n  it \"renders options correctly when they contain characters that require HTML encoding\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <option value=\"A &amp; B\">A &amp; B</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".active-result\").length).toBe(1)\n    expect(div.find(\".active-result\").first().html()).toBe(\"A &amp; B\")\n\n    search_field = div.find(\".chosen-search-input\").first()\n    search_field.val(\"A\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".active-result\").length).toBe(1)\n    expect(div.find(\".active-result\").first().html()).toBe(\"<em>A</em> &amp; B\")\n\n  it \"renders optgroups correctly when they contain html encoded tags\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <optgroup label=\"A &lt;b&gt;hi&lt;/b&gt; B\">\n          <option value=\"Item\">Item</option>\n        </optgroup>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".group-result\").length).toBe(1)\n    expect(div.find(\".group-result\").first().html()).toBe(\"A &lt;b&gt;hi&lt;/b&gt; B\")\n\n  it \"renders optgroups correctly when they contain characters that require HTML encoding when searching\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <optgroup label=\"A &amp; B\">\n          <option value=\"Item\">Item</option>\n        </optgroup>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".group-result\").length).toBe(1)\n    expect(div.find(\".group-result\").first().html()).toBe(\"A &amp; B\")\n\n    search_field = div.find(\".chosen-search-input\").first()\n    search_field.val(\"A\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".group-result\").length).toBe(1)\n    expect(div.find(\".group-result\").first().html()).toBe(\"<em>A</em> &amp; B\")\n\n  it \"renders no results message correctly when it contains characters that require HTML encoding\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <option value=\"Item\">Item</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    search_field = div.find(\".chosen-search-input\").first()\n    search_field.val(\"&\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".no-results\").length).toBe(1)\n    expect(div.find(\".no-results\").first().html().trim()).toBe(\"No results match <span>&amp;</span>\")\n\n    search_field.val(\"&amp;\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".no-results\").length).toBe(1)\n    expect(div.find(\".no-results\").first().html().trim()).toBe(\"No results match <span>&amp;amp;</span>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting a single item\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".active-result\").length).toBe(12)\n\n    search_field = div.find(\".chosen-search-input\").first()\n    search_field.val(\"一\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".active-result\").length).toBe(1)\n    expect(div.find(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting a single item with search_contains\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen({search_contains: true})\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".active-result\").length).toBe(12)\n\n    search_field = div.find(\".chosen-search-input\").first()\n    search_field.val(\"一\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".active-result\").length).toBe(2)\n    expect(div.find(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n    expect(div.find(\".active-result\")[1].innerHTML).toBe(\"十<em>一</em>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting multiple items\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select multiple>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".active-result\").length).toBe(12)\n\n    search_field = div.find(\".chosen-search-input\")\n    search_field.val(\"一\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".active-result\").length).toBe(1)\n    expect(div.find(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting multiple items with search_contains\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select multiple>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen({search_contains: true})\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".active-result\").length).toBe(12)\n\n    search_field = div.find(\".chosen-search-input\")\n    search_field.val(\"一\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".active-result\").length).toBe(2)\n    expect(div.find(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n    expect(div.find(\".active-result\")[1].innerHTML).toBe(\"十<em>一</em>\")\n\n  it \"highlights results correctly when multiple words are present\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <option value=\"oh hello\">oh hello</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    expect(div.find(\".active-result\").length).toBe(1)\n\n    search_field = div.find(\".chosen-search-input\")\n    search_field.val(\"h\")\n    search_field.trigger(\"keyup\")\n\n    expect(div.find(\".active-result\").length).toBe(1)\n    expect(div.find(\".active-result\")[0].innerHTML).toBe(\"oh <em>h</em>ello\")\n\n  describe \"respects word boundaries when not using search_contains\", ->\n    div = $(\"<div>\").html(\"\"\"\n      <select>\n        <option value=\"(lparen\">(lparen</option>\n        <option value=\"&lt;langle\">&lt;langle</option>\n        <option value=\"[lbrace\">[lbrace</option>\n        <option value=\"{lcurly\">{lcurly</option>\n        <option value=\"¡upsidedownbang\">¡upsidedownbang</option>\n        <option value=\"¿upsidedownqmark\">¿upsidedownqmark</option>\n        <option value=\".period\">.period</option>\n        <option value=\"-dash\">-dash</option>\n        <option value='\"leftquote'>\"leftquote</option>\n        <option value=\"'leftsinglequote\">'leftsinglequote</option>\n        <option value=\"“angledleftquote\">“angledleftquote</option>\n        <option value=\"‘angledleftsinglequote\">‘angledleftsinglequote</option>\n        <option value=\"«guillemet\">«guillemet</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    search_field = div.find(\".chosen-search-input\")\n\n    div.find(\"option\").each () ->\n      boundary_thing = this.value.slice(1)\n      it \"correctly finds words that start after a(n) #{boundary_thing}\", ->\n        search_field.val(boundary_thing)\n        search_field.trigger(\"keyup\")\n        expect(div.find(\".active-result\").length).toBe(1)\n        expect(div.find(\".active-result\")[0].innerText.slice(1)).toBe(boundary_thing)\n\n  it \"does not clear search text or highlight first suggestion when holding ctrl/cmd and selecting multiple items\", () ->\n    div = $(\"<div>\").html(\"\"\"\n      <select multiple>\n        <option></option>\n        <option>Betty Holberton</option>\n        <option>Radia Perlman</option>\n        <option>Barbara Liskov</option>\n        <option>Frances Allen</option>\n        <option>Shafi Goldwasser</option>\n        <option>Maria Klawe</option>\n        <option>Jean E. Sammet</option>\n        <option>Adele Goldberg</option>\n        <option>Jeannette Wing</option>\n        <option>Éva Tardos</option>\n        <option>Lynn Conway</option>\n        <option>Karen Spärck Jones</option>\n        <option>Sophie Wilson</option>\n        <option>Wendy Hall</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen()\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    search_field = div.find(\".chosen-search-input\")\n    search_field.val(\"s\").trigger(\"keyup\")\n\n    results = div.find(\".chosen-results\")\n    first_result = results.find(\"li:nth-of-type(1)\")\n    second_result = results.find(\"li:nth-of-type(2)\")\n\n    expect(first_result.prop(\"class\")).toContain(\"highlighted\")\n\n    mouseup_with_meta = $.Event(\"mouseup\")\n    mouseup_with_meta.metaKey = true\n    second_result.mouseover().trigger(mouseup_with_meta)\n\n    expect(div.find(\".search-choice\").length).toBe(1)\n    expect(search_field.val()).toBe(\"s\")\n    expect(first_result.prop(\"class\")).not.toContain(\"highlighted\")\n\n    third_result = results.find(\"li:nth-of-type(3)\")\n\n    mouseup_with_ctrl = $.Event(\"mouseup\")\n    mouseup_with_ctrl.ctrlKey = true\n    third_result.mouseover().trigger(mouseup_with_ctrl)\n\n    expect(div.find(\".search-choice\").length).toBe(2)\n    expect(search_field.val()).toBe(\"s\")\n    expect(first_result.prop(\"class\")).not.toContain(\"highlighted\")\n\n  it \"clears search text and highlights first suggestion without ctrl/cmd and selecting multiple items without hide_results_on_select\", () ->\n    div = $(\"<div>\").html(\"\"\"\n      <select multiple>\n        <option></option>\n        <option>Betty Holberton</option>\n        <option>Radia Perlman</option>\n        <option>Barbara Liskov</option>\n        <option>Frances Allen</option>\n        <option>Shafi Goldwasser</option>\n        <option>Maria Klawe</option>\n        <option>Jean E. Sammet</option>\n        <option>Adele Goldberg</option>\n        <option>Jeannette Wing</option>\n        <option>Éva Tardos</option>\n        <option>Lynn Conway</option>\n        <option>Karen Spärck Jones</option>\n        <option>Sophie Wilson</option>\n        <option>Wendy Hall</option>\n      </select>\n    \"\"\")\n\n    div.find(\"select\").chosen(hide_results_on_select: false)\n    div.find(\".chosen-container\").trigger(\"mousedown\") # open the drop\n\n    search_field = div.find(\".chosen-search-input\")\n    search_field.val(\"s\").trigger(\"keyup\")\n\n    results = div.find(\".chosen-results\")\n    first_result = results.find(\"li:nth-of-type(1)\")\n    second_result = results.find(\"li:nth-of-type(2)\")\n\n    expect(first_result.prop(\"class\")).toContain(\"highlighted\")\n\n    second_result.mouseover().mouseup()\n\n    expect(div.find(\".search-choice\").length).toBe(1)\n    expect(search_field.val()).toBe(\"\")\n    expect(results.find(\"li:nth-of-type(1)\").prop(\"class\")).toContain(\"highlighted\")\n"
  },
  {
    "path": "spec/proto/basic.spec.coffee",
    "content": "describe \"Basic setup\", ->\n  it \"should add expose a Chosen global\", ->\n    expect(Chosen).toBeDefined()\n\n  it \"should create very basic chosen\", ->\n    tmpl = \"\n      <select data-placeholder='Choose a Country...'>\n        <option value=''></option>\n        <option value='United States'>United States</option>\n        <option value='United Kingdom'>United Kingdom</option>\n        <option value='Afghanistan'>Afghanistan</option>\n      </select>\n    \"\n\n    div = new Element(\"div\")\n    document.body.insert(div)\n    div.update(tmpl)\n    select = div.down(\"select\")\n    expect(select).toBeDefined()\n    new Chosen(select)\n    # very simple check that the necessary elements have been created\n    [\"container\", \"container-single\", \"single\", \"default\"].forEach (clazz)->\n      el = div.down(\".chosen-#{clazz}\")\n      expect(el).toBeDefined()\n\n    # test a few interactions\n    expect($F(select)).toBe \"\"\n\n    container = div.down(\".chosen-container\")\n    simulant.fire(container, \"mousedown\") # open the drop\n    expect(container.hasClassName(\"chosen-container-active\")).toBe true\n\n    #select an item\n    result = container.select(\".active-result\").last()\n    simulant.fire(result, \"mouseup\")\n\n    expect($F(select)).toBe \"Afghanistan\"\n    div.remove()\n\n  describe \"data-placeholder\", ->\n\n    it \"should render\", ->\n      tmpl = \"\n        <select data-placeholder='Choose a Country...'>\n          <option value=''></option>\n          <option value='United States'>United States</option>\n          <option value='United Kingdom'>United Kingdom</option>\n          <option value='Afghanistan'>Afghanistan</option>\n        </select>\n      \"\n      div = new Element(\"div\")\n      document.body.insert(div)\n      div.update(tmpl)\n      select = div.down(\"select\")\n      expect(select).toBeDefined()\n      new Chosen(select)\n\n      placeholder = div.down(\".chosen-single > span\")\n      expect(placeholder.innerText).toBe(\"Choose a Country...\")\n\n    it \"should render with special characters\", ->\n      tmpl = \"\n        <select data-placeholder='&lt;None&gt;'>\n          <option value=''></option>\n          <option value='United States'>United States</option>\n          <option value='United Kingdom'>United Kingdom</option>\n          <option value='Afghanistan'>Afghanistan</option>\n        </select>\n      \"\n      div = new Element(\"div\")\n      document.body.insert(div)\n      div.update(tmpl)\n      select = div.down(\"select\")\n      expect(select).toBeDefined()\n      new Chosen(select)\n\n      placeholder = div.down(\".chosen-single > span\")\n      expect(placeholder.innerText).toBe(\"<None>\")\n\n  describe \"disabled fieldset\", ->\n\n    it \"should render as disabled\", ->\n      tmpl = \"\n        <fieldset disabled>\n          <select data-placeholder='Choose a Country...'>\n            <option value=''></option>\n            <option value='United States'>United States</option>\n            <option value='United Kingdom'>United Kingdom</option>\n            <option value='Afghanistan'>Afghanistan</option>\n          </select>\n        </fieldset>\n      \"\n      div = new Element(\"div\")\n      document.body.insert(div)\n      div.update(tmpl)\n      select = div.down(\"select\")\n      expect(select).toBeDefined()\n      new Chosen(select)\n\n      container = div.down(\".chosen-container\")\n      expect(container.hasClassName(\"chosen-disabled\")).toBe true\n"
  },
  {
    "path": "spec/proto/bugfixes.spec.coffee",
    "content": "describe \"Bugfixes\", ->\n  it \"https://github.com/harvesthq/chosen/issues/2996 - XSS Vulnerability with `include_group_label_in_selected: true`\", ->\n    tmpl = \"\n      <select>\n        <option value=''></option>\n        <optgroup id='xss' label='</script><script>console.log(1)</script>'>\n          <option>an xss option</option>\n        </optgroup>\n      </select>\n    \"\n    div = new Element(\"div\")\n    document.body.insert(div)\n    div.innerHTML = tmpl\n\n    select = div.down(\"select\")\n    new Chosen select,\n      include_group_label_in_selected: true\n\n    # open the drop\n    container = div.down(\".chosen-container\")\n    simulant.fire(container, \"mousedown\") # open the drop\n\n    xss_option = container.select(\".active-result\").last()\n    expect(xss_option.innerHTML).toBe \"an xss option\"\n\n    # trigger the selection of the xss option\n    simulant.fire(xss_option, \"mouseup\")\n\n    # make sure the script tags are escaped correctly\n    label_html = container.down(\"a.chosen-single\").innerHTML\n    expect(label_html).toContain('&lt;/script&gt;&lt;script&gt;console.log(1)&lt;/script&gt;')\n\n"
  },
  {
    "path": "spec/proto/events.spec.coffee",
    "content": "describe \"Events\", ->\n  it \"chosen should fire the right events\", ->\n    tmpl = \"\n      <select data-placeholder='Choose a Country...'>\n        <option value=''></option>\n        <option value='United States'>United States</option>\n        <option value='United Kingdom'>United Kingdom</option>\n        <option value='Afghanistan'>Afghanistan</option>\n      </select>\n    \"\n\n    div = new Element(\"div\")\n    document.body.insert(div)\n\n    div.update(tmpl)\n    select = div.down(\"select\")\n    expect(select).toBeDefined()\n    new Chosen(select)\n\n    event_sequence = []\n    document.addEventListener 'input', -> event_sequence.push 'input'\n    document.addEventListener 'change', -> event_sequence.push 'change'\n\n    container = div.down(\".chosen-container\")\n    simulant.fire(container, \"mousedown\") # open the drop\n    expect(container.hasClassName(\"chosen-container-active\")).toBe true\n\n    #select an item\n    result = container.select(\".active-result\").last()\n    simulant.fire(result, \"mouseup\")\n\n    expect(event_sequence).toEqual ['input', 'change']\n    div.remove()\n"
  },
  {
    "path": "spec/proto/max_shown_results.spec.coffee",
    "content": "describe 'search', ->\n  it 'should display only matching items when entering a search term', ->\n    tmpl = '''\n      <select data-placeholder=\"Choose a Country...\">\n        <option value=\"\"></option>\n        <option value=\"United States\">United States</option>\n        <option value=\"United Kingdom\">United Kingdom</option>\n        <option value=\"Afghanistan\">Afghanistan</option>\n      </select>\n    '''\n    div = new Element('div')\n    document.body.insert(div)\n    div.update(tmpl)\n    select = div.down('select')\n    new Chosen(select)\n\n    container = div.down('.chosen-container')\n    simulant.fire(container, 'mousedown') # open the drop\n    # Expect all results to be shown\n    results = div.select('.active-result')\n    expect(results.length).toBe(3)\n\n    # Enter some text in the search field.\n    search_field = div.down('.chosen-search input')\n    search_field.value = 'Afgh'\n    simulant.fire(search_field, 'keyup')\n\n    # Expect to only have one result: 'Afghanistan'.\n    results = div.select('.active-result')\n    expect(results.length).toBe(1)\n    expect(results[0].innerText).toBe 'Afghanistan'\n\n  it 'should only show max_shown_results items in results', ->\n    tmpl = '''\n      <select data-placeholder=\"Choose a Country...\">\n        <option value=\"\"></option>\n        <option value=\"United States\">United States</option>\n        <option value=\"United Kingdom\">United Kingdom</option>\n        <option value=\"Afghanistan\">Afghanistan</option>\n      </select>\n    '''\n    div = new Element('div')\n    document.body.insert(div)\n    div.update(tmpl)\n    select = div.down('select')\n    new Chosen(select, { max_shown_results: 1 })\n\n    container = div.down('.chosen-container')\n    simulant.fire(container, 'mousedown') # open the drop\n    results = div.select('.active-result')\n    expect(results.length).toBe(1)\n\n    # Enter some text in the search field.\n    search_field = div.down('.chosen-search input')\n    search_field.value = 'United'\n    simulant.fire(search_field, 'keyup')\n\n    # Showing only one result: the one that occurs first.\n    results = div.select('.active-result')\n    expect(results.length).toBe(1)\n    expect(results[0].innerText).toBe 'United States'\n\n    # Showing still only one result, but not the first one.\n    search_field.value = 'United Ki'\n    simulant.fire(search_field, 'keyup')\n    results = div.select('.active-result')\n    expect(results.length).toBe(1)\n    expect(results[0].innerText).toBe 'United Kingdom'\n"
  },
  {
    "path": "spec/proto/searching.spec.coffee",
    "content": "describe \"Searching\", ->\n  it \"should not match the actual text of HTML entities\", ->\n    tmpl = \"\n      <select data-placeholder='Choose an HTML Entity...'>\n        <option value=''></option>\n        <option value='This & That'>This &amp; That</option>\n        <option value='This < That'>This &lt; That</option>\n      </select>\n    \"\n\n    div = new Element('div')\n    document.body.insert(div)\n    div.update(tmpl)\n    select = div.down('select')\n    new Chosen(select, {search_contains: true})\n\n    container = div.down('.chosen-container')\n    simulant.fire(container, 'mousedown') # open the drop\n\n    # Both options should be active\n    results = div.select('.active-result')\n    expect(results.length).toBe(2)\n\n    # Search for the html entity by name\n    search_field = div.down(\".chosen-search input\")\n    search_field.value = \"mp\"\n    simulant.fire(search_field, 'keyup')\n\n    results = div.select(\".active-result\")\n    expect(results.length).toBe(0)\n\n  it \"renders options correctly when they contain characters that require HTML encoding\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <option value=\"A &amp; B\">A &amp; B</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".active-result\").length).toBe(1)\n    expect(div.down(\".active-result\").innerHTML).toBe(\"A &amp; B\")\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"A\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".active-result\").length).toBe(1)\n    expect(div.down(\".active-result\").innerHTML).toBe(\"<em>A</em> &amp; B\")\n\n  it \"renders optgroups correctly when they contain characters that require HTML encoding\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <optgroup label=\"A &lt;b&gt;hi&lt;/b&gt; B\">\n          <option value=\"Item\">Item</option>\n        </optgroup>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".group-result\").length).toBe(1)\n    expect(div.down(\".group-result\").innerHTML).toBe(\"A &lt;b&gt;hi&lt;/b&gt; B\")\n\n  it \"renders optgroups correctly when they contain characters that require HTML encoding when searching\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <optgroup label=\"A &amp; B\">\n          <option value=\"Item\">Item</option>\n        </optgroup>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".group-result\").length).toBe(1)\n    expect(div.down(\".group-result\").innerHTML).toBe(\"A &amp; B\")\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"A\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".group-result\").length).toBe(1)\n    expect(div.down(\".group-result\").innerHTML).toBe(\"<em>A</em> &amp; B\")\n\n  it \"renders no results message correctly when it contains characters that require HTML encoding\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <option value=\"Item\">Item</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"&\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".no-results\").length).toBe(1)\n    expect(div.down(\".no-results\").innerHTML.trim()).toBe(\"No results match <span>&amp;</span>\")\n\n    search_field.value = \"&amp;\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".no-results\").length).toBe(1)\n    expect(div.down(\".no-results\").innerHTML.trim()).toBe(\"No results match <span>&amp;amp;</span>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting a single item\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".active-result\").length).toBe(12)\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"一\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".active-result\").length).toBe(1)\n    expect(div.select(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting a single item with search_contains\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"), {search_contains: true})\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".active-result\").length).toBe(12)\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"一\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".active-result\").length).toBe(2)\n    expect(div.select(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n    expect(div.select(\".active-result\")[1].innerHTML).toBe(\"十<em>一</em>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting multiple items\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select multiple>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".active-result\").length).toBe(12)\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"一\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".active-result\").length).toBe(1)\n    expect(div.select(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n\n  it \"matches in non-ascii languages like Chinese when selecting multiple items with search_contains\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select multiple>\n        <option value=\"一\">一</option>\n        <option value=\"二\">二</option>\n        <option value=\"三\">三</option>\n        <option value=\"四\">四</option>\n        <option value=\"五\">五</option>\n        <option value=\"六\">六</option>\n        <option value=\"七\">七</option>\n        <option value=\"八\">八</option>\n        <option value=\"九\">九</option>\n        <option value=\"十\">十</option>\n        <option value=\"十一\">十一</option>\n        <option value=\"十二\">十二</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"), {search_contains: true})\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".active-result\").length).toBe(12)\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"一\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".active-result\").length).toBe(2)\n    expect(div.select(\".active-result\")[0].innerHTML).toBe(\"<em>一</em>\")\n    expect(div.select(\".active-result\")[1].innerHTML).toBe(\"十<em>一</em>\")\n\n  it \"highlights results correctly when multiple words are present\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <option value=\"oh hello\">oh hello</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    expect(div.select(\".active-result\").length).toBe(1)\n\n    search_field = div.down(\".chosen-search-input\")\n    search_field.value = \"h\"\n    simulant.fire(search_field, \"keyup\")\n\n    expect(div.select(\".active-result\").length).toBe(1)\n    expect(div.select(\".active-result\")[0].innerHTML).toBe(\"oh <em>h</em>ello\")\n\n  describe \"respects word boundaries when not using search_contains\", ->\n    div = new Element(\"div\")\n    div.update(\"\"\"\n      <select>\n        <option value=\"(lparen\">(lparen</option>\n        <option value=\"&lt;langle\">&lt;langle</option>\n        <option value=\"[lbrace\">[lbrace</option>\n        <option value=\"{lcurly\">{lcurly</option>\n        <option value=\"¡upsidedownbang\">¡upsidedownbang</option>\n        <option value=\"¿upsidedownqmark\">¿upsidedownqmark</option>\n        <option value=\".period\">.period</option>\n        <option value=\"-dash\">-dash</option>\n        <option value='\"leftquote'>\"leftquote</option>\n        <option value=\"'leftsinglequote\">'leftsinglequote</option>\n        <option value=\"“angledleftquote\">“angledleftquote</option>\n        <option value=\"‘angledleftsinglequote\">‘angledleftsinglequote</option>\n        <option value=\"«guillemet\">«guillemet</option>\n      </select>\n    \"\"\")\n\n    new Chosen(div.down(\"select\"))\n    simulant.fire(div.down(\".chosen-container\"), \"mousedown\") # open the drop\n\n    search_field = div.down(\".chosen-search-input\")\n\n    div.select(\"option\").forEach (option) ->\n      boundary_thing = option.value.slice(1)\n      it \"correctly finds words that start after a(n) #{boundary_thing}\", ->\n        search_field.value = boundary_thing\n        simulant.fire(search_field, \"keyup\")\n        expect(div.select(\".active-result\").length).toBe(1)\n        expect(div.select(\".active-result\")[0].innerText.slice(1)).toBe(boundary_thing)\n"
  },
  {
    "path": "tasks/package.coffee",
    "content": "###\nThis file contains tasks only necessary for packaging and publishing Chosen\n###\nmodule.exports = (grunt) ->\n\n  grunt.config 'dom_munger',\n    latest_version:\n      src: ['public/index.html', 'public/index.proto.html', 'public/options.html']\n      options:\n        callback: ($) ->\n          $('#latest-version').text(grunt.config.get('version_tag'))\n\n  grunt.config 'zip',\n    chosen:\n      cwd: 'public/'\n      src: ['public/**/*']\n      dest: 'chosen_<%= version_tag %>.zip'\n\n  grunt.config 'gh-pages',\n    options:\n      base: 'public',\n      message: 'Updated to new Chosen version <%= pkg.version %>'\n    src: ['**']\n\n  grunt.registerTask 'package-npm', 'Generate npm manifest', () ->\n    pkg = grunt.config.get('pkg')\n    extra = pkg._extra\n\n    json =\n      name: \"#{pkg.name}-js\"\n      version: pkg.version\n      description: pkg.description\n      keywords: pkg.keywords\n      homepage: pkg.homepage\n      bugs: pkg.bugs\n      license: pkg.license\n      contributors: pkg.contributors\n      dependencies: pkg.dependencies\n      files: extra.files\n      main: extra.main[0]\n      repository: pkg.repository\n\n    grunt.file.write('public/package.json', JSON.stringify(json, null, 2) + \"\\n\")\n\n  grunt.registerTask 'package-bower', 'Generate bower manifest', () ->\n    pkg = grunt.config.get('pkg')\n    extra = pkg._extra\n\n    json =\n      name: pkg.name\n      description: pkg.description\n      keywords: pkg.keywords\n      homepage: pkg.homepage\n      license: extra.license.url\n      authors: pkg.contributors\n      dependencies: pkg.dependencies\n      main: extra.main\n      ignore: []\n      repository: pkg.repository\n\n    grunt.file.write('public/bower.json', JSON.stringify(json, null, 2) + \"\\n\")\n\n  grunt.registerTask 'prep-release', ['build', 'dom_munger:latest_version', 'zip:chosen', 'package-npm', 'package-bower']\n  grunt.registerTask 'publish-release', ['gh-pages']\n"
  }
]