aboutsummaryrefslogtreecommitdiff
path: root/js/collapse.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/collapse.js')
-rw-r--r--js/collapse.js26
1 files changed, 17 insertions, 9 deletions
diff --git a/js/collapse.js b/js/collapse.js
index f8b65b393..6b18e2577 100644
--- a/js/collapse.js
+++ b/js/collapse.js
@@ -44,6 +44,10 @@
Collapse.prototype.show = function () {
if (this.transitioning || this.$element.hasClass('in')) return
+ var startEvent = $.Event('show.bs.collapse')
+ this.$element.trigger(startEvent)
+ if (startEvent.isDefaultPrevented()) return
+
var dimension = this.dimension()
var scroll = $.camelCase(['scroll', dimension].join('-'))
var actives = this.$parent && this.$parent.find('> .accordion-group > .in')
@@ -56,16 +60,21 @@
}
this.$element[dimension](0)
- this.transition('addClass', $.Event('show.bs.collapse'), 'shown.bs.collapse')
+ this.transition('addClass', 'shown.bs.collapse')
if ($.support.transition) this.$element[dimension](this.$element[0][scroll])
}
Collapse.prototype.hide = function () {
if (this.transitioning || !this.$element.hasClass('in')) return
+
+ var startEvent = $.Event('hide.bs.collapse')
+ this.$element.trigger(startEvent)
+ if (startEvent.isDefaultPrevented()) return
+
var dimension = this.dimension()
this.reset(this.$element[dimension]())
- this.transition('removeClass', $.Event('hide.bs.collapse'), 'hidden')
+ this.transition('removeClass', 'shown.bs.hidden')
this.$element[dimension](0)
}
@@ -77,23 +86,19 @@
[dimension](size || 'auto')
[0].offsetWidth
- this.$element[size !== null ? 'addClass' : 'removeClass']('collapse')
+ this.$element[size != null ? 'addClass' : 'removeClass']('collapse')
return this
}
- Collapse.prototype.transition = function (method, startEvent, completeEvent) {
+ Collapse.prototype.transition = function (method, completeEvent) {
var that = this
var complete = function () {
- if (startEvent.type == 'show') that.reset()
+ if (completeEvent == 'shown.bs.collapse') that.reset()
that.transitioning = 0
that.$element.trigger(completeEvent)
}
- this.$element.trigger(startEvent)
-
- if (startEvent.isDefaultPrevented()) return
-
this.transitioning = 1
this.$element[method]('in')
@@ -145,7 +150,10 @@
|| e.preventDefault()
|| (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
var option = $(target).data('collapse') ? 'toggle' : $this.data()
+ var parent = $this.attr('data-parent')
+ var $parent = parent && $(parent)
+ if ($parent) $parent.find('[data-toggle=collapse][data-parent=' + parent + ']').not($this).addClass('collapsed')
$this[$(target).hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
$(target).collapse(option)
})