luca 0.9.9 → 0.9.42

Sign up to get free protection for your applications and to get access to all the features.
Files changed (604) hide show
  1. data/CHANGELOG +9 -153
  2. data/Gemfile +1 -10
  3. data/Gemfile.lock +40 -113
  4. data/Guardfile +25 -3
  5. data/README.md +57 -54
  6. data/ROADMAP +32 -15
  7. data/Rakefile +75 -24
  8. data/app.rb +46 -12
  9. data/{app/assets → assets}/images/glyphicons-halflings-white.png +0 -0
  10. data/{app/assets → assets}/images/glyphicons-halflings.png +0 -0
  11. data/assets/javascripts/dependencies/backbone-min.js +37 -0
  12. data/assets/javascripts/dependencies/backbone-query.min.js +1 -0
  13. data/assets/javascripts/dependencies/bootstrap.min.js +7 -0
  14. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-coffeescript.js +0 -0
  15. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-css.js +0 -0
  16. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-html.js +0 -0
  17. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-javascript.js +0 -0
  18. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-less.js +0 -0
  19. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-vim.js +0 -0
  20. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror.js +0 -0
  21. data/assets/javascripts/dependencies/coffee-script.js +12189 -0
  22. data/{spec → assets}/javascripts/dependencies/jasmine-html.js +0 -0
  23. data/{spec → assets}/javascripts/dependencies/jasmine.js +0 -0
  24. data/assets/javascripts/dependencies/jquery.js +4 -0
  25. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/modal.js +0 -0
  26. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/modernizr.min.js +0 -0
  27. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/prettify.js +0 -0
  28. data/{spec → assets}/javascripts/dependencies/sinon.js +0 -0
  29. data/{vendor/assets/javascripts → assets/javascripts/dependencies}/spin-min.js +0 -0
  30. data/assets/javascripts/dependencies/underscore-min.js +31 -0
  31. data/assets/javascripts/dependencies/underscore-string.min.js +14 -0
  32. data/assets/javascripts/dependencies.coffee +5 -0
  33. data/assets/javascripts/luca/index.coffee +1 -0
  34. data/assets/javascripts/luca-templates.js +1 -0
  35. data/assets/javascripts/luca-ui-base.coffee +1 -0
  36. data/assets/javascripts/luca-ui-bootstrap.js +1 -0
  37. data/assets/javascripts/luca-ui-development-tools.coffee +9 -0
  38. data/assets/javascripts/luca-ui-full.js +3 -0
  39. data/assets/javascripts/luca-ui-spec.coffee +2 -0
  40. data/assets/javascripts/luca-ui.js +3 -0
  41. data/assets/javascripts/sandbox/application.coffee +57 -0
  42. data/assets/javascripts/sandbox/config.coffee +7 -0
  43. data/assets/javascripts/sandbox/router.coffee +24 -0
  44. data/assets/javascripts/sandbox/templates/builder/component_list.luca +1 -0
  45. data/assets/javascripts/sandbox/templates/builder.luca +2 -0
  46. data/assets/javascripts/sandbox/templates/main.luca +53 -0
  47. data/assets/javascripts/sandbox/templates/sandbox/docs_index.luca +1 -0
  48. data/assets/javascripts/sandbox/templates/sandbox/navigation.luca +8 -0
  49. data/assets/javascripts/sandbox/templates/sandbox/readme.luca +30 -0
  50. data/assets/javascripts/sandbox/templates/sandbox.luca +1 -0
  51. data/assets/javascripts/sandbox/views/builder/builder_canvas.coffee +3 -0
  52. data/assets/javascripts/sandbox/views/builder/builder_editor.coffee +6 -0
  53. data/assets/javascripts/sandbox/views/builder/component_list.coffee +38 -0
  54. data/assets/javascripts/sandbox/views/builder/project_browser.coffee +14 -0
  55. data/assets/javascripts/sandbox/views/builder.coffee +133 -0
  56. data/assets/javascripts/sandbox/views/docs_controller.coffee +7 -0
  57. data/assets/javascripts/sandbox/views/inspector/instance_filter.coffee +18 -0
  58. data/{app/assets/stylesheets/luca/containers/modal_view.scss → assets/javascripts/sandbox/views/inspector/instance_list.coffee} +0 -0
  59. data/assets/javascripts/sandbox/views/inspector.coffee +11 -0
  60. data/assets/javascripts/sandbox/views/top_navigation.coffee +4 -0
  61. data/assets/javascripts/sandbox.coffee +7 -0
  62. data/assets/javascripts/spec-dependencies.coffee +4 -0
  63. data/assets/stylesheets/bootstrap-responsive.min.css +2 -0
  64. data/assets/stylesheets/bootstrap.min.css +727 -0
  65. data/{vendor/assets → assets}/stylesheets/codemirror-blackboard.css +0 -0
  66. data/{vendor/assets → assets}/stylesheets/codemirror-monokai.css +0 -0
  67. data/{vendor/assets → assets}/stylesheets/codemirror.css +0 -0
  68. data/{vendor/assets → assets}/stylesheets/jasmine.css +0 -0
  69. data/assets/stylesheets/luca-ui-bootstrap.css +4 -0
  70. data/assets/stylesheets/luca-ui-development-tools.css +5 -0
  71. data/assets/stylesheets/luca-ui-full.css +3 -0
  72. data/assets/stylesheets/luca-ui-spec.css +3 -0
  73. data/assets/stylesheets/luca-ui.css +3 -0
  74. data/assets/stylesheets/prettify.css +40 -0
  75. data/assets/stylesheets/sandbox/builder.scss +79 -0
  76. data/assets/stylesheets/sandbox/sandbox.scss +18 -0
  77. data/assets/stylesheets/sandbox.css +3 -0
  78. data/assets/stylesheets/themes/amelia-bootstrap.css +826 -0
  79. data/assets/stylesheets/themes/slate-bootstrap.css +797 -0
  80. data/assets/stylesheets/themes/superhero-bootstrap.css +830 -0
  81. data/config.ru +2 -1
  82. data/docs/{old/application.md → application.md} +0 -0
  83. data/docs/{old/collection.md → collection.md} +0 -0
  84. data/docs/{old/collection_manager.md → collection_manager.md} +0 -0
  85. data/docs/{old/container_philosophy.md → container_philosophy.md} +0 -0
  86. data/docs/{old/event_binding_helpers.md → event_binding_helpers.md} +0 -0
  87. data/docs/{old/method_caching_and_computed_properties.md → method_caching_and_computed_properties.md} +0 -0
  88. data/docs/{old/view.md → view.md} +0 -0
  89. data/lib/luca/code_browser.rb +55 -0
  90. data/lib/luca/command_line.rb +69 -0
  91. data/lib/luca/rails/engine.rb +0 -12
  92. data/lib/luca/rails/version.rb +2 -1
  93. data/lib/luca/rails.rb +3 -5
  94. data/lib/luca/template.rb +0 -2
  95. data/lib/luca.rb +1 -25
  96. data/luca.gemspec +7 -16
  97. data/site/assets/bootstrap.min.js +7 -0
  98. data/site/assets/dependencies.js +94 -0
  99. data/site/assets/glyphicons-halflings-white.png +0 -0
  100. data/site/assets/glyphicons-halflings.png +0 -0
  101. data/site/assets/luca-ui-bootstrap.css +1331 -0
  102. data/site/assets/luca-ui-bootstrap.js +9 -0
  103. data/site/assets/luca-ui-development-tools.css +234 -0
  104. data/site/assets/luca-ui-development-tools.js +18561 -0
  105. data/site/assets/luca-ui-development-tools.min.js +15 -0
  106. data/site/assets/luca-ui-full.min.js +8 -0
  107. data/site/assets/luca-ui.min.js +4 -0
  108. data/site/assets/sandbox.css +62 -0
  109. data/site/assets/sandbox.js +469 -0
  110. data/site/docs/application.html +41 -0
  111. data/site/docs/caching.html +43 -0
  112. data/site/docs/collection.html +75 -0
  113. data/site/docs/collection_manager.html +71 -0
  114. data/site/docs/containers.html +118 -0
  115. data/site/docs/events.html +153 -0
  116. data/site/docs/view.html +128 -0
  117. data/site/img/glyphicons-halflings-white.png +0 -0
  118. data/site/img/glyphicons-halflings.png +0 -0
  119. data/site/index.html +20 -0
  120. data/site/source-map.js +1 -0
  121. data/spec/{javascripts/components → components}/application_spec.coffee +0 -0
  122. data/spec/{javascripts/components → components}/collection_loader_view_spec.coffee +0 -0
  123. data/{site/source/app/assets/javascripts/docs/lib/util.coffee → spec/components/controller_spec.coffee} +0 -0
  124. data/spec/{javascripts/components → components}/fields/checkbox_array_spec.coffee +0 -0
  125. data/spec/components/form_view_spec.coffee +80 -0
  126. data/spec/{javascripts/components → components}/grid_view_spec.coffee +0 -0
  127. data/spec/{javascripts/components → components}/record_manager_spec.coffee +0 -0
  128. data/spec/{javascripts/components → components}/template_spec.coffee +0 -0
  129. data/spec/containers/card_view_spec.coffee +50 -0
  130. data/{site/source/app/assets/javascripts/docs/views/components/code_editor/index.coffee → spec/containers/column_view_spec.coffee} +0 -0
  131. data/spec/{javascripts/containers → containers}/modal_view_spec.coffee +0 -0
  132. data/spec/{javascripts/containers → containers}/panel_view_spec.coffee +0 -0
  133. data/spec/{javascripts/components/pagination_control_spec.coffee → containers/split_view_spec.coffee} +0 -0
  134. data/spec/{javascripts/containers → containers}/tab_view_spec.coffee +0 -0
  135. data/spec/{javascripts/containers → containers}/viewport_spec.coffee +0 -0
  136. data/spec/{javascripts/core → core}/collection_spec.coffee +1 -26
  137. data/spec/core/container_spec.coffee +66 -0
  138. data/spec/{javascripts/concerns/paginatable_spec.coffee → core/field_spec.coffee} +0 -0
  139. data/spec/{javascripts/core → core}/model_spec.coffee +3 -26
  140. data/spec/{javascripts/core → core}/observer_spec.coffee +0 -0
  141. data/spec/{javascripts/core → core}/view_spec.coffee +38 -114
  142. data/spec/{javascripts/core/framework_spec.coffee → framework_spec.coffee} +2 -31
  143. data/spec/{javascripts/helper.coffee → helper.coffee} +0 -0
  144. data/spec/{javascripts/managers → managers}/collection_manager_spec.coffee +0 -0
  145. data/spec/{javascripts/managers → managers}/socket_manager_spec.coffee +0 -0
  146. data/src/components/application.coffee +318 -0
  147. data/src/components/base_toolbar.coffee +15 -0
  148. data/{app/assets/javascripts/luca → src}/components/collection_loader_view.coffee +1 -3
  149. data/src/components/collection_view.coffee +131 -0
  150. data/src/components/controller.coffee +63 -0
  151. data/src/components/fields/button_field.coffee +38 -0
  152. data/{app/assets/javascripts/luca → src}/components/fields/checkbox_array.coffee +7 -18
  153. data/{app/assets/javascripts/luca → src}/components/fields/checkbox_field.coffee +10 -19
  154. data/{app/assets/javascripts/luca → src}/components/fields/file_upload_field.coffee +4 -5
  155. data/src/components/fields/hidden_field.coffee +12 -0
  156. data/src/components/fields/label_field.coffee +14 -0
  157. data/src/components/fields/select_field.coffee +97 -0
  158. data/src/components/fields/text_area_field.coffee +40 -0
  159. data/{app/assets/javascripts/luca → src}/components/fields/text_field.coffee +5 -16
  160. data/src/components/fields/type_ahead_field.coffee +22 -0
  161. data/src/components/form_button_toolbar.coffee +25 -0
  162. data/src/components/form_view.coffee +275 -0
  163. data/src/components/grid_view.coffee +269 -0
  164. data/src/components/index.coffee +1 -0
  165. data/src/components/load_mask.coffee +3 -0
  166. data/src/components/nav_bar.coffee +22 -0
  167. data/src/components/page_controller.coffee +2 -0
  168. data/{app/assets/javascripts/luca → src}/components/record_manager.coffee +0 -0
  169. data/{app/assets/javascripts/luca → src}/components/router.coffee +1 -6
  170. data/src/components/table_view.coffee +53 -0
  171. data/src/components/template.coffee +5 -0
  172. data/src/components/toolbar_dialog.coffee +25 -0
  173. data/src/containers/card_view.coffee +93 -0
  174. data/src/containers/column_view.coffee +42 -0
  175. data/{app/assets/javascripts/luca → src}/containers/modal_view.coffee +9 -9
  176. data/src/containers/page_view.coffee +2 -0
  177. data/{app/assets/javascripts/luca → src}/containers/panel_toolbar.coffee +84 -89
  178. data/src/containers/panel_view.coffee +23 -0
  179. data/src/containers/split_view.coffee +8 -0
  180. data/{app/assets/javascripts/luca → src}/containers/tab_view.coffee +21 -27
  181. data/{app/assets/javascripts/luca → src}/containers/viewport.coffee +18 -14
  182. data/{app/assets/javascripts/luca → src}/core/collection.coffee +51 -97
  183. data/src/core/container.coffee +374 -0
  184. data/{tutorials/component-definitions.md → src/core/core.coffee} +0 -0
  185. data/src/core/field.coffee +79 -0
  186. data/src/core/model.coffee +43 -0
  187. data/{app/assets/javascripts/luca → src}/core/observer.coffee +0 -0
  188. data/src/core/panel.coffee +118 -0
  189. data/{app/assets/javascripts/luca/core/registry → src/core}/registry.coffee +43 -63
  190. data/{app/assets/javascripts/luca/util → src/core}/script_loader.coffee +0 -0
  191. data/src/core/view.coffee +264 -0
  192. data/src/define.coffee +110 -0
  193. data/{app/assets/javascripts/luca → src}/framework.coffee +103 -98
  194. data/src/index.coffee +23 -0
  195. data/{app/assets/javascripts/luca → src}/managers/collection_manager.coffee +13 -37
  196. data/src/managers/socket_manager.coffee +54 -0
  197. data/{app/assets/javascripts/luca/concerns → src/modules}/deferrable.coffee +4 -5
  198. data/src/modules/grid_layout.coffee +3 -0
  199. data/{app/assets/javascripts/luca/concerns/loadmaskable.coffee → src/modules/load_mask.coffee} +11 -23
  200. data/{app/assets/javascripts/luca/concerns → src/modules}/local_storage.coffee +0 -0
  201. data/src/plugins/development_tool_helpers.coffee +21 -0
  202. data/src/plugins/events.coffee +54 -0
  203. data/src/samples/definition.coffee +49 -0
  204. data/{tutorials/component-definitions/01_intro.md → src/stylesheets/base.scss} +0 -0
  205. data/{app/assets/stylesheets/luca → src/stylesheets}/components/checkbox_array.scss +1 -1
  206. data/src/stylesheets/components/form_view.scss +59 -0
  207. data/{app/assets/stylesheets/luca → src/stylesheets}/components/grid_view.scss +0 -0
  208. data/{app/assets/stylesheets/luca → src/stylesheets}/components/load_mask.scss +0 -0
  209. data/src/stylesheets/components/toolbar.scss +0 -0
  210. data/{app/assets/stylesheets/luca → src/stylesheets}/components/viewport.scss +4 -1
  211. data/src/stylesheets/containers/container.scss +16 -0
  212. data/src/stylesheets/containers/modal_view.scss +0 -0
  213. data/{app/assets/stylesheets/luca → src/stylesheets}/containers/panels.scss +0 -0
  214. data/{app/assets/stylesheets/luca → src/stylesheets}/containers/tab_view.scss +5 -5
  215. data/{app/assets/stylesheets/luca → src/stylesheets}/normalize.scss +0 -0
  216. data/src/stylesheets/tools/class_browser.scss +32 -0
  217. data/src/stylesheets/tools/code_editor.scss +24 -0
  218. data/src/stylesheets/tools/component_tester.scss +26 -0
  219. data/{app/assets/stylesheets/luca/development → src/stylesheets/tools}/console.scss +0 -0
  220. data/src/templates/components/bootstrap_form_controls.luca +7 -0
  221. data/src/templates/components/collection_loader_view.luca +5 -0
  222. data/src/templates/components/form_alert +0 -0
  223. data/src/templates/components/form_alert.luca +3 -0
  224. data/src/templates/components/grid_view.luca +7 -0
  225. data/src/templates/components/grid_view_empty_text.luca +3 -0
  226. data/src/templates/components/load_mask.luca +3 -0
  227. data/src/templates/components/nav_bar.luca +2 -0
  228. data/src/templates/containers/basic.luca +1 -0
  229. data/src/templates/containers/tab_selector_container.luca +8 -0
  230. data/src/templates/containers/tab_view.luca +2 -0
  231. data/src/templates/containers/toolbar_wrapper.luca +1 -0
  232. data/src/templates/fields/button_field.luca +2 -0
  233. data/src/templates/fields/button_field_link.luca +5 -0
  234. data/src/templates/fields/checkbox_array.luca +4 -0
  235. data/src/templates/fields/checkbox_array_item.luca +4 -0
  236. data/src/templates/fields/checkbox_field.luca +9 -0
  237. data/src/templates/fields/file_upload_field.luca +8 -0
  238. data/src/templates/fields/hidden_field.luca +1 -0
  239. data/src/templates/fields/select_field.luca +8 -0
  240. data/src/templates/fields/text_area_field.luca +8 -0
  241. data/src/templates/fields/text_field.luca +17 -0
  242. data/src/templates/sample/contents.luca +1 -0
  243. data/src/templates/sample/welcome.luca +1 -0
  244. data/src/templates/table_view.luca +4 -0
  245. data/src/tools/application_inspector.coffee +2 -0
  246. data/src/tools/code_editor.coffee +258 -0
  247. data/{app/assets/javascripts/luca/development → src/tools}/code_mirror_field.coffee +1 -2
  248. data/src/tools/coffee_script_editor.coffee +82 -0
  249. data/src/tools/collection_inspector.coffee +4 -0
  250. data/src/tools/collections/components.coffee +59 -0
  251. data/src/tools/collections/instances.coffee +15 -0
  252. data/src/tools/component_tester.coffee +462 -0
  253. data/{app/assets/javascripts/luca/development → src/tools}/console.coffee +24 -55
  254. data/src/tools/models/components.coffee +25 -0
  255. data/src/tools/models/instance.coffee +2 -0
  256. data/src/tools/templates/component_tester/help.luca +14 -0
  257. data/{app/assets/javascripts/luca/util/luca.coffee → src/util.coffee} +6 -90
  258. data/vendor/assets/javascripts/luca-ui-development-tools.js +18533 -0
  259. data/vendor/assets/javascripts/luca-ui-development-tools.min.js +15 -0
  260. data/vendor/assets/javascripts/luca-ui-full.js +4806 -0
  261. data/vendor/assets/javascripts/luca-ui-full.min.js +8 -0
  262. data/vendor/assets/javascripts/luca-ui-templates.js +24 -0
  263. data/vendor/assets/javascripts/luca-ui.js +1703 -4394
  264. data/vendor/assets/javascripts/luca-ui.min.js +4 -5
  265. data/vendor/assets/luca-ui/base.css +85 -0
  266. data/vendor/assets/luca-ui/components/application.js +91 -0
  267. data/vendor/assets/luca-ui/components/base_toolbar.js +23 -0
  268. data/vendor/assets/luca-ui/components/controller.js +38 -0
  269. data/vendor/assets/luca-ui/components/fields/button_field.js +45 -0
  270. data/vendor/assets/luca-ui/components/fields/checkbox_field.js +43 -0
  271. data/vendor/assets/luca-ui/components/fields/file_upload_field.js +20 -0
  272. data/vendor/assets/luca-ui/components/fields/hidden_field.js +20 -0
  273. data/vendor/assets/luca-ui/components/fields/select_field.js +97 -0
  274. data/vendor/assets/luca-ui/components/fields/text_area_field.js +48 -0
  275. data/vendor/assets/luca-ui/components/fields/text_field.js +46 -0
  276. data/vendor/assets/luca-ui/components/fields/type_ahead_field.js +13 -0
  277. data/vendor/assets/luca-ui/components/form_button_toolbar.js +32 -0
  278. data/vendor/assets/luca-ui/components/form_view.css +32 -0
  279. data/vendor/assets/luca-ui/components/form_view.js +207 -0
  280. data/{app/assets/stylesheets/luca/components/table_view.scss → vendor/assets/luca-ui/components/grid_view.css} +51 -60
  281. data/vendor/assets/luca-ui/components/grid_view.js +202 -0
  282. data/vendor/assets/luca-ui/components/record_manager.js +207 -0
  283. data/vendor/assets/luca-ui/components/router.js +36 -0
  284. data/vendor/assets/luca-ui/components/template.js +26 -0
  285. data/vendor/assets/luca-ui/components/toolbar.css +11 -0
  286. data/vendor/assets/luca-ui/containers/card_view.js +98 -0
  287. data/vendor/assets/luca-ui/containers/column_view.js +52 -0
  288. data/vendor/assets/luca-ui/containers/container.css +3 -0
  289. data/vendor/assets/luca-ui/containers/modal_view.css +0 -0
  290. data/vendor/assets/luca-ui/containers/modal_view.js +87 -0
  291. data/vendor/assets/luca-ui/containers/panel_view.js +34 -0
  292. data/vendor/assets/luca-ui/containers/split_view.js +13 -0
  293. data/vendor/assets/luca-ui/containers/tab_view.css +16 -0
  294. data/vendor/assets/luca-ui/containers/tab_view.js +80 -0
  295. data/vendor/assets/luca-ui/containers/viewport.js +18 -0
  296. data/vendor/assets/luca-ui/core/collection.js +221 -0
  297. data/vendor/assets/luca-ui/core/container.js +205 -0
  298. data/vendor/assets/luca-ui/core/field.js +59 -0
  299. data/vendor/assets/luca-ui/core/observer.js +42 -0
  300. data/vendor/assets/luca-ui/core/view.js +127 -0
  301. data/vendor/assets/luca-ui/framework.js +110 -0
  302. data/vendor/assets/luca-ui/index.js +5 -0
  303. data/vendor/assets/luca-ui/managers/collection_manager.js +98 -0
  304. data/vendor/assets/luca-ui/managers/socket_manager.js +52 -0
  305. data/vendor/assets/luca-ui/modules/deferrable.js +21 -0
  306. data/vendor/assets/luca-ui/modules/local_storage.js +81 -0
  307. data/vendor/assets/luca-ui/normalize.css +359 -0
  308. data/vendor/assets/luca-ui/stylesheets/base.css +85 -0
  309. data/vendor/assets/luca-ui/stylesheets/components/form_view.css +32 -0
  310. data/vendor/assets/luca-ui/stylesheets/components/grid_view.css +76 -0
  311. data/vendor/assets/luca-ui/stylesheets/components/toolbar.css +11 -0
  312. data/vendor/assets/luca-ui/stylesheets/containers/container.css +3 -0
  313. data/vendor/assets/luca-ui/stylesheets/containers/modal_view.css +0 -0
  314. data/vendor/assets/luca-ui/stylesheets/containers/tab_view.css +16 -0
  315. data/vendor/assets/luca-ui/stylesheets/normalize.css +359 -0
  316. data/vendor/assets/luca-ui/templates/components/bootstrap_form_controls.js +4 -0
  317. data/vendor/assets/luca-ui/templates/components/form_view.js +4 -0
  318. data/vendor/assets/luca-ui/templates/components/grid_view.js +4 -0
  319. data/vendor/assets/luca-ui/templates/components/grid_view_empty_text.js +4 -0
  320. data/vendor/assets/luca-ui/templates/containers/basic.js +4 -0
  321. data/vendor/assets/luca-ui/templates/containers/tab_selector_container.js +4 -0
  322. data/vendor/assets/luca-ui/templates/containers/tab_view.js +4 -0
  323. data/vendor/assets/luca-ui/templates/containers/toolbar_wrapper.js +4 -0
  324. data/vendor/assets/luca-ui/templates/fields/button_field.js +4 -0
  325. data/vendor/assets/luca-ui/templates/fields/button_field_link.js +4 -0
  326. data/vendor/assets/luca-ui/templates/fields/checkbox_field.js +4 -0
  327. data/vendor/assets/luca-ui/templates/fields/file_upload_field.js +4 -0
  328. data/vendor/assets/luca-ui/templates/fields/hidden_field.js +4 -0
  329. data/vendor/assets/luca-ui/templates/fields/select_field.js +4 -0
  330. data/vendor/assets/luca-ui/templates/fields/text_area_field.js +4 -0
  331. data/vendor/assets/luca-ui/templates/fields/text_field.js +4 -0
  332. data/vendor/assets/luca-ui/templates/sample/contents.js +4 -0
  333. data/vendor/assets/luca-ui/templates/sample/welcome.js +4 -0
  334. data/vendor/assets/stylesheets/luca-ui.css +471 -68
  335. data/views/jasmine.erb +2 -2
  336. metadata +328 -496
  337. data/app/assets/javascripts/luca/basic.coffee +0 -8
  338. data/app/assets/javascripts/luca/components/application.coffee +0 -530
  339. data/app/assets/javascripts/luca/components/collection_view.coffee +0 -211
  340. data/app/assets/javascripts/luca/components/controller.coffee +0 -176
  341. data/app/assets/javascripts/luca/components/fields/base.coffee +0 -144
  342. data/app/assets/javascripts/luca/components/fields/button_field.coffee +0 -91
  343. data/app/assets/javascripts/luca/components/fields/hidden_field.coffee +0 -11
  344. data/app/assets/javascripts/luca/components/fields/label_field.coffee +0 -12
  345. data/app/assets/javascripts/luca/components/fields/select_field.coffee +0 -159
  346. data/app/assets/javascripts/luca/components/fields/text_area_field.coffee +0 -57
  347. data/app/assets/javascripts/luca/components/fields/type_ahead_field.coffee +0 -20
  348. data/app/assets/javascripts/luca/components/form_view.coffee +0 -421
  349. data/app/assets/javascripts/luca/components/grid_layout_view.coffee +0 -42
  350. data/app/assets/javascripts/luca/components/index.coffee +0 -7
  351. data/app/assets/javascripts/luca/components/load_mask.coffee +0 -8
  352. data/app/assets/javascripts/luca/components/multi_collection_view.coffee +0 -92
  353. data/app/assets/javascripts/luca/components/nav_bar.coffee +0 -80
  354. data/app/assets/javascripts/luca/components/page.coffee +0 -70
  355. data/app/assets/javascripts/luca/components/pagination_control.coffee +0 -104
  356. data/app/assets/javascripts/luca/components/simple_collection_view.coffee +0 -10
  357. data/app/assets/javascripts/luca/components/table_view.coffee +0 -93
  358. data/app/assets/javascripts/luca/components/table_view_scrollable.coffee +0 -23
  359. data/app/assets/javascripts/luca/concerns/application_event_bindings.coffee +0 -19
  360. data/app/assets/javascripts/luca/concerns/collection_event_bindings.coffee +0 -47
  361. data/app/assets/javascripts/luca/concerns/development_tool_helpers.coffee +0 -30
  362. data/app/assets/javascripts/luca/concerns/dom_helpers.coffee +0 -61
  363. data/app/assets/javascripts/luca/concerns/enhanced_properties.coffee +0 -23
  364. data/app/assets/javascripts/luca/concerns/filterable.coffee +0 -101
  365. data/app/assets/javascripts/luca/concerns/form_model_bindings.coffee +0 -20
  366. data/app/assets/javascripts/luca/concerns/grid_layout.coffee +0 -15
  367. data/app/assets/javascripts/luca/concerns/modal_view.coffee +0 -63
  368. data/app/assets/javascripts/luca/concerns/model_presenter.coffee +0 -23
  369. data/app/assets/javascripts/luca/concerns/paginatable.coffee +0 -79
  370. data/app/assets/javascripts/luca/concerns/query_collection_bindings.coffee +0 -52
  371. data/app/assets/javascripts/luca/concerns/sortable.coffee +0 -69
  372. data/app/assets/javascripts/luca/concerns/state_model.coffee +0 -58
  373. data/app/assets/javascripts/luca/concerns/templating.coffee +0 -13
  374. data/app/assets/javascripts/luca/config.coffee +0 -54
  375. data/app/assets/javascripts/luca/containers/card_view.coffee +0 -178
  376. data/app/assets/javascripts/luca/containers/container.coffee +0 -711
  377. data/app/assets/javascripts/luca/containers/index.coffee +0 -2
  378. data/app/assets/javascripts/luca/containers/page_controller.coffee +0 -25
  379. data/app/assets/javascripts/luca/core/events.coffee +0 -114
  380. data/app/assets/javascripts/luca/core/index.coffee +0 -12
  381. data/app/assets/javascripts/luca/core/model.coffee +0 -56
  382. data/app/assets/javascripts/luca/core/panel.coffee +0 -124
  383. data/app/assets/javascripts/luca/core/registry/component_definition.coffee +0 -319
  384. data/app/assets/javascripts/luca/core/registry/concerns.coffee +0 -70
  385. data/app/assets/javascripts/luca/core/registry/index.coffee +0 -4
  386. data/app/assets/javascripts/luca/core/registry/meta_data.coffee +0 -99
  387. data/app/assets/javascripts/luca/core/templates.coffee +0 -51
  388. data/app/assets/javascripts/luca/core/view.coffee +0 -383
  389. data/app/assets/javascripts/luca/dependencies.coffee +0 -9
  390. data/app/assets/javascripts/luca/development/code_sync_manager.coffee +0 -173
  391. data/app/assets/javascripts/luca/development/component.coffee +0 -76
  392. data/app/assets/javascripts/luca/development/components.coffee +0 -57
  393. data/app/assets/javascripts/luca/development/index.coffee +0 -5
  394. data/app/assets/javascripts/luca/index.coffee +0 -9
  395. data/app/assets/javascripts/luca/managers/index.coffee +0 -2
  396. data/app/assets/javascripts/luca/managers/socket_manager.coffee +0 -89
  397. data/app/assets/javascripts/luca/templates/components/bootstrap_form_controls.jst.ejs +0 -10
  398. data/app/assets/javascripts/luca/templates/components/collection_loader_view.jst.ejs +0 -6
  399. data/app/assets/javascripts/luca/templates/components/form_alert.jst.ejs +0 -4
  400. data/app/assets/javascripts/luca/templates/components/grid_view.jst.ejs +0 -11
  401. data/app/assets/javascripts/luca/templates/components/grid_view_empty_text.jst.ejs +0 -3
  402. data/app/assets/javascripts/luca/templates/components/load_mask.jst.ejs +0 -5
  403. data/app/assets/javascripts/luca/templates/components/nav_bar.jst.ejs +0 -19
  404. data/app/assets/javascripts/luca/templates/components/pagination.jst.ejs +0 -10
  405. data/app/assets/javascripts/luca/templates/components/table_view.jst.ejs +0 -4
  406. data/app/assets/javascripts/luca/templates/containers/basic.jst.ejs +0 -1
  407. data/app/assets/javascripts/luca/templates/containers/tab_selector_container.jst.ejs +0 -12
  408. data/app/assets/javascripts/luca/templates/containers/tab_view.jst.ejs +0 -2
  409. data/app/assets/javascripts/luca/templates/containers/toolbar_wrapper.jst.ejs +0 -1
  410. data/app/assets/javascripts/luca/templates/fields/button_field.jst.ejs +0 -2
  411. data/app/assets/javascripts/luca/templates/fields/button_field_link.jst.ejs +0 -6
  412. data/app/assets/javascripts/luca/templates/fields/checkbox_array.jst.ejs +0 -4
  413. data/app/assets/javascripts/luca/templates/fields/checkbox_array_item.jst.ejs +0 -3
  414. data/app/assets/javascripts/luca/templates/fields/checkbox_field.jst.ejs +0 -10
  415. data/app/assets/javascripts/luca/templates/fields/file_upload_field.jst.ejs +0 -10
  416. data/app/assets/javascripts/luca/templates/fields/hidden_field.jst.ejs +0 -1
  417. data/app/assets/javascripts/luca/templates/fields/select_field.jst.ejs +0 -11
  418. data/app/assets/javascripts/luca/templates/fields/text_area_field.jst.ejs +0 -11
  419. data/app/assets/javascripts/luca/templates/fields/text_field.jst.ejs +0 -16
  420. data/app/assets/javascripts/luca/util/deprecations.coffee +0 -18
  421. data/app/assets/javascripts/luca/util/index.coffee +0 -4
  422. data/app/assets/javascripts/luca/util/keybindings.coffee +0 -24
  423. data/app/assets/javascripts/luca/util/logging.coffee +0 -30
  424. data/app/assets/javascripts/luca-ui.js +0 -1
  425. data/app/assets/stylesheets/luca/components/form_view.scss +0 -7
  426. data/app/assets/stylesheets/luca/containers/container.scss +0 -19
  427. data/app/assets/stylesheets/luca/development/index.css +0 -3
  428. data/app/assets/stylesheets/luca/index.css +0 -4
  429. data/bin/luca +0 -14
  430. data/docs/framework.json +0 -1
  431. data/docs/luca-framework-documentation.js +0 -1
  432. data/lib/generators/luca/application/application_generator.rb +0 -75
  433. data/lib/generators/luca/application/templates/controller.rb +0 -4
  434. data/lib/generators/luca/application/templates/index.html.erb +0 -19
  435. data/lib/generators/luca/application/templates/index.html.haml +0 -7
  436. data/lib/generators/luca/application/templates/javascripts/application.coffee +0 -18
  437. data/lib/generators/luca/application/templates/javascripts/collection_manager.coffee +0 -2
  438. data/lib/generators/luca/application/templates/javascripts/config.coffee +0 -3
  439. data/lib/generators/luca/application/templates/javascripts/dependencies.coffee +0 -3
  440. data/lib/generators/luca/application/templates/javascripts/home.jst.ejs +0 -2
  441. data/lib/generators/luca/application/templates/javascripts/index.coffee +0 -15
  442. data/lib/generators/luca/application/templates/javascripts/router.coffee +0 -4
  443. data/lib/guard/luca.rb +0 -84
  444. data/lib/luca/asset_compiler.rb +0 -117
  445. data/lib/luca/cli/generate.rb +0 -37
  446. data/lib/luca/cli/server.rb +0 -20
  447. data/lib/luca/cli/sync.rb +0 -40
  448. data/lib/luca/cli/watch.rb +0 -16
  449. data/lib/luca/cli.rb +0 -68
  450. data/lib/luca/collection/endpoint.rb +0 -38
  451. data/lib/luca/collection/file_backend.rb +0 -121
  452. data/lib/luca/collection/redis_backend.rb +0 -153
  453. data/lib/luca/collection.rb +0 -64
  454. data/lib/luca/compiled_asset.rb +0 -61
  455. data/lib/luca/component_definition.rb +0 -356
  456. data/lib/luca/luca_application.rb +0 -258
  457. data/lib/luca/project.rb +0 -73
  458. data/lib/luca/project_harness.rb +0 -96
  459. data/lib/luca/server.rb +0 -7
  460. data/lib/luca/stylesheet.rb +0 -35
  461. data/lib/luca/template_asset.rb +0 -64
  462. data/lib/luca/version.rb +0 -3
  463. data/lib/luca/watcher.rb +0 -72
  464. data/lib/railties/luca/tasks.rake +0 -38
  465. data/site/.bundle/config +0 -2
  466. data/site/.gitignore +0 -5
  467. data/site/.rvmrc +0 -1
  468. data/site/CHANGELOG.md +0 -41
  469. data/site/DOCS.md +0 -41
  470. data/site/Gemfile +0 -8
  471. data/site/Gemfile.lock +0 -134
  472. data/site/LICENSE.md +0 -19
  473. data/site/config.rb +0 -84
  474. data/site/helpers/site_helpers.rb +0 -20
  475. data/site/html5bp-docs/README.md +0 -38
  476. data/site/html5bp-docs/contribute.md +0 -104
  477. data/site/html5bp-docs/crossdomain.md +0 -21
  478. data/site/html5bp-docs/css.md +0 -135
  479. data/site/html5bp-docs/extend.md +0 -507
  480. data/site/html5bp-docs/faq.md +0 -77
  481. data/site/html5bp-docs/htaccess.md +0 -323
  482. data/site/html5bp-docs/html.md +0 -170
  483. data/site/html5bp-docs/js.md +0 -31
  484. data/site/html5bp-docs/misc.md +0 -25
  485. data/site/html5bp-docs/usage.md +0 -109
  486. data/site/readme.md +0 -47
  487. data/site/source/.htaccess +0 -540
  488. data/site/source/404.html +0 -157
  489. data/site/source/app/assets/javascripts/dependencies.js.coffee +0 -6
  490. data/site/source/app/assets/javascripts/docs/application.coffee +0 -64
  491. data/site/source/app/assets/javascripts/docs/collections/docs_documentation.coffee +0 -17
  492. data/site/source/app/assets/javascripts/docs/collections/github_repositories.coffee +0 -7
  493. data/site/source/app/assets/javascripts/docs/collections/index.coffee +0 -1
  494. data/site/source/app/assets/javascripts/docs/collections/luca_documentation.coffee +0 -17
  495. data/site/source/app/assets/javascripts/docs/collections/public_gists.coffee +0 -4
  496. data/site/source/app/assets/javascripts/docs/config.coffee +0 -5
  497. data/site/source/app/assets/javascripts/docs/index.coffee +0 -12
  498. data/site/source/app/assets/javascripts/docs/lib/router.coffee +0 -3
  499. data/site/source/app/assets/javascripts/docs/models/component.coffee +0 -99
  500. data/site/source/app/assets/javascripts/docs/models/github_repository.coffee +0 -3
  501. data/site/source/app/assets/javascripts/docs/models/index.coffee +0 -1
  502. data/site/source/app/assets/javascripts/docs/templates/component_documentation.jst.ejs +0 -55
  503. data/site/source/app/assets/javascripts/docs/templates/examples_browser/overview.jst.ejs +0 -4
  504. data/site/source/app/assets/javascripts/docs/templates/examples_browser/selector.jst.ejs +0 -11
  505. data/site/source/app/assets/javascripts/docs/templates/github_repository.jst.ejs +0 -4
  506. data/site/source/app/assets/javascripts/docs/templates/layouts/main.jst.ejs +0 -4
  507. data/site/source/app/assets/javascripts/docs/templates/left_navigation.jst.ejs +0 -5
  508. data/site/source/app/assets/javascripts/docs/templates/pages/getting_started.jst.ejs +0 -78
  509. data/site/source/app/assets/javascripts/docs/templates/pages/home.jst.ejs +0 -57
  510. data/site/source/app/assets/javascripts/docs/views/components/code_editor.coffee +0 -45
  511. data/site/source/app/assets/javascripts/docs/views/components/component_documentation.coffee +0 -72
  512. data/site/source/app/assets/javascripts/docs/views/index.coffee +0 -3
  513. data/site/source/app/assets/javascripts/docs/views/pages/browse_source/details.coffee +0 -37
  514. data/site/source/app/assets/javascripts/docs/views/pages/browse_source/list.coffee +0 -31
  515. data/site/source/app/assets/javascripts/docs/views/pages/browse_source.coffee +0 -46
  516. data/site/source/app/assets/javascripts/docs/views/pages/component_editor.coffee +0 -10
  517. data/site/source/app/assets/javascripts/docs/views/pages/examples_browser/docs.coffee +0 -12
  518. data/site/source/app/assets/javascripts/docs/views/pages/examples_browser/source.coffee +0 -13
  519. data/site/source/app/assets/javascripts/docs/views/pages/examples_browser.coffee +0 -102
  520. data/site/source/app/assets/javascripts/docs/views/pages/home.coffee +0 -10
  521. data/site/source/app/assets/javascripts/docs/views/views/api_browser/index.coffee +0 -43
  522. data/site/source/app/assets/javascripts/docs/views/views/collection_view_examples/grid_layout_view_example.coffee +0 -14
  523. data/site/source/app/assets/javascripts/docs/views/views/collection_view_examples/table_view_example.coffee +0 -39
  524. data/site/source/app/assets/javascripts/docs/views/views/form_view_examples/basic_example.coffee +0 -38
  525. data/site/source/app/assets/javascripts/docs/views/views/form_view_examples/complex_layout.coffee +0 -110
  526. data/site/source/app/assets/javascripts/docs/views/views/top_navigation.coffee +0 -6
  527. data/site/source/app/assets/javascripts/docs-docs.js +0 -1
  528. data/site/source/app/assets/javascripts/luca-docs.js +0 -1
  529. data/site/source/app/assets/javascripts/luca-framework-documentation.js +0 -1
  530. data/site/source/app/assets/javascripts/site.js.coffee +0 -4
  531. data/site/source/app/assets/javascripts/vendor/codemirror.js +0 -4786
  532. data/site/source/app/assets/javascripts/vendor/coffeescript.js +0 -346
  533. data/site/source/app/assets/javascripts/vendor/css.js +0 -465
  534. data/site/source/app/assets/javascripts/vendor/htmlmixed.js +0 -84
  535. data/site/source/app/assets/javascripts/vendor/javascript.js +0 -422
  536. data/site/source/app/assets/javascripts/vendor/js-beautify.js +0 -1353
  537. data/site/source/app/assets/javascripts/vendor/modernizr-2.6.1.min.js +0 -4
  538. data/site/source/app/assets/javascripts/vendor/vim.js +0 -2511
  539. data/site/source/app/assets/stylesheets/docs/api-browser.css.scss +0 -5
  540. data/site/source/app/assets/stylesheets/docs/application.css.scss +0 -35
  541. data/site/source/app/assets/stylesheets/docs/browse-source.css.scss +0 -5
  542. data/site/source/app/assets/stylesheets/docs/scrollable-table.css.scss +0 -5
  543. data/site/source/app/assets/stylesheets/site.css.scss +0 -2
  544. data/site/source/app/assets/stylesheets/vendor/codemirror.css +0 -240
  545. data/site/source/app/assets/stylesheets/vendor/prettify-tomorrow-night-bright.css +0 -160
  546. data/site/source/app/assets/stylesheets/vendor/twilight.css +0 -26
  547. data/site/source/crossdomain.xml +0 -15
  548. data/site/source/documentation.html.haml +0 -1
  549. data/site/source/favicon_base.png +0 -0
  550. data/site/source/humans.txt +0 -15
  551. data/site/source/images/background.png +0 -0
  552. data/site/source/images/middleman.png +0 -0
  553. data/site/source/index.html.haml +0 -1
  554. data/site/source/layouts/layout.haml +0 -55
  555. data/site/source/readme.md +0 -63
  556. data/site/source/robots.txt +0 -3
  557. data/spec/javascripts/components/collection_view_spec.coffee +0 -59
  558. data/spec/javascripts/components/controller_spec.coffee +0 -62
  559. data/spec/javascripts/components/form_view_spec.coffee +0 -162
  560. data/spec/javascripts/components/multi_collection_view_spec.coffee +0 -5
  561. data/spec/javascripts/components/table_view_spec.coffee +0 -17
  562. data/spec/javascripts/concerns/collection_event_bindings_spec.coffee +0 -15
  563. data/spec/javascripts/concerns/dom_helpers_spec.coffee +0 -16
  564. data/spec/javascripts/concerns/filterable_spec.coffee +0 -25
  565. data/spec/javascripts/concerns/model_presenter_spec.coffee +0 -31
  566. data/spec/javascripts/concerns/state_model_spec.coffee +0 -55
  567. data/spec/javascripts/containers/card_view_spec.coffee +0 -108
  568. data/spec/javascripts/core/concerns_spec.coffee +0 -88
  569. data/spec/javascripts/core/container_spec.coffee +0 -287
  570. data/spec/javascripts/core/define_spec.coffee +0 -116
  571. data/spec/javascripts/core/events_spec.coffee +0 -26
  572. data/spec/javascripts/core/field_spec.coffee +0 -4
  573. data/spec/javascripts/core/util_spec.coffee +0 -24
  574. data/spec/javascripts/dependencies/index.coffee +0 -3
  575. data/spec/lib/component_definition_spec.rb +0 -63
  576. data/spec/lib/input_compiler_spec.rb +0 -9
  577. data/spec/lib/luca_application_spec.rb +0 -30
  578. data/spec/support/fixtures/application.coffee +0 -45
  579. data/spec/support/fixtures/component.coffee +0 -34
  580. data/tutorials/component-driven-design.md +0 -140
  581. data/tutorials/structure-of-a-project.md +0 -63
  582. data/vendor/assets/javascripts/backbone-ext.js +0 -21
  583. data/vendor/assets/javascripts/backbone-min.js +0 -42
  584. data/vendor/assets/javascripts/backbone-query.min.js +0 -1
  585. data/vendor/assets/javascripts/bootstrap.min.js +0 -7
  586. data/vendor/assets/javascripts/codemirror-ui.js +0 -503
  587. data/vendor/assets/javascripts/hogan.js +0 -707
  588. data/vendor/assets/javascripts/inflections.js +0 -656
  589. data/vendor/assets/javascripts/jasmine-html.js +0 -190
  590. data/vendor/assets/javascripts/jasmine.js +0 -2476
  591. data/vendor/assets/javascripts/jquery.js +0 -5
  592. data/vendor/assets/javascripts/keymaster.min.js +0 -4
  593. data/vendor/assets/javascripts/luca-dependencies.min.js +0 -8
  594. data/vendor/assets/javascripts/luca-development.min.js +0 -1
  595. data/vendor/assets/javascripts/luca-spec.js +0 -11
  596. data/vendor/assets/javascripts/luca.full.min.js +0 -12
  597. data/vendor/assets/javascripts/luca.min.js +0 -5
  598. data/vendor/assets/javascripts/sinon.js +0 -3469
  599. data/vendor/assets/javascripts/underscore-min.js +0 -1
  600. data/vendor/assets/javascripts/underscore-string.min.js +0 -1
  601. data/vendor/assets/stylesheets/bootstrap-responsive.min.css +0 -9
  602. data/vendor/assets/stylesheets/bootstrap.min.css +0 -9
  603. data/vendor/assets/stylesheets/luca-components.css +0 -202
  604. data/vendor/assets/stylesheets/luca-development.css +0 -23
@@ -1,59 +0,0 @@
1
- describe 'The Collection View', ->
2
- beforeEach ->
3
- @collection = new Luca.Collection([
4
- id: 1, attr: "value_one", filter: "value"
5
- ,
6
- id: 2, attr: "value_two", filter: "value"
7
- ],
8
- model: Luca.Model)
9
-
10
- @view = new Luca.components.CollectionView
11
- itemTagName: "li"
12
- itemClassName: "custom-class"
13
- itemProperty: 'attr'
14
- collection: @collection
15
- filterable:
16
- query:
17
- filter: "value"
18
- options:
19
- sortBy: "filter"
20
-
21
- @view.render()
22
-
23
- it "should provide access to the query", ->
24
- expect( @view.getQuery() ).toBeDefined()
25
-
26
- it "should provide access to the query options", ->
27
- expect( @view.getQueryOptions() ).toBeDefined()
28
-
29
- it "should combine filter and pagination in the options hash", ->
30
- @view.setPage(5)
31
- @view.applyFilter({filter:"value"},{sortBy:'filter'})
32
-
33
- options = @view.getQueryOptions()
34
- query = @view.getQuery()
35
-
36
- expect( options.page ).toEqual 5
37
- expect( options.sortBy ).toEqual 'filter'
38
- expect( query.filter ).toEqual 'value'
39
-
40
- it "should render the attributes in the specified list elements", ->
41
- expect( @view.$html().match(/value_one/) ).toBeTruthy()
42
-
43
- it "should render each of the attributes", ->
44
- expect( @view.$('li.custom-class').length ).toEqual 2
45
-
46
- it "should locate a dom element by luca model id", ->
47
- expect( @view.locateItemElement(2).html() ).toContain('value_two')
48
-
49
- it "should refresh the view when a model is added", ->
50
- @view.collection.add(attr:"value_three",id:3)
51
- expect( @view ).toHaveTriggered('after:refresh')
52
-
53
- it "should refresh the view when a model is removed", ->
54
- @view.collection.remove( @view.collection.at(0) )
55
- expect( @view ).toHaveTriggered('after:refresh')
56
-
57
-
58
-
59
-
@@ -1,62 +0,0 @@
1
- describe 'The Controller Component', ->
2
- beforeEach ->
3
- controller = Luca.register 'Luca.components.SpecController'
4
- controller.extends 'Luca.components.Controller'
5
- controller.defines
6
- name: "spec_controller"
7
- defaultCard: 'one'
8
- rootComponent: true
9
- components:[
10
- name: "one"
11
- type: "controller"
12
- components:[
13
- name: "alpha"
14
- ,
15
- name: "bravo"
16
- ]
17
- ,
18
- name: "two"
19
- type: "controller"
20
- components:[
21
- name: "charlie"
22
- ,
23
- name: "delta"
24
- ]
25
- ,
26
- name: "three"
27
- type: "controller"
28
- components:[
29
- name: "echo"
30
- ]
31
- ,
32
- name: "four"
33
- type: "view"
34
- ]
35
-
36
- @controller = new Luca.components.SpecController().render()
37
-
38
- it "should track the names of its pages", ->
39
- names = @controller.sectionNames()
40
- expect( names... ).toEqual 'one', 'two', 'three', 'four'
41
-
42
- it "should track the names of its controllers", ->
43
- names = _( @controller.controllers() ).pluck 'name'
44
- expect( names... ).toEqual 'one', 'two', 'three'
45
-
46
- it "should be stateful", ->
47
- expect( @controller.state ).toBeDefined()
48
-
49
- it "should track the active page", ->
50
- @controller.navigate_to("two")
51
- expect( @controller.activePage() ).toEqual 'two'
52
-
53
- it "should track controller activation events", ->
54
- two = @controller.navigate_to("two")
55
- expect( two.activatedByController ).toBeTruthy()
56
-
57
- it "should define a controllerPath method on each page", ->
58
- expect( @controller.activeComponent().controllerPath ).toBeDefined()
59
-
60
- it "should know the controller path", ->
61
- path = @controller.activeComponent().controllerPath()
62
- expect( path... ).toEqual "spec_controller", "one"
@@ -1,162 +0,0 @@
1
- describe 'The Form View', ->
2
- beforeEach ->
3
- FormView = Luca.components.FormView.extend
4
- components:[
5
- ctype: 'hidden_field'
6
- name: 'id'
7
- ,
8
-
9
- ctype: "text_field",
10
- label: "Field Two"
11
- name: "field2"
12
- ,
13
- ctype: "text_field",
14
- label: "Field One"
15
- name: "field1"
16
- ,
17
- ctype: "checkbox_field"
18
- label: "Field Three"
19
- name: "field3"
20
- ,
21
- name: "field4"
22
- label: "Field Four"
23
- ctype: "text_area_field"
24
- ,
25
- name: "field5"
26
- ctype: "button_field"
27
- label: "Click Me"
28
- ]
29
-
30
- Model = Backbone.Model.extend
31
- schema:
32
- field0: "hidden"
33
- field2: "text"
34
- field1: "text"
35
- field3: "boolean"
36
- field4: "blob"
37
- field5:
38
- collection: "sample"
39
-
40
- @form = new FormView()
41
- @model = new Model(field0:1,field1:"jonathan",field3:true,field4:"what up player?")
42
-
43
- afterEach ->
44
- @form = undefined
45
- @model = undefined
46
-
47
- it "should create a form", ->
48
- expect( @form ).toBeDefined()
49
-
50
- it "should have access to all of the fields", ->
51
- @form.render()
52
- expect( @form.getFields().length ).toEqual 6
53
-
54
- it "should load the model", ->
55
- @form.loadModel(@model)
56
- expect( @form.currentModel() ).toEqual @model
57
-
58
- it "should set the field values from the model when loaded", ->
59
- @form.render()
60
- @form.loadModel(@model)
61
- values = @form.getValues()
62
- expect( values.field1 ).toEqual "jonathan"
63
-
64
- it "should render the components within the body element", ->
65
- @form.render()
66
- expect( @form.$bodyEl().is('.form-view-body') ).toEqual true
67
-
68
- it "should assign the components to render inside of the body", ->
69
- @form.render()
70
- expect( @form.$bodyEl().html() ).toContain "Field Four"
71
-
72
- it "should allow me to set the values of the form fields with a hash", ->
73
- @form.render()
74
- @form.setValues(field1:"yes",field2:"no")
75
- values = @form.getValues()
76
-
77
- expect( values.field1 ).toEqual "yes"
78
- expect( values.field2 ).toEqual "no"
79
-
80
- it "should sync the model with the form field values", ->
81
- @form.render()
82
- @form.loadModel(@model)
83
- @form.setValues(field1:"yes")
84
- expect( @form.getValues().field1 ).toEqual "yes"
85
-
86
- describe 'Dirty Tracking', ->
87
- Luca.register("Luca.components.DirtyForm").extends("Luca.components.FormView").defines
88
- trackDirtyState: true
89
- components:[
90
- type: "text"
91
- name: "dirty_field"
92
- ]
93
-
94
- beforeEach ->
95
- (@dirtyForm = new Luca.components.DirtyForm()).render()
96
-
97
-
98
- it "should be stateful", ->
99
- expect( @dirtyForm.state ).toBeDefined()
100
- expect( @dirtyForm.state.set('dirty', true) )
101
- expect( @dirtyForm ).toHaveTriggered("state:change:dirty")
102
-
103
- it "should start off in a clean state", ->
104
- dirty = @dirtyForm.isDirty()
105
- expect( dirty ).not.toBeTruthy()
106
-
107
- it "should become dirty if a field changes", ->
108
- @dirtyForm.getField('dirty_field').trigger("on:change")
109
- dirty = @dirtyForm.isDirty()
110
- expect( dirty ).toBeTruthy()
111
-
112
- it "should trigger a state change event", ->
113
- @dirtyForm.getField('dirty_field').trigger("on:change")
114
- expect( @dirtyForm ).toHaveTriggered('state:change:dirty')
115
-
116
- it "should bubble up field change events", ->
117
- @dirtyForm.getField('dirty_field').trigger("on:change")
118
- expect( @dirtyForm ).toHaveTriggered('field:change')
119
-
120
- it "should become clean on a reset", ->
121
- @dirtyForm.getField('dirty_field').trigger("on:change")
122
- @dirtyForm.reset()
123
- dirty = @dirtyForm.isDirty()
124
- expect( dirty ).not.toBeTruthy()
125
-
126
- describe 'Model Binding', ->
127
- Luca.register("Luca.FormModel").extends("Luca.Model").defines(defaults:model_field:"value")
128
-
129
- form = Luca.register('Luca.components.ModelBoundForm')
130
-
131
- form.extends("Luca.components.FormView")
132
-
133
- form.defines
134
- trackModelChanges: true
135
- components:[
136
- type: "text"
137
- name: "model_field"
138
- ]
139
-
140
- beforeEach ->
141
- @modelForm = new Luca.components.ModelBoundForm()
142
- @formModel = new Luca.FormModel()
143
- @modelForm.render()
144
- @modelForm.loadModel(@formModel)
145
-
146
- it "should trigger a state change event", ->
147
- expect( @modelForm ).toHaveTriggered("state:change:currentModel")
148
-
149
- it "should not bind to model changes by default", ->
150
- expect( Luca.components.FormView::trackModelChanges ).not.toBeTruthy()
151
-
152
- it "should be setup to track model changes", ->
153
- expect( @modelForm.trackModelChanges ).toBeTruthy()
154
-
155
- it "should change the model's value when the form applies itself", ->
156
- @modelForm.setValues('model_field':"smooth, baby")
157
- @modelForm.applyFormValuesToModel()
158
- expect( @modelForm.getField('model_field').getValue() ).toEqual 'smooth, baby'
159
-
160
- it "should change the field's value when the underlying model changes", ->
161
- @formModel.set('model_field', 'haha')
162
- expect( @modelForm.getValues().model_field ).toEqual 'haha'
@@ -1,5 +0,0 @@
1
- describe 'The Collection Multi View component', ->
2
- it "should share a single collection among multiple collection views", ->
3
- it "should toggle visibility of one or more views", ->
4
- it "should share pagination state across the multiple views", ->
5
- it "should share filter state across the multiple views", ->
@@ -1,17 +0,0 @@
1
- describe 'The Table View', ->
2
- beforeEach ->
3
- @tableView = new Luca.components.TableView
4
- collection: new Luca.Collection
5
- columns:[
6
- "column_one"
7
- "column_two"
8
- ]
9
-
10
- $('body').append( @tableView.render() )
11
-
12
- it 'should accept strings for column config', ->
13
- expect( @tableView.columns[0].reader ).toEqual("column_one")
14
-
15
- it 'should automatically determine a missing header config', ->
16
- expect( @tableView.columns[0].header ).toBeDefined()
17
-
@@ -1,15 +0,0 @@
1
- describe 'Collection Event Bindings', ->
2
- view = Luca.register("Luca.components.CollectionBindingView")
3
- view.extends "Luca.View"
4
- view.mixesIn "CollectionEventBindings"
5
- view.defines
6
- collection: new Luca.Collection()
7
-
8
- xit "should allow me to bind to collection manager events"
9
-
10
- it "should setup event relaying from the collection", ->
11
- view = new Luca.components.CollectionBindingView()
12
- for eventId in ["reset","add","remove","change"]
13
- view.collection.trigger(eventId)
14
- expect( view ).toHaveTriggered("collection:#{ eventId }")
15
-
@@ -1,16 +0,0 @@
1
- describe 'The DOM Helpers module', ->
2
- describe "The Wrapping Helper", ->
3
- it "should accept a space delimited list", ->
4
- v = new Luca.View(wrapperClass: "class-one class-two")
5
- expect( v.$el.parent().is(".class-one.class-two") ).toEqual(true)
6
-
7
- describe "Auto Assigning Class Names", ->
8
- it "should apply the class of the component all the way up its hierarchy", ->
9
- c = new Luca.Container()
10
- expect( c.$el.is(".luca-container") ).toBeTruthy()
11
- expect( c.$el.is(".luca-panel") ).toBeTruthy()
12
-
13
- it "should leave out backbone and luca view classes", ->
14
- c = new Luca.Container()
15
- expect( c.$el.is(".luca-view") ).not.toBeTruthy()
16
- expect( c.$el.is(".backbone-view") ).not.toBeTruthy()
@@ -1,25 +0,0 @@
1
- describe 'The Filterable Plugin', ->
2
- describe 'Through the CollectionView', ->
3
- beforeEach ->
4
- @collection = new Luca.Collection [{name:"name"},{name:"filterable"}]
5
-
6
- @view = new Luca.components.TableView
7
- collection:@collection
8
- columns:[reader:"name"]
9
-
10
- it 'should generate a Backbone.QueryCollection query payload', ->
11
- expect( @view.getFilterState().toQuery() ).toBeDefined()
12
-
13
- it 'should generate a Backbone.QueryCollection options payload', ->
14
- expect( @view.getFilterState().toOptions() ).toBeDefined()
15
-
16
- it "should have a toRemote method which merges params", ->
17
- expect( @view.getFilterState().toRemote() ).toBeDefined()
18
-
19
- it 'should apply filter values', ->
20
- @view.applyFilter(filter:"value")
21
- expect( @view.getFilterState().toQuery().filter ).toEqual('value')
22
-
23
- it "should trigger a refresh event on filter change", ->
24
- @view.applyFilter(filter:"value")
25
- expect( @view ).toHaveTriggered("data:refresh")
@@ -1,31 +0,0 @@
1
- describe 'The Presenter Mixin', ->
2
- presenterModel = Luca.register("Luca.models.PresenterModel").extends("Luca.Model")
3
- presenterModel.mixesIn("ModelPresenter")
4
- presenterModel.defines
5
- randomProperty: "chocolate"
6
- fullName: ()->
7
- @get("first_name") + ' ' + @get("last_name")
8
- defaults:
9
- first_name: "Jonathan"
10
- last_name: "Soeder"
11
-
12
- it "should respond to presentAs", ->
13
- expect( Luca.models.PresenterModel::presentAs ).toBeDefined()
14
-
15
- it "should define the presenter class methods on the model class", ->
16
- expect( Luca.models.PresenterModel.registerPresenter ).toBeDefined()
17
-
18
- it "should define the presenter class methods on the model class", ->
19
- expect( Luca.models.PresenterModel.getPresenter ).toBeDefined()
20
-
21
- it "should register a presenter format", ->
22
- Luca.models.PresenterModel.registerPresenter "names", ["first_name", "last_name", "fullName"]
23
- expect( Luca.models.PresenterModel.getPresenter("names") ).toBeDefined()
24
-
25
- it "should present a model in the desired format", ->
26
- model = new Luca.models.PresenterModel()
27
- presented = model.presentAs('names')
28
- expect( _.isObject(presented) ).toEqual true
29
- expect( presented ).toBeDefined()
30
- expect( _( presented ).keys()... ).toEqual "first_name", "last_name", "fullName"
31
- expect( presented.fullName ).toEqual 'Jonathan Soeder'
@@ -1,55 +0,0 @@
1
- describe 'The State Model Concern', ->
2
- view = Luca.register "Luca.components.StatefulView"
3
- view.extends "Luca.View"
4
- view.mixesIn "StateModel"
5
- view.defines
6
- stateful:
7
- key1: "val1"
8
- key2: "val2"
9
-
10
- it "should create a state model on the view", ->
11
- view = new Luca.components.StatefulView()
12
- expect( view.state ).toBeDefined()
13
- expect( Luca.isBackboneModel(view.state) ).toEqual true
14
-
15
- it "should delegate the get method on the state model to the view", ->
16
- view = new Luca.components.StatefulView()
17
- expect( view.get ).toBeDefined()
18
- expect( view.get('key1') ).toEqual 'val1'
19
-
20
- it "should delegate the set method on the state model to the view", ->
21
- view = new Luca.components.StatefulView()
22
- view.set('key1','boom')
23
- expect( view.state.get('key1') ).toEqual 'boom'
24
-
25
- it "should apply the default state attributes", ->
26
- view = new Luca.components.StatefulView()
27
- expect( view.state.toJSON() ).toEqual key1:"val1", key2: "val2"
28
-
29
- it "should define a get/set method on the view which effect state", ->
30
- view = new Luca.components.StatefulView()
31
- view.set('testsetter', 'works')
32
- expect( view.get('testsetter') ).toEqual('works')
33
-
34
- describe 'State Change Event Bindings', ->
35
- it "should trigger state change events on the view", ->
36
- view = new Luca.components.StatefulView()
37
- view.set('key1','boom')
38
- expect( view ).toHaveTriggered("state:change")
39
-
40
- it "should trigger individual attribute change events on the view", ->
41
- view = new Luca.components.StatefulView()
42
- view.set('key1','boom')
43
- expect( view ).toHaveTriggered("state:change:key1")
44
-
45
- it "should respond to @stateChangeEvents configuration", ->
46
- view = new Luca.components.StatefulView
47
- onKeyChange: sinon.spy()
48
- blah: sinon.spy()
49
- stateChangeEvents:
50
- "key1" : "onKeyChange"
51
- "key2" : "blah"
52
-
53
- view.set('key1','boom')
54
- expect( view.blah ).not.toHaveBeenCalled()
55
- expect( view.onKeyChange ).toHaveBeenCalled()
@@ -1,108 +0,0 @@
1
- describe "The Card View", ->
2
- beforeEach ->
3
- @cardView = new Luca.containers.CardView
4
- visible: true
5
- activeItem: 0
6
- afterCardSwitch: sinon.spy()
7
- beforeCardSwitch: sinon.spy()
8
- components:[
9
- markup: "component one"
10
- name: "one"
11
- one: true
12
- firstActivation: sinon.spy()
13
- activation: sinon.spy()
14
- deactivation: sinon.spy()
15
- afterInitialize: ()->
16
- @on "activation", @oneSpy ||= sinon.spy()
17
- ,
18
- markup: "component two"
19
- name: "two"
20
- two: true
21
- firstActivation: sinon.spy()
22
- activation: sinon.spy()
23
- ,
24
- markup: "component three"
25
- name: "three"
26
- three: true
27
- ]
28
-
29
- @cardView.render()
30
-
31
- it "should create three card elements", ->
32
- expect( @cardView.componentElements().length ).toEqual 3
33
-
34
- it "should hide all but one of the card elements", ->
35
- display = _( @cardView.$('.luca-ui-card') ).map (el)-> $(el).css('display')
36
- expect( display ).toEqual(['block','none','none'])
37
-
38
- it "should be able to find the cards by name", ->
39
- expect( @cardView.find("one") ).toBeDefined()
40
- expect( @cardView.find("one").one ).toEqual true
41
-
42
- it "should start with the first component active", ->
43
- expect( @cardView.activeComponent()?.name ).toEqual "one"
44
-
45
- it "should be able to activate components by name", ->
46
- @cardView.activate("two")
47
- expect( @cardView.activeComponent()?.name ).toEqual "two"
48
-
49
- it "shouldn't fire first activation on a component that hasn't been activated", ->
50
- expect( @cardView.find("two")?.firstActivation ).not.toHaveBeenCalled()
51
- expect( @cardView.find("two") ).not.toHaveTriggered("first:activation")
52
- expect( @cardView.find("two").previously_activated ).not.toBeTruthy()
53
-
54
- it "should fire firstActivation on a component", ->
55
- @cardView.activate("two")
56
- expect( @cardView.find("two") ).toHaveTriggered("first:activation")
57
- expect( @cardView.find("two")?.firstActivation ).toHaveBeenCalled()
58
- expect( @cardView.find("two").previously_activated ).toBeTruthy()
59
-
60
- it "should fire deactivation on a component", ->
61
- @cardView.find("one").spiedEvents = {}
62
- @cardView.activate("two")
63
- expect( @cardView.find("one") ).toHaveTriggered("deactivation")
64
-
65
- it "should only fire first activation once", ->
66
- @cardView.activate("two")
67
- @cardView.activate("one")
68
- @cardView.activate("two")
69
- expect( @cardView.find("two").firstActivation.callCount ).toEqual(1)
70
-
71
- it "should fire the first activation hook on the default card", ->
72
- expect( @cardView.find("one").firstActivation.callCount ).toEqual(1)
73
-
74
- it "should fire the activation hook on the default card", ->
75
- expect( @cardView.find("one").activation.callCount ).toEqual(1)
76
-
77
- it "should only fire the activation hook once upon activation", ->
78
- @cardView.activate("two")
79
- expect( @cardView.find("two").activation.callCount ).toEqual(1)
80
-
81
- it "should only fire the deactivation hook once upon deactivation", ->
82
- @cardView.activate("two")
83
- expect( @cardView.find("one").deactivation.callCount ).toEqual(1)
84
-
85
- it "should fire the beforeCardSwitch hook", ->
86
- @cardView.activate("two")
87
- expect( @cardView.beforeCardSwitch ).toHaveBeenCalled()
88
-
89
- it "should fire the afterCardSwitch hook", ->
90
- @cardView.activate("two")
91
- expect( @cardView.afterCardSwitch ).toHaveBeenCalled()
92
-
93
- it "should allow me to next through the cards", ->
94
- @cardView.next()
95
- expect(@cardView.activeComponent().name ).toEqual("two")
96
-
97
- it "should allow me to previous through the cards", ->
98
- @cardView.activate("two")
99
- @cardView.previous()
100
- expect(@cardView.activeComponent().name).toEqual("one")
101
-
102
- it "should allow me to cycle through the cards", ->
103
- @cardView.cycle()
104
- expect(@cardView.activeComponent().name ).toEqual("two")
105
- @cardView.cycle()
106
- expect(@cardView.activeComponent().name ).toEqual("three")
107
- @cardView.cycle()
108
- expect(@cardView.activeComponent().name ).toEqual("one")
@@ -1,88 +0,0 @@
1
- describe 'The Concern System', ->
2
-
3
- window.Luca ||= {}
4
-
5
- Luca.concern.namespace 'Luca.test_concerns'
6
-
7
- Luca.test_concerns =
8
- CollectionMixin:
9
- __initializer: ()->
10
- @trigger "collection:mixin"
11
- SecondMixin:
12
- __included: ()->
13
- window.secondMixinIncluded = true
14
- __initializer: ()->
15
- @trigger "second:mixin"
16
- FirstMixin:
17
- __initializer: ()->
18
- @trigger "first:mixin"
19
- __privateMethod: ()->
20
- true
21
- publicMethod: ()->
22
- true
23
-
24
- sampleView = Luca.register('Luca.components.FirstView')
25
-
26
- sampleView.mixesIn 'FirstMixin'
27
-
28
- sampleView.defines
29
- sampleMethod: ()->
30
- "sample"
31
-
32
- secondView = Luca.register("Luca.components.SecondView")
33
- secondView.extends 'Luca.components.FirstView'
34
- secondView.mixesIn 'SecondMixin'
35
- secondView.defines
36
- version: 2
37
-
38
- collection = Luca.register("Luca.components.MixinCollection")
39
- collection.mixesIn "CollectionMixin"
40
- collection.defines version: 2
41
-
42
- model = Luca.register("Luca.components.MixinModel")
43
- model.mixesIn "CollectionMixin"
44
- model.defines version: 2
45
-
46
- it "should work on models", ->
47
- model = new Luca.components.MixinModel()
48
- expect( model ).toHaveTriggered("collection:mixin")
49
-
50
- it "should work on collections", ->
51
- collection = new Luca.components.MixinCollection()
52
- expect( collection ).toHaveTriggered("collection:mixin")
53
-
54
- it "should work on views", ->
55
- secondView = new Luca.components.SecondView
56
- expect( secondView ).toHaveTriggered("second:mixin")
57
-
58
- it "should omit methods prefixed with the double underscore", ->
59
- sampleView = new Luca.components.FirstView
60
- expect( sampleView.__privateMethod ).not.toBeDefined()
61
-
62
-
63
- it "should extend the prototype with the concern definition", ->
64
- sampleView = new Luca.components.FirstView
65
- expect( sampleView.publicMethod ).toBeDefined()
66
-
67
- it "should call the initializers up the prototype chain", ->
68
- secondView = new Luca.components.SecondView
69
- expect( secondView ).toHaveTriggered("first:mixin")
70
- expect( secondView ).toHaveTriggered("second:mixin")
71
-
72
- describe "Class Methods on the concern", ->
73
- Luca.test_concerns.ExampleConcern =
74
- instanceMethod: ()-> "instanceMethod"
75
- classMethods:
76
- classMethod: ()-> "classMethod"
77
-
78
- v = Luca.register("Luca.components.ClassMethodView").mixesIn("ExampleConcern")
79
-
80
- v.defines(version:1)
81
-
82
- it "should distinguish between instance methods and class methods", ->
83
- value = Luca.components.ClassMethodView::instanceMethod.call(@)
84
- expect( value ).toEqual 'instanceMethod'
85
-
86
- it "should distinguish between instance methods and class methods", ->
87
- value = Luca.components.ClassMethodView.classMethod.call(@)
88
- expect( value ).toEqual 'classMethod'