Вход Регистрация
Файл: style/js/umd/collapse.js
Строк: 402
<?php
(function (global, factory) {
  if (
typeof define === 'function' && define.amd) {
    
define(['exports''module''./util'], factory);
  } else if (
typeof exports !== 'undefined' && typeof module !== 'undefined') {
    
factory(exportsmodule, require('./util'));
  } else {
    var 
mod = {
      
exports: {}
    };
    
factory(mod.exportsmod, global.Util);
    global.
collapse mod.exports;
  }
})(
this, function (exportsmodule_util) {
  
'use strict';

  var 
_createClass = (function () { function defineProperties(targetprops) { for (var 0props.lengthi++) { var descriptor props[i]; descriptor.enumerable descriptor.enumerable || falsedescriptor.configurable true; if ('value' in descriptordescriptor.writable trueObject.defineProperty(targetdescriptor.keydescriptor); } } return function (ConstructorprotoPropsstaticProps) { if (protoPropsdefineProperties(Constructor.prototypeprotoProps); if (staticPropsdefineProperties(ConstructorstaticProps); return Constructor; }; })();

  function 
_interopRequireDefault(obj) { return obj && obj.__esModule obj : { 'default'obj }; }

  function 
_classCallCheck(instanceConstructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }

  var 
_Util _interopRequireDefault(_util);

  
/**
   * --------------------------------------------------------------------------
   * Bootstrap (v4.0.0): collapse.js
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
   * --------------------------------------------------------------------------
   */

  
var Collapse = (function ($) {

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

    
var NAME 'collapse';
    var 
VERSION '4.0.0';
    var 
DATA_KEY 'bs.collapse';
    var 
EVENT_KEY '.' DATA_KEY;
    var 
DATA_API_KEY '.data-api';
    var 
JQUERY_NO_CONFLICT = $.fn[NAME];
    var 
TRANSITION_DURATION 600;

    var Default = {
      
toggletrue,
      
parent''
    
};

    var 
DefaultType = {
      
toggle'boolean',
      
parent'string'
    
};

    var 
Event = {
      
SHOW'show' EVENT_KEY,
      
SHOWN'shown' EVENT_KEY,
      
HIDE'hide' EVENT_KEY,
      
HIDDEN'hidden' EVENT_KEY,
      
CLICK_DATA_API'click' EVENT_KEY DATA_API_KEY
    
};

    var 
ClassName = {
      
IN'in',
      
COLLAPSE'collapse',
      
COLLAPSING'collapsing',
      
COLLAPSED'collapsed'
    
};

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

    var 
Selector = {
      
ACTIVES'.panel > .in, .panel > .collapsing',
      
DATA_TOGGLE'[data-toggle="collapse"]'
    
};

    
/**
     * ------------------------------------------------------------------------
     * Class Definition
     * ------------------------------------------------------------------------
     */

    
var Collapse = (function () {
      function 
Collapse(elementconfig) {
        
_classCallCheck(thisCollapse);

        
this._isTransitioning false;
        
this._element element;
        
this._config this._getConfig(config);
        
this._triggerArray = $.makeArray($('[data-toggle="collapse"][href="#' element.id '"],' + ('[data-toggle="collapse"][data-target="#' element.id '"]')));

        
this._parent this._config.parent this._getParent() : null;

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

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

      
/**
       * ------------------------------------------------------------------------
       * Data Api implementation
       * ------------------------------------------------------------------------
       */

      // getters

      
_createClass(Collapse, [{
        
key'toggle',

        
// public

        
value: function toggle() {
          if ($(
this._element).hasClass(ClassName.IN)) {
            
this.hide();
          } else {
            
this.show();
          }
        }
      }, {
        
key'show',
        
value: function show() {
          var 
_this this;

          if (
this._isTransitioning || $(this._element).hasClass(ClassName.IN)) {
            return;
          }

          var 
actives undefined;
          var 
activesData undefined;

          if (
this._parent) {
            
actives = $.makeArray($(Selector.ACTIVES));
            if (!
actives.length) {
              
actives null;
            }
          }

          if (
actives) {
            
activesData = $(actives).data(DATA_KEY);
            if (
activesData && activesData._isTransitioning) {
              return;
            }
          }

          var 
startEvent = $.Event(Event.SHOW);
          $(
this._element).trigger(startEvent);
          if (
startEvent.isDefaultPrevented()) {
            return;
          }

          if (
actives) {
            
Collapse._jQueryInterface.call($(actives), 'hide');
            if (!
activesData) {
              $(
actives).data(DATA_KEYnull);
            }
          }

          var 
dimension this._getDimension();

          $(
this._element).removeClass(ClassName.COLLAPSE).addClass(ClassName.COLLAPSING);

          
this._element.style[dimension] = 0;
          
this._element.setAttribute('aria-expanded'true);

          if (
this._triggerArray.length) {
            $(
this._triggerArray).removeClass(ClassName.COLLAPSED).attr('aria-expanded'true);
          }

          
this.setTransitioning(true);

          var 
complete = function complete() {
            $(
_this._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).addClass(ClassName.IN);

            
_this._element.style[dimension] = '';

            
_this.setTransitioning(false);

            $(
_this._element).trigger(Event.SHOWN);
          };

          if (!
_Util['default'].supportsTransitionEnd()) {
            
complete();
            return;
          }

          var 
capitalizedDimension dimension[0].toUpperCase() + dimension.slice(1);
          var 
scrollSize 'scroll' capitalizedDimension;

          $(
this._element).one(_Util['default'].TRANSITION_ENDcomplete).emulateTransitionEnd(TRANSITION_DURATION);

          
this._element.style[dimension] = this._element[scrollSize] + 'px';
        }
      }, {
        
key'hide',
        
value: function hide() {
          var 
_this2 this;

          if (
this._isTransitioning || !$(this._element).hasClass(ClassName.IN)) {
            return;
          }

          var 
startEvent = $.Event(Event.HIDE);
          $(
this._element).trigger(startEvent);
          if (
startEvent.isDefaultPrevented()) {
            return;
          }

          var 
dimension this._getDimension();
          var 
offsetDimension dimension === Dimension.WIDTH 'offsetWidth' 'offsetHeight';

          
this._element.style[dimension] = this._element[offsetDimension] + 'px';

          
_Util['default'].reflow(this._element);

          $(
this._element).addClass(ClassName.COLLAPSING).removeClass(ClassName.COLLAPSE).removeClass(ClassName.IN);

          
this._element.setAttribute('aria-expanded'false);

          if (
this._triggerArray.length) {
            $(
this._triggerArray).addClass(ClassName.COLLAPSED).attr('aria-expanded'false);
          }

          
this.setTransitioning(true);

          var 
complete = function complete() {
            
_this2.setTransitioning(false);
            $(
_this2._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).trigger(Event.HIDDEN);
          };

          
this._element.style[dimension] = 0;

          if (!
_Util['default'].supportsTransitionEnd()) {
            
complete();
            return;
          }

          $(
this._element).one(_Util['default'].TRANSITION_ENDcomplete).emulateTransitionEnd(TRANSITION_DURATION);
        }
      }, {
        
key'setTransitioning',
        
value: function setTransitioning(isTransitioning) {
          
this._isTransitioning isTransitioning;
        }
      }, {
        
key'dispose',
        
value: function dispose() {
          $.
removeData(this._elementDATA_KEY);

          
this._config null;
          
this._parent null;
          
this._element null;
          
this._triggerArray null;
          
this._isTransitioning null;
        }

        
// private

      
}, {
        
key'_getConfig',
        
value: function _getConfig(config) {
          
config = $.extend({}, Default, config);
          
config.toggle Boolean(config.toggle); // coerce string values
          
_Util['default'].typeCheckConfig(NAMEconfigDefaultType);
          return 
config;
        }
      }, {
        
key'_getDimension',
        
value: function _getDimension() {
          var 
hasWidth = $(this._element).hasClass(Dimension.WIDTH);
          return 
hasWidth Dimension.WIDTH Dimension.HEIGHT;
        }
      }, {
        
key'_getParent',
        
value: 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 (ielement) {
            
_this3._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]);
          });

          return 
parent;
        }
      }, {
        
key'_addAriaAndCollapsedClass',
        
value: function _addAriaAndCollapsedClass(elementtriggerArray) {
          if (
element) {
            var 
isOpen = $(element).hasClass(ClassName.IN);
            
element.setAttribute('aria-expanded'isOpen);

            if (
triggerArray.length) {
              $(
triggerArray).toggleClass(ClassName.COLLAPSED, !isOpen).attr('aria-expanded'isOpen);
            }
          }
        }

        
// static

      
}], [{
        
key'_getTargetFromElement',
        
value: function _getTargetFromElement(element) {
          var 
selector _Util['default'].getSelectorFromElement(element);
          return 
selector ? $(selector)[0] : null;
        }
      }, {
        
key'_jQueryInterface',
        
value: function _jQueryInterface(config) {
          return 
this.each(function () {
            var 
$this = $(this);
            var 
data $this.data(DATA_KEY);
            var 
_config = $.extend({}, Default, $this.data(), typeof config === 'object' && config);

            if (!
data && _config.toggle && /show|hide/.test(config)) {
              
_config.toggle false;
            }

            if (!
data) {
              
data = new Collapse(this_config);
              
$this.data(DATA_KEYdata);
            }

            if (
typeof config === 'string') {
              
data[config]();
            }
          });
        }
      }, {
        
key'VERSION',
        
get: function get() {
          return 
VERSION;
        }
      }, {
        
key'Default',
        
get: function get() {
          return Default;
        }
      }]);

      return 
Collapse;
    })();

    $(
document).on(Event.CLICK_DATA_APISelector.DATA_TOGGLE, function (event) {
      
event.preventDefault();

      var 
target Collapse._getTargetFromElement(this);
      var 
data = $(target).data(DATA_KEY);
      var 
config data 'toggle' : $(this).data();

      
Collapse._jQueryInterface.call($(target), config);
    });

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

    
$.fn[NAME] = Collapse._jQueryInterface;
    $.fn[
NAME].Constructor Collapse;
    $.fn[
NAME].noConflict = function () {
      $.fn[
NAME] = JQUERY_NO_CONFLICT;
      return 
Collapse._jQueryInterface;
    };

    return 
Collapse;
  })(
jQuery);

  
module.exports Collapse;
});
?>
Онлайн: 2
Реклама