unpoly-rails 0.62.1 → 2.0.0.pre.rc6

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.

Files changed (340) hide show
  1. checksums.yaml +4 -4
  2. data/.yardopts +1 -1
  3. data/CHANGELOG.md +60 -1
  4. data/README.md +3 -11
  5. data/README_RAILS.md +295 -14
  6. data/dist/unpoly-bootstrap3.css +9 -14
  7. data/dist/unpoly-bootstrap3.js +4 -18
  8. data/dist/unpoly-bootstrap3.min.css +1 -1
  9. data/dist/unpoly-bootstrap3.min.js +1 -1
  10. data/dist/unpoly-bootstrap4.css +9 -0
  11. data/dist/unpoly-bootstrap4.js +16 -0
  12. data/dist/unpoly-bootstrap4.min.css +1 -0
  13. data/dist/unpoly-bootstrap4.min.js +1 -0
  14. data/dist/unpoly-bootstrap5.css +9 -0
  15. data/dist/unpoly-bootstrap5.js +14 -0
  16. data/dist/unpoly-bootstrap5.min.css +1 -0
  17. data/dist/unpoly-bootstrap5.min.js +1 -0
  18. data/dist/unpoly-migrate.js +1225 -0
  19. data/dist/unpoly-migrate.min.js +1 -0
  20. data/dist/unpoly.css +109 -140
  21. data/dist/unpoly.js +15805 -10558
  22. data/dist/unpoly.min.css +1 -1
  23. data/dist/unpoly.min.js +6 -4
  24. data/lib/unpoly-rails.rb +9 -3
  25. data/lib/unpoly/rails/change.rb +372 -0
  26. data/lib/unpoly/rails/change/cache.rb +26 -0
  27. data/lib/unpoly/rails/change/context.rb +80 -0
  28. data/lib/unpoly/rails/change/field.rb +117 -0
  29. data/lib/unpoly/rails/change/field_definition.rb +74 -0
  30. data/lib/unpoly/rails/change/layer.rb +60 -0
  31. data/lib/unpoly/rails/controller.rb +47 -0
  32. data/lib/unpoly/rails/error.rb +5 -0
  33. data/lib/unpoly/rails/request_echo_headers.rb +2 -2
  34. data/lib/unpoly/rails/version.rb +1 -1
  35. data/lib/unpoly/tasks.rb +55 -0
  36. metadata +43 -313
  37. data/.gitignore +0 -10
  38. data/.ruby-version +0 -1
  39. data/Gemfile +0 -8
  40. data/Gemfile.lock +0 -45
  41. data/Rakefile +0 -145
  42. data/bower.json +0 -27
  43. data/design/animation-ghosting.txt +0 -72
  44. data/design/design.txt +0 -34
  45. data/design/draft.html.erb +0 -48
  46. data/design/draft.rb +0 -9
  47. data/design/es6.js +0 -32
  48. data/design/ghost-debugging.txt +0 -118
  49. data/design/homepage.txt +0 -236
  50. data/design/ie11.txt +0 -9
  51. data/design/measure_import_node.js +0 -330
  52. data/design/measure_jquery/element_list.js +0 -41
  53. data/design/measure_jquery/up.on_vs_addEventListener.js +0 -56
  54. data/design/positioning.txt +0 -28
  55. data/design/query-params-in-form-actions/cases.html +0 -125
  56. data/design/rename.txt +0 -0
  57. data/design/test_rejected_promise.txt +0 -5
  58. data/design/unpoly errors.txt +0 -19
  59. data/lib/assets/javascripts/unpoly-bootstrap3.coffee +0 -2
  60. data/lib/assets/javascripts/unpoly-bootstrap3/feedback-ext.coffee +0 -5
  61. data/lib/assets/javascripts/unpoly-bootstrap3/form-ext.coffee +0 -1
  62. data/lib/assets/javascripts/unpoly-bootstrap3/modal-ext.coffee +0 -14
  63. data/lib/assets/javascripts/unpoly-bootstrap3/viewport-ext.coffee +0 -5
  64. data/lib/assets/javascripts/unpoly.coffee +0 -28
  65. data/lib/assets/javascripts/unpoly/browser.coffee.erb +0 -240
  66. data/lib/assets/javascripts/unpoly/classes/body_shifter.coffee +0 -45
  67. data/lib/assets/javascripts/unpoly/classes/cache.coffee +0 -127
  68. data/lib/assets/javascripts/unpoly/classes/compile_pass.coffee +0 -93
  69. data/lib/assets/javascripts/unpoly/classes/config.coffee +0 -9
  70. data/lib/assets/javascripts/unpoly/classes/css_transition.coffee +0 -118
  71. data/lib/assets/javascripts/unpoly/classes/divertible_chain.coffee +0 -39
  72. data/lib/assets/javascripts/unpoly/classes/event_listener.coffee +0 -116
  73. data/lib/assets/javascripts/unpoly/classes/extract_cascade.coffee +0 -86
  74. data/lib/assets/javascripts/unpoly/classes/extract_plan.coffee +0 -111
  75. data/lib/assets/javascripts/unpoly/classes/field_observer.coffee +0 -80
  76. data/lib/assets/javascripts/unpoly/classes/focus_follower.coffee +0 -29
  77. data/lib/assets/javascripts/unpoly/classes/follow_variant.coffee +0 -64
  78. data/lib/assets/javascripts/unpoly/classes/html_parser.coffee +0 -46
  79. data/lib/assets/javascripts/unpoly/classes/motion_controller.coffee +0 -157
  80. data/lib/assets/javascripts/unpoly/classes/params.coffee.erb +0 -544
  81. data/lib/assets/javascripts/unpoly/classes/record.coffee +0 -22
  82. data/lib/assets/javascripts/unpoly/classes/rect.js +0 -21
  83. data/lib/assets/javascripts/unpoly/classes/request.coffee +0 -246
  84. data/lib/assets/javascripts/unpoly/classes/response.coffee +0 -157
  85. data/lib/assets/javascripts/unpoly/classes/reveal_motion.coffee +0 -102
  86. data/lib/assets/javascripts/unpoly/classes/scroll_motion.coffee +0 -67
  87. data/lib/assets/javascripts/unpoly/classes/selector.coffee +0 -60
  88. data/lib/assets/javascripts/unpoly/classes/store/memory.coffee +0 -26
  89. data/lib/assets/javascripts/unpoly/classes/store/session.coffee +0 -59
  90. data/lib/assets/javascripts/unpoly/classes/tether.coffee +0 -105
  91. data/lib/assets/javascripts/unpoly/classes/url_set.coffee +0 -32
  92. data/lib/assets/javascripts/unpoly/cookie.coffee +0 -56
  93. data/lib/assets/javascripts/unpoly/element.coffee.erb +0 -1126
  94. data/lib/assets/javascripts/unpoly/event.coffee.erb +0 -445
  95. data/lib/assets/javascripts/unpoly/feedback.coffee +0 -353
  96. data/lib/assets/javascripts/unpoly/form.coffee.erb +0 -1075
  97. data/lib/assets/javascripts/unpoly/fragment.coffee.erb +0 -928
  98. data/lib/assets/javascripts/unpoly/framework.coffee +0 -67
  99. data/lib/assets/javascripts/unpoly/history.coffee +0 -268
  100. data/lib/assets/javascripts/unpoly/legacy.coffee +0 -60
  101. data/lib/assets/javascripts/unpoly/link.coffee.erb +0 -622
  102. data/lib/assets/javascripts/unpoly/log.coffee +0 -248
  103. data/lib/assets/javascripts/unpoly/modal.coffee.erb +0 -827
  104. data/lib/assets/javascripts/unpoly/motion.coffee.erb +0 -668
  105. data/lib/assets/javascripts/unpoly/namespace.coffee.erb +0 -5
  106. data/lib/assets/javascripts/unpoly/popup.coffee.erb +0 -515
  107. data/lib/assets/javascripts/unpoly/protocol.coffee +0 -298
  108. data/lib/assets/javascripts/unpoly/proxy.coffee +0 -672
  109. data/lib/assets/javascripts/unpoly/radio.coffee +0 -60
  110. data/lib/assets/javascripts/unpoly/rails.coffee +0 -24
  111. data/lib/assets/javascripts/unpoly/syntax.coffee.erb +0 -476
  112. data/lib/assets/javascripts/unpoly/toast.coffee +0 -67
  113. data/lib/assets/javascripts/unpoly/tooltip.coffee +0 -276
  114. data/lib/assets/javascripts/unpoly/util.coffee.erb +0 -1676
  115. data/lib/assets/javascripts/unpoly/viewport.coffee.erb +0 -830
  116. data/lib/assets/stylesheets/unpoly-bootstrap3.sass +0 -1
  117. data/lib/assets/stylesheets/unpoly-bootstrap3/modal-ext.sass +0 -27
  118. data/lib/assets/stylesheets/unpoly.sass +0 -1
  119. data/lib/assets/stylesheets/unpoly/close.sass +0 -2
  120. data/lib/assets/stylesheets/unpoly/dom.sass +0 -5
  121. data/lib/assets/stylesheets/unpoly/layout.sass +0 -2
  122. data/lib/assets/stylesheets/unpoly/link.sass +0 -2
  123. data/lib/assets/stylesheets/unpoly/modal.sass +0 -116
  124. data/lib/assets/stylesheets/unpoly/popup.sass +0 -7
  125. data/lib/assets/stylesheets/unpoly/toast.sass +0 -33
  126. data/lib/assets/stylesheets/unpoly/tooltip.sass +0 -62
  127. data/lib/unpoly/rails/inspector.rb +0 -149
  128. data/lib/unpoly/rails/inspector_accessor.rb +0 -30
  129. data/package.json +0 -38
  130. data/spec_app/.firefox-version +0 -1
  131. data/spec_app/.gitignore +0 -17
  132. data/spec_app/.rspec +0 -2
  133. data/spec_app/Gemfile +0 -30
  134. data/spec_app/Gemfile.lock +0 -229
  135. data/spec_app/README.rdoc +0 -28
  136. data/spec_app/Rakefile +0 -6
  137. data/spec_app/app/assets/images/.keep +0 -0
  138. data/spec_app/app/assets/images/favicon.png +0 -0
  139. data/spec_app/app/assets/images/grid.png +0 -0
  140. data/spec_app/app/assets/javascripts/bootstrap_manifest.coffee +0 -6
  141. data/spec_app/app/assets/javascripts/integration_test.coffee +0 -6
  142. data/spec_app/app/assets/javascripts/jasmine_specs.coffee +0 -6
  143. data/spec_app/app/assets/stylesheets/_helpers.sass +0 -5
  144. data/spec_app/app/assets/stylesheets/bootstrap_manifest.sass +0 -2
  145. data/spec_app/app/assets/stylesheets/integration_test.sass +0 -88
  146. data/spec_app/app/assets/stylesheets/jasmine_specs.sass +0 -20
  147. data/spec_app/app/controllers/application_controller.rb +0 -14
  148. data/spec_app/app/controllers/binding_test_controller.rb +0 -51
  149. data/spec_app/app/controllers/compiler_test_controller.rb +0 -5
  150. data/spec_app/app/controllers/css_test_controller.rb +0 -5
  151. data/spec_app/app/controllers/error_test_controller.rb +0 -5
  152. data/spec_app/app/controllers/form_test/basics_controller.rb +0 -14
  153. data/spec_app/app/controllers/form_test/redirects_controller.rb +0 -17
  154. data/spec_app/app/controllers/form_test/uploads_controller.rb +0 -15
  155. data/spec_app/app/controllers/hash_test_controller.rb +0 -5
  156. data/spec_app/app/controllers/method_test_controller.rb +0 -16
  157. data/spec_app/app/controllers/motion_test_controller.rb +0 -5
  158. data/spec_app/app/controllers/pages_controller.rb +0 -9
  159. data/spec_app/app/controllers/replace_test_controller.rb +0 -5
  160. data/spec_app/app/controllers/reveal_test_controller.rb +0 -5
  161. data/spec_app/app/controllers/scroll_test_controller.rb +0 -5
  162. data/spec_app/app/helpers/application_helper.rb +0 -2
  163. data/spec_app/app/mailers/.keep +0 -0
  164. data/spec_app/app/models/concerns/.keep +0 -0
  165. data/spec_app/app/views/compiler_test/timestamp.erb +0 -9
  166. data/spec_app/app/views/css_test/modal.erb +0 -47
  167. data/spec_app/app/views/css_test/modal_contents.erb +0 -5
  168. data/spec_app/app/views/css_test/modal_contents_wide.erb +0 -5
  169. data/spec_app/app/views/css_test/popup.erb +0 -81
  170. data/spec_app/app/views/css_test/popup_contents.erb +0 -5
  171. data/spec_app/app/views/css_test/tooltip.erb +0 -48
  172. data/spec_app/app/views/error_test/trigger.erb +0 -80
  173. data/spec_app/app/views/error_test/unexpected_response.erb +0 -3
  174. data/spec_app/app/views/form_test/basics/new.erb +0 -60
  175. data/spec_app/app/views/form_test/redirects/new.erb +0 -27
  176. data/spec_app/app/views/form_test/redirects/target.erb +0 -4
  177. data/spec_app/app/views/form_test/submission_result.erb +0 -30
  178. data/spec_app/app/views/form_test/uploads/new.erb +0 -44
  179. data/spec_app/app/views/hash_test/unpoly.erb +0 -30
  180. data/spec_app/app/views/hash_test/vanilla.erb +0 -13
  181. data/spec_app/app/views/layouts/integration_test.erb +0 -22
  182. data/spec_app/app/views/layouts/jasmine_rails/spec_runner.html.erb +0 -20
  183. data/spec_app/app/views/method_test/form_target.erb +0 -17
  184. data/spec_app/app/views/method_test/page1.erb +0 -11
  185. data/spec_app/app/views/method_test/page2.erb +0 -6
  186. data/spec_app/app/views/motion_test/animations.erb +0 -16
  187. data/spec_app/app/views/motion_test/transitions.erb +0 -13
  188. data/spec_app/app/views/pages/start.erb +0 -79
  189. data/spec_app/app/views/replace_test/_nav.erb +0 -6
  190. data/spec_app/app/views/replace_test/page1.erb +0 -14
  191. data/spec_app/app/views/replace_test/page2.erb +0 -14
  192. data/spec_app/app/views/replace_test/table.erb +0 -16
  193. data/spec_app/app/views/reveal_test/long1.erb +0 -17
  194. data/spec_app/app/views/reveal_test/long2.erb +0 -17
  195. data/spec_app/app/views/reveal_test/within_document_viewport.erb +0 -24
  196. data/spec_app/app/views/reveal_test/within_overflowing_div_viewport.erb +0 -28
  197. data/spec_app/app/views/scroll_test/long1.erb +0 -30
  198. data/spec_app/bin/bundle +0 -3
  199. data/spec_app/bin/rails +0 -8
  200. data/spec_app/bin/rake +0 -8
  201. data/spec_app/bin/setup +0 -29
  202. data/spec_app/bin/spring +0 -18
  203. data/spec_app/config.ru +0 -4
  204. data/spec_app/config/application.rb +0 -28
  205. data/spec_app/config/boot.rb +0 -3
  206. data/spec_app/config/database.yml +0 -25
  207. data/spec_app/config/environment.rb +0 -5
  208. data/spec_app/config/environments/development.rb +0 -41
  209. data/spec_app/config/environments/production.rb +0 -79
  210. data/spec_app/config/environments/test.rb +0 -42
  211. data/spec_app/config/initializers/assets.rb +0 -19
  212. data/spec_app/config/initializers/backtrace_silencers.rb +0 -7
  213. data/spec_app/config/initializers/bower_rails.rb +0 -16
  214. data/spec_app/config/initializers/cookies_serializer.rb +0 -3
  215. data/spec_app/config/initializers/filter_parameter_logging.rb +0 -4
  216. data/spec_app/config/initializers/inflections.rb +0 -16
  217. data/spec_app/config/initializers/mime_types.rb +0 -4
  218. data/spec_app/config/initializers/session_store.rb +0 -3
  219. data/spec_app/config/initializers/wrap_parameters.rb +0 -14
  220. data/spec_app/config/locales/en.yml +0 -23
  221. data/spec_app/config/routes.rb +0 -30
  222. data/spec_app/config/secrets.yml +0 -22
  223. data/spec_app/db/schema.rb +0 -23
  224. data/spec_app/db/seeds.rb +0 -7
  225. data/spec_app/lib/assets/.keep +0 -0
  226. data/spec_app/lib/tasks/.keep +0 -0
  227. data/spec_app/lib/tasks/cucumber.rake +0 -65
  228. data/spec_app/log/.keep +0 -0
  229. data/spec_app/public/404.html +0 -67
  230. data/spec_app/public/422.html +0 -67
  231. data/spec_app/public/500.html +0 -66
  232. data/spec_app/public/favicon.ico +0 -0
  233. data/spec_app/public/robots.txt +0 -5
  234. data/spec_app/script/cucumber +0 -10
  235. data/spec_app/spec/controllers/binding_test_controller_spec.rb +0 -248
  236. data/spec_app/spec/javascripts/helpers/agent_detector.coffee +0 -20
  237. data/spec_app/spec/javascripts/helpers/async_sequence.js.coffee +0 -103
  238. data/spec_app/spec/javascripts/helpers/browser_switches.js.coffee +0 -21
  239. data/spec_app/spec/javascripts/helpers/enable_logging.js.coffee +0 -2
  240. data/spec_app/spec/javascripts/helpers/fixture.js.coffee +0 -25
  241. data/spec_app/spec/javascripts/helpers/index.js.coffee +0 -1
  242. data/spec_app/spec/javascripts/helpers/jquery_no_conflict.js +0 -1
  243. data/spec_app/spec/javascripts/helpers/knife.js.coffee +0 -69
  244. data/spec_app/spec/javascripts/helpers/last_request.js.coffee +0 -25
  245. data/spec_app/spec/javascripts/helpers/mock_ajax.js.coffee +0 -8
  246. data/spec_app/spec/javascripts/helpers/mock_clock.js.coffee +0 -2
  247. data/spec_app/spec/javascripts/helpers/parse_form_data.js.coffee +0 -24
  248. data/spec_app/spec/javascripts/helpers/promise_state.js +0 -18
  249. data/spec_app/spec/javascripts/helpers/protect_jasmine_runner.coffee +0 -12
  250. data/spec_app/spec/javascripts/helpers/remove_body_margin.js.coffee +0 -8
  251. data/spec_app/spec/javascripts/helpers/reset_history.js.coffee +0 -23
  252. data/spec_app/spec/javascripts/helpers/reset_knife.js.coffee +0 -2
  253. data/spec_app/spec/javascripts/helpers/reset_up.js.coffee +0 -25
  254. data/spec_app/spec/javascripts/helpers/restore_body_scroll.js.coffee +0 -5
  255. data/spec_app/spec/javascripts/helpers/show_lib_versions.coffee +0 -12
  256. data/spec_app/spec/javascripts/helpers/spec_util.coffee +0 -47
  257. data/spec_app/spec/javascripts/helpers/to_be_around.js.coffee +0 -8
  258. data/spec_app/spec/javascripts/helpers/to_be_array.coffee +0 -5
  259. data/spec_app/spec/javascripts/helpers/to_be_attached.coffee +0 -9
  260. data/spec_app/spec/javascripts/helpers/to_be_blank.js.coffee +0 -8
  261. data/spec_app/spec/javascripts/helpers/to_be_detached.coffee +0 -9
  262. data/spec_app/spec/javascripts/helpers/to_be_element.js.coffee +0 -8
  263. data/spec_app/spec/javascripts/helpers/to_be_error.coffee +0 -8
  264. data/spec_app/spec/javascripts/helpers/to_be_given.js.coffee +0 -8
  265. data/spec_app/spec/javascripts/helpers/to_be_hidden.js.coffee +0 -8
  266. data/spec_app/spec/javascripts/helpers/to_be_jquery.js.coffee +0 -5
  267. data/spec_app/spec/javascripts/helpers/to_be_missing.js.coffee +0 -8
  268. data/spec_app/spec/javascripts/helpers/to_be_present.js.coffee +0 -8
  269. data/spec_app/spec/javascripts/helpers/to_be_scrolled_to.coffee +0 -11
  270. data/spec_app/spec/javascripts/helpers/to_be_visible.js.coffee +0 -9
  271. data/spec_app/spec/javascripts/helpers/to_contain.js.coffee +0 -8
  272. data/spec_app/spec/javascripts/helpers/to_end_with.js.coffee +0 -11
  273. data/spec_app/spec/javascripts/helpers/to_equal_jquery.js.coffee +0 -8
  274. data/spec_app/spec/javascripts/helpers/to_equal_node_list.coffee +0 -7
  275. data/spec_app/spec/javascripts/helpers/to_equal_via_is_equal.js.coffee +0 -7
  276. data/spec_app/spec/javascripts/helpers/to_have_class.js.coffee +0 -10
  277. data/spec_app/spec/javascripts/helpers/to_have_descendant.js.coffee +0 -10
  278. data/spec_app/spec/javascripts/helpers/to_have_length.js.coffee +0 -8
  279. data/spec_app/spec/javascripts/helpers/to_have_opacity.coffee +0 -15
  280. data/spec_app/spec/javascripts/helpers/to_have_own_property.js.coffee +0 -8
  281. data/spec_app/spec/javascripts/helpers/to_have_request_method.js.coffee +0 -16
  282. data/spec_app/spec/javascripts/helpers/to_have_text.js.coffee +0 -9
  283. data/spec_app/spec/javascripts/helpers/to_have_unhandled_rejections.coffee +0 -18
  284. data/spec_app/spec/javascripts/helpers/to_match_list.coffee +0 -14
  285. data/spec_app/spec/javascripts/helpers/to_match_selector.coffee +0 -8
  286. data/spec_app/spec/javascripts/helpers/to_match_text.js.coffee +0 -13
  287. data/spec_app/spec/javascripts/helpers/to_match_url.coffee +0 -14
  288. data/spec_app/spec/javascripts/helpers/trigger.js.coffee +0 -200
  289. data/spec_app/spec/javascripts/helpers/wait_until_dom_ready.js.coffee +0 -5
  290. data/spec_app/spec/javascripts/support/jasmine.yml +0 -51
  291. data/spec_app/spec/javascripts/up/browser_spec.js.coffee +0 -150
  292. data/spec_app/spec/javascripts/up/classes/cache_spec.js.coffee +0 -82
  293. data/spec_app/spec/javascripts/up/classes/config_spec.coffee +0 -24
  294. data/spec_app/spec/javascripts/up/classes/divertible_chain_spec.coffee +0 -45
  295. data/spec_app/spec/javascripts/up/classes/focus_tracker_spec.coffee +0 -34
  296. data/spec_app/spec/javascripts/up/classes/params_spec.coffee +0 -557
  297. data/spec_app/spec/javascripts/up/classes/request_spec.coffee +0 -50
  298. data/spec_app/spec/javascripts/up/classes/scroll_motion_spec.js.coffee +0 -51
  299. data/spec_app/spec/javascripts/up/classes/store/memory_spec.js.coffee +0 -70
  300. data/spec_app/spec/javascripts/up/classes/store/session_spec.js.coffee +0 -114
  301. data/spec_app/spec/javascripts/up/element_spec.coffee +0 -897
  302. data/spec_app/spec/javascripts/up/event_spec.js.coffee +0 -530
  303. data/spec_app/spec/javascripts/up/feedback_spec.js.coffee +0 -401
  304. data/spec_app/spec/javascripts/up/form_spec.js.coffee +0 -1527
  305. data/spec_app/spec/javascripts/up/fragment_spec.js.coffee +0 -2624
  306. data/spec_app/spec/javascripts/up/history_spec.js.coffee +0 -340
  307. data/spec_app/spec/javascripts/up/jquery_spec.js.coffee +0 -4
  308. data/spec_app/spec/javascripts/up/legacy_spec.js.coffee +0 -27
  309. data/spec_app/spec/javascripts/up/link_spec.js.coffee +0 -1098
  310. data/spec_app/spec/javascripts/up/log_spec.js.coffee +0 -119
  311. data/spec_app/spec/javascripts/up/modal_spec.js.coffee +0 -939
  312. data/spec_app/spec/javascripts/up/motion_spec.js.coffee +0 -582
  313. data/spec_app/spec/javascripts/up/popup_spec.js.coffee +0 -508
  314. data/spec_app/spec/javascripts/up/protocol_spec.js.coffee +0 -39
  315. data/spec_app/spec/javascripts/up/proxy_spec.js.coffee +0 -1137
  316. data/spec_app/spec/javascripts/up/radio_spec.js.coffee +0 -212
  317. data/spec_app/spec/javascripts/up/rails_spec.js.coffee +0 -118
  318. data/spec_app/spec/javascripts/up/spec_spec.js.coffee +0 -9
  319. data/spec_app/spec/javascripts/up/syntax_spec.js.coffee +0 -304
  320. data/spec_app/spec/javascripts/up/toast_spec.js.coffee +0 -37
  321. data/spec_app/spec/javascripts/up/tooltip_spec.js.coffee +0 -163
  322. data/spec_app/spec/javascripts/up/util_spec.js.coffee +0 -1420
  323. data/spec_app/spec/javascripts/up/viewport_spec.js.coffee +0 -655
  324. data/spec_app/spec/spec_helper.rb +0 -62
  325. data/spec_app/test/controllers/.keep +0 -0
  326. data/spec_app/test/fixtures/.keep +0 -0
  327. data/spec_app/test/helpers/.keep +0 -0
  328. data/spec_app/test/integration/.keep +0 -0
  329. data/spec_app/test/mailers/.keep +0 -0
  330. data/spec_app/test/models/.keep +0 -0
  331. data/spec_app/test/test_helper.rb +0 -10
  332. data/spec_app/vendor/asset-libs/es6-promise-4.1.6/es6-promise.auto.js +0 -1159
  333. data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.bower.json +0 -43
  334. data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.gitignore +0 -6
  335. data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.npmignore +0 -10
  336. data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.pairs +0 -6
  337. data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/.travis.yml +0 -56
  338. data/spec_app/vendor/asset-libs/jasmine-ajax-3.3.1/jasmine-ajax.js +0 -790
  339. data/spec_app/vendor/assets/.keep +0 -0
  340. 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'