blueshift 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (74) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +17 -0
  3. data/Gemfile +4 -0
  4. data/LICENSE.txt +22 -0
  5. data/README.md +74 -0
  6. data/Rakefile +1 -0
  7. data/app/assets/fonts/gotham/gotham-bold.eot +0 -0
  8. data/app/assets/fonts/gotham/gotham-bold.svg +628 -0
  9. data/app/assets/fonts/gotham/gotham-bold.ttf +0 -0
  10. data/app/assets/fonts/gotham/gotham-bold.woff +0 -0
  11. data/app/assets/fonts/gotham/gotham-book.eot +0 -0
  12. data/app/assets/fonts/gotham/gotham-book.svg +631 -0
  13. data/app/assets/fonts/gotham/gotham-book.ttf +0 -0
  14. data/app/assets/fonts/gotham/gotham-book.woff +0 -0
  15. data/app/assets/fonts/gotham/gotham-light.eot +0 -0
  16. data/app/assets/fonts/gotham/gotham-light.svg +635 -0
  17. data/app/assets/fonts/gotham/gotham-light.ttf +0 -0
  18. data/app/assets/fonts/gotham/gotham-light.woff +0 -0
  19. data/app/assets/fonts/gotham/gotham-medium.eot +0 -0
  20. data/app/assets/fonts/gotham/gotham-medium.svg +629 -0
  21. data/app/assets/fonts/gotham/gotham-medium.ttf +0 -0
  22. data/app/assets/fonts/gotham/gotham-medium.woff +0 -0
  23. data/app/assets/fonts/ionicons/ionicons.eot +0 -0
  24. data/app/assets/fonts/ionicons/ionicons.svg +2254 -0
  25. data/app/assets/fonts/ionicons/ionicons.ttf +0 -0
  26. data/app/assets/fonts/ionicons/ionicons.woff +0 -0
  27. data/blueshift.gemspec +23 -0
  28. data/lib/blueshift.rb +6 -0
  29. data/lib/blueshift/version.rb +3 -0
  30. data/vendor/assets/javascripts/alert.js +99 -0
  31. data/vendor/assets/javascripts/collapse.js +167 -0
  32. data/vendor/assets/javascripts/date_picker.js +474 -0
  33. data/vendor/assets/javascripts/dropdown.js +169 -0
  34. data/vendor/assets/javascripts/file_input.js +100 -0
  35. data/vendor/assets/javascripts/map.js +2044 -0
  36. data/vendor/assets/javascripts/modal (1).js +247 -0
  37. data/vendor/assets/javascripts/modal.js +247 -0
  38. data/vendor/assets/javascripts/popover.js +114 -0
  39. data/vendor/assets/javascripts/tab.js +144 -0
  40. data/vendor/assets/javascripts/time_picker.js +888 -0
  41. data/vendor/assets/javascripts/tooltip.js +361 -0
  42. data/vendor/assets/javascripts/transitions.js +60 -0
  43. data/vendor/assets/stylesheets/ad.css.scss +72 -0
  44. data/vendor/assets/stylesheets/alert.css.scss +40 -0
  45. data/vendor/assets/stylesheets/breadcrumb.css.scss +22 -0
  46. data/vendor/assets/stylesheets/button.css.scss +202 -0
  47. data/vendor/assets/stylesheets/code.css.scss +49 -0
  48. data/vendor/assets/stylesheets/collapse.css.scss +14 -0
  49. data/vendor/assets/stylesheets/datepicker.css.scss +102 -0
  50. data/vendor/assets/stylesheets/dropdown.css.scss +84 -0
  51. data/vendor/assets/stylesheets/footer.css.scss +33 -0
  52. data/vendor/assets/stylesheets/form.css.scss +207 -0
  53. data/vendor/assets/stylesheets/grid.css.scss +291 -0
  54. data/vendor/assets/stylesheets/header.css.scss +134 -0
  55. data/vendor/assets/stylesheets/icon.css.scss +966 -0
  56. data/vendor/assets/stylesheets/image.css.scss +39 -0
  57. data/vendor/assets/stylesheets/label_and_badge.css.scss +53 -0
  58. data/vendor/assets/stylesheets/link.css.scss +19 -0
  59. data/vendor/assets/stylesheets/list.css.scss +38 -0
  60. data/vendor/assets/stylesheets/map.css.scss +13 -0
  61. data/vendor/assets/stylesheets/modal.css.scss +117 -0
  62. data/vendor/assets/stylesheets/pagination.css.scss +37 -0
  63. data/vendor/assets/stylesheets/placeholder.css.scss +11 -0
  64. data/vendor/assets/stylesheets/popover.css.scss +107 -0
  65. data/vendor/assets/stylesheets/progress.css.scss +25 -0
  66. data/vendor/assets/stylesheets/reset.css.scss +57 -0
  67. data/vendor/assets/stylesheets/tab.css.scss +165 -0
  68. data/vendor/assets/stylesheets/table.css.scss +70 -0
  69. data/vendor/assets/stylesheets/timepicker.css.scss +69 -0
  70. data/vendor/assets/stylesheets/tooltip.css.scss +81 -0
  71. data/vendor/assets/stylesheets/transitions.css.scss +12 -0
  72. data/vendor/assets/stylesheets/trunk.css.scss +72 -0
  73. data/vendor/assets/stylesheets/typography.css.scss +140 -0
  74. metadata +145 -0
@@ -0,0 +1,361 @@
1
+ /* ===========================================================
2
+ * bootstrap-tooltip.js v2.3.2
3
+ * http://getbootstrap.com/2.3.2/javascript.html#tooltips
4
+ * Inspired by the original jQuery.tipsy by Jason Frame
5
+ * ===========================================================
6
+ * Copyright 2013 Twitter, Inc.
7
+ *
8
+ * Licensed under the Apache License, Version 2.0 (the "License");
9
+ * you may not use this file except in compliance with the License.
10
+ * You may obtain a copy of the License at
11
+ *
12
+ * http://www.apache.org/licenses/LICENSE-2.0
13
+ *
14
+ * Unless required by applicable law or agreed to in writing, software
15
+ * distributed under the License is distributed on an "AS IS" BASIS,
16
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ * See the License for the specific language governing permissions and
18
+ * limitations under the License.
19
+ * ========================================================== */
20
+
21
+
22
+ !function ($) {
23
+
24
+ "use strict"; // jshint ;_;
25
+
26
+
27
+ /* TOOLTIP PUBLIC CLASS DEFINITION
28
+ * =============================== */
29
+
30
+ var Tooltip = function (element, options) {
31
+ this.init('tooltip', element, options)
32
+ }
33
+
34
+ Tooltip.prototype = {
35
+
36
+ constructor: Tooltip
37
+
38
+ , init: function (type, element, options) {
39
+ var eventIn
40
+ , eventOut
41
+ , triggers
42
+ , trigger
43
+ , i
44
+
45
+ this.type = type
46
+ this.$element = $(element)
47
+ this.options = this.getOptions(options)
48
+ this.enabled = true
49
+
50
+ triggers = this.options.trigger.split(' ')
51
+
52
+ for (i = triggers.length; i--;) {
53
+ trigger = triggers[i]
54
+ if (trigger == 'click') {
55
+ this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
56
+ } else if (trigger != 'manual') {
57
+ eventIn = trigger == 'hover' ? 'mouseenter' : 'focus'
58
+ eventOut = trigger == 'hover' ? 'mouseleave' : 'blur'
59
+ this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
60
+ this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
61
+ }
62
+ }
63
+
64
+ this.options.selector ?
65
+ (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
66
+ this.fixTitle()
67
+ }
68
+
69
+ , getOptions: function (options) {
70
+ options = $.extend({}, $.fn[this.type].defaults, this.$element.data(), options)
71
+
72
+ if (options.delay && typeof options.delay == 'number') {
73
+ options.delay = {
74
+ show: options.delay
75
+ , hide: options.delay
76
+ }
77
+ }
78
+
79
+ return options
80
+ }
81
+
82
+ , enter: function (e) {
83
+ var defaults = $.fn[this.type].defaults
84
+ , options = {}
85
+ , self
86
+
87
+ this._options && $.each(this._options, function (key, value) {
88
+ if (defaults[key] != value) options[key] = value
89
+ }, this)
90
+
91
+ self = $(e.currentTarget)[this.type](options).data(this.type)
92
+
93
+ if (!self.options.delay || !self.options.delay.show) return self.show()
94
+
95
+ clearTimeout(this.timeout)
96
+ self.hoverState = 'in'
97
+ this.timeout = setTimeout(function() {
98
+ if (self.hoverState == 'in') self.show()
99
+ }, self.options.delay.show)
100
+ }
101
+
102
+ , leave: function (e) {
103
+ var self = $(e.currentTarget)[this.type](this._options).data(this.type)
104
+
105
+ if (this.timeout) clearTimeout(this.timeout)
106
+ if (!self.options.delay || !self.options.delay.hide) return self.hide()
107
+
108
+ self.hoverState = 'out'
109
+ this.timeout = setTimeout(function() {
110
+ if (self.hoverState == 'out') self.hide()
111
+ }, self.options.delay.hide)
112
+ }
113
+
114
+ , show: function () {
115
+ var $tip
116
+ , pos
117
+ , actualWidth
118
+ , actualHeight
119
+ , placement
120
+ , tp
121
+ , e = $.Event('show')
122
+
123
+ if (this.hasContent() && this.enabled) {
124
+ this.$element.trigger(e)
125
+ if (e.isDefaultPrevented()) return
126
+ $tip = this.tip()
127
+ this.setContent()
128
+
129
+ if (this.options.animation) {
130
+ $tip.addClass('fade')
131
+ }
132
+
133
+ placement = typeof this.options.placement == 'function' ?
134
+ this.options.placement.call(this, $tip[0], this.$element[0]) :
135
+ this.options.placement
136
+
137
+ $tip
138
+ .detach()
139
+ .css({ top: 0, left: 0, display: 'block' })
140
+
141
+ this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
142
+
143
+ pos = this.getPosition()
144
+
145
+ actualWidth = $tip[0].offsetWidth
146
+ actualHeight = $tip[0].offsetHeight
147
+
148
+ switch (placement) {
149
+ case 'bottom':
150
+ tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}
151
+ break
152
+ case 'top':
153
+ tp = {top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2}
154
+ break
155
+ case 'left':
156
+ tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth}
157
+ break
158
+ case 'right':
159
+ tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width}
160
+ break
161
+ }
162
+
163
+ this.applyPlacement(tp, placement)
164
+ this.$element.trigger('shown')
165
+ }
166
+ }
167
+
168
+ , applyPlacement: function(offset, placement){
169
+ var $tip = this.tip()
170
+ , width = $tip[0].offsetWidth
171
+ , height = $tip[0].offsetHeight
172
+ , actualWidth
173
+ , actualHeight
174
+ , delta
175
+ , replace
176
+
177
+ $tip
178
+ .offset(offset)
179
+ .addClass(placement)
180
+ .addClass('in')
181
+
182
+ actualWidth = $tip[0].offsetWidth
183
+ actualHeight = $tip[0].offsetHeight
184
+
185
+ if (placement == 'top' && actualHeight != height) {
186
+ offset.top = offset.top + height - actualHeight
187
+ replace = true
188
+ }
189
+
190
+ if (placement == 'bottom' || placement == 'top') {
191
+ delta = 0
192
+
193
+ if (offset.left < 0){
194
+ delta = offset.left * -2
195
+ offset.left = 0
196
+ $tip.offset(offset)
197
+ actualWidth = $tip[0].offsetWidth
198
+ actualHeight = $tip[0].offsetHeight
199
+ }
200
+
201
+ this.replaceArrow(delta - width + actualWidth, actualWidth, 'left')
202
+ } else {
203
+ this.replaceArrow(actualHeight - height, actualHeight, 'top')
204
+ }
205
+
206
+ if (replace) $tip.offset(offset)
207
+ }
208
+
209
+ , replaceArrow: function(delta, dimension, position){
210
+ this
211
+ .arrow()
212
+ .css(position, delta ? (50 * (1 - delta / dimension) + "%") : '')
213
+ }
214
+
215
+ , setContent: function () {
216
+ var $tip = this.tip()
217
+ , title = this.getTitle()
218
+
219
+ $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
220
+ $tip.removeClass('fade in top bottom left right')
221
+ }
222
+
223
+ , hide: function () {
224
+ var that = this
225
+ , $tip = this.tip()
226
+ , e = $.Event('hide')
227
+
228
+ this.$element.trigger(e)
229
+ if (e.isDefaultPrevented()) return
230
+
231
+ $tip.removeClass('in')
232
+
233
+ function removeWithAnimation() {
234
+ var timeout = setTimeout(function () {
235
+ $tip.off($.support.transition.end).detach()
236
+ }, 500)
237
+
238
+ $tip.one($.support.transition.end, function () {
239
+ clearTimeout(timeout)
240
+ $tip.detach()
241
+ })
242
+ }
243
+
244
+ $.support.transition && this.$tip.hasClass('fade') ?
245
+ removeWithAnimation() :
246
+ $tip.detach()
247
+
248
+ this.$element.trigger('hidden')
249
+
250
+ return this
251
+ }
252
+
253
+ , fixTitle: function () {
254
+ var $e = this.$element
255
+ if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
256
+ $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
257
+ }
258
+ }
259
+
260
+ , hasContent: function () {
261
+ return this.getTitle()
262
+ }
263
+
264
+ , getPosition: function () {
265
+ var el = this.$element[0]
266
+ return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : {
267
+ width: el.offsetWidth
268
+ , height: el.offsetHeight
269
+ }, this.$element.offset())
270
+ }
271
+
272
+ , getTitle: function () {
273
+ var title
274
+ , $e = this.$element
275
+ , o = this.options
276
+
277
+ title = $e.attr('data-original-title')
278
+ || (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
279
+
280
+ return title
281
+ }
282
+
283
+ , tip: function () {
284
+ return this.$tip = this.$tip || $(this.options.template)
285
+ }
286
+
287
+ , arrow: function(){
288
+ return this.$arrow = this.$arrow || this.tip().find(".tooltip-arrow")
289
+ }
290
+
291
+ , validate: function () {
292
+ if (!this.$element[0].parentNode) {
293
+ this.hide()
294
+ this.$element = null
295
+ this.options = null
296
+ }
297
+ }
298
+
299
+ , enable: function () {
300
+ this.enabled = true
301
+ }
302
+
303
+ , disable: function () {
304
+ this.enabled = false
305
+ }
306
+
307
+ , toggleEnabled: function () {
308
+ this.enabled = !this.enabled
309
+ }
310
+
311
+ , toggle: function (e) {
312
+ var self = e ? $(e.currentTarget)[this.type](this._options).data(this.type) : this
313
+ self.tip().hasClass('in') ? self.hide() : self.show()
314
+ }
315
+
316
+ , destroy: function () {
317
+ this.hide().$element.off('.' + this.type).removeData(this.type)
318
+ }
319
+
320
+ }
321
+
322
+
323
+ /* TOOLTIP PLUGIN DEFINITION
324
+ * ========================= */
325
+
326
+ var old = $.fn.tooltip
327
+
328
+ $.fn.tooltip = function ( option ) {
329
+ return this.each(function () {
330
+ var $this = $(this)
331
+ , data = $this.data('tooltip')
332
+ , options = typeof option == 'object' && option
333
+ if (!data) $this.data('tooltip', (data = new Tooltip(this, options)))
334
+ if (typeof option == 'string') data[option]()
335
+ })
336
+ }
337
+
338
+ $.fn.tooltip.Constructor = Tooltip
339
+
340
+ $.fn.tooltip.defaults = {
341
+ animation: true
342
+ , placement: 'top'
343
+ , selector: false
344
+ , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
345
+ , trigger: 'hover focus'
346
+ , title: ''
347
+ , delay: 0
348
+ , html: false
349
+ , container: false
350
+ }
351
+
352
+
353
+ /* TOOLTIP NO CONFLICT
354
+ * =================== */
355
+
356
+ $.fn.tooltip.noConflict = function () {
357
+ $.fn.tooltip = old
358
+ return this
359
+ }
360
+
361
+ }(window.jQuery);
@@ -0,0 +1,60 @@
1
+ /* ===================================================
2
+ * bootstrap-transition.js v2.3.2
3
+ * http://getbootstrap.com/2.3.2/javascript.html#transitions
4
+ * ===================================================
5
+ * Copyright 2013 Twitter, Inc.
6
+ *
7
+ * Licensed under the Apache License, Version 2.0 (the "License");
8
+ * you may not use this file except in compliance with the License.
9
+ * You may obtain a copy of the License at
10
+ *
11
+ * http://www.apache.org/licenses/LICENSE-2.0
12
+ *
13
+ * Unless required by applicable law or agreed to in writing, software
14
+ * distributed under the License is distributed on an "AS IS" BASIS,
15
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ * See the License for the specific language governing permissions and
17
+ * limitations under the License.
18
+ * ========================================================== */
19
+
20
+
21
+ !function ($) {
22
+
23
+ "use strict"; // jshint ;_;
24
+
25
+
26
+ /* CSS TRANSITION SUPPORT (http://www.modernizr.com/)
27
+ * ======================================================= */
28
+
29
+ $(function () {
30
+
31
+ $.support.transition = (function () {
32
+
33
+ var transitionEnd = (function () {
34
+
35
+ var el = document.createElement('bootstrap')
36
+ , transEndEventNames = {
37
+ 'WebkitTransition' : 'webkitTransitionEnd'
38
+ , 'MozTransition' : 'transitionend'
39
+ , 'OTransition' : 'oTransitionEnd otransitionend'
40
+ , 'transition' : 'transitionend'
41
+ }
42
+ , name
43
+
44
+ for (name in transEndEventNames){
45
+ if (el.style[name] !== undefined) {
46
+ return transEndEventNames[name]
47
+ }
48
+ }
49
+
50
+ }())
51
+
52
+ return transitionEnd && {
53
+ end: transitionEnd
54
+ }
55
+
56
+ })()
57
+
58
+ })
59
+
60
+ }(window.jQuery);
@@ -0,0 +1,72 @@
1
+ /* Table of Contents
2
+ ==================================================
3
+ #Ad */
4
+
5
+ /* #Ad
6
+ ================================================== */
7
+ .ad {
8
+ background-color: rgba(236,238,241,1);
9
+ height: 220px;
10
+ width: 220px;
11
+ }
12
+ .ad-large-rectangle {
13
+ height: 280px;
14
+ width: 336px;
15
+ }
16
+ .ad-medium-rectangle {
17
+ height: 250px;
18
+ width: 300px;
19
+ }
20
+ .ad-small-rectangle {
21
+ height: 150px;
22
+ width: 180px;
23
+ }
24
+ .ad-square {
25
+ height: 250px;
26
+ width: 250px;
27
+ }
28
+ .ad-small-square {
29
+ height: 200px;
30
+ width: 200px;
31
+ }
32
+ .ad-button {
33
+ height: 125px;
34
+ width: 125px;
35
+ }
36
+ .ad-large-leaderboard {
37
+ height: 90px;
38
+ width: 970px;
39
+ }
40
+ .ad-leaderboard {
41
+ height: 90px;
42
+ width: 728px;
43
+ }
44
+ .ad-banner {
45
+ height: 60px;
46
+ width: 468px;
47
+ }
48
+ .ad-half-banner {
49
+ height: 60px;
50
+ width: 234px;
51
+ }
52
+ .ad-mobile-banner {
53
+ height: 50px;
54
+ width: 320px;
55
+ }
56
+ .ad-vertical-banner {
57
+ height: 240px;
58
+ width: 120px;
59
+ }
60
+ .ad-large-skyscrapper {
61
+ height: 600px;
62
+ width: 300px;
63
+ }
64
+ .ad-wide-skyscrapper {
65
+ height: 600px;
66
+ width: 160px;
67
+ }
68
+ .ad-skyscrapper {
69
+ height: 600px;
70
+ width: 120px;
71
+ }
72
+ .ad-center { margin: 0 auto; }