brighter_planet_layout 0.4.3 → 0.4.4

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,191 @@
1
+ (function() {
2
+ // Technique from Juriy Zaytsev
3
+ // http://thinkweb2.com/projects/prototype/detecting-event-support-without-browser-sniffing/
4
+ function isEventSupported(eventName) {
5
+ var el = document.createElement('div');
6
+ eventName = 'on' + eventName;
7
+ var isSupported = (eventName in el);
8
+ if (!isSupported) {
9
+ el.setAttribute(eventName, 'return;');
10
+ isSupported = typeof el[eventName] == 'function';
11
+ }
12
+ el = null;
13
+ return isSupported;
14
+ }
15
+
16
+ function isForm(element) {
17
+ return Object.isElement(element) && element.nodeName.toUpperCase() == 'FORM'
18
+ }
19
+
20
+ function isInput(element) {
21
+ if (Object.isElement(element)) {
22
+ var name = element.nodeName.toUpperCase()
23
+ return name == 'INPUT' || name == 'SELECT' || name == 'TEXTAREA'
24
+ }
25
+ else return false
26
+ }
27
+
28
+ var submitBubbles = isEventSupported('submit'),
29
+ changeBubbles = isEventSupported('change')
30
+
31
+ if (!submitBubbles || !changeBubbles) {
32
+ // augment the Event.Handler class to observe custom events when needed
33
+ Event.Handler.prototype.initialize = Event.Handler.prototype.initialize.wrap(
34
+ function(init, element, eventName, selector, callback) {
35
+ init(element, eventName, selector, callback)
36
+ // is the handler being attached to an element that doesn't support this event?
37
+ if ( (!submitBubbles && this.eventName == 'submit' && !isForm(this.element)) ||
38
+ (!changeBubbles && this.eventName == 'change' && !isInput(this.element)) ) {
39
+ // "submit" => "emulated:submit"
40
+ this.eventName = 'emulated:' + this.eventName
41
+ }
42
+ }
43
+ )
44
+ }
45
+
46
+ if (!submitBubbles) {
47
+ // discover forms on the page by observing focus events which always bubble
48
+ document.on('focusin', 'form', function(focusEvent, form) {
49
+ // special handler for the real "submit" event (one-time operation)
50
+ if (!form.retrieve('emulated:submit')) {
51
+ form.on('submit', function(submitEvent) {
52
+ var emulated = form.fire('emulated:submit', submitEvent, true)
53
+ // if custom event received preventDefault, cancel the real one too
54
+ if (emulated.returnValue === false) submitEvent.preventDefault()
55
+ })
56
+ form.store('emulated:submit', true)
57
+ }
58
+ })
59
+ }
60
+
61
+ if (!changeBubbles) {
62
+ // discover form inputs on the page
63
+ document.on('focusin', 'input, select, texarea', function(focusEvent, input) {
64
+ // special handler for real "change" events
65
+ if (!input.retrieve('emulated:change')) {
66
+ input.on('change', function(changeEvent) {
67
+ input.fire('emulated:change', changeEvent, true)
68
+ })
69
+ input.store('emulated:change', true)
70
+ }
71
+ })
72
+ }
73
+
74
+ function handleRemote(element) {
75
+ var method, url, params;
76
+
77
+ var event = element.fire("ajax:before");
78
+ if (event.stopped) return false;
79
+
80
+ if (element.tagName.toLowerCase() === 'form') {
81
+ method = element.readAttribute('method') || 'post';
82
+ url = element.readAttribute('action');
83
+ params = element.serialize();
84
+ } else {
85
+ method = element.readAttribute('data-method') || 'get';
86
+ url = element.readAttribute('href');
87
+ params = {};
88
+ }
89
+
90
+ new Ajax.Request(url, {
91
+ method: method,
92
+ parameters: params,
93
+ evalScripts: true,
94
+
95
+ onComplete: function(request) { element.fire("ajax:complete", request); },
96
+ onSuccess: function(request) { element.fire("ajax:success", request); },
97
+ onFailure: function(request) { element.fire("ajax:failure", request); }
98
+ });
99
+
100
+ element.fire("ajax:after");
101
+ }
102
+
103
+ function handleMethod(element) {
104
+ var method = element.readAttribute('data-method'),
105
+ url = element.readAttribute('href'),
106
+ csrf_param = $$('meta[name=csrf-param]')[0],
107
+ csrf_token = $$('meta[name=csrf-token]')[0];
108
+
109
+ var form = new Element('form', { method: "POST", action: url, style: "display: none;" });
110
+ element.parentNode.insert(form);
111
+
112
+ if (method !== 'post') {
113
+ var field = new Element('input', { type: 'hidden', name: '_method', value: method });
114
+ form.insert(field);
115
+ }
116
+
117
+ if (csrf_param) {
118
+ var param = csrf_param.readAttribute('content'),
119
+ token = csrf_token.readAttribute('content'),
120
+ field = new Element('input', { type: 'hidden', name: param, value: token });
121
+ form.insert(field);
122
+ }
123
+
124
+ form.submit();
125
+ }
126
+
127
+
128
+ document.on("click", "*[data-confirm]", function(event, element) {
129
+ var message = element.readAttribute('data-confirm');
130
+ if (!confirm(message)) event.stop();
131
+ });
132
+
133
+ document.on("click", "a[data-remote]", function(event, element) {
134
+ if (event.stopped) return;
135
+ handleRemote(element);
136
+ event.stop();
137
+ });
138
+
139
+ document.on("click", "a[data-method]", function(event, element) {
140
+ if (event.stopped) return;
141
+ handleMethod(element);
142
+ event.stop();
143
+ });
144
+
145
+ document.on("submit", function(event) {
146
+ var element = event.findElement(),
147
+ message = element.readAttribute('data-confirm');
148
+ if (message && !confirm(message)) {
149
+ event.stop();
150
+ return false;
151
+ }
152
+
153
+ var inputs = element.select("input[type=submit][data-disable-with]");
154
+ inputs.each(function(input) {
155
+ input.disabled = true;
156
+ input.writeAttribute('data-original-value', input.value);
157
+ input.value = input.readAttribute('data-disable-with');
158
+ });
159
+
160
+ var element = event.findElement("form[data-remote]");
161
+ if (element) {
162
+ handleRemote(element);
163
+ event.stop();
164
+ }
165
+ });
166
+
167
+ document.on("ajax:after", "form", function(event, element) {
168
+ var inputs = element.select("input[type=submit][disabled=true][data-disable-with]");
169
+ inputs.each(function(input) {
170
+ input.value = input.readAttribute('data-original-value');
171
+ input.removeAttribute('data-original-value');
172
+ input.disabled = false;
173
+ });
174
+ });
175
+
176
+ Ajax.Responders.register({
177
+ onCreate: function(request) {
178
+ var csrf_meta_tag = $$('meta[name=csrf-token]')[0];
179
+
180
+ if (csrf_meta_tag) {
181
+ var header = 'X-CSRF-Token',
182
+ token = csrf_meta_tag.readAttribute('content');
183
+
184
+ if (!request.options.requestHeaders) {
185
+ request.options.requestHeaders = {};
186
+ }
187
+ request.options.requestHeaders[header] = token;
188
+ }
189
+ }
190
+ });
191
+ })();
@@ -36,6 +36,8 @@ pre {
36
36
  margin: 10px -15px;
37
37
  border-top: 1px solid #ddd;
38
38
  -moz-box-shadow: inset 0 5px 5px #eee;
39
+ -webkit-box-shadow: inset 0 5px 5px #eee;
40
+ box-shadow: inset 0 5px 5px #eee;
39
41
  }
40
42
 
41
43
  a {
@@ -651,12 +653,42 @@ p.flash.error:before {
651
653
  margin: 25px 0 0;
652
654
  }
653
655
 
654
- #footer #map #links p {
655
- font-size: 14px;
656
+ #footer #links ul {
657
+ list-style: none;
656
658
  }
657
659
 
658
- #footer #map #links p a {
659
- color: inherit;
660
+ #footer #links>ul {
661
+ overflow: auto;
662
+ width: 364px;
663
+ }
664
+
665
+ #footer #links>ul>li {
666
+ width: 121px;
667
+ float: left;
668
+ }
669
+
670
+ #footer #links ul li.home,
671
+ #footer #links ul li.models,
672
+ #footer #links ul li ul li span,
673
+ #footer #links ul li ul li:first-child,
674
+ #footer #links ul li p {
675
+ display: none;
676
+ }
677
+
678
+ #footer #links a {
679
+ color: gray;
680
+ font-size: 16px;
681
+ text-decoration: none;
682
+ }
683
+
684
+ #footer #links a:hover {
685
+ text-decoration: underline;
686
+ color: silver;
687
+ }
688
+
689
+ #footer #links ul li ul li a {
690
+ color: #555;
691
+ font-size: 13px;
660
692
  }
661
693
 
662
694
  #footer #map #social {
data/test/dummy/Gemfile CHANGED
@@ -3,3 +3,4 @@ source 'http://rubygems.org'
3
3
  gem 'rails', '3.0.5'
4
4
  gem 'brighter_planet_layout', :path => '../..'
5
5
  gem 'spox-ultraviolet'
6
+ gem 'unicorn'
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: brighter_planet_layout
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.4.3
4
+ version: 0.4.4
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -10,11 +10,11 @@ authors:
10
10
  autorequire:
11
11
  bindir: bin
12
12
  cert_chain: []
13
- date: 2011-10-04 00:00:00.000000000Z
13
+ date: 2011-10-18 00:00:00.000000000Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: simple-rss
17
- requirement: &2168751120 !ruby/object:Gem::Requirement
17
+ requirement: &2165774820 !ruby/object:Gem::Requirement
18
18
  none: false
19
19
  requirements:
20
20
  - - ! '>='
@@ -22,10 +22,10 @@ dependencies:
22
22
  version: 1.2.3
23
23
  type: :runtime
24
24
  prerelease: false
25
- version_requirements: *2168751120
25
+ version_requirements: *2165774820
26
26
  - !ruby/object:Gem::Dependency
27
27
  name: eat
28
- requirement: &2168750700 !ruby/object:Gem::Requirement
28
+ requirement: &2165773820 !ruby/object:Gem::Requirement
29
29
  none: false
30
30
  requirements:
31
31
  - - ! '>='
@@ -33,10 +33,10 @@ dependencies:
33
33
  version: '0'
34
34
  type: :runtime
35
35
  prerelease: false
36
- version_requirements: *2168750700
36
+ version_requirements: *2165773820
37
37
  - !ruby/object:Gem::Dependency
38
38
  name: tronprint
39
- requirement: &2168750160 !ruby/object:Gem::Requirement
39
+ requirement: &2165772600 !ruby/object:Gem::Requirement
40
40
  none: false
41
41
  requirements:
42
42
  - - ! '>='
@@ -44,10 +44,10 @@ dependencies:
44
44
  version: 1.2.0
45
45
  type: :runtime
46
46
  prerelease: false
47
- version_requirements: *2168750160
47
+ version_requirements: *2165772600
48
48
  - !ruby/object:Gem::Dependency
49
49
  name: test-unit
50
- requirement: &2168749740 !ruby/object:Gem::Requirement
50
+ requirement: &2165770900 !ruby/object:Gem::Requirement
51
51
  none: false
52
52
  requirements:
53
53
  - - ! '>='
@@ -55,7 +55,7 @@ dependencies:
55
55
  version: '0'
56
56
  type: :development
57
57
  prerelease: false
58
- version_requirements: *2168749740
58
+ version_requirements: *2165770900
59
59
  description: Layouts, partials, stylesheets, and images
60
60
  email:
61
61
  - andy@rossmeissl.net
@@ -74,6 +74,7 @@ files:
74
74
  - app/views/layouts/_footer.html.erb
75
75
  - app/views/layouts/_google_analytics.html.erb
76
76
  - app/views/layouts/_header.html.erb
77
+ - app/views/layouts/_nav.html.erb
77
78
  - app/views/layouts/brighter_planet.html.erb
78
79
  - brighter_planet_layout.gemspec
79
80
  - examples/apache2-webfont-header.conf
@@ -97,7 +98,9 @@ files:
97
98
  - public/javascripts/effects.js
98
99
  - public/javascripts/prototype.rails-2.3.10.js
99
100
  - public/javascripts/prototype.rails-2.3.11.js
101
+ - public/javascripts/prototype.rails-3.0.10.js
100
102
  - public/javascripts/prototype.rails-3.0.9.js
103
+ - public/javascripts/rails.rails-3.0.10.js
101
104
  - public/javascripts/rails.rails-3.0.9.js
102
105
  - public/maintenance.html
103
106
  - public/stylesheets/brighter_planet.css
@@ -201,7 +204,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
201
204
  version: '0'
202
205
  requirements: []
203
206
  rubyforge_project: brighter_planet_layout
204
- rubygems_version: 1.8.6
207
+ rubygems_version: 1.8.10
205
208
  signing_key:
206
209
  specification_version: 3
207
210
  summary: Layout assets for Brighter Planet sites