sproutcore 1.6.0.beta.3-java → 1.6.0-java
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +70 -0
- data/{History.txt → History.rdoc} +0 -0
- data/{README.txt → README.rdoc} +3 -2
- data/Rakefile +213 -10
- data/{Todo.txt → Todo.rdoc} +0 -0
- data/VERSION.yml +1 -1
- data/bin/sc-docs +6 -1
- data/lib/Buildfile +5 -1
- data/lib/buildtasks/manifest.rake +14 -1
- data/lib/buildtasks/target.rake +20 -23
- data/lib/frameworks/sproutcore/Buildfile +8 -3
- data/lib/frameworks/sproutcore/CHANGELOG.md +364 -1
- data/lib/frameworks/sproutcore/README.md +1 -1
- data/lib/frameworks/sproutcore/apps/test_controls/controllers/select.js +12 -0
- data/lib/frameworks/sproutcore/apps/test_controls/resources/select_page.js +19 -5
- data/lib/frameworks/sproutcore/apps/welcome/english.lproj/main_page.css +9 -0
- data/lib/frameworks/sproutcore/frameworks/ajax/system/request.js +243 -199
- data/lib/frameworks/sproutcore/frameworks/ajax/system/response.js +250 -172
- data/lib/frameworks/sproutcore/frameworks/ajax/tests/system/request.js +29 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/controllers/array.js +5 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/controllers/controller.js +21 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/controls/button.js +6 -2
- data/lib/frameworks/sproutcore/frameworks/core_foundation/core.js +2 -42
- data/lib/frameworks/sproutcore/frameworks/core_foundation/ext/handlebars/bind.js +38 -15
- data/lib/frameworks/sproutcore/frameworks/core_foundation/ext/handlebars/collection.js +6 -4
- data/lib/frameworks/sproutcore/frameworks/core_foundation/mixins/responder_context.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/mixins/template_helpers/checkbox_support.js +11 -6
- data/lib/frameworks/sproutcore/frameworks/core_foundation/mixins/template_helpers/text_field_support.js +55 -20
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/keyboard.js +2 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/pane.js +26 -20
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/template.js +37 -21
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/application.js +2 -7
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/event.js +7 -7
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/locale.js +157 -5
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/platform.js +2 -2
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/render_context.js +7 -6
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/responder.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/root_responder.js +29 -15
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/sparse_array.js +8 -8
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/string.js +162 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/theme.js +3 -56
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/utils.js +24 -8
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/controllers/array/array_case.js +42 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/controllers/object/content_destroyed.js +59 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/controls/button.js +39 -57
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/mixins/string.js +41 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/mixins/template_helpers/text_field_support.js +19 -2
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/panes/template.js +16 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/render_context/helpers_style.js +5 -3
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/sparse_array.js +32 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template/collection.js +135 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template/handlebars.js +29 -18
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/clippingFrame.js +11 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/didAppendToDocument.js +18 -2
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/insertBefore.js +10 -6
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/keyboard.js +414 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/view.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/{system → views}/bindable_span.js +2 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template_collection.js +112 -40
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view.js +13 -7
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/enabled.js +2 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/keyboard.js +245 -67
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/manipulation.js +17 -9
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/theming.js +8 -18
- data/lib/frameworks/sproutcore/frameworks/core_tools/core.js +8 -2
- data/lib/frameworks/sproutcore/frameworks/core_tools/data_source.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/core_tools/models/target.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/datastore/data_sources/data_source.js +15 -8
- data/lib/frameworks/sproutcore/frameworks/datastore/data_sources/fixtures.js +12 -2
- data/lib/frameworks/sproutcore/frameworks/datastore/mixins/relationship_support.js +296 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/child_record.js +3 -3
- data/lib/frameworks/sproutcore/frameworks/datastore/models/record.js +330 -326
- data/lib/frameworks/sproutcore/frameworks/datastore/models/record_attribute.js +23 -1
- data/lib/frameworks/sproutcore/frameworks/datastore/system/child_array.js +26 -5
- data/lib/frameworks/sproutcore/frameworks/datastore/system/nested_store.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/datastore/system/record_array.js +69 -58
- data/lib/frameworks/sproutcore/frameworks/datastore/system/store.js +614 -614
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/data_sources/data_source.js +203 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record.js +3 -1
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array_complex.js +2 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_complex.js +2 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/core_methods.js +20 -13
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record_attribute.js +76 -47
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/commitChangesFromNestedStore.js +30 -30
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/record_array/core_methods.js +74 -53
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/record_array/flush.js +0 -1
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/commitChangesFromNestedStore.js +24 -24
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/connectDataSource.js +31 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/pushRelationships.js +1177 -0
- data/lib/frameworks/sproutcore/frameworks/datetime/frameworks/core/system/datetime.js +212 -182
- data/lib/frameworks/sproutcore/frameworks/datetime/frameworks/localized/system/datetime.js +6 -67
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/border.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_row_delegate.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/scrollable.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/alert.js +13 -15
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/menu.js +41 -12
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/panel.js +9 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/picker.js +6 -3
- data/lib/frameworks/sproutcore/frameworks/desktop/protocols/drag_data_source.js +3 -3
- data/lib/frameworks/sproutcore/frameworks/desktop/protocols/drop_target.js +3 -3
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/button.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/checkbox.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/collection.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/disclosure.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/image_button.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/master_detail.js +3 -2
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/menu.js +12 -2
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/panel.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/picker.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/progress.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/radio.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/radio_group.js +2 -2
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/segment.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/segmented.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/slider.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/toolbar.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/well.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/workspace.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/alert.css +49 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/debug/a_sample_image.jpg +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/debug/apple-logo1.jpeg +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/debug/iframe.html +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/disclosure.css +20 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/drag.css +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/icons.css +214 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/images/cap.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/images/downbutton.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-alert-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-alert-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-alert-48.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-bookmark-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-bookmark-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-cancel-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-document-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-document-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-down-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-error-48.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-favorite-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-favorite-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-folder-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-folder-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-group-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-group-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-help-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-help-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-info-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-info-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-info-48.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-left-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-options-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-options-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-redo-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-right-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-tools-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-trash-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-trash-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-undo-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-up-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-user-16.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/images/icons/sc-icon-user-24.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/images/thumb-bottom.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/images/thumb-center.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/images/thumb-top.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/images/track.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/images/upbutton.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/list_item.css +145 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/menu.css +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/menu_item_view.css +88 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/modal.css +3 -4
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/panel.css +91 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/picker.css +37 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/progress.css +29 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/radio.css +11 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/segmented.css +122 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/separator.css +20 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/slider.css +34 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/split.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/split_divider.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/tab.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/toolbar.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/{english.lproj → resources}/touch-scroller.css +13 -13
- data/lib/frameworks/sproutcore/frameworks/desktop/resources/well.css +65 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/alert/ui.js +58 -23
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/panel/methods.js +20 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/checkbox/methods.js +121 -103
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/date_field/methods.js +34 -7
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/static_content.js +3 -2
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/tab/methods.js +1 -3
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/tab/ui.js +20 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/views/button.js +14 -15
- data/lib/frameworks/sproutcore/frameworks/desktop/views/checkbox.js +43 -16
- data/lib/frameworks/sproutcore/frameworks/desktop/views/collection.js +717 -700
- data/lib/frameworks/sproutcore/frameworks/desktop/views/list_item.js +2 -2
- data/lib/frameworks/sproutcore/frameworks/desktop/views/master_detail.js +11 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/views/menu_item.js +16 -6
- data/lib/frameworks/sproutcore/frameworks/desktop/views/popup_button.js +4 -7
- data/lib/frameworks/sproutcore/frameworks/desktop/views/progress.js +0 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/views/radio.js +49 -7
- data/lib/frameworks/sproutcore/frameworks/desktop/views/segmented.js +9 -2
- data/lib/frameworks/sproutcore/frameworks/desktop/{panes → views}/select_button.js +52 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/select_field.js +7 -3
- data/lib/frameworks/sproutcore/frameworks/desktop/views/slider.js +4 -26
- data/lib/frameworks/sproutcore/frameworks/desktop/views/tab.js +46 -49
- data/lib/frameworks/sproutcore/frameworks/desktop/views/web.js +20 -19
- data/lib/frameworks/sproutcore/frameworks/experimental/Buildfile +2 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/designer/designers/view_designer.js +249 -249
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/mixins/edit_mode.js +13 -5
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/mixins/emptiness.js +53 -37
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/render_delegates/form.js +2 -1
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/render_delegates/form_row.js +3 -11
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/mixins/edit_mode.js +53 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/mixins/emptiness.js +114 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/views/form.js +174 -6
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/views/form_row.js +86 -6
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/views/form.js +98 -126
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/views/form_row.js +96 -97
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/README.md +2 -1
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/models/record.js +20 -36
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/ext/menu.js +121 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/ext/menu_item.js +90 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/mixins/select_view_menu.js +139 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/render_delegates/select_button.js +14 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/ext/menu_resizing.js +25 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/mixins/select_view_menu/bindings.js +43 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/mixins/select_view_menu/check_selected.js +32 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/views/popup_button/menu_setup.js +40 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/views/popup_button/show_menu.js +45 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/views/select/menu_width.js +49 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/views/select/selected_item.js +191 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/views/popup_button.js +264 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/views/select.js +450 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/split_view/mixins/split_child.js +14 -6
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/split_view/mixins/split_thumb.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/split_view/render_delegates/split.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/split_view/render_delegates/split_divider.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/split_view/views/split.js +9 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/split_view/views/thumb.js +3 -2
- data/lib/frameworks/sproutcore/frameworks/foundation/core.js +2 -2
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/auto_resize.js +16 -19
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/button.js +4 -7
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/content_value_support.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/flowed_layout.js +85 -16
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/inline_editable.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/inline_editor.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/inline_editor_delegate.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/inner_frame.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/canvas_image.js +4 -2
- data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/helpers/sizing.js +2 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/image.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/label.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/render_delegate.js +13 -13
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/benchmark.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/blank.gif +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/bootstrap.rhtml +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/resources/button_view.css +36 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/checkbox_view.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/debug/control-test-pane.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/resources/images/favicon.ico +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/images/sproutcore-logo.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/images/sproutcore-startup-landscape.jpg +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/images/sproutcore-startup-landscape.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/images/sproutcore-startup-portrait.jpg +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/images/sproutcore-startup-portrait.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/images/sproutcore-startup.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/images/sproutcore.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/inline_editor.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/resources/label.css +47 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/radio_view.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/{english.lproj → resources}/static_layout.css +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/resources/text_field.css +125 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/chance.js +5 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/system/exception_handler.js +4 -2
- data/lib/frameworks/sproutcore/frameworks/foundation/system/math.js +2 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/system/module.js +13 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/string.js +0 -43
- data/lib/frameworks/sproutcore/frameworks/foundation/system/utils/string_measurement.js +11 -11
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/flowed_layout/tests.js +912 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/container/ui.js +23 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/methods.js +36 -7
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/ui.js +58 -4
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/date.js +4 -4
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/validator.js +1 -3
- data/lib/frameworks/sproutcore/frameworks/foundation/views/container.js +17 -6
- data/lib/frameworks/sproutcore/frameworks/foundation/views/field.js +0 -15
- data/lib/frameworks/sproutcore/frameworks/foundation/views/label.js +3 -3
- data/lib/frameworks/sproutcore/frameworks/foundation/views/text_field.js +30 -19
- data/lib/frameworks/sproutcore/frameworks/handlebars/handlebars.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/jquery/jquery-buffered.js +2 -76
- data/lib/frameworks/sproutcore/frameworks/jquery/jquery.js +3348 -1591
- data/lib/frameworks/sproutcore/frameworks/routing/system/routes.js +6 -3
- data/lib/frameworks/sproutcore/frameworks/routing/tests/system/routes.js +11 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/core.js +38 -12
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/flatten.js +24 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/ext/array.js +2 -1
- data/lib/frameworks/sproutcore/frameworks/runtime/ext/function.js +5 -5
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/array.js +21 -2
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/copyable.js +3 -2
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/freezable.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/observable.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/runtime/private/property_chain.js +2 -2
- data/lib/frameworks/sproutcore/frameworks/runtime/system/binding.js +14 -14
- data/lib/frameworks/sproutcore/frameworks/runtime/system/error.js +4 -1
- data/lib/frameworks/sproutcore/frameworks/runtime/system/index_set.js +0 -3
- data/lib/frameworks/sproutcore/frameworks/runtime/system/logger.js +4 -4
- data/lib/frameworks/sproutcore/frameworks/runtime/system/object.js +4 -4
- data/lib/frameworks/sproutcore/frameworks/runtime/system/range_observer.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/runtime/system/run_loop.js +3 -3
- data/lib/frameworks/sproutcore/frameworks/runtime/system/set.js +15 -16
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/itemType.js +6 -2
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/objectForPropertyPath.js +10 -5
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/requiredObjectForPropertyPath.js +29 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/private/observer_queue.js +98 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/object/enhance.js +30 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/create.js +17 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/debug/monitor.js +4 -73
- data/lib/frameworks/sproutcore/frameworks/statechart/debug/sequence_matcher.js +189 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/ext/function.js +122 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/system/async.js +88 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/system/empty_state.js +34 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/system/history_state.js +97 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/system/state.js +16 -191
- data/lib/frameworks/sproutcore/frameworks/statechart/system/statechart.js +17 -79
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/debug/sequence_matcher.js +464 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/event_handling/basic/with_concurrent_states.js +31 -11
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/state_transitioning/async/with_concurrent_states.js +6 -4
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/state_transitioning/standard/with_concurrent_states/advanced.js +40 -6
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/state_transitioning/standard/with_concurrent_states/basic.js +22 -2
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/state_transitioning/standard/with_concurrent_states/intermediate.js +44 -3
- data/lib/frameworks/sproutcore/frameworks/testing/core.js +61 -9
- data/lib/frameworks/sproutcore/frameworks/testing/{english.lproj → resources}/additions.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/testing/{english.lproj → resources}/runner.css +10 -2
- data/lib/frameworks/sproutcore/frameworks/testing/{english.lproj → resources}/testsuite.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/testing/system/runner.js +66 -27
- data/lib/frameworks/sproutcore/frameworks/testing/tests/spy_on.js +41 -0
- data/lib/frameworks/sproutcore/frameworks/testing/tests/stub_method.js +9 -0
- data/lib/frameworks/sproutcore/frameworks/yuireset/resources/base.css +80 -0
- data/lib/frameworks/sproutcore/frameworks/yuireset/resources/core.css +20 -0
- data/lib/frameworks/sproutcore/frameworks/yuireset/resources/fonts.css +39 -0
- data/lib/frameworks/sproutcore/frameworks/yuireset/resources/reset.css +126 -0
- data/lib/frameworks/sproutcore/frameworks/yuireset/resources/view.css +57 -0
- data/lib/frameworks/sproutcore/lib/index.rhtml +8 -4
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/14px/checkbox_checked.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/14px/checkbox_checked_active.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/14px/checkbox_mixed.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/14px/checkbox_mixed_active.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/14px/checkbox_unchecked.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/14px/checkbox_unchecked_active.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/16px/checkbox_checked.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/16px/checkbox_checked_active.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/16px/checkbox_mixed.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/16px/checkbox_mixed_active.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/16px/checkbox_unchecked.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/checkbox/ace/16px/checkbox_unchecked_active.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/designs/psds/menu/menu_item.psd +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/14px/checkbox_checked.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/14px/checkbox_checked_active.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/14px/checkbox_mixed.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/14px/checkbox_mixed_active.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/14px/checkbox_unchecked.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/14px/checkbox_unchecked_active.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/16px/checkbox_checked.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/16px/checkbox_checked_active.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/16px/checkbox_mixed.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/16px/checkbox_mixed_active.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/16px/checkbox_unchecked.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/checkbox/ace/16px/checkbox_unchecked_active.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/collection/normal/list.css +13 -4
- data/lib/frameworks/sproutcore/themes/ace/resources/collection/normal/list_item.css +16 -14
- data/lib/frameworks/sproutcore/themes/ace/resources/form/form.css +9 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/menu/menu.css +3 -1
- data/lib/frameworks/sproutcore/themes/ace/resources/menu/menu_item.png +0 -0
- data/lib/frameworks/sproutcore/themes/ace/resources/picker/popover/picker.js +1 -1
- data/lib/frameworks/sproutcore/themes/ace/resources/picker/popover/workspace.js +1 -1
- data/lib/frameworks/sproutcore/themes/ace/resources/split/split.css +1 -1
- data/lib/frameworks/sproutcore/themes/legacy_theme/render_delegates/button.js +1 -1
- data/lib/frameworks/sproutcore/themes/legacy_theme/render_delegates/panel.js +1 -1
- data/lib/frameworks/sproutcore/themes/legacy_theme/render_delegates/progress.js +2 -0
- data/lib/frameworks/sproutcore/themes/legacy_theme/render_delegates/slider.js +1 -1
- data/lib/frameworks/sproutcore/themes/legacy_theme/render_delegates/well.js +1 -1
- data/lib/gen/app/templates/apps/@target_name@/Buildfile +1 -4
- data/lib/gen/app/templates/apps/@target_name@/core.js +1 -4
- data/lib/gen/app/templates/apps/@target_name@/main.js +1 -4
- data/lib/gen/app/templates/apps/@target_name@/resources/main_page.js +1 -4
- data/lib/gen/app/templates/apps/@target_name@/theme.js +1 -4
- data/lib/gen/controller/templates/controllers/{@filename@.js → @filename@_controller.js} +1 -4
- data/lib/gen/controller/templates/tests/controllers/{@filename@.js → @filename@_test.js} +1 -4
- data/lib/gen/data-source/templates/data_sources/{@filename@.js → @filename@_data_source.js} +1 -4
- data/lib/gen/design/templates/resources/@filename@.js +1 -4
- data/lib/gen/framework/templates/frameworks/@target_name@/core.js +1 -4
- data/lib/gen/framework/templates/frameworks/@target_name@/english.lproj/strings.js +1 -4
- data/lib/gen/html_app/templates/apps/@target_name@/@target_name@.js +1 -4
- data/lib/gen/html_app/templates/apps/@target_name@/resources/stylesheets/@target_name@.css +2 -0
- data/lib/gen/html_project/templates/@filename@/Buildfile +1 -4
- data/lib/gen/html_project/templates/@filename@/README +1 -4
- data/lib/gen/language/Buildfile +1 -1
- data/lib/gen/language/templates/@filename@/strings.js +1 -4
- data/lib/gen/model/templates/fixtures/{@filename@.js → @filename@_fixtures.js} +2 -5
- data/lib/gen/model/templates/models/{@filename@.js → @filename@_model.js} +1 -4
- data/lib/gen/model/templates/tests/models/{@filename@.js → @filename@_test.js} +1 -4
- data/lib/gen/page/templates/pages/@target_name@/Buildfile +1 -4
- data/lib/gen/page/templates/pages/@target_name@/core.js +1 -4
- data/lib/gen/page/templates/pages/@target_name@/en.lproj/strings.js +1 -4
- data/lib/gen/page/templates/pages/@target_name@/resources/body.css +3 -1
- data/lib/gen/project/templates/@filename@/Buildfile +1 -4
- data/lib/gen/project/templates/@filename@/README +1 -5
- data/lib/gen/responder/templates/states/{@filename@.js → @filename@_state.js} +1 -4
- data/lib/gen/test/templates/tests/{@filename@.js → @filename@_test.js} +1 -4
- data/lib/gen/theme/templates/themes/@target_name@/resources/theme_styles.css +1 -5
- data/lib/gen/theme/templates/themes/@target_name@/theme.js +1 -4
- data/lib/gen/view/templates/tests/views/{@filename@.js → @filename@_test.js} +1 -4
- data/lib/gen/view/templates/views/{@filename@.js → @filename@_view.js} +1 -4
- data/lib/sproutcore.rb +5 -15
- data/lib/sproutcore/builders/base.rb +5 -1
- data/lib/sproutcore/builders/handlebars.rb +12 -1
- data/lib/sproutcore/builders/module.rb +2 -2
- data/lib/sproutcore/buildfile/string_ext.rb +0 -4
- data/lib/sproutcore/helpers/cssmin.rb +44 -59
- data/lib/sproutcore/helpers/static_helper.rb +4 -2
- data/lib/sproutcore/helpers/text_helper.rb +11 -13
- data/lib/sproutcore/models/generator.rb +22 -0
- data/lib/sproutcore/models/manifest.rb +4 -4
- data/lib/sproutcore/models/manifest_entry.rb +1 -0
- data/lib/sproutcore/models/target.rb +3 -107
- data/lib/sproutcore/rack.rb +0 -1
- data/lib/sproutcore/rack/builder.rb +3 -0
- data/lib/sproutcore/rack/dev.rb +0 -1
- data/lib/sproutcore/rack/proxy.rb +240 -93
- data/lib/sproutcore/rack/service.rb +1 -1
- data/lib/sproutcore/render_engines/haml.rb +2 -5
- data/lib/sproutcore/tools.rb +11 -11
- data/lib/sproutcore/tools/build.rb +2 -0
- data/lib/sproutcore/tools/docs.rb +2 -37
- data/lib/sproutcore/tools/init.rb +10 -22
- data/lib/sproutcore/tools/manifest.rb +21 -22
- data/spec/buildtasks/manifest/prepare_build_tasks/combine_spec.rb +21 -1
- data/spec/buildtasks/target_spec.rb +9 -0
- data/spec/fixtures/builder_tests/apps/handlebars_test/Buildfile +1 -0
- data/spec/fixtures/builder_tests/apps/handlebars_test/{template.handlebars → templates/template.handlebars} +2 -0
- data/{lib/doc_templates/sproutcore/allclasses.tmpl → spec/fixtures/ordered_entries/apps/template_style/a.js} +0 -0
- data/spec/fixtures/{real_world/frameworks/sproutcore/apps/docs/PLACEHOLDER → ordered_entries/apps/template_style/template_style.js} +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/Buildfile +1 -1
- data/spec/lib/builders/handlebars_spec.rb +10 -4
- data/spec/lib/buildfile_commands/build_task_spec.rb +1 -1
- data/spec/lib/tools/manifest_spec.rb +11 -0
- data/sproutcore.gemspec +8 -7
- data/vendor/chance/lib/chance/instance.rb +8 -9
- metadata +167 -266
- data/lib/doc_templates/jsdoc/allclasses.tmpl +0 -17
- data/lib/doc_templates/jsdoc/allfiles.tmpl +0 -56
- data/lib/doc_templates/jsdoc/class.tmpl +0 -487
- data/lib/doc_templates/jsdoc/index.tmpl +0 -38
- data/lib/doc_templates/jsdoc/publish.js +0 -170
- data/lib/doc_templates/jsdoc/static/default.css +0 -162
- data/lib/doc_templates/jsdoc/static/header.html +0 -2
- data/lib/doc_templates/jsdoc/static/index.html +0 -19
- data/lib/doc_templates/jsdoc/symbol.tmpl +0 -35
- data/lib/doc_templates/sproutcore/allfiles.tmpl +0 -56
- data/lib/doc_templates/sproutcore/class.tmpl +0 -674
- data/lib/doc_templates/sproutcore/classes-json.tmpl +0 -55
- data/lib/doc_templates/sproutcore/index.tmpl +0 -62
- data/lib/doc_templates/sproutcore/publish.js +0 -346
- data/lib/doc_templates/sproutcore/static/default.css +0 -258
- data/lib/doc_templates/sproutcore/static/header.html +0 -2
- data/lib/doc_templates/sproutcore/static/index.html +0 -19
- data/lib/doc_templates/sproutcore/symbol.tmpl +0 -35
- data/lib/frameworks/sproutcore/frameworks/core_foundation/resources/core.css +0 -378
- data/lib/frameworks/sproutcore/frameworks/core_foundation/resources/view.css +0 -57
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/alert.css +0 -56
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/disclosure.css +0 -73
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/icons.css +0 -916
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/icons/shared.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/list_item.css +0 -185
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/menu.css +0 -12
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/menu_item_view.css +0 -101
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/panel.css +0 -91
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/picker.css +0 -35
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/progress.css +0 -33
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/radio.css +0 -10
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/segmented.css +0 -132
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/separator.css +0 -19
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/slider.css +0 -69
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/strings.js +0 -14
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/well.css +0 -71
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/english.lproj/default_styles.css +0 -5
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/english.lproj/strings.js +0 -15
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/views/form_checkbox_field.js +0 -17
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/views/form_field.js +0 -17
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/views/form_label.js +0 -17
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/views/form_radio_field.js +0 -17
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/tests/views/form_text_field.js +0 -17
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/button_view.css +0 -40
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/images/favicon.ico +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/label.css +0 -47
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/text_field.css +0 -146
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/private/observer_queue/isObservingSuspended.js +0 -55
- data/lib/frameworks/sproutcore/themes/empty_theme/tests/mini_icons.rhtml +0 -69
- data/lib/sproutcore/rack/docs.rb +0 -24
- data/vendor/jsdoc/README.txt +0 -151
- data/vendor/jsdoc/app/frame.js +0 -33
- data/vendor/jsdoc/app/frame/Chain.js +0 -102
- data/vendor/jsdoc/app/frame/Dumper.js +0 -144
- data/vendor/jsdoc/app/frame/Hash.js +0 -47
- data/vendor/jsdoc/app/frame/Link.js +0 -142
- data/vendor/jsdoc/app/frame/Namespace.js +0 -10
- data/vendor/jsdoc/app/frame/Opt.js +0 -134
- data/vendor/jsdoc/app/frame/Reflection.js +0 -26
- data/vendor/jsdoc/app/frame/String.js +0 -93
- data/vendor/jsdoc/app/frame/Testrun.js +0 -129
- data/vendor/jsdoc/app/handlers/FOODOC.js +0 -26
- data/vendor/jsdoc/app/handlers/XMLDOC.js +0 -26
- data/vendor/jsdoc/app/handlers/XMLDOC/DomReader.js +0 -159
- data/vendor/jsdoc/app/handlers/XMLDOC/XMLDoc.js +0 -16
- data/vendor/jsdoc/app/handlers/XMLDOC/XMLParse.js +0 -292
- data/vendor/jsdoc/app/lib/JSDOC.js +0 -98
- data/vendor/jsdoc/app/lib/JSDOC/DocComment.js +0 -200
- data/vendor/jsdoc/app/lib/JSDOC/DocTag.js +0 -294
- data/vendor/jsdoc/app/lib/JSDOC/JsDoc.js +0 -162
- data/vendor/jsdoc/app/lib/JSDOC/JsPlate.js +0 -100
- data/vendor/jsdoc/app/lib/JSDOC/Lang.js +0 -144
- data/vendor/jsdoc/app/lib/JSDOC/Parser.js +0 -109
- data/vendor/jsdoc/app/lib/JSDOC/PluginManager.js +0 -33
- data/vendor/jsdoc/app/lib/JSDOC/Symbol.js +0 -681
- data/vendor/jsdoc/app/lib/JSDOC/SymbolSet.js +0 -226
- data/vendor/jsdoc/app/lib/JSDOC/TextStream.js +0 -41
- data/vendor/jsdoc/app/lib/JSDOC/Token.js +0 -18
- data/vendor/jsdoc/app/lib/JSDOC/TokenReader.js +0 -332
- data/vendor/jsdoc/app/lib/JSDOC/TokenStream.js +0 -133
- data/vendor/jsdoc/app/lib/JSDOC/Util.js +0 -32
- data/vendor/jsdoc/app/lib/JSDOC/Walker.js +0 -453
- data/vendor/jsdoc/app/main.js +0 -74
- data/vendor/jsdoc/app/plugins/commentSrcJson.js +0 -19
- data/vendor/jsdoc/app/plugins/frameworkPrototype.js +0 -16
- data/vendor/jsdoc/app/plugins/functionCall.js +0 -10
- data/vendor/jsdoc/app/plugins/publishSrcHilite.js +0 -62
- data/vendor/jsdoc/app/plugins/sproutcoreTags.js +0 -26
- data/vendor/jsdoc/app/plugins/symbolLink.js +0 -9
- data/vendor/jsdoc/app/plugins/tagParamConfig.js +0 -31
- data/vendor/jsdoc/app/plugins/tagSynonyms.js +0 -43
- data/vendor/jsdoc/app/run.js +0 -346
- data/vendor/jsdoc/app/t/TestDoc.js +0 -144
- data/vendor/jsdoc/app/t/runner.js +0 -13
- data/vendor/jsdoc/app/test.js +0 -304
- data/vendor/jsdoc/app/test/addon.js +0 -24
- data/vendor/jsdoc/app/test/anon_inner.js +0 -14
- data/vendor/jsdoc/app/test/augments.js +0 -31
- data/vendor/jsdoc/app/test/augments2.js +0 -26
- data/vendor/jsdoc/app/test/borrows.js +0 -41
- data/vendor/jsdoc/app/test/borrows2.js +0 -23
- data/vendor/jsdoc/app/test/config.js +0 -22
- data/vendor/jsdoc/app/test/constructs.js +0 -18
- data/vendor/jsdoc/app/test/encoding.js +0 -10
- data/vendor/jsdoc/app/test/encoding_other.js +0 -12
- data/vendor/jsdoc/app/test/functions_anon.js +0 -39
- data/vendor/jsdoc/app/test/functions_nested.js +0 -33
- data/vendor/jsdoc/app/test/global.js +0 -13
- data/vendor/jsdoc/app/test/globals.js +0 -25
- data/vendor/jsdoc/app/test/ignore.js +0 -10
- data/vendor/jsdoc/app/test/inner.js +0 -16
- data/vendor/jsdoc/app/test/jsdoc_test.js +0 -477
- data/vendor/jsdoc/app/test/lend.js +0 -33
- data/vendor/jsdoc/app/test/memberof.js +0 -20
- data/vendor/jsdoc/app/test/memberof_constructor.js +0 -15
- data/vendor/jsdoc/app/test/name.js +0 -19
- data/vendor/jsdoc/app/test/namespace_nested.js +0 -23
- data/vendor/jsdoc/app/test/nocode.js +0 -13
- data/vendor/jsdoc/app/test/oblit_anon.js +0 -20
- data/vendor/jsdoc/app/test/overview.js +0 -20
- data/vendor/jsdoc/app/test/param_inline.js +0 -37
- data/vendor/jsdoc/app/test/params_optional.js +0 -8
- data/vendor/jsdoc/app/test/prototype.js +0 -17
- data/vendor/jsdoc/app/test/prototype_nested.js +0 -9
- data/vendor/jsdoc/app/test/prototype_oblit.js +0 -13
- data/vendor/jsdoc/app/test/prototype_oblit_constructor.js +0 -24
- data/vendor/jsdoc/app/test/public.js +0 -10
- data/vendor/jsdoc/app/test/shared.js +0 -42
- data/vendor/jsdoc/app/test/shared2.js +0 -2
- data/vendor/jsdoc/app/test/shortcuts.js +0 -22
- data/vendor/jsdoc/app/test/static_this.js +0 -13
- data/vendor/jsdoc/app/test/synonyms.js +0 -23
- data/vendor/jsdoc/app/test/tosource.js +0 -23
- data/vendor/jsdoc/app/test/variable_redefine.js +0 -14
- data/vendor/jsdoc/changes.txt +0 -47
- data/vendor/jsdoc/conf/sample.conf +0 -31
- data/vendor/jsdoc/java/build.xml +0 -36
- data/vendor/jsdoc/java/build_1.4.xml +0 -36
- data/vendor/jsdoc/java/classes/js.jar +0 -0
- data/vendor/jsdoc/java/src/JsDebugRun.java +0 -21
- data/vendor/jsdoc/java/src/JsRun.java +0 -21
- data/vendor/jsdoc/jsdebug.jar +0 -0
- data/vendor/jsdoc/jsrun.jar +0 -0
- data/vendor/jsdoc/t/TestDoc.js +0 -144
- data/vendor/jsdoc/t/runner.js +0 -13
- data/vendor/jsdoc/test.js +0 -304
- data/vendor/jsdoc/test/addon.js +0 -24
- data/vendor/jsdoc/test/anon_inner.js +0 -14
- data/vendor/jsdoc/test/augments.js +0 -31
- data/vendor/jsdoc/test/augments2.js +0 -26
- data/vendor/jsdoc/test/borrows.js +0 -41
- data/vendor/jsdoc/test/borrows2.js +0 -23
- data/vendor/jsdoc/test/config.js +0 -22
- data/vendor/jsdoc/test/constructs.js +0 -18
- data/vendor/jsdoc/test/encoding.js +0 -10
- data/vendor/jsdoc/test/encoding_other.js +0 -12
- data/vendor/jsdoc/test/functions_anon.js +0 -39
- data/vendor/jsdoc/test/functions_nested.js +0 -33
- data/vendor/jsdoc/test/global.js +0 -13
- data/vendor/jsdoc/test/globals.js +0 -25
- data/vendor/jsdoc/test/ignore.js +0 -10
- data/vendor/jsdoc/test/inner.js +0 -16
- data/vendor/jsdoc/test/jsdoc_test.js +0 -477
- data/vendor/jsdoc/test/lend.js +0 -33
- data/vendor/jsdoc/test/memberof.js +0 -20
- data/vendor/jsdoc/test/memberof_constructor.js +0 -15
- data/vendor/jsdoc/test/name.js +0 -19
- data/vendor/jsdoc/test/namespace_nested.js +0 -23
- data/vendor/jsdoc/test/nocode.js +0 -13
- data/vendor/jsdoc/test/oblit_anon.js +0 -20
- data/vendor/jsdoc/test/overview.js +0 -20
- data/vendor/jsdoc/test/param_inline.js +0 -37
- data/vendor/jsdoc/test/params_optional.js +0 -8
- data/vendor/jsdoc/test/prototype.js +0 -17
- data/vendor/jsdoc/test/prototype_nested.js +0 -9
- data/vendor/jsdoc/test/prototype_oblit.js +0 -13
- data/vendor/jsdoc/test/prototype_oblit_constructor.js +0 -24
- data/vendor/jsdoc/test/public.js +0 -10
- data/vendor/jsdoc/test/shared.js +0 -42
- data/vendor/jsdoc/test/shared2.js +0 -2
- data/vendor/jsdoc/test/shortcuts.js +0 -22
- data/vendor/jsdoc/test/static_this.js +0 -13
- data/vendor/jsdoc/test/synonyms.js +0 -23
- data/vendor/jsdoc/test/tosource.js +0 -23
- data/vendor/jsdoc/test/variable_redefine.js +0 -14
@@ -0,0 +1,203 @@
|
|
1
|
+
// ==========================================================================
|
2
|
+
// Project: SC.DataSource Unit Test
|
3
|
+
// Copyright: ©2011 Junction Networks and contributors.
|
4
|
+
// License: Licensed under MIT license (see license.js)
|
5
|
+
// ==========================================================================
|
6
|
+
/*globals JN module test ok equals same stop start */
|
7
|
+
|
8
|
+
var MyApp, wasCalled, resetWasCalled;
|
9
|
+
module("SC.DataSource", {
|
10
|
+
setup: function () {
|
11
|
+
MyApp = window.MyApp = {};
|
12
|
+
MyApp.store = SC.Store.create();
|
13
|
+
MyApp.Foo = SC.Record.extend();
|
14
|
+
|
15
|
+
MyApp.DataSource = SC.DataSource.extend({
|
16
|
+
fetch: function (store, query) {
|
17
|
+
wasCalled = true;
|
18
|
+
equals(arguments.length, 2);
|
19
|
+
return YES;
|
20
|
+
},
|
21
|
+
|
22
|
+
createRecord: function (store, storeKey, params) {
|
23
|
+
wasCalled = true;
|
24
|
+
equals(arguments.length, 3);
|
25
|
+
return YES;
|
26
|
+
},
|
27
|
+
|
28
|
+
updateRecord: function (store, storeKey, params) {
|
29
|
+
wasCalled = true;
|
30
|
+
equals(arguments.length, 3);
|
31
|
+
return YES;
|
32
|
+
},
|
33
|
+
|
34
|
+
retrieveRecord: function (store, storeKey, params) {
|
35
|
+
wasCalled = true;
|
36
|
+
equals(arguments.length, 3);
|
37
|
+
return YES;
|
38
|
+
},
|
39
|
+
|
40
|
+
destroyRecord: function (store, storeKey, params) {
|
41
|
+
wasCalled = true;
|
42
|
+
equals(arguments.length, 3);
|
43
|
+
return YES;
|
44
|
+
},
|
45
|
+
|
46
|
+
reset: function() {
|
47
|
+
resetWasCalled = true;
|
48
|
+
return this;
|
49
|
+
}
|
50
|
+
});
|
51
|
+
SC.RunLoop.begin();
|
52
|
+
},
|
53
|
+
|
54
|
+
teardown: function () {
|
55
|
+
SC.RunLoop.end();
|
56
|
+
}
|
57
|
+
});
|
58
|
+
|
59
|
+
test("The dataSource will forward calls to the appropriate methods", function () {
|
60
|
+
var ds = MyApp.DataSource.create();
|
61
|
+
MyApp.store.set('dataSource', ds);
|
62
|
+
ok(MyApp.store.find(SC.Query.remote(MyApp.Foo)),
|
63
|
+
"the fetch should return a record array");
|
64
|
+
ok(wasCalled, "`fetch` should have been called");
|
65
|
+
wasCalled = NO;
|
66
|
+
|
67
|
+
ok(MyApp.store.find(MyApp.Foo, "testing retrieve"),
|
68
|
+
"retrieve should return a new record (because the dataSource handled the request YES)");
|
69
|
+
ok(wasCalled, "`retrieve` should have been called");
|
70
|
+
wasCalled = NO;
|
71
|
+
|
72
|
+
var rec = MyApp.store.createRecord(MyApp.Foo, {});
|
73
|
+
|
74
|
+
equals(MyApp.store.commitRecord(MyApp.Foo, 'foo', rec.get('storeKey')), YES,
|
75
|
+
"commiting a new record should return YES");
|
76
|
+
ok(wasCalled, "`createRecord` should have been called");
|
77
|
+
wasCalled = NO;
|
78
|
+
|
79
|
+
MyApp.store.writeStatus(rec.get('storeKey'), SC.Record.READY_CLEAN);
|
80
|
+
|
81
|
+
rec.set('zero', 0);
|
82
|
+
equals(MyApp.store.commitRecord(MyApp.Foo, 'foo', rec.get('storeKey')), YES,
|
83
|
+
"updating a record should return YES");
|
84
|
+
ok(wasCalled, "`updateRecord` should have been called");
|
85
|
+
wasCalled = NO;
|
86
|
+
|
87
|
+
MyApp.store.writeStatus(rec.get('storeKey'), SC.Record.READY_CLEAN);
|
88
|
+
|
89
|
+
rec.destroy();
|
90
|
+
// broken in SC.Store
|
91
|
+
equals(MyApp.store.commitRecord(MyApp.Foo, 'foo', rec.get('storeKey')), YES,
|
92
|
+
"destroying the record should return YES");
|
93
|
+
ok(wasCalled, "`destroyRecord` should have been called");
|
94
|
+
});
|
95
|
+
|
96
|
+
test("The dataSource will return YES when all records committed return YES", function () {
|
97
|
+
var ds = MyApp.DataSource.create({
|
98
|
+
createRecord: function () { return YES; },
|
99
|
+
updateRecord: function () { return YES; },
|
100
|
+
destroyRecord: function () { return YES; }
|
101
|
+
});
|
102
|
+
|
103
|
+
MyApp.store.set('dataSource', ds);
|
104
|
+
|
105
|
+
var rec1 = MyApp.store.createRecord(MyApp.Foo, {}),
|
106
|
+
rec2, rec3;
|
107
|
+
|
108
|
+
equals(MyApp.store.commitRecords(), YES,
|
109
|
+
"commiting a single new record should return YES");
|
110
|
+
|
111
|
+
MyApp.store.writeStatus(rec1.get('storeKey'), SC.Record.READY_CLEAN);
|
112
|
+
|
113
|
+
rec1.set('zero', 0);
|
114
|
+
rec2 = MyApp.store.createRecord(MyApp.Foo, {});
|
115
|
+
|
116
|
+
equals(MyApp.store.commitRecords(), YES,
|
117
|
+
"commiting records for an 'update' and 'create' should return YES");
|
118
|
+
|
119
|
+
MyApp.store.writeStatus(rec1.get('storeKey'), SC.Record.READY_CLEAN);
|
120
|
+
MyApp.store.writeStatus(rec2.get('storeKey'), SC.Record.READY_CLEAN);
|
121
|
+
|
122
|
+
rec1.destroy();
|
123
|
+
rec2.set('one', 1);
|
124
|
+
rec3 = MyApp.store.createRecord(MyApp.Foo, {});
|
125
|
+
|
126
|
+
equals(MyApp.store.commitRecords(), YES,
|
127
|
+
"commiting records for an 'update', 'create', and 'destroy' should return YES");
|
128
|
+
});
|
129
|
+
|
130
|
+
test("The dataSource will return SC.MIXED_STATE when all records committed return YES and NO", function () {
|
131
|
+
var ds = MyApp.DataSource.create({
|
132
|
+
createRecord: function () { return NO; },
|
133
|
+
updateRecord: function () { return YES; },
|
134
|
+
destroyRecord: function () { return NO; }
|
135
|
+
});
|
136
|
+
|
137
|
+
MyApp.store.set('dataSource', ds);
|
138
|
+
|
139
|
+
var rec1 = MyApp.store.createRecord(MyApp.Foo, {}),
|
140
|
+
rec2, rec3;
|
141
|
+
|
142
|
+
equals(MyApp.store.commitRecords(), NO,
|
143
|
+
"commiting a single new record should return NO");
|
144
|
+
|
145
|
+
MyApp.store.writeStatus(rec1.get('storeKey'), SC.Record.READY_CLEAN);
|
146
|
+
|
147
|
+
rec1.set('zero', 0);
|
148
|
+
rec2 = MyApp.store.createRecord(MyApp.Foo, {});
|
149
|
+
|
150
|
+
equals(MyApp.store.commitRecords(), SC.MIXED_STATE,
|
151
|
+
"commiting records for an 'update' and 'create' should return %@".fmt(SC.MIXED_STATE));
|
152
|
+
|
153
|
+
MyApp.store.writeStatus(rec1.get('storeKey'), SC.Record.READY_CLEAN);
|
154
|
+
MyApp.store.writeStatus(rec2.get('storeKey'), SC.Record.READY_CLEAN);
|
155
|
+
|
156
|
+
rec1.destroy();
|
157
|
+
rec2.set('one', 1);
|
158
|
+
rec3 = MyApp.store.createRecord(MyApp.Foo, {});
|
159
|
+
|
160
|
+
equals(MyApp.store.commitRecords(), SC.MIXED_STATE,
|
161
|
+
"commiting records for an 'update', 'create', and 'destroy' should return %@".fmt(SC.MIXED_STATE));
|
162
|
+
});
|
163
|
+
|
164
|
+
test("The dataSource will return NO when all records committed return NO", function () {
|
165
|
+
var ds = MyApp.DataSource.create({
|
166
|
+
createRecord: function () { return NO; },
|
167
|
+
updateRecord: function () { return NO; },
|
168
|
+
destroyRecord: function () { return NO; }
|
169
|
+
});
|
170
|
+
MyApp.store.set('dataSource', ds);
|
171
|
+
|
172
|
+
var rec1 = MyApp.store.createRecord(MyApp.Foo, {}),
|
173
|
+
rec2, rec3;
|
174
|
+
|
175
|
+
equals(MyApp.store.commitRecords(), NO,
|
176
|
+
"commiting a single new record should return NO");
|
177
|
+
|
178
|
+
MyApp.store.writeStatus(rec1.get('storeKey'), SC.Record.READY_CLEAN);
|
179
|
+
|
180
|
+
rec1.set('zero', 0);
|
181
|
+
rec2 = MyApp.store.createRecord(MyApp.Foo, {});
|
182
|
+
|
183
|
+
equals(MyApp.store.commitRecords(), NO,
|
184
|
+
"commiting records for an 'update' and 'create' should return NO");
|
185
|
+
|
186
|
+
MyApp.store.writeStatus(rec1.get('storeKey'), SC.Record.READY_CLEAN);
|
187
|
+
MyApp.store.writeStatus(rec2.get('storeKey'), SC.Record.READY_CLEAN);
|
188
|
+
|
189
|
+
rec1.destroy();
|
190
|
+
rec2.set('one', 1);
|
191
|
+
rec3 = MyApp.store.createRecord(MyApp.Foo, {});
|
192
|
+
|
193
|
+
equals(MyApp.store.commitRecords(), NO,
|
194
|
+
"commiting records for an 'update', 'create', and 'destroy' should return NO");
|
195
|
+
});
|
196
|
+
|
197
|
+
test("The store calls reset on the dataSource when reset", function(){
|
198
|
+
MyApp.store.set('dataSource', MyApp.DataSource.create());
|
199
|
+
resetWasCalled = NO; // Just to be sure
|
200
|
+
|
201
|
+
MyApp.store.reset();
|
202
|
+
ok(resetWasCalled, "should have called reset");
|
203
|
+
});
|
data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record.js
CHANGED
@@ -9,7 +9,7 @@
|
|
9
9
|
//
|
10
10
|
var NestedRecord, store, testParent, testParent2, childData1;
|
11
11
|
|
12
|
-
var initModels = function(){
|
12
|
+
var initModels = function() {
|
13
13
|
NestedRecord.ParentRecordTest = SC.Record.extend({
|
14
14
|
/** Child Record Namespace */
|
15
15
|
nestedRecordNamespace: NestedRecord,
|
@@ -34,6 +34,7 @@ module("Basic SC.Record Functions w/ Parent > Child", {
|
|
34
34
|
NestedRecord = SC.Object.create({
|
35
35
|
store: SC.Store.create()
|
36
36
|
});
|
37
|
+
window.NestedRecord = NestedRecord;
|
37
38
|
store = NestedRecord.store;
|
38
39
|
initModels();
|
39
40
|
SC.RunLoop.begin();
|
@@ -79,6 +80,7 @@ module("Basic SC.Record Functions w/ Parent > Child", {
|
|
79
80
|
store = null;
|
80
81
|
childData1 = null;
|
81
82
|
NestedRecord = null;
|
83
|
+
delete(window.NestedRecord);
|
82
84
|
}
|
83
85
|
});
|
84
86
|
|
@@ -360,4 +360,48 @@ test("Create Parent with Broken Child Array", function(){
|
|
360
360
|
|
361
361
|
});
|
362
362
|
|
363
|
+
test("pushObject should trigger an arrayContentDidChange with only 1 added item", function() {
|
364
|
+
var didChangeCalls = [], target;
|
363
365
|
|
366
|
+
target = SC.Object.create({
|
367
|
+
willChange: function() {},
|
368
|
+
didChange: function() {
|
369
|
+
didChangeCalls.push(arguments);
|
370
|
+
}
|
371
|
+
});
|
372
|
+
|
373
|
+
testParent.get('elements').addArrayObservers({
|
374
|
+
target: target,
|
375
|
+
willChange: 'willChange',
|
376
|
+
didChange: 'didChange'
|
377
|
+
});
|
378
|
+
testParent.get('elements').pushObject({});
|
379
|
+
|
380
|
+
equals(didChangeCalls.length, 1, 'didChange should only be called once');
|
381
|
+
equals(didChangeCalls[0][0], 4, 'didChange should be called with a start index of 4');
|
382
|
+
equals(didChangeCalls[0][1], 0, 'didChange should be called with a removed count of 0');
|
383
|
+
equals(didChangeCalls[0][2], 1, 'didChange should be called with an added count of 1');
|
384
|
+
});
|
385
|
+
|
386
|
+
test("replace should trigger an arrayContentDidChange with only 1 added item", function() {
|
387
|
+
var didChangeCalls = [], target;
|
388
|
+
|
389
|
+
target = SC.Object.create({
|
390
|
+
willChange: function() {},
|
391
|
+
didChange: function() {
|
392
|
+
didChangeCalls.push(arguments);
|
393
|
+
}
|
394
|
+
});
|
395
|
+
|
396
|
+
testParent.get('elements').addArrayObservers({
|
397
|
+
target: target,
|
398
|
+
willChange: 'willChange',
|
399
|
+
didChange: 'didChange'
|
400
|
+
});
|
401
|
+
testParent.get('elements').replace(3, 1, [{}]);
|
402
|
+
|
403
|
+
equals(didChangeCalls.length, 1, 'didChange should only be called once');
|
404
|
+
equals(didChangeCalls[0][0], 3, 'didChange should be called with a start index of 3');
|
405
|
+
equals(didChangeCalls[0][1], 1, 'didChange should be called with a removed count of 1');
|
406
|
+
equals(didChangeCalls[0][2], 1, 'didChange should be called with an added count of 1');
|
407
|
+
});
|
@@ -42,6 +42,7 @@ module("Complex SC.Record: Parent > Array of Children > Array of Children", {
|
|
42
42
|
NestedRecord = SC.Object.create({
|
43
43
|
store: SC.Store.create()
|
44
44
|
});
|
45
|
+
window.NestedRecord = NestedRecord;
|
45
46
|
store = NestedRecord.store;
|
46
47
|
initModels();
|
47
48
|
SC.RunLoop.begin();
|
@@ -117,6 +118,7 @@ module("Complex SC.Record: Parent > Array of Children > Array of Children", {
|
|
117
118
|
delete NestedRecord.Group;
|
118
119
|
delete NestedRecord.Person;
|
119
120
|
delete NestedRecord.Address;
|
121
|
+
delete window.NestedRecord;
|
120
122
|
NestedRecord = null;
|
121
123
|
testParent = null;
|
122
124
|
peopleData1 = null;
|
@@ -42,6 +42,7 @@ module("Basic SC.Record Functions w/ a Parent > Child > Child", {
|
|
42
42
|
NestedRecord = SC.Object.create({
|
43
43
|
store: SC.Store.create()
|
44
44
|
});
|
45
|
+
window.NestedRecord = NestedRecord;
|
45
46
|
store = NestedRecord.store;
|
46
47
|
initModels();
|
47
48
|
SC.RunLoop.begin();
|
@@ -65,6 +66,7 @@ module("Basic SC.Record Functions w/ a Parent > Child > Child", {
|
|
65
66
|
delete NestedRecord.ParentRecordTest;
|
66
67
|
delete NestedRecord.Person;
|
67
68
|
delete NestedRecord.Address;
|
69
|
+
delete window.NestedRecord;
|
68
70
|
NestedRecord = null;
|
69
71
|
testParent = null;
|
70
72
|
store = null;
|
@@ -8,33 +8,33 @@
|
|
8
8
|
var MyApp, dataSource;
|
9
9
|
module("SC.Record core methods", {
|
10
10
|
setup: function() {
|
11
|
-
dataSource = SC.DataSource.create({
|
12
|
-
|
11
|
+
dataSource = SC.DataSource.create({
|
12
|
+
|
13
13
|
gotParams: NO,
|
14
14
|
wasCommitted: NO,
|
15
|
-
|
15
|
+
|
16
16
|
createRecord: function(store, storeKey, params) {
|
17
17
|
this.wasCommitted = YES;
|
18
18
|
this.gotParams = params && params['param1'] ? YES: NO;
|
19
19
|
}});
|
20
|
-
|
20
|
+
|
21
21
|
MyApp = SC.Object.create({
|
22
22
|
store: SC.Store.create().from(dataSource)
|
23
23
|
}) ;
|
24
|
-
|
24
|
+
|
25
25
|
MyApp.Foo = SC.Record.extend({});
|
26
|
-
MyApp.json = {
|
27
|
-
foo: "bar",
|
26
|
+
MyApp.json = {
|
27
|
+
foo: "bar",
|
28
28
|
number: 123,
|
29
29
|
bool: YES,
|
30
30
|
array: [1,2,3],
|
31
31
|
guid: 1
|
32
32
|
};
|
33
|
-
|
33
|
+
|
34
34
|
SC.RunLoop.begin();
|
35
35
|
MyApp.foo = MyApp.store.createRecord(MyApp.Foo, MyApp.json);
|
36
36
|
SC.RunLoop.end();
|
37
|
-
|
37
|
+
|
38
38
|
}
|
39
39
|
});
|
40
40
|
|
@@ -43,13 +43,20 @@ test("statusString", function() {
|
|
43
43
|
});
|
44
44
|
|
45
45
|
test("Can commitRecord() specific SC.Record instance", function() {
|
46
|
-
|
46
|
+
|
47
47
|
MyApp.foo.set('foo', 'foobar');
|
48
|
-
|
48
|
+
|
49
49
|
// commit the new record
|
50
50
|
MyApp.foo.commitRecord({ param1: 'value1' });
|
51
|
-
|
51
|
+
|
52
52
|
equals(dataSource.wasCommitted, YES, 'Record was committed');
|
53
53
|
equals(dataSource.gotParams, YES, 'Params were properly passed through commitRecord');
|
54
|
-
|
54
|
+
|
55
|
+
});
|
56
|
+
|
57
|
+
test("JSON encoding an SC.Record should encode the attributes", function(){
|
58
|
+
var str = SC.json.encode(MyApp.foo);
|
59
|
+
var result = SC.json.decode(str);
|
60
|
+
|
61
|
+
same(MyApp.json, result, "original = encoded record");
|
55
62
|
});
|
@@ -6,7 +6,7 @@
|
|
6
6
|
/*globals module ok equals same test MyApp */
|
7
7
|
|
8
8
|
// test core array-mapping methods for RecordArray with RecordAttribute
|
9
|
-
var storeKeys, rec, rec2, bar, MyApp;
|
9
|
+
var storeKeys, rec, rec2, rec3, bar, MyApp;
|
10
10
|
|
11
11
|
module("SC.RecordAttribute core methods", {
|
12
12
|
setup: function() {
|
@@ -14,118 +14,125 @@ module("SC.RecordAttribute core methods", {
|
|
14
14
|
MyApp = SC.Object.create({
|
15
15
|
store: SC.Store.create()
|
16
16
|
});
|
17
|
-
|
17
|
+
|
18
18
|
// stick it to the window object so that objectForPropertyPath works
|
19
19
|
window.MyApp = MyApp;
|
20
|
-
|
20
|
+
|
21
21
|
MyApp.Foo = SC.Record.extend({
|
22
|
-
|
22
|
+
|
23
23
|
// test simple reading of a pass-through prop
|
24
24
|
firstName: SC.Record.attr(String),
|
25
25
|
|
26
26
|
// test mapping to another internal key
|
27
27
|
otherName: SC.Record.attr(String, { key: "firstName" }),
|
28
|
-
|
28
|
+
|
29
29
|
// test mapping Date
|
30
30
|
date: SC.Record.attr(Date),
|
31
31
|
nonIsoDate: SC.Record.attr(Date, { useIsoDate: false }),
|
32
|
-
|
32
|
+
|
33
|
+
// test SC.DateTimes
|
34
|
+
dateTime: SC.Record.attr(SC.DateTime),
|
35
|
+
|
33
36
|
// test Array
|
34
37
|
anArray: SC.Record.attr(Array),
|
35
|
-
|
38
|
+
|
36
39
|
// test Object
|
37
40
|
anObject: SC.Record.attr(Object),
|
38
|
-
|
41
|
+
|
39
42
|
// test Number
|
40
43
|
aNumber: SC.Record.attr(Number),
|
41
|
-
|
44
|
+
|
42
45
|
// used to test default value
|
43
46
|
defaultValue: SC.Record.attr(String, {
|
44
47
|
defaultValue: "default"
|
45
48
|
}),
|
46
|
-
|
49
|
+
|
47
50
|
// used to test default value
|
48
51
|
defaultComputedValue: SC.Record.attr(Number, {
|
49
52
|
defaultValue: function() {
|
50
53
|
return Math.floor(Math.random()*3+1);
|
51
54
|
}
|
52
55
|
}),
|
53
|
-
|
56
|
+
|
54
57
|
// test toOne relationships
|
55
58
|
relatedTo: SC.Record.toOne('MyApp.Foo'),
|
56
|
-
|
59
|
+
|
57
60
|
// test toOne relationship with computed type
|
58
61
|
relatedToComputed: SC.Record.toOne(function() {
|
59
|
-
// not using .get() to avoid another transform which will
|
62
|
+
// not using .get() to avoid another transform which will
|
60
63
|
// trigger an infinite loop
|
61
64
|
return (this.readAttribute('relatedToComputed').indexOf("foo")===0) ? MyApp.Foo : MyApp.Bar;
|
62
65
|
}),
|
63
|
-
|
66
|
+
|
64
67
|
// test readONly
|
65
68
|
readOnly: SC.Record.attr(String, { isEditable: NO })
|
66
|
-
|
69
|
+
|
67
70
|
});
|
68
|
-
|
71
|
+
|
69
72
|
MyApp.Bar = SC.Record.extend({
|
70
73
|
parent: SC.Record.toOne('MyApp.Foo', { aggregate: YES }),
|
71
74
|
relatedMany: SC.Record.toMany('MyApp.Foo', { aggregate: YES })
|
72
75
|
});
|
73
|
-
|
76
|
+
|
74
77
|
SC.RunLoop.begin();
|
75
78
|
storeKeys = MyApp.store.loadRecords(MyApp.Foo, [
|
76
|
-
{
|
77
|
-
guid: 'foo1',
|
78
|
-
firstName: "John",
|
79
|
-
lastName: "Doe",
|
79
|
+
{
|
80
|
+
guid: 'foo1',
|
81
|
+
firstName: "John",
|
82
|
+
lastName: "Doe",
|
80
83
|
date: "2009-03-01T20:30-08:00",
|
84
|
+
dateTime: new Date(1235939425000),
|
81
85
|
anArray: ['one', 'two', 'three'],
|
82
86
|
anObject: { 'key1': 'value1', 'key2': 'value2' },
|
83
87
|
aNumber: '123',
|
84
88
|
readOnly: 'foo1'
|
85
89
|
},
|
86
|
-
|
87
|
-
{
|
88
|
-
guid: 'foo2',
|
89
|
-
firstName: "Jane",
|
90
|
-
lastName: "Doe",
|
90
|
+
|
91
|
+
{
|
92
|
+
guid: 'foo2',
|
93
|
+
firstName: "Jane",
|
94
|
+
lastName: "Doe",
|
91
95
|
relatedTo: 'foo1',
|
92
96
|
relatedToAggregate: 'bar1',
|
97
|
+
dateTime: "2009-03-01T20:30:25Z",
|
93
98
|
anArray: 'notAnArray',
|
94
99
|
anObject: 'notAnObject',
|
95
100
|
aNumber: '123',
|
96
101
|
nonIsoDate: "2009/06/10 8:55:50 +0000"
|
97
102
|
},
|
98
|
-
|
99
|
-
{
|
100
|
-
guid: 'foo3',
|
101
|
-
firstName: "Alex",
|
102
|
-
lastName: "Doe",
|
103
|
+
|
104
|
+
{
|
105
|
+
guid: 'foo3',
|
106
|
+
firstName: "Alex",
|
107
|
+
lastName: "Doe",
|
103
108
|
relatedToComputed: 'bar1',
|
109
|
+
dateTime: SC.DateTime.create(1235939425000),
|
104
110
|
anArray: ['one', 'two', 'three'],
|
105
111
|
anObject: { 'key1': 'value1', 'key2': 'value2' },
|
106
112
|
aNumber: '123'
|
107
113
|
}
|
108
|
-
|
114
|
+
|
109
115
|
]);
|
110
|
-
|
116
|
+
|
111
117
|
MyApp.store.loadRecords(MyApp.Bar, [
|
112
118
|
{ guid: 'bar1', city: "Chicago", parent: 'foo2', relatedMany: ['foo1', 'foo2'] }
|
113
119
|
]);
|
114
|
-
|
120
|
+
|
115
121
|
SC.RunLoop.end();
|
116
|
-
|
122
|
+
|
117
123
|
rec = MyApp.store.find(MyApp.Foo, 'foo1');
|
118
124
|
rec2 = MyApp.store.find(MyApp.Foo, 'foo2');
|
119
|
-
|
125
|
+
rec3 = MyApp.store.find(MyApp.Foo, 'foo3');
|
126
|
+
|
120
127
|
bar = MyApp.store.find(MyApp.Bar, 'bar1');
|
121
128
|
equals(rec.storeKey, storeKeys[0], 'should find record');
|
122
|
-
|
129
|
+
|
123
130
|
}
|
124
131
|
});
|
125
132
|
|
126
133
|
// ..........................................................
|
127
134
|
// READING
|
128
|
-
//
|
135
|
+
//
|
129
136
|
|
130
137
|
test("pass-through should return builtin value" ,function() {
|
131
138
|
equals(rec.get('firstName'), 'John', 'reading prop should get attr value');
|
@@ -158,6 +165,13 @@ test("reading date should parse ISO date", function() {
|
|
158
165
|
equals(rec.get('date').toString(), d.toString(), 'should have matched date');
|
159
166
|
});
|
160
167
|
|
168
|
+
test("reading dateTime should parse ISO date", function() {
|
169
|
+
var ms = 1235939425000;
|
170
|
+
equals(rec.getPath('dateTime.milliseconds'), ms, 'should have parsed Date properly');
|
171
|
+
equals(rec2.getPath('dateTime.milliseconds'), ms, 'should have parsed String properly');
|
172
|
+
equals(rec3.getPath('dateTime.milliseconds'), ms, 'should have parsed SC.DateTime properly');
|
173
|
+
});
|
174
|
+
|
161
175
|
test("reading date should parse non-ISO date", function() {
|
162
176
|
var d = new Date(1244624150000);
|
163
177
|
equals(rec2.get('nonIsoDate').toString(), d.toString(), 'should have matched date');
|
@@ -176,7 +190,7 @@ test("reading computed default value", function() {
|
|
176
190
|
|
177
191
|
// ..........................................................
|
178
192
|
// WRITING
|
179
|
-
//
|
193
|
+
//
|
180
194
|
|
181
195
|
test("writing pass-through should simply set value", function() {
|
182
196
|
rec.set("firstName", "Foo");
|
@@ -187,7 +201,7 @@ test("writing pass-through should simply set value", function() {
|
|
187
201
|
|
188
202
|
rec.set("firstName", YES);
|
189
203
|
equals(rec.readAttribute("firstName"), YES, "should write bool");
|
190
|
-
|
204
|
+
|
191
205
|
});
|
192
206
|
|
193
207
|
test("writing when isEditable is NO should ignore", function() {
|
@@ -203,7 +217,7 @@ test("writing a value should override default value", function() {
|
|
203
217
|
});
|
204
218
|
|
205
219
|
test("writing a string to a number attribute should store a number" ,function() {
|
206
|
-
equals(rec.set('aNumber', "456"), rec, 'returns
|
220
|
+
equals(rec.set('aNumber', "456"), rec, 'returns receiver');
|
207
221
|
equals(rec.get('aNumber'), 456, 'should have new value');
|
208
222
|
equals(typeof rec.get('aNumber'), 'number', 'new value should be a number');
|
209
223
|
});
|
@@ -215,27 +229,27 @@ test("writing a date should generate an ISO date" ,function() {
|
|
215
229
|
var utcDate = new Date(Number(date) + (date.getTimezoneOffset() * 60000)); // Adjust for timezone offset
|
216
230
|
utcDate.getTimezoneOffset = function(){ return 0; }; // Hack the offset to respond 0
|
217
231
|
|
218
|
-
equals(rec.set('date', utcDate), rec, 'returns
|
232
|
+
equals(rec.set('date', utcDate), rec, 'returns receiver');
|
219
233
|
equals(rec.readAttribute('date'), '2009-04-02T05:28:03Z', 'should have time in ISO format');
|
220
234
|
});
|
221
235
|
|
222
236
|
test("writing an attribute should make relationship aggregate dirty" ,function() {
|
223
237
|
equals(bar.get('status'), SC.Record.READY_CLEAN, "precond - bar should be READY_CLEAN");
|
224
238
|
equals(rec2.get('status'), SC.Record.READY_CLEAN, "precond - rec2 should be READY_CLEAN");
|
225
|
-
|
239
|
+
|
226
240
|
bar.set('city', 'Oslo');
|
227
241
|
bar.get('store').flush();
|
228
|
-
|
242
|
+
|
229
243
|
equals(rec2.get('status'), SC.Record.READY_DIRTY, "foo2 should be READY_DIRTY");
|
230
244
|
});
|
231
245
|
|
232
246
|
test("writing an attribute should make many relationship aggregate dirty" ,function() {
|
233
247
|
equals(bar.get('status'), SC.Record.READY_CLEAN, "precond - bar should be READY_CLEAN");
|
234
248
|
equals(rec2.get('status'), SC.Record.READY_CLEAN, "precond - rec2 should be READY_CLEAN");
|
235
|
-
|
249
|
+
|
236
250
|
bar.set('city', 'Oslo');
|
237
251
|
bar.get('store').flush();
|
238
|
-
|
252
|
+
|
239
253
|
equals(rec.get('status'), SC.Record.READY_DIRTY, "foo1 should be READY_DIRTY");
|
240
254
|
equals(rec2.get('status'), SC.Record.READY_DIRTY, "foo2 should be READY_DIRTY");
|
241
255
|
});
|
@@ -243,10 +257,25 @@ test("writing an attribute should make many relationship aggregate dirty" ,funct
|
|
243
257
|
test("writing an attribute should make many relationship aggregate dirty and add the aggregate to the store" ,function() {
|
244
258
|
equals(bar.get('status'), SC.Record.READY_CLEAN, "precond - bar should be READY_CLEAN");
|
245
259
|
equals(rec2.get('status'), SC.Record.READY_CLEAN, "precond - rec2 should be READY_CLEAN");
|
246
|
-
|
260
|
+
|
247
261
|
bar.set('city', 'Oslo');
|
248
262
|
|
249
263
|
var store = bar.get('store');
|
250
264
|
ok(store.changelog.contains(rec.get('storeKey')), "foo1 should be in the store's changelog");
|
251
265
|
ok(store.changelog.contains(rec2.get('storeKey')), "foo2 should be in the store's changelog");
|
252
266
|
});
|
267
|
+
|
268
|
+
test("adding attribute with non existing class should throw error", function() {
|
269
|
+
MyApp.InvalidModel = SC.Record.extend({
|
270
|
+
foo: SC.Record.attr("SomethingSomethingSomething")
|
271
|
+
});
|
272
|
+
|
273
|
+
var message;
|
274
|
+
try {
|
275
|
+
MyApp.InvalidModel.prototype.foo.typeClass();
|
276
|
+
} catch (x) {
|
277
|
+
message = x;
|
278
|
+
}
|
279
|
+
|
280
|
+
same(message, 'SomethingSomethingSomething could not be found');
|
281
|
+
});
|