teacup 2.1.1 → 2.1.2
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile.lock +1 -1
- data/app/controllers/motion_layout_controller.rb +14 -0
- data/lib/teacup/constraint.rb +30 -30
- data/lib/teacup/teacup_util.rb +1 -5
- data/lib/teacup/version.rb +1 -1
- data/spec/ios/motion_layout_spec.rb +8 -0
- metadata +2 -2
data/Gemfile.lock
CHANGED
@@ -2,11 +2,13 @@ class MotionLayoutController < UIViewController
|
|
2
2
|
attr :label1
|
3
3
|
attr :label2
|
4
4
|
attr :label3
|
5
|
+
attr :container
|
5
6
|
|
6
7
|
layout :root do
|
7
8
|
@label1 = subview(UILabel, :label1, text: 'label1')
|
8
9
|
@label2 = subview(UILabel, :label2, text: 'label2')
|
9
10
|
@label3 = subview(UILabel, :label3, text: 'label3')
|
11
|
+
@container = subview(CustomContainer, :container)
|
10
12
|
end
|
11
13
|
|
12
14
|
def layoutDidLoad
|
@@ -14,8 +16,20 @@ class MotionLayoutController < UIViewController
|
|
14
16
|
metrics "margin" => 20, "top" => 100
|
15
17
|
horizontal '|-margin-[label1]-margin-[label2(==label1)]-margin-|'
|
16
18
|
horizontal '|-margin-[label3]-margin-|'
|
19
|
+
horizontal '|-margin-[container]-margin-|'
|
17
20
|
vertical '|-top-[label1]'
|
18
21
|
vertical '|-220-[label3(==label1)]'
|
22
|
+
vertical '|-320-[container(==label1)]'
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
class CustomContainer < UIView
|
27
|
+
attr :label4
|
28
|
+
|
29
|
+
def init
|
30
|
+
super.tap do
|
31
|
+
@label4 = subview(UILabel, :label4, text: 'label4')
|
32
|
+
end
|
19
33
|
end
|
20
34
|
end
|
21
35
|
|
data/lib/teacup/constraint.rb
CHANGED
@@ -44,69 +44,69 @@ module Teacup
|
|
44
44
|
case sym
|
45
45
|
when :full
|
46
46
|
[
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
47
|
+
self.new(:self, :left).equals(relative_to, :left),
|
48
|
+
self.new(:self, :top).equals(relative_to, :top),
|
49
|
+
self.new(:self, :width).equals(relative_to, :width),
|
50
|
+
self.new(:self, :height).equals(relative_to, :height),
|
51
51
|
]
|
52
52
|
when :full_width
|
53
53
|
[
|
54
|
-
|
55
|
-
|
54
|
+
self.new(:self, :center_x).equals(relative_to, :center_x),
|
55
|
+
self.new(:self, :width).equals(relative_to, :width),
|
56
56
|
]
|
57
57
|
when :full_height
|
58
58
|
[
|
59
|
-
|
60
|
-
|
59
|
+
self.new(:self, :center_y).equals(relative_to, :center_y),
|
60
|
+
self.new(:self, :height).equals(relative_to, :height),
|
61
61
|
]
|
62
62
|
when :center_x
|
63
63
|
[
|
64
|
-
|
64
|
+
self.new(:self, :center_x).equals(:superview, :center_x),
|
65
65
|
]
|
66
66
|
when :center_y
|
67
67
|
[
|
68
|
-
|
68
|
+
self.new(:self, :center_y).equals(:superview, :center_y),
|
69
69
|
]
|
70
70
|
when :centered
|
71
71
|
[
|
72
|
-
|
73
|
-
|
72
|
+
self.new(:self, :center_x).equals(:superview, :center_x),
|
73
|
+
self.new(:self, :center_y).equals(:superview, :center_y),
|
74
74
|
]
|
75
75
|
when :top
|
76
76
|
[
|
77
|
-
|
77
|
+
self.new(:self, :top).equals(relative_to, :top),
|
78
78
|
]
|
79
79
|
when :right
|
80
80
|
[
|
81
|
-
|
81
|
+
self.new(:self, :right).equals(relative_to, :right),
|
82
82
|
]
|
83
83
|
when :bottom
|
84
84
|
[
|
85
|
-
|
85
|
+
self.new(:self, :bottom).equals(relative_to, :bottom),
|
86
86
|
]
|
87
87
|
when :left
|
88
88
|
[
|
89
|
-
|
89
|
+
self.new(:self, :left).equals(relative_to, :left),
|
90
90
|
]
|
91
91
|
when :top_left, :topleft
|
92
92
|
[
|
93
|
-
|
94
|
-
|
93
|
+
self.new(:self, :left).equals(relative_to, :left),
|
94
|
+
self.new(:self, :top).equals(relative_to, :top),
|
95
95
|
]
|
96
96
|
when :top_right, :topright
|
97
97
|
[
|
98
|
-
|
99
|
-
|
98
|
+
self.new(:self, :right).equals(relative_to, :right),
|
99
|
+
self.new(:self, :top).equals(relative_to, :top),
|
100
100
|
]
|
101
101
|
when :bottom_right, :bottomright
|
102
102
|
[
|
103
|
-
|
104
|
-
|
103
|
+
self.new(:self, :right).equals(relative_to, :right),
|
104
|
+
self.new(:self, :bottom).equals(relative_to, :bottom),
|
105
105
|
]
|
106
106
|
when :bottom_left, :bottomleft
|
107
107
|
[
|
108
|
-
|
109
|
-
|
108
|
+
self.new(:self, :left).equals(relative_to, :left),
|
109
|
+
self.new(:self, :bottom).equals(relative_to, :bottom),
|
110
110
|
]
|
111
111
|
else
|
112
112
|
raise "Unknown symbol #{sym.inspect}"
|
@@ -118,7 +118,7 @@ module Teacup
|
|
118
118
|
self.attribute = attribute
|
119
119
|
self.constant = 0
|
120
120
|
self.multiplier = 1
|
121
|
-
self.priority = :high
|
121
|
+
self.priority = :high # this is the xcode default
|
122
122
|
end
|
123
123
|
|
124
124
|
def equals(relative_to, attribute2=nil)
|
@@ -188,7 +188,7 @@ module Teacup
|
|
188
188
|
end
|
189
189
|
|
190
190
|
def copy
|
191
|
-
copy =
|
191
|
+
copy = self.class.new(self.target, self.attribute)
|
192
192
|
copy.relationship = self.relationship
|
193
193
|
copy.relative_to = self.relative_to
|
194
194
|
copy.attribute2 = self.attribute2
|
@@ -211,16 +211,16 @@ module Teacup
|
|
211
211
|
end
|
212
212
|
|
213
213
|
def nslayoutconstraint
|
214
|
-
NSLayoutConstraint.constraintWithItem( self.target,
|
214
|
+
nsconstraint = NSLayoutConstraint.constraintWithItem( self.target,
|
215
215
|
attribute: self.attribute,
|
216
216
|
relatedBy: self.relationship,
|
217
217
|
toItem: self.relative_to,
|
218
218
|
attribute: self.attribute2,
|
219
219
|
multiplier: self.multiplier,
|
220
220
|
constant: self.constant
|
221
|
-
)
|
222
|
-
|
223
|
-
|
221
|
+
)
|
222
|
+
nsconstraint.priority = priority_lookup(self.priority)
|
223
|
+
return nsconstraint
|
224
224
|
end
|
225
225
|
|
226
226
|
private
|
data/lib/teacup/teacup_util.rb
CHANGED
@@ -4,11 +4,7 @@ module Teacup
|
|
4
4
|
# Returns all the subviews of `target` that have a stylename. `target` is not
|
5
5
|
# included in the list. Used by the motion-layout integration in layout.rb.
|
6
6
|
def get_styled_subviews(target)
|
7
|
-
|
8
|
-
retval.concat(target.subviews.map do |subview|
|
9
|
-
get_styled_subviews(subview)
|
10
|
-
end)
|
11
|
-
retval.flatten
|
7
|
+
target.subviews.select { |v| v.stylename }
|
12
8
|
end
|
13
9
|
|
14
10
|
def to_instance(class_or_instance)
|
data/lib/teacup/version.rb
CHANGED
@@ -39,6 +39,14 @@ describe "MotionLayout" do
|
|
39
39
|
label3_top.should == 220
|
40
40
|
end
|
41
41
|
|
42
|
+
it 'should have label4 at 320' do
|
43
|
+
frame = controller.container.label4.frame
|
44
|
+
frame = controller.container.convertRect(frame, toView: controller.view)
|
45
|
+
label4_top = CGRectGetMinY(frame)
|
46
|
+
label4_top.should == 320
|
47
|
+
end
|
48
|
+
|
49
|
+
|
42
50
|
end
|
43
51
|
|
44
52
|
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: teacup
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.1.
|
4
|
+
version: 2.1.2
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2013-07-
|
12
|
+
date: 2013-07-28 00:00:00.000000000 Z
|
13
13
|
dependencies: []
|
14
14
|
description: ! 'Teacup is a community-driven DSL for making CSS-like styling, and
|
15
15
|
layouts for
|