sproutcore 1.5.0.pre.3 → 1.5.0.pre.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (308) hide show
  1. data/.rspec +1 -0
  2. data/CHANGELOG +42 -0
  3. data/README.txt +25 -0
  4. data/VERSION.yml +1 -1
  5. data/bin/sc-build +1 -1
  6. data/bin/sc-build-number +1 -1
  7. data/bin/sc-docs +1 -1
  8. data/bin/sc-gen +1 -1
  9. data/bin/sc-init +1 -1
  10. data/bin/sc-manifest +1 -1
  11. data/bin/sc-server +1 -1
  12. data/bin/sproutcore +1 -1
  13. data/lib/buildtasks/build.rake +5 -0
  14. data/lib/buildtasks/manifest.rake +20 -1
  15. data/lib/frameworks/sproutcore/Buildfile +12 -9
  16. data/lib/frameworks/sproutcore/CHANGELOG.md +48 -0
  17. data/lib/frameworks/sproutcore/apps/greenhouse/README +2 -9
  18. data/lib/frameworks/sproutcore/apps/greenhouse/TODO +11 -27
  19. data/lib/frameworks/sproutcore/apps/greenhouse/controllers/library.js +3 -10
  20. data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/css/main-page.css +4 -31
  21. data/lib/frameworks/sproutcore/apps/greenhouse/english.lproj/dialogs.js +5 -4
  22. data/lib/frameworks/sproutcore/apps/greenhouse/models/dir.js +3 -3
  23. data/lib/frameworks/sproutcore/apps/greenhouse/models/file.js +2 -2
  24. data/lib/frameworks/sproutcore/apps/greenhouse/states/main.js +31 -14
  25. data/lib/frameworks/sproutcore/apps/greenhouse/states/modals.js +2 -1
  26. data/lib/frameworks/sproutcore/apps/greenhouse/states/ready.js +27 -1
  27. data/lib/frameworks/sproutcore/apps/greenhouse/tests/views/list_item.js +1 -0
  28. data/lib/frameworks/sproutcore/apps/greenhouse/tests/views/plist_item.js +20 -0
  29. data/lib/frameworks/sproutcore/apps/greenhouse/theme.js +25 -0
  30. data/lib/frameworks/sproutcore/apps/greenhouse/views/plist_item.js +161 -24
  31. data/lib/frameworks/sproutcore/apps/greenhouse/views/tear_off_picker.js +1 -1
  32. data/lib/frameworks/sproutcore/frameworks/bootstrap/system/browser.js +37 -25
  33. data/lib/frameworks/sproutcore/frameworks/bootstrap/tests/system/browser.js +135 -26
  34. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/controllers/array.js +0 -0
  35. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/controllers/controller.js +0 -0
  36. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/controllers/object.js +1 -1
  37. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/core.js +0 -0
  38. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/ext/object.js +0 -0
  39. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/ext/run_loop.js +1 -0
  40. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/delegate_support.js +0 -0
  41. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/responder_context.js +0 -0
  42. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/selection_support.js +0 -0
  43. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/mixins/string.js +0 -0
  44. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/keyboard.js +68 -0
  45. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/layout.js +108 -0
  46. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/panes/main.js +2 -2
  47. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/manipulation.js +27 -0
  48. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/panes/pane.js +215 -505
  49. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/template.js +24 -0
  50. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/visibility.js +11 -0
  51. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/protocols/observable_protocol.js +0 -0
  52. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/protocols/sparse_array_delegate.js +0 -0
  53. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/resources/core.css +0 -0
  54. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/resources/view.css +0 -0
  55. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/application.js +0 -0
  56. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/browser.js +1 -0
  57. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/builder.js +0 -0
  58. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/core_query.js +1 -1
  59. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/cursor.js +0 -0
  60. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/device.js +210 -0
  61. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/event.js +5 -5
  62. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/json.js +0 -0
  63. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/locale.js +0 -0
  64. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/page.js +0 -0
  65. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/platform.js +31 -5
  66. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/ready.js +1 -1
  67. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/render_context.js +0 -0
  68. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/responder.js +0 -0
  69. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/root_responder.js +83 -110
  70. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/selection_set.js +7 -4
  71. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/sparse_array.js +0 -0
  72. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/theme.js +0 -0
  73. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/timer.js +0 -0
  74. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/system/utils/rect.js +0 -0
  75. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/utils.js +151 -0
  76. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/array_case.js +0 -0
  77. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/enum_case.js +0 -0
  78. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/null_case.js +0 -0
  79. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/selection_support.js +26 -0
  80. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/array/single_case.js +0 -0
  81. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/empty_case.js +0 -0
  82. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/multiple_case.js +0 -0
  83. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/single_case.js +0 -0
  84. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/controllers/object/single_enumerable_case.js +0 -0
  85. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/mixins/responder_context.js +0 -0
  86. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/mixins/string.js +0 -0
  87. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/panes/template.js +14 -0
  88. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/builder.js +0 -0
  89. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/core_query/within.js +0 -0
  90. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/json.js +0 -0
  91. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/locale.js +0 -0
  92. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/begin.js +0 -0
  93. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/element.js +0 -0
  94. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/end.js +0 -0
  95. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/get.js +0 -0
  96. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_attr.js +0 -0
  97. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_basic.js +0 -0
  98. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_className.js +0 -0
  99. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/helpers_style.js +0 -0
  100. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/init.js +0 -0
  101. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/join.js +0 -0
  102. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/push_text.js +0 -0
  103. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/tag.js +0 -0
  104. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/render_context/update.js +0 -0
  105. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/makeKeyPane.js +0 -0
  106. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/makeMainPane.js +0 -0
  107. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/makeMenuPane.js +0 -0
  108. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/root_responder.js +0 -0
  109. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/root_responder/targetForAction.js +0 -0
  110. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/add.js +0 -0
  111. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/copy.js +0 -0
  112. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/indexSetForSource.js +0 -0
  113. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/isEqual.js +0 -0
  114. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/selection_set/remove.js +0 -0
  115. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/sparse_array.js +0 -0
  116. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/theme.js +0 -0
  117. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/invalidate.js +0 -0
  118. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/invokeLater.js +0 -0
  119. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/isPaused.js +0 -0
  120. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/performAction.js +0 -0
  121. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/timer/schedule.js +0 -0
  122. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/utils/normalizeURL.js +0 -0
  123. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/utils/offset.js +268 -0
  124. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/system/utils/rect.js +0 -0
  125. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/main_pane.js +43 -0
  126. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/append_remove.js +107 -18
  127. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/pane/child_view.js +20 -0
  128. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/firstResponder.js +0 -0
  129. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/keyPane.js +0 -0
  130. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/layout.js +0 -0
  131. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/pane/sendEvent.js +0 -0
  132. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template/checkbox_support.js +32 -0
  133. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template/text_field_support.js +73 -0
  134. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template_view/collection.js +65 -0
  135. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template_view/core.js +67 -0
  136. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/template_view/handlebars.js +295 -0
  137. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/animation.js +19 -18
  138. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/build.js +0 -0
  139. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/build_children.js +0 -0
  140. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/clippingFrame.js +0 -0
  141. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/convertFrames.js +0 -0
  142. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/convertLayouts.js +0 -0
  143. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/createChildViews.js +18 -15
  144. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/createLayer.js +0 -0
  145. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/destroyLayer.js +0 -0
  146. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/didAppendToDocument.js +11 -8
  147. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/findLayerInParentLayer.js +0 -0
  148. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/init.js +0 -0
  149. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/insertBefore.js +0 -0
  150. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/isVisible.js +28 -0
  151. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/isVisibleInWindow.js +0 -0
  152. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/keyboard.js +22 -0
  153. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/layer.js +0 -0
  154. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/layoutChildViews.js +0 -0
  155. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/layoutDidChange.js +180 -0
  156. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/layoutStyle.js +640 -0
  157. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/parentViewDidChange.js +0 -0
  158. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/prepareContext.js +0 -0
  159. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/removeChild.js +0 -0
  160. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/render.js +125 -0
  161. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/render_delegate_support.js +0 -0
  162. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/replaceChild.js +0 -0
  163. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/static_layout.js +21 -0
  164. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/theme.js +0 -0
  165. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/updateLayer.js +0 -0
  166. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/updateLayerLocation.js +0 -0
  167. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/view.js +0 -0
  168. data/lib/frameworks/sproutcore/frameworks/{amber → core_foundation}/tests/views/view/viewDidResize.js +0 -0
  169. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template/checkbox_support.js +20 -0
  170. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template/collection.js +99 -0
  171. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template/text_field_support.js +35 -0
  172. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/template.js +77 -0
  173. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/animation.js +187 -0
  174. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/base.js +1 -0
  175. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/cursor.js +41 -0
  176. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/enabled.js +57 -0
  177. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/keyboard.js +223 -0
  178. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/layout.js +1150 -0
  179. data/lib/frameworks/sproutcore/frameworks/{amber/views → core_foundation/views/view}/layout_style.js +93 -1
  180. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/manipulation.js +489 -0
  181. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/theming.js +362 -0
  182. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/touch.js +67 -0
  183. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/visibility.js +113 -0
  184. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view.js +1280 -0
  185. data/lib/frameworks/sproutcore/frameworks/datastore/models/child_attribute.js +27 -53
  186. data/lib/frameworks/sproutcore/frameworks/datastore/models/children_attribute.js +13 -19
  187. data/lib/frameworks/sproutcore/frameworks/datastore/models/many_attribute.js +1 -0
  188. data/lib/frameworks/sproutcore/frameworks/datastore/models/record.js +183 -71
  189. data/lib/frameworks/sproutcore/frameworks/datastore/models/record_attribute.js +1 -2
  190. data/lib/frameworks/sproutcore/frameworks/datastore/system/child_array.js +26 -46
  191. data/lib/frameworks/sproutcore/frameworks/datastore/system/nested_store.js +25 -4
  192. data/lib/frameworks/sproutcore/frameworks/datastore/system/store.js +139 -21
  193. data/lib/frameworks/sproutcore/frameworks/datastore/tests/data_sources/fixtures.js +6 -1
  194. data/lib/frameworks/sproutcore/frameworks/datastore/tests/integration/cyclical_relationship.js +1 -1
  195. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/{parentless.js → data_store.js} +62 -16
  196. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record.js +51 -17
  197. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array.js +36 -10
  198. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array_complex.js +11 -11
  199. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_complex.js +8 -8
  200. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/normalize.js +2 -2
  201. data/lib/frameworks/sproutcore/frameworks/{foundation/english.lproj → datetime/resources}/strings.js +1 -0
  202. data/lib/frameworks/sproutcore/frameworks/{foundation → datetime}/system/datetime.js +5 -37
  203. data/lib/frameworks/sproutcore/frameworks/{foundation → datetime}/tests/system/datetime.js +1 -0
  204. data/lib/frameworks/sproutcore/frameworks/debug/core.js +1 -1
  205. data/lib/frameworks/sproutcore/frameworks/designer/controllers/designs.js +1 -2
  206. data/lib/frameworks/sproutcore/frameworks/designer/designers/object_designer.js +3 -3
  207. data/lib/frameworks/sproutcore/frameworks/designer/designers/view_designer.js +3 -3
  208. data/lib/frameworks/sproutcore/frameworks/designer/views/designer_drop_target.js +9 -3
  209. data/lib/frameworks/sproutcore/frameworks/desktop/english.lproj/segmented.css +71 -70
  210. data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_row_delegate.js +10 -2
  211. data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/segment.js +4 -19
  212. data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/segmented.js +33 -14
  213. data/lib/frameworks/sproutcore/frameworks/desktop/system/drag.js +25 -0
  214. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/date_field/ui.js +1 -1
  215. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/methods.js +25 -103
  216. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/ui.js +102 -92
  217. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/tab/ui.js +22 -25
  218. data/lib/frameworks/sproutcore/frameworks/desktop/views/collection.js +38 -25
  219. data/lib/frameworks/sproutcore/frameworks/desktop/views/date_field.js +1 -1
  220. data/lib/frameworks/sproutcore/frameworks/desktop/views/scroll.js +1 -1
  221. data/lib/frameworks/sproutcore/frameworks/desktop/views/segment.js +42 -22
  222. data/lib/frameworks/sproutcore/frameworks/desktop/views/segmented.js +513 -230
  223. data/lib/frameworks/sproutcore/frameworks/desktop/views/select_field.js +0 -2
  224. data/lib/frameworks/sproutcore/frameworks/experimental/README.md +23 -0
  225. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/device_motion/README.md +11 -0
  226. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/device_motion/device.js +215 -0
  227. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/device_motion/platform.js +67 -0
  228. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/README.md +34 -0
  229. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/models/polymorphic_single_attribute.js +183 -0
  230. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/models/record.js +23 -0
  231. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/tests/models/polymorphic/single.js +124 -0
  232. data/lib/frameworks/sproutcore/frameworks/foundation/mixins/auto_resize.js +0 -2
  233. data/lib/frameworks/sproutcore/frameworks/foundation/mixins/inner_frame.js +151 -0
  234. data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/canvas_image.js +27 -17
  235. data/lib/frameworks/sproutcore/frameworks/foundation/system/image_queue.js +6 -3
  236. data/lib/frameworks/sproutcore/frameworks/foundation/system/logger.js +163 -0
  237. data/lib/frameworks/sproutcore/frameworks/foundation/system/user_defaults.js +6 -3
  238. data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/inline_text_field/beginEditing.js +1 -0
  239. data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/logger.js +44 -0
  240. data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/image/ui.js +200 -167
  241. data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/ui.js +1 -1
  242. data/lib/frameworks/sproutcore/frameworks/foundation/views/image.js +52 -137
  243. data/lib/frameworks/sproutcore/frameworks/foundation/views/text_field.js +7 -11
  244. data/lib/frameworks/sproutcore/frameworks/handlebars/extensions.js +138 -0
  245. data/lib/frameworks/sproutcore/frameworks/handlebars/handlebars.js +1338 -0
  246. data/lib/frameworks/sproutcore/frameworks/runtime/core.js +32 -26
  247. data/lib/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/base.js +162 -3
  248. data/lib/frameworks/sproutcore/frameworks/runtime/mixins/array.js +10 -5
  249. data/lib/frameworks/sproutcore/frameworks/runtime/mixins/enumerable.js +123 -3
  250. data/lib/frameworks/sproutcore/frameworks/runtime/mixins/observable.js +12 -5
  251. data/lib/frameworks/sproutcore/frameworks/runtime/private/chain_observer.js +50 -13
  252. data/lib/frameworks/sproutcore/frameworks/runtime/system/logger.js +163 -333
  253. data/lib/frameworks/sproutcore/frameworks/runtime/system/object.js +58 -8
  254. data/lib/frameworks/sproutcore/frameworks/runtime/system/run_loop.js +2 -0
  255. data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/itemType.js +9 -6
  256. data/lib/frameworks/sproutcore/frameworks/runtime/tests/core/makeArray.js +15 -1
  257. data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/array.js +2 -0
  258. data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/chained.js +31 -0
  259. data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/observable.js +18 -0
  260. data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/logger.js +31 -143
  261. data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/object/concatenated_properties.js +71 -0
  262. data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/object/enhance.js +177 -0
  263. data/lib/frameworks/sproutcore/frameworks/table/views/table.js +5 -4
  264. data/lib/frameworks/sproutcore/frameworks/table/views/table_header.js +5 -3
  265. data/lib/frameworks/sproutcore/themes/ace/resources/button/button.js +8 -2
  266. data/lib/frameworks/sproutcore/themes/ace/resources/menu/menu.css +2 -3
  267. data/lib/frameworks/sproutcore/themes/ace/resources/segmented/18px/segmented.css +1 -1
  268. data/lib/frameworks/sproutcore/themes/ace/resources/segmented/24px/segmented.css +1 -1
  269. data/lib/frameworks/sproutcore/themes/ace/resources/segmented/30px/segmented.css +1 -1
  270. data/lib/frameworks/sproutcore/themes/ace/resources/segmented/44px/segmented.css +1 -1
  271. data/lib/frameworks/sproutcore/themes/ace/resources/segmented/segmented.css +2 -2
  272. data/lib/frameworks/sproutcore/themes/standard_theme/english.lproj/segmented.css +62 -62
  273. data/lib/gen/html_app/Buildfile +36 -0
  274. data/lib/gen/html_app/README +1 -0
  275. data/lib/gen/html_app/USAGE +15 -0
  276. data/lib/gen/html_app/templates/apps/@target_name@/@target_name@.js +14 -0
  277. data/lib/gen/html_app/templates/apps/@target_name@/resources/images/.gitkeep +0 -0
  278. data/lib/gen/html_app/templates/apps/@target_name@/resources/stylesheets/@target_name@.css +0 -0
  279. data/lib/gen/html_app/templates/apps/@target_name@/resources/templates/@target_name@.handlebars +1 -0
  280. data/lib/gen/html_project/Buildfile +45 -0
  281. data/lib/gen/html_project/INIT +3 -0
  282. data/lib/gen/html_project/README +1 -0
  283. data/lib/gen/html_project/USAGE +2 -0
  284. data/lib/gen/html_project/templates/@filename@/Buildfile +8 -0
  285. data/lib/gen/html_project/templates/@filename@/README +7 -0
  286. data/lib/sproutcore/builders/handlebars.rb +30 -0
  287. data/lib/sproutcore/builders.rb +1 -1
  288. data/lib/sproutcore/helpers/static_helper.rb +3 -3
  289. data/lib/sproutcore/tools/init.rb +25 -9
  290. data/spec/buildtasks/manifest/prepare_build_tasks/handlebars_spec.rb +39 -0
  291. data/spec/fixtures/builder_tests/apps/handlebars_test/template.handlebars +5 -0
  292. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/templates/demo.handlebars +4 -0
  293. data/spec/lib/builders/handlebars_spec.rb +29 -0
  294. data/vendor/chance/lib/chance/imagers/data_url.rb +20 -7
  295. data/vendor/chance/lib/chance/instance.rb +4 -1
  296. data/vendor/chance/lib/chance/parser.rb +31 -31
  297. data/vendor/chance/lib/chance/slicing.rb +38 -8
  298. metadata +195 -225
  299. data/lib/frameworks/sproutcore/frameworks/amber/system/device.js +0 -143
  300. data/lib/frameworks/sproutcore/frameworks/amber/system/utils.js +0 -174
  301. data/lib/frameworks/sproutcore/frameworks/amber/tests/views/main_pane.js +0 -31
  302. data/lib/frameworks/sproutcore/frameworks/amber/tests/views/pane/sendTouchEvent.js +0 -267
  303. data/lib/frameworks/sproutcore/frameworks/amber/tests/views/view/layoutDidChange.js +0 -149
  304. data/lib/frameworks/sproutcore/frameworks/amber/tests/views/view/layoutStyle.js +0 -602
  305. data/lib/frameworks/sproutcore/frameworks/amber/tests/views/view/render.js +0 -115
  306. data/lib/frameworks/sproutcore/frameworks/amber/views/base.js +0 -1
  307. data/lib/frameworks/sproutcore/frameworks/amber/views/view.js +0 -4003
  308. data/lib/frameworks/sproutcore/frameworks/datastore/models/child_record.js +0 -105
@@ -1,602 +0,0 @@
1
- // ========================================================================
2
- // View Layout Unit Tests
3
- // ========================================================================
4
-
5
- /*globals module test ok same equals */
6
-
7
- /* These unit tests verify: layout(), frame(), styleLayout() and clippingFrame(). */
8
-
9
- var parent, child;
10
-
11
- /*
12
- helper method to test the layout of a view. Applies the passed layout to a
13
- view, then compares both its frame and layoutStyle properties both before
14
- and after adding the view to a parent view.
15
-
16
- You can pass frame rects with some properties missing and they will be
17
- filled in for you just so you don't have to write so much code.
18
-
19
- @param {Hash} layout layout hash to test
20
- @param {Hash} no_f expected frame for view with no parent
21
- @param {Hash} no_s expected layoutStyle for view with no parent
22
- @param {Hash} with_f expected frame for view with parent
23
- @param {Hash} with_s expected layoutStyle for view with parent
24
- @returns {void}
25
- */
26
- function performLayoutTest(layout, no_f, no_s, with_f, with_s) {
27
-
28
- // make sure we add null properties and convert numbers to 'XXpx' to style layout.
29
- var keys = 'width height top bottom marginLeft marginTop left right zIndex minWidth maxWidth minHeight maxHeight'.w();
30
- if (SC.platform.supportsCSSTransforms) keys.push('transform');
31
-
32
- keys.forEach(function(key) {
33
- if (no_s[key]===undefined) no_s[key] = null;
34
- if (with_s[key]===undefined) with_s[key] = null;
35
-
36
- if (typeof no_s[key] === 'number') no_s[key] = no_s[key].toString() + 'px';
37
- if (typeof with_s[key] === 'number') with_s[key] = no_s[key].toString() + 'px';
38
- });
39
-
40
- // set layout
41
- child.set('layout', layout) ;
42
-
43
- var testKey;
44
-
45
- // test
46
- keys.forEach(function(key) {
47
- testKey = key === 'transform' ? SC.platform.domCSSPrefix+'Transform' : key;
48
- equals(child.get('layoutStyle')[testKey], no_s[key], "STYLE NO PARENT %@".fmt(key)) ;
49
- });
50
-
51
- // add parent
52
- SC.RunLoop.begin();
53
- parent.appendChild(child);
54
- SC.RunLoop.end();
55
-
56
- // test again
57
- keys.forEach(function(key) {
58
- testKey = key === 'transform' ? SC.platform.domCSSPrefix+'Transform' : key;
59
- equals(child.get('layoutStyle')[testKey], with_s[key], "STYLE W/ PARENT %@".fmt(key)) ;
60
- });
61
- }
62
-
63
- /**
64
- Helper setup that creates a parent and child view so that you can do basic
65
- tests.
66
- */
67
- var commonSetup = {
68
- setup: function() {
69
-
70
- // create basic parent view
71
- parent = SC.View.create({
72
- layout: { top: 0, left: 0, width: 200, height: 200 }
73
- });
74
-
75
- // create child view to test against.
76
- child = SC.View.create();
77
- },
78
-
79
- teardown: function() {
80
- parent = child = null ;
81
- }
82
- };
83
-
84
- module("NOTIFICATIONS", commonSetup) ;
85
-
86
- test("Setting layout will notify frame observers", function() {
87
- var didNotify = NO, didNotifyStyle = NO;
88
- child.addObserver('frame', this, function() { didNotify = YES; }) ;
89
- child.addObserver('layoutStyle', this, function() { didNotifyStyle = YES; });
90
-
91
- child.set('layout', { left: 0, top: 10, bottom: 20, right: 50 }) ;
92
- ok(didNotify, "didNotify");
93
- ok(didNotifyStyle, 'didNotifyStyle');
94
- }) ;
95
-
96
- // ..........................................................
97
- // TEST FRAME/STYLEFRAME WITH BASIC LAYOUT VARIATIONS
98
- //
99
- // NOTE: Each test evaluates the frame before and after adding it to the
100
- // parent.
101
-
102
- module('BASIC LAYOUT VARIATIONS', commonSetup);
103
-
104
- test("layout {top, left, width, height}", function() {
105
-
106
- var layout = { top: 10, left: 10, width: 50, height: 50 };
107
- var s = { top: 10, left: 10, width: 50, height: 50 } ;
108
- var no_f = { x: 10, y: 10, width: 50, height: 50 } ;
109
- var with_f = { x: 10, y: 10, width: 50, height: 50 } ;
110
-
111
- performLayoutTest(layout, no_f, s, with_f, s) ;
112
- }) ;
113
-
114
- test("layout {top, left, bottom, right}", function() {
115
-
116
- var layout = { top: 10, left: 10, bottom: 10, right: 10 };
117
- var no_f = { x: 10, y: 10, width: 0, height: 0 } ;
118
- var with_f = { x: 10, y: 10, width: 180, height: 180 } ;
119
- var s = { top: 10, left: 10, bottom: 10, right: 10 } ;
120
-
121
- performLayoutTest(layout, no_f, s, with_f, s) ;
122
- }) ;
123
-
124
- test("layout {bottom, right, width, height}", function() {
125
-
126
- var layout = { bottom: 10, right: 10, width: 50, height: 50 };
127
- var no_f = { x: 0, y: 0, width: 50, height: 50 } ;
128
- var with_f = { x: 140, y: 140, width: 50, height: 50 } ;
129
- var s = { bottom: 10, right: 10, width: 50, height: 50 } ;
130
-
131
- performLayoutTest(layout, no_f, s, with_f, s) ;
132
- }) ;
133
-
134
- test("layout {centerX, centerY, width, height}", function() {
135
-
136
- var layout = { centerX: 10, centerY: 10, width: 60, height: 60 };
137
- var no_f = { x: 10, y: 10, width: 60, height: 60 } ;
138
- var with_f = { x: 80, y: 80, width: 60, height: 60 } ;
139
- var s = { marginLeft: -20, marginTop: -20, width: 60, height: 60, top: "50%", left: "50%" } ;
140
-
141
- performLayoutTest(layout, no_f, s, with_f, s) ;
142
- }) ;
143
-
144
- test("layout {top, left, width: auto, height: auto}", function() {
145
- child = SC.View.create({
146
- useStaticLayout: YES,
147
- render: function(context) {
148
- // needed for auto
149
- context.push('<div style="padding: 10px"></div>');
150
- }
151
- });
152
-
153
- // parent MUST have a layer.
154
- parent.createLayer();
155
- var layer = parent.get('layer');
156
- document.body.appendChild(layer);
157
-
158
- var layout = { top: 0, left: 0, width: 'auto', height: 'auto' };
159
- var no_f = { x: 0, y: 0, width: 0, height: 0 };
160
- var with_f = { x: 0, y: 0, width: 20, height: 20 };
161
- var s = { top: 0, left: 0, width: 'auto', height: 'auto' };
162
-
163
- performLayoutTest(layout, no_f, s, with_f, s);
164
-
165
- layer.parentNode.removeChild(layer);
166
- });
167
-
168
-
169
- // ..........................................................
170
- // TEST FRAME/STYLEFRAME WITH BASIC LAYOUT VARIATIONS
171
- //
172
- // NOTE: Each test evaluates the frame before and after adding it to the
173
- // parent.
174
-
175
- module('BASIC LAYOUT VARIATIONS PERCENTAGE', commonSetup);
176
-
177
- test("layout {top, left, width, height}", function() {
178
-
179
- var layout = { top: 0.1, left: 0.1, width: 0.5, height: 0.5 };
180
- var s = { top: '10%', left: '10%', width: '50%', height: '50%' } ;
181
- var no_f = { top: '10%', left: '10%', width: '50%', height: '50%' } ;
182
- var with_f = { top: '10%', left: '10%', width: '50%', height: '50%' } ;
183
-
184
- performLayoutTest(layout, no_f, s, with_f, s) ;
185
- }) ;
186
-
187
- test("layout {top, left, bottom, right}", function() {
188
-
189
- var layout = { top: 0.1, left: 0.1, bottom: 0.1, right: 0.1 };
190
- var no_f = { top: '10%', left: '10%', bottom: '10%', right: '10%' };
191
- var with_f = { top: '10%', left: '10%', bottom: '10%', right: '10%' };
192
- var s = { top: '10%', left: '10%', bottom: '10%', right: '10%' } ;
193
-
194
- performLayoutTest(layout, no_f, s, with_f, s) ;
195
- }) ;
196
-
197
- test("layout {bottom, right, width, height}", function() {
198
-
199
- var layout = { bottom: 0.1, right: 0.1, width: 0.5, height: 0.5 };
200
- var no_f = { bottom: '10%', right: '10%', width: '50%', height: '50%' };
201
- var with_f = { bottom: '10%', right: '10%', width: '50%', height: '50%' };
202
- var s = { bottom: '10%', right: '10%', width: '50%', height: '50%' } ;
203
-
204
- performLayoutTest(layout, no_f, s, with_f, s) ;
205
- }) ;
206
-
207
- test("layout {centerX, centerY, width, height}", function() {
208
-
209
- var layout = { centerX: 0.1, centerY: 0.1, width: 0.6, height: 0.6 };
210
- var no_f = { x: 10, y: 10, width: 60, height: 60 } ;
211
- var with_f = { x: 80, y: 80, width: 60, height: 60 } ;
212
- var s = { marginLeft: '-20%', marginTop: '-20%', width: '60%', height: '60%', top: "50%", left: "50%" } ;
213
-
214
- performLayoutTest(layout, no_f, s, with_f, s) ;
215
- }) ;
216
-
217
- test("layout {top, left, width: auto, height: auto}", function() {
218
- child = SC.View.create({
219
- useStaticLayout: YES,
220
- render: function(context) {
221
- // needed for auto
222
- context.push('<div style="padding: 10px"></div>');
223
- }
224
- });
225
-
226
- // parent MUST have a layer.
227
- parent.createLayer();
228
- var layer = parent.get('layer');
229
- document.body.appendChild(layer);
230
-
231
- var layout = { top: 0.1, left: 0.1, width: 'auto', height: 'auto' };
232
- var no_f = { x: 0, y: 0, width: 0, height: 0 };
233
- var with_f = { x: 0, y: 0, width: 20, height: 20 };
234
- var s = { top: '10%', left: '10%', width: 'auto', height: 'auto' };
235
-
236
- performLayoutTest(layout, no_f, s, with_f, s);
237
-
238
- layer.parentNode.removeChild(layer);
239
- });
240
-
241
-
242
-
243
- // ..........................................................
244
- // TEST CSS TRANSFORM LAYOUT VARIATIONS
245
- //
246
- // NOTE: Each test evaluates the frame before and after adding it to the
247
- // parent.
248
-
249
- module('CSS TRANSFORM LAYOUT VARIATIONS', {
250
- setup: function(){
251
- commonSetup.setup();
252
- child.createLayer();
253
- document.body.appendChild(child.get('layer'));
254
- },
255
-
256
- teardown: function(){
257
- child.destroyLayer();
258
- commonSetup.teardown();
259
- }
260
- });
261
-
262
- function transformFor(view){
263
- return view.get('layer').style[SC.platform.domCSSPrefix+'Transform'];
264
- }
265
-
266
- test("layout {rotateX}", function() {
267
- child.adjust('rotateX', 45).updateLayout();
268
- equals(transformFor(child), 'rotateX(45deg)', 'transform attribute should be "rotateX(45deg)"')
269
- });
270
-
271
- test("layout {rotateY}", function() {
272
- child.adjust('rotateY', 45).updateLayout();
273
- equals(transformFor(child), 'rotateY(45deg)', 'transform attribute should be "rotateY(45deg)"')
274
- });
275
-
276
- test("layout {rotateZ}", function() {
277
- child.adjust('rotateZ', 45).updateLayout();
278
- equals(transformFor(child), 'rotateZ(45deg)', 'transform attribute should be "rotateZ(45deg)"')
279
- });
280
-
281
- test("layout {rotate}", function() {
282
- child.adjust('rotate', 45).updateLayout();
283
- equals(transformFor(child), 'rotateX(45deg)', 'transform attribute should be "rotateX(45deg)"')
284
- });
285
-
286
- test("layout {rotateX} with units", function() {
287
- child.adjust('rotateX', '1rad').updateLayout();
288
- equals(transformFor(child), 'rotateX(1rad)', 'transform attribute should be "rotateX(1rad)"')
289
- });
290
-
291
- test("layout {scale}", function() {
292
- child.adjust('scale', 2).updateLayout();
293
- equals(transformFor(child), 'scale(2)', 'transform attribute should be "scale(2)"')
294
- });
295
-
296
- test("layout {scale} with multiple", function() {
297
- child.adjust('scale', [2, 3]).updateLayout();
298
- equals(transformFor(child), 'scale(2, 3)', 'transform attribute should be "scale(2, 3)"')
299
- });
300
-
301
- test("layout {rotateX, scale}", function() {
302
- child.adjust({ rotateX: 45, scale: 2 }).updateLayout();
303
- equals(transformFor(child), 'rotateX(45deg) scale(2)', 'transform attribute should be "rotateX(45deg) scale(2)"')
304
- });
305
-
306
- test("layout {rotateX} update", function() {
307
- child.adjust('rotateX', 45).updateLayout();
308
- child.adjust('rotateX', 90).updateLayout();
309
- equals(transformFor(child), 'rotateX(90deg)', 'transform attribute should be "rotateX(90deg)"')
310
- });
311
-
312
-
313
- if (SC.platform.supportsCSSTransforms) {
314
-
315
- // ..........................................................
316
- // TEST FRAME/STYLEFRAME WITH ACCELERATE LAYOUT VARIATIONS
317
- //
318
- // NOTE: Each test evaluates the frame before and after adding it to the
319
- // parent.
320
-
321
- module('ACCELERATED LAYOUT VARIATIONS', {
322
- setup: function(){
323
- commonSetup.setup();
324
- child.wantsAcceleratedLayer = YES;
325
- },
326
-
327
- teardown: commonSetup.teardown
328
- });
329
-
330
- test("layout {top, left, width, height}", function() {
331
- var layout = { top: 10, left: 10, width: 50, height: 50 };
332
- var expectedTransform = 'translateX(10px) translateY(10px)';
333
- if (SC.platform.supportsCSS3DTransforms) expectedTransform += ' translateZ(0px)';
334
- var s = { top: 0, left: 0, width: 50, height: 50, transform: expectedTransform } ;
335
- var no_f = { x: 0, y: 0, width: 50, height: 50, transform: expectedTransform } ;
336
- var with_f = { x: 0, y: 0, width: 50, height: 50, transform: expectedTransform } ;
337
-
338
- performLayoutTest(layout, no_f, s, with_f, s) ;
339
- }) ;
340
-
341
- test("layout {top, left, bottom, right}", function() {
342
-
343
- var layout = { top: 10, left: 10, bottom: 10, right: 10 };
344
- var no_f = { x: 10, y: 10, width: 0, height: 0, transform: null } ;
345
- var with_f = { x: 10, y: 10, width: 180, height: 180, transform: null } ;
346
- var s = { top: 10, left: 10, bottom: 10, right: 10, transform: null } ;
347
-
348
- performLayoutTest(layout, no_f, s, with_f, s) ;
349
- }) ;
350
-
351
- test("layout {top, left, width: auto, height: auto}", function() {
352
- child = SC.View.create({
353
- wantsAcceleratedLayer: YES,
354
- useStaticLayout: YES,
355
- render: function(context) {
356
- // needed for auto
357
- context.push('<div style="padding: 10px"></div>');
358
- }
359
- });
360
-
361
- // parent MUST have a layer.
362
- parent.createLayer();
363
- var layer = parent.get('layer');
364
- document.body.appendChild(layer);
365
-
366
- var layout = { top: 0, left: 0, width: 'auto', height: 'auto' };
367
- var no_f = { x: 0, y: 0, width: 0, height: 0, transform: null };
368
- var with_f = { x: 0, y: 0, width: 20, height: 20, transform: null };
369
- var s = { top: 0, left: 0, width: 'auto', height: 'auto', transform: null };
370
-
371
- performLayoutTest(layout, no_f, s, with_f, s);
372
-
373
- layer.parentNode.removeChild(layer);
374
- });
375
-
376
- test("layout w/ percentage {top, left, width, height}", function() {
377
-
378
- var layout = { top: 0.1, left: 0.1, width: 0.5, height: 0.5 };
379
- var s = { top: '10%', left: '10%', width: '50%', height: '50%', transform: null } ;
380
- var no_f = { top: '10%', left: '10%', width: '50%', height: '50%', transform: null } ;
381
- var with_f = { top: '10%', left: '10%', width: '50%', height: '50%', transform: null } ;
382
-
383
- performLayoutTest(layout, no_f, s, with_f, s) ;
384
- }) ;
385
-
386
- }
387
-
388
-
389
-
390
-
391
-
392
-
393
-
394
- // ..........................................................
395
- // TEST FRAME/STYLEFRAME WITH INVALID LAYOUT VARIATIONS
396
- //
397
- // NOTE: Each test evaluates the frame before and after adding it to the
398
- // parent.
399
-
400
- module('INVALID LAYOUT VARIATIONS', commonSetup);
401
-
402
- test("layout {top, left} - assume right/bottom=0", function() {
403
-
404
- var layout = { top: 0.1, left: 0.1 };
405
- var no_f = { x: 10, y: 10, width: 0, height: 0 } ;
406
- var with_f = { x: 10, y: 10, width: 190, height: 190 } ;
407
- var s = { bottom: 0, right: 0, top: '10%', left: '10%' } ;
408
-
409
- performLayoutTest(layout, no_f, s, with_f, s) ;
410
- }) ;
411
-
412
- test("layout {height, width} - assume top/left=0", function() {
413
-
414
- var layout = { height: 0.6, width: 0.6 };
415
- var no_f = { x: 0, y: 0, width: 60, height: 60 } ;
416
- var with_f = { x: 0, y: 0, width: 60, height: 60 } ;
417
- var s = { width: '60%', height: '60%', top: 0, left: 0 } ;
418
-
419
- performLayoutTest(layout, no_f, s, with_f, s) ;
420
-
421
- }) ;
422
-
423
- test("layout {right, bottom} - assume top/left=0", function() {
424
-
425
- var layout = { right: 0.1, bottom: 0.1 };
426
- var no_f = { x: 0, y: 0, width: 0, height: 0 } ;
427
- var with_f = { x: 0, y: 0, width: 190, height: 190 } ;
428
- var s = { bottom: '10%', right: '10%', top: 0, left: 0 } ;
429
-
430
- performLayoutTest(layout, no_f, s, with_f, s) ;
431
-
432
- }) ;
433
-
434
- test("layout {right, bottom, maxWidth, maxHeight} - assume top/left=null", function() {
435
-
436
- var layout = { right: 0.1, bottom: 0.1, maxWidth: 10, maxHeight: 10 };
437
- var no_f = { x: 0, y: 0, width: 0, height: 0 } ;
438
- var with_f = { x: 0, y: 0, width: 190, height: 190 } ;
439
- var s = { bottom: '10%', right: '10%', top: null, left: null, maxWidth: 10, maxHeight: 10 } ;
440
-
441
- performLayoutTest(layout, no_f, s, with_f, s) ;
442
-
443
- }) ;
444
-
445
- test("layout {centerX, centerY} - assume width/height=0", function() {
446
-
447
- var layout = { centerX: 0.1, centerY: 0.1 };
448
- var no_f = { x: 10, y: 10, width: 0, height: 0 } ;
449
- var with_f = { x: 110, y: 110, width: 0, height: 0 } ;
450
- var s = { width: 0, height: 0, top: "50%", left: "50%", marginTop: "50%", marginLeft: "50%" } ;
451
- performLayoutTest(layout, no_f, s, with_f, s) ;
452
-
453
- }) ;
454
-
455
- test("layout {top, left, centerX, centerY, height, width} - top/left take presidence", function() {
456
-
457
- var layout = { top: 0.1, left: 0.1, centerX: 0.1, centerY: 0.1, height: 0.6, width: 0.6 };
458
- var no_f = { x: 10, y: 10, width: 60, height: 60 } ;
459
- var with_f = { x: 10, y: 10, width: 60, height: 60 } ;
460
- var s = { width: '60%', height: '60%', top: '10%', left: '10%' } ;
461
-
462
- performLayoutTest(layout, no_f, s, with_f, s) ;
463
-
464
- }) ;
465
-
466
- test("layout {bottom, right, centerX, centerY, height, width} - bottom/right take presidence", function() {
467
-
468
- var layout = { bottom: 0.1, right: 0.1, centerX: 0.1, centerY: 0.1, height: 0.6, width: 0.6 };
469
- var no_f = { x: 0, y: 0, width: 60, height: 60 } ;
470
- var with_f = { x: 130, y: 130, width: 60, height: 60 } ;
471
- var s = { width: '60%', height: '60%', bottom: '10%', right: '10%' } ;
472
-
473
- performLayoutTest(layout, no_f, s, with_f, s) ;
474
-
475
- }) ;
476
-
477
- test("layout {top, left, bottom, right, centerX, centerY, height, width} - top/left take presidence", function() {
478
-
479
- var layout = { top: 0.1, left: 0.1, bottom: 0.1, right: 0.1, centerX: 0.1, centerY: 0.1, height: 0.6, width: 0.6 };
480
- var no_f = { x: 10, y: 10, width: 60, height: 60 } ;
481
- var with_f = { x: 10, y: 10, width: 60, height: 60 } ;
482
- var s = { width: '60%', height: '60%', top: '10%', left: '10%' } ;
483
-
484
- performLayoutTest(layout, no_f, s, with_f, s) ;
485
-
486
- }) ;
487
-
488
-
489
- test("layout {centerX, centerY, width:auto, height:auto}", function() {
490
- var error= 'NONE';
491
- var layout = { centerX: 0.1, centerY: 0.1, width: 'auto', height: 'auto' };
492
-
493
- child.set('layout', layout) ;
494
- try{
495
- child.layoutStyle();
496
- }catch(e){
497
- error=e;
498
- }
499
-
500
- equals(SC.T_ERROR, SC.typeOf(error), 'Layout style functions should throw an '+
501
- 'error if centerx/y and width/height are set at the same time ' + error );
502
-
503
- }) ;
504
-
505
-
506
- // ..........................................................
507
- // TEST FRAME/STYLEFRAME WHEN PARENT VIEW IS RESIZED
508
- //
509
-
510
- module('RESIZE FRAME', commonSetup);
511
-
512
- function verifyFrameResize(layout, before, after) {
513
- parent.appendChild(child);
514
- SC.run(function() { child.set('layout', layout); });
515
-
516
- same(child.get('frame'), before, "Before: %@ == %@".fmt(SC.inspect(child.get('frame')), SC.inspect(before))) ;
517
- SC.run(function() { parent.adjust('width', 300).adjust('height', 300); });
518
-
519
- same(child.get('frame'), after, "After: %@ == %@".fmt(SC.inspect(child.get('frame')), SC.inspect(after)));
520
-
521
- }
522
-
523
- test("frame does not change with top/left/w/h", function(){
524
- var layout = { top: 10, left: 10, width: 60, height: 60 };
525
- var before = { x: 10, y: 10, width: 60, height: 60 };
526
- var after = { x: 10, y: 10, width: 60, height: 60 };
527
- verifyFrameResize(layout, before, after);
528
- });
529
-
530
- test("frame shifts down with bottom/right/w/h", function(){
531
- var layout = { bottom: 10, right: 10, width: 60, height: 60 };
532
- var before = { x: 130, y: 130, width: 60, height: 60 };
533
- var after = { x: 230, y: 230, width: 60, height: 60 };
534
- verifyFrameResize(layout, before, after);
535
- });
536
-
537
- test("frame size shifts with top/left/bottom/right", function(){
538
- var layout = { top: 10, left: 10, bottom: 10, right: 10 };
539
- var before = { x: 10, y: 10, width: 180, height: 180 };
540
- var after = { x: 10, y: 10, width: 280, height: 280 };
541
- verifyFrameResize(layout, before, after);
542
- });
543
-
544
- test("frame loc shifts with centerX/centerY", function(){
545
- var layout = { centerX: 10, centerY: 10, width: 60, height: 60 };
546
- var before = { x: 80, y: 80, width: 60, height: 60 };
547
- var after = { x: 130, y: 130, width: 60, height: 60 };
548
- verifyFrameResize(layout, before, after);
549
- });
550
-
551
- //with percentage
552
-
553
- test("frame does not change with top/left/w/h", function(){
554
- var layout = { top: 0.1, left: 0.1, width: 0.6, height: 0.6 };
555
- var before = { x: 20, width: 120, y: 20, height: 120 };
556
- var after = { x: 30, y: 30, width: 180, height: 180 };
557
- verifyFrameResize(layout, before, after);
558
- });
559
-
560
- test("frame shifts down with bottom/right/w/h", function(){
561
- var layout = { bottom: 0.1, right: 0.1, width: 0.6, height: 0.6 };
562
- var before = { x: 60, y: 60, width: 120, height: 120 };
563
- var after = { x: 90, y: 90, width: 180, height: 180 };
564
- verifyFrameResize(layout, before, after);
565
- });
566
-
567
- test("frame size shifts with top/left/bottom/right", function(){
568
- var layout = { top: 0.1, left: 0.1, bottom: 0.1, right: 0.1 };
569
- var before = { x: 20, y: 20, width: 160, height: 160 };
570
- var after = { x: 30, y: 30, width: 240, height: 240 };
571
- verifyFrameResize(layout, before, after);
572
- });
573
-
574
- test("frame loc shifts with centerX/centerY", function(){
575
- var layout = { centerX: 0, centerY: 0, width: 0.6, height: 0.6 };
576
- var before = { x: 40, y: 40, width: 120, height: 120 };
577
- var after = { x: 60, y: 60, width: 180, height: 180 };
578
- verifyFrameResize(layout, before, after);
579
- });
580
-
581
- test("for proper null variables");
582
- // nothing should get passed through as undefined, instead we want null in certain cases
583
-
584
-
585
-
586
- // test("frame size shifts with top/left/bottom/right", function(){
587
- // var error=null;
588
- // var layout = { top: 10, left: 10, bottom: 10, right: 10 };
589
- // parent.appendChild(child);
590
- // child.set('layout', layout);
591
- // child.get('frame');
592
- // parent.adjust('width', 'auto').adjust('height', 'auto');
593
- // try{
594
- // child.get('frame');
595
- // }catch(e){
596
- // error=e;
597
- // }
598
- // equals(SC.T_ERROR,SC.typeOf(error),'Layout style functions should throw and '+
599
- // 'error if centerx/y and width/height are set at the same time ' + error );
600
- //
601
- //
602
- // });