collapse.js 11 KB
Newer Older
Mark Otto's avatar
grunt    
Mark Otto committed
1
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
fat's avatar
fat committed
2

Mark Otto's avatar
grunt    
Mark Otto committed
3
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
fat's avatar
fat committed
4

Mark Otto's avatar
grunt    
Mark Otto committed
5
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
fat's avatar
fat committed
6
7
8

/**
 * --------------------------------------------------------------------------
Mark Otto's avatar
Mark Otto committed
9
 * Bootstrap (v4.0.0-beta): collapse.js
fat's avatar
fat committed
10
11
12
13
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 * --------------------------------------------------------------------------
 */

Mark Otto's avatar
grunt    
Mark Otto committed
14
var Collapse = function ($) {
fat's avatar
fat committed
15
16
17
18
19
20
21
22

  /**
   * ------------------------------------------------------------------------
   * Constants
   * ------------------------------------------------------------------------
   */

  var NAME = 'collapse';
Mark Otto's avatar
Mark Otto committed
23
  var VERSION = '4.0.0-beta';
fat's avatar
fat committed
24
  var DATA_KEY = 'bs.collapse';
fat's avatar
fat committed
25
26
  var EVENT_KEY = '.' + DATA_KEY;
  var DATA_API_KEY = '.data-api';
fat's avatar
fat committed
27
28
29
  var JQUERY_NO_CONFLICT = $.fn[NAME];
  var TRANSITION_DURATION = 600;

30
  var Default = {
fat's avatar
fat committed
31
    toggle: true,
32
    parent: ''
fat's avatar
fat committed
33
34
  };

fat's avatar
fat committed
35
36
  var DefaultType = {
    toggle: 'boolean',
37
    parent: 'string'
fat's avatar
fat committed
38
39
  };

fat's avatar
fat committed
40
  var Event = {
fat's avatar
fat committed
41
42
43
44
    SHOW: 'show' + EVENT_KEY,
    SHOWN: 'shown' + EVENT_KEY,
    HIDE: 'hide' + EVENT_KEY,
    HIDDEN: 'hidden' + EVENT_KEY,
Jacob Thornton's avatar
Jacob Thornton committed
45
    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
fat's avatar
fat committed
46
47
48
  };

  var ClassName = {
Mark Otto's avatar
grunt    
Mark Otto committed
49
    SHOW: 'show',
fat's avatar
fat committed
50
51
52
53
54
55
56
57
58
59
60
    COLLAPSE: 'collapse',
    COLLAPSING: 'collapsing',
    COLLAPSED: 'collapsed'
  };

  var Dimension = {
    WIDTH: 'width',
    HEIGHT: 'height'
  };

  var Selector = {
Johann-S's avatar
build    
Johann-S committed
61
62
    ACTIVES: '.show, .collapsing',
    DATA_TOGGLE: '[data-toggle="collapse"]'
Mark Otto's avatar
dist    
Mark Otto committed
63
  };
fat's avatar
fat committed
64

Mark Otto's avatar
dist    
Mark Otto committed
65
66
67
68
69
  /**
   * ------------------------------------------------------------------------
   * Class Definition
   * ------------------------------------------------------------------------
   */
fat's avatar
fat committed
70

Mark Otto's avatar
grunt    
Mark Otto committed
71
  var Collapse = function () {
fat's avatar
fat committed
72
73
74
75
76
    function Collapse(element, config) {
      _classCallCheck(this, Collapse);

      this._isTransitioning = false;
      this._element = element;
fat's avatar
fat committed
77
      this._config = this._getConfig(config);
fat's avatar
fat committed
78
      this._triggerArray = $.makeArray($('[data-toggle="collapse"][href="#' + element.id + '"],' + ('[data-toggle="collapse"][data-target="#' + element.id + '"]')));
Mark Otto's avatar
build    
Mark Otto committed
79
80
81
82
83
84
85
86
      var tabToggles = $(Selector.DATA_TOGGLE);
      for (var i = 0; i < tabToggles.length; i++) {
        var elem = tabToggles[i];
        var selector = Util.getSelectorFromElement(elem);
        if (selector !== null && $(selector).filter(element).length > 0) {
          this._triggerArray.push(elem);
        }
      }
Johann-S's avatar
build    
Johann-S committed
87

fat's avatar
fat committed
88
89
90
91
92
93
94
95
96
97
98
      this._parent = this._config.parent ? this._getParent() : null;

      if (!this._config.parent) {
        this._addAriaAndCollapsedClass(this._element, this._triggerArray);
      }

      if (this._config.toggle) {
        this.toggle();
      }
    }

Jacob Thornton's avatar
Jacob Thornton committed
99
100
    // getters

Mark Otto's avatar
grunt    
Mark Otto committed
101
102
103
    // public

    Collapse.prototype.toggle = function toggle() {
Mark Otto's avatar
grunt    
Mark Otto committed
104
      if ($(this._element).hasClass(ClassName.SHOW)) {
Mark Otto's avatar
grunt    
Mark Otto committed
105
106
107
108
109
        this.hide();
      } else {
        this.show();
      }
    };
fat's avatar
fat committed
110

Mark Otto's avatar
grunt    
Mark Otto committed
111
112
113
    Collapse.prototype.show = function show() {
      var _this = this;

Mark Otto's avatar
grunt    
Mark Otto committed
114
      if (this._isTransitioning || $(this._element).hasClass(ClassName.SHOW)) {
Mark Otto's avatar
grunt    
Mark Otto committed
115
116
        return;
      }
fat's avatar
fat committed
117

Mark Otto's avatar
grunt    
Mark Otto committed
118
119
120
121
      var actives = void 0;
      var activesData = void 0;

      if (this._parent) {
Johann-S's avatar
build    
Johann-S committed
122
        actives = $.makeArray($(this._parent).children().children(Selector.ACTIVES));
Mark Otto's avatar
grunt    
Mark Otto committed
123
124
        if (!actives.length) {
          actives = null;
fat's avatar
fat committed
125
126
127
        }
      }

Mark Otto's avatar
grunt    
Mark Otto committed
128
129
130
      if (actives) {
        activesData = $(actives).data(DATA_KEY);
        if (activesData && activesData._isTransitioning) {
fat's avatar
fat committed
131
132
          return;
        }
Mark Otto's avatar
grunt    
Mark Otto committed
133
      }
fat's avatar
fat committed
134

Mark Otto's avatar
grunt    
Mark Otto committed
135
136
137
138
139
      var startEvent = $.Event(Event.SHOW);
      $(this._element).trigger(startEvent);
      if (startEvent.isDefaultPrevented()) {
        return;
      }
fat's avatar
fat committed
140

Mark Otto's avatar
grunt    
Mark Otto committed
141
142
143
144
      if (actives) {
        Collapse._jQueryInterface.call($(actives), 'hide');
        if (!activesData) {
          $(actives).data(DATA_KEY, null);
fat's avatar
fat committed
145
        }
Mark Otto's avatar
grunt    
Mark Otto committed
146
      }
fat's avatar
fat committed
147

Mark Otto's avatar
grunt    
Mark Otto committed
148
      var dimension = this._getDimension();
fat's avatar
fat committed
149

Mark Otto's avatar
grunt    
Mark Otto committed
150
      $(this._element).removeClass(ClassName.COLLAPSE).addClass(ClassName.COLLAPSING);
fat's avatar
fat committed
151

Mark Otto's avatar
grunt    
Mark Otto committed
152
      this._element.style[dimension] = 0;
fat's avatar
fat committed
153

Mark Otto's avatar
grunt    
Mark Otto committed
154
155
156
      if (this._triggerArray.length) {
        $(this._triggerArray).removeClass(ClassName.COLLAPSED).attr('aria-expanded', true);
      }
fat's avatar
fat committed
157

Mark Otto's avatar
grunt    
Mark Otto committed
158
      this.setTransitioning(true);
fat's avatar
fat committed
159

Mark Otto's avatar
grunt    
Mark Otto committed
160
      var complete = function complete() {
Mark Otto's avatar
grunt    
Mark Otto committed
161
        $(_this._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).addClass(ClassName.SHOW);
fat's avatar
fat committed
162

Mark Otto's avatar
grunt    
Mark Otto committed
163
        _this._element.style[dimension] = '';
fat's avatar
fat committed
164

Mark Otto's avatar
grunt    
Mark Otto committed
165
        _this.setTransitioning(false);
fat's avatar
fat committed
166

Mark Otto's avatar
grunt    
Mark Otto committed
167
168
        $(_this._element).trigger(Event.SHOWN);
      };
fat's avatar
fat committed
169

Mark Otto's avatar
grunt    
Mark Otto committed
170
171
172
173
      if (!Util.supportsTransitionEnd()) {
        complete();
        return;
      }
fat's avatar
fat committed
174

Mark Otto's avatar
grunt    
Mark Otto committed
175
176
      var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1);
      var scrollSize = 'scroll' + capitalizedDimension;
fat's avatar
fat committed
177

Mark Otto's avatar
grunt    
Mark Otto committed
178
      $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
fat's avatar
fat committed
179

Mark Otto's avatar
grunt    
Mark Otto committed
180
181
      this._element.style[dimension] = this._element[scrollSize] + 'px';
    };
fat's avatar
fat committed
182

Mark Otto's avatar
grunt    
Mark Otto committed
183
184
    Collapse.prototype.hide = function hide() {
      var _this2 = this;
fat's avatar
fat committed
185

Mark Otto's avatar
grunt    
Mark Otto committed
186
      if (this._isTransitioning || !$(this._element).hasClass(ClassName.SHOW)) {
Mark Otto's avatar
grunt    
Mark Otto committed
187
188
        return;
      }
fat's avatar
fat committed
189

Mark Otto's avatar
grunt    
Mark Otto committed
190
191
192
193
      var startEvent = $.Event(Event.HIDE);
      $(this._element).trigger(startEvent);
      if (startEvent.isDefaultPrevented()) {
        return;
fat's avatar
fat committed
194
195
      }

Mark Otto's avatar
grunt    
Mark Otto committed
196
      var dimension = this._getDimension();
fat's avatar
fat committed
197

Mark Otto's avatar
grunt    
Mark Otto committed
198
      this._element.style[dimension] = this._element.getBoundingClientRect()[dimension] + 'px';
fat's avatar
fat committed
199

Mark Otto's avatar
grunt    
Mark Otto committed
200
      Util.reflow(this._element);
fat's avatar
fat committed
201

Mark Otto's avatar
grunt    
Mark Otto committed
202
      $(this._element).addClass(ClassName.COLLAPSING).removeClass(ClassName.COLLAPSE).removeClass(ClassName.SHOW);
fat's avatar
fat committed
203

Mark Otto's avatar
grunt    
Mark Otto committed
204
      if (this._triggerArray.length) {
Mark Otto's avatar
build    
Mark Otto committed
205
206
207
208
209
210
211
212
213
214
        for (var i = 0; i < this._triggerArray.length; i++) {
          var trigger = this._triggerArray[i];
          var selector = Util.getSelectorFromElement(trigger);
          if (selector !== null) {
            var $elem = $(selector);
            if (!$elem.hasClass(ClassName.SHOW)) {
              $(trigger).addClass(ClassName.COLLAPSED).attr('aria-expanded', false);
            }
          }
        }
Mark Otto's avatar
grunt    
Mark Otto committed
215
      }
fat's avatar
fat committed
216

Mark Otto's avatar
grunt    
Mark Otto committed
217
      this.setTransitioning(true);
fat's avatar
fat committed
218

Mark Otto's avatar
grunt    
Mark Otto committed
219
220
221
222
      var complete = function complete() {
        _this2.setTransitioning(false);
        $(_this2._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).trigger(Event.HIDDEN);
      };
fat's avatar
fat committed
223

Mark Otto's avatar
grunt    
Mark Otto committed
224
      this._element.style[dimension] = '';
fat's avatar
fat committed
225

Mark Otto's avatar
grunt    
Mark Otto committed
226
227
228
229
      if (!Util.supportsTransitionEnd()) {
        complete();
        return;
      }
fat's avatar
fat committed
230

Mark Otto's avatar
grunt    
Mark Otto committed
231
232
      $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
    };
fat's avatar
fat committed
233

Mark Otto's avatar
grunt    
Mark Otto committed
234
235
236
    Collapse.prototype.setTransitioning = function setTransitioning(isTransitioning) {
      this._isTransitioning = isTransitioning;
    };
fat's avatar
fat committed
237

Mark Otto's avatar
grunt    
Mark Otto committed
238
239
    Collapse.prototype.dispose = function dispose() {
      $.removeData(this._element, DATA_KEY);
fat's avatar
fat committed
240

Mark Otto's avatar
grunt    
Mark Otto committed
241
242
243
244
245
246
      this._config = null;
      this._parent = null;
      this._element = null;
      this._triggerArray = null;
      this._isTransitioning = null;
    };
fat's avatar
fat committed
247

Mark Otto's avatar
grunt    
Mark Otto committed
248
    // private
fat's avatar
fat committed
249

Mark Otto's avatar
grunt    
Mark Otto committed
250
251
    Collapse.prototype._getConfig = function _getConfig(config) {
      config = $.extend({}, Default, config);
Mark Otto's avatar
Mark Otto committed
252
253
      config.toggle = Boolean(config.toggle); // coerce string values
      Util.typeCheckConfig(NAME, config, DefaultType);
Mark Otto's avatar
grunt    
Mark Otto committed
254
255
      return config;
    };
fat's avatar
fat committed
256

Mark Otto's avatar
grunt    
Mark Otto committed
257
258
259
260
    Collapse.prototype._getDimension = function _getDimension() {
      var hasWidth = $(this._element).hasClass(Dimension.WIDTH);
      return hasWidth ? Dimension.WIDTH : Dimension.HEIGHT;
    };
fat's avatar
fat committed
261

Mark Otto's avatar
grunt    
Mark Otto committed
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
    Collapse.prototype._getParent = function _getParent() {
      var _this3 = this;

      var parent = $(this._config.parent)[0];
      var selector = '[data-toggle="collapse"][data-parent="' + this._config.parent + '"]';

      $(parent).find(selector).each(function (i, element) {
        _this3._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]);
      });

      return parent;
    };

    Collapse.prototype._addAriaAndCollapsedClass = function _addAriaAndCollapsedClass(element, triggerArray) {
      if (element) {
Mark Otto's avatar
grunt    
Mark Otto committed
277
        var isOpen = $(element).hasClass(ClassName.SHOW);
Mark Otto's avatar
grunt    
Mark Otto committed
278
279
280

        if (triggerArray.length) {
          $(triggerArray).toggleClass(ClassName.COLLAPSED, !isOpen).attr('aria-expanded', isOpen);
fat's avatar
fat committed
281
282
        }
      }
Mark Otto's avatar
grunt    
Mark Otto committed
283
    };
fat's avatar
fat committed
284

Mark Otto's avatar
grunt    
Mark Otto committed
285
    // static
fat's avatar
fat committed
286

Mark Otto's avatar
grunt    
Mark Otto committed
287
288
289
290
    Collapse._getTargetFromElement = function _getTargetFromElement(element) {
      var selector = Util.getSelectorFromElement(element);
      return selector ? $(selector)[0] : null;
    };
fat's avatar
fat committed
291

Mark Otto's avatar
grunt    
Mark Otto committed
292
293
294
295
296
    Collapse._jQueryInterface = function _jQueryInterface(config) {
      return this.each(function () {
        var $this = $(this);
        var data = $this.data(DATA_KEY);
        var _config = $.extend({}, Default, $this.data(), (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config);
fat's avatar
fat committed
297

Mark Otto's avatar
grunt    
Mark Otto committed
298
299
300
301
302
303
304
305
306
307
308
309
        if (!data && _config.toggle && /show|hide/.test(config)) {
          _config.toggle = false;
        }

        if (!data) {
          data = new Collapse(this, _config);
          $this.data(DATA_KEY, data);
        }

        if (typeof config === 'string') {
          if (data[config] === undefined) {
            throw new Error('No method named "' + config + '"');
fat's avatar
fat committed
310
          }
Mark Otto's avatar
grunt    
Mark Otto committed
311
312
313
314
315
316
          data[config]();
        }
      });
    };

    _createClass(Collapse, null, [{
Jacob Thornton's avatar
Jacob Thornton committed
317
318
319
320
321
322
323
324
325
      key: 'VERSION',
      get: function get() {
        return VERSION;
      }
    }, {
      key: 'Default',
      get: function get() {
        return Default;
      }
fat's avatar
fat committed
326
327
328
    }]);

    return Collapse;
Mark Otto's avatar
grunt    
Mark Otto committed
329
330
331
332
333
334
335
  }();

  /**
   * ------------------------------------------------------------------------
   * Data Api implementation
   * ------------------------------------------------------------------------
   */
fat's avatar
fat committed
336

fat's avatar
fat committed
337
  $(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {
Mark Otto's avatar
grunt    
Mark Otto committed
338
    if (!/input|textarea/i.test(event.target.tagName)) {
Mark Otto's avatar
grunt    
Mark Otto committed
339
340
      event.preventDefault();
    }
fat's avatar
fat committed
341

Mark Otto's avatar
build    
Mark Otto committed
342
343
344
345
346
347
348
349
    var $trigger = $(this);
    var selector = Util.getSelectorFromElement(this);
    $(selector).each(function () {
      var $target = $(this);
      var data = $target.data(DATA_KEY);
      var config = data ? 'toggle' : $trigger.data();
      Collapse._jQueryInterface.call($target, config);
    });
Mark Otto's avatar
Mark Otto committed
350
  });
fat's avatar
fat committed
351
352
353
354
355
356
357

  /**
   * ------------------------------------------------------------------------
   * jQuery
   * ------------------------------------------------------------------------
   */

Mark Otto's avatar
Mark Otto committed
358
  $.fn[NAME] = Collapse._jQueryInterface;
fat's avatar
fat committed
359
360
361
362
363
364
365
  $.fn[NAME].Constructor = Collapse;
  $.fn[NAME].noConflict = function () {
    $.fn[NAME] = JQUERY_NO_CONFLICT;
    return Collapse._jQueryInterface;
  };

  return Collapse;
Mark Otto's avatar
grunt    
Mark Otto committed
366
}(jQuery);
Mark Otto's avatar
build    
Mark Otto committed
367
//# sourceMappingURL=collapse.js.map