Skip to content

Commit

Permalink
Add update method for Collapse plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
Johann-S committed Jun 6, 2017
1 parent f1b3f2b commit 598db14
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 15 deletions.
4 changes: 4 additions & 0 deletions docs/4.0/components/collapse.md
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,10 @@ Shows a collapsible element. **Returns to the caller before the collapsible elem

Hides a collapsible element. **Returns to the caller before the collapsible element has actually been hidden** (i.e. before the `hidden.bs.collapse` event occurs).

#### `.collapse('update')`

Update a collapsible element if this element changed during his lifetime

### Events

Bootstrap's collapse class exposes a few events for hooking into collapse functionality.
Expand Down
46 changes: 33 additions & 13 deletions js/src/collapse.js
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,8 @@ const Collapse = (($) => {
`[data-toggle="collapse"][data-target="#${element.id}"]`
))

this._parent = this._config.parent ? this._getParent() : null
this._parent = this._config.parent ? this._getParent() : null
this._showClass = this._getShowClass()

if (!this._config.parent) {
this._addAriaAndCollapsedClass(this._element, this._triggerArray)
Expand All @@ -105,17 +106,16 @@ const Collapse = (($) => {
// public

toggle() {
if ($(this._element).hasClass(ClassName.SHOW) || $(this._element).hasClass(ClassName.FLEXSHOW)) {
if ($(this._element).hasClass(this._showClass)) {
this.hide()
} else {
this.show()
}
}

show() {
const showClass = this._getShowClass()
if (this._isTransitioning ||
$(this._element).hasClass(showClass)) {
$(this._element).hasClass(this._showClass)) {
return
}

Expand Down Expand Up @@ -169,7 +169,7 @@ const Collapse = (($) => {
$(this._element)
.removeClass(ClassName.COLLAPSING)
.addClass(ClassName.COLLAPSE)
.addClass(showClass)
.addClass(this._showClass)

this._element.style[dimension] = ''

Expand All @@ -194,9 +194,8 @@ const Collapse = (($) => {
}

hide() {
const showClass = this._getShowClass()
if (this._isTransitioning ||
!$(this._element).hasClass(showClass)) {
!$(this._element).hasClass(this._showClass)) {
return
}

Expand All @@ -206,16 +205,15 @@ const Collapse = (($) => {
return
}

const dimension = this._getDimension()

const dimension = this._getDimension()
this._element.style[dimension] = `${this._element.getBoundingClientRect()[dimension]}px`

Util.reflow(this._element)

$(this._element)
.addClass(ClassName.COLLAPSING)
.removeClass(ClassName.COLLAPSE)
.removeClass(showClass)
.removeClass(this._showClass)

if (this._triggerArray.length) {
$(this._triggerArray)
Expand Down Expand Up @@ -249,6 +247,16 @@ const Collapse = (($) => {
this._isTransitioning = isTransitioning
}

update() {
if ($(this._element).hasClass(this._showClass)) {
$(this._element).removeClass(this._showClass)
this._showClass = this._getShowClass()
$(this._element).addClass(this._showClass)
} else {
this._showClass = this._getShowClass()
}
}

dispose() {
$.removeData(this._element, DATA_KEY)

Expand Down Expand Up @@ -303,15 +311,27 @@ const Collapse = (($) => {

_getShowClass() {
const tabClass = this._element.classList
let useFlex = $(this._element).css('display') === 'flex'

// Detect flex for inline style
let useFlex = $(this._element).css('display').indexOf('flex') !== -1

// Create a wrapper to hide our flex detection
const $tmpWrapper = $('<div class="d-none"></div>')
$tmpWrapper.insertAfter($(this._element))
const $tmpElem = $('<div></div>')
$tmpWrapper.append($tmpElem)

// Detect flex in used classes
for (let i = 0; i < tabClass.length; i++) {
const tmpDisplay = $('<div></div>').addClass(tabClass[i]).css('display')
if (tmpDisplay === 'flex') {
$tmpElem.addClass(tabClass[i])
const tmpDisplay = $tmpElem.css('display')
$tmpElem.removeClass(tabClass[i])
if (tmpDisplay.indexOf('flex') !== -1) {
useFlex = true
break
}
}
$tmpWrapper.remove()
return !useFlex ? ClassName.SHOW : ClassName.FLEXSHOW
}

Expand Down
6 changes: 4 additions & 2 deletions scss/_transitions.scss
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,15 @@
}

tr {
&.collapse.show {
&.collapse.show,
&.collapse.flexshow {
display: table-row;
}
}

tbody {
&.collapse.show {
&.collapse.show,
&.collapse.flexshow {
display: table-row-group;
}
}
Expand Down

0 comments on commit 598db14

Please sign in to comment.