quantum 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +17 -0
  3. data/.project +13 -0
  4. data/Gemfile +4 -0
  5. data/LICENSE.txt +22 -0
  6. data/README.md +82 -0
  7. data/Rakefile +1 -0
  8. data/lib/quantum.rb +8 -0
  9. data/lib/quantum/version.rb +3 -0
  10. data/quantum.gemspec +23 -0
  11. data/vendor/assets/.keep +0 -0
  12. data/vendor/assets/javascripts/alert.js +99 -0
  13. data/vendor/assets/javascripts/chart.js +1424 -0
  14. data/vendor/assets/javascripts/collapse.js +167 -0
  15. data/vendor/assets/javascripts/date_picker.js +474 -0
  16. data/vendor/assets/javascripts/dropdown.js +169 -0
  17. data/vendor/assets/javascripts/file_input.js +100 -0
  18. data/vendor/assets/javascripts/input_mask.js +355 -0
  19. data/vendor/assets/javascripts/map.js +1982 -0
  20. data/vendor/assets/javascripts/modal.js +247 -0
  21. data/vendor/assets/javascripts/popover.js +114 -0
  22. data/vendor/assets/javascripts/qrcode.js +89 -0
  23. data/vendor/assets/javascripts/qrcoder.js +1237 -0
  24. data/vendor/assets/javascripts/tab.js +144 -0
  25. data/vendor/assets/javascripts/time_picker.js +888 -0
  26. data/vendor/assets/javascripts/tooltip.js +361 -0
  27. data/vendor/assets/javascripts/transitions.js +60 -0
  28. data/vendor/assets/javascripts/typeahead.js +335 -0
  29. data/vendor/assets/javascripts/wizard.js +114 -0
  30. data/vendor/assets/stylesheets/alert.css.scss +42 -0
  31. data/vendor/assets/stylesheets/breadcrumb.css.scss +24 -0
  32. data/vendor/assets/stylesheets/button.css.scss +252 -0
  33. data/vendor/assets/stylesheets/chart.css.scss +10 -0
  34. data/vendor/assets/stylesheets/code.css.scss +47 -0
  35. data/vendor/assets/stylesheets/collapse.css.scss +16 -0
  36. data/vendor/assets/stylesheets/datepicker.css.scss +111 -0
  37. data/vendor/assets/stylesheets/dropdown.css.scss +98 -0
  38. data/vendor/assets/stylesheets/file_input.css.scss +7 -0
  39. data/vendor/assets/stylesheets/footer.css.scss +99 -0
  40. data/vendor/assets/stylesheets/form.css.scss +190 -0
  41. data/vendor/assets/stylesheets/grid.css.scss +334 -0
  42. data/vendor/assets/stylesheets/header.css.scss +162 -0
  43. data/vendor/assets/stylesheets/icon.css.scss +533 -0
  44. data/vendor/assets/stylesheets/image.css.scss +48 -0
  45. data/vendor/assets/stylesheets/label_and_badge.css.scss +60 -0
  46. data/vendor/assets/stylesheets/link.css.scss +22 -0
  47. data/vendor/assets/stylesheets/map.css.scss +13 -0
  48. data/vendor/assets/stylesheets/modal.css.scss +100 -0
  49. data/vendor/assets/stylesheets/pagination.css.scss +65 -0
  50. data/vendor/assets/stylesheets/popover.css.scss +110 -0
  51. data/vendor/assets/stylesheets/progress.css.scss +81 -0
  52. data/vendor/assets/stylesheets/qrcode.css.scss +7 -0
  53. data/vendor/assets/stylesheets/reset.css.scss +75 -0
  54. data/vendor/assets/stylesheets/tab.css.scss +202 -0
  55. data/vendor/assets/stylesheets/table.css.scss +71 -0
  56. data/vendor/assets/stylesheets/timepicker.css.scss +74 -0
  57. data/vendor/assets/stylesheets/tooltip.css.scss +83 -0
  58. data/vendor/assets/stylesheets/transitions.css.scss +14 -0
  59. data/vendor/assets/stylesheets/trunk.css.scss +80 -0
  60. data/vendor/assets/stylesheets/typeahead.css.scss +7 -0
  61. data/vendor/assets/stylesheets/typography.css.scss +130 -0
  62. data/vendor/assets/stylesheets/wizard.css.scss +27 -0
  63. metadata +134 -0
@@ -0,0 +1,247 @@
1
+ /* =========================================================
2
+ * bootstrap-modal.js v2.3.2
3
+ * http://twitter.github.com/bootstrap/javascript.html#modals
4
+ * =========================================================
5
+ * Copyright 2012 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
+ /* MODAL CLASS DEFINITION
27
+ * ====================== */
28
+
29
+ var Modal = function (element, options) {
30
+ this.options = options
31
+ this.$element = $(element)
32
+ .delegate('[data-dismiss="modal"]', 'click.dismiss.modal', $.proxy(this.hide, this))
33
+ this.options.remote && this.$element.find('.modal-body').load(this.options.remote)
34
+ }
35
+
36
+ Modal.prototype = {
37
+
38
+ constructor: Modal
39
+
40
+ , toggle: function () {
41
+ return this[!this.isShown ? 'show' : 'hide']()
42
+ }
43
+
44
+ , show: function () {
45
+ var that = this
46
+ , e = $.Event('show')
47
+
48
+ this.$element.trigger(e)
49
+
50
+ if (this.isShown || e.isDefaultPrevented()) return
51
+
52
+ this.isShown = true
53
+
54
+ this.escape()
55
+
56
+ this.backdrop(function () {
57
+ var transition = $.support.transition && that.$element.hasClass('fade')
58
+
59
+ if (!that.$element.parent().length) {
60
+ that.$element.appendTo(document.body) //don't move modals dom position
61
+ }
62
+
63
+ that.$element.show()
64
+
65
+ if (transition) {
66
+ that.$element[0].offsetWidth // force reflow
67
+ }
68
+
69
+ that.$element
70
+ .addClass('in')
71
+ .attr('aria-hidden', false)
72
+
73
+ that.enforceFocus()
74
+
75
+ transition ?
76
+ that.$element.one($.support.transition.end, function () { that.$element.focus().trigger('shown') }) :
77
+ that.$element.focus().trigger('shown')
78
+
79
+ })
80
+ }
81
+
82
+ , hide: function (e) {
83
+ e && e.preventDefault()
84
+
85
+ var that = this
86
+
87
+ e = $.Event('hide')
88
+
89
+ this.$element.trigger(e)
90
+
91
+ if (!this.isShown || e.isDefaultPrevented()) return
92
+
93
+ this.isShown = false
94
+
95
+ this.escape()
96
+
97
+ $(document).off('focusin.modal')
98
+
99
+ this.$element
100
+ .removeClass('in')
101
+ .attr('aria-hidden', true)
102
+
103
+ $.support.transition && this.$element.hasClass('fade') ?
104
+ this.hideWithTransition() :
105
+ this.hideModal()
106
+ }
107
+
108
+ , enforceFocus: function () {
109
+ var that = this
110
+ $(document).on('focusin.modal', function (e) {
111
+ if (that.$element[0] !== e.target && !that.$element.has(e.target).length) {
112
+ that.$element.focus()
113
+ }
114
+ })
115
+ }
116
+
117
+ , escape: function () {
118
+ var that = this
119
+ if (this.isShown && this.options.keyboard) {
120
+ this.$element.on('keyup.dismiss.modal', function ( e ) {
121
+ e.which == 27 && that.hide()
122
+ })
123
+ } else if (!this.isShown) {
124
+ this.$element.off('keyup.dismiss.modal')
125
+ }
126
+ }
127
+
128
+ , hideWithTransition: function () {
129
+ var that = this
130
+ , timeout = setTimeout(function () {
131
+ that.$element.off($.support.transition.end)
132
+ that.hideModal()
133
+ }, 500)
134
+
135
+ this.$element.one($.support.transition.end, function () {
136
+ clearTimeout(timeout)
137
+ that.hideModal()
138
+ })
139
+ }
140
+
141
+ , hideModal: function () {
142
+ var that = this
143
+ this.$element.hide()
144
+ this.backdrop(function () {
145
+ that.removeBackdrop()
146
+ that.$element.trigger('hidden')
147
+ })
148
+ }
149
+
150
+ , removeBackdrop: function () {
151
+ this.$backdrop && this.$backdrop.remove()
152
+ this.$backdrop = null
153
+ }
154
+
155
+ , backdrop: function (callback) {
156
+ var that = this
157
+ , animate = this.$element.hasClass('fade') ? 'fade' : ''
158
+
159
+ if (this.isShown && this.options.backdrop) {
160
+ var doAnimate = $.support.transition && animate
161
+
162
+ this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
163
+ .appendTo(document.body)
164
+
165
+ this.$backdrop.click(
166
+ this.options.backdrop == 'static' ?
167
+ $.proxy(this.$element[0].focus, this.$element[0])
168
+ : $.proxy(this.hide, this)
169
+ )
170
+
171
+ if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
172
+
173
+ this.$backdrop.addClass('in')
174
+
175
+ if (!callback) return
176
+
177
+ doAnimate ?
178
+ this.$backdrop.one($.support.transition.end, callback) :
179
+ callback()
180
+
181
+ } else if (!this.isShown && this.$backdrop) {
182
+ this.$backdrop.removeClass('in')
183
+
184
+ $.support.transition && this.$element.hasClass('fade')?
185
+ this.$backdrop.one($.support.transition.end, callback) :
186
+ callback()
187
+
188
+ } else if (callback) {
189
+ callback()
190
+ }
191
+ }
192
+ }
193
+
194
+
195
+ /* MODAL PLUGIN DEFINITION
196
+ * ======================= */
197
+
198
+ var old = $.fn.modal
199
+
200
+ $.fn.modal = function (option) {
201
+ return this.each(function () {
202
+ var $this = $(this)
203
+ , data = $this.data('modal')
204
+ , options = $.extend({}, $.fn.modal.defaults, $this.data(), typeof option == 'object' && option)
205
+ if (!data) $this.data('modal', (data = new Modal(this, options)))
206
+ if (typeof option == 'string') data[option]()
207
+ else if (options.show) data.show()
208
+ })
209
+ }
210
+
211
+ $.fn.modal.defaults = {
212
+ backdrop: true
213
+ , keyboard: true
214
+ , show: true
215
+ }
216
+
217
+ $.fn.modal.Constructor = Modal
218
+
219
+
220
+ /* MODAL NO CONFLICT
221
+ * ================= */
222
+
223
+ $.fn.modal.noConflict = function () {
224
+ $.fn.modal = old
225
+ return this
226
+ }
227
+
228
+
229
+ /* MODAL DATA-API
230
+ * ============== */
231
+
232
+ $(document).on('click.modal.data-api', '[data-toggle="modal"]', function (e) {
233
+ var $this = $(this)
234
+ , href = $this.attr('href')
235
+ , $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
236
+ , option = $target.data('modal') ? 'toggle' : $.extend({ remote:!/#/.test(href) && href }, $target.data(), $this.data())
237
+
238
+ e.preventDefault()
239
+
240
+ $target
241
+ .modal(option)
242
+ .one('hide', function () {
243
+ $this.focus()
244
+ })
245
+ })
246
+
247
+ }(window.jQuery);
@@ -0,0 +1,114 @@
1
+ /* ===========================================================
2
+ * bootstrap-popover.js v2.3.2
3
+ * http://twitter.github.com/bootstrap/javascript.html#popovers
4
+ * ===========================================================
5
+ * Copyright 2012 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
+ /* POPOVER PUBLIC CLASS DEFINITION
27
+ * =============================== */
28
+
29
+ var Popover = function (element, options) {
30
+ this.init('popover', element, options)
31
+ }
32
+
33
+
34
+ /* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
35
+ ========================================== */
36
+
37
+ Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype, {
38
+
39
+ constructor: Popover
40
+
41
+ , setContent: function () {
42
+ var $tip = this.tip()
43
+ , title = this.getTitle()
44
+ , content = this.getContent()
45
+
46
+ $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
47
+ $tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
48
+
49
+ $tip.removeClass('fade top bottom left right in')
50
+ }
51
+
52
+ , hasContent: function () {
53
+ return this.getTitle() || this.getContent()
54
+ }
55
+
56
+ , getContent: function () {
57
+ var content
58
+ , $e = this.$element
59
+ , o = this.options
60
+
61
+ content = (typeof o.content == 'function' ? o.content.call($e[0]) : o.content)
62
+ || $e.attr('data-content')
63
+
64
+ return content
65
+ }
66
+
67
+ , tip: function () {
68
+ if (!this.$tip) {
69
+ this.$tip = $(this.options.template)
70
+ }
71
+ return this.$tip
72
+ }
73
+
74
+ , destroy: function () {
75
+ this.hide().$element.off('.' + this.type).removeData(this.type)
76
+ }
77
+
78
+ })
79
+
80
+
81
+ /* POPOVER PLUGIN DEFINITION
82
+ * ======================= */
83
+
84
+ var old = $.fn.popover
85
+
86
+ $.fn.popover = function (option) {
87
+ return this.each(function () {
88
+ var $this = $(this)
89
+ , data = $this.data('popover')
90
+ , options = typeof option == 'object' && option
91
+ if (!data) $this.data('popover', (data = new Popover(this, options)))
92
+ if (typeof option == 'string') data[option]()
93
+ })
94
+ }
95
+
96
+ $.fn.popover.Constructor = Popover
97
+
98
+ $.fn.popover.defaults = $.extend({} , $.fn.tooltip.defaults, {
99
+ placement: 'right'
100
+ , trigger: 'click'
101
+ , content: ''
102
+ , template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
103
+ })
104
+
105
+
106
+ /* POPOVER NO CONFLICT
107
+ * =================== */
108
+
109
+ $.fn.popover.noConflict = function () {
110
+ $.fn.popover = old
111
+ return this
112
+ }
113
+
114
+ }(window.jQuery);
@@ -0,0 +1,89 @@
1
+ (function( $ ){
2
+ $.fn.qrcode = function(options) {
3
+ // if options is string,
4
+ if( typeof options === 'string' ){
5
+ options = { text: options };
6
+ }
7
+
8
+ // set default values
9
+ // typeNumber < 1 for automatic calculation
10
+ options = $.extend( {}, {
11
+ render : "canvas",
12
+ width : 256,
13
+ height : 256,
14
+ typeNumber : -1,
15
+ correctLevel : QRErrorCorrectLevel.H,
16
+ background : "rgba(255,255,255,1)",
17
+ foreground : "rgba(236,238,241,1)"
18
+ }, options);
19
+
20
+ var createCanvas = function(){
21
+ // create the qrcode itself
22
+ var qrcode = new QRCode(options.typeNumber, options.correctLevel);
23
+ qrcode.addData(options.text);
24
+ qrcode.make();
25
+
26
+ // create canvas element
27
+ var canvas = document.createElement('canvas');
28
+ canvas.width = options.width;
29
+ canvas.height = options.height;
30
+ var ctx = canvas.getContext('2d');
31
+
32
+ // compute tileW/tileH based on options.width/options.height
33
+ var tileW = options.width / qrcode.getModuleCount();
34
+ var tileH = options.height / qrcode.getModuleCount();
35
+
36
+ // draw in the canvas
37
+ for( var row = 0; row < qrcode.getModuleCount(); row++ ){
38
+ for( var col = 0; col < qrcode.getModuleCount(); col++ ){
39
+ ctx.fillStyle = qrcode.isDark(row, col) ? options.foreground : options.background;
40
+ var w = (Math.ceil((col+1)*tileW) - Math.floor(col*tileW));
41
+ var h = (Math.ceil((row+1)*tileW) - Math.floor(row*tileW));
42
+ ctx.fillRect(Math.round(col*tileW),Math.round(row*tileH), w, h);
43
+ }
44
+ }
45
+ // return just built canvas
46
+ return canvas;
47
+ }
48
+
49
+ // from Jon-Carlos Rivera (https://github.com/imbcmdth)
50
+ var createTable = function(){
51
+ // create the qrcode itself
52
+ var qrcode = new QRCode(options.typeNumber, options.correctLevel);
53
+ qrcode.addData(options.text);
54
+ qrcode.make();
55
+
56
+ // create table element
57
+ var $table = $('<table></table>')
58
+ .css("width", options.width+"px")
59
+ .css("height", options.height+"px")
60
+ .css("border", "0px")
61
+ .css("border-collapse", "collapse")
62
+ .css('background-color', options.background);
63
+
64
+ // compute tileS percentage
65
+ var tileW = options.width / qrcode.getModuleCount();
66
+ var tileH = options.height / qrcode.getModuleCount();
67
+
68
+ // draw in the table
69
+ for(var row = 0; row < qrcode.getModuleCount(); row++ ){
70
+ var $row = $('<tr></tr>').css('height', tileH+"px").appendTo($table);
71
+
72
+ for(var col = 0; col < qrcode.getModuleCount(); col++ ){
73
+ $('<td></td>')
74
+ .css('width', tileW+"px")
75
+ .css('background-color', qrcode.isDark(row, col) ? options.foreground : options.background)
76
+ .appendTo($row);
77
+ }
78
+ }
79
+ // return just built canvas
80
+ return $table;
81
+ }
82
+
83
+
84
+ return this.each(function(){
85
+ var element = options.render == "canvas" ? createCanvas() : createTable();
86
+ $(element).appendTo(this);
87
+ });
88
+ };
89
+ })( jQuery );