| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010 | (function (global, factory) {	typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :	typeof define === 'function' && define.amd ? define(factory) :	(global.BrowserSprite = factory());}(this, (function () { 'use strict';var commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};function createCommonjsModule(fn, module) {	return module = { exports: {} }, fn(module, module.exports), module.exports;}var deepmerge = createCommonjsModule(function (module, exports) {(function (root, factory) {    if (typeof undefined === 'function' && undefined.amd) {        undefined(factory);    } else {        module.exports = factory();    }}(commonjsGlobal, function () {function isMergeableObject(val) {    var nonNullObject = val && typeof val === 'object';    return nonNullObject        && Object.prototype.toString.call(val) !== '[object RegExp]'        && Object.prototype.toString.call(val) !== '[object Date]'}function emptyTarget(val) {    return Array.isArray(val) ? [] : {}}function cloneIfNecessary(value, optionsArgument) {    var clone = optionsArgument && optionsArgument.clone === true;    return (clone && isMergeableObject(value)) ? deepmerge(emptyTarget(value), value, optionsArgument) : value}function defaultArrayMerge(target, source, optionsArgument) {    var destination = target.slice();    source.forEach(function(e, i) {        if (typeof destination[i] === 'undefined') {            destination[i] = cloneIfNecessary(e, optionsArgument);        } else if (isMergeableObject(e)) {            destination[i] = deepmerge(target[i], e, optionsArgument);        } else if (target.indexOf(e) === -1) {            destination.push(cloneIfNecessary(e, optionsArgument));        }    });    return destination}function mergeObject(target, source, optionsArgument) {    var destination = {};    if (isMergeableObject(target)) {        Object.keys(target).forEach(function (key) {            destination[key] = cloneIfNecessary(target[key], optionsArgument);        });    }    Object.keys(source).forEach(function (key) {        if (!isMergeableObject(source[key]) || !target[key]) {            destination[key] = cloneIfNecessary(source[key], optionsArgument);        } else {            destination[key] = deepmerge(target[key], source[key], optionsArgument);        }    });    return destination}function deepmerge(target, source, optionsArgument) {    var array = Array.isArray(source);    var options = optionsArgument || { arrayMerge: defaultArrayMerge };    var arrayMerge = options.arrayMerge || defaultArrayMerge;    if (array) {        return Array.isArray(target) ? arrayMerge(target, source, optionsArgument) : cloneIfNecessary(source, optionsArgument)    } else {        return mergeObject(target, source, optionsArgument)    }}deepmerge.all = function deepmergeAll(array, optionsArgument) {    if (!Array.isArray(array) || array.length < 2) {        throw new Error('first argument should be an array with at least two elements')    }    // we are sure there are at least 2 values, so it is safe to have no initial value    return array.reduce(function(prev, next) {        return deepmerge(prev, next, optionsArgument)    })};return deepmerge}));});//      // An event handler can take an optional event argument// and should not return a value                                          // An array of all currently registered event handlers for a type                                            // A map of event types and their corresponding event handlers.                                                             /** Mitt: Tiny (~200b) functional event emitter / pubsub. *  @name mitt *  @returns {Mitt} */function mitt(all                 ) {	all = all || Object.create(null);	return {		/**		 * Register an event handler for the given type.		 *		 * @param  {String} type	Type of event to listen for, or `"*"` for all events		 * @param  {Function} handler Function to call in response to given event		 * @memberOf mitt		 */		on: function on(type        , handler              ) {			(all[type] || (all[type] = [])).push(handler);		},		/**		 * Remove an event handler for the given type.		 *		 * @param  {String} type	Type of event to unregister `handler` from, or `"*"`		 * @param  {Function} handler Handler function to remove		 * @memberOf mitt		 */		off: function off(type        , handler              ) {			if (all[type]) {				all[type].splice(all[type].indexOf(handler) >>> 0, 1);			}		},		/**		 * Invoke all handlers for the given type.		 * If present, `"*"` handlers are invoked after type-matched handlers.		 *		 * @param {String} type  The event type to invoke		 * @param {Any} [evt]  Any value (object is recommended and powerful), passed to each handler		 * @memberof mitt		 */		emit: function emit(type        , evt     ) {			(all[type] || []).map(function (handler) { handler(evt); });			(all['*'] || []).map(function (handler) { handler(type, evt); });		}	};}var namespaces_1 = createCommonjsModule(function (module, exports) {var namespaces = {  svg: {    name: 'xmlns',    uri: 'http://www.w3.org/2000/svg'  },  xlink: {    name: 'xmlns:xlink',    uri: 'http://www.w3.org/1999/xlink'  }};exports.default = namespaces;module.exports = exports.default;});/** * @param {Object} attrs * @return {string} */var objectToAttrsString = function (attrs) {  return Object.keys(attrs).map(function (attr) {    var value = attrs[attr].toString().replace(/"/g, '"');    return (attr + "=\"" + value + "\"");  }).join(' ');};var svg = namespaces_1.svg;var xlink = namespaces_1.xlink;var defaultAttrs = {};defaultAttrs[svg.name] = svg.uri;defaultAttrs[xlink.name] = xlink.uri;/** * @param {string} [content] * @param {Object} [attributes] * @return {string} */var wrapInSvgString = function (content, attributes) {  if ( content === void 0 ) content = '';  var attrs = deepmerge(defaultAttrs, attributes || {});  var attrsRendered = objectToAttrsString(attrs);  return ("<svg " + attrsRendered + ">" + content + "</svg>");};var svg$1 = namespaces_1.svg;var xlink$1 = namespaces_1.xlink;var defaultConfig = {  attrs: ( obj = {    style: ['position: absolute', 'width: 0', 'height: 0'].join('; '),    'aria-hidden': 'true'  }, obj[svg$1.name] = svg$1.uri, obj[xlink$1.name] = xlink$1.uri, obj )};var obj;var Sprite = function Sprite(config) {  this.config = deepmerge(defaultConfig, config || {});  this.symbols = [];};/** * Add new symbol. If symbol with the same id exists it will be replaced. * @param {SpriteSymbol} symbol * @return {boolean} `true` - symbol was added, `false` - replaced */Sprite.prototype.add = function add (symbol) {  var ref = this;    var symbols = ref.symbols;  var existing = this.find(symbol.id);  if (existing) {    symbols[symbols.indexOf(existing)] = symbol;    return false;  }  symbols.push(symbol);  return true;};/** * Remove symbol & destroy it * @param {string} id * @return {boolean} `true` - symbol was found & successfully destroyed, `false` - otherwise */Sprite.prototype.remove = function remove (id) {  var ref = this;    var symbols = ref.symbols;  var symbol = this.find(id);  if (symbol) {    symbols.splice(symbols.indexOf(symbol), 1);    symbol.destroy();    return true;  }  return false;};/** * @param {string} id * @return {SpriteSymbol|null} */Sprite.prototype.find = function find (id) {  return this.symbols.filter(function (s) { return s.id === id; })[0] || null;};/** * @param {string} id * @return {boolean} */Sprite.prototype.has = function has (id) {  return this.find(id) !== null;};/** * @return {string} */Sprite.prototype.stringify = function stringify () {  var ref = this.config;    var attrs = ref.attrs;  var stringifiedSymbols = this.symbols.map(function (s) { return s.stringify(); }).join('');  return wrapInSvgString(stringifiedSymbols, attrs);};/** * @return {string} */Sprite.prototype.toString = function toString () {  return this.stringify();};Sprite.prototype.destroy = function destroy () {  this.symbols.forEach(function (s) { return s.destroy(); });};var SpriteSymbol = function SpriteSymbol(ref) {  var id = ref.id;  var viewBox = ref.viewBox;  var content = ref.content;  this.id = id;  this.viewBox = viewBox;  this.content = content;};/** * @return {string} */SpriteSymbol.prototype.stringify = function stringify () {  return this.content;};/** * @return {string} */SpriteSymbol.prototype.toString = function toString () {  return this.stringify();};SpriteSymbol.prototype.destroy = function destroy () {    var this$1 = this;  ['id', 'viewBox', 'content'].forEach(function (prop) { return delete this$1[prop]; });};/** * @param {string} content * @return {Element} */var parse = function (content) {  var hasImportNode = !!document.importNode;  var doc = new DOMParser().parseFromString(content, 'image/svg+xml').documentElement;  /**   * Fix for browser which are throwing WrongDocumentError   * if you insert an element which is not part of the document   * @see http://stackoverflow.com/a/7986519/4624403   */  if (hasImportNode) {    return document.importNode(doc, true);  }  return doc;};var BrowserSpriteSymbol = (function (SpriteSymbol$$1) {  function BrowserSpriteSymbol () {    SpriteSymbol$$1.apply(this, arguments);  }  if ( SpriteSymbol$$1 ) BrowserSpriteSymbol.__proto__ = SpriteSymbol$$1;  BrowserSpriteSymbol.prototype = Object.create( SpriteSymbol$$1 && SpriteSymbol$$1.prototype );  BrowserSpriteSymbol.prototype.constructor = BrowserSpriteSymbol;  var prototypeAccessors = { isMounted: {} };  prototypeAccessors.isMounted.get = function () {    return !!this.node;  };  /**   * @param {Element} node   * @return {BrowserSpriteSymbol}   */  BrowserSpriteSymbol.createFromExistingNode = function createFromExistingNode (node) {    return new BrowserSpriteSymbol({      id: node.getAttribute('id'),      viewBox: node.getAttribute('viewBox'),      content: node.outerHTML    });  };  BrowserSpriteSymbol.prototype.destroy = function destroy () {    if (this.isMounted) {      this.unmount();    }    SpriteSymbol$$1.prototype.destroy.call(this);  };  /**   * @param {Element|string} target   * @return {Element}   */  BrowserSpriteSymbol.prototype.mount = function mount (target) {    if (this.isMounted) {      return this.node;    }    var mountTarget = typeof target === 'string' ? document.querySelector(target) : target;    var node = this.render();    this.node = node;    mountTarget.appendChild(node);    return node;  };  /**   * @return {Element}   */  BrowserSpriteSymbol.prototype.render = function render () {    var content = this.stringify();    return parse(wrapInSvgString(content)).childNodes[0];  };  BrowserSpriteSymbol.prototype.unmount = function unmount () {    this.node.parentNode.removeChild(this.node);  };  Object.defineProperties( BrowserSpriteSymbol.prototype, prototypeAccessors );  return BrowserSpriteSymbol;}(SpriteSymbol));var defaultConfig$1 = {  /**   * Should following options be automatically configured:   * - `syncUrlsWithBaseTag`   * - `locationChangeAngularEmitter`   * - `moveGradientsOutsideSymbol`   * @type {boolean}   */  autoConfigure: true,  /**   * Default mounting selector   * @type {string}   */  mountTo: 'body',  /**   * Fix disappearing SVG elements when <base href> exists.   * Executes when sprite mounted.   * @see http://stackoverflow.com/a/18265336/796152   * @see https://github.com/everdimension/angular-svg-base-fix   * @see https://github.com/angular/angular.js/issues/8934#issuecomment-56568466   * @type {boolean}   */  syncUrlsWithBaseTag: false,  /**   * Should sprite listen custom location change event   * @type {boolean}   */  listenLocationChangeEvent: true,  /**   * Custom window event name which should be emitted to update sprite urls   * @type {string}   */  locationChangeEvent: 'locationChange',  /**   * Emit location change event in Angular automatically   * @type {boolean}   */  locationChangeAngularEmitter: false,  /**   * Selector to find symbols usages when updating sprite urls   * @type {string}   */  usagesToUpdate: 'use[*|href]',  /**   * Fix Firefox bug when gradients and patterns don't work if they are within a symbol.   * Executes when sprite is rendered, but not mounted.   * @see https://bugzilla.mozilla.org/show_bug.cgi?id=306674   * @see https://bugzilla.mozilla.org/show_bug.cgi?id=353575   * @see https://bugzilla.mozilla.org/show_bug.cgi?id=1235364   * @type {boolean}   */  moveGradientsOutsideSymbol: false};/** * @param {*} arrayLike * @return {Array} */var arrayFrom = function (arrayLike) {  return Array.prototype.slice.call(arrayLike, 0);};var browser = {  isChrome: function () { return /chrome/i.test(navigator.userAgent); },  isFirefox: function () { return /firefox/i.test(navigator.userAgent); },  // https://msdn.microsoft.com/en-us/library/ms537503(v=vs.85).aspx  isIE: function () { return /msie/i.test(navigator.userAgent) || /trident/i.test(navigator.userAgent); },  isEdge: function () { return /edge/i.test(navigator.userAgent); }};/** * @param {string} name * @param {*} data */var dispatchEvent = function (name, data) {  var event = document.createEvent('CustomEvent');  event.initCustomEvent(name, false, false, data);  window.dispatchEvent(event);};/** * IE doesn't evaluate <style> tags in SVGs that are dynamically added to the page. * This trick will trigger IE to read and use any existing SVG <style> tags. * @see https://github.com/iconic/SVGInjector/issues/23 * @see https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/10898469/ * * @param {Element} node DOM Element to search <style> tags in * @return {Array<HTMLStyleElement>} */var evalStylesIEWorkaround = function (node) {  var updatedNodes = [];  arrayFrom(node.querySelectorAll('style'))    .forEach(function (style) {      style.textContent += '';      updatedNodes.push(style);    });  return updatedNodes;};/** * @param {string} [url] If not provided - current URL will be used * @return {string} */var getUrlWithoutFragment = function (url) {  return (url || window.location.href).split('#')[0];};/* global angular *//** * @param {string} eventName */var locationChangeAngularEmitter = function (eventName) {  angular.module('ng').run(['$rootScope', function ($rootScope) {    $rootScope.$on('$locationChangeSuccess', function (e, newUrl, oldUrl) {      dispatchEvent(eventName, { oldUrl: oldUrl, newUrl: newUrl });    });  }]);};var defaultSelector = 'linearGradient, radialGradient, pattern, mask, clipPath';/** * @param {Element} svg * @param {string} [selector] * @return {Element} */var moveGradientsOutsideSymbol = function (svg, selector) {  if ( selector === void 0 ) selector = defaultSelector;  arrayFrom(svg.querySelectorAll('symbol')).forEach(function (symbol) {    arrayFrom(symbol.querySelectorAll(selector)).forEach(function (node) {      symbol.parentNode.insertBefore(node, symbol);    });  });  return svg;};/** * @param {NodeList} nodes * @param {Function} [matcher] * @return {Attr[]} */function selectAttributes(nodes, matcher) {  var attrs = arrayFrom(nodes).reduce(function (acc, node) {    if (!node.attributes) {      return acc;    }    var arrayfied = arrayFrom(node.attributes);    var matched = matcher ? arrayfied.filter(matcher) : arrayfied;    return acc.concat(matched);  }, []);  return attrs;}/** * @param {NodeList|Node} nodes * @param {boolean} [clone=true] * @return {string} */var xLinkNS = namespaces_1.xlink.uri;var xLinkAttrName = 'xlink:href';// eslint-disable-next-line no-useless-escapevar specialUrlCharsPattern = /[{}|\\\^\[\]`"<>]/g;function encoder(url) {  return url.replace(specialUrlCharsPattern, function (match) {    return ("%" + (match[0].charCodeAt(0).toString(16).toUpperCase()));  });}function escapeRegExp(str) {  return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string}/** * @param {NodeList} nodes * @param {string} startsWith * @param {string} replaceWith * @return {NodeList} */function updateReferences(nodes, startsWith, replaceWith) {  arrayFrom(nodes).forEach(function (node) {    var href = node.getAttribute(xLinkAttrName);    if (href && href.indexOf(startsWith) === 0) {      var newUrl = href.replace(startsWith, replaceWith);      node.setAttributeNS(xLinkNS, xLinkAttrName, newUrl);    }  });  return nodes;}/** * List of SVG attributes to update url() target in them */var attList = [  'clipPath',  'colorProfile',  'src',  'cursor',  'fill',  'filter',  'marker',  'markerStart',  'markerMid',  'markerEnd',  'mask',  'stroke',  'style'];var attSelector = attList.map(function (attr) { return ("[" + attr + "]"); }).join(',');/** * Update URLs in svg image (like `fill="url(...)"`) and update referencing elements * @param {Element} svg * @param {NodeList} references * @param {string|RegExp} startsWith * @param {string} replaceWith * @return {void} * * @example * const sprite = document.querySelector('svg.sprite'); * const usages = document.querySelectorAll('use'); * updateUrls(sprite, usages, '#', 'prefix#'); */var updateUrls = function (svg, references, startsWith, replaceWith) {  var startsWithEncoded = encoder(startsWith);  var replaceWithEncoded = encoder(replaceWith);  var nodes = svg.querySelectorAll(attSelector);  var attrs = selectAttributes(nodes, function (ref) {    var localName = ref.localName;    var value = ref.value;    return attList.indexOf(localName) !== -1 && value.indexOf(("url(" + startsWithEncoded)) !== -1;  });  attrs.forEach(function (attr) { return attr.value = attr.value.replace(new RegExp(escapeRegExp(startsWithEncoded), 'g'), replaceWithEncoded); });  updateReferences(references, startsWithEncoded, replaceWithEncoded);};/** * Internal emitter events * @enum * @private */var Events = {  MOUNT: 'mount',  SYMBOL_MOUNT: 'symbol_mount'};var BrowserSprite = (function (Sprite$$1) {  function BrowserSprite(cfg) {    var this$1 = this;    if ( cfg === void 0 ) cfg = {};    Sprite$$1.call(this, deepmerge(defaultConfig$1, cfg));    var emitter = mitt();    this._emitter = emitter;    this.node = null;    var ref = this;    var config = ref.config;    if (config.autoConfigure) {      this._autoConfigure(cfg);    }    if (config.syncUrlsWithBaseTag) {      var baseUrl = document.getElementsByTagName('base')[0].getAttribute('href');      emitter.on(Events.MOUNT, function () { return this$1.updateUrls('#', baseUrl); });    }    var handleLocationChange = this._handleLocationChange.bind(this);    this._handleLocationChange = handleLocationChange;    // Provide way to update sprite urls externally via dispatching custom window event    if (config.listenLocationChangeEvent) {      window.addEventListener(config.locationChangeEvent, handleLocationChange);    }    // Emit location change event in Angular automatically    if (config.locationChangeAngularEmitter) {      locationChangeAngularEmitter(config.locationChangeEvent);    }    // After sprite mounted    emitter.on(Events.MOUNT, function (spriteNode) {      if (config.moveGradientsOutsideSymbol) {        moveGradientsOutsideSymbol(spriteNode);      }    });    // After symbol mounted into sprite    emitter.on(Events.SYMBOL_MOUNT, function (symbolNode) {      if (config.moveGradientsOutsideSymbol) {        moveGradientsOutsideSymbol(symbolNode.parentNode);      }      if (browser.isIE() || browser.isEdge()) {        evalStylesIEWorkaround(symbolNode);      }    });  }  if ( Sprite$$1 ) BrowserSprite.__proto__ = Sprite$$1;  BrowserSprite.prototype = Object.create( Sprite$$1 && Sprite$$1.prototype );  BrowserSprite.prototype.constructor = BrowserSprite;  var prototypeAccessors = { isMounted: {} };  /**   * @return {boolean}   */  prototypeAccessors.isMounted.get = function () {    return !!this.node;  };  /**   * Automatically configure following options   * - `syncUrlsWithBaseTag`   * - `locationChangeAngularEmitter`   * - `moveGradientsOutsideSymbol`   * @param {Object} cfg   * @private   */  BrowserSprite.prototype._autoConfigure = function _autoConfigure (cfg) {    var ref = this;    var config = ref.config;    if (typeof cfg.syncUrlsWithBaseTag === 'undefined') {      config.syncUrlsWithBaseTag = typeof document.getElementsByTagName('base')[0] !== 'undefined';    }    if (typeof cfg.locationChangeAngularEmitter === 'undefined') {        config.locationChangeAngularEmitter = typeof window.angular !== 'undefined';    }    if (typeof cfg.moveGradientsOutsideSymbol === 'undefined') {      config.moveGradientsOutsideSymbol = browser.isFirefox();    }  };  /**   * @param {Event} event   * @param {Object} event.detail   * @param {string} event.detail.oldUrl   * @param {string} event.detail.newUrl   * @private   */  BrowserSprite.prototype._handleLocationChange = function _handleLocationChange (event) {    var ref = event.detail;    var oldUrl = ref.oldUrl;    var newUrl = ref.newUrl;    this.updateUrls(oldUrl, newUrl);  };  /**   * Add new symbol. If symbol with the same id exists it will be replaced.   * If sprite already mounted - `symbol.mount(sprite.node)` will be called.   * @fires Events#SYMBOL_MOUNT   * @param {BrowserSpriteSymbol} symbol   * @return {boolean} `true` - symbol was added, `false` - replaced   */  BrowserSprite.prototype.add = function add (symbol) {    var sprite = this;    var isNewSymbol = Sprite$$1.prototype.add.call(this, symbol);    if (this.isMounted && isNewSymbol) {      symbol.mount(sprite.node);      this._emitter.emit(Events.SYMBOL_MOUNT, symbol.node);    }    return isNewSymbol;  };  /**   * Attach to existing DOM node   * @param {string|Element} target   * @return {Element|null} attached DOM Element. null if node to attach not found.   */  BrowserSprite.prototype.attach = function attach (target) {    var this$1 = this;    var sprite = this;    if (sprite.isMounted) {      return sprite.node;    }    /** @type Element */    var node = typeof target === 'string' ? document.querySelector(target) : target;    sprite.node = node;    // Already added symbols needs to be mounted    this.symbols.forEach(function (symbol) {      symbol.mount(sprite.node);      this$1._emitter.emit(Events.SYMBOL_MOUNT, symbol.node);    });    // Create symbols from existing DOM nodes, add and mount them    arrayFrom(node.querySelectorAll('symbol'))      .forEach(function (symbolNode) {        var symbol = BrowserSpriteSymbol.createFromExistingNode(symbolNode);        symbol.node = symbolNode; // hack to prevent symbol mounting to sprite when adding        sprite.add(symbol);      });    this._emitter.emit(Events.MOUNT, node);    return node;  };  BrowserSprite.prototype.destroy = function destroy () {    var ref = this;    var config = ref.config;    var symbols = ref.symbols;    var _emitter = ref._emitter;    symbols.forEach(function (s) { return s.destroy(); });    _emitter.off('*');    window.removeEventListener(config.locationChangeEvent, this._handleLocationChange);    if (this.isMounted) {      this.unmount();    }  };  /**   * @fires Events#MOUNT   * @param {string|Element} [target]   * @param {boolean} [prepend=false]   * @return {Element|null} rendered sprite node. null if mount node not found.   */  BrowserSprite.prototype.mount = function mount (target, prepend) {    if ( target === void 0 ) target = this.config.mountTo;    if ( prepend === void 0 ) prepend = false;    var sprite = this;    if (sprite.isMounted) {      return sprite.node;    }    var mountNode = typeof target === 'string' ? document.querySelector(target) : target;    var node = sprite.render();    this.node = node;    if (prepend && mountNode.childNodes[0]) {      mountNode.insertBefore(node, mountNode.childNodes[0]);    } else {      mountNode.appendChild(node);    }    this._emitter.emit(Events.MOUNT, node);    return node;  };  /**   * @return {Element}   */  BrowserSprite.prototype.render = function render () {    return parse(this.stringify());  };  /**   * Detach sprite from the DOM   */  BrowserSprite.prototype.unmount = function unmount () {    this.node.parentNode.removeChild(this.node);  };  /**   * Update URLs in sprite and usage elements   * @param {string} oldUrl   * @param {string} newUrl   * @return {boolean} `true` - URLs was updated, `false` - sprite is not mounted   */  BrowserSprite.prototype.updateUrls = function updateUrls$1 (oldUrl, newUrl) {    if (!this.isMounted) {      return false;    }    var usages = document.querySelectorAll(this.config.usagesToUpdate);    updateUrls(      this.node,      usages,      ((getUrlWithoutFragment(oldUrl)) + "#"),      ((getUrlWithoutFragment(newUrl)) + "#")    );    return true;  };  Object.defineProperties( BrowserSprite.prototype, prototypeAccessors );  return BrowserSprite;}(Sprite));var ready$1 = createCommonjsModule(function (module) {/*!  * domready (c) Dustin Diaz 2014 - License MIT  */!function (name, definition) {  { module.exports = definition(); }}('domready', function () {  var fns = [], listener    , doc = document    , hack = doc.documentElement.doScroll    , domContentLoaded = 'DOMContentLoaded'    , loaded = (hack ? /^loaded|^c/ : /^loaded|^i|^c/).test(doc.readyState);  if (!loaded)  { doc.addEventListener(domContentLoaded, listener = function () {    doc.removeEventListener(domContentLoaded, listener);    loaded = 1;    while (listener = fns.shift()) { listener(); }  }); }  return function (fn) {    loaded ? setTimeout(fn, 0) : fns.push(fn);  }});});var spriteNodeId = '__SVG_SPRITE_NODE__';var spriteGlobalVarName = '__SVG_SPRITE__';var isSpriteExists = !!window[spriteGlobalVarName];// eslint-disable-next-line import/no-mutable-exportsvar sprite;if (isSpriteExists) {  sprite = window[spriteGlobalVarName];} else {  sprite = new BrowserSprite({    attrs: {      id: spriteNodeId,      'aria-hidden': 'true'    }  });  window[spriteGlobalVarName] = sprite;}var loadSprite = function () {  /**   * Check for page already contains sprite node   * If found - attach to and reuse it's content   * If not - render and mount the new sprite   */  var existing = document.getElementById(spriteNodeId);  if (existing) {    sprite.attach(existing);  } else {    sprite.mount(document.body, true);  }};if (document.body) {  loadSprite();} else {  ready$1(loadSprite);}var sprite$1 = sprite;return sprite$1;})));
 |