sproutcore 1.4.0-java
Sign up to get free protection for your applications and to get access to all the features.
- data/DISTRIBUTION.yml +20 -0
- data/Gemfile +3 -0
- data/History.txt +54 -0
- data/README.txt +104 -0
- data/Rakefile +446 -0
- data/Todo.txt +1 -0
- data/VERSION.yml +7 -0
- data/bin/sc-build +18 -0
- data/bin/sc-build-number +18 -0
- data/bin/sc-docs +19 -0
- data/bin/sc-gen +18 -0
- data/bin/sc-init +18 -0
- data/bin/sc-manifest +18 -0
- data/bin/sc-server +18 -0
- data/bin/sproutcore +18 -0
- data/design/Technical Notes.graffle/QuickLook/Preview.pdf +0 -0
- data/design/Technical Notes.graffle/QuickLook/Thumbnail.tiff +0 -0
- data/design/Technical Notes.graffle/data.plist +5534 -0
- data/design/Technical Notes.graffle/image8.png +0 -0
- data/lib/Buildfile +140 -0
- data/lib/buildtasks/build.rake +103 -0
- data/lib/buildtasks/entry.rake +68 -0
- data/lib/buildtasks/manifest.rake +615 -0
- data/lib/buildtasks/render.rake +21 -0
- data/lib/buildtasks/target.rake +65 -0
- data/lib/doc_templates/jsdoc/allclasses.tmpl +17 -0
- data/lib/doc_templates/jsdoc/allfiles.tmpl +56 -0
- data/lib/doc_templates/jsdoc/class.tmpl +487 -0
- data/lib/doc_templates/jsdoc/index.tmpl +38 -0
- data/lib/doc_templates/jsdoc/publish.js +170 -0
- data/lib/doc_templates/jsdoc/static/default.css +162 -0
- data/lib/doc_templates/jsdoc/static/header.html +2 -0
- data/lib/doc_templates/jsdoc/static/index.html +19 -0
- data/lib/doc_templates/jsdoc/symbol.tmpl +35 -0
- data/lib/doc_templates/sproutcore/allclasses.tmpl +0 -0
- data/lib/doc_templates/sproutcore/allfiles.tmpl +56 -0
- data/lib/doc_templates/sproutcore/class.tmpl +674 -0
- data/lib/doc_templates/sproutcore/classes-json.tmpl +55 -0
- data/lib/doc_templates/sproutcore/index.tmpl +48 -0
- data/lib/doc_templates/sproutcore/publish.js +346 -0
- data/lib/doc_templates/sproutcore/static/default.css +258 -0
- data/lib/doc_templates/sproutcore/static/header.html +2 -0
- data/lib/doc_templates/sproutcore/static/index.html +19 -0
- data/lib/doc_templates/sproutcore/symbol.tmpl +35 -0
- data/lib/frameworks/sproutcore/Buildfile +101 -0
- data/lib/frameworks/sproutcore/CHANGELOG.md +170 -0
- data/lib/frameworks/sproutcore/HISTORY +697 -0
- data/lib/frameworks/sproutcore/README.md +68 -0
- data/lib/frameworks/sproutcore/apps/docs/core.js +27 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/QuickLook/Preview.pdf +0 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/QuickLook/Thumbnail.tiff +0 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/data.plist +14378 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image10.png +0 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image11.png +0 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image13.png +0 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image14.png +0 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image8.png +0 -0
- data/lib/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image9.tiff +0 -0
- data/lib/frameworks/sproutcore/apps/docs/english.lproj/loading.rhtml +9 -0
- data/lib/frameworks/sproutcore/apps/docs/english.lproj/main_page.js +22 -0
- data/lib/frameworks/sproutcore/apps/docs/english.lproj/strings.js +15 -0
- data/lib/frameworks/sproutcore/apps/docs/main.js +30 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/README +25 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/TODO +72 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/beautify.js +1058 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/design.js +20 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/file.js +75 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/files.js +40 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/layout.js +53 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/library.js +201 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/page.js +18 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/property.js +19 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/property_editor.js +17 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/target.js +20 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/targets.js +43 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/controllers/view_configs.js +100 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/core.js +67 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/core_file.js +124 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/data_source.js +250 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/app_page.js +377 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/app-selector.css +111 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/button.css +310 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/dock.css +85 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/general.css +52 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/main-page.css +120 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/menu.css +52 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/modal.css +40 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/picker.css +188 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/search.css +60 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/tabbed.css +68 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/text-field.css +67 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/dialogs.js +302 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/fonts/museosans_500.eot +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/fonts/museosans_500.otf +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/fonts/museosans_500.woff +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/fonts/museosans_500_italic.eot +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/fonts/museosans_500_italic.otf +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/fonts/museosans_500_italic.woff +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/app-selector/choose-app.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/app-selector/list-item-sel.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule-xl/active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule-xl/active-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule-xl/active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule-xl/regular-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule-xl/regular-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule-xl/regular-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/disabled-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/disabled-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/regular-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/regular-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/sel-active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/sel-active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/sel-disabled-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/sel-disabled-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/sel-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/capsule/sel-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/active-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-sel-active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-sel-active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-sel-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/cap-sel-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/disabled-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/disabled-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/disabled-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/regular-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/regular-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/regular-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-active-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-disabled-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-disabled-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-disabled-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/dark/sel-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/shared/active-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/shared/disabled-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/shared/regular-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/shared/sel-active-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/shared/sel-disabled-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/shared/sel-m.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/disabled-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/disabled-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/regular-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/regular-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/sel-active-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/sel-active-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/sel-disabled-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/sel-disabled-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/sel-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/buttons/square/sel-r.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/actions-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/actions.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/inspector-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/inspector.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/library-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/library.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/projects-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/projects.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/run-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/run.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/save-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/icons/save.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/logos/greenhouse-l.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/logos/greenhouse-s.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/logos/sproutcore.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/main-bg.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/bottom-left.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/bottom-right.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/bottom.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/close-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/close.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/left.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/pointer-bottom.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/pointer-left.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/pointer-right.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/pointer-top.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/right.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/search-active.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/search.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/top-left.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/top-right.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/picker/top.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/images/toolbar-bg.png +0 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/inspectors.js +365 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/loading.rhtml +9 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/main_page.js +95 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/strings.js +87 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/fixtures/file.js +35 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/main.js +28 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/mixins/drop_down.js +97 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/models/design.js +22 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/models/dir.js +92 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/models/file.js +51 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/models/target.js +82 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/models/view_config.js +49 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/resources/test_page.js +37 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/states/inspector.js +144 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/states/library.js +133 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/states/main.js +224 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/states/modals.js +291 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/states/ready.js +197 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/controllers/design.js +15 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/controllers/designs.js +15 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/controllers/file.js +15 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/controllers/files.js +15 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/models/file.js +15 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/models/view_config.js +15 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/tests/views/list_item.js +15 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/anchor.js +277 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/application_list_item.js +19 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/event_blocker.js +32 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/label_designer.js +16 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/list_item.js +42 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/plist_item.js +39 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/simple_button.js +157 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/tear_off_picker.js +56 -0
- data/lib/frameworks/sproutcore/apps/greenhouse/views/web.js +44 -0
- data/lib/frameworks/sproutcore/apps/tests/controllers/detail.js +25 -0
- data/lib/frameworks/sproutcore/apps/tests/controllers/source.js +29 -0
- data/lib/frameworks/sproutcore/apps/tests/controllers/target.js +26 -0
- data/lib/frameworks/sproutcore/apps/tests/controllers/targets.js +86 -0
- data/lib/frameworks/sproutcore/apps/tests/controllers/tests.js +33 -0
- data/lib/frameworks/sproutcore/apps/tests/core.js +133 -0
- data/lib/frameworks/sproutcore/apps/tests/english.lproj/loading.rhtml +9 -0
- data/lib/frameworks/sproutcore/apps/tests/english.lproj/main_page.css +48 -0
- data/lib/frameworks/sproutcore/apps/tests/english.lproj/main_page.js +233 -0
- data/lib/frameworks/sproutcore/apps/tests/english.lproj/strings.js +26 -0
- data/lib/frameworks/sproutcore/apps/tests/main.js +27 -0
- data/lib/frameworks/sproutcore/apps/tests/states/no_targets.js +26 -0
- data/lib/frameworks/sproutcore/apps/tests/states/ready.js +56 -0
- data/lib/frameworks/sproutcore/apps/tests/states/ready_detail.js +41 -0
- data/lib/frameworks/sproutcore/apps/tests/states/ready_empty.js +48 -0
- data/lib/frameworks/sproutcore/apps/tests/states/ready_list.js +41 -0
- data/lib/frameworks/sproutcore/apps/tests/states/ready_loading.js +44 -0
- data/lib/frameworks/sproutcore/apps/tests/states/ready_no_tests.js +31 -0
- data/lib/frameworks/sproutcore/apps/tests/states/start.js +39 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/controllers/detail.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/controllers/source.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/controllers/target.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/controllers/targets.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/controllers/tests.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/models/target.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/models/test.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/tests/views/offset_checkbox.js +15 -0
- data/lib/frameworks/sproutcore/apps/tests/views/offset_checkbox.js +26 -0
- data/lib/frameworks/sproutcore/apps/welcome/controllers/targets.js +49 -0
- data/lib/frameworks/sproutcore/apps/welcome/core.js +30 -0
- data/lib/frameworks/sproutcore/apps/welcome/english.lproj/loading.rhtml +10 -0
- data/lib/frameworks/sproutcore/apps/welcome/english.lproj/main_page.css +7 -0
- data/lib/frameworks/sproutcore/apps/welcome/english.lproj/main_page.js +77 -0
- data/lib/frameworks/sproutcore/apps/welcome/english.lproj/strings.js +15 -0
- data/lib/frameworks/sproutcore/apps/welcome/main.js +19 -0
- data/lib/frameworks/sproutcore/apps/welcome/tests/controllers/targets.js +15 -0
- data/lib/frameworks/sproutcore/design/CollectionView State Charts.graffle +4848 -0
- data/lib/frameworks/sproutcore/design/Design Charts.graffle +16845 -0
- data/lib/frameworks/sproutcore/design/Record State Table.numbers +0 -0
- data/lib/frameworks/sproutcore/design/SproutCore Datastore Design.graffle/QuickLook/Preview.pdf +0 -0
- data/lib/frameworks/sproutcore/design/SproutCore Datastore Design.graffle/QuickLook/Thumbnail.tiff +0 -0
- data/lib/frameworks/sproutcore/design/SproutCore Datastore Design.graffle/data.plist +19588 -0
- data/lib/frameworks/sproutcore/design/SproutCore Datastore Design.graffle/image8.png +0 -0
- data/lib/frameworks/sproutcore/design/SproutCore Design Template.graffle/QuickLook/Preview.pdf +0 -0
- data/lib/frameworks/sproutcore/design/SproutCore Design Template.graffle/QuickLook/Thumbnail.tiff +0 -0
- data/lib/frameworks/sproutcore/design/SproutCore Design Template.graffle/data.plist +1452 -0
- data/lib/frameworks/sproutcore/design/SproutCore Design Template.graffle/image8.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/QuickLook/Preview.pdf +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/QuickLook/Thumbnail.tiff +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/data.plist +24187 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image10.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image11.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image13.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image15.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image16.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image17.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image18.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image19.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image22.tiff +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image23.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image24.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image25.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image30.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image31.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image8.png +0 -0
- data/lib/frameworks/sproutcore/design/TestRunner Design.graffle/image9.png +0 -0
- data/lib/frameworks/sproutcore/design/greenhouse-statechart.graffle +9025 -0
- data/lib/frameworks/sproutcore/design/greenhouse-statechart.pdf +0 -0
- data/lib/frameworks/sproutcore/design/iphone-webapp-loading.psd +0 -0
- data/lib/frameworks/sproutcore/frameworks/animation/Buildfile +3 -0
- data/lib/frameworks/sproutcore/frameworks/animation/LICENSE +25 -0
- data/lib/frameworks/sproutcore/frameworks/animation/README.md +79 -0
- data/lib/frameworks/sproutcore/frameworks/animation/core.js +1192 -0
- data/lib/frameworks/sproutcore/frameworks/animation/tests/core.js +147 -0
- data/lib/frameworks/sproutcore/frameworks/bootstrap/README +9 -0
- data/lib/frameworks/sproutcore/frameworks/bootstrap/core.js +7 -0
- data/lib/frameworks/sproutcore/frameworks/bootstrap/setup_body_class_names.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/bootstrap/system/browser.js +29 -0
- data/lib/frameworks/sproutcore/frameworks/bootstrap/system/loader.js +49 -0
- data/lib/frameworks/sproutcore/frameworks/core_tools/core.js +20 -0
- data/lib/frameworks/sproutcore/frameworks/core_tools/data_source.js +99 -0
- data/lib/frameworks/sproutcore/frameworks/core_tools/english.lproj/strings.js +15 -0
- data/lib/frameworks/sproutcore/frameworks/core_tools/fixtures/target.js +87 -0
- data/lib/frameworks/sproutcore/frameworks/core_tools/fixtures/test.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/core_tools/models/target.js +108 -0
- data/lib/frameworks/sproutcore/frameworks/core_tools/models/test.js +48 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/core.js +8 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/data_sources/cascade.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/data_sources/data_source.js +340 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/data_sources/fixtures.js +393 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/debug/json.js +71 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/debug/standard_setup.js +96 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/fixtures/author_fixtures.js +2503 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/fixtures/sample.js +17 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/child_attribute.js +122 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/child_record.js +105 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/children_attribute.js +81 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/fetched_attribute.js +100 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/many_attribute.js +153 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/record.js +1201 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/record_attribute.js +494 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/models/single_attribute.js +159 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/system/child_array.js +242 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/system/many_array.js +415 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/system/nested_store.js +588 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/system/query.js +1600 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/system/record_array.js +651 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/system/store.js +2666 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/data_sources/fixtures.js +117 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/integration/contact_model.js +131 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/integration/cyclical_relationship.js +119 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/integration/mail_model.js +91 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/integration/test_runner_model.js +56 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/datetime_recordattribute.js +73 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/many_attribute.js +423 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record.js +235 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array.js +337 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array_complex.js +421 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_complex.js +304 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/parentless.js +134 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/core_methods.js +55 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/destroy.js +92 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/error_methods.js +56 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/normalize.js +273 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/readAttribute.js +53 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/refresh.js +48 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/storeDidChangeProperties.js +170 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/unknownProperty.js +66 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/writeAttribute.js +112 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record_attribute.js +252 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/single_attribute.js +284 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/many_array/core_methods.js +204 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/chain.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/commitChanges.js +171 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/commitChangesFromNestedStore.js +154 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/core_methods.js +70 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/dataHashDidChange.js +113 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/discardChanges.js +99 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/readDataHash.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/readEditableDataHash.js +126 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/removeDataHash.js +163 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/writeDataHash.js +166 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/builders.js +219 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/compare.js +144 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/contains.js +131 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/containsRecordTypes.js +81 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/copy.js +30 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/evaluation.js +197 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/evaluation_of_records.js +92 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/expandedRecordTypes.js +64 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/parse.js +216 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/queryWithScope.js +57 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/record_type_is.js +43 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/registered_comparisons.js +66 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/registered_query_extensions.js +67 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/record_array/core_methods.js +177 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/record_array/error_methods.js +50 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/record_array/flush.js +177 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/cancelRecord.js +54 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/commitChangesFromNestedStore.js +133 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/commitRecord.js +211 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/core_methods.js +156 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/createRecord.js +72 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/dataHashDidChange.js +157 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/dataSourceCallbacks.js +278 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/destroyRecord.js +106 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/error_methods.js +62 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/find.js +530 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/init.js +23 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/pushChanges.js +61 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/readDataHash.js +74 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/readEditableDataHash.js +74 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/recordDidChange.js +73 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/removeDataHash.js +144 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/retrieveRecord.js +184 -0
- data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/writeDataHash.js +125 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/core.js +865 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/english.lproj/en-US.js +186 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/extras.js +332 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/license.js +25 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/parser.js +1116 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/spanish.lproj/es-CO.js +186 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/sugarpak.js +475 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/time.js +269 -0
- data/lib/frameworks/sproutcore/frameworks/datejs/validators/datejs.js +34 -0
- data/lib/frameworks/sproutcore/frameworks/debug/core.js +114 -0
- data/lib/frameworks/sproutcore/frameworks/debug/invoke_once_last_debugging.js +265 -0
- data/lib/frameworks/sproutcore/frameworks/designer/coders/design.js +20 -0
- data/lib/frameworks/sproutcore/frameworks/designer/coders/localization.js +19 -0
- data/lib/frameworks/sproutcore/frameworks/designer/coders/object.js +347 -0
- data/lib/frameworks/sproutcore/frameworks/designer/controllers/controllers.js +16 -0
- data/lib/frameworks/sproutcore/frameworks/designer/controllers/design.js +37 -0
- data/lib/frameworks/sproutcore/frameworks/designer/controllers/designs.js +134 -0
- data/lib/frameworks/sproutcore/frameworks/designer/controllers/page_design.js +170 -0
- data/lib/frameworks/sproutcore/frameworks/designer/controllers/page_files.js +22 -0
- data/lib/frameworks/sproutcore/frameworks/designer/core.js +26 -0
- data/lib/frameworks/sproutcore/frameworks/designer/css/css_rule.js +22 -0
- data/lib/frameworks/sproutcore/frameworks/designer/css/css_style.js +29 -0
- data/lib/frameworks/sproutcore/frameworks/designer/css/css_style_sheet.js +201 -0
- data/lib/frameworks/sproutcore/frameworks/designer/designers/button.js +21 -0
- data/lib/frameworks/sproutcore/frameworks/designer/designers/label.js +16 -0
- data/lib/frameworks/sproutcore/frameworks/designer/designers/object_designer.js +296 -0
- data/lib/frameworks/sproutcore/frameworks/designer/designers/tab.js +18 -0
- data/lib/frameworks/sproutcore/frameworks/designer/designers/text_field.js +15 -0
- data/lib/frameworks/sproutcore/frameworks/designer/designers/view_designer.js +1259 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/css/designer.css +96 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/design_page.js +55 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/high_light.css +10 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/controller.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/dock-bg.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/dock-item-bg.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/dock-item-divider.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/dock-item-sel-bg.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/dock-item-sel-divider.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/main-bg.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/page.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/pane.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/images/view.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/designer/english.lproj/selection_handles.css +58 -0
- data/lib/frameworks/sproutcore/frameworks/designer/ext/object.js +26 -0
- data/lib/frameworks/sproutcore/frameworks/designer/ext/page.js +86 -0
- data/lib/frameworks/sproutcore/frameworks/designer/ext/view.js +54 -0
- data/lib/frameworks/sproutcore/frameworks/designer/mixins/button.js +11 -0
- data/lib/frameworks/sproutcore/frameworks/designer/mixins/snap_lines.js +221 -0
- data/lib/frameworks/sproutcore/frameworks/designer/views/designer_drop_target.js +138 -0
- data/lib/frameworks/sproutcore/frameworks/designer/views/drawing.js +219 -0
- data/lib/frameworks/sproutcore/frameworks/designer/views/high_light.js +66 -0
- data/lib/frameworks/sproutcore/frameworks/designer/views/page_item_view.js +130 -0
- data/lib/frameworks/sproutcore/frameworks/designer/views/selection_handles.js +78 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/core.js +18 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/debug/drag.js +41 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/alert.css +56 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/debug/a_sample_image.jpg +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/debug/apple-logo1.jpeg +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/debug/iframe.html +23 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/disclosure.css +74 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/drag.css +7 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/icons.css +943 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/cap.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/downbutton.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/icons/shared.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/thumb-bottom.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/thumb-center.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/thumb-top.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/track.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/images/upbutton.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/list_item.css +161 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/menu.css +12 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/menu_item_view.css +109 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/modal.css +9 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/panel.css +91 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/picker.css +35 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/progress.css +33 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/radio.css +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/segmented.css +134 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/separator.css +19 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/slider.css +66 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/split.css +0 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/split_divider.css +6 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/strings.js +14 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/tab.css +7 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/toolbar.css +5 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/touch-scroller.css +196 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/video.css +3 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/well.css +71 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/border.js +138 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_fast_path.js +694 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_group.js +22 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_row_delegate.js +61 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_view_delegate.js +295 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/mixins/scrollable.js +253 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/alert.js +410 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/menu.js +1115 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/modal.js +71 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/palette.js +74 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/panel.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/picker.js +696 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/select_button.js +849 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/panes/sheet.js +214 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/protocols/drag_data_source.js +39 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/protocols/drag_source.js +81 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/protocols/drop_target.js +175 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/protocols/responder.js +299 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/system/drag.js +923 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/system/key_bindings.js +40 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/system/undo_manager.js +187 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/integration/dialog.js +43 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/mixins/border.js +96 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/alert/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/alert/ui.js +152 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/menu/methods.js +135 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/menu/ui.js +223 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/palette/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/palette/ui.js +35 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/pane_page.js +41 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/panel/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/panel/ui.js +40 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/picker/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/picker/ui.js +86 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/select_button/methods.js +194 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/select_button/ui.js +212 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/sheet/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/sheet/ui.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/button/methods.js +124 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/button/ui.js +163 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/checkbox/methods.js +142 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/checkbox/ui.js +95 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/content.js +249 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/deleteSelection.js +82 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/deselect.js +215 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/displayProperties.js +31 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/itemViewForContentIndex.js +300 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/layerIdFor.js +65 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/length.js +88 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/mouse.js +240 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/nowShowing.js +121 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/reload.js +177 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/select.js +240 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/selectNextItem.js +205 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/selectPreviousItem.js +211 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/selection.js +141 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/ui_diagram.js +182 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/date_field/methods.js +76 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/date_field/ui.js +456 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/disclosure/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/disclosure/ui.js +64 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/grid/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/grid/ui.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/render.js +92 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowDelegate.js +183 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowHeightForContentIndex.js +133 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowOffsetForContentIndex.js +131 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_alternatingrows.js +130 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_outline.js +56 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_row_heights.js +205 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_simple.js +127 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list_item.js +288 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/menu_item/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/menu_item/ui.js +46 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/progress/methods.js +128 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/progress/ui.js +287 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/radio/methods.js +119 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/radio/ui.js +232 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroll/methods.js +143 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroll/ui.js +150 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroller.js +90 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/methods.js +119 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/ui.js +226 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/select/methods.js +144 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/select/ui.js +216 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/select_field/methods.js +132 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/select_field/ui.js +110 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/separator.js +37 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/source_list/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/source_list/ui.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/split/methods.js +60 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/split/ui.js +52 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/stacked/ui_comments.js +231 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/static_content.js +46 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/tab/methods.js +54 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/tab/ui.js +88 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/web/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/web/ui.js +110 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/well/ui.js +54 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/button.js +619 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/checkbox.js +112 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/collection.js +3073 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/date_field.js +319 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/disclosure.js +77 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/grid.js +207 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/list.js +631 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/list_item.js +836 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/menu_item.js +681 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/menu_scroll.js +588 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/popup_button.js +298 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/progress.js +250 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/radio.js +376 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/scene.js +204 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/scroll.js +1790 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/scroller.js +884 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/segmented.js +678 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/select.js +673 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/select_field.js +324 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/separator.js +36 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/slider.js +286 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/source_list.js +47 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/source_list_group.js +169 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/split.js +781 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/split_divider.js +57 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/stacked.js +110 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/static_content.js +134 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/tab.js +184 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/thumb.js +53 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/toolbar.js +49 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/web.js +87 -0
- data/lib/frameworks/sproutcore/frameworks/desktop/views/well.js +85 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/TESTING +46 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/controllers/array.js +518 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/controllers/controller.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/controllers/object.js +342 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/controllers/tree.js +124 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/core.js +150 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/debug/control_test_pane.js +193 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/blank.gif +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/bootstrap.rhtml +79 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/button_view.css +40 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/core.css +474 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/debug/control-test-pane.css +9 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/images/sproutcore-logo.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/images/sproutcore-startup-landscape.jpg +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/images/sproutcore-startup-landscape.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/images/sproutcore-startup-portrait.jpg +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/images/sproutcore-startup-portrait.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/images/sproutcore-startup.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/inline_editor.css +12 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/label.css +42 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/static_layout.css +5 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/strings.js +15 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/text_field.css +148 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/view.css +57 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/ext/object.js +83 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/ext/run_loop.js +162 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/fixtures/file_exists.json +1 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/fixtures/malformed.json +11 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/license.js +30 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/button.js +360 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/collection_content.js +179 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/content_display.js +96 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/control.js +377 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/editable.js +152 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/inline_text_field.js +580 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/responder_context.js +269 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/selection_support.js +250 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/static_layout.js +77 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/string.js +543 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/tree_item_content.js +160 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/mixins/validatable.js +189 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/panes/main.js +51 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/panes/pane.js +848 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/private/tree_item_observer.js +907 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/protocols/inline_editor_delegate.js +84 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/application.js +37 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/benchmark.js +514 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/browser.js +59 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/builder.js +210 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/bundle.js +337 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/core_query.js +2049 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/cursor.js +131 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/datetime.js +1129 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/device.js +143 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/event.js +894 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/exception_handler.js +85 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/image_cache.js +432 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/json.js +515 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/locale.js +293 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/math.js +57 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/page.js +108 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/platform.js +297 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/ready.js +197 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/render_context.js +988 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/request.js +599 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/responder.js +124 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/response.js +538 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/root_responder.js +2060 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/routes.js +420 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/task_queue.js +150 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/text_selection.js +103 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/time.js +473 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/timer.js +551 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/user_defaults.js +397 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/system/utils.js +710 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tasks/preload_bundle.js +41 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tasks/task.js +17 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/array_case.js +218 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/enum_case.js +206 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/null_case.js +64 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/selection_support.js +318 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/single_case.js +136 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/empty_case.js +82 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/multiple_case.js +111 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/single_case.js +193 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/single_enumerable_case.js +265 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/tree/outline_case.js +108 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/controllers/tree/selection_support.js +340 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/debug/control_test_pane/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/debug/control_test_pane/ui.js +113 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/integration/creating_views.js +113 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/button/content.js +195 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/button/displayProperties.js +89 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/button/keyEquivalents.js +57 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/button/ui.js +68 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/control/content.js +168 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/control/displayProperties.js +89 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/inline_text_field/api.js +52 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/inline_text_field/beginEditing.js +227 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/responder_context.js +75 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/staticLayout.js +142 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/string.js +83 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/validatable/ui.js +74 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/private/tree_item_observer/flat_case.js +325 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/private/tree_item_observer/group_case.js +718 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/private/tree_item_observer/outline_case.js +484 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/builder.js +42 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/core_query/jquery_core.js +1334 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/core_query/jquery_dimensions.js +387 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/core_query/jquery_selector.js +405 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/core_query/setClass.js +49 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/core_query/within.js +66 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/datetime.js +348 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/json.js +14 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/locale.js +134 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/math.js +39 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/begin.js +47 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/element.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/end.js +124 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/get.js +51 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_attr.js +50 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_basic.js +28 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_className.js +179 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_style.js +101 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/init.js +55 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/join.js +28 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/push_text.js +74 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/tag.js +46 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/update.js +218 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/request.js +223 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/root_responder/makeKeyPane.js +124 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/root_responder/makeMainPane.js +68 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/root_responder/makeMenuPane.js +48 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/root_responder/root_responder.js +101 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/root_responder/targetForAction.js +238 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/routes.js +352 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/task_queue.js +43 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/timer/invalidate.js +38 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/timer/invokeLater.js +201 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/timer/isPaused.js +71 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/timer/performAction.js +69 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/timer/schedule.js +170 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/user_defaults.js +24 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/utils/normalizeURL.js +18 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/utils/range.js +62 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/utils/rect.js +99 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/validators/credit_card.js +35 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/validators/date.js +26 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/validators/number.js +47 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/validators/password.js +13 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/validators/validator.js +20 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/container/methods.js +10 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/container/ui.js +115 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/image/ui.js +59 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/label/ui.js +148 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/main_pane.js +31 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/pane/append_remove.js +124 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/pane/firstResponder.js +148 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/pane/keyPane.js +133 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/pane/layout.js +31 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/pane/sendEvent.js +206 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/methods.js +87 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/ui.js +530 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/clippingFrame.js +133 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/convertFrames.js +246 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/convertLayouts.js +145 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/createChildViews.js +122 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/createLayer.js +97 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/destroyLayer.js +83 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/didAppendToDocument.js +48 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/findLayerInParentLayer.js +50 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/init.js +50 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/insertBefore.js +200 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/isVisible.js +51 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/isVisibleInWindow.js +116 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/layer.js +150 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/layoutChildViews.js +162 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/layoutDidChange.js +127 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/layoutStyle.js +531 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/nextValidKeyView.js +110 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/parentViewDidChange.js +67 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/prepareContext.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/removeChild.js +189 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/render.js +83 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/replaceChild.js +29 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/updateLayer.js +146 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/updateLayerLocation.js +194 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/view/viewDidResize.js +202 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/credit_card.js +125 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/date.js +52 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/date_time.js +48 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/email.js +45 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/not_empty.js +33 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/number.js +98 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/password.js +86 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/positive_integer.js +84 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/validators/validator.js +326 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/views/container.js +139 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/views/field.js +320 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/views/image.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/views/label.js +339 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/views/text_field.js +946 -0
- data/lib/frameworks/sproutcore/frameworks/foundation/views/view.js +3313 -0
- data/lib/frameworks/sproutcore/frameworks/media/resources/controls.png +0 -0
- data/lib/frameworks/sproutcore/frameworks/media/resources/playeras3.fla +0 -0
- data/lib/frameworks/sproutcore/frameworks/media/resources/video.css +120 -0
- data/lib/frameworks/sproutcore/frameworks/media/resources/videoCanvas.swf +0 -0
- data/lib/frameworks/sproutcore/frameworks/media/views/audio.js +739 -0
- data/lib/frameworks/sproutcore/frameworks/media/views/controls.js +90 -0
- data/lib/frameworks/sproutcore/frameworks/media/views/media_slider.js +243 -0
- data/lib/frameworks/sproutcore/frameworks/media/views/mini_controls.js +63 -0
- data/lib/frameworks/sproutcore/frameworks/media/views/simple_controls.js +55 -0
- data/lib/frameworks/sproutcore/frameworks/media/views/video.js +832 -0
- data/lib/frameworks/sproutcore/frameworks/mini/license.js +28 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/README +12 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/core.js +1061 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/base.js +238 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/indexOf.js +33 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/insertAt.js +121 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/objectAt.js +34 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/popObject.js +50 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/pushObject.js +46 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/rangeObserver.js +371 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/removeAt.js +100 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/removeObject.js +49 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/replace.js +94 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/shiftObject.js +50 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/unshiftObject.js +47 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/license.js +28 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/array.js +643 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/comparable.js +45 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/copyable.js +64 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/delegate_support.js +110 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/enumerable.js +1298 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/freezable.js +110 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/mixins/observable.js +1347 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/private/chain_observer.js +141 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/private/observer_queue.js +173 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/private/observer_set.js +180 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/protocols/observable_protocol.js +40 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/protocols/sparse_array_delegate.js +131 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/binding.js +1000 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/cookie.js +160 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/enumerator.js +107 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/error.js +157 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/index_set.js +1199 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/logger.js +452 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/object.js +888 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/range_observer.js +271 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/run_loop.js +295 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/selection_set.js +697 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/set.js +532 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/system/sparse_array.js +379 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/IsEqual.js +60 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/beget.js +23 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/clone.js +84 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/compare.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/console.js +16 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/guidFor.js +182 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/inspect.js +27 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/isArray.js +25 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/itemType.js +39 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/keys.js +20 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/makeArray.js +30 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/objectForPropertyPath.js +19 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/tupleForPropertyPath.js +37 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/array.js +57 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/comparable.js +44 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/enumerable.js +622 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/observable.js +667 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/propertyChanges.js +155 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/registerDependentKeys.js +79 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/propertyChanges.js +81 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/private/observer_queue/isObservingSuspended.js +55 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/binding.js +395 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/cookie.js +163 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/error.js +53 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/add.js +212 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/addEach.js +49 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/clone.js +43 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/contains.js +74 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/create.js +42 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/indexAfter.js +38 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/indexBefore.js +38 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/intersects.js +74 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/max.js +40 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/min.js +50 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/rangeStartForIndex.js +36 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/remove.js +189 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/removeEach.js +49 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/without.js +89 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/logger.js +177 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/object/base.js +195 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/object/bindings.js +360 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/create.js +59 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/destroy.js +75 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/objectPropertyDidChange.js +117 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/rangeDidChange.js +110 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/update.js +65 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/run_loop.js +120 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/add.js +92 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/copy.js +17 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/indexSetForSource.js +98 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/isEqual.js +60 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/remove.js +111 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/set.js +292 -0
- data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/sparse_array.js +194 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/core.js +11 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/mixins/statechart.js +336 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/system/state.js +176 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/basic.js +90 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/history.js +71 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/nested.js +59 -0
- data/lib/frameworks/sproutcore/frameworks/statechart/tests/transient.js +148 -0
- data/lib/frameworks/sproutcore/frameworks/table/mixins/table_delegate.js +41 -0
- data/lib/frameworks/sproutcore/frameworks/table/system/table_column.js +125 -0
- data/lib/frameworks/sproutcore/frameworks/table/views/table.js +439 -0
- data/lib/frameworks/sproutcore/frameworks/table/views/table_cell.js +62 -0
- data/lib/frameworks/sproutcore/frameworks/table/views/table_head.js +158 -0
- data/lib/frameworks/sproutcore/frameworks/table/views/table_header.js +212 -0
- data/lib/frameworks/sproutcore/frameworks/table/views/table_row.js +155 -0
- data/lib/frameworks/sproutcore/frameworks/testing/core.js +196 -0
- data/lib/frameworks/sproutcore/frameworks/testing/english.lproj/additions.css +8 -0
- data/lib/frameworks/sproutcore/frameworks/testing/english.lproj/runner.css +128 -0
- data/lib/frameworks/sproutcore/frameworks/testing/english.lproj/testsuite.css +136 -0
- data/lib/frameworks/sproutcore/frameworks/testing/extras.js +17 -0
- data/lib/frameworks/sproutcore/frameworks/testing/jquery.js +3559 -0
- data/lib/frameworks/sproutcore/frameworks/testing/qunit.js +827 -0
- data/lib/frameworks/sproutcore/frameworks/testing/system/dump.js +205 -0
- data/lib/frameworks/sproutcore/frameworks/testing/system/equiv.js +201 -0
- data/lib/frameworks/sproutcore/frameworks/testing/system/plan.js +695 -0
- data/lib/frameworks/sproutcore/frameworks/testing/system/runner.js +209 -0
- data/lib/frameworks/sproutcore/frameworks/testing/system/suite.js +228 -0
- data/lib/frameworks/sproutcore/frameworks/testing/utils.js +62 -0
- data/lib/frameworks/sproutcore/lib/index.rhtml +119 -0
- data/lib/frameworks/sproutcore/license.js +30 -0
- data/lib/frameworks/sproutcore/themes/empty_theme/tests/mini_icons.rhtml +69 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/button.css +41 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/core.css +8 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/backButton.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/blueButton.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/cancel.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/grayButton.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/leftButton.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/listArrow.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/listArrowSel.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/listGroup.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/loading.gif +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/pinstripes.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/rightButton.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/selection.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/thumb.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/toggle.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/toggleOn.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/toolButton.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/toolbar.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/images/whiteButton.png +0 -0
- data/lib/frameworks/sproutcore/themes/iphone_theme/english.lproj/strings.js +15 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/Panel.drawit/Data +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/Panel.drawit/QuickLook/Preview.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/Panel.drawit/QuickLook/Thumbnail.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/SproutCore Theme Buttons.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/ToolbarView Pattern.drawit/Data +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/ToolbarView Pattern.drawit/QuickLook/Preview.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/ToolbarView Pattern.drawit/QuickLook/Thumbnail.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/10.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/100.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/102.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/110.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/120.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/127.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/18.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/19.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/2.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/24.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/26.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/27.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/28.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/29.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/30.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/31.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/33.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/37.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/41.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/16/99.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/10.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/100.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/102.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/110.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/120.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/127.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/18.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/19.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/2.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/24.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/26.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/27.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/28.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/29.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/30.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/31.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/33.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/37.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/41.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/24/99.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/10.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/100.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/102.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/110.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/120.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/127.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/18.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/19.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/2.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/24.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/26.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/27.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/28.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/29.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/30.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/31.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/33.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/37.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/41.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/32/99.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/48/10.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/48/18.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/48/19.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/icons/48/2.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/panel-sprite-x.drawit/Data +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/panel-sprite-x.drawit/QuickLook/Preview.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/panel-sprite-x.drawit/QuickLook/Thumbnail.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/panel-sprite-y.drawit/Data +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/panel-sprite-y.drawit/QuickLook/Preview.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/panel-sprite-y.drawit/QuickLook/Thumbnail.jpg +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-repeat-x-2.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-repeat-x.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-sprite.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-ysprite.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/shared-icons.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/sproutcore-logo.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/Source/sticky-note.psd +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/button.css +399 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/checkbox.css +78 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/collection.css +135 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/core.css +76 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/disclosure.css +57 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/icons/mini_222222.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/icons/mini_454545.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/icons/mini_888888.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/icons/mini_ffffff.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/panels/sprite-x.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/panels/sprite-y.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/sc-scroller-repeat-x.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/sc-scroller-repeat-y.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/sc-scroller-sprite.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/sc-theme-repeat-x.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/sc-theme-ysprite.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/images/sc-toolbar-view.png +0 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/label.css +11 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/list_item.css +82 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/menu.css +20 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/menu_item_view.css +36 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/pane.css +18 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/panel.css +33 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/picker.css +17 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/progress.css +27 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/radio.css +125 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/scroller.css +159 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/segmented.css +275 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/slider.css +94 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/split_view.css +11 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/tab.css +14 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/table.css +14 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/text_field.css +5 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/toolbar.css +7 -0
- data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/well.css +36 -0
- data/lib/gen/Buildfile +16 -0
- data/lib/gen/app/Buildfile +36 -0
- data/lib/gen/app/README +1 -0
- data/lib/gen/app/USAGE +13 -0
- data/lib/gen/app/templates/apps/@target_name@/core.js +27 -0
- data/lib/gen/app/templates/apps/@target_name@/main.js +30 -0
- data/lib/gen/app/templates/apps/@target_name@/resources/loading.rhtml +9 -0
- data/lib/gen/app/templates/apps/@target_name@/resources/main_page.js +24 -0
- data/lib/gen/controller/Buildfile +18 -0
- data/lib/gen/controller/README +1 -0
- data/lib/gen/controller/USAGE +13 -0
- data/lib/gen/controller/templates/controllers/@filename@.js +18 -0
- data/lib/gen/controller/templates/tests/controllers/@filename@.js +15 -0
- data/lib/gen/data-source/Buildfile +18 -0
- data/lib/gen/data-source/README +1 -0
- data/lib/gen/data-source/USAGE +15 -0
- data/lib/gen/data-source/templates/data_sources/@filename@.js +64 -0
- data/lib/gen/design/Buildfile +23 -0
- data/lib/gen/design/README +1 -0
- data/lib/gen/design/USAGE +10 -0
- data/lib/gen/design/templates/resources/@filename@.js +16 -0
- data/lib/gen/framework/Buildfile +36 -0
- data/lib/gen/framework/README +1 -0
- data/lib/gen/framework/USAGE +13 -0
- data/lib/gen/framework/templates/frameworks/@target_name@/core.js +21 -0
- data/lib/gen/framework/templates/frameworks/@target_name@/english.lproj/strings.js +15 -0
- data/lib/gen/language/Buildfile +26 -0
- data/lib/gen/language/README +1 -0
- data/lib/gen/language/USAGE +13 -0
- data/lib/gen/language/templates/@filename@/strings.js +14 -0
- data/lib/gen/model/Buildfile +16 -0
- data/lib/gen/model/README +1 -0
- data/lib/gen/model/USAGE +15 -0
- data/lib/gen/model/templates/fixtures/@filename@.js +35 -0
- data/lib/gen/model/templates/models/@filename@.js +19 -0
- data/lib/gen/model/templates/tests/models/@filename@.js +15 -0
- data/lib/gen/page/Buildfile +36 -0
- data/lib/gen/page/README +1 -0
- data/lib/gen/page/USAGE +15 -0
- data/lib/gen/page/templates/pages/@target_name@/Buildfile +16 -0
- data/lib/gen/page/templates/pages/@target_name@/core.js +22 -0
- data/lib/gen/page/templates/pages/@target_name@/en.lproj/strings.js +14 -0
- data/lib/gen/page/templates/pages/@target_name@/resources/body.css +1 -0
- data/lib/gen/page/templates/pages/@target_name@/resources/body.rhtml +7 -0
- data/lib/gen/project/Buildfile +45 -0
- data/lib/gen/project/INIT +3 -0
- data/lib/gen/project/README +1 -0
- data/lib/gen/project/USAGE +2 -0
- data/lib/gen/project/templates/@filename@/Buildfile +7 -0
- data/lib/gen/project/templates/@filename@/README +7 -0
- data/lib/gen/responder/Buildfile +18 -0
- data/lib/gen/responder/README +1 -0
- data/lib/gen/responder/USAGE +15 -0
- data/lib/gen/responder/templates/states/@filename@.js +39 -0
- data/lib/gen/test/Buildfile +25 -0
- data/lib/gen/test/README +1 -0
- data/lib/gen/test/USAGE +12 -0
- data/lib/gen/test/templates/tests/@filename@.js +15 -0
- data/lib/gen/theme/Buildfile +36 -0
- data/lib/gen/theme/README +1 -0
- data/lib/gen/theme/USAGE +13 -0
- data/lib/gen/theme/templates/themes/@target_name@/resources/theme_styles.css +11 -0
- data/lib/gen/view/Buildfile +18 -0
- data/lib/gen/view/README +1 -0
- data/lib/gen/view/USAGE +13 -0
- data/lib/gen/view/templates/tests/views/@filename@.js +15 -0
- data/lib/gen/view/templates/views/@filename@.js +18 -0
- data/lib/sproutcore.rb +167 -0
- data/lib/sproutcore/builders.rb +13 -0
- data/lib/sproutcore/builders/base.rb +90 -0
- data/lib/sproutcore/builders/bundle.rb +63 -0
- data/lib/sproutcore/builders/combine.rb +60 -0
- data/lib/sproutcore/builders/html.rb +211 -0
- data/lib/sproutcore/builders/javascript.rb +101 -0
- data/lib/sproutcore/builders/less.rb +41 -0
- data/lib/sproutcore/builders/minify.rb +159 -0
- data/lib/sproutcore/builders/sass.rb +65 -0
- data/lib/sproutcore/builders/strings.rb +45 -0
- data/lib/sproutcore/builders/stylesheet.rb +56 -0
- data/lib/sproutcore/builders/test.rb +59 -0
- data/lib/sproutcore/builders/test_index.rb +26 -0
- data/lib/sproutcore/buildfile.rb +490 -0
- data/lib/sproutcore/buildfile/build_task.rb +33 -0
- data/lib/sproutcore/buildfile/buildfile_dsl.rb +169 -0
- data/lib/sproutcore/buildfile/cloneable.rb +34 -0
- data/lib/sproutcore/buildfile/early_time.rb +30 -0
- data/lib/sproutcore/buildfile/invocation_chain.rb +64 -0
- data/lib/sproutcore/buildfile/namespace.rb +33 -0
- data/lib/sproutcore/buildfile/string_ext.rb +202 -0
- data/lib/sproutcore/buildfile/task.rb +333 -0
- data/lib/sproutcore/buildfile/task_arguments.rb +106 -0
- data/lib/sproutcore/buildfile/task_manager.rb +195 -0
- data/lib/sproutcore/deprecated/view_helper.rb +662 -0
- data/lib/sproutcore/helpers.rb +11 -0
- data/lib/sproutcore/helpers/capture_helper.rb +30 -0
- data/lib/sproutcore/helpers/cssmin.rb +202 -0
- data/lib/sproutcore/helpers/dom_id_helper.rb +21 -0
- data/lib/sproutcore/helpers/entry_sorter.rb +128 -0
- data/lib/sproutcore/helpers/html5_manifest.rb +88 -0
- data/lib/sproutcore/helpers/packed_optimizer.rb +102 -0
- data/lib/sproutcore/helpers/static_helper.rb +376 -0
- data/lib/sproutcore/helpers/tag_helper.rb +182 -0
- data/lib/sproutcore/helpers/text_helper.rb +303 -0
- data/lib/sproutcore/models.rb +8 -0
- data/lib/sproutcore/models/generator.rb +493 -0
- data/lib/sproutcore/models/hash_struct.rb +124 -0
- data/lib/sproutcore/models/manifest.rb +385 -0
- data/lib/sproutcore/models/manifest_entry.rb +355 -0
- data/lib/sproutcore/models/project.rb +267 -0
- data/lib/sproutcore/models/target.rb +758 -0
- data/lib/sproutcore/rack.rb +7 -0
- data/lib/sproutcore/rack/builder.rb +344 -0
- data/lib/sproutcore/rack/dev.rb +92 -0
- data/lib/sproutcore/rack/docs.rb +24 -0
- data/lib/sproutcore/rack/filesystem.rb +324 -0
- data/lib/sproutcore/rack/proxy.rb +149 -0
- data/lib/sproutcore/rack/service.rb +153 -0
- data/lib/sproutcore/rack/test_runner.rb +24 -0
- data/lib/sproutcore/render_engines/erubis.rb +55 -0
- data/lib/sproutcore/render_engines/haml.rb +39 -0
- data/lib/sproutcore/tools.rb +360 -0
- data/lib/sproutcore/tools/build.rb +106 -0
- data/lib/sproutcore/tools/build_number.rb +23 -0
- data/lib/sproutcore/tools/docs.rb +53 -0
- data/lib/sproutcore/tools/gen.rb +101 -0
- data/lib/sproutcore/tools/init.rb +40 -0
- data/lib/sproutcore/tools/manifest.rb +85 -0
- data/lib/sproutcore/tools/server.rb +48 -0
- data/lib/sproutcore/vendor/github_gem_lint.rb +22 -0
- data/lib/sproutcore/vendor/jsdoc/README.txt +151 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame.js +33 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Chain.js +102 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Dumper.js +144 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Hash.js +47 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Link.js +142 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Namespace.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Opt.js +134 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Reflection.js +26 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/String.js +93 -0
- data/lib/sproutcore/vendor/jsdoc/app/frame/Testrun.js +129 -0
- data/lib/sproutcore/vendor/jsdoc/app/handlers/FOODOC.js +26 -0
- data/lib/sproutcore/vendor/jsdoc/app/handlers/XMLDOC.js +26 -0
- data/lib/sproutcore/vendor/jsdoc/app/handlers/XMLDOC/DomReader.js +159 -0
- data/lib/sproutcore/vendor/jsdoc/app/handlers/XMLDOC/XMLDoc.js +16 -0
- data/lib/sproutcore/vendor/jsdoc/app/handlers/XMLDOC/XMLParse.js +292 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC.js +98 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/DocComment.js +200 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/DocTag.js +294 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/JsDoc.js +162 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/JsPlate.js +100 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/Lang.js +144 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/Parser.js +109 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/PluginManager.js +33 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/Symbol.js +681 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/SymbolSet.js +226 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/TextStream.js +41 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/Token.js +18 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/TokenReader.js +332 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/TokenStream.js +133 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/Util.js +32 -0
- data/lib/sproutcore/vendor/jsdoc/app/lib/JSDOC/Walker.js +453 -0
- data/lib/sproutcore/vendor/jsdoc/app/main.js +74 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/commentSrcJson.js +19 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/frameworkPrototype.js +16 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/functionCall.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/publishSrcHilite.js +62 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/sproutcoreTags.js +26 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/symbolLink.js +9 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/tagParamConfig.js +31 -0
- data/lib/sproutcore/vendor/jsdoc/app/plugins/tagSynonyms.js +43 -0
- data/lib/sproutcore/vendor/jsdoc/app/run.js +346 -0
- data/lib/sproutcore/vendor/jsdoc/app/t/TestDoc.js +144 -0
- data/lib/sproutcore/vendor/jsdoc/app/t/runner.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/app/test.js +304 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/addon.js +24 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/anon_inner.js +14 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/augments.js +31 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/augments2.js +26 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/borrows.js +41 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/borrows2.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/config.js +22 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/constructs.js +18 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/encoding.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/encoding_other.js +12 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/functions_anon.js +39 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/functions_nested.js +33 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/global.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/globals.js +25 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/ignore.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/inner.js +16 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/jsdoc_test.js +477 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/lend.js +33 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/memberof.js +20 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/memberof_constructor.js +15 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/name.js +19 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/namespace_nested.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/nocode.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/oblit_anon.js +20 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/overview.js +20 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/param_inline.js +37 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/params_optional.js +8 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/prototype.js +17 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/prototype_nested.js +9 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/prototype_oblit.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/prototype_oblit_constructor.js +24 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/public.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/shared.js +42 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/shared2.js +2 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/shortcuts.js +22 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/static_this.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/synonyms.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/tosource.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/app/test/variable_redefine.js +14 -0
- data/lib/sproutcore/vendor/jsdoc/changes.txt +47 -0
- data/lib/sproutcore/vendor/jsdoc/conf/sample.conf +31 -0
- data/lib/sproutcore/vendor/jsdoc/java/build.xml +36 -0
- data/lib/sproutcore/vendor/jsdoc/java/build_1.4.xml +36 -0
- data/lib/sproutcore/vendor/jsdoc/java/classes/js.jar +0 -0
- data/lib/sproutcore/vendor/jsdoc/java/src/JsDebugRun.java +21 -0
- data/lib/sproutcore/vendor/jsdoc/java/src/JsRun.java +21 -0
- data/lib/sproutcore/vendor/jsdoc/jsdebug.jar +0 -0
- data/lib/sproutcore/vendor/jsdoc/jsrun.jar +0 -0
- data/lib/sproutcore/vendor/jsdoc/t/TestDoc.js +144 -0
- data/lib/sproutcore/vendor/jsdoc/t/runner.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/test.js +304 -0
- data/lib/sproutcore/vendor/jsdoc/test/addon.js +24 -0
- data/lib/sproutcore/vendor/jsdoc/test/anon_inner.js +14 -0
- data/lib/sproutcore/vendor/jsdoc/test/augments.js +31 -0
- data/lib/sproutcore/vendor/jsdoc/test/augments2.js +26 -0
- data/lib/sproutcore/vendor/jsdoc/test/borrows.js +41 -0
- data/lib/sproutcore/vendor/jsdoc/test/borrows2.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/test/config.js +22 -0
- data/lib/sproutcore/vendor/jsdoc/test/constructs.js +18 -0
- data/lib/sproutcore/vendor/jsdoc/test/encoding.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/test/encoding_other.js +12 -0
- data/lib/sproutcore/vendor/jsdoc/test/functions_anon.js +39 -0
- data/lib/sproutcore/vendor/jsdoc/test/functions_nested.js +33 -0
- data/lib/sproutcore/vendor/jsdoc/test/global.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/test/globals.js +25 -0
- data/lib/sproutcore/vendor/jsdoc/test/ignore.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/test/inner.js +16 -0
- data/lib/sproutcore/vendor/jsdoc/test/jsdoc_test.js +477 -0
- data/lib/sproutcore/vendor/jsdoc/test/lend.js +33 -0
- data/lib/sproutcore/vendor/jsdoc/test/memberof.js +20 -0
- data/lib/sproutcore/vendor/jsdoc/test/memberof_constructor.js +15 -0
- data/lib/sproutcore/vendor/jsdoc/test/name.js +19 -0
- data/lib/sproutcore/vendor/jsdoc/test/namespace_nested.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/test/nocode.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/test/oblit_anon.js +20 -0
- data/lib/sproutcore/vendor/jsdoc/test/overview.js +20 -0
- data/lib/sproutcore/vendor/jsdoc/test/param_inline.js +37 -0
- data/lib/sproutcore/vendor/jsdoc/test/params_optional.js +8 -0
- data/lib/sproutcore/vendor/jsdoc/test/prototype.js +17 -0
- data/lib/sproutcore/vendor/jsdoc/test/prototype_nested.js +9 -0
- data/lib/sproutcore/vendor/jsdoc/test/prototype_oblit.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/test/prototype_oblit_constructor.js +24 -0
- data/lib/sproutcore/vendor/jsdoc/test/public.js +10 -0
- data/lib/sproutcore/vendor/jsdoc/test/shared.js +42 -0
- data/lib/sproutcore/vendor/jsdoc/test/shared2.js +2 -0
- data/lib/sproutcore/vendor/jsdoc/test/shortcuts.js +22 -0
- data/lib/sproutcore/vendor/jsdoc/test/static_this.js +13 -0
- data/lib/sproutcore/vendor/jsdoc/test/synonyms.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/test/tosource.js +23 -0
- data/lib/sproutcore/vendor/jsdoc/test/variable_redefine.js +14 -0
- data/lib/sproutcore/vendor/yui-compressor/SCyuicompressor-2.4.2.jar +0 -0
- data/lib/sproutcore/vendor/yui-compressor/yuicompressor-2.4.2.jar +0 -0
- data/lib/sproutcore/version.rb +11 -0
- data/spec/buildtasks/build/copy_spec.rb +60 -0
- data/spec/buildtasks/build/spec_helper.rb +36 -0
- data/spec/buildtasks/manifest/catalog_spec.rb +48 -0
- data/spec/buildtasks/manifest/hide_buildfiles_spec.rb +126 -0
- data/spec/buildtasks/manifest/localize_spec.rb +97 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/bundle_spec.rb +254 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/combine_spec.rb +254 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/css_spec.rb +87 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/html_spec.rb +175 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/javascript_spec.rb +65 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/minify_spec.rb +70 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/packed_spec.rb +152 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/sass_spec.rb +98 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/strings_spec.rb +64 -0
- data/spec/buildtasks/manifest/prepare_build_tasks/tests_spec.rb +163 -0
- data/spec/buildtasks/manifest/prepare_spec.rb +43 -0
- data/spec/buildtasks/manifest/spec_helper.rb +35 -0
- data/spec/buildtasks/target_spec.rb +270 -0
- data/spec/fixtures/builder_tests/Buildfile +20 -0
- data/spec/fixtures/builder_tests/apps/bundle_test/bundle.js +1 -0
- data/spec/fixtures/builder_tests/apps/combine_test/a.js +1 -0
- data/spec/fixtures/builder_tests/apps/combine_test/b.js +1 -0
- data/spec/fixtures/builder_tests/apps/combine_test/c.js +1 -0
- data/spec/fixtures/builder_tests/apps/combine_test/english.lproj/a.css +1 -0
- data/spec/fixtures/builder_tests/apps/combine_test/english.lproj/b.css +1 -0
- data/spec/fixtures/builder_tests/apps/combine_test/english.lproj/c.css +1 -0
- data/spec/fixtures/builder_tests/apps/html_test/english.lproj/bar1_sample.rhtml +2 -0
- data/spec/fixtures/builder_tests/apps/html_test/english.lproj/erb_sample.html.erb +1 -0
- data/spec/fixtures/builder_tests/apps/html_test/english.lproj/icons/image.png +0 -0
- data/spec/fixtures/builder_tests/apps/html_test/english.lproj/image.jpg +0 -0
- data/spec/fixtures/builder_tests/apps/html_test/english.lproj/rhtml_sample.rhtml +1 -0
- data/spec/fixtures/builder_tests/apps/html_test/english.lproj/strings.js +4 -0
- data/spec/fixtures/builder_tests/apps/html_test/english.lproj/style.css +0 -0
- data/spec/fixtures/builder_tests/apps/html_test/french.lproj/french-icons/fr.png +0 -0
- data/spec/fixtures/builder_tests/apps/html_test/french.lproj/strings.js +4 -0
- data/spec/fixtures/builder_tests/apps/html_test/lib/layout_template.rhtml +1 -0
- data/spec/fixtures/builder_tests/apps/html_test/scripts.js +0 -0
- data/spec/fixtures/builder_tests/apps/javascript_test/sc_static.js +15 -0
- data/spec/fixtures/builder_tests/apps/javascript_test/sc_super.js +4 -0
- data/spec/fixtures/builder_tests/apps/javascript_test/strings.js +7 -0
- data/spec/fixtures/builder_tests/apps/less_test/sample.less +4 -0
- data/spec/fixtures/builder_tests/apps/sass_test/sample.sass +4 -0
- data/spec/fixtures/builder_tests/apps/sass_test/sample.scss +4 -0
- data/spec/fixtures/builder_tests/apps/strings_test/lproj/strings.js +8 -0
- data/spec/fixtures/builder_tests/apps/stylesheet_test/build_directives.css +9 -0
- data/spec/fixtures/builder_tests/apps/stylesheet_test/sc_static.css +12 -0
- data/spec/fixtures/builder_tests/apps/test_test/lib/alt_layout.rhtml +1 -0
- data/spec/fixtures/builder_tests/apps/test_test/lib/test_layout.rhtml +3 -0
- data/spec/fixtures/builder_tests/apps/test_test/tests/qunit_test.js +1 -0
- data/spec/fixtures/builder_tests/apps/test_test/tests/qunit_test2.js +1 -0
- data/spec/fixtures/builder_tests/apps/test_test/tests/rhtml_test.rhtml +4 -0
- data/spec/fixtures/builder_tests/frameworks/debug/core.js +0 -0
- data/spec/fixtures/builder_tests/frameworks/debug/english.lproj/dummy.css +0 -0
- data/spec/fixtures/builder_tests/frameworks/dynamic_req_target_1/dynamic_req_js_1.js +0 -0
- data/spec/fixtures/builder_tests/frameworks/dynamic_req_target_1/english.lproj/dynamic_req_style_1.css +0 -0
- data/spec/fixtures/builder_tests/frameworks/qunit/core.js +0 -0
- data/spec/fixtures/builder_tests/frameworks/qunit/english.lproj/dummy.css +0 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_1/english.lproj/req_style_1.css +0 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_1/english.lproj/strings.js +4 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_1/english.lproj/test.rhtml +1 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_1/req_js_1.js +0 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_2/english.lproj/req_style_2.css +0 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_2/english.lproj/test.rhtml +1 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_2/javascript.js +1 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_2/lib/alt_layout.rhtml +0 -0
- data/spec/fixtures/builder_tests/frameworks/req_target_2/req_js_2.js +0 -0
- data/spec/fixtures/builder_tests/themes/sample_theme/Buildfile +1 -0
- data/spec/fixtures/buildfiles/basic/Buildfile +11 -0
- data/spec/fixtures/buildfiles/basic/task_module.rake +6 -0
- data/spec/fixtures/buildfiles/installed/Buildfile +5 -0
- data/spec/fixtures/buildfiles/installed/Buildfile2 +5 -0
- data/spec/fixtures/buildfiles/project_test/Buildfile +4 -0
- data/spec/fixtures/buildfiles/project_test/not_project/Buildfile +2 -0
- data/spec/fixtures/buildfiles/project_test/not_project/child/PLACEHOLDER +0 -0
- data/spec/fixtures/entry_for_project/Buildfile +1 -0
- data/spec/fixtures/entry_for_project/apps/test_app/entry.txt +0 -0
- data/spec/fixtures/entry_for_project/apps/test_app/frameworks/nested/PLACEHOLDER +0 -0
- data/spec/fixtures/entry_for_project/frameworks/shared/PLACEHOLDER +0 -0
- data/spec/fixtures/entry_for_project/frameworks/unrelated/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/Buildfile +8 -0
- data/spec/fixtures/find_targets/custom/bars/bar1/bars/bar1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/bars/bar1/bars/bar2/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/bars/bar1/foos/foo1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/bars/bar1/foos/foo2/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/foos/custom_foos/Buildfile +5 -0
- data/spec/fixtures/find_targets/custom/foos/custom_foos/custom_foodir/foo1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/foos/custom_foos/custom_foodir/foo2/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/foos/custom_foos/foos/not_foo1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/foos/foo1/bars/bar1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/custom/foos/foo1/bars/bar2/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/nested/Buildfile +8 -0
- data/spec/fixtures/find_targets/nested/apps/app1/Buildfile +1 -0
- data/spec/fixtures/find_targets/nested/apps/app1/apps/nested_app/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/standard/Apps/app1/frameworks/framework1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/standard/Apps/app1/frameworks/framework2/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/standard/clients/client1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/standard/frameworks/framework1/frameworks/framework1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/standard/frameworks/framework2/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/standard/themes/theme1/PLACEHOLDER +0 -0
- data/spec/fixtures/find_targets/standard/themes/theme2/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/caps_long_names/English.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/caps_long_names/FreNCH.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/caps_long_names/UnknOWN.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/long_names/english.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/long_names/french.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/long_names/german.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/long_names/italian.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/long_names/japanese.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/long_names/spanish.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/long_names/unknown.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/no_names/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/de.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/en-CA.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/en-GB.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/en-US.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/en.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/es.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/foo.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/fr.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/it.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/languages/apps/short_names/ja.lproj/PLACEHOLDER +0 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/1.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/B.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/a.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/a/a.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/a/b.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/b/a.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/c.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/core.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/B.css +0 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/a.css +0 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/a/a.css +0 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/a/b.css +0 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/b/a.css +0 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/c.css +0 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/strings.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/main.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/resources/main_page.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/t.js +1 -0
- data/spec/fixtures/ordered_entries/apps/no_requires/utils.js +1 -0
- data/spec/fixtures/ordered_entries/apps/with_requires/a.js +2 -0
- data/spec/fixtures/ordered_entries/apps/with_requires/b.js +3 -0
- data/spec/fixtures/ordered_entries/apps/with_requires/c.js +2 -0
- data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/a.css +2 -0
- data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/b.css +2 -0
- data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/c.css +2 -0
- data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/d.js +1 -0
- data/spec/fixtures/real_world/Buildfile +12 -0
- data/spec/fixtures/real_world/apps/account/README +1 -0
- data/spec/fixtures/real_world/apps/calendar/README +1 -0
- data/spec/fixtures/real_world/apps/contacts/README_BEFORE_EDITING +1 -0
- data/spec/fixtures/real_world/apps/files/README +1 -0
- data/spec/fixtures/real_world/apps/mail/README +1 -0
- data/spec/fixtures/real_world/apps/mobile_photos/README +1 -0
- data/spec/fixtures/real_world/apps/photos/README +1 -0
- data/spec/fixtures/real_world/apps/uploader/README +1 -0
- data/spec/fixtures/real_world/frameworks/core_files/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/core_photos/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/shared/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/Buildfile +26 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/README +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/apps/docs/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/apps/test_runner/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/core.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/debug/debug-resource.html +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/debug/sample_debug.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/demo2.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/demo3.scss +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/debug/sample_debug-loc.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo.css +4 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo.html +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo2.sass +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo3.scss +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo4.less +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/file_extension_test.haml +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/file_extension_test.html.erb +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/file_extension_test.rhtml +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/fixtures/sample_fixtures-loc.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/has_require.css +4 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/no_require.css +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/no_sc_resource.rhtml +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/protocols/sample-loc.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/sc_resource.css +6 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/sc_resource.rhtml +3 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/strings.js +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/tests/sample-loc.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/fixtures/sample-json-fixture.json +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/fixtures/sample_fixtures.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/application/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/costello/core.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/data_store/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/debug/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/desktop/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/empty_theme/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/foundation/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/mobile/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/qunit/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/uploader/PLACEHOLDER +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/french.lproj/french-resource.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/french.lproj/strings.js +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/german.lproj/german-resource.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/german.lproj/strings.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/has_require.js +4 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/lib/index.html +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/no_require.js +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/protocols/sample.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/resources/boo.png +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/sc_resource.js +6 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/tests/nested/sample1.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/tests/nested/sample2.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/tests/sample.js +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/tests/sample.rhtml +1 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/themes/standard_theme/README +0 -0
- data/spec/fixtures/real_world/frameworks/sproutcore/views/view.js +1 -0
- data/spec/fixtures/real_world/generators/sample_custom/Buildfile +0 -0
- data/spec/fixtures/real_world/generators/sample_custom/templates/{filename}.js +1 -0
- data/spec/fixtures/recursive_project/Buildfile +8 -0
- data/spec/fixtures/recursive_project/frameworks/sproutcore/frameworks/costello/PLACEHOLDER +0 -0
- data/spec/lib/builders/bundle_spec.rb +295 -0
- data/spec/lib/builders/combine_spec.rb +67 -0
- data/spec/lib/builders/html_spec.rb +580 -0
- data/spec/lib/builders/javascript_spec.rb +82 -0
- data/spec/lib/builders/less_spec.rb +51 -0
- data/spec/lib/builders/sass_spec.rb +72 -0
- data/spec/lib/builders/spec_helper.rb +30 -0
- data/spec/lib/builders/strings_spec.rb +55 -0
- data/spec/lib/builders/stylesheet_spec.rb +64 -0
- data/spec/lib/builders/test_index_spec.rb +45 -0
- data/spec/lib/builders/test_spec.rb +137 -0
- data/spec/lib/buildfile/config_for_spec.rb +81 -0
- data/spec/lib/buildfile/define_spec.rb +59 -0
- data/spec/lib/buildfile/dup_spec.rb +65 -0
- data/spec/lib/buildfile/invoke_spec.rb +135 -0
- data/spec/lib/buildfile/load_spec.rb +51 -0
- data/spec/lib/buildfile/task/dup_spec.rb +55 -0
- data/spec/lib/buildfile/task_defined_spec.rb +17 -0
- data/spec/lib/buildfile_commands/build_task_spec.rb +19 -0
- data/spec/lib/buildfile_commands/config_spec.rb +97 -0
- data/spec/lib/buildfile_commands/import_spec.rb +17 -0
- data/spec/lib/buildfile_commands/namespace_spec.rb +18 -0
- data/spec/lib/buildfile_commands/proxies_spec.rb +38 -0
- data/spec/lib/buildfile_commands/replace_task_spec.rb +29 -0
- data/spec/lib/buildfile_commands/task_spec.rb +36 -0
- data/spec/lib/helpers/packing_optimizer/optimize_spec.rb +26 -0
- data/spec/lib/models/hash_struct/deep_clone_spec.rb +27 -0
- data/spec/lib/models/hash_struct/has_options_spec.rb +32 -0
- data/spec/lib/models/hash_struct/hash_spec.rb +29 -0
- data/spec/lib/models/hash_struct/merge_spec.rb +19 -0
- data/spec/lib/models/hash_struct/method_missing.rb +41 -0
- data/spec/lib/models/manifest/add_entry_spec.rb +36 -0
- data/spec/lib/models/manifest/add_transform_spec.rb +93 -0
- data/spec/lib/models/manifest/build_spec.rb +78 -0
- data/spec/lib/models/manifest/entry_for_spec.rb +94 -0
- data/spec/lib/models/manifest/find_entry.rb +109 -0
- data/spec/lib/models/manifest/prepare_spec.rb +62 -0
- data/spec/lib/models/manifest_entry/cacheable_url_spec.rb +31 -0
- data/spec/lib/models/manifest_entry/hyperdomain_prefix.rb +34 -0
- data/spec/lib/models/manifest_entry/prepare_spec.rb +54 -0
- data/spec/lib/models/project/add_target_spec.rb +44 -0
- data/spec/lib/models/project/buildfile_spec.rb +35 -0
- data/spec/lib/models/project/find_targets_for_spec.rb +78 -0
- data/spec/lib/models/project/load_nearest_project_spec.rb +23 -0
- data/spec/lib/models/project/target_for_spec.rb +33 -0
- data/spec/lib/models/project/targets_spec.rb +62 -0
- data/spec/lib/models/target/compute_build_number_spec.rb +126 -0
- data/spec/lib/models/target/config_spec.rb +30 -0
- data/spec/lib/models/target/expand_required_targets_spec.rb +48 -0
- data/spec/lib/models/target/installed_languages_spec.rb +47 -0
- data/spec/lib/models/target/lproj_for_spec.rb +38 -0
- data/spec/lib/models/target/manifest_for_spec.rb +42 -0
- data/spec/lib/models/target/parent_target_spec.rb +21 -0
- data/spec/lib/models/target/prepare_spec.rb +53 -0
- data/spec/lib/models/target/required_targets_spec.rb +129 -0
- data/spec/lib/models/target/target_for_spec.rb +56 -0
- data/spec/lib/tools/build_number_spec.rb +35 -0
- data/spec/lib/tools/gen_spec.rb +209 -0
- data/spec/lib/tools/tools_spec.rb +96 -0
- data/spec/spec.opts +4 -0
- data/spec/spec_helper.rb +138 -0
- data/sproutcore.gemspec +51 -0
- metadata +1897 -0
@@ -0,0 +1,1790 @@
|
|
1
|
+
// ==========================================================================
|
2
|
+
// Project: SproutCore - JavaScript Application Framework
|
3
|
+
// Copyright: ©2006-2010 Sprout Systems, Inc. and contributors.
|
4
|
+
// Portions ©2008-2010 Apple Inc. All rights reserved.
|
5
|
+
// License: Licensed under MIT license (see license.js)
|
6
|
+
// ==========================================================================
|
7
|
+
|
8
|
+
sc_require('views/scroller');
|
9
|
+
sc_require('mixins/border');
|
10
|
+
|
11
|
+
SC.NORMAL_SCROLL_DECELERATION = 0.95;
|
12
|
+
SC.FAST_SCROLL_DECELERATION = 0.85;
|
13
|
+
|
14
|
+
/** @class
|
15
|
+
|
16
|
+
Implements a complete scroll view. This class uses a manual implementation
|
17
|
+
of scrollers in order to properly support clipping frames.
|
18
|
+
|
19
|
+
Important Events:
|
20
|
+
|
21
|
+
- contentView frame size changes (to autoshow/hide scrollbar - adjust scrollbar size)
|
22
|
+
- horizontalScrollOffset change
|
23
|
+
- verticalScrollOffsetChanges
|
24
|
+
- scroll wheel events
|
25
|
+
|
26
|
+
@extends SC.View
|
27
|
+
@since SproutCore 1.0
|
28
|
+
*/
|
29
|
+
SC.ScrollView = SC.View.extend(SC.Border, {
|
30
|
+
/** @scope SC.ScrollView.prototype */
|
31
|
+
classNames: ['sc-scroll-view'],
|
32
|
+
|
33
|
+
// ..........................................................
|
34
|
+
// PROPERTIES
|
35
|
+
//
|
36
|
+
|
37
|
+
isScrollable: YES,
|
38
|
+
|
39
|
+
/**
|
40
|
+
The content view you want the scroll view to manage. This will be assigned to the contentView of the clipView also.
|
41
|
+
*/
|
42
|
+
contentView: null,
|
43
|
+
|
44
|
+
/**
|
45
|
+
The horizontal alignment for non-filling content inside of the ScrollView.
|
46
|
+
*/
|
47
|
+
horizontalAlign: SC.ALIGN_LEFT,
|
48
|
+
|
49
|
+
/**
|
50
|
+
The vertical alignment for non-filling content inside of the ScrollView.
|
51
|
+
*/
|
52
|
+
verticalAlign: SC.ALIGN_TOP,
|
53
|
+
|
54
|
+
/**
|
55
|
+
The current horizontal scroll offset. Changing this value will update both the contentView and the horizontal scroller, if there is one.
|
56
|
+
*/
|
57
|
+
horizontalScrollOffset: function(key, value) {
|
58
|
+
if (value !== undefined) {
|
59
|
+
var minOffset = this.minimumHorizontalScrollOffset(),
|
60
|
+
maxOffset = this.get('maximumHorizontalScrollOffset');
|
61
|
+
this._scroll_horizontalScrollOffset = Math.max(minOffset,Math.min(maxOffset, value)) ;
|
62
|
+
}
|
63
|
+
|
64
|
+
return this._scroll_horizontalScrollOffset||0;
|
65
|
+
}.property().cacheable(),
|
66
|
+
|
67
|
+
/**
|
68
|
+
The current vertical scroll offset. Changing this value will update both the contentView and the vertical scroller, if there is one.
|
69
|
+
*/
|
70
|
+
verticalScrollOffset: function(key, value) {
|
71
|
+
if (value !== undefined) {
|
72
|
+
var minOffset = this.get('minimumVerticalScrollOffset'),
|
73
|
+
maxOffset = this.get('maximumVerticalScrollOffset');
|
74
|
+
this._scroll_verticalScrollOffset = Math.max(minOffset,Math.min(maxOffset, value)) ;
|
75
|
+
}
|
76
|
+
|
77
|
+
return this._scroll_verticalScrollOffset||0;
|
78
|
+
}.property().cacheable(),
|
79
|
+
|
80
|
+
/**
|
81
|
+
@private
|
82
|
+
Calculates the maximum offset given content and container sizes, and the
|
83
|
+
alignment.
|
84
|
+
*/
|
85
|
+
maximumScrollOffset: function(contentSize, containerSize, align) {
|
86
|
+
// if our content size is larger than or the same size as the container, it's quite
|
87
|
+
// simple to calculate the answer. Otherwise, we need to do some fancy-pants
|
88
|
+
// alignment logic (read: simple math)
|
89
|
+
if (contentSize >= containerSize) return contentSize - containerSize;
|
90
|
+
|
91
|
+
// alignment, yeah
|
92
|
+
if (align === SC.ALIGN_LEFT || align === SC.ALIGN_TOP) {
|
93
|
+
// if we left-align something, and it is smaller than the view, does that not mean
|
94
|
+
// that it's maximum (and minimum) offset is 0, because it should be positioned at 0?
|
95
|
+
return 0;
|
96
|
+
} else if (align === SC.ALIGN_MIDDLE || align === SC.ALIGN_CENTER) {
|
97
|
+
// middle align means the difference divided by two, because we want equal parts on each side.
|
98
|
+
return 0 - Math.round((containerSize - contentSize) / 2);
|
99
|
+
} else {
|
100
|
+
// right align means the entire difference, because we want all that space on the left
|
101
|
+
return 0 - (containerSize - contentSize);
|
102
|
+
}
|
103
|
+
},
|
104
|
+
|
105
|
+
/**
|
106
|
+
@private
|
107
|
+
Calculates the minimum offset given content and container sizes, and the
|
108
|
+
alignment.
|
109
|
+
*/
|
110
|
+
minimumScrollOffset: function(contentSize, containerSize, align) {
|
111
|
+
// if the content is larger than the container, we have no need to change the minimum
|
112
|
+
// away from the natural 0 position.
|
113
|
+
if (contentSize > containerSize) return 0;
|
114
|
+
|
115
|
+
// alignment, yeah
|
116
|
+
if (align === SC.ALIGN_LEFT || align === SC.ALIGN_TOP) {
|
117
|
+
// if we left-align something, and it is smaller than the view, does that not mean
|
118
|
+
// that it's maximum (and minimum) offset is 0, because it should be positioned at 0?
|
119
|
+
return 0;
|
120
|
+
} else if (align === SC.ALIGN_MIDDLE || align === SC.ALIGN_CENTER) {
|
121
|
+
// middle align means the difference divided by two, because we want equal parts on each side.
|
122
|
+
return 0 - Math.round((containerSize - contentSize) / 2);
|
123
|
+
} else {
|
124
|
+
// right align means the entire difference, because we want all that space on the left
|
125
|
+
return 0 - (containerSize - contentSize);
|
126
|
+
}
|
127
|
+
},
|
128
|
+
|
129
|
+
/**
|
130
|
+
The maximum horizontal scroll offset allowed given the current contentView
|
131
|
+
size and the size of the scroll view. If horizontal scrolling is
|
132
|
+
disabled, this will always return 0.
|
133
|
+
|
134
|
+
@property {Number}
|
135
|
+
*/
|
136
|
+
maximumHorizontalScrollOffset: function() {
|
137
|
+
var view = this.get('contentView'),
|
138
|
+
contentWidth = 0, calculatedWidth = 0;
|
139
|
+
|
140
|
+
if (view && view.get('frame')) contentWidth = view.get('frame').width;
|
141
|
+
if (view) calculatedWidth = view.calculatedWidth || 0;
|
142
|
+
|
143
|
+
// The following code checks if there is a calculatedWidth (collections)
|
144
|
+
// to avoid looking at the incorrect value calculated by frame.
|
145
|
+
if(view && view.calculatedWidth && view.calculatedWidth!==0){
|
146
|
+
contentWidth = view.calculatedWidth;
|
147
|
+
}
|
148
|
+
contentWidth *= this._scale;
|
149
|
+
|
150
|
+
var containerWidth = this.get('containerView').get('frame').width ;
|
151
|
+
|
152
|
+
// we still must go through minimumScrollOffset even if we can't scroll
|
153
|
+
// because we need to adjust for alignment. So, just make sure it won't allow scrolling.
|
154
|
+
if (!this.get('canScrollHorizontal')) contentWidth = Math.min(contentWidth, containerWidth);
|
155
|
+
return this.maximumScrollOffset(contentWidth, containerWidth, this.get("horizontalAlign"));
|
156
|
+
}.property(),
|
157
|
+
|
158
|
+
/**
|
159
|
+
The maximum vertical scroll offset allowed given the current contentView
|
160
|
+
size and the size of the scroll view. If vertical scrolling is disabled,
|
161
|
+
this will always return 0 (or whatever alignment dictates).
|
162
|
+
|
163
|
+
@property {Number}
|
164
|
+
*/
|
165
|
+
maximumVerticalScrollOffset: function() {
|
166
|
+
var view = this.get('contentView'),
|
167
|
+
contentHeight = 0, calculatedHeight = 0;
|
168
|
+
|
169
|
+
if (view && view.get('frame')) contentHeight = view.get('frame').height;
|
170
|
+
if (view) calculatedHeight = view.calculatedHeight || 0;
|
171
|
+
|
172
|
+
// The following code checks if there is a calculatedWidth (collections)
|
173
|
+
// to avoid looking at the incorrect value calculated by frame.
|
174
|
+
if(view && view.calculatedHeight && view.calculatedHeight!==0){
|
175
|
+
contentHeight = view.calculatedHeight;
|
176
|
+
}
|
177
|
+
contentHeight *= this._scale;
|
178
|
+
|
179
|
+
var containerHeight = this.get('containerView').get('frame').height ;
|
180
|
+
|
181
|
+
// we still must go through minimumScrollOffset even if we can't scroll
|
182
|
+
// because we need to adjust for alignment. So, just make sure it won't allow scrolling.
|
183
|
+
if (!this.get('canScrollVertical')) contentHeight = Math.min(contentHeight, containerHeight);
|
184
|
+
return this.maximumScrollOffset(contentHeight, containerHeight, this.get("verticalAlign"));
|
185
|
+
}.property(),
|
186
|
+
|
187
|
+
|
188
|
+
/**
|
189
|
+
The minimum horizontal scroll offset allowed given the current contentView
|
190
|
+
size and the size of the scroll view. If horizontal scrolling is
|
191
|
+
disabled, this will always return 0 (or whatever alignment dictates).
|
192
|
+
|
193
|
+
@property {Number}
|
194
|
+
*/
|
195
|
+
minimumHorizontalScrollOffset: function() {
|
196
|
+
var view = this.get('contentView') ;
|
197
|
+
var contentWidth = view ? view.get('frame').width : 0 ;
|
198
|
+
|
199
|
+
// The following code checks if there is a calculatedWidth (collections)
|
200
|
+
// to avoid looking at the incorrect value calculated by frame.
|
201
|
+
if(view && view.calculatedWidth && view.calculatedWidth!==0){
|
202
|
+
contentWidth = view.calculatedWidth;
|
203
|
+
}
|
204
|
+
contentWidth *= this._scale;
|
205
|
+
|
206
|
+
var containerWidth = this.get('containerView').get('frame').width ;
|
207
|
+
|
208
|
+
// we still must go through minimumScrollOffset even if we can't scroll
|
209
|
+
// because we need to adjust for alignment. So, just make sure it won't allow scrolling.
|
210
|
+
if (!this.get('canScrollHorizontal')) contentWidth = Math.min(contentWidth, containerWidth);
|
211
|
+
return this.minimumScrollOffset(contentWidth, containerWidth, this.get("horizontalAlign"));
|
212
|
+
}.property(),
|
213
|
+
|
214
|
+
/**
|
215
|
+
The minimum vertical scroll offset allowed given the current contentView
|
216
|
+
size and the size of the scroll view. If vertical scrolling is disabled,
|
217
|
+
this will always return 0 (or whatever alignment dictates).
|
218
|
+
|
219
|
+
@property {Number}
|
220
|
+
*/
|
221
|
+
minimumVerticalScrollOffset: function() {
|
222
|
+
var view = this.get('contentView') ;
|
223
|
+
var contentHeight = (view && view.get('frame')) ? view.get('frame').height : 0 ;
|
224
|
+
|
225
|
+
// The following code checks if there is a calculatedWidth (collections)
|
226
|
+
// to avoid looking at the incorrect value calculated by frame.
|
227
|
+
if(view && view.calculatedHeight && view.calculatedHeight!==0){
|
228
|
+
contentHeight = view.calculatedHeight;
|
229
|
+
}
|
230
|
+
contentHeight *= this._scale;
|
231
|
+
|
232
|
+
var containerHeight = this.get('containerView').get('frame').height ;
|
233
|
+
|
234
|
+
// we still must go through minimumScrollOffset even if we can't scroll
|
235
|
+
// because we need to adjust for alignment. So, just make sure it won't allow scrolling.
|
236
|
+
if (!this.get('canScrollVertical')) contentHeight = Math.min(contentHeight, containerHeight);
|
237
|
+
return this.minimumScrollOffset(contentHeight, containerHeight, this.get("verticalAlign"));
|
238
|
+
}.property(),
|
239
|
+
|
240
|
+
|
241
|
+
|
242
|
+
/**
|
243
|
+
Amount to scroll one vertical line.
|
244
|
+
|
245
|
+
Used by the default implementation of scrollDownLine() and scrollUpLine().
|
246
|
+
Defaults to 20px.
|
247
|
+
*/
|
248
|
+
verticalLineScroll: 20,
|
249
|
+
|
250
|
+
/**
|
251
|
+
Amount to scroll one horizontal line.
|
252
|
+
|
253
|
+
Used by the default implementation of scrollLeftLine() and
|
254
|
+
scrollRightLine(). Defaults to 20px.
|
255
|
+
*/
|
256
|
+
horizontalLineScroll: 20,
|
257
|
+
|
258
|
+
/**
|
259
|
+
Amount to scroll one vertical page.
|
260
|
+
|
261
|
+
Used by the default implementation of scrollUpPage() and scrollDownPage().
|
262
|
+
Defaults to current frame height.
|
263
|
+
*/
|
264
|
+
verticalPageScroll: function() {
|
265
|
+
return this.get('frame').height ;
|
266
|
+
}.property('frame'),
|
267
|
+
|
268
|
+
/**
|
269
|
+
Amount to scroll one horizontal page.
|
270
|
+
|
271
|
+
Used by the default implementation of scrollLeftPage() and
|
272
|
+
scrollRightPage(). Defaults to current innerFrame width.
|
273
|
+
*/
|
274
|
+
horizontalPageScroll: function() {
|
275
|
+
return this.get('frame').width ;
|
276
|
+
}.property('frame'),
|
277
|
+
|
278
|
+
// ..........................................................
|
279
|
+
// SCROLLERS
|
280
|
+
//
|
281
|
+
|
282
|
+
/**
|
283
|
+
YES if the view should maintain a horizontal scroller. This property
|
284
|
+
must be set when the view is created.
|
285
|
+
|
286
|
+
@property {Boolean}
|
287
|
+
*/
|
288
|
+
hasHorizontalScroller: YES,
|
289
|
+
|
290
|
+
/**
|
291
|
+
The horizontal scroller view class. This will be replaced with a view
|
292
|
+
instance when the ScrollView is created unless hasHorizontalScroller is
|
293
|
+
NO.
|
294
|
+
|
295
|
+
@property {SC.View}
|
296
|
+
*/
|
297
|
+
horizontalScrollerView: SC.ScrollerView,
|
298
|
+
|
299
|
+
/**
|
300
|
+
The horizontal scroller view for touch. This will be replaced with a view
|
301
|
+
instance when touch is enabled when the ScrollView is created unless
|
302
|
+
hasHorizontalScroller is NO.
|
303
|
+
*/
|
304
|
+
horizontalTouchScrollerView: SC.TouchScrollerView,
|
305
|
+
|
306
|
+
/**
|
307
|
+
YES if the horizontal scroller should be visible. You can change this
|
308
|
+
property value anytime to show or hide the horizontal scroller. If you
|
309
|
+
do not want to use a horizontal scroller at all, you should instead set
|
310
|
+
hasHorizontalScroller to NO to avoid creating a scroller view in the
|
311
|
+
first place.
|
312
|
+
|
313
|
+
@property {Boolean}
|
314
|
+
*/
|
315
|
+
isHorizontalScrollerVisible: YES,
|
316
|
+
|
317
|
+
/**
|
318
|
+
Returns YES if the view both has a horizontal scroller, the scroller is
|
319
|
+
visible.
|
320
|
+
|
321
|
+
@property {Boolean}
|
322
|
+
*/
|
323
|
+
canScrollHorizontal: function() {
|
324
|
+
return !!(this.get('hasHorizontalScroller') &&
|
325
|
+
this.get('horizontalScrollerView') &&
|
326
|
+
this.get('isHorizontalScrollerVisible')) ;
|
327
|
+
}.property('isHorizontalScrollerVisible').cacheable(),
|
328
|
+
|
329
|
+
/**
|
330
|
+
If YES, the horizontal scroller will autohide if the contentView is
|
331
|
+
smaller than the visible area. You must set hasHorizontalScroller to YES
|
332
|
+
for this property to have any effect.
|
333
|
+
*/
|
334
|
+
autohidesHorizontalScroller: YES,
|
335
|
+
|
336
|
+
/**
|
337
|
+
YES if the view shuld maintain a vertical scroller. This property must
|
338
|
+
be set when the view is created.
|
339
|
+
|
340
|
+
@property {Boolean}
|
341
|
+
*/
|
342
|
+
hasVerticalScroller: YES,
|
343
|
+
|
344
|
+
/**
|
345
|
+
The vertical scroller view class. This will be replaced with a view
|
346
|
+
instance when the ScrollView is created unless hasVerticalScroller is NO.
|
347
|
+
|
348
|
+
@property {SC.View}
|
349
|
+
*/
|
350
|
+
verticalScrollerView: SC.ScrollerView,
|
351
|
+
|
352
|
+
/**
|
353
|
+
The vertical touch scroller view class. This will be replaced with a view
|
354
|
+
instance when the ScrollView is created.
|
355
|
+
*/
|
356
|
+
verticalTouchScrollerView: SC.TouchScrollerView,
|
357
|
+
|
358
|
+
/**
|
359
|
+
YES if the vertical scroller should be visible. You can change this
|
360
|
+
property value anytime to show or hide the vertical scroller. If you do
|
361
|
+
not want to use a vertical scroller at all, you should instead set
|
362
|
+
hasVerticalScroller to NO to avoid creating a scroller view in the first
|
363
|
+
place.
|
364
|
+
|
365
|
+
@property {Boolean}
|
366
|
+
*/
|
367
|
+
isVerticalScrollerVisible: YES,
|
368
|
+
|
369
|
+
/**
|
370
|
+
Returns YES if the view both has a horizontal scroller, the scroller is
|
371
|
+
visible.
|
372
|
+
|
373
|
+
@property {Boolean}
|
374
|
+
*/
|
375
|
+
canScrollVertical: function() {
|
376
|
+
return !!(this.get('hasVerticalScroller') &&
|
377
|
+
this.get('verticalScrollerView') &&
|
378
|
+
this.get('isVerticalScrollerVisible')) ;
|
379
|
+
}.property('isVerticalScrollerVisible').cacheable(),
|
380
|
+
|
381
|
+
/**
|
382
|
+
If YES, the vertical scroller will autohide if the contentView is
|
383
|
+
smaller than the visible area. You must set hasVerticalScroller to YES
|
384
|
+
for this property to have any effect.
|
385
|
+
*/
|
386
|
+
autohidesVerticalScroller: YES,
|
387
|
+
|
388
|
+
/**
|
389
|
+
Use this property to set the 'bottom' offset of your vertical scroller,
|
390
|
+
to make room for a thumb view or other accessory view. Default is 0.
|
391
|
+
|
392
|
+
@property {Number}
|
393
|
+
*/
|
394
|
+
verticalScrollerBottom: 0,
|
395
|
+
|
396
|
+
/**
|
397
|
+
Use this to overlay the vertical scroller.
|
398
|
+
|
399
|
+
This ensures that the container frame will not resize to accomodate the
|
400
|
+
vertical scroller, hence overlaying the scroller on top of
|
401
|
+
the container.
|
402
|
+
|
403
|
+
@property {Boolean}
|
404
|
+
*/
|
405
|
+
verticalOverlay: function() {
|
406
|
+
if (SC.platform.touch) return YES;
|
407
|
+
return NO;
|
408
|
+
}.property().cacheable(),
|
409
|
+
|
410
|
+
/**
|
411
|
+
Use this to overlay the horizontal scroller.
|
412
|
+
|
413
|
+
This ensures that the container frame will not resize to accomodate the
|
414
|
+
horizontal scroller, hence overlaying the scroller on top of
|
415
|
+
the container
|
416
|
+
|
417
|
+
@property {Boolean}
|
418
|
+
*/
|
419
|
+
horizontalOverlay: function() {
|
420
|
+
if (SC.platform.touch) return YES;
|
421
|
+
return NO;
|
422
|
+
}.property().cacheable(),
|
423
|
+
|
424
|
+
/**
|
425
|
+
Use to control the positioning of the vertical scroller. If you do not
|
426
|
+
set 'verticalOverlay' to YES, then the content view will be automatically
|
427
|
+
sized to meet the left edge of the vertical scroller, wherever it may be.
|
428
|
+
This allows you to easily, for example, have “one pixel higher and one
|
429
|
+
pixel lower” scroll bars that blend into their parent views.
|
430
|
+
|
431
|
+
If you do set 'verticalOverlay' to YES, then the scroller view will
|
432
|
+
“float on top” of the content view.
|
433
|
+
|
434
|
+
Example: { top: -1, bottom: -1, right: 0 }
|
435
|
+
*/
|
436
|
+
verticalScrollerLayout: null,
|
437
|
+
|
438
|
+
/**
|
439
|
+
Use to control the positioning of the horizontal scroller. If you do not
|
440
|
+
set 'horizontalOverlay' to YES, then the content view will be
|
441
|
+
automatically sized to meet the top edge of the horizontal scroller,
|
442
|
+
wherever it may be.
|
443
|
+
|
444
|
+
If you do set 'horizontalOverlay' to YES, then the scroller view will
|
445
|
+
“float on top” of the content view.
|
446
|
+
|
447
|
+
Example: { left: 0, bottom: 0, right: 0 }
|
448
|
+
*/
|
449
|
+
horizontalScrollerLayout: null,
|
450
|
+
|
451
|
+
// ..........................................................
|
452
|
+
// CUSTOM VIEWS
|
453
|
+
//
|
454
|
+
|
455
|
+
/**
|
456
|
+
The container view that will contain your main content view. You can
|
457
|
+
replace this property with your own custom subclass if you prefer.
|
458
|
+
|
459
|
+
@type {SC.ContainerView}
|
460
|
+
*/
|
461
|
+
containerView: SC.ContainerView.extend({
|
462
|
+
|
463
|
+
}),
|
464
|
+
|
465
|
+
// ..........................................................
|
466
|
+
// METHODS
|
467
|
+
//
|
468
|
+
|
469
|
+
/**
|
470
|
+
Scrolls the receiver to the specified x,y coordinate. This should be the
|
471
|
+
offset into the contentView you want to appear at the top-left corner of
|
472
|
+
the scroll view.
|
473
|
+
|
474
|
+
This method will contrain the actual scroll based on whether the view
|
475
|
+
can scroll in the named direction and the maximum distance it can
|
476
|
+
scroll.
|
477
|
+
|
478
|
+
If you only want to scroll in one direction, pass null for the other
|
479
|
+
direction. You can also optionally pass a Hash for the first parameter
|
480
|
+
with x and y coordinates.
|
481
|
+
|
482
|
+
@param x {Number} the x scroll location
|
483
|
+
@param y {Number} the y scroll location
|
484
|
+
@returns {SC.ScrollView} receiver
|
485
|
+
*/
|
486
|
+
scrollTo: function(x,y) {
|
487
|
+
// normalize params
|
488
|
+
if (y===undefined && SC.typeOf(x) === SC.T_HASH) {
|
489
|
+
y = x.y; x = x.x;
|
490
|
+
}
|
491
|
+
|
492
|
+
if (!SC.none(x)) {
|
493
|
+
x = Math.max(this.get('minimumHorizontalScrollOffset'),Math.min(this.get('maximumHorizontalScrollOffset'), x)) ;
|
494
|
+
this.set('horizontalScrollOffset', x) ;
|
495
|
+
}
|
496
|
+
|
497
|
+
if (!SC.none(y)) {
|
498
|
+
y = Math.max(this.get('minimumVerticalScrollOffset'),Math.min(this.get('maximumVerticalScrollOffset'), y)) ;
|
499
|
+
this.set('verticalScrollOffset', y) ;
|
500
|
+
}
|
501
|
+
|
502
|
+
return this ;
|
503
|
+
},
|
504
|
+
|
505
|
+
/**
|
506
|
+
Scrolls the receiver in the horizontal and vertical directions by the
|
507
|
+
amount specified, if allowed. The actual scroll amount will be
|
508
|
+
constrained by the current scroll view settings.
|
509
|
+
|
510
|
+
If you only want to scroll in one direction, pass null or 0 for the other
|
511
|
+
direction. You can also optionally pass a Hash for the first parameter
|
512
|
+
with x and y coordinates.
|
513
|
+
|
514
|
+
@param x {Number} change in the x direction (or hash)
|
515
|
+
@param y {Number} change in the y direction
|
516
|
+
@returns {SC.ScrollView} receiver
|
517
|
+
*/
|
518
|
+
scrollBy: function(x , y) {
|
519
|
+
// normalize params
|
520
|
+
if (y===undefined && SC.typeOf(x) === SC.T_HASH) {
|
521
|
+
y = x.y; x = x.x;
|
522
|
+
}
|
523
|
+
|
524
|
+
// if null, undefined, or 0, pass null; otherwise just add current offset
|
525
|
+
x = (x) ? this.get('horizontalScrollOffset')+x : null ;
|
526
|
+
y = (y) ? this.get('verticalScrollOffset')+y : null ;
|
527
|
+
return this.scrollTo(x,y) ;
|
528
|
+
},
|
529
|
+
|
530
|
+
/**
|
531
|
+
Scroll the view to make the view's frame visible. For this to make sense,
|
532
|
+
the view should be a subview of the contentView. Otherwise the results
|
533
|
+
will be undefined.
|
534
|
+
|
535
|
+
@param {SC.View} view view to scroll or null to scroll receiver visible
|
536
|
+
@returns {Boolean} YES if scroll position was changed
|
537
|
+
*/
|
538
|
+
scrollToVisible: function(view) {
|
539
|
+
|
540
|
+
// if no view is passed, do default
|
541
|
+
if (arguments.length === 0) return sc_super();
|
542
|
+
|
543
|
+
var contentView = this.get('contentView') ;
|
544
|
+
if (!contentView) return NO; // nothing to do if no contentView.
|
545
|
+
|
546
|
+
// get the frame for the view - should work even for views with static
|
547
|
+
// layout, assuming it has been added to the screen.
|
548
|
+
var vf = view.get('frame');
|
549
|
+
if (!vf) return NO; // nothing to do
|
550
|
+
|
551
|
+
// convert view's frame to an offset from the contentView origin. This
|
552
|
+
// will become the new scroll offset after some adjustment.
|
553
|
+
vf = contentView.convertFrameFromView(vf, view.get('parentView')) ;
|
554
|
+
|
555
|
+
return this.scrollToRect(vf);
|
556
|
+
},
|
557
|
+
|
558
|
+
/**
|
559
|
+
Scroll to the supplied rectangle.
|
560
|
+
@param {rect} Rectangle to scroll to.
|
561
|
+
@returns {Boolean} YES if scroll position was changed.
|
562
|
+
*/
|
563
|
+
scrollToRect: function(rect) {
|
564
|
+
// find current visible frame.
|
565
|
+
var vo = SC.cloneRect(this.get('containerView').get('frame')) ;
|
566
|
+
|
567
|
+
vo.x = this.get('horizontalScrollOffset') ;
|
568
|
+
vo.y = this.get('verticalScrollOffset') ;
|
569
|
+
|
570
|
+
var origX = vo.x, origY = vo.y;
|
571
|
+
|
572
|
+
// if top edge is not visible, shift origin
|
573
|
+
vo.y -= Math.max(0, SC.minY(vo) - SC.minY(rect)) ;
|
574
|
+
vo.x -= Math.max(0, SC.minX(vo) - SC.minX(rect)) ;
|
575
|
+
|
576
|
+
// if bottom edge is not visible, shift origin
|
577
|
+
vo.y += Math.max(0, SC.maxY(rect) - SC.maxY(vo)) ;
|
578
|
+
vo.x += Math.max(0, SC.maxX(rect) - SC.maxX(vo)) ;
|
579
|
+
|
580
|
+
// scroll to that origin.
|
581
|
+
if ((origX !== vo.x) || (origY !== vo.y)) {
|
582
|
+
this.scrollTo(vo.x, vo.y);
|
583
|
+
return YES ;
|
584
|
+
} else return NO;
|
585
|
+
},
|
586
|
+
|
587
|
+
|
588
|
+
/**
|
589
|
+
Scrolls the receiver down one or more lines if allowed. If number of
|
590
|
+
lines is not specified, scrolls one line.
|
591
|
+
|
592
|
+
@param lines {Number} options number of lines
|
593
|
+
@returns {SC.ScrollView} receiver
|
594
|
+
*/
|
595
|
+
scrollDownLine: function(lines) {
|
596
|
+
if (lines === undefined) lines = 1 ;
|
597
|
+
return this.scrollBy(null, this.get('verticalLineScroll')*lines) ;
|
598
|
+
},
|
599
|
+
|
600
|
+
/**
|
601
|
+
Scrolls the receiver up one or more lines if allowed. If number of
|
602
|
+
lines is not specified, scrolls one line.
|
603
|
+
|
604
|
+
@param lines {Number} options number of lines
|
605
|
+
@returns {SC.ScrollView} receiver
|
606
|
+
*/
|
607
|
+
scrollUpLine: function(lines) {
|
608
|
+
if (lines === undefined) lines = 1 ;
|
609
|
+
return this.scrollBy(null, 0-this.get('verticalLineScroll')*lines) ;
|
610
|
+
},
|
611
|
+
|
612
|
+
/**
|
613
|
+
Scrolls the receiver right one or more lines if allowed. If number of
|
614
|
+
lines is not specified, scrolls one line.
|
615
|
+
|
616
|
+
@param lines {Number} options number of lines
|
617
|
+
@returns {SC.ScrollView} receiver
|
618
|
+
*/
|
619
|
+
scrollRightLine: function(lines) {
|
620
|
+
if (lines === undefined) lines = 1 ;
|
621
|
+
return this.scrollTo(this.get('horizontalLineScroll')*lines, null) ;
|
622
|
+
},
|
623
|
+
|
624
|
+
/**
|
625
|
+
Scrolls the receiver left one or more lines if allowed. If number of
|
626
|
+
lines is not specified, scrolls one line.
|
627
|
+
|
628
|
+
@param lines {Number} options number of lines
|
629
|
+
@returns {SC.ScrollView} receiver
|
630
|
+
*/
|
631
|
+
scrollLeftLine: function(lines) {
|
632
|
+
if (lines === undefined) lines = 1 ;
|
633
|
+
return this.scrollTo(0-this.get('horizontalLineScroll')*lines, null) ;
|
634
|
+
},
|
635
|
+
|
636
|
+
/**
|
637
|
+
Scrolls the receiver down one or more page if allowed. If number of
|
638
|
+
pages is not specified, scrolls one page. The page size is determined by
|
639
|
+
the verticalPageScroll value. By default this is the size of the current
|
640
|
+
scrollable area.
|
641
|
+
|
642
|
+
@param pages {Number} options number of pages
|
643
|
+
@returns {SC.ScrollView} receiver
|
644
|
+
*/
|
645
|
+
scrollDownPage: function(pages) {
|
646
|
+
if (pages === undefined) pages = 1 ;
|
647
|
+
return this.scrollBy(null, this.get('verticalPageScroll')*pages) ;
|
648
|
+
},
|
649
|
+
|
650
|
+
/**
|
651
|
+
Scrolls the receiver up one or more page if allowed. If number of
|
652
|
+
pages is not specified, scrolls one page. The page size is determined by
|
653
|
+
the verticalPageScroll value. By default this is the size of the current
|
654
|
+
scrollable area.
|
655
|
+
|
656
|
+
@param pages {Number} options number of pages
|
657
|
+
@returns {SC.ScrollView} receiver
|
658
|
+
*/
|
659
|
+
scrollUpPage: function(pages) {
|
660
|
+
if (pages === undefined) pages = 1 ;
|
661
|
+
return this.scrollBy(null, 0-(this.get('verticalPageScroll')*pages)) ;
|
662
|
+
},
|
663
|
+
|
664
|
+
/**
|
665
|
+
Scrolls the receiver right one or more page if allowed. If number of
|
666
|
+
pages is not specified, scrolls one page. The page size is determined by
|
667
|
+
the verticalPageScroll value. By default this is the size of the current
|
668
|
+
scrollable area.
|
669
|
+
|
670
|
+
@param pages {Number} options number of pages
|
671
|
+
@returns {SC.ScrollView} receiver
|
672
|
+
*/
|
673
|
+
scrollRightPage: function(pages) {
|
674
|
+
if (pages === undefined) pages = 1 ;
|
675
|
+
return this.scrollBy(this.get('horizontalPageScroll')*pages, null) ;
|
676
|
+
},
|
677
|
+
|
678
|
+
/**
|
679
|
+
Scrolls the receiver left one or more page if allowed. If number of
|
680
|
+
pages is not specified, scrolls one page. The page size is determined by
|
681
|
+
the verticalPageScroll value. By default this is the size of the current
|
682
|
+
scrollable area.
|
683
|
+
|
684
|
+
@param pages {Number} options number of pages
|
685
|
+
@returns {SC.ScrollView} receiver
|
686
|
+
*/
|
687
|
+
scrollLeftPage: function(pages) {
|
688
|
+
if (pages === undefined) pages = 1 ;
|
689
|
+
return this.scrollBy(0-(this.get('horizontalPageScroll')*pages), null) ;
|
690
|
+
},
|
691
|
+
|
692
|
+
/**
|
693
|
+
Adjusts the layout for the various internal views. This method is called
|
694
|
+
once when the scroll view is first configured and then anytime a scroller
|
695
|
+
is shown or hidden. You can call this method yourself as well to retile.
|
696
|
+
|
697
|
+
You may also want to override this method to handle layout for any
|
698
|
+
additional controls you have added to the view.
|
699
|
+
*/
|
700
|
+
tile: function() {
|
701
|
+
// get horizontal scroller/determine if we should have a scroller
|
702
|
+
var hscroll = this.get('hasHorizontalScroller') ? this.get('horizontalScrollerView') : null ;
|
703
|
+
var hasHorizontal = hscroll && this.get('isHorizontalScrollerVisible');
|
704
|
+
|
705
|
+
// get vertical scroller/determine if we should have a scroller
|
706
|
+
var vscroll = this.get('hasVerticalScroller') ? this.get('verticalScrollerView') : null ;
|
707
|
+
var hasVertical = vscroll && this.get('isVerticalScrollerVisible') ;
|
708
|
+
|
709
|
+
// get the containerView
|
710
|
+
var clip = this.get('containerView') ;
|
711
|
+
var clipLayout = { left: 0, top: 0 } ;
|
712
|
+
var t, layout, vo, ho, vl, hl;
|
713
|
+
|
714
|
+
var ht = ((hasHorizontal) ? hscroll.get('scrollbarThickness') : 0) ;
|
715
|
+
var vt = (hasVertical) ? vscroll.get('scrollbarThickness') : 0 ;
|
716
|
+
|
717
|
+
if (hasHorizontal) {
|
718
|
+
hl = this.get('horizontalScrollerLayout');
|
719
|
+
layout = {
|
720
|
+
left: (hl ? hl.left : 0),
|
721
|
+
bottom: (hl ? hl.bottom : 0),
|
722
|
+
right: (hl ? hl.right + vt-1 : vt-1),
|
723
|
+
height: ht
|
724
|
+
};
|
725
|
+
hscroll.set('layout', layout) ;
|
726
|
+
ho = this.get('horizontalOverlay');
|
727
|
+
clipLayout.bottom = ho ? 0 : (layout.bottom + ht) ;
|
728
|
+
} else {
|
729
|
+
clipLayout.bottom = 0 ;
|
730
|
+
}
|
731
|
+
if (hscroll) hscroll.set('isVisible', hasHorizontal) ;
|
732
|
+
|
733
|
+
if (hasVertical) {
|
734
|
+
ht = ht + this.get('verticalScrollerBottom') ;
|
735
|
+
vl = this.get('verticalScrollerLayout');
|
736
|
+
layout = {
|
737
|
+
top: (vl ? vl.top : 0),
|
738
|
+
bottom: (vl ? vl.bottom + ht : ht),
|
739
|
+
right: (vl ? vl.right : 0),
|
740
|
+
width: vt
|
741
|
+
};
|
742
|
+
vscroll.set('layout', layout) ;
|
743
|
+
vo = this.get('verticalOverlay');
|
744
|
+
clipLayout.right = vo ? 0 : (layout.right + vt) ;
|
745
|
+
} else {
|
746
|
+
clipLayout.right = 0 ;
|
747
|
+
}
|
748
|
+
if (vscroll) vscroll.set('isVisible', hasVertical) ;
|
749
|
+
|
750
|
+
clip.adjust(clipLayout) ;
|
751
|
+
},
|
752
|
+
|
753
|
+
/** @private
|
754
|
+
Called whenever a scroller visibility changes. Calls the tile() method.
|
755
|
+
*/
|
756
|
+
scrollerVisibilityDidChange: function() {
|
757
|
+
this.tile();
|
758
|
+
}.observes('isVerticalScrollerVisible', 'isHorizontalScrollerVisible'),
|
759
|
+
|
760
|
+
// ..........................................................
|
761
|
+
// SCROLL WHEEL SUPPORT
|
762
|
+
//
|
763
|
+
|
764
|
+
/** @private */ _scroll_wheelDeltaX: 0,
|
765
|
+
/** @private */ _scroll_wheelDeltaY: 0,
|
766
|
+
|
767
|
+
// save adjustment and then invoke the actual scroll code later. This will
|
768
|
+
// keep the view feeling smooth.
|
769
|
+
mouseWheel: function(evt) {
|
770
|
+
var deltaAdjust = (SC.browser.safari && SC.browser.version > 533.0) ? 120 : 1;
|
771
|
+
|
772
|
+
this._scroll_wheelDeltaX += evt.wheelDeltaX / deltaAdjust;
|
773
|
+
this._scroll_wheelDeltaY += evt.wheelDeltaY / deltaAdjust;
|
774
|
+
this.invokeLater(this._scroll_mouseWheel, 10) ;
|
775
|
+
return this.get('canScrollHorizontal') || this.get('canScrollVertical') ;
|
776
|
+
},
|
777
|
+
|
778
|
+
/** @private */
|
779
|
+
_scroll_mouseWheel: function() {
|
780
|
+
this.scrollBy(this._scroll_wheelDeltaX, this._scroll_wheelDeltaY);
|
781
|
+
if (SC.WHEEL_MOMENTUM && this._scroll_wheelDeltaY > 0) {
|
782
|
+
this._scroll_wheelDeltaY = Math.floor(this._scroll_wheelDeltaY*0.950);
|
783
|
+
this._scroll_wheelDeltaY = Math.max(this._scroll_wheelDeltaY, 0);
|
784
|
+
this.invokeLater(this._scroll_mouseWheel, 10) ;
|
785
|
+
} else if (SC.WHEEL_MOMENTUM && this._scroll_wheelDeltaY < 0){
|
786
|
+
this._scroll_wheelDeltaY = Math.ceil(this._scroll_wheelDeltaY*0.950);
|
787
|
+
this._scroll_wheelDeltaY = Math.min(this._scroll_wheelDeltaY, 0);
|
788
|
+
this.invokeLater(this._scroll_mouseWheel, 10) ;
|
789
|
+
} else {
|
790
|
+
this._scroll_wheelDeltaY = 0;
|
791
|
+
this._scroll_wheelDeltaX = 0;
|
792
|
+
}
|
793
|
+
},
|
794
|
+
|
795
|
+
/*..............................................
|
796
|
+
SCALING SUPPORT
|
797
|
+
*/
|
798
|
+
|
799
|
+
/**
|
800
|
+
Determines whether scaling is allowed.
|
801
|
+
*/
|
802
|
+
canScale: NO,
|
803
|
+
|
804
|
+
/**
|
805
|
+
The current scale.
|
806
|
+
*/
|
807
|
+
_scale: 1.0,
|
808
|
+
scale: function(key, value) {
|
809
|
+
if (value !== undefined) {
|
810
|
+
this._scale = Math.min(Math.max(this.get("minimumScale"), value), this.get("maximumScale"));
|
811
|
+
}
|
812
|
+
return this._scale;
|
813
|
+
}.property().cacheable(),
|
814
|
+
|
815
|
+
/**
|
816
|
+
The minimum scale.
|
817
|
+
*/
|
818
|
+
minimumScale: 0.25,
|
819
|
+
|
820
|
+
/**
|
821
|
+
The maximum scale.
|
822
|
+
*/
|
823
|
+
maximumScale: 2.0,
|
824
|
+
|
825
|
+
/**
|
826
|
+
Whether to automatically determine the scale range based on the size of the content.
|
827
|
+
*/
|
828
|
+
autoScaleRange: NO,
|
829
|
+
|
830
|
+
_scale_css: "",
|
831
|
+
|
832
|
+
updateScale: function(scale) {
|
833
|
+
var contentView = this.get("contentView");
|
834
|
+
if (!contentView) return;
|
835
|
+
|
836
|
+
if (contentView.isScalable) {
|
837
|
+
this.get("contentView").applyScale(scale);
|
838
|
+
this._scale_css = "";
|
839
|
+
} else {
|
840
|
+
this._scale_css = "scale3d(" + scale + ", " + scale + ", 1)";
|
841
|
+
}
|
842
|
+
},
|
843
|
+
|
844
|
+
/*..............................................
|
845
|
+
TOUCH SUPPORT
|
846
|
+
*/
|
847
|
+
acceptsMultitouch: YES,
|
848
|
+
|
849
|
+
/**
|
850
|
+
The scroll deceleration rate.
|
851
|
+
*/
|
852
|
+
decelerationRate: SC.NORMAL_SCROLL_DECELERATION,
|
853
|
+
|
854
|
+
/**
|
855
|
+
If YES, bouncing will always be enabled in the horizontal direction, even if the content
|
856
|
+
is smaller or the same size as the view. NO by default.
|
857
|
+
*/
|
858
|
+
alwaysBounceHorizontal: NO,
|
859
|
+
|
860
|
+
/**
|
861
|
+
If NO, bouncing will not be enabled in the vertical direction when the content is smaller
|
862
|
+
or the same size as the scroll view. YES by default.
|
863
|
+
*/
|
864
|
+
alwaysBounceVertical: YES,
|
865
|
+
|
866
|
+
/**
|
867
|
+
Whether to delay touches from passing through to the content.
|
868
|
+
*/
|
869
|
+
delaysContentTouches: YES,
|
870
|
+
|
871
|
+
/**
|
872
|
+
@private
|
873
|
+
If the view supports it, this
|
874
|
+
*/
|
875
|
+
_touchScrollDidChange: function() {
|
876
|
+
if (this.get("contentView").touchScrollDidChange) {
|
877
|
+
this.get("contentView").touchScrollDidChange(
|
878
|
+
this._scroll_horizontalScrollOffset,
|
879
|
+
this._scroll_verticalScrollOffset
|
880
|
+
);
|
881
|
+
}
|
882
|
+
|
883
|
+
// tell scrollers
|
884
|
+
if (this.verticalScrollerView && this.verticalScrollerView.touchScrollDidChange) {
|
885
|
+
this.verticalScrollerView.touchScrollDidChange(this._scroll_verticalScrollOffset);
|
886
|
+
}
|
887
|
+
|
888
|
+
if (this.horizontalScrollerView && this.horizontalScrollerView.touchScrollDidChange) {
|
889
|
+
this.horizontalScrollerView.touchScrollDidChange(this._scroll_horizontalScrollOffset);
|
890
|
+
}
|
891
|
+
},
|
892
|
+
|
893
|
+
_touchScrollDidStart: function() {
|
894
|
+
if (this.get("contentView").touchScrollDidStart) {
|
895
|
+
this.get("contentView").touchScrollDidStart(this._scroll_horizontalScrollOffset, this._scroll_verticalScrollOffset);
|
896
|
+
}
|
897
|
+
|
898
|
+
// tell scrollers
|
899
|
+
if (this.verticalScrollerView && this.verticalScrollerView.touchScrollDidStart) {
|
900
|
+
this.verticalScrollerView.touchScrollDidStart(this._touch_verticalScrollOffset);
|
901
|
+
}
|
902
|
+
if (this.horizontalScrollerView && this.horizontalScrollerView.touchScrollDidStart) {
|
903
|
+
this.horizontalScrollerView.touchScrollDidStart(this._touch_horizontalScrollOffset);
|
904
|
+
}
|
905
|
+
},
|
906
|
+
|
907
|
+
_touchScrollDidEnd: function() {
|
908
|
+
if (this.get("contentView").touchScrollDidEnd) {
|
909
|
+
this.get("contentView").touchScrollDidEnd(this._scroll_horizontalScrollOffset, this._scroll_verticalScrollOffset);
|
910
|
+
}
|
911
|
+
|
912
|
+
// tell scrollers
|
913
|
+
if (this.verticalScrollerView && this.verticalScrollerView.touchScrollDidEnd) {
|
914
|
+
this.verticalScrollerView.touchScrollDidEnd(this._touch_verticalScrollOffset);
|
915
|
+
}
|
916
|
+
|
917
|
+
if (this.horizontalScrollerView && this.horizontalScrollerView.touchScrollDidEnd) {
|
918
|
+
this.horizontalScrollerView.touchScrollDidEnd(this._touch_horizontalScrollOffset);
|
919
|
+
}
|
920
|
+
},
|
921
|
+
|
922
|
+
_applyCSSTransforms: function(layer) {
|
923
|
+
var transform = "";
|
924
|
+
this.updateScale(this._scale);
|
925
|
+
transform += 'translate3d('+ -this._scroll_horizontalScrollOffset +'px, '+ -Math.round(this._scroll_verticalScrollOffset)+'px,0) ';
|
926
|
+
transform += this._scale_css;
|
927
|
+
layer.style.webkitTransform = transform;
|
928
|
+
layer.style.webkitTransformOrigin = "top left";
|
929
|
+
},
|
930
|
+
|
931
|
+
captureTouch: function(touch) {
|
932
|
+
return YES;
|
933
|
+
},
|
934
|
+
|
935
|
+
touchGeneration: 0,
|
936
|
+
touchStart: function(touch) {
|
937
|
+
var generation = ++this.touchGeneration;
|
938
|
+
if (!this.tracking && this.get("delaysContentTouches")) {
|
939
|
+
this.invokeLater(this.beginTouchesInContent, 150, generation);
|
940
|
+
} else if (!this.tracking) {
|
941
|
+
// NOTE: We still have to delay because we don't want to call touchStart
|
942
|
+
// while touchStart is itself being called...
|
943
|
+
this.invokeLater(this.beginTouchesInContent, 1, generation);
|
944
|
+
}
|
945
|
+
this.beginTouchTracking(touch, YES);
|
946
|
+
return YES;
|
947
|
+
},
|
948
|
+
|
949
|
+
beginTouchesInContent: function(gen) {
|
950
|
+
if (gen !== this.touchGeneration) return;
|
951
|
+
|
952
|
+
var touch = this.touch, itemView;
|
953
|
+
if (touch && this.tracking && !this.dragging && !touch.touch.scrollHasEnded) {
|
954
|
+
// try to capture the touch
|
955
|
+
touch.touch.captureTouch(this, YES);
|
956
|
+
|
957
|
+
if (!touch.touch.touchResponder) {
|
958
|
+
// if it DIDN'T WORK!!!!!
|
959
|
+
// then we need to take possession again.
|
960
|
+
touch.touch.makeTouchResponder(this);
|
961
|
+
} else {
|
962
|
+
// Otherwise, it did work, and if we had a pending scroll end, we must do it now
|
963
|
+
if (touch.needsScrollEnd) {
|
964
|
+
this._touchScrollDidEnd();
|
965
|
+
}
|
966
|
+
}
|
967
|
+
}
|
968
|
+
},
|
969
|
+
|
970
|
+
/**
|
971
|
+
Initializes the start state of the gesture.
|
972
|
+
|
973
|
+
We keep information about the initial location of the touch so we can
|
974
|
+
disambiguate between a tap and a drag.
|
975
|
+
|
976
|
+
@param {Event} evt
|
977
|
+
*/
|
978
|
+
beginTouchTracking: function(touch, starting) {
|
979
|
+
var avg = touch.averagedTouchesForView(this, starting);
|
980
|
+
|
981
|
+
var verticalScrollOffset = this._scroll_verticalScrollOffset || 0,
|
982
|
+
horizontalScrollOffset = this._scroll_horizontalScrollOffset || 0,
|
983
|
+
startClipOffsetX = horizontalScrollOffset,
|
984
|
+
startClipOffsetY = verticalScrollOffset,
|
985
|
+
needsScrollEnd = NO;
|
986
|
+
|
987
|
+
if (this.touch && this.touch.timeout) {
|
988
|
+
// clear the timeout
|
989
|
+
clearTimeout(this.touch.timeout);
|
990
|
+
this.touch.timeout = null;
|
991
|
+
|
992
|
+
// get the scroll offsets
|
993
|
+
startClipOffsetX = this.touch.startClipOffset.x;
|
994
|
+
startClipOffsetY = this.touch.startClipOffset.y;
|
995
|
+
needsScrollEnd = YES;
|
996
|
+
}
|
997
|
+
|
998
|
+
// calculate container+content width/height
|
999
|
+
var view = this.get('contentView') ;
|
1000
|
+
var contentWidth = view ? view.get('frame').width : 0,
|
1001
|
+
contentHeight = view ? view.get('frame').height : 0;
|
1002
|
+
|
1003
|
+
if(view.calculatedWidth && view.calculatedWidth!==0) contentWidth = view.calculatedWidth;
|
1004
|
+
if (view.calculatedHeight && view.calculatedHeight !==0) contentHeight = view.calculatedHeight;
|
1005
|
+
|
1006
|
+
var containerWidth = this.get('containerView').get('frame').width,
|
1007
|
+
containerHeight = this.get('containerView').get('frame').height;
|
1008
|
+
|
1009
|
+
|
1010
|
+
// calculate position in content
|
1011
|
+
var globalFrame = this.convertFrameToView(this.get("frame"), null),
|
1012
|
+
positionInContentX = (horizontalScrollOffset + (avg.x - globalFrame.x)) / this._scale,
|
1013
|
+
positionInContentY = (verticalScrollOffset + (avg.y - globalFrame.y)) / this._scale;
|
1014
|
+
|
1015
|
+
this.touch = {
|
1016
|
+
startTime: touch.timeStamp,
|
1017
|
+
notCalculated: YES,
|
1018
|
+
|
1019
|
+
enableScrolling: {
|
1020
|
+
x: contentWidth * this._scale > containerWidth || this.get("alwaysBounceHorizontal"),
|
1021
|
+
y: contentHeight * this._scale > containerHeight || this.get("alwaysBounceVertical") }, // TODO: get from class properties
|
1022
|
+
scrolling: { x: NO, y: NO },
|
1023
|
+
|
1024
|
+
// offsets and velocities
|
1025
|
+
startClipOffset: { x: startClipOffsetX, y: startClipOffsetY },
|
1026
|
+
lastScrollOffset: { x: horizontalScrollOffset, y: verticalScrollOffset },
|
1027
|
+
startTouchOffset: { x: avg.x, y: avg.y },
|
1028
|
+
scrollVelocity: { x: 0, y: 0 },
|
1029
|
+
|
1030
|
+
startTouchOffsetInContent: { x: positionInContentX, y: positionInContentY },
|
1031
|
+
|
1032
|
+
containerSize: { width: containerWidth, height: containerHeight },
|
1033
|
+
contentSize: { width: contentWidth, height: contentHeight },
|
1034
|
+
|
1035
|
+
startScale: this._scale,
|
1036
|
+
startDistance: avg.d,
|
1037
|
+
canScale: this.get("canScale"),
|
1038
|
+
minimumScale: this.get("minimumScale"),
|
1039
|
+
maximumScale: this.get("maximumScale"),
|
1040
|
+
|
1041
|
+
globalFrame: globalFrame,
|
1042
|
+
|
1043
|
+
// cache some things
|
1044
|
+
layer: this.get("contentView").get('layer'),
|
1045
|
+
|
1046
|
+
// some constants
|
1047
|
+
resistanceCoefficient: 0.998,
|
1048
|
+
resistanceAsymptote: 320,
|
1049
|
+
decelerationFromEdge: 0.05,
|
1050
|
+
accelerationToEdge: 0.1,
|
1051
|
+
|
1052
|
+
// how much percent of the other drag direction you must drag to start dragging that direction too.
|
1053
|
+
scrollTolerance: { x: 15, y: 15 },
|
1054
|
+
scaleTolerance: 5,
|
1055
|
+
secondaryScrollTolerance: 30,
|
1056
|
+
scrollLock: 500,
|
1057
|
+
|
1058
|
+
decelerationRate: this.get("decelerationRate"),
|
1059
|
+
|
1060
|
+
// general status
|
1061
|
+
lastEventTime: touch.timeStamp,
|
1062
|
+
|
1063
|
+
// the touch used
|
1064
|
+
touch: (starting ? touch : (this.touch ? this.touch.touch : null)),
|
1065
|
+
|
1066
|
+
// needsScrollEnd will cause a scrollDidEnd even if this particular touch does not start a scroll.
|
1067
|
+
// the reason for this is because we don't want to say we've stopped scrolling just because we got
|
1068
|
+
// another touch, but simultaneously, we still need to send a touch end eventually.
|
1069
|
+
// there are two cases in which this will be used:
|
1070
|
+
//
|
1071
|
+
// 1. If the touch was sent to content touches (in which case we will not be scrolling)
|
1072
|
+
// 2. If the touch ends before scrolling starts (no scrolling then, either)
|
1073
|
+
needsScrollEnd: needsScrollEnd
|
1074
|
+
};
|
1075
|
+
|
1076
|
+
if (!this.tracking) {
|
1077
|
+
this.tracking = YES;
|
1078
|
+
this.dragging = NO;
|
1079
|
+
}
|
1080
|
+
},
|
1081
|
+
|
1082
|
+
_adjustForEdgeResistance: function(offset, minOffset, maxOffset, resistanceCoefficient, asymptote) {
|
1083
|
+
var distanceFromEdge;
|
1084
|
+
|
1085
|
+
// find distance from edge
|
1086
|
+
if (offset < minOffset) distanceFromEdge = offset - minOffset;
|
1087
|
+
else if (offset > maxOffset) distanceFromEdge = maxOffset - offset;
|
1088
|
+
else return offset;
|
1089
|
+
|
1090
|
+
// manipulate logarithmically
|
1091
|
+
distanceFromEdge = Math.pow(resistanceCoefficient, Math.abs(distanceFromEdge)) * asymptote;
|
1092
|
+
|
1093
|
+
// adjust mathematically
|
1094
|
+
if (offset < minOffset) distanceFromEdge = distanceFromEdge - asymptote;
|
1095
|
+
else distanceFromEdge = -distanceFromEdge + asymptote;
|
1096
|
+
|
1097
|
+
// generate final value
|
1098
|
+
return Math.min(Math.max(minOffset, offset), maxOffset) + distanceFromEdge;
|
1099
|
+
},
|
1100
|
+
|
1101
|
+
touchesDragged: function(evt, touches) {
|
1102
|
+
var avg = evt.averagedTouchesForView(this);
|
1103
|
+
this.updateTouchScroll(avg.x, avg.y, avg.d, evt.timeStamp);
|
1104
|
+
},
|
1105
|
+
|
1106
|
+
updateTouchScroll: function(touchX, touchY, distance, timeStamp) {
|
1107
|
+
// get some vars
|
1108
|
+
var touch = this.touch,
|
1109
|
+
touchXInFrame = touchX - touch.globalFrame.x,
|
1110
|
+
touchYInFrame = touchY - touch.globalFrame.y,
|
1111
|
+
offsetY,
|
1112
|
+
maxOffsetY,
|
1113
|
+
offsetX,
|
1114
|
+
maxOffsetX,
|
1115
|
+
minOffsetX, minOffsetY;
|
1116
|
+
|
1117
|
+
// calculate new position in content
|
1118
|
+
var positionInContentX = ((this._scroll_horizontalScrollOffset||0) + touchXInFrame) / this._scale,
|
1119
|
+
positionInContentY = ((this._scroll_verticalScrollOffset||0) + touchYInFrame) / this._scale;
|
1120
|
+
|
1121
|
+
// calculate deltas
|
1122
|
+
var deltaX = positionInContentX - touch.startTouchOffset.x,
|
1123
|
+
deltaY = positionInContentY - touch.startTouchOffset.y;
|
1124
|
+
|
1125
|
+
var isDragging = touch.dragging;
|
1126
|
+
if (!touch.scrolling.x && Math.abs(deltaX) > touch.scrollTolerance.x && touch.enableScrolling.x) {
|
1127
|
+
// say we are scrolling
|
1128
|
+
isDragging = YES;
|
1129
|
+
touch.scrolling.x = YES;
|
1130
|
+
touch.scrollTolerance.y = touch.secondaryScrollTolerance;
|
1131
|
+
|
1132
|
+
// reset position
|
1133
|
+
touch.startTouchOffset.x = touchX;
|
1134
|
+
deltaX = 0;
|
1135
|
+
}
|
1136
|
+
if (!touch.scrolling.y && Math.abs(deltaY) > touch.scrollTolerance.y && touch.enableScrolling.y) {
|
1137
|
+
// say we are scrolling
|
1138
|
+
isDragging = YES;
|
1139
|
+
touch.scrolling.y = YES;
|
1140
|
+
touch.scrollTolerance.x = touch.secondaryScrollTolerance;
|
1141
|
+
|
1142
|
+
// reset position
|
1143
|
+
touch.startTouchOffset.y = touchY;
|
1144
|
+
deltaY = 0;
|
1145
|
+
}
|
1146
|
+
|
1147
|
+
// handle scroll start
|
1148
|
+
if (isDragging && !touch.dragging) {
|
1149
|
+
touch.dragging = YES;
|
1150
|
+
this.dragging = YES;
|
1151
|
+
this._touchScrollDidStart();
|
1152
|
+
}
|
1153
|
+
|
1154
|
+
// calculate new offset
|
1155
|
+
if (!touch.scrolling.x && !touch.scrolling.y && !touch.canScale) return;
|
1156
|
+
if (touch.scrolling.x && !touch.scrolling.y) {
|
1157
|
+
if (deltaX > touch.scrollLock && !touch.scrolling.y) touch.enableScrolling.y = NO;
|
1158
|
+
}
|
1159
|
+
if (touch.scrolling.y && !touch.scrolling.x) {
|
1160
|
+
if (deltaY > touch.scrollLock && !touch.scrolling.x) touch.enableScrolling.x = NO;
|
1161
|
+
}
|
1162
|
+
|
1163
|
+
// handle scaling
|
1164
|
+
if (touch.canScale) {
|
1165
|
+
|
1166
|
+
var startDistance = touch.startDistance, dd = distance - startDistance;
|
1167
|
+
if (Math.abs(dd) > touch.scaleTolerance) {
|
1168
|
+
touch.scrolling.y = YES; // if you scale, you can scroll.
|
1169
|
+
touch.scrolling.x = YES;
|
1170
|
+
|
1171
|
+
// we want to say something that was the startDistance away from each other should now be
|
1172
|
+
// distance away. So, if we are twice as far away as we started...
|
1173
|
+
var scale = touch.startScale * (distance / Math.max(startDistance, 50));
|
1174
|
+
|
1175
|
+
var newScale = this._adjustForEdgeResistance(scale, touch.minimumScale, touch.maximumScale, touch.resistanceCoefficient, touch.resistanceAsymptote);
|
1176
|
+
this.dragging = YES;
|
1177
|
+
this._scale = newScale;
|
1178
|
+
var newPositionInContentX = positionInContentX * this._scale,
|
1179
|
+
newPositionInContentY = positionInContentY * this._scale;
|
1180
|
+
}
|
1181
|
+
}
|
1182
|
+
|
1183
|
+
|
1184
|
+
minOffsetX = this.minimumScrollOffset(touch.contentSize.width * this._scale, touch.containerSize.width, this.get("horizontalAlign"));
|
1185
|
+
minOffsetY = this.minimumScrollOffset(touch.contentSize.height * this._scale, touch.containerSize.height, this.get("verticalAlign"));
|
1186
|
+
|
1187
|
+
maxOffsetX = this.maximumScrollOffset(touch.contentSize.width * this._scale, touch.containerSize.width, this.get("horizontalAlign"));
|
1188
|
+
maxOffsetY = this.maximumScrollOffset(touch.contentSize.height * this._scale, touch.containerSize.height, this.get("verticalAlign"));
|
1189
|
+
|
1190
|
+
// (offsetY + touchYInFrame) / this._scale = touch.startTouchOffsetInContent.y
|
1191
|
+
// offsetY + touchYInFrame = touch.startTouchOffsetInContent.y * this._scale;
|
1192
|
+
// offsetY = touch.startTouchOffset * this._scale - touchYInFrame
|
1193
|
+
offsetX = touch.startTouchOffsetInContent.x * this._scale - touchXInFrame;
|
1194
|
+
offsetY = touch.startTouchOffsetInContent.y * this._scale - touchYInFrame;
|
1195
|
+
|
1196
|
+
|
1197
|
+
// update immediately, without consulting anyone else.
|
1198
|
+
offsetX = this._adjustForEdgeResistance(offsetX, minOffsetX, maxOffsetX, touch.resistanceCoefficient, touch.resistanceAsymptote);
|
1199
|
+
offsetY = this._adjustForEdgeResistance(offsetY, minOffsetY, maxOffsetY, touch.resistanceCoefficient, touch.resistanceAsymptote);
|
1200
|
+
|
1201
|
+
if (touch.scrolling.x) this._scroll_horizontalScrollOffset = offsetX;
|
1202
|
+
if (touch.scrolling.y) this._scroll_verticalScrollOffset = offsetY;
|
1203
|
+
|
1204
|
+
this._applyCSSTransforms(touch.layer);
|
1205
|
+
this._touchScrollDidChange();
|
1206
|
+
|
1207
|
+
if (timeStamp - touch.lastEventTime >= 1 || touch.notCalculated) {
|
1208
|
+
touch.notCalculated = NO;
|
1209
|
+
var horizontalOffset = this._scroll_horizontalScrollOffset;
|
1210
|
+
var verticalOffset = this._scroll_verticalScrollOffset;
|
1211
|
+
|
1212
|
+
touch.scrollVelocity.x = ((horizontalOffset - touch.lastScrollOffset.x) / Math.max(1, timeStamp - touch.lastEventTime)); // in px per ms
|
1213
|
+
touch.scrollVelocity.y = ((verticalOffset - touch.lastScrollOffset.y) / Math.max(1, timeStamp - touch.lastEventTime)); // in px per ms
|
1214
|
+
touch.lastScrollOffset.x = horizontalOffset;
|
1215
|
+
touch.lastScrollOffset.y = verticalOffset;
|
1216
|
+
touch.lastEventTime = timeStamp;
|
1217
|
+
}
|
1218
|
+
},
|
1219
|
+
|
1220
|
+
touchEnd: function(touch) {
|
1221
|
+
var touchStatus = this.touch,
|
1222
|
+
avg = touch.averagedTouchesForView(this);
|
1223
|
+
|
1224
|
+
touch.scrollHasEnded = YES;
|
1225
|
+
if (avg.touchCount > 0) {
|
1226
|
+
this.beginTouchTracking(touch, NO);
|
1227
|
+
} else {
|
1228
|
+
if (this.dragging) {
|
1229
|
+
touchStatus.dragging = NO;
|
1230
|
+
|
1231
|
+
// reset last event time
|
1232
|
+
touchStatus.lastEventTime = touch.timeStamp;
|
1233
|
+
|
1234
|
+
this.startDecelerationAnimation();
|
1235
|
+
} else {
|
1236
|
+
// well. The scrolling stopped. Let us tell everyone if there was a pending one that this non-drag op interrupted.
|
1237
|
+
if (touchStatus.needsScrollEnd) this._touchScrollDidEnd();
|
1238
|
+
|
1239
|
+
// this part looks weird, but it is actually quite simple.
|
1240
|
+
// First, we send the touch off for capture+starting again, but telling it to return to us
|
1241
|
+
// if nothing is found or if it is released.
|
1242
|
+
touch.captureTouch(this, YES);
|
1243
|
+
|
1244
|
+
// if we went anywhere, did anything, etc., call end()
|
1245
|
+
if (touch.touchResponder && touch.touchResponder !== this) {
|
1246
|
+
touch.end();
|
1247
|
+
} else if (!touch.touchResponder || touch.touchResponder === this) {
|
1248
|
+
// if it was released to us or stayed with us the whole time, or is for some
|
1249
|
+
// wacky reason empty (in which case it is ours still). If so, and there is a next responder,
|
1250
|
+
// relay to that.
|
1251
|
+
|
1252
|
+
if (touch.nextTouchResponder) touch.makeTouchResponder(touch.nextTouchResponder);
|
1253
|
+
} else {
|
1254
|
+
// in this case, the view that captured it and changed responder should have handled
|
1255
|
+
// everything for us.
|
1256
|
+
}
|
1257
|
+
|
1258
|
+
this.touch = null;
|
1259
|
+
}
|
1260
|
+
|
1261
|
+
this.tracking = NO;
|
1262
|
+
this.dragging = NO;
|
1263
|
+
}
|
1264
|
+
},
|
1265
|
+
|
1266
|
+
touchCancelled: function(touch) {
|
1267
|
+
var touchStatus = this.touch,
|
1268
|
+
avg = touch.averagedTouchesForView(this);
|
1269
|
+
|
1270
|
+
// if we are decelerating, we don't want to stop that. That would be bad. Because there's no point.
|
1271
|
+
if (!this.touch || !this.touch.timeout) {
|
1272
|
+
this.beginPropertyChanges();
|
1273
|
+
this.set("scale", this._scale);
|
1274
|
+
this.set("verticalScrollOffset", this._scroll_verticalScrollOffset);
|
1275
|
+
this.set("horizontalScrollOffset", this._scroll_horizontalScrollOffset);
|
1276
|
+
this.endPropertyChanges();
|
1277
|
+
this.tracking = NO;
|
1278
|
+
|
1279
|
+
if (this.dragging) {
|
1280
|
+
this._touchScrollDidEnd();
|
1281
|
+
}
|
1282
|
+
|
1283
|
+
this.dragging = NO;
|
1284
|
+
this.touch = null;
|
1285
|
+
}
|
1286
|
+
},
|
1287
|
+
|
1288
|
+
startDecelerationAnimation: function(evt) {
|
1289
|
+
var touch = this.touch;
|
1290
|
+
touch.decelerationVelocity = {
|
1291
|
+
x: touch.scrollVelocity.x * 10,
|
1292
|
+
y: touch.scrollVelocity.y * 10
|
1293
|
+
};
|
1294
|
+
|
1295
|
+
this.decelerateAnimation();
|
1296
|
+
},
|
1297
|
+
|
1298
|
+
/**
|
1299
|
+
@private
|
1300
|
+
Does bounce calculations, adjusting velocity.
|
1301
|
+
|
1302
|
+
Bouncing is fun. Functions that handle it should have fun names,
|
1303
|
+
don'tcha think?
|
1304
|
+
|
1305
|
+
P.S.: should this be named "bouncityBounce" instead?
|
1306
|
+
*/
|
1307
|
+
bouncyBounce: function(velocity, value, minValue, maxValue, de, ac, additionalAcceleration) {
|
1308
|
+
// we have 4 possible paths. On a higher level, we have two leaf paths that can be applied
|
1309
|
+
// for either of two super-paths.
|
1310
|
+
//
|
1311
|
+
// The first path is if we are decelerating past an edge: in this case, this function must
|
1312
|
+
// must enhance that deceleration. In this case, our math boils down to taking the amount
|
1313
|
+
// by which we are past the edge, multiplying it by our deceleration factor, and reducing
|
1314
|
+
// velocity by that amount.
|
1315
|
+
//
|
1316
|
+
// The second path is if we are not decelerating, but are still past the edge. In this case,
|
1317
|
+
// we must start acceleration back _to_ the edge. The math here takes the distance we are from
|
1318
|
+
// the edge, multiplies by the acceleration factor, and then performs two additional things:
|
1319
|
+
// First, it speeds up the acceleration artificially with additionalAcceleration; this will
|
1320
|
+
// make the stop feel more sudden, as it will still have this additional acceleration when it reaches
|
1321
|
+
// the edge. Second, it ensures the result does not go past the final value, so we don't end up
|
1322
|
+
// bouncing back and forth all crazy-like.
|
1323
|
+
if (value < minValue) {
|
1324
|
+
if (velocity < 0) velocity = velocity + ((minValue - value) * de);
|
1325
|
+
else {
|
1326
|
+
velocity = Math.min((minValue-value) * ac + additionalAcceleration, minValue - value - 0.01);
|
1327
|
+
}
|
1328
|
+
} else if (value > maxValue) {
|
1329
|
+
if (velocity > 0) velocity = velocity - ((value - maxValue) * de);
|
1330
|
+
else {
|
1331
|
+
velocity = -Math.min((value - maxValue) * ac + additionalAcceleration, value - maxValue - 0.01);
|
1332
|
+
}
|
1333
|
+
}
|
1334
|
+
return velocity;
|
1335
|
+
},
|
1336
|
+
|
1337
|
+
decelerateAnimation: function() {
|
1338
|
+
// get a bunch of properties. They are named well, so not much explanation of what they are...
|
1339
|
+
// However, note maxOffsetX/Y takes into account the scale;
|
1340
|
+
// also, newX/Y adds in the current deceleration velocity (the deceleration velocity will
|
1341
|
+
// be changed later in this function).
|
1342
|
+
var touch = this.touch,
|
1343
|
+
scale = this._scale,
|
1344
|
+
minOffsetX = this.minimumScrollOffset(touch.contentSize.width * this._scale, touch.containerSize.width, this.get("horizontalAlign")),
|
1345
|
+
minOffsetY = this.minimumScrollOffset(touch.contentSize.height * this._scale, touch.containerSize.height, this.get("verticalAlign")),
|
1346
|
+
maxOffsetX = this.maximumScrollOffset(touch.contentSize.width * this._scale, touch.containerSize.width, this.get("horizontalAlign")),
|
1347
|
+
maxOffsetY = this.maximumScrollOffset(touch.contentSize.height * this._scale, touch.containerSize.height, this.get("verticalAlign")),
|
1348
|
+
|
1349
|
+
now = Date.now(),
|
1350
|
+
t = Math.max(now - touch.lastEventTime, 1),
|
1351
|
+
|
1352
|
+
newX = this._scroll_horizontalScrollOffset + touch.decelerationVelocity.x * (t/10),
|
1353
|
+
newY = this._scroll_verticalScrollOffset + touch.decelerationVelocity.y * (t/10);
|
1354
|
+
|
1355
|
+
var de = touch.decelerationFromEdge, ac = touch.accelerationToEdge;
|
1356
|
+
|
1357
|
+
// determine if position was okay before adjusting scale (which we do, in
|
1358
|
+
// a lovely, animated way, for the scaled out/in too far bounce-back).
|
1359
|
+
// if the position was okay, then we are going to make sure that we keep the
|
1360
|
+
// position okay when adjusting the scale.
|
1361
|
+
//
|
1362
|
+
// Position OKness, here, referring to if the position is valid (within
|
1363
|
+
// minimum and maximum scroll offsets)
|
1364
|
+
var validXPosition = newX >= minOffsetX && newX <= maxOffsetX;
|
1365
|
+
var validYPosition = newY >= minOffsetY && newY <= maxOffsetY;
|
1366
|
+
|
1367
|
+
// We are going to change scale in a moment, but the position should stay the
|
1368
|
+
// same, if possible (unless it would be more jarring, as described above, in
|
1369
|
+
// the case of starting with a valid position and ending with an invalid one).
|
1370
|
+
//
|
1371
|
+
// Because we are changing the scale, we need to make the position scale-neutral.
|
1372
|
+
// we'll make it non-scale-neutral after applying scale.
|
1373
|
+
//
|
1374
|
+
// Question: might it be better to save the center position instead, so scaling
|
1375
|
+
// bounces back around the center of the screen?
|
1376
|
+
newX /= this._scale;
|
1377
|
+
newY /= this._scale;
|
1378
|
+
|
1379
|
+
// scale velocity (amount to change) starts out at 0 each time, because
|
1380
|
+
// it is calculated by how far out of bounds it is, rather than by the
|
1381
|
+
// previous such velocity.
|
1382
|
+
var sv = 0;
|
1383
|
+
|
1384
|
+
// do said calculation; we'll use the same bouncyBounce method used for everything
|
1385
|
+
// else, but our adjustor that gives a minimum amount to change by and (which, as we'll
|
1386
|
+
// discuss, is to make the stop feel slightly more like a stop), we'll leave at 0
|
1387
|
+
// (scale doesn't really need it as much; if you disagree, at least come up with
|
1388
|
+
// numbers more appropriate for scale than the ones for X/Y)
|
1389
|
+
sv = this.bouncyBounce(sv, scale, touch.minimumScale, touch.maximumScale, de, ac, 0);
|
1390
|
+
|
1391
|
+
// add the amount to scale. This is linear, rather than multiplicative. If you think
|
1392
|
+
// it should be multiplicative (or however you say that), come up with a new formula.
|
1393
|
+
this._scale = scale = scale + sv;
|
1394
|
+
|
1395
|
+
// now we can convert newX/Y back to scale-specific coordinates...
|
1396
|
+
newX *= this._scale;
|
1397
|
+
newY *= this._scale;
|
1398
|
+
|
1399
|
+
// It looks very weird if the content started in-bounds, but the scale animation
|
1400
|
+
// made it not be in bounds; it causes the position to animate snapping back, and,
|
1401
|
+
// well, it looks very weird. It is more proper to just make sure it stays in a valid
|
1402
|
+
// position. So, we'll determine the new maximum/minimum offsets, and then, if it was
|
1403
|
+
// originally a valid position, we'll adjust the new position to a valid position as well.
|
1404
|
+
|
1405
|
+
|
1406
|
+
// determine new max offset
|
1407
|
+
minOffsetX = this.minimumScrollOffset(touch.contentSize.width * this._scale, touch.containerSize.width, this.get("horizontalAlign"));
|
1408
|
+
minOffsetY = this.minimumScrollOffset(touch.contentSize.height * this._scale, touch.containerSize.height, this.get("verticalAlign"));
|
1409
|
+
maxOffsetX = this.maximumScrollOffset(touch.contentSize.width * this._scale, touch.containerSize.width, this.get("horizontalAlign"));
|
1410
|
+
maxOffsetY = this.maximumScrollOffset(touch.contentSize.height * this._scale, touch.containerSize.height, this.get("verticalAlign"));
|
1411
|
+
|
1412
|
+
// see if scaling messed up the X position (but ignore if 'tweren't right to begin with).
|
1413
|
+
if (validXPosition && (newX < minOffsetX || newX > maxOffsetX)) {
|
1414
|
+
// Correct the position
|
1415
|
+
newX = Math.max(minOffsetX, Math.min(newX, maxOffsetX));
|
1416
|
+
}
|
1417
|
+
|
1418
|
+
// now the y
|
1419
|
+
if (validYPosition && (newY < minOffsetY || newY > maxOffsetY)) {
|
1420
|
+
// again, correct it...
|
1421
|
+
newY = Math.max(minOffsetY, Math.min(newY, maxOffsetY));
|
1422
|
+
}
|
1423
|
+
|
1424
|
+
|
1425
|
+
// now that we are done modifying the position, we may update the actual scroll
|
1426
|
+
this._scroll_horizontalScrollOffset = newX;
|
1427
|
+
this._scroll_verticalScrollOffset = newY;
|
1428
|
+
|
1429
|
+
this._applyCSSTransforms(touch.layer); // <- Does what it sounds like.
|
1430
|
+
|
1431
|
+
SC.RunLoop.begin();
|
1432
|
+
this._touchScrollDidChange();
|
1433
|
+
SC.RunLoop.end();
|
1434
|
+
|
1435
|
+
// Now we have to adjust the velocities. The velocities are simple x and y numbers that
|
1436
|
+
// get added to the scroll X/Y positions each frame.
|
1437
|
+
// The default decay rate is .950 per frame. To achieve some semblance of accuracy, we
|
1438
|
+
// make it to the power of the elapsed number of frames. This is not fully accurate,
|
1439
|
+
// as this is applying the elapsed time between this frame and the previous time to
|
1440
|
+
// modify the velocity for the next frame. My mind goes blank when I try to figure out
|
1441
|
+
// a way to fix this (given that we don't want to change the velocity on the first frame),
|
1442
|
+
// and as it seems to work great as-is, I'm just leaving it.
|
1443
|
+
var decay = touch.decelerationRate;
|
1444
|
+
touch.decelerationVelocity.y *= Math.pow(decay, (t / 10));
|
1445
|
+
touch.decelerationVelocity.x *= Math.pow(decay, (t / 10));
|
1446
|
+
|
1447
|
+
// We have a bouncyBounce method that adjusts the velocity for bounce. That is, if it is
|
1448
|
+
// out of range and still going, it will slow it down. This step is decelerationFromEdge.
|
1449
|
+
// If it is not moving (or has come to a stop from decelerating), but is still out of range,
|
1450
|
+
// it will start it moving back into range (accelerationToEdge)
|
1451
|
+
// we supply de and ac as these properties.
|
1452
|
+
// The .3 artificially increases the acceleration by .3; this is actually to make the final
|
1453
|
+
// stop a bit more abrupt.
|
1454
|
+
touch.decelerationVelocity.x = this.bouncyBounce(touch.decelerationVelocity.x, newX, minOffsetX, maxOffsetX, de, ac, 0.3);
|
1455
|
+
touch.decelerationVelocity.y = this.bouncyBounce(touch.decelerationVelocity.y, newY, minOffsetY, maxOffsetY, de, ac, 0.3);
|
1456
|
+
|
1457
|
+
// if we ain't got no velocity... then we must be finished, as there is no where else to go.
|
1458
|
+
// to determine our velocity, we take the absolue value, and use that; if it is less than .01, we
|
1459
|
+
// must be done. Note that we check scale's most recent velocity, calculated above using bouncyBounce,
|
1460
|
+
// as well.
|
1461
|
+
var absXVelocity = Math.abs(touch.decelerationVelocity.x);
|
1462
|
+
var absYVelocity = Math.abs(touch.decelerationVelocity.y);
|
1463
|
+
if (absYVelocity < 0.01 && absXVelocity < 0.01 && Math.abs(sv) < 0.01) {
|
1464
|
+
// we can reset the timeout, as it will no longer be required, and we don't want to re-cancel it later.
|
1465
|
+
touch.timeout = null;
|
1466
|
+
this.touch = null;
|
1467
|
+
|
1468
|
+
// we aren't in a run loop right now (see below, where we trigger the timer)
|
1469
|
+
// so, we must start one.
|
1470
|
+
SC.RunLoop.begin();
|
1471
|
+
|
1472
|
+
// trigger scroll end
|
1473
|
+
this._touchScrollDidEnd();
|
1474
|
+
|
1475
|
+
// set the scale, vertical, and horizontal offsets to what they technically already are,
|
1476
|
+
// but don't know they are yet. This will finally update things like, say, the clipping frame.
|
1477
|
+
this.beginPropertyChanges();
|
1478
|
+
this.set("scale", this._scale);
|
1479
|
+
this.set("verticalScrollOffset", this._scroll_verticalScrollOffset);
|
1480
|
+
this.set("horizontalScrollOffset", this._scroll_horizontalScrollOffset);
|
1481
|
+
this.endPropertyChanges();
|
1482
|
+
|
1483
|
+
// and now we're done, so just end the run loop and return.
|
1484
|
+
SC.RunLoop.end();
|
1485
|
+
return;
|
1486
|
+
}
|
1487
|
+
|
1488
|
+
// We now set up the next round. We are doing this as raw as we possibly can, not touching the
|
1489
|
+
// run loop at all. This speeds up performance drastically--keep in mind, we're on comparatively
|
1490
|
+
// slow devices, here. So, we'll just make a closure, saving "this" into "self" and calling
|
1491
|
+
// 10ms later (or however long it takes). Note also that we save both the last event time
|
1492
|
+
// (so we may calculate elapsed time) and the timeout we are creating, so we may cancel it in future.
|
1493
|
+
var self = this;
|
1494
|
+
touch.lastEventTime = Date.now();
|
1495
|
+
this.touch.timeout = setTimeout(function(){
|
1496
|
+
self.decelerateAnimation();
|
1497
|
+
}, 10);
|
1498
|
+
},
|
1499
|
+
|
1500
|
+
// ..........................................................
|
1501
|
+
// INTERNAL SUPPORT
|
1502
|
+
//
|
1503
|
+
|
1504
|
+
/** @private
|
1505
|
+
Instantiate scrollers & container views as needed. Replace their classes
|
1506
|
+
in the regular properties.
|
1507
|
+
*/
|
1508
|
+
createChildViews: function() {
|
1509
|
+
var childViews = [] , view;
|
1510
|
+
|
1511
|
+
// create the containerView. We must always have a container view.
|
1512
|
+
// also, setup the contentView as the child of the containerView...
|
1513
|
+
if (SC.none(view = this.containerView)) view = SC.ContainerView;
|
1514
|
+
|
1515
|
+
childViews.push(this.containerView = this.createChildView(view, {
|
1516
|
+
contentView: this.contentView,
|
1517
|
+
isScrollContainer: YES
|
1518
|
+
}));
|
1519
|
+
|
1520
|
+
// and replace our own contentView...
|
1521
|
+
this.contentView = this.containerView.get('contentView');
|
1522
|
+
|
1523
|
+
// create a horizontal scroller view if needed...
|
1524
|
+
view = SC.platform.touch ? this.get("horizontalTouchScrollerView") : this.get("horizontalScrollerView");
|
1525
|
+
if (view) {
|
1526
|
+
if (this.get('hasHorizontalScroller')) {
|
1527
|
+
view = this.horizontalScrollerView = this.createChildView(view, {
|
1528
|
+
layoutDirection: SC.LAYOUT_HORIZONTAL,
|
1529
|
+
valueBinding: '*owner.horizontalScrollOffset'
|
1530
|
+
}) ;
|
1531
|
+
childViews.push(view);
|
1532
|
+
} else this.horizontalScrollerView = null ;
|
1533
|
+
}
|
1534
|
+
|
1535
|
+
// create a vertical scroller view if needed...
|
1536
|
+
view = SC.platform.touch ? this.get("verticalTouchScrollerView") : this.get("verticalScrollerView");
|
1537
|
+
if (view) {
|
1538
|
+
if (this.get('hasVerticalScroller')) {
|
1539
|
+
view = this.verticalScrollerView = this.createChildView(view, {
|
1540
|
+
layoutDirection: SC.LAYOUT_VERTICAL,
|
1541
|
+
valueBinding: '*owner.verticalScrollOffset'
|
1542
|
+
}) ;
|
1543
|
+
childViews.push(view);
|
1544
|
+
} else this.verticalScrollerView = null ;
|
1545
|
+
}
|
1546
|
+
|
1547
|
+
// set childViews array.
|
1548
|
+
this.childViews = childViews ;
|
1549
|
+
|
1550
|
+
this.contentViewDidChange() ; // setup initial display...
|
1551
|
+
this.tile() ; // set up initial tiling
|
1552
|
+
},
|
1553
|
+
|
1554
|
+
init: function() {
|
1555
|
+
sc_super();
|
1556
|
+
|
1557
|
+
// start observing initial content view. The content view's frame has
|
1558
|
+
// already been setup in prepareDisplay so we don't need to call
|
1559
|
+
// viewFrameDidChange...
|
1560
|
+
this._scroll_contentView = this.get('contentView') ;
|
1561
|
+
var contentView = this._scroll_contentView ;
|
1562
|
+
|
1563
|
+
if (contentView) {
|
1564
|
+
contentView.addObserver('frame', this, this.contentViewFrameDidChange) ;
|
1565
|
+
}
|
1566
|
+
|
1567
|
+
if (this.get('isVisibleInWindow')) this._scsv_registerAutoscroll() ;
|
1568
|
+
},
|
1569
|
+
|
1570
|
+
/** @private Registers/deregisters view with SC.Drag for autoscrolling */
|
1571
|
+
_scsv_registerAutoscroll: function() {
|
1572
|
+
if (this.get('isVisibleInWindow')) SC.Drag.addScrollableView(this);
|
1573
|
+
else SC.Drag.removeScrollableView(this);
|
1574
|
+
}.observes('isVisibleInWindow'),
|
1575
|
+
|
1576
|
+
/** @private
|
1577
|
+
Whenever the contentView is changed, we need to observe the content view's
|
1578
|
+
frame to be notified whenever it's size changes.
|
1579
|
+
*/
|
1580
|
+
contentViewDidChange: function() {
|
1581
|
+
var newView = this.get('contentView'),
|
1582
|
+
oldView = this._scroll_contentView,
|
1583
|
+
frameObserver = this.contentViewFrameDidChange,
|
1584
|
+
layerObserver = this.contentViewLayerDidChange;
|
1585
|
+
|
1586
|
+
if (newView !== oldView) {
|
1587
|
+
|
1588
|
+
// stop observing old content view
|
1589
|
+
if (oldView) {
|
1590
|
+
oldView.removeObserver('frame', this, frameObserver);
|
1591
|
+
oldView.removeObserver('layer', this, layerObserver);
|
1592
|
+
}
|
1593
|
+
|
1594
|
+
// update cache
|
1595
|
+
this._scroll_contentView = newView;
|
1596
|
+
if (newView) {
|
1597
|
+
newView.addObserver('frame', this, frameObserver);
|
1598
|
+
newView.addObserver('layer', this, layerObserver);
|
1599
|
+
}
|
1600
|
+
|
1601
|
+
// replace container
|
1602
|
+
this.containerView.set('contentView', newView);
|
1603
|
+
|
1604
|
+
this.contentViewFrameDidChange();
|
1605
|
+
}
|
1606
|
+
}.observes('contentView'),
|
1607
|
+
|
1608
|
+
/** @private
|
1609
|
+
If we redraw after the initial render, we need to make sure that we reset
|
1610
|
+
the scrollTop/scrollLeft properties on the content view. This ensures
|
1611
|
+
that, for example, the scroll views displays correctly when switching
|
1612
|
+
views out in a ContainerView.
|
1613
|
+
*/
|
1614
|
+
render: function(context, firstTime) {
|
1615
|
+
this.invokeLast(this.adjustElementScroll);
|
1616
|
+
if (firstTime) {
|
1617
|
+
context.push('<div class="corner"></div>');
|
1618
|
+
}
|
1619
|
+
return sc_super();
|
1620
|
+
},
|
1621
|
+
|
1622
|
+
/** @private
|
1623
|
+
Invoked whenever the contentView's frame changes. This will update the
|
1624
|
+
scroller maxmimum and optionally update the scroller visibility if the
|
1625
|
+
size of the contentView changes. We don't care about the origin since
|
1626
|
+
that is tracked separately from the offset values.
|
1627
|
+
|
1628
|
+
@param {Boolean} force (optional) Re-calculate everything even if the contentView’s frame didn’t change size
|
1629
|
+
*/
|
1630
|
+
|
1631
|
+
oldMaxHOffset: 0,
|
1632
|
+
oldMaxVOffset: 0,
|
1633
|
+
|
1634
|
+
contentViewFrameDidChange: function(force) {
|
1635
|
+
var view = this.get('contentView'),
|
1636
|
+
f = (view) ? view.get('frame') : null,
|
1637
|
+
scale = this._scale,
|
1638
|
+
width = (f) ? f.width * scale : 0,
|
1639
|
+
height = (f) ? f.height * scale : 0,
|
1640
|
+
dim, dimWidth, dimHeight;
|
1641
|
+
|
1642
|
+
// cache out scroll settings...
|
1643
|
+
if (!force && (width === this._scroll_contentWidth) && (height === this._scroll_contentHeight)) return ;
|
1644
|
+
this._scroll_contentWidth = width;
|
1645
|
+
this._scroll_contentHeight = height;
|
1646
|
+
|
1647
|
+
dim = this.getPath('containerView.frame');
|
1648
|
+
dimWidth = dim.width;
|
1649
|
+
dimHeight = dim.height;
|
1650
|
+
|
1651
|
+
if (this.get('hasHorizontalScroller') && (view = this.get('horizontalScrollerView'))) {
|
1652
|
+
// decide if it should be visible or not
|
1653
|
+
if (this.get('autohidesHorizontalScroller')) {
|
1654
|
+
this.set('isHorizontalScrollerVisible', width > dimWidth);
|
1655
|
+
}
|
1656
|
+
view.setIfChanged('maximum', width-dimWidth) ;
|
1657
|
+
view.setIfChanged('proportion', dimWidth/width);
|
1658
|
+
}
|
1659
|
+
|
1660
|
+
if (this.get('hasVerticalScroller') && (view = this.get('verticalScrollerView'))) {
|
1661
|
+
// decide if it should be visible or not
|
1662
|
+
if (this.get('autohidesVerticalScroller')) {
|
1663
|
+
this.set('isVerticalScrollerVisible', height > dimHeight);
|
1664
|
+
}
|
1665
|
+
view.setIfChanged('maximum', height-dimHeight) ;
|
1666
|
+
view.setIfChanged('proportion', dimHeight/height);
|
1667
|
+
}
|
1668
|
+
|
1669
|
+
// If there is no vertical scroller and auto hiding is on, make
|
1670
|
+
// sure we are at the top if not already there
|
1671
|
+
if (!this.get('isVerticalScrollerVisible') && (this.get('verticalScrollOffset') !== 0) &&
|
1672
|
+
this.get('autohidesVerticalScroller')) {
|
1673
|
+
this.set('verticalScrollOffset', 0);
|
1674
|
+
}
|
1675
|
+
|
1676
|
+
// Same thing for horizontal scrolling.
|
1677
|
+
if (!this.get('isHorizontalScrollerVisible') && (this.get('horizontalScrollOffset') !== 0) &&
|
1678
|
+
this.get('autohidesHorizontalScroller')) {
|
1679
|
+
this.set('horizontalScrollOffset', 0);
|
1680
|
+
}
|
1681
|
+
|
1682
|
+
// This forces to recalculate the height of the frame when is at the bottom
|
1683
|
+
// of the scroll and the content dimension are smaller that the previous one
|
1684
|
+
var mxVOffSet = this.get('maximumVerticalScrollOffset'),
|
1685
|
+
vOffSet = this.get('verticalScrollOffset'),
|
1686
|
+
mxHOffSet = this.get('maximumHorizontalScrollOffset'),
|
1687
|
+
hOffSet = this.get('horizontalScrollOffset'),
|
1688
|
+
forceHeight = mxVOffSet < vOffSet,
|
1689
|
+
forceWidth = mxHOffSet < hOffSet;
|
1690
|
+
if (forceHeight || forceWidth) {
|
1691
|
+
this.forceDimensionsRecalculation(forceWidth, forceHeight, vOffSet, hOffSet);
|
1692
|
+
}
|
1693
|
+
},
|
1694
|
+
|
1695
|
+
/** @private
|
1696
|
+
If our frame changes, then we need to re-calculate the visiblility of our
|
1697
|
+
scrollers, etc.
|
1698
|
+
*/
|
1699
|
+
frameDidChange: function() {
|
1700
|
+
this.contentViewFrameDidChange(YES);
|
1701
|
+
}.observes('frame'),
|
1702
|
+
|
1703
|
+
/** @private
|
1704
|
+
If the layer of the content view changes, we need to readjust the
|
1705
|
+
scrollTop and scrollLeft properties on the new DOM element.
|
1706
|
+
*/
|
1707
|
+
contentViewLayerDidChange: function() {
|
1708
|
+
// Invalidate these cached values, as they're no longer valid
|
1709
|
+
if (this._verticalScrollOffset !== 0) this._verticalScrollOffset = -1;
|
1710
|
+
if (this._horizontalScrollOffset !== 0) this._horizontalScrollOffset = -1;
|
1711
|
+
this.invokeLast(this.adjustElementScroll);
|
1712
|
+
},
|
1713
|
+
|
1714
|
+
/** @private
|
1715
|
+
Whenever the horizontal scroll offset changes, update the scrollers and
|
1716
|
+
edit the location of the contentView.
|
1717
|
+
*/
|
1718
|
+
_scroll_horizontalScrollOffsetDidChange: function() {
|
1719
|
+
this.invokeLast(this.adjustElementScroll);
|
1720
|
+
}.observes('horizontalScrollOffset'),
|
1721
|
+
|
1722
|
+
/** @private
|
1723
|
+
Whenever the vertical scroll offset changes, update the scrollers and
|
1724
|
+
edit the location of the contentView.
|
1725
|
+
*/
|
1726
|
+
_scroll_verticalScrollOffsetDidChange: function() {
|
1727
|
+
this.invokeLast(this.adjustElementScroll);
|
1728
|
+
}.observes('verticalScrollOffset'),
|
1729
|
+
|
1730
|
+
/** @private
|
1731
|
+
Called at the end of the run loop to actually adjust the scrollTop
|
1732
|
+
and scrollLeft properties of the container view.
|
1733
|
+
*/
|
1734
|
+
adjustElementScroll: function() {
|
1735
|
+
var container = this.get('containerView'),
|
1736
|
+
content = this.get('contentView'),
|
1737
|
+
verticalScrollOffset = this.get('verticalScrollOffset'),
|
1738
|
+
horizontalScrollOffset = this.get('horizontalScrollOffset');
|
1739
|
+
|
1740
|
+
// We notify the content view that its frame property has changed
|
1741
|
+
// before we actually update the scrollTop/scrollLeft properties.
|
1742
|
+
// This gives views that use incremental rendering a chance to render
|
1743
|
+
// newly-appearing elements before they come into view.
|
1744
|
+
if (content) {
|
1745
|
+
SC.RunLoop.begin();
|
1746
|
+
content._viewFrameDidChange();
|
1747
|
+
SC.RunLoop.end();
|
1748
|
+
|
1749
|
+
// Use accelerated drawing if the browser supports it
|
1750
|
+
if (SC.platform.touch) {
|
1751
|
+
this._applyCSSTransforms(content.get('layer'));
|
1752
|
+
}
|
1753
|
+
}
|
1754
|
+
|
1755
|
+
if (container && !SC.platform.touch) {
|
1756
|
+
container = container.$()[0];
|
1757
|
+
|
1758
|
+
if (container) {
|
1759
|
+
if (verticalScrollOffset !== this._verticalScrollOffset) {
|
1760
|
+
container.scrollTop = verticalScrollOffset;
|
1761
|
+
this._verticalScrollOffset = verticalScrollOffset;
|
1762
|
+
}
|
1763
|
+
|
1764
|
+
if (horizontalScrollOffset !== this._horizontalScrollOffset) {
|
1765
|
+
container.scrollLeft = horizontalScrollOffset;
|
1766
|
+
this._horizontalScrollOffset = horizontalScrollOffset;
|
1767
|
+
}
|
1768
|
+
}
|
1769
|
+
}
|
1770
|
+
},
|
1771
|
+
|
1772
|
+
forceDimensionsRecalculation: function (forceWidth, forceHeight, vOffSet, hOffSet) {
|
1773
|
+
var oldScrollHOffset = hOffSet;
|
1774
|
+
var oldScrollVOffset = vOffSet;
|
1775
|
+
this.scrollTo(0,0);
|
1776
|
+
if(forceWidth && forceHeight){
|
1777
|
+
this.scrollTo(this.get('maximumHorizontalScrollOffset'), this.get('maximumVerticalScrollOffset'));
|
1778
|
+
}
|
1779
|
+
if(forceWidth && !forceHeight){
|
1780
|
+
this.scrollTo(this.get('maximumHorizontalScrollOffset'), oldScrollVOffset);
|
1781
|
+
}
|
1782
|
+
if(!forceWidth && forceHeight){
|
1783
|
+
this.scrollTo(oldScrollHOffset ,this.get('maximumVerticalScrollOffset'));
|
1784
|
+
}
|
1785
|
+
},
|
1786
|
+
|
1787
|
+
_scroll_verticalScrollOffset: 0,
|
1788
|
+
_scroll_horizontalScrollOffset: 0
|
1789
|
+
|
1790
|
+
});
|