unpoly-rails 0.62.1 → 2.0.0.pre.rc2
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 +4 -4
- data/.yardopts +1 -1
- data/CHANGELOG.md +53 -1
- data/README.md +1 -1
- data/README_RAILS.md +295 -14
- data/dist/unpoly-bootstrap3.css +9 -14
- data/dist/unpoly-bootstrap3.js +4 -18
- data/dist/unpoly-bootstrap3.min.css +1 -1
- data/dist/unpoly-bootstrap3.min.js +1 -1
- data/dist/unpoly-bootstrap4.css +9 -0
- data/dist/unpoly-bootstrap4.js +16 -0
- data/dist/unpoly-bootstrap4.min.css +1 -0
- data/dist/unpoly-bootstrap4.min.js +1 -0
- data/dist/unpoly-bootstrap5.css +9 -0
- data/dist/unpoly-bootstrap5.js +14 -0
- data/dist/unpoly-bootstrap5.min.css +1 -0
- data/dist/unpoly-bootstrap5.min.js +1 -0
- data/dist/unpoly-migrate.js +1213 -0
- data/dist/unpoly-migrate.min.js +1 -0
- data/dist/unpoly.css +109 -140
- data/dist/unpoly.js +15377 -10465
- data/dist/unpoly.min.css +1 -1
- data/dist/unpoly.min.js +6 -4
- data/lib/unpoly-rails.rb +9 -3
- data/lib/unpoly/rails/change.rb +372 -0
- data/lib/unpoly/rails/change/cache.rb +26 -0
- data/lib/unpoly/rails/change/context.rb +80 -0
- data/lib/unpoly/rails/change/field.rb +117 -0
- data/lib/unpoly/rails/change/field_definition.rb +74 -0
- data/lib/unpoly/rails/change/layer.rb +60 -0
- data/lib/unpoly/rails/controller.rb +47 -0
- data/lib/unpoly/rails/error.rb +5 -0
- data/lib/unpoly/rails/request_echo_headers.rb +2 -2
- data/lib/unpoly/rails/version.rb +1 -1
- data/lib/unpoly/tasks.rb +45 -0
- metadata +43 -313
- data/.gitignore +0 -10
- data/.ruby-version +0 -1
- data/Gemfile +0 -8
- data/Gemfile.lock +0 -45
- data/Rakefile +0 -145
- data/bower.json +0 -27
- data/design/animation-ghosting.txt +0 -72
- data/design/design.txt +0 -34
- data/design/draft.html.erb +0 -48
- data/design/draft.rb +0 -9
- data/design/es6.js +0 -32
- data/design/ghost-debugging.txt +0 -118
- data/design/homepage.txt +0 -236
- data/design/ie11.txt +0 -9
- data/design/measure_import_node.js +0 -330
- data/design/measure_jquery/element_list.js +0 -41
- data/design/measure_jquery/up.on_vs_addEventListener.js +0 -56
- data/design/positioning.txt +0 -28
- data/design/query-params-in-form-actions/cases.html +0 -125
- data/design/rename.txt +0 -0
- data/design/test_rejected_promise.txt +0 -5
- data/design/unpoly errors.txt +0 -19
- data/lib/assets/javascripts/unpoly-bootstrap3.coffee +0 -2
- data/lib/assets/javascripts/unpoly-bootstrap3/feedback-ext.coffee +0 -5
- data/lib/assets/javascripts/unpoly-bootstrap3/form-ext.coffee +0 -1
- data/lib/assets/javascripts/unpoly-bootstrap3/modal-ext.coffee +0 -14
- data/lib/assets/javascripts/unpoly-bootstrap3/viewport-ext.coffee +0 -5
- data/lib/assets/javascripts/unpoly.coffee +0 -28
- data/lib/assets/javascripts/unpoly/browser.coffee.erb +0 -240
- data/lib/assets/javascripts/unpoly/classes/body_shifter.coffee +0 -45
- data/lib/assets/javascripts/unpoly/classes/cache.coffee +0 -127
- data/lib/assets/javascripts/unpoly/classes/compile_pass.coffee +0 -93
- data/lib/assets/javascripts/unpoly/classes/config.coffee +0 -9
- data/lib/assets/javascripts/unpoly/classes/css_transition.coffee +0 -118
- data/lib/assets/javascripts/unpoly/classes/divertible_chain.coffee +0 -39
- data/lib/assets/javascripts/unpoly/classes/event_listener.coffee +0 -116
- data/lib/assets/javascripts/unpoly/classes/extract_cascade.coffee +0 -86
- data/lib/assets/javascripts/unpoly/classes/extract_plan.coffee +0 -111
- data/lib/assets/javascripts/unpoly/classes/field_observer.coffee +0 -80
- data/lib/assets/javascripts/unpoly/classes/focus_follower.coffee +0 -29
- data/lib/assets/javascripts/unpoly/classes/follow_variant.coffee +0 -64
- data/lib/assets/javascripts/unpoly/classes/html_parser.coffee +0 -46
- data/lib/assets/javascripts/unpoly/classes/motion_controller.coffee +0 -157
- data/lib/assets/javascripts/unpoly/classes/params.coffee.erb +0 -544
- data/lib/assets/javascripts/unpoly/classes/record.coffee +0 -22
- data/lib/assets/javascripts/unpoly/classes/rect.js +0 -21
- data/lib/assets/javascripts/unpoly/classes/request.coffee +0 -246
- data/lib/assets/javascripts/unpoly/classes/response.coffee +0 -157
- data/lib/assets/javascripts/unpoly/classes/reveal_motion.coffee +0 -102
- data/lib/assets/javascripts/unpoly/classes/scroll_motion.coffee +0 -67
- data/lib/assets/javascripts/unpoly/classes/selector.coffee +0 -60
- data/lib/assets/javascripts/unpoly/classes/store/memory.coffee +0 -26
- data/lib/assets/javascripts/unpoly/classes/store/session.coffee +0 -59
- data/lib/assets/javascripts/unpoly/classes/tether.coffee +0 -105
- data/lib/assets/javascripts/unpoly/classes/url_set.coffee +0 -32
- data/lib/assets/javascripts/unpoly/cookie.coffee +0 -56
- data/lib/assets/javascripts/unpoly/element.coffee.erb +0 -1126
- data/lib/assets/javascripts/unpoly/event.coffee.erb +0 -445
- data/lib/assets/javascripts/unpoly/feedback.coffee +0 -353
- data/lib/assets/javascripts/unpoly/form.coffee.erb +0 -1075
- data/lib/assets/javascripts/unpoly/fragment.coffee.erb +0 -928
- data/lib/assets/javascripts/unpoly/framework.coffee +0 -67
- data/lib/assets/javascripts/unpoly/history.coffee +0 -268
- data/lib/assets/javascripts/unpoly/legacy.coffee +0 -60
- data/lib/assets/javascripts/unpoly/link.coffee.erb +0 -622
- data/lib/assets/javascripts/unpoly/log.coffee +0 -248
- data/lib/assets/javascripts/unpoly/modal.coffee.erb +0 -827
- data/lib/assets/javascripts/unpoly/motion.coffee.erb +0 -668
- data/lib/assets/javascripts/unpoly/namespace.coffee.erb +0 -5
- data/lib/assets/javascripts/unpoly/popup.coffee.erb +0 -515
- data/lib/assets/javascripts/unpoly/protocol.coffee +0 -298
- data/lib/assets/javascripts/unpoly/proxy.coffee +0 -672
- data/lib/assets/javascripts/unpoly/radio.coffee +0 -60
- data/lib/assets/javascripts/unpoly/rails.coffee +0 -24
- data/lib/assets/javascripts/unpoly/syntax.coffee.erb +0 -476
- data/lib/assets/javascripts/unpoly/toast.coffee +0 -67
- data/lib/assets/javascripts/unpoly/tooltip.coffee +0 -276
- data/lib/assets/javascripts/unpoly/util.coffee.erb +0 -1676
- data/lib/assets/javascripts/unpoly/viewport.coffee.erb +0 -830
- data/lib/assets/stylesheets/unpoly-bootstrap3.sass +0 -1
- data/lib/assets/stylesheets/unpoly-bootstrap3/modal-ext.sass +0 -27
- data/lib/assets/stylesheets/unpoly.sass +0 -1
- data/lib/assets/stylesheets/unpoly/close.sass +0 -2
- data/lib/assets/stylesheets/unpoly/dom.sass +0 -5
- data/lib/assets/stylesheets/unpoly/layout.sass +0 -2
- data/lib/assets/stylesheets/unpoly/link.sass +0 -2
- data/lib/assets/stylesheets/unpoly/modal.sass +0 -116
- data/lib/assets/stylesheets/unpoly/popup.sass +0 -7
- data/lib/assets/stylesheets/unpoly/toast.sass +0 -33
- data/lib/assets/stylesheets/unpoly/tooltip.sass +0 -62
- data/lib/unpoly/rails/inspector.rb +0 -149
- data/lib/unpoly/rails/inspector_accessor.rb +0 -30
- data/package.json +0 -38
- data/spec_app/.firefox-version +0 -1
- data/spec_app/.gitignore +0 -17
- data/spec_app/.rspec +0 -2
- data/spec_app/Gemfile +0 -30
- data/spec_app/Gemfile.lock +0 -229
- data/spec_app/README.rdoc +0 -28
- data/spec_app/Rakefile +0 -6
- data/spec_app/app/assets/images/.keep +0 -0
- data/spec_app/app/assets/images/favicon.png +0 -0
- data/spec_app/app/assets/images/grid.png +0 -0
- data/spec_app/app/assets/javascripts/bootstrap_manifest.coffee +0 -6
- data/spec_app/app/assets/javascripts/integration_test.coffee +0 -6
- data/spec_app/app/assets/javascripts/jasmine_specs.coffee +0 -6
- data/spec_app/app/assets/stylesheets/_helpers.sass +0 -5
- data/spec_app/app/assets/stylesheets/bootstrap_manifest.sass +0 -2
- data/spec_app/app/assets/stylesheets/integration_test.sass +0 -88
- data/spec_app/app/assets/stylesheets/jasmine_specs.sass +0 -20
- data/spec_app/app/controllers/application_controller.rb +0 -14
- data/spec_app/app/controllers/binding_test_controller.rb +0 -51
- data/spec_app/app/controllers/compiler_test_controller.rb +0 -5
- data/spec_app/app/controllers/css_test_controller.rb +0 -5
- data/spec_app/app/controllers/error_test_controller.rb +0 -5
- data/spec_app/app/controllers/form_test/basics_controller.rb +0 -14
- data/spec_app/app/controllers/form_test/redirects_controller.rb +0 -17
- data/spec_app/app/controllers/form_test/uploads_controller.rb +0 -15
- data/spec_app/app/controllers/hash_test_controller.rb +0 -5
- data/spec_app/app/controllers/method_test_controller.rb +0 -16
- data/spec_app/app/controllers/motion_test_controller.rb +0 -5
- data/spec_app/app/controllers/pages_controller.rb +0 -9
- data/spec_app/app/controllers/replace_test_controller.rb +0 -5
- data/spec_app/app/controllers/reveal_test_controller.rb +0 -5
- data/spec_app/app/controllers/scroll_test_controller.rb +0 -5
- data/spec_app/app/helpers/application_helper.rb +0 -2
- data/spec_app/app/mailers/.keep +0 -0
- data/spec_app/app/models/concerns/.keep +0 -0
- data/spec_app/app/views/compiler_test/timestamp.erb +0 -9
- data/spec_app/app/views/css_test/modal.erb +0 -47
- data/spec_app/app/views/css_test/modal_contents.erb +0 -5
- data/spec_app/app/views/css_test/modal_contents_wide.erb +0 -5
- data/spec_app/app/views/css_test/popup.erb +0 -81
- data/spec_app/app/views/css_test/popup_contents.erb +0 -5
- data/spec_app/app/views/css_test/tooltip.erb +0 -48
- data/spec_app/app/views/error_test/trigger.erb +0 -80
- data/spec_app/app/views/error_test/unexpected_response.erb +0 -3
- data/spec_app/app/views/form_test/basics/new.erb +0 -60
- data/spec_app/app/views/form_test/redirects/new.erb +0 -27
- data/spec_app/app/views/form_test/redirects/target.erb +0 -4
- data/spec_app/app/views/form_test/submission_result.erb +0 -30
- data/spec_app/app/views/form_test/uploads/new.erb +0 -44
- data/spec_app/app/views/hash_test/unpoly.erb +0 -30
- data/spec_app/app/views/hash_test/vanilla.erb +0 -13
- data/spec_app/app/views/layouts/integration_test.erb +0 -22
- data/spec_app/app/views/layouts/jasmine_rails/spec_runner.html.erb +0 -20
- data/spec_app/app/views/method_test/form_target.erb +0 -17
- data/spec_app/app/views/method_test/page1.erb +0 -11
- data/spec_app/app/views/method_test/page2.erb +0 -6
- data/spec_app/app/views/motion_test/animations.erb +0 -16
- data/spec_app/app/views/motion_test/transitions.erb +0 -13
- data/spec_app/app/views/pages/start.erb +0 -79
- data/spec_app/app/views/replace_test/_nav.erb +0 -6
- data/spec_app/app/views/replace_test/page1.erb +0 -14
- data/spec_app/app/views/replace_test/page2.erb +0 -14
- data/spec_app/app/views/replace_test/table.erb +0 -16
- data/spec_app/app/views/reveal_test/long1.erb +0 -17
- data/spec_app/app/views/reveal_test/long2.erb +0 -17
- data/spec_app/app/views/reveal_test/within_document_viewport.erb +0 -24
- data/spec_app/app/views/reveal_test/within_overflowing_div_viewport.erb +0 -28
- data/spec_app/app/views/scroll_test/long1.erb +0 -30
- data/spec_app/bin/bundle +0 -3
- data/spec_app/bin/rails +0 -8
- data/spec_app/bin/rake +0 -8
- data/spec_app/bin/setup +0 -29
- data/spec_app/bin/spring +0 -18
- data/spec_app/config.ru +0 -4
- data/spec_app/config/application.rb +0 -28
- data/spec_app/config/boot.rb +0 -3
- data/spec_app/config/database.yml +0 -25
- data/spec_app/config/environment.rb +0 -5
- data/spec_app/config/environments/development.rb +0 -41
- data/spec_app/config/environments/production.rb +0 -79
- data/spec_app/config/environments/test.rb +0 -42
- data/spec_app/config/initializers/assets.rb +0 -19
- data/spec_app/config/initializers/backtrace_silencers.rb +0 -7
- data/spec_app/config/initializers/bower_rails.rb +0 -16
- data/spec_app/config/initializers/cookies_serializer.rb +0 -3
- data/spec_app/config/initializers/filter_parameter_logging.rb +0 -4
- data/spec_app/config/initializers/inflections.rb +0 -16
- data/spec_app/config/initializers/mime_types.rb +0 -4
- data/spec_app/config/initializers/session_store.rb +0 -3
- data/spec_app/config/initializers/wrap_parameters.rb +0 -14
- data/spec_app/config/locales/en.yml +0 -23
- data/spec_app/config/routes.rb +0 -30
- data/spec_app/config/secrets.yml +0 -22
- data/spec_app/db/schema.rb +0 -23
- data/spec_app/db/seeds.rb +0 -7
- data/spec_app/lib/assets/.keep +0 -0
- data/spec_app/lib/tasks/.keep +0 -0
- data/spec_app/lib/tasks/cucumber.rake +0 -65
- data/spec_app/log/.keep +0 -0
- data/spec_app/public/404.html +0 -67
- data/spec_app/public/422.html +0 -67
- data/spec_app/public/500.html +0 -66
- data/spec_app/public/favicon.ico +0 -0
- data/spec_app/public/robots.txt +0 -5
- data/spec_app/script/cucumber +0 -10
- data/spec_app/spec/controllers/binding_test_controller_spec.rb +0 -248
- data/spec_app/spec/javascripts/helpers/agent_detector.coffee +0 -20
- data/spec_app/spec/javascripts/helpers/async_sequence.js.coffee +0 -103
- data/spec_app/spec/javascripts/helpers/browser_switches.js.coffee +0 -21
- data/spec_app/spec/javascripts/helpers/enable_logging.js.coffee +0 -2
- data/spec_app/spec/javascripts/helpers/fixture.js.coffee +0 -25
- data/spec_app/spec/javascripts/helpers/index.js.coffee +0 -1
- data/spec_app/spec/javascripts/helpers/jquery_no_conflict.js +0 -1
- data/spec_app/spec/javascripts/helpers/knife.js.coffee +0 -69
- data/spec_app/spec/javascripts/helpers/last_request.js.coffee +0 -25
- data/spec_app/spec/javascripts/helpers/mock_ajax.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/mock_clock.js.coffee +0 -2
- data/spec_app/spec/javascripts/helpers/parse_form_data.js.coffee +0 -24
- data/spec_app/spec/javascripts/helpers/promise_state.js +0 -18
- data/spec_app/spec/javascripts/helpers/protect_jasmine_runner.coffee +0 -12
- data/spec_app/spec/javascripts/helpers/remove_body_margin.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/reset_history.js.coffee +0 -23
- data/spec_app/spec/javascripts/helpers/reset_knife.js.coffee +0 -2
- data/spec_app/spec/javascripts/helpers/reset_up.js.coffee +0 -25
- data/spec_app/spec/javascripts/helpers/restore_body_scroll.js.coffee +0 -5
- data/spec_app/spec/javascripts/helpers/show_lib_versions.coffee +0 -12
- data/spec_app/spec/javascripts/helpers/spec_util.coffee +0 -47
- data/spec_app/spec/javascripts/helpers/to_be_around.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_array.coffee +0 -5
- data/spec_app/spec/javascripts/helpers/to_be_attached.coffee +0 -9
- data/spec_app/spec/javascripts/helpers/to_be_blank.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_detached.coffee +0 -9
- data/spec_app/spec/javascripts/helpers/to_be_element.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_error.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_given.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_hidden.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_jquery.js.coffee +0 -5
- data/spec_app/spec/javascripts/helpers/to_be_missing.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_present.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_be_scrolled_to.coffee +0 -11
- data/spec_app/spec/javascripts/helpers/to_be_visible.js.coffee +0 -9
- data/spec_app/spec/javascripts/helpers/to_contain.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_end_with.js.coffee +0 -11
- data/spec_app/spec/javascripts/helpers/to_equal_jquery.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_equal_node_list.coffee +0 -7
- data/spec_app/spec/javascripts/helpers/to_equal_via_is_equal.js.coffee +0 -7
- data/spec_app/spec/javascripts/helpers/to_have_class.js.coffee +0 -10
- data/spec_app/spec/javascripts/helpers/to_have_descendant.js.coffee +0 -10
- data/spec_app/spec/javascripts/helpers/to_have_length.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_have_opacity.coffee +0 -15
- data/spec_app/spec/javascripts/helpers/to_have_own_property.js.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_have_request_method.js.coffee +0 -16
- data/spec_app/spec/javascripts/helpers/to_have_text.js.coffee +0 -9
- data/spec_app/spec/javascripts/helpers/to_have_unhandled_rejections.coffee +0 -18
- data/spec_app/spec/javascripts/helpers/to_match_list.coffee +0 -14
- data/spec_app/spec/javascripts/helpers/to_match_selector.coffee +0 -8
- data/spec_app/spec/javascripts/helpers/to_match_text.js.coffee +0 -13
- data/spec_app/spec/javascripts/helpers/to_match_url.coffee +0 -14
- data/spec_app/spec/javascripts/helpers/trigger.js.coffee +0 -200
- data/spec_app/spec/javascripts/helpers/wait_until_dom_ready.js.coffee +0 -5
- data/spec_app/spec/javascripts/support/jasmine.yml +0 -51
- data/spec_app/spec/javascripts/up/browser_spec.js.coffee +0 -150
- data/spec_app/spec/javascripts/up/classes/cache_spec.js.coffee +0 -82
- data/spec_app/spec/javascripts/up/classes/config_spec.coffee +0 -24
- data/spec_app/spec/javascripts/up/classes/divertible_chain_spec.coffee +0 -45
- data/spec_app/spec/javascripts/up/classes/focus_tracker_spec.coffee +0 -34
- data/spec_app/spec/javascripts/up/classes/params_spec.coffee +0 -557
- data/spec_app/spec/javascripts/up/classes/request_spec.coffee +0 -50
- data/spec_app/spec/javascripts/up/classes/scroll_motion_spec.js.coffee +0 -51
- data/spec_app/spec/javascripts/up/classes/store/memory_spec.js.coffee +0 -70
- data/spec_app/spec/javascripts/up/classes/store/session_spec.js.coffee +0 -114
- data/spec_app/spec/javascripts/up/element_spec.coffee +0 -897
- data/spec_app/spec/javascripts/up/event_spec.js.coffee +0 -530
- data/spec_app/spec/javascripts/up/feedback_spec.js.coffee +0 -401
- data/spec_app/spec/javascripts/up/form_spec.js.coffee +0 -1527
- data/spec_app/spec/javascripts/up/fragment_spec.js.coffee +0 -2624
- data/spec_app/spec/javascripts/up/history_spec.js.coffee +0 -340
- data/spec_app/spec/javascripts/up/jquery_spec.js.coffee +0 -4
- data/spec_app/spec/javascripts/up/legacy_spec.js.coffee +0 -27
- data/spec_app/spec/javascripts/up/link_spec.js.coffee +0 -1098
- data/spec_app/spec/javascripts/up/log_spec.js.coffee +0 -119
- data/spec_app/spec/javascripts/up/modal_spec.js.coffee +0 -939
- data/spec_app/spec/javascripts/up/motion_spec.js.coffee +0 -582
- data/spec_app/spec/javascripts/up/popup_spec.js.coffee +0 -508
- data/spec_app/spec/javascripts/up/protocol_spec.js.coffee +0 -39
- data/spec_app/spec/javascripts/up/proxy_spec.js.coffee +0 -1137
- data/spec_app/spec/javascripts/up/radio_spec.js.coffee +0 -212
- data/spec_app/spec/javascripts/up/rails_spec.js.coffee +0 -118
- data/spec_app/spec/javascripts/up/spec_spec.js.coffee +0 -9
- data/spec_app/spec/javascripts/up/syntax_spec.js.coffee +0 -304
- data/spec_app/spec/javascripts/up/toast_spec.js.coffee +0 -37
- data/spec_app/spec/javascripts/up/tooltip_spec.js.coffee +0 -163
- data/spec_app/spec/javascripts/up/util_spec.js.coffee +0 -1420
- data/spec_app/spec/javascripts/up/viewport_spec.js.coffee +0 -655
- data/spec_app/spec/spec_helper.rb +0 -62
- 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 +0 -10
- data/spec_app/vendor/asset-libs/es6-promise-4.1.6/es6-promise.auto.js +0 -1159
- data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.bower.json +0 -43
- data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.gitignore +0 -6
- data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.npmignore +0 -10
- data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.pairs +0 -6
- data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.travis.yml +0 -56
- data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/jasmine-ajax.js +0 -790
- data/spec_app/vendor/assets/.keep +0 -0
- data/unpoly-rails.gemspec +0 -24
@@ -1,445 +0,0 @@
|
|
1
|
-
###**
|
2
|
-
Events
|
3
|
-
======
|
4
|
-
|
5
|
-
Most Unpoly interactions emit DOM events that are prefixed with `up:`.
|
6
|
-
|
7
|
-
document.addEventListener('up:modal:opened', (event) => {
|
8
|
-
console.log('A new modal has just opened!')
|
9
|
-
})
|
10
|
-
|
11
|
-
Events often have both present and past forms. For example,
|
12
|
-
`up:modal:open` is emitted before a modal starts to open.
|
13
|
-
`up:modal:opened` is emitted when the modal has finished its
|
14
|
-
opening animation.
|
15
|
-
|
16
|
-
\#\#\# Preventing events
|
17
|
-
|
18
|
-
You can prevent most present form events by calling `preventDefault()`:
|
19
|
-
|
20
|
-
document.addEventListener('up:modal:open', (event) => {
|
21
|
-
if (event.url == '/evil') {
|
22
|
-
// Prevent the modal from opening
|
23
|
-
event.preventDefault()
|
24
|
-
}
|
25
|
-
})
|
26
|
-
|
27
|
-
|
28
|
-
\#\#\# A better way to bind event listeners
|
29
|
-
|
30
|
-
Instead of using [`Element#addEventListener()`](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener),
|
31
|
-
you may find it convenient to use [`up.on()`](/up.on) instead:
|
32
|
-
|
33
|
-
up.on('click', 'button', function(event, button, data) {
|
34
|
-
// button is the clicked element
|
35
|
-
// data is the parsed [`up-data`](/up-data) attribute
|
36
|
-
})
|
37
|
-
|
38
|
-
There are some advantages to using `up.on()`:
|
39
|
-
|
40
|
-
- You may pass a selector for [event delegation](https://davidwalsh.name/event-delegate).
|
41
|
-
- The event target is automatically passed as a second argument.
|
42
|
-
- You may register a listener to multiple events by passing a space-separated list of event name (e.g. `"click mousedown"`).
|
43
|
-
- You may register a listener to multiple elements in a single `up.on()` call, by passing a [list](/up.util.isList) of elements.
|
44
|
-
- You may use an [`[up-data]`](/up-data) attribute to [attach structured data](/up.on#attaching-structured-data)
|
45
|
-
to observed elements. If an `[up-data]` attribute is set, its value will automatically be
|
46
|
-
parsed as JSON and passed as a third argument.
|
47
|
-
- Event listeners on [unsupported browsers](/up.browser.isSupported) are silently discarded,
|
48
|
-
leaving you with an application without JavaScript. This is typically preferable to
|
49
|
-
a soup of randomly broken JavaScript in ancient browsers.
|
50
|
-
|
51
|
-
@module up.event
|
52
|
-
###
|
53
|
-
up.event = do ->
|
54
|
-
|
55
|
-
u = up.util
|
56
|
-
e = up.element
|
57
|
-
|
58
|
-
reset = ->
|
59
|
-
# Resets the list of registered event listeners to the
|
60
|
-
# moment when the framework was booted.
|
61
|
-
for element in [window, document, document.documentElement, document.body]
|
62
|
-
up.EventListener.unbindNonDefault(element)
|
63
|
-
|
64
|
-
###**
|
65
|
-
Listens to a [DOM event](https://developer.mozilla.org/en-US/docs/Web/API/Document_Object_Model/Events)
|
66
|
-
on `document` or a given element.
|
67
|
-
|
68
|
-
`up.on()` has some quality of life improvements over
|
69
|
-
[`Element#addEventListener()`](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener):
|
70
|
-
|
71
|
-
- You may pass a selector for [event delegation](https://davidwalsh.name/event-delegate).
|
72
|
-
- The event target is automatically passed as a second argument.
|
73
|
-
- You may register a listener to multiple events by passing a space-separated list of event name (e.g. `"click mousedown"`)
|
74
|
-
- You may register a listener to multiple elements in a single `up.on()` call, by passing a [list](/up.util.isList) of elements.
|
75
|
-
- You use an [`[up-data]`](/up-data) attribute to [attach structured data](/up.on#attaching-structured-data)
|
76
|
-
to observed elements. If an `[up-data]` attribute is set, its value will automatically be
|
77
|
-
parsed as JSON and passed as a third argument.
|
78
|
-
- Event listeners on [unsupported browsers](/up.browser.isSupported) are silently discarded,
|
79
|
-
leaving you with an application without JavaScript. This is typically preferable to
|
80
|
-
a soup of randomly broken JavaScript in ancient browsers.
|
81
|
-
|
82
|
-
\#\#\# Examples
|
83
|
-
|
84
|
-
The code below will call the listener when a `<a>` is clicked
|
85
|
-
anywhere in the `document`:
|
86
|
-
|
87
|
-
up.on('click', 'a', function(event, element) {
|
88
|
-
console.log("Click on a link %o", element)
|
89
|
-
})
|
90
|
-
|
91
|
-
You may also bind the listener to a given element instead of `document`:
|
92
|
-
|
93
|
-
var form = document.querySelector('form')
|
94
|
-
up.on(form, 'click', function(event, form) {
|
95
|
-
console.log("Click within %o", form)
|
96
|
-
})
|
97
|
-
|
98
|
-
You may also pass both an element and a selector
|
99
|
-
for [event delegation](https://davidwalsh.name/event-delegate):
|
100
|
-
|
101
|
-
var form = document.querySelector('form')
|
102
|
-
up.on(form, 'click', 'a', function(event, link) {
|
103
|
-
console.log("Click on a link %o within %o", link, form)
|
104
|
-
})
|
105
|
-
|
106
|
-
\#\#\# Attaching structured data
|
107
|
-
|
108
|
-
In case you want to attach structured data to the event you're observing,
|
109
|
-
you can serialize the data to JSON and put it into an `[up-data]` attribute:
|
110
|
-
|
111
|
-
<span class='person' up-data='{ "age": 18, "name": "Bob" }'>Bob</span>
|
112
|
-
<span class='person' up-data='{ "age": 22, "name": "Jim" }'>Jim</span>
|
113
|
-
|
114
|
-
The JSON will be parsed and handed to your event handler as a third argument:
|
115
|
-
|
116
|
-
up.on('click', '.person', function(event, element, data) {
|
117
|
-
console.log("This is %o who is %o years old", data.name, data.age)
|
118
|
-
})
|
119
|
-
|
120
|
-
\#\#\# Unbinding an event listener
|
121
|
-
|
122
|
-
`up.on()` returns a function that unbinds the event listeners when called:
|
123
|
-
|
124
|
-
// Define the listener
|
125
|
-
var listener = function(event) { ... }
|
126
|
-
|
127
|
-
// Binding the listener returns an unbind function
|
128
|
-
var unbind = up.on('click', listener)
|
129
|
-
|
130
|
-
// Unbind the listener
|
131
|
-
unbind()
|
132
|
-
|
133
|
-
There is also a function [`up.off()`](/up.off) which you can use for the same purpose:
|
134
|
-
|
135
|
-
// Define the listener
|
136
|
-
var listener = function(event) { ... }
|
137
|
-
|
138
|
-
// Bind the listener
|
139
|
-
up.on('click', listener)
|
140
|
-
|
141
|
-
// Unbind the listener
|
142
|
-
up.off('click', listener)
|
143
|
-
|
144
|
-
@function up.on
|
145
|
-
@param {Element|jQuery} [element=document]
|
146
|
-
The element on which to register the event listener.
|
147
|
-
|
148
|
-
If no element is given, the listener is registered on the `document`.
|
149
|
-
@param {string} events
|
150
|
-
A space-separated list of event names to bind to.
|
151
|
-
@param {string} [selector]
|
152
|
-
The selector of an element on which the event must be triggered.
|
153
|
-
Omit the selector to listen to all events with that name, regardless
|
154
|
-
of the event target.
|
155
|
-
@param {Function(event, [element], [data])} listener
|
156
|
-
The listener function that should be called.
|
157
|
-
|
158
|
-
The function takes the affected element as the first argument).
|
159
|
-
If the element has an [`up-data`](/up-data) attribute, its value is parsed as JSON
|
160
|
-
and passed as a second argument.
|
161
|
-
@return {Function()}
|
162
|
-
A function that unbinds the event listeners when called.
|
163
|
-
@stable
|
164
|
-
###
|
165
|
-
bind = (args...) ->
|
166
|
-
bindNow(args)
|
167
|
-
|
168
|
-
###**
|
169
|
-
Listens to an event on `document` or a given element.
|
170
|
-
The event handler is called with the event target as a
|
171
|
-
[jQuery collection](https://learn.jquery.com/using-jquery-core/jquery-object/).
|
172
|
-
|
173
|
-
If you're not using jQuery, use `up.on()` instead, which calls
|
174
|
-
event handlers with a native element.
|
175
|
-
|
176
|
-
\#\#\# Example
|
177
|
-
|
178
|
-
```
|
179
|
-
up.$on('click', 'a', function(event, $link) {
|
180
|
-
console.log("Click on a link with destination %s", $element.attr('href'))
|
181
|
-
})
|
182
|
-
```
|
183
|
-
|
184
|
-
@function up.$on
|
185
|
-
@param {Element|jQuery} [element=document]
|
186
|
-
The element on which to register the event listener.
|
187
|
-
|
188
|
-
If no element is given, the listener is registered on the `document`.
|
189
|
-
@param {string} events
|
190
|
-
A space-separated list of event names to bind to.
|
191
|
-
@param {string} [selector]
|
192
|
-
The selector of an element on which the event must be triggered.
|
193
|
-
Omit the selector to listen to all events with that name, regardless
|
194
|
-
of the event target.
|
195
|
-
@param {Function(event, [element], [data])} listener
|
196
|
-
The listener function that should be called.
|
197
|
-
|
198
|
-
The function takes the affected element as the first argument).
|
199
|
-
If the element has an [`up-data`](/up-data) attribute, its value is parsed as JSON
|
200
|
-
and passed as a second argument.
|
201
|
-
@return {Function()}
|
202
|
-
A function that unbinds the event listeners when called.
|
203
|
-
@stable
|
204
|
-
###
|
205
|
-
$bind = (args...) ->
|
206
|
-
bindNow(args, jQuery: true)
|
207
|
-
|
208
|
-
bindNow = (args, options) ->
|
209
|
-
# Silently discard any event handlers that are registered on unsupported
|
210
|
-
# browsers and return a no-op destructor
|
211
|
-
return (->) unless up.browser.isSupported()
|
212
|
-
|
213
|
-
up.EventListener.bind(args, options)
|
214
|
-
|
215
|
-
###**
|
216
|
-
Unbinds an event listener previously bound with [`up.on()`](/up.on).
|
217
|
-
|
218
|
-
\#\#\# Example
|
219
|
-
|
220
|
-
Let's say you are listing to clicks on `.button` elements:
|
221
|
-
|
222
|
-
var listener = function() { ... }
|
223
|
-
up.on('click', '.button', listener)
|
224
|
-
|
225
|
-
You can stop listening to these events like this:
|
226
|
-
|
227
|
-
up.off('click', '.button', listener)
|
228
|
-
|
229
|
-
Note that you need to pass `up.off()` a reference to the same listener function
|
230
|
-
that was passed to `up.on()` earlier.
|
231
|
-
|
232
|
-
@function up.off
|
233
|
-
@stable
|
234
|
-
###
|
235
|
-
unbind = (args...) ->
|
236
|
-
up.EventListener.unbind(args)
|
237
|
-
|
238
|
-
###**
|
239
|
-
Emits a event with the given name and properties.
|
240
|
-
|
241
|
-
The event will be triggered as an event on `document` or on the given element.
|
242
|
-
|
243
|
-
Other code can subscribe to events with that name using
|
244
|
-
[`Element#addEventListener()`](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener)
|
245
|
-
or [`up.on()`](/up.on).
|
246
|
-
|
247
|
-
\#\#\# Example
|
248
|
-
|
249
|
-
up.on('my:event', function(event) {
|
250
|
-
console.log(event.foo)
|
251
|
-
})
|
252
|
-
|
253
|
-
up.emit('my:event', { foo: 'bar' })
|
254
|
-
// Prints "bar" to the console
|
255
|
-
|
256
|
-
@function up.emit
|
257
|
-
@param {Element|jQuery} [target=document]
|
258
|
-
The element on which the event is triggered.
|
259
|
-
|
260
|
-
If omitted, the event will be emitted on the `document`.
|
261
|
-
@param {string} eventName
|
262
|
-
The name of the event.
|
263
|
-
@param {Object} [eventProps={}]
|
264
|
-
A list of properties to become part of the event object
|
265
|
-
that will be passed to listeners. Note that the event object
|
266
|
-
will by default include properties like `preventDefault()`
|
267
|
-
or `stopPropagation()`.
|
268
|
-
@param {string|Array} [eventProps.log=false]
|
269
|
-
A message to print to the console when the event is emitted.
|
270
|
-
|
271
|
-
Pass `true` to print a default message
|
272
|
-
@param {Element|jQuery} [eventProps.target=document]
|
273
|
-
The element on which the event is triggered.
|
274
|
-
@stable
|
275
|
-
###
|
276
|
-
emit = (args...) ->
|
277
|
-
if args[0].addEventListener
|
278
|
-
target = args.shift()
|
279
|
-
else if u.isJQuery(args[0])
|
280
|
-
target = e.get(args.shift())
|
281
|
-
|
282
|
-
eventName = args[0]
|
283
|
-
eventProps = args[1] || {}
|
284
|
-
|
285
|
-
if targetFromProps = u.pluckKey(eventProps, 'target')
|
286
|
-
target = targetFromProps
|
287
|
-
target ?= document
|
288
|
-
|
289
|
-
logEmission(eventName, eventProps)
|
290
|
-
|
291
|
-
event = buildEvent(eventName, eventProps)
|
292
|
-
target.dispatchEvent(event)
|
293
|
-
|
294
|
-
return event
|
295
|
-
|
296
|
-
buildEvent = (name, props) ->
|
297
|
-
event = document.createEvent('Event')
|
298
|
-
event.initEvent(name, true, true) # name, bubbles, cancelable
|
299
|
-
u.assign(event, props)
|
300
|
-
|
301
|
-
# IE11 does not set { defaultPrevented: true } after #preventDefault()
|
302
|
-
# was called on a custom event.
|
303
|
-
# See discussion here: https://stackoverflow.com/questions/23349191
|
304
|
-
if up.browser.isIE11()
|
305
|
-
event.preventDefault = ->
|
306
|
-
Object.defineProperty(event, 'defaultPrevented', get: -> true)
|
307
|
-
|
308
|
-
event
|
309
|
-
|
310
|
-
logEmission = (eventName, eventProps) ->
|
311
|
-
return unless up.log.isEnabled()
|
312
|
-
|
313
|
-
message = u.pluckKey(eventProps, 'log')
|
314
|
-
|
315
|
-
if u.isArray(message)
|
316
|
-
[message, messageArgs...] = message
|
317
|
-
else
|
318
|
-
messageArgs = []
|
319
|
-
|
320
|
-
if u.isString(message)
|
321
|
-
if u.isPresent(eventProps)
|
322
|
-
up.puts "#{message} (%s (%o))", messageArgs..., eventName, eventProps
|
323
|
-
else
|
324
|
-
up.puts "#{message} (%s)", messageArgs..., eventName
|
325
|
-
else if message == true
|
326
|
-
if u.isPresent(eventProps)
|
327
|
-
up.puts 'Event %s (%o)', eventName, eventProps
|
328
|
-
else
|
329
|
-
up.puts 'Event %s', eventName
|
330
|
-
|
331
|
-
###**
|
332
|
-
[Emits an event](/up.emit) and returns whether no listener
|
333
|
-
has prevented the default action.
|
334
|
-
|
335
|
-
@function up.event.nobodyPrevents
|
336
|
-
@param {string} eventName
|
337
|
-
@param {Object} eventProps
|
338
|
-
@param {string|Array} [eventProps.log]
|
339
|
-
@return {boolean}
|
340
|
-
whether no listener has prevented the default action
|
341
|
-
@experimental
|
342
|
-
###
|
343
|
-
nobodyPrevents = (args...) ->
|
344
|
-
event = emit(args...)
|
345
|
-
not event.defaultPrevented
|
346
|
-
|
347
|
-
###**
|
348
|
-
[Emits](/up.emit) the given event and returns a promise
|
349
|
-
that will be fulfilled if no listener has prevented the default action.
|
350
|
-
|
351
|
-
If any listener prevented the default listener
|
352
|
-
the returned promise will never be resolved.
|
353
|
-
|
354
|
-
@function up.event.whenEmitted
|
355
|
-
@param {string} eventName
|
356
|
-
@param {Object} eventProps
|
357
|
-
@param {string|Array} [eventProps.message]
|
358
|
-
@return {Promise}
|
359
|
-
@internal
|
360
|
-
###
|
361
|
-
whenEmitted = (args...) ->
|
362
|
-
new Promise (resolve, reject) ->
|
363
|
-
if nobodyPrevents(args...)
|
364
|
-
resolve()
|
365
|
-
else
|
366
|
-
reject(new Error("Event #{args[0]} was prevented"))
|
367
|
-
|
368
|
-
###**
|
369
|
-
Registers an event listener to be called when the user
|
370
|
-
presses the `Escape` key.
|
371
|
-
|
372
|
-
@function up.event.onEscape
|
373
|
-
@param {Function(event)} listener
|
374
|
-
The listener function to register.
|
375
|
-
@return {Function()}
|
376
|
-
A function that unbinds the event listeners when called.
|
377
|
-
@experimental
|
378
|
-
###
|
379
|
-
onEscape = (listener) ->
|
380
|
-
bind('keydown', 'body', (event) ->
|
381
|
-
if u.escapePressed(event)
|
382
|
-
listener(event)
|
383
|
-
)
|
384
|
-
|
385
|
-
###**
|
386
|
-
Prevents the event from bubbling up the DOM.
|
387
|
-
Also prevents other event handlers bound on the same element.
|
388
|
-
Also prevents the event's default action.
|
389
|
-
|
390
|
-
\#\#\# Example
|
391
|
-
|
392
|
-
up.on('click', 'link.disabled', function(event) {
|
393
|
-
up.event.halt(event)
|
394
|
-
})
|
395
|
-
|
396
|
-
@function up.event.halt
|
397
|
-
@param {Event} event
|
398
|
-
@experimental
|
399
|
-
###
|
400
|
-
halt = (event) ->
|
401
|
-
event.stopImmediatePropagation()
|
402
|
-
event.preventDefault()
|
403
|
-
|
404
|
-
###**
|
405
|
-
@function up.event.consumeAction
|
406
|
-
@internal
|
407
|
-
###
|
408
|
-
consumeAction = (event) ->
|
409
|
-
# Halt the event chain to stop duplicate processing of this user interaction.
|
410
|
-
halt(event)
|
411
|
-
unless event.type == 'up:action:consumed'
|
412
|
-
# Although we have consumed this action and halted the event chain,
|
413
|
-
# other components might still need to react. E.g. a popup needs to close when
|
414
|
-
# an outside link consumes the user click. So we emit another event for that.
|
415
|
-
emit(event.target, 'up:action:consumed', log: false)
|
416
|
-
|
417
|
-
onReady = (callback) ->
|
418
|
-
# Values are "loading", "interactive" and "completed".
|
419
|
-
# https://developer.mozilla.org/en-US/docs/Web/API/Document/readyState
|
420
|
-
if document.readyState != 'loading'
|
421
|
-
callback()
|
422
|
-
else
|
423
|
-
document.addEventListener('DOMContentLoaded', callback)
|
424
|
-
|
425
|
-
bind 'up:framework:reset', reset
|
426
|
-
|
427
|
-
<% if ENV['JS_KNIFE'] %>knife: eval(Knife.point)<% end %>
|
428
|
-
on: bind # can't name symbols `on` in Coffeescript
|
429
|
-
$on: $bind
|
430
|
-
off: unbind # can't name symbols `off` in Coffeescript
|
431
|
-
emit: emit
|
432
|
-
nobodyPrevents: nobodyPrevents
|
433
|
-
whenEmitted: whenEmitted
|
434
|
-
onEscape: onEscape
|
435
|
-
halt: halt
|
436
|
-
consumeAction: consumeAction
|
437
|
-
onReady: onReady
|
438
|
-
|
439
|
-
up.on = up.event.on
|
440
|
-
up.$on = up.event.$on
|
441
|
-
up.off = up.event.off
|
442
|
-
up.$off = up.event.off # it's the same as up.off()
|
443
|
-
up.emit = up.event.emit
|
444
|
-
|
445
|
-
up.legacy.renamedModule 'bus', 'event'
|
@@ -1,353 +0,0 @@
|
|
1
|
-
###**
|
2
|
-
Navigation feedback
|
3
|
-
===================
|
4
|
-
|
5
|
-
The `up.feedback` module adds useful CSS classes to links while they are loading,
|
6
|
-
or when they point to the current URL. By styling these classes you may
|
7
|
-
provide instant feedback to user interactions. This improves the perceived speed of your interface.
|
8
|
-
|
9
|
-
|
10
|
-
\#\#\# Example
|
11
|
-
|
12
|
-
Let's say we have an navigation bar with two links, pointing to `/foo` and `/bar` respectively:
|
13
|
-
|
14
|
-
<div up-nav>
|
15
|
-
<a href="/foo" up-follow>Foo</a>
|
16
|
-
<a href="/bar" up-follow>Bar</a>
|
17
|
-
</div>
|
18
|
-
|
19
|
-
If the current URL is `/foo`, the first link is automatically marked with an [`.up-current`](/a.up-current) class:
|
20
|
-
|
21
|
-
<div up-nav>
|
22
|
-
<a href="/foo" up-follow class="up-current">Foo</a>
|
23
|
-
<a href="/bar" up-follow>Bar</a>
|
24
|
-
</div>
|
25
|
-
|
26
|
-
When the user clicks on the `/bar` link, the link will receive the [`up-active`](/a.up-active) class while it is waiting
|
27
|
-
for the server to respond:
|
28
|
-
|
29
|
-
<div up-nav>
|
30
|
-
<a href="/foo" up-follow class="up-current">Foo</a>
|
31
|
-
<a href="/bar" up-follow class="up-active">Bar</a>
|
32
|
-
</div>
|
33
|
-
|
34
|
-
Once the response is received the URL will change to `/bar` and the `up-active` class is removed:
|
35
|
-
|
36
|
-
<div up-nav>
|
37
|
-
<a href="/foo" up-follow>Foo</a>
|
38
|
-
<a href="/bar" up-follow class="up-current">Bar</a>
|
39
|
-
</div>
|
40
|
-
|
41
|
-
|
42
|
-
@module up.feedback
|
43
|
-
###
|
44
|
-
up.feedback = do ->
|
45
|
-
|
46
|
-
u = up.util
|
47
|
-
e = up.element
|
48
|
-
|
49
|
-
###**
|
50
|
-
Sets default options for this module.
|
51
|
-
|
52
|
-
@property up.feedback.config
|
53
|
-
@param {Array<string>} [config.currentClasses]
|
54
|
-
An array of classes to set on [links that point the current location](/a.up-current).
|
55
|
-
@param {Array<string>} [config.navs]
|
56
|
-
An array of CSS selectors that match [navigation components](/up-nav).
|
57
|
-
@stable
|
58
|
-
###
|
59
|
-
config = new up.Config
|
60
|
-
currentClasses: ['up-current']
|
61
|
-
navs: ['[up-nav]']
|
62
|
-
|
63
|
-
previousUrlSet = undefined
|
64
|
-
currentUrlSet = undefined
|
65
|
-
|
66
|
-
reset = ->
|
67
|
-
config.reset()
|
68
|
-
previousUrlSet = undefined
|
69
|
-
currentUrlSet = undefined
|
70
|
-
|
71
|
-
CLASS_ACTIVE = 'up-active'
|
72
|
-
SELECTOR_LINK = 'a, [up-href]'
|
73
|
-
|
74
|
-
navSelector = ->
|
75
|
-
config.navs.join(',')
|
76
|
-
|
77
|
-
normalizeUrl = (url) ->
|
78
|
-
if u.isPresent(url)
|
79
|
-
u.normalizeUrl(url, stripTrailingSlash: true)
|
80
|
-
|
81
|
-
sectionUrls = (section) ->
|
82
|
-
# Check if we have computed the URLs before.
|
83
|
-
# Computation is sort of expensive (multiplied by number of links),
|
84
|
-
# so we cache the results in a data attribute.
|
85
|
-
unless urls = section.upNormalizedUrls
|
86
|
-
urls = buildSectionUrls(section)
|
87
|
-
section.upNormalizedUrls = urls
|
88
|
-
urls
|
89
|
-
|
90
|
-
buildSectionUrls = (section) ->
|
91
|
-
urls = []
|
92
|
-
|
93
|
-
# A link with an unsafe method will never be higlighted with .up-current,
|
94
|
-
# so we cache an empty array.
|
95
|
-
if up.link.isSafe(section)
|
96
|
-
for attr in ['href', 'up-href', 'up-alias']
|
97
|
-
if value = section.getAttribute(attr)
|
98
|
-
# Allow to include multiple space-separated URLs in [up-alias]
|
99
|
-
for url in u.splitValues(value)
|
100
|
-
unless url == '#'
|
101
|
-
url = normalizeUrl(url)
|
102
|
-
urls.push(url)
|
103
|
-
urls
|
104
|
-
|
105
|
-
buildCurrentUrlSet = ->
|
106
|
-
urls = [
|
107
|
-
up.browser.url(), # The URL displayed in the address bar
|
108
|
-
up.modal.url(), # Even when a modal does not change the address bar, we consider the URL of its content
|
109
|
-
up.modal.coveredUrl(), # The URL of the page behind the modal
|
110
|
-
up.popup.url(), # Even when a popup does not change the address bar, we consider the URL of its content
|
111
|
-
up.popup.coveredUrl() # The URL of the page behind the popup
|
112
|
-
]
|
113
|
-
new up.UrlSet(urls, { normalizeUrl })
|
114
|
-
|
115
|
-
updateAllNavigationSectionsIfLocationChanged = ->
|
116
|
-
previousUrlSet = currentUrlSet
|
117
|
-
currentUrlSet = buildCurrentUrlSet()
|
118
|
-
unless u.isEqual(currentUrlSet, previousUrlSet)
|
119
|
-
updateAllNavigationSections(document.body)
|
120
|
-
|
121
|
-
updateAllNavigationSections = (root) ->
|
122
|
-
navs = e.subtree(root, navSelector())
|
123
|
-
sections = u.flatMap navs, (nav) -> e.subtree(nav, SELECTOR_LINK)
|
124
|
-
updateCurrentClassForLinks(sections)
|
125
|
-
|
126
|
-
updateNavigationSectionsInNewFragment = (fragment) ->
|
127
|
-
if e.closest(fragment, navSelector())
|
128
|
-
# If the new fragment is an [up-nav], or if the new fragment is a child of an [up-nav],
|
129
|
-
# all links in the new fragment are considered sections that we need to update.
|
130
|
-
# Note that:
|
131
|
-
# - The [up-nav] element might not be part of this update.
|
132
|
-
# It might already be in the DOM, and only a child was updated.
|
133
|
-
# - The fragment might be a link itself
|
134
|
-
# - We do not need to update sibling links of fragment that have been processed before.
|
135
|
-
sections = e.subtree(fragment, SELECTOR_LINK)
|
136
|
-
updateCurrentClassForLinks(sections)
|
137
|
-
else
|
138
|
-
updateAllNavigationSections(fragment)
|
139
|
-
|
140
|
-
updateCurrentClassForLinks = (links) ->
|
141
|
-
currentUrlSet ||= buildCurrentUrlSet()
|
142
|
-
u.each links, (link) ->
|
143
|
-
urls = sectionUrls(link)
|
144
|
-
|
145
|
-
classList = link.classList
|
146
|
-
if currentUrlSet.matchesAny(urls)
|
147
|
-
for klass in config.currentClasses
|
148
|
-
# Once we drop IE11 support in 2020 we can call add() with multiple arguments
|
149
|
-
classList.add(klass)
|
150
|
-
else
|
151
|
-
for klass in config.currentClasses
|
152
|
-
# Once we drop IE11 support in 2020 we can call remove() with multiple arguments
|
153
|
-
classList.remove(klass)
|
154
|
-
|
155
|
-
###**
|
156
|
-
@function findActivatableArea
|
157
|
-
@param {string|Element|jQuery} elementOrSelector
|
158
|
-
@internal
|
159
|
-
###
|
160
|
-
findActivatableArea = (element) ->
|
161
|
-
element = e.get(element)
|
162
|
-
# Try to enlarge links that are expanded with [up-expand] on a surrounding container.
|
163
|
-
# Note that the expression below is not the same as e.closest(area, SELECTOR_LINK)!
|
164
|
-
e.ancestor(element, SELECTOR_LINK) || element
|
165
|
-
|
166
|
-
###**
|
167
|
-
Marks the given element as currently loading, by assigning the CSS class [`up-active`](/a.up-active).
|
168
|
-
|
169
|
-
This happens automatically when following links or submitting forms through the Unpoly API.
|
170
|
-
Use this function if you make custom network calls from your own JavaScript code.
|
171
|
-
|
172
|
-
If the given element is a link within an [expanded click area](/up-expand),
|
173
|
-
the class will be assigned to the expanded area.
|
174
|
-
|
175
|
-
\#\#\# Example
|
176
|
-
|
177
|
-
var button = document.querySelector('button')
|
178
|
-
|
179
|
-
button.addEventListener('click', () => {
|
180
|
-
up.feedback.start(button)
|
181
|
-
up.request(...).then(() => {
|
182
|
-
up.feedback.stop(button)
|
183
|
-
})
|
184
|
-
})
|
185
|
-
|
186
|
-
@method up.feedback.start
|
187
|
-
@param {Element|jQuery|string} element
|
188
|
-
The element to mark as active
|
189
|
-
@internal
|
190
|
-
###
|
191
|
-
start = (element) ->
|
192
|
-
findActivatableArea(element).classList.add(CLASS_ACTIVE)
|
193
|
-
|
194
|
-
###**
|
195
|
-
Links that are currently [loading through Unpoly](/form-up-target)
|
196
|
-
are assigned the `up-active` class automatically.
|
197
|
-
Style `.up-active` in your CSS to improve the perceived responsiveness
|
198
|
-
of your user interface.
|
199
|
-
|
200
|
-
The `up-active` class will be removed when the link is done loading.
|
201
|
-
|
202
|
-
\#\#\# Example
|
203
|
-
|
204
|
-
We have a link:
|
205
|
-
|
206
|
-
<a href="/foo" up-follow>Foo</a>
|
207
|
-
|
208
|
-
The user clicks on the link. While the request is loading,
|
209
|
-
the link has the `up-active` class:
|
210
|
-
|
211
|
-
<a href="/foo" up-follow class="up-active">Foo</a>
|
212
|
-
|
213
|
-
Once the link destination has loaded and rendered, the `up-active` class
|
214
|
-
is removed and the [`up-current`](/a.up-current) class is added:
|
215
|
-
|
216
|
-
<a href="/foo" up-follow class="up-current">Foo</a>
|
217
|
-
|
218
|
-
@selector a.up-active
|
219
|
-
@stable
|
220
|
-
###
|
221
|
-
|
222
|
-
###**
|
223
|
-
Forms that are currently [loading through Unpoly](/a-up-target)
|
224
|
-
are assigned the `up-active` class automatically.
|
225
|
-
Style `.up-active` in your CSS to improve the perceived responsiveness
|
226
|
-
of your user interface.
|
227
|
-
|
228
|
-
The `up-active` class will be removed as soon as the response to the
|
229
|
-
form submission has been received.
|
230
|
-
|
231
|
-
\#\#\# Example
|
232
|
-
|
233
|
-
We have a form:
|
234
|
-
|
235
|
-
<form up-target=".foo">
|
236
|
-
<button type="submit">Submit</button>
|
237
|
-
</form>
|
238
|
-
|
239
|
-
The user clicks on the submit button. While the form is being submitted
|
240
|
-
and waiting for the server to respond, the form has the `up-active` class:
|
241
|
-
|
242
|
-
<form up-target=".foo" class="up-active">
|
243
|
-
<button type="submit">Submit</button>
|
244
|
-
</form>
|
245
|
-
|
246
|
-
Once the link destination has loaded and rendered, the `up-active` class
|
247
|
-
is removed.
|
248
|
-
|
249
|
-
@selector form.up-active
|
250
|
-
@stable
|
251
|
-
###
|
252
|
-
|
253
|
-
###**
|
254
|
-
Marks the given element as no longer loading, by removing the CSS class [`up-active`](/a.up-active).
|
255
|
-
|
256
|
-
This happens automatically when network requests initiated by the Unpoly API have completed.
|
257
|
-
Use this function if you make custom network calls from your own JavaScript code.
|
258
|
-
|
259
|
-
@function up.feedback.stop
|
260
|
-
@param {Element|jQuery|string} element
|
261
|
-
The link or form that has finished loading.
|
262
|
-
@internal
|
263
|
-
###
|
264
|
-
stop = (element) ->
|
265
|
-
findActivatableArea(element).classList.remove(CLASS_ACTIVE)
|
266
|
-
|
267
|
-
###**
|
268
|
-
Marks this element as a navigation component, such as a menu or navigation bar.
|
269
|
-
|
270
|
-
When a link within an `[up-nav]` element points to the current location, it is assigned the `.up-current` class. When the browser navigates to another location, the class is removed automatically.
|
271
|
-
|
272
|
-
You may also assign `[up-nav]` to an individual link instead of an navigational container.
|
273
|
-
|
274
|
-
If you don't want to manually add this attribute to every navigational element, you can configure selectors to automatically match your navigation components in [`up.feedback.config.navs`](/up.feedback.config#config.navs).
|
275
|
-
|
276
|
-
|
277
|
-
\#\#\# Example
|
278
|
-
|
279
|
-
Let's take a simple menu with two links. The menu has been marked with the `[up-nav]` attribute:
|
280
|
-
|
281
|
-
<div up-nav>
|
282
|
-
<a href="/foo">Foo</a>
|
283
|
-
<a href="/bar">Bar</a>
|
284
|
-
</div>
|
285
|
-
|
286
|
-
If the browser location changes to `/foo`, the first link is marked as `.up-current`:
|
287
|
-
|
288
|
-
<div up-nav>
|
289
|
-
<a href="/foo" class="up-current">Foo</a>
|
290
|
-
<a href="/bar">Bar</a>
|
291
|
-
</div>
|
292
|
-
|
293
|
-
If the browser location changes to `/bar`, the first link automatically loses its `.up-current` class. Now the second link is marked as `.up-current`:
|
294
|
-
|
295
|
-
<div up-nav>
|
296
|
-
<a href="/foo">Foo</a>
|
297
|
-
<a href="/bar" class="up-current">Bar</a>
|
298
|
-
</div>
|
299
|
-
|
300
|
-
|
301
|
-
\#\#\# What is considered to be "current"?
|
302
|
-
|
303
|
-
The current location is considered to be either:
|
304
|
-
|
305
|
-
- the URL displayed in the browser window's location bar
|
306
|
-
- the source URL of a [modal dialog](/up.modal)
|
307
|
-
- the URL of the page behind a [modal dialog](/up.modal)
|
308
|
-
- the source URL of a [popup overlay](/up.popup)
|
309
|
-
- the URL of the content behind a [popup overlay](/up.popup)
|
310
|
-
|
311
|
-
A link matches the current location (and is marked as `.up-current`) if it matches either:
|
312
|
-
|
313
|
-
- the link's `href` attribute
|
314
|
-
- the link's `up-href` attribute
|
315
|
-
- a space-separated list of URLs in the link's `up-alias` attribute
|
316
|
-
|
317
|
-
\#\#\# Matching URL by pattern
|
318
|
-
|
319
|
-
You can mark a link as `.up-current` whenever the current URL matches a prefix or suffix.
|
320
|
-
To do so, include an asterisk (`*`) in the `up-alias` attribute.
|
321
|
-
|
322
|
-
For instance, the following `[up-nav]` link is highlighted for both `/reports` and `/reports/123`:
|
323
|
-
|
324
|
-
<a up-nav href="/reports" up-alias="/reports/*">Reports</a>
|
325
|
-
|
326
|
-
@selector [up-nav]
|
327
|
-
@stable
|
328
|
-
###
|
329
|
-
|
330
|
-
###**
|
331
|
-
When a link within an `[up-nav]` element points to the current location, it is assigned the `.up-current` class.
|
332
|
-
|
333
|
-
See [`[up-nav]`](/up-nav) for more documentation and examples.
|
334
|
-
|
335
|
-
@selector [up-nav] a.up-current
|
336
|
-
@stable
|
337
|
-
###
|
338
|
-
|
339
|
-
# Even when the modal or popup does not change history, we consider the URLs of the content it displays.
|
340
|
-
up.on 'up:history:pushed up:history:replaced up:history:restored up:modal:opened up:modal:closed up:popup:opened up:popup:closed', (event) -> # take 1 arg to prevent data parsing
|
341
|
-
updateAllNavigationSectionsIfLocationChanged()
|
342
|
-
|
343
|
-
up.on 'up:fragment:inserted', (event, newFragment) ->
|
344
|
-
updateNavigationSectionsInNewFragment(newFragment)
|
345
|
-
|
346
|
-
# The framework is reset between tests
|
347
|
-
up.on 'up:framework:reset', reset
|
348
|
-
|
349
|
-
config: config
|
350
|
-
start: start
|
351
|
-
stop: stop
|
352
|
-
|
353
|
-
up.legacy.renamedModule 'navigation', 'feedback'
|