flexa_lib 0.1.3 → 0.1.5
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.
- data/lib/flexa_lib/version.rb +1 -1
- data/vendor/assets/images/glyphicons-halflings-white.png +0 -0
- data/vendor/assets/images/glyphicons-halflings.png +0 -0
- data/vendor/assets/javascripts/bootstrap-alert.js +94 -0
- data/vendor/assets/javascripts/bootstrap-button.js +98 -0
- data/vendor/assets/javascripts/bootstrap-carousel.js +157 -0
- data/vendor/assets/javascripts/bootstrap-collapse.js +136 -0
- data/vendor/assets/javascripts/bootstrap-dropdown.js +92 -0
- data/vendor/assets/javascripts/bootstrap-modal.js +210 -0
- data/vendor/assets/javascripts/bootstrap-popover.js +95 -0
- data/vendor/assets/javascripts/bootstrap-scrollspy.js +125 -0
- data/vendor/assets/javascripts/bootstrap-tab.js +130 -0
- data/vendor/assets/javascripts/bootstrap-tooltip.js +270 -0
- data/vendor/assets/javascripts/bootstrap-transition.js +51 -0
- data/vendor/assets/javascripts/bootstrap-typeahead.js +271 -0
- data/vendor/assets/javascripts/bootstrap.js +12 -0
- data/vendor/assets/javascripts/flexa-themejs.js +94 -0
- data/vendor/assets/javascripts/jquery.cookie.js +96 -0
- data/vendor/assets/javascripts/jquery.pjax.js +460 -0
- data/vendor/assets/javascripts/populate.js +272 -0
- data/vendor/assets/stylesheets/_bootstrap-responsive.scss +318 -0
- data/vendor/assets/stylesheets/_bootstrap.scss +63 -0
- data/vendor/assets/stylesheets/bootstrap/_accordion.scss +28 -0
- data/vendor/assets/stylesheets/bootstrap/_alerts.scss +62 -0
- data/vendor/assets/stylesheets/bootstrap/_breadcrumbs.scss +22 -0
- data/vendor/assets/stylesheets/bootstrap/_button-groups.scss +136 -0
- data/vendor/assets/stylesheets/bootstrap/_buttons.scss +163 -0
- data/vendor/assets/stylesheets/bootstrap/_carousel.scss +116 -0
- data/vendor/assets/stylesheets/bootstrap/_close.scss +18 -0
- data/vendor/assets/stylesheets/bootstrap/_code.scss +56 -0
- data/vendor/assets/stylesheets/bootstrap/_component-animations.scss +18 -0
- data/vendor/assets/stylesheets/bootstrap/_dropdowns.scss +126 -0
- data/vendor/assets/stylesheets/bootstrap/_forms.scss +463 -0
- data/vendor/assets/stylesheets/bootstrap/_grid.scss +8 -0
- data/vendor/assets/stylesheets/bootstrap/_hero-unit.scss +20 -0
- data/vendor/assets/stylesheets/bootstrap/_labels.scss +32 -0
- data/vendor/assets/stylesheets/bootstrap/_layouts.scss +17 -0
- data/vendor/assets/stylesheets/bootstrap/_mixins.scss +530 -0
- data/vendor/assets/stylesheets/bootstrap/_modals.scss +83 -0
- data/vendor/assets/stylesheets/bootstrap/_navbar.scss +288 -0
- data/vendor/assets/stylesheets/bootstrap/_navs.scss +329 -0
- data/vendor/assets/stylesheets/bootstrap/_pager.scss +30 -0
- data/vendor/assets/stylesheets/bootstrap/_pagination.scss +53 -0
- data/vendor/assets/stylesheets/bootstrap/_popovers.scss +49 -0
- data/vendor/assets/stylesheets/bootstrap/_progress-bars.scss +95 -0
- data/vendor/assets/stylesheets/bootstrap/_reset.scss +105 -0
- data/vendor/assets/stylesheets/bootstrap/_scaffolding.scss +29 -0
- data/vendor/assets/stylesheets/bootstrap/_sprites.scss +157 -0
- data/vendor/assets/stylesheets/bootstrap/_tables.scss +126 -0
- data/vendor/assets/stylesheets/bootstrap/_thumbnails.scss +35 -0
- data/vendor/assets/stylesheets/bootstrap/_tooltip.scss +35 -0
- data/vendor/assets/stylesheets/bootstrap/_type.scss +209 -0
- data/vendor/assets/stylesheets/bootstrap/_utilities.scss +23 -0
- data/vendor/assets/stylesheets/bootstrap/_variables.scss +103 -0
- data/vendor/assets/stylesheets/bootstrap/_wells.scss +17 -0
- data/vendor/assets/stylesheets/docs.css.scss +790 -0
- data/vendor/assets/stylesheets/flexa-theme.css.scss +32 -0
- data/vendor/assets/stylesheets/override.css.scss +77 -0
- metadata +60 -3
@@ -0,0 +1,270 @@
|
|
1
|
+
/* ===========================================================
|
2
|
+
* bootstrap-tooltip.js v2.0.1
|
3
|
+
* http://twitter.github.com/bootstrap/javascript.html#tooltips
|
4
|
+
* Inspired by the original jQuery.tipsy by Jason Frame
|
5
|
+
* ===========================================================
|
6
|
+
* Copyright 2012 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
|
+
!function( $ ) {
|
22
|
+
|
23
|
+
"use strict"
|
24
|
+
|
25
|
+
/* TOOLTIP PUBLIC CLASS DEFINITION
|
26
|
+
* =============================== */
|
27
|
+
|
28
|
+
var Tooltip = function ( element, options ) {
|
29
|
+
this.init('tooltip', element, options)
|
30
|
+
}
|
31
|
+
|
32
|
+
Tooltip.prototype = {
|
33
|
+
|
34
|
+
constructor: Tooltip
|
35
|
+
|
36
|
+
, init: function ( type, element, options ) {
|
37
|
+
var eventIn
|
38
|
+
, eventOut
|
39
|
+
|
40
|
+
this.type = type
|
41
|
+
this.$element = $(element)
|
42
|
+
this.options = this.getOptions(options)
|
43
|
+
this.enabled = true
|
44
|
+
|
45
|
+
if (this.options.trigger != 'manual') {
|
46
|
+
eventIn = this.options.trigger == 'hover' ? 'mouseenter' : 'focus'
|
47
|
+
eventOut = this.options.trigger == 'hover' ? 'mouseleave' : 'blur'
|
48
|
+
this.$element.on(eventIn, this.options.selector, $.proxy(this.enter, this))
|
49
|
+
this.$element.on(eventOut, this.options.selector, $.proxy(this.leave, this))
|
50
|
+
}
|
51
|
+
|
52
|
+
this.options.selector ?
|
53
|
+
(this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
|
54
|
+
this.fixTitle()
|
55
|
+
}
|
56
|
+
|
57
|
+
, getOptions: function ( options ) {
|
58
|
+
options = $.extend({}, $.fn[this.type].defaults, options, this.$element.data())
|
59
|
+
|
60
|
+
if (options.delay && typeof options.delay == 'number') {
|
61
|
+
options.delay = {
|
62
|
+
show: options.delay
|
63
|
+
, hide: options.delay
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
return options
|
68
|
+
}
|
69
|
+
|
70
|
+
, enter: function ( e ) {
|
71
|
+
var self = $(e.currentTarget)[this.type](this._options).data(this.type)
|
72
|
+
|
73
|
+
if (!self.options.delay || !self.options.delay.show) {
|
74
|
+
self.show()
|
75
|
+
} else {
|
76
|
+
self.hoverState = 'in'
|
77
|
+
setTimeout(function() {
|
78
|
+
if (self.hoverState == 'in') {
|
79
|
+
self.show()
|
80
|
+
}
|
81
|
+
}, self.options.delay.show)
|
82
|
+
}
|
83
|
+
}
|
84
|
+
|
85
|
+
, leave: function ( e ) {
|
86
|
+
var self = $(e.currentTarget)[this.type](this._options).data(this.type)
|
87
|
+
|
88
|
+
if (!self.options.delay || !self.options.delay.hide) {
|
89
|
+
self.hide()
|
90
|
+
} else {
|
91
|
+
self.hoverState = 'out'
|
92
|
+
setTimeout(function() {
|
93
|
+
if (self.hoverState == 'out') {
|
94
|
+
self.hide()
|
95
|
+
}
|
96
|
+
}, self.options.delay.hide)
|
97
|
+
}
|
98
|
+
}
|
99
|
+
|
100
|
+
, show: function () {
|
101
|
+
var $tip
|
102
|
+
, inside
|
103
|
+
, pos
|
104
|
+
, actualWidth
|
105
|
+
, actualHeight
|
106
|
+
, placement
|
107
|
+
, tp
|
108
|
+
|
109
|
+
if (this.hasContent() && this.enabled) {
|
110
|
+
$tip = this.tip()
|
111
|
+
this.setContent()
|
112
|
+
|
113
|
+
if (this.options.animation) {
|
114
|
+
$tip.addClass('fade')
|
115
|
+
}
|
116
|
+
|
117
|
+
placement = typeof this.options.placement == 'function' ?
|
118
|
+
this.options.placement.call(this, $tip[0], this.$element[0]) :
|
119
|
+
this.options.placement
|
120
|
+
|
121
|
+
inside = /in/.test(placement)
|
122
|
+
|
123
|
+
$tip
|
124
|
+
.remove()
|
125
|
+
.css({ top: 0, left: 0, display: 'block' })
|
126
|
+
.appendTo(inside ? this.$element : document.body)
|
127
|
+
|
128
|
+
pos = this.getPosition(inside)
|
129
|
+
|
130
|
+
actualWidth = $tip[0].offsetWidth
|
131
|
+
actualHeight = $tip[0].offsetHeight
|
132
|
+
|
133
|
+
switch (inside ? placement.split(' ')[1] : placement) {
|
134
|
+
case 'bottom':
|
135
|
+
tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}
|
136
|
+
break
|
137
|
+
case 'top':
|
138
|
+
tp = {top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2}
|
139
|
+
break
|
140
|
+
case 'left':
|
141
|
+
tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth}
|
142
|
+
break
|
143
|
+
case 'right':
|
144
|
+
tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width}
|
145
|
+
break
|
146
|
+
}
|
147
|
+
|
148
|
+
$tip
|
149
|
+
.css(tp)
|
150
|
+
.addClass(placement)
|
151
|
+
.addClass('in')
|
152
|
+
}
|
153
|
+
}
|
154
|
+
|
155
|
+
, setContent: function () {
|
156
|
+
var $tip = this.tip()
|
157
|
+
$tip.find('.tooltip-inner').html(this.getTitle())
|
158
|
+
$tip.removeClass('fade in top bottom left right')
|
159
|
+
}
|
160
|
+
|
161
|
+
, hide: function () {
|
162
|
+
var that = this
|
163
|
+
, $tip = this.tip()
|
164
|
+
|
165
|
+
$tip.removeClass('in')
|
166
|
+
|
167
|
+
function removeWithAnimation() {
|
168
|
+
var timeout = setTimeout(function () {
|
169
|
+
$tip.off($.support.transition.end).remove()
|
170
|
+
}, 500)
|
171
|
+
|
172
|
+
$tip.one($.support.transition.end, function () {
|
173
|
+
clearTimeout(timeout)
|
174
|
+
$tip.remove()
|
175
|
+
})
|
176
|
+
}
|
177
|
+
|
178
|
+
$.support.transition && this.$tip.hasClass('fade') ?
|
179
|
+
removeWithAnimation() :
|
180
|
+
$tip.remove()
|
181
|
+
}
|
182
|
+
|
183
|
+
, fixTitle: function () {
|
184
|
+
var $e = this.$element
|
185
|
+
if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
|
186
|
+
$e.attr('data-original-title', $e.attr('title') || '').removeAttr('title')
|
187
|
+
}
|
188
|
+
}
|
189
|
+
|
190
|
+
, hasContent: function () {
|
191
|
+
return this.getTitle()
|
192
|
+
}
|
193
|
+
|
194
|
+
, getPosition: function (inside) {
|
195
|
+
return $.extend({}, (inside ? {top: 0, left: 0} : this.$element.offset()), {
|
196
|
+
width: this.$element[0].offsetWidth
|
197
|
+
, height: this.$element[0].offsetHeight
|
198
|
+
})
|
199
|
+
}
|
200
|
+
|
201
|
+
, getTitle: function () {
|
202
|
+
var title
|
203
|
+
, $e = this.$element
|
204
|
+
, o = this.options
|
205
|
+
|
206
|
+
title = $e.attr('data-original-title')
|
207
|
+
|| (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
|
208
|
+
|
209
|
+
title = title.toString().replace(/(^\s*|\s*$)/, "")
|
210
|
+
|
211
|
+
return title
|
212
|
+
}
|
213
|
+
|
214
|
+
, tip: function () {
|
215
|
+
return this.$tip = this.$tip || $(this.options.template)
|
216
|
+
}
|
217
|
+
|
218
|
+
, validate: function () {
|
219
|
+
if (!this.$element[0].parentNode) {
|
220
|
+
this.hide()
|
221
|
+
this.$element = null
|
222
|
+
this.options = null
|
223
|
+
}
|
224
|
+
}
|
225
|
+
|
226
|
+
, enable: function () {
|
227
|
+
this.enabled = true
|
228
|
+
}
|
229
|
+
|
230
|
+
, disable: function () {
|
231
|
+
this.enabled = false
|
232
|
+
}
|
233
|
+
|
234
|
+
, toggleEnabled: function () {
|
235
|
+
this.enabled = !this.enabled
|
236
|
+
}
|
237
|
+
|
238
|
+
, toggle: function () {
|
239
|
+
this[this.tip().hasClass('in') ? 'hide' : 'show']()
|
240
|
+
}
|
241
|
+
|
242
|
+
}
|
243
|
+
|
244
|
+
|
245
|
+
/* TOOLTIP PLUGIN DEFINITION
|
246
|
+
* ========================= */
|
247
|
+
|
248
|
+
$.fn.tooltip = function ( option ) {
|
249
|
+
return this.each(function () {
|
250
|
+
var $this = $(this)
|
251
|
+
, data = $this.data('tooltip')
|
252
|
+
, options = typeof option == 'object' && option
|
253
|
+
if (!data) $this.data('tooltip', (data = new Tooltip(this, options)))
|
254
|
+
if (typeof option == 'string') data[option]()
|
255
|
+
})
|
256
|
+
}
|
257
|
+
|
258
|
+
$.fn.tooltip.Constructor = Tooltip
|
259
|
+
|
260
|
+
$.fn.tooltip.defaults = {
|
261
|
+
animation: true
|
262
|
+
, delay: 0
|
263
|
+
, selector: false
|
264
|
+
, placement: 'top'
|
265
|
+
, trigger: 'hover'
|
266
|
+
, title: ''
|
267
|
+
, template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
|
268
|
+
}
|
269
|
+
|
270
|
+
}( window.jQuery );
|
@@ -0,0 +1,51 @@
|
|
1
|
+
/* ===================================================
|
2
|
+
* bootstrap-transition.js v2.0.1
|
3
|
+
* http://twitter.github.com/bootstrap/javascript.html#transitions
|
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
|
+
!function( $ ) {
|
21
|
+
|
22
|
+
$(function () {
|
23
|
+
|
24
|
+
"use strict"
|
25
|
+
|
26
|
+
/* CSS TRANSITION SUPPORT (https://gist.github.com/373874)
|
27
|
+
* ======================================================= */
|
28
|
+
|
29
|
+
$.support.transition = (function () {
|
30
|
+
var thisBody = document.body || document.documentElement
|
31
|
+
, thisStyle = thisBody.style
|
32
|
+
, support = thisStyle.transition !== undefined || thisStyle.WebkitTransition !== undefined || thisStyle.MozTransition !== undefined || thisStyle.MsTransition !== undefined || thisStyle.OTransition !== undefined
|
33
|
+
|
34
|
+
return support && {
|
35
|
+
end: (function () {
|
36
|
+
var transitionEnd = "TransitionEnd"
|
37
|
+
if ( $.browser.webkit ) {
|
38
|
+
transitionEnd = "webkitTransitionEnd"
|
39
|
+
} else if ( $.browser.mozilla ) {
|
40
|
+
transitionEnd = "transitionend"
|
41
|
+
} else if ( $.browser.opera ) {
|
42
|
+
transitionEnd = "oTransitionEnd"
|
43
|
+
}
|
44
|
+
return transitionEnd
|
45
|
+
}())
|
46
|
+
}
|
47
|
+
})()
|
48
|
+
|
49
|
+
})
|
50
|
+
|
51
|
+
}( window.jQuery );
|
@@ -0,0 +1,271 @@
|
|
1
|
+
/* =============================================================
|
2
|
+
* bootstrap-typeahead.js v2.0.1
|
3
|
+
* http://twitter.github.com/bootstrap/javascript.html#typeahead
|
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
|
+
!function( $ ){
|
21
|
+
|
22
|
+
"use strict"
|
23
|
+
|
24
|
+
var Typeahead = function ( element, options ) {
|
25
|
+
this.$element = $(element)
|
26
|
+
this.options = $.extend({}, $.fn.typeahead.defaults, options)
|
27
|
+
this.matcher = this.options.matcher || this.matcher
|
28
|
+
this.sorter = this.options.sorter || this.sorter
|
29
|
+
this.highlighter = this.options.highlighter || this.highlighter
|
30
|
+
this.$menu = $(this.options.menu).appendTo('body')
|
31
|
+
this.source = this.options.source
|
32
|
+
this.shown = false
|
33
|
+
this.listen()
|
34
|
+
}
|
35
|
+
|
36
|
+
Typeahead.prototype = {
|
37
|
+
|
38
|
+
constructor: Typeahead
|
39
|
+
|
40
|
+
, select: function () {
|
41
|
+
var val = this.$menu.find('.active').attr('data-value')
|
42
|
+
this.$element.val(val)
|
43
|
+
return this.hide()
|
44
|
+
}
|
45
|
+
|
46
|
+
, show: function () {
|
47
|
+
var pos = $.extend({}, this.$element.offset(), {
|
48
|
+
height: this.$element[0].offsetHeight
|
49
|
+
})
|
50
|
+
|
51
|
+
this.$menu.css({
|
52
|
+
top: pos.top + pos.height
|
53
|
+
, left: pos.left
|
54
|
+
})
|
55
|
+
|
56
|
+
this.$menu.show()
|
57
|
+
this.shown = true
|
58
|
+
return this
|
59
|
+
}
|
60
|
+
|
61
|
+
, hide: function () {
|
62
|
+
this.$menu.hide()
|
63
|
+
this.shown = false
|
64
|
+
return this
|
65
|
+
}
|
66
|
+
|
67
|
+
, lookup: function (event) {
|
68
|
+
var that = this
|
69
|
+
, items
|
70
|
+
, q
|
71
|
+
|
72
|
+
this.query = this.$element.val()
|
73
|
+
|
74
|
+
if (!this.query) {
|
75
|
+
return this.shown ? this.hide() : this
|
76
|
+
}
|
77
|
+
|
78
|
+
items = $.grep(this.source, function (item) {
|
79
|
+
if (that.matcher(item)) return item
|
80
|
+
})
|
81
|
+
|
82
|
+
items = this.sorter(items)
|
83
|
+
|
84
|
+
if (!items.length) {
|
85
|
+
return this.shown ? this.hide() : this
|
86
|
+
}
|
87
|
+
|
88
|
+
return this.render(items.slice(0, this.options.items)).show()
|
89
|
+
}
|
90
|
+
|
91
|
+
, matcher: function (item) {
|
92
|
+
return ~item.toLowerCase().indexOf(this.query.toLowerCase())
|
93
|
+
}
|
94
|
+
|
95
|
+
, sorter: function (items) {
|
96
|
+
var beginswith = []
|
97
|
+
, caseSensitive = []
|
98
|
+
, caseInsensitive = []
|
99
|
+
, item
|
100
|
+
|
101
|
+
while (item = items.shift()) {
|
102
|
+
if (!item.toLowerCase().indexOf(this.query.toLowerCase())) beginswith.push(item)
|
103
|
+
else if (~item.indexOf(this.query)) caseSensitive.push(item)
|
104
|
+
else caseInsensitive.push(item)
|
105
|
+
}
|
106
|
+
|
107
|
+
return beginswith.concat(caseSensitive, caseInsensitive)
|
108
|
+
}
|
109
|
+
|
110
|
+
, highlighter: function (item) {
|
111
|
+
return item.replace(new RegExp('(' + this.query + ')', 'ig'), function ($1, match) {
|
112
|
+
return '<strong>' + match + '</strong>'
|
113
|
+
})
|
114
|
+
}
|
115
|
+
|
116
|
+
, render: function (items) {
|
117
|
+
var that = this
|
118
|
+
|
119
|
+
items = $(items).map(function (i, item) {
|
120
|
+
i = $(that.options.item).attr('data-value', item)
|
121
|
+
i.find('a').html(that.highlighter(item))
|
122
|
+
return i[0]
|
123
|
+
})
|
124
|
+
|
125
|
+
items.first().addClass('active')
|
126
|
+
this.$menu.html(items)
|
127
|
+
return this
|
128
|
+
}
|
129
|
+
|
130
|
+
, next: function (event) {
|
131
|
+
var active = this.$menu.find('.active').removeClass('active')
|
132
|
+
, next = active.next()
|
133
|
+
|
134
|
+
if (!next.length) {
|
135
|
+
next = $(this.$menu.find('li')[0])
|
136
|
+
}
|
137
|
+
|
138
|
+
next.addClass('active')
|
139
|
+
}
|
140
|
+
|
141
|
+
, prev: function (event) {
|
142
|
+
var active = this.$menu.find('.active').removeClass('active')
|
143
|
+
, prev = active.prev()
|
144
|
+
|
145
|
+
if (!prev.length) {
|
146
|
+
prev = this.$menu.find('li').last()
|
147
|
+
}
|
148
|
+
|
149
|
+
prev.addClass('active')
|
150
|
+
}
|
151
|
+
|
152
|
+
, listen: function () {
|
153
|
+
this.$element
|
154
|
+
.on('blur', $.proxy(this.blur, this))
|
155
|
+
.on('keypress', $.proxy(this.keypress, this))
|
156
|
+
.on('keyup', $.proxy(this.keyup, this))
|
157
|
+
|
158
|
+
if ($.browser.webkit || $.browser.msie) {
|
159
|
+
this.$element.on('keydown', $.proxy(this.keypress, this))
|
160
|
+
}
|
161
|
+
|
162
|
+
this.$menu
|
163
|
+
.on('click', $.proxy(this.click, this))
|
164
|
+
.on('mouseenter', 'li', $.proxy(this.mouseenter, this))
|
165
|
+
}
|
166
|
+
|
167
|
+
, keyup: function (e) {
|
168
|
+
e.stopPropagation()
|
169
|
+
e.preventDefault()
|
170
|
+
|
171
|
+
switch(e.keyCode) {
|
172
|
+
case 40: // down arrow
|
173
|
+
case 38: // up arrow
|
174
|
+
break
|
175
|
+
|
176
|
+
case 9: // tab
|
177
|
+
case 13: // enter
|
178
|
+
if (!this.shown) return
|
179
|
+
this.select()
|
180
|
+
break
|
181
|
+
|
182
|
+
case 27: // escape
|
183
|
+
this.hide()
|
184
|
+
break
|
185
|
+
|
186
|
+
default:
|
187
|
+
this.lookup()
|
188
|
+
}
|
189
|
+
|
190
|
+
}
|
191
|
+
|
192
|
+
, keypress: function (e) {
|
193
|
+
e.stopPropagation()
|
194
|
+
if (!this.shown) return
|
195
|
+
|
196
|
+
switch(e.keyCode) {
|
197
|
+
case 9: // tab
|
198
|
+
case 13: // enter
|
199
|
+
case 27: // escape
|
200
|
+
e.preventDefault()
|
201
|
+
break
|
202
|
+
|
203
|
+
case 38: // up arrow
|
204
|
+
e.preventDefault()
|
205
|
+
this.prev()
|
206
|
+
break
|
207
|
+
|
208
|
+
case 40: // down arrow
|
209
|
+
e.preventDefault()
|
210
|
+
this.next()
|
211
|
+
break
|
212
|
+
}
|
213
|
+
}
|
214
|
+
|
215
|
+
, blur: function (e) {
|
216
|
+
var that = this
|
217
|
+
e.stopPropagation()
|
218
|
+
e.preventDefault()
|
219
|
+
setTimeout(function () { that.hide() }, 150)
|
220
|
+
}
|
221
|
+
|
222
|
+
, click: function (e) {
|
223
|
+
e.stopPropagation()
|
224
|
+
e.preventDefault()
|
225
|
+
this.select()
|
226
|
+
}
|
227
|
+
|
228
|
+
, mouseenter: function (e) {
|
229
|
+
this.$menu.find('.active').removeClass('active')
|
230
|
+
$(e.currentTarget).addClass('active')
|
231
|
+
}
|
232
|
+
|
233
|
+
}
|
234
|
+
|
235
|
+
|
236
|
+
/* TYPEAHEAD PLUGIN DEFINITION
|
237
|
+
* =========================== */
|
238
|
+
|
239
|
+
$.fn.typeahead = function ( option ) {
|
240
|
+
return this.each(function () {
|
241
|
+
var $this = $(this)
|
242
|
+
, data = $this.data('typeahead')
|
243
|
+
, options = typeof option == 'object' && option
|
244
|
+
if (!data) $this.data('typeahead', (data = new Typeahead(this, options)))
|
245
|
+
if (typeof option == 'string') data[option]()
|
246
|
+
})
|
247
|
+
}
|
248
|
+
|
249
|
+
$.fn.typeahead.defaults = {
|
250
|
+
source: []
|
251
|
+
, items: 8
|
252
|
+
, menu: '<ul class="typeahead dropdown-menu"></ul>'
|
253
|
+
, item: '<li><a href="#"></a></li>'
|
254
|
+
}
|
255
|
+
|
256
|
+
$.fn.typeahead.Constructor = Typeahead
|
257
|
+
|
258
|
+
|
259
|
+
/* TYPEAHEAD DATA-API
|
260
|
+
* ================== */
|
261
|
+
|
262
|
+
$(function () {
|
263
|
+
$('body').on('focus.typeahead.data-api', '[data-provide="typeahead"]', function (e) {
|
264
|
+
var $this = $(this)
|
265
|
+
if ($this.data('typeahead')) return
|
266
|
+
e.preventDefault()
|
267
|
+
$this.typeahead($this.data())
|
268
|
+
})
|
269
|
+
})
|
270
|
+
|
271
|
+
}( window.jQuery );
|
@@ -0,0 +1,12 @@
|
|
1
|
+
//= require bootstrap-transition
|
2
|
+
//= require bootstrap-alert
|
3
|
+
//= require bootstrap-button
|
4
|
+
//= require bootstrap-carousel
|
5
|
+
//= require bootstrap-collapse
|
6
|
+
//= require bootstrap-dropdown
|
7
|
+
//= require bootstrap-modal
|
8
|
+
//= require bootstrap-scrollspy
|
9
|
+
//= require bootstrap-tab
|
10
|
+
//= require bootstrap-tooltip
|
11
|
+
//= require bootstrap-popover
|
12
|
+
//= require bootstrap-typeahead
|
@@ -0,0 +1,94 @@
|
|
1
|
+
// This is a manifest file that'll be compiled into including all the files listed below.
|
2
|
+
// Add new JavaScript/Coffee code in separate files in this directory and they'll automatically
|
3
|
+
// be included in the compiled file accessible from http://example.com/assets/application.js
|
4
|
+
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
5
|
+
// the compiled file.
|
6
|
+
//
|
7
|
+
// = require jquery
|
8
|
+
// = require jquery_ujs
|
9
|
+
//= require bootstrap
|
10
|
+
//= require populate
|
11
|
+
//= require 'jquery.pjax'
|
12
|
+
//= require 'jquery.cookie'
|
13
|
+
|
14
|
+
$(document).ready(function(){
|
15
|
+
|
16
|
+
$("#short").live('click', function(event){
|
17
|
+
window.parent.frames["frameworkarea"].setAttribute('cols',0+',*');
|
18
|
+
$(this).html("<icon class='icon-fast-forward icon-white'>");
|
19
|
+
$(this).attr("id","long");
|
20
|
+
});
|
21
|
+
$("#long").live('click', function(event){
|
22
|
+
window.parent.frames["frameworkarea"].setAttribute('cols',200+',*');
|
23
|
+
$(this).html("<icon class='icon-fast-backward icon-white'>");
|
24
|
+
$(this).attr("id","short");
|
25
|
+
});
|
26
|
+
|
27
|
+
//window.parent.frames[0].setAttribute('rows',80+',*,10');
|
28
|
+
//alert($(window.parent.frames[1].frames[0]).setAttribute('rows',80+',*'));
|
29
|
+
//alert(window.parent.$("frameset").child);
|
30
|
+
$('a').pjax('#caixa');
|
31
|
+
|
32
|
+
|
33
|
+
//.live('click', function(event){
|
34
|
+
|
35
|
+
//var urltmp = $(this).attr('href')+'?search='+$("#search").val();
|
36
|
+
//alert(urltmp);
|
37
|
+
//$(this).attr('href',urltmp);
|
38
|
+
|
39
|
+
//event.returnValue=false;
|
40
|
+
//return false;
|
41
|
+
//$(this).pjax({
|
42
|
+
// url: urltmp,
|
43
|
+
// container: '#caixa'}).click();
|
44
|
+
//});
|
45
|
+
|
46
|
+
|
47
|
+
//$('.modal').on('show', function () {
|
48
|
+
//$(this).find('#caixa').load('/perfis/search');
|
49
|
+
// do something…
|
50
|
+
//});
|
51
|
+
//$('#caixa').scrollspy();
|
52
|
+
|
53
|
+
$('input.ui-datepicker').datepicker();
|
54
|
+
$('.datePicker').datepicker();
|
55
|
+
|
56
|
+
if ($("input:text:visible:first").get(0).tagName) {
|
57
|
+
$("input:text:visible:first").focus();
|
58
|
+
} else {
|
59
|
+
$(document).focus();
|
60
|
+
alert('a');
|
61
|
+
}
|
62
|
+
var pressedCtrl = false;
|
63
|
+
$(document).keyup(function (e) {
|
64
|
+
if(e.which == 17)
|
65
|
+
pressedCtrl=false;
|
66
|
+
})
|
67
|
+
|
68
|
+
$(document).keydown(function (e) {
|
69
|
+
if(e.which == 17)
|
70
|
+
pressedCtrl = true;
|
71
|
+
//alert(e.which);
|
72
|
+
if(e.which == 73 && pressedCtrl == true) {
|
73
|
+
//Aqui vai o código e chamadas de funções para o ctrl+s
|
74
|
+
window.location = $("#add").attr("href");
|
75
|
+
}
|
76
|
+
if(e.which == 113) {
|
77
|
+
//Aqui vai o código e chamadas de funções para o ctrl+s
|
78
|
+
window.location = $("#add").attr("href");
|
79
|
+
}
|
80
|
+
if(e.which == 115) {
|
81
|
+
//Aqui vai o código e chamadas de funções para o ctrl+s
|
82
|
+
window.location = $("#cancel").attr("href");
|
83
|
+
}
|
84
|
+
if(e.which == 117) {
|
85
|
+
//Aqui vai o código e chamadas de funções para o ctrl+s
|
86
|
+
$("#submit").closest('form').submit()
|
87
|
+
}
|
88
|
+
if(e.which == 118) {
|
89
|
+
//Aqui vai o código e chamadas de funções para o ctrl+s
|
90
|
+
$("#search").closest('form').submit()
|
91
|
+
}
|
92
|
+
});
|
93
|
+
});
|
94
|
+
|