unpoly-rails 0.20.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of unpoly-rails might be problematic. Click here for more details.

Files changed (339) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +9 -0
  3. data/.ruby-version +2 -0
  4. data/.yardopts +1 -0
  5. data/CHANGELOG.md +577 -0
  6. data/Gemfile +8 -0
  7. data/Gemfile.lock +42 -0
  8. data/LICENSE +22 -0
  9. data/README.md +75 -0
  10. data/README_RAILS.md +116 -0
  11. data/Rakefile +45 -0
  12. data/bower.json +26 -0
  13. data/design/animation-ghosting.txt +72 -0
  14. data/design/design.txt +34 -0
  15. data/design/draft.html.erb +48 -0
  16. data/design/draft.rb +9 -0
  17. data/design/ghost-debugging.txt +118 -0
  18. data/design/homepage.txt +236 -0
  19. data/design/rename.txt +0 -0
  20. data/dist/unpoly-bootstrap3.css +5 -0
  21. data/dist/unpoly-bootstrap3.js +28 -0
  22. data/dist/unpoly-bootstrap3.min.css +1 -0
  23. data/dist/unpoly-bootstrap3.min.js +1 -0
  24. data/dist/unpoly.css +98 -0
  25. data/dist/unpoly.js +9041 -0
  26. data/dist/unpoly.min.css +1 -0
  27. data/dist/unpoly.min.js +3 -0
  28. data/lib/assets/javascripts/unpoly-bootstrap3.js.coffee +2 -0
  29. data/lib/assets/javascripts/unpoly-bootstrap3/form-ext.js.coffee +1 -0
  30. data/lib/assets/javascripts/unpoly-bootstrap3/layout-ext.js.coffee +5 -0
  31. data/lib/assets/javascripts/unpoly-bootstrap3/modal-ext.js.coffee +11 -0
  32. data/lib/assets/javascripts/unpoly-bootstrap3/navigation-ext.js.coffee +3 -0
  33. data/lib/assets/javascripts/unpoly.js.coffee +20 -0
  34. data/lib/assets/javascripts/unpoly/browser.js.coffee +252 -0
  35. data/lib/assets/javascripts/unpoly/bus.js.coffee +393 -0
  36. data/lib/assets/javascripts/unpoly/flow.js.coffee +809 -0
  37. data/lib/assets/javascripts/unpoly/form.js.coffee +864 -0
  38. data/lib/assets/javascripts/unpoly/history.js.coffee +204 -0
  39. data/lib/assets/javascripts/unpoly/layout.js.coffee +529 -0
  40. data/lib/assets/javascripts/unpoly/link.js.coffee +496 -0
  41. data/lib/assets/javascripts/unpoly/log.js.coffee +73 -0
  42. data/lib/assets/javascripts/unpoly/modal.js.coffee +509 -0
  43. data/lib/assets/javascripts/unpoly/module.js.coffee +4 -0
  44. data/lib/assets/javascripts/unpoly/motion.js.coffee +690 -0
  45. data/lib/assets/javascripts/unpoly/navigation.js.coffee +219 -0
  46. data/lib/assets/javascripts/unpoly/popup.js.coffee +409 -0
  47. data/lib/assets/javascripts/unpoly/proxy.js.coffee +521 -0
  48. data/lib/assets/javascripts/unpoly/rails.js.coffee +36 -0
  49. data/lib/assets/javascripts/unpoly/syntax.js.coffee +337 -0
  50. data/lib/assets/javascripts/unpoly/tooltip.js.coffee +183 -0
  51. data/lib/assets/javascripts/unpoly/util.js.coffee +1593 -0
  52. data/lib/assets/stylesheets/unpoly-bootstrap3.css.sass +1 -0
  53. data/lib/assets/stylesheets/unpoly-bootstrap3/modal-ext.css.sass +9 -0
  54. data/lib/assets/stylesheets/unpoly.css.sass +1 -0
  55. data/lib/assets/stylesheets/unpoly/close.css.sass +2 -0
  56. data/lib/assets/stylesheets/unpoly/error.css.sass +15 -0
  57. data/lib/assets/stylesheets/unpoly/link.css.sass +2 -0
  58. data/lib/assets/stylesheets/unpoly/modal.css.sass +69 -0
  59. data/lib/assets/stylesheets/unpoly/popup.css.sass +8 -0
  60. data/lib/assets/stylesheets/unpoly/tooltip.css.sass +42 -0
  61. data/lib/unpoly-rails.rb +7 -0
  62. data/lib/unpoly/rails/engine.rb +6 -0
  63. data/lib/unpoly/rails/inspector.rb +78 -0
  64. data/lib/unpoly/rails/inspector_accessor.rb +30 -0
  65. data/lib/unpoly/rails/request_echo_headers.rb +27 -0
  66. data/lib/unpoly/rails/request_method_cookie.rb +36 -0
  67. data/lib/unpoly/rails/version.rb +9 -0
  68. data/spec_app/.firefox-version +1 -0
  69. data/spec_app/.gitignore +17 -0
  70. data/spec_app/.rspec +2 -0
  71. data/spec_app/Bowerfile +3 -0
  72. data/spec_app/Gemfile +29 -0
  73. data/spec_app/Gemfile.lock +212 -0
  74. data/spec_app/README.rdoc +28 -0
  75. data/spec_app/Rakefile +6 -0
  76. data/spec_app/app/assets/images/.keep +0 -0
  77. data/spec_app/app/assets/javascripts/application.js +20 -0
  78. data/spec_app/app/assets/stylesheets/application.css +17 -0
  79. data/spec_app/app/assets/stylesheets/blocks/card.css.sass +11 -0
  80. data/spec_app/app/assets/stylesheets/blocks/controls.css.sass +7 -0
  81. data/spec_app/app/assets/stylesheets/blocks/menu.css.sass +13 -0
  82. data/spec_app/app/assets/stylesheets/blocks/panel.css.sass +8 -0
  83. data/spec_app/app/assets/stylesheets/jasmine_specs.css +5 -0
  84. data/spec_app/app/controllers/application_controller.rb +6 -0
  85. data/spec_app/app/controllers/concerns/.keep +0 -0
  86. data/spec_app/app/controllers/test_controller.rb +28 -0
  87. data/spec_app/app/helpers/application_helper.rb +2 -0
  88. data/spec_app/app/mailers/.keep +0 -0
  89. data/spec_app/app/models/concerns/.keep +0 -0
  90. data/spec_app/app/views/layouts/application.html.erb +12 -0
  91. data/spec_app/bin/bundle +3 -0
  92. data/spec_app/bin/rails +8 -0
  93. data/spec_app/bin/rake +8 -0
  94. data/spec_app/bin/setup +29 -0
  95. data/spec_app/bin/spring +18 -0
  96. data/spec_app/config.ru +4 -0
  97. data/spec_app/config/application.rb +26 -0
  98. data/spec_app/config/boot.rb +3 -0
  99. data/spec_app/config/database.yml +25 -0
  100. data/spec_app/config/environment.rb +5 -0
  101. data/spec_app/config/environments/development.rb +41 -0
  102. data/spec_app/config/environments/production.rb +79 -0
  103. data/spec_app/config/environments/test.rb +42 -0
  104. data/spec_app/config/initializers/assets.rb +11 -0
  105. data/spec_app/config/initializers/backtrace_silencers.rb +7 -0
  106. data/spec_app/config/initializers/bower_rails.rb +16 -0
  107. data/spec_app/config/initializers/cookies_serializer.rb +3 -0
  108. data/spec_app/config/initializers/filter_parameter_logging.rb +4 -0
  109. data/spec_app/config/initializers/inflections.rb +16 -0
  110. data/spec_app/config/initializers/mime_types.rb +4 -0
  111. data/spec_app/config/initializers/session_store.rb +3 -0
  112. data/spec_app/config/initializers/wrap_parameters.rb +14 -0
  113. data/spec_app/config/locales/en.yml +23 -0
  114. data/spec_app/config/routes.rb +8 -0
  115. data/spec_app/config/secrets.yml +22 -0
  116. data/spec_app/db/schema.rb +23 -0
  117. data/spec_app/db/seeds.rb +7 -0
  118. data/spec_app/lib/assets/.keep +0 -0
  119. data/spec_app/lib/tasks/.keep +0 -0
  120. data/spec_app/lib/tasks/cucumber.rake +65 -0
  121. data/spec_app/log/.keep +0 -0
  122. data/spec_app/public/404.html +67 -0
  123. data/spec_app/public/422.html +67 -0
  124. data/spec_app/public/500.html +66 -0
  125. data/spec_app/public/favicon.ico +0 -0
  126. data/spec_app/public/robots.txt +5 -0
  127. data/spec_app/script/cucumber +10 -0
  128. data/spec_app/spec/controllers/test_controller_spec.rb +76 -0
  129. data/spec_app/spec/javascripts/helpers/append_fixture.js.coffee +8 -0
  130. data/spec_app/spec/javascripts/helpers/browser_switches.js.coffee +9 -0
  131. data/spec_app/spec/javascripts/helpers/index.js.coffee +1 -0
  132. data/spec_app/spec/javascripts/helpers/knife.js.coffee +69 -0
  133. data/spec_app/spec/javascripts/helpers/last_request.js.coffee +22 -0
  134. data/spec_app/spec/javascripts/helpers/mock_ajax.js.coffee +5 -0
  135. data/spec_app/spec/javascripts/helpers/mock_clock.js.coffee +2 -0
  136. data/spec_app/spec/javascripts/helpers/remove_body_margin.js.coffee +5 -0
  137. data/spec_app/spec/javascripts/helpers/reset_knife.js.coffee +2 -0
  138. data/spec_app/spec/javascripts/helpers/reset_path.js.coffee +8 -0
  139. data/spec_app/spec/javascripts/helpers/reset_up.js.coffee +4 -0
  140. data/spec_app/spec/javascripts/helpers/restore_body_scroll.js.coffee +2 -0
  141. data/spec_app/spec/javascripts/helpers/set_timer.js.coffee +3 -0
  142. data/spec_app/spec/javascripts/helpers/to_be_around.js.coffee +5 -0
  143. data/spec_app/spec/javascripts/helpers/to_be_blank.js.coffee +5 -0
  144. data/spec_app/spec/javascripts/helpers/to_be_given.js.coffee +5 -0
  145. data/spec_app/spec/javascripts/helpers/to_be_missing.js.coffee +5 -0
  146. data/spec_app/spec/javascripts/helpers/to_be_present.js.coffee +5 -0
  147. data/spec_app/spec/javascripts/helpers/to_end_with.js.coffee +8 -0
  148. data/spec_app/spec/javascripts/helpers/to_equal_jquery.js.coffee +9 -0
  149. data/spec_app/spec/javascripts/helpers/to_have_request_method.js.coffee +8 -0
  150. data/spec_app/spec/javascripts/helpers/trigger.js.coffee +68 -0
  151. data/spec_app/spec/javascripts/support/jasmine.yml +51 -0
  152. data/spec_app/spec/javascripts/up/bus_spec.js.coffee +122 -0
  153. data/spec_app/spec/javascripts/up/flow_spec.js.coffee +755 -0
  154. data/spec_app/spec/javascripts/up/form_spec.js.coffee +471 -0
  155. data/spec_app/spec/javascripts/up/history_spec.js.coffee +96 -0
  156. data/spec_app/spec/javascripts/up/layout_spec.js.coffee +318 -0
  157. data/spec_app/spec/javascripts/up/link_spec.js.coffee +340 -0
  158. data/spec_app/spec/javascripts/up/modal_spec.js.coffee +265 -0
  159. data/spec_app/spec/javascripts/up/motion_spec.js.coffee +306 -0
  160. data/spec_app/spec/javascripts/up/navigation_spec.js.coffee +132 -0
  161. data/spec_app/spec/javascripts/up/popup_spec.js.coffee +220 -0
  162. data/spec_app/spec/javascripts/up/proxy_spec.js.coffee +371 -0
  163. data/spec_app/spec/javascripts/up/rails_spec.js.coffee +101 -0
  164. data/spec_app/spec/javascripts/up/syntax_spec.js.coffee +99 -0
  165. data/spec_app/spec/javascripts/up/tooltip_spec.js.coffee +60 -0
  166. data/spec_app/spec/javascripts/up/util_spec.js.coffee +325 -0
  167. data/spec_app/spec/spec_helper.rb +62 -0
  168. data/spec_app/test/controllers/.keep +0 -0
  169. data/spec_app/test/fixtures/.keep +0 -0
  170. data/spec_app/test/helpers/.keep +0 -0
  171. data/spec_app/test/integration/.keep +0 -0
  172. data/spec_app/test/mailers/.keep +0 -0
  173. data/spec_app/test/models/.keep +0 -0
  174. data/spec_app/test/test_helper.rb +10 -0
  175. data/spec_app/vendor/assets/.bowerrc +3 -0
  176. data/spec_app/vendor/assets/bower.json +8 -0
  177. data/spec_app/vendor/assets/bower_components/jasmine-ajax/.bower.json +43 -0
  178. data/spec_app/vendor/assets/bower_components/jasmine-ajax/MIT.LICENSE +20 -0
  179. data/spec_app/vendor/assets/bower_components/jasmine-ajax/README.markdown +289 -0
  180. data/spec_app/vendor/assets/bower_components/jasmine-ajax/bower.json +35 -0
  181. data/spec_app/vendor/assets/bower_components/jasmine-ajax/lib/mock-ajax.js +733 -0
  182. data/spec_app/vendor/assets/bower_components/jasmine-ajax/package.json +26 -0
  183. data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/2.0.2.md +50 -0
  184. data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/2.99.md +14 -0
  185. data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.0.md +28 -0
  186. data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.1.0.md +24 -0
  187. data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.1.1.md +23 -0
  188. data/spec_app/vendor/assets/bower_components/jasmine-ajax/release_notes/3.2.0.md +20 -0
  189. data/spec_app/vendor/assets/bower_components/jasmine-fixture/.bower.json +27 -0
  190. data/spec_app/vendor/assets/bower_components/jasmine-fixture/.gitignore +8 -0
  191. data/spec_app/vendor/assets/bower_components/jasmine-fixture/.npmignore +8 -0
  192. data/spec_app/vendor/assets/bower_components/jasmine-fixture/LICENSE.txt +24 -0
  193. data/spec_app/vendor/assets/bower_components/jasmine-fixture/README.md +118 -0
  194. data/spec_app/vendor/assets/bower_components/jasmine-fixture/bower.json +17 -0
  195. data/spec_app/vendor/assets/bower_components/jasmine-fixture/dist/jasmine-fixture.js +433 -0
  196. data/spec_app/vendor/assets/bower_components/jasmine-fixture/dist/jasmine-fixture.min.js +5 -0
  197. data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/basic-usage-spec.coffee +14 -0
  198. data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/helpers/invariants.coffee +17 -0
  199. data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/helpers/spec-within-a-spec.coffee +24 -0
  200. data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/helpers/tmp-files.coffee +8 -0
  201. data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/support/jasmine1-testem-config.json +11 -0
  202. data/spec_app/vendor/assets/bower_components/jasmine-fixture/spec-e2e/support/jasmine2-testem-config.json +11 -0
  203. data/spec_app/vendor/assets/bower_components/jasmine-fixture/vendor/js/jquery-1.11.0.js +10337 -0
  204. data/spec_app/vendor/assets/bower_components/jasmine-fixture/vendor/js/jquery-1.8.3.js +9472 -0
  205. data/spec_app/vendor/assets/bower_components/jasmine-fixture/vendor/js/jquery-2.1.0.js +9111 -0
  206. data/spec_app/vendor/assets/bower_components/jasmine-jquery/.bower.json +26 -0
  207. data/spec_app/vendor/assets/bower_components/jasmine-jquery/CONTRIBUTING.md +28 -0
  208. data/spec_app/vendor/assets/bower_components/jasmine-jquery/Gruntfile.js +49 -0
  209. data/spec_app/vendor/assets/bower_components/jasmine-jquery/LICENSE +20 -0
  210. data/spec_app/vendor/assets/bower_components/jasmine-jquery/README.md +367 -0
  211. data/spec_app/vendor/assets/bower_components/jasmine-jquery/bower.json +15 -0
  212. data/spec_app/vendor/assets/bower_components/jasmine-jquery/lib/jasmine-jquery.js +838 -0
  213. data/spec_app/vendor/assets/bower_components/jasmine-jquery/package.json +35 -0
  214. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/fixture_with_checkbox_with_checked.html +6 -0
  215. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/fixture_with_javascript.html +1 -0
  216. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/fixture_with_javascript_block.html +1 -0
  217. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/javascripts/jasmine_javascript_click.js +1 -0
  218. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/javascripts/jasmine_javascript_hover.js +1 -0
  219. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/json/jasmine_json_test.json +1 -0
  220. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/real_non_mocked_fixture.html +1 -0
  221. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/fixtures/real_non_mocked_fixture_style.css +1 -0
  222. data/spec_app/vendor/assets/bower_components/jasmine-jquery/spec/suites/jasmine-jquery-spec.js +1842 -0
  223. data/spec_app/vendor/assets/bower_components/jasmine/.bower.json +50 -0
  224. data/spec_app/vendor/assets/bower_components/jasmine/CONTRIBUTING.md +130 -0
  225. data/spec_app/vendor/assets/bower_components/jasmine/GOALS_2.0.md +64 -0
  226. data/spec_app/vendor/assets/bower_components/jasmine/MANIFEST.in +5 -0
  227. data/spec_app/vendor/assets/bower_components/jasmine/MIT.LICENSE +20 -0
  228. data/spec_app/vendor/assets/bower_components/jasmine/README.md +73 -0
  229. data/spec_app/vendor/assets/bower_components/jasmine/RELEASE.md +73 -0
  230. data/spec_app/vendor/assets/bower_components/jasmine/bower.json +41 -0
  231. data/spec_app/vendor/assets/bower_components/jasmine/images/jasmine-horizontal.png +0 -0
  232. data/spec_app/vendor/assets/bower_components/jasmine/images/jasmine-horizontal.svg +102 -0
  233. data/spec_app/vendor/assets/bower_components/jasmine/images/jasmine_favicon.png +0 -0
  234. data/spec_app/vendor/assets/bower_components/jasmine/lib/console/console.js +190 -0
  235. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core.js +37 -0
  236. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/boot.js +143 -0
  237. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/example/node_example/lib/jasmine_examples/Player.js +24 -0
  238. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/example/node_example/lib/jasmine_examples/Song.js +9 -0
  239. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/jasmine-html.js +446 -0
  240. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/jasmine.css +58 -0
  241. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/jasmine.js +3298 -0
  242. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/json2.js +489 -0
  243. data/spec_app/vendor/assets/bower_components/jasmine/lib/jasmine-core/node_boot.js +41 -0
  244. data/spec_app/vendor/assets/bower_components/jasmine/package.json +34 -0
  245. data/spec_app/vendor/assets/bower_components/jasmine/requirements.txt +1 -0
  246. data/spec_app/vendor/assets/bower_components/jquery/.bower.json +38 -0
  247. data/spec_app/vendor/assets/bower_components/jquery/MIT-LICENSE.txt +21 -0
  248. data/spec_app/vendor/assets/bower_components/jquery/bower.json +28 -0
  249. data/spec_app/vendor/assets/bower_components/jquery/dist/jquery.js +9210 -0
  250. data/spec_app/vendor/assets/bower_components/jquery/dist/jquery.min.js +5 -0
  251. data/spec_app/vendor/assets/bower_components/jquery/dist/jquery.min.map +1 -0
  252. data/spec_app/vendor/assets/bower_components/jquery/src/ajax.js +786 -0
  253. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/jsonp.js +89 -0
  254. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/load.js +75 -0
  255. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/parseJSON.js +13 -0
  256. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/parseXML.js +28 -0
  257. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/script.js +64 -0
  258. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/var/nonce.js +5 -0
  259. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/var/rquery.js +3 -0
  260. data/spec_app/vendor/assets/bower_components/jquery/src/ajax/xhr.js +136 -0
  261. data/spec_app/vendor/assets/bower_components/jquery/src/attributes.js +11 -0
  262. data/spec_app/vendor/assets/bower_components/jquery/src/attributes/attr.js +141 -0
  263. data/spec_app/vendor/assets/bower_components/jquery/src/attributes/classes.js +158 -0
  264. data/spec_app/vendor/assets/bower_components/jquery/src/attributes/prop.js +94 -0
  265. data/spec_app/vendor/assets/bower_components/jquery/src/attributes/support.js +35 -0
  266. data/spec_app/vendor/assets/bower_components/jquery/src/attributes/val.js +161 -0
  267. data/spec_app/vendor/assets/bower_components/jquery/src/callbacks.js +205 -0
  268. data/spec_app/vendor/assets/bower_components/jquery/src/core.js +502 -0
  269. data/spec_app/vendor/assets/bower_components/jquery/src/core/access.js +60 -0
  270. data/spec_app/vendor/assets/bower_components/jquery/src/core/init.js +123 -0
  271. data/spec_app/vendor/assets/bower_components/jquery/src/core/parseHTML.js +39 -0
  272. data/spec_app/vendor/assets/bower_components/jquery/src/core/ready.js +97 -0
  273. data/spec_app/vendor/assets/bower_components/jquery/src/core/var/rsingleTag.js +4 -0
  274. data/spec_app/vendor/assets/bower_components/jquery/src/css.js +450 -0
  275. data/spec_app/vendor/assets/bower_components/jquery/src/css/addGetHookIf.js +22 -0
  276. data/spec_app/vendor/assets/bower_components/jquery/src/css/curCSS.js +57 -0
  277. data/spec_app/vendor/assets/bower_components/jquery/src/css/defaultDisplay.js +70 -0
  278. data/spec_app/vendor/assets/bower_components/jquery/src/css/hiddenVisibleSelectors.js +15 -0
  279. data/spec_app/vendor/assets/bower_components/jquery/src/css/support.js +96 -0
  280. data/spec_app/vendor/assets/bower_components/jquery/src/css/swap.js +28 -0
  281. data/spec_app/vendor/assets/bower_components/jquery/src/css/var/cssExpand.js +3 -0
  282. data/spec_app/vendor/assets/bower_components/jquery/src/css/var/getStyles.js +12 -0
  283. data/spec_app/vendor/assets/bower_components/jquery/src/css/var/isHidden.js +13 -0
  284. data/spec_app/vendor/assets/bower_components/jquery/src/css/var/rmargin.js +3 -0
  285. data/spec_app/vendor/assets/bower_components/jquery/src/css/var/rnumnonpx.js +5 -0
  286. data/spec_app/vendor/assets/bower_components/jquery/src/data.js +178 -0
  287. data/spec_app/vendor/assets/bower_components/jquery/src/data/Data.js +181 -0
  288. data/spec_app/vendor/assets/bower_components/jquery/src/data/accepts.js +20 -0
  289. data/spec_app/vendor/assets/bower_components/jquery/src/data/var/data_priv.js +5 -0
  290. data/spec_app/vendor/assets/bower_components/jquery/src/data/var/data_user.js +5 -0
  291. data/spec_app/vendor/assets/bower_components/jquery/src/deferred.js +149 -0
  292. data/spec_app/vendor/assets/bower_components/jquery/src/deprecated.js +13 -0
  293. data/spec_app/vendor/assets/bower_components/jquery/src/dimensions.js +50 -0
  294. data/spec_app/vendor/assets/bower_components/jquery/src/effects.js +648 -0
  295. data/spec_app/vendor/assets/bower_components/jquery/src/effects/Tween.js +114 -0
  296. data/spec_app/vendor/assets/bower_components/jquery/src/effects/animatedSelector.js +13 -0
  297. data/spec_app/vendor/assets/bower_components/jquery/src/event.js +868 -0
  298. data/spec_app/vendor/assets/bower_components/jquery/src/event/ajax.js +13 -0
  299. data/spec_app/vendor/assets/bower_components/jquery/src/event/alias.js +39 -0
  300. data/spec_app/vendor/assets/bower_components/jquery/src/event/support.js +9 -0
  301. data/spec_app/vendor/assets/bower_components/jquery/src/exports/amd.js +24 -0
  302. data/spec_app/vendor/assets/bower_components/jquery/src/exports/global.js +32 -0
  303. data/spec_app/vendor/assets/bower_components/jquery/src/intro.js +44 -0
  304. data/spec_app/vendor/assets/bower_components/jquery/src/jquery.js +37 -0
  305. data/spec_app/vendor/assets/bower_components/jquery/src/manipulation.js +580 -0
  306. data/spec_app/vendor/assets/bower_components/jquery/src/manipulation/_evalUrl.js +18 -0
  307. data/spec_app/vendor/assets/bower_components/jquery/src/manipulation/support.js +32 -0
  308. data/spec_app/vendor/assets/bower_components/jquery/src/manipulation/var/rcheckableType.js +3 -0
  309. data/spec_app/vendor/assets/bower_components/jquery/src/offset.js +207 -0
  310. data/spec_app/vendor/assets/bower_components/jquery/src/outro.js +1 -0
  311. data/spec_app/vendor/assets/bower_components/jquery/src/queue.js +142 -0
  312. data/spec_app/vendor/assets/bower_components/jquery/src/queue/delay.js +22 -0
  313. data/spec_app/vendor/assets/bower_components/jquery/src/selector-native.js +172 -0
  314. data/spec_app/vendor/assets/bower_components/jquery/src/selector-sizzle.js +14 -0
  315. data/spec_app/vendor/assets/bower_components/jquery/src/selector.js +1 -0
  316. data/spec_app/vendor/assets/bower_components/jquery/src/serialize.js +111 -0
  317. data/spec_app/vendor/assets/bower_components/jquery/src/sizzle/dist/sizzle.js +2067 -0
  318. data/spec_app/vendor/assets/bower_components/jquery/src/sizzle/dist/sizzle.min.js +3 -0
  319. data/spec_app/vendor/assets/bower_components/jquery/src/sizzle/dist/sizzle.min.map +1 -0
  320. data/spec_app/vendor/assets/bower_components/jquery/src/traversing.js +199 -0
  321. data/spec_app/vendor/assets/bower_components/jquery/src/traversing/findFilter.js +100 -0
  322. data/spec_app/vendor/assets/bower_components/jquery/src/traversing/var/rneedsContext.js +6 -0
  323. data/spec_app/vendor/assets/bower_components/jquery/src/var/arr.js +3 -0
  324. data/spec_app/vendor/assets/bower_components/jquery/src/var/class2type.js +4 -0
  325. data/spec_app/vendor/assets/bower_components/jquery/src/var/concat.js +5 -0
  326. data/spec_app/vendor/assets/bower_components/jquery/src/var/hasOwn.js +5 -0
  327. data/spec_app/vendor/assets/bower_components/jquery/src/var/indexOf.js +5 -0
  328. data/spec_app/vendor/assets/bower_components/jquery/src/var/pnum.js +3 -0
  329. data/spec_app/vendor/assets/bower_components/jquery/src/var/push.js +5 -0
  330. data/spec_app/vendor/assets/bower_components/jquery/src/var/rnotwhite.js +3 -0
  331. data/spec_app/vendor/assets/bower_components/jquery/src/var/slice.js +5 -0
  332. data/spec_app/vendor/assets/bower_components/jquery/src/var/strundefined.js +3 -0
  333. data/spec_app/vendor/assets/bower_components/jquery/src/var/support.js +4 -0
  334. data/spec_app/vendor/assets/bower_components/jquery/src/var/toString.js +5 -0
  335. data/spec_app/vendor/assets/bower_components/jquery/src/wrap.js +79 -0
  336. data/spec_app/vendor/assets/javascripts/.keep +0 -0
  337. data/spec_app/vendor/assets/stylesheets/.keep +0 -0
  338. data/unpoly-rails.gemspec +24 -0
  339. metadata +423 -0
@@ -0,0 +1,471 @@
1
+ describe 'up.form', ->
2
+
3
+ u = up.util
4
+
5
+ describe 'Javascript functions', ->
6
+
7
+ describe 'up.observe', ->
8
+
9
+ changeEvents = if up.browser.canInputEvent()
10
+ # Actually we only need `input`, but we want to notice
11
+ # if another script manually triggers `change` on the element.
12
+ ['input', 'change']
13
+ else
14
+ # Actually we won't ever get `input` from the user in this browser,
15
+ # but we want to notice if another script manually triggers `input`
16
+ # on the element.
17
+ ['input', 'change', 'keypress', 'paste', 'cut', 'click', 'propertychange']
18
+
19
+ u.each changeEvents, (eventName) ->
20
+
21
+ describe 'when the first argument is a form field', ->
22
+
23
+ it "runs the callback when the input receives a '#{eventName}' event and the value changed", (done) ->
24
+ $input = affix('input[value="old-value"]')
25
+ callback = jasmine.createSpy('change callback')
26
+ up.observe($input, callback)
27
+ $input.val('new-value')
28
+ u.times 2, -> $input.trigger(eventName)
29
+ u.nextFrame ->
30
+ expect(callback).toHaveBeenCalledWith('new-value', $input)
31
+ expect(callback.calls.count()).toEqual(1)
32
+ done()
33
+
34
+ it "does not run the callback when the input receives a '#{eventName}' event, but the value didn't change", (done) ->
35
+ $input = affix('input[value="old-value"]')
36
+ callback = jasmine.createSpy('change callback')
37
+ up.observe($input, callback)
38
+ $input.trigger(eventName)
39
+ u.nextFrame ->
40
+ expect(callback).not.toHaveBeenCalled()
41
+ done()
42
+
43
+ it "runs a callback in the same frame if the delay is 0 and it receives a '#{eventName}' event", ->
44
+ $input = affix('input[value="old-value"]')
45
+ callback = jasmine.createSpy('change callback')
46
+ up.observe($input, { delay: 0 }, callback)
47
+ $input.val('new-value')
48
+ $input.trigger(eventName)
49
+ expect(callback.calls.count()).toEqual(1)
50
+
51
+ it "runs multiple callbacks in the same frame if the delay is 0 and it receives a '#{eventName}' event", ->
52
+ $input = affix('input[value="old-value"]')
53
+ callback = jasmine.createSpy('change callback')
54
+ up.observe($input, { delay: 0 }, callback)
55
+ $input.val('new-value')
56
+ $input.trigger(eventName)
57
+ $input.val('yet-another-value')
58
+ $input.trigger(eventName)
59
+ expect(callback.calls.count()).toEqual(2)
60
+
61
+ describe 'when the first argument is a form', ->
62
+
63
+ it "runs the callback when any of the form's inputs receives a '#{eventName}' event and the value changed", (done) ->
64
+ $form = affix('form')
65
+ $input = $form.affix('input[value="old-value"]')
66
+ callback = jasmine.createSpy('change callback')
67
+ up.observe($form, callback)
68
+ $input.val('new-value')
69
+ u.times 2, -> $input.trigger(eventName)
70
+ u.nextFrame ->
71
+ expect(callback).toHaveBeenCalledWith('new-value', $input)
72
+ expect(callback.calls.count()).toEqual(1)
73
+ done()
74
+
75
+ it "does not run the callback when any of the form's inputs receives a '#{eventName}' event, but the value didn't change", (done) ->
76
+ $form = affix('form')
77
+ $input = $form.affix('input[value="old-value"]')
78
+ callback = jasmine.createSpy('change callback')
79
+ up.observe($form, callback)
80
+ $input.trigger(eventName)
81
+ u.nextFrame ->
82
+ expect(callback).not.toHaveBeenCalled()
83
+ done()
84
+
85
+ describe 'up.submit', ->
86
+
87
+ describeCapability 'canPushState', ->
88
+
89
+ beforeEach ->
90
+ @$form = affix('form[action="/path/to"][method="put"][up-target=".response"]')
91
+ @$form.append('<input name="field1" value="value1">')
92
+ @$form.append('<input name="field2" value="value2">')
93
+ affix('.response').text('old-text')
94
+ @promise = up.submit(@$form)
95
+ @request = @lastRequest()
96
+
97
+ it 'submits the given form and replaces the target with the response', ->
98
+ expect(@request.url).toMatch /\/path\/to$/
99
+ expect(@request).toHaveRequestMethod('PUT')
100
+ expect(@request.data()['field1']).toEqual(['value1'])
101
+ expect(@request.data()['field2']).toEqual(['value2'])
102
+ expect(@request.requestHeaders['X-Up-Target']).toEqual('.response')
103
+
104
+ @respondWith """
105
+ text-before
106
+
107
+ <div class="response">
108
+ new-text
109
+ </div>
110
+
111
+ text-after
112
+ """
113
+
114
+ it "places the response into the form and doesn't update the browser URL if the submission returns a 5xx status code", ->
115
+ up.submit(@$form)
116
+ @respondWith
117
+ status: 500
118
+ contentType: 'text/html'
119
+ responseText:
120
+ """
121
+ text-before
122
+
123
+ <form>
124
+ error-messages
125
+ </form>
126
+
127
+ text-after
128
+ """
129
+ expect(up.browser.url()).toEqual(@hrefBeforeExample)
130
+ expect($('.response')).toHaveText('old-text')
131
+ expect($('form')).toHaveText('error-messages')
132
+ expect($('body')).not.toHaveText('text-before')
133
+ expect($('body')).not.toHaveText('text-after')
134
+
135
+ it 'respects X-Up-Method and X-Up-Location response headers so the server can show that it redirected to a GET URL', ->
136
+ up.submit(@$form)
137
+ @respondWith
138
+ status: 200
139
+ contentType: 'text/html'
140
+ responseHeaders:
141
+ 'X-Up-Location': '/other-path'
142
+ 'X-Up-Method': 'GET'
143
+ responseText:
144
+ """
145
+ <div class="response">
146
+ new-text
147
+ </div>
148
+ """
149
+
150
+ expect(up.browser.url()).toEndWith('/other-path')
151
+
152
+ describe 'with { history } option', ->
153
+
154
+ it 'uses the given URL as the new browser location if the request succeeded', ->
155
+ up.submit(@$form, history: '/given-path')
156
+ @respondWith('<div class="response">new-text</div>')
157
+ expect(up.browser.url()).toEndWith('/given-path')
158
+
159
+ it 'keeps the current browser location if the request failed', ->
160
+ up.submit(@$form, history: '/given-path', failTarget: '.response')
161
+ @respondWith('<div class="response">new-text</div>', status: 500)
162
+ expect(up.browser.url()).toEqual(@hrefBeforeExample)
163
+
164
+ it 'keeps the current browser location if the option is set to false', ->
165
+ up.submit(@$form, history: false)
166
+ @respondWith('<div class="response">new-text</div>')
167
+ expect(up.browser.url()).toEqual(@hrefBeforeExample)
168
+
169
+ describeFallback 'canPushState', ->
170
+
171
+ it 'submits the given form', ->
172
+ $form = affix('form[action="/path/to"][method="put"][up-target=".response"]')
173
+ form = $form.get(0)
174
+ spyOn(form, 'submit')
175
+
176
+ up.submit($form)
177
+ expect(form.submit).toHaveBeenCalled()
178
+
179
+ describe 'unobtrusive behavior', ->
180
+
181
+ describe 'form[up-target]', ->
182
+
183
+ it 'rigs the form to use up.submit instead of a standard submit'
184
+
185
+ describe 'input[up-autosubmit]', ->
186
+
187
+ it 'submits the form when a change is observed in the given form field', (done) ->
188
+ $form = affix('form')
189
+ $field = $form.affix('input[up-autosubmit][val="old-value"]')
190
+ up.hello($field)
191
+ submitSpy = up.form.knife.mock('submit').and.returnValue(u.unresolvablePromise())
192
+ $field.val('new-value')
193
+ $field.trigger('change')
194
+ u.nextFrame ->
195
+ expect(submitSpy).toHaveBeenCalled()
196
+ done()
197
+
198
+ describe 'form[up-autosubmit]', ->
199
+
200
+ it 'submits the form when a change is observed in any of its fields', (done) ->
201
+ $form = affix('form[up-autosubmit]')
202
+ $field = $form.affix('input[val="old-value"]')
203
+ up.hello($form)
204
+ submitSpy = up.form.knife.mock('submit').and.returnValue(u.unresolvablePromise())
205
+ $field.val('new-value')
206
+ $field.trigger('change')
207
+ u.nextFrame ->
208
+ expect(submitSpy).toHaveBeenCalled()
209
+ done()
210
+
211
+ describe '[up-observe]', ->
212
+
213
+ it 'should have tests'
214
+
215
+ describe 'input[up-validate]', ->
216
+
217
+ describe 'when a selector is given', ->
218
+
219
+ it "submits the input's form with an 'X-Up-Validate' header and replaces the selector with the response", ->
220
+
221
+ $form = affix('form[action="/path/to"]')
222
+ $group = $("""
223
+ <div class="field-group">
224
+ <input name="user" value="judy" up-validate=".field-group:has(&)">
225
+ </div>
226
+ """).appendTo($form)
227
+ $group.find('input').trigger('change')
228
+
229
+ request = @lastRequest()
230
+ expect(request.requestHeaders['X-Up-Validate']).toEqual('user')
231
+ expect(request.requestHeaders['X-Up-Target']).toEqual(".field-group:has([name='user'])")
232
+
233
+ @respondWith """
234
+ <div class="field-group has-error">
235
+ <div class='error'>Username has already been taken</div>
236
+ <input name="user" value="judy" up-validate=".field-group:has(&)">
237
+ </div>
238
+ """
239
+
240
+ $group = $('.field-group')
241
+ expect($group.length).toBe(1)
242
+ expect($group).toHaveClass('has-error')
243
+ expect($group).toHaveText('Username has already been taken')
244
+
245
+ describe 'when no selector is given', ->
246
+
247
+ it 'automatically finds a form group around the input field and only updates that', ->
248
+
249
+ @appendFixture """
250
+ <form action="/users" id="registration">
251
+
252
+ <label>
253
+ <input type="text" name="email" up-validate />
254
+ </label>
255
+
256
+ <label>
257
+ <input type="password" name="password" up-validate />
258
+ </label>
259
+
260
+ </form>
261
+ """
262
+
263
+ $('#registration input[name=password]').trigger('change')
264
+
265
+ @respondWith """
266
+ <form action="/users" id="registration">
267
+
268
+ <label>
269
+ Validation message
270
+ <input type="text" name="email" up-validate />
271
+ </label>
272
+
273
+ <label>
274
+ Validation message
275
+ <input type="password" name="password" up-validate />
276
+ </label>
277
+
278
+ </form>
279
+ """
280
+
281
+ $labels = $('#registration label')
282
+ expect($labels[0]).not.toHaveText('Validation message')
283
+ expect($labels[1]).toHaveText('Validation message')
284
+
285
+ describe '[up-toggle]', ->
286
+
287
+ describe 'on a select', ->
288
+
289
+ beforeEach ->
290
+ @$select = affix('select[up-toggle=".target"]')
291
+ @$blankOption = @$select.affix('option').text('<Please select something>').val('')
292
+ @$fooOption = @$select.affix('option[value="foo"]').text('Foo')
293
+ @$barOption = @$select.affix('option[value="bar"]').text('Bar')
294
+ @$bazOption = @$select.affix('option[value="baz"]').text('Baz')
295
+
296
+ it "shows the target element iff its up-show-for attribute contains the select value", ->
297
+ $target = affix('.target[up-show-for="something bar other"]')
298
+ up.hello(@$select)
299
+ expect($target).toBeHidden()
300
+ @$select.val('bar').change()
301
+ expect($target).toBeVisible()
302
+
303
+ it "shows the target element iff its up-hide-for attribute doesn't contain the select value", ->
304
+ $target = affix('.target[up-hide-for="something bar other"]')
305
+ up.hello(@$select)
306
+ expect($target).toBeVisible()
307
+ @$select.val('bar').change()
308
+ expect($target).toBeHidden()
309
+
310
+ it "shows the target element iff it has neither up-show-for nor up-hide-for and the select value is present", ->
311
+ $target = affix('.target')
312
+ up.hello(@$select)
313
+ expect($target).toBeHidden()
314
+ @$select.val('bar').change()
315
+ expect($target).toBeVisible()
316
+
317
+ it "shows the target element iff its up-show-for attribute contains a value ':present' and the select value is present", ->
318
+ $target = affix('.target[up-show-for=":present"]')
319
+ up.hello(@$select)
320
+ expect($target).toBeHidden()
321
+ @$select.val('bar').change()
322
+ expect($target).toBeVisible()
323
+
324
+ it "shows the target element iff its up-show-for attribute contains a value ':blank' and the select value is blank", ->
325
+ $target = affix('.target[up-show-for=":blank"]')
326
+ up.hello(@$select)
327
+ expect($target).toBeVisible()
328
+ @$select.val('bar').change()
329
+ expect($target).toBeHidden()
330
+
331
+ describe 'on a checkbox', ->
332
+
333
+ beforeEach ->
334
+ @$checkbox = affix('input[type="checkbox"][value="1"][up-toggle=".target"]')
335
+
336
+ it "shows the target element iff its up-show-for attribute is :checked and the checkbox is checked", ->
337
+ $target = affix('.target[up-show-for=":checked"]')
338
+ up.hello(@$checkbox)
339
+ expect($target).toBeHidden()
340
+ @$checkbox.prop('checked', true).change()
341
+ expect($target).toBeVisible()
342
+
343
+ it "shows the target element iff its up-show-for attribute is :unchecked and the checkbox is unchecked", ->
344
+ $target = affix('.target[up-show-for=":unchecked"]')
345
+ up.hello(@$checkbox)
346
+ expect($target).toBeVisible()
347
+ @$checkbox.prop('checked', true).change()
348
+ expect($target).toBeHidden()
349
+
350
+ it "shows the target element iff its up-hide-for attribute is :checked and the checkbox is unchecked", ->
351
+ $target = affix('.target[up-hide-for=":checked"]')
352
+ up.hello(@$checkbox)
353
+ expect($target).toBeVisible()
354
+ @$checkbox.prop('checked', true).change()
355
+ expect($target).toBeHidden()
356
+
357
+ it "shows the target element iff its up-hide-for attribute is :unchecked and the checkbox is checked", ->
358
+ $target = affix('.target[up-hide-for=":unchecked"]')
359
+ up.hello(@$checkbox)
360
+ expect($target).toBeHidden()
361
+ @$checkbox.prop('checked', true).change()
362
+ expect($target).toBeVisible()
363
+
364
+ it "shows the target element iff it has neither up-show-for nor up-hide-for and the checkbox is checked", ->
365
+ $target = affix('.target')
366
+ up.hello(@$checkbox)
367
+ expect($target).toBeHidden()
368
+ @$checkbox.prop('checked', true).change()
369
+ expect($target).toBeVisible()
370
+
371
+ describe 'on a group of radio buttons', ->
372
+
373
+ beforeEach ->
374
+ @$buttons = affix('.radio-buttons')
375
+ @$blankButton = @$buttons.affix('input[type="radio"][name="group"][up-toggle=".target"]').val('')
376
+ @$fooButton = @$buttons.affix('input[type="radio"][name="group"][up-toggle=".target"]').val('foo')
377
+ @$barButton = @$buttons.affix('input[type="radio"][name="group"][up-toggle=".target"]').val('bar')
378
+ @$bazkButton = @$buttons.affix('input[type="radio"][name="group"][up-toggle=".target"]').val('baz')
379
+
380
+ it "shows the target element iff its up-show-for attribute contains the selected button value", ->
381
+ $target = affix('.target[up-show-for="something bar other"]')
382
+ up.hello(@$buttons)
383
+ expect($target).toBeHidden()
384
+ @$barButton.prop('checked', true).change()
385
+ expect($target).toBeVisible()
386
+
387
+ it "shows the target element iff its up-hide-for attribute doesn't contain the selected button value", ->
388
+ $target = affix('.target[up-hide-for="something bar other"]')
389
+ up.hello(@$buttons)
390
+ expect($target).toBeVisible()
391
+ @$barButton.prop('checked', true).change()
392
+ expect($target).toBeHidden()
393
+
394
+ it "shows the target element iff it has neither up-show-for nor up-hide-for and the selected button value is present", ->
395
+ $target = affix('.target')
396
+ up.hello(@$buttons)
397
+ expect($target).toBeHidden()
398
+ @$barButton.prop('checked', true).change()
399
+ expect($target).toBeVisible()
400
+
401
+ it "shows the target element iff its up-show-for attribute contains a value ':present' and the selected button value is present", ->
402
+ $target = affix('.target[up-show-for=":present"]')
403
+ up.hello(@$buttons)
404
+ expect($target).toBeHidden()
405
+ @$blankButton.prop('checked', true).change()
406
+ expect($target).toBeHidden()
407
+ @$barButton.prop('checked', true).change()
408
+ expect($target).toBeVisible()
409
+
410
+ it "shows the target element iff its up-show-for attribute contains a value ':blank' and the selected button value is blank", ->
411
+ $target = affix('.target[up-show-for=":blank"]')
412
+ up.hello(@$buttons)
413
+ expect($target).toBeVisible()
414
+ @$blankButton.prop('checked', true).change()
415
+ expect($target).toBeVisible()
416
+ @$barButton.prop('checked', true).change()
417
+ expect($target).toBeHidden()
418
+
419
+ it "shows the target element iff its up-show-for attribute contains a value ':checked' and any button is checked", ->
420
+ $target = affix('.target[up-show-for=":checked"]')
421
+ up.hello(@$buttons)
422
+ expect($target).toBeHidden()
423
+ @$blankButton.prop('checked', true).change()
424
+ expect($target).toBeVisible()
425
+
426
+ it "shows the target element iff its up-show-for attribute contains a value ':unchecked' and no button is checked", ->
427
+ $target = affix('.target[up-show-for=":unchecked"]')
428
+ up.hello(@$buttons)
429
+ expect($target).toBeVisible()
430
+ @$blankButton.prop('checked', true).change()
431
+ expect($target).toBeHidden()
432
+
433
+ describe 'on a text input', ->
434
+
435
+ beforeEach ->
436
+ @$textInput = affix('input[type="text"][up-toggle=".target"]')
437
+
438
+ it "shows the target element iff its up-show-for attribute contains the input value", ->
439
+ $target = affix('.target[up-show-for="something bar other"]')
440
+ up.hello(@$textInput)
441
+ expect($target).toBeHidden()
442
+ @$textInput.val('bar').change()
443
+ expect($target).toBeVisible()
444
+
445
+ it "shows the target element iff its up-hide-for attribute doesn't contain the input value", ->
446
+ $target = affix('.target[up-hide-for="something bar other"]')
447
+ up.hello(@$textInput)
448
+ expect($target).toBeVisible()
449
+ @$textInput.val('bar').change()
450
+ expect($target).toBeHidden()
451
+
452
+ it "shows the target element iff it has neither up-show-for nor up-hide-for and the input value is present", ->
453
+ $target = affix('.target')
454
+ up.hello(@$textInput)
455
+ expect($target).toBeHidden()
456
+ @$textInput.val('bar').change()
457
+ expect($target).toBeVisible()
458
+
459
+ it "shows the target element iff its up-show-for attribute contains a value ':present' and the input value is present", ->
460
+ $target = affix('.target[up-show-for=":present"]')
461
+ up.hello(@$textInput)
462
+ expect($target).toBeHidden()
463
+ @$textInput.val('bar').change()
464
+ expect($target).toBeVisible()
465
+
466
+ it "shows the target element iff its up-show-for attribute contains a value ':blank' and the input value is blank", ->
467
+ $target = affix('.target[up-show-for=":blank"]')
468
+ up.hello(@$textInput)
469
+ expect($target).toBeVisible()
470
+ @$textInput.val('bar').change()
471
+ expect($target).toBeHidden()