sproutcore 1.5.0.pre.3 → 1.5.0.pre.4
Sign up to get free protection for your applications and to get access to all the features.
- data/.rspec +1 -0
- data/CHANGELOG +42 -0
- data/README.txt +25 -0
- data/VERSION.yml +1 -1
- data/bin/sc-build +1 -1
- data/bin/sc-build-number +1 -1
- data/bin/sc-docs +1 -1
- data/bin/sc-gen +1 -1
- data/bin/sc-init +1 -1
- data/bin/sc-manifest +1 -1
- data/bin/sc-server +1 -1
- data/bin/sproutcore +1 -1
- data/lib/buildtasks/build.rake +5 -0
- data/lib/buildtasks/manifest.rake +20 -1
- data/lib/frameworks/sproutcore/Buildfile +12 -9
- data/lib/frameworks/sproutcore/CHANGELOG.md +48 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/README +2 -9
- data/lib/frameworks/sproutcore/apps/greenhouse/TODO +11 -27
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/library.js +3 -10
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/main-page.css +4 -31
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/dialogs.js +5 -4
- data/lib/frameworks/sproutcore/apps/greenhouse/models/dir.js +3 -3
- data/lib/frameworks/sproutcore/apps/greenhouse/models/file.js +2 -2
- data/lib/frameworks/sproutcore/apps/greenhouse/states/main.js +31 -14
- data/lib/frameworks/sproutcore/apps/greenhouse/states/modals.js +2 -1
- data/lib/frameworks/sproutcore/apps/greenhouse/states/ready.js +27 -1
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/views/list_item.js +1 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/views/plist_item.js +20 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/theme.js +25 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/plist_item.js +161 -24
- data/lib/frameworks/sproutcore/apps/greenhouse/views/tear_off_picker.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/bootstrap/system/browser.js +37 -25
- data/lib/frameworks/sproutcore/frameworks/bootstrap/tests/system/browser.js +135 -26
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/controllers/array.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/controllers/controller.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/controllers/object.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/core.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/ext/object.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/ext/run_loop.js +1 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/delegate_support.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/responder_context.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/selection_support.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/string.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/keyboard.js +68 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/layout.js +108 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/panes/main.js +2 -2
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/manipulation.js +27 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/panes/pane.js +215 -505
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/template.js +24 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/visibility.js +11 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/protocols/observable_protocol.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/protocols/sparse_array_delegate.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/resources/core.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/resources/view.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/application.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/browser.js +1 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/builder.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/core_query.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/cursor.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/device.js +210 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/event.js +5 -5
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/json.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/locale.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/page.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/platform.js +31 -5
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/ready.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/render_context.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/responder.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/root_responder.js +83 -110
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/selection_set.js +7 -4
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/sparse_array.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/theme.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/timer.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/utils/rect.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/system/utils.js +151 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/array_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/enum_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/null_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/selection_support.js +26 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/single_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/empty_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/multiple_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/single_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/single_enumerable_case.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/mixins/responder_context.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/mixins/string.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/panes/template.js +14 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/builder.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/core_query/within.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/json.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/locale.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/begin.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/element.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/end.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/get.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_attr.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_basic.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_className.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_style.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/init.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/join.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/push_text.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/tag.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/update.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/makeKeyPane.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/makeMainPane.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/makeMenuPane.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/root_responder.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/targetForAction.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/add.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/copy.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/indexSetForSource.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/isEqual.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/remove.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/sparse_array.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/theme.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/invalidate.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/invokeLater.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/isPaused.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/performAction.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/schedule.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/utils/normalizeURL.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/utils/offset.js +268 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/utils/rect.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/main_pane.js +43 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/append_remove.js +107 -18
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/pane/child_view.js +20 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/firstResponder.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/keyPane.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/layout.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/sendEvent.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template/checkbox_support.js +32 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template/text_field_support.js +73 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template_view/collection.js +65 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template_view/core.js +67 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template_view/handlebars.js +295 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/animation.js +19 -18
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/build.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/build_children.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/clippingFrame.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/convertFrames.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/convertLayouts.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/createChildViews.js +18 -15
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/createLayer.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/destroyLayer.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/didAppendToDocument.js +11 -8
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/findLayerInParentLayer.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/init.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/insertBefore.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/isVisible.js +28 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/isVisibleInWindow.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/keyboard.js +22 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/layer.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/layoutChildViews.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/layoutDidChange.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/layoutStyle.js +640 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/parentViewDidChange.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/prepareContext.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/removeChild.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/render.js +125 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/render_delegate_support.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/replaceChild.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/static_layout.js +21 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/theme.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/updateLayer.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/updateLayerLocation.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/view.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/viewDidResize.js +0 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template/checkbox_support.js +20 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template/collection.js +99 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template/text_field_support.js +35 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template.js +77 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/animation.js +187 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/base.js +1 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/cursor.js +41 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/enabled.js +57 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/keyboard.js +223 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/layout.js +1150 -0
- data/lib/frameworks/sproutcore/frameworks/{amber/views → core_foundation/views/view}/layout_style.js +93 -1
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/manipulation.js +489 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/theming.js +362 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/touch.js +67 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/visibility.js +113 -0
- data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view.js +1280 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/child_attribute.js +27 -53
- data/lib/frameworks/sproutcore/frameworks/datastore/models/children_attribute.js +13 -19
- data/lib/frameworks/sproutcore/frameworks/datastore/models/many_attribute.js +1 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/record.js +183 -71
- data/lib/frameworks/sproutcore/frameworks/datastore/models/record_attribute.js +1 -2
- data/lib/frameworks/sproutcore/frameworks/datastore/system/child_array.js +26 -46
- data/lib/frameworks/sproutcore/frameworks/datastore/system/nested_store.js +25 -4
- data/lib/frameworks/sproutcore/frameworks/datastore/system/store.js +139 -21
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/data_sources/fixtures.js +6 -1
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/integration/cyclical_relationship.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/{parentless.js → data_store.js} +62 -16
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record.js +51 -17
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array.js +36 -10
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array_complex.js +11 -11
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_complex.js +8 -8
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/normalize.js +2 -2
- data/lib/frameworks/sproutcore/frameworks/{foundation/english.lproj → datetime/resources}/strings.js +1 -0
- data/lib/frameworks/sproutcore/frameworks/{foundation → datetime}/system/datetime.js +5 -37
- data/lib/frameworks/sproutcore/frameworks/{foundation → datetime}/tests/system/datetime.js +1 -0
- data/lib/frameworks/sproutcore/frameworks/debug/core.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/designer/controllers/designs.js +1 -2
- data/lib/frameworks/sproutcore/frameworks/designer/designers/object_designer.js +3 -3
- data/lib/frameworks/sproutcore/frameworks/designer/designers/view_designer.js +3 -3
- data/lib/frameworks/sproutcore/frameworks/designer/views/designer_drop_target.js +9 -3
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/segmented.css +71 -70
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_row_delegate.js +10 -2
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/segment.js +4 -19
- data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/segmented.js +33 -14
- data/lib/frameworks/sproutcore/frameworks/desktop/system/drag.js +25 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/date_field/ui.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/methods.js +25 -103
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/ui.js +102 -92
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/tab/ui.js +22 -25
- data/lib/frameworks/sproutcore/frameworks/desktop/views/collection.js +38 -25
- data/lib/frameworks/sproutcore/frameworks/desktop/views/date_field.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/views/scroll.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/desktop/views/segment.js +42 -22
- data/lib/frameworks/sproutcore/frameworks/desktop/views/segmented.js +513 -230
- data/lib/frameworks/sproutcore/frameworks/desktop/views/select_field.js +0 -2
- data/lib/frameworks/sproutcore/frameworks/experimental/README.md +23 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/device_motion/README.md +11 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/device_motion/device.js +215 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/device_motion/platform.js +67 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/README.md +34 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/models/polymorphic_single_attribute.js +183 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/models/record.js +23 -0
- data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/tests/models/polymorphic/single.js +124 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/auto_resize.js +0 -2
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/inner_frame.js +151 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/canvas_image.js +27 -17
- data/lib/frameworks/sproutcore/frameworks/foundation/system/image_queue.js +6 -3
- data/lib/frameworks/sproutcore/frameworks/foundation/system/logger.js +163 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/user_defaults.js +6 -3
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/inline_text_field/beginEditing.js +1 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/logger.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/image/ui.js +200 -167
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/ui.js +1 -1
- data/lib/frameworks/sproutcore/frameworks/foundation/views/image.js +52 -137
- data/lib/frameworks/sproutcore/frameworks/foundation/views/text_field.js +7 -11
- data/lib/frameworks/sproutcore/frameworks/handlebars/extensions.js +138 -0
- data/lib/frameworks/sproutcore/frameworks/handlebars/handlebars.js +1338 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/core.js +32 -26
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/base.js +162 -3
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/array.js +10 -5
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/enumerable.js +123 -3
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/observable.js +12 -5
- data/lib/frameworks/sproutcore/frameworks/runtime/private/chain_observer.js +50 -13
- data/lib/frameworks/sproutcore/frameworks/runtime/system/logger.js +163 -333
- data/lib/frameworks/sproutcore/frameworks/runtime/system/object.js +58 -8
- data/lib/frameworks/sproutcore/frameworks/runtime/system/run_loop.js +2 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/itemType.js +9 -6
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/makeArray.js +15 -1
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/array.js +2 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/chained.js +31 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/observable.js +18 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/logger.js +31 -143
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/object/concatenated_properties.js +71 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/object/enhance.js +177 -0
- data/lib/frameworks/sproutcore/frameworks/table/views/table.js +5 -4
- data/lib/frameworks/sproutcore/frameworks/table/views/table_header.js +5 -3
- data/lib/frameworks/sproutcore/themes/ace/resources/button/button.js +8 -2
- data/lib/frameworks/sproutcore/themes/ace/resources/menu/menu.css +2 -3
- data/lib/frameworks/sproutcore/themes/ace/resources/segmented/18px/segmented.css +1 -1
- data/lib/frameworks/sproutcore/themes/ace/resources/segmented/24px/segmented.css +1 -1
- data/lib/frameworks/sproutcore/themes/ace/resources/segmented/30px/segmented.css +1 -1
- data/lib/frameworks/sproutcore/themes/ace/resources/segmented/44px/segmented.css +1 -1
- data/lib/frameworks/sproutcore/themes/ace/resources/segmented/segmented.css +2 -2
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/segmented.css +62 -62
- data/lib/gen/html_app/Buildfile +36 -0
- data/lib/gen/html_app/README +1 -0
- data/lib/gen/html_app/USAGE +15 -0
- data/lib/gen/html_app/templates/apps/@target_name@/@target_name@.js +14 -0
- data/lib/gen/html_app/templates/apps/@target_name@/resources/images/.gitkeep +0 -0
- data/lib/gen/html_app/templates/apps/@target_name@/resources/stylesheets/@target_name@.css +0 -0
- data/lib/gen/html_app/templates/apps/@target_name@/resources/templates/@target_name@.handlebars +1 -0
- data/lib/gen/html_project/Buildfile +45 -0
- data/lib/gen/html_project/INIT +3 -0
- data/lib/gen/html_project/README +1 -0
- data/lib/gen/html_project/USAGE +2 -0
- data/lib/gen/html_project/templates/@filename@/Buildfile +8 -0
- data/lib/gen/html_project/templates/@filename@/README +7 -0
- data/lib/sproutcore/builders/handlebars.rb +30 -0
- data/lib/sproutcore/builders.rb +1 -1
- data/lib/sproutcore/helpers/static_helper.rb +3 -3
- data/lib/sproutcore/tools/init.rb +25 -9
- data/spec/buildtasks/manifest/prepare_build_tasks/handlebars_spec.rb +39 -0
- data/spec/fixtures/builder_tests/apps/handlebars_test/template.handlebars +5 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/templates/demo.handlebars +4 -0
- data/spec/lib/builders/handlebars_spec.rb +29 -0
- data/vendor/chance/lib/chance/imagers/data_url.rb +20 -7
- data/vendor/chance/lib/chance/instance.rb +4 -1
- data/vendor/chance/lib/chance/parser.rb +31 -31
- data/vendor/chance/lib/chance/slicing.rb +38 -8
- metadata +195 -225
- data/lib/frameworks/sproutcore/frameworks/amber/system/device.js +0 -143
- data/lib/frameworks/sproutcore/frameworks/amber/system/utils.js +0 -174
- data/lib/frameworks/sproutcore/frameworks/amber/tests/views/main_pane.js +0 -31
- data/lib/frameworks/sproutcore/frameworks/amber/tests/views/pane/sendTouchEvent.js +0 -267
- data/lib/frameworks/sproutcore/frameworks/amber/tests/views/view/layoutDidChange.js +0 -149
- data/lib/frameworks/sproutcore/frameworks/amber/tests/views/view/layoutStyle.js +0 -602
- data/lib/frameworks/sproutcore/frameworks/amber/tests/views/view/render.js +0 -115
- data/lib/frameworks/sproutcore/frameworks/amber/views/base.js +0 -1
- data/lib/frameworks/sproutcore/frameworks/amber/views/view.js +0 -4003
- data/lib/frameworks/sproutcore/frameworks/datastore/models/child_record.js +0 -105
@@ -3,59 +3,60 @@
|
|
3
3
|
white-space: nowrap;
|
4
4
|
}
|
5
5
|
|
6
|
-
.sc-segment:active, .sc-segment:focus {
|
7
|
-
|
6
|
+
.sc-segment-view:active, .sc-segment-view:focus {
|
7
|
+
outline: none;
|
8
8
|
}
|
9
9
|
|
10
|
-
.sc-segment img.icon {
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
10
|
+
.sc-segment-view img.icon {
|
11
|
+
position: relative;
|
12
|
+
vertical-align: middle;
|
13
|
+
top: -2px;
|
14
|
+
margin-right: 2px;
|
15
|
+
height: 16px;
|
16
|
+
width: 16px;
|
17
17
|
}
|
18
18
|
|
19
19
|
/* @group Layout */
|
20
20
|
|
21
|
-
.sc-segmented-view .sc-segment {
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
21
|
+
.sc-segmented-view .sc-segment-view {
|
22
|
+
position: relative;
|
23
|
+
display: inline-block;
|
24
|
+
top: 0;
|
25
|
+
height: 22px;
|
26
|
+
line-height: 22px;
|
27
|
+
border-right: 1px #555 solid;
|
28
|
+
text-shadow: #b0b0b0 0px 1px 0px;
|
29
|
+
text-decoration: none ;
|
30
|
+
color: black ;
|
31
|
+
text-align: center;
|
31
32
|
}
|
32
33
|
|
33
34
|
.sc-segmented-view .sc-button-inner {
|
34
|
-
|
35
|
-
|
36
|
-
|
35
|
+
display: block;
|
36
|
+
min-width: 20px;
|
37
|
+
min-height: 22px;
|
37
38
|
}
|
38
39
|
|
39
|
-
.sc-segmented-view .sc-segment.sc-first-segment {
|
40
|
-
|
40
|
+
.sc-segmented-view .sc-segment-view.sc-first-segment {
|
41
|
+
padding-left: 10px;
|
41
42
|
}
|
42
43
|
|
43
44
|
|
44
|
-
.sc-segmented-view .sc-segment.sc-first-segment .sc-button-inner {
|
45
|
-
|
45
|
+
.sc-segmented-view .sc-segment-view.sc-first-segment .sc-button-inner {
|
46
|
+
padding-right: 10px;
|
46
47
|
}
|
47
|
-
.sc-segmented-view .sc-segment.sc-middle-segment .sc-button-inner {
|
48
|
-
|
49
|
-
|
50
|
-
|
48
|
+
.sc-segmented-view .sc-segment-view.sc-middle-segment .sc-button-inner {
|
49
|
+
padding-left: 10px;
|
50
|
+
padding-right: 10px;
|
51
|
+
|
51
52
|
}
|
52
|
-
.sc-segmented-view .sc-segment.sc-last-segment .sc-button-inner {
|
53
|
-
|
53
|
+
.sc-segmented-view .sc-segment-view.sc-last-segment .sc-button-inner {
|
54
|
+
padding-left: 10px;
|
54
55
|
}
|
55
56
|
|
56
|
-
.sc-segmented-view .sc-segment.sc-last-segment {
|
57
|
-
|
58
|
-
|
57
|
+
.sc-segmented-view .sc-segment-view.sc-last-segment {
|
58
|
+
padding-right: 10px;
|
59
|
+
border:none;
|
59
60
|
}
|
60
61
|
|
61
62
|
/* @end */
|
@@ -64,67 +65,67 @@
|
|
64
65
|
|
65
66
|
/* NORMAL */
|
66
67
|
|
67
|
-
.sc-segmented-view .sc-segment .sc-button-inner {
|
68
|
-
|
68
|
+
.sc-segmented-view .sc-segment-view .sc-button-inner {
|
69
|
+
background: #DDDDDD;
|
69
70
|
}
|
70
71
|
|
71
|
-
.sc-segmented-view .sc-segment.sc-last-segment {
|
72
|
-
|
72
|
+
.sc-segmented-view .sc-segment-view.sc-last-segment {
|
73
|
+
background: #DDDDDD;
|
73
74
|
}
|
74
75
|
|
75
|
-
.sc-segmented-view .sc-segment.sc-first-segment {
|
76
|
-
|
76
|
+
.sc-segmented-view .sc-segment-view.sc-first-segment {
|
77
|
+
background: #DDDDDD;
|
77
78
|
}
|
78
79
|
|
79
80
|
|
80
81
|
/* SELECTED */
|
81
|
-
.sc-segmented-view .sc-segment.active .sc-button-inner,
|
82
|
-
.sc-segmented-view .sc-segment.sel .sc-button-inner {
|
83
|
-
|
84
|
-
|
82
|
+
.sc-segmented-view .sc-segment-view.active .sc-button-inner,
|
83
|
+
.sc-segmented-view .sc-segment-view.sel .sc-button-inner {
|
84
|
+
background: #999999;
|
85
|
+
text-shadow: #909090 0px 1px 0px;
|
85
86
|
}
|
86
87
|
|
87
|
-
.sc-segmented-view .sc-segment.sc-last-segment.sel,
|
88
|
-
.sc-segmented-view .sc-segment.sc-last-segment.active {
|
89
|
-
|
88
|
+
.sc-segmented-view .sc-segment-view.sc-last-segment.sel,
|
89
|
+
.sc-segmented-view .sc-segment-view.sc-last-segment.active {
|
90
|
+
background: #999999;
|
90
91
|
}
|
91
92
|
|
92
|
-
.sc-segmented-view .sc-segment.sc-first-segment.sel,
|
93
|
-
.sc-segmented-view .sc-segment.sc-first-segment.active {
|
94
|
-
|
93
|
+
.sc-segmented-view .sc-segment-view.sc-first-segment.sel,
|
94
|
+
.sc-segmented-view .sc-segment-view.sc-first-segment.active {
|
95
|
+
background: #999999;
|
95
96
|
}
|
96
97
|
|
97
98
|
/* DISABLED */
|
98
99
|
|
99
|
-
.sc-segmented-view .sc-segment.disabled .sc-button-inner,
|
100
|
-
.sc-segmented-view.disabled .sc-segment .sc-button-inner {
|
101
|
-
|
102
|
-
|
100
|
+
.sc-segmented-view .sc-segment-view.disabled .sc-button-inner,
|
101
|
+
.sc-segmented-view.disabled .sc-segment-view .sc-button-inner {
|
102
|
+
background: #FFFFFF;
|
103
|
+
color: #999;
|
103
104
|
}
|
104
105
|
|
105
|
-
.sc-segmented-view .sc-segment.sc-last-segment.disabled,
|
106
|
-
.sc-segmented-view.disabled .sc-segment.sc-last-segment {
|
107
|
-
|
106
|
+
.sc-segmented-view .sc-segment-view.sc-last-segment.disabled,
|
107
|
+
.sc-segmented-view.disabled .sc-segment-view.sc-last-segment {
|
108
|
+
background: #FFFFFF;
|
108
109
|
}
|
109
110
|
|
110
|
-
.sc-segmented-view .sc-segment.sc-first-segment.disabled,
|
111
|
-
.sc-segmented-view.disabled .sc-segment.sc-first-segment {
|
112
|
-
|
111
|
+
.sc-segmented-view .sc-segment-view.sc-first-segment.disabled,
|
112
|
+
.sc-segmented-view.disabled .sc-segment-view.sc-first-segment {
|
113
|
+
background: #FFFFFF;
|
113
114
|
}
|
114
115
|
|
115
|
-
.sc-segmented-view .sc-segment.sel .sc-button-inner.disabled,
|
116
|
-
.sc-segmented-view.disabled .sc-segment.sel .sc-button-inner {
|
117
|
-
|
116
|
+
.sc-segmented-view .sc-segment-view.sel .sc-button-inner.disabled,
|
117
|
+
.sc-segmented-view.disabled .sc-segment-view.sel .sc-button-inner {
|
118
|
+
background: #FFFFFF;
|
118
119
|
}
|
119
120
|
|
120
|
-
.sc-segmented-view .sc-segment.sc-last-segment.sel.disabled,
|
121
|
-
.sc-segmented-view.disabled .sc-segment.sc-last-segment.sel {
|
122
|
-
|
121
|
+
.sc-segmented-view .sc-segment-view.sc-last-segment.sel.disabled,
|
122
|
+
.sc-segmented-view.disabled .sc-segment-view.sc-last-segment.sel {
|
123
|
+
background: #FFFFFF;
|
123
124
|
}
|
124
125
|
|
125
|
-
.sc-segmented-view .sc-segment.sc-first-segment.sel.disabled,
|
126
|
-
.sc-segmented-view.disabled .sc-segment.sc-first-segment.sel {
|
127
|
-
|
126
|
+
.sc-segmented-view .sc-segment-view.sc-first-segment.sel.disabled,
|
127
|
+
.sc-segmented-view.disabled .sc-segment-view.sc-first-segment.sel {
|
128
|
+
background: #FFFFFF;
|
128
129
|
}
|
129
130
|
/* @end */
|
130
131
|
|
@@ -55,8 +55,16 @@ SC.CollectionRowDelegate = {
|
|
55
55
|
@property
|
56
56
|
@type Number
|
57
57
|
*/
|
58
|
-
rowHeight: function() {
|
59
|
-
|
58
|
+
rowHeight: function(key, value) {
|
59
|
+
var rowPadding = this.get('rowPadding');
|
60
|
+
var itemHeight = this.get('itemHeight');
|
61
|
+
|
62
|
+
if (value !== undefined) {
|
63
|
+
this.set('itemHeight', value-rowPadding*2);
|
64
|
+
return value;
|
65
|
+
}
|
66
|
+
|
67
|
+
return itemHeight + rowPadding * 2;
|
60
68
|
}.property('itemHeight', 'rowPadding'),
|
61
69
|
|
62
70
|
/**
|
@@ -10,8 +10,7 @@
|
|
10
10
|
SC.SegmentedView.
|
11
11
|
*/
|
12
12
|
SC.BaseTheme.segmentRenderDelegate = SC.Object.create({
|
13
|
-
|
14
|
-
|
13
|
+
|
15
14
|
render: function(dataSource, context) {
|
16
15
|
var theme = dataSource.get('theme'),
|
17
16
|
buttonDelegate,
|
@@ -19,13 +18,12 @@ SC.BaseTheme.segmentRenderDelegate = SC.Object.create({
|
|
19
18
|
|
20
19
|
// Segment specific additions
|
21
20
|
classes = {
|
22
|
-
'sc-segment': YES,
|
23
21
|
'sc-first-segment': dataSource.get('isFirstSegment'),
|
24
22
|
'sc-middle-segment': dataSource.get('isMiddleSegment'),
|
25
23
|
'sc-last-segment': dataSource.get('isLastSegment'),
|
26
24
|
'sc-overflow-segment': dataSource.get('isOverflowSegment')
|
27
25
|
};
|
28
|
-
classes['sc-segment-' + dataSource.get('index')] = YES;
|
26
|
+
if (!SC.none(dataSource.get('index'))) classes['sc-segment-' + dataSource.get('index')] = YES;
|
29
27
|
context.setClass(classes);
|
30
28
|
|
31
29
|
// Use the SC.ButtonView render delegate for the current theme to render the segment as a button
|
@@ -40,28 +38,15 @@ SC.BaseTheme.segmentRenderDelegate = SC.Object.create({
|
|
40
38
|
classes = {};
|
41
39
|
|
42
40
|
// Segment specific additions
|
43
|
-
// 1. This should be the proper way to do it, only update the classes if necessary, but SC.View will reset all the classes that we added in render!
|
44
|
-
// if (displayProperties.contains('index', 'isFirstSegment', 'isMiddleSegment', 'isLastSegment', 'isOverflowSegment')) {
|
45
|
-
//
|
46
|
-
// if (displayProperties.index) classes['sc-segment-' + displayProperties.index] = YES;
|
47
|
-
// if (displayProperties.isFirstSegment) classes['sc-first-segment'] = displayProperties.isFirstSegment;
|
48
|
-
// if (displayProperties.isMiddleSegment) classes['sc-middle-segment'] = displayProperties.isMiddleSegment;
|
49
|
-
// if (displayProperties.isLastSegment) classes['sc-last-segment'] = displayProperties.isLastSegment;
|
50
|
-
// if (displayProperties.isOverflowSegment) classes['sc-overflow-segment'] = displayProperties.isOverflowSegment;
|
51
|
-
//
|
52
|
-
// jquery.setClass(classes);
|
53
|
-
// }
|
54
|
-
// 2. So just re-assign them (even if unchanged)
|
55
41
|
classes = {
|
56
|
-
'sc-segment': YES,
|
57
42
|
'sc-first-segment': dataSource.get('isFirstSegment'),
|
58
43
|
'sc-middle-segment': dataSource.get('isMiddleSegment'),
|
59
44
|
'sc-last-segment': dataSource.get('isLastSegment'),
|
60
45
|
'sc-overflow-segment': dataSource.get('isOverflowSegment') || NO
|
61
46
|
};
|
62
|
-
classes['sc-segment-' + dataSource.get('index')] = YES;
|
47
|
+
if (!SC.none(dataSource.get('index'))) classes['sc-segment-' + dataSource.get('index')] = YES;
|
63
48
|
jquery.setClass(classes);
|
64
|
-
|
49
|
+
|
65
50
|
// Use the SC.ButtonView render delegate for the current theme to update the segment as a button
|
66
51
|
buttonDelegate = theme['buttonRenderDelegate'];
|
67
52
|
buttonDelegate.update(dataSource, jquery);
|
@@ -9,49 +9,68 @@
|
|
9
9
|
Renders and updates the HTML representation of SC.SegmentedView.
|
10
10
|
*/
|
11
11
|
SC.BaseTheme.segmentedRenderDelegate = SC.Object.create({
|
12
|
-
|
13
|
-
|
12
|
+
|
14
13
|
/*
|
15
14
|
We render everything external to the segments and let each segment use it's own render
|
16
15
|
delegate to render its contents.
|
17
|
-
|
16
|
+
|
18
17
|
*/
|
19
|
-
render: function(dataSource, context) {
|
18
|
+
render: function(dataSource, context) {
|
20
19
|
// Use text-align to align the segments
|
21
20
|
context.addStyle('text-align', dataSource.get('align'));
|
22
21
|
},
|
23
|
-
|
22
|
+
|
24
23
|
update: function(dataSource, jquery) {
|
25
24
|
jquery.css('text-align', dataSource.get('align'));
|
26
25
|
},
|
27
|
-
|
26
|
+
|
28
27
|
/**
|
29
|
-
Return the DOM elements of the segments. This will be measured by the view to
|
28
|
+
Return the widths of the DOM elements of the segments. This will be measured by the view to
|
30
29
|
determine which segments should be overflowed.
|
30
|
+
|
31
|
+
It ignores the last segment (the overflow segment).
|
31
32
|
*/
|
32
|
-
|
33
|
-
|
33
|
+
segmentWidths: function(dataSource) {
|
34
|
+
var elements = dataSource.$('.sc-segment-view'),
|
35
|
+
el,
|
36
|
+
widths = [];
|
37
|
+
|
38
|
+
for (var i = 0, length = elements.length; i < length - 1; i++) {
|
39
|
+
el = elements[i];
|
40
|
+
widths[i] = el.getBoundingClientRect().width;
|
41
|
+
}
|
42
|
+
|
43
|
+
return widths;
|
44
|
+
},
|
45
|
+
|
46
|
+
overflowSegmentWidth: function(dataSource) {
|
47
|
+
var elements = dataSource.$('.sc-segment-view'),
|
48
|
+
el;
|
49
|
+
|
50
|
+
el = elements[elements.length - 1];
|
51
|
+
|
52
|
+
return el.getBoundingClientRect().width;
|
34
53
|
},
|
35
54
|
|
36
55
|
indexForClientPosition: function(dataSource, x, y) {
|
37
|
-
var segmentLayers = dataSource.$('.sc-segment'),
|
56
|
+
var segmentLayers = dataSource.$('.sc-segment-view'),
|
38
57
|
length, i,
|
39
58
|
segmentLayer, rect,
|
40
59
|
point;
|
41
|
-
|
60
|
+
|
42
61
|
point = {x: x, y: y};
|
43
62
|
for (i = 0, length = segmentLayers.length; i < length; i++) {
|
44
63
|
segmentLayer = segmentLayers[i];
|
45
64
|
rect = segmentLayer.getBoundingClientRect();
|
46
|
-
|
65
|
+
|
47
66
|
// Convert client rect into standard rect
|
48
67
|
rect.x = rect.left;
|
49
68
|
rect.y = rect.top;
|
50
|
-
|
69
|
+
|
51
70
|
// Return the index early if found
|
52
71
|
if (SC.pointInRect(point, rect)) return i;
|
53
72
|
}
|
54
|
-
|
73
|
+
|
55
74
|
// Default not found
|
56
75
|
return -1;
|
57
76
|
}
|
@@ -8,6 +8,31 @@ SC.DRAG_LINK = 0x0004; SC.DRAG_COPY = 0x0001; SC.DRAG_MOVE = 0x0002;
|
|
8
8
|
SC.DRAG_NONE = 0x0000; SC.DRAG_ANY = 0x000F; SC.DRAG_DATA = 0x0008; // includes SC.DRAG_REORDER
|
9
9
|
SC.DRAG_AUTOSCROLL_ZONE_THICKNESS = 20;
|
10
10
|
|
11
|
+
// Add draggable and scrollable support to SC.View
|
12
|
+
SC.View.reopen(
|
13
|
+
/** @scope SC.View.prototype */ {
|
14
|
+
|
15
|
+
init: function(original) {
|
16
|
+
original();
|
17
|
+
|
18
|
+
// register for drags
|
19
|
+
if (this.get('isDropTarget')) { SC.Drag.addDropTarget(this) ; }
|
20
|
+
|
21
|
+
// register scroll views for autoscroll during drags
|
22
|
+
if (this.get('isScrollable')) { SC.Drag.addScrollableView(this) ; }
|
23
|
+
}.enhance(),
|
24
|
+
|
25
|
+
destroy: function(original) {
|
26
|
+
// unregister for drags
|
27
|
+
if (this.get('isDropTarget')) { SC.Drag.removeDropTarget(this) ; }
|
28
|
+
|
29
|
+
// unregister for autoscroll during drags
|
30
|
+
if (this.get('isScrollable')) { SC.Drag.removeScrollableView(this) ; }
|
31
|
+
|
32
|
+
return original();
|
33
|
+
}.enhance()
|
34
|
+
});
|
35
|
+
|
11
36
|
/**
|
12
37
|
@class
|
13
38
|
|
@@ -70,7 +70,7 @@ pane.verifyEmpty = function verifyEmpty(view, expectedHint) {
|
|
70
70
|
var layer = view.$();
|
71
71
|
|
72
72
|
ok(!layer.hasClass('not-empty'), 'layer should not have not-empty class');
|
73
|
-
if(SC.browser.
|
73
|
+
if(SC.browser.webkit) equals(input.val(), '', 'input should have empty value');
|
74
74
|
else equals(input.val(), expectedHint, 'input should have empty value');
|
75
75
|
|
76
76
|
if (expectedHint) {
|
@@ -8,7 +8,8 @@
|
|
8
8
|
/*global module test htmlbody ok equals same stop start */
|
9
9
|
|
10
10
|
var iconURL= "http://www.freeiconsweb.com/Icons/16x16_people_icons/People_046.gif";
|
11
|
-
var pane, view
|
11
|
+
var pane, view;
|
12
|
+
|
12
13
|
module("SC.SegmentedView", {
|
13
14
|
setup: function() {
|
14
15
|
SC.RunLoop.begin();
|
@@ -22,118 +23,39 @@ module("SC.SegmentedView", {
|
|
22
23
|
itemTitleKey: 'value',
|
23
24
|
itemValueKey: 'value',
|
24
25
|
itemIconKey: 'icon',
|
26
|
+
itemActionKey: 'action',
|
25
27
|
value: "Item1 Item3".w(),
|
26
28
|
allowsEmptySelection: NO,
|
27
|
-
layout: { height: 25 }
|
29
|
+
layout: { height: 25, width: 400 }
|
28
30
|
})]
|
29
31
|
});
|
30
32
|
pane.append(); // make sure there is a layer...
|
31
33
|
SC.RunLoop.end();
|
32
|
-
|
34
|
+
|
33
35
|
view = pane.childViews[0];
|
34
|
-
|
35
|
-
|
36
|
-
var r;
|
37
|
-
if (segment.getBoundingClientRect) {
|
38
|
-
r = segment.getBoundingClientRect();
|
39
|
-
}else{
|
40
|
-
r = {};
|
41
|
-
var ret = SC.viewportOffset(segment); // get x & y
|
42
|
-
var cq = SC.$(segment);
|
43
|
-
r.top = ret.y;
|
44
|
-
r.left = ret.x;
|
45
|
-
r.bottom = ret.y + cq.outerHeight();
|
46
|
-
r.right = ret.x + cq.outerWidth();
|
47
|
-
}
|
48
|
-
|
49
|
-
return r;
|
50
|
-
};
|
51
|
-
|
52
|
-
|
53
|
-
elem = view.get('layer').childNodes[0];
|
54
|
-
rect1 = boundingRect(elem);
|
55
|
-
elem = view.get('layer').childNodes[1];
|
56
|
-
rect2 = boundingRect(elem);
|
57
|
-
elem = view.get('layer').childNodes[2];
|
58
|
-
rect3 = boundingRect(elem);
|
59
|
-
|
60
|
-
|
61
|
-
},
|
62
|
-
|
36
|
+
},
|
37
|
+
|
63
38
|
teardown: function() {
|
64
39
|
pane.remove();
|
65
|
-
pane = view =
|
40
|
+
pane = view = null ;
|
66
41
|
}
|
67
42
|
});
|
68
43
|
|
69
44
|
test("Check that properties are mapped correctly", function() {
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
equals(view.get('activeIndex'), 0, '');
|
88
|
-
|
89
|
-
});
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
test("Check that mouse actions work", function() {
|
94
|
-
view.triggerItemAtIndex(1);
|
95
|
-
SC.RunLoop.begin();
|
96
|
-
view.set('isEnabled', YES);
|
97
|
-
SC.RunLoop.end();
|
98
|
-
|
99
|
-
// Test Mouse Down
|
100
|
-
// it now gets the item by the position, so we have to pass a position
|
101
|
-
var firstItemEvent = SC.Event.simulateEvent(elem, 'mousedown', { clientX: rect1.left + 1, clientY: rect1.top + 1 });
|
102
|
-
view.mouseDown(firstItemEvent);
|
103
|
-
|
104
|
-
equals(view._isMouseDown, YES, 'Mouse down flag on mousedown should be ');
|
105
|
-
equals(view.get('activeIndex'), 0, 'The active item is the first segment.');
|
106
|
-
|
107
|
-
// Test Mouse Up
|
108
|
-
elem = view.get('layer').childNodes[1];
|
109
|
-
|
110
|
-
view.mouseUp(firstItemEvent);
|
111
|
-
equals(view._isMouseDown, NO, 'Mouse down flag on mouseup should be ');
|
112
|
-
equals(view.get('activeIndex'), -1, 'There shouldnt be any active item');
|
113
|
-
|
114
|
-
// Test third item
|
115
|
-
elem = view.get('layer').childNodes[2];
|
116
|
-
var thirdItemEvent = SC.Event.simulateEvent(elem, 'mousedown', { clientX: rect3.left + 1, client: rect3.top + 1 });
|
117
|
-
|
118
|
-
// mouse down and move
|
119
|
-
view.mouseDown(thirdItemEvent);
|
120
|
-
view.mouseMoved(thirdItemEvent);
|
121
|
-
equals(view._isMouseDown, YES, 'Mouse down flag on mousemoved should be ');
|
122
|
-
equals(view.get('activeIndex'), 2, 'The active item is the third segment.');
|
123
|
-
|
124
|
-
// try moving mouse while mouse down
|
125
|
-
var secondItemEvent = SC.Event.simulateEvent(elem, 'mousedown', { clientX: rect2.left + 1, clientY: rect2.top + 1 });
|
126
|
-
view.mouseMoved(secondItemEvent);
|
127
|
-
equals(view._isMouseDown, YES, 'Mouse down flag on mousemoved should be ');
|
128
|
-
equals(view.get('activeIndex'), 1, 'The active item should have changed to the second segment.');
|
129
|
-
|
130
|
-
// and check that mouse out cancels.
|
131
|
-
var noItemEvent = SC.Event.simulateEvent(elem, 'mousedown', { clientX: rect1.left - 5, clientY: rect1.top - 5 });
|
132
|
-
|
133
|
-
view.mouseExited(noItemEvent);
|
134
|
-
equals(view._isMouseDown, YES, 'Mouse down flag on mouseout should still be ');
|
135
|
-
equals(view.get('activeIndex'), -1, 'The active item is no longer specified.');
|
136
|
-
|
137
|
-
});
|
138
|
-
|
139
|
-
|
45
|
+
view.triggerItemAtIndex(1);
|
46
|
+
|
47
|
+
SC.RunLoop.begin();
|
48
|
+
view.set('isEnabled', YES);
|
49
|
+
SC.RunLoop.end();
|
50
|
+
|
51
|
+
equals(view.get('value'), "Item2", "the second item should be selected.");
|
52
|
+
|
53
|
+
var childViews = view.get('childViews');
|
54
|
+
equals(childViews[0].title, "Item1", 'Computed properties should match');
|
55
|
+
equals(childViews[0].value, "Item1", 'Computed properties should match');
|
56
|
+
equals(childViews[0].isEnabled, true, 'Computed properties should match');
|
57
|
+
equals(childViews[0].icon, iconURL, 'Computed properties should match');
|
58
|
+
equals(childViews[0].width, null, 'Computed properties should match');
|
59
|
+
equals(childViews[0].toolTip, null, 'Computed properties should match');
|
60
|
+
equals(childViews[0].index, 0, 'Computed properties should match');
|
61
|
+
});
|