quantum 0.0.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +17 -0
- data/.project +13 -0
- data/Gemfile +4 -0
- data/LICENSE.txt +22 -0
- data/README.md +82 -0
- data/Rakefile +1 -0
- data/lib/quantum.rb +8 -0
- data/lib/quantum/version.rb +3 -0
- data/quantum.gemspec +23 -0
- data/vendor/assets/.keep +0 -0
- data/vendor/assets/javascripts/alert.js +99 -0
- data/vendor/assets/javascripts/chart.js +1424 -0
- data/vendor/assets/javascripts/collapse.js +167 -0
- data/vendor/assets/javascripts/date_picker.js +474 -0
- data/vendor/assets/javascripts/dropdown.js +169 -0
- data/vendor/assets/javascripts/file_input.js +100 -0
- data/vendor/assets/javascripts/input_mask.js +355 -0
- data/vendor/assets/javascripts/map.js +1982 -0
- data/vendor/assets/javascripts/modal.js +247 -0
- data/vendor/assets/javascripts/popover.js +114 -0
- data/vendor/assets/javascripts/qrcode.js +89 -0
- data/vendor/assets/javascripts/qrcoder.js +1237 -0
- data/vendor/assets/javascripts/tab.js +144 -0
- data/vendor/assets/javascripts/time_picker.js +888 -0
- data/vendor/assets/javascripts/tooltip.js +361 -0
- data/vendor/assets/javascripts/transitions.js +60 -0
- data/vendor/assets/javascripts/typeahead.js +335 -0
- data/vendor/assets/javascripts/wizard.js +114 -0
- data/vendor/assets/stylesheets/alert.css.scss +42 -0
- data/vendor/assets/stylesheets/breadcrumb.css.scss +24 -0
- data/vendor/assets/stylesheets/button.css.scss +252 -0
- data/vendor/assets/stylesheets/chart.css.scss +10 -0
- data/vendor/assets/stylesheets/code.css.scss +47 -0
- data/vendor/assets/stylesheets/collapse.css.scss +16 -0
- data/vendor/assets/stylesheets/datepicker.css.scss +111 -0
- data/vendor/assets/stylesheets/dropdown.css.scss +98 -0
- data/vendor/assets/stylesheets/file_input.css.scss +7 -0
- data/vendor/assets/stylesheets/footer.css.scss +99 -0
- data/vendor/assets/stylesheets/form.css.scss +190 -0
- data/vendor/assets/stylesheets/grid.css.scss +334 -0
- data/vendor/assets/stylesheets/header.css.scss +162 -0
- data/vendor/assets/stylesheets/icon.css.scss +533 -0
- data/vendor/assets/stylesheets/image.css.scss +48 -0
- data/vendor/assets/stylesheets/label_and_badge.css.scss +60 -0
- data/vendor/assets/stylesheets/link.css.scss +22 -0
- data/vendor/assets/stylesheets/map.css.scss +13 -0
- data/vendor/assets/stylesheets/modal.css.scss +100 -0
- data/vendor/assets/stylesheets/pagination.css.scss +65 -0
- data/vendor/assets/stylesheets/popover.css.scss +110 -0
- data/vendor/assets/stylesheets/progress.css.scss +81 -0
- data/vendor/assets/stylesheets/qrcode.css.scss +7 -0
- data/vendor/assets/stylesheets/reset.css.scss +75 -0
- data/vendor/assets/stylesheets/tab.css.scss +202 -0
- data/vendor/assets/stylesheets/table.css.scss +71 -0
- data/vendor/assets/stylesheets/timepicker.css.scss +74 -0
- data/vendor/assets/stylesheets/tooltip.css.scss +83 -0
- data/vendor/assets/stylesheets/transitions.css.scss +14 -0
- data/vendor/assets/stylesheets/trunk.css.scss +80 -0
- data/vendor/assets/stylesheets/typeahead.css.scss +7 -0
- data/vendor/assets/stylesheets/typography.css.scss +130 -0
- data/vendor/assets/stylesheets/wizard.css.scss +27 -0
- 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 );
|