luca 0.9.9 → 0.9.42
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +9 -153
- data/Gemfile +1 -10
- data/Gemfile.lock +40 -113
- data/Guardfile +25 -3
- data/README.md +57 -54
- data/ROADMAP +32 -15
- data/Rakefile +75 -24
- data/app.rb +46 -12
- data/{app/assets → assets}/images/glyphicons-halflings-white.png +0 -0
- data/{app/assets → assets}/images/glyphicons-halflings.png +0 -0
- data/assets/javascripts/dependencies/backbone-min.js +37 -0
- data/assets/javascripts/dependencies/backbone-query.min.js +1 -0
- data/assets/javascripts/dependencies/bootstrap.min.js +7 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-coffeescript.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-css.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-html.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-javascript.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-less.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror-vim.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/codemirror.js +0 -0
- data/assets/javascripts/dependencies/coffee-script.js +12189 -0
- data/{spec → assets}/javascripts/dependencies/jasmine-html.js +0 -0
- data/{spec → assets}/javascripts/dependencies/jasmine.js +0 -0
- data/assets/javascripts/dependencies/jquery.js +4 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/modal.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/modernizr.min.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/prettify.js +0 -0
- data/{spec → assets}/javascripts/dependencies/sinon.js +0 -0
- data/{vendor/assets/javascripts → assets/javascripts/dependencies}/spin-min.js +0 -0
- data/assets/javascripts/dependencies/underscore-min.js +31 -0
- data/assets/javascripts/dependencies/underscore-string.min.js +14 -0
- data/assets/javascripts/dependencies.coffee +5 -0
- data/assets/javascripts/luca/index.coffee +1 -0
- data/assets/javascripts/luca-templates.js +1 -0
- data/assets/javascripts/luca-ui-base.coffee +1 -0
- data/assets/javascripts/luca-ui-bootstrap.js +1 -0
- data/assets/javascripts/luca-ui-development-tools.coffee +9 -0
- data/assets/javascripts/luca-ui-full.js +3 -0
- data/assets/javascripts/luca-ui-spec.coffee +2 -0
- data/assets/javascripts/luca-ui.js +3 -0
- data/assets/javascripts/sandbox/application.coffee +57 -0
- data/assets/javascripts/sandbox/config.coffee +7 -0
- data/assets/javascripts/sandbox/router.coffee +24 -0
- data/assets/javascripts/sandbox/templates/builder/component_list.luca +1 -0
- data/assets/javascripts/sandbox/templates/builder.luca +2 -0
- data/assets/javascripts/sandbox/templates/main.luca +53 -0
- data/assets/javascripts/sandbox/templates/sandbox/docs_index.luca +1 -0
- data/assets/javascripts/sandbox/templates/sandbox/navigation.luca +8 -0
- data/assets/javascripts/sandbox/templates/sandbox/readme.luca +30 -0
- data/assets/javascripts/sandbox/templates/sandbox.luca +1 -0
- data/assets/javascripts/sandbox/views/builder/builder_canvas.coffee +3 -0
- data/assets/javascripts/sandbox/views/builder/builder_editor.coffee +6 -0
- data/assets/javascripts/sandbox/views/builder/component_list.coffee +38 -0
- data/assets/javascripts/sandbox/views/builder/project_browser.coffee +14 -0
- data/assets/javascripts/sandbox/views/builder.coffee +133 -0
- data/assets/javascripts/sandbox/views/docs_controller.coffee +7 -0
- data/assets/javascripts/sandbox/views/inspector/instance_filter.coffee +18 -0
- data/{app/assets/stylesheets/luca/containers/modal_view.scss → assets/javascripts/sandbox/views/inspector/instance_list.coffee} +0 -0
- data/assets/javascripts/sandbox/views/inspector.coffee +11 -0
- data/assets/javascripts/sandbox/views/top_navigation.coffee +4 -0
- data/assets/javascripts/sandbox.coffee +7 -0
- data/assets/javascripts/spec-dependencies.coffee +4 -0
- data/assets/stylesheets/bootstrap-responsive.min.css +2 -0
- data/assets/stylesheets/bootstrap.min.css +727 -0
- data/{vendor/assets → assets}/stylesheets/codemirror-blackboard.css +0 -0
- data/{vendor/assets → assets}/stylesheets/codemirror-monokai.css +0 -0
- data/{vendor/assets → assets}/stylesheets/codemirror.css +0 -0
- data/{vendor/assets → assets}/stylesheets/jasmine.css +0 -0
- data/assets/stylesheets/luca-ui-bootstrap.css +4 -0
- data/assets/stylesheets/luca-ui-development-tools.css +5 -0
- data/assets/stylesheets/luca-ui-full.css +3 -0
- data/assets/stylesheets/luca-ui-spec.css +3 -0
- data/assets/stylesheets/luca-ui.css +3 -0
- data/assets/stylesheets/prettify.css +40 -0
- data/assets/stylesheets/sandbox/builder.scss +79 -0
- data/assets/stylesheets/sandbox/sandbox.scss +18 -0
- data/assets/stylesheets/sandbox.css +3 -0
- data/assets/stylesheets/themes/amelia-bootstrap.css +826 -0
- data/assets/stylesheets/themes/slate-bootstrap.css +797 -0
- data/assets/stylesheets/themes/superhero-bootstrap.css +830 -0
- data/config.ru +2 -1
- data/docs/{old/application.md → application.md} +0 -0
- data/docs/{old/collection.md → collection.md} +0 -0
- data/docs/{old/collection_manager.md → collection_manager.md} +0 -0
- data/docs/{old/container_philosophy.md → container_philosophy.md} +0 -0
- data/docs/{old/event_binding_helpers.md → event_binding_helpers.md} +0 -0
- data/docs/{old/method_caching_and_computed_properties.md → method_caching_and_computed_properties.md} +0 -0
- data/docs/{old/view.md → view.md} +0 -0
- data/lib/luca/code_browser.rb +55 -0
- data/lib/luca/command_line.rb +69 -0
- data/lib/luca/rails/engine.rb +0 -12
- data/lib/luca/rails/version.rb +2 -1
- data/lib/luca/rails.rb +3 -5
- data/lib/luca/template.rb +0 -2
- data/lib/luca.rb +1 -25
- data/luca.gemspec +7 -16
- data/site/assets/bootstrap.min.js +7 -0
- data/site/assets/dependencies.js +94 -0
- data/site/assets/glyphicons-halflings-white.png +0 -0
- data/site/assets/glyphicons-halflings.png +0 -0
- data/site/assets/luca-ui-bootstrap.css +1331 -0
- data/site/assets/luca-ui-bootstrap.js +9 -0
- data/site/assets/luca-ui-development-tools.css +234 -0
- data/site/assets/luca-ui-development-tools.js +18561 -0
- data/site/assets/luca-ui-development-tools.min.js +15 -0
- data/site/assets/luca-ui-full.min.js +8 -0
- data/site/assets/luca-ui.min.js +4 -0
- data/site/assets/sandbox.css +62 -0
- data/site/assets/sandbox.js +469 -0
- data/site/docs/application.html +41 -0
- data/site/docs/caching.html +43 -0
- data/site/docs/collection.html +75 -0
- data/site/docs/collection_manager.html +71 -0
- data/site/docs/containers.html +118 -0
- data/site/docs/events.html +153 -0
- data/site/docs/view.html +128 -0
- data/site/img/glyphicons-halflings-white.png +0 -0
- data/site/img/glyphicons-halflings.png +0 -0
- data/site/index.html +20 -0
- data/site/source-map.js +1 -0
- data/spec/{javascripts/components → components}/application_spec.coffee +0 -0
- data/spec/{javascripts/components → components}/collection_loader_view_spec.coffee +0 -0
- data/{site/source/app/assets/javascripts/docs/lib/util.coffee → spec/components/controller_spec.coffee} +0 -0
- data/spec/{javascripts/components → components}/fields/checkbox_array_spec.coffee +0 -0
- data/spec/components/form_view_spec.coffee +80 -0
- data/spec/{javascripts/components → components}/grid_view_spec.coffee +0 -0
- data/spec/{javascripts/components → components}/record_manager_spec.coffee +0 -0
- data/spec/{javascripts/components → components}/template_spec.coffee +0 -0
- data/spec/containers/card_view_spec.coffee +50 -0
- data/{site/source/app/assets/javascripts/docs/views/components/code_editor/index.coffee → spec/containers/column_view_spec.coffee} +0 -0
- data/spec/{javascripts/containers → containers}/modal_view_spec.coffee +0 -0
- data/spec/{javascripts/containers → containers}/panel_view_spec.coffee +0 -0
- data/spec/{javascripts/components/pagination_control_spec.coffee → containers/split_view_spec.coffee} +0 -0
- data/spec/{javascripts/containers → containers}/tab_view_spec.coffee +0 -0
- data/spec/{javascripts/containers → containers}/viewport_spec.coffee +0 -0
- data/spec/{javascripts/core → core}/collection_spec.coffee +1 -26
- data/spec/core/container_spec.coffee +66 -0
- data/spec/{javascripts/concerns/paginatable_spec.coffee → core/field_spec.coffee} +0 -0
- data/spec/{javascripts/core → core}/model_spec.coffee +3 -26
- data/spec/{javascripts/core → core}/observer_spec.coffee +0 -0
- data/spec/{javascripts/core → core}/view_spec.coffee +38 -114
- data/spec/{javascripts/core/framework_spec.coffee → framework_spec.coffee} +2 -31
- data/spec/{javascripts/helper.coffee → helper.coffee} +0 -0
- data/spec/{javascripts/managers → managers}/collection_manager_spec.coffee +0 -0
- data/spec/{javascripts/managers → managers}/socket_manager_spec.coffee +0 -0
- data/src/components/application.coffee +318 -0
- data/src/components/base_toolbar.coffee +15 -0
- data/{app/assets/javascripts/luca → src}/components/collection_loader_view.coffee +1 -3
- data/src/components/collection_view.coffee +131 -0
- data/src/components/controller.coffee +63 -0
- data/src/components/fields/button_field.coffee +38 -0
- data/{app/assets/javascripts/luca → src}/components/fields/checkbox_array.coffee +7 -18
- data/{app/assets/javascripts/luca → src}/components/fields/checkbox_field.coffee +10 -19
- data/{app/assets/javascripts/luca → src}/components/fields/file_upload_field.coffee +4 -5
- data/src/components/fields/hidden_field.coffee +12 -0
- data/src/components/fields/label_field.coffee +14 -0
- data/src/components/fields/select_field.coffee +97 -0
- data/src/components/fields/text_area_field.coffee +40 -0
- data/{app/assets/javascripts/luca → src}/components/fields/text_field.coffee +5 -16
- data/src/components/fields/type_ahead_field.coffee +22 -0
- data/src/components/form_button_toolbar.coffee +25 -0
- data/src/components/form_view.coffee +275 -0
- data/src/components/grid_view.coffee +269 -0
- data/src/components/index.coffee +1 -0
- data/src/components/load_mask.coffee +3 -0
- data/src/components/nav_bar.coffee +22 -0
- data/src/components/page_controller.coffee +2 -0
- data/{app/assets/javascripts/luca → src}/components/record_manager.coffee +0 -0
- data/{app/assets/javascripts/luca → src}/components/router.coffee +1 -6
- data/src/components/table_view.coffee +53 -0
- data/src/components/template.coffee +5 -0
- data/src/components/toolbar_dialog.coffee +25 -0
- data/src/containers/card_view.coffee +93 -0
- data/src/containers/column_view.coffee +42 -0
- data/{app/assets/javascripts/luca → src}/containers/modal_view.coffee +9 -9
- data/src/containers/page_view.coffee +2 -0
- data/{app/assets/javascripts/luca → src}/containers/panel_toolbar.coffee +84 -89
- data/src/containers/panel_view.coffee +23 -0
- data/src/containers/split_view.coffee +8 -0
- data/{app/assets/javascripts/luca → src}/containers/tab_view.coffee +21 -27
- data/{app/assets/javascripts/luca → src}/containers/viewport.coffee +18 -14
- data/{app/assets/javascripts/luca → src}/core/collection.coffee +51 -97
- data/src/core/container.coffee +374 -0
- data/{tutorials/component-definitions.md → src/core/core.coffee} +0 -0
- data/src/core/field.coffee +79 -0
- data/src/core/model.coffee +43 -0
- data/{app/assets/javascripts/luca → src}/core/observer.coffee +0 -0
- data/src/core/panel.coffee +118 -0
- data/{app/assets/javascripts/luca/core/registry → src/core}/registry.coffee +43 -63
- data/{app/assets/javascripts/luca/util → src/core}/script_loader.coffee +0 -0
- data/src/core/view.coffee +264 -0
- data/src/define.coffee +110 -0
- data/{app/assets/javascripts/luca → src}/framework.coffee +103 -98
- data/src/index.coffee +23 -0
- data/{app/assets/javascripts/luca → src}/managers/collection_manager.coffee +13 -37
- data/src/managers/socket_manager.coffee +54 -0
- data/{app/assets/javascripts/luca/concerns → src/modules}/deferrable.coffee +4 -5
- data/src/modules/grid_layout.coffee +3 -0
- data/{app/assets/javascripts/luca/concerns/loadmaskable.coffee → src/modules/load_mask.coffee} +11 -23
- data/{app/assets/javascripts/luca/concerns → src/modules}/local_storage.coffee +0 -0
- data/src/plugins/development_tool_helpers.coffee +21 -0
- data/src/plugins/events.coffee +54 -0
- data/src/samples/definition.coffee +49 -0
- data/{tutorials/component-definitions/01_intro.md → src/stylesheets/base.scss} +0 -0
- data/{app/assets/stylesheets/luca → src/stylesheets}/components/checkbox_array.scss +1 -1
- data/src/stylesheets/components/form_view.scss +59 -0
- data/{app/assets/stylesheets/luca → src/stylesheets}/components/grid_view.scss +0 -0
- data/{app/assets/stylesheets/luca → src/stylesheets}/components/load_mask.scss +0 -0
- data/src/stylesheets/components/toolbar.scss +0 -0
- data/{app/assets/stylesheets/luca → src/stylesheets}/components/viewport.scss +4 -1
- data/src/stylesheets/containers/container.scss +16 -0
- data/src/stylesheets/containers/modal_view.scss +0 -0
- data/{app/assets/stylesheets/luca → src/stylesheets}/containers/panels.scss +0 -0
- data/{app/assets/stylesheets/luca → src/stylesheets}/containers/tab_view.scss +5 -5
- data/{app/assets/stylesheets/luca → src/stylesheets}/normalize.scss +0 -0
- data/src/stylesheets/tools/class_browser.scss +32 -0
- data/src/stylesheets/tools/code_editor.scss +24 -0
- data/src/stylesheets/tools/component_tester.scss +26 -0
- data/{app/assets/stylesheets/luca/development → src/stylesheets/tools}/console.scss +0 -0
- data/src/templates/components/bootstrap_form_controls.luca +7 -0
- data/src/templates/components/collection_loader_view.luca +5 -0
- data/src/templates/components/form_alert +0 -0
- data/src/templates/components/form_alert.luca +3 -0
- data/src/templates/components/grid_view.luca +7 -0
- data/src/templates/components/grid_view_empty_text.luca +3 -0
- data/src/templates/components/load_mask.luca +3 -0
- data/src/templates/components/nav_bar.luca +2 -0
- data/src/templates/containers/basic.luca +1 -0
- data/src/templates/containers/tab_selector_container.luca +8 -0
- data/src/templates/containers/tab_view.luca +2 -0
- data/src/templates/containers/toolbar_wrapper.luca +1 -0
- data/src/templates/fields/button_field.luca +2 -0
- data/src/templates/fields/button_field_link.luca +5 -0
- data/src/templates/fields/checkbox_array.luca +4 -0
- data/src/templates/fields/checkbox_array_item.luca +4 -0
- data/src/templates/fields/checkbox_field.luca +9 -0
- data/src/templates/fields/file_upload_field.luca +8 -0
- data/src/templates/fields/hidden_field.luca +1 -0
- data/src/templates/fields/select_field.luca +8 -0
- data/src/templates/fields/text_area_field.luca +8 -0
- data/src/templates/fields/text_field.luca +17 -0
- data/src/templates/sample/contents.luca +1 -0
- data/src/templates/sample/welcome.luca +1 -0
- data/src/templates/table_view.luca +4 -0
- data/src/tools/application_inspector.coffee +2 -0
- data/src/tools/code_editor.coffee +258 -0
- data/{app/assets/javascripts/luca/development → src/tools}/code_mirror_field.coffee +1 -2
- data/src/tools/coffee_script_editor.coffee +82 -0
- data/src/tools/collection_inspector.coffee +4 -0
- data/src/tools/collections/components.coffee +59 -0
- data/src/tools/collections/instances.coffee +15 -0
- data/src/tools/component_tester.coffee +462 -0
- data/{app/assets/javascripts/luca/development → src/tools}/console.coffee +24 -55
- data/src/tools/models/components.coffee +25 -0
- data/src/tools/models/instance.coffee +2 -0
- data/src/tools/templates/component_tester/help.luca +14 -0
- data/{app/assets/javascripts/luca/util/luca.coffee → src/util.coffee} +6 -90
- data/vendor/assets/javascripts/luca-ui-development-tools.js +18533 -0
- data/vendor/assets/javascripts/luca-ui-development-tools.min.js +15 -0
- data/vendor/assets/javascripts/luca-ui-full.js +4806 -0
- data/vendor/assets/javascripts/luca-ui-full.min.js +8 -0
- data/vendor/assets/javascripts/luca-ui-templates.js +24 -0
- data/vendor/assets/javascripts/luca-ui.js +1703 -4394
- data/vendor/assets/javascripts/luca-ui.min.js +4 -5
- data/vendor/assets/luca-ui/base.css +85 -0
- data/vendor/assets/luca-ui/components/application.js +91 -0
- data/vendor/assets/luca-ui/components/base_toolbar.js +23 -0
- data/vendor/assets/luca-ui/components/controller.js +38 -0
- data/vendor/assets/luca-ui/components/fields/button_field.js +45 -0
- data/vendor/assets/luca-ui/components/fields/checkbox_field.js +43 -0
- data/vendor/assets/luca-ui/components/fields/file_upload_field.js +20 -0
- data/vendor/assets/luca-ui/components/fields/hidden_field.js +20 -0
- data/vendor/assets/luca-ui/components/fields/select_field.js +97 -0
- data/vendor/assets/luca-ui/components/fields/text_area_field.js +48 -0
- data/vendor/assets/luca-ui/components/fields/text_field.js +46 -0
- data/vendor/assets/luca-ui/components/fields/type_ahead_field.js +13 -0
- data/vendor/assets/luca-ui/components/form_button_toolbar.js +32 -0
- data/vendor/assets/luca-ui/components/form_view.css +32 -0
- data/vendor/assets/luca-ui/components/form_view.js +207 -0
- data/{app/assets/stylesheets/luca/components/table_view.scss → vendor/assets/luca-ui/components/grid_view.css} +51 -60
- data/vendor/assets/luca-ui/components/grid_view.js +202 -0
- data/vendor/assets/luca-ui/components/record_manager.js +207 -0
- data/vendor/assets/luca-ui/components/router.js +36 -0
- data/vendor/assets/luca-ui/components/template.js +26 -0
- data/vendor/assets/luca-ui/components/toolbar.css +11 -0
- data/vendor/assets/luca-ui/containers/card_view.js +98 -0
- data/vendor/assets/luca-ui/containers/column_view.js +52 -0
- data/vendor/assets/luca-ui/containers/container.css +3 -0
- data/vendor/assets/luca-ui/containers/modal_view.css +0 -0
- data/vendor/assets/luca-ui/containers/modal_view.js +87 -0
- data/vendor/assets/luca-ui/containers/panel_view.js +34 -0
- data/vendor/assets/luca-ui/containers/split_view.js +13 -0
- data/vendor/assets/luca-ui/containers/tab_view.css +16 -0
- data/vendor/assets/luca-ui/containers/tab_view.js +80 -0
- data/vendor/assets/luca-ui/containers/viewport.js +18 -0
- data/vendor/assets/luca-ui/core/collection.js +221 -0
- data/vendor/assets/luca-ui/core/container.js +205 -0
- data/vendor/assets/luca-ui/core/field.js +59 -0
- data/vendor/assets/luca-ui/core/observer.js +42 -0
- data/vendor/assets/luca-ui/core/view.js +127 -0
- data/vendor/assets/luca-ui/framework.js +110 -0
- data/vendor/assets/luca-ui/index.js +5 -0
- data/vendor/assets/luca-ui/managers/collection_manager.js +98 -0
- data/vendor/assets/luca-ui/managers/socket_manager.js +52 -0
- data/vendor/assets/luca-ui/modules/deferrable.js +21 -0
- data/vendor/assets/luca-ui/modules/local_storage.js +81 -0
- data/vendor/assets/luca-ui/normalize.css +359 -0
- data/vendor/assets/luca-ui/stylesheets/base.css +85 -0
- data/vendor/assets/luca-ui/stylesheets/components/form_view.css +32 -0
- data/vendor/assets/luca-ui/stylesheets/components/grid_view.css +76 -0
- data/vendor/assets/luca-ui/stylesheets/components/toolbar.css +11 -0
- data/vendor/assets/luca-ui/stylesheets/containers/container.css +3 -0
- data/vendor/assets/luca-ui/stylesheets/containers/modal_view.css +0 -0
- data/vendor/assets/luca-ui/stylesheets/containers/tab_view.css +16 -0
- data/vendor/assets/luca-ui/stylesheets/normalize.css +359 -0
- data/vendor/assets/luca-ui/templates/components/bootstrap_form_controls.js +4 -0
- data/vendor/assets/luca-ui/templates/components/form_view.js +4 -0
- data/vendor/assets/luca-ui/templates/components/grid_view.js +4 -0
- data/vendor/assets/luca-ui/templates/components/grid_view_empty_text.js +4 -0
- data/vendor/assets/luca-ui/templates/containers/basic.js +4 -0
- data/vendor/assets/luca-ui/templates/containers/tab_selector_container.js +4 -0
- data/vendor/assets/luca-ui/templates/containers/tab_view.js +4 -0
- data/vendor/assets/luca-ui/templates/containers/toolbar_wrapper.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/button_field.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/button_field_link.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/checkbox_field.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/file_upload_field.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/hidden_field.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/select_field.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/text_area_field.js +4 -0
- data/vendor/assets/luca-ui/templates/fields/text_field.js +4 -0
- data/vendor/assets/luca-ui/templates/sample/contents.js +4 -0
- data/vendor/assets/luca-ui/templates/sample/welcome.js +4 -0
- data/vendor/assets/stylesheets/luca-ui.css +471 -68
- data/views/jasmine.erb +2 -2
- metadata +328 -496
- data/app/assets/javascripts/luca/basic.coffee +0 -8
- data/app/assets/javascripts/luca/components/application.coffee +0 -530
- data/app/assets/javascripts/luca/components/collection_view.coffee +0 -211
- data/app/assets/javascripts/luca/components/controller.coffee +0 -176
- data/app/assets/javascripts/luca/components/fields/base.coffee +0 -144
- data/app/assets/javascripts/luca/components/fields/button_field.coffee +0 -91
- data/app/assets/javascripts/luca/components/fields/hidden_field.coffee +0 -11
- data/app/assets/javascripts/luca/components/fields/label_field.coffee +0 -12
- data/app/assets/javascripts/luca/components/fields/select_field.coffee +0 -159
- data/app/assets/javascripts/luca/components/fields/text_area_field.coffee +0 -57
- data/app/assets/javascripts/luca/components/fields/type_ahead_field.coffee +0 -20
- data/app/assets/javascripts/luca/components/form_view.coffee +0 -421
- data/app/assets/javascripts/luca/components/grid_layout_view.coffee +0 -42
- data/app/assets/javascripts/luca/components/index.coffee +0 -7
- data/app/assets/javascripts/luca/components/load_mask.coffee +0 -8
- data/app/assets/javascripts/luca/components/multi_collection_view.coffee +0 -92
- data/app/assets/javascripts/luca/components/nav_bar.coffee +0 -80
- data/app/assets/javascripts/luca/components/page.coffee +0 -70
- data/app/assets/javascripts/luca/components/pagination_control.coffee +0 -104
- data/app/assets/javascripts/luca/components/simple_collection_view.coffee +0 -10
- data/app/assets/javascripts/luca/components/table_view.coffee +0 -93
- data/app/assets/javascripts/luca/components/table_view_scrollable.coffee +0 -23
- data/app/assets/javascripts/luca/concerns/application_event_bindings.coffee +0 -19
- data/app/assets/javascripts/luca/concerns/collection_event_bindings.coffee +0 -47
- data/app/assets/javascripts/luca/concerns/development_tool_helpers.coffee +0 -30
- data/app/assets/javascripts/luca/concerns/dom_helpers.coffee +0 -61
- data/app/assets/javascripts/luca/concerns/enhanced_properties.coffee +0 -23
- data/app/assets/javascripts/luca/concerns/filterable.coffee +0 -101
- data/app/assets/javascripts/luca/concerns/form_model_bindings.coffee +0 -20
- data/app/assets/javascripts/luca/concerns/grid_layout.coffee +0 -15
- data/app/assets/javascripts/luca/concerns/modal_view.coffee +0 -63
- data/app/assets/javascripts/luca/concerns/model_presenter.coffee +0 -23
- data/app/assets/javascripts/luca/concerns/paginatable.coffee +0 -79
- data/app/assets/javascripts/luca/concerns/query_collection_bindings.coffee +0 -52
- data/app/assets/javascripts/luca/concerns/sortable.coffee +0 -69
- data/app/assets/javascripts/luca/concerns/state_model.coffee +0 -58
- data/app/assets/javascripts/luca/concerns/templating.coffee +0 -13
- data/app/assets/javascripts/luca/config.coffee +0 -54
- data/app/assets/javascripts/luca/containers/card_view.coffee +0 -178
- data/app/assets/javascripts/luca/containers/container.coffee +0 -711
- data/app/assets/javascripts/luca/containers/index.coffee +0 -2
- data/app/assets/javascripts/luca/containers/page_controller.coffee +0 -25
- data/app/assets/javascripts/luca/core/events.coffee +0 -114
- data/app/assets/javascripts/luca/core/index.coffee +0 -12
- data/app/assets/javascripts/luca/core/model.coffee +0 -56
- data/app/assets/javascripts/luca/core/panel.coffee +0 -124
- data/app/assets/javascripts/luca/core/registry/component_definition.coffee +0 -319
- data/app/assets/javascripts/luca/core/registry/concerns.coffee +0 -70
- data/app/assets/javascripts/luca/core/registry/index.coffee +0 -4
- data/app/assets/javascripts/luca/core/registry/meta_data.coffee +0 -99
- data/app/assets/javascripts/luca/core/templates.coffee +0 -51
- data/app/assets/javascripts/luca/core/view.coffee +0 -383
- data/app/assets/javascripts/luca/dependencies.coffee +0 -9
- data/app/assets/javascripts/luca/development/code_sync_manager.coffee +0 -173
- data/app/assets/javascripts/luca/development/component.coffee +0 -76
- data/app/assets/javascripts/luca/development/components.coffee +0 -57
- data/app/assets/javascripts/luca/development/index.coffee +0 -5
- data/app/assets/javascripts/luca/index.coffee +0 -9
- data/app/assets/javascripts/luca/managers/index.coffee +0 -2
- data/app/assets/javascripts/luca/managers/socket_manager.coffee +0 -89
- data/app/assets/javascripts/luca/templates/components/bootstrap_form_controls.jst.ejs +0 -10
- data/app/assets/javascripts/luca/templates/components/collection_loader_view.jst.ejs +0 -6
- data/app/assets/javascripts/luca/templates/components/form_alert.jst.ejs +0 -4
- data/app/assets/javascripts/luca/templates/components/grid_view.jst.ejs +0 -11
- data/app/assets/javascripts/luca/templates/components/grid_view_empty_text.jst.ejs +0 -3
- data/app/assets/javascripts/luca/templates/components/load_mask.jst.ejs +0 -5
- data/app/assets/javascripts/luca/templates/components/nav_bar.jst.ejs +0 -19
- data/app/assets/javascripts/luca/templates/components/pagination.jst.ejs +0 -10
- data/app/assets/javascripts/luca/templates/components/table_view.jst.ejs +0 -4
- data/app/assets/javascripts/luca/templates/containers/basic.jst.ejs +0 -1
- data/app/assets/javascripts/luca/templates/containers/tab_selector_container.jst.ejs +0 -12
- data/app/assets/javascripts/luca/templates/containers/tab_view.jst.ejs +0 -2
- data/app/assets/javascripts/luca/templates/containers/toolbar_wrapper.jst.ejs +0 -1
- data/app/assets/javascripts/luca/templates/fields/button_field.jst.ejs +0 -2
- data/app/assets/javascripts/luca/templates/fields/button_field_link.jst.ejs +0 -6
- data/app/assets/javascripts/luca/templates/fields/checkbox_array.jst.ejs +0 -4
- data/app/assets/javascripts/luca/templates/fields/checkbox_array_item.jst.ejs +0 -3
- data/app/assets/javascripts/luca/templates/fields/checkbox_field.jst.ejs +0 -10
- data/app/assets/javascripts/luca/templates/fields/file_upload_field.jst.ejs +0 -10
- data/app/assets/javascripts/luca/templates/fields/hidden_field.jst.ejs +0 -1
- data/app/assets/javascripts/luca/templates/fields/select_field.jst.ejs +0 -11
- data/app/assets/javascripts/luca/templates/fields/text_area_field.jst.ejs +0 -11
- data/app/assets/javascripts/luca/templates/fields/text_field.jst.ejs +0 -16
- data/app/assets/javascripts/luca/util/deprecations.coffee +0 -18
- data/app/assets/javascripts/luca/util/index.coffee +0 -4
- data/app/assets/javascripts/luca/util/keybindings.coffee +0 -24
- data/app/assets/javascripts/luca/util/logging.coffee +0 -30
- data/app/assets/javascripts/luca-ui.js +0 -1
- data/app/assets/stylesheets/luca/components/form_view.scss +0 -7
- data/app/assets/stylesheets/luca/containers/container.scss +0 -19
- data/app/assets/stylesheets/luca/development/index.css +0 -3
- data/app/assets/stylesheets/luca/index.css +0 -4
- data/bin/luca +0 -14
- data/docs/framework.json +0 -1
- data/docs/luca-framework-documentation.js +0 -1
- data/lib/generators/luca/application/application_generator.rb +0 -75
- data/lib/generators/luca/application/templates/controller.rb +0 -4
- data/lib/generators/luca/application/templates/index.html.erb +0 -19
- data/lib/generators/luca/application/templates/index.html.haml +0 -7
- data/lib/generators/luca/application/templates/javascripts/application.coffee +0 -18
- data/lib/generators/luca/application/templates/javascripts/collection_manager.coffee +0 -2
- data/lib/generators/luca/application/templates/javascripts/config.coffee +0 -3
- data/lib/generators/luca/application/templates/javascripts/dependencies.coffee +0 -3
- data/lib/generators/luca/application/templates/javascripts/home.jst.ejs +0 -2
- data/lib/generators/luca/application/templates/javascripts/index.coffee +0 -15
- data/lib/generators/luca/application/templates/javascripts/router.coffee +0 -4
- data/lib/guard/luca.rb +0 -84
- data/lib/luca/asset_compiler.rb +0 -117
- data/lib/luca/cli/generate.rb +0 -37
- data/lib/luca/cli/server.rb +0 -20
- data/lib/luca/cli/sync.rb +0 -40
- data/lib/luca/cli/watch.rb +0 -16
- data/lib/luca/cli.rb +0 -68
- data/lib/luca/collection/endpoint.rb +0 -38
- data/lib/luca/collection/file_backend.rb +0 -121
- data/lib/luca/collection/redis_backend.rb +0 -153
- data/lib/luca/collection.rb +0 -64
- data/lib/luca/compiled_asset.rb +0 -61
- data/lib/luca/component_definition.rb +0 -356
- data/lib/luca/luca_application.rb +0 -258
- data/lib/luca/project.rb +0 -73
- data/lib/luca/project_harness.rb +0 -96
- data/lib/luca/server.rb +0 -7
- data/lib/luca/stylesheet.rb +0 -35
- data/lib/luca/template_asset.rb +0 -64
- data/lib/luca/version.rb +0 -3
- data/lib/luca/watcher.rb +0 -72
- data/lib/railties/luca/tasks.rake +0 -38
- data/site/.bundle/config +0 -2
- data/site/.gitignore +0 -5
- data/site/.rvmrc +0 -1
- data/site/CHANGELOG.md +0 -41
- data/site/DOCS.md +0 -41
- data/site/Gemfile +0 -8
- data/site/Gemfile.lock +0 -134
- data/site/LICENSE.md +0 -19
- data/site/config.rb +0 -84
- data/site/helpers/site_helpers.rb +0 -20
- data/site/html5bp-docs/README.md +0 -38
- data/site/html5bp-docs/contribute.md +0 -104
- data/site/html5bp-docs/crossdomain.md +0 -21
- data/site/html5bp-docs/css.md +0 -135
- data/site/html5bp-docs/extend.md +0 -507
- data/site/html5bp-docs/faq.md +0 -77
- data/site/html5bp-docs/htaccess.md +0 -323
- data/site/html5bp-docs/html.md +0 -170
- data/site/html5bp-docs/js.md +0 -31
- data/site/html5bp-docs/misc.md +0 -25
- data/site/html5bp-docs/usage.md +0 -109
- data/site/readme.md +0 -47
- data/site/source/.htaccess +0 -540
- data/site/source/404.html +0 -157
- data/site/source/app/assets/javascripts/dependencies.js.coffee +0 -6
- data/site/source/app/assets/javascripts/docs/application.coffee +0 -64
- data/site/source/app/assets/javascripts/docs/collections/docs_documentation.coffee +0 -17
- data/site/source/app/assets/javascripts/docs/collections/github_repositories.coffee +0 -7
- data/site/source/app/assets/javascripts/docs/collections/index.coffee +0 -1
- data/site/source/app/assets/javascripts/docs/collections/luca_documentation.coffee +0 -17
- data/site/source/app/assets/javascripts/docs/collections/public_gists.coffee +0 -4
- data/site/source/app/assets/javascripts/docs/config.coffee +0 -5
- data/site/source/app/assets/javascripts/docs/index.coffee +0 -12
- data/site/source/app/assets/javascripts/docs/lib/router.coffee +0 -3
- data/site/source/app/assets/javascripts/docs/models/component.coffee +0 -99
- data/site/source/app/assets/javascripts/docs/models/github_repository.coffee +0 -3
- data/site/source/app/assets/javascripts/docs/models/index.coffee +0 -1
- data/site/source/app/assets/javascripts/docs/templates/component_documentation.jst.ejs +0 -55
- data/site/source/app/assets/javascripts/docs/templates/examples_browser/overview.jst.ejs +0 -4
- data/site/source/app/assets/javascripts/docs/templates/examples_browser/selector.jst.ejs +0 -11
- data/site/source/app/assets/javascripts/docs/templates/github_repository.jst.ejs +0 -4
- data/site/source/app/assets/javascripts/docs/templates/layouts/main.jst.ejs +0 -4
- data/site/source/app/assets/javascripts/docs/templates/left_navigation.jst.ejs +0 -5
- data/site/source/app/assets/javascripts/docs/templates/pages/getting_started.jst.ejs +0 -78
- data/site/source/app/assets/javascripts/docs/templates/pages/home.jst.ejs +0 -57
- data/site/source/app/assets/javascripts/docs/views/components/code_editor.coffee +0 -45
- data/site/source/app/assets/javascripts/docs/views/components/component_documentation.coffee +0 -72
- data/site/source/app/assets/javascripts/docs/views/index.coffee +0 -3
- data/site/source/app/assets/javascripts/docs/views/pages/browse_source/details.coffee +0 -37
- data/site/source/app/assets/javascripts/docs/views/pages/browse_source/list.coffee +0 -31
- data/site/source/app/assets/javascripts/docs/views/pages/browse_source.coffee +0 -46
- data/site/source/app/assets/javascripts/docs/views/pages/component_editor.coffee +0 -10
- data/site/source/app/assets/javascripts/docs/views/pages/examples_browser/docs.coffee +0 -12
- data/site/source/app/assets/javascripts/docs/views/pages/examples_browser/source.coffee +0 -13
- data/site/source/app/assets/javascripts/docs/views/pages/examples_browser.coffee +0 -102
- data/site/source/app/assets/javascripts/docs/views/pages/home.coffee +0 -10
- data/site/source/app/assets/javascripts/docs/views/views/api_browser/index.coffee +0 -43
- data/site/source/app/assets/javascripts/docs/views/views/collection_view_examples/grid_layout_view_example.coffee +0 -14
- data/site/source/app/assets/javascripts/docs/views/views/collection_view_examples/table_view_example.coffee +0 -39
- data/site/source/app/assets/javascripts/docs/views/views/form_view_examples/basic_example.coffee +0 -38
- data/site/source/app/assets/javascripts/docs/views/views/form_view_examples/complex_layout.coffee +0 -110
- data/site/source/app/assets/javascripts/docs/views/views/top_navigation.coffee +0 -6
- data/site/source/app/assets/javascripts/docs-docs.js +0 -1
- data/site/source/app/assets/javascripts/luca-docs.js +0 -1
- data/site/source/app/assets/javascripts/luca-framework-documentation.js +0 -1
- data/site/source/app/assets/javascripts/site.js.coffee +0 -4
- data/site/source/app/assets/javascripts/vendor/codemirror.js +0 -4786
- data/site/source/app/assets/javascripts/vendor/coffeescript.js +0 -346
- data/site/source/app/assets/javascripts/vendor/css.js +0 -465
- data/site/source/app/assets/javascripts/vendor/htmlmixed.js +0 -84
- data/site/source/app/assets/javascripts/vendor/javascript.js +0 -422
- data/site/source/app/assets/javascripts/vendor/js-beautify.js +0 -1353
- data/site/source/app/assets/javascripts/vendor/modernizr-2.6.1.min.js +0 -4
- data/site/source/app/assets/javascripts/vendor/vim.js +0 -2511
- data/site/source/app/assets/stylesheets/docs/api-browser.css.scss +0 -5
- data/site/source/app/assets/stylesheets/docs/application.css.scss +0 -35
- data/site/source/app/assets/stylesheets/docs/browse-source.css.scss +0 -5
- data/site/source/app/assets/stylesheets/docs/scrollable-table.css.scss +0 -5
- data/site/source/app/assets/stylesheets/site.css.scss +0 -2
- data/site/source/app/assets/stylesheets/vendor/codemirror.css +0 -240
- data/site/source/app/assets/stylesheets/vendor/prettify-tomorrow-night-bright.css +0 -160
- data/site/source/app/assets/stylesheets/vendor/twilight.css +0 -26
- data/site/source/crossdomain.xml +0 -15
- data/site/source/documentation.html.haml +0 -1
- data/site/source/favicon_base.png +0 -0
- data/site/source/humans.txt +0 -15
- data/site/source/images/background.png +0 -0
- data/site/source/images/middleman.png +0 -0
- data/site/source/index.html.haml +0 -1
- data/site/source/layouts/layout.haml +0 -55
- data/site/source/readme.md +0 -63
- data/site/source/robots.txt +0 -3
- data/spec/javascripts/components/collection_view_spec.coffee +0 -59
- data/spec/javascripts/components/controller_spec.coffee +0 -62
- data/spec/javascripts/components/form_view_spec.coffee +0 -162
- data/spec/javascripts/components/multi_collection_view_spec.coffee +0 -5
- data/spec/javascripts/components/table_view_spec.coffee +0 -17
- data/spec/javascripts/concerns/collection_event_bindings_spec.coffee +0 -15
- data/spec/javascripts/concerns/dom_helpers_spec.coffee +0 -16
- data/spec/javascripts/concerns/filterable_spec.coffee +0 -25
- data/spec/javascripts/concerns/model_presenter_spec.coffee +0 -31
- data/spec/javascripts/concerns/state_model_spec.coffee +0 -55
- data/spec/javascripts/containers/card_view_spec.coffee +0 -108
- data/spec/javascripts/core/concerns_spec.coffee +0 -88
- data/spec/javascripts/core/container_spec.coffee +0 -287
- data/spec/javascripts/core/define_spec.coffee +0 -116
- data/spec/javascripts/core/events_spec.coffee +0 -26
- data/spec/javascripts/core/field_spec.coffee +0 -4
- data/spec/javascripts/core/util_spec.coffee +0 -24
- data/spec/javascripts/dependencies/index.coffee +0 -3
- data/spec/lib/component_definition_spec.rb +0 -63
- data/spec/lib/input_compiler_spec.rb +0 -9
- data/spec/lib/luca_application_spec.rb +0 -30
- data/spec/support/fixtures/application.coffee +0 -45
- data/spec/support/fixtures/component.coffee +0 -34
- data/tutorials/component-driven-design.md +0 -140
- data/tutorials/structure-of-a-project.md +0 -63
- data/vendor/assets/javascripts/backbone-ext.js +0 -21
- data/vendor/assets/javascripts/backbone-min.js +0 -42
- data/vendor/assets/javascripts/backbone-query.min.js +0 -1
- data/vendor/assets/javascripts/bootstrap.min.js +0 -7
- data/vendor/assets/javascripts/codemirror-ui.js +0 -503
- data/vendor/assets/javascripts/hogan.js +0 -707
- data/vendor/assets/javascripts/inflections.js +0 -656
- data/vendor/assets/javascripts/jasmine-html.js +0 -190
- data/vendor/assets/javascripts/jasmine.js +0 -2476
- data/vendor/assets/javascripts/jquery.js +0 -5
- data/vendor/assets/javascripts/keymaster.min.js +0 -4
- data/vendor/assets/javascripts/luca-dependencies.min.js +0 -8
- data/vendor/assets/javascripts/luca-development.min.js +0 -1
- data/vendor/assets/javascripts/luca-spec.js +0 -11
- data/vendor/assets/javascripts/luca.full.min.js +0 -12
- data/vendor/assets/javascripts/luca.min.js +0 -5
- data/vendor/assets/javascripts/sinon.js +0 -3469
- data/vendor/assets/javascripts/underscore-min.js +0 -1
- data/vendor/assets/javascripts/underscore-string.min.js +0 -1
- data/vendor/assets/stylesheets/bootstrap-responsive.min.css +0 -9
- data/vendor/assets/stylesheets/bootstrap.min.css +0 -9
- data/vendor/assets/stylesheets/luca-components.css +0 -202
- 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'
|