quantum 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
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 );