unpoly-rails 0.20.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of unpoly-rails might be problematic. Click here for more details.
- checksums.yaml +7 -0
- data/.gitignore +9 -0
- data/.ruby-version +2 -0
- data/.yardopts +1 -0
- data/CHANGELOG.md +577 -0
- data/Gemfile +8 -0
- data/Gemfile.lock +42 -0
- data/LICENSE +22 -0
- data/README.md +75 -0
- data/README_RAILS.md +116 -0
- data/Rakefile +45 -0
- data/bower.json +26 -0
- data/design/animation-ghosting.txt +72 -0
- data/design/design.txt +34 -0
- data/design/draft.html.erb +48 -0
- data/design/draft.rb +9 -0
- data/design/ghost-debugging.txt +118 -0
- data/design/homepage.txt +236 -0
- data/design/rename.txt +0 -0
- data/dist/unpoly-bootstrap3.css +5 -0
- data/dist/unpoly-bootstrap3.js +28 -0
- data/dist/unpoly-bootstrap3.min.css +1 -0
- data/dist/unpoly-bootstrap3.min.js +1 -0
- data/dist/unpoly.css +98 -0
- data/dist/unpoly.js +9041 -0
- data/dist/unpoly.min.css +1 -0
- data/dist/unpoly.min.js +3 -0
- data/lib/assets/javascripts/unpoly-bootstrap3.js.coffee +2 -0
- data/lib/assets/javascripts/unpoly-bootstrap3/form-ext.js.coffee +1 -0
- data/lib/assets/javascripts/unpoly-bootstrap3/layout-ext.js.coffee +5 -0
- data/lib/assets/javascripts/unpoly-bootstrap3/modal-ext.js.coffee +11 -0
- data/lib/assets/javascripts/unpoly-bootstrap3/navigation-ext.js.coffee +3 -0
- data/lib/assets/javascripts/unpoly.js.coffee +20 -0
- data/lib/assets/javascripts/unpoly/browser.js.coffee +252 -0
- data/lib/assets/javascripts/unpoly/bus.js.coffee +393 -0
- data/lib/assets/javascripts/unpoly/flow.js.coffee +809 -0
- data/lib/assets/javascripts/unpoly/form.js.coffee +864 -0
- data/lib/assets/javascripts/unpoly/history.js.coffee +204 -0
- data/lib/assets/javascripts/unpoly/layout.js.coffee +529 -0
- data/lib/assets/javascripts/unpoly/link.js.coffee +496 -0
- data/lib/assets/javascripts/unpoly/log.js.coffee +73 -0
- data/lib/assets/javascripts/unpoly/modal.js.coffee +509 -0
- data/lib/assets/javascripts/unpoly/module.js.coffee +4 -0
- data/lib/assets/javascripts/unpoly/motion.js.coffee +690 -0
- data/lib/assets/javascripts/unpoly/navigation.js.coffee +219 -0
- data/lib/assets/javascripts/unpoly/popup.js.coffee +409 -0
- data/lib/assets/javascripts/unpoly/proxy.js.coffee +521 -0
- data/lib/assets/javascripts/unpoly/rails.js.coffee +36 -0
- data/lib/assets/javascripts/unpoly/syntax.js.coffee +337 -0
- data/lib/assets/javascripts/unpoly/tooltip.js.coffee +183 -0
- data/lib/assets/javascripts/unpoly/util.js.coffee +1593 -0
- data/lib/assets/stylesheets/unpoly-bootstrap3.css.sass +1 -0
- data/lib/assets/stylesheets/unpoly-bootstrap3/modal-ext.css.sass +9 -0
- data/lib/assets/stylesheets/unpoly.css.sass +1 -0
- data/lib/assets/stylesheets/unpoly/close.css.sass +2 -0
- data/lib/assets/stylesheets/unpoly/error.css.sass +15 -0
- data/lib/assets/stylesheets/unpoly/link.css.sass +2 -0
- data/lib/assets/stylesheets/unpoly/modal.css.sass +69 -0
- data/lib/assets/stylesheets/unpoly/popup.css.sass +8 -0
- data/lib/assets/stylesheets/unpoly/tooltip.css.sass +42 -0
- data/lib/unpoly-rails.rb +7 -0
- data/lib/unpoly/rails/engine.rb +6 -0
- data/lib/unpoly/rails/inspector.rb +78 -0
- data/lib/unpoly/rails/inspector_accessor.rb +30 -0
- data/lib/unpoly/rails/request_echo_headers.rb +27 -0
- data/lib/unpoly/rails/request_method_cookie.rb +36 -0
- data/lib/unpoly/rails/version.rb +9 -0
- data/spec_app/.firefox-version +1 -0
- data/spec_app/.gitignore +17 -0
- data/spec_app/.rspec +2 -0
- data/spec_app/Bowerfile +3 -0
- data/spec_app/Gemfile +29 -0
- data/spec_app/Gemfile.lock +212 -0
- data/spec_app/README.rdoc +28 -0
- data/spec_app/Rakefile +6 -0
- data/spec_app/app/assets/images/.keep +0 -0
- data/spec_app/app/assets/javascripts/application.js +20 -0
- data/spec_app/app/assets/stylesheets/application.css +17 -0
- data/spec_app/app/assets/stylesheets/blocks/card.css.sass +11 -0
- data/spec_app/app/assets/stylesheets/blocks/controls.css.sass +7 -0
- data/spec_app/app/assets/stylesheets/blocks/menu.css.sass +13 -0
- data/spec_app/app/assets/stylesheets/blocks/panel.css.sass +8 -0
- data/spec_app/app/assets/stylesheets/jasmine_specs.css +5 -0
- data/spec_app/app/controllers/application_controller.rb +6 -0
- data/spec_app/app/controllers/concerns/.keep +0 -0
- data/spec_app/app/controllers/test_controller.rb +28 -0
- data/spec_app/app/helpers/application_helper.rb +2 -0
- data/spec_app/app/mailers/.keep +0 -0
- data/spec_app/app/models/concerns/.keep +0 -0
- data/spec_app/app/views/layouts/application.html.erb +12 -0
- data/spec_app/bin/bundle +3 -0
- data/spec_app/bin/rails +8 -0
- data/spec_app/bin/rake +8 -0
- data/spec_app/bin/setup +29 -0
- data/spec_app/bin/spring +18 -0
- data/spec_app/config.ru +4 -0
- data/spec_app/config/application.rb +26 -0
- data/spec_app/config/boot.rb +3 -0
- data/spec_app/config/database.yml +25 -0
- data/spec_app/config/environment.rb +5 -0
- data/spec_app/config/environments/development.rb +41 -0
- data/spec_app/config/environments/production.rb +79 -0
- data/spec_app/config/environments/test.rb +42 -0
- data/spec_app/config/initializers/assets.rb +11 -0
- data/spec_app/config/initializers/backtrace_silencers.rb +7 -0
- data/spec_app/config/initializers/bower_rails.rb +16 -0
- data/spec_app/config/initializers/cookies_serializer.rb +3 -0
- data/spec_app/config/initializers/filter_parameter_logging.rb +4 -0
- data/spec_app/config/initializers/inflections.rb +16 -0
- data/spec_app/config/initializers/mime_types.rb +4 -0
- data/spec_app/config/initializers/session_store.rb +3 -0
- data/spec_app/config/initializers/wrap_parameters.rb +14 -0
- data/spec_app/config/locales/en.yml +23 -0
- data/spec_app/config/routes.rb +8 -0
- data/spec_app/config/secrets.yml +22 -0
- data/spec_app/db/schema.rb +23 -0
- data/spec_app/db/seeds.rb +7 -0
- data/spec_app/lib/assets/.keep +0 -0
- data/spec_app/lib/tasks/.keep +0 -0
- data/spec_app/lib/tasks/cucumber.rake +65 -0
- data/spec_app/log/.keep +0 -0
- data/spec_app/public/404.html +67 -0
- data/spec_app/public/422.html +67 -0
- data/spec_app/public/500.html +66 -0
- data/spec_app/public/favicon.ico +0 -0
- data/spec_app/public/robots.txt +5 -0
- data/spec_app/script/cucumber +10 -0
- data/spec_app/spec/controllers/test_controller_spec.rb +76 -0
- data/spec_app/spec/javascripts/helpers/append_fixture.js.coffee +8 -0
- data/spec_app/spec/javascripts/helpers/browser_switches.js.coffee +9 -0
- data/spec_app/spec/javascripts/helpers/index.js.coffee +1 -0
- data/spec_app/spec/javascripts/helpers/knife.js.coffee +69 -0
- data/spec_app/spec/javascripts/helpers/last_request.js.coffee +22 -0
- data/spec_app/spec/javascripts/helpers/mock_ajax.js.coffee +5 -0
- data/spec_app/spec/javascripts/helpers/mock_clock.js.coffee +2 -0
- data/spec_app/spec/javascripts/helpers/remove_body_margin.js.coffee +5 -0
- data/spec_app/spec/javascripts/helpers/reset_knife.js.coffee +2 -0
- data/spec_app/spec/javascripts/helpers/reset_path.js.coffee +8 -0
- data/spec_app/spec/javascripts/helpers/reset_up.js.coffee +4 -0
- data/spec_app/spec/javascripts/helpers/restore_body_scroll.js.coffee +2 -0
- data/spec_app/spec/javascripts/helpers/set_timer.js.coffee +3 -0
- data/spec_app/spec/javascripts/helpers/to_be_around.js.coffee +5 -0
- data/spec_app/spec/javascripts/helpers/to_be_blank.js.coffee +5 -0
- data/spec_app/spec/javascripts/helpers/to_be_given.js.coffee +5 -0
- data/spec_app/spec/javascripts/helpers/to_be_missing.js.coffee +5 -0
- data/spec_app/spec/javascripts/helpers/to_be_present.js.coffee +5 -0
- data/spec_app/spec/javascripts/helpers/to_end_with.js.coffee +8 -0
- data/spec_app/spec/javascripts/helpers/to_equal_jquery.js.coffee +9 -0
- data/spec_app/spec/javascripts/helpers/to_have_request_method.js.coffee +8 -0
- data/spec_app/spec/javascripts/helpers/trigger.js.coffee +68 -0
- data/spec_app/spec/javascripts/support/jasmine.yml +51 -0
- data/spec_app/spec/javascripts/up/bus_spec.js.coffee +122 -0
- data/spec_app/spec/javascripts/up/flow_spec.js.coffee +755 -0
- data/spec_app/spec/javascripts/up/form_spec.js.coffee +471 -0
- data/spec_app/spec/javascripts/up/history_spec.js.coffee +96 -0
- data/spec_app/spec/javascripts/up/layout_spec.js.coffee +318 -0
- data/spec_app/spec/javascripts/up/link_spec.js.coffee +340 -0
- data/spec_app/spec/javascripts/up/modal_spec.js.coffee +265 -0
- data/spec_app/spec/javascripts/up/motion_spec.js.coffee +306 -0
- data/spec_app/spec/javascripts/up/navigation_spec.js.coffee +132 -0
- data/spec_app/spec/javascripts/up/popup_spec.js.coffee +220 -0
- data/spec_app/spec/javascripts/up/proxy_spec.js.coffee +371 -0
- data/spec_app/spec/javascripts/up/rails_spec.js.coffee +101 -0
- data/spec_app/spec/javascripts/up/syntax_spec.js.coffee +99 -0
- data/spec_app/spec/javascripts/up/tooltip_spec.js.coffee +60 -0
- data/spec_app/spec/javascripts/up/util_spec.js.coffee +325 -0
- data/spec_app/spec/spec_helper.rb +62 -0
- data/spec_app/test/controllers/.keep +0 -0
- data/spec_app/test/fixtures/.keep +0 -0
- data/spec_app/test/helpers/.keep +0 -0
- data/spec_app/test/integration/.keep +0 -0
- data/spec_app/test/mailers/.keep +0 -0
- data/spec_app/test/models/.keep +0 -0
- data/spec_app/test/test_helper.rb +10 -0
- data/spec_app/vendor/assets/.bowerrc +3 -0
- data/spec_app/vendor/assets/bower.json +8 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/.bower.json +43 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/MIT.LICENSE +20 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/README.markdown +289 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/bower.json +35 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/lib/mock-ajax.js +733 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/package.json +26 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/2.0.2.md +50 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/2.99.md +14 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.0.md +28 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.1.0.md +24 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.1.1.md +23 -0
- data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.2.0.md +20 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/.bower.json +27 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/.gitignore +8 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/.npmignore +8 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/LICENSE.txt +24 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/README.md +118 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/bower.json +17 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/dist/jasmine-fixture.js +433 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/dist/jasmine-fixture.min.js +5 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/basic-usage-spec.coffee +14 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/helpers/invariants.coffee +17 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/helpers/spec-within-a-spec.coffee +24 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/helpers/tmp-files.coffee +8 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/support/jasmine1-testem-config.json +11 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/support/jasmine2-testem-config.json +11 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/vendor/js/jquery-1.11.0.js +10337 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/vendor/js/jquery-1.8.3.js +9472 -0
- data/spec_app/vendor/assets/bower_components/jasmine-fixture/vendor/js/jquery-2.1.0.js +9111 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/.bower.json +26 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/CONTRIBUTING.md +28 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/Gruntfile.js +49 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/LICENSE +20 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/README.md +367 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/bower.json +15 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/lib/jasmine-jquery.js +838 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/package.json +35 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/fixture_with_checkbox_with_checked.html +6 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/fixture_with_javascript.html +1 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/fixture_with_javascript_block.html +1 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/javascripts/jasmine_javascript_click.js +1 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/javascripts/jasmine_javascript_hover.js +1 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/json/jasmine_json_test.json +1 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/real_non_mocked_fixture.html +1 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/real_non_mocked_fixture_style.css +1 -0
- data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/suites/jasmine-jquery-spec.js +1842 -0
- data/spec_app/vendor/assets/bower_components/jasmine/.bower.json +50 -0
- data/spec_app/vendor/assets/bower_components/jasmine/CONTRIBUTING.md +130 -0
- data/spec_app/vendor/assets/bower_components/jasmine/GOALS_2.0.md +64 -0
- data/spec_app/vendor/assets/bower_components/jasmine/MANIFEST.in +5 -0
- data/spec_app/vendor/assets/bower_components/jasmine/MIT.LICENSE +20 -0
- data/spec_app/vendor/assets/bower_components/jasmine/README.md +73 -0
- data/spec_app/vendor/assets/bower_components/jasmine/RELEASE.md +73 -0
- data/spec_app/vendor/assets/bower_components/jasmine/bower.json +41 -0
- data/spec_app/vendor/assets/bower_components/jasmine/images/jasmine-horizontal.png +0 -0
- data/spec_app/vendor/assets/bower_components/jasmine/images/jasmine-horizontal.svg +102 -0
- data/spec_app/vendor/assets/bower_components/jasmine/images/jasmine_favicon.png +0 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/console/console.js +190 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core.js +37 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/boot.js +143 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/example/node_example/lib/jasmine_examples/Player.js +24 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/example/node_example/lib/jasmine_examples/Song.js +9 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/jasmine-html.js +446 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/jasmine.css +58 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/jasmine.js +3298 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/json2.js +489 -0
- data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/node_boot.js +41 -0
- data/spec_app/vendor/assets/bower_components/jasmine/package.json +34 -0
- data/spec_app/vendor/assets/bower_components/jasmine/requirements.txt +1 -0
- data/spec_app/vendor/assets/bower_components/jquery/.bower.json +38 -0
- data/spec_app/vendor/assets/bower_components/jquery/MIT-LICENSE.txt +21 -0
- data/spec_app/vendor/assets/bower_components/jquery/bower.json +28 -0
- data/spec_app/vendor/assets/bower_components/jquery/dist/jquery.js +9210 -0
- data/spec_app/vendor/assets/bower_components/jquery/dist/jquery.min.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/dist/jquery.min.map +1 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax.js +786 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/jsonp.js +89 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/load.js +75 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/parseJSON.js +13 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/parseXML.js +28 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/script.js +64 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/var/nonce.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/var/rquery.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/ajax/xhr.js +136 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/attributes.js +11 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/attributes/attr.js +141 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/attributes/classes.js +158 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/attributes/prop.js +94 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/attributes/support.js +35 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/attributes/val.js +161 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/callbacks.js +205 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/core.js +502 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/core/access.js +60 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/core/init.js +123 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/core/parseHTML.js +39 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/core/ready.js +97 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/core/var/rsingleTag.js +4 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css.js +450 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/addGetHookIf.js +22 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/curCSS.js +57 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/defaultDisplay.js +70 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/hiddenVisibleSelectors.js +15 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/support.js +96 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/swap.js +28 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/var/cssExpand.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/var/getStyles.js +12 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/var/isHidden.js +13 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/var/rmargin.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/css/var/rnumnonpx.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/data.js +178 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/data/Data.js +181 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/data/accepts.js +20 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/data/var/data_priv.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/data/var/data_user.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/deferred.js +149 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/deprecated.js +13 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/dimensions.js +50 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/effects.js +648 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/effects/Tween.js +114 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/effects/animatedSelector.js +13 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/event.js +868 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/event/ajax.js +13 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/event/alias.js +39 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/event/support.js +9 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/exports/amd.js +24 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/exports/global.js +32 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/intro.js +44 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/jquery.js +37 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/manipulation.js +580 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/manipulation/_evalUrl.js +18 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/manipulation/support.js +32 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/manipulation/var/rcheckableType.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/offset.js +207 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/outro.js +1 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/queue.js +142 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/queue/delay.js +22 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/selector-native.js +172 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/selector-sizzle.js +14 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/selector.js +1 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/serialize.js +111 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/sizzle/dist/sizzle.js +2067 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/sizzle/dist/sizzle.min.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/sizzle/dist/sizzle.min.map +1 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/traversing.js +199 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/traversing/findFilter.js +100 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/traversing/var/rneedsContext.js +6 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/arr.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/class2type.js +4 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/concat.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/hasOwn.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/indexOf.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/pnum.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/push.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/rnotwhite.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/slice.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/strundefined.js +3 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/support.js +4 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/var/toString.js +5 -0
- data/spec_app/vendor/assets/bower_components/jquery/src/wrap.js +79 -0
- data/spec_app/vendor/assets/javascripts/.keep +0 -0
- data/spec_app/vendor/assets/stylesheets/.keep +0 -0
- data/unpoly-rails.gemspec +24 -0
- metadata +423 -0
@@ -0,0 +1,101 @@
|
|
1
|
+
describe 'up.rails', ->
|
2
|
+
|
3
|
+
u = up.util
|
4
|
+
|
5
|
+
upAttributes = ['up-follow', 'up-target', 'up-modal', 'up-popup']
|
6
|
+
|
7
|
+
describe '[data-method]', ->
|
8
|
+
|
9
|
+
beforeEach ->
|
10
|
+
@oldRails = $.rails
|
11
|
+
|
12
|
+
afterEach ->
|
13
|
+
$.rails = @oldRails
|
14
|
+
|
15
|
+
describe 'when Rails UJS is loaded', ->
|
16
|
+
|
17
|
+
beforeEach ->
|
18
|
+
$.rails = {}
|
19
|
+
|
20
|
+
u.each upAttributes, (upAttribute) ->
|
21
|
+
describe "on an [#{upAttribute}] element", ->
|
22
|
+
|
23
|
+
it "is transformed to an up-method attribute so the element isn't handled a second time by Rails UJS", ->
|
24
|
+
$element = affix("span[#{upAttribute}][data-method=\"put\"]")
|
25
|
+
up.hello($element)
|
26
|
+
expect($element.attr('data-method')).toBeUndefined()
|
27
|
+
expect($element.attr('up-method')).toEqual('put')
|
28
|
+
|
29
|
+
it "does not overwrite an existing up-method attribute, but gets deleted", ->
|
30
|
+
$element = affix("span[#{upAttribute}][up-method=\"patch\"][data-method=\"put\"]")
|
31
|
+
up.hello($element)
|
32
|
+
expect($element.attr('data-method')).toBeUndefined()
|
33
|
+
expect($element.attr('up-method')).toEqual('patch')
|
34
|
+
|
35
|
+
describe 'on an element without Unpoly attributes', ->
|
36
|
+
|
37
|
+
it "is not changed", ->
|
38
|
+
$element = affix("span[data-method=\"put\"]")
|
39
|
+
up.hello($element)
|
40
|
+
expect($element.attr('data-method')).toEqual('put')
|
41
|
+
|
42
|
+
describe 'when Rails UJS is not loaded', ->
|
43
|
+
|
44
|
+
beforeEach ->
|
45
|
+
$.rails = undefined
|
46
|
+
|
47
|
+
u.each upAttributes, (upAttribute) ->
|
48
|
+
describe "on an [#{upAttribute}] element", ->
|
49
|
+
|
50
|
+
it "is not changed", ->
|
51
|
+
$element = affix("span[#{upAttribute}][data-method=\"put\"]")
|
52
|
+
up.hello($element)
|
53
|
+
expect($element.attr('data-method')).toEqual('put')
|
54
|
+
|
55
|
+
describe '[data-confirm]', ->
|
56
|
+
|
57
|
+
beforeEach ->
|
58
|
+
@oldRails = $.rails
|
59
|
+
|
60
|
+
afterEach ->
|
61
|
+
$.rails = @oldRails
|
62
|
+
|
63
|
+
describe 'when Rails UJS is loaded', ->
|
64
|
+
|
65
|
+
beforeEach ->
|
66
|
+
$.rails = {}
|
67
|
+
|
68
|
+
u.each upAttributes, (upAttribute) ->
|
69
|
+
describe "on an [#{upAttribute}] element", ->
|
70
|
+
|
71
|
+
it "is transformed to an up-confirm attribute so the element isn't handled a second time by Rails UJS", ->
|
72
|
+
$element = affix("span[#{upAttribute}][data-confirm=\"Really?\"]")
|
73
|
+
up.hello($element)
|
74
|
+
expect($element.attr('data-confirm')).toBeUndefined()
|
75
|
+
expect($element.attr('up-confirm')).toEqual('Really?')
|
76
|
+
|
77
|
+
it "does not overwrite an existing up-confirm attribute, but gets deleted", ->
|
78
|
+
$element = affix("span[#{upAttribute}][up-confirm=\"Seriously?\"][data-confirm=\"Really?\"]")
|
79
|
+
up.hello($element)
|
80
|
+
expect($element.attr('data-confirm')).toBeUndefined()
|
81
|
+
expect($element.attr('up-confirm')).toEqual('Seriously?')
|
82
|
+
|
83
|
+
describe 'on an element without Unpoly attributes', ->
|
84
|
+
|
85
|
+
it "is not changed", ->
|
86
|
+
$element = affix("span[data-confirm=\"Really?\"]")
|
87
|
+
up.hello($element)
|
88
|
+
expect($element.attr('data-confirm')).toEqual('Really?')
|
89
|
+
|
90
|
+
describe 'when Rails UJS is not loaded', ->
|
91
|
+
|
92
|
+
beforeEach ->
|
93
|
+
$.rails = undefined
|
94
|
+
|
95
|
+
u.each upAttributes, (upAttribute) ->
|
96
|
+
describe "on an [#{upAttribute}] element", ->
|
97
|
+
|
98
|
+
it "is not changed", ->
|
99
|
+
$element = affix("span[#{upAttribute}][data-confirm=\"Really?\"]")
|
100
|
+
up.hello($element)
|
101
|
+
expect($element.attr('data-confirm')).toEqual('Really?')
|
@@ -0,0 +1,99 @@
|
|
1
|
+
describe 'up.syntax', ->
|
2
|
+
|
3
|
+
describe 'Javascript functions', ->
|
4
|
+
|
5
|
+
describe 'up.compiler', ->
|
6
|
+
|
7
|
+
it 'applies an event initializer whenever a matching fragment is inserted', ->
|
8
|
+
|
9
|
+
observeClass = jasmine.createSpy()
|
10
|
+
up.compiler '.child', ($element) ->
|
11
|
+
observeClass($element.attr('class'))
|
12
|
+
|
13
|
+
up.hello(affix('.container .child'))
|
14
|
+
|
15
|
+
expect(observeClass).not.toHaveBeenCalledWith('container')
|
16
|
+
expect(observeClass).toHaveBeenCalledWith('child')
|
17
|
+
|
18
|
+
|
19
|
+
destructor = jasmine.createSpy()
|
20
|
+
up.compiler '.child', ($element) ->
|
21
|
+
destructor
|
22
|
+
|
23
|
+
up.hello(affix('.container .child'))
|
24
|
+
expect(destructor).not.toHaveBeenCalled()
|
25
|
+
|
26
|
+
up.destroy('.container')
|
27
|
+
expect(destructor).toHaveBeenCalled()
|
28
|
+
|
29
|
+
it 'parses an up-data attribute as JSON and passes the parsed object as a second argument to the initializer', ->
|
30
|
+
|
31
|
+
observeArgs = jasmine.createSpy()
|
32
|
+
up.compiler '.child', ($element, data) ->
|
33
|
+
observeArgs($element.attr('class'), data)
|
34
|
+
|
35
|
+
data = { key1: 'value1', key2: 'value2' }
|
36
|
+
|
37
|
+
$tag = affix(".child").attr('up-data', JSON.stringify(data))
|
38
|
+
up.hello($tag)
|
39
|
+
|
40
|
+
expect(observeArgs).toHaveBeenCalledWith('child', data)
|
41
|
+
|
42
|
+
it 'passes an empty object as a second argument to the initializer if there is no up-data attribute', ->
|
43
|
+
|
44
|
+
observeArgs = jasmine.createSpy()
|
45
|
+
up.compiler '.child', ($element, data) ->
|
46
|
+
observeArgs($element.attr('class'), data)
|
47
|
+
|
48
|
+
up.hello(affix(".child"))
|
49
|
+
|
50
|
+
expect(observeArgs).toHaveBeenCalledWith('child', {})
|
51
|
+
|
52
|
+
it 'compiles matching elements one-by-one', ->
|
53
|
+
compiler = jasmine.createSpy('compiler')
|
54
|
+
up.compiler '.foo', ($element) -> compiler($element)
|
55
|
+
$container = affix('.container')
|
56
|
+
$first = $container.affix('.foo.first')
|
57
|
+
$second = $container.affix('.foo.second')
|
58
|
+
up.hello($container)
|
59
|
+
expect(compiler.calls.count()).toEqual(2)
|
60
|
+
expect(compiler).toHaveBeenCalledWith($first)
|
61
|
+
expect(compiler).toHaveBeenCalledWith($second)
|
62
|
+
|
63
|
+
describe 'with { batch } option', ->
|
64
|
+
|
65
|
+
it 'compiles all matching elements at once', ->
|
66
|
+
compiler = jasmine.createSpy('compiler')
|
67
|
+
up.compiler '.foo', { batch: true }, ($element) -> compiler($element)
|
68
|
+
$container = affix('.container')
|
69
|
+
$first = $container.affix('.foo.first')
|
70
|
+
$second = $container.affix('.foo.second')
|
71
|
+
$both = $first.add($second)
|
72
|
+
up.hello($container)
|
73
|
+
expect(compiler.calls.count()).toEqual(1)
|
74
|
+
expect(compiler).toHaveBeenCalledWith($both)
|
75
|
+
|
76
|
+
describe 'with { keep } option', ->
|
77
|
+
|
78
|
+
it 'adds an up-keep attribute to the fragment during compilation', ->
|
79
|
+
|
80
|
+
up.compiler '.foo', { keep: true }, ->
|
81
|
+
up.compiler '.bar', { }, ->
|
82
|
+
up.compiler '.bar', { keep: false }, ->
|
83
|
+
up.compiler '.bam', { keep: '.partner' }, ->
|
84
|
+
|
85
|
+
$foo = up.hello(affix('.foo'))
|
86
|
+
$bar = up.hello(affix('.bar'))
|
87
|
+
$baz = up.hello(affix('.baz'))
|
88
|
+
$bam = up.hello(affix('.bam'))
|
89
|
+
|
90
|
+
expect($foo.attr('up-keep')).toEqual('')
|
91
|
+
expect($bar.attr('up-keep')).toBeMissing()
|
92
|
+
expect($baz.attr('up-keep')).toBeMissing()
|
93
|
+
expect($bam.attr('up-keep')).toEqual('.partner')
|
94
|
+
|
95
|
+
describe 'up.hello', ->
|
96
|
+
|
97
|
+
it 'should have tests'
|
98
|
+
|
99
|
+
|
@@ -0,0 +1,60 @@
|
|
1
|
+
describe 'up.tooltip', ->
|
2
|
+
|
3
|
+
describe 'Javascript functions', ->
|
4
|
+
|
5
|
+
describe 'up.tooltip.attach', ->
|
6
|
+
|
7
|
+
it 'opens a tooltop above the center of the given element', ->
|
8
|
+
$link = affix('span').text('button label')
|
9
|
+
$link.css(
|
10
|
+
position: 'absolute'
|
11
|
+
left: '200px'
|
12
|
+
top: '200px'
|
13
|
+
width: '50px'
|
14
|
+
height: '50px'
|
15
|
+
)
|
16
|
+
up.tooltip.attach($link, html: 'tooltip text')
|
17
|
+
$tooltip = $('.up-tooltip')
|
18
|
+
expect($tooltip).toBeInDOM()
|
19
|
+
expect($tooltip).toHaveText('tooltip text')
|
20
|
+
tooltipBox = up.util.measure($tooltip, relative: true)
|
21
|
+
linkBox = up.util.measure($link, relative: true)
|
22
|
+
expect(tooltipBox.top).toBeAround(linkBox.top - tooltipBox.height, 15)
|
23
|
+
expect(tooltipBox.left).toBeAround(linkBox.left + 0.5 * (linkBox.width - tooltipBox.width), 15)
|
24
|
+
|
25
|
+
it 'allows HTML for the tooltip text when contents are given as .html option', ->
|
26
|
+
$link = affix('span')
|
27
|
+
up.tooltip.attach($link, html: '<b>text</b>')
|
28
|
+
$tooltip = $('.up-tooltip')
|
29
|
+
expect($tooltip.html()).toEqual('<b>text</b>')
|
30
|
+
|
31
|
+
it 'escapes HTML for the tooltip text when contents given as .html option', ->
|
32
|
+
$link = affix('span')
|
33
|
+
up.tooltip.attach($link, text: '<b>text</b>')
|
34
|
+
$tooltip = $('.up-tooltip')
|
35
|
+
expect($tooltip.html()).toEqual('<b>text</b>')
|
36
|
+
|
37
|
+
it 'closes an existing tooltip'
|
38
|
+
|
39
|
+
describe 'with position option', ->
|
40
|
+
|
41
|
+
it 'anchors the tooltip at a different edge of the element'
|
42
|
+
|
43
|
+
describe 'up.tooltip.close', ->
|
44
|
+
|
45
|
+
it 'should have tests'
|
46
|
+
|
47
|
+
describe 'unobtrusive behavior', ->
|
48
|
+
|
49
|
+
describe '[up-tooltip]', ->
|
50
|
+
|
51
|
+
it 'should have tests'
|
52
|
+
|
53
|
+
describe '[up-tooltip-html]', ->
|
54
|
+
|
55
|
+
it 'should have tests'
|
56
|
+
|
57
|
+
describe 'body', ->
|
58
|
+
|
59
|
+
it 'closes a tooltip when clicked'
|
60
|
+
|
@@ -0,0 +1,325 @@
|
|
1
|
+
describe 'up.util', ->
|
2
|
+
|
3
|
+
describe 'Javascript functions', ->
|
4
|
+
|
5
|
+
# describe 'up.util.argNames', ->
|
6
|
+
#
|
7
|
+
# it 'returns an array of argument names for the given function', ->
|
8
|
+
# fun = ($element, data) ->
|
9
|
+
# expect(up.util.argNames(fun)).toEqual(['$element', 'data'])
|
10
|
+
|
11
|
+
describe 'up.util.only', ->
|
12
|
+
|
13
|
+
it 'returns a copy of the given object with only the given whitelisted properties', ->
|
14
|
+
original =
|
15
|
+
foo: 'foo-value'
|
16
|
+
bar: 'bar-value'
|
17
|
+
baz: 'baz-value'
|
18
|
+
bam: 'bam-value'
|
19
|
+
whitelisted = up.util.only(original, 'bar', 'bam')
|
20
|
+
expect(whitelisted).toEqual
|
21
|
+
bar: 'bar-value'
|
22
|
+
bam: 'bam-value'
|
23
|
+
# Show that original did not change
|
24
|
+
expect(original).toEqual
|
25
|
+
foo: 'foo-value'
|
26
|
+
bar: 'bar-value'
|
27
|
+
baz: 'baz-value'
|
28
|
+
bam: 'bam-value'
|
29
|
+
|
30
|
+
describe 'up.util.except', ->
|
31
|
+
|
32
|
+
it 'returns a copy of the given object but omits the given blacklisted properties', ->
|
33
|
+
original =
|
34
|
+
foo: 'foo-value'
|
35
|
+
bar: 'bar-value'
|
36
|
+
baz: 'baz-value'
|
37
|
+
bam: 'bam-value'
|
38
|
+
whitelisted = up.util.except(original, 'foo', 'baz')
|
39
|
+
expect(whitelisted).toEqual
|
40
|
+
bar: 'bar-value'
|
41
|
+
bam: 'bam-value'
|
42
|
+
# Show that original did not change
|
43
|
+
expect(original).toEqual
|
44
|
+
foo: 'foo-value'
|
45
|
+
bar: 'bar-value'
|
46
|
+
baz: 'baz-value'
|
47
|
+
bam: 'bam-value'
|
48
|
+
|
49
|
+
describe 'up.util.selectorForElement', ->
|
50
|
+
|
51
|
+
it "prefers using the element's 'up-id' attribute to using the element's ID", ->
|
52
|
+
$element = affix('div[up-id=up-id-value]#id-value')
|
53
|
+
expect(up.util.selectorForElement($element)).toBe("[up-id='up-id-value']")
|
54
|
+
|
55
|
+
it "prefers using the element's ID to using the element's name", ->
|
56
|
+
$element = affix('div#id-value[name=name-value]')
|
57
|
+
expect(up.util.selectorForElement($element)).toBe("#id-value")
|
58
|
+
|
59
|
+
it "prefers using the element's name to using the element's classes", ->
|
60
|
+
$element = affix('div[name=name-value].class1.class2')
|
61
|
+
expect(up.util.selectorForElement($element)).toBe("[name='name-value']")
|
62
|
+
|
63
|
+
it "prefers using the element's classes to using the element's tag name", ->
|
64
|
+
$element = affix('div.class1.class2')
|
65
|
+
expect(up.util.selectorForElement($element)).toBe(".class1.class2")
|
66
|
+
|
67
|
+
it "uses the element's tag name if no better description is available", ->
|
68
|
+
$element = affix('div')
|
69
|
+
expect(up.util.selectorForElement($element)).toBe("div")
|
70
|
+
|
71
|
+
|
72
|
+
describe 'up.util.castedAttr', ->
|
73
|
+
|
74
|
+
it 'returns true if the attribute value is the string "true"', ->
|
75
|
+
$element = affix('div').attr('foo', 'true')
|
76
|
+
expect(up.util.castedAttr($element, 'foo')).toBe(true)
|
77
|
+
|
78
|
+
it 'returns false if the attribute value is the string "false"', ->
|
79
|
+
$element = affix('div').attr('foo', 'false')
|
80
|
+
expect(up.util.castedAttr($element, 'foo')).toBe(false)
|
81
|
+
|
82
|
+
it 'returns undefined if the element has no such attribute', ->
|
83
|
+
$element = affix('div')
|
84
|
+
expect(up.util.castedAttr($element, 'foo')).toBe(undefined)
|
85
|
+
|
86
|
+
it 'returns the attribute value unchanged if the value is some string', ->
|
87
|
+
$element = affix('div').attr('foo', 'some text')
|
88
|
+
expect(up.util.castedAttr($element, 'foo')).toBe('some text')
|
89
|
+
|
90
|
+
describe 'up.util.any', ->
|
91
|
+
|
92
|
+
it 'returns true if an element in the array returns true for the given function', ->
|
93
|
+
result = up.util.any [null, undefined, 'foo', ''], up.util.isPresent
|
94
|
+
expect(result).toBe(true)
|
95
|
+
|
96
|
+
it 'returns false if no element in the array returns true for the given function', ->
|
97
|
+
result = up.util.any [null, undefined, ''], up.util.isPresent
|
98
|
+
expect(result).toBe(false)
|
99
|
+
|
100
|
+
it 'short-circuits once an element returns true', ->
|
101
|
+
count = 0
|
102
|
+
up.util.any [null, undefined, 'foo', ''], (element) ->
|
103
|
+
count += 1
|
104
|
+
up.util.isPresent(element)
|
105
|
+
expect(count).toBe(3)
|
106
|
+
|
107
|
+
describe 'up.util.all', ->
|
108
|
+
|
109
|
+
it 'returns true if all element in the array returns true for the given function', ->
|
110
|
+
result = up.util.all ['foo', 'bar', 'baz'], up.util.isPresent
|
111
|
+
expect(result).toBe(true)
|
112
|
+
|
113
|
+
it 'returns false if an element in the array returns false for the given function', ->
|
114
|
+
result = up.util.all ['foo', 'bar', null, 'baz'], up.util.isPresent
|
115
|
+
expect(result).toBe(false)
|
116
|
+
|
117
|
+
it 'short-circuits once an element returns false', ->
|
118
|
+
count = 0
|
119
|
+
up.util.all ['foo', 'bar', '', 'baz'], (element) ->
|
120
|
+
count += 1
|
121
|
+
up.util.isPresent(element)
|
122
|
+
expect(count).toBe(3)
|
123
|
+
|
124
|
+
describe 'up.util.isBlank', ->
|
125
|
+
|
126
|
+
it 'returns false for false', ->
|
127
|
+
expect(up.util.isBlank(false)).toBe(false)
|
128
|
+
|
129
|
+
it 'returns false for true', ->
|
130
|
+
expect(up.util.isBlank(true)).toBe(false)
|
131
|
+
|
132
|
+
it 'returns true for null', ->
|
133
|
+
expect(up.util.isBlank(null)).toBe(true)
|
134
|
+
|
135
|
+
it 'returns true for undefined', ->
|
136
|
+
expect(up.util.isBlank(undefined)).toBe(true)
|
137
|
+
|
138
|
+
it 'returns true for an empty String', ->
|
139
|
+
expect(up.util.isBlank('')).toBe(true)
|
140
|
+
|
141
|
+
it 'returns false for a String with at least one character', ->
|
142
|
+
expect(up.util.isBlank('string')).toBe(false)
|
143
|
+
|
144
|
+
it 'returns true for an empty array', ->
|
145
|
+
expect(up.util.isBlank([])).toBe(true)
|
146
|
+
|
147
|
+
it 'returns false for an array with at least one element', ->
|
148
|
+
expect(up.util.isBlank(['element'])).toBe(false)
|
149
|
+
|
150
|
+
it 'returns true for an empty object', ->
|
151
|
+
expect(up.util.isBlank({})).toBe(true)
|
152
|
+
|
153
|
+
it 'returns true for an object with at least one key', ->
|
154
|
+
expect(up.util.isBlank({key: 'value'})).toBe(false)
|
155
|
+
|
156
|
+
describe 'up.util.normalizeUrl', ->
|
157
|
+
|
158
|
+
it 'normalizes a relative path', ->
|
159
|
+
expect(up.util.normalizeUrl('foo')).toBe("http://#{location.hostname}:#{location.port}/foo")
|
160
|
+
|
161
|
+
it 'normalizes an absolute path', ->
|
162
|
+
expect(up.util.normalizeUrl('/foo')).toBe("http://#{location.hostname}:#{location.port}/foo")
|
163
|
+
|
164
|
+
it 'normalizes a full URL', ->
|
165
|
+
expect(up.util.normalizeUrl('http://example.com/foo/bar')).toBe('http://example.com/foo/bar')
|
166
|
+
|
167
|
+
describe 'up.util.detect', ->
|
168
|
+
|
169
|
+
it 'finds the first element in the given array that matches the given tester', ->
|
170
|
+
array = ['foo', 'bar', 'baz']
|
171
|
+
tester = (element) -> element[0] == 'b'
|
172
|
+
expect(up.util.detect(array, tester)).toEqual('bar')
|
173
|
+
|
174
|
+
it "returns undefined if the given array doesn't contain a matching element", ->
|
175
|
+
array = ['foo', 'bar', 'baz']
|
176
|
+
tester = (element) -> element[0] == 'z'
|
177
|
+
expect(up.util.detect(array, tester)).toBeUndefined()
|
178
|
+
|
179
|
+
describe 'up.util.config', ->
|
180
|
+
|
181
|
+
it 'creates an object with the given attributes', ->
|
182
|
+
object = up.util.config(a: 1, b: 2)
|
183
|
+
expect(object.a).toBe(1)
|
184
|
+
expect(object.b).toBe(2)
|
185
|
+
|
186
|
+
it 'does not allow to set a key that was not included in the factory settings', ->
|
187
|
+
object = up.util.config(a: 1)
|
188
|
+
object.b = 2
|
189
|
+
expect(object.b).toBeUndefined()
|
190
|
+
|
191
|
+
describe '#reset', ->
|
192
|
+
|
193
|
+
it 'resets the object to its original state', ->
|
194
|
+
object = up.util.config(a: 1)
|
195
|
+
expect(object.b).toBeUndefined()
|
196
|
+
object.a = 2
|
197
|
+
expect(object.a).toBe(2)
|
198
|
+
object.reset()
|
199
|
+
expect(object.a).toBe(1)
|
200
|
+
|
201
|
+
it 'does not remove the #reset or #update method from the object', ->
|
202
|
+
object = up.util.config(a: 1)
|
203
|
+
object.b = 2
|
204
|
+
object.reset()
|
205
|
+
expect(object.reset).toBeDefined()
|
206
|
+
|
207
|
+
describe 'up.util.requestDataAsQuery', ->
|
208
|
+
|
209
|
+
encodedOpeningBracket = '%5B'
|
210
|
+
encodedClosingBracket = '%5D'
|
211
|
+
encodedSpace = '%20'
|
212
|
+
|
213
|
+
it 'returns the query section for the given object', ->
|
214
|
+
string = up.util.requestDataAsQuery('foo-key': 'foo value', 'bar-key': 'bar value')
|
215
|
+
expect(string).toEqual("foo-key=foo#{encodedSpace}value&bar-key=bar#{encodedSpace}value")
|
216
|
+
|
217
|
+
it 'returns the query section for the given nested object', ->
|
218
|
+
string = up.util.requestDataAsQuery('foo-key': { 'bar-key': 'bar-value' }, 'bam-key': 'bam-value')
|
219
|
+
expect(string).toEqual("foo-key#{encodedOpeningBracket}bar-key#{encodedClosingBracket}=bar-value&bam-key=bam-value")
|
220
|
+
|
221
|
+
it 'returns the query section for the given array with { name } and { value } keys', ->
|
222
|
+
string = up.util.requestDataAsQuery([
|
223
|
+
{ name: 'foo-key', value: 'foo value' },
|
224
|
+
{ name: 'bar-key', value: 'bar value' }
|
225
|
+
])
|
226
|
+
expect(string).toEqual("foo-key=foo#{encodedSpace}value&bar-key=bar#{encodedSpace}value")
|
227
|
+
|
228
|
+
it 'returns an empty string for an empty object', ->
|
229
|
+
string = up.util.requestDataAsQuery({})
|
230
|
+
expect(string).toEqual('')
|
231
|
+
|
232
|
+
it 'returns an empty string for an empty string', ->
|
233
|
+
string = up.util.requestDataAsQuery('')
|
234
|
+
expect(string).toEqual('')
|
235
|
+
|
236
|
+
it 'returns an empty string for undefined', ->
|
237
|
+
string = up.util.requestDataAsQuery(undefined)
|
238
|
+
expect(string).toEqual('')
|
239
|
+
|
240
|
+
it 'URL-encodes characters in the key and value', ->
|
241
|
+
string = up.util.requestDataAsQuery({ 'äpfel': 'bäume' })
|
242
|
+
expect(string).toEqual('%C3%A4pfel=b%C3%A4ume')
|
243
|
+
|
244
|
+
it 'URL-encodes plus characters', ->
|
245
|
+
string = up.util.requestDataAsQuery({ 'my+key': 'my+value' })
|
246
|
+
expect(string).toEqual('my%2Bkey=my%2Bvalue')
|
247
|
+
|
248
|
+
|
249
|
+
describe 'up.util.requestDataAsArray', ->
|
250
|
+
|
251
|
+
it 'normalized null to an empty array', ->
|
252
|
+
array = up.util.requestDataAsArray(null)
|
253
|
+
expect(array).toEqual([])
|
254
|
+
|
255
|
+
it 'normalized undefined to an empty array', ->
|
256
|
+
array = up.util.requestDataAsArray(undefined)
|
257
|
+
expect(array).toEqual([])
|
258
|
+
|
259
|
+
it 'normalizes an object hash to an array of objects with { name } and { value } keys', ->
|
260
|
+
array = up.util.requestDataAsArray(
|
261
|
+
'foo-key': 'foo-value'
|
262
|
+
'bar-key': 'bar-value'
|
263
|
+
)
|
264
|
+
expect(array).toEqual([
|
265
|
+
{ name: 'foo-key', value: 'foo-value' },
|
266
|
+
{ name: 'bar-key', value: 'bar-value' },
|
267
|
+
])
|
268
|
+
|
269
|
+
it 'normalizes a nested object hash to a flat array using param naming conventions', ->
|
270
|
+
array = up.util.requestDataAsArray(
|
271
|
+
'foo-key': 'foo-value'
|
272
|
+
'bar-key': {
|
273
|
+
'bam-key': 'bam-value'
|
274
|
+
'baz-key': {
|
275
|
+
'qux-key': 'qux-value'
|
276
|
+
}
|
277
|
+
}
|
278
|
+
)
|
279
|
+
expect(array).toEqual([
|
280
|
+
{ name: 'foo-key', value: 'foo-value' },
|
281
|
+
{ name: 'bar-key[bam-key]', value: 'bam-value' },
|
282
|
+
{ name: 'bar-key[baz-key][qux-key]', value: 'qux-value' },
|
283
|
+
])
|
284
|
+
|
285
|
+
it 'returns a given array without modification', ->
|
286
|
+
array = up.util.requestDataAsArray([
|
287
|
+
{ name: 'foo-key', value: 'foo-value' },
|
288
|
+
{ name: 'bar-key', value: 'bar-value' },
|
289
|
+
])
|
290
|
+
expect(array).toEqual([
|
291
|
+
{ name: 'foo-key', value: 'foo-value' },
|
292
|
+
{ name: 'bar-key', value: 'bar-value' },
|
293
|
+
])
|
294
|
+
|
295
|
+
it 'does not URL-encode special characters keys or values', ->
|
296
|
+
array = up.util.requestDataAsArray(
|
297
|
+
'äpfel': { 'bäume': 'börse' }
|
298
|
+
)
|
299
|
+
expect(array).toEqual([
|
300
|
+
{ name: 'äpfel[bäume]', value: 'börse' },
|
301
|
+
])
|
302
|
+
|
303
|
+
it 'does not URL-encode spaces in keys or values', ->
|
304
|
+
array = up.util.requestDataAsArray(
|
305
|
+
'my key': 'my value'
|
306
|
+
)
|
307
|
+
expect(array).toEqual([
|
308
|
+
{ name: 'my key', value: 'my value' },
|
309
|
+
])
|
310
|
+
|
311
|
+
it 'does not URL-encode ampersands in keys or values', ->
|
312
|
+
array = up.util.requestDataAsArray(
|
313
|
+
'my&key': 'my&value'
|
314
|
+
)
|
315
|
+
expect(array).toEqual([
|
316
|
+
{ name: 'my&key', value: 'my&value' },
|
317
|
+
])
|
318
|
+
|
319
|
+
it 'does not URL-encode equal signs in keys or values', ->
|
320
|
+
array = up.util.requestDataAsArray(
|
321
|
+
'my=key': 'my=value'
|
322
|
+
)
|
323
|
+
expect(array).toEqual([
|
324
|
+
{ name: 'my=key', value: 'my=value' },
|
325
|
+
])
|