sproutcore 1.10.3.1 → 1.11.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (380) hide show
  1. checksums.yaml +8 -8
  2. data/CHANGELOG +4 -8
  3. data/VERSION.yml +2 -2
  4. data/lib/frameworks/sproutcore/Buildfile +5 -4
  5. data/lib/frameworks/sproutcore/CHANGELOG.md +274 -40
  6. data/lib/frameworks/sproutcore/CONTRIBUTORS.md +133 -0
  7. data/lib/frameworks/sproutcore/README.md +31 -144
  8. data/lib/frameworks/sproutcore/apps/showcase/controllers/source_tree_controller.js +9 -4
  9. data/lib/frameworks/sproutcore/apps/showcase/resources/stylesheet.css +5 -0
  10. data/lib/frameworks/sproutcore/apps/showcase/system/views_item_content.js +1 -1
  11. data/lib/frameworks/sproutcore/apps/showcase/views/split_views.js +15 -2
  12. data/lib/frameworks/sproutcore/apps/showcase/views/stacked_views.js +1 -1
  13. data/lib/frameworks/sproutcore/apps/tests/english.lproj/main_page.js +11 -1
  14. data/lib/frameworks/sproutcore/frameworks/ajax/mixins/websocket_delegate.js +90 -0
  15. data/lib/frameworks/sproutcore/frameworks/ajax/system/request.js +81 -5
  16. data/lib/frameworks/sproutcore/frameworks/ajax/system/response.js +23 -4
  17. data/lib/frameworks/sproutcore/frameworks/ajax/system/websocket.js +475 -0
  18. data/lib/frameworks/sproutcore/frameworks/ajax/tests/system/request.js +149 -26
  19. data/lib/frameworks/sproutcore/frameworks/ajax/tests/system/websocket.js +197 -0
  20. data/lib/frameworks/sproutcore/frameworks/ajax/tests/system/xhr_response_test.js +65 -0
  21. data/lib/frameworks/sproutcore/frameworks/bootstrap/system/loader.js +4 -0
  22. data/lib/frameworks/sproutcore/frameworks/core_foundation/child_view_layouts/horizontal_stack_layout.js +232 -52
  23. data/lib/frameworks/sproutcore/frameworks/core_foundation/child_view_layouts/vertical_stack_layout.js +235 -49
  24. data/lib/frameworks/sproutcore/frameworks/core_foundation/controllers/array.js +23 -13
  25. data/lib/frameworks/sproutcore/frameworks/core_foundation/controllers/object.js +3 -1
  26. data/lib/frameworks/sproutcore/frameworks/core_foundation/core.js +81 -1
  27. data/lib/frameworks/sproutcore/frameworks/core_foundation/english.lproj/ordinal.js +17 -0
  28. data/lib/frameworks/sproutcore/frameworks/core_foundation/ext/string.js +7 -0
  29. data/lib/frameworks/sproutcore/frameworks/{desktop/tests/views/disclosure/methods.js → core_foundation/french.lproj/ordinal.js} +7 -4
  30. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/layout.js +2 -6
  31. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/main.js +1 -1
  32. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/pane.js +104 -69
  33. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/pane_statechart.js +6 -1
  34. data/lib/frameworks/sproutcore/frameworks/core_foundation/protocols/child_view_layout_protocol.js +59 -0
  35. data/lib/frameworks/sproutcore/frameworks/core_foundation/protocols/view_transition_protocol.js +18 -1
  36. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/application.js +192 -0
  37. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/bezier_curves.js +52 -0
  38. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/color.js +384 -64
  39. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/core_query.js +6 -14
  40. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/device.js +21 -35
  41. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/event.js +72 -36
  42. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/locale.js +90 -34
  43. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/platform.js +55 -7
  44. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/render_context.js +20 -15
  45. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/req_anim_frame.js +9 -10
  46. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/root_responder.js +763 -542
  47. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/selection_set.js +4 -3
  48. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/sparse_array.js +1 -7
  49. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/string.js +14 -0
  50. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/touch.js +538 -0
  51. data/lib/frameworks/sproutcore/frameworks/core_foundation/system/utils/rect.js +56 -1
  52. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/controllers/array/array_case.js +99 -4
  53. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/controllers/object/single_case.js +25 -19
  54. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/core_tests.js +75 -0
  55. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/ext/number_test.js +81 -0
  56. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/mixins/action_support.js +4 -4
  57. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/mixins/responder_context.js +4 -4
  58. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/mixins/string.js +19 -1
  59. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/color.js +36 -20
  60. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/root_responder/design_modes_test.js +83 -0
  61. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/root_responder/makeMainPane.js +7 -3
  62. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/root_responder/mouse_events.js +338 -0
  63. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/root_responder/root_responder.js +14 -89
  64. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/root_responder/touch.js +106 -0
  65. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/sparse_array.js +2 -2
  66. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/touch.js +136 -0
  67. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/system/utils/rect.js +42 -1
  68. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/pane/append_remove.js +11 -0
  69. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/pane/child_view.js +5 -5
  70. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/pane/design_mode_test.js +457 -0
  71. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/pane/sendEvent.js +36 -10
  72. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/background_color.js +44 -0
  73. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/border_frame_test.js +51 -24
  74. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/childViewLayout_test.js +176 -1
  75. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/clippingFrame.js +46 -16
  76. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/convertFrames.js +69 -15
  77. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/didAppendToDocument.js +2 -2
  78. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/layout.js +7 -1
  79. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/layoutDidChange.js +30 -10
  80. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/layoutStyle.js +376 -71
  81. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/static_layout.js +0 -10
  82. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/viewDidResize.js +117 -34
  83. data/lib/frameworks/sproutcore/frameworks/core_foundation/tests/views/view/view_states_test.js +52 -2
  84. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view.js +656 -42
  85. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/animation.js +159 -38
  86. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/cursor.js +0 -7
  87. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/design_mode.js +206 -0
  88. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/enabled.js +0 -28
  89. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/keyboard.js +21 -6
  90. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/layout.js +372 -450
  91. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/layout_style.js +28 -13
  92. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/manipulation.js +22 -51
  93. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/statechart.js +59 -30
  94. data/lib/frameworks/sproutcore/frameworks/core_foundation/views/view/theming.js +0 -29
  95. data/lib/frameworks/sproutcore/frameworks/datastore/mixins/relationship_support.js +22 -10
  96. data/lib/frameworks/sproutcore/frameworks/datastore/models/children_attribute.js +42 -36
  97. data/lib/frameworks/sproutcore/frameworks/datastore/models/many_attribute.js +54 -3
  98. data/lib/frameworks/sproutcore/frameworks/datastore/models/record.js +178 -59
  99. data/lib/frameworks/sproutcore/frameworks/datastore/models/record_attribute.js +2 -2
  100. data/lib/frameworks/sproutcore/frameworks/datastore/system/child_array.js +206 -132
  101. data/lib/frameworks/sproutcore/frameworks/datastore/system/many_array.js +214 -118
  102. data/lib/frameworks/sproutcore/frameworks/datastore/system/nested_store.js +96 -13
  103. data/lib/frameworks/sproutcore/frameworks/datastore/system/query.js +14 -4
  104. data/lib/frameworks/sproutcore/frameworks/datastore/system/record_array.js +82 -42
  105. data/lib/frameworks/sproutcore/frameworks/datastore/system/store.js +272 -177
  106. data/lib/frameworks/sproutcore/frameworks/datastore/tests/integration/store_interaction_test.js +54 -0
  107. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/datetime_recordattribute.js +24 -16
  108. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/many_attribute.js +6 -3
  109. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/data_store.js +267 -35
  110. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record.js +57 -46
  111. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array.js +150 -53
  112. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_array_complex.js +57 -17
  113. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/nested_records/nested_record_complex.js +13 -9
  114. data/lib/frameworks/sproutcore/frameworks/{experimental/frameworks/polymorphism → datastore}/tests/models/polymorphism/many.js +2 -2
  115. data/lib/frameworks/sproutcore/frameworks/{experimental/frameworks/polymorphism → datastore}/tests/models/polymorphism/simple.js +0 -0
  116. data/lib/frameworks/sproutcore/frameworks/{experimental/frameworks/polymorphism → datastore}/tests/models/polymorphism/single.js +12 -2
  117. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record/writeAttribute.js +20 -15
  118. data/lib/frameworks/sproutcore/frameworks/datastore/tests/models/record_attribute.js +9 -2
  119. data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/many_array/core_methods.js +80 -14
  120. data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/autonomous_dataSourceCallbacks.js +280 -0
  121. data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/autonomous_pushChanges.js +232 -0
  122. data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/chain.js +31 -5
  123. data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/query/parse.js +16 -2
  124. data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/core_methods.js +60 -40
  125. data/lib/frameworks/sproutcore/frameworks/datastore/tests/system/store/materializeRecord.js +78 -0
  126. data/lib/frameworks/sproutcore/frameworks/datetime/frameworks/core/system/datetime.js +13 -1
  127. data/lib/frameworks/sproutcore/frameworks/datetime/frameworks/core/tests/system/datetime.js +20 -0
  128. data/lib/frameworks/sproutcore/frameworks/datetime/frameworks/localized/{resources → english.lproj}/strings.js +0 -0
  129. data/lib/frameworks/sproutcore/frameworks/datetime/frameworks/localized/french.lproj/strings.js +45 -0
  130. data/lib/frameworks/sproutcore/frameworks/designer/designers/object_designer.js +7 -3
  131. data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_row_delegate.js +125 -44
  132. data/lib/frameworks/sproutcore/frameworks/desktop/panes/alert.js +139 -48
  133. data/lib/frameworks/sproutcore/frameworks/desktop/panes/draggable.js +202 -0
  134. data/lib/frameworks/sproutcore/frameworks/desktop/panes/menu.js +59 -56
  135. data/lib/frameworks/sproutcore/frameworks/desktop/panes/palette.js +13 -49
  136. data/lib/frameworks/sproutcore/frameworks/desktop/panes/picker.js +466 -305
  137. data/lib/frameworks/sproutcore/frameworks/desktop/protocols/drag_source.js +49 -12
  138. data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/slider.js +79 -21
  139. data/lib/frameworks/sproutcore/frameworks/desktop/render_delegates/split.js +12 -2
  140. data/lib/frameworks/sproutcore/frameworks/desktop/resources/menu_item_view.css +8 -0
  141. data/lib/frameworks/sproutcore/frameworks/desktop/resources/overlay-scroller.css +187 -0
  142. data/lib/frameworks/sproutcore/frameworks/desktop/system/drag.js +94 -30
  143. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/alert/ui.js +163 -3
  144. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/menu/methods.js +97 -78
  145. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/menu/ui.js +61 -1
  146. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/panel/methods.js +7 -3
  147. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/panel/ui.js +47 -22
  148. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/picker/methods.js +66 -9
  149. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/picker/ui.js +21 -11
  150. data/lib/frameworks/sproutcore/frameworks/desktop/tests/panes/sheet/ui.js +12 -18
  151. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/button/methods.js +17 -14
  152. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/button/ui.js +2 -1
  153. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/checkbox/methods.js +9 -6
  154. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/collection_fast_path.js +54 -21
  155. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/content.js +52 -20
  156. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/itemViewForContentIndex.js +94 -4
  157. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/keyboard.js +177 -0
  158. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/layerIdFor.js +13 -1
  159. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/length.js +9 -9
  160. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/collection/mouse.js +18 -0
  161. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/date_field/methods.js +104 -0
  162. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/disclosure/ui.js +48 -49
  163. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/grid/drag_and_drop.js +22 -18
  164. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/grid/methods.js +17 -5
  165. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/link_view_test.js +136 -0
  166. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/contentIndexesInRect.js +77 -0
  167. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/drag_and_drop.js +53 -16
  168. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/layoutForContentIndex.js +41 -0
  169. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowDelegate.js +25 -25
  170. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowOffsetForContentIndex.js +102 -27
  171. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/{rowHeightForContentIndex.js → rowSizeForContentIndex.js} +7 -6
  172. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_outline.js +2 -0
  173. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_row_heights.js +70 -75
  174. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_simple.js +29 -30
  175. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/list_item.js +57 -0
  176. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/menu_scroll_view/menu_scroll_view_test.js +206 -0
  177. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/progress/ui.js +15 -0
  178. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/radio/methods.js +15 -7
  179. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroll/integration.js +16 -11
  180. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroll/methods.js +164 -12
  181. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroll/scale.js +387 -0
  182. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroll/touch.js +549 -0
  183. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroll/ui.js +214 -45
  184. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/scroller.js +5 -5
  185. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/methods.js +73 -22
  186. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/ui.js +88 -3
  187. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/select/methods.js +8 -0
  188. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/slider/methods.js +16 -1
  189. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/slider/ui.js +54 -0
  190. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/split/dividers.js +21 -2
  191. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/static_content.js +31 -25
  192. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/tab/methods.js +109 -29
  193. data/lib/frameworks/sproutcore/frameworks/desktop/views/button.js +10 -1
  194. data/lib/frameworks/sproutcore/frameworks/desktop/views/checkbox.js +3 -0
  195. data/lib/frameworks/sproutcore/frameworks/desktop/views/collection.js +779 -603
  196. data/lib/frameworks/sproutcore/frameworks/desktop/views/date_field.js +106 -7
  197. data/lib/frameworks/sproutcore/frameworks/desktop/views/link_view.js +406 -0
  198. data/lib/frameworks/sproutcore/frameworks/desktop/views/list.js +437 -245
  199. data/lib/frameworks/sproutcore/frameworks/desktop/views/list_item.js +13 -0
  200. data/lib/frameworks/sproutcore/frameworks/desktop/views/menu_item.js +124 -62
  201. data/lib/frameworks/sproutcore/frameworks/desktop/views/menu_scroll.js +176 -597
  202. data/lib/frameworks/sproutcore/frameworks/desktop/views/menu_scroller_view.js +206 -0
  203. data/lib/frameworks/sproutcore/frameworks/desktop/views/popup_button.js +3 -0
  204. data/lib/frameworks/sproutcore/frameworks/desktop/views/progress.js +5 -4
  205. data/lib/frameworks/sproutcore/frameworks/desktop/views/radio.js +3 -0
  206. data/lib/frameworks/sproutcore/frameworks/desktop/views/scene.js +56 -158
  207. data/lib/frameworks/sproutcore/frameworks/desktop/views/scroll_view.js +2560 -0
  208. data/lib/frameworks/sproutcore/frameworks/desktop/views/scroller.js +458 -242
  209. data/lib/frameworks/sproutcore/frameworks/desktop/views/segmented.js +117 -54
  210. data/lib/frameworks/sproutcore/frameworks/desktop/views/select.js +18 -12
  211. data/lib/frameworks/sproutcore/frameworks/desktop/views/slider.js +162 -34
  212. data/lib/frameworks/sproutcore/frameworks/desktop/views/split.js +30 -15
  213. data/lib/frameworks/sproutcore/frameworks/desktop/views/split_divider.js +33 -7
  214. data/lib/frameworks/sproutcore/frameworks/desktop/views/static_content.js +22 -2
  215. data/lib/frameworks/sproutcore/frameworks/desktop/views/tab.js +47 -22
  216. data/lib/frameworks/sproutcore/frameworks/experimental/Buildfile +0 -6
  217. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/views/form.js +2 -1
  218. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/forms/views/form_row.js +21 -21
  219. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/ext/menu.js +14 -3
  220. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/mixins/select_view_menu.js +24 -10
  221. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/ext/menu_resizing.js +1 -1
  222. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/mixins/select_view_menu/bindings.js +7 -4
  223. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/mixins/select_view_menu/check_selected.js +7 -9
  224. data/lib/frameworks/sproutcore/frameworks/{desktop/tests/panes/select_button/methods.js → experimental/frameworks/select_view/tests/views/select/method.js} +54 -76
  225. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/tests/views/select/selected_item.js +35 -0
  226. data/lib/frameworks/sproutcore/frameworks/{desktop/tests/panes/select_button → experimental/frameworks/select_view/tests/views/select}/ui.js +107 -36
  227. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/select_view/views/select.js +225 -66
  228. data/lib/frameworks/sproutcore/frameworks/foundation/controllers/tree.js +39 -38
  229. data/lib/frameworks/sproutcore/frameworks/foundation/core.js +5 -18
  230. data/lib/frameworks/sproutcore/frameworks/foundation/debug/control_test_pane.js +12 -0
  231. data/lib/frameworks/sproutcore/frameworks/foundation/english.lproj/inflections.js +84 -0
  232. data/lib/frameworks/sproutcore/frameworks/foundation/french.lproj/inflections.js +41 -0
  233. data/lib/frameworks/sproutcore/frameworks/foundation/mixins/auto_mixin.js +1 -0
  234. data/lib/frameworks/sproutcore/frameworks/foundation/mixins/auto_resize.js +7 -0
  235. data/lib/frameworks/sproutcore/frameworks/foundation/mixins/content_display.js +3 -4
  236. data/lib/frameworks/sproutcore/frameworks/foundation/mixins/flowed_layout.js +6 -2
  237. data/lib/frameworks/sproutcore/frameworks/foundation/private/tree_item_observer.js +408 -239
  238. data/lib/frameworks/sproutcore/frameworks/foundation/render_delegates/canvas_image.js +1 -1
  239. data/lib/frameworks/sproutcore/frameworks/foundation/resources/text_field.css +2 -1
  240. data/lib/frameworks/sproutcore/frameworks/foundation/spanish.lproj/inflections.js +38 -0
  241. data/lib/frameworks/sproutcore/frameworks/foundation/system/benchmark.js +104 -76
  242. data/lib/frameworks/sproutcore/frameworks/foundation/system/string.js +20 -94
  243. data/lib/frameworks/sproutcore/frameworks/foundation/system/text_selection.js +33 -22
  244. data/lib/frameworks/sproutcore/frameworks/foundation/system/undo_manager.js +475 -0
  245. data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/auto_resize_test.js +163 -1
  246. data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/flowed_layout/tests.js +41 -0
  247. data/lib/frameworks/sproutcore/frameworks/foundation/tests/mixins/staticLayout.js +2 -5
  248. data/lib/frameworks/sproutcore/frameworks/foundation/tests/private/tree_item_observer/methods.js +268 -0
  249. data/lib/frameworks/sproutcore/frameworks/foundation/tests/system/undo_manager.js +231 -0
  250. data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/container/ui.js +16 -0
  251. data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/image/ui.js +27 -0
  252. data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/methods.js +24 -0
  253. data/lib/frameworks/sproutcore/frameworks/foundation/tests/views/text_field/ui.js +135 -6
  254. data/lib/frameworks/sproutcore/frameworks/foundation/transitions/fade_transition.js +6 -0
  255. data/lib/frameworks/sproutcore/frameworks/foundation/transitions/pop_transition.js +7 -0
  256. data/lib/frameworks/sproutcore/frameworks/foundation/transitions/scale_transition.js +6 -0
  257. data/lib/frameworks/sproutcore/frameworks/foundation/transitions/slide_transition.js +4 -0
  258. data/lib/frameworks/sproutcore/frameworks/foundation/transitions/swap_dissolve_transition.js +3 -1
  259. data/lib/frameworks/sproutcore/frameworks/foundation/validators/credit_card.js +21 -21
  260. data/lib/frameworks/sproutcore/frameworks/foundation/views/container.js +65 -15
  261. data/lib/frameworks/sproutcore/frameworks/foundation/views/image.js +4 -1
  262. data/lib/frameworks/sproutcore/frameworks/foundation/views/label.js +1 -1
  263. data/lib/frameworks/sproutcore/frameworks/foundation/views/text_field.js +193 -213
  264. data/lib/frameworks/sproutcore/frameworks/jquery/{jquery-1.8.3-patched.js → jquery-1.11.1.js} +7507 -6684
  265. data/lib/frameworks/sproutcore/frameworks/routing/system/routes.js +28 -11
  266. data/lib/frameworks/sproutcore/frameworks/routing/tests/system/routes.js +26 -0
  267. data/lib/frameworks/sproutcore/frameworks/runtime/core.js +54 -25
  268. data/lib/frameworks/sproutcore/frameworks/runtime/ext/array.js +0 -6
  269. data/lib/frameworks/sproutcore/frameworks/runtime/ext/number.js +36 -0
  270. data/lib/frameworks/sproutcore/frameworks/runtime/ext/window.js +25 -0
  271. data/lib/frameworks/sproutcore/frameworks/runtime/mixins/array.js +3 -3
  272. data/lib/frameworks/sproutcore/frameworks/runtime/mixins/enumerable.js +1 -1
  273. data/lib/frameworks/sproutcore/frameworks/runtime/mixins/observable.js +156 -66
  274. data/lib/frameworks/sproutcore/frameworks/runtime/private/observer_set.js +2 -2
  275. data/lib/frameworks/sproutcore/frameworks/runtime/system/binding.js +150 -65
  276. data/lib/frameworks/sproutcore/frameworks/runtime/system/index_set.js +57 -11
  277. data/lib/frameworks/sproutcore/frameworks/runtime/system/object.js +68 -49
  278. data/lib/frameworks/sproutcore/frameworks/runtime/system/run_loop.js +14 -6
  279. data/lib/frameworks/sproutcore/frameworks/runtime/system/string.js +23 -23
  280. data/lib/frameworks/sproutcore/frameworks/runtime/tests/ext/number_test.js +44 -0
  281. data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/array.js +0 -10
  282. data/lib/frameworks/sproutcore/frameworks/runtime/tests/mixins/enumerable/enumerable.js +340 -285
  283. data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/binding.js +104 -3
  284. data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/observer_set.js +14 -1
  285. data/lib/frameworks/sproutcore/frameworks/runtime/tests/system/string.js +15 -2
  286. data/lib/frameworks/sproutcore/frameworks/statechart/system/state.js +21 -18
  287. data/lib/frameworks/sproutcore/frameworks/statechart/system/statechart.js +52 -19
  288. data/lib/frameworks/sproutcore/frameworks/statechart/tests/event_handling/responder/pane.js +27 -24
  289. data/lib/frameworks/sproutcore/frameworks/template_view/controls/button.js +30 -0
  290. data/lib/frameworks/sproutcore/frameworks/template_view/ext/handlebars/bind.js +1 -1
  291. data/lib/frameworks/sproutcore/frameworks/template_view/ext/handlebars/collection.js +2 -0
  292. data/lib/frameworks/sproutcore/frameworks/template_view/ext/handlebars/view.js +1 -0
  293. data/lib/frameworks/sproutcore/frameworks/template_view/tests/mixins/template_helpers/checkbox_support.js +2 -2
  294. data/lib/frameworks/sproutcore/frameworks/template_view/tests/views/template/handlebars.js +4 -2
  295. data/lib/frameworks/sproutcore/frameworks/template_view/views/bindable_span.js +1 -1
  296. data/lib/frameworks/sproutcore/frameworks/template_view/views/template_collection.js +16 -14
  297. data/lib/frameworks/sproutcore/frameworks/testing/core.js +5 -3
  298. data/lib/frameworks/sproutcore/frameworks/testing/system/plan.js +13 -0
  299. data/lib/frameworks/sproutcore/lib/index.rhtml +2 -2
  300. data/lib/frameworks/sproutcore/phantomjs/test_runner.js +28 -7
  301. data/lib/frameworks/sproutcore/scripts/run_sc_server_master.sh +1 -1
  302. data/lib/frameworks/sproutcore/themes/ace/resources/_variables.css +2 -0
  303. data/lib/frameworks/sproutcore/themes/ace/resources/disclosure/ace/disclosure.css +1 -0
  304. data/lib/frameworks/sproutcore/themes/ace/resources/picker/popover/popover.css +3 -4
  305. data/lib/frameworks/sproutcore/themes/ace/resources/scroller/horizontal/horizontal.css +15 -15
  306. data/lib/frameworks/sproutcore/themes/ace/resources/scroller/horizontal/horizontal_overlay.css +74 -0
  307. data/lib/frameworks/sproutcore/themes/ace/resources/scroller/vertical/vertical.css +11 -13
  308. data/lib/frameworks/sproutcore/themes/ace/resources/scroller/vertical/vertical_overlay.css +74 -0
  309. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/jumbo/knob-active.png +0 -0
  310. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/jumbo/knob-active@2x.png +0 -0
  311. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/jumbo/knob.png +0 -0
  312. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/jumbo/knob@2x.png +0 -0
  313. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/{22px → jumbo}/slider.css +9 -4
  314. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/jumbo/track.png +0 -0
  315. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/jumbo/track@2x.png +0 -0
  316. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/regular/knob-active.png +0 -0
  317. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/regular/knob-active@2x.png +0 -0
  318. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/regular/knob.png +0 -0
  319. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/regular/knob@2x.png +0 -0
  320. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/regular/slider.css +32 -0
  321. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/regular/track.png +0 -0
  322. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/regular/track@2x.png +0 -0
  323. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/slider.css +13 -0
  324. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/small/knob-active.png +0 -0
  325. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/small/knob-active@2x.png +0 -0
  326. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/small/knob.png +0 -0
  327. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/small/knob@2x.png +0 -0
  328. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/small/slider.css +32 -0
  329. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/small/track.png +0 -0
  330. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/small/track@2x.png +0 -0
  331. data/lib/frameworks/sproutcore/themes/ace/resources/split/split.css +2 -3
  332. data/lib/sproutcore/builders/chance_file.rb +3 -3
  333. data/lib/sproutcore/helpers/minifier.rb +1 -0
  334. data/vendor/chance/lib/chance/instance.rb +34 -34
  335. data/vendor/chance/lib/chance/instance/spriting.rb +21 -16
  336. metadata +81 -58
  337. data/lib/frameworks/sproutcore/frameworks/core_foundation/panes/visibility.js +0 -17
  338. data/lib/frameworks/sproutcore/frameworks/desktop/mixins/collection_fast_path.js +0 -710
  339. data/lib/frameworks/sproutcore/frameworks/desktop/mixins/scrollable.js +0 -267
  340. data/lib/frameworks/sproutcore/frameworks/desktop/resources/touch-scroller.css +0 -196
  341. data/lib/frameworks/sproutcore/frameworks/desktop/system/undo_manager.js +0 -224
  342. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/select_field/methods.js +0 -163
  343. data/lib/frameworks/sproutcore/frameworks/desktop/tests/views/select_field/ui.js +0 -177
  344. data/lib/frameworks/sproutcore/frameworks/desktop/views/scroll.js +0 -2053
  345. data/lib/frameworks/sproutcore/frameworks/desktop/views/select_button.js +0 -1024
  346. data/lib/frameworks/sproutcore/frameworks/desktop/views/select_field.js +0 -404
  347. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/menu/render_delegates/menu_scroller.js +0 -28
  348. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/menu/tests/menu/scroll.js +0 -235
  349. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/menu/views/menu/scroll.js +0 -363
  350. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/menu/views/menu/scroller.js +0 -250
  351. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/README.md +0 -47
  352. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/polymorphism/models/record.js +0 -134
  353. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/render_delegates/desktop_scroller.js +0 -92
  354. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/render_delegates/native_scroll.js +0 -25
  355. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/render_delegates/scroll.js +0 -33
  356. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/render_delegates/touch_scroller.js +0 -76
  357. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/tests/scroll/integration.js +0 -25
  358. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/tests/scroll/methods.js +0 -143
  359. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/tests/scroll/ui.js +0 -256
  360. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/core_scroll.js +0 -1164
  361. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/core_scroller.js +0 -332
  362. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/desktop/scroll.js +0 -236
  363. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/desktop/scroller.js +0 -347
  364. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/scroll.js +0 -15
  365. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/scroller.js +0 -10
  366. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/touch/scroll.js +0 -804
  367. data/lib/frameworks/sproutcore/frameworks/experimental/frameworks/scroll_view/views/touch/scroller.js +0 -133
  368. data/lib/frameworks/sproutcore/frameworks/foundation/tasks/preload_bundle.js +0 -41
  369. data/lib/frameworks/sproutcore/themes/ace/resources/scroller/horizontal/horizontal_touch.css +0 -91
  370. data/lib/frameworks/sproutcore/themes/ace/resources/scroller/vertical/vertical_touch.css +0 -92
  371. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/14px/knob.png +0 -0
  372. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/14px/knob_active.png +0 -0
  373. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/14px/slider.css +0 -27
  374. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/16px/knob.png +0 -0
  375. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/16px/knob_active.png +0 -0
  376. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/16px/slider.css +0 -27
  377. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/22px/knob.png +0 -0
  378. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/22px/knob_active.png +0 -0
  379. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/22px/track.png +0 -0
  380. data/lib/frameworks/sproutcore/themes/ace/resources/slider/ace/track.png +0 -0
@@ -0,0 +1,65 @@
1
+ // ==========================================================================
2
+ // Project: SproutCore
3
+ // License: Licensed under MIT license (see license.js)
4
+ // ==========================================================================
5
+ /*globals module, test, ok */
6
+
7
+ var url, test_timeout = 2500;
8
+
9
+ module("SC.XHRResponse", {
10
+
11
+ setup: function() {
12
+ url = sc_static("file_exists.json");
13
+ },
14
+
15
+ teardown: function() {
16
+ url = null;
17
+ }
18
+
19
+ });
20
+
21
+ /**
22
+ If the request is across domains, we need to set the `withCredentials` property of the XHR request
23
+ to true in order to allow Cookies to be passed.
24
+ */
25
+ test("Test cross domain request credentials support (Default).", function() {
26
+ var request = SC.Request.getUrl('http://some-bogus-cross-domain.fake/' + url).json();
27
+
28
+ request.notify(this, function(response) {
29
+ ok(response.get('rawRequest').withCredentials, "The XHR request should have the withCredentials property set to true.");
30
+
31
+ window.start();
32
+ });
33
+
34
+ window.stop(test_timeout); // Stops the test runner
35
+
36
+ request.send();
37
+ });
38
+
39
+ test("Test cross domain request credentials support (Prohibited).", function() {
40
+ var request = SC.Request.getUrl('http://some-bogus-cross-domain.fake/' + url).json().credentials(false); // Don't allow credentials.
41
+
42
+ request.notify(this, function(response) {
43
+ ok(!response.get('rawRequest').withCredentials, "The XHR request should have the withCredentials property set to false.");
44
+
45
+ window.start();
46
+ });
47
+
48
+ window.stop(test_timeout); // Stops the test runner
49
+
50
+ request.send();
51
+ });
52
+
53
+ test("Test same domain request credentials support (Ignored).", function() {
54
+ var request = SC.Request.getUrl(url).json();
55
+
56
+ request.notify(this, function(response) {
57
+ ok(!response.get('rawRequest').withCredentials, "The XHR request should have the withCredentials property set to false (because it's same domain).");
58
+
59
+ window.start();
60
+ });
61
+
62
+ window.stop(test_timeout); // Stops the test runner
63
+
64
+ request.send();
65
+ });
@@ -34,6 +34,7 @@ SC.setupBodyClassNames = function() {
34
34
  // in practical usage.
35
35
  ieVersion = parseInt(SC.browser.version, 10);
36
36
  if (SC.browser.isIE) {
37
+ classNames.push('msie'); // Used by several framework CSS declarations, including the one to address issue #971.
37
38
  if (ieVersion === 7) {
38
39
  classNames.push('ie7');
39
40
  }
@@ -43,6 +44,9 @@ SC.setupBodyClassNames = function() {
43
44
  else if (ieVersion === 9) {
44
45
  classNames.push('ie9');
45
46
  }
47
+ else if (ieVersion === 10) {
48
+ classNames.push('ie10');
49
+ }
46
50
  }
47
51
 
48
52
  if(browser==="safari" || browser==="chrome") classNames.push('webkit');
@@ -11,18 +11,15 @@ SC.mixin(SC.View,
11
11
 
12
12
  /**
13
13
  This child layout plugin automatically positions the view's child views in a
14
- horizontal stack and optionally adjusts the parent view's height to fit. It
15
- does this by checking the height of each child view and positioning the
16
- following child view accordingly. By default any time that a child view's
17
- height changes, the view will use this plugin to re-adjust all other child
18
- views and its own height appropriately.
19
-
20
- A typical usage scenario is a long "form" made of multiple subsection
21
- views. If we want to adjust the height of a subsection, to make space for
22
- an error label for example, it would be a lot of work to manually
23
- reposition all the following sections below it. A much easier to code and
24
- cleaner solution is to just set the childViewLayout plugin on the wrapper
25
- view.
14
+ horizontal stack and optionally adjusts the view's width to fit. It does this
15
+ by checking the width of each child view and positioning the following child
16
+ views accordingly. Afterwards, by default, any time that a child view's
17
+ width or visibility changes, the view will use this plugin to re-adjust all
18
+ following child views' positions and potentially its own width appropriately.
19
+
20
+ This allows you to stack absolutely positioned views that dynamically change
21
+ their width and/or visibility without having to resort to using browser
22
+ flow layout.
26
23
 
27
24
  For example,
28
25
 
@@ -34,27 +31,38 @@ SC.mixin(SC.View,
34
31
  // The order of child views is important!
35
32
  childViews: ['sectionA', 'sectionB', 'sectionC'],
36
33
 
37
- // Actual layout will become { left: 10, bottom: 20, top: 20, width: 270 }
38
- layout: { left: 10, bottom: 20, top: 20 }, // Don't need to specify layout.width, this is automatic.
34
+ // The view will resize itself to fit its children.
35
+ // i.e. We don't need to specify layout.width, this is automatic.
36
+ // The actual layout will become { left: 10, bottom: 20, top: 20, width: 270 } initially.
37
+ layout: { left: 10, bottom: 20, top: 20 },
39
38
 
40
39
  sectionA: SC.View.design({
41
- // Actual layout will become { left: 0, bottom: 0, top: 0, width: 100 }
42
- layout: { width: 100 } // Don't need to specify layout.left, this is automatic.
40
+
41
+ // We don't need to specify layout.left, this is automatic.
42
+ // The actual layout will become { left: 0, bottom: 0, top: 0, width: 100 } initially.
43
+ layout: { width: 100 }
44
+
43
45
  }),
44
46
 
45
47
  sectionB: SC.View.design({
46
- // Actual layout will become { border: 1, left: 100, bottom: 0, top: 0, width: 50 }
47
- layout: { border: 1, width: 50 } // Don't need to specify layout.left, this is automatic.
48
+
49
+ // We don't need to specify layout.left, this is automatic.
50
+ // The actual layout will become { border: 1, left: 100, bottom: 0, top: 0, width: 50 } initially.
51
+ layout: { border: 1, width: 50 }
52
+
48
53
  }),
49
54
 
50
55
  sectionC: SC.View.design({
51
- // Actual layout will become { left: 150, bottom: 10, top: 10, width: 120 }
52
- layout: { right: 10, top: 10, width: 120 } // Don't need to specify layout.left, this is automatic.
56
+
57
+ // We don't need to specify layout.left, this is automatic.
58
+ // The actual layout will become { left: 150, bottom: 10, top: 10, width: 120 } initially.
59
+ layout: { right: 10, top: 10, width: 120 }
60
+
53
61
  })
54
62
 
55
63
  });
56
64
 
57
- ## Modify all child view layouts with `childViewLayoutOptions`
65
+ ## Modify the default behavior with `childViewLayoutOptions`
58
66
 
59
67
  To modify the plugin behavior for all child view layouts, you can set the
60
68
  following child view layout options in `childViewLayoutOptions` on the view:
@@ -81,31 +89,45 @@ SC.mixin(SC.View,
81
89
  // The order of child views is important!
82
90
  childViews: ['sectionA', 'sectionB', 'sectionC'],
83
91
 
84
- // Actual layout will become { left: 10, bottom: 20, top: 20, width: 310 }
92
+ // The view will resize itself to fit its children. The actual layout will become { left: 10, bottom: 20, top: 20, width: 310 }
85
93
  layout: { left: 10, bottom: 20, top: 20 }, // Don't need to specify layout.width, this is automatic.
86
94
 
87
95
  sectionA: SC.View.design({
96
+
88
97
  // Actual layout will become { left: 10, bottom: 0, top: 0, width: 100 }
89
98
  layout: { width: 100 } // Don't need to specify layout.left, this is automatic.
99
+
90
100
  }),
91
101
 
92
102
  sectionB: SC.View.design({
103
+
93
104
  // Actual layout will become { border: 1, left: 115, bottom: 0, top: 0, width: 50 }
94
105
  layout: { border: 1, width: 50 } // Don't need to specify layout.left, this is automatic.
106
+
95
107
  }),
96
108
 
97
109
  sectionC: SC.View.design({
110
+
98
111
  // Actual layout will become { left: 170, top: 10, bottom: 10, width: 120 }
99
112
  layout: { top: 10, bottom: 10, width: 120 } // Don't need to specify layout.left, this is automatic.
113
+
100
114
  })
101
115
 
102
116
  });
103
117
 
104
118
  If `resizeToFit` is set to `false`, the view will not adjust itself to fit
105
119
  its child views. This means that when `resizeToFit` is false, the view should
106
- specify its width component in its layout. This also means that you can
107
- ignore the last child view's layout width if you want the last child view
108
- to stretch to fill the parent view.
120
+ specify its width component in its layout. A direct effect of this is the
121
+ possibility for the child views to automatically expand or shrink in order to
122
+ fill the empty, unclaimed space of the view.
123
+
124
+ This available space is shared between all children that don't specify a fixed width
125
+ such that their final width is calculated proportionally to the value of the
126
+ property `fillRatio`.
127
+
128
+ For simplicity, when none of the children specifies `fillRatio`,
129
+ you can ignore the last child view's layout width and the last child view
130
+ will stretch to fill the parent view.
109
131
 
110
132
  For example,
111
133
 
@@ -118,28 +140,48 @@ SC.mixin(SC.View,
118
140
  childViewLayoutOptions: {
119
141
  paddingBefore: 10,
120
142
  paddingAfter: 20,
121
- spacing: 5
143
+ spacing: 5,
144
+ resizeToFit: false // Setting this to false, so that the child views stretch/contract to fit the parent's size.
122
145
  },
123
146
 
124
147
  // The order of child views is important!
125
148
  childViews: ['sectionA', 'sectionB', 'sectionC'],
126
149
 
127
- // Actual layout will become { left: 10, bottom: 20, top: 20, width: 500 }
128
- layout: { left: 10, bottom: 20, top: 20, width: 500 }, // Need to specify layout.width.
150
+ // The parent view will not resize itself to fit its contents, so we specify the width.
151
+ layout: { left: 10, bottom: 20, top: 20, width: 500 },
129
152
 
130
153
  sectionA: SC.View.design({
154
+
155
+ // We don't need to specify layout.left, this is automatic. This child will not stretch, its width is set.
131
156
  // Actual layout will become { left: 10, bottom: 0, top: 0, width: 100 }
132
- layout: { width: 100 } // Don't need to specify layout.left, this is automatic.
157
+ layout: { width: 100 }
158
+
133
159
  }),
134
160
 
135
161
  sectionB: SC.View.design({
136
- // Actual layout will become { border: 1, left: 115, bottom: 0, top: 0, width: 50 }
137
- layout: { border: 1, width: 50 } // Don't need to specify layout.left, this is automatic.
162
+
163
+ // The unclaimed space so far is 500 - 10 - 100 - 5 - 5 - 20, or 360px. This space will be shared between
164
+ // the two last sections, because we won't specity a width on them.
165
+ // This view will get 1/3 of the available space, because the other flexibile view has a ratio of 2.
166
+ fillRatio: 1,
167
+
168
+ // This section will take 1/3 * 360px = 120px.
169
+ // Actual layout will become { border: 1, left: 115, bottom: 0, top: 0, right: 265 }, in other words, width == 120
170
+ // We don't need to specify layout.left, layout.right or layout.width, this is automatic.
171
+ layout: { border: 1 }
172
+
138
173
  }),
139
174
 
140
175
  sectionC: SC.View.design({
141
- // Actual layout will become { left: 170, top: 10, bottom: 10, right: 20 }
142
- layout: { top: 10, bottom: 10 } // Don't need to specify layout.left, layout.right or layout.width, this is automatic.
176
+
177
+ // This view will get 2/3 of the available space, because the other flexibile view has a ratio of 1.
178
+ fillRatio: 2,
179
+
180
+ // This section will take 2/3 * 360px = 240px.
181
+ // Actual layout will become { left: 240, top: 10, bottom: 10, right: 20 }, in other words, width == 240
182
+ // We don't need to specify layout.left, layout.right or layout.width, this is automatic.
183
+ layout: { top: 10, bottom: 10 }
184
+
143
185
  })
144
186
 
145
187
  });
@@ -154,6 +196,7 @@ SC.mixin(SC.View,
154
196
  - useAbsoluteLayout - Don't include this child view in automatic layout, use absolute positioning based on the child view's `layout` property.
155
197
  - useStaticLayout - Don't include this child view in automatic layout. This child view uses relative positioning and is not eligible for automatic layout.
156
198
  - isVisible - Non-visible child views are not included in the stack.
199
+ - fillRatio - When the parent view is configured with a fixed dimension, children not specifying a width but specifying fillRatio will be resized to fill the unclaimed space proportionally to this ratio.
157
200
 
158
201
  For example,
159
202
 
@@ -219,6 +262,17 @@ SC.mixin(SC.View,
219
262
  /** @private Properties to observe on child views that affect the overall child view layout. */
220
263
  childLayoutProperties: ['marginBefore', 'marginAfter', 'isVisible'],
221
264
 
265
+ /** @private When resizeToFit is false, then we need to know when the view's frame changes. */
266
+ layoutDependsOnSize: function (view) {
267
+ var options = view.get('childViewLayoutOptions');
268
+
269
+ if (options) {
270
+ return SC.none(options.resizeToFit) ? false : !options.resizeToFit;
271
+ } else {
272
+ return false;
273
+ }
274
+ },
275
+
222
276
  /** @private */
223
277
  layoutChildViews: function (view) {
224
278
  var childViews = view.get('childViews'),
@@ -227,14 +281,96 @@ SC.mixin(SC.View,
227
281
  lastMargin = 0, // Used to avoid adding spacing to the final margin.
228
282
  marginAfter = options.paddingBefore || 0,
229
283
  paddingAfter = options.paddingAfter || 0,
230
- position = 0,
284
+ leftPosition = 0,
285
+ provisionedSpace = 0,
286
+ autoFillAvailableSpace = 0,
287
+ totalAvailableSpace = 0,
288
+ totalFillAvailableSpaceRatio = 0,
231
289
  spacing = options.spacing || 0,
290
+ childView,
291
+ fillRatio,
292
+ layout,
293
+ marginBefore,
232
294
  i, len;
233
295
 
296
+ // if the view is not configured to resize to fit content, then we give a chance to the children to fill the available space
297
+ // we make a 1st pass to check the conditions, to evaluate the available space and the proportions between children
298
+ if (!resizeToFit) {
299
+
300
+ totalAvailableSpace = view.get('frame').width;
301
+
302
+ // if the view is not configured to resize and it doesn't have yet a width, it doesn't make sense to layout children
303
+ if (!totalAvailableSpace) {
304
+ return;
305
+ }
306
+
307
+ for (i = 0, len = childViews.get('length'); i < len; i++) {
308
+ childView = childViews.objectAt(i);
309
+
310
+ // Ignore child views with useAbsoluteLayout true, useStaticLayout true or that are not visible.
311
+ if (!childView.get('isVisible') ||
312
+ childView.get('useAbsoluteLayout') ||
313
+ childView.get('useStaticLayout')) {
314
+ continue;
315
+ }
316
+
317
+ layout = childView.get('layout');
318
+
319
+ // Determine the left margin.
320
+ marginBefore = childView.get('marginBefore') || 0;
321
+ provisionedSpace += Math.max(marginAfter, marginBefore);
322
+
323
+ // if the width is not set, let's check if is possible to resize the view
324
+ if (SC.none(layout.width)) {
325
+ fillRatio = childView.get('fillRatio');
326
+
327
+ if (!SC.none(fillRatio)) {
328
+ totalFillAvailableSpaceRatio += fillRatio;
329
+ } else {
330
+ // if none of the child views has fillRatio defined, allow the last one to stretch and fill the available space.
331
+ if (i == len - 1 && totalFillAvailableSpaceRatio === 0) {
332
+ totalFillAvailableSpaceRatio = 1;
333
+ }
334
+ //@if(debug)
335
+ // Add some developer support.
336
+ else {
337
+ // even if we don't have a width set, as last instance we accept the presence of minWidth
338
+ if (SC.none(layout.minWidth))
339
+ {
340
+ SC.warn('Developer Warning: The SC.View.HORIZONTAL_STACK plugin requires that each childView layout contains at least a width or has a configured fillRatio. The layout may also optionally contain top and bottom, top and height, bottom and height or centerY and height. The childView %@ has an invalid layout/fillRatio: %@'.fmt(childView, SC.stringFromLayout(layout)));
341
+ return;
342
+ }
343
+ }
344
+ //@endif
345
+ }
346
+ } else {
347
+ provisionedSpace += childView.getPath('borderFrame.width');
348
+ }
349
+
350
+ // Determine the right margin.
351
+ lastMargin = childView.get('marginAfter') || 0;
352
+ marginAfter = lastMargin || spacing;
353
+ }
354
+
355
+ // consider the end padding when calculating the provisionedSpace
356
+ if (provisionedSpace !== 0 || totalFillAvailableSpaceRatio !== 0) {
357
+ provisionedSpace += Math.max(lastMargin, paddingAfter);
358
+ }
359
+
360
+ autoFillAvailableSpace = Math.max(0, totalAvailableSpace - provisionedSpace);
361
+ }
362
+
363
+ // reset the references for the effective layout
364
+ lastMargin = 0;
365
+ marginAfter = options.paddingBefore || 0;
366
+ paddingAfter = options.paddingAfter || 0;
367
+
234
368
  for (i = 0, len = childViews.get('length'); i < len; i++) {
235
- var childView = childViews.objectAt(i),
236
- layout,
237
- marginBefore;
369
+ var width,
370
+ adjustLeft,
371
+ adjustRight;
372
+
373
+ childView = childViews.objectAt(i);
238
374
 
239
375
  // Ignore child views with useAbsoluteLayout true, useStaticLayout true or that are not visible.
240
376
  if (!childView.get('isVisible') ||
@@ -244,39 +380,83 @@ SC.mixin(SC.View,
244
380
  }
245
381
 
246
382
  layout = childView.get('layout');
383
+
247
384
  //@if(debug)
248
- // Add some developer support.
249
- if (SC.none(layout.width) && (i < len - 1 || resizeToFit)) {
250
- SC.warn('Developer Warning: The SC.View.HORIZONTAL_STACK plugin requires that each childView layout contains at least a width and optionally also top and bottom, top and height, bottom and height or centerY and height. The childView %@ has an invalid layout: %@'.fmt(childView, SC.stringFromLayout(layout)));
385
+ // Add some developer support. The case of !resizeToFit was already checked above
386
+ if (resizeToFit && SC.none(layout.width) && SC.none(layout.minWidth)) {
387
+ SC.warn('Developer Warning: The SC.View.HORIZONTAL_STACK plugin, when configured with resizeToFit, requires that each childView layout contains at least a width/minWidth and optionally also top and bottom, top and height, bottom and height or centerY and height. The childView %@ has an invalid layout: %@'.fmt(childView, SC.stringFromLayout(layout)));
251
388
  return;
252
389
  }
253
390
  //@endif
254
391
 
255
392
  // Determine the left margin.
256
393
  marginBefore = childView.get('marginBefore') || 0;
257
- position += Math.max(marginAfter, marginBefore);
394
+ leftPosition += Math.max(marginAfter, marginBefore);
258
395
 
259
- if (layout.left !== position) {
260
- childView.adjust('left', position);
396
+ // Try to avoid useless adjustments left or right or left then right.
397
+ // The required adjustments will be merged into a single call
398
+ adjustLeft = layout.left !== leftPosition;
399
+
400
+ childView.beginPropertyChanges();
401
+ if (!resizeToFit && !layout.width) {
402
+ var rightPosition;
403
+
404
+ fillRatio = childView.get('fillRatio');
405
+
406
+ // if the last child doesn't define fillRatio, default it to 1 as above during the 1st pass
407
+ if (i == len - 1 && SC.none(fillRatio)) {
408
+ fillRatio = 1;
409
+ }
261
410
 
262
- // Allow the last child view to stretch.
263
- if (!resizeToFit && !layout.width && !layout.right) {
264
- childView.adjust('right', paddingAfter);
411
+ // we should get here only in two cases: 1. child defines fillRatio, 2. child defines a minWidth
412
+ // if both defined, we prefer to handle fillRatio, the other case being handled below by the normal adjustment to left
413
+ if (!SC.none(fillRatio)) {
414
+ var currentAvailableSpaceRatio = (fillRatio / totalFillAvailableSpaceRatio);
415
+
416
+ // calculate the width according to fillRatio and totalFillAvailableSpaceRatio
417
+ // but set the "right" position so any subsequent layout is not considering the width as fixed
418
+ width = Math.ceil(autoFillAvailableSpace * currentAvailableSpaceRatio);
419
+
420
+ // INCOMPLETE: We need to flag this view as constrained and re-compute all the auto-fill amounts
421
+ // Constrain the width to the maximum width allowed.
422
+ // var maxWidth = layout.maxWidth;
423
+ // if (!SC.none(maxWidth)) {
424
+ // // Constrain the width according to maxWidth. Which frees up additional available space for further child views.
425
+ // if (width > maxWidth) {
426
+ // width = maxWidth;
427
+ // }
428
+ // }
429
+
430
+ // Determine the right position. If the position overflows (i.e. goes negative) because of rounding up, stop at 0.
431
+ rightPosition = Math.max(0, totalAvailableSpace - leftPosition - width);
432
+ adjustRight = layout.right !== rightPosition;
433
+
434
+ if (adjustRight) {
435
+ childView.adjust('right', rightPosition);
436
+ }
265
437
  }
266
438
  }
267
- position += childView.getPath('borderFrame.width');
439
+
440
+ if (adjustLeft) {
441
+ childView.adjust('left', leftPosition);
442
+ }
443
+ childView.endPropertyChanges();
444
+
445
+ leftPosition += childView.getPath('borderFrame.width');
268
446
 
269
447
  // Determine the right margin.
270
448
  lastMargin = childView.get('marginAfter') || 0;
271
449
  marginAfter = lastMargin || spacing;
272
450
  }
273
451
 
274
- // Adjust our frame to fit as well, this ensures that scrolling works.
275
452
  // If the current size is 0 (all children are hidden), it doesn't make sense to add the padding
276
- if (position !== 0)
277
- position += Math.max(lastMargin, paddingAfter);
278
- if (resizeToFit && view.getPath('layout.width') !== position) {
279
- view.adjust('width', position);
453
+ if (leftPosition !== 0) {
454
+ leftPosition += Math.max(lastMargin, paddingAfter);
455
+ }
456
+
457
+ // Adjust our frame to fit as well, this ensures that scrolling works.
458
+ if (resizeToFit && view.getPath('layout.width') !== leftPosition) {
459
+ view.adjust('width', leftPosition);
280
460
  }
281
461
  }
282
462