honoka-rails 3.3.6 → 3.3.6.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (103) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/assets/fonts/bootstrap/glyphicons-halflings-regular.eot +0 -0
  4. data/assets/fonts/bootstrap/glyphicons-halflings-regular.svg +288 -0
  5. data/assets/fonts/bootstrap/glyphicons-halflings-regular.ttf +0 -0
  6. data/assets/fonts/bootstrap/glyphicons-halflings-regular.woff +0 -0
  7. data/assets/fonts/bootstrap/glyphicons-halflings-regular.woff2 +0 -0
  8. data/assets/javascripts/bootstrap-sprockets.js +12 -0
  9. data/assets/javascripts/bootstrap.js +2363 -0
  10. data/assets/javascripts/bootstrap.min.js +7 -0
  11. data/assets/javascripts/bootstrap/affix.js +162 -0
  12. data/assets/javascripts/bootstrap/alert.js +94 -0
  13. data/assets/javascripts/bootstrap/button.js +120 -0
  14. data/assets/javascripts/bootstrap/carousel.js +237 -0
  15. data/assets/javascripts/bootstrap/collapse.js +211 -0
  16. data/assets/javascripts/bootstrap/dropdown.js +165 -0
  17. data/assets/javascripts/bootstrap/modal.js +337 -0
  18. data/assets/javascripts/bootstrap/popover.js +108 -0
  19. data/assets/javascripts/bootstrap/scrollspy.js +172 -0
  20. data/assets/javascripts/bootstrap/tab.js +155 -0
  21. data/assets/javascripts/bootstrap/tooltip.js +514 -0
  22. data/assets/javascripts/bootstrap/transition.js +59 -0
  23. data/assets/stylesheets/_bootstrap-compass.scss +9 -0
  24. data/assets/stylesheets/_bootstrap-mincer.scss +19 -0
  25. data/assets/stylesheets/_bootstrap-sprockets.scss +9 -0
  26. data/assets/stylesheets/_bootstrap.scss +56 -0
  27. data/assets/stylesheets/_honoka.scss +3 -0
  28. data/assets/stylesheets/bootstrap/_alerts.scss +73 -0
  29. data/assets/stylesheets/bootstrap/_badges.scss +68 -0
  30. data/assets/stylesheets/bootstrap/_breadcrumbs.scss +28 -0
  31. data/assets/stylesheets/bootstrap/_button-groups.scss +244 -0
  32. data/assets/stylesheets/bootstrap/_buttons.scss +168 -0
  33. data/assets/stylesheets/bootstrap/_carousel.scss +270 -0
  34. data/assets/stylesheets/bootstrap/_close.scss +36 -0
  35. data/assets/stylesheets/bootstrap/_code.scss +69 -0
  36. data/assets/stylesheets/bootstrap/_component-animations.scss +37 -0
  37. data/assets/stylesheets/bootstrap/_dropdowns.scss +216 -0
  38. data/assets/stylesheets/bootstrap/_forms.scss +617 -0
  39. data/assets/stylesheets/bootstrap/_glyphicons.scss +307 -0
  40. data/assets/stylesheets/bootstrap/_grid.scss +84 -0
  41. data/assets/stylesheets/bootstrap/_input-groups.scss +171 -0
  42. data/assets/stylesheets/bootstrap/_jumbotron.scss +54 -0
  43. data/assets/stylesheets/bootstrap/_labels.scss +66 -0
  44. data/assets/stylesheets/bootstrap/_list-group.scss +130 -0
  45. data/assets/stylesheets/bootstrap/_media.scss +66 -0
  46. data/assets/stylesheets/bootstrap/_mixins.scss +40 -0
  47. data/assets/stylesheets/bootstrap/_modals.scss +150 -0
  48. data/assets/stylesheets/bootstrap/_navbar.scss +662 -0
  49. data/assets/stylesheets/bootstrap/_navs.scss +242 -0
  50. data/assets/stylesheets/bootstrap/_normalize.scss +424 -0
  51. data/assets/stylesheets/bootstrap/_pager.scss +54 -0
  52. data/assets/stylesheets/bootstrap/_pagination.scss +89 -0
  53. data/assets/stylesheets/bootstrap/_panels.scss +271 -0
  54. data/assets/stylesheets/bootstrap/_popovers.scss +131 -0
  55. data/assets/stylesheets/bootstrap/_print.scss +101 -0
  56. data/assets/stylesheets/bootstrap/_progress-bars.scss +87 -0
  57. data/assets/stylesheets/bootstrap/_responsive-embed.scss +35 -0
  58. data/assets/stylesheets/bootstrap/_responsive-utilities.scss +179 -0
  59. data/assets/stylesheets/bootstrap/_scaffolding.scss +161 -0
  60. data/assets/stylesheets/bootstrap/_tables.scss +234 -0
  61. data/assets/stylesheets/bootstrap/_theme.scss +291 -0
  62. data/assets/stylesheets/bootstrap/_thumbnails.scss +38 -0
  63. data/assets/stylesheets/bootstrap/_tooltip.scss +101 -0
  64. data/assets/stylesheets/bootstrap/_type.scss +298 -0
  65. data/assets/stylesheets/bootstrap/_utilities.scss +55 -0
  66. data/assets/stylesheets/bootstrap/_variables.scss +874 -0
  67. data/assets/stylesheets/bootstrap/_wells.scss +29 -0
  68. data/assets/stylesheets/bootstrap/mixins/_alerts.scss +14 -0
  69. data/assets/stylesheets/bootstrap/mixins/_background-variant.scss +12 -0
  70. data/assets/stylesheets/bootstrap/mixins/_border-radius.scss +18 -0
  71. data/assets/stylesheets/bootstrap/mixins/_buttons.scss +65 -0
  72. data/assets/stylesheets/bootstrap/mixins/_center-block.scss +7 -0
  73. data/assets/stylesheets/bootstrap/mixins/_clearfix.scss +22 -0
  74. data/assets/stylesheets/bootstrap/mixins/_forms.scss +88 -0
  75. data/assets/stylesheets/bootstrap/mixins/_gradients.scss +58 -0
  76. data/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +81 -0
  77. data/assets/stylesheets/bootstrap/mixins/_grid.scss +122 -0
  78. data/assets/stylesheets/bootstrap/mixins/_hide-text.scss +21 -0
  79. data/assets/stylesheets/bootstrap/mixins/_image.scss +33 -0
  80. data/assets/stylesheets/bootstrap/mixins/_labels.scss +12 -0
  81. data/assets/stylesheets/bootstrap/mixins/_list-group.scss +32 -0
  82. data/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +10 -0
  83. data/assets/stylesheets/bootstrap/mixins/_nav-vertical-align.scss +9 -0
  84. data/assets/stylesheets/bootstrap/mixins/_opacity.scss +8 -0
  85. data/assets/stylesheets/bootstrap/mixins/_pagination.scss +24 -0
  86. data/assets/stylesheets/bootstrap/mixins/_panels.scss +24 -0
  87. data/assets/stylesheets/bootstrap/mixins/_progress-bar.scss +10 -0
  88. data/assets/stylesheets/bootstrap/mixins/_reset-filter.scss +8 -0
  89. data/assets/stylesheets/bootstrap/mixins/_reset-text.scss +18 -0
  90. data/assets/stylesheets/bootstrap/mixins/_resize.scss +6 -0
  91. data/assets/stylesheets/bootstrap/mixins/_responsive-visibility.scss +21 -0
  92. data/assets/stylesheets/bootstrap/mixins/_size.scss +10 -0
  93. data/assets/stylesheets/bootstrap/mixins/_tab-focus.scss +9 -0
  94. data/assets/stylesheets/bootstrap/mixins/_table-row.scss +28 -0
  95. data/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +12 -0
  96. data/assets/stylesheets/bootstrap/mixins/_text-overflow.scss +8 -0
  97. data/assets/stylesheets/bootstrap/mixins/_vendor-prefixes.scss +222 -0
  98. data/assets/stylesheets/honoka/_honoka.scss +56 -0
  99. data/assets/stylesheets/honoka/_mixins.scss +60 -0
  100. data/assets/stylesheets/honoka/_override.scss +73 -0
  101. data/assets/stylesheets/honoka/_variables.scss +876 -0
  102. data/lib/honoka_rails/version.rb +1 -1
  103. metadata +101 -2
@@ -0,0 +1,211 @@
1
+ /* ========================================================================
2
+ * Bootstrap: collapse.js v3.3.6
3
+ * http://getbootstrap.com/javascript/#collapse
4
+ * ========================================================================
5
+ * Copyright 2011-2015 Twitter, Inc.
6
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
7
+ * ======================================================================== */
8
+
9
+
10
+ +function ($) {
11
+ 'use strict';
12
+
13
+ // COLLAPSE PUBLIC CLASS DEFINITION
14
+ // ================================
15
+
16
+ var Collapse = function (element, options) {
17
+ this.$element = $(element)
18
+ this.options = $.extend({}, Collapse.DEFAULTS, options)
19
+ this.$trigger = $('[data-toggle="collapse"][href="#' + element.id + '"],' +
20
+ '[data-toggle="collapse"][data-target="#' + element.id + '"]')
21
+ this.transitioning = null
22
+
23
+ if (this.options.parent) {
24
+ this.$parent = this.getParent()
25
+ } else {
26
+ this.addAriaAndCollapsedClass(this.$element, this.$trigger)
27
+ }
28
+
29
+ if (this.options.toggle) this.toggle()
30
+ }
31
+
32
+ Collapse.VERSION = '3.3.6'
33
+
34
+ Collapse.TRANSITION_DURATION = 350
35
+
36
+ Collapse.DEFAULTS = {
37
+ toggle: true
38
+ }
39
+
40
+ Collapse.prototype.dimension = function () {
41
+ var hasWidth = this.$element.hasClass('width')
42
+ return hasWidth ? 'width' : 'height'
43
+ }
44
+
45
+ Collapse.prototype.show = function () {
46
+ if (this.transitioning || this.$element.hasClass('in')) return
47
+
48
+ var activesData
49
+ var actives = this.$parent && this.$parent.children('.panel').children('.in, .collapsing')
50
+
51
+ if (actives && actives.length) {
52
+ activesData = actives.data('bs.collapse')
53
+ if (activesData && activesData.transitioning) return
54
+ }
55
+
56
+ var startEvent = $.Event('show.bs.collapse')
57
+ this.$element.trigger(startEvent)
58
+ if (startEvent.isDefaultPrevented()) return
59
+
60
+ if (actives && actives.length) {
61
+ Plugin.call(actives, 'hide')
62
+ activesData || actives.data('bs.collapse', null)
63
+ }
64
+
65
+ var dimension = this.dimension()
66
+
67
+ this.$element
68
+ .removeClass('collapse')
69
+ .addClass('collapsing')[dimension](0)
70
+ .attr('aria-expanded', true)
71
+
72
+ this.$trigger
73
+ .removeClass('collapsed')
74
+ .attr('aria-expanded', true)
75
+
76
+ this.transitioning = 1
77
+
78
+ var complete = function () {
79
+ this.$element
80
+ .removeClass('collapsing')
81
+ .addClass('collapse in')[dimension]('')
82
+ this.transitioning = 0
83
+ this.$element
84
+ .trigger('shown.bs.collapse')
85
+ }
86
+
87
+ if (!$.support.transition) return complete.call(this)
88
+
89
+ var scrollSize = $.camelCase(['scroll', dimension].join('-'))
90
+
91
+ this.$element
92
+ .one('bsTransitionEnd', $.proxy(complete, this))
93
+ .emulateTransitionEnd(Collapse.TRANSITION_DURATION)[dimension](this.$element[0][scrollSize])
94
+ }
95
+
96
+ Collapse.prototype.hide = function () {
97
+ if (this.transitioning || !this.$element.hasClass('in')) return
98
+
99
+ var startEvent = $.Event('hide.bs.collapse')
100
+ this.$element.trigger(startEvent)
101
+ if (startEvent.isDefaultPrevented()) return
102
+
103
+ var dimension = this.dimension()
104
+
105
+ this.$element[dimension](this.$element[dimension]())[0].offsetHeight
106
+
107
+ this.$element
108
+ .addClass('collapsing')
109
+ .removeClass('collapse in')
110
+ .attr('aria-expanded', false)
111
+
112
+ this.$trigger
113
+ .addClass('collapsed')
114
+ .attr('aria-expanded', false)
115
+
116
+ this.transitioning = 1
117
+
118
+ var complete = function () {
119
+ this.transitioning = 0
120
+ this.$element
121
+ .removeClass('collapsing')
122
+ .addClass('collapse')
123
+ .trigger('hidden.bs.collapse')
124
+ }
125
+
126
+ if (!$.support.transition) return complete.call(this)
127
+
128
+ this.$element
129
+ [dimension](0)
130
+ .one('bsTransitionEnd', $.proxy(complete, this))
131
+ .emulateTransitionEnd(Collapse.TRANSITION_DURATION)
132
+ }
133
+
134
+ Collapse.prototype.toggle = function () {
135
+ this[this.$element.hasClass('in') ? 'hide' : 'show']()
136
+ }
137
+
138
+ Collapse.prototype.getParent = function () {
139
+ return $(this.options.parent)
140
+ .find('[data-toggle="collapse"][data-parent="' + this.options.parent + '"]')
141
+ .each($.proxy(function (i, element) {
142
+ var $element = $(element)
143
+ this.addAriaAndCollapsedClass(getTargetFromTrigger($element), $element)
144
+ }, this))
145
+ .end()
146
+ }
147
+
148
+ Collapse.prototype.addAriaAndCollapsedClass = function ($element, $trigger) {
149
+ var isOpen = $element.hasClass('in')
150
+
151
+ $element.attr('aria-expanded', isOpen)
152
+ $trigger
153
+ .toggleClass('collapsed', !isOpen)
154
+ .attr('aria-expanded', isOpen)
155
+ }
156
+
157
+ function getTargetFromTrigger($trigger) {
158
+ var href
159
+ var target = $trigger.attr('data-target')
160
+ || (href = $trigger.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') // strip for ie7
161
+
162
+ return $(target)
163
+ }
164
+
165
+
166
+ // COLLAPSE PLUGIN DEFINITION
167
+ // ==========================
168
+
169
+ function Plugin(option) {
170
+ return this.each(function () {
171
+ var $this = $(this)
172
+ var data = $this.data('bs.collapse')
173
+ var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
174
+
175
+ if (!data && options.toggle && /show|hide/.test(option)) options.toggle = false
176
+ if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
177
+ if (typeof option == 'string') data[option]()
178
+ })
179
+ }
180
+
181
+ var old = $.fn.collapse
182
+
183
+ $.fn.collapse = Plugin
184
+ $.fn.collapse.Constructor = Collapse
185
+
186
+
187
+ // COLLAPSE NO CONFLICT
188
+ // ====================
189
+
190
+ $.fn.collapse.noConflict = function () {
191
+ $.fn.collapse = old
192
+ return this
193
+ }
194
+
195
+
196
+ // COLLAPSE DATA-API
197
+ // =================
198
+
199
+ $(document).on('click.bs.collapse.data-api', '[data-toggle="collapse"]', function (e) {
200
+ var $this = $(this)
201
+
202
+ if (!$this.attr('data-target')) e.preventDefault()
203
+
204
+ var $target = getTargetFromTrigger($this)
205
+ var data = $target.data('bs.collapse')
206
+ var option = data ? 'toggle' : $this.data()
207
+
208
+ Plugin.call($target, option)
209
+ })
210
+
211
+ }(jQuery);
@@ -0,0 +1,165 @@
1
+ /* ========================================================================
2
+ * Bootstrap: dropdown.js v3.3.6
3
+ * http://getbootstrap.com/javascript/#dropdowns
4
+ * ========================================================================
5
+ * Copyright 2011-2015 Twitter, Inc.
6
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
7
+ * ======================================================================== */
8
+
9
+
10
+ +function ($) {
11
+ 'use strict';
12
+
13
+ // DROPDOWN CLASS DEFINITION
14
+ // =========================
15
+
16
+ var backdrop = '.dropdown-backdrop'
17
+ var toggle = '[data-toggle="dropdown"]'
18
+ var Dropdown = function (element) {
19
+ $(element).on('click.bs.dropdown', this.toggle)
20
+ }
21
+
22
+ Dropdown.VERSION = '3.3.6'
23
+
24
+ function getParent($this) {
25
+ var selector = $this.attr('data-target')
26
+
27
+ if (!selector) {
28
+ selector = $this.attr('href')
29
+ selector = selector && /#[A-Za-z]/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
30
+ }
31
+
32
+ var $parent = selector && $(selector)
33
+
34
+ return $parent && $parent.length ? $parent : $this.parent()
35
+ }
36
+
37
+ function clearMenus(e) {
38
+ if (e && e.which === 3) return
39
+ $(backdrop).remove()
40
+ $(toggle).each(function () {
41
+ var $this = $(this)
42
+ var $parent = getParent($this)
43
+ var relatedTarget = { relatedTarget: this }
44
+
45
+ if (!$parent.hasClass('open')) return
46
+
47
+ if (e && e.type == 'click' && /input|textarea/i.test(e.target.tagName) && $.contains($parent[0], e.target)) return
48
+
49
+ $parent.trigger(e = $.Event('hide.bs.dropdown', relatedTarget))
50
+
51
+ if (e.isDefaultPrevented()) return
52
+
53
+ $this.attr('aria-expanded', 'false')
54
+ $parent.removeClass('open').trigger($.Event('hidden.bs.dropdown', relatedTarget))
55
+ })
56
+ }
57
+
58
+ Dropdown.prototype.toggle = function (e) {
59
+ var $this = $(this)
60
+
61
+ if ($this.is('.disabled, :disabled')) return
62
+
63
+ var $parent = getParent($this)
64
+ var isActive = $parent.hasClass('open')
65
+
66
+ clearMenus()
67
+
68
+ if (!isActive) {
69
+ if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
70
+ // if mobile we use a backdrop because click events don't delegate
71
+ $(document.createElement('div'))
72
+ .addClass('dropdown-backdrop')
73
+ .insertAfter($(this))
74
+ .on('click', clearMenus)
75
+ }
76
+
77
+ var relatedTarget = { relatedTarget: this }
78
+ $parent.trigger(e = $.Event('show.bs.dropdown', relatedTarget))
79
+
80
+ if (e.isDefaultPrevented()) return
81
+
82
+ $this
83
+ .trigger('focus')
84
+ .attr('aria-expanded', 'true')
85
+
86
+ $parent
87
+ .toggleClass('open')
88
+ .trigger($.Event('shown.bs.dropdown', relatedTarget))
89
+ }
90
+
91
+ return false
92
+ }
93
+
94
+ Dropdown.prototype.keydown = function (e) {
95
+ if (!/(38|40|27|32)/.test(e.which) || /input|textarea/i.test(e.target.tagName)) return
96
+
97
+ var $this = $(this)
98
+
99
+ e.preventDefault()
100
+ e.stopPropagation()
101
+
102
+ if ($this.is('.disabled, :disabled')) return
103
+
104
+ var $parent = getParent($this)
105
+ var isActive = $parent.hasClass('open')
106
+
107
+ if (!isActive && e.which != 27 || isActive && e.which == 27) {
108
+ if (e.which == 27) $parent.find(toggle).trigger('focus')
109
+ return $this.trigger('click')
110
+ }
111
+
112
+ var desc = ' li:not(.disabled):visible a'
113
+ var $items = $parent.find('.dropdown-menu' + desc)
114
+
115
+ if (!$items.length) return
116
+
117
+ var index = $items.index(e.target)
118
+
119
+ if (e.which == 38 && index > 0) index-- // up
120
+ if (e.which == 40 && index < $items.length - 1) index++ // down
121
+ if (!~index) index = 0
122
+
123
+ $items.eq(index).trigger('focus')
124
+ }
125
+
126
+
127
+ // DROPDOWN PLUGIN DEFINITION
128
+ // ==========================
129
+
130
+ function Plugin(option) {
131
+ return this.each(function () {
132
+ var $this = $(this)
133
+ var data = $this.data('bs.dropdown')
134
+
135
+ if (!data) $this.data('bs.dropdown', (data = new Dropdown(this)))
136
+ if (typeof option == 'string') data[option].call($this)
137
+ })
138
+ }
139
+
140
+ var old = $.fn.dropdown
141
+
142
+ $.fn.dropdown = Plugin
143
+ $.fn.dropdown.Constructor = Dropdown
144
+
145
+
146
+ // DROPDOWN NO CONFLICT
147
+ // ====================
148
+
149
+ $.fn.dropdown.noConflict = function () {
150
+ $.fn.dropdown = old
151
+ return this
152
+ }
153
+
154
+
155
+ // APPLY TO STANDARD DROPDOWN ELEMENTS
156
+ // ===================================
157
+
158
+ $(document)
159
+ .on('click.bs.dropdown.data-api', clearMenus)
160
+ .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
161
+ .on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle)
162
+ .on('keydown.bs.dropdown.data-api', toggle, Dropdown.prototype.keydown)
163
+ .on('keydown.bs.dropdown.data-api', '.dropdown-menu', Dropdown.prototype.keydown)
164
+
165
+ }(jQuery);
@@ -0,0 +1,337 @@
1
+ /* ========================================================================
2
+ * Bootstrap: modal.js v3.3.6
3
+ * http://getbootstrap.com/javascript/#modals
4
+ * ========================================================================
5
+ * Copyright 2011-2015 Twitter, Inc.
6
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
7
+ * ======================================================================== */
8
+
9
+
10
+ +function ($) {
11
+ 'use strict';
12
+
13
+ // MODAL CLASS DEFINITION
14
+ // ======================
15
+
16
+ var Modal = function (element, options) {
17
+ this.options = options
18
+ this.$body = $(document.body)
19
+ this.$element = $(element)
20
+ this.$dialog = this.$element.find('.modal-dialog')
21
+ this.$backdrop = null
22
+ this.isShown = null
23
+ this.originalBodyPad = null
24
+ this.scrollbarWidth = 0
25
+ this.ignoreBackdropClick = false
26
+
27
+ if (this.options.remote) {
28
+ this.$element
29
+ .find('.modal-content')
30
+ .load(this.options.remote, $.proxy(function () {
31
+ this.$element.trigger('loaded.bs.modal')
32
+ }, this))
33
+ }
34
+ }
35
+
36
+ Modal.VERSION = '3.3.6'
37
+
38
+ Modal.TRANSITION_DURATION = 300
39
+ Modal.BACKDROP_TRANSITION_DURATION = 150
40
+
41
+ Modal.DEFAULTS = {
42
+ backdrop: true,
43
+ keyboard: true,
44
+ show: true
45
+ }
46
+
47
+ Modal.prototype.toggle = function (_relatedTarget) {
48
+ return this.isShown ? this.hide() : this.show(_relatedTarget)
49
+ }
50
+
51
+ Modal.prototype.show = function (_relatedTarget) {
52
+ var that = this
53
+ var e = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
54
+
55
+ this.$element.trigger(e)
56
+
57
+ if (this.isShown || e.isDefaultPrevented()) return
58
+
59
+ this.isShown = true
60
+
61
+ this.checkScrollbar()
62
+ this.setScrollbar()
63
+ this.$body.addClass('modal-open')
64
+
65
+ this.escape()
66
+ this.resize()
67
+
68
+ this.$element.on('click.dismiss.bs.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
69
+
70
+ this.$dialog.on('mousedown.dismiss.bs.modal', function () {
71
+ that.$element.one('mouseup.dismiss.bs.modal', function (e) {
72
+ if ($(e.target).is(that.$element)) that.ignoreBackdropClick = true
73
+ })
74
+ })
75
+
76
+ this.backdrop(function () {
77
+ var transition = $.support.transition && that.$element.hasClass('fade')
78
+
79
+ if (!that.$element.parent().length) {
80
+ that.$element.appendTo(that.$body) // don't move modals dom position
81
+ }
82
+
83
+ that.$element
84
+ .show()
85
+ .scrollTop(0)
86
+
87
+ that.adjustDialog()
88
+
89
+ if (transition) {
90
+ that.$element[0].offsetWidth // force reflow
91
+ }
92
+
93
+ that.$element.addClass('in')
94
+
95
+ that.enforceFocus()
96
+
97
+ var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
98
+
99
+ transition ?
100
+ that.$dialog // wait for modal to slide in
101
+ .one('bsTransitionEnd', function () {
102
+ that.$element.trigger('focus').trigger(e)
103
+ })
104
+ .emulateTransitionEnd(Modal.TRANSITION_DURATION) :
105
+ that.$element.trigger('focus').trigger(e)
106
+ })
107
+ }
108
+
109
+ Modal.prototype.hide = function (e) {
110
+ if (e) e.preventDefault()
111
+
112
+ e = $.Event('hide.bs.modal')
113
+
114
+ this.$element.trigger(e)
115
+
116
+ if (!this.isShown || e.isDefaultPrevented()) return
117
+
118
+ this.isShown = false
119
+
120
+ this.escape()
121
+ this.resize()
122
+
123
+ $(document).off('focusin.bs.modal')
124
+
125
+ this.$element
126
+ .removeClass('in')
127
+ .off('click.dismiss.bs.modal')
128
+ .off('mouseup.dismiss.bs.modal')
129
+
130
+ this.$dialog.off('mousedown.dismiss.bs.modal')
131
+
132
+ $.support.transition && this.$element.hasClass('fade') ?
133
+ this.$element
134
+ .one('bsTransitionEnd', $.proxy(this.hideModal, this))
135
+ .emulateTransitionEnd(Modal.TRANSITION_DURATION) :
136
+ this.hideModal()
137
+ }
138
+
139
+ Modal.prototype.enforceFocus = function () {
140
+ $(document)
141
+ .off('focusin.bs.modal') // guard against infinite focus loop
142
+ .on('focusin.bs.modal', $.proxy(function (e) {
143
+ if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
144
+ this.$element.trigger('focus')
145
+ }
146
+ }, this))
147
+ }
148
+
149
+ Modal.prototype.escape = function () {
150
+ if (this.isShown && this.options.keyboard) {
151
+ this.$element.on('keydown.dismiss.bs.modal', $.proxy(function (e) {
152
+ e.which == 27 && this.hide()
153
+ }, this))
154
+ } else if (!this.isShown) {
155
+ this.$element.off('keydown.dismiss.bs.modal')
156
+ }
157
+ }
158
+
159
+ Modal.prototype.resize = function () {
160
+ if (this.isShown) {
161
+ $(window).on('resize.bs.modal', $.proxy(this.handleUpdate, this))
162
+ } else {
163
+ $(window).off('resize.bs.modal')
164
+ }
165
+ }
166
+
167
+ Modal.prototype.hideModal = function () {
168
+ var that = this
169
+ this.$element.hide()
170
+ this.backdrop(function () {
171
+ that.$body.removeClass('modal-open')
172
+ that.resetAdjustments()
173
+ that.resetScrollbar()
174
+ that.$element.trigger('hidden.bs.modal')
175
+ })
176
+ }
177
+
178
+ Modal.prototype.removeBackdrop = function () {
179
+ this.$backdrop && this.$backdrop.remove()
180
+ this.$backdrop = null
181
+ }
182
+
183
+ Modal.prototype.backdrop = function (callback) {
184
+ var that = this
185
+ var animate = this.$element.hasClass('fade') ? 'fade' : ''
186
+
187
+ if (this.isShown && this.options.backdrop) {
188
+ var doAnimate = $.support.transition && animate
189
+
190
+ this.$backdrop = $(document.createElement('div'))
191
+ .addClass('modal-backdrop ' + animate)
192
+ .appendTo(this.$body)
193
+
194
+ this.$element.on('click.dismiss.bs.modal', $.proxy(function (e) {
195
+ if (this.ignoreBackdropClick) {
196
+ this.ignoreBackdropClick = false
197
+ return
198
+ }
199
+ if (e.target !== e.currentTarget) return
200
+ this.options.backdrop == 'static'
201
+ ? this.$element[0].focus()
202
+ : this.hide()
203
+ }, this))
204
+
205
+ if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
206
+
207
+ this.$backdrop.addClass('in')
208
+
209
+ if (!callback) return
210
+
211
+ doAnimate ?
212
+ this.$backdrop
213
+ .one('bsTransitionEnd', callback)
214
+ .emulateTransitionEnd(Modal.BACKDROP_TRANSITION_DURATION) :
215
+ callback()
216
+
217
+ } else if (!this.isShown && this.$backdrop) {
218
+ this.$backdrop.removeClass('in')
219
+
220
+ var callbackRemove = function () {
221
+ that.removeBackdrop()
222
+ callback && callback()
223
+ }
224
+ $.support.transition && this.$element.hasClass('fade') ?
225
+ this.$backdrop
226
+ .one('bsTransitionEnd', callbackRemove)
227
+ .emulateTransitionEnd(Modal.BACKDROP_TRANSITION_DURATION) :
228
+ callbackRemove()
229
+
230
+ } else if (callback) {
231
+ callback()
232
+ }
233
+ }
234
+
235
+ // these following methods are used to handle overflowing modals
236
+
237
+ Modal.prototype.handleUpdate = function () {
238
+ this.adjustDialog()
239
+ }
240
+
241
+ Modal.prototype.adjustDialog = function () {
242
+ var modalIsOverflowing = this.$element[0].scrollHeight > document.documentElement.clientHeight
243
+
244
+ this.$element.css({
245
+ paddingLeft: !this.bodyIsOverflowing && modalIsOverflowing ? this.scrollbarWidth : '',
246
+ paddingRight: this.bodyIsOverflowing && !modalIsOverflowing ? this.scrollbarWidth : ''
247
+ })
248
+ }
249
+
250
+ Modal.prototype.resetAdjustments = function () {
251
+ this.$element.css({
252
+ paddingLeft: '',
253
+ paddingRight: ''
254
+ })
255
+ }
256
+
257
+ Modal.prototype.checkScrollbar = function () {
258
+ var fullWindowWidth = window.innerWidth
259
+ if (!fullWindowWidth) { // workaround for missing window.innerWidth in IE8
260
+ var documentElementRect = document.documentElement.getBoundingClientRect()
261
+ fullWindowWidth = documentElementRect.right - Math.abs(documentElementRect.left)
262
+ }
263
+ this.bodyIsOverflowing = document.body.clientWidth < fullWindowWidth
264
+ this.scrollbarWidth = this.measureScrollbar()
265
+ }
266
+
267
+ Modal.prototype.setScrollbar = function () {
268
+ var bodyPad = parseInt((this.$body.css('padding-right') || 0), 10)
269
+ this.originalBodyPad = document.body.style.paddingRight || ''
270
+ if (this.bodyIsOverflowing) this.$body.css('padding-right', bodyPad + this.scrollbarWidth)
271
+ }
272
+
273
+ Modal.prototype.resetScrollbar = function () {
274
+ this.$body.css('padding-right', this.originalBodyPad)
275
+ }
276
+
277
+ Modal.prototype.measureScrollbar = function () { // thx walsh
278
+ var scrollDiv = document.createElement('div')
279
+ scrollDiv.className = 'modal-scrollbar-measure'
280
+ this.$body.append(scrollDiv)
281
+ var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth
282
+ this.$body[0].removeChild(scrollDiv)
283
+ return scrollbarWidth
284
+ }
285
+
286
+
287
+ // MODAL PLUGIN DEFINITION
288
+ // =======================
289
+
290
+ function Plugin(option, _relatedTarget) {
291
+ return this.each(function () {
292
+ var $this = $(this)
293
+ var data = $this.data('bs.modal')
294
+ var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)
295
+
296
+ if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
297
+ if (typeof option == 'string') data[option](_relatedTarget)
298
+ else if (options.show) data.show(_relatedTarget)
299
+ })
300
+ }
301
+
302
+ var old = $.fn.modal
303
+
304
+ $.fn.modal = Plugin
305
+ $.fn.modal.Constructor = Modal
306
+
307
+
308
+ // MODAL NO CONFLICT
309
+ // =================
310
+
311
+ $.fn.modal.noConflict = function () {
312
+ $.fn.modal = old
313
+ return this
314
+ }
315
+
316
+
317
+ // MODAL DATA-API
318
+ // ==============
319
+
320
+ $(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
321
+ var $this = $(this)
322
+ var href = $this.attr('href')
323
+ var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) // strip for ie7
324
+ var option = $target.data('bs.modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
325
+
326
+ if ($this.is('a')) e.preventDefault()
327
+
328
+ $target.one('show.bs.modal', function (showEvent) {
329
+ if (showEvent.isDefaultPrevented()) return // only register focus restorer if modal will actually get shown
330
+ $target.one('hidden.bs.modal', function () {
331
+ $this.is(':visible') && $this.trigger('focus')
332
+ })
333
+ })
334
+ Plugin.call($target, option, this)
335
+ })
336
+
337
+ }(jQuery);