Вход Регистрация
Файл: sngine-v2.8/Documentation/assets/fontawesome/js/fontawesome.js
Строк: 2976
<?php
/*!
 * Font Awesome Free 5.9.0 by @fontawesome - https://fontawesome.com
 * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)
 */
(function () {
  
'use strict';

  function 
_typeof(obj) {
    if (
typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
      
_typeof = function (obj) {
        return 
typeof obj;
      };
    } else {
      
_typeof = function (obj) {
        return 
obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype "symbol" typeof obj;
      };
    }

    return 
_typeof(obj);
  }

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

  function 
_defineProperties(targetprops) {
    for (var 
0props.lengthi++) {
      var 
descriptor props[i];
      
descriptor.enumerable descriptor.enumerable || false;
      
descriptor.configurable true;
      if (
"value" in descriptordescriptor.writable true;
      
Object.defineProperty(targetdescriptor.keydescriptor);
    }
  }

  function 
_createClass(ConstructorprotoPropsstaticProps) {
    if (
protoProps_defineProperties(Constructor.prototypeprotoProps);
    if (
staticProps_defineProperties(ConstructorstaticProps);
    return 
Constructor;
  }

  function 
_defineProperty(objkeyvalue) {
    if (
key in obj) {
      
Object.defineProperty(objkey, {
        
valuevalue,
        
enumerabletrue,
        
configurabletrue,
        
writabletrue
      
});
    } else {
      
obj[key] = value;
    }

    return 
obj;
  }

  function 
_objectSpread(target) {
    for (var 
1arguments.lengthi++) {
      var 
source arguments[i] != null arguments[i] : {};
      var 
ownKeys Object.keys(source);

      if (
typeof Object.getOwnPropertySymbols === 'function') {
        
ownKeys ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) {
          return 
Object.getOwnPropertyDescriptor(sourcesym).enumerable;
        }));
      }

      
ownKeys.forEach(function (key) {
        
_defineProperty(targetkeysource[key]);
      });
    }

    return 
target;
  }

  function 
_slicedToArray(arri) {
    return 
_arrayWithHoles(arr) || _iterableToArrayLimit(arri) || _nonIterableRest();
  }

  function 
_toConsumableArray(arr) {
    return 
_arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread();
  }

  function 
_arrayWithoutHoles(arr) {
    if (Array.
isArray(arr)) {
      for (var 
0arr2 = new Array(arr.length); arr.lengthi++) arr2[i] = arr[i];

      return 
arr2;
    }
  }

  function 
_arrayWithHoles(arr) {
    if (Array.
isArray(arr)) return arr;
  }

  function 
_iterableToArray(iter) {
    if (
Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter);
  }

  function 
_iterableToArrayLimit(arri) {
    var 
_arr = [];
    var 
_n true;
    var 
_d false;
    var 
_e undefined;

    try {
      for (var 
_i arr[Symbol.iterator](), _s; !(_n = (_s _i.next()).done); _n true) {
        
_arr.push(_s.value);

        if (
&& _arr.length === i) break;
      }
    } catch (
err) {
      
_d true;
      
_e err;
    } finally {
      try {
        if (!
_n && _i["return"] != null_i["return"]();
      } finally {
        if (
_d) throw _e;
      }
    }

    return 
_arr;
  }

  function 
_nonIterableSpread() {
    throw new 
TypeError("Invalid attempt to spread non-iterable instance");
  }

  function 
_nonIterableRest() {
    throw new 
TypeError("Invalid attempt to destructure non-iterable instance");
  }

  var 
noop = function noop() {};

  var 
_WINDOW = {};
  var 
_DOCUMENT = {};
  var 
_MUTATION_OBSERVER null;
  var 
_PERFORMANCE = {
    
marknoop,
    
measurenoop
  
};

  try {
    if (
typeof window !== 'undefined'_WINDOW window;
    if (
typeof document !== 'undefined'_DOCUMENT document;
    if (
typeof MutationObserver !== 'undefined'_MUTATION_OBSERVER MutationObserver;
    if (
typeof performance !== 'undefined'_PERFORMANCE performance;
  } catch (
e) {}

  var 
_ref _WINDOW.navigator || {},
      
_ref$userAgent _ref.userAgent,
      
userAgent _ref$userAgent === void 0 '' _ref$userAgent;

  var 
WINDOW _WINDOW;
  var 
DOCUMENT _DOCUMENT;
  var 
MUTATION_OBSERVER _MUTATION_OBSERVER;
  var 
PERFORMANCE _PERFORMANCE;
  var 
IS_BROWSER = !!WINDOW.document;
  var 
IS_DOM = !!DOCUMENT.documentElement && !!DOCUMENT.head && typeof DOCUMENT.addEventListener === 'function' && typeof DOCUMENT.createElement === 'function';
  var 
IS_IE = ~userAgent.indexOf('MSIE') || ~userAgent.indexOf('Trident/');

  var 
NAMESPACE_IDENTIFIER '___FONT_AWESOME___';
  var 
UNITS_IN_GRID 16;
  var 
DEFAULT_FAMILY_PREFIX 'fa';
  var 
DEFAULT_REPLACEMENT_CLASS 'svg-inline--fa';
  var 
DATA_FA_I2SVG 'data-fa-i2svg';
  var 
DATA_FA_PSEUDO_ELEMENT 'data-fa-pseudo-element';
  var 
DATA_FA_PSEUDO_ELEMENT_PENDING 'data-fa-pseudo-element-pending';
  var 
DATA_PREFIX 'data-prefix';
  var 
DATA_ICON 'data-icon';
  var 
HTML_CLASS_I2SVG_BASE_CLASS 'fontawesome-i2svg';
  var 
MUTATION_APPROACH_ASYNC 'async';
  var 
TAGNAMES_TO_SKIP_FOR_PSEUDOELEMENTS = ['HTML''HEAD''STYLE''SCRIPT'];
  var 
PRODUCTION = function () {
    try {
      return 
"production" === 'production';
    } catch (
e) {
      return 
false;
    }
  }();
  var 
PREFIX_TO_STYLE = {
    
'fas''solid',
    
'far''regular',
    
'fal''light',
    
'fab''brands',
    
'fa''solid'
  
};
  var 
STYLE_TO_PREFIX = {
    
'solid''fas',
    
'regular''far',
    
'light''fal',
    
'brands''fab'
  
};
  var 
LAYERS_TEXT_CLASSNAME 'fa-layers-text';
  var 
FONT_FAMILY_PATTERN = /Font Awesome 5 (Solid|Regular|Light|Brands|Free|Pro)/;
  var 
FONT_WEIGHT_TO_PREFIX = {
    
'900''fas',
    
'400''far',
    
'normal''far',
    
'300''fal'
  
};
  var 
oneToTen = [12345678910];
  var 
oneToTwenty oneToTen.concat([11121314151617181920]);
  var 
ATTRIBUTES_WATCHED_FOR_MUTATION = ['class''data-prefix''data-icon''data-fa-transform''data-fa-mask'];
  var 
RESERVED_CLASSES = ['xs''sm''lg''fw''ul''li''border''pull-left''pull-right''spin''pulse''rotate-90''rotate-180''rotate-270''flip-horizontal''flip-vertical''flip-both''stack''stack-1x''stack-2x''inverse''layers''layers-text''layers-counter'].concat(oneToTen.map(function (n) {
    return 
"".concat(n"x");
  })).
concat(oneToTwenty.map(function (n) {
    return 
"w-".concat(n);
  }));

  var 
initial WINDOW.FontAwesomeConfig || {};

  function 
getAttrConfig(attr) {
    var 
element DOCUMENT.querySelector('script[' attr ']');

    if (
element) {
      return 
element.getAttribute(attr);
    }
  }

  function 
coerce(val) {
    
// Getting an empty string will occur if the attribute is set on the HTML tag but without a value
    // We'll assume that this is an indication that it should be toggled to true
    // For example <script data-search-pseudo-elements src="..."></script>
    
if (val === '') return true;
    if (
val === 'false') return false;
    if (
val === 'true') return true;
    return 
val;
  }

  if (
DOCUMENT && typeof DOCUMENT.querySelector === 'function') {
    var 
attrs = [['data-family-prefix''familyPrefix'], ['data-replacement-class''replacementClass'], ['data-auto-replace-svg''autoReplaceSvg'], ['data-auto-add-css''autoAddCss'], ['data-auto-a11y''autoA11y'], ['data-search-pseudo-elements''searchPseudoElements'], ['data-observe-mutations''observeMutations'], ['data-mutate-approach''mutateApproach'], ['data-keep-original-source''keepOriginalSource'], ['data-measure-performance''measurePerformance'], ['data-show-missing-icons''showMissingIcons']];
    
attrs.forEach(function (_ref) {
      var 
_ref2 _slicedToArray(_ref2),
          
attr _ref2[0],
          
key _ref2[1];

      var 
val coerce(getAttrConfig(attr));

      if (
val !== undefined && val !== null) {
        
initial[key] = val;
      }
    });
  }

  var 
_default = {
    
familyPrefixDEFAULT_FAMILY_PREFIX,
    
replacementClassDEFAULT_REPLACEMENT_CLASS,
    
autoReplaceSvgtrue,
    
autoAddCsstrue,
    
autoA11ytrue,
    
searchPseudoElementsfalse,
    
observeMutationstrue,
    
mutateApproach'async',
    
keepOriginalSourcetrue,
    
measurePerformancefalse,
    
showMissingIconstrue
  
};

  var 
_config _objectSpread({}, _defaultinitial);

  if (!
_config.autoReplaceSvg_config.observeMutations false;

  var 
config _objectSpread({}, _config);

  
WINDOW.FontAwesomeConfig config;

  var 
WINDOW || {};
  if (!
w[NAMESPACE_IDENTIFIER]) w[NAMESPACE_IDENTIFIER] = {};
  if (!
w[NAMESPACE_IDENTIFIER].stylesw[NAMESPACE_IDENTIFIER].styles = {};
  if (!
w[NAMESPACE_IDENTIFIER].hooksw[NAMESPACE_IDENTIFIER].hooks = {};
  if (!
w[NAMESPACE_IDENTIFIER].shimsw[NAMESPACE_IDENTIFIER].shims = [];
  var namespace = 
w[NAMESPACE_IDENTIFIER];

  var 
functions = [];

  var 
listener = function listener() {
    
DOCUMENT.removeEventListener('DOMContentLoaded'listener);
    
loaded 1;
    
functions.map(function (fn) {
      return fn();
    });
  };

  var 
loaded false;

  if (
IS_DOM) {
    
loaded = (DOCUMENT.documentElement.doScroll ? /^loaded|^c/ : /^loaded|^i|^c/).test(DOCUMENT.readyState);
    if (!
loadedDOCUMENT.addEventListener('DOMContentLoaded'listener);
  }

  function 
domready (fn) {
    if (!
IS_DOM) return;
    
loaded setTimeout(fn, 0) : functions.push(fn);
  }

  var 
PENDING 'pending';
  var 
SETTLED 'settled';
  var 
FULFILLED 'fulfilled';
  var 
REJECTED 'rejected';

  var 
NOOP = function NOOP() {};

  var 
isNode typeof global !== 'undefined' && typeof global.process !== 'undefined' && typeof global.process.emit === 'function';
  var 
asyncSetTimer typeof setImmediate === 'undefined' setTimeout setImmediate;
  var 
asyncQueue = [];
  var 
asyncTimer;

  function 
asyncFlush() {
    
// run promise callbacks
    
for (var 0asyncQueue.lengthi++) {
      
asyncQueue[i][0](asyncQueue[i][1]);
    } 
// reset async asyncQueue


    
asyncQueue = [];
    
asyncTimer false;
  }

  function 
asyncCall(callbackarg) {
    
asyncQueue.push([callbackarg]);

    if (!
asyncTimer) {
      
asyncTimer true;
      
asyncSetTimer(asyncFlush0);
    }
  }

  function 
invokeResolver(resolverpromise) {
    function 
resolvePromise(value) {
      
resolve(promisevalue);
    }

    function 
rejectPromise(reason) {
      
reject(promisereason);
    }

    try {
      
resolver(resolvePromiserejectPromise);
    } catch (
e) {
      
rejectPromise(e);
    }
  }

  function 
invokeCallback(subscriber) {
    var 
owner subscriber.owner;
    var 
settled owner._state;
    var 
value owner._data;
    var 
callback subscriber[settled];
    var 
promise subscriber.then;

    if (
typeof callback === 'function') {
      
settled FULFILLED;

      try {
        
value callback(value);
      } catch (
e) {
        
reject(promisee);
      }
    }

    if (!
handleThenable(promisevalue)) {
      if (
settled === FULFILLED) {
        
resolve(promisevalue);
      }

      if (
settled === REJECTED) {
        
reject(promisevalue);
      }
    }
  }

  function 
handleThenable(promisevalue) {
    var 
resolved;

    try {
      if (
promise === value) {
        throw new 
TypeError('A promises callback cannot return that same promise.');
      }

      if (
value && (typeof value === 'function' || _typeof(value) === 'object')) {
        
// then should be retrieved only once
        
var then value.then;

        if (
typeof then === 'function') {
          
then.call(value, function (val) {
            if (!
resolved) {
              
resolved true;

              if (
value === val) {
                
fulfill(promiseval);
              } else {
                
resolve(promiseval);
              }
            }
          }, function (
reason) {
            if (!
resolved) {
              
resolved true;
              
reject(promisereason);
            }
          });
          return 
true;
        }
      }
    } catch (
e) {
      if (!
resolved) {
        
reject(promisee);
      }

      return 
true;
    }

    return 
false;
  }

  function 
resolve(promisevalue) {
    if (
promise === value || !handleThenable(promisevalue)) {
      
fulfill(promisevalue);
    }
  }

  function 
fulfill(promisevalue) {
    if (
promise._state === PENDING) {
      
promise._state SETTLED;
      
promise._data value;
      
asyncCall(publishFulfillmentpromise);
    }
  }

  function 
reject(promisereason) {
    if (
promise._state === PENDING) {
      
promise._state SETTLED;
      
promise._data reason;
      
asyncCall(publishRejectionpromise);
    }
  }

  function 
publish(promise) {
    
promise._then promise._then.forEach(invokeCallback);
  }

  function 
publishFulfillment(promise) {
    
promise._state FULFILLED;
    
publish(promise);
  }

  function 
publishRejection(promise) {
    
promise._state REJECTED;
    
publish(promise);

    if (!
promise._handled && isNode) {
      global.
process.emit('unhandledRejection'promise._datapromise);
    }
  }

  function 
notifyRejectionHandled(promise) {
    global.
process.emit('rejectionHandled'promise);
  }
  
/**
   * @class
   */


  
function P(resolver) {
    if (
typeof resolver !== 'function') {
      throw new 
TypeError('Promise resolver ' resolver ' is not a function');
    }

    if (
this instanceof === false) {
      throw new 
TypeError('Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.');
    }

    
this._then = [];
    
invokeResolver(resolverthis);
  }

  
P.prototype = {
    
constructorP,
    
_statePENDING,
    
_thennull,
    
_dataundefined,
    
_handledfalse,
    
then: function then(onFulfillmentonRejection) {
      var 
subscriber = {
        
ownerthis,
        
then: new this.constructor(NOOP),
        
fulfilledonFulfillment,
        
rejectedonRejection
      
};

      if ((
onRejection || onFulfillment) && !this._handled) {
        
this._handled true;

        if (
this._state === REJECTED && isNode) {
          
asyncCall(notifyRejectionHandledthis);
        }
      }

      if (
this._state === FULFILLED || this._state === REJECTED) {
        
// already resolved, call callback async
        
asyncCall(invokeCallbacksubscriber);
      } else {
        
// subscribe
        
this._then.push(subscriber);
      }

      return 
subscriber.then;
    },
    catch: function 
_catch(onRejection) {
      return 
this.then(nullonRejection);
    }
  };

  
P.all = function (promises) {
    if (!Array.
isArray(promises)) {
      throw new 
TypeError('You must pass an array to Promise.all().');
    }

    return new 
P(function (resolvereject) {
      var 
results = [];
      var 
remaining 0;

      function 
resolver(index) {
        
remaining++;
        return function (
value) {
          
results[index] = value;

          if (! --
remaining) {
            
resolve(results);
          }
        };
      }

      for (var 
0promisepromises.lengthi++) {
        
promise promises[i];

        if (
promise && typeof promise.then === 'function') {
          
promise.then(resolver(i), reject);
        } else {
          
results[i] = promise;
        }
      }

      if (!
remaining) {
        
resolve(results);
      }
    });
  };

  
P.race = function (promises) {
    if (!Array.
isArray(promises)) {
      throw new 
TypeError('You must pass an array to Promise.race().');
    }

    return new 
P(function (resolvereject) {
      for (var 
0promisepromises.lengthi++) {
        
promise promises[i];

        if (
promise && typeof promise.then === 'function') {
          
promise.then(resolvereject);
        } else {
          
resolve(promise);
        }
      }
    });
  };

  
P.resolve = function (value) {
    if (
value && _typeof(value) === 'object' && value.constructor === P) {
      return 
value;
    }

    return new 
P(function (resolve) {
      
resolve(value);
    });
  };

  
P.reject = function (reason) {
    return new 
P(function (resolvereject) {
      
reject(reason);
    });
  };

  var 
picked typeof Promise === 'function' Promise P;

  var 
UNITS_IN_GRID;
  var 
meaninglessTransform = {
    
size16,
    
x0,
    
y0,
    
rotate0,
    
flipXfalse,
    
flipYfalse
  
};

  function 
isReserved(name) {
    return ~
RESERVED_CLASSES.indexOf(name);
  }

  function 
bunker(fn) {
    try {
      fn();
    } catch (
e) {
      if (!
PRODUCTION) {
        throw 
e;
      }
    }
  }
  function 
insertCss(css) {
    if (!
css || !IS_DOM) {
      return;
    }

    var 
style DOCUMENT.createElement('style');
    
style.setAttribute('type''text/css');
    
style.innerHTML css;
    var 
headChildren DOCUMENT.head.childNodes;
    var 
beforeChild null;

    for (var 
headChildren.length 1> -1i--) {
      var 
child headChildren[i];
      var 
tagName = (child.tagName || '').toUpperCase();

      if ([
'STYLE''LINK'].indexOf(tagName) > -1) {
        
beforeChild child;
      }
    }

    
DOCUMENT.head.insertBefore(stylebeforeChild);
    return 
css;
  }
  var 
idPool '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
  function 
nextUniqueId() {
    var 
size 12;
    var 
id '';

    while (
size-- > 0) {
      
id += idPool[Math.random() * 62 0];
    }

    return 
id;
  }
  function 
toArray(obj) {
    var array = [];

    for (var 
= (obj || []).length >>> 0i--;) {
      array[
i] = obj[i];
    }

    return array;
  }
  function 
classArray(node) {
    if (
node.classList) {
      return 
toArray(node.classList);
    } else {
      return (
node.getAttribute('class') || '').split(' ').filter(function (i) {
        return 
i;
      });
    }
  }
  function 
getIconName(familyPrefixcls) {
    var 
parts cls.split('-');
    var 
prefix parts[0];
    var 
iconName parts.slice(1).join('-');

    if (
prefix === familyPrefix && iconName !== '' && !isReserved(iconName)) {
      return 
iconName;
    } else {
      return 
null;
    }
  }
  function 
htmlEscape(str) {
    return 
"".concat(str).replace(/&/g'&amp;').replace(/"/g, '&quot;').replace(/'/g, '&#39;').replace(/</g, '&lt;').replace(/>/g, '&gt;');
  }
  function joinAttributes(attributes) {
    return Object.keys(attributes || {}).reduce(function (acc, attributeName) {
      return acc + "".concat(attributeName, "
="").concat(htmlEscape(attributes[attributeName]), "" ");
    }, '').trim();
  }
  function joinStyles(styles) {
    return Object.keys(styles || {}).reduce(function (acc, styleName) {
      return acc + "".concat(styleName, "
").concat(styles[styleName], ";");
    }, '');
  }
  function transformIsMeaningful(transform) {
    return transform.size !== meaninglessTransform.size || transform.x !== meaninglessTransform.x || transform.y !== meaninglessTransform.y || transform.rotate !== meaninglessTransform.rotate || transform.flipX || transform.flipY;
  }
  function transformForSvg(_ref) {
    var transform = _ref.transform,
        containerWidth = _ref.containerWidth,
        iconWidth = _ref.iconWidth;
    var outer = {
      transform: "
translate(".concat(containerWidth / 2, " 256)")
    };
    var innerTranslate = "
translate(".concat(transform.x * 32, "").concat(transform.y * 32, "");
    var innerScale = "
scale(".concat(transform.size / 16 * (transform.flipX ? -1 : 1), "").concat(transform.size / 16 * (transform.flipY ? -1 : 1), "");
    var innerRotate = "
rotate(".concat(transform.rotate, " 0 0)");
    var inner = {
      transform: "".concat(innerTranslate, " ").concat(innerScale, " ").concat(innerRotate)
    };
    var path = {
      transform: "
translate(".concat(iconWidth / 2 * -1, " -256)")
    };
    return {
      outer: outer,
      inner: inner,
      path: path
    };
  }
  function transformForCss(_ref2) {
    var transform = _ref2.transform,
        _ref2
$width = _ref2.width,
        width = _ref2
$width === void 0 ? UNITS_IN_GRID : _ref2$width,
        _ref2
$height = _ref2.height,
        height = _ref2
$height === void 0 ? UNITS_IN_GRID : _ref2$height,
        _ref2
$startCentered = _ref2.startCentered,
        startCentered = _ref2
$startCentered === void 0 ? false : _ref2$startCentered;
    var val = '';

    if (startCentered && IS_IE) {
      val += "
translate(".concat(transform.x / d - width / 2, "em").concat(transform.y / d - height / 2, "em");
    } else if (startCentered) {
      val += "
translate(calc(-50% + ".concat(transform.x / d, "em), calc(-50% + ").concat(transform.y / d, "em)) ");
    } else {
      val += "
translate(".concat(transform.x / d, "em").concat(transform.y / d, "em");
    }

    val += "
scale(".concat(transform.size / d * (transform.flipX ? -1 : 1), "").concat(transform.size / d * (transform.flipY ? -1 : 1), "");
    val += "
rotate(".concat(transform.rotate, "deg");
    return val;
  }

  var ALL_SPACE = {
    x: 0,
    y: 0,
    width: '100%',
    height: '100%'
  };
  function makeIconMasking (_ref) {
    var children = _ref.children,
        attributes = _ref.attributes,
        main = _ref.main,
        mask = _ref.mask,
        transform = _ref.transform;
    var mainWidth = main.width,
        mainPath = main.icon;
    var maskWidth = mask.width,
        maskPath = mask.icon;
    var trans = transformForSvg({
      transform: transform,
      containerWidth: maskWidth,
      iconWidth: mainWidth
    });
    var maskRect = {
      tag: 'rect',
      attributes: _objectSpread({}, ALL_SPACE, {
        fill: 'white'
      })
    };
    var maskInnerGroup = {
      tag: 'g',
      attributes: _objectSpread({}, trans.inner),
      children: [{
        tag: 'path',
        attributes: _objectSpread({}, mainPath.attributes, trans.path, {
          fill: 'black'
        })
      }]
    };
    var maskOuterGroup = {
      tag: 'g',
      attributes: _objectSpread({}, trans.outer),
      children: [maskInnerGroup]
    };
    var maskId = "
mask-".concat(nextUniqueId());
    var clipId = "
clip-".concat(nextUniqueId());
    var maskTag = {
      tag: 'mask',
      attributes: _objectSpread({}, ALL_SPACE, {
        id: maskId,
        maskUnits: 'userSpaceOnUse',
        maskContentUnits: 'userSpaceOnUse'
      }),
      children: [maskRect, maskOuterGroup]
    };
    var defs = {
      tag: 'defs',
      children: [{
        tag: 'clipPath',
        attributes: {
          id: clipId
        },
        children: [maskPath]
      }, maskTag]
    };
    children.push(defs, {
      tag: 'rect',
      attributes: _objectSpread({
        fill: 'currentColor',
        'clip-path': "
url(#".concat(clipId, ")"),
        
mask"url(#".concat(maskId")")
      }, 
ALL_SPACE)
    });
    return {
      
childrenchildren,
      
attributesattributes
    
};
  }

  function 
makeIconStandard (_ref) {
    var 
children _ref.children,
        
attributes _ref.attributes,
        
main _ref.main,
        
transform _ref.transform,
        
styles _ref.styles;
    var 
styleString joinStyles(styles);

    if (
styleString.length 0) {
      
attributes['style'] = styleString;
    }

    if (
transformIsMeaningful(transform)) {
      var 
trans transformForSvg({
        
transformtransform,
        
containerWidthmain.width,
        
iconWidthmain.width
      
});
      
children.push({
        
tag'g',
        
attributes_objectSpread({}, trans.outer),
        
children: [{
          
tag'g',
          
attributes_objectSpread({}, trans.inner),
          
children: [{
            
tagmain.icon.tag,
            
childrenmain.icon.children,
            
attributes_objectSpread({}, main.icon.attributestrans.path)
          }]
        }]
      });
    } else {
      
children.push(main.icon);
    }

    return {
      
childrenchildren,
      
attributesattributes
    
};
  }

  function 
asIcon (_ref) {
    var 
children _ref.children,
        
main _ref.main,
        
mask _ref.mask,
        
attributes _ref.attributes,
        
styles _ref.styles,
        
transform _ref.transform;

    if (
transformIsMeaningful(transform) && main.found && !mask.found) {
      var 
width main.width,
          
height main.height;
      var 
offset = {
        
xwidth height 2,
        
y0.5
      
};
      
attributes['style'] = joinStyles(_objectSpread({}, styles, {
        
'transform-origin'"".concat(offset.transform.16"em ").concat(offset.transform.16"em")
      }));
    }

    return [{
      
tag'svg',
      
attributesattributes,
      
childrenchildren
    
}];
  }

  function 
asSymbol (_ref) {
    var 
prefix _ref.prefix,
        
iconName _ref.iconName,
        
children _ref.children,
        
attributes _ref.attributes,
        
symbol _ref.symbol;
    var 
id symbol === true "".concat(prefix"-").concat(config.familyPrefix"-").concat(iconName) : symbol;
    return [{
      
tag'svg',
      
attributes: {
        
style'display: none;'
      
},
      
children: [{
        
tag'symbol',
        
attributes_objectSpread({}, attributes, {
          
idid
        
}),
        
childrenchildren
      
}]
    }];
  }

  function 
makeInlineSvgAbstract(params) {
    var 
_params$icons params.icons,
        
main _params$icons.main,
        
mask _params$icons.mask,
        
prefix params.prefix,
        
iconName params.iconName,
        
transform params.transform,
        
symbol params.symbol,
        
title params.title,
        
extra params.extra,
        
_params$watchable params.watchable,
        
watchable _params$watchable === void 0 false _params$watchable;

    var 
_ref mask.found mask main,
        
width _ref.width,
        
height _ref.height;

    var 
widthClass "fa-w-".concat(Math.ceil(width height 16));
    var 
attrClass = [config.replacementClassiconName "".concat(config.familyPrefix"-").concat(iconName) : ''widthClass].filter(function (c) {
      return 
extra.classes.indexOf(c) === -1;
    }).
concat(extra.classes).join(' ');
    var 
content = {
      
children: [],
      
attributes_objectSpread({}, extra.attributes, {
        
'data-prefix'prefix,
        
'data-icon'iconName,
        
'class'attrClass,
        
'role'extra.attributes.role || 'img',
        
'xmlns''http://www.w3.org/2000/svg',
        
'viewBox'"0 0 ".concat(width" ").concat(height)
      })
    };

    if (
watchable) {
      
content.attributes[DATA_FA_I2SVG] = '';
    }

    if (
titlecontent.children.push({
      
tag'title',
      
attributes: {
        
idcontent.attributes['aria-labelledby'] || "title-".concat(nextUniqueId())
      },
      
children: [title]
    });

    var 
args _objectSpread({}, content, {
      
prefixprefix,
      
iconNameiconName,
      
mainmain,
      
maskmask,
      
transformtransform,
      
symbolsymbol,
      
stylesextra.styles
    
});

    var 
_ref2 mask.found && main.found makeIconMasking(args) : makeIconStandard(args),
        
children _ref2.children,
        
attributes _ref2.attributes;

    
args.children children;
    
args.attributes attributes;

    if (
symbol) {
      return 
asSymbol(args);
    } else {
      return 
asIcon(args);
    }
  }
  function 
makeLayersTextAbstract(params) {
    var 
content params.content,
        
width params.width,
        
height params.height,
        
transform params.transform,
        
title params.title,
        
extra params.extra,
        
_params$watchable2 params.watchable,
        
watchable _params$watchable2 === void 0 false _params$watchable2;

    var 
attributes _objectSpread({}, extra.attributestitle ? {
      
'title'title
    
} : {}, {
      
'class'extra.classes.join(' ')
    });

    if (
watchable) {
      
attributes[DATA_FA_I2SVG] = '';
    }

    var 
styles _objectSpread({}, extra.styles);

    if (
transformIsMeaningful(transform)) {
      
styles['transform'] = transformForCss({
        
transformtransform,
        
startCenteredtrue,
        
widthwidth,
        
heightheight
      
});
      
styles['-webkit-transform'] = styles['transform'];
    }

    var 
styleString joinStyles(styles);

    if (
styleString.length 0) {
      
attributes['style'] = styleString;
    }

    var 
val = [];
    
val.push({
      
tag'span',
      
attributesattributes,
      
children: [content]
    });

    if (
title) {
      
val.push({
        
tag'span',
        
attributes: {
          class: 
'sr-only'
        
},
        
children: [title]
      });
    }

    return 
val;
  }
  function 
makeLayersCounterAbstract(params) {
    var 
content params.content,
        
title params.title,
        
extra params.extra;

    var 
attributes _objectSpread({}, extra.attributestitle ? {
      
'title'title
    
} : {}, {
      
'class'extra.classes.join(' ')
    });

    var 
styleString joinStyles(extra.styles);

    if (
styleString.length 0) {
      
attributes['style'] = styleString;
    }

    var 
val = [];
    
val.push({
      
tag'span',
      
attributesattributes,
      
children: [content]
    });

    if (
title) {
      
val.push({
        
tag'span',
        
attributes: {
          class: 
'sr-only'
        
},
        
children: [title]
      });
    }

    return 
val;
  }

  var 
noop$= function noop() {};

  var 
config.measurePerformance && PERFORMANCE && PERFORMANCE.mark && PERFORMANCE.measure PERFORMANCE : {
    
marknoop$1,
    
measurenoop$1
  
};
  var 
preamble "FA "5.9.0"";

  var 
begin = function begin(name) {
    
p.mark("".concat(preamble" ").concat(name" begins"));
    return function () {
      return 
end(name);
    };
  };

  var 
end = function end(name) {
    
p.mark("".concat(preamble" ").concat(name" ends"));
    
p.measure("".concat(preamble" ").concat(name), "".concat(preamble" ").concat(name" begins"), "".concat(preamble" ").concat(name" ends"));
  };

  var 
perf = {
    
beginbegin,
    
endend
  
};

  
/**
   * Internal helper to bind a function known to have 4 arguments
   * to a given context.
   */

  
var bindInternal4 = function bindInternal4(functhisContext) {
    return function (
abcd) {
      return 
func.call(thisContextabcd);
    };
  };

  
/**
   * # Reduce
   *
   * A fast object `.reduce()` implementation.
   *
   * @param  {Object}   subject      The object to reduce over.
   * @param  {Function} fn           The reducer function.
   * @param  {mixed}    initialValue The initial value for the reducer, defaults to subject[0].
   * @param  {Object}   thisContext  The context for the reducer.
   * @return {mixed}                 The final result.
   */


  
var reduce = function fastReduceObject(subject, fn, initialValuethisContext) {
    var 
keys Object.keys(subject),
        
length keys.length,
        
iterator thisContext !== undefined bindInternal4(fn, thisContext) : fn,
        
i,
        
key,
        
result;

    if (
initialValue === undefined) {
      
1;
      
result subject[keys[0]];
    } else {
      
0;
      
result initialValue;
    }

    for (; 
lengthi++) {
      
key keys[i];
      
result iterator(resultsubject[key], keysubject);
    }

    return 
result;
  };

  function 
toHex(unicode) {
    var 
result '';

    for (var 
0unicode.lengthi++) {
      var 
hex unicode.charCodeAt(i).toString(16);
      
result += ('000' hex).slice(-4);
    }

    return 
result;
  }

  function 
defineIcons(prefixicons) {
    var 
params arguments.length && arguments[2] !== undefined arguments[2] : {};
    var 
_params$skipHooks params.skipHooks,
        
skipHooks _params$skipHooks === void 0 false _params$skipHooks;
    var 
normalized Object.keys(icons).reduce(function (acciconName) {
      var 
icon icons[iconName];
      var 
expanded = !!icon.icon;

      if (
expanded) {
        
acc[icon.iconName] = icon.icon;
      } else {
        
acc[iconName] = icon;
      }

      return 
acc;
    }, {});

    if (
typeof namespace.hooks.addPack === 'function' && !skipHooks) {
      namespace.
hooks.addPack(prefixnormalized);
    } else {
      namespace.
styles[prefix] = _objectSpread({}, namespace.styles[prefix] || {}, normalized);
    }
    
/**
     * Font Awesome 4 used the prefix of `fa` for all icons. With the introduction
     * of new styles we needed to differentiate between them. Prefix `fa` is now an alias
     * for `fas` so we'll easy the upgrade process for our users by automatically defining
     * this as well.
     */


    
if (prefix === 'fas') {
      
defineIcons('fa'icons);
    }
  }

  var 
styles = namespace.styles,
      
shims = namespace.shims;
  var 
_byUnicode = {};
  var 
_byLigature = {};
  var 
_byOldName = {};
  var 
build = function build() {
    var 
lookup = function lookup(reducer) {
      return 
reduce(styles, function (ostyleprefix) {
        
o[prefix] = reduce(stylereducer, {});
        return 
o;
      }, {});
    };

    
_byUnicode lookup(function (acciconiconName) {
      if (
icon[3]) {
        
acc[icon[3]] = iconName;
      }

      return 
acc;
    });
    
_byLigature lookup(function (acciconiconName) {
      var 
ligatures icon[2];
      
acc[iconName] = iconName;
      
ligatures.forEach(function (ligature) {
        
acc[ligature] = iconName;
      });
      return 
acc;
    });
    var 
hasRegular 'far' in styles;
    
_byOldName reduce(shims, function (accshim) {
      var 
oldName shim[0];
      var 
prefix shim[1];
      var 
iconName shim[2];

      if (
prefix === 'far' && !hasRegular) {
        
prefix 'fas';
      }

      
acc[oldName] = {
        
prefixprefix,
        
iconNameiconName
      
};
      return 
acc;
    }, {});
  };
  
build();
  function 
byUnicode(prefixunicode) {
    return (
_byUnicode[prefix] || {})[unicode];
  }
  function 
byLigature(prefixligature) {
    return (
_byLigature[prefix] || {})[ligature];
  }
  function 
byOldName(name) {
    return 
_byOldName[name] || {
      
prefixnull,
      
iconNamenull
    
};
  }

  var 
styles$= namespace.styles;
  var 
emptyCanonicalIcon = function emptyCanonicalIcon() {
    return {
      
prefixnull,
      
iconNamenull,
      
rest: []
    };
  };
  function 
getCanonicalIcon(values) {
    return 
values.reduce(function (acccls) {
      var 
iconName getIconName(config.familyPrefixcls);

      if (
styles$1[cls]) {
        
acc.prefix cls;
      } else if (
config.autoFetchSvg && ['fas''far''fal''fab''fa'].indexOf(cls) > -1) {
        
acc.prefix cls;
      } else if (
iconName) {
        var 
shim acc.prefix === 'fa' byOldName(iconName) : {};
        
acc.iconName shim.iconName || iconName;
        
acc.prefix shim.prefix || acc.prefix;
      } else if (
cls !== config.replacementClass && cls.indexOf('fa-w-') !== 0) {
        
acc.rest.push(cls);
      }

      return 
acc;
    }, 
emptyCanonicalIcon());
  }
  function 
iconFromMapping(mappingprefixiconName) {
    if (
mapping && mapping[prefix] && mapping[prefix][iconName]) {
      return {
        
prefixprefix,
        
iconNameiconName,
        
iconmapping[prefix][iconName]
      };
    }
  }

  function 
toHtml(abstractNodes) {
    var 
tag abstractNodes.tag,
        
_abstractNodes$attrib abstractNodes.attributes,
        
attributes _abstractNodes$attrib === void 0 ? {} : _abstractNodes$attrib,
        
_abstractNodes$childr abstractNodes.children,
        
children _abstractNodes$childr === void 0 ? [] : _abstractNodes$childr;

    if (
typeof abstractNodes === 'string') {
      return 
htmlEscape(abstractNodes);
    } else {
      return 
"<".concat(tag" ").concat(joinAttributes(attributes), ">").concat(children.map(toHtml).join(''), "</").concat(tag">");
    }
  }

  var 
noop$= function noop() {};

  function 
isWatched(node) {
    var 
i2svg node.getAttribute node.getAttribute(DATA_FA_I2SVG) : null;
    return 
typeof i2svg === 'string';
  }

  function 
getMutator() {
    if (
config.autoReplaceSvg === true) {
      return 
mutators.replace;
    }

    var 
mutator mutators[config.autoReplaceSvg];
    return 
mutator || mutators.replace;
  }

  var 
mutators = {
    
replace: function replace(mutation) {
      var 
node mutation[0];
      var abstract = 
mutation[1];
      var 
newOuterHTML = abstract.map(function (a) {
        return 
toHtml(a);
      }).
join('n');

      if (
node.parentNode && node.outerHTML) {
        
node.outerHTML newOuterHTML + (config.keepOriginalSource && node.tagName.toLowerCase() !== 'svg' "<!-- ".concat(node.outerHTML" -->") : '');
      } else if (
node.parentNode) {
        var 
newNode document.createElement('span');
        
node.parentNode.replaceChild(newNodenode);
        
newNode.outerHTML newOuterHTML;
      }
    },
    
nest: function nest(mutation) {
      var 
node mutation[0];
      var abstract = 
mutation[1]; // If we already have a replaced node we do not want to continue nesting within it.
      // Short-circuit to the standard replacement

      
if (~classArray(node).indexOf(config.replacementClass)) {
        return 
mutators.replace(mutation);
      }

      var 
forSvg = new RegExp("".concat(config.familyPrefix"-.*"));
      
delete abstract[0].attributes.style;
      var 
splitClasses = abstract[0].attributes.class.split(' ').reduce(function (acccls) {
        if (
cls === config.replacementClass || cls.match(forSvg)) {
          
acc.toSvg.push(cls);
        } else {
          
acc.toNode.push(cls);
        }

        return 
acc;
      }, {
        
toNode: [],
        
toSvg: []
      });
      abstract[
0].attributes.class = splitClasses.toSvg.join(' ');
      var 
newInnerHTML = abstract.map(function (a) {
        return 
toHtml(a);
      }).
join('n');
      
node.setAttribute('class'splitClasses.toNode.join(' '));
      
node.setAttribute(DATA_FA_I2SVG'');
      
node.innerHTML newInnerHTML;
    }
  };

  function 
performOperationSync(op) {
    
op();
  }

  function 
perform(mutationscallback) {
    var 
callbackFunction typeof callback === 'function' callback noop$2;

    if (
mutations.length === 0) {
      
callbackFunction();
    } else {
      var 
frame performOperationSync;

      if (
config.mutateApproach === MUTATION_APPROACH_ASYNC) {
        
frame WINDOW.requestAnimationFrame || performOperationSync;
      }

      
frame(function () {
        var 
mutator getMutator();
        var 
mark perf.begin('mutate');
        
mutations.map(mutator);
        
mark();
        
callbackFunction();
      });
    }
  }
  var 
disabled false;
  function 
disableObservation() {
    
disabled true;
  }
  function 
enableObservation() {
    
disabled false;
  }
  var 
mo null;
  function 
observe(options) {
    if (!
MUTATION_OBSERVER) {
      return;
    }

    if (!
config.observeMutations) {
      return;
    }

    var 
treeCallback options.treeCallback,
        
nodeCallback options.nodeCallback,
        
pseudoElementsCallback options.pseudoElementsCallback,
        
_options$observeMutat options.observeMutationsRoot,
        
observeMutationsRoot _options$observeMutat === void 0 DOCUMENT _options$observeMutat;
    
mo = new MUTATION_OBSERVER(function (objects) {
      if (
disabled) return;
      
toArray(objects).forEach(function (mutationRecord) {
        if (
mutationRecord.type === 'childList' && mutationRecord.addedNodes.length && !isWatched(mutationRecord.addedNodes[0])) {
          if (
config.searchPseudoElements) {
            
pseudoElementsCallback(mutationRecord.target);
          }

          
treeCallback(mutationRecord.target);
        }

        if (
mutationRecord.type === 'attributes' && mutationRecord.target.parentNode && config.searchPseudoElements) {
          
pseudoElementsCallback(mutationRecord.target.parentNode);
        }

        if (
mutationRecord.type === 'attributes' && isWatched(mutationRecord.target) && ~ATTRIBUTES_WATCHED_FOR_MUTATION.indexOf(mutationRecord.attributeName)) {
          if (
mutationRecord.attributeName === 'class') {
            var 
_getCanonicalIcon getCanonicalIcon(classArray(mutationRecord.target)),
                
prefix _getCanonicalIcon.prefix,
                
iconName _getCanonicalIcon.iconName;

            if (
prefixmutationRecord.target.setAttribute('data-prefix'prefix);
            if (
iconNamemutationRecord.target.setAttribute('data-icon'iconName);
          } else {
            
nodeCallback(mutationRecord.target);
          }
        }
      });
    });
    if (!
IS_DOM) return;
    
mo.observe(observeMutationsRoot, {
      
childListtrue,
      
attributestrue,
      
characterDatatrue,
      
subtreetrue
    
});
  }
  function 
disconnect() {
    if (!
mo) return;
    
mo.disconnect();
  }

  function 
styleParser (node) {
    var 
style node.getAttribute('style');
    var 
val = [];

    if (
style) {
      
val style.split(';').reduce(function (accstyle) {
        var 
styles style.split(':');
        var 
prop styles[0];
        var 
value styles.slice(1);

        if (
prop && value.length 0) {
          
acc[prop] = value.join(':').trim();
        }

        return 
acc;
      }, {});
    }

    return 
val;
  }

  function 
classParser (node) {
    var 
existingPrefix node.getAttribute('data-prefix');
    var 
existingIconName node.getAttribute('data-icon');
    var 
innerText node.innerText !== undefined node.innerText.trim() : '';
    var 
val getCanonicalIcon(classArray(node));

    if (
existingPrefix && existingIconName) {
      
val.prefix existingPrefix;
      
val.iconName existingIconName;
    }

    if (
val.prefix && innerText.length 1) {
      
val.iconName byLigature(val.prefixnode.innerText);
    } else if (
val.prefix && innerText.length === 1) {
      
val.iconName byUnicode(val.prefixtoHex(node.innerText));
    }

    return 
val;
  }

  var 
parseTransformString = function parseTransformString(transformString) {
    var 
transform = {
      
size16,
      
x0,
      
y0,
      
flipXfalse,
      
flipYfalse,
      
rotate0
    
};

    if (!
transformString) {
      return 
transform;
    } else {
      return 
transformString.toLowerCase().split(' ').reduce(function (accn) {
        var 
parts n.toLowerCase().split('-');
        var 
first parts[0];
        var 
rest parts.slice(1).join('-');

        if (
first && rest === 'h') {
          
acc.flipX true;
          return 
acc;
        }

        if (
first && rest === 'v') {
          
acc.flipY true;
          return 
acc;
        }

        
rest parseFloat(rest);

        if (
isNaN(rest)) {
          return 
acc;
        }

        switch (
first) {
          case 
'grow':
            
acc.size acc.size rest;
            break;

          case 
'shrink':
            
acc.size acc.size rest;
            break;

          case 
'left':
            
acc.acc.rest;
            break;

          case 
'right':
            
acc.acc.rest;
            break;

          case 
'up':
            
acc.acc.rest;
            break;

          case 
'down':
            
acc.acc.rest;
            break;

          case 
'rotate':
            
acc.rotate acc.rotate rest;
            break;
        }

        return 
acc;
      }, 
transform);
    }
  };
  function 
transformParser (node) {
    return 
parseTransformString(node.getAttribute('data-fa-transform'));
  }

  function 
symbolParser (node) {
    var 
symbol node.getAttribute('data-fa-symbol');
    return 
symbol === null false symbol === '' true symbol;
  }

  function 
attributesParser (node) {
    var 
extraAttributes toArray(node.attributes).reduce(function (accattr) {
      if (
acc.name !== 'class' && acc.name !== 'style') {
        
acc[attr.name] = attr.value;
      }

      return 
acc;
    }, {});
    var 
title node.getAttribute('title');

    if (
config.autoA11y) {
      if (
title) {
        
extraAttributes['aria-labelledby'] = "".concat(config.replacementClass"-title-").concat(nextUniqueId());
      } else {
        
extraAttributes['aria-hidden'] = 'true';
        
extraAttributes['focusable'] = 'false';
      }
    }

    return 
extraAttributes;
  }

  function 
maskParser (node) {
    var 
mask node.getAttribute('data-fa-mask');

    if (!
mask) {
      return 
emptyCanonicalIcon();
    } else {
      return 
getCanonicalIcon(mask.split(' ').map(function (i) {
        return 
i.trim();
      }));
    }
  }

  function 
blankMeta() {
    return {
      
iconNamenull,
      
titlenull,
      
prefixnull,
      
transformmeaninglessTransform,
      
symbolfalse,
      
masknull,
      
extra: {
        
classes: [],
        
styles: {},
        
attributes: {}
      }
    };
  }
  function 
parseMeta(node) {
    var 
_classParser classParser(node),
        
iconName _classParser.iconName,
        
prefix _classParser.prefix,
        
extraClasses _classParser.rest;

    var 
extraStyles styleParser(node);
    var 
transform transformParser(node);
    var 
symbol symbolParser(node);
    var 
extraAttributes attributesParser(node);
    var 
mask maskParser(node);
    return {
      
iconNameiconName,
      
titlenode.getAttribute('title'),
      
prefixprefix,
      
transformtransform,
      
symbolsymbol,
      
maskmask,
      
extra: {
        
classesextraClasses,
        
stylesextraStyles,
        
attributesextraAttributes
      
}
    };
  }

  function 
MissingIcon(error) {
    
this.name 'MissingIcon';
    
this.message error || 'Icon unavailable';
    
this.stack = new Error().stack;
  }
  
MissingIcon.prototype Object.create(Error.prototype);
  
MissingIcon.prototype.constructor MissingIcon;

  var 
FILL = {
    
fill'currentColor'
  
};
  var 
ANIMATION_BASE = {
    
attributeType'XML',
    
repeatCount'indefinite',
    
dur'2s'
  
};
  var 
RING = {
    
tag'path',
    
attributes_objectSpread({}, FILL, {
      
d'M156.5,447.7l-12.6,29.5c-18.7-9.5-35.9-21.2-51.5-34.9l22.7-22.7C127.6,430.5,141.5,440,156.5,447.7z M40.6,272H8.5 c1.4,21.2,5.4,41.7,11.7,61.1L50,321.2C45.1,305.5,41.8,289,40.6,272z M40.6,240c1.4-18.8,5.2-37,11.1-54.1l-29.5-12.6 C14.7,194.3,10,216.7,8.5,240H40.6z M64.3,156.5c7.8-14.9,17.2-28.8,28.1-41.5L69.7,92.3c-13.7,15.6-25.5,32.8-34.9,51.5 L64.3,156.5z M397,419.6c-13.9,12-29.4,22.3-46.1,30.4l11.9,29.8c20.7-9.9,39.8-22.6,56.9-37.6L397,419.6z M115,92.4 c13.9-12,29.4-22.3,46.1-30.4l-11.9-29.8c-20.7,9.9-39.8,22.6-56.8,37.6L115,92.4z M447.7,355.5c-7.8,14.9-17.2,28.8-28.1,41.5 l22.7,22.7c13.7-15.6,25.5-32.9,34.9-51.5L447.7,355.5z M471.4,272c-1.4,18.8-5.2,37-11.1,54.1l29.5,12.6 c7.5-21.1,12.2-43.5,13.6-66.8H471.4z M321.2,462c-15.7,5-32.2,8.2-49.2,9.4v32.1c21.2-1.4,41.7-5.4,61.1-11.7L321.2,462z M240,471.4c-18.8-1.4-37-5.2-54.1-11.1l-12.6,29.5c21.1,7.5,43.5,12.2,66.8,13.6V471.4z M462,190.8c5,15.7,8.2,32.2,9.4,49.2h32.1 c-1.4-21.2-5.4-41.7-11.7-61.1L462,190.8z M92.4,397c-12-13.9-22.3-29.4-30.4-46.1l-29.8,11.9c9.9,20.7,22.6,39.8,37.6,56.9 L92.4,397z M272,40.6c18.8,1.4,36.9,5.2,54.1,11.1l12.6-29.5C317.7,14.7,295.3,10,272,8.5V40.6z M190.8,50 c15.7-5,32.2-8.2,49.2-9.4V8.5c-21.2,1.4-41.7,5.4-61.1,11.7L190.8,50z M442.3,92.3L419.6,115c12,13.9,22.3,29.4,30.5,46.1 l29.8-11.9C470,128.5,457.3,109.4,442.3,92.3z M397,92.4l22.7-22.7c-15.6-13.7-32.8-25.5-51.5-34.9l-12.6,29.5 C370.4,72.1,384.4,81.5,397,92.4z'
    
})
  };

  var 
OPACITY_ANIMATE _objectSpread({}, ANIMATION_BASE, {
    
attributeName'opacity'
  
});

  var 
DOT = {
    
tag'circle',
    
attributes_objectSpread({}, FILL, {
      
cx'256',
      
cy'364',
      
r'28'
    
}),
    
children: [{
      
tag'animate',
      
attributes_objectSpread({}, ANIMATION_BASE, {
        
attributeName'r',
        
values'28;14;28;28;14;28;'
      
})
    }, {
      
tag'animate',
      
attributes_objectSpread({}, OPACITY_ANIMATE, {
        
values'1;0;1;1;0;1;'
      
})
    }]
  };
  var 
QUESTION = {
    
tag'path',
    
attributes_objectSpread({}, FILL, {
      
opacity'1',
      
d'M263.7,312h-16c-6.6,0-12-5.4-12-12c0-71,77.4-63.9,77.4-107.8c0-20-17.8-40.2-57.4-40.2c-29.1,0-44.3,9.6-59.2,28.7 c-3.9,5-11.1,6-16.2,2.4l-13.1-9.2c-5.6-3.9-6.9-11.8-2.6-17.2c21.2-27.2,46.4-44.7,91.2-44.7c52.3,0,97.4,29.8,97.4,80.2 c0,67.6-77.4,63.5-77.4,107.8C275.7,306.6,270.3,312,263.7,312z'
    
}),
    
children: [{
      
tag'animate',
      
attributes_objectSpread({}, OPACITY_ANIMATE, {
        
values'1;0;0;0;0;1;'
      
})
    }]
  };
  var 
EXCLAMATION = {
    
tag'path',
    
attributes_objectSpread({}, FILL, {
      
opacity'0',
      
d'M232.5,134.5l7,168c0.3,6.4,5.6,11.5,12,11.5h9c6.4,0,11.7-5.1,12-11.5l7-168c0.3-6.8-5.2-12.5-12-12.5h-23 C237.7,122,232.2,127.7,232.5,134.5z'
    
}),
    
children: [{
      
tag'animate',
      
attributes_objectSpread({}, OPACITY_ANIMATE, {
        
values'0;0;1;1;0;0;'
      
})
    }]
  };
  var 
missing = {
    
tag'g',
    
children: [RINGDOTQUESTIONEXCLAMATION]
  };

  var 
styles$= namespace.styles;
  function 
findIcon(iconNameprefix) {
    return new 
picked(function (resolvereject) {
      var 
val = {
        
foundfalse,
        
width512,
        
height512,
        
iconmissing
      
};

      if (
iconName && prefix && styles$2[prefix] && styles$2[prefix][iconName]) {
        var 
icon styles$2[prefix][iconName];
        var 
width icon[0];
        var 
height icon[1];
        var 
vectorData icon.slice(4);
        
val = {
          
foundtrue,
          
widthwidth,
          
heightheight,
          
icon: {
            
tag'path',
            
attributes: {
              
fill'currentColor',
              
dvectorData[0]
            }
          }
        };
        return 
resolve(val);
      }

      if (
iconName && prefix && !config.showMissingIcons) {
        
reject(new MissingIcon("Icon is missing for prefix ".concat(prefix" with icon name ").concat(iconName)));
      } else {
        
resolve(val);
      }
    });
  }

  var 
styles$= namespace.styles;

  function 
generateSvgReplacementMutation(nodenodeMeta) {
    var 
iconName nodeMeta.iconName,
        
title nodeMeta.title,
        
prefix nodeMeta.prefix,
        
transform nodeMeta.transform,
        
symbol nodeMeta.symbol,
        
mask nodeMeta.mask,
        
extra nodeMeta.extra;
    return new 
picked(function (resolvereject) {
      
picked.all([findIcon(iconNameprefix), findIcon(mask.iconNamemask.prefix)]).then(function (_ref) {
        var 
_ref2 _slicedToArray(_ref2),
            
main _ref2[0],
            
mask _ref2[1];

        
resolve([nodemakeInlineSvgAbstract({
          
icons: {
            
mainmain,
            
maskmask
          
},
          
prefixprefix,
          
iconNameiconName,
          
transformtransform,
          
symbolsymbol,
          
maskmask,
          
titletitle,
          
extraextra,
          
watchabletrue
        
})]);
      });
    });
  }

  function 
generateLayersText(nodenodeMeta) {
    var 
title nodeMeta.title,
        
transform nodeMeta.transform,
        
extra nodeMeta.extra;
    var 
width null;
    var 
height null;

    if (
IS_IE) {
      var 
computedFontSize parseInt(getComputedStyle(node).fontSize10);
      var 
boundingClientRect node.getBoundingClientRect();
      
width boundingClientRect.width computedFontSize;
      
height boundingClientRect.height computedFontSize;
    }

    if (
config.autoA11y && !title) {
      
extra.attributes['aria-hidden'] = 'true';
    }

    return 
picked.resolve([nodemakeLayersTextAbstract({
      
contentnode.innerHTML,
      
widthwidth,
      
heightheight,
      
transformtransform,
      
titletitle,
      
extraextra,
      
watchabletrue
    
})]);
  }

  function 
generateMutation(node) {
    var 
nodeMeta parseMeta(node);

    if (~
nodeMeta.extra.classes.indexOf(LAYERS_TEXT_CLASSNAME)) {
      return 
generateLayersText(nodenodeMeta);
    } else {
      return 
generateSvgReplacementMutation(nodenodeMeta);
    }
  }

  function 
onTree(root) {
    var 
callback arguments.length && arguments[1] !== undefined arguments[1] : null;
    if (!
IS_DOM) return;
    var 
htmlClassList DOCUMENT.documentElement.classList;

    var 
hclAdd = function hclAdd(suffix) {
      return 
htmlClassList.add("".concat(HTML_CLASS_I2SVG_BASE_CLASS"-").concat(suffix));
    };

    var 
hclRemove = function hclRemove(suffix) {
      return 
htmlClassList.remove("".concat(HTML_CLASS_I2SVG_BASE_CLASS"-").concat(suffix));
    };

    var 
prefixes config.autoFetchSvg Object.keys(PREFIX_TO_STYLE) : Object.keys(styles$3);
    var 
prefixesDomQuery = [".".concat(LAYERS_TEXT_CLASSNAME":not([").concat(DATA_FA_I2SVG"])")].concat(prefixes.map(function (p) {
      return 
".".concat(p":not([").concat(DATA_FA_I2SVG"])");
    })).
join(', ');

    if (
prefixesDomQuery.length === 0) {
      return;
    }

    var 
candidates = [];

    try {
      
candidates toArray(root.querySelectorAll(prefixesDomQuery));
    } catch (
e) {// noop
    
}

    if (
candidates.length 0) {
      
hclAdd('pending');
      
hclRemove('complete');
    } else {
      return;
    }

    var 
mark perf.begin('onTree');
    var 
mutations candidates.reduce(function (accnode) {
      try {
        var 
mutation generateMutation(node);

        if (
mutation) {
          
acc.push(mutation);
        }
      } catch (
e) {
        if (!
PRODUCTION) {
          if (
instanceof MissingIcon) {
            
console.error(e);
          }
        }
      }

      return 
acc;
    }, []);
    return new 
picked(function (resolvereject) {
      
picked.all(mutations).then(function (resolvedMutations) {
        
perform(resolvedMutations, function () {
          
hclAdd('active');
          
hclAdd('complete');
          
hclRemove('pending');
          if (
typeof callback === 'function'callback();
          
mark();
          
resolve();
        });
      }).catch(function () {
        
mark();
        
reject();
      });
    });
  }
  function 
onNode(node) {
    var 
callback arguments.length && arguments[1] !== undefined arguments[1] : null;
    
generateMutation(node).then(function (mutation) {
      if (
mutation) {
        
perform([mutation], callback);
      }
    });
  }

  function 
replaceForPosition(nodeposition) {
    var 
pendingAttribute "".concat(DATA_FA_PSEUDO_ELEMENT_PENDING).concat(position.replace(':''-'));
    return new 
picked(function (resolvereject) {
      if (
node.getAttribute(pendingAttribute) !== null) {
        
// This node is already being processed
        
return resolve();
      }

      var 
children toArray(node.children);
      var 
alreadyProcessedPseudoElement children.filter(function (c) {
        return 
c.getAttribute(DATA_FA_PSEUDO_ELEMENT) === position;
      })[
0];
      var 
styles WINDOW.getComputedStyle(nodeposition);
      var 
fontFamily styles.getPropertyValue('font-family').match(FONT_FAMILY_PATTERN);
      var 
fontWeight styles.getPropertyValue('font-weight');

      if (
alreadyProcessedPseudoElement && !fontFamily) {
        
// If we've already processed it but the current computed style does not result in a font-family,
        // that probably means that a class name that was previously present to make the icon has been
        // removed. So we now should delete the icon.
        
node.removeChild(alreadyProcessedPseudoElement);
        return 
resolve();
      } else if (
fontFamily) {
        var 
content styles.getPropertyValue('content');
        var 
prefix = ~['Light''Regular''Solid''Brands'].indexOf(fontFamily[1]) ? STYLE_TO_PREFIX[fontFamily[1].toLowerCase()] : FONT_WEIGHT_TO_PREFIX[fontWeight];
        var 
hexValue toHex(content.length === content.substr(11) : content);
        var 
iconName byUnicode(prefixhexValue);
        var 
iconIdentifier iconName// Only convert the pseudo element in this :before/:after position into an icon if we haven't
        // already done so with the same prefix and iconName

        
if (iconName && (!alreadyProcessedPseudoElement || alreadyProcessedPseudoElement.getAttribute(DATA_PREFIX) !== prefix || alreadyProcessedPseudoElement.getAttribute(DATA_ICON) !== iconIdentifier)) {
          
node.setAttribute(pendingAttributeiconIdentifier);

          if (
alreadyProcessedPseudoElement) {
            
// Delete the old one, since we're replacing it with a new one
            
node.removeChild(alreadyProcessedPseudoElement);
          }

          var 
meta blankMeta();
          var 
extra meta.extra;
          
extra.attributes[DATA_FA_PSEUDO_ELEMENT] = position;
          
findIcon(iconNameprefix).then(function (main) {
            var abstract = 
makeInlineSvgAbstract(_objectSpread({}, meta, {
              
icons: {
                
mainmain,
                
maskemptyCanonicalIcon()
              },
              
prefixprefix,
              
iconNameiconIdentifier,
              
extraextra,
              
watchabletrue
            
}));
            var 
element DOCUMENT.createElement('svg');

            if (
position === ':before') {
              
node.insertBefore(elementnode.firstChild);
            } else {
              
node.appendChild(element);
            }

            
element.outerHTML = abstract.map(function (a) {
              return 
toHtml(a);
            }).
join('n');
            
node.removeAttribute(pendingAttribute);
            
resolve();
          }).catch(
reject);
        } else {
          
resolve();
        }
      } else {
        
resolve();
      }
    });
  }

  function 
replace(node) {
    return 
picked.all([replaceForPosition(node':before'), replaceForPosition(node':after')]);
  }

  function 
processable(node) {
    return 
node.parentNode !== document.head && !~TAGNAMES_TO_SKIP_FOR_PSEUDOELEMENTS.indexOf(node.tagName.toUpperCase()) && !node.getAttribute(DATA_FA_PSEUDO_ELEMENT) && (!node.parentNode || node.parentNode.tagName !== 'svg');
  }

  function 
searchPseudoElements (root) {
    if (!
IS_DOM) return;
    return new 
picked(function (resolvereject) {
      var 
operations toArray(root.querySelectorAll('*')).filter(processable).map(replace);
      var 
end perf.begin('searchPseudoElements');
      
disableObservation();
      
picked.all(operations).then(function () {
        
end();
        
enableObservation();
        
resolve();
      }).catch(function () {
        
end();
        
enableObservation();
        
reject();
      });
    });
  }

  var 
baseStyles "svg:not(:root).svg-inline--fa{overflow:visible}.svg-inline--fa{display:inline-block;font-size:inherit;height:1em;overflow:visible;vertical-align:-.125em}.svg-inline--fa.fa-lg{vertical-align:-.225em}.svg-inline--fa.fa-w-1{width:.0625em}.svg-inline--fa.fa-w-2{width:.125em}.svg-inline--fa.fa-w-3{width:.1875em}.svg-inline--fa.fa-w-4{width:.25em}.svg-inline--fa.fa-w-5{width:.3125em}.svg-inline--fa.fa-w-6{width:.375em}.svg-inline--fa.fa-w-7{width:.4375em}.svg-inline--fa.fa-w-8{width:.5em}.svg-inline--fa.fa-w-9{width:.5625em}.svg-inline--fa.fa-w-10{width:.625em}.svg-inline--fa.fa-w-11{width:.6875em}.svg-inline--fa.fa-w-12{width:.75em}.svg-inline--fa.fa-w-13{width:.8125em}.svg-inline--fa.fa-w-14{width:.875em}.svg-inline--fa.fa-w-15{width:.9375em}.svg-inline--fa.fa-w-16{width:1em}.svg-inline--fa.fa-w-17{width:1.0625em}.svg-inline--fa.fa-w-18{width:1.125em}.svg-inline--fa.fa-w-19{width:1.1875em}.svg-inline--fa.fa-w-20{width:1.25em}.svg-inline--fa.fa-pull-left{margin-right:.3em;width:auto}.svg-inline--fa.fa-pull-right{margin-left:.3em;width:auto}.svg-inline--fa.fa-border{height:1.5em}.svg-inline--fa.fa-li{width:2em}.svg-inline--fa.fa-fw{width:1.25em}.fa-layers svg.svg-inline--fa{bottom:0;left:0;margin:auto;position:absolute;right:0;top:0}.fa-layers{display:inline-block;height:1em;position:relative;text-align:center;vertical-align:-.125em;width:1em}.fa-layers svg.svg-inline--fa{-webkit-transform-origin:center center;transform-origin:center center}.fa-layers-counter,.fa-layers-text{display:inline-block;position:absolute;text-align:center}.fa-layers-text{left:50%;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);-webkit-transform-origin:center center;transform-origin:center center}.fa-layers-counter{background-color:#ff253a;border-radius:1em;-webkit-box-sizing:border-box;box-sizing:border-box;color:#fff;height:1.5em;line-height:1;max-width:5em;min-width:1.5em;overflow:hidden;padding:.25em;right:0;text-overflow:ellipsis;top:0;-webkit-transform:scale(.25);transform:scale(.25);-webkit-transform-origin:top right;transform-origin:top right}.fa-layers-bottom-right{bottom:0;right:0;top:auto;-webkit-transform:scale(.25);transform:scale(.25);-webkit-transform-origin:bottom right;transform-origin:bottom right}.fa-layers-bottom-left{bottom:0;left:0;right:auto;top:auto;-webkit-transform:scale(.25);transform:scale(.25);-webkit-transform-origin:bottom left;transform-origin:bottom left}.fa-layers-top-right{right:0;top:0;-webkit-transform:scale(.25);transform:scale(.25);-webkit-transform-origin:top right;transform-origin:top right}.fa-layers-top-left{left:0;right:auto;top:0;-webkit-transform:scale(.25);transform:scale(.25);-webkit-transform-origin:top left;transform-origin:top left}.fa-lg{font-size:1.3333333333em;line-height:.75em;vertical-align:-.0667em}.fa-xs{font-size:.75em}.fa-sm{font-size:.875em}.fa-1x{font-size:1em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-6x{font-size:6em}.fa-7x{font-size:7em}.fa-8x{font-size:8em}.fa-9x{font-size:9em}.fa-10x{font-size:10em}.fa-fw{text-align:center;width:1.25em}.fa-ul{list-style-type:none;margin-left:2.5em;padding-left:0}.fa-ul>li{position:relative}.fa-li{left:-2em;position:absolute;text-align:center;width:2em;line-height:inherit}.fa-border{border:solid .08em #eee;border-radius:.1em;padding:.2em .25em .15em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa.fa-pull-left,.fab.fa-pull-left,.fal.fa-pull-left,.far.fa-pull-left,.fas.fa-pull-left{margin-right:.3em}.fa.fa-pull-right,.fab.fa-pull-right,.fal.fa-pull-right,.far.fa-pull-right,.fas.fa-pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}.fa-pulse{-webkit-animation:fa-spin 1s infinite steps(8);animation:fa-spin 1s infinite steps(8)}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0);transform:rotate(0)}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0);transform:rotate(0)}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.fa-rotate-90{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-webkit-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-webkit-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-webkit-transform:scale(-1,1);transform:scale(-1,1)}.fa-flip-vertical{-webkit-transform:scale(1,-1);transform:scale(1,-1)}.fa-flip-both,.fa-flip-horizontal.fa-flip-vertical{-webkit-transform:scale(-1,-1);transform:scale(-1,-1)}:root .fa-flip-both,:root .fa-flip-horizontal,:root .fa-flip-vertical,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-rotate-90{-webkit-filter:none;filter:none}.fa-stack{display:inline-block;height:2em;position:relative;width:2.5em}.fa-stack-1x,.fa-stack-2x{bottom:0;left:0;margin:auto;position:absolute;right:0;top:0}.svg-inline--fa.fa-stack-1x{height:1em;width:1.25em}.svg-inline--fa.fa-stack-2x{height:2em;width:2.5em}.fa-inverse{color:#fff}.sr-only{border:0;clip:rect(0,0,0,0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.sr-only-focusable:active,.sr-only-focusable:focus{clip:auto;height:auto;margin:0;overflow:visible;position:static;width:auto}";

  function 
css () {
    var 
dfp DEFAULT_FAMILY_PREFIX;
    var 
drc DEFAULT_REPLACEMENT_CLASS;
    var 
fp config.familyPrefix;
    var 
rc config.replacementClass;
    var 
baseStyles;

    if (
fp !== dfp || rc !== drc) {
      var 
dPatt = new RegExp("\.".concat(dfp"\-"), 'g');
      var 
rPatt = new RegExp("\.".concat(drc), 'g');
      
s.replace(dPatt".".concat(fp"-")).replace(rPatt".".concat(rc));
    }

    return 
s;
  }

  var 
Library =
  
/*#__PURE__*/
  
function () {
    function 
Library() {
      
_classCallCheck(thisLibrary);

      
this.definitions = {};
    }

    
_createClass(Library, [{
      
key"add",
      
value: function add() {
        var 
_this this;

        for (var 
_len arguments.lengthdefinitions = new Array(_len), _key 0_key _len_key++) {
          
definitions[_key] = arguments[_key];
        }

        var 
additions definitions.reduce(this._pullDefinitions, {});
        
Object.keys(additions).forEach(function (key) {
          
_this.definitions[key] = _objectSpread({}, _this.definitions[key] || {}, additions[key]);
          
defineIcons(keyadditions[key]);
          
build();
        });
      }
    }, {
      
key"reset",
      
value: function reset() {
        
this.definitions = {};
      }
    }, {
      
key"_pullDefinitions",
      
value: function _pullDefinitions(additionsdefinition) {
        var 
normalized definition.prefix && definition.iconName && definition.icon ? {
          
0definition
        
} : definition;
        
Object.keys(normalized).map(function (key) {
          var 
_normalized$key normalized[key],
              
prefix _normalized$key.prefix,
              
iconName _normalized$key.iconName,
              
icon _normalized$key.icon;
          if (!
additions[prefix]) additions[prefix] = {};
          
additions[prefix][iconName] = icon;
        });
        return 
additions;
      }
    }]);

    return 
Library;
  }();

  function 
prepIcon(icon) {
    var 
width icon[0];
    var 
height icon[1];
    var 
vectorData icon.slice(4);
    return {
      
foundtrue,
      
widthwidth,
      
heightheight,
      
icon: {
        
tag'path',
        
attributes: {
          
fill'currentColor',
          
dvectorData[0]
        }
      }
    };
  }

  function 
ensureCss() {
    if (
config.autoAddCss && !_cssInserted) {
      
insertCss(css());

      
_cssInserted true;
    }
  }

  function 
apiObject(valabstractCreator) {
    
Object.defineProperty(val'abstract', {
      
getabstractCreator
    
});
    
Object.defineProperty(val'html', {
      
get: function get() {
        return 
val.abstract.map(function (a) {
          return 
toHtml(a);
        });
      }
    });
    
Object.defineProperty(val'node', {
      
get: function get() {
        if (!
IS_DOM) return;
        var 
container DOCUMENT.createElement('div');
        
container.innerHTML val.html;
        return 
container.children;
      }
    });
    return 
val;
  }

  function 
findIconDefinition(iconLookup) {
    var 
_iconLookup$prefix iconLookup.prefix,
        
prefix _iconLookup$prefix === void 0 'fa' _iconLookup$prefix,
        
iconName iconLookup.iconName;
    if (!
iconName) return;
    return 
iconFromMapping(library.definitionsprefixiconName) || iconFromMapping(namespace.stylesprefixiconName);
  }

  function 
resolveIcons(next) {
    return function (
maybeIconDefinition) {
      var 
params arguments.length && arguments[1] !== undefined arguments[1] : {};
      var 
iconDefinition = (maybeIconDefinition || {}).icon maybeIconDefinition findIconDefinition(maybeIconDefinition || {});
      var 
mask params.mask;

      if (
mask) {
        
mask = (mask || {}).icon mask findIconDefinition(mask || {});
      }

      return 
next(iconDefinition_objectSpread({}, params, {
        
maskmask
      
}));
    };
  }

  var 
library = new Library();
  var 
noAuto = function noAuto() {
    
config.autoReplaceSvg false;
    
config.observeMutations false;
    
disconnect();
  };
  var 
_cssInserted false;
  var 
dom = {
    
i2svg: function i2svg() {
      var 
params arguments.length && arguments[0] !== undefined arguments[0] : {};

      if (
IS_DOM) {
        
ensureCss();
        var 
_params$node params.node,
            
node _params$node === void 0 DOCUMENT _params$node,
            
_params$callback params.callback,
            
callback _params$callback === void 0 ? function () {} : _params$callback;

        if (
config.searchPseudoElements) {
          
searchPseudoElements(node);
        }

        return 
onTree(nodecallback);
      } else {
        return 
picked.reject('Operation requires a DOM of some kind.');
      }
    },
    
csscss,
    
insertCss: function insertCss$$1() {
      if (!
_cssInserted) {
        
insertCss(css());

        
_cssInserted true;
      }
    },
    
watch: function watch() {
      var 
params arguments.length && arguments[0] !== undefined arguments[0] : {};
      var 
autoReplaceSvgRoot params.autoReplaceSvgRoot,
          
observeMutationsRoot params.observeMutationsRoot;

      if (
config.autoReplaceSvg === false) {
        
config.autoReplaceSvg true;
      }

      
config.observeMutations true;
      
domready(function () {
        
autoReplace({
          
autoReplaceSvgRootautoReplaceSvgRoot
        
});
        
observe({
          
treeCallbackonTree,
          
nodeCallbackonNode,
          
pseudoElementsCallbacksearchPseudoElements,
          
observeMutationsRootobserveMutationsRoot
        
});
      });
    }
  };
  var 
parse = {
    
transform: function transform(transformString) {
      return 
parseTransformString(transformString);
    }
  };
  var 
icon resolveIcons(function (iconDefinition) {
    var 
params arguments.length && arguments[1] !== undefined arguments[1] : {};
    var 
_params$transform params.transform,
        
transform _params$transform === void 0 meaninglessTransform _params$transform,
        
_params$symbol params.symbol,
        
symbol _params$symbol === void 0 false _params$symbol,
        
_params$mask params.mask,
        
mask _params$mask === void 0 null _params$mask,
        
_params$title params.title,
        
title _params$title === void 0 null _params$title,
        
_params$classes params.classes,
        
classes _params$classes === void 0 ? [] : _params$classes,
        
_params$attributes params.attributes,
        
attributes _params$attributes === void 0 ? {} : _params$attributes,
        
_params$styles params.styles,
        
styles _params$styles === void 0 ? {} : _params$styles;
    if (!
iconDefinition) return;
    var 
prefix iconDefinition.prefix,
        
iconName iconDefinition.iconName,
        
icon iconDefinition.icon;
    return 
apiObject(_objectSpread({
      
type'icon'
    
}, iconDefinition), function () {
      
ensureCss();

      if (
config.autoA11y) {
        if (
title) {
          
attributes['aria-labelledby'] = "".concat(config.replacementClass"-title-").concat(nextUniqueId());
        } else {
          
attributes['aria-hidden'] = 'true';
          
attributes['focusable'] = 'false';
        }
      }

      return 
makeInlineSvgAbstract({
        
icons: {
          
mainprepIcon(icon),
          
maskmask prepIcon(mask.icon) : {
            
foundfalse,
            
widthnull,
            
heightnull,
            
icon: {}
          }
        },
        
prefixprefix,
        
iconNameiconName,
        
transform_objectSpread({}, meaninglessTransformtransform),
        
symbolsymbol,
        
titletitle,
        
extra: {
          
attributesattributes,
          
stylesstyles,
          
classesclasses
        
}
      });
    });
  });
  var 
text = function text(content) {
    var 
params arguments.length && arguments[1] !== undefined arguments[1] : {};
    var 
_params$transform2 params.transform,
        
transform _params$transform2 === void 0 meaninglessTransform _params$transform2,
        
_params$title2 params.title,
        
title _params$title2 === void 0 null _params$title2,
        
_params$classes2 params.classes,
        
classes _params$classes2 === void 0 ? [] : _params$classes2,
        
_params$attributes2 params.attributes,
        
attributes _params$attributes2 === void 0 ? {} : _params$attributes2,
        
_params$styles2 params.styles,
        
styles _params$styles2 === void 0 ? {} : _params$styles2;
    return 
apiObject({
      
type'text',
      
contentcontent
    
}, function () {
      
ensureCss();
      return 
makeLayersTextAbstract({
        
contentcontent,
        
transform_objectSpread({}, meaninglessTransformtransform),
        
titletitle,
        
extra: {
          
attributesattributes,
          
stylesstyles,
          
classes: ["".concat(config.familyPrefix"-layers-text")].concat(_toConsumableArray(classes))
        }
      });
    });
  };
  var 
counter = function counter(content) {
    var 
params arguments.length && arguments[1] !== undefined arguments[1] : {};
    var 
_params$title3 params.title,
        
title _params$title3 === void 0 null _params$title3,
        
_params$classes3 params.classes,
        
classes _params$classes3 === void 0 ? [] : _params$classes3,
        
_params$attributes3 params.attributes,
        
attributes _params$attributes3 === void 0 ? {} : _params$attributes3,
        
_params$styles3 params.styles,
        
styles _params$styles3 === void 0 ? {} : _params$styles3;
    return 
apiObject({
      
type'counter',
      
contentcontent
    
}, function () {
      
ensureCss();
      return 
makeLayersCounterAbstract({
        
contentcontent.toString(),
        
titletitle,
        
extra: {
          
attributesattributes,
          
stylesstyles,
          
classes: ["".concat(config.familyPrefix"-layers-counter")].concat(_toConsumableArray(classes))
        }
      });
    });
  };
  var 
layer = function layer(assembler) {
    return 
apiObject({
      
type'layer'
    
}, function () {
      
ensureCss();
      var 
children = [];
      
assembler(function (args) {
        Array.
isArray(args) ? args.map(function (a) {
          
children children.concat(a.abstract);
        }) : 
children children.concat(args.abstract);
      });
      return [{
        
tag'span',
        
attributes: {
          class: 
"".concat(config.familyPrefix"-layers")
        },
        
childrenchildren
      
}];
    });
  };
  var 
api = {
    
noAutonoAuto,
    
configconfig,
    
domdom,
    
librarylibrary,
    
parseparse,
    
findIconDefinitionfindIconDefinition,
    
iconicon,
    
texttext,
    
countercounter,
    
layerlayer,
    
toHtmltoHtml
  
};

  var 
autoReplace = function autoReplace() {
    var 
params arguments.length && arguments[0] !== undefined arguments[0] : {};
    var 
_params$autoReplaceSv params.autoReplaceSvgRoot,
        
autoReplaceSvgRoot _params$autoReplaceSv === void 0 DOCUMENT _params$autoReplaceSv;
    if ((
Object.keys(namespace.styles).length || config.autoFetchSvg) && IS_DOM && config.autoReplaceSvgapi.dom.i2svg({
      
nodeautoReplaceSvgRoot
    
});
  };

  function 
bootstrap() {
    if (
IS_BROWSER) {
      if (!
WINDOW.FontAwesome) {
        
WINDOW.FontAwesome api;
      }

      
domready(function () {
        
autoReplace();
        
observe({
          
treeCallbackonTree,
          
nodeCallbackonNode,
          
pseudoElementsCallbacksearchPseudoElements
        
});
      });
    }

    namespace.
hooks _objectSpread({}, namespace.hooks, {
      
addPack: function addPack(prefixicons) {
        namespace.
styles[prefix] = _objectSpread({}, namespace.styles[prefix] || {}, icons);
        
build();
        
autoReplace();
      },
      
addShims: function addShims(shims) {
        var 
_namespace$shims;

        (
_namespace$shims = namespace.shims).push.apply(_namespace$shims_toConsumableArray(shims));

        
build();
        
autoReplace();
      }
    });
  }

  
bunker(bootstrap);

}());
?>
Онлайн: 1
Реклама