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,96 @@
|
|
1
|
+
describe 'up.history', ->
|
2
|
+
|
3
|
+
describe 'Javascript functions', ->
|
4
|
+
|
5
|
+
describe 'up.history.replace', ->
|
6
|
+
|
7
|
+
it 'should have tests'
|
8
|
+
|
9
|
+
describe 'up.history.push', ->
|
10
|
+
|
11
|
+
it 'should have tests'
|
12
|
+
|
13
|
+
describe 'unobtrusive behavior', ->
|
14
|
+
|
15
|
+
describe '[up-back]', ->
|
16
|
+
|
17
|
+
describeCapability 'canPushState', ->
|
18
|
+
|
19
|
+
it 'sets an [up-href] attribute to the previous URL and sets the up-restore-scroll attribute to "true"', ->
|
20
|
+
up.history.push('/one')
|
21
|
+
up.history.push('/two')
|
22
|
+
$element = up.hello(affix('a[href="/three"][up-back]').text('text'))
|
23
|
+
expect($element.attr('href')).toEndWith('/three')
|
24
|
+
expect($element.attr('up-href')).toEndWith('/one')
|
25
|
+
expect($element.attr('up-restore-scroll')).toBe('')
|
26
|
+
expect($element.attr('up-follow')).toBe('')
|
27
|
+
|
28
|
+
it 'does not overwrite an existing up-href or up-restore-scroll attribute'
|
29
|
+
|
30
|
+
it 'does not set an up-href attribute if there is no previous URL'
|
31
|
+
|
32
|
+
describeFallback 'canPushState', ->
|
33
|
+
|
34
|
+
it 'does not change the element', ->
|
35
|
+
$element = up.hello(affix('a[href="/three"][up-back]').text('text'))
|
36
|
+
expect($element.attr('up-href')).toBeUndefined()
|
37
|
+
|
38
|
+
describe 'scroll restauration', ->
|
39
|
+
|
40
|
+
describeCapability 'canPushState', ->
|
41
|
+
|
42
|
+
afterEach ->
|
43
|
+
$('.viewport').remove()
|
44
|
+
|
45
|
+
it 'restores the scroll position of viewports when the user hits the back button', (done) ->
|
46
|
+
|
47
|
+
longContentHtml = """
|
48
|
+
<div class="viewport" style="width: 100px; height: 100px; overflow-y: scroll">
|
49
|
+
<div class="content" style="height: 1000px"></div>
|
50
|
+
</div>
|
51
|
+
"""
|
52
|
+
|
53
|
+
respond = => @respondWith(longContentHtml)
|
54
|
+
|
55
|
+
$viewport = $(longContentHtml).appendTo(document.body)
|
56
|
+
|
57
|
+
up.layout.config.viewports = ['.viewport']
|
58
|
+
up.history.config.popTargets = ['.viewport']
|
59
|
+
|
60
|
+
$viewport.append(longContentHtml)
|
61
|
+
|
62
|
+
up.replace('.content', '/one')
|
63
|
+
respond()
|
64
|
+
|
65
|
+
$viewport.scrollTop(50)
|
66
|
+
|
67
|
+
up.replace('.content', '/two')
|
68
|
+
respond()
|
69
|
+
|
70
|
+
$('.viewport').scrollTop(150)
|
71
|
+
|
72
|
+
up.replace('.content', '/three')
|
73
|
+
respond()
|
74
|
+
$('.viewport').scrollTop(250)
|
75
|
+
|
76
|
+
history.back()
|
77
|
+
@setTimer 50, =>
|
78
|
+
respond() # we need to respond since we've never requested /two with the popTarget
|
79
|
+
expect($('.viewport').scrollTop()).toBe(150)
|
80
|
+
|
81
|
+
history.back()
|
82
|
+
@setTimer 50, =>
|
83
|
+
respond() # we need to respond since we've never requested /one with the popTarget
|
84
|
+
expect($('.viewport').scrollTop()).toBe(50)
|
85
|
+
|
86
|
+
history.forward()
|
87
|
+
@setTimer 50, =>
|
88
|
+
# No need to respond since we requested /two with the popTarget
|
89
|
+
# when we went backwards
|
90
|
+
expect($('.viewport').scrollTop()).toBe(150)
|
91
|
+
|
92
|
+
history.forward()
|
93
|
+
@setTimer 50, =>
|
94
|
+
respond() # we need to respond since we've never requested /three with the popTarget
|
95
|
+
expect($('.viewport').scrollTop()).toBe(250)
|
96
|
+
done()
|
@@ -0,0 +1,318 @@
|
|
1
|
+
describe 'up.layout', ->
|
2
|
+
|
3
|
+
u = up.util
|
4
|
+
|
5
|
+
describe 'Javascript functions', ->
|
6
|
+
|
7
|
+
describe 'up.reveal', ->
|
8
|
+
|
9
|
+
beforeEach ->
|
10
|
+
up.layout.config.snap = 0
|
11
|
+
up.layout.config.substance = 99999
|
12
|
+
up.layout.config.viewports = [document]
|
13
|
+
|
14
|
+
describe 'when the viewport is the document', ->
|
15
|
+
|
16
|
+
beforeEach ->
|
17
|
+
$body = $('body')
|
18
|
+
|
19
|
+
@$elements = []
|
20
|
+
@$container = $('<div class="container">').prependTo($body)
|
21
|
+
|
22
|
+
@clientHeight = u.clientSize().height
|
23
|
+
|
24
|
+
for height in [@clientHeight, '50px', '5000px']
|
25
|
+
$element = $('<div>').css(height: height)
|
26
|
+
$element.appendTo(@$container)
|
27
|
+
@$elements.push($element)
|
28
|
+
|
29
|
+
afterEach ->
|
30
|
+
@$container.remove()
|
31
|
+
|
32
|
+
it 'reveals the given element', ->
|
33
|
+
up.reveal(@$elements[0])
|
34
|
+
# ---------------------
|
35
|
+
# [0] 0 .......... ch-1
|
36
|
+
# ---------------------
|
37
|
+
# [1] ch+0 ...... ch+49
|
38
|
+
# [2] ch+50 ... ch+5049
|
39
|
+
expect($(document).scrollTop()).toBe(0)
|
40
|
+
|
41
|
+
up.reveal(@$elements[1])
|
42
|
+
# ---------------------
|
43
|
+
# [0] 0 .......... ch-1
|
44
|
+
# [1] ch+0 ...... ch+49
|
45
|
+
# ---------------------
|
46
|
+
# [2] ch+50 ... ch+5049
|
47
|
+
expect($(document).scrollTop()).toBe(50)
|
48
|
+
|
49
|
+
up.reveal(@$elements[2])
|
50
|
+
# [0] 0 .......... ch-1
|
51
|
+
# [1] ch+0 ...... ch+49
|
52
|
+
# ---------------------
|
53
|
+
# [2] ch+50 ... ch+5049
|
54
|
+
# ---------------------
|
55
|
+
expect($(document).scrollTop()).toBe(@clientHeight + 50)
|
56
|
+
|
57
|
+
it 'snaps to the top if the space above the future-visible area is smaller than the value of config.snap', ->
|
58
|
+
|
59
|
+
up.layout.config.snap = 30
|
60
|
+
|
61
|
+
@$elements[0].css(height: '20px')
|
62
|
+
|
63
|
+
up.reveal(@$elements[2])
|
64
|
+
# [0] 0 ............ 19
|
65
|
+
# [1] 20 ........... 69
|
66
|
+
# ---------------------
|
67
|
+
# [2] 70 ......... 5069
|
68
|
+
# ---------------------
|
69
|
+
expect($(document).scrollTop()).toBe(70)
|
70
|
+
|
71
|
+
# Even though we're revealing the second element, the viewport
|
72
|
+
# snaps to the top edge.
|
73
|
+
up.reveal(@$elements[1])
|
74
|
+
# ---------------------
|
75
|
+
# [0] 0 ............ 19
|
76
|
+
# [1] 20 ........... 69
|
77
|
+
# ---------------------
|
78
|
+
# [2] 70 ......... 5069
|
79
|
+
expect($(document).scrollTop()).toBe(0)
|
80
|
+
|
81
|
+
it 'scrolls far enough so the element is not obstructed by an element fixed to the top', ->
|
82
|
+
$topNav = affix('[up-fixed=top]').css(
|
83
|
+
position: 'fixed',
|
84
|
+
top: '0',
|
85
|
+
left: '0',
|
86
|
+
right: '0'
|
87
|
+
height: '100px'
|
88
|
+
)
|
89
|
+
|
90
|
+
up.reveal(@$elements[0], viewport: @viewport)
|
91
|
+
# ---------------------
|
92
|
+
# [F] 0 ............ 99
|
93
|
+
# [0] 0 .......... ch-1
|
94
|
+
# ---------------------
|
95
|
+
# [1] ch+0 ...... ch+49
|
96
|
+
# [2] ch+50 ... ch+5049
|
97
|
+
expect($(document).scrollTop()).toBe(0) # would need to be -100
|
98
|
+
|
99
|
+
up.reveal(@$elements[1])
|
100
|
+
# ---------------------
|
101
|
+
# [F] 0 ............ 99
|
102
|
+
# [0] 00000 ...... ch-1
|
103
|
+
# [1] ch+0 ...... ch+49
|
104
|
+
# ---------------------
|
105
|
+
# [2] ch+50 ... ch+5049
|
106
|
+
|
107
|
+
expect($(document).scrollTop()).toBe(50)
|
108
|
+
|
109
|
+
up.reveal(@$elements[2])
|
110
|
+
# [0] 00000 ...... ch-1
|
111
|
+
# [1] ch+0 ...... ch+49
|
112
|
+
# ---------------------
|
113
|
+
# [F] 0 ............ 99
|
114
|
+
# [2] ch+50 ... ch+5049
|
115
|
+
# ----------------
|
116
|
+
expect($(document).scrollTop()).toBe(@clientHeight + 50 - 100)
|
117
|
+
|
118
|
+
up.reveal(@$elements[1])
|
119
|
+
# [0] 00000 ...... ch-1
|
120
|
+
# ---------------------
|
121
|
+
# [F] 0 ............ 99
|
122
|
+
# [1] ch+0 ...... ch+49
|
123
|
+
# [2] ch+50 ... ch+5049
|
124
|
+
# ----------------
|
125
|
+
expect($(document).scrollTop()).toBe(@clientHeight + 50 - 100 - 50)
|
126
|
+
|
127
|
+
|
128
|
+
it 'scrolls far enough so the element is not obstructed by an element fixed to the bottom', ->
|
129
|
+
$bottomNav = affix('[up-fixed=bottom]').css(
|
130
|
+
position: 'fixed',
|
131
|
+
bottom: '0',
|
132
|
+
left: '0',
|
133
|
+
right: '0'
|
134
|
+
height: '100px'
|
135
|
+
)
|
136
|
+
|
137
|
+
up.reveal(@$elements[0])
|
138
|
+
# ---------------------
|
139
|
+
# [0] 0 .......... ch-1
|
140
|
+
# [F] 0 ............ 99
|
141
|
+
# ---------------------
|
142
|
+
# [1] ch+0 ...... ch+49
|
143
|
+
# [2] ch+50 ... ch+5049
|
144
|
+
expect($(document).scrollTop()).toBe(0)
|
145
|
+
|
146
|
+
up.reveal(@$elements[1])
|
147
|
+
# ---------------------
|
148
|
+
# [0] 0 .......... ch-1
|
149
|
+
# [1] ch+0 ...... ch+49
|
150
|
+
# [F] 0 ............ 99
|
151
|
+
# ---------------------
|
152
|
+
# [2] ch+50 ... ch+5049
|
153
|
+
expect($(document).scrollTop()).toBe(150)
|
154
|
+
|
155
|
+
up.reveal(@$elements[2])
|
156
|
+
# ---------------------
|
157
|
+
# [0] 0 .......... ch-1
|
158
|
+
# [1] ch+0 ...... ch+49
|
159
|
+
# ---------------------
|
160
|
+
# [2] ch+50 ... ch+5049
|
161
|
+
# [F] 0 ............ 99
|
162
|
+
expect($(document).scrollTop()).toBe(@clientHeight + 50)
|
163
|
+
|
164
|
+
|
165
|
+
describe 'when the viewport is a container with overflow-y: scroll', ->
|
166
|
+
|
167
|
+
it 'reveals the given element', ->
|
168
|
+
$viewport = affix('div').css
|
169
|
+
'position': 'absolute'
|
170
|
+
'top': '50px'
|
171
|
+
'left': '50px'
|
172
|
+
'width': '100px'
|
173
|
+
'height': '100px'
|
174
|
+
'overflow-y': 'scroll'
|
175
|
+
$elements = []
|
176
|
+
u.each [0..5], ->
|
177
|
+
$element = $('<div>').css(height: '50px')
|
178
|
+
$element.appendTo($viewport)
|
179
|
+
$elements.push($element)
|
180
|
+
|
181
|
+
# ------------
|
182
|
+
# [0] 000..049
|
183
|
+
# [1] 050..099
|
184
|
+
# ------------
|
185
|
+
# [2] 100..149
|
186
|
+
# [3] 150..199
|
187
|
+
# [4] 200..249
|
188
|
+
# [5] 250..399
|
189
|
+
expect($viewport.scrollTop()).toBe(0)
|
190
|
+
|
191
|
+
# See that the view only scrolls down as little as possible
|
192
|
+
# in order to reveal the element
|
193
|
+
up.reveal($elements[3], viewport: $viewport)
|
194
|
+
# [0] 000..049
|
195
|
+
# [1] 050..099
|
196
|
+
# ------------
|
197
|
+
# [2] 100..149
|
198
|
+
# [3] 150..199
|
199
|
+
# ------------
|
200
|
+
# [4] 200..249
|
201
|
+
# [5] 250..299
|
202
|
+
expect($viewport.scrollTop()).toBe(100)
|
203
|
+
|
204
|
+
# See that the view doesn't move if the element
|
205
|
+
# is already revealed
|
206
|
+
up.reveal($elements[2], viewport: $viewport)
|
207
|
+
expect($viewport.scrollTop()).toBe(100)
|
208
|
+
|
209
|
+
# See that the view scrolls as far down as it cans
|
210
|
+
# to show the bottom element
|
211
|
+
up.reveal($elements[5], viewport: $viewport)
|
212
|
+
# [0] 000..049
|
213
|
+
# [1] 050..099
|
214
|
+
# [2] 100..149
|
215
|
+
# [3] 150..199
|
216
|
+
# ------------
|
217
|
+
# [4] 200..249
|
218
|
+
# [5] 250..299
|
219
|
+
# ------------
|
220
|
+
expect($viewport.scrollTop()).toBe(200)
|
221
|
+
|
222
|
+
# See that the view only scrolls up as little as possible
|
223
|
+
# in order to reveal the element
|
224
|
+
up.reveal($elements[1], viewport: $viewport)
|
225
|
+
# [0] 000..049
|
226
|
+
# ------------
|
227
|
+
# [1] 050..099
|
228
|
+
# [2] 100..149
|
229
|
+
# ------------
|
230
|
+
# [3] 150..199
|
231
|
+
# [4] 200..249
|
232
|
+
# [5] 250..299
|
233
|
+
expect($viewport.scrollTop()).toBe(50)
|
234
|
+
|
235
|
+
it 'only reveals the top number of pixels defined in config.substance', ->
|
236
|
+
|
237
|
+
up.layout.config.substance = 20
|
238
|
+
|
239
|
+
$viewport = affix('div').css
|
240
|
+
'position': 'absolute'
|
241
|
+
'top': '50px'
|
242
|
+
'left': '50px'
|
243
|
+
'width': '100px'
|
244
|
+
'height': '100px'
|
245
|
+
'overflow-y': 'scroll'
|
246
|
+
$elements = []
|
247
|
+
u.each [0..5], ->
|
248
|
+
$element = $('<div>').css(height: '50px')
|
249
|
+
$element.appendTo($viewport)
|
250
|
+
$elements.push($element)
|
251
|
+
|
252
|
+
# [0] 000..049
|
253
|
+
# [1] 050..099
|
254
|
+
# [2] 100..149
|
255
|
+
# [3] 150..199
|
256
|
+
# [4] 200..249
|
257
|
+
# [5] 250..299
|
258
|
+
|
259
|
+
# Viewing 0 .. 99
|
260
|
+
expect($viewport.scrollTop()).toBe(0)
|
261
|
+
|
262
|
+
# See that the view only scrolls down as little as possible
|
263
|
+
# in order to reveal the first 20 rows of the element
|
264
|
+
up.reveal($elements[3], viewport: $viewport)
|
265
|
+
# Viewing 70 to 169
|
266
|
+
expect($viewport.scrollTop()).toBe(50 + 20)
|
267
|
+
|
268
|
+
# See that the view doesn't move if the element
|
269
|
+
# is already revealed
|
270
|
+
up.reveal($elements[2], viewport: $viewport)
|
271
|
+
expect($viewport.scrollTop()).toBe(50 + 20)
|
272
|
+
|
273
|
+
# See that the view scrolls as far down as it cans
|
274
|
+
# to show the first 20 rows of the bottom element
|
275
|
+
up.reveal($elements[5], viewport: $viewport)
|
276
|
+
# Viewing 170 to 269
|
277
|
+
expect($viewport.scrollTop()).toBe(150 + 20)
|
278
|
+
|
279
|
+
# See that the view only scrolls up as little as possible
|
280
|
+
# in order to reveal the first 20 rows element
|
281
|
+
up.reveal($elements[2], viewport: $viewport)
|
282
|
+
# Viewing 100 to 199
|
283
|
+
expect($viewport.scrollTop()).toBe(100)
|
284
|
+
|
285
|
+
describe 'up.layout.viewportsWithin', ->
|
286
|
+
|
287
|
+
it 'should have tests'
|
288
|
+
|
289
|
+
describe 'up.layout.viewportsOf', ->
|
290
|
+
|
291
|
+
it 'seeks upwards from the given element', ->
|
292
|
+
up.layout.config.viewports = ['.viewport1', '.viewport2']
|
293
|
+
$viewport1 = affix('.viewport1')
|
294
|
+
$viewport2 = affix('.viewport2')
|
295
|
+
$element = affix('div').appendTo($viewport2)
|
296
|
+
expect(up.layout.viewportOf($element)).toEqual($viewport2)
|
297
|
+
|
298
|
+
it 'returns the given element if it is a configured viewport itself', ->
|
299
|
+
up.layout.config.viewports = ['.viewport']
|
300
|
+
$viewport = affix('.viewport')
|
301
|
+
expect(up.layout.viewportOf($viewport)).toEqual($viewport)
|
302
|
+
|
303
|
+
it 'finds the document if the viewport is the document', ->
|
304
|
+
# This actually tests that the hierarchy returned by `$.parent`
|
305
|
+
# is $element => ... => $('body') => $('html') => $(document)
|
306
|
+
up.layout.config.viewports = [document]
|
307
|
+
$element = affix('div')
|
308
|
+
expect(up.layout.viewportOf($element)).toEqual($(document))
|
309
|
+
|
310
|
+
it 'throws an error if no viewport could be found', ->
|
311
|
+
up.layout.config.viewports = ['.does-not-exist']
|
312
|
+
$element = affix('div')
|
313
|
+
lookup = -> up.layout.viewportOf($element)
|
314
|
+
expect(lookup).toThrowError(/Could not find viewport/i)
|
315
|
+
|
316
|
+
describe 'up.scroll', ->
|
317
|
+
|
318
|
+
it 'should have tests'
|
@@ -0,0 +1,340 @@
|
|
1
|
+
describe 'up.link', ->
|
2
|
+
|
3
|
+
u = up.util
|
4
|
+
|
5
|
+
describe 'Javascript functions', ->
|
6
|
+
|
7
|
+
describe 'up.follow', ->
|
8
|
+
|
9
|
+
describeCapability 'canPushState', ->
|
10
|
+
|
11
|
+
it 'loads the given link via AJAX and replaces the response in the given target', (done) ->
|
12
|
+
affix('.before').text('old-before')
|
13
|
+
affix('.middle').text('old-middle')
|
14
|
+
affix('.after').text('old-after')
|
15
|
+
$link = affix('a[href="/path"][up-target=".middle"]')
|
16
|
+
|
17
|
+
promise = up.follow($link)
|
18
|
+
|
19
|
+
@respondWith """
|
20
|
+
<div class="before">new-before</div>
|
21
|
+
<div class="middle">new-middle</div>
|
22
|
+
<div class="after">new-after</div>
|
23
|
+
"""
|
24
|
+
|
25
|
+
promise.then ->
|
26
|
+
expect($('.before')).toHaveText('old-before')
|
27
|
+
expect($('.middle')).toHaveText('new-middle')
|
28
|
+
expect($('.after')).toHaveText('old-after')
|
29
|
+
done()
|
30
|
+
|
31
|
+
it 'uses the method from a data-method attribute', ->
|
32
|
+
$link = affix('a[href="/path"][data-method="PUT"]')
|
33
|
+
up.follow($link)
|
34
|
+
request = @lastRequest()
|
35
|
+
expect(request).toHaveRequestMethod('PUT')
|
36
|
+
|
37
|
+
it 'allows to refer to the link itself as "&" in the CSS selector', ->
|
38
|
+
$container = affix('div')
|
39
|
+
$link1 = $('<a id="first" href="/path" up-target="&">first-link</a>').appendTo($container)
|
40
|
+
$link2 = $('<a id="second" href="/path" up-target="&">second-link</a>').appendTo($container)
|
41
|
+
up.follow($link2)
|
42
|
+
@respondWith '<div id="second">second-div</div>'
|
43
|
+
expect($container.text()).toBe('first-linksecond-div')
|
44
|
+
|
45
|
+
it 'adds history entries and allows the user to use the back- and forward-buttons', (done) ->
|
46
|
+
|
47
|
+
# By default, up.history will replace the <body> tag when
|
48
|
+
# the user presses the back-button. We reconfigure this
|
49
|
+
# so we don't lose the Jasmine runner interface.
|
50
|
+
up.history.config.popTargets = ['.container']
|
51
|
+
|
52
|
+
respondWith = (html) =>
|
53
|
+
@lastRequest().respondWith
|
54
|
+
status: 200
|
55
|
+
contentType: 'text/html'
|
56
|
+
responseText: "<div class='container'><div class='target'>#{html}</div></div>"
|
57
|
+
|
58
|
+
followAndRespond = ($link, html) ->
|
59
|
+
promise = up.follow($link)
|
60
|
+
respondWith(html)
|
61
|
+
promise
|
62
|
+
|
63
|
+
$link1 = affix('a[href="/one"][up-target=".target"]')
|
64
|
+
$link2 = affix('a[href="/two"][up-target=".target"]')
|
65
|
+
$link3 = affix('a[href="/three"][up-target=".target"]')
|
66
|
+
$container = affix('.container')
|
67
|
+
$target = affix('.target').appendTo($container).text('original text')
|
68
|
+
|
69
|
+
followAndRespond($link1, 'text from one').then =>
|
70
|
+
expect($('.target')).toHaveText('text from one')
|
71
|
+
expect(location.pathname).toEqual('/one')
|
72
|
+
|
73
|
+
followAndRespond($link2, 'text from two').then =>
|
74
|
+
expect($('.target')).toHaveText('text from two')
|
75
|
+
expect(location.pathname).toEqual('/two')
|
76
|
+
|
77
|
+
followAndRespond($link3, 'text from three').then =>
|
78
|
+
expect($('.target')).toHaveText('text from three')
|
79
|
+
expect(location.pathname).toEqual('/three')
|
80
|
+
|
81
|
+
history.back()
|
82
|
+
@setTimer 50, =>
|
83
|
+
respondWith('restored text from two')
|
84
|
+
expect($('.target')).toHaveText('restored text from two')
|
85
|
+
expect(location.pathname).toEqual('/two')
|
86
|
+
|
87
|
+
history.back()
|
88
|
+
@setTimer 50, =>
|
89
|
+
respondWith('restored text from one')
|
90
|
+
expect($('.target')).toHaveText('restored text from one')
|
91
|
+
expect(location.pathname).toEqual('/one')
|
92
|
+
|
93
|
+
history.forward()
|
94
|
+
@setTimer 50, =>
|
95
|
+
# Since the response is cached, we don't have to respond
|
96
|
+
expect($('.target')).toHaveText('restored text from two')
|
97
|
+
expect(location.pathname).toEqual('/two')
|
98
|
+
|
99
|
+
done()
|
100
|
+
|
101
|
+
describe 'with { restoreScroll: true } option', ->
|
102
|
+
|
103
|
+
it 'does not reveal, but instead restores the scroll positions of all viewports around the target', ->
|
104
|
+
|
105
|
+
$viewport = affix('div[up-viewport] .element').css
|
106
|
+
'height': '100px'
|
107
|
+
'width': '100px'
|
108
|
+
'overflow-y': 'scroll'
|
109
|
+
|
110
|
+
followLink = (options = {}) ->
|
111
|
+
$link = $viewport.find('.link')
|
112
|
+
up.follow($link, options)
|
113
|
+
|
114
|
+
respond = (linkDestination) =>
|
115
|
+
@respondWith """
|
116
|
+
<div class="element" style="height: 300px">
|
117
|
+
<a class="link" href="#{linkDestination}" up-target=".element">Link</a>
|
118
|
+
</div>
|
119
|
+
"""
|
120
|
+
|
121
|
+
up.replace('.element', '/foo')
|
122
|
+
# Provide the content at /foo with a link to /bar in the HTML
|
123
|
+
respond('/bar')
|
124
|
+
|
125
|
+
$viewport.scrollTop(65)
|
126
|
+
|
127
|
+
# Follow the link to /bar
|
128
|
+
followLink()
|
129
|
+
|
130
|
+
# Provide the content at /bar with a link back to /foo in the HTML
|
131
|
+
respond('/foo')
|
132
|
+
|
133
|
+
# Follow the link back to /foo, restoring the scroll position of 65px
|
134
|
+
followLink(restoreScroll: true)
|
135
|
+
# No need to respond because /foo has been cached before
|
136
|
+
|
137
|
+
expect($viewport.scrollTop()).toEqual(65)
|
138
|
+
|
139
|
+
# describe "when the browser is already on the link's destination", ->
|
140
|
+
#
|
141
|
+
# it "doesn't make a request and reveals the target container"
|
142
|
+
#
|
143
|
+
# it "doesn't make a request and reveals the target of a #hash in the URL"
|
144
|
+
|
145
|
+
describe 'with { confirm } option', ->
|
146
|
+
|
147
|
+
it 'follows the link after the user OKs a confirmation dialog', ->
|
148
|
+
deferred = $.Deferred()
|
149
|
+
spyOn(up.browser, 'confirm').and.returnValue(deferred)
|
150
|
+
spyOn(up, 'replace')
|
151
|
+
$link = affix('a[href="/danger"][up-target=".middle"]')
|
152
|
+
up.follow($link, confirm: 'Do you really want to go there?')
|
153
|
+
expect(up.browser.confirm).toHaveBeenCalledWith('Do you really want to go there?')
|
154
|
+
expect(up.replace).not.toHaveBeenCalled()
|
155
|
+
deferred.resolve()
|
156
|
+
expect(up.replace).toHaveBeenCalled()
|
157
|
+
|
158
|
+
it 'does not show a confirmation dialog if the option is not a present string', ->
|
159
|
+
spyOn(up, 'replace')
|
160
|
+
$link = affix('a[href="/danger"][up-target=".middle"]')
|
161
|
+
up.follow($link, confirm: '')
|
162
|
+
expect(up.replace).toHaveBeenCalled()
|
163
|
+
|
164
|
+
describeFallback 'canPushState', ->
|
165
|
+
|
166
|
+
it 'follows the given link', ->
|
167
|
+
$link = affix('a[href="/path"]')
|
168
|
+
spyOn(up.browser, 'loadPage')
|
169
|
+
up.follow($link)
|
170
|
+
expect(up.browser.loadPage).toHaveBeenCalledWith('/path', jasmine.anything())
|
171
|
+
|
172
|
+
it 'uses the method from a data-method attribute', ->
|
173
|
+
$link = affix('a[href="/path"][data-method="PUT"]')
|
174
|
+
spyOn(up.browser, 'loadPage')
|
175
|
+
up.follow($link)
|
176
|
+
expect(up.browser.loadPage).toHaveBeenCalledWith('/path', { method: 'PUT' })
|
177
|
+
|
178
|
+
|
179
|
+
describe 'up.visit', ->
|
180
|
+
|
181
|
+
it 'should have tests'
|
182
|
+
|
183
|
+
describe 'unobtrusive behavior', ->
|
184
|
+
|
185
|
+
describe 'a[up-target]', ->
|
186
|
+
|
187
|
+
it 'does not follow a form with up-target attribute (bugfix)', ->
|
188
|
+
$form = affix('form[up-target]')
|
189
|
+
up.hello($form)
|
190
|
+
followSpy = up.link.knife.mock('follow')
|
191
|
+
$form.click()
|
192
|
+
expect(followSpy).not.toHaveBeenCalled()
|
193
|
+
|
194
|
+
describeCapability 'canPushState', ->
|
195
|
+
|
196
|
+
it 'adds a history entry', ->
|
197
|
+
affix('.target')
|
198
|
+
$link = affix('a[href="/path"][up-target=".target"]')
|
199
|
+
$link.click()
|
200
|
+
@respondWith('<div class="target">new text</div>')
|
201
|
+
expect($('.target')).toHaveText('new text')
|
202
|
+
expect(location.pathname).toEqual('/path')
|
203
|
+
|
204
|
+
it 'respects a X-Up-Location header that the server sends in case of a redirect', ->
|
205
|
+
affix('.target')
|
206
|
+
$link = affix('a[href="/path"][up-target=".target"]')
|
207
|
+
$link.click()
|
208
|
+
@respondWith
|
209
|
+
responseText: '<div class="target">new text</div>'
|
210
|
+
responseHeaders: { 'X-Up-Location': '/other/path' }
|
211
|
+
expect($('.target')).toHaveText('new text')
|
212
|
+
expect(location.pathname).toEqual('/other/path')
|
213
|
+
|
214
|
+
it 'does not add a history entry when an up-history attribute is set to "false"', ->
|
215
|
+
oldPathname = location.pathname
|
216
|
+
affix('.target')
|
217
|
+
$link = affix('a[href="/path"][up-target=".target"][up-history="false"]')
|
218
|
+
$link.click()
|
219
|
+
@respondWith
|
220
|
+
responseText: '<div class="target">new text</div>'
|
221
|
+
responseHeaders: { 'X-Up-Location': '/other/path' }
|
222
|
+
expect($('.target')).toHaveText('new text')
|
223
|
+
expect(location.pathname).toEqual(oldPathname)
|
224
|
+
|
225
|
+
describe 'a[up-follow]', ->
|
226
|
+
|
227
|
+
beforeEach ->
|
228
|
+
@$link = affix('a[href="/path"][up-follow]')
|
229
|
+
@followSpy = up.link.knife.mock('follow')
|
230
|
+
@defaultSpy = up.link.knife.mock('allowDefault').and.callFake((event) -> event.preventDefault())
|
231
|
+
|
232
|
+
it "calls up.follow with the clicked link", ->
|
233
|
+
Trigger.click(@$link)
|
234
|
+
expect(@followSpy).toHaveBeenCalledWith(@$link)
|
235
|
+
|
236
|
+
# IE does not call Javascript and always performs the default action on right clicks
|
237
|
+
unless navigator.userAgent.match(/Trident/)
|
238
|
+
it 'does nothing if the right mouse button is used', ->
|
239
|
+
Trigger.click(@$link, button: 2)
|
240
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
241
|
+
|
242
|
+
it 'does nothing if shift is pressed during the click', ->
|
243
|
+
Trigger.click(@$link, shiftKey: true)
|
244
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
245
|
+
|
246
|
+
it 'does nothing if ctrl is pressed during the click', ->
|
247
|
+
Trigger.click(@$link, ctrlKey: true)
|
248
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
249
|
+
|
250
|
+
it 'does nothing if meta is pressed during the click', ->
|
251
|
+
Trigger.click(@$link, metaKey: true)
|
252
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
253
|
+
|
254
|
+
describe 'with [up-instant] modifier', ->
|
255
|
+
|
256
|
+
beforeEach ->
|
257
|
+
@$link.attr('up-instant', '')
|
258
|
+
|
259
|
+
it 'follows a link on mousedown (instead of on click)', ->
|
260
|
+
Trigger.mousedown(@$link)
|
261
|
+
expect(@followSpy.calls.mostRecent().args[0]).toEqual(@$link)
|
262
|
+
|
263
|
+
it 'does nothing on mouseup', ->
|
264
|
+
Trigger.mouseup(@$link)
|
265
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
266
|
+
|
267
|
+
it 'does nothing on click', ->
|
268
|
+
Trigger.click(@$link)
|
269
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
270
|
+
|
271
|
+
# IE does not call Javascript and always performs the default action on right clicks
|
272
|
+
unless navigator.userAgent.match(/Trident/)
|
273
|
+
it 'does nothing if the right mouse button is pressed down', ->
|
274
|
+
Trigger.mousedown(@$link, button: 2)
|
275
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
276
|
+
|
277
|
+
it 'does nothing if shift is pressed during mousedown', ->
|
278
|
+
Trigger.mousedown(@$link, shiftKey: true)
|
279
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
280
|
+
|
281
|
+
it 'does nothing if ctrl is pressed during mousedown', ->
|
282
|
+
Trigger.mousedown(@$link, ctrlKey: true)
|
283
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
284
|
+
|
285
|
+
it 'does nothing if meta is pressed during mousedown', ->
|
286
|
+
Trigger.mousedown(@$link, metaKey: true)
|
287
|
+
expect(@followSpy).not.toHaveBeenCalled()
|
288
|
+
|
289
|
+
describe '[up-expand]', ->
|
290
|
+
|
291
|
+
it 'copies up-related attributes of a contained link', ->
|
292
|
+
$area = affix('div[up-expand] a[href="/path"][up-target="selector"][up-instant][up-preload]')
|
293
|
+
up.hello($area)
|
294
|
+
expect($area.attr('up-target')).toEqual('selector')
|
295
|
+
expect($area.attr('up-instant')).toEqual('')
|
296
|
+
expect($area.attr('up-preload')).toEqual('')
|
297
|
+
|
298
|
+
it "renames a contained link's href attribute to up-href so the container is considered a link", ->
|
299
|
+
$area = affix('div[up-expand] a[up-follow][href="/path"]')
|
300
|
+
up.hello($area)
|
301
|
+
expect($area.attr('up-href')).toEqual('/path')
|
302
|
+
|
303
|
+
it 'copies attributes from the first link if there are multiple links', ->
|
304
|
+
$area = affix('div[up-expand]')
|
305
|
+
$link1 = $area.affix('a[href="/path1"]')
|
306
|
+
$link2 = $area.affix('a[href="/path2"]')
|
307
|
+
up.hello($area)
|
308
|
+
expect($area.attr('up-href')).toEqual('/path1')
|
309
|
+
|
310
|
+
it "copies an contained non-link element with up-href attribute", ->
|
311
|
+
$area = affix('div[up-expand] span[up-follow][up-href="/path"]')
|
312
|
+
up.hello($area)
|
313
|
+
expect($area.attr('up-href')).toEqual('/path')
|
314
|
+
|
315
|
+
it 'adds an up-follow attribute if the contained link has neither up-follow nor up-target attributes', ->
|
316
|
+
$area = affix('div[up-expand] a[href="/path"]')
|
317
|
+
up.hello($area)
|
318
|
+
expect($area.attr('up-follow')).toEqual('')
|
319
|
+
|
320
|
+
describe 'with a CSS selector in the property value', ->
|
321
|
+
|
322
|
+
it "expands the contained link that matches the selector", ->
|
323
|
+
$area = affix('div[up-expand=".second"]')
|
324
|
+
$link1 = $area.affix('a.first[href="/path1"]')
|
325
|
+
$link2 = $area.affix('a.second[href="/path2"]')
|
326
|
+
up.hello($area)
|
327
|
+
expect($area.attr('up-href')).toEqual('/path2')
|
328
|
+
|
329
|
+
it 'does nothing if no contained link matches the selector', ->
|
330
|
+
$area = affix('div[up-expand=".foo"]')
|
331
|
+
$link = $area.affix('a[href="/path1"]')
|
332
|
+
up.hello($area)
|
333
|
+
expect($area.attr('up-href')).toBeUndefined()
|
334
|
+
|
335
|
+
it 'does not match an element that is not a descendant', ->
|
336
|
+
$area = affix('div[up-expand=".second"]')
|
337
|
+
$link1 = $area.affix('a.first[href="/path1"]')
|
338
|
+
$link2 = affix('a.second[href="/path2"]') # not a child of $area
|
339
|
+
up.hello($area)
|
340
|
+
expect($area.attr('up-href')).toBeUndefined()
|