diff options
author | dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com> | 2019-06-23 01:13:14 +0000 |
---|---|---|
committer | Roeland Jago Douma <roeland@famdouma.nl> | 2019-06-24 10:57:22 +0200 |
commit | 16dd043560e39ce8c1b12c98b4a37030835e9fb7 (patch) | |
tree | 8d3129f2997ed1faaceaddd7989c153c51078ee3 /settings | |
parent | 9b5f6ec1d809267cf380030cdb6eb3ade1554afe (diff) | |
download | nextcloud-server-16dd043560e39ce8c1b12c98b4a37030835e9fb7.tar.gz nextcloud-server-16dd043560e39ce8c1b12c98b4a37030835e9fb7.zip |
Bump dompurify from 1.0.10 to 1.0.11
Bumps [dompurify](https://github.com/cure53/DOMPurify) from 1.0.10 to 1.0.11.
- [Release notes](https://github.com/cure53/DOMPurify/releases)
- [Commits](https://github.com/cure53/DOMPurify/compare/1.0.10...1.0.11)
Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
Diffstat (limited to 'settings')
-rw-r--r-- | settings/js/vue-5.js | 2 | ||||
-rw-r--r-- | settings/js/vue-5.js.map | 2 |
2 files changed, 2 insertions, 2 deletions
diff --git a/settings/js/vue-5.js b/settings/js/vue-5.js index e900850faf7..e2d3309c5a5 100644 --- a/settings/js/vue-5.js +++ b/settings/js/vue-5.js @@ -1,2 +1,2 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[5],{19:function(e,t,n){"use strict";e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var n=function(e,t){var n=e[1]||"",r=e[3];if(!r)return n;if(t&&"function"==typeof btoa){var i=(s=r,"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(s))))+" */"),o=r.sources.map(function(e){return"/*# sourceURL="+r.sourceRoot+e+" */"});return[n].concat(o).concat([i]).join("\n")}var s;return[n].join("\n")}(t,e);return t[2]?"@media "+t[2]+"{"+n+"}":n}).join("")},t.i=function(e,n){"string"==typeof e&&(e=[[null,e,""]]);for(var r={},i=0;i<this.length;i++){var o=this[i][0];null!=o&&(r[o]=!0)}for(i=0;i<e.length;i++){var s=e[i];null!=s[0]&&r[s[0]]||(n&&!s[2]?s[2]=n:n&&(s[2]="("+s[2]+") and ("+n+")"),t.push(s))}},t}},20:function(e,t,n){var r,i,o={},s=(r=function(){return window&&document&&document.all&&!window.atob},function(){return void 0===i&&(i=r.apply(this,arguments)),i}),a=function(e){var t={};return function(e,n){if("function"==typeof e)return e();if(void 0===t[e]){var r=function(e,t){return t?t.querySelector(e):document.querySelector(e)}.call(this,e,n);if(window.HTMLIFrameElement&&r instanceof window.HTMLIFrameElement)try{r=r.contentDocument.head}catch(e){r=null}t[e]=r}return t[e]}}(),l=null,c=0,u=[],p=n(48);function h(e,t){for(var n=0;n<e.length;n++){var r=e[n],i=o[r.id];if(i){i.refs++;for(var s=0;s<i.parts.length;s++)i.parts[s](r.parts[s]);for(;s<r.parts.length;s++)i.parts.push(y(r.parts[s],t))}else{var a=[];for(s=0;s<r.parts.length;s++)a.push(y(r.parts[s],t));o[r.id]={id:r.id,refs:1,parts:a}}}}function f(e,t){for(var n=[],r={},i=0;i<e.length;i++){var o=e[i],s=t.base?o[0]+t.base:o[0],a={css:o[1],media:o[2],sourceMap:o[3]};r[s]?r[s].parts.push(a):n.push(r[s]={id:s,parts:[a]})}return n}function d(e,t){var n=a(e.insertInto);if(!n)throw new Error("Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid.");var r=u[u.length-1];if("top"===e.insertAt)r?r.nextSibling?n.insertBefore(t,r.nextSibling):n.appendChild(t):n.insertBefore(t,n.firstChild),u.push(t);else if("bottom"===e.insertAt)n.appendChild(t);else{if("object"!=typeof e.insertAt||!e.insertAt.before)throw new Error("[Style Loader]\n\n Invalid value for parameter 'insertAt' ('options.insertAt') found.\n Must be 'top', 'bottom', or Object.\n (https://github.com/webpack-contrib/style-loader#insertat)\n");var i=a(e.insertAt.before,n);n.insertBefore(t,i)}}function g(e){if(null===e.parentNode)return!1;e.parentNode.removeChild(e);var t=u.indexOf(e);t>=0&&u.splice(t,1)}function m(e){var t=document.createElement("style");if(void 0===e.attrs.type&&(e.attrs.type="text/css"),void 0===e.attrs.nonce){var r=function(){0;return n.nc}();r&&(e.attrs.nonce=r)}return b(t,e.attrs),d(e,t),t}function b(e,t){Object.keys(t).forEach(function(n){e.setAttribute(n,t[n])})}function y(e,t){var n,r,i,o;if(t.transform&&e.css){if(!(o="function"==typeof t.transform?t.transform(e.css):t.transform.default(e.css)))return function(){};e.css=o}if(t.singleton){var s=c++;n=l||(l=m(t)),r=k.bind(null,n,s,!1),i=k.bind(null,n,s,!0)}else e.sourceMap&&"function"==typeof URL&&"function"==typeof URL.createObjectURL&&"function"==typeof URL.revokeObjectURL&&"function"==typeof Blob&&"function"==typeof btoa?(n=function(e){var t=document.createElement("link");return void 0===e.attrs.type&&(e.attrs.type="text/css"),e.attrs.rel="stylesheet",b(t,e.attrs),d(e,t),t}(t),r=function(e,t,n){var r=n.css,i=n.sourceMap,o=void 0===t.convertToAbsoluteUrls&&i;(t.convertToAbsoluteUrls||o)&&(r=p(r));i&&(r+="\n/*# sourceMappingURL=data:application/json;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(i))))+" */");var s=new Blob([r],{type:"text/css"}),a=e.href;e.href=URL.createObjectURL(s),a&&URL.revokeObjectURL(a)}.bind(null,n,t),i=function(){g(n),n.href&&URL.revokeObjectURL(n.href)}):(n=m(t),r=function(e,t){var n=t.css,r=t.media;r&&e.setAttribute("media",r);if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}.bind(null,n),i=function(){g(n)});return r(e),function(t){if(t){if(t.css===e.css&&t.media===e.media&&t.sourceMap===e.sourceMap)return;r(e=t)}else i()}}e.exports=function(e,t){if("undefined"!=typeof DEBUG&&DEBUG&&"object"!=typeof document)throw new Error("The style-loader cannot be used in a non-browser environment");(t=t||{}).attrs="object"==typeof t.attrs?t.attrs:{},t.singleton||"boolean"==typeof t.singleton||(t.singleton=s()),t.insertInto||(t.insertInto="head"),t.insertAt||(t.insertAt="bottom");var n=f(e,t);return h(n,t),function(e){for(var r=[],i=0;i<n.length;i++){var s=n[i];(a=o[s.id]).refs--,r.push(a)}e&&h(f(e,t),t);for(i=0;i<r.length;i++){var a;if(0===(a=r[i]).refs){for(var l=0;l<a.parts.length;l++)a.parts[l]();delete o[a.id]}}}};var v,x=(v=[],function(e,t){return v[e]=t,v.filter(Boolean).join("\n")});function k(e,t,n,r){var i=n?"":r.css;if(e.styleSheet)e.styleSheet.cssText=x(t,i);else{var o=document.createTextNode(i),s=e.childNodes;s[t]&&e.removeChild(s[t]),s.length?e.insertBefore(o,s[t]):e.appendChild(o)}}},48:function(e,t){e.exports=function(e){var t="undefined"!=typeof window&&window.location;if(!t)throw new Error("fixUrls requires window.location");if(!e||"string"!=typeof e)return e;var n=t.protocol+"//"+t.host,r=n+t.pathname.replace(/\/[^\/]*$/,"/");return e.replace(/url\s*\(((?:[^)(]|\((?:[^)(]+|\([^)(]*\))*\))*)\)/gi,function(e,t){var i,o=t.trim().replace(/^"(.*)"$/,function(e,t){return t}).replace(/^'(.*)'$/,function(e,t){return t});return/^(#|data:|http:\/\/|https:\/\/|file:\/\/\/|\s*$)/i.test(o)?e:(i=0===o.indexOf("//")?o:0===o.indexOf("/")?n+o:r+o.replace(/^\.\//,""),"url("+JSON.stringify(i)+")")})}},74:function(e,t,n){(function(t){!function(t){"use strict";var n={newline:/^\n+/,code:/^( {4}[^\n]+\n*)+/,fences:m,hr:/^ {0,3}((?:- *){3,}|(?:_ *){3,}|(?:\* *){3,})(?:\n+|$)/,heading:/^ *(#{1,6}) *([^\n]+?) *(?:#+ *)?(?:\n+|$)/,nptable:m,blockquote:/^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/,list:/^( {0,3})(bull) [\s\S]+?(?:hr|def|\n{2,}(?! )(?!\1bull )\n*|\s*$)/,html:"^ {0,3}(?:<(script|pre|style)[\\s>][\\s\\S]*?(?:</\\1>[^\\n]*\\n+|$)|comment[^\\n]*(\\n+|$)|<\\?[\\s\\S]*?\\?>\\n*|<![A-Z][\\s\\S]*?>\\n*|<!\\[CDATA\\[[\\s\\S]*?\\]\\]>\\n*|</?(tag)(?: +|\\n|/?>)[\\s\\S]*?(?:\\n{2,}|$)|<(?!script|pre|style)([a-z][\\w-]*)(?:attribute)*? */?>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:\\n{2,}|$)|</(?!script|pre|style)[a-z][\\w-]*\\s*>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:\\n{2,}|$))",def:/^ {0,3}\[(label)\]: *\n? *<?([^\s>]+)>?(?:(?: +\n? *| *\n *)(title))? *(?:\n+|$)/,table:m,lheading:/^([^\n]+)\n *(=|-){2,} *(?:\n+|$)/,paragraph:/^([^\n]+(?:\n(?!hr|heading|lheading| {0,3}>|<\/?(?:tag)(?: +|\n|\/?>)|<(?:script|pre|style|!--))[^\n]+)*)/,text:/^[^\n]+/};function r(e){this.tokens=[],this.tokens.links=Object.create(null),this.options=e||k.defaults,this.rules=n.normal,this.options.pedantic?this.rules=n.pedantic:this.options.gfm&&(this.options.tables?this.rules=n.tables:this.rules=n.gfm)}n._label=/(?!\s*\])(?:\\[\[\]]|[^\[\]])+/,n._title=/(?:"(?:\\"?|[^"\\])*"|'[^'\n]*(?:\n[^'\n]+)*\n?'|\([^()]*\))/,n.def=h(n.def).replace("label",n._label).replace("title",n._title).getRegex(),n.bullet=/(?:[*+-]|\d{1,9}\.)/,n.item=/^( *)(bull) ?[^\n]*(?:\n(?!\1bull ?)[^\n]*)*/,n.item=h(n.item,"gm").replace(/bull/g,n.bullet).getRegex(),n.list=h(n.list).replace(/bull/g,n.bullet).replace("hr","\\n+(?=\\1?(?:(?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$))").replace("def","\\n+(?="+n.def.source+")").getRegex(),n._tag="address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul",n._comment=/<!--(?!-?>)[\s\S]*?-->/,n.html=h(n.html,"i").replace("comment",n._comment).replace("tag",n._tag).replace("attribute",/ +[a-zA-Z:_][\w.:-]*(?: *= *"[^"\n]*"| *= *'[^'\n]*'| *= *[^\s"'=<>`]+)?/).getRegex(),n.paragraph=h(n.paragraph).replace("hr",n.hr).replace("heading",n.heading).replace("lheading",n.lheading).replace("tag",n._tag).getRegex(),n.blockquote=h(n.blockquote).replace("paragraph",n.paragraph).getRegex(),n.normal=b({},n),n.gfm=b({},n.normal,{fences:/^ {0,3}(`{3,}|~{3,})([^`\n]*)\n(?:|([\s\S]*?)\n)(?: {0,3}\1[~`]* *(?:\n+|$)|$)/,paragraph:/^/,heading:/^ *(#{1,6}) +([^\n]+?) *#* *(?:\n+|$)/}),n.gfm.paragraph=h(n.paragraph).replace("(?!","(?!"+n.gfm.fences.source.replace("\\1","\\2")+"|"+n.list.source.replace("\\1","\\3")+"|").getRegex(),n.tables=b({},n.gfm,{nptable:/^ *([^|\n ].*\|.*)\n *([-:]+ *\|[-| :]*)(?:\n((?:.*[^>\n ].*(?:\n|$))*)\n*|$)/,table:/^ *\|(.+)\n *\|?( *[-:]+[-| :]*)(?:\n((?: *[^>\n ].*(?:\n|$))*)\n*|$)/}),n.pedantic=b({},n.normal,{html:h("^ *(?:comment *(?:\\n|\\s*$)|<(tag)[\\s\\S]+?</\\1> *(?:\\n{2,}|\\s*$)|<tag(?:\"[^\"]*\"|'[^']*'|\\s[^'\"/>\\s]*)*?/?> *(?:\\n{2,}|\\s*$))").replace("comment",n._comment).replace(/tag/g,"(?!(?:a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)\\b)\\w+(?!:|[^\\w\\s@]*@)\\b").getRegex(),def:/^ *\[([^\]]+)\]: *<?([^\s>]+)>?(?: +(["(][^\n]+[")]))? *(?:\n+|$)/}),r.rules=n,r.lex=function(e,t){return new r(t).lex(e)},r.prototype.lex=function(e){return e=e.replace(/\r\n|\r/g,"\n").replace(/\t/g," ").replace(/\u00a0/g," ").replace(/\u2424/g,"\n"),this.token(e,!0)},r.prototype.token=function(e,t){var r,i,o,s,a,l,c,u,p,h,f,d,g,m,b,x;for(e=e.replace(/^ +$/gm,"");e;)if((o=this.rules.newline.exec(e))&&(e=e.substring(o[0].length),o[0].length>1&&this.tokens.push({type:"space"})),o=this.rules.code.exec(e))e=e.substring(o[0].length),o=o[0].replace(/^ {4}/gm,""),this.tokens.push({type:"code",text:this.options.pedantic?o:v(o,"\n")});else if(o=this.rules.fences.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"code",lang:o[2]?o[2].trim():o[2],text:o[3]||""});else if(o=this.rules.heading.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"heading",depth:o[1].length,text:o[2]});else if((o=this.rules.nptable.exec(e))&&(l={type:"table",header:y(o[1].replace(/^ *| *\| *$/g,"")),align:o[2].replace(/^ *|\| *$/g,"").split(/ *\| */),cells:o[3]?o[3].replace(/\n$/,"").split("\n"):[]}).header.length===l.align.length){for(e=e.substring(o[0].length),f=0;f<l.align.length;f++)/^ *-+: *$/.test(l.align[f])?l.align[f]="right":/^ *:-+: *$/.test(l.align[f])?l.align[f]="center":/^ *:-+ *$/.test(l.align[f])?l.align[f]="left":l.align[f]=null;for(f=0;f<l.cells.length;f++)l.cells[f]=y(l.cells[f],l.header.length);this.tokens.push(l)}else if(o=this.rules.hr.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"hr"});else if(o=this.rules.blockquote.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"blockquote_start"}),o=o[0].replace(/^ *> ?/gm,""),this.token(o,t),this.tokens.push({type:"blockquote_end"});else if(o=this.rules.list.exec(e)){for(e=e.substring(o[0].length),c={type:"list_start",ordered:m=(s=o[2]).length>1,start:m?+s:"",loose:!1},this.tokens.push(c),u=[],r=!1,g=(o=o[0].match(this.rules.item)).length,f=0;f<g;f++)h=(l=o[f]).length,~(l=l.replace(/^ *([*+-]|\d+\.) */,"")).indexOf("\n ")&&(h-=l.length,l=this.options.pedantic?l.replace(/^ {1,4}/gm,""):l.replace(new RegExp("^ {1,"+h+"}","gm"),"")),f!==g-1&&(a=n.bullet.exec(o[f+1])[0],(s.length>1?1===a.length:a.length>1||this.options.smartLists&&a!==s)&&(e=o.slice(f+1).join("\n")+e,f=g-1)),i=r||/\n\n(?!\s*$)/.test(l),f!==g-1&&(r="\n"===l.charAt(l.length-1),i||(i=r)),i&&(c.loose=!0),x=void 0,(b=/^\[[ xX]\] /.test(l))&&(x=" "!==l[1],l=l.replace(/^\[[ xX]\] +/,"")),p={type:"list_item_start",task:b,checked:x,loose:i},u.push(p),this.tokens.push(p),this.token(l,!1),this.tokens.push({type:"list_item_end"});if(c.loose)for(g=u.length,f=0;f<g;f++)u[f].loose=!0;this.tokens.push({type:"list_end"})}else if(o=this.rules.html.exec(e))e=e.substring(o[0].length),this.tokens.push({type:this.options.sanitize?"paragraph":"html",pre:!this.options.sanitizer&&("pre"===o[1]||"script"===o[1]||"style"===o[1]),text:o[0]});else if(t&&(o=this.rules.def.exec(e)))e=e.substring(o[0].length),o[3]&&(o[3]=o[3].substring(1,o[3].length-1)),d=o[1].toLowerCase().replace(/\s+/g," "),this.tokens.links[d]||(this.tokens.links[d]={href:o[2],title:o[3]});else if((o=this.rules.table.exec(e))&&(l={type:"table",header:y(o[1].replace(/^ *| *\| *$/g,"")),align:o[2].replace(/^ *|\| *$/g,"").split(/ *\| */),cells:o[3]?o[3].replace(/\n$/,"").split("\n"):[]}).header.length===l.align.length){for(e=e.substring(o[0].length),f=0;f<l.align.length;f++)/^ *-+: *$/.test(l.align[f])?l.align[f]="right":/^ *:-+: *$/.test(l.align[f])?l.align[f]="center":/^ *:-+ *$/.test(l.align[f])?l.align[f]="left":l.align[f]=null;for(f=0;f<l.cells.length;f++)l.cells[f]=y(l.cells[f].replace(/^ *\| *| *\| *$/g,""),l.header.length);this.tokens.push(l)}else if(o=this.rules.lheading.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"heading",depth:"="===o[2]?1:2,text:o[1]});else if(t&&(o=this.rules.paragraph.exec(e)))e=e.substring(o[0].length),this.tokens.push({type:"paragraph",text:"\n"===o[1].charAt(o[1].length-1)?o[1].slice(0,-1):o[1]});else if(o=this.rules.text.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"text",text:o[0]});else if(e)throw new Error("Infinite loop on byte: "+e.charCodeAt(0));return this.tokens};var i={escape:/^\\([!"#$%&'()*+,\-.\/:;<=>?@\[\]\\^_`{|}~])/,autolink:/^<(scheme:[^\s\x00-\x1f<>]*|email)>/,url:m,tag:"^comment|^</[a-zA-Z][\\w:-]*\\s*>|^<[a-zA-Z][\\w-]*(?:attribute)*?\\s*/?>|^<\\?[\\s\\S]*?\\?>|^<![a-zA-Z]+\\s[\\s\\S]*?>|^<!\\[CDATA\\[[\\s\\S]*?\\]\\]>",link:/^!?\[(label)\]\(href(?:\s+(title))?\s*\)/,reflink:/^!?\[(label)\]\[(?!\s*\])((?:\\[\[\]]?|[^\[\]\\])+)\]/,nolink:/^!?\[(?!\s*\])((?:\[[^\[\]]*\]|\\[\[\]]|[^\[\]])*)\](?:\[\])?/,strong:/^__([^\s_])__(?!_)|^\*\*([^\s*])\*\*(?!\*)|^__([^\s][\s\S]*?[^\s])__(?!_)|^\*\*([^\s][\s\S]*?[^\s])\*\*(?!\*)/,em:/^_([^\s_])_(?!_)|^\*([^\s*"<\[])\*(?!\*)|^_([^\s][\s\S]*?[^\s_])_(?!_|[^\spunctuation])|^_([^\s_][\s\S]*?[^\s])_(?!_|[^\spunctuation])|^\*([^\s"<\[][\s\S]*?[^\s*])\*(?!\*)|^\*([^\s*"<\[][\s\S]*?[^\s])\*(?!\*)/,code:/^(`+)([^`]|[^`][\s\S]*?[^`])\1(?!`)/,br:/^( {2,}|\\)\n(?!\s*$)/,del:m,text:/^(`+|[^`])(?:[\s\S]*?(?:(?=[\\<!\[`*]|\b_|$)|[^ ](?= {2,}\n))|(?= {2,}\n))/};function o(e,t){if(this.options=t||k.defaults,this.links=e,this.rules=i.normal,this.renderer=this.options.renderer||new s,this.renderer.options=this.options,!this.links)throw new Error("Tokens array requires a `links` property.");this.options.pedantic?this.rules=i.pedantic:this.options.gfm&&(this.options.breaks?this.rules=i.breaks:this.rules=i.gfm)}function s(e){this.options=e||k.defaults}function a(){}function l(e){this.tokens=[],this.token=null,this.options=e||k.defaults,this.options.renderer=this.options.renderer||new s,this.renderer=this.options.renderer,this.renderer.options=this.options,this.slugger=new c}function c(){this.seen={}}function u(e,t){if(t){if(u.escapeTest.test(e))return e.replace(u.escapeReplace,function(e){return u.replacements[e]})}else if(u.escapeTestNoEncode.test(e))return e.replace(u.escapeReplaceNoEncode,function(e){return u.replacements[e]});return e}function p(e){return e.replace(/&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/gi,function(e,t){return"colon"===(t=t.toLowerCase())?":":"#"===t.charAt(0)?"x"===t.charAt(1)?String.fromCharCode(parseInt(t.substring(2),16)):String.fromCharCode(+t.substring(1)):""})}function h(e,t){return e=e.source||e,t=t||"",{replace:function(t,n){return n=(n=n.source||n).replace(/(^|[^\[])\^/g,"$1"),e=e.replace(t,n),this},getRegex:function(){return new RegExp(e,t)}}}function f(e,t,n){if(e){try{var r=decodeURIComponent(p(n)).replace(/[^\w:]/g,"").toLowerCase()}catch(e){return null}if(0===r.indexOf("javascript:")||0===r.indexOf("vbscript:")||0===r.indexOf("data:"))return null}t&&!g.test(n)&&(n=function(e,t){d[" "+e]||(/^[^:]+:\/*[^\/]*$/.test(e)?d[" "+e]=e+"/":d[" "+e]=v(e,"/",!0));return e=d[" "+e],"//"===t.slice(0,2)?e.replace(/:[\s\S]*/,":")+t:"/"===t.charAt(0)?e.replace(/(:\/*[^\/]*)[\s\S]*/,"$1")+t:e+t}(t,n));try{n=encodeURI(n).replace(/%25/g,"%")}catch(e){return null}return n}i._punctuation="!\"#$%&'()*+,\\-./:;<=>?@\\[^_{|}~",i.em=h(i.em).replace(/punctuation/g,i._punctuation).getRegex(),i._escapes=/\\([!"#$%&'()*+,\-.\/:;<=>?@\[\]\\^_`{|}~])/g,i._scheme=/[a-zA-Z][a-zA-Z0-9+.-]{1,31}/,i._email=/[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/,i.autolink=h(i.autolink).replace("scheme",i._scheme).replace("email",i._email).getRegex(),i._attribute=/\s+[a-zA-Z:_][\w.:-]*(?:\s*=\s*"[^"]*"|\s*=\s*'[^']*'|\s*=\s*[^\s"'=<>`]+)?/,i.tag=h(i.tag).replace("comment",n._comment).replace("attribute",i._attribute).getRegex(),i._label=/(?:\[[^\[\]]*\]|\\[\[\]]?|`[^`]*`|`(?!`)|[^\[\]\\`])*?/,i._href=/\s*(<(?:\\[<>]?|[^\s<>\\])*>|[^\s\x00-\x1f]*)/,i._title=/"(?:\\"?|[^"\\])*"|'(?:\\'?|[^'\\])*'|\((?:\\\)?|[^)\\])*\)/,i.link=h(i.link).replace("label",i._label).replace("href",i._href).replace("title",i._title).getRegex(),i.reflink=h(i.reflink).replace("label",i._label).getRegex(),i.normal=b({},i),i.pedantic=b({},i.normal,{strong:/^__(?=\S)([\s\S]*?\S)__(?!_)|^\*\*(?=\S)([\s\S]*?\S)\*\*(?!\*)/,em:/^_(?=\S)([\s\S]*?\S)_(?!_)|^\*(?=\S)([\s\S]*?\S)\*(?!\*)/,link:h(/^!?\[(label)\]\((.*?)\)/).replace("label",i._label).getRegex(),reflink:h(/^!?\[(label)\]\s*\[([^\]]*)\]/).replace("label",i._label).getRegex()}),i.gfm=b({},i.normal,{escape:h(i.escape).replace("])","~|])").getRegex(),_extended_email:/[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/,url:/^((?:ftp|https?):\/\/|www\.)(?:[a-zA-Z0-9\-]+\.?)+[^\s<]*|^email/,_backpedal:/(?:[^?!.,:;*_~()&]+|\([^)]*\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_~)]+(?!$))+/,del:/^~+(?=\S)([\s\S]*?\S)~+/,text:/^(`+|[^`])(?:[\s\S]*?(?:(?=[\\<!\[`*~]|\b_|https?:\/\/|ftp:\/\/|www\.|$)|[^ ](?= {2,}\n)|[^a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-](?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@))|(?= {2,}\n|[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@))/}),i.gfm.url=h(i.gfm.url,"i").replace("email",i.gfm._extended_email).getRegex(),i.breaks=b({},i.gfm,{br:h(i.br).replace("{2,}","*").getRegex(),text:h(i.gfm.text).replace(/\{2,\}/g,"*").getRegex()}),o.rules=i,o.output=function(e,t,n){return new o(t,n).output(e)},o.prototype.output=function(e){for(var t,n,r,i,s,a,l="";e;)if(s=this.rules.escape.exec(e))e=e.substring(s[0].length),l+=u(s[1]);else if(s=this.rules.tag.exec(e))!this.inLink&&/^<a /i.test(s[0])?this.inLink=!0:this.inLink&&/^<\/a>/i.test(s[0])&&(this.inLink=!1),!this.inRawBlock&&/^<(pre|code|kbd|script)(\s|>)/i.test(s[0])?this.inRawBlock=!0:this.inRawBlock&&/^<\/(pre|code|kbd|script)(\s|>)/i.test(s[0])&&(this.inRawBlock=!1),e=e.substring(s[0].length),l+=this.options.sanitize?this.options.sanitizer?this.options.sanitizer(s[0]):u(s[0]):s[0];else if(s=this.rules.link.exec(e)){var c=x(s[2],"()");if(c>-1){var p=s[0].length-(s[2].length-c)-(s[3]||"").length;s[2]=s[2].substring(0,c),s[0]=s[0].substring(0,p).trim(),s[3]=""}e=e.substring(s[0].length),this.inLink=!0,r=s[2],this.options.pedantic?(t=/^([^'"]*[^\s])\s+(['"])(.*)\2/.exec(r))?(r=t[1],i=t[3]):i="":i=s[3]?s[3].slice(1,-1):"",r=r.trim().replace(/^<([\s\S]*)>$/,"$1"),l+=this.outputLink(s,{href:o.escapes(r),title:o.escapes(i)}),this.inLink=!1}else if((s=this.rules.reflink.exec(e))||(s=this.rules.nolink.exec(e))){if(e=e.substring(s[0].length),t=(s[2]||s[1]).replace(/\s+/g," "),!(t=this.links[t.toLowerCase()])||!t.href){l+=s[0].charAt(0),e=s[0].substring(1)+e;continue}this.inLink=!0,l+=this.outputLink(s,t),this.inLink=!1}else if(s=this.rules.strong.exec(e))e=e.substring(s[0].length),l+=this.renderer.strong(this.output(s[4]||s[3]||s[2]||s[1]));else if(s=this.rules.em.exec(e))e=e.substring(s[0].length),l+=this.renderer.em(this.output(s[6]||s[5]||s[4]||s[3]||s[2]||s[1]));else if(s=this.rules.code.exec(e))e=e.substring(s[0].length),l+=this.renderer.codespan(u(s[2].trim(),!0));else if(s=this.rules.br.exec(e))e=e.substring(s[0].length),l+=this.renderer.br();else if(s=this.rules.del.exec(e))e=e.substring(s[0].length),l+=this.renderer.del(this.output(s[1]));else if(s=this.rules.autolink.exec(e))e=e.substring(s[0].length),r="@"===s[2]?"mailto:"+(n=u(this.mangle(s[1]))):n=u(s[1]),l+=this.renderer.link(r,null,n);else if(this.inLink||!(s=this.rules.url.exec(e))){if(s=this.rules.text.exec(e))e=e.substring(s[0].length),this.inRawBlock?l+=this.renderer.text(s[0]):l+=this.renderer.text(u(this.smartypants(s[0])));else if(e)throw new Error("Infinite loop on byte: "+e.charCodeAt(0))}else{if("@"===s[2])r="mailto:"+(n=u(s[0]));else{do{a=s[0],s[0]=this.rules._backpedal.exec(s[0])[0]}while(a!==s[0]);n=u(s[0]),r="www."===s[1]?"http://"+n:n}e=e.substring(s[0].length),l+=this.renderer.link(r,null,n)}return l},o.escapes=function(e){return e?e.replace(o.rules._escapes,"$1"):e},o.prototype.outputLink=function(e,t){var n=t.href,r=t.title?u(t.title):null;return"!"!==e[0].charAt(0)?this.renderer.link(n,r,this.output(e[1])):this.renderer.image(n,r,u(e[1]))},o.prototype.smartypants=function(e){return this.options.smartypants?e.replace(/---/g,"—").replace(/--/g,"–").replace(/(^|[-\u2014\/(\[{"\s])'/g,"$1‘").replace(/'/g,"’").replace(/(^|[-\u2014\/(\[{\u2018\s])"/g,"$1“").replace(/"/g,"”").replace(/\.{3}/g,"…"):e},o.prototype.mangle=function(e){if(!this.options.mangle)return e;for(var t,n="",r=e.length,i=0;i<r;i++)t=e.charCodeAt(i),Math.random()>.5&&(t="x"+t.toString(16)),n+="&#"+t+";";return n},s.prototype.code=function(e,t,n){var r=(t||"").match(/\S*/)[0];if(this.options.highlight){var i=this.options.highlight(e,r);null!=i&&i!==e&&(n=!0,e=i)}return r?'<pre><code class="'+this.options.langPrefix+u(r,!0)+'">'+(n?e:u(e,!0))+"</code></pre>\n":"<pre><code>"+(n?e:u(e,!0))+"</code></pre>"},s.prototype.blockquote=function(e){return"<blockquote>\n"+e+"</blockquote>\n"},s.prototype.html=function(e){return e},s.prototype.heading=function(e,t,n,r){return this.options.headerIds?"<h"+t+' id="'+this.options.headerPrefix+r.slug(n)+'">'+e+"</h"+t+">\n":"<h"+t+">"+e+"</h"+t+">\n"},s.prototype.hr=function(){return this.options.xhtml?"<hr/>\n":"<hr>\n"},s.prototype.list=function(e,t,n){var r=t?"ol":"ul";return"<"+r+(t&&1!==n?' start="'+n+'"':"")+">\n"+e+"</"+r+">\n"},s.prototype.listitem=function(e){return"<li>"+e+"</li>\n"},s.prototype.checkbox=function(e){return"<input "+(e?'checked="" ':"")+'disabled="" type="checkbox"'+(this.options.xhtml?" /":"")+"> "},s.prototype.paragraph=function(e){return"<p>"+e+"</p>\n"},s.prototype.table=function(e,t){return t&&(t="<tbody>"+t+"</tbody>"),"<table>\n<thead>\n"+e+"</thead>\n"+t+"</table>\n"},s.prototype.tablerow=function(e){return"<tr>\n"+e+"</tr>\n"},s.prototype.tablecell=function(e,t){var n=t.header?"th":"td";return(t.align?"<"+n+' align="'+t.align+'">':"<"+n+">")+e+"</"+n+">\n"},s.prototype.strong=function(e){return"<strong>"+e+"</strong>"},s.prototype.em=function(e){return"<em>"+e+"</em>"},s.prototype.codespan=function(e){return"<code>"+e+"</code>"},s.prototype.br=function(){return this.options.xhtml?"<br/>":"<br>"},s.prototype.del=function(e){return"<del>"+e+"</del>"},s.prototype.link=function(e,t,n){if(null===(e=f(this.options.sanitize,this.options.baseUrl,e)))return n;var r='<a href="'+u(e)+'"';return t&&(r+=' title="'+t+'"'),r+=">"+n+"</a>"},s.prototype.image=function(e,t,n){if(null===(e=f(this.options.sanitize,this.options.baseUrl,e)))return n;var r='<img src="'+e+'" alt="'+n+'"';return t&&(r+=' title="'+t+'"'),r+=this.options.xhtml?"/>":">"},s.prototype.text=function(e){return e},a.prototype.strong=a.prototype.em=a.prototype.codespan=a.prototype.del=a.prototype.text=function(e){return e},a.prototype.link=a.prototype.image=function(e,t,n){return""+n},a.prototype.br=function(){return""},l.parse=function(e,t){return new l(t).parse(e)},l.prototype.parse=function(e){this.inline=new o(e.links,this.options),this.inlineText=new o(e.links,b({},this.options,{renderer:new a})),this.tokens=e.reverse();for(var t="";this.next();)t+=this.tok();return t},l.prototype.next=function(){return this.token=this.tokens.pop()},l.prototype.peek=function(){return this.tokens[this.tokens.length-1]||0},l.prototype.parseText=function(){for(var e=this.token.text;"text"===this.peek().type;)e+="\n"+this.next().text;return this.inline.output(e)},l.prototype.tok=function(){switch(this.token.type){case"space":return"";case"hr":return this.renderer.hr();case"heading":return this.renderer.heading(this.inline.output(this.token.text),this.token.depth,p(this.inlineText.output(this.token.text)),this.slugger);case"code":return this.renderer.code(this.token.text,this.token.lang,this.token.escaped);case"table":var e,t,n,r,i="",o="";for(n="",e=0;e<this.token.header.length;e++)n+=this.renderer.tablecell(this.inline.output(this.token.header[e]),{header:!0,align:this.token.align[e]});for(i+=this.renderer.tablerow(n),e=0;e<this.token.cells.length;e++){for(t=this.token.cells[e],n="",r=0;r<t.length;r++)n+=this.renderer.tablecell(this.inline.output(t[r]),{header:!1,align:this.token.align[r]});o+=this.renderer.tablerow(n)}return this.renderer.table(i,o);case"blockquote_start":for(o="";"blockquote_end"!==this.next().type;)o+=this.tok();return this.renderer.blockquote(o);case"list_start":o="";for(var s=this.token.ordered,a=this.token.start;"list_end"!==this.next().type;)o+=this.tok();return this.renderer.list(o,s,a);case"list_item_start":o="";var l=this.token.loose,c=this.token.checked,u=this.token.task;for(this.token.task&&(o+=this.renderer.checkbox(c));"list_item_end"!==this.next().type;)o+=l||"text"!==this.token.type?this.tok():this.parseText();return this.renderer.listitem(o,u,c);case"html":return this.renderer.html(this.token.text);case"paragraph":return this.renderer.paragraph(this.inline.output(this.token.text));case"text":return this.renderer.paragraph(this.parseText());default:var h='Token with "'+this.token.type+'" type was not found.';if(!this.options.silent)throw new Error(h);console.log(h)}},c.prototype.slug=function(e){var t=e.toLowerCase().trim().replace(/[\u2000-\u206F\u2E00-\u2E7F\\'!"#$%&()*+,.\/:;<=>?@[\]^`{|}~]/g,"").replace(/\s/g,"-");if(this.seen.hasOwnProperty(t)){var n=t;do{this.seen[n]++,t=n+"-"+this.seen[n]}while(this.seen.hasOwnProperty(t))}return this.seen[t]=0,t},u.escapeTest=/[&<>"']/,u.escapeReplace=/[&<>"']/g,u.replacements={"&":"&","<":"<",">":">",'"':""","'":"'"},u.escapeTestNoEncode=/[<>"']|&(?!#?\w+;)/,u.escapeReplaceNoEncode=/[<>"']|&(?!#?\w+;)/g;var d={},g=/^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;function m(){}function b(e){for(var t,n,r=1;r<arguments.length;r++)for(n in t=arguments[r])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}function y(e,t){var n=e.replace(/\|/g,function(e,t,n){for(var r=!1,i=t;--i>=0&&"\\"===n[i];)r=!r;return r?"|":" |"}).split(/ \|/),r=0;if(n.length>t)n.splice(t);else for(;n.length<t;)n.push("");for(;r<n.length;r++)n[r]=n[r].trim().replace(/\\\|/g,"|");return n}function v(e,t,n){if(0===e.length)return"";for(var r=0;r<e.length;){var i=e.charAt(e.length-r-1);if(i!==t||n){if(i===t||!n)break;r++}else r++}return e.substr(0,e.length-r)}function x(e,t){if(-1===e.indexOf(t[1]))return-1;for(var n=0,r=0;r<e.length;r++)if("\\"===e[r])r++;else if(e[r]===t[0])n++;else if(e[r]===t[1]&&--n<0)return r;return-1}function k(e,t,n){if(null==e)throw new Error("marked(): input parameter is undefined or null");if("string"!=typeof e)throw new Error("marked(): input parameter is of type "+Object.prototype.toString.call(e)+", string expected");if(n||"function"==typeof t){n||(n=t,t=null);var i,o,s=(t=b({},k.defaults,t||{})).highlight,a=0;try{i=r.lex(e,t)}catch(e){return n(e)}o=i.length;var c=function(e){if(e)return t.highlight=s,n(e);var r;try{r=l.parse(i,t)}catch(t){e=t}return t.highlight=s,e?n(e):n(null,r)};if(!s||s.length<3)return c();if(delete t.highlight,!o)return c();for(;a<i.length;a++)!function(e){"code"!==e.type?--o||c():s(e.text,e.lang,function(t,n){return t?c(t):null==n||n===e.text?--o||c():(e.text=n,e.escaped=!0,void(--o||c()))})}(i[a])}else try{return t&&(t=b({},k.defaults,t)),l.parse(r.lex(e,t),t)}catch(e){if(e.message+="\nPlease report this to https://github.com/markedjs/marked.",(t||k.defaults).silent)return"<p>An error occurred:</p><pre>"+u(e.message+"",!0)+"</pre>";throw e}}m.exec=m,k.options=k.setOptions=function(e){return b(k.defaults,e),k},k.getDefaults=function(){return{baseUrl:null,breaks:!1,gfm:!0,headerIds:!0,headerPrefix:"",highlight:null,langPrefix:"language-",mangle:!0,pedantic:!1,renderer:new s,sanitize:!1,sanitizer:null,silent:!1,smartLists:!1,smartypants:!1,tables:!0,xhtml:!1}},k.defaults=k.getDefaults(),k.Parser=l,k.parser=l.parse,k.Renderer=s,k.TextRenderer=a,k.Lexer=r,k.lexer=r.lex,k.InlineLexer=o,k.inlineLexer=o.output,k.Slugger=c,k.parse=k,e.exports=k}(this||"undefined"!=typeof window&&window)}).call(this,n(3))},75:function(e,t,n){e.exports=function(){"use strict";var e=Object.freeze||function(e){return e},t=e(["a","abbr","acronym","address","area","article","aside","audio","b","bdi","bdo","big","blink","blockquote","body","br","button","canvas","caption","center","cite","code","col","colgroup","content","data","datalist","dd","decorator","del","details","dfn","dir","div","dl","dt","element","em","fieldset","figcaption","figure","font","footer","form","h1","h2","h3","h4","h5","h6","head","header","hgroup","hr","html","i","img","input","ins","kbd","label","legend","li","main","map","mark","marquee","menu","menuitem","meter","nav","nobr","ol","optgroup","option","output","p","pre","progress","q","rp","rt","ruby","s","samp","section","select","shadow","small","source","spacer","span","strike","strong","style","sub","summary","sup","table","tbody","td","template","textarea","tfoot","th","thead","time","tr","track","tt","u","ul","var","video","wbr"]),n=e(["svg","a","altglyph","altglyphdef","altglyphitem","animatecolor","animatemotion","animatetransform","audio","canvas","circle","clippath","defs","desc","ellipse","filter","font","g","glyph","glyphref","hkern","image","line","lineargradient","marker","mask","metadata","mpath","path","pattern","polygon","polyline","radialgradient","rect","stop","style","switch","symbol","text","textpath","title","tref","tspan","video","view","vkern"]),r=e(["feBlend","feColorMatrix","feComponentTransfer","feComposite","feConvolveMatrix","feDiffuseLighting","feDisplacementMap","feDistantLight","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feMerge","feMergeNode","feMorphology","feOffset","fePointLight","feSpecularLighting","feSpotLight","feTile","feTurbulence"]),i=e(["math","menclose","merror","mfenced","mfrac","mglyph","mi","mlabeledtr","mmultiscripts","mn","mo","mover","mpadded","mphantom","mroot","mrow","ms","mspace","msqrt","mstyle","msub","msup","msubsup","mtable","mtd","mtext","mtr","munder","munderover"]),o=e(["#text"]),s=Object.freeze||function(e){return e},a=s(["accept","action","align","alt","autocomplete","background","bgcolor","border","cellpadding","cellspacing","checked","cite","class","clear","color","cols","colspan","coords","crossorigin","datetime","default","dir","disabled","download","enctype","face","for","headers","height","hidden","high","href","hreflang","id","integrity","ismap","label","lang","list","loop","low","max","maxlength","media","method","min","multiple","name","noshade","novalidate","nowrap","open","optimum","pattern","placeholder","poster","preload","pubdate","radiogroup","readonly","rel","required","rev","reversed","role","rows","rowspan","spellcheck","scope","selected","shape","size","sizes","span","srclang","start","src","srcset","step","style","summary","tabindex","title","type","usemap","valign","value","width","xmlns"]),l=s(["accent-height","accumulate","additive","alignment-baseline","ascent","attributename","attributetype","azimuth","basefrequency","baseline-shift","begin","bias","by","class","clip","clip-path","clip-rule","color","color-interpolation","color-interpolation-filters","color-profile","color-rendering","cx","cy","d","dx","dy","diffuseconstant","direction","display","divisor","dur","edgemode","elevation","end","fill","fill-opacity","fill-rule","filter","flood-color","flood-opacity","font-family","font-size","font-size-adjust","font-stretch","font-style","font-variant","font-weight","fx","fy","g1","g2","glyph-name","glyphref","gradientunits","gradienttransform","height","href","id","image-rendering","in","in2","k","k1","k2","k3","k4","kerning","keypoints","keysplines","keytimes","lang","lengthadjust","letter-spacing","kernelmatrix","kernelunitlength","lighting-color","local","marker-end","marker-mid","marker-start","markerheight","markerunits","markerwidth","maskcontentunits","maskunits","max","mask","media","method","mode","min","name","numoctaves","offset","operator","opacity","order","orient","orientation","origin","overflow","paint-order","path","pathlength","patterncontentunits","patterntransform","patternunits","points","preservealpha","preserveaspectratio","r","rx","ry","radius","refx","refy","repeatcount","repeatdur","restart","result","rotate","scale","seed","shape-rendering","specularconstant","specularexponent","spreadmethod","stddeviation","stitchtiles","stop-color","stop-opacity","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke","stroke-width","style","surfacescale","tabindex","targetx","targety","transform","text-anchor","text-decoration","text-rendering","textlength","type","u1","u2","unicode","values","viewbox","visibility","version","vert-adv-y","vert-origin-x","vert-origin-y","width","word-spacing","wrap","writing-mode","xchannelselector","ychannelselector","x","x1","x2","xmlns","y","y1","y2","z","zoomandpan"]),c=s(["accent","accentunder","align","bevelled","close","columnsalign","columnlines","columnspan","denomalign","depth","dir","display","displaystyle","fence","frame","height","href","id","largeop","length","linethickness","lspace","lquote","mathbackground","mathcolor","mathsize","mathvariant","maxsize","minsize","movablelimits","notation","numalign","open","rowalign","rowlines","rowspacing","rowspan","rspace","rquote","scriptlevel","scriptminsize","scriptsizemultiplier","selection","separator","separators","stretchy","subscriptshift","supscriptshift","symmetric","voffset","width","xmlns"]),u=s(["xlink:href","xml:id","xlink:title","xml:space","xmlns:xlink"]),p=Object.hasOwnProperty,h=Object.setPrototypeOf,f=("undefined"!=typeof Reflect&&Reflect).apply;function d(e,t){h&&h(e,null);for(var n=t.length;n--;){var r=t[n];if("string"==typeof r){var i=r.toLowerCase();i!==r&&(Object.isFrozen(t)||(t[n]=i),r=i)}e[r]=!0}return e}function g(e){var t={},n=void 0;for(n in e)f(p,e,[n])&&(t[n]=e[n]);return t}f||(f=function(e,t,n){return e.apply(t,n)});var m=Object.seal||function(e){return e},b=m(/\{\{[\s\S]*|[\s\S]*\}\}/gm),y=m(/<%[\s\S]*|[\s\S]*%>/gm),v=m(/^data-[\-\w.\u00B7-\uFFFF]/),x=m(/^aria-[\-\w]+$/),k=m(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),w=m(/^(?:\w+script|data):/i),_=m(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205f\u3000]/g),A="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};function S(e){if(Array.isArray(e)){for(var t=0,n=Array(e.length);t<e.length;t++)n[t]=e[t];return n}return Array.from(e)}var T=("undefined"!=typeof Reflect&&Reflect).apply,L=Array.prototype.slice,R=Object.freeze,E=function(){return"undefined"==typeof window?null:window};T||(T=function(e,t,n){return e.apply(t,n)});var O=function(e,t){if("object"!==(void 0===e?"undefined":A(e))||"function"!=typeof e.createPolicy)return null;var n=null;t.currentScript&&t.currentScript.hasAttribute("data-tt-policy-suffix")&&(n=t.currentScript.getAttribute("data-tt-policy-suffix"));var r="dompurify"+(n?"#"+n:"");try{return e.createPolicy(r,{createHTML:function(e){return e}})}catch(e){return console.warn("TrustedTypes policy "+r+" could not be created."),null}};return function e(){var s=arguments.length>0&&void 0!==arguments[0]?arguments[0]:E(),p=function(t){return e(t)};if(p.version="1.0.10",p.removed=[],!s||!s.document||9!==s.document.nodeType)return p.isSupported=!1,p;var h=s.document,f=!1,m=!1,$=s.document,z=s.DocumentFragment,C=s.HTMLTemplateElement,M=s.Node,N=s.NodeFilter,D=s.NamedNodeMap,j=void 0===D?s.NamedNodeMap||s.MozNamedAttrMap:D,U=s.Text,H=s.Comment,I=s.DOMParser,F=s.TrustedTypes;if("function"==typeof C){var q=$.createElement("template");q.content&&q.content.ownerDocument&&($=q.content.ownerDocument)}var B=O(F,h),P=B?B.createHTML(""):"",Z=$,G=Z.implementation,W=Z.createNodeIterator,J=Z.getElementsByTagName,V=Z.createDocumentFragment,X=h.importNode,Y={};p.isSupported=G&&void 0!==G.createHTMLDocument&&9!==$.documentMode;var K=b,Q=y,ee=v,te=x,ne=w,re=_,ie=k,oe=null,se=d({},[].concat(S(t),S(n),S(r),S(i),S(o))),ae=null,le=d({},[].concat(S(a),S(l),S(c),S(u))),ce=null,ue=null,pe=!0,he=!0,fe=!1,de=!1,ge=!1,me=!1,be=!1,ye=!1,ve=!1,xe=!1,ke=!1,we=!0,_e=!0,Ae=!1,Se={},Te=d({},["audio","head","math","script","style","template","svg","video"]),Le=d({},["audio","video","img","source","image"]),Re=d({},["alt","class","for","id","label","name","pattern","placeholder","summary","title","value","style","xmlns"]),Ee=null,Oe=$.createElement("form"),$e=function(e){Ee&&Ee===e||(e&&"object"===(void 0===e?"undefined":A(e))||(e={}),oe="ALLOWED_TAGS"in e?d({},e.ALLOWED_TAGS):se,ae="ALLOWED_ATTR"in e?d({},e.ALLOWED_ATTR):le,ce="FORBID_TAGS"in e?d({},e.FORBID_TAGS):{},ue="FORBID_ATTR"in e?d({},e.FORBID_ATTR):{},Se="USE_PROFILES"in e&&e.USE_PROFILES,pe=!1!==e.ALLOW_ARIA_ATTR,he=!1!==e.ALLOW_DATA_ATTR,fe=e.ALLOW_UNKNOWN_PROTOCOLS||!1,de=e.SAFE_FOR_JQUERY||!1,ge=e.SAFE_FOR_TEMPLATES||!1,me=e.WHOLE_DOCUMENT||!1,ve=e.RETURN_DOM||!1,xe=e.RETURN_DOM_FRAGMENT||!1,ke=e.RETURN_DOM_IMPORT||!1,ye=e.FORCE_BODY||!1,we=!1!==e.SANITIZE_DOM,_e=!1!==e.KEEP_CONTENT,Ae=e.IN_PLACE||!1,ie=e.ALLOWED_URI_REGEXP||ie,ge&&(he=!1),xe&&(ve=!0),Se&&(oe=d({},[].concat(S(o))),ae=[],!0===Se.html&&(d(oe,t),d(ae,a)),!0===Se.svg&&(d(oe,n),d(ae,l),d(ae,u)),!0===Se.svgFilters&&(d(oe,r),d(ae,l),d(ae,u)),!0===Se.mathMl&&(d(oe,i),d(ae,c),d(ae,u))),e.ADD_TAGS&&(oe===se&&(oe=g(oe)),d(oe,e.ADD_TAGS)),e.ADD_ATTR&&(ae===le&&(ae=g(ae)),d(ae,e.ADD_ATTR)),e.ADD_URI_SAFE_ATTR&&d(Re,e.ADD_URI_SAFE_ATTR),_e&&(oe["#text"]=!0),me&&d(oe,["html","head","body"]),oe.table&&d(oe,["tbody"]),R&&R(e),Ee=e)},ze=function(e){p.removed.push({element:e});try{e.parentNode.removeChild(e)}catch(t){e.outerHTML=P}},Ce=function(e,t){try{p.removed.push({attribute:t.getAttributeNode(e),from:t})}catch(e){p.removed.push({attribute:null,from:t})}t.removeAttribute(e)},Me=function(e){var t=void 0,n=void 0;if(ye)e="<remove></remove>"+e;else{var r=e.match(/^[\s]+/);(n=r&&r[0])&&(e=e.slice(n.length))}if(f)try{t=(new I).parseFromString(e,"text/html")}catch(e){}if(m&&d(ce,["title"]),!t||!t.documentElement){var i=t=G.createHTMLDocument(""),o=i.body;o.parentNode.removeChild(o.parentNode.firstElementChild),o.outerHTML=B?B.createHTML(e):e}return n&&t.body.insertBefore($.createTextNode(n),t.body.childNodes[0]||null),J.call(t,me?"html":"body")[0]};p.isSupported&&(function(){try{var e=Me('<svg><p><style><img src="</style><img src=x onerror=1//">');e.querySelector("svg img")&&(f=!0)}catch(e){}}(),function(){try{var e=Me("<x/><title></title><img>");e.querySelector("title").innerHTML.match(/<\/title/)&&(m=!0)}catch(e){}}());var Ne=function(e){return W.call(e.ownerDocument||e,e,N.SHOW_ELEMENT|N.SHOW_COMMENT|N.SHOW_TEXT,function(){return N.FILTER_ACCEPT},!1)},De=function(e){return"object"===(void 0===M?"undefined":A(M))?e instanceof M:e&&"object"===(void 0===e?"undefined":A(e))&&"number"==typeof e.nodeType&&"string"==typeof e.nodeName},je=function(e,t,n){Y[e]&&Y[e].forEach(function(e){e.call(p,t,n,Ee)})},Ue=function(e){var t,n=void 0;if(je("beforeSanitizeElements",e,null),!((t=e)instanceof U||t instanceof H||"string"==typeof t.nodeName&&"string"==typeof t.textContent&&"function"==typeof t.removeChild&&t.attributes instanceof j&&"function"==typeof t.removeAttribute&&"function"==typeof t.setAttribute))return ze(e),!0;var r=e.nodeName.toLowerCase();if(je("uponSanitizeElement",e,{tagName:r,allowedTags:oe}),!oe[r]||ce[r]){if(_e&&!Te[r]&&"function"==typeof e.insertAdjacentHTML)try{var i=e.innerHTML;e.insertAdjacentHTML("AfterEnd",B?B.createHTML(i):i)}catch(e){}return ze(e),!0}return"noscript"===r&&e.innerHTML.match(/<\/noscript/i)?(ze(e),!0):"noembed"===r&&e.innerHTML.match(/<\/noembed/i)?(ze(e),!0):(!de||e.firstElementChild||e.content&&e.content.firstElementChild||!/</g.test(e.textContent)||(p.removed.push({element:e.cloneNode()}),e.innerHTML?e.innerHTML=e.innerHTML.replace(/</g,"<"):e.innerHTML=e.textContent.replace(/</g,"<")),ge&&3===e.nodeType&&(n=(n=(n=e.textContent).replace(K," ")).replace(Q," "),e.textContent!==n&&(p.removed.push({element:e.cloneNode()}),e.textContent=n)),je("afterSanitizeElements",e,null),!1)},He=function(e,t,n){if(we&&("id"===t||"name"===t)&&(n in $||n in Oe))return!1;if(he&&ee.test(t));else if(pe&&te.test(t));else{if(!ae[t]||ue[t])return!1;if(Re[t]);else if(ie.test(n.replace(re,"")));else if("src"!==t&&"xlink:href"!==t||"script"===e||0!==n.indexOf("data:")||!Le[e])if(fe&&!ne.test(n.replace(re,"")));else if(n)return!1}return!0},Ie=function(e){var t=void 0,n=void 0,r=void 0,i=void 0,o=void 0;je("beforeSanitizeAttributes",e,null);var s=e.attributes;if(s){var a={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:ae};for(o=s.length;o--;){var l=t=s[o],c=l.name,u=l.namespaceURI;if(n=t.value.trim(),r=c.toLowerCase(),a.attrName=r,a.attrValue=n,a.keepAttr=!0,je("uponSanitizeAttribute",e,a),n=a.attrValue,"name"===r&&"IMG"===e.nodeName&&s.id)i=s.id,s=T(L,s,[]),Ce("id",e),Ce(c,e),s.indexOf(i)>o&&e.setAttribute("id",i.value);else{if("INPUT"===e.nodeName&&"type"===r&&"file"===n&&(ae[r]||!ue[r]))continue;"id"===c&&e.setAttribute(c,""),Ce(c,e)}if(a.keepAttr){ge&&(n=(n=n.replace(K," ")).replace(Q," "));var h=e.nodeName.toLowerCase();if(He(h,r,n))try{u?e.setAttributeNS(u,c,n):e.setAttribute(c,n),p.removed.pop()}catch(e){}}}je("afterSanitizeAttributes",e,null)}},Fe=function e(t){var n=void 0,r=Ne(t);for(je("beforeSanitizeShadowDOM",t,null);n=r.nextNode();)je("uponSanitizeShadowNode",n,null),Ue(n)||(n.content instanceof z&&e(n.content),Ie(n));je("afterSanitizeShadowDOM",t,null)};return p.sanitize=function(e,t){var n=void 0,r=void 0,i=void 0,o=void 0,a=void 0;if(e||(e="\x3c!--\x3e"),"string"!=typeof e&&!De(e)){if("function"!=typeof e.toString)throw new TypeError("toString is not a function");if("string"!=typeof(e=e.toString()))throw new TypeError("dirty is not a string, aborting")}if(!p.isSupported){if("object"===A(s.toStaticHTML)||"function"==typeof s.toStaticHTML){if("string"==typeof e)return s.toStaticHTML(e);if(De(e))return s.toStaticHTML(e.outerHTML)}return e}if(be||$e(t),p.removed=[],Ae);else if(e instanceof M)n=Me("\x3c!--\x3e"),1===(r=n.ownerDocument.importNode(e,!0)).nodeType&&"BODY"===r.nodeName?n=r:n.appendChild(r);else{if(!ve&&!ge&&!me&&-1===e.indexOf("<"))return B?B.createHTML(e):e;if(!(n=Me(e)))return ve?null:P}n&&ye&&ze(n.firstChild);for(var l=Ne(Ae?e:n);i=l.nextNode();)3===i.nodeType&&i===o||Ue(i)||(i.content instanceof z&&Fe(i.content),Ie(i),o=i);if(o=null,Ae)return e;if(ve){if(xe)for(a=V.call(n.ownerDocument);n.firstChild;)a.appendChild(n.firstChild);else a=n;return ke&&(a=X.call(h,a,!0)),a}var c=me?n.outerHTML:n.innerHTML;return ge&&(c=(c=c.replace(K," ")).replace(Q," ")),B?B.createHTML(c):c},p.setConfig=function(e){$e(e),be=!0},p.clearConfig=function(){Ee=null,be=!1},p.isValidAttribute=function(e,t,n){Ee||$e({});var r=e.toLowerCase(),i=t.toLowerCase();return He(r,i,n)},p.addHook=function(e,t){"function"==typeof t&&(Y[e]=Y[e]||[],Y[e].push(t))},p.removeHook=function(e){Y[e]&&Y[e].pop()},p.removeHooks=function(e){Y[e]&&(Y[e]=[])},p.removeAllHooks=function(){Y={}},p}()}()}}]); +(window.webpackJsonp=window.webpackJsonp||[]).push([[5],{19:function(e,t,n){"use strict";e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var n=function(e,t){var n=e[1]||"",r=e[3];if(!r)return n;if(t&&"function"==typeof btoa){var i=(s=r,"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(s))))+" */"),o=r.sources.map(function(e){return"/*# sourceURL="+r.sourceRoot+e+" */"});return[n].concat(o).concat([i]).join("\n")}var s;return[n].join("\n")}(t,e);return t[2]?"@media "+t[2]+"{"+n+"}":n}).join("")},t.i=function(e,n){"string"==typeof e&&(e=[[null,e,""]]);for(var r={},i=0;i<this.length;i++){var o=this[i][0];null!=o&&(r[o]=!0)}for(i=0;i<e.length;i++){var s=e[i];null!=s[0]&&r[s[0]]||(n&&!s[2]?s[2]=n:n&&(s[2]="("+s[2]+") and ("+n+")"),t.push(s))}},t}},20:function(e,t,n){var r,i,o={},s=(r=function(){return window&&document&&document.all&&!window.atob},function(){return void 0===i&&(i=r.apply(this,arguments)),i}),a=function(e){var t={};return function(e,n){if("function"==typeof e)return e();if(void 0===t[e]){var r=function(e,t){return t?t.querySelector(e):document.querySelector(e)}.call(this,e,n);if(window.HTMLIFrameElement&&r instanceof window.HTMLIFrameElement)try{r=r.contentDocument.head}catch(e){r=null}t[e]=r}return t[e]}}(),l=null,c=0,u=[],p=n(48);function h(e,t){for(var n=0;n<e.length;n++){var r=e[n],i=o[r.id];if(i){i.refs++;for(var s=0;s<i.parts.length;s++)i.parts[s](r.parts[s]);for(;s<r.parts.length;s++)i.parts.push(y(r.parts[s],t))}else{var a=[];for(s=0;s<r.parts.length;s++)a.push(y(r.parts[s],t));o[r.id]={id:r.id,refs:1,parts:a}}}}function f(e,t){for(var n=[],r={},i=0;i<e.length;i++){var o=e[i],s=t.base?o[0]+t.base:o[0],a={css:o[1],media:o[2],sourceMap:o[3]};r[s]?r[s].parts.push(a):n.push(r[s]={id:s,parts:[a]})}return n}function d(e,t){var n=a(e.insertInto);if(!n)throw new Error("Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid.");var r=u[u.length-1];if("top"===e.insertAt)r?r.nextSibling?n.insertBefore(t,r.nextSibling):n.appendChild(t):n.insertBefore(t,n.firstChild),u.push(t);else if("bottom"===e.insertAt)n.appendChild(t);else{if("object"!=typeof e.insertAt||!e.insertAt.before)throw new Error("[Style Loader]\n\n Invalid value for parameter 'insertAt' ('options.insertAt') found.\n Must be 'top', 'bottom', or Object.\n (https://github.com/webpack-contrib/style-loader#insertat)\n");var i=a(e.insertAt.before,n);n.insertBefore(t,i)}}function g(e){if(null===e.parentNode)return!1;e.parentNode.removeChild(e);var t=u.indexOf(e);t>=0&&u.splice(t,1)}function m(e){var t=document.createElement("style");if(void 0===e.attrs.type&&(e.attrs.type="text/css"),void 0===e.attrs.nonce){var r=function(){0;return n.nc}();r&&(e.attrs.nonce=r)}return b(t,e.attrs),d(e,t),t}function b(e,t){Object.keys(t).forEach(function(n){e.setAttribute(n,t[n])})}function y(e,t){var n,r,i,o;if(t.transform&&e.css){if(!(o="function"==typeof t.transform?t.transform(e.css):t.transform.default(e.css)))return function(){};e.css=o}if(t.singleton){var s=c++;n=l||(l=m(t)),r=k.bind(null,n,s,!1),i=k.bind(null,n,s,!0)}else e.sourceMap&&"function"==typeof URL&&"function"==typeof URL.createObjectURL&&"function"==typeof URL.revokeObjectURL&&"function"==typeof Blob&&"function"==typeof btoa?(n=function(e){var t=document.createElement("link");return void 0===e.attrs.type&&(e.attrs.type="text/css"),e.attrs.rel="stylesheet",b(t,e.attrs),d(e,t),t}(t),r=function(e,t,n){var r=n.css,i=n.sourceMap,o=void 0===t.convertToAbsoluteUrls&&i;(t.convertToAbsoluteUrls||o)&&(r=p(r));i&&(r+="\n/*# sourceMappingURL=data:application/json;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(i))))+" */");var s=new Blob([r],{type:"text/css"}),a=e.href;e.href=URL.createObjectURL(s),a&&URL.revokeObjectURL(a)}.bind(null,n,t),i=function(){g(n),n.href&&URL.revokeObjectURL(n.href)}):(n=m(t),r=function(e,t){var n=t.css,r=t.media;r&&e.setAttribute("media",r);if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}.bind(null,n),i=function(){g(n)});return r(e),function(t){if(t){if(t.css===e.css&&t.media===e.media&&t.sourceMap===e.sourceMap)return;r(e=t)}else i()}}e.exports=function(e,t){if("undefined"!=typeof DEBUG&&DEBUG&&"object"!=typeof document)throw new Error("The style-loader cannot be used in a non-browser environment");(t=t||{}).attrs="object"==typeof t.attrs?t.attrs:{},t.singleton||"boolean"==typeof t.singleton||(t.singleton=s()),t.insertInto||(t.insertInto="head"),t.insertAt||(t.insertAt="bottom");var n=f(e,t);return h(n,t),function(e){for(var r=[],i=0;i<n.length;i++){var s=n[i];(a=o[s.id]).refs--,r.push(a)}e&&h(f(e,t),t);for(i=0;i<r.length;i++){var a;if(0===(a=r[i]).refs){for(var l=0;l<a.parts.length;l++)a.parts[l]();delete o[a.id]}}}};var v,x=(v=[],function(e,t){return v[e]=t,v.filter(Boolean).join("\n")});function k(e,t,n,r){var i=n?"":r.css;if(e.styleSheet)e.styleSheet.cssText=x(t,i);else{var o=document.createTextNode(i),s=e.childNodes;s[t]&&e.removeChild(s[t]),s.length?e.insertBefore(o,s[t]):e.appendChild(o)}}},48:function(e,t){e.exports=function(e){var t="undefined"!=typeof window&&window.location;if(!t)throw new Error("fixUrls requires window.location");if(!e||"string"!=typeof e)return e;var n=t.protocol+"//"+t.host,r=n+t.pathname.replace(/\/[^\/]*$/,"/");return e.replace(/url\s*\(((?:[^)(]|\((?:[^)(]+|\([^)(]*\))*\))*)\)/gi,function(e,t){var i,o=t.trim().replace(/^"(.*)"$/,function(e,t){return t}).replace(/^'(.*)'$/,function(e,t){return t});return/^(#|data:|http:\/\/|https:\/\/|file:\/\/\/|\s*$)/i.test(o)?e:(i=0===o.indexOf("//")?o:0===o.indexOf("/")?n+o:r+o.replace(/^\.\//,""),"url("+JSON.stringify(i)+")")})}},74:function(e,t,n){(function(t){!function(t){"use strict";var n={newline:/^\n+/,code:/^( {4}[^\n]+\n*)+/,fences:m,hr:/^ {0,3}((?:- *){3,}|(?:_ *){3,}|(?:\* *){3,})(?:\n+|$)/,heading:/^ *(#{1,6}) *([^\n]+?) *(?:#+ *)?(?:\n+|$)/,nptable:m,blockquote:/^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/,list:/^( {0,3})(bull) [\s\S]+?(?:hr|def|\n{2,}(?! )(?!\1bull )\n*|\s*$)/,html:"^ {0,3}(?:<(script|pre|style)[\\s>][\\s\\S]*?(?:</\\1>[^\\n]*\\n+|$)|comment[^\\n]*(\\n+|$)|<\\?[\\s\\S]*?\\?>\\n*|<![A-Z][\\s\\S]*?>\\n*|<!\\[CDATA\\[[\\s\\S]*?\\]\\]>\\n*|</?(tag)(?: +|\\n|/?>)[\\s\\S]*?(?:\\n{2,}|$)|<(?!script|pre|style)([a-z][\\w-]*)(?:attribute)*? */?>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:\\n{2,}|$)|</(?!script|pre|style)[a-z][\\w-]*\\s*>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:\\n{2,}|$))",def:/^ {0,3}\[(label)\]: *\n? *<?([^\s>]+)>?(?:(?: +\n? *| *\n *)(title))? *(?:\n+|$)/,table:m,lheading:/^([^\n]+)\n *(=|-){2,} *(?:\n+|$)/,paragraph:/^([^\n]+(?:\n(?!hr|heading|lheading| {0,3}>|<\/?(?:tag)(?: +|\n|\/?>)|<(?:script|pre|style|!--))[^\n]+)*)/,text:/^[^\n]+/};function r(e){this.tokens=[],this.tokens.links=Object.create(null),this.options=e||k.defaults,this.rules=n.normal,this.options.pedantic?this.rules=n.pedantic:this.options.gfm&&(this.options.tables?this.rules=n.tables:this.rules=n.gfm)}n._label=/(?!\s*\])(?:\\[\[\]]|[^\[\]])+/,n._title=/(?:"(?:\\"?|[^"\\])*"|'[^'\n]*(?:\n[^'\n]+)*\n?'|\([^()]*\))/,n.def=h(n.def).replace("label",n._label).replace("title",n._title).getRegex(),n.bullet=/(?:[*+-]|\d{1,9}\.)/,n.item=/^( *)(bull) ?[^\n]*(?:\n(?!\1bull ?)[^\n]*)*/,n.item=h(n.item,"gm").replace(/bull/g,n.bullet).getRegex(),n.list=h(n.list).replace(/bull/g,n.bullet).replace("hr","\\n+(?=\\1?(?:(?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$))").replace("def","\\n+(?="+n.def.source+")").getRegex(),n._tag="address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul",n._comment=/<!--(?!-?>)[\s\S]*?-->/,n.html=h(n.html,"i").replace("comment",n._comment).replace("tag",n._tag).replace("attribute",/ +[a-zA-Z:_][\w.:-]*(?: *= *"[^"\n]*"| *= *'[^'\n]*'| *= *[^\s"'=<>`]+)?/).getRegex(),n.paragraph=h(n.paragraph).replace("hr",n.hr).replace("heading",n.heading).replace("lheading",n.lheading).replace("tag",n._tag).getRegex(),n.blockquote=h(n.blockquote).replace("paragraph",n.paragraph).getRegex(),n.normal=b({},n),n.gfm=b({},n.normal,{fences:/^ {0,3}(`{3,}|~{3,})([^`\n]*)\n(?:|([\s\S]*?)\n)(?: {0,3}\1[~`]* *(?:\n+|$)|$)/,paragraph:/^/,heading:/^ *(#{1,6}) +([^\n]+?) *#* *(?:\n+|$)/}),n.gfm.paragraph=h(n.paragraph).replace("(?!","(?!"+n.gfm.fences.source.replace("\\1","\\2")+"|"+n.list.source.replace("\\1","\\3")+"|").getRegex(),n.tables=b({},n.gfm,{nptable:/^ *([^|\n ].*\|.*)\n *([-:]+ *\|[-| :]*)(?:\n((?:.*[^>\n ].*(?:\n|$))*)\n*|$)/,table:/^ *\|(.+)\n *\|?( *[-:]+[-| :]*)(?:\n((?: *[^>\n ].*(?:\n|$))*)\n*|$)/}),n.pedantic=b({},n.normal,{html:h("^ *(?:comment *(?:\\n|\\s*$)|<(tag)[\\s\\S]+?</\\1> *(?:\\n{2,}|\\s*$)|<tag(?:\"[^\"]*\"|'[^']*'|\\s[^'\"/>\\s]*)*?/?> *(?:\\n{2,}|\\s*$))").replace("comment",n._comment).replace(/tag/g,"(?!(?:a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)\\b)\\w+(?!:|[^\\w\\s@]*@)\\b").getRegex(),def:/^ *\[([^\]]+)\]: *<?([^\s>]+)>?(?: +(["(][^\n]+[")]))? *(?:\n+|$)/}),r.rules=n,r.lex=function(e,t){return new r(t).lex(e)},r.prototype.lex=function(e){return e=e.replace(/\r\n|\r/g,"\n").replace(/\t/g," ").replace(/\u00a0/g," ").replace(/\u2424/g,"\n"),this.token(e,!0)},r.prototype.token=function(e,t){var r,i,o,s,a,l,c,u,p,h,f,d,g,m,b,x;for(e=e.replace(/^ +$/gm,"");e;)if((o=this.rules.newline.exec(e))&&(e=e.substring(o[0].length),o[0].length>1&&this.tokens.push({type:"space"})),o=this.rules.code.exec(e))e=e.substring(o[0].length),o=o[0].replace(/^ {4}/gm,""),this.tokens.push({type:"code",text:this.options.pedantic?o:v(o,"\n")});else if(o=this.rules.fences.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"code",lang:o[2]?o[2].trim():o[2],text:o[3]||""});else if(o=this.rules.heading.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"heading",depth:o[1].length,text:o[2]});else if((o=this.rules.nptable.exec(e))&&(l={type:"table",header:y(o[1].replace(/^ *| *\| *$/g,"")),align:o[2].replace(/^ *|\| *$/g,"").split(/ *\| */),cells:o[3]?o[3].replace(/\n$/,"").split("\n"):[]}).header.length===l.align.length){for(e=e.substring(o[0].length),f=0;f<l.align.length;f++)/^ *-+: *$/.test(l.align[f])?l.align[f]="right":/^ *:-+: *$/.test(l.align[f])?l.align[f]="center":/^ *:-+ *$/.test(l.align[f])?l.align[f]="left":l.align[f]=null;for(f=0;f<l.cells.length;f++)l.cells[f]=y(l.cells[f],l.header.length);this.tokens.push(l)}else if(o=this.rules.hr.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"hr"});else if(o=this.rules.blockquote.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"blockquote_start"}),o=o[0].replace(/^ *> ?/gm,""),this.token(o,t),this.tokens.push({type:"blockquote_end"});else if(o=this.rules.list.exec(e)){for(e=e.substring(o[0].length),c={type:"list_start",ordered:m=(s=o[2]).length>1,start:m?+s:"",loose:!1},this.tokens.push(c),u=[],r=!1,g=(o=o[0].match(this.rules.item)).length,f=0;f<g;f++)h=(l=o[f]).length,~(l=l.replace(/^ *([*+-]|\d+\.) */,"")).indexOf("\n ")&&(h-=l.length,l=this.options.pedantic?l.replace(/^ {1,4}/gm,""):l.replace(new RegExp("^ {1,"+h+"}","gm"),"")),f!==g-1&&(a=n.bullet.exec(o[f+1])[0],(s.length>1?1===a.length:a.length>1||this.options.smartLists&&a!==s)&&(e=o.slice(f+1).join("\n")+e,f=g-1)),i=r||/\n\n(?!\s*$)/.test(l),f!==g-1&&(r="\n"===l.charAt(l.length-1),i||(i=r)),i&&(c.loose=!0),x=void 0,(b=/^\[[ xX]\] /.test(l))&&(x=" "!==l[1],l=l.replace(/^\[[ xX]\] +/,"")),p={type:"list_item_start",task:b,checked:x,loose:i},u.push(p),this.tokens.push(p),this.token(l,!1),this.tokens.push({type:"list_item_end"});if(c.loose)for(g=u.length,f=0;f<g;f++)u[f].loose=!0;this.tokens.push({type:"list_end"})}else if(o=this.rules.html.exec(e))e=e.substring(o[0].length),this.tokens.push({type:this.options.sanitize?"paragraph":"html",pre:!this.options.sanitizer&&("pre"===o[1]||"script"===o[1]||"style"===o[1]),text:o[0]});else if(t&&(o=this.rules.def.exec(e)))e=e.substring(o[0].length),o[3]&&(o[3]=o[3].substring(1,o[3].length-1)),d=o[1].toLowerCase().replace(/\s+/g," "),this.tokens.links[d]||(this.tokens.links[d]={href:o[2],title:o[3]});else if((o=this.rules.table.exec(e))&&(l={type:"table",header:y(o[1].replace(/^ *| *\| *$/g,"")),align:o[2].replace(/^ *|\| *$/g,"").split(/ *\| */),cells:o[3]?o[3].replace(/\n$/,"").split("\n"):[]}).header.length===l.align.length){for(e=e.substring(o[0].length),f=0;f<l.align.length;f++)/^ *-+: *$/.test(l.align[f])?l.align[f]="right":/^ *:-+: *$/.test(l.align[f])?l.align[f]="center":/^ *:-+ *$/.test(l.align[f])?l.align[f]="left":l.align[f]=null;for(f=0;f<l.cells.length;f++)l.cells[f]=y(l.cells[f].replace(/^ *\| *| *\| *$/g,""),l.header.length);this.tokens.push(l)}else if(o=this.rules.lheading.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"heading",depth:"="===o[2]?1:2,text:o[1]});else if(t&&(o=this.rules.paragraph.exec(e)))e=e.substring(o[0].length),this.tokens.push({type:"paragraph",text:"\n"===o[1].charAt(o[1].length-1)?o[1].slice(0,-1):o[1]});else if(o=this.rules.text.exec(e))e=e.substring(o[0].length),this.tokens.push({type:"text",text:o[0]});else if(e)throw new Error("Infinite loop on byte: "+e.charCodeAt(0));return this.tokens};var i={escape:/^\\([!"#$%&'()*+,\-.\/:;<=>?@\[\]\\^_`{|}~])/,autolink:/^<(scheme:[^\s\x00-\x1f<>]*|email)>/,url:m,tag:"^comment|^</[a-zA-Z][\\w:-]*\\s*>|^<[a-zA-Z][\\w-]*(?:attribute)*?\\s*/?>|^<\\?[\\s\\S]*?\\?>|^<![a-zA-Z]+\\s[\\s\\S]*?>|^<!\\[CDATA\\[[\\s\\S]*?\\]\\]>",link:/^!?\[(label)\]\(href(?:\s+(title))?\s*\)/,reflink:/^!?\[(label)\]\[(?!\s*\])((?:\\[\[\]]?|[^\[\]\\])+)\]/,nolink:/^!?\[(?!\s*\])((?:\[[^\[\]]*\]|\\[\[\]]|[^\[\]])*)\](?:\[\])?/,strong:/^__([^\s_])__(?!_)|^\*\*([^\s*])\*\*(?!\*)|^__([^\s][\s\S]*?[^\s])__(?!_)|^\*\*([^\s][\s\S]*?[^\s])\*\*(?!\*)/,em:/^_([^\s_])_(?!_)|^\*([^\s*"<\[])\*(?!\*)|^_([^\s][\s\S]*?[^\s_])_(?!_|[^\spunctuation])|^_([^\s_][\s\S]*?[^\s])_(?!_|[^\spunctuation])|^\*([^\s"<\[][\s\S]*?[^\s*])\*(?!\*)|^\*([^\s*"<\[][\s\S]*?[^\s])\*(?!\*)/,code:/^(`+)([^`]|[^`][\s\S]*?[^`])\1(?!`)/,br:/^( {2,}|\\)\n(?!\s*$)/,del:m,text:/^(`+|[^`])(?:[\s\S]*?(?:(?=[\\<!\[`*]|\b_|$)|[^ ](?= {2,}\n))|(?= {2,}\n))/};function o(e,t){if(this.options=t||k.defaults,this.links=e,this.rules=i.normal,this.renderer=this.options.renderer||new s,this.renderer.options=this.options,!this.links)throw new Error("Tokens array requires a `links` property.");this.options.pedantic?this.rules=i.pedantic:this.options.gfm&&(this.options.breaks?this.rules=i.breaks:this.rules=i.gfm)}function s(e){this.options=e||k.defaults}function a(){}function l(e){this.tokens=[],this.token=null,this.options=e||k.defaults,this.options.renderer=this.options.renderer||new s,this.renderer=this.options.renderer,this.renderer.options=this.options,this.slugger=new c}function c(){this.seen={}}function u(e,t){if(t){if(u.escapeTest.test(e))return e.replace(u.escapeReplace,function(e){return u.replacements[e]})}else if(u.escapeTestNoEncode.test(e))return e.replace(u.escapeReplaceNoEncode,function(e){return u.replacements[e]});return e}function p(e){return e.replace(/&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/gi,function(e,t){return"colon"===(t=t.toLowerCase())?":":"#"===t.charAt(0)?"x"===t.charAt(1)?String.fromCharCode(parseInt(t.substring(2),16)):String.fromCharCode(+t.substring(1)):""})}function h(e,t){return e=e.source||e,t=t||"",{replace:function(t,n){return n=(n=n.source||n).replace(/(^|[^\[])\^/g,"$1"),e=e.replace(t,n),this},getRegex:function(){return new RegExp(e,t)}}}function f(e,t,n){if(e){try{var r=decodeURIComponent(p(n)).replace(/[^\w:]/g,"").toLowerCase()}catch(e){return null}if(0===r.indexOf("javascript:")||0===r.indexOf("vbscript:")||0===r.indexOf("data:"))return null}t&&!g.test(n)&&(n=function(e,t){d[" "+e]||(/^[^:]+:\/*[^\/]*$/.test(e)?d[" "+e]=e+"/":d[" "+e]=v(e,"/",!0));return e=d[" "+e],"//"===t.slice(0,2)?e.replace(/:[\s\S]*/,":")+t:"/"===t.charAt(0)?e.replace(/(:\/*[^\/]*)[\s\S]*/,"$1")+t:e+t}(t,n));try{n=encodeURI(n).replace(/%25/g,"%")}catch(e){return null}return n}i._punctuation="!\"#$%&'()*+,\\-./:;<=>?@\\[^_{|}~",i.em=h(i.em).replace(/punctuation/g,i._punctuation).getRegex(),i._escapes=/\\([!"#$%&'()*+,\-.\/:;<=>?@\[\]\\^_`{|}~])/g,i._scheme=/[a-zA-Z][a-zA-Z0-9+.-]{1,31}/,i._email=/[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/,i.autolink=h(i.autolink).replace("scheme",i._scheme).replace("email",i._email).getRegex(),i._attribute=/\s+[a-zA-Z:_][\w.:-]*(?:\s*=\s*"[^"]*"|\s*=\s*'[^']*'|\s*=\s*[^\s"'=<>`]+)?/,i.tag=h(i.tag).replace("comment",n._comment).replace("attribute",i._attribute).getRegex(),i._label=/(?:\[[^\[\]]*\]|\\[\[\]]?|`[^`]*`|`(?!`)|[^\[\]\\`])*?/,i._href=/\s*(<(?:\\[<>]?|[^\s<>\\])*>|[^\s\x00-\x1f]*)/,i._title=/"(?:\\"?|[^"\\])*"|'(?:\\'?|[^'\\])*'|\((?:\\\)?|[^)\\])*\)/,i.link=h(i.link).replace("label",i._label).replace("href",i._href).replace("title",i._title).getRegex(),i.reflink=h(i.reflink).replace("label",i._label).getRegex(),i.normal=b({},i),i.pedantic=b({},i.normal,{strong:/^__(?=\S)([\s\S]*?\S)__(?!_)|^\*\*(?=\S)([\s\S]*?\S)\*\*(?!\*)/,em:/^_(?=\S)([\s\S]*?\S)_(?!_)|^\*(?=\S)([\s\S]*?\S)\*(?!\*)/,link:h(/^!?\[(label)\]\((.*?)\)/).replace("label",i._label).getRegex(),reflink:h(/^!?\[(label)\]\s*\[([^\]]*)\]/).replace("label",i._label).getRegex()}),i.gfm=b({},i.normal,{escape:h(i.escape).replace("])","~|])").getRegex(),_extended_email:/[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/,url:/^((?:ftp|https?):\/\/|www\.)(?:[a-zA-Z0-9\-]+\.?)+[^\s<]*|^email/,_backpedal:/(?:[^?!.,:;*_~()&]+|\([^)]*\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_~)]+(?!$))+/,del:/^~+(?=\S)([\s\S]*?\S)~+/,text:/^(`+|[^`])(?:[\s\S]*?(?:(?=[\\<!\[`*~]|\b_|https?:\/\/|ftp:\/\/|www\.|$)|[^ ](?= {2,}\n)|[^a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-](?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@))|(?= {2,}\n|[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@))/}),i.gfm.url=h(i.gfm.url,"i").replace("email",i.gfm._extended_email).getRegex(),i.breaks=b({},i.gfm,{br:h(i.br).replace("{2,}","*").getRegex(),text:h(i.gfm.text).replace(/\{2,\}/g,"*").getRegex()}),o.rules=i,o.output=function(e,t,n){return new o(t,n).output(e)},o.prototype.output=function(e){for(var t,n,r,i,s,a,l="";e;)if(s=this.rules.escape.exec(e))e=e.substring(s[0].length),l+=u(s[1]);else if(s=this.rules.tag.exec(e))!this.inLink&&/^<a /i.test(s[0])?this.inLink=!0:this.inLink&&/^<\/a>/i.test(s[0])&&(this.inLink=!1),!this.inRawBlock&&/^<(pre|code|kbd|script)(\s|>)/i.test(s[0])?this.inRawBlock=!0:this.inRawBlock&&/^<\/(pre|code|kbd|script)(\s|>)/i.test(s[0])&&(this.inRawBlock=!1),e=e.substring(s[0].length),l+=this.options.sanitize?this.options.sanitizer?this.options.sanitizer(s[0]):u(s[0]):s[0];else if(s=this.rules.link.exec(e)){var c=x(s[2],"()");if(c>-1){var p=s[0].length-(s[2].length-c)-(s[3]||"").length;s[2]=s[2].substring(0,c),s[0]=s[0].substring(0,p).trim(),s[3]=""}e=e.substring(s[0].length),this.inLink=!0,r=s[2],this.options.pedantic?(t=/^([^'"]*[^\s])\s+(['"])(.*)\2/.exec(r))?(r=t[1],i=t[3]):i="":i=s[3]?s[3].slice(1,-1):"",r=r.trim().replace(/^<([\s\S]*)>$/,"$1"),l+=this.outputLink(s,{href:o.escapes(r),title:o.escapes(i)}),this.inLink=!1}else if((s=this.rules.reflink.exec(e))||(s=this.rules.nolink.exec(e))){if(e=e.substring(s[0].length),t=(s[2]||s[1]).replace(/\s+/g," "),!(t=this.links[t.toLowerCase()])||!t.href){l+=s[0].charAt(0),e=s[0].substring(1)+e;continue}this.inLink=!0,l+=this.outputLink(s,t),this.inLink=!1}else if(s=this.rules.strong.exec(e))e=e.substring(s[0].length),l+=this.renderer.strong(this.output(s[4]||s[3]||s[2]||s[1]));else if(s=this.rules.em.exec(e))e=e.substring(s[0].length),l+=this.renderer.em(this.output(s[6]||s[5]||s[4]||s[3]||s[2]||s[1]));else if(s=this.rules.code.exec(e))e=e.substring(s[0].length),l+=this.renderer.codespan(u(s[2].trim(),!0));else if(s=this.rules.br.exec(e))e=e.substring(s[0].length),l+=this.renderer.br();else if(s=this.rules.del.exec(e))e=e.substring(s[0].length),l+=this.renderer.del(this.output(s[1]));else if(s=this.rules.autolink.exec(e))e=e.substring(s[0].length),r="@"===s[2]?"mailto:"+(n=u(this.mangle(s[1]))):n=u(s[1]),l+=this.renderer.link(r,null,n);else if(this.inLink||!(s=this.rules.url.exec(e))){if(s=this.rules.text.exec(e))e=e.substring(s[0].length),this.inRawBlock?l+=this.renderer.text(s[0]):l+=this.renderer.text(u(this.smartypants(s[0])));else if(e)throw new Error("Infinite loop on byte: "+e.charCodeAt(0))}else{if("@"===s[2])r="mailto:"+(n=u(s[0]));else{do{a=s[0],s[0]=this.rules._backpedal.exec(s[0])[0]}while(a!==s[0]);n=u(s[0]),r="www."===s[1]?"http://"+n:n}e=e.substring(s[0].length),l+=this.renderer.link(r,null,n)}return l},o.escapes=function(e){return e?e.replace(o.rules._escapes,"$1"):e},o.prototype.outputLink=function(e,t){var n=t.href,r=t.title?u(t.title):null;return"!"!==e[0].charAt(0)?this.renderer.link(n,r,this.output(e[1])):this.renderer.image(n,r,u(e[1]))},o.prototype.smartypants=function(e){return this.options.smartypants?e.replace(/---/g,"—").replace(/--/g,"–").replace(/(^|[-\u2014\/(\[{"\s])'/g,"$1‘").replace(/'/g,"’").replace(/(^|[-\u2014\/(\[{\u2018\s])"/g,"$1“").replace(/"/g,"”").replace(/\.{3}/g,"…"):e},o.prototype.mangle=function(e){if(!this.options.mangle)return e;for(var t,n="",r=e.length,i=0;i<r;i++)t=e.charCodeAt(i),Math.random()>.5&&(t="x"+t.toString(16)),n+="&#"+t+";";return n},s.prototype.code=function(e,t,n){var r=(t||"").match(/\S*/)[0];if(this.options.highlight){var i=this.options.highlight(e,r);null!=i&&i!==e&&(n=!0,e=i)}return r?'<pre><code class="'+this.options.langPrefix+u(r,!0)+'">'+(n?e:u(e,!0))+"</code></pre>\n":"<pre><code>"+(n?e:u(e,!0))+"</code></pre>"},s.prototype.blockquote=function(e){return"<blockquote>\n"+e+"</blockquote>\n"},s.prototype.html=function(e){return e},s.prototype.heading=function(e,t,n,r){return this.options.headerIds?"<h"+t+' id="'+this.options.headerPrefix+r.slug(n)+'">'+e+"</h"+t+">\n":"<h"+t+">"+e+"</h"+t+">\n"},s.prototype.hr=function(){return this.options.xhtml?"<hr/>\n":"<hr>\n"},s.prototype.list=function(e,t,n){var r=t?"ol":"ul";return"<"+r+(t&&1!==n?' start="'+n+'"':"")+">\n"+e+"</"+r+">\n"},s.prototype.listitem=function(e){return"<li>"+e+"</li>\n"},s.prototype.checkbox=function(e){return"<input "+(e?'checked="" ':"")+'disabled="" type="checkbox"'+(this.options.xhtml?" /":"")+"> "},s.prototype.paragraph=function(e){return"<p>"+e+"</p>\n"},s.prototype.table=function(e,t){return t&&(t="<tbody>"+t+"</tbody>"),"<table>\n<thead>\n"+e+"</thead>\n"+t+"</table>\n"},s.prototype.tablerow=function(e){return"<tr>\n"+e+"</tr>\n"},s.prototype.tablecell=function(e,t){var n=t.header?"th":"td";return(t.align?"<"+n+' align="'+t.align+'">':"<"+n+">")+e+"</"+n+">\n"},s.prototype.strong=function(e){return"<strong>"+e+"</strong>"},s.prototype.em=function(e){return"<em>"+e+"</em>"},s.prototype.codespan=function(e){return"<code>"+e+"</code>"},s.prototype.br=function(){return this.options.xhtml?"<br/>":"<br>"},s.prototype.del=function(e){return"<del>"+e+"</del>"},s.prototype.link=function(e,t,n){if(null===(e=f(this.options.sanitize,this.options.baseUrl,e)))return n;var r='<a href="'+u(e)+'"';return t&&(r+=' title="'+t+'"'),r+=">"+n+"</a>"},s.prototype.image=function(e,t,n){if(null===(e=f(this.options.sanitize,this.options.baseUrl,e)))return n;var r='<img src="'+e+'" alt="'+n+'"';return t&&(r+=' title="'+t+'"'),r+=this.options.xhtml?"/>":">"},s.prototype.text=function(e){return e},a.prototype.strong=a.prototype.em=a.prototype.codespan=a.prototype.del=a.prototype.text=function(e){return e},a.prototype.link=a.prototype.image=function(e,t,n){return""+n},a.prototype.br=function(){return""},l.parse=function(e,t){return new l(t).parse(e)},l.prototype.parse=function(e){this.inline=new o(e.links,this.options),this.inlineText=new o(e.links,b({},this.options,{renderer:new a})),this.tokens=e.reverse();for(var t="";this.next();)t+=this.tok();return t},l.prototype.next=function(){return this.token=this.tokens.pop()},l.prototype.peek=function(){return this.tokens[this.tokens.length-1]||0},l.prototype.parseText=function(){for(var e=this.token.text;"text"===this.peek().type;)e+="\n"+this.next().text;return this.inline.output(e)},l.prototype.tok=function(){switch(this.token.type){case"space":return"";case"hr":return this.renderer.hr();case"heading":return this.renderer.heading(this.inline.output(this.token.text),this.token.depth,p(this.inlineText.output(this.token.text)),this.slugger);case"code":return this.renderer.code(this.token.text,this.token.lang,this.token.escaped);case"table":var e,t,n,r,i="",o="";for(n="",e=0;e<this.token.header.length;e++)n+=this.renderer.tablecell(this.inline.output(this.token.header[e]),{header:!0,align:this.token.align[e]});for(i+=this.renderer.tablerow(n),e=0;e<this.token.cells.length;e++){for(t=this.token.cells[e],n="",r=0;r<t.length;r++)n+=this.renderer.tablecell(this.inline.output(t[r]),{header:!1,align:this.token.align[r]});o+=this.renderer.tablerow(n)}return this.renderer.table(i,o);case"blockquote_start":for(o="";"blockquote_end"!==this.next().type;)o+=this.tok();return this.renderer.blockquote(o);case"list_start":o="";for(var s=this.token.ordered,a=this.token.start;"list_end"!==this.next().type;)o+=this.tok();return this.renderer.list(o,s,a);case"list_item_start":o="";var l=this.token.loose,c=this.token.checked,u=this.token.task;for(this.token.task&&(o+=this.renderer.checkbox(c));"list_item_end"!==this.next().type;)o+=l||"text"!==this.token.type?this.tok():this.parseText();return this.renderer.listitem(o,u,c);case"html":return this.renderer.html(this.token.text);case"paragraph":return this.renderer.paragraph(this.inline.output(this.token.text));case"text":return this.renderer.paragraph(this.parseText());default:var h='Token with "'+this.token.type+'" type was not found.';if(!this.options.silent)throw new Error(h);console.log(h)}},c.prototype.slug=function(e){var t=e.toLowerCase().trim().replace(/[\u2000-\u206F\u2E00-\u2E7F\\'!"#$%&()*+,.\/:;<=>?@[\]^`{|}~]/g,"").replace(/\s/g,"-");if(this.seen.hasOwnProperty(t)){var n=t;do{this.seen[n]++,t=n+"-"+this.seen[n]}while(this.seen.hasOwnProperty(t))}return this.seen[t]=0,t},u.escapeTest=/[&<>"']/,u.escapeReplace=/[&<>"']/g,u.replacements={"&":"&","<":"<",">":">",'"':""","'":"'"},u.escapeTestNoEncode=/[<>"']|&(?!#?\w+;)/,u.escapeReplaceNoEncode=/[<>"']|&(?!#?\w+;)/g;var d={},g=/^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;function m(){}function b(e){for(var t,n,r=1;r<arguments.length;r++)for(n in t=arguments[r])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}function y(e,t){var n=e.replace(/\|/g,function(e,t,n){for(var r=!1,i=t;--i>=0&&"\\"===n[i];)r=!r;return r?"|":" |"}).split(/ \|/),r=0;if(n.length>t)n.splice(t);else for(;n.length<t;)n.push("");for(;r<n.length;r++)n[r]=n[r].trim().replace(/\\\|/g,"|");return n}function v(e,t,n){if(0===e.length)return"";for(var r=0;r<e.length;){var i=e.charAt(e.length-r-1);if(i!==t||n){if(i===t||!n)break;r++}else r++}return e.substr(0,e.length-r)}function x(e,t){if(-1===e.indexOf(t[1]))return-1;for(var n=0,r=0;r<e.length;r++)if("\\"===e[r])r++;else if(e[r]===t[0])n++;else if(e[r]===t[1]&&--n<0)return r;return-1}function k(e,t,n){if(null==e)throw new Error("marked(): input parameter is undefined or null");if("string"!=typeof e)throw new Error("marked(): input parameter is of type "+Object.prototype.toString.call(e)+", string expected");if(n||"function"==typeof t){n||(n=t,t=null);var i,o,s=(t=b({},k.defaults,t||{})).highlight,a=0;try{i=r.lex(e,t)}catch(e){return n(e)}o=i.length;var c=function(e){if(e)return t.highlight=s,n(e);var r;try{r=l.parse(i,t)}catch(t){e=t}return t.highlight=s,e?n(e):n(null,r)};if(!s||s.length<3)return c();if(delete t.highlight,!o)return c();for(;a<i.length;a++)!function(e){"code"!==e.type?--o||c():s(e.text,e.lang,function(t,n){return t?c(t):null==n||n===e.text?--o||c():(e.text=n,e.escaped=!0,void(--o||c()))})}(i[a])}else try{return t&&(t=b({},k.defaults,t)),l.parse(r.lex(e,t),t)}catch(e){if(e.message+="\nPlease report this to https://github.com/markedjs/marked.",(t||k.defaults).silent)return"<p>An error occurred:</p><pre>"+u(e.message+"",!0)+"</pre>";throw e}}m.exec=m,k.options=k.setOptions=function(e){return b(k.defaults,e),k},k.getDefaults=function(){return{baseUrl:null,breaks:!1,gfm:!0,headerIds:!0,headerPrefix:"",highlight:null,langPrefix:"language-",mangle:!0,pedantic:!1,renderer:new s,sanitize:!1,sanitizer:null,silent:!1,smartLists:!1,smartypants:!1,tables:!0,xhtml:!1}},k.defaults=k.getDefaults(),k.Parser=l,k.parser=l.parse,k.Renderer=s,k.TextRenderer=a,k.Lexer=r,k.lexer=r.lex,k.InlineLexer=o,k.inlineLexer=o.output,k.Slugger=c,k.parse=k,e.exports=k}(this||"undefined"!=typeof window&&window)}).call(this,n(3))},75:function(e,t,n){e.exports=function(){"use strict";var e=Object.freeze||function(e){return e},t=e(["a","abbr","acronym","address","area","article","aside","audio","b","bdi","bdo","big","blink","blockquote","body","br","button","canvas","caption","center","cite","code","col","colgroup","content","data","datalist","dd","decorator","del","details","dfn","dir","div","dl","dt","element","em","fieldset","figcaption","figure","font","footer","form","h1","h2","h3","h4","h5","h6","head","header","hgroup","hr","html","i","img","input","ins","kbd","label","legend","li","main","map","mark","marquee","menu","menuitem","meter","nav","nobr","ol","optgroup","option","output","p","pre","progress","q","rp","rt","ruby","s","samp","section","select","shadow","small","source","spacer","span","strike","strong","style","sub","summary","sup","table","tbody","td","template","textarea","tfoot","th","thead","time","tr","track","tt","u","ul","var","video","wbr"]),n=e(["svg","a","altglyph","altglyphdef","altglyphitem","animatecolor","animatemotion","animatetransform","audio","canvas","circle","clippath","defs","desc","ellipse","filter","font","g","glyph","glyphref","hkern","image","line","lineargradient","marker","mask","metadata","mpath","path","pattern","polygon","polyline","radialgradient","rect","stop","style","switch","symbol","text","textpath","title","tref","tspan","video","view","vkern"]),r=e(["feBlend","feColorMatrix","feComponentTransfer","feComposite","feConvolveMatrix","feDiffuseLighting","feDisplacementMap","feDistantLight","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feMerge","feMergeNode","feMorphology","feOffset","fePointLight","feSpecularLighting","feSpotLight","feTile","feTurbulence"]),i=e(["math","menclose","merror","mfenced","mfrac","mglyph","mi","mlabeledtr","mmultiscripts","mn","mo","mover","mpadded","mphantom","mroot","mrow","ms","mspace","msqrt","mstyle","msub","msup","msubsup","mtable","mtd","mtext","mtr","munder","munderover"]),o=e(["#text"]),s=Object.freeze||function(e){return e},a=s(["accept","action","align","alt","autocomplete","background","bgcolor","border","cellpadding","cellspacing","checked","cite","class","clear","color","cols","colspan","controls","coords","crossorigin","datetime","default","dir","disabled","download","enctype","face","for","headers","height","hidden","high","href","hreflang","id","integrity","ismap","label","lang","list","loop","low","max","maxlength","media","method","min","multiple","name","noshade","novalidate","nowrap","open","optimum","pattern","placeholder","poster","preload","pubdate","radiogroup","readonly","rel","required","rev","reversed","role","rows","rowspan","spellcheck","scope","selected","shape","size","sizes","span","srclang","start","src","srcset","step","style","summary","tabindex","title","type","usemap","valign","value","width","xmlns"]),l=s(["accent-height","accumulate","additive","alignment-baseline","ascent","attributename","attributetype","azimuth","basefrequency","baseline-shift","begin","bias","by","class","clip","clip-path","clip-rule","color","color-interpolation","color-interpolation-filters","color-profile","color-rendering","cx","cy","d","dx","dy","diffuseconstant","direction","display","divisor","dur","edgemode","elevation","end","fill","fill-opacity","fill-rule","filter","filterunits","flood-color","flood-opacity","font-family","font-size","font-size-adjust","font-stretch","font-style","font-variant","font-weight","fx","fy","g1","g2","glyph-name","glyphref","gradientunits","gradienttransform","height","href","id","image-rendering","in","in2","k","k1","k2","k3","k4","kerning","keypoints","keysplines","keytimes","lang","lengthadjust","letter-spacing","kernelmatrix","kernelunitlength","lighting-color","local","marker-end","marker-mid","marker-start","markerheight","markerunits","markerwidth","maskcontentunits","maskunits","max","mask","media","method","mode","min","name","numoctaves","offset","operator","opacity","order","orient","orientation","origin","overflow","paint-order","path","pathlength","patterncontentunits","patterntransform","patternunits","points","preservealpha","preserveaspectratio","primitiveunits","r","rx","ry","radius","refx","refy","repeatcount","repeatdur","restart","result","rotate","scale","seed","shape-rendering","specularconstant","specularexponent","spreadmethod","stddeviation","stitchtiles","stop-color","stop-opacity","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke","stroke-width","style","surfacescale","tabindex","targetx","targety","transform","text-anchor","text-decoration","text-rendering","textlength","type","u1","u2","unicode","values","viewbox","visibility","version","vert-adv-y","vert-origin-x","vert-origin-y","width","word-spacing","wrap","writing-mode","xchannelselector","ychannelselector","x","x1","x2","xmlns","y","y1","y2","z","zoomandpan"]),c=s(["accent","accentunder","align","bevelled","close","columnsalign","columnlines","columnspan","denomalign","depth","dir","display","displaystyle","fence","frame","height","href","id","largeop","length","linethickness","lspace","lquote","mathbackground","mathcolor","mathsize","mathvariant","maxsize","minsize","movablelimits","notation","numalign","open","rowalign","rowlines","rowspacing","rowspan","rspace","rquote","scriptlevel","scriptminsize","scriptsizemultiplier","selection","separator","separators","stretchy","subscriptshift","supscriptshift","symmetric","voffset","width","xmlns"]),u=s(["xlink:href","xml:id","xlink:title","xml:space","xmlns:xlink"]),p=Object.hasOwnProperty,h=Object.setPrototypeOf,f=("undefined"!=typeof Reflect&&Reflect).apply;function d(e,t){h&&h(e,null);for(var n=t.length;n--;){var r=t[n];if("string"==typeof r){var i=r.toLowerCase();i!==r&&(Object.isFrozen(t)||(t[n]=i),r=i)}e[r]=!0}return e}function g(e){var t={},n=void 0;for(n in e)f(p,e,[n])&&(t[n]=e[n]);return t}f||(f=function(e,t,n){return e.apply(t,n)});var m=Object.seal||function(e){return e},b=m(/\{\{[\s\S]*|[\s\S]*\}\}/gm),y=m(/<%[\s\S]*|[\s\S]*%>/gm),v=m(/^data-[\-\w.\u00B7-\uFFFF]/),x=m(/^aria-[\-\w]+$/),k=m(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),w=m(/^(?:\w+script|data):/i),_=m(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205f\u3000]/g),A="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};function S(e){if(Array.isArray(e)){for(var t=0,n=Array(e.length);t<e.length;t++)n[t]=e[t];return n}return Array.from(e)}var T=("undefined"!=typeof Reflect&&Reflect).apply,L=Array.prototype.slice,R=Object.freeze,E=function(){return"undefined"==typeof window?null:window};T||(T=function(e,t,n){return e.apply(t,n)});var O=function(e,t){if("object"!==(void 0===e?"undefined":A(e))||"function"!=typeof e.createPolicy)return null;var n=null;t.currentScript&&t.currentScript.hasAttribute("data-tt-policy-suffix")&&(n=t.currentScript.getAttribute("data-tt-policy-suffix"));var r="dompurify"+(n?"#"+n:"");try{return e.createPolicy(r,{createHTML:function(e){return e}})}catch(e){return console.warn("TrustedTypes policy "+r+" could not be created."),null}};return function e(){var s=arguments.length>0&&void 0!==arguments[0]?arguments[0]:E(),p=function(t){return e(t)};if(p.version="1.0.11",p.removed=[],!s||!s.document||9!==s.document.nodeType)return p.isSupported=!1,p;var h=s.document,f=!1,m=!1,$=s.document,M=s.DocumentFragment,z=s.HTMLTemplateElement,C=s.Node,N=s.NodeFilter,D=s.NamedNodeMap,U=void 0===D?s.NamedNodeMap||s.MozNamedAttrMap:D,j=s.Text,H=s.Comment,I=s.DOMParser,F=s.TrustedTypes;if("function"==typeof z){var q=$.createElement("template");q.content&&q.content.ownerDocument&&($=q.content.ownerDocument)}var B=O(F,h),P=B?B.createHTML(""):"",Z=$,G=Z.implementation,W=Z.createNodeIterator,J=Z.getElementsByTagName,V=Z.createDocumentFragment,X=h.importNode,Y={};p.isSupported=G&&void 0!==G.createHTMLDocument&&9!==$.documentMode;var K=b,Q=y,ee=v,te=x,ne=w,re=_,ie=k,oe=null,se=d({},[].concat(S(t),S(n),S(r),S(i),S(o))),ae=null,le=d({},[].concat(S(a),S(l),S(c),S(u))),ce=null,ue=null,pe=!0,he=!0,fe=!1,de=!1,ge=!1,me=!1,be=!1,ye=!1,ve=!1,xe=!1,ke=!1,we=!0,_e=!0,Ae=!1,Se={},Te=d({},["audio","head","math","script","style","template","svg","video"]),Le=d({},["audio","video","img","source","image"]),Re=null,Ee=d({},["alt","class","for","id","label","name","pattern","placeholder","summary","title","value","style","xmlns"]),Oe=null,$e=$.createElement("form"),Me=function(e){Oe&&Oe===e||(e&&"object"===(void 0===e?"undefined":A(e))||(e={}),oe="ALLOWED_TAGS"in e?d({},e.ALLOWED_TAGS):se,ae="ALLOWED_ATTR"in e?d({},e.ALLOWED_ATTR):le,Re="ADD_URI_SAFE_ATTR"in e?d({},e.ADD_URI_SAFE_ATTR):Ee,ce="FORBID_TAGS"in e?d({},e.FORBID_TAGS):{},ue="FORBID_ATTR"in e?d({},e.FORBID_ATTR):{},Se="USE_PROFILES"in e&&e.USE_PROFILES,pe=!1!==e.ALLOW_ARIA_ATTR,he=!1!==e.ALLOW_DATA_ATTR,fe=e.ALLOW_UNKNOWN_PROTOCOLS||!1,de=e.SAFE_FOR_JQUERY||!1,ge=e.SAFE_FOR_TEMPLATES||!1,me=e.WHOLE_DOCUMENT||!1,ve=e.RETURN_DOM||!1,xe=e.RETURN_DOM_FRAGMENT||!1,ke=e.RETURN_DOM_IMPORT||!1,ye=e.FORCE_BODY||!1,we=!1!==e.SANITIZE_DOM,_e=!1!==e.KEEP_CONTENT,Ae=e.IN_PLACE||!1,ie=e.ALLOWED_URI_REGEXP||ie,ge&&(he=!1),xe&&(ve=!0),Se&&(oe=d({},[].concat(S(o))),ae=[],!0===Se.html&&(d(oe,t),d(ae,a)),!0===Se.svg&&(d(oe,n),d(ae,l),d(ae,u)),!0===Se.svgFilters&&(d(oe,r),d(ae,l),d(ae,u)),!0===Se.mathMl&&(d(oe,i),d(ae,c),d(ae,u))),e.ADD_TAGS&&(oe===se&&(oe=g(oe)),d(oe,e.ADD_TAGS)),e.ADD_ATTR&&(ae===le&&(ae=g(ae)),d(ae,e.ADD_ATTR)),e.ADD_URI_SAFE_ATTR&&d(Re,e.ADD_URI_SAFE_ATTR),_e&&(oe["#text"]=!0),me&&d(oe,["html","head","body"]),oe.table&&d(oe,["tbody"]),R&&R(e),Oe=e)},ze=function(e){p.removed.push({element:e});try{e.parentNode.removeChild(e)}catch(t){e.outerHTML=P}},Ce=function(e,t){try{p.removed.push({attribute:t.getAttributeNode(e),from:t})}catch(e){p.removed.push({attribute:null,from:t})}t.removeAttribute(e)},Ne=function(e){var t=void 0,n=void 0;if(ye)e="<remove></remove>"+e;else{var r=e.match(/^[\s]+/);(n=r&&r[0])&&(e=e.slice(n.length))}if(f)try{t=(new I).parseFromString(e,"text/html")}catch(e){}if(m&&d(ce,["title"]),!t||!t.documentElement){var i=t=G.createHTMLDocument(""),o=i.body;o.parentNode.removeChild(o.parentNode.firstElementChild),o.outerHTML=B?B.createHTML(e):e}return n&&t.body.insertBefore($.createTextNode(n),t.body.childNodes[0]||null),J.call(t,me?"html":"body")[0]};p.isSupported&&(function(){try{var e=Ne('<svg><p><style><img src="</style><img src=x onerror=1//">');e.querySelector("svg img")&&(f=!0)}catch(e){}}(),function(){try{var e=Ne("<x/><title></title><img>");e.querySelector("title").innerHTML.match(/<\/title/)&&(m=!0)}catch(e){}}());var De=function(e){return W.call(e.ownerDocument||e,e,N.SHOW_ELEMENT|N.SHOW_COMMENT|N.SHOW_TEXT,function(){return N.FILTER_ACCEPT},!1)},Ue=function(e){return"object"===(void 0===C?"undefined":A(C))?e instanceof C:e&&"object"===(void 0===e?"undefined":A(e))&&"number"==typeof e.nodeType&&"string"==typeof e.nodeName},je=function(e,t,n){Y[e]&&Y[e].forEach(function(e){e.call(p,t,n,Oe)})},He=function(e){var t,n=void 0;if(je("beforeSanitizeElements",e,null),!((t=e)instanceof j||t instanceof H||"string"==typeof t.nodeName&&"string"==typeof t.textContent&&"function"==typeof t.removeChild&&t.attributes instanceof U&&"function"==typeof t.removeAttribute&&"function"==typeof t.setAttribute))return ze(e),!0;var r=e.nodeName.toLowerCase();if(je("uponSanitizeElement",e,{tagName:r,allowedTags:oe}),!oe[r]||ce[r]){if(_e&&!Te[r]&&"function"==typeof e.insertAdjacentHTML)try{var i=e.innerHTML;e.insertAdjacentHTML("AfterEnd",B?B.createHTML(i):i)}catch(e){}return ze(e),!0}return"noscript"===r&&e.innerHTML.match(/<\/noscript/i)?(ze(e),!0):"noembed"===r&&e.innerHTML.match(/<\/noembed/i)?(ze(e),!0):(!de||e.firstElementChild||e.content&&e.content.firstElementChild||!/</g.test(e.textContent)||(p.removed.push({element:e.cloneNode()}),e.innerHTML?e.innerHTML=e.innerHTML.replace(/</g,"<"):e.innerHTML=e.textContent.replace(/</g,"<")),ge&&3===e.nodeType&&(n=(n=(n=e.textContent).replace(K," ")).replace(Q," "),e.textContent!==n&&(p.removed.push({element:e.cloneNode()}),e.textContent=n)),je("afterSanitizeElements",e,null),!1)},Ie=function(e,t,n){if(we&&("id"===t||"name"===t)&&(n in $||n in $e))return!1;if(he&&ee.test(t));else if(pe&&te.test(t));else{if(!ae[t]||ue[t])return!1;if(Re[t]);else if(ie.test(n.replace(re,"")));else if("src"!==t&&"xlink:href"!==t||"script"===e||0!==n.indexOf("data:")||!Le[e])if(fe&&!ne.test(n.replace(re,"")));else if(n)return!1}return!0},Fe=function(e){var t=void 0,n=void 0,r=void 0,i=void 0,o=void 0;je("beforeSanitizeAttributes",e,null);var s=e.attributes;if(s){var a={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:ae};for(o=s.length;o--;){var l=t=s[o],c=l.name,u=l.namespaceURI;if(n=t.value.trim(),r=c.toLowerCase(),a.attrName=r,a.attrValue=n,a.keepAttr=!0,je("uponSanitizeAttribute",e,a),n=a.attrValue,"name"===r&&"IMG"===e.nodeName&&s.id)i=s.id,s=T(L,s,[]),Ce("id",e),Ce(c,e),s.indexOf(i)>o&&e.setAttribute("id",i.value);else{if("INPUT"===e.nodeName&&"type"===r&&"file"===n&&a.keepAttr&&(ae[r]||!ue[r]))continue;"id"===c&&e.setAttribute(c,""),Ce(c,e)}if(a.keepAttr){ge&&(n=(n=n.replace(K," ")).replace(Q," "));var h=e.nodeName.toLowerCase();if(Ie(h,r,n))try{u?e.setAttributeNS(u,c,n):e.setAttribute(c,n),p.removed.pop()}catch(e){}}}je("afterSanitizeAttributes",e,null)}},qe=function e(t){var n=void 0,r=De(t);for(je("beforeSanitizeShadowDOM",t,null);n=r.nextNode();)je("uponSanitizeShadowNode",n,null),He(n)||(n.content instanceof M&&e(n.content),Fe(n));je("afterSanitizeShadowDOM",t,null)};return p.sanitize=function(e,t){var n=void 0,r=void 0,i=void 0,o=void 0,a=void 0;if(e||(e="\x3c!--\x3e"),"string"!=typeof e&&!Ue(e)){if("function"!=typeof e.toString)throw new TypeError("toString is not a function");if("string"!=typeof(e=e.toString()))throw new TypeError("dirty is not a string, aborting")}if(!p.isSupported){if("object"===A(s.toStaticHTML)||"function"==typeof s.toStaticHTML){if("string"==typeof e)return s.toStaticHTML(e);if(Ue(e))return s.toStaticHTML(e.outerHTML)}return e}if(be||Me(t),p.removed=[],Ae);else if(e instanceof C)n=Ne("\x3c!--\x3e"),1===(r=n.ownerDocument.importNode(e,!0)).nodeType&&"BODY"===r.nodeName?n=r:"HTML"===r.nodeName?n=r:n.appendChild(r);else{if(!ve&&!ge&&!me&&-1===e.indexOf("<"))return B?B.createHTML(e):e;if(!(n=Ne(e)))return ve?null:P}n&&ye&&ze(n.firstChild);for(var l=De(Ae?e:n);i=l.nextNode();)3===i.nodeType&&i===o||He(i)||(i.content instanceof M&&qe(i.content),Fe(i),o=i);if(o=null,Ae)return e;if(ve){if(xe)for(a=V.call(n.ownerDocument);n.firstChild;)a.appendChild(n.firstChild);else a=n;return ke&&(a=X.call(h,a,!0)),a}var c=me?n.outerHTML:n.innerHTML;return ge&&(c=(c=c.replace(K," ")).replace(Q," ")),B?B.createHTML(c):c},p.setConfig=function(e){Me(e),be=!0},p.clearConfig=function(){Oe=null,be=!1},p.isValidAttribute=function(e,t,n){Oe||Me({});var r=e.toLowerCase(),i=t.toLowerCase();return Ie(r,i,n)},p.addHook=function(e,t){"function"==typeof t&&(Y[e]=Y[e]||[],Y[e].push(t))},p.removeHook=function(e){Y[e]&&Y[e].pop()},p.removeHooks=function(e){Y[e]&&(Y[e]=[])},p.removeAllHooks=function(){Y={}},p}()}()}}]); //# sourceMappingURL=vue-5.js.map
\ No newline at end of file diff --git a/settings/js/vue-5.js.map b/settings/js/vue-5.js.map index aed7b346900..66cf5e910b3 100644 --- a/settings/js/vue-5.js.map +++ b/settings/js/vue-5.js.map @@ -1 +1 @@ -{"version":3,"sources":["webpack:///./node_modules/css-loader/dist/runtime/api.js","webpack:///./node_modules/style-loader/lib/addStyles.js","webpack:///./node_modules/style-loader/lib/urls.js","webpack:///./node_modules/marked/lib/marked.js","webpack:///./node_modules/dompurify/dist/purify.js"],"names":["module","exports","useSourceMap","list","toString","this","map","item","content","cssMapping","btoa","sourceMapping","sourceMap","unescape","encodeURIComponent","JSON","stringify","sourceURLs","sources","source","sourceRoot","concat","join","cssWithMappingToString","i","modules","mediaQuery","alreadyImportedModules","length","id","push","fn","memo","stylesInDom","isOldIE","window","document","all","atob","apply","arguments","getElement","target","parent","styleTarget","querySelector","call","HTMLIFrameElement","contentDocument","head","e","singleton","singletonCounter","stylesInsertedAtTop","fixUrls","__webpack_require__","addStylesToDom","styles","options","domStyle","refs","j","parts","addStyle","listToStyles","newStyles","base","part","css","media","insertStyleElement","style","insertInto","Error","lastStyleElementInsertedAtTop","insertAt","nextSibling","insertBefore","appendChild","firstChild","before","removeStyleElement","parentNode","removeChild","idx","indexOf","splice","createStyleElement","createElement","undefined","attrs","type","nonce","nc","getNonce","addAttrs","el","Object","keys","forEach","key","setAttribute","obj","update","remove","result","transform","default","styleIndex","applyToSingletonTag","bind","URL","createObjectURL","revokeObjectURL","Blob","link","rel","createLinkElement","autoFixUrls","convertToAbsoluteUrls","blob","oldSrc","href","styleSheet","cssText","createTextNode","newObj","DEBUG","newList","mayRemove","textStore","replaceText","index","replacement","filter","Boolean","cssNode","childNodes","location","baseUrl","protocol","host","currentDir","pathname","replace","fullMatch","origUrl","newUrl","unquotedOrigUrl","trim","o","$1","test","global","root","block","newline","code","fences","noop","hr","heading","nptable","blockquote","html","def","table","lheading","paragraph","text","Lexer","tokens","links","create","marked","defaults","rules","normal","pedantic","gfm","tables","_label","_title","edit","getRegex","bullet","_tag","_comment","merge","lex","src","prototype","token","top","next","loose","cap","bull","b","listStart","listItems","t","space","tag","l","isordered","istask","ischecked","exec","substring","rtrim","lang","depth","header","splitCells","align","split","cells","ordered","start","match","RegExp","smartLists","slice","charAt","task","checked","sanitize","pre","sanitizer","toLowerCase","title","charCodeAt","inline","escape","autolink","url","reflink","nolink","strong","em","br","del","InlineLexer","renderer","Renderer","breaks","TextRenderer","Parser","slugger","Slugger","seen","encode","escapeTest","escapeReplace","ch","replacements","escapeTestNoEncode","escapeReplaceNoEncode","_","n","String","fromCharCode","parseInt","regex","opt","name","val","cleanUrl","prot","decodeURIComponent","originIndependentUrl","baseUrls","resolveUrl","encodeURI","_punctuation","_escapes","_scheme","_email","_attribute","_href","_extended_email","_backpedal","output","prevCapZero","out","inLink","inRawBlock","lastParenIndex","findClosingBracket","linkLen","outputLink","escapes","codespan","mangle","smartypants","image","Math","random","infostring","escaped","highlight","langPrefix","quote","level","raw","headerIds","headerPrefix","slug","xhtml","body","listitem","checkbox","tablerow","tablecell","flags","parse","inlineText","reverse","tok","pop","peek","parseText","row","cell","errMsg","silent","console","log","value","hasOwnProperty","originalSlug","&","<",">","\"","'","tableRow","count","offset","str","curr","c","invert","suffLen","currChar","substr","callback","pending","done","err","message","setOptions","getDefaults","parser","lexer","inlineLexer","freeze$1","freeze","x","svg","svgFilters","mathMl","freeze$2","html$1","svg$1","mathMl$1","xml","setPrototypeOf","apply$1","Reflect","addToSet","set","array","element","lcElement","isFrozen","clone","object","newObject","property","fun","thisValue","args","seal","MUSTACHE_EXPR","ERB_EXPR","DATA_ATTR","ARIA_ATTR","IS_ALLOWED_URI","IS_SCRIPT_OR_DATA","ATTR_WHITESPACE","_typeof","Symbol","iterator","constructor","_toConsumableArray","arr","Array","isArray","arr2","from","arraySlice","getGlobal","_createTrustedTypesPolicy","trustedTypes","createPolicy","suffix","currentScript","hasAttribute","getAttribute","policyName","createHTML","html$$1","error","warn","createDOMPurify","DOMPurify","version","removed","nodeType","isSupported","originalDocument","useDOMParser","removeTitle","DocumentFragment","HTMLTemplateElement","Node","NodeFilter","_window$NamedNodeMap","NamedNodeMap","MozNamedAttrMap","Text","Comment","DOMParser","TrustedTypes","template","ownerDocument","trustedTypesPolicy","emptyHTML","_document","implementation","createNodeIterator","getElementsByTagName","createDocumentFragment","importNode","hooks","createHTMLDocument","documentMode","MUSTACHE_EXPR$$1","ERB_EXPR$$1","DATA_ATTR$$1","ARIA_ATTR$$1","IS_SCRIPT_OR_DATA$$1","ATTR_WHITESPACE$$1","IS_ALLOWED_URI$$1","ALLOWED_TAGS","DEFAULT_ALLOWED_TAGS","ALLOWED_ATTR","DEFAULT_ALLOWED_ATTR","FORBID_TAGS","FORBID_ATTR","ALLOW_ARIA_ATTR","ALLOW_DATA_ATTR","ALLOW_UNKNOWN_PROTOCOLS","SAFE_FOR_JQUERY","SAFE_FOR_TEMPLATES","WHOLE_DOCUMENT","SET_CONFIG","FORCE_BODY","RETURN_DOM","RETURN_DOM_FRAGMENT","RETURN_DOM_IMPORT","SANITIZE_DOM","KEEP_CONTENT","IN_PLACE","USE_PROFILES","FORBID_CONTENTS","DATA_URI_TAGS","URI_SAFE_ATTRIBUTES","CONFIG","formElement","_parseConfig","cfg","ALLOWED_URI_REGEXP","ADD_TAGS","ADD_ATTR","ADD_URI_SAFE_ATTR","_forceRemove","node","outerHTML","_removeAttribute","attribute","getAttributeNode","removeAttribute","_initDocument","dirty","doc","leadingWhitespace","matches","parseFromString","documentElement","_doc","firstElementChild","innerHTML","_createIterator","SHOW_ELEMENT","SHOW_COMMENT","SHOW_TEXT","FILTER_ACCEPT","_isNode","nodeName","_executeHook","entryPoint","currentNode","data","hook","_sanitizeElements","elm","textContent","attributes","tagName","allowedTags","insertAdjacentHTML","htmlToInsert","cloneNode","_isValidAttribute","lcTag","lcName","_sanitizeAttributes","attr","idAttr","hookEvent","attrName","attrValue","keepAttr","allowedAttributes","_attr","namespaceURI","setAttributeNS","_sanitizeShadowDOM","fragment","shadowNode","shadowIterator","nextNode","importedNode","oldNode","returnNode","TypeError","toStaticHTML","nodeIterator","serializedHTML","setConfig","clearConfig","isValidAttribute","addHook","hookFunction","removeHook","removeHooks","removeAllHooks","factory"],"mappings":"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","file":"vue-5.js","sourcesContent":["\"use strict\";\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\n// css base code, injected by the css-loader\nmodule.exports = function (useSourceMap) {\n var list = []; // return the list of modules as css string\n\n list.toString = function toString() {\n return this.map(function (item) {\n var content = cssWithMappingToString(item, useSourceMap);\n\n if (item[2]) {\n return '@media ' + item[2] + '{' + content + '}';\n } else {\n return content;\n }\n }).join('');\n }; // import a list of modules into the list\n\n\n list.i = function (modules, mediaQuery) {\n if (typeof modules === 'string') {\n modules = [[null, modules, '']];\n }\n\n var alreadyImportedModules = {};\n\n for (var i = 0; i < this.length; i++) {\n var id = this[i][0];\n\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n\n for (i = 0; i < modules.length; i++) {\n var item = modules[i]; // skip already imported module\n // this implementation is not 100% perfect for weird media query combinations\n // when a module is imported multiple times with different media queries.\n // I hope this will never occur (Hey this way we have smaller bundles)\n\n if (item[0] == null || !alreadyImportedModules[item[0]]) {\n if (mediaQuery && !item[2]) {\n item[2] = mediaQuery;\n } else if (mediaQuery) {\n item[2] = '(' + item[2] + ') and (' + mediaQuery + ')';\n }\n\n list.push(item);\n }\n }\n };\n\n return list;\n};\n\nfunction cssWithMappingToString(item, useSourceMap) {\n var content = item[1] || '';\n var cssMapping = item[3];\n\n if (!cssMapping) {\n return content;\n }\n\n if (useSourceMap && typeof btoa === 'function') {\n var sourceMapping = toComment(cssMapping);\n var sourceURLs = cssMapping.sources.map(function (source) {\n return '/*# sourceURL=' + cssMapping.sourceRoot + source + ' */';\n });\n return [content].concat(sourceURLs).concat([sourceMapping]).join('\\n');\n }\n\n return [content].join('\\n');\n} // Adapted from convert-source-map (MIT)\n\n\nfunction toComment(sourceMap) {\n // eslint-disable-next-line no-undef\n var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));\n var data = 'sourceMappingURL=data:application/json;charset=utf-8;base64,' + base64;\n return '/*# ' + data + ' */';\n}","/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\n\nvar stylesInDom = {};\n\nvar\tmemoize = function (fn) {\n\tvar memo;\n\n\treturn function () {\n\t\tif (typeof memo === \"undefined\") memo = fn.apply(this, arguments);\n\t\treturn memo;\n\t};\n};\n\nvar isOldIE = memoize(function () {\n\t// Test for IE <= 9 as proposed by Browserhacks\n\t// @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805\n\t// Tests for existence of standard globals is to allow style-loader\n\t// to operate correctly into non-standard environments\n\t// @see https://github.com/webpack-contrib/style-loader/issues/177\n\treturn window && document && document.all && !window.atob;\n});\n\nvar getTarget = function (target, parent) {\n if (parent){\n return parent.querySelector(target);\n }\n return document.querySelector(target);\n};\n\nvar getElement = (function (fn) {\n\tvar memo = {};\n\n\treturn function(target, parent) {\n // If passing function in options, then use it for resolve \"head\" element.\n // Useful for Shadow Root style i.e\n // {\n // insertInto: function () { return document.querySelector(\"#foo\").shadowRoot }\n // }\n if (typeof target === 'function') {\n return target();\n }\n if (typeof memo[target] === \"undefined\") {\n\t\t\tvar styleTarget = getTarget.call(this, target, parent);\n\t\t\t// Special case to return head of iframe instead of iframe itself\n\t\t\tif (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n\t\t\t\ttry {\n\t\t\t\t\t// This will throw an exception if access to iframe is blocked\n\t\t\t\t\t// due to cross-origin restrictions\n\t\t\t\t\tstyleTarget = styleTarget.contentDocument.head;\n\t\t\t\t} catch(e) {\n\t\t\t\t\tstyleTarget = null;\n\t\t\t\t}\n\t\t\t}\n\t\t\tmemo[target] = styleTarget;\n\t\t}\n\t\treturn memo[target]\n\t};\n})();\n\nvar singleton = null;\nvar\tsingletonCounter = 0;\nvar\tstylesInsertedAtTop = [];\n\nvar\tfixUrls = require(\"./urls\");\n\nmodule.exports = function(list, options) {\n\tif (typeof DEBUG !== \"undefined\" && DEBUG) {\n\t\tif (typeof document !== \"object\") throw new Error(\"The style-loader cannot be used in a non-browser environment\");\n\t}\n\n\toptions = options || {};\n\n\toptions.attrs = typeof options.attrs === \"object\" ? options.attrs : {};\n\n\t// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\n\t// tags it will allow on a page\n\tif (!options.singleton && typeof options.singleton !== \"boolean\") options.singleton = isOldIE();\n\n\t// By default, add <style> tags to the <head> element\n if (!options.insertInto) options.insertInto = \"head\";\n\n\t// By default, add <style> tags to the bottom of the target\n\tif (!options.insertAt) options.insertAt = \"bottom\";\n\n\tvar styles = listToStyles(list, options);\n\n\taddStylesToDom(styles, options);\n\n\treturn function update (newList) {\n\t\tvar mayRemove = [];\n\n\t\tfor (var i = 0; i < styles.length; i++) {\n\t\t\tvar item = styles[i];\n\t\t\tvar domStyle = stylesInDom[item.id];\n\n\t\t\tdomStyle.refs--;\n\t\t\tmayRemove.push(domStyle);\n\t\t}\n\n\t\tif(newList) {\n\t\t\tvar newStyles = listToStyles(newList, options);\n\t\t\taddStylesToDom(newStyles, options);\n\t\t}\n\n\t\tfor (var i = 0; i < mayRemove.length; i++) {\n\t\t\tvar domStyle = mayRemove[i];\n\n\t\t\tif(domStyle.refs === 0) {\n\t\t\t\tfor (var j = 0; j < domStyle.parts.length; j++) domStyle.parts[j]();\n\n\t\t\t\tdelete stylesInDom[domStyle.id];\n\t\t\t}\n\t\t}\n\t};\n};\n\nfunction addStylesToDom (styles, options) {\n\tfor (var i = 0; i < styles.length; i++) {\n\t\tvar item = styles[i];\n\t\tvar domStyle = stylesInDom[item.id];\n\n\t\tif(domStyle) {\n\t\t\tdomStyle.refs++;\n\n\t\t\tfor(var j = 0; j < domStyle.parts.length; j++) {\n\t\t\t\tdomStyle.parts[j](item.parts[j]);\n\t\t\t}\n\n\t\t\tfor(; j < item.parts.length; j++) {\n\t\t\t\tdomStyle.parts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\t\t} else {\n\t\t\tvar parts = [];\n\n\t\t\tfor(var j = 0; j < item.parts.length; j++) {\n\t\t\t\tparts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\n\t\t\tstylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};\n\t\t}\n\t}\n}\n\nfunction listToStyles (list, options) {\n\tvar styles = [];\n\tvar newStyles = {};\n\n\tfor (var i = 0; i < list.length; i++) {\n\t\tvar item = list[i];\n\t\tvar id = options.base ? item[0] + options.base : item[0];\n\t\tvar css = item[1];\n\t\tvar media = item[2];\n\t\tvar sourceMap = item[3];\n\t\tvar part = {css: css, media: media, sourceMap: sourceMap};\n\n\t\tif(!newStyles[id]) styles.push(newStyles[id] = {id: id, parts: [part]});\n\t\telse newStyles[id].parts.push(part);\n\t}\n\n\treturn styles;\n}\n\nfunction insertStyleElement (options, style) {\n\tvar target = getElement(options.insertInto)\n\n\tif (!target) {\n\t\tthrow new Error(\"Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid.\");\n\t}\n\n\tvar lastStyleElementInsertedAtTop = stylesInsertedAtTop[stylesInsertedAtTop.length - 1];\n\n\tif (options.insertAt === \"top\") {\n\t\tif (!lastStyleElementInsertedAtTop) {\n\t\t\ttarget.insertBefore(style, target.firstChild);\n\t\t} else if (lastStyleElementInsertedAtTop.nextSibling) {\n\t\t\ttarget.insertBefore(style, lastStyleElementInsertedAtTop.nextSibling);\n\t\t} else {\n\t\t\ttarget.appendChild(style);\n\t\t}\n\t\tstylesInsertedAtTop.push(style);\n\t} else if (options.insertAt === \"bottom\") {\n\t\ttarget.appendChild(style);\n\t} else if (typeof options.insertAt === \"object\" && options.insertAt.before) {\n\t\tvar nextSibling = getElement(options.insertAt.before, target);\n\t\ttarget.insertBefore(style, nextSibling);\n\t} else {\n\t\tthrow new Error(\"[Style Loader]\\n\\n Invalid value for parameter 'insertAt' ('options.insertAt') found.\\n Must be 'top', 'bottom', or Object.\\n (https://github.com/webpack-contrib/style-loader#insertat)\\n\");\n\t}\n}\n\nfunction removeStyleElement (style) {\n\tif (style.parentNode === null) return false;\n\tstyle.parentNode.removeChild(style);\n\n\tvar idx = stylesInsertedAtTop.indexOf(style);\n\tif(idx >= 0) {\n\t\tstylesInsertedAtTop.splice(idx, 1);\n\t}\n}\n\nfunction createStyleElement (options) {\n\tvar style = document.createElement(\"style\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\n\tif(options.attrs.nonce === undefined) {\n\t\tvar nonce = getNonce();\n\t\tif (nonce) {\n\t\t\toptions.attrs.nonce = nonce;\n\t\t}\n\t}\n\n\taddAttrs(style, options.attrs);\n\tinsertStyleElement(options, style);\n\n\treturn style;\n}\n\nfunction createLinkElement (options) {\n\tvar link = document.createElement(\"link\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\toptions.attrs.rel = \"stylesheet\";\n\n\taddAttrs(link, options.attrs);\n\tinsertStyleElement(options, link);\n\n\treturn link;\n}\n\nfunction addAttrs (el, attrs) {\n\tObject.keys(attrs).forEach(function (key) {\n\t\tel.setAttribute(key, attrs[key]);\n\t});\n}\n\nfunction getNonce() {\n\tif (typeof __webpack_nonce__ === 'undefined') {\n\t\treturn null;\n\t}\n\n\treturn __webpack_nonce__;\n}\n\nfunction addStyle (obj, options) {\n\tvar style, update, remove, result;\n\n\t// If a transform function was defined, run it on the css\n\tif (options.transform && obj.css) {\n\t result = typeof options.transform === 'function'\n\t\t ? options.transform(obj.css) \n\t\t : options.transform.default(obj.css);\n\n\t if (result) {\n\t \t// If transform returns a value, use that instead of the original css.\n\t \t// This allows running runtime transformations on the css.\n\t \tobj.css = result;\n\t } else {\n\t \t// If the transform function returns a falsy value, don't add this css.\n\t \t// This allows conditional loading of css\n\t \treturn function() {\n\t \t\t// noop\n\t \t};\n\t }\n\t}\n\n\tif (options.singleton) {\n\t\tvar styleIndex = singletonCounter++;\n\n\t\tstyle = singleton || (singleton = createStyleElement(options));\n\n\t\tupdate = applyToSingletonTag.bind(null, style, styleIndex, false);\n\t\tremove = applyToSingletonTag.bind(null, style, styleIndex, true);\n\n\t} else if (\n\t\tobj.sourceMap &&\n\t\ttypeof URL === \"function\" &&\n\t\ttypeof URL.createObjectURL === \"function\" &&\n\t\ttypeof URL.revokeObjectURL === \"function\" &&\n\t\ttypeof Blob === \"function\" &&\n\t\ttypeof btoa === \"function\"\n\t) {\n\t\tstyle = createLinkElement(options);\n\t\tupdate = updateLink.bind(null, style, options);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\n\t\t\tif(style.href) URL.revokeObjectURL(style.href);\n\t\t};\n\t} else {\n\t\tstyle = createStyleElement(options);\n\t\tupdate = applyToTag.bind(null, style);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\t\t};\n\t}\n\n\tupdate(obj);\n\n\treturn function updateStyle (newObj) {\n\t\tif (newObj) {\n\t\t\tif (\n\t\t\t\tnewObj.css === obj.css &&\n\t\t\t\tnewObj.media === obj.media &&\n\t\t\t\tnewObj.sourceMap === obj.sourceMap\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tupdate(obj = newObj);\n\t\t} else {\n\t\t\tremove();\n\t\t}\n\t};\n}\n\nvar replaceText = (function () {\n\tvar textStore = [];\n\n\treturn function (index, replacement) {\n\t\ttextStore[index] = replacement;\n\n\t\treturn textStore.filter(Boolean).join('\\n');\n\t};\n})();\n\nfunction applyToSingletonTag (style, index, remove, obj) {\n\tvar css = remove ? \"\" : obj.css;\n\n\tif (style.styleSheet) {\n\t\tstyle.styleSheet.cssText = replaceText(index, css);\n\t} else {\n\t\tvar cssNode = document.createTextNode(css);\n\t\tvar childNodes = style.childNodes;\n\n\t\tif (childNodes[index]) style.removeChild(childNodes[index]);\n\n\t\tif (childNodes.length) {\n\t\t\tstyle.insertBefore(cssNode, childNodes[index]);\n\t\t} else {\n\t\t\tstyle.appendChild(cssNode);\n\t\t}\n\t}\n}\n\nfunction applyToTag (style, obj) {\n\tvar css = obj.css;\n\tvar media = obj.media;\n\n\tif(media) {\n\t\tstyle.setAttribute(\"media\", media)\n\t}\n\n\tif(style.styleSheet) {\n\t\tstyle.styleSheet.cssText = css;\n\t} else {\n\t\twhile(style.firstChild) {\n\t\t\tstyle.removeChild(style.firstChild);\n\t\t}\n\n\t\tstyle.appendChild(document.createTextNode(css));\n\t}\n}\n\nfunction updateLink (link, options, obj) {\n\tvar css = obj.css;\n\tvar sourceMap = obj.sourceMap;\n\n\t/*\n\t\tIf convertToAbsoluteUrls isn't defined, but sourcemaps are enabled\n\t\tand there is no publicPath defined then lets turn convertToAbsoluteUrls\n\t\ton by default. Otherwise default to the convertToAbsoluteUrls option\n\t\tdirectly\n\t*/\n\tvar autoFixUrls = options.convertToAbsoluteUrls === undefined && sourceMap;\n\n\tif (options.convertToAbsoluteUrls || autoFixUrls) {\n\t\tcss = fixUrls(css);\n\t}\n\n\tif (sourceMap) {\n\t\t// http://stackoverflow.com/a/26603875\n\t\tcss += \"\\n/*# sourceMappingURL=data:application/json;base64,\" + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + \" */\";\n\t}\n\n\tvar blob = new Blob([css], { type: \"text/css\" });\n\n\tvar oldSrc = link.href;\n\n\tlink.href = URL.createObjectURL(blob);\n\n\tif(oldSrc) URL.revokeObjectURL(oldSrc);\n}\n","\n/**\n * When source maps are enabled, `style-loader` uses a link element with a data-uri to\n * embed the css on the page. This breaks all relative urls because now they are relative to a\n * bundle instead of the current page.\n *\n * One solution is to only use full urls, but that may be impossible.\n *\n * Instead, this function \"fixes\" the relative urls to be absolute according to the current page location.\n *\n * A rudimentary test suite is located at `test/fixUrls.js` and can be run via the `npm test` command.\n *\n */\n\nmodule.exports = function (css) {\n // get current location\n var location = typeof window !== \"undefined\" && window.location;\n\n if (!location) {\n throw new Error(\"fixUrls requires window.location\");\n }\n\n\t// blank or null?\n\tif (!css || typeof css !== \"string\") {\n\t return css;\n }\n\n var baseUrl = location.protocol + \"//\" + location.host;\n var currentDir = baseUrl + location.pathname.replace(/\\/[^\\/]*$/, \"/\");\n\n\t// convert each url(...)\n\t/*\n\tThis regular expression is just a way to recursively match brackets within\n\ta string.\n\n\t /url\\s*\\( = Match on the word \"url\" with any whitespace after it and then a parens\n\t ( = Start a capturing group\n\t (?: = Start a non-capturing group\n\t [^)(] = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t (?: = Start another non-capturing groups\n\t [^)(]+ = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t [^)(]* = Match anything that isn't a parentheses\n\t \\) = Match a end parentheses\n\t ) = End Group\n *\\) = Match anything and then a close parens\n ) = Close non-capturing group\n * = Match anything\n ) = Close capturing group\n\t \\) = Match a close parens\n\n\t /gi = Get all matches, not the first. Be case insensitive.\n\t */\n\tvar fixedCss = css.replace(/url\\s*\\(((?:[^)(]|\\((?:[^)(]+|\\([^)(]*\\))*\\))*)\\)/gi, function(fullMatch, origUrl) {\n\t\t// strip quotes (if they exist)\n\t\tvar unquotedOrigUrl = origUrl\n\t\t\t.trim()\n\t\t\t.replace(/^\"(.*)\"$/, function(o, $1){ return $1; })\n\t\t\t.replace(/^'(.*)'$/, function(o, $1){ return $1; });\n\n\t\t// already a full url? no change\n\t\tif (/^(#|data:|http:\\/\\/|https:\\/\\/|file:\\/\\/\\/|\\s*$)/i.test(unquotedOrigUrl)) {\n\t\t return fullMatch;\n\t\t}\n\n\t\t// convert the url to a full url\n\t\tvar newUrl;\n\n\t\tif (unquotedOrigUrl.indexOf(\"//\") === 0) {\n\t\t \t//TODO: should we add protocol?\n\t\t\tnewUrl = unquotedOrigUrl;\n\t\t} else if (unquotedOrigUrl.indexOf(\"/\") === 0) {\n\t\t\t// path should be relative to the base url\n\t\t\tnewUrl = baseUrl + unquotedOrigUrl; // already starts with '/'\n\t\t} else {\n\t\t\t// path should be relative to current directory\n\t\t\tnewUrl = currentDir + unquotedOrigUrl.replace(/^\\.\\//, \"\"); // Strip leading './'\n\t\t}\n\n\t\t// send back the fixed url(...)\n\t\treturn \"url(\" + JSON.stringify(newUrl) + \")\";\n\t});\n\n\t// send back the fixed css\n\treturn fixedCss;\n};\n","/**\n * marked - a markdown parser\n * Copyright (c) 2011-2018, Christopher Jeffrey. (MIT Licensed)\n * https://github.com/markedjs/marked\n */\n\n;(function(root) {\n'use strict';\n\n/**\n * Block-Level Grammar\n */\n\nvar block = {\n newline: /^\\n+/,\n code: /^( {4}[^\\n]+\\n*)+/,\n fences: noop,\n hr: /^ {0,3}((?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$)/,\n heading: /^ *(#{1,6}) *([^\\n]+?) *(?:#+ *)?(?:\\n+|$)/,\n nptable: noop,\n blockquote: /^( {0,3}> ?(paragraph|[^\\n]*)(?:\\n|$))+/,\n list: /^( {0,3})(bull) [\\s\\S]+?(?:hr|def|\\n{2,}(?! )(?!\\1bull )\\n*|\\s*$)/,\n html: '^ {0,3}(?:' // optional indentation\n + '<(script|pre|style)[\\\\s>][\\\\s\\\\S]*?(?:</\\\\1>[^\\\\n]*\\\\n+|$)' // (1)\n + '|comment[^\\\\n]*(\\\\n+|$)' // (2)\n + '|<\\\\?[\\\\s\\\\S]*?\\\\?>\\\\n*' // (3)\n + '|<![A-Z][\\\\s\\\\S]*?>\\\\n*' // (4)\n + '|<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?\\\\]\\\\]>\\\\n*' // (5)\n + '|</?(tag)(?: +|\\\\n|/?>)[\\\\s\\\\S]*?(?:\\\\n{2,}|$)' // (6)\n + '|<(?!script|pre|style)([a-z][\\\\w-]*)(?:attribute)*? */?>(?=[ \\\\t]*(?:\\\\n|$))[\\\\s\\\\S]*?(?:\\\\n{2,}|$)' // (7) open tag\n + '|</(?!script|pre|style)[a-z][\\\\w-]*\\\\s*>(?=[ \\\\t]*(?:\\\\n|$))[\\\\s\\\\S]*?(?:\\\\n{2,}|$)' // (7) closing tag\n + ')',\n def: /^ {0,3}\\[(label)\\]: *\\n? *<?([^\\s>]+)>?(?:(?: +\\n? *| *\\n *)(title))? *(?:\\n+|$)/,\n table: noop,\n lheading: /^([^\\n]+)\\n *(=|-){2,} *(?:\\n+|$)/,\n paragraph: /^([^\\n]+(?:\\n(?!hr|heading|lheading| {0,3}>|<\\/?(?:tag)(?: +|\\n|\\/?>)|<(?:script|pre|style|!--))[^\\n]+)*)/,\n text: /^[^\\n]+/\n};\n\nblock._label = /(?!\\s*\\])(?:\\\\[\\[\\]]|[^\\[\\]])+/;\nblock._title = /(?:\"(?:\\\\\"?|[^\"\\\\])*\"|'[^'\\n]*(?:\\n[^'\\n]+)*\\n?'|\\([^()]*\\))/;\nblock.def = edit(block.def)\n .replace('label', block._label)\n .replace('title', block._title)\n .getRegex();\n\nblock.bullet = /(?:[*+-]|\\d{1,9}\\.)/;\nblock.item = /^( *)(bull) ?[^\\n]*(?:\\n(?!\\1bull ?)[^\\n]*)*/;\nblock.item = edit(block.item, 'gm')\n .replace(/bull/g, block.bullet)\n .getRegex();\n\nblock.list = edit(block.list)\n .replace(/bull/g, block.bullet)\n .replace('hr', '\\\\n+(?=\\\\1?(?:(?:- *){3,}|(?:_ *){3,}|(?:\\\\* *){3,})(?:\\\\n+|$))')\n .replace('def', '\\\\n+(?=' + block.def.source + ')')\n .getRegex();\n\nblock._tag = 'address|article|aside|base|basefont|blockquote|body|caption'\n + '|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption'\n + '|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe'\n + '|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option'\n + '|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr'\n + '|track|ul';\nblock._comment = /<!--(?!-?>)[\\s\\S]*?-->/;\nblock.html = edit(block.html, 'i')\n .replace('comment', block._comment)\n .replace('tag', block._tag)\n .replace('attribute', / +[a-zA-Z:_][\\w.:-]*(?: *= *\"[^\"\\n]*\"| *= *'[^'\\n]*'| *= *[^\\s\"'=<>`]+)?/)\n .getRegex();\n\nblock.paragraph = edit(block.paragraph)\n .replace('hr', block.hr)\n .replace('heading', block.heading)\n .replace('lheading', block.lheading)\n .replace('tag', block._tag) // pars can be interrupted by type (6) html blocks\n .getRegex();\n\nblock.blockquote = edit(block.blockquote)\n .replace('paragraph', block.paragraph)\n .getRegex();\n\n/**\n * Normal Block Grammar\n */\n\nblock.normal = merge({}, block);\n\n/**\n * GFM Block Grammar\n */\n\nblock.gfm = merge({}, block.normal, {\n fences: /^ {0,3}(`{3,}|~{3,})([^`\\n]*)\\n(?:|([\\s\\S]*?)\\n)(?: {0,3}\\1[~`]* *(?:\\n+|$)|$)/,\n paragraph: /^/,\n heading: /^ *(#{1,6}) +([^\\n]+?) *#* *(?:\\n+|$)/\n});\n\nblock.gfm.paragraph = edit(block.paragraph)\n .replace('(?!', '(?!'\n + block.gfm.fences.source.replace('\\\\1', '\\\\2') + '|'\n + block.list.source.replace('\\\\1', '\\\\3') + '|')\n .getRegex();\n\n/**\n * GFM + Tables Block Grammar\n */\n\nblock.tables = merge({}, block.gfm, {\n nptable: /^ *([^|\\n ].*\\|.*)\\n *([-:]+ *\\|[-| :]*)(?:\\n((?:.*[^>\\n ].*(?:\\n|$))*)\\n*|$)/,\n table: /^ *\\|(.+)\\n *\\|?( *[-:]+[-| :]*)(?:\\n((?: *[^>\\n ].*(?:\\n|$))*)\\n*|$)/\n});\n\n/**\n * Pedantic grammar\n */\n\nblock.pedantic = merge({}, block.normal, {\n html: edit(\n '^ *(?:comment *(?:\\\\n|\\\\s*$)'\n + '|<(tag)[\\\\s\\\\S]+?</\\\\1> *(?:\\\\n{2,}|\\\\s*$)' // closed tag\n + '|<tag(?:\"[^\"]*\"|\\'[^\\']*\\'|\\\\s[^\\'\"/>\\\\s]*)*?/?> *(?:\\\\n{2,}|\\\\s*$))')\n .replace('comment', block._comment)\n .replace(/tag/g, '(?!(?:'\n + 'a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub'\n + '|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)'\n + '\\\\b)\\\\w+(?!:|[^\\\\w\\\\s@]*@)\\\\b')\n .getRegex(),\n def: /^ *\\[([^\\]]+)\\]: *<?([^\\s>]+)>?(?: +([\"(][^\\n]+[\")]))? *(?:\\n+|$)/\n});\n\n/**\n * Block Lexer\n */\n\nfunction Lexer(options) {\n this.tokens = [];\n this.tokens.links = Object.create(null);\n this.options = options || marked.defaults;\n this.rules = block.normal;\n\n if (this.options.pedantic) {\n this.rules = block.pedantic;\n } else if (this.options.gfm) {\n if (this.options.tables) {\n this.rules = block.tables;\n } else {\n this.rules = block.gfm;\n }\n }\n}\n\n/**\n * Expose Block Rules\n */\n\nLexer.rules = block;\n\n/**\n * Static Lex Method\n */\n\nLexer.lex = function(src, options) {\n var lexer = new Lexer(options);\n return lexer.lex(src);\n};\n\n/**\n * Preprocessing\n */\n\nLexer.prototype.lex = function(src) {\n src = src\n .replace(/\\r\\n|\\r/g, '\\n')\n .replace(/\\t/g, ' ')\n .replace(/\\u00a0/g, ' ')\n .replace(/\\u2424/g, '\\n');\n\n return this.token(src, true);\n};\n\n/**\n * Lexing\n */\n\nLexer.prototype.token = function(src, top) {\n src = src.replace(/^ +$/gm, '');\n var next,\n loose,\n cap,\n bull,\n b,\n item,\n listStart,\n listItems,\n t,\n space,\n i,\n tag,\n l,\n isordered,\n istask,\n ischecked;\n\n while (src) {\n // newline\n if (cap = this.rules.newline.exec(src)) {\n src = src.substring(cap[0].length);\n if (cap[0].length > 1) {\n this.tokens.push({\n type: 'space'\n });\n }\n }\n\n // code\n if (cap = this.rules.code.exec(src)) {\n src = src.substring(cap[0].length);\n cap = cap[0].replace(/^ {4}/gm, '');\n this.tokens.push({\n type: 'code',\n text: !this.options.pedantic\n ? rtrim(cap, '\\n')\n : cap\n });\n continue;\n }\n\n // fences (gfm)\n if (cap = this.rules.fences.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'code',\n lang: cap[2] ? cap[2].trim() : cap[2],\n text: cap[3] || ''\n });\n continue;\n }\n\n // heading\n if (cap = this.rules.heading.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'heading',\n depth: cap[1].length,\n text: cap[2]\n });\n continue;\n }\n\n // table no leading pipe (gfm)\n if (cap = this.rules.nptable.exec(src)) {\n item = {\n type: 'table',\n header: splitCells(cap[1].replace(/^ *| *\\| *$/g, '')),\n align: cap[2].replace(/^ *|\\| *$/g, '').split(/ *\\| */),\n cells: cap[3] ? cap[3].replace(/\\n$/, '').split('\\n') : []\n };\n\n if (item.header.length === item.align.length) {\n src = src.substring(cap[0].length);\n\n for (i = 0; i < item.align.length; i++) {\n if (/^ *-+: *$/.test(item.align[i])) {\n item.align[i] = 'right';\n } else if (/^ *:-+: *$/.test(item.align[i])) {\n item.align[i] = 'center';\n } else if (/^ *:-+ *$/.test(item.align[i])) {\n item.align[i] = 'left';\n } else {\n item.align[i] = null;\n }\n }\n\n for (i = 0; i < item.cells.length; i++) {\n item.cells[i] = splitCells(item.cells[i], item.header.length);\n }\n\n this.tokens.push(item);\n\n continue;\n }\n }\n\n // hr\n if (cap = this.rules.hr.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'hr'\n });\n continue;\n }\n\n // blockquote\n if (cap = this.rules.blockquote.exec(src)) {\n src = src.substring(cap[0].length);\n\n this.tokens.push({\n type: 'blockquote_start'\n });\n\n cap = cap[0].replace(/^ *> ?/gm, '');\n\n // Pass `top` to keep the current\n // \"toplevel\" state. This is exactly\n // how markdown.pl works.\n this.token(cap, top);\n\n this.tokens.push({\n type: 'blockquote_end'\n });\n\n continue;\n }\n\n // list\n if (cap = this.rules.list.exec(src)) {\n src = src.substring(cap[0].length);\n bull = cap[2];\n isordered = bull.length > 1;\n\n listStart = {\n type: 'list_start',\n ordered: isordered,\n start: isordered ? +bull : '',\n loose: false\n };\n\n this.tokens.push(listStart);\n\n // Get each top-level item.\n cap = cap[0].match(this.rules.item);\n\n listItems = [];\n next = false;\n l = cap.length;\n i = 0;\n\n for (; i < l; i++) {\n item = cap[i];\n\n // Remove the list item's bullet\n // so it is seen as the next token.\n space = item.length;\n item = item.replace(/^ *([*+-]|\\d+\\.) */, '');\n\n // Outdent whatever the\n // list item contains. Hacky.\n if (~item.indexOf('\\n ')) {\n space -= item.length;\n item = !this.options.pedantic\n ? item.replace(new RegExp('^ {1,' + space + '}', 'gm'), '')\n : item.replace(/^ {1,4}/gm, '');\n }\n\n // Determine whether the next list item belongs here.\n // Backpedal if it does not belong in this list.\n if (i !== l - 1) {\n b = block.bullet.exec(cap[i + 1])[0];\n if (bull.length > 1 ? b.length === 1\n : (b.length > 1 || (this.options.smartLists && b !== bull))) {\n src = cap.slice(i + 1).join('\\n') + src;\n i = l - 1;\n }\n }\n\n // Determine whether item is loose or not.\n // Use: /(^|\\n)(?! )[^\\n]+\\n\\n(?!\\s*$)/\n // for discount behavior.\n loose = next || /\\n\\n(?!\\s*$)/.test(item);\n if (i !== l - 1) {\n next = item.charAt(item.length - 1) === '\\n';\n if (!loose) loose = next;\n }\n\n if (loose) {\n listStart.loose = true;\n }\n\n // Check for task list items\n istask = /^\\[[ xX]\\] /.test(item);\n ischecked = undefined;\n if (istask) {\n ischecked = item[1] !== ' ';\n item = item.replace(/^\\[[ xX]\\] +/, '');\n }\n\n t = {\n type: 'list_item_start',\n task: istask,\n checked: ischecked,\n loose: loose\n };\n\n listItems.push(t);\n this.tokens.push(t);\n\n // Recurse.\n this.token(item, false);\n\n this.tokens.push({\n type: 'list_item_end'\n });\n }\n\n if (listStart.loose) {\n l = listItems.length;\n i = 0;\n for (; i < l; i++) {\n listItems[i].loose = true;\n }\n }\n\n this.tokens.push({\n type: 'list_end'\n });\n\n continue;\n }\n\n // html\n if (cap = this.rules.html.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: this.options.sanitize\n ? 'paragraph'\n : 'html',\n pre: !this.options.sanitizer\n && (cap[1] === 'pre' || cap[1] === 'script' || cap[1] === 'style'),\n text: cap[0]\n });\n continue;\n }\n\n // def\n if (top && (cap = this.rules.def.exec(src))) {\n src = src.substring(cap[0].length);\n if (cap[3]) cap[3] = cap[3].substring(1, cap[3].length - 1);\n tag = cap[1].toLowerCase().replace(/\\s+/g, ' ');\n if (!this.tokens.links[tag]) {\n this.tokens.links[tag] = {\n href: cap[2],\n title: cap[3]\n };\n }\n continue;\n }\n\n // table (gfm)\n if (cap = this.rules.table.exec(src)) {\n item = {\n type: 'table',\n header: splitCells(cap[1].replace(/^ *| *\\| *$/g, '')),\n align: cap[2].replace(/^ *|\\| *$/g, '').split(/ *\\| */),\n cells: cap[3] ? cap[3].replace(/\\n$/, '').split('\\n') : []\n };\n\n if (item.header.length === item.align.length) {\n src = src.substring(cap[0].length);\n\n for (i = 0; i < item.align.length; i++) {\n if (/^ *-+: *$/.test(item.align[i])) {\n item.align[i] = 'right';\n } else if (/^ *:-+: *$/.test(item.align[i])) {\n item.align[i] = 'center';\n } else if (/^ *:-+ *$/.test(item.align[i])) {\n item.align[i] = 'left';\n } else {\n item.align[i] = null;\n }\n }\n\n for (i = 0; i < item.cells.length; i++) {\n item.cells[i] = splitCells(\n item.cells[i].replace(/^ *\\| *| *\\| *$/g, ''),\n item.header.length);\n }\n\n this.tokens.push(item);\n\n continue;\n }\n }\n\n // lheading\n if (cap = this.rules.lheading.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'heading',\n depth: cap[2] === '=' ? 1 : 2,\n text: cap[1]\n });\n continue;\n }\n\n // top-level paragraph\n if (top && (cap = this.rules.paragraph.exec(src))) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'paragraph',\n text: cap[1].charAt(cap[1].length - 1) === '\\n'\n ? cap[1].slice(0, -1)\n : cap[1]\n });\n continue;\n }\n\n // text\n if (cap = this.rules.text.exec(src)) {\n // Top-level should never reach here.\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'text',\n text: cap[0]\n });\n continue;\n }\n\n if (src) {\n throw new Error('Infinite loop on byte: ' + src.charCodeAt(0));\n }\n }\n\n return this.tokens;\n};\n\n/**\n * Inline-Level Grammar\n */\n\nvar inline = {\n escape: /^\\\\([!\"#$%&'()*+,\\-./:;<=>?@\\[\\]\\\\^_`{|}~])/,\n autolink: /^<(scheme:[^\\s\\x00-\\x1f<>]*|email)>/,\n url: noop,\n tag: '^comment'\n + '|^</[a-zA-Z][\\\\w:-]*\\\\s*>' // self-closing tag\n + '|^<[a-zA-Z][\\\\w-]*(?:attribute)*?\\\\s*/?>' // open tag\n + '|^<\\\\?[\\\\s\\\\S]*?\\\\?>' // processing instruction, e.g. <?php ?>\n + '|^<![a-zA-Z]+\\\\s[\\\\s\\\\S]*?>' // declaration, e.g. <!DOCTYPE html>\n + '|^<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?\\\\]\\\\]>', // CDATA section\n link: /^!?\\[(label)\\]\\(href(?:\\s+(title))?\\s*\\)/,\n reflink: /^!?\\[(label)\\]\\[(?!\\s*\\])((?:\\\\[\\[\\]]?|[^\\[\\]\\\\])+)\\]/,\n nolink: /^!?\\[(?!\\s*\\])((?:\\[[^\\[\\]]*\\]|\\\\[\\[\\]]|[^\\[\\]])*)\\](?:\\[\\])?/,\n strong: /^__([^\\s_])__(?!_)|^\\*\\*([^\\s*])\\*\\*(?!\\*)|^__([^\\s][\\s\\S]*?[^\\s])__(?!_)|^\\*\\*([^\\s][\\s\\S]*?[^\\s])\\*\\*(?!\\*)/,\n em: /^_([^\\s_])_(?!_)|^\\*([^\\s*\"<\\[])\\*(?!\\*)|^_([^\\s][\\s\\S]*?[^\\s_])_(?!_|[^\\spunctuation])|^_([^\\s_][\\s\\S]*?[^\\s])_(?!_|[^\\spunctuation])|^\\*([^\\s\"<\\[][\\s\\S]*?[^\\s*])\\*(?!\\*)|^\\*([^\\s*\"<\\[][\\s\\S]*?[^\\s])\\*(?!\\*)/,\n code: /^(`+)([^`]|[^`][\\s\\S]*?[^`])\\1(?!`)/,\n br: /^( {2,}|\\\\)\\n(?!\\s*$)/,\n del: noop,\n text: /^(`+|[^`])(?:[\\s\\S]*?(?:(?=[\\\\<!\\[`*]|\\b_|$)|[^ ](?= {2,}\\n))|(?= {2,}\\n))/\n};\n\n// list of punctuation marks from common mark spec\n// without ` and ] to workaround Rule 17 (inline code blocks/links)\ninline._punctuation = '!\"#$%&\\'()*+,\\\\-./:;<=>?@\\\\[^_{|}~';\ninline.em = edit(inline.em).replace(/punctuation/g, inline._punctuation).getRegex();\n\ninline._escapes = /\\\\([!\"#$%&'()*+,\\-./:;<=>?@\\[\\]\\\\^_`{|}~])/g;\n\ninline._scheme = /[a-zA-Z][a-zA-Z0-9+.-]{1,31}/;\ninline._email = /[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/;\ninline.autolink = edit(inline.autolink)\n .replace('scheme', inline._scheme)\n .replace('email', inline._email)\n .getRegex();\n\ninline._attribute = /\\s+[a-zA-Z:_][\\w.:-]*(?:\\s*=\\s*\"[^\"]*\"|\\s*=\\s*'[^']*'|\\s*=\\s*[^\\s\"'=<>`]+)?/;\n\ninline.tag = edit(inline.tag)\n .replace('comment', block._comment)\n .replace('attribute', inline._attribute)\n .getRegex();\n\ninline._label = /(?:\\[[^\\[\\]]*\\]|\\\\[\\[\\]]?|`[^`]*`|`(?!`)|[^\\[\\]\\\\`])*?/;\ninline._href = /\\s*(<(?:\\\\[<>]?|[^\\s<>\\\\])*>|[^\\s\\x00-\\x1f]*)/;\ninline._title = /\"(?:\\\\\"?|[^\"\\\\])*\"|'(?:\\\\'?|[^'\\\\])*'|\\((?:\\\\\\)?|[^)\\\\])*\\)/;\n\ninline.link = edit(inline.link)\n .replace('label', inline._label)\n .replace('href', inline._href)\n .replace('title', inline._title)\n .getRegex();\n\ninline.reflink = edit(inline.reflink)\n .replace('label', inline._label)\n .getRegex();\n\n/**\n * Normal Inline Grammar\n */\n\ninline.normal = merge({}, inline);\n\n/**\n * Pedantic Inline Grammar\n */\n\ninline.pedantic = merge({}, inline.normal, {\n strong: /^__(?=\\S)([\\s\\S]*?\\S)__(?!_)|^\\*\\*(?=\\S)([\\s\\S]*?\\S)\\*\\*(?!\\*)/,\n em: /^_(?=\\S)([\\s\\S]*?\\S)_(?!_)|^\\*(?=\\S)([\\s\\S]*?\\S)\\*(?!\\*)/,\n link: edit(/^!?\\[(label)\\]\\((.*?)\\)/)\n .replace('label', inline._label)\n .getRegex(),\n reflink: edit(/^!?\\[(label)\\]\\s*\\[([^\\]]*)\\]/)\n .replace('label', inline._label)\n .getRegex()\n});\n\n/**\n * GFM Inline Grammar\n */\n\ninline.gfm = merge({}, inline.normal, {\n escape: edit(inline.escape).replace('])', '~|])').getRegex(),\n _extended_email: /[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/,\n url: /^((?:ftp|https?):\\/\\/|www\\.)(?:[a-zA-Z0-9\\-]+\\.?)+[^\\s<]*|^email/,\n _backpedal: /(?:[^?!.,:;*_~()&]+|\\([^)]*\\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_~)]+(?!$))+/,\n del: /^~+(?=\\S)([\\s\\S]*?\\S)~+/,\n text: /^(`+|[^`])(?:[\\s\\S]*?(?:(?=[\\\\<!\\[`*~]|\\b_|https?:\\/\\/|ftp:\\/\\/|www\\.|$)|[^ ](?= {2,}\\n)|[^a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-](?=[a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-]+@))|(?= {2,}\\n|[a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-]+@))/\n});\n\ninline.gfm.url = edit(inline.gfm.url, 'i')\n .replace('email', inline.gfm._extended_email)\n .getRegex();\n/**\n * GFM + Line Breaks Inline Grammar\n */\n\ninline.breaks = merge({}, inline.gfm, {\n br: edit(inline.br).replace('{2,}', '*').getRegex(),\n text: edit(inline.gfm.text).replace(/\\{2,\\}/g, '*').getRegex()\n});\n\n/**\n * Inline Lexer & Compiler\n */\n\nfunction InlineLexer(links, options) {\n this.options = options || marked.defaults;\n this.links = links;\n this.rules = inline.normal;\n this.renderer = this.options.renderer || new Renderer();\n this.renderer.options = this.options;\n\n if (!this.links) {\n throw new Error('Tokens array requires a `links` property.');\n }\n\n if (this.options.pedantic) {\n this.rules = inline.pedantic;\n } else if (this.options.gfm) {\n if (this.options.breaks) {\n this.rules = inline.breaks;\n } else {\n this.rules = inline.gfm;\n }\n }\n}\n\n/**\n * Expose Inline Rules\n */\n\nInlineLexer.rules = inline;\n\n/**\n * Static Lexing/Compiling Method\n */\n\nInlineLexer.output = function(src, links, options) {\n var inline = new InlineLexer(links, options);\n return inline.output(src);\n};\n\n/**\n * Lexing/Compiling\n */\n\nInlineLexer.prototype.output = function(src) {\n var out = '',\n link,\n text,\n href,\n title,\n cap,\n prevCapZero;\n\n while (src) {\n // escape\n if (cap = this.rules.escape.exec(src)) {\n src = src.substring(cap[0].length);\n out += escape(cap[1]);\n continue;\n }\n\n // tag\n if (cap = this.rules.tag.exec(src)) {\n if (!this.inLink && /^<a /i.test(cap[0])) {\n this.inLink = true;\n } else if (this.inLink && /^<\\/a>/i.test(cap[0])) {\n this.inLink = false;\n }\n if (!this.inRawBlock && /^<(pre|code|kbd|script)(\\s|>)/i.test(cap[0])) {\n this.inRawBlock = true;\n } else if (this.inRawBlock && /^<\\/(pre|code|kbd|script)(\\s|>)/i.test(cap[0])) {\n this.inRawBlock = false;\n }\n\n src = src.substring(cap[0].length);\n out += this.options.sanitize\n ? this.options.sanitizer\n ? this.options.sanitizer(cap[0])\n : escape(cap[0])\n : cap[0];\n continue;\n }\n\n // link\n if (cap = this.rules.link.exec(src)) {\n var lastParenIndex = findClosingBracket(cap[2], '()');\n if (lastParenIndex > -1) {\n var linkLen = cap[0].length - (cap[2].length - lastParenIndex) - (cap[3] || '').length;\n cap[2] = cap[2].substring(0, lastParenIndex);\n cap[0] = cap[0].substring(0, linkLen).trim();\n cap[3] = '';\n }\n src = src.substring(cap[0].length);\n this.inLink = true;\n href = cap[2];\n if (this.options.pedantic) {\n link = /^([^'\"]*[^\\s])\\s+(['\"])(.*)\\2/.exec(href);\n\n if (link) {\n href = link[1];\n title = link[3];\n } else {\n title = '';\n }\n } else {\n title = cap[3] ? cap[3].slice(1, -1) : '';\n }\n href = href.trim().replace(/^<([\\s\\S]*)>$/, '$1');\n out += this.outputLink(cap, {\n href: InlineLexer.escapes(href),\n title: InlineLexer.escapes(title)\n });\n this.inLink = false;\n continue;\n }\n\n // reflink, nolink\n if ((cap = this.rules.reflink.exec(src))\n || (cap = this.rules.nolink.exec(src))) {\n src = src.substring(cap[0].length);\n link = (cap[2] || cap[1]).replace(/\\s+/g, ' ');\n link = this.links[link.toLowerCase()];\n if (!link || !link.href) {\n out += cap[0].charAt(0);\n src = cap[0].substring(1) + src;\n continue;\n }\n this.inLink = true;\n out += this.outputLink(cap, link);\n this.inLink = false;\n continue;\n }\n\n // strong\n if (cap = this.rules.strong.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.strong(this.output(cap[4] || cap[3] || cap[2] || cap[1]));\n continue;\n }\n\n // em\n if (cap = this.rules.em.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.em(this.output(cap[6] || cap[5] || cap[4] || cap[3] || cap[2] || cap[1]));\n continue;\n }\n\n // code\n if (cap = this.rules.code.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.codespan(escape(cap[2].trim(), true));\n continue;\n }\n\n // br\n if (cap = this.rules.br.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.br();\n continue;\n }\n\n // del (gfm)\n if (cap = this.rules.del.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.del(this.output(cap[1]));\n continue;\n }\n\n // autolink\n if (cap = this.rules.autolink.exec(src)) {\n src = src.substring(cap[0].length);\n if (cap[2] === '@') {\n text = escape(this.mangle(cap[1]));\n href = 'mailto:' + text;\n } else {\n text = escape(cap[1]);\n href = text;\n }\n out += this.renderer.link(href, null, text);\n continue;\n }\n\n // url (gfm)\n if (!this.inLink && (cap = this.rules.url.exec(src))) {\n if (cap[2] === '@') {\n text = escape(cap[0]);\n href = 'mailto:' + text;\n } else {\n // do extended autolink path validation\n do {\n prevCapZero = cap[0];\n cap[0] = this.rules._backpedal.exec(cap[0])[0];\n } while (prevCapZero !== cap[0]);\n text = escape(cap[0]);\n if (cap[1] === 'www.') {\n href = 'http://' + text;\n } else {\n href = text;\n }\n }\n src = src.substring(cap[0].length);\n out += this.renderer.link(href, null, text);\n continue;\n }\n\n // text\n if (cap = this.rules.text.exec(src)) {\n src = src.substring(cap[0].length);\n if (this.inRawBlock) {\n out += this.renderer.text(cap[0]);\n } else {\n out += this.renderer.text(escape(this.smartypants(cap[0])));\n }\n continue;\n }\n\n if (src) {\n throw new Error('Infinite loop on byte: ' + src.charCodeAt(0));\n }\n }\n\n return out;\n};\n\nInlineLexer.escapes = function(text) {\n return text ? text.replace(InlineLexer.rules._escapes, '$1') : text;\n};\n\n/**\n * Compile Link\n */\n\nInlineLexer.prototype.outputLink = function(cap, link) {\n var href = link.href,\n title = link.title ? escape(link.title) : null;\n\n return cap[0].charAt(0) !== '!'\n ? this.renderer.link(href, title, this.output(cap[1]))\n : this.renderer.image(href, title, escape(cap[1]));\n};\n\n/**\n * Smartypants Transformations\n */\n\nInlineLexer.prototype.smartypants = function(text) {\n if (!this.options.smartypants) return text;\n return text\n // em-dashes\n .replace(/---/g, '\\u2014')\n // en-dashes\n .replace(/--/g, '\\u2013')\n // opening singles\n .replace(/(^|[-\\u2014/(\\[{\"\\s])'/g, '$1\\u2018')\n // closing singles & apostrophes\n .replace(/'/g, '\\u2019')\n // opening doubles\n .replace(/(^|[-\\u2014/(\\[{\\u2018\\s])\"/g, '$1\\u201c')\n // closing doubles\n .replace(/\"/g, '\\u201d')\n // ellipses\n .replace(/\\.{3}/g, '\\u2026');\n};\n\n/**\n * Mangle Links\n */\n\nInlineLexer.prototype.mangle = function(text) {\n if (!this.options.mangle) return text;\n var out = '',\n l = text.length,\n i = 0,\n ch;\n\n for (; i < l; i++) {\n ch = text.charCodeAt(i);\n if (Math.random() > 0.5) {\n ch = 'x' + ch.toString(16);\n }\n out += '&#' + ch + ';';\n }\n\n return out;\n};\n\n/**\n * Renderer\n */\n\nfunction Renderer(options) {\n this.options = options || marked.defaults;\n}\n\nRenderer.prototype.code = function(code, infostring, escaped) {\n var lang = (infostring || '').match(/\\S*/)[0];\n if (this.options.highlight) {\n var out = this.options.highlight(code, lang);\n if (out != null && out !== code) {\n escaped = true;\n code = out;\n }\n }\n\n if (!lang) {\n return '<pre><code>'\n + (escaped ? code : escape(code, true))\n + '</code></pre>';\n }\n\n return '<pre><code class=\"'\n + this.options.langPrefix\n + escape(lang, true)\n + '\">'\n + (escaped ? code : escape(code, true))\n + '</code></pre>\\n';\n};\n\nRenderer.prototype.blockquote = function(quote) {\n return '<blockquote>\\n' + quote + '</blockquote>\\n';\n};\n\nRenderer.prototype.html = function(html) {\n return html;\n};\n\nRenderer.prototype.heading = function(text, level, raw, slugger) {\n if (this.options.headerIds) {\n return '<h'\n + level\n + ' id=\"'\n + this.options.headerPrefix\n + slugger.slug(raw)\n + '\">'\n + text\n + '</h'\n + level\n + '>\\n';\n }\n // ignore IDs\n return '<h' + level + '>' + text + '</h' + level + '>\\n';\n};\n\nRenderer.prototype.hr = function() {\n return this.options.xhtml ? '<hr/>\\n' : '<hr>\\n';\n};\n\nRenderer.prototype.list = function(body, ordered, start) {\n var type = ordered ? 'ol' : 'ul',\n startatt = (ordered && start !== 1) ? (' start=\"' + start + '\"') : '';\n return '<' + type + startatt + '>\\n' + body + '</' + type + '>\\n';\n};\n\nRenderer.prototype.listitem = function(text) {\n return '<li>' + text + '</li>\\n';\n};\n\nRenderer.prototype.checkbox = function(checked) {\n return '<input '\n + (checked ? 'checked=\"\" ' : '')\n + 'disabled=\"\" type=\"checkbox\"'\n + (this.options.xhtml ? ' /' : '')\n + '> ';\n};\n\nRenderer.prototype.paragraph = function(text) {\n return '<p>' + text + '</p>\\n';\n};\n\nRenderer.prototype.table = function(header, body) {\n if (body) body = '<tbody>' + body + '</tbody>';\n\n return '<table>\\n'\n + '<thead>\\n'\n + header\n + '</thead>\\n'\n + body\n + '</table>\\n';\n};\n\nRenderer.prototype.tablerow = function(content) {\n return '<tr>\\n' + content + '</tr>\\n';\n};\n\nRenderer.prototype.tablecell = function(content, flags) {\n var type = flags.header ? 'th' : 'td';\n var tag = flags.align\n ? '<' + type + ' align=\"' + flags.align + '\">'\n : '<' + type + '>';\n return tag + content + '</' + type + '>\\n';\n};\n\n// span level renderer\nRenderer.prototype.strong = function(text) {\n return '<strong>' + text + '</strong>';\n};\n\nRenderer.prototype.em = function(text) {\n return '<em>' + text + '</em>';\n};\n\nRenderer.prototype.codespan = function(text) {\n return '<code>' + text + '</code>';\n};\n\nRenderer.prototype.br = function() {\n return this.options.xhtml ? '<br/>' : '<br>';\n};\n\nRenderer.prototype.del = function(text) {\n return '<del>' + text + '</del>';\n};\n\nRenderer.prototype.link = function(href, title, text) {\n href = cleanUrl(this.options.sanitize, this.options.baseUrl, href);\n if (href === null) {\n return text;\n }\n var out = '<a href=\"' + escape(href) + '\"';\n if (title) {\n out += ' title=\"' + title + '\"';\n }\n out += '>' + text + '</a>';\n return out;\n};\n\nRenderer.prototype.image = function(href, title, text) {\n href = cleanUrl(this.options.sanitize, this.options.baseUrl, href);\n if (href === null) {\n return text;\n }\n\n var out = '<img src=\"' + href + '\" alt=\"' + text + '\"';\n if (title) {\n out += ' title=\"' + title + '\"';\n }\n out += this.options.xhtml ? '/>' : '>';\n return out;\n};\n\nRenderer.prototype.text = function(text) {\n return text;\n};\n\n/**\n * TextRenderer\n * returns only the textual part of the token\n */\n\nfunction TextRenderer() {}\n\n// no need for block level renderers\n\nTextRenderer.prototype.strong =\nTextRenderer.prototype.em =\nTextRenderer.prototype.codespan =\nTextRenderer.prototype.del =\nTextRenderer.prototype.text = function (text) {\n return text;\n};\n\nTextRenderer.prototype.link =\nTextRenderer.prototype.image = function(href, title, text) {\n return '' + text;\n};\n\nTextRenderer.prototype.br = function() {\n return '';\n};\n\n/**\n * Parsing & Compiling\n */\n\nfunction Parser(options) {\n this.tokens = [];\n this.token = null;\n this.options = options || marked.defaults;\n this.options.renderer = this.options.renderer || new Renderer();\n this.renderer = this.options.renderer;\n this.renderer.options = this.options;\n this.slugger = new Slugger();\n}\n\n/**\n * Static Parse Method\n */\n\nParser.parse = function(src, options) {\n var parser = new Parser(options);\n return parser.parse(src);\n};\n\n/**\n * Parse Loop\n */\n\nParser.prototype.parse = function(src) {\n this.inline = new InlineLexer(src.links, this.options);\n // use an InlineLexer with a TextRenderer to extract pure text\n this.inlineText = new InlineLexer(\n src.links,\n merge({}, this.options, {renderer: new TextRenderer()})\n );\n this.tokens = src.reverse();\n\n var out = '';\n while (this.next()) {\n out += this.tok();\n }\n\n return out;\n};\n\n/**\n * Next Token\n */\n\nParser.prototype.next = function() {\n return this.token = this.tokens.pop();\n};\n\n/**\n * Preview Next Token\n */\n\nParser.prototype.peek = function() {\n return this.tokens[this.tokens.length - 1] || 0;\n};\n\n/**\n * Parse Text Tokens\n */\n\nParser.prototype.parseText = function() {\n var body = this.token.text;\n\n while (this.peek().type === 'text') {\n body += '\\n' + this.next().text;\n }\n\n return this.inline.output(body);\n};\n\n/**\n * Parse Current Token\n */\n\nParser.prototype.tok = function() {\n switch (this.token.type) {\n case 'space': {\n return '';\n }\n case 'hr': {\n return this.renderer.hr();\n }\n case 'heading': {\n return this.renderer.heading(\n this.inline.output(this.token.text),\n this.token.depth,\n unescape(this.inlineText.output(this.token.text)),\n this.slugger);\n }\n case 'code': {\n return this.renderer.code(this.token.text,\n this.token.lang,\n this.token.escaped);\n }\n case 'table': {\n var header = '',\n body = '',\n i,\n row,\n cell,\n j;\n\n // header\n cell = '';\n for (i = 0; i < this.token.header.length; i++) {\n cell += this.renderer.tablecell(\n this.inline.output(this.token.header[i]),\n { header: true, align: this.token.align[i] }\n );\n }\n header += this.renderer.tablerow(cell);\n\n for (i = 0; i < this.token.cells.length; i++) {\n row = this.token.cells[i];\n\n cell = '';\n for (j = 0; j < row.length; j++) {\n cell += this.renderer.tablecell(\n this.inline.output(row[j]),\n { header: false, align: this.token.align[j] }\n );\n }\n\n body += this.renderer.tablerow(cell);\n }\n return this.renderer.table(header, body);\n }\n case 'blockquote_start': {\n body = '';\n\n while (this.next().type !== 'blockquote_end') {\n body += this.tok();\n }\n\n return this.renderer.blockquote(body);\n }\n case 'list_start': {\n body = '';\n var ordered = this.token.ordered,\n start = this.token.start;\n\n while (this.next().type !== 'list_end') {\n body += this.tok();\n }\n\n return this.renderer.list(body, ordered, start);\n }\n case 'list_item_start': {\n body = '';\n var loose = this.token.loose;\n var checked = this.token.checked;\n var task = this.token.task;\n\n if (this.token.task) {\n body += this.renderer.checkbox(checked);\n }\n\n while (this.next().type !== 'list_item_end') {\n body += !loose && this.token.type === 'text'\n ? this.parseText()\n : this.tok();\n }\n return this.renderer.listitem(body, task, checked);\n }\n case 'html': {\n // TODO parse inline content if parameter markdown=1\n return this.renderer.html(this.token.text);\n }\n case 'paragraph': {\n return this.renderer.paragraph(this.inline.output(this.token.text));\n }\n case 'text': {\n return this.renderer.paragraph(this.parseText());\n }\n default: {\n var errMsg = 'Token with \"' + this.token.type + '\" type was not found.';\n if (this.options.silent) {\n console.log(errMsg);\n } else {\n throw new Error(errMsg);\n }\n }\n }\n};\n\n/**\n * Slugger generates header id\n */\n\nfunction Slugger () {\n this.seen = {};\n}\n\n/**\n * Convert string to unique id\n */\n\nSlugger.prototype.slug = function (value) {\n var slug = value\n .toLowerCase()\n .trim()\n .replace(/[\\u2000-\\u206F\\u2E00-\\u2E7F\\\\'!\"#$%&()*+,./:;<=>?@[\\]^`{|}~]/g, '')\n .replace(/\\s/g, '-');\n\n if (this.seen.hasOwnProperty(slug)) {\n var originalSlug = slug;\n do {\n this.seen[originalSlug]++;\n slug = originalSlug + '-' + this.seen[originalSlug];\n } while (this.seen.hasOwnProperty(slug));\n }\n this.seen[slug] = 0;\n\n return slug;\n};\n\n/**\n * Helpers\n */\n\nfunction escape(html, encode) {\n if (encode) {\n if (escape.escapeTest.test(html)) {\n return html.replace(escape.escapeReplace, function (ch) { return escape.replacements[ch]; });\n }\n } else {\n if (escape.escapeTestNoEncode.test(html)) {\n return html.replace(escape.escapeReplaceNoEncode, function (ch) { return escape.replacements[ch]; });\n }\n }\n\n return html;\n}\n\nescape.escapeTest = /[&<>\"']/;\nescape.escapeReplace = /[&<>\"']/g;\nescape.replacements = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n};\n\nescape.escapeTestNoEncode = /[<>\"']|&(?!#?\\w+;)/;\nescape.escapeReplaceNoEncode = /[<>\"']|&(?!#?\\w+;)/g;\n\nfunction unescape(html) {\n // explicitly match decimal, hex, and named HTML entities\n return html.replace(/&(#(?:\\d+)|(?:#x[0-9A-Fa-f]+)|(?:\\w+));?/ig, function(_, n) {\n n = n.toLowerCase();\n if (n === 'colon') return ':';\n if (n.charAt(0) === '#') {\n return n.charAt(1) === 'x'\n ? String.fromCharCode(parseInt(n.substring(2), 16))\n : String.fromCharCode(+n.substring(1));\n }\n return '';\n });\n}\n\nfunction edit(regex, opt) {\n regex = regex.source || regex;\n opt = opt || '';\n return {\n replace: function(name, val) {\n val = val.source || val;\n val = val.replace(/(^|[^\\[])\\^/g, '$1');\n regex = regex.replace(name, val);\n return this;\n },\n getRegex: function() {\n return new RegExp(regex, opt);\n }\n };\n}\n\nfunction cleanUrl(sanitize, base, href) {\n if (sanitize) {\n try {\n var prot = decodeURIComponent(unescape(href))\n .replace(/[^\\w:]/g, '')\n .toLowerCase();\n } catch (e) {\n return null;\n }\n if (prot.indexOf('javascript:') === 0 || prot.indexOf('vbscript:') === 0 || prot.indexOf('data:') === 0) {\n return null;\n }\n }\n if (base && !originIndependentUrl.test(href)) {\n href = resolveUrl(base, href);\n }\n try {\n href = encodeURI(href).replace(/%25/g, '%');\n } catch (e) {\n return null;\n }\n return href;\n}\n\nfunction resolveUrl(base, href) {\n if (!baseUrls[' ' + base]) {\n // we can ignore everything in base after the last slash of its path component,\n // but we might need to add _that_\n // https://tools.ietf.org/html/rfc3986#section-3\n if (/^[^:]+:\\/*[^/]*$/.test(base)) {\n baseUrls[' ' + base] = base + '/';\n } else {\n baseUrls[' ' + base] = rtrim(base, '/', true);\n }\n }\n base = baseUrls[' ' + base];\n\n if (href.slice(0, 2) === '//') {\n return base.replace(/:[\\s\\S]*/, ':') + href;\n } else if (href.charAt(0) === '/') {\n return base.replace(/(:\\/*[^/]*)[\\s\\S]*/, '$1') + href;\n } else {\n return base + href;\n }\n}\nvar baseUrls = {};\nvar originIndependentUrl = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;\n\nfunction noop() {}\nnoop.exec = noop;\n\nfunction merge(obj) {\n var i = 1,\n target,\n key;\n\n for (; i < arguments.length; i++) {\n target = arguments[i];\n for (key in target) {\n if (Object.prototype.hasOwnProperty.call(target, key)) {\n obj[key] = target[key];\n }\n }\n }\n\n return obj;\n}\n\nfunction splitCells(tableRow, count) {\n // ensure that every cell-delimiting pipe has a space\n // before it to distinguish it from an escaped pipe\n var row = tableRow.replace(/\\|/g, function (match, offset, str) {\n var escaped = false,\n curr = offset;\n while (--curr >= 0 && str[curr] === '\\\\') escaped = !escaped;\n if (escaped) {\n // odd number of slashes means | is escaped\n // so we leave it alone\n return '|';\n } else {\n // add space before unescaped |\n return ' |';\n }\n }),\n cells = row.split(/ \\|/),\n i = 0;\n\n if (cells.length > count) {\n cells.splice(count);\n } else {\n while (cells.length < count) cells.push('');\n }\n\n for (; i < cells.length; i++) {\n // leading or trailing whitespace is ignored per the gfm spec\n cells[i] = cells[i].trim().replace(/\\\\\\|/g, '|');\n }\n return cells;\n}\n\n// Remove trailing 'c's. Equivalent to str.replace(/c*$/, '').\n// /c*$/ is vulnerable to REDOS.\n// invert: Remove suffix of non-c chars instead. Default falsey.\nfunction rtrim(str, c, invert) {\n if (str.length === 0) {\n return '';\n }\n\n // Length of suffix matching the invert condition.\n var suffLen = 0;\n\n // Step left until we fail to match the invert condition.\n while (suffLen < str.length) {\n var currChar = str.charAt(str.length - suffLen - 1);\n if (currChar === c && !invert) {\n suffLen++;\n } else if (currChar !== c && invert) {\n suffLen++;\n } else {\n break;\n }\n }\n\n return str.substr(0, str.length - suffLen);\n}\n\nfunction findClosingBracket(str, b) {\n if (str.indexOf(b[1]) === -1) {\n return -1;\n }\n var level = 0;\n for (var i = 0; i < str.length; i++) {\n if (str[i] === '\\\\') {\n i++;\n } else if (str[i] === b[0]) {\n level++;\n } else if (str[i] === b[1]) {\n level--;\n if (level < 0) {\n return i;\n }\n }\n }\n return -1;\n}\n\n/**\n * Marked\n */\n\nfunction marked(src, opt, callback) {\n // throw error in case of non string input\n if (typeof src === 'undefined' || src === null) {\n throw new Error('marked(): input parameter is undefined or null');\n }\n if (typeof src !== 'string') {\n throw new Error('marked(): input parameter is of type '\n + Object.prototype.toString.call(src) + ', string expected');\n }\n\n if (callback || typeof opt === 'function') {\n if (!callback) {\n callback = opt;\n opt = null;\n }\n\n opt = merge({}, marked.defaults, opt || {});\n\n var highlight = opt.highlight,\n tokens,\n pending,\n i = 0;\n\n try {\n tokens = Lexer.lex(src, opt);\n } catch (e) {\n return callback(e);\n }\n\n pending = tokens.length;\n\n var done = function(err) {\n if (err) {\n opt.highlight = highlight;\n return callback(err);\n }\n\n var out;\n\n try {\n out = Parser.parse(tokens, opt);\n } catch (e) {\n err = e;\n }\n\n opt.highlight = highlight;\n\n return err\n ? callback(err)\n : callback(null, out);\n };\n\n if (!highlight || highlight.length < 3) {\n return done();\n }\n\n delete opt.highlight;\n\n if (!pending) return done();\n\n for (; i < tokens.length; i++) {\n (function(token) {\n if (token.type !== 'code') {\n return --pending || done();\n }\n return highlight(token.text, token.lang, function(err, code) {\n if (err) return done(err);\n if (code == null || code === token.text) {\n return --pending || done();\n }\n token.text = code;\n token.escaped = true;\n --pending || done();\n });\n })(tokens[i]);\n }\n\n return;\n }\n try {\n if (opt) opt = merge({}, marked.defaults, opt);\n return Parser.parse(Lexer.lex(src, opt), opt);\n } catch (e) {\n e.message += '\\nPlease report this to https://github.com/markedjs/marked.';\n if ((opt || marked.defaults).silent) {\n return '<p>An error occurred:</p><pre>'\n + escape(e.message + '', true)\n + '</pre>';\n }\n throw e;\n }\n}\n\n/**\n * Options\n */\n\nmarked.options =\nmarked.setOptions = function(opt) {\n merge(marked.defaults, opt);\n return marked;\n};\n\nmarked.getDefaults = function () {\n return {\n baseUrl: null,\n breaks: false,\n gfm: true,\n headerIds: true,\n headerPrefix: '',\n highlight: null,\n langPrefix: 'language-',\n mangle: true,\n pedantic: false,\n renderer: new Renderer(),\n sanitize: false,\n sanitizer: null,\n silent: false,\n smartLists: false,\n smartypants: false,\n tables: true,\n xhtml: false\n };\n};\n\nmarked.defaults = marked.getDefaults();\n\n/**\n * Expose\n */\n\nmarked.Parser = Parser;\nmarked.parser = Parser.parse;\n\nmarked.Renderer = Renderer;\nmarked.TextRenderer = TextRenderer;\n\nmarked.Lexer = Lexer;\nmarked.lexer = Lexer.lex;\n\nmarked.InlineLexer = InlineLexer;\nmarked.inlineLexer = InlineLexer.output;\n\nmarked.Slugger = Slugger;\n\nmarked.parse = marked;\n\nif (typeof module !== 'undefined' && typeof exports === 'object') {\n module.exports = marked;\n} else if (typeof define === 'function' && define.amd) {\n define(function() { return marked; });\n} else {\n root.marked = marked;\n}\n})(this || (typeof window !== 'undefined' ? window : global));\n","(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n\ttypeof define === 'function' && define.amd ? define(factory) :\n\t(global.DOMPurify = factory());\n}(this, (function () { 'use strict';\n\nvar freeze$1 = Object.freeze || function (x) {\n return x;\n};\n\nvar html = freeze$1(['a', 'abbr', 'acronym', 'address', 'area', 'article', 'aside', 'audio', 'b', 'bdi', 'bdo', 'big', 'blink', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'center', 'cite', 'code', 'col', 'colgroup', 'content', 'data', 'datalist', 'dd', 'decorator', 'del', 'details', 'dfn', 'dir', 'div', 'dl', 'dt', 'element', 'em', 'fieldset', 'figcaption', 'figure', 'font', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'img', 'input', 'ins', 'kbd', 'label', 'legend', 'li', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meter', 'nav', 'nobr', 'ol', 'optgroup', 'option', 'output', 'p', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'section', 'select', 'shadow', 'small', 'source', 'spacer', 'span', 'strike', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'template', 'textarea', 'tfoot', 'th', 'thead', 'time', 'tr', 'track', 'tt', 'u', 'ul', 'var', 'video', 'wbr']);\n\n// SVG\nvar svg = freeze$1(['svg', 'a', 'altglyph', 'altglyphdef', 'altglyphitem', 'animatecolor', 'animatemotion', 'animatetransform', 'audio', 'canvas', 'circle', 'clippath', 'defs', 'desc', 'ellipse', 'filter', 'font', 'g', 'glyph', 'glyphref', 'hkern', 'image', 'line', 'lineargradient', 'marker', 'mask', 'metadata', 'mpath', 'path', 'pattern', 'polygon', 'polyline', 'radialgradient', 'rect', 'stop', 'style', 'switch', 'symbol', 'text', 'textpath', 'title', 'tref', 'tspan', 'video', 'view', 'vkern']);\n\nvar svgFilters = freeze$1(['feBlend', 'feColorMatrix', 'feComponentTransfer', 'feComposite', 'feConvolveMatrix', 'feDiffuseLighting', 'feDisplacementMap', 'feDistantLight', 'feFlood', 'feFuncA', 'feFuncB', 'feFuncG', 'feFuncR', 'feGaussianBlur', 'feMerge', 'feMergeNode', 'feMorphology', 'feOffset', 'fePointLight', 'feSpecularLighting', 'feSpotLight', 'feTile', 'feTurbulence']);\n\nvar mathMl = freeze$1(['math', 'menclose', 'merror', 'mfenced', 'mfrac', 'mglyph', 'mi', 'mlabeledtr', 'mmultiscripts', 'mn', 'mo', 'mover', 'mpadded', 'mphantom', 'mroot', 'mrow', 'ms', 'mspace', 'msqrt', 'mstyle', 'msub', 'msup', 'msubsup', 'mtable', 'mtd', 'mtext', 'mtr', 'munder', 'munderover']);\n\nvar text = freeze$1(['#text']);\n\nvar freeze$2 = Object.freeze || function (x) {\n return x;\n};\n\nvar html$1 = freeze$2(['accept', 'action', 'align', 'alt', 'autocomplete', 'background', 'bgcolor', 'border', 'cellpadding', 'cellspacing', 'checked', 'cite', 'class', 'clear', 'color', 'cols', 'colspan', 'coords', 'crossorigin', 'datetime', 'default', 'dir', 'disabled', 'download', 'enctype', 'face', 'for', 'headers', 'height', 'hidden', 'high', 'href', 'hreflang', 'id', 'integrity', 'ismap', 'label', 'lang', 'list', 'loop', 'low', 'max', 'maxlength', 'media', 'method', 'min', 'multiple', 'name', 'noshade', 'novalidate', 'nowrap', 'open', 'optimum', 'pattern', 'placeholder', 'poster', 'preload', 'pubdate', 'radiogroup', 'readonly', 'rel', 'required', 'rev', 'reversed', 'role', 'rows', 'rowspan', 'spellcheck', 'scope', 'selected', 'shape', 'size', 'sizes', 'span', 'srclang', 'start', 'src', 'srcset', 'step', 'style', 'summary', 'tabindex', 'title', 'type', 'usemap', 'valign', 'value', 'width', 'xmlns']);\n\nvar svg$1 = freeze$2(['accent-height', 'accumulate', 'additive', 'alignment-baseline', 'ascent', 'attributename', 'attributetype', 'azimuth', 'basefrequency', 'baseline-shift', 'begin', 'bias', 'by', 'class', 'clip', 'clip-path', 'clip-rule', 'color', 'color-interpolation', 'color-interpolation-filters', 'color-profile', 'color-rendering', 'cx', 'cy', 'd', 'dx', 'dy', 'diffuseconstant', 'direction', 'display', 'divisor', 'dur', 'edgemode', 'elevation', 'end', 'fill', 'fill-opacity', 'fill-rule', 'filter', 'flood-color', 'flood-opacity', 'font-family', 'font-size', 'font-size-adjust', 'font-stretch', 'font-style', 'font-variant', 'font-weight', 'fx', 'fy', 'g1', 'g2', 'glyph-name', 'glyphref', 'gradientunits', 'gradienttransform', 'height', 'href', 'id', 'image-rendering', 'in', 'in2', 'k', 'k1', 'k2', 'k3', 'k4', 'kerning', 'keypoints', 'keysplines', 'keytimes', 'lang', 'lengthadjust', 'letter-spacing', 'kernelmatrix', 'kernelunitlength', 'lighting-color', 'local', 'marker-end', 'marker-mid', 'marker-start', 'markerheight', 'markerunits', 'markerwidth', 'maskcontentunits', 'maskunits', 'max', 'mask', 'media', 'method', 'mode', 'min', 'name', 'numoctaves', 'offset', 'operator', 'opacity', 'order', 'orient', 'orientation', 'origin', 'overflow', 'paint-order', 'path', 'pathlength', 'patterncontentunits', 'patterntransform', 'patternunits', 'points', 'preservealpha', 'preserveaspectratio', 'r', 'rx', 'ry', 'radius', 'refx', 'refy', 'repeatcount', 'repeatdur', 'restart', 'result', 'rotate', 'scale', 'seed', 'shape-rendering', 'specularconstant', 'specularexponent', 'spreadmethod', 'stddeviation', 'stitchtiles', 'stop-color', 'stop-opacity', 'stroke-dasharray', 'stroke-dashoffset', 'stroke-linecap', 'stroke-linejoin', 'stroke-miterlimit', 'stroke-opacity', 'stroke', 'stroke-width', 'style', 'surfacescale', 'tabindex', 'targetx', 'targety', 'transform', 'text-anchor', 'text-decoration', 'text-rendering', 'textlength', 'type', 'u1', 'u2', 'unicode', 'values', 'viewbox', 'visibility', 'version', 'vert-adv-y', 'vert-origin-x', 'vert-origin-y', 'width', 'word-spacing', 'wrap', 'writing-mode', 'xchannelselector', 'ychannelselector', 'x', 'x1', 'x2', 'xmlns', 'y', 'y1', 'y2', 'z', 'zoomandpan']);\n\nvar mathMl$1 = freeze$2(['accent', 'accentunder', 'align', 'bevelled', 'close', 'columnsalign', 'columnlines', 'columnspan', 'denomalign', 'depth', 'dir', 'display', 'displaystyle', 'fence', 'frame', 'height', 'href', 'id', 'largeop', 'length', 'linethickness', 'lspace', 'lquote', 'mathbackground', 'mathcolor', 'mathsize', 'mathvariant', 'maxsize', 'minsize', 'movablelimits', 'notation', 'numalign', 'open', 'rowalign', 'rowlines', 'rowspacing', 'rowspan', 'rspace', 'rquote', 'scriptlevel', 'scriptminsize', 'scriptsizemultiplier', 'selection', 'separator', 'separators', 'stretchy', 'subscriptshift', 'supscriptshift', 'symmetric', 'voffset', 'width', 'xmlns']);\n\nvar xml = freeze$2(['xlink:href', 'xml:id', 'xlink:title', 'xml:space', 'xmlns:xlink']);\n\nvar hasOwnProperty = Object.hasOwnProperty;\nvar setPrototypeOf = Object.setPrototypeOf;\n\nvar _ref$1 = typeof Reflect !== 'undefined' && Reflect;\nvar apply$1 = _ref$1.apply;\n\nif (!apply$1) {\n apply$1 = function apply(fun, thisValue, args) {\n return fun.apply(thisValue, args);\n };\n}\n\n/* Add properties to a lookup table */\nfunction addToSet(set, array) {\n if (setPrototypeOf) {\n // Make 'in' and truthy checks like Boolean(set.constructor)\n // independent of any properties defined on Object.prototype.\n // Prevent prototype setters from intercepting set as a this value.\n setPrototypeOf(set, null);\n }\n\n var l = array.length;\n while (l--) {\n var element = array[l];\n if (typeof element === 'string') {\n var lcElement = element.toLowerCase();\n if (lcElement !== element) {\n // Config presets (e.g. tags.js, attrs.js) are immutable.\n if (!Object.isFrozen(array)) {\n array[l] = lcElement;\n }\n\n element = lcElement;\n }\n }\n\n set[element] = true;\n }\n\n return set;\n}\n\n/* Shallow clone an object */\nfunction clone(object) {\n var newObject = {};\n\n var property = void 0;\n for (property in object) {\n if (apply$1(hasOwnProperty, object, [property])) {\n newObject[property] = object[property];\n }\n }\n\n return newObject;\n}\n\nvar seal = Object.seal || function (x) {\n return x;\n};\n\nvar MUSTACHE_EXPR = seal(/\\{\\{[\\s\\S]*|[\\s\\S]*\\}\\}/gm); // Specify template detection regex for SAFE_FOR_TEMPLATES mode\nvar ERB_EXPR = seal(/<%[\\s\\S]*|[\\s\\S]*%>/gm);\nvar DATA_ATTR = seal(/^data-[\\-\\w.\\u00B7-\\uFFFF]/); // eslint-disable-line no-useless-escape\nvar ARIA_ATTR = seal(/^aria-[\\-\\w]+$/); // eslint-disable-line no-useless-escape\nvar IS_ALLOWED_URI = seal(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp):|[^a-z]|[a-z+.\\-]+(?:[^a-z+.\\-:]|$))/i // eslint-disable-line no-useless-escape\n);\nvar IS_SCRIPT_OR_DATA = seal(/^(?:\\w+script|data):/i);\nvar ATTR_WHITESPACE = seal(/[\\u0000-\\u0020\\u00A0\\u1680\\u180E\\u2000-\\u2029\\u205f\\u3000]/g // eslint-disable-line no-control-regex\n);\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar _ref = typeof Reflect !== 'undefined' && Reflect;\nvar apply = _ref.apply;\n\nvar arraySlice = Array.prototype.slice;\nvar freeze = Object.freeze;\n\nvar getGlobal = function getGlobal() {\n return typeof window === 'undefined' ? null : window;\n};\n\nif (!apply) {\n apply = function apply(fun, thisValue, args) {\n return fun.apply(thisValue, args);\n };\n}\n\n/**\n * Creates a no-op policy for internal use only.\n * Don't export this function outside this module!\n * @param {?TrustedTypePolicyFactory} trustedTypes The policy factory.\n * @param {Document} document The document object (to determine policy name suffix)\n * @return {?TrustedTypePolicy} The policy created (or null, if Trusted Types\n * are not supported).\n */\nvar _createTrustedTypesPolicy = function _createTrustedTypesPolicy(trustedTypes, document) {\n if ((typeof trustedTypes === 'undefined' ? 'undefined' : _typeof(trustedTypes)) !== 'object' || typeof trustedTypes.createPolicy !== 'function') {\n return null;\n }\n\n // Allow the callers to control the unique policy name\n // by adding a data-tt-policy-suffix to the script element with the DOMPurify.\n // Policy creation with duplicate names throws in Trusted Types.\n var suffix = null;\n var ATTR_NAME = 'data-tt-policy-suffix';\n if (document.currentScript && document.currentScript.hasAttribute(ATTR_NAME)) {\n suffix = document.currentScript.getAttribute(ATTR_NAME);\n }\n\n var policyName = 'dompurify' + (suffix ? '#' + suffix : '');\n\n try {\n return trustedTypes.createPolicy(policyName, {\n createHTML: function createHTML(html$$1) {\n return html$$1;\n }\n });\n } catch (error) {\n // Policy creation failed (most likely another DOMPurify script has\n // already run). Skip creating the policy, as this will only cause errors\n // if TT are enforced.\n console.warn('TrustedTypes policy ' + policyName + ' could not be created.');\n return null;\n }\n};\n\nfunction createDOMPurify() {\n var window = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getGlobal();\n\n var DOMPurify = function DOMPurify(root) {\n return createDOMPurify(root);\n };\n\n /**\n * Version label, exposed for easier checks\n * if DOMPurify is up to date or not\n */\n DOMPurify.version = '1.0.10';\n\n /**\n * Array of elements that DOMPurify removed during sanitation.\n * Empty if nothing was removed.\n */\n DOMPurify.removed = [];\n\n if (!window || !window.document || window.document.nodeType !== 9) {\n // Not running in a browser, provide a factory function\n // so that you can pass your own Window\n DOMPurify.isSupported = false;\n\n return DOMPurify;\n }\n\n var originalDocument = window.document;\n var useDOMParser = false;\n var removeTitle = false;\n\n var document = window.document;\n var DocumentFragment = window.DocumentFragment,\n HTMLTemplateElement = window.HTMLTemplateElement,\n Node = window.Node,\n NodeFilter = window.NodeFilter,\n _window$NamedNodeMap = window.NamedNodeMap,\n NamedNodeMap = _window$NamedNodeMap === undefined ? window.NamedNodeMap || window.MozNamedAttrMap : _window$NamedNodeMap,\n Text = window.Text,\n Comment = window.Comment,\n DOMParser = window.DOMParser,\n TrustedTypes = window.TrustedTypes;\n\n // As per issue #47, the web-components registry is inherited by a\n // new document created via createHTMLDocument. As per the spec\n // (http://w3c.github.io/webcomponents/spec/custom/#creating-and-passing-registries)\n // a new empty registry is used when creating a template contents owner\n // document, so we use that as our parent document to ensure nothing\n // is inherited.\n\n if (typeof HTMLTemplateElement === 'function') {\n var template = document.createElement('template');\n if (template.content && template.content.ownerDocument) {\n document = template.content.ownerDocument;\n }\n }\n\n var trustedTypesPolicy = _createTrustedTypesPolicy(TrustedTypes, originalDocument);\n var emptyHTML = trustedTypesPolicy ? trustedTypesPolicy.createHTML('') : '';\n\n var _document = document,\n implementation = _document.implementation,\n createNodeIterator = _document.createNodeIterator,\n getElementsByTagName = _document.getElementsByTagName,\n createDocumentFragment = _document.createDocumentFragment;\n var importNode = originalDocument.importNode;\n\n\n var hooks = {};\n\n /**\n * Expose whether this browser supports running the full DOMPurify.\n */\n DOMPurify.isSupported = implementation && typeof implementation.createHTMLDocument !== 'undefined' && document.documentMode !== 9;\n\n var MUSTACHE_EXPR$$1 = MUSTACHE_EXPR,\n ERB_EXPR$$1 = ERB_EXPR,\n DATA_ATTR$$1 = DATA_ATTR,\n ARIA_ATTR$$1 = ARIA_ATTR,\n IS_SCRIPT_OR_DATA$$1 = IS_SCRIPT_OR_DATA,\n ATTR_WHITESPACE$$1 = ATTR_WHITESPACE;\n var IS_ALLOWED_URI$$1 = IS_ALLOWED_URI;\n /**\n * We consider the elements and attributes below to be safe. Ideally\n * don't add any new ones but feel free to remove unwanted ones.\n */\n\n /* allowed element names */\n\n var ALLOWED_TAGS = null;\n var DEFAULT_ALLOWED_TAGS = addToSet({}, [].concat(_toConsumableArray(html), _toConsumableArray(svg), _toConsumableArray(svgFilters), _toConsumableArray(mathMl), _toConsumableArray(text)));\n\n /* Allowed attribute names */\n var ALLOWED_ATTR = null;\n var DEFAULT_ALLOWED_ATTR = addToSet({}, [].concat(_toConsumableArray(html$1), _toConsumableArray(svg$1), _toConsumableArray(mathMl$1), _toConsumableArray(xml)));\n\n /* Explicitly forbidden tags (overrides ALLOWED_TAGS/ADD_TAGS) */\n var FORBID_TAGS = null;\n\n /* Explicitly forbidden attributes (overrides ALLOWED_ATTR/ADD_ATTR) */\n var FORBID_ATTR = null;\n\n /* Decide if ARIA attributes are okay */\n var ALLOW_ARIA_ATTR = true;\n\n /* Decide if custom data attributes are okay */\n var ALLOW_DATA_ATTR = true;\n\n /* Decide if unknown protocols are okay */\n var ALLOW_UNKNOWN_PROTOCOLS = false;\n\n /* Output should be safe for jQuery's $() factory? */\n var SAFE_FOR_JQUERY = false;\n\n /* Output should be safe for common template engines.\n * This means, DOMPurify removes data attributes, mustaches and ERB\n */\n var SAFE_FOR_TEMPLATES = false;\n\n /* Decide if document with <html>... should be returned */\n var WHOLE_DOCUMENT = false;\n\n /* Track whether config is already set on this instance of DOMPurify. */\n var SET_CONFIG = false;\n\n /* Decide if all elements (e.g. style, script) must be children of\n * document.body. By default, browsers might move them to document.head */\n var FORCE_BODY = false;\n\n /* Decide if a DOM `HTMLBodyElement` should be returned, instead of a html\n * string (or a TrustedHTML object if Trusted Types are supported).\n * If `WHOLE_DOCUMENT` is enabled a `HTMLHtmlElement` will be returned instead\n */\n var RETURN_DOM = false;\n\n /* Decide if a DOM `DocumentFragment` should be returned, instead of a html\n * string (or a TrustedHTML object if Trusted Types are supported) */\n var RETURN_DOM_FRAGMENT = false;\n\n /* If `RETURN_DOM` or `RETURN_DOM_FRAGMENT` is enabled, decide if the returned DOM\n * `Node` is imported into the current `Document`. If this flag is not enabled the\n * `Node` will belong (its ownerDocument) to a fresh `HTMLDocument`, created by\n * DOMPurify. */\n var RETURN_DOM_IMPORT = false;\n\n /* Output should be free from DOM clobbering attacks? */\n var SANITIZE_DOM = true;\n\n /* Keep element content when removing element? */\n var KEEP_CONTENT = true;\n\n /* If a `Node` is passed to sanitize(), then performs sanitization in-place instead\n * of importing it into a new Document and returning a sanitized copy */\n var IN_PLACE = false;\n\n /* Allow usage of profiles like html, svg and mathMl */\n var USE_PROFILES = {};\n\n /* Tags to ignore content of when KEEP_CONTENT is true */\n var FORBID_CONTENTS = addToSet({}, ['audio', 'head', 'math', 'script', 'style', 'template', 'svg', 'video']);\n\n /* Tags that are safe for data: URIs */\n var DATA_URI_TAGS = addToSet({}, ['audio', 'video', 'img', 'source', 'image']);\n\n /* Attributes safe for values like \"javascript:\" */\n var URI_SAFE_ATTRIBUTES = addToSet({}, ['alt', 'class', 'for', 'id', 'label', 'name', 'pattern', 'placeholder', 'summary', 'title', 'value', 'style', 'xmlns']);\n\n /* Keep a reference to config to pass to hooks */\n var CONFIG = null;\n\n /* Ideally, do not touch anything below this line */\n /* ______________________________________________ */\n\n var formElement = document.createElement('form');\n\n /**\n * _parseConfig\n *\n * @param {Object} cfg optional config literal\n */\n // eslint-disable-next-line complexity\n var _parseConfig = function _parseConfig(cfg) {\n if (CONFIG && CONFIG === cfg) {\n return;\n }\n\n /* Shield configuration object from tampering */\n if (!cfg || (typeof cfg === 'undefined' ? 'undefined' : _typeof(cfg)) !== 'object') {\n cfg = {};\n }\n\n /* Set configuration parameters */\n ALLOWED_TAGS = 'ALLOWED_TAGS' in cfg ? addToSet({}, cfg.ALLOWED_TAGS) : DEFAULT_ALLOWED_TAGS;\n ALLOWED_ATTR = 'ALLOWED_ATTR' in cfg ? addToSet({}, cfg.ALLOWED_ATTR) : DEFAULT_ALLOWED_ATTR;\n FORBID_TAGS = 'FORBID_TAGS' in cfg ? addToSet({}, cfg.FORBID_TAGS) : {};\n FORBID_ATTR = 'FORBID_ATTR' in cfg ? addToSet({}, cfg.FORBID_ATTR) : {};\n USE_PROFILES = 'USE_PROFILES' in cfg ? cfg.USE_PROFILES : false;\n ALLOW_ARIA_ATTR = cfg.ALLOW_ARIA_ATTR !== false; // Default true\n ALLOW_DATA_ATTR = cfg.ALLOW_DATA_ATTR !== false; // Default true\n ALLOW_UNKNOWN_PROTOCOLS = cfg.ALLOW_UNKNOWN_PROTOCOLS || false; // Default false\n SAFE_FOR_JQUERY = cfg.SAFE_FOR_JQUERY || false; // Default false\n SAFE_FOR_TEMPLATES = cfg.SAFE_FOR_TEMPLATES || false; // Default false\n WHOLE_DOCUMENT = cfg.WHOLE_DOCUMENT || false; // Default false\n RETURN_DOM = cfg.RETURN_DOM || false; // Default false\n RETURN_DOM_FRAGMENT = cfg.RETURN_DOM_FRAGMENT || false; // Default false\n RETURN_DOM_IMPORT = cfg.RETURN_DOM_IMPORT || false; // Default false\n FORCE_BODY = cfg.FORCE_BODY || false; // Default false\n SANITIZE_DOM = cfg.SANITIZE_DOM !== false; // Default true\n KEEP_CONTENT = cfg.KEEP_CONTENT !== false; // Default true\n IN_PLACE = cfg.IN_PLACE || false; // Default false\n\n IS_ALLOWED_URI$$1 = cfg.ALLOWED_URI_REGEXP || IS_ALLOWED_URI$$1;\n\n if (SAFE_FOR_TEMPLATES) {\n ALLOW_DATA_ATTR = false;\n }\n\n if (RETURN_DOM_FRAGMENT) {\n RETURN_DOM = true;\n }\n\n /* Parse profile info */\n if (USE_PROFILES) {\n ALLOWED_TAGS = addToSet({}, [].concat(_toConsumableArray(text)));\n ALLOWED_ATTR = [];\n if (USE_PROFILES.html === true) {\n addToSet(ALLOWED_TAGS, html);\n addToSet(ALLOWED_ATTR, html$1);\n }\n\n if (USE_PROFILES.svg === true) {\n addToSet(ALLOWED_TAGS, svg);\n addToSet(ALLOWED_ATTR, svg$1);\n addToSet(ALLOWED_ATTR, xml);\n }\n\n if (USE_PROFILES.svgFilters === true) {\n addToSet(ALLOWED_TAGS, svgFilters);\n addToSet(ALLOWED_ATTR, svg$1);\n addToSet(ALLOWED_ATTR, xml);\n }\n\n if (USE_PROFILES.mathMl === true) {\n addToSet(ALLOWED_TAGS, mathMl);\n addToSet(ALLOWED_ATTR, mathMl$1);\n addToSet(ALLOWED_ATTR, xml);\n }\n }\n\n /* Merge configuration parameters */\n if (cfg.ADD_TAGS) {\n if (ALLOWED_TAGS === DEFAULT_ALLOWED_TAGS) {\n ALLOWED_TAGS = clone(ALLOWED_TAGS);\n }\n\n addToSet(ALLOWED_TAGS, cfg.ADD_TAGS);\n }\n\n if (cfg.ADD_ATTR) {\n if (ALLOWED_ATTR === DEFAULT_ALLOWED_ATTR) {\n ALLOWED_ATTR = clone(ALLOWED_ATTR);\n }\n\n addToSet(ALLOWED_ATTR, cfg.ADD_ATTR);\n }\n\n if (cfg.ADD_URI_SAFE_ATTR) {\n addToSet(URI_SAFE_ATTRIBUTES, cfg.ADD_URI_SAFE_ATTR);\n }\n\n /* Add #text in case KEEP_CONTENT is set to true */\n if (KEEP_CONTENT) {\n ALLOWED_TAGS['#text'] = true;\n }\n\n /* Add html, head and body to ALLOWED_TAGS in case WHOLE_DOCUMENT is true */\n if (WHOLE_DOCUMENT) {\n addToSet(ALLOWED_TAGS, ['html', 'head', 'body']);\n }\n\n /* Add tbody to ALLOWED_TAGS in case tables are permitted, see #286 */\n if (ALLOWED_TAGS.table) {\n addToSet(ALLOWED_TAGS, ['tbody']);\n }\n\n // Prevent further manipulation of configuration.\n // Not available in IE8, Safari 5, etc.\n if (freeze) {\n freeze(cfg);\n }\n\n CONFIG = cfg;\n };\n\n /**\n * _forceRemove\n *\n * @param {Node} node a DOM node\n */\n var _forceRemove = function _forceRemove(node) {\n DOMPurify.removed.push({ element: node });\n try {\n node.parentNode.removeChild(node);\n } catch (error) {\n node.outerHTML = emptyHTML;\n }\n };\n\n /**\n * _removeAttribute\n *\n * @param {String} name an Attribute name\n * @param {Node} node a DOM node\n */\n var _removeAttribute = function _removeAttribute(name, node) {\n try {\n DOMPurify.removed.push({\n attribute: node.getAttributeNode(name),\n from: node\n });\n } catch (error) {\n DOMPurify.removed.push({\n attribute: null,\n from: node\n });\n }\n\n node.removeAttribute(name);\n };\n\n /**\n * _initDocument\n *\n * @param {String} dirty a string of dirty markup\n * @return {Document} a DOM, filled with the dirty markup\n */\n var _initDocument = function _initDocument(dirty) {\n /* Create a HTML document */\n var doc = void 0;\n var leadingWhitespace = void 0;\n\n if (FORCE_BODY) {\n dirty = '<remove></remove>' + dirty;\n } else {\n /* If FORCE_BODY isn't used, leading whitespace needs to be preserved manually */\n var matches = dirty.match(/^[\\s]+/);\n leadingWhitespace = matches && matches[0];\n if (leadingWhitespace) {\n dirty = dirty.slice(leadingWhitespace.length);\n }\n }\n\n /* Use DOMParser to workaround Firefox bug (see comment below) */\n if (useDOMParser) {\n try {\n doc = new DOMParser().parseFromString(dirty, 'text/html');\n } catch (error) {}\n }\n\n /* Remove title to fix a mXSS bug in older MS Edge */\n if (removeTitle) {\n addToSet(FORBID_TAGS, ['title']);\n }\n\n /* Otherwise use createHTMLDocument, because DOMParser is unsafe in\n Safari (see comment below) */\n if (!doc || !doc.documentElement) {\n doc = implementation.createHTMLDocument('');\n var _doc = doc,\n body = _doc.body;\n\n body.parentNode.removeChild(body.parentNode.firstElementChild);\n body.outerHTML = trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty;\n }\n\n if (leadingWhitespace) {\n doc.body.insertBefore(document.createTextNode(leadingWhitespace), doc.body.childNodes[0] || null);\n }\n\n /* Work on whole document or just its body */\n return getElementsByTagName.call(doc, WHOLE_DOCUMENT ? 'html' : 'body')[0];\n };\n\n // Firefox uses a different parser for innerHTML rather than\n // DOMParser (see https://bugzilla.mozilla.org/show_bug.cgi?id=1205631)\n // which means that you *must* use DOMParser, otherwise the output may\n // not be safe if used in a document.write context later.\n //\n // So we feature detect the Firefox bug and use the DOMParser if necessary.\n //\n // MS Edge, in older versions, is affected by an mXSS behavior. The second\n // check tests for the behavior and fixes it if necessary.\n if (DOMPurify.isSupported) {\n (function () {\n try {\n var doc = _initDocument('<svg><p><style><img src=\"</style><img src=x onerror=1//\">');\n if (doc.querySelector('svg img')) {\n useDOMParser = true;\n }\n } catch (error) {}\n })();\n\n (function () {\n try {\n var doc = _initDocument('<x/><title></title><img>');\n if (doc.querySelector('title').innerHTML.match(/<\\/title/)) {\n removeTitle = true;\n }\n } catch (error) {}\n })();\n }\n\n /**\n * _createIterator\n *\n * @param {Document} root document/fragment to create iterator for\n * @return {Iterator} iterator instance\n */\n var _createIterator = function _createIterator(root) {\n return createNodeIterator.call(root.ownerDocument || root, root, NodeFilter.SHOW_ELEMENT | NodeFilter.SHOW_COMMENT | NodeFilter.SHOW_TEXT, function () {\n return NodeFilter.FILTER_ACCEPT;\n }, false);\n };\n\n /**\n * _isClobbered\n *\n * @param {Node} elm element to check for clobbering attacks\n * @return {Boolean} true if clobbered, false if safe\n */\n var _isClobbered = function _isClobbered(elm) {\n if (elm instanceof Text || elm instanceof Comment) {\n return false;\n }\n\n if (typeof elm.nodeName !== 'string' || typeof elm.textContent !== 'string' || typeof elm.removeChild !== 'function' || !(elm.attributes instanceof NamedNodeMap) || typeof elm.removeAttribute !== 'function' || typeof elm.setAttribute !== 'function') {\n return true;\n }\n\n return false;\n };\n\n /**\n * _isNode\n *\n * @param {Node} obj object to check whether it's a DOM node\n * @return {Boolean} true is object is a DOM node\n */\n var _isNode = function _isNode(obj) {\n return (typeof Node === 'undefined' ? 'undefined' : _typeof(Node)) === 'object' ? obj instanceof Node : obj && (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object' && typeof obj.nodeType === 'number' && typeof obj.nodeName === 'string';\n };\n\n /**\n * _executeHook\n * Execute user configurable hooks\n *\n * @param {String} entryPoint Name of the hook's entry point\n * @param {Node} currentNode node to work on with the hook\n * @param {Object} data additional hook parameters\n */\n var _executeHook = function _executeHook(entryPoint, currentNode, data) {\n if (!hooks[entryPoint]) {\n return;\n }\n\n hooks[entryPoint].forEach(function (hook) {\n hook.call(DOMPurify, currentNode, data, CONFIG);\n });\n };\n\n /**\n * _sanitizeElements\n *\n * @protect nodeName\n * @protect textContent\n * @protect removeChild\n *\n * @param {Node} currentNode to check for permission to exist\n * @return {Boolean} true if node was killed, false if left alive\n */\n // eslint-disable-next-line complexity\n var _sanitizeElements = function _sanitizeElements(currentNode) {\n var content = void 0;\n\n /* Execute a hook if present */\n _executeHook('beforeSanitizeElements', currentNode, null);\n\n /* Check if element is clobbered or can clobber */\n if (_isClobbered(currentNode)) {\n _forceRemove(currentNode);\n return true;\n }\n\n /* Now let's check the element's type and name */\n var tagName = currentNode.nodeName.toLowerCase();\n\n /* Execute a hook if present */\n _executeHook('uponSanitizeElement', currentNode, {\n tagName: tagName,\n allowedTags: ALLOWED_TAGS\n });\n\n /* Remove element if anything forbids its presence */\n if (!ALLOWED_TAGS[tagName] || FORBID_TAGS[tagName]) {\n /* Keep content except for black-listed elements */\n if (KEEP_CONTENT && !FORBID_CONTENTS[tagName] && typeof currentNode.insertAdjacentHTML === 'function') {\n try {\n var htmlToInsert = currentNode.innerHTML;\n currentNode.insertAdjacentHTML('AfterEnd', trustedTypesPolicy ? trustedTypesPolicy.createHTML(htmlToInsert) : htmlToInsert);\n } catch (error) {}\n }\n\n _forceRemove(currentNode);\n return true;\n }\n\n /* Remove in case a noscript/noembed XSS is suspected */\n if (tagName === 'noscript' && currentNode.innerHTML.match(/<\\/noscript/i)) {\n _forceRemove(currentNode);\n return true;\n }\n\n if (tagName === 'noembed' && currentNode.innerHTML.match(/<\\/noembed/i)) {\n _forceRemove(currentNode);\n return true;\n }\n\n /* Convert markup to cover jQuery behavior */\n if (SAFE_FOR_JQUERY && !currentNode.firstElementChild && (!currentNode.content || !currentNode.content.firstElementChild) && /</g.test(currentNode.textContent)) {\n DOMPurify.removed.push({ element: currentNode.cloneNode() });\n if (currentNode.innerHTML) {\n currentNode.innerHTML = currentNode.innerHTML.replace(/</g, '<');\n } else {\n currentNode.innerHTML = currentNode.textContent.replace(/</g, '<');\n }\n }\n\n /* Sanitize element content to be template-safe */\n if (SAFE_FOR_TEMPLATES && currentNode.nodeType === 3) {\n /* Get the element's text content */\n content = currentNode.textContent;\n content = content.replace(MUSTACHE_EXPR$$1, ' ');\n content = content.replace(ERB_EXPR$$1, ' ');\n if (currentNode.textContent !== content) {\n DOMPurify.removed.push({ element: currentNode.cloneNode() });\n currentNode.textContent = content;\n }\n }\n\n /* Execute a hook if present */\n _executeHook('afterSanitizeElements', currentNode, null);\n\n return false;\n };\n\n /**\n * _isValidAttribute\n *\n * @param {string} lcTag Lowercase tag name of containing element.\n * @param {string} lcName Lowercase attribute name.\n * @param {string} value Attribute value.\n * @return {Boolean} Returns true if `value` is valid, otherwise false.\n */\n // eslint-disable-next-line complexity\n var _isValidAttribute = function _isValidAttribute(lcTag, lcName, value) {\n /* Make sure attribute cannot clobber */\n if (SANITIZE_DOM && (lcName === 'id' || lcName === 'name') && (value in document || value in formElement)) {\n return false;\n }\n\n /* Allow valid data-* attributes: At least one character after \"-\"\n (https://html.spec.whatwg.org/multipage/dom.html#embedding-custom-non-visible-data-with-the-data-*-attributes)\n XML-compatible (https://html.spec.whatwg.org/multipage/infrastructure.html#xml-compatible and http://www.w3.org/TR/xml/#d0e804)\n We don't need to check the value; it's always URI safe. */\n if (ALLOW_DATA_ATTR && DATA_ATTR$$1.test(lcName)) {\n // This attribute is safe\n } else if (ALLOW_ARIA_ATTR && ARIA_ATTR$$1.test(lcName)) {\n // This attribute is safe\n /* Otherwise, check the name is permitted */\n } else if (!ALLOWED_ATTR[lcName] || FORBID_ATTR[lcName]) {\n return false;\n\n /* Check value is safe. First, is attr inert? If so, is safe */\n } else if (URI_SAFE_ATTRIBUTES[lcName]) {\n // This attribute is safe\n /* Check no script, data or unknown possibly unsafe URI\n unless we know URI values are safe for that attribute */\n } else if (IS_ALLOWED_URI$$1.test(value.replace(ATTR_WHITESPACE$$1, ''))) {\n // This attribute is safe\n /* Keep image data URIs alive if src/xlink:href is allowed */\n /* Further prevent gadget XSS for dynamically built script tags */\n } else if ((lcName === 'src' || lcName === 'xlink:href') && lcTag !== 'script' && value.indexOf('data:') === 0 && DATA_URI_TAGS[lcTag]) {\n // This attribute is safe\n /* Allow unknown protocols: This provides support for links that\n are handled by protocol handlers which may be unknown ahead of\n time, e.g. fb:, spotify: */\n } else if (ALLOW_UNKNOWN_PROTOCOLS && !IS_SCRIPT_OR_DATA$$1.test(value.replace(ATTR_WHITESPACE$$1, ''))) {\n // This attribute is safe\n /* Check for binary attributes */\n // eslint-disable-next-line no-negated-condition\n } else if (!value) {\n // Binary attributes are safe at this point\n /* Anything else, presume unsafe, do not add it back */\n } else {\n return false;\n }\n\n return true;\n };\n\n /**\n * _sanitizeAttributes\n *\n * @protect attributes\n * @protect nodeName\n * @protect removeAttribute\n * @protect setAttribute\n *\n * @param {Node} currentNode to sanitize\n */\n var _sanitizeAttributes = function _sanitizeAttributes(currentNode) {\n var attr = void 0;\n var value = void 0;\n var lcName = void 0;\n var idAttr = void 0;\n var l = void 0;\n /* Execute a hook if present */\n _executeHook('beforeSanitizeAttributes', currentNode, null);\n\n var attributes = currentNode.attributes;\n\n /* Check if we have attributes; if not we might have a text node */\n\n if (!attributes) {\n return;\n }\n\n var hookEvent = {\n attrName: '',\n attrValue: '',\n keepAttr: true,\n allowedAttributes: ALLOWED_ATTR\n };\n l = attributes.length;\n\n /* Go backwards over all attributes; safely remove bad ones */\n while (l--) {\n attr = attributes[l];\n var _attr = attr,\n name = _attr.name,\n namespaceURI = _attr.namespaceURI;\n\n value = attr.value.trim();\n lcName = name.toLowerCase();\n\n /* Execute a hook if present */\n hookEvent.attrName = lcName;\n hookEvent.attrValue = value;\n hookEvent.keepAttr = true;\n _executeHook('uponSanitizeAttribute', currentNode, hookEvent);\n value = hookEvent.attrValue;\n\n /* Remove attribute */\n // Safari (iOS + Mac), last tested v8.0.5, crashes if you try to\n // remove a \"name\" attribute from an <img> tag that has an \"id\"\n // attribute at the time.\n if (lcName === 'name' && currentNode.nodeName === 'IMG' && attributes.id) {\n idAttr = attributes.id;\n attributes = apply(arraySlice, attributes, []);\n _removeAttribute('id', currentNode);\n _removeAttribute(name, currentNode);\n if (attributes.indexOf(idAttr) > l) {\n currentNode.setAttribute('id', idAttr.value);\n }\n } else if (\n // This works around a bug in Safari, where input[type=file]\n // cannot be dynamically set after type has been removed\n currentNode.nodeName === 'INPUT' && lcName === 'type' && value === 'file' && (ALLOWED_ATTR[lcName] || !FORBID_ATTR[lcName])) {\n continue;\n } else {\n // This avoids a crash in Safari v9.0 with double-ids.\n // The trick is to first set the id to be empty and then to\n // remove the attribute\n if (name === 'id') {\n currentNode.setAttribute(name, '');\n }\n\n _removeAttribute(name, currentNode);\n }\n\n /* Did the hooks approve of the attribute? */\n if (!hookEvent.keepAttr) {\n continue;\n }\n\n /* Sanitize attribute content to be template-safe */\n if (SAFE_FOR_TEMPLATES) {\n value = value.replace(MUSTACHE_EXPR$$1, ' ');\n value = value.replace(ERB_EXPR$$1, ' ');\n }\n\n /* Is `value` valid for this attribute? */\n var lcTag = currentNode.nodeName.toLowerCase();\n if (!_isValidAttribute(lcTag, lcName, value)) {\n continue;\n }\n\n /* Handle invalid data-* attribute set by try-catching it */\n try {\n if (namespaceURI) {\n currentNode.setAttributeNS(namespaceURI, name, value);\n } else {\n /* Fallback to setAttribute() for browser-unrecognized namespaces e.g. \"x-schema\". */\n currentNode.setAttribute(name, value);\n }\n\n DOMPurify.removed.pop();\n } catch (error) {}\n }\n\n /* Execute a hook if present */\n _executeHook('afterSanitizeAttributes', currentNode, null);\n };\n\n /**\n * _sanitizeShadowDOM\n *\n * @param {DocumentFragment} fragment to iterate over recursively\n */\n var _sanitizeShadowDOM = function _sanitizeShadowDOM(fragment) {\n var shadowNode = void 0;\n var shadowIterator = _createIterator(fragment);\n\n /* Execute a hook if present */\n _executeHook('beforeSanitizeShadowDOM', fragment, null);\n\n while (shadowNode = shadowIterator.nextNode()) {\n /* Execute a hook if present */\n _executeHook('uponSanitizeShadowNode', shadowNode, null);\n\n /* Sanitize tags and elements */\n if (_sanitizeElements(shadowNode)) {\n continue;\n }\n\n /* Deep shadow DOM detected */\n if (shadowNode.content instanceof DocumentFragment) {\n _sanitizeShadowDOM(shadowNode.content);\n }\n\n /* Check attributes, sanitize if necessary */\n _sanitizeAttributes(shadowNode);\n }\n\n /* Execute a hook if present */\n _executeHook('afterSanitizeShadowDOM', fragment, null);\n };\n\n /**\n * Sanitize\n * Public method providing core sanitation functionality\n *\n * @param {String|Node} dirty string or DOM node\n * @param {Object} configuration object\n */\n // eslint-disable-next-line complexity\n DOMPurify.sanitize = function (dirty, cfg) {\n var body = void 0;\n var importedNode = void 0;\n var currentNode = void 0;\n var oldNode = void 0;\n var returnNode = void 0;\n /* Make sure we have a string to sanitize.\n DO NOT return early, as this will return the wrong type if\n the user has requested a DOM object rather than a string */\n if (!dirty) {\n dirty = '<!-->';\n }\n\n /* Stringify, in case dirty is an object */\n if (typeof dirty !== 'string' && !_isNode(dirty)) {\n // eslint-disable-next-line no-negated-condition\n if (typeof dirty.toString !== 'function') {\n throw new TypeError('toString is not a function');\n } else {\n dirty = dirty.toString();\n if (typeof dirty !== 'string') {\n throw new TypeError('dirty is not a string, aborting');\n }\n }\n }\n\n /* Check we can run. Otherwise fall back or ignore */\n if (!DOMPurify.isSupported) {\n if (_typeof(window.toStaticHTML) === 'object' || typeof window.toStaticHTML === 'function') {\n if (typeof dirty === 'string') {\n return window.toStaticHTML(dirty);\n }\n\n if (_isNode(dirty)) {\n return window.toStaticHTML(dirty.outerHTML);\n }\n }\n\n return dirty;\n }\n\n /* Assign config vars */\n if (!SET_CONFIG) {\n _parseConfig(cfg);\n }\n\n /* Clean up removed elements */\n DOMPurify.removed = [];\n\n if (IN_PLACE) {\n /* No special handling necessary for in-place sanitization */\n } else if (dirty instanceof Node) {\n /* If dirty is a DOM element, append to an empty document to avoid\n elements being stripped by the parser */\n body = _initDocument('<!-->');\n importedNode = body.ownerDocument.importNode(dirty, true);\n if (importedNode.nodeType === 1 && importedNode.nodeName === 'BODY') {\n /* Node is already a body, use as is */\n body = importedNode;\n } else {\n // eslint-disable-next-line unicorn/prefer-node-append\n body.appendChild(importedNode);\n }\n } else {\n /* Exit directly if we have nothing to do */\n if (!RETURN_DOM && !SAFE_FOR_TEMPLATES && !WHOLE_DOCUMENT && dirty.indexOf('<') === -1) {\n return trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty;\n }\n\n /* Initialize the document to work on */\n body = _initDocument(dirty);\n\n /* Check we have a DOM node from the data */\n if (!body) {\n return RETURN_DOM ? null : emptyHTML;\n }\n }\n\n /* Remove first element node (ours) if FORCE_BODY is set */\n if (body && FORCE_BODY) {\n _forceRemove(body.firstChild);\n }\n\n /* Get node iterator */\n var nodeIterator = _createIterator(IN_PLACE ? dirty : body);\n\n /* Now start iterating over the created document */\n while (currentNode = nodeIterator.nextNode()) {\n /* Fix IE's strange behavior with manipulated textNodes #89 */\n if (currentNode.nodeType === 3 && currentNode === oldNode) {\n continue;\n }\n\n /* Sanitize tags and elements */\n if (_sanitizeElements(currentNode)) {\n continue;\n }\n\n /* Shadow DOM detected, sanitize it */\n if (currentNode.content instanceof DocumentFragment) {\n _sanitizeShadowDOM(currentNode.content);\n }\n\n /* Check attributes, sanitize if necessary */\n _sanitizeAttributes(currentNode);\n\n oldNode = currentNode;\n }\n\n oldNode = null;\n\n /* If we sanitized `dirty` in-place, return it. */\n if (IN_PLACE) {\n return dirty;\n }\n\n /* Return sanitized string or DOM */\n if (RETURN_DOM) {\n if (RETURN_DOM_FRAGMENT) {\n returnNode = createDocumentFragment.call(body.ownerDocument);\n\n while (body.firstChild) {\n // eslint-disable-next-line unicorn/prefer-node-append\n returnNode.appendChild(body.firstChild);\n }\n } else {\n returnNode = body;\n }\n\n if (RETURN_DOM_IMPORT) {\n /* AdoptNode() is not used because internal state is not reset\n (e.g. the past names map of a HTMLFormElement), this is safe\n in theory but we would rather not risk another attack vector.\n The state that is cloned by importNode() is explicitly defined\n by the specs. */\n returnNode = importNode.call(originalDocument, returnNode, true);\n }\n\n return returnNode;\n }\n\n var serializedHTML = WHOLE_DOCUMENT ? body.outerHTML : body.innerHTML;\n\n /* Sanitize final string template-safe */\n if (SAFE_FOR_TEMPLATES) {\n serializedHTML = serializedHTML.replace(MUSTACHE_EXPR$$1, ' ');\n serializedHTML = serializedHTML.replace(ERB_EXPR$$1, ' ');\n }\n\n return trustedTypesPolicy ? trustedTypesPolicy.createHTML(serializedHTML) : serializedHTML;\n };\n\n /**\n * Public method to set the configuration once\n * setConfig\n *\n * @param {Object} cfg configuration object\n */\n DOMPurify.setConfig = function (cfg) {\n _parseConfig(cfg);\n SET_CONFIG = true;\n };\n\n /**\n * Public method to remove the configuration\n * clearConfig\n *\n */\n DOMPurify.clearConfig = function () {\n CONFIG = null;\n SET_CONFIG = false;\n };\n\n /**\n * Public method to check if an attribute value is valid.\n * Uses last set config, if any. Otherwise, uses config defaults.\n * isValidAttribute\n *\n * @param {string} tag Tag name of containing element.\n * @param {string} attr Attribute name.\n * @param {string} value Attribute value.\n * @return {Boolean} Returns true if `value` is valid. Otherwise, returns false.\n */\n DOMPurify.isValidAttribute = function (tag, attr, value) {\n /* Initialize shared config vars if necessary. */\n if (!CONFIG) {\n _parseConfig({});\n }\n\n var lcTag = tag.toLowerCase();\n var lcName = attr.toLowerCase();\n return _isValidAttribute(lcTag, lcName, value);\n };\n\n /**\n * AddHook\n * Public method to add DOMPurify hooks\n *\n * @param {String} entryPoint entry point for the hook to add\n * @param {Function} hookFunction function to execute\n */\n DOMPurify.addHook = function (entryPoint, hookFunction) {\n if (typeof hookFunction !== 'function') {\n return;\n }\n\n hooks[entryPoint] = hooks[entryPoint] || [];\n hooks[entryPoint].push(hookFunction);\n };\n\n /**\n * RemoveHook\n * Public method to remove a DOMPurify hook at a given entryPoint\n * (pops it from the stack of hooks if more are present)\n *\n * @param {String} entryPoint entry point for the hook to remove\n */\n DOMPurify.removeHook = function (entryPoint) {\n if (hooks[entryPoint]) {\n hooks[entryPoint].pop();\n }\n };\n\n /**\n * RemoveHooks\n * Public method to remove all DOMPurify hooks at a given entryPoint\n *\n * @param {String} entryPoint entry point for the hooks to remove\n */\n DOMPurify.removeHooks = function (entryPoint) {\n if (hooks[entryPoint]) {\n hooks[entryPoint] = [];\n }\n };\n\n /**\n * RemoveAllHooks\n * Public method to remove all DOMPurify hooks\n *\n */\n DOMPurify.removeAllHooks = function () {\n hooks = {};\n };\n\n return DOMPurify;\n}\n\nvar purify = createDOMPurify();\n\nreturn purify;\n\n})));\n//# sourceMappingURL=purify.js.map\n"],"sourceRoot":""}
\ No newline at end of file +{"version":3,"sources":["webpack:///./node_modules/css-loader/dist/runtime/api.js","webpack:///./node_modules/style-loader/lib/addStyles.js","webpack:///./node_modules/style-loader/lib/urls.js","webpack:///./node_modules/marked/lib/marked.js","webpack:///./node_modules/dompurify/dist/purify.js"],"names":["module","exports","useSourceMap","list","toString","this","map","item","content","cssMapping","btoa","sourceMapping","sourceMap","unescape","encodeURIComponent","JSON","stringify","sourceURLs","sources","source","sourceRoot","concat","join","cssWithMappingToString","i","modules","mediaQuery","alreadyImportedModules","length","id","push","fn","memo","stylesInDom","isOldIE","window","document","all","atob","apply","arguments","getElement","target","parent","styleTarget","querySelector","call","HTMLIFrameElement","contentDocument","head","e","singleton","singletonCounter","stylesInsertedAtTop","fixUrls","__webpack_require__","addStylesToDom","styles","options","domStyle","refs","j","parts","addStyle","listToStyles","newStyles","base","part","css","media","insertStyleElement","style","insertInto","Error","lastStyleElementInsertedAtTop","insertAt","nextSibling","insertBefore","appendChild","firstChild","before","removeStyleElement","parentNode","removeChild","idx","indexOf","splice","createStyleElement","createElement","undefined","attrs","type","nonce","nc","getNonce","addAttrs","el","Object","keys","forEach","key","setAttribute","obj","update","remove","result","transform","default","styleIndex","applyToSingletonTag","bind","URL","createObjectURL","revokeObjectURL","Blob","link","rel","createLinkElement","autoFixUrls","convertToAbsoluteUrls","blob","oldSrc","href","styleSheet","cssText","createTextNode","newObj","DEBUG","newList","mayRemove","textStore","replaceText","index","replacement","filter","Boolean","cssNode","childNodes","location","baseUrl","protocol","host","currentDir","pathname","replace","fullMatch","origUrl","newUrl","unquotedOrigUrl","trim","o","$1","test","global","root","block","newline","code","fences","noop","hr","heading","nptable","blockquote","html","def","table","lheading","paragraph","text","Lexer","tokens","links","create","marked","defaults","rules","normal","pedantic","gfm","tables","_label","_title","edit","getRegex","bullet","_tag","_comment","merge","lex","src","prototype","token","top","next","loose","cap","bull","b","listStart","listItems","t","space","tag","l","isordered","istask","ischecked","exec","substring","rtrim","lang","depth","header","splitCells","align","split","cells","ordered","start","match","RegExp","smartLists","slice","charAt","task","checked","sanitize","pre","sanitizer","toLowerCase","title","charCodeAt","inline","escape","autolink","url","reflink","nolink","strong","em","br","del","InlineLexer","renderer","Renderer","breaks","TextRenderer","Parser","slugger","Slugger","seen","encode","escapeTest","escapeReplace","ch","replacements","escapeTestNoEncode","escapeReplaceNoEncode","_","n","String","fromCharCode","parseInt","regex","opt","name","val","cleanUrl","prot","decodeURIComponent","originIndependentUrl","baseUrls","resolveUrl","encodeURI","_punctuation","_escapes","_scheme","_email","_attribute","_href","_extended_email","_backpedal","output","prevCapZero","out","inLink","inRawBlock","lastParenIndex","findClosingBracket","linkLen","outputLink","escapes","codespan","mangle","smartypants","image","Math","random","infostring","escaped","highlight","langPrefix","quote","level","raw","headerIds","headerPrefix","slug","xhtml","body","listitem","checkbox","tablerow","tablecell","flags","parse","inlineText","reverse","tok","pop","peek","parseText","row","cell","errMsg","silent","console","log","value","hasOwnProperty","originalSlug","&","<",">","\"","'","tableRow","count","offset","str","curr","c","invert","suffLen","currChar","substr","callback","pending","done","err","message","setOptions","getDefaults","parser","lexer","inlineLexer","freeze$1","freeze","x","svg","svgFilters","mathMl","freeze$2","html$1","svg$1","mathMl$1","xml","setPrototypeOf","apply$1","Reflect","addToSet","set","array","element","lcElement","isFrozen","clone","object","newObject","property","fun","thisValue","args","seal","MUSTACHE_EXPR","ERB_EXPR","DATA_ATTR","ARIA_ATTR","IS_ALLOWED_URI","IS_SCRIPT_OR_DATA","ATTR_WHITESPACE","_typeof","Symbol","iterator","constructor","_toConsumableArray","arr","Array","isArray","arr2","from","arraySlice","getGlobal","_createTrustedTypesPolicy","trustedTypes","createPolicy","suffix","currentScript","hasAttribute","getAttribute","policyName","createHTML","html$$1","error","warn","createDOMPurify","DOMPurify","version","removed","nodeType","isSupported","originalDocument","useDOMParser","removeTitle","DocumentFragment","HTMLTemplateElement","Node","NodeFilter","_window$NamedNodeMap","NamedNodeMap","MozNamedAttrMap","Text","Comment","DOMParser","TrustedTypes","template","ownerDocument","trustedTypesPolicy","emptyHTML","_document","implementation","createNodeIterator","getElementsByTagName","createDocumentFragment","importNode","hooks","createHTMLDocument","documentMode","MUSTACHE_EXPR$$1","ERB_EXPR$$1","DATA_ATTR$$1","ARIA_ATTR$$1","IS_SCRIPT_OR_DATA$$1","ATTR_WHITESPACE$$1","IS_ALLOWED_URI$$1","ALLOWED_TAGS","DEFAULT_ALLOWED_TAGS","ALLOWED_ATTR","DEFAULT_ALLOWED_ATTR","FORBID_TAGS","FORBID_ATTR","ALLOW_ARIA_ATTR","ALLOW_DATA_ATTR","ALLOW_UNKNOWN_PROTOCOLS","SAFE_FOR_JQUERY","SAFE_FOR_TEMPLATES","WHOLE_DOCUMENT","SET_CONFIG","FORCE_BODY","RETURN_DOM","RETURN_DOM_FRAGMENT","RETURN_DOM_IMPORT","SANITIZE_DOM","KEEP_CONTENT","IN_PLACE","USE_PROFILES","FORBID_CONTENTS","DATA_URI_TAGS","URI_SAFE_ATTRIBUTES","DEFAULT_URI_SAFE_ATTRIBUTES","CONFIG","formElement","_parseConfig","cfg","ADD_URI_SAFE_ATTR","ALLOWED_URI_REGEXP","ADD_TAGS","ADD_ATTR","_forceRemove","node","outerHTML","_removeAttribute","attribute","getAttributeNode","removeAttribute","_initDocument","dirty","doc","leadingWhitespace","matches","parseFromString","documentElement","_doc","firstElementChild","innerHTML","_createIterator","SHOW_ELEMENT","SHOW_COMMENT","SHOW_TEXT","FILTER_ACCEPT","_isNode","nodeName","_executeHook","entryPoint","currentNode","data","hook","_sanitizeElements","elm","textContent","attributes","tagName","allowedTags","insertAdjacentHTML","htmlToInsert","cloneNode","_isValidAttribute","lcTag","lcName","_sanitizeAttributes","attr","idAttr","hookEvent","attrName","attrValue","keepAttr","allowedAttributes","_attr","namespaceURI","setAttributeNS","_sanitizeShadowDOM","fragment","shadowNode","shadowIterator","nextNode","importedNode","oldNode","returnNode","TypeError","toStaticHTML","nodeIterator","serializedHTML","setConfig","clearConfig","isValidAttribute","addHook","hookFunction","removeHook","removeHooks","removeAllHooks","factory"],"mappings":"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","file":"vue-5.js","sourcesContent":["\"use strict\";\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\n// css base code, injected by the css-loader\nmodule.exports = function (useSourceMap) {\n var list = []; // return the list of modules as css string\n\n list.toString = function toString() {\n return this.map(function (item) {\n var content = cssWithMappingToString(item, useSourceMap);\n\n if (item[2]) {\n return '@media ' + item[2] + '{' + content + '}';\n } else {\n return content;\n }\n }).join('');\n }; // import a list of modules into the list\n\n\n list.i = function (modules, mediaQuery) {\n if (typeof modules === 'string') {\n modules = [[null, modules, '']];\n }\n\n var alreadyImportedModules = {};\n\n for (var i = 0; i < this.length; i++) {\n var id = this[i][0];\n\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n\n for (i = 0; i < modules.length; i++) {\n var item = modules[i]; // skip already imported module\n // this implementation is not 100% perfect for weird media query combinations\n // when a module is imported multiple times with different media queries.\n // I hope this will never occur (Hey this way we have smaller bundles)\n\n if (item[0] == null || !alreadyImportedModules[item[0]]) {\n if (mediaQuery && !item[2]) {\n item[2] = mediaQuery;\n } else if (mediaQuery) {\n item[2] = '(' + item[2] + ') and (' + mediaQuery + ')';\n }\n\n list.push(item);\n }\n }\n };\n\n return list;\n};\n\nfunction cssWithMappingToString(item, useSourceMap) {\n var content = item[1] || '';\n var cssMapping = item[3];\n\n if (!cssMapping) {\n return content;\n }\n\n if (useSourceMap && typeof btoa === 'function') {\n var sourceMapping = toComment(cssMapping);\n var sourceURLs = cssMapping.sources.map(function (source) {\n return '/*# sourceURL=' + cssMapping.sourceRoot + source + ' */';\n });\n return [content].concat(sourceURLs).concat([sourceMapping]).join('\\n');\n }\n\n return [content].join('\\n');\n} // Adapted from convert-source-map (MIT)\n\n\nfunction toComment(sourceMap) {\n // eslint-disable-next-line no-undef\n var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));\n var data = 'sourceMappingURL=data:application/json;charset=utf-8;base64,' + base64;\n return '/*# ' + data + ' */';\n}","/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\n\nvar stylesInDom = {};\n\nvar\tmemoize = function (fn) {\n\tvar memo;\n\n\treturn function () {\n\t\tif (typeof memo === \"undefined\") memo = fn.apply(this, arguments);\n\t\treturn memo;\n\t};\n};\n\nvar isOldIE = memoize(function () {\n\t// Test for IE <= 9 as proposed by Browserhacks\n\t// @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805\n\t// Tests for existence of standard globals is to allow style-loader\n\t// to operate correctly into non-standard environments\n\t// @see https://github.com/webpack-contrib/style-loader/issues/177\n\treturn window && document && document.all && !window.atob;\n});\n\nvar getTarget = function (target, parent) {\n if (parent){\n return parent.querySelector(target);\n }\n return document.querySelector(target);\n};\n\nvar getElement = (function (fn) {\n\tvar memo = {};\n\n\treturn function(target, parent) {\n // If passing function in options, then use it for resolve \"head\" element.\n // Useful for Shadow Root style i.e\n // {\n // insertInto: function () { return document.querySelector(\"#foo\").shadowRoot }\n // }\n if (typeof target === 'function') {\n return target();\n }\n if (typeof memo[target] === \"undefined\") {\n\t\t\tvar styleTarget = getTarget.call(this, target, parent);\n\t\t\t// Special case to return head of iframe instead of iframe itself\n\t\t\tif (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n\t\t\t\ttry {\n\t\t\t\t\t// This will throw an exception if access to iframe is blocked\n\t\t\t\t\t// due to cross-origin restrictions\n\t\t\t\t\tstyleTarget = styleTarget.contentDocument.head;\n\t\t\t\t} catch(e) {\n\t\t\t\t\tstyleTarget = null;\n\t\t\t\t}\n\t\t\t}\n\t\t\tmemo[target] = styleTarget;\n\t\t}\n\t\treturn memo[target]\n\t};\n})();\n\nvar singleton = null;\nvar\tsingletonCounter = 0;\nvar\tstylesInsertedAtTop = [];\n\nvar\tfixUrls = require(\"./urls\");\n\nmodule.exports = function(list, options) {\n\tif (typeof DEBUG !== \"undefined\" && DEBUG) {\n\t\tif (typeof document !== \"object\") throw new Error(\"The style-loader cannot be used in a non-browser environment\");\n\t}\n\n\toptions = options || {};\n\n\toptions.attrs = typeof options.attrs === \"object\" ? options.attrs : {};\n\n\t// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\n\t// tags it will allow on a page\n\tif (!options.singleton && typeof options.singleton !== \"boolean\") options.singleton = isOldIE();\n\n\t// By default, add <style> tags to the <head> element\n if (!options.insertInto) options.insertInto = \"head\";\n\n\t// By default, add <style> tags to the bottom of the target\n\tif (!options.insertAt) options.insertAt = \"bottom\";\n\n\tvar styles = listToStyles(list, options);\n\n\taddStylesToDom(styles, options);\n\n\treturn function update (newList) {\n\t\tvar mayRemove = [];\n\n\t\tfor (var i = 0; i < styles.length; i++) {\n\t\t\tvar item = styles[i];\n\t\t\tvar domStyle = stylesInDom[item.id];\n\n\t\t\tdomStyle.refs--;\n\t\t\tmayRemove.push(domStyle);\n\t\t}\n\n\t\tif(newList) {\n\t\t\tvar newStyles = listToStyles(newList, options);\n\t\t\taddStylesToDom(newStyles, options);\n\t\t}\n\n\t\tfor (var i = 0; i < mayRemove.length; i++) {\n\t\t\tvar domStyle = mayRemove[i];\n\n\t\t\tif(domStyle.refs === 0) {\n\t\t\t\tfor (var j = 0; j < domStyle.parts.length; j++) domStyle.parts[j]();\n\n\t\t\t\tdelete stylesInDom[domStyle.id];\n\t\t\t}\n\t\t}\n\t};\n};\n\nfunction addStylesToDom (styles, options) {\n\tfor (var i = 0; i < styles.length; i++) {\n\t\tvar item = styles[i];\n\t\tvar domStyle = stylesInDom[item.id];\n\n\t\tif(domStyle) {\n\t\t\tdomStyle.refs++;\n\n\t\t\tfor(var j = 0; j < domStyle.parts.length; j++) {\n\t\t\t\tdomStyle.parts[j](item.parts[j]);\n\t\t\t}\n\n\t\t\tfor(; j < item.parts.length; j++) {\n\t\t\t\tdomStyle.parts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\t\t} else {\n\t\t\tvar parts = [];\n\n\t\t\tfor(var j = 0; j < item.parts.length; j++) {\n\t\t\t\tparts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\n\t\t\tstylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};\n\t\t}\n\t}\n}\n\nfunction listToStyles (list, options) {\n\tvar styles = [];\n\tvar newStyles = {};\n\n\tfor (var i = 0; i < list.length; i++) {\n\t\tvar item = list[i];\n\t\tvar id = options.base ? item[0] + options.base : item[0];\n\t\tvar css = item[1];\n\t\tvar media = item[2];\n\t\tvar sourceMap = item[3];\n\t\tvar part = {css: css, media: media, sourceMap: sourceMap};\n\n\t\tif(!newStyles[id]) styles.push(newStyles[id] = {id: id, parts: [part]});\n\t\telse newStyles[id].parts.push(part);\n\t}\n\n\treturn styles;\n}\n\nfunction insertStyleElement (options, style) {\n\tvar target = getElement(options.insertInto)\n\n\tif (!target) {\n\t\tthrow new Error(\"Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid.\");\n\t}\n\n\tvar lastStyleElementInsertedAtTop = stylesInsertedAtTop[stylesInsertedAtTop.length - 1];\n\n\tif (options.insertAt === \"top\") {\n\t\tif (!lastStyleElementInsertedAtTop) {\n\t\t\ttarget.insertBefore(style, target.firstChild);\n\t\t} else if (lastStyleElementInsertedAtTop.nextSibling) {\n\t\t\ttarget.insertBefore(style, lastStyleElementInsertedAtTop.nextSibling);\n\t\t} else {\n\t\t\ttarget.appendChild(style);\n\t\t}\n\t\tstylesInsertedAtTop.push(style);\n\t} else if (options.insertAt === \"bottom\") {\n\t\ttarget.appendChild(style);\n\t} else if (typeof options.insertAt === \"object\" && options.insertAt.before) {\n\t\tvar nextSibling = getElement(options.insertAt.before, target);\n\t\ttarget.insertBefore(style, nextSibling);\n\t} else {\n\t\tthrow new Error(\"[Style Loader]\\n\\n Invalid value for parameter 'insertAt' ('options.insertAt') found.\\n Must be 'top', 'bottom', or Object.\\n (https://github.com/webpack-contrib/style-loader#insertat)\\n\");\n\t}\n}\n\nfunction removeStyleElement (style) {\n\tif (style.parentNode === null) return false;\n\tstyle.parentNode.removeChild(style);\n\n\tvar idx = stylesInsertedAtTop.indexOf(style);\n\tif(idx >= 0) {\n\t\tstylesInsertedAtTop.splice(idx, 1);\n\t}\n}\n\nfunction createStyleElement (options) {\n\tvar style = document.createElement(\"style\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\n\tif(options.attrs.nonce === undefined) {\n\t\tvar nonce = getNonce();\n\t\tif (nonce) {\n\t\t\toptions.attrs.nonce = nonce;\n\t\t}\n\t}\n\n\taddAttrs(style, options.attrs);\n\tinsertStyleElement(options, style);\n\n\treturn style;\n}\n\nfunction createLinkElement (options) {\n\tvar link = document.createElement(\"link\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\toptions.attrs.rel = \"stylesheet\";\n\n\taddAttrs(link, options.attrs);\n\tinsertStyleElement(options, link);\n\n\treturn link;\n}\n\nfunction addAttrs (el, attrs) {\n\tObject.keys(attrs).forEach(function (key) {\n\t\tel.setAttribute(key, attrs[key]);\n\t});\n}\n\nfunction getNonce() {\n\tif (typeof __webpack_nonce__ === 'undefined') {\n\t\treturn null;\n\t}\n\n\treturn __webpack_nonce__;\n}\n\nfunction addStyle (obj, options) {\n\tvar style, update, remove, result;\n\n\t// If a transform function was defined, run it on the css\n\tif (options.transform && obj.css) {\n\t result = typeof options.transform === 'function'\n\t\t ? options.transform(obj.css) \n\t\t : options.transform.default(obj.css);\n\n\t if (result) {\n\t \t// If transform returns a value, use that instead of the original css.\n\t \t// This allows running runtime transformations on the css.\n\t \tobj.css = result;\n\t } else {\n\t \t// If the transform function returns a falsy value, don't add this css.\n\t \t// This allows conditional loading of css\n\t \treturn function() {\n\t \t\t// noop\n\t \t};\n\t }\n\t}\n\n\tif (options.singleton) {\n\t\tvar styleIndex = singletonCounter++;\n\n\t\tstyle = singleton || (singleton = createStyleElement(options));\n\n\t\tupdate = applyToSingletonTag.bind(null, style, styleIndex, false);\n\t\tremove = applyToSingletonTag.bind(null, style, styleIndex, true);\n\n\t} else if (\n\t\tobj.sourceMap &&\n\t\ttypeof URL === \"function\" &&\n\t\ttypeof URL.createObjectURL === \"function\" &&\n\t\ttypeof URL.revokeObjectURL === \"function\" &&\n\t\ttypeof Blob === \"function\" &&\n\t\ttypeof btoa === \"function\"\n\t) {\n\t\tstyle = createLinkElement(options);\n\t\tupdate = updateLink.bind(null, style, options);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\n\t\t\tif(style.href) URL.revokeObjectURL(style.href);\n\t\t};\n\t} else {\n\t\tstyle = createStyleElement(options);\n\t\tupdate = applyToTag.bind(null, style);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\t\t};\n\t}\n\n\tupdate(obj);\n\n\treturn function updateStyle (newObj) {\n\t\tif (newObj) {\n\t\t\tif (\n\t\t\t\tnewObj.css === obj.css &&\n\t\t\t\tnewObj.media === obj.media &&\n\t\t\t\tnewObj.sourceMap === obj.sourceMap\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tupdate(obj = newObj);\n\t\t} else {\n\t\t\tremove();\n\t\t}\n\t};\n}\n\nvar replaceText = (function () {\n\tvar textStore = [];\n\n\treturn function (index, replacement) {\n\t\ttextStore[index] = replacement;\n\n\t\treturn textStore.filter(Boolean).join('\\n');\n\t};\n})();\n\nfunction applyToSingletonTag (style, index, remove, obj) {\n\tvar css = remove ? \"\" : obj.css;\n\n\tif (style.styleSheet) {\n\t\tstyle.styleSheet.cssText = replaceText(index, css);\n\t} else {\n\t\tvar cssNode = document.createTextNode(css);\n\t\tvar childNodes = style.childNodes;\n\n\t\tif (childNodes[index]) style.removeChild(childNodes[index]);\n\n\t\tif (childNodes.length) {\n\t\t\tstyle.insertBefore(cssNode, childNodes[index]);\n\t\t} else {\n\t\t\tstyle.appendChild(cssNode);\n\t\t}\n\t}\n}\n\nfunction applyToTag (style, obj) {\n\tvar css = obj.css;\n\tvar media = obj.media;\n\n\tif(media) {\n\t\tstyle.setAttribute(\"media\", media)\n\t}\n\n\tif(style.styleSheet) {\n\t\tstyle.styleSheet.cssText = css;\n\t} else {\n\t\twhile(style.firstChild) {\n\t\t\tstyle.removeChild(style.firstChild);\n\t\t}\n\n\t\tstyle.appendChild(document.createTextNode(css));\n\t}\n}\n\nfunction updateLink (link, options, obj) {\n\tvar css = obj.css;\n\tvar sourceMap = obj.sourceMap;\n\n\t/*\n\t\tIf convertToAbsoluteUrls isn't defined, but sourcemaps are enabled\n\t\tand there is no publicPath defined then lets turn convertToAbsoluteUrls\n\t\ton by default. Otherwise default to the convertToAbsoluteUrls option\n\t\tdirectly\n\t*/\n\tvar autoFixUrls = options.convertToAbsoluteUrls === undefined && sourceMap;\n\n\tif (options.convertToAbsoluteUrls || autoFixUrls) {\n\t\tcss = fixUrls(css);\n\t}\n\n\tif (sourceMap) {\n\t\t// http://stackoverflow.com/a/26603875\n\t\tcss += \"\\n/*# sourceMappingURL=data:application/json;base64,\" + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + \" */\";\n\t}\n\n\tvar blob = new Blob([css], { type: \"text/css\" });\n\n\tvar oldSrc = link.href;\n\n\tlink.href = URL.createObjectURL(blob);\n\n\tif(oldSrc) URL.revokeObjectURL(oldSrc);\n}\n","\n/**\n * When source maps are enabled, `style-loader` uses a link element with a data-uri to\n * embed the css on the page. This breaks all relative urls because now they are relative to a\n * bundle instead of the current page.\n *\n * One solution is to only use full urls, but that may be impossible.\n *\n * Instead, this function \"fixes\" the relative urls to be absolute according to the current page location.\n *\n * A rudimentary test suite is located at `test/fixUrls.js` and can be run via the `npm test` command.\n *\n */\n\nmodule.exports = function (css) {\n // get current location\n var location = typeof window !== \"undefined\" && window.location;\n\n if (!location) {\n throw new Error(\"fixUrls requires window.location\");\n }\n\n\t// blank or null?\n\tif (!css || typeof css !== \"string\") {\n\t return css;\n }\n\n var baseUrl = location.protocol + \"//\" + location.host;\n var currentDir = baseUrl + location.pathname.replace(/\\/[^\\/]*$/, \"/\");\n\n\t// convert each url(...)\n\t/*\n\tThis regular expression is just a way to recursively match brackets within\n\ta string.\n\n\t /url\\s*\\( = Match on the word \"url\" with any whitespace after it and then a parens\n\t ( = Start a capturing group\n\t (?: = Start a non-capturing group\n\t [^)(] = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t (?: = Start another non-capturing groups\n\t [^)(]+ = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t [^)(]* = Match anything that isn't a parentheses\n\t \\) = Match a end parentheses\n\t ) = End Group\n *\\) = Match anything and then a close parens\n ) = Close non-capturing group\n * = Match anything\n ) = Close capturing group\n\t \\) = Match a close parens\n\n\t /gi = Get all matches, not the first. Be case insensitive.\n\t */\n\tvar fixedCss = css.replace(/url\\s*\\(((?:[^)(]|\\((?:[^)(]+|\\([^)(]*\\))*\\))*)\\)/gi, function(fullMatch, origUrl) {\n\t\t// strip quotes (if they exist)\n\t\tvar unquotedOrigUrl = origUrl\n\t\t\t.trim()\n\t\t\t.replace(/^\"(.*)\"$/, function(o, $1){ return $1; })\n\t\t\t.replace(/^'(.*)'$/, function(o, $1){ return $1; });\n\n\t\t// already a full url? no change\n\t\tif (/^(#|data:|http:\\/\\/|https:\\/\\/|file:\\/\\/\\/|\\s*$)/i.test(unquotedOrigUrl)) {\n\t\t return fullMatch;\n\t\t}\n\n\t\t// convert the url to a full url\n\t\tvar newUrl;\n\n\t\tif (unquotedOrigUrl.indexOf(\"//\") === 0) {\n\t\t \t//TODO: should we add protocol?\n\t\t\tnewUrl = unquotedOrigUrl;\n\t\t} else if (unquotedOrigUrl.indexOf(\"/\") === 0) {\n\t\t\t// path should be relative to the base url\n\t\t\tnewUrl = baseUrl + unquotedOrigUrl; // already starts with '/'\n\t\t} else {\n\t\t\t// path should be relative to current directory\n\t\t\tnewUrl = currentDir + unquotedOrigUrl.replace(/^\\.\\//, \"\"); // Strip leading './'\n\t\t}\n\n\t\t// send back the fixed url(...)\n\t\treturn \"url(\" + JSON.stringify(newUrl) + \")\";\n\t});\n\n\t// send back the fixed css\n\treturn fixedCss;\n};\n","/**\n * marked - a markdown parser\n * Copyright (c) 2011-2018, Christopher Jeffrey. (MIT Licensed)\n * https://github.com/markedjs/marked\n */\n\n;(function(root) {\n'use strict';\n\n/**\n * Block-Level Grammar\n */\n\nvar block = {\n newline: /^\\n+/,\n code: /^( {4}[^\\n]+\\n*)+/,\n fences: noop,\n hr: /^ {0,3}((?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$)/,\n heading: /^ *(#{1,6}) *([^\\n]+?) *(?:#+ *)?(?:\\n+|$)/,\n nptable: noop,\n blockquote: /^( {0,3}> ?(paragraph|[^\\n]*)(?:\\n|$))+/,\n list: /^( {0,3})(bull) [\\s\\S]+?(?:hr|def|\\n{2,}(?! )(?!\\1bull )\\n*|\\s*$)/,\n html: '^ {0,3}(?:' // optional indentation\n + '<(script|pre|style)[\\\\s>][\\\\s\\\\S]*?(?:</\\\\1>[^\\\\n]*\\\\n+|$)' // (1)\n + '|comment[^\\\\n]*(\\\\n+|$)' // (2)\n + '|<\\\\?[\\\\s\\\\S]*?\\\\?>\\\\n*' // (3)\n + '|<![A-Z][\\\\s\\\\S]*?>\\\\n*' // (4)\n + '|<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?\\\\]\\\\]>\\\\n*' // (5)\n + '|</?(tag)(?: +|\\\\n|/?>)[\\\\s\\\\S]*?(?:\\\\n{2,}|$)' // (6)\n + '|<(?!script|pre|style)([a-z][\\\\w-]*)(?:attribute)*? */?>(?=[ \\\\t]*(?:\\\\n|$))[\\\\s\\\\S]*?(?:\\\\n{2,}|$)' // (7) open tag\n + '|</(?!script|pre|style)[a-z][\\\\w-]*\\\\s*>(?=[ \\\\t]*(?:\\\\n|$))[\\\\s\\\\S]*?(?:\\\\n{2,}|$)' // (7) closing tag\n + ')',\n def: /^ {0,3}\\[(label)\\]: *\\n? *<?([^\\s>]+)>?(?:(?: +\\n? *| *\\n *)(title))? *(?:\\n+|$)/,\n table: noop,\n lheading: /^([^\\n]+)\\n *(=|-){2,} *(?:\\n+|$)/,\n paragraph: /^([^\\n]+(?:\\n(?!hr|heading|lheading| {0,3}>|<\\/?(?:tag)(?: +|\\n|\\/?>)|<(?:script|pre|style|!--))[^\\n]+)*)/,\n text: /^[^\\n]+/\n};\n\nblock._label = /(?!\\s*\\])(?:\\\\[\\[\\]]|[^\\[\\]])+/;\nblock._title = /(?:\"(?:\\\\\"?|[^\"\\\\])*\"|'[^'\\n]*(?:\\n[^'\\n]+)*\\n?'|\\([^()]*\\))/;\nblock.def = edit(block.def)\n .replace('label', block._label)\n .replace('title', block._title)\n .getRegex();\n\nblock.bullet = /(?:[*+-]|\\d{1,9}\\.)/;\nblock.item = /^( *)(bull) ?[^\\n]*(?:\\n(?!\\1bull ?)[^\\n]*)*/;\nblock.item = edit(block.item, 'gm')\n .replace(/bull/g, block.bullet)\n .getRegex();\n\nblock.list = edit(block.list)\n .replace(/bull/g, block.bullet)\n .replace('hr', '\\\\n+(?=\\\\1?(?:(?:- *){3,}|(?:_ *){3,}|(?:\\\\* *){3,})(?:\\\\n+|$))')\n .replace('def', '\\\\n+(?=' + block.def.source + ')')\n .getRegex();\n\nblock._tag = 'address|article|aside|base|basefont|blockquote|body|caption'\n + '|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption'\n + '|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe'\n + '|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option'\n + '|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr'\n + '|track|ul';\nblock._comment = /<!--(?!-?>)[\\s\\S]*?-->/;\nblock.html = edit(block.html, 'i')\n .replace('comment', block._comment)\n .replace('tag', block._tag)\n .replace('attribute', / +[a-zA-Z:_][\\w.:-]*(?: *= *\"[^\"\\n]*\"| *= *'[^'\\n]*'| *= *[^\\s\"'=<>`]+)?/)\n .getRegex();\n\nblock.paragraph = edit(block.paragraph)\n .replace('hr', block.hr)\n .replace('heading', block.heading)\n .replace('lheading', block.lheading)\n .replace('tag', block._tag) // pars can be interrupted by type (6) html blocks\n .getRegex();\n\nblock.blockquote = edit(block.blockquote)\n .replace('paragraph', block.paragraph)\n .getRegex();\n\n/**\n * Normal Block Grammar\n */\n\nblock.normal = merge({}, block);\n\n/**\n * GFM Block Grammar\n */\n\nblock.gfm = merge({}, block.normal, {\n fences: /^ {0,3}(`{3,}|~{3,})([^`\\n]*)\\n(?:|([\\s\\S]*?)\\n)(?: {0,3}\\1[~`]* *(?:\\n+|$)|$)/,\n paragraph: /^/,\n heading: /^ *(#{1,6}) +([^\\n]+?) *#* *(?:\\n+|$)/\n});\n\nblock.gfm.paragraph = edit(block.paragraph)\n .replace('(?!', '(?!'\n + block.gfm.fences.source.replace('\\\\1', '\\\\2') + '|'\n + block.list.source.replace('\\\\1', '\\\\3') + '|')\n .getRegex();\n\n/**\n * GFM + Tables Block Grammar\n */\n\nblock.tables = merge({}, block.gfm, {\n nptable: /^ *([^|\\n ].*\\|.*)\\n *([-:]+ *\\|[-| :]*)(?:\\n((?:.*[^>\\n ].*(?:\\n|$))*)\\n*|$)/,\n table: /^ *\\|(.+)\\n *\\|?( *[-:]+[-| :]*)(?:\\n((?: *[^>\\n ].*(?:\\n|$))*)\\n*|$)/\n});\n\n/**\n * Pedantic grammar\n */\n\nblock.pedantic = merge({}, block.normal, {\n html: edit(\n '^ *(?:comment *(?:\\\\n|\\\\s*$)'\n + '|<(tag)[\\\\s\\\\S]+?</\\\\1> *(?:\\\\n{2,}|\\\\s*$)' // closed tag\n + '|<tag(?:\"[^\"]*\"|\\'[^\\']*\\'|\\\\s[^\\'\"/>\\\\s]*)*?/?> *(?:\\\\n{2,}|\\\\s*$))')\n .replace('comment', block._comment)\n .replace(/tag/g, '(?!(?:'\n + 'a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub'\n + '|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)'\n + '\\\\b)\\\\w+(?!:|[^\\\\w\\\\s@]*@)\\\\b')\n .getRegex(),\n def: /^ *\\[([^\\]]+)\\]: *<?([^\\s>]+)>?(?: +([\"(][^\\n]+[\")]))? *(?:\\n+|$)/\n});\n\n/**\n * Block Lexer\n */\n\nfunction Lexer(options) {\n this.tokens = [];\n this.tokens.links = Object.create(null);\n this.options = options || marked.defaults;\n this.rules = block.normal;\n\n if (this.options.pedantic) {\n this.rules = block.pedantic;\n } else if (this.options.gfm) {\n if (this.options.tables) {\n this.rules = block.tables;\n } else {\n this.rules = block.gfm;\n }\n }\n}\n\n/**\n * Expose Block Rules\n */\n\nLexer.rules = block;\n\n/**\n * Static Lex Method\n */\n\nLexer.lex = function(src, options) {\n var lexer = new Lexer(options);\n return lexer.lex(src);\n};\n\n/**\n * Preprocessing\n */\n\nLexer.prototype.lex = function(src) {\n src = src\n .replace(/\\r\\n|\\r/g, '\\n')\n .replace(/\\t/g, ' ')\n .replace(/\\u00a0/g, ' ')\n .replace(/\\u2424/g, '\\n');\n\n return this.token(src, true);\n};\n\n/**\n * Lexing\n */\n\nLexer.prototype.token = function(src, top) {\n src = src.replace(/^ +$/gm, '');\n var next,\n loose,\n cap,\n bull,\n b,\n item,\n listStart,\n listItems,\n t,\n space,\n i,\n tag,\n l,\n isordered,\n istask,\n ischecked;\n\n while (src) {\n // newline\n if (cap = this.rules.newline.exec(src)) {\n src = src.substring(cap[0].length);\n if (cap[0].length > 1) {\n this.tokens.push({\n type: 'space'\n });\n }\n }\n\n // code\n if (cap = this.rules.code.exec(src)) {\n src = src.substring(cap[0].length);\n cap = cap[0].replace(/^ {4}/gm, '');\n this.tokens.push({\n type: 'code',\n text: !this.options.pedantic\n ? rtrim(cap, '\\n')\n : cap\n });\n continue;\n }\n\n // fences (gfm)\n if (cap = this.rules.fences.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'code',\n lang: cap[2] ? cap[2].trim() : cap[2],\n text: cap[3] || ''\n });\n continue;\n }\n\n // heading\n if (cap = this.rules.heading.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'heading',\n depth: cap[1].length,\n text: cap[2]\n });\n continue;\n }\n\n // table no leading pipe (gfm)\n if (cap = this.rules.nptable.exec(src)) {\n item = {\n type: 'table',\n header: splitCells(cap[1].replace(/^ *| *\\| *$/g, '')),\n align: cap[2].replace(/^ *|\\| *$/g, '').split(/ *\\| */),\n cells: cap[3] ? cap[3].replace(/\\n$/, '').split('\\n') : []\n };\n\n if (item.header.length === item.align.length) {\n src = src.substring(cap[0].length);\n\n for (i = 0; i < item.align.length; i++) {\n if (/^ *-+: *$/.test(item.align[i])) {\n item.align[i] = 'right';\n } else if (/^ *:-+: *$/.test(item.align[i])) {\n item.align[i] = 'center';\n } else if (/^ *:-+ *$/.test(item.align[i])) {\n item.align[i] = 'left';\n } else {\n item.align[i] = null;\n }\n }\n\n for (i = 0; i < item.cells.length; i++) {\n item.cells[i] = splitCells(item.cells[i], item.header.length);\n }\n\n this.tokens.push(item);\n\n continue;\n }\n }\n\n // hr\n if (cap = this.rules.hr.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'hr'\n });\n continue;\n }\n\n // blockquote\n if (cap = this.rules.blockquote.exec(src)) {\n src = src.substring(cap[0].length);\n\n this.tokens.push({\n type: 'blockquote_start'\n });\n\n cap = cap[0].replace(/^ *> ?/gm, '');\n\n // Pass `top` to keep the current\n // \"toplevel\" state. This is exactly\n // how markdown.pl works.\n this.token(cap, top);\n\n this.tokens.push({\n type: 'blockquote_end'\n });\n\n continue;\n }\n\n // list\n if (cap = this.rules.list.exec(src)) {\n src = src.substring(cap[0].length);\n bull = cap[2];\n isordered = bull.length > 1;\n\n listStart = {\n type: 'list_start',\n ordered: isordered,\n start: isordered ? +bull : '',\n loose: false\n };\n\n this.tokens.push(listStart);\n\n // Get each top-level item.\n cap = cap[0].match(this.rules.item);\n\n listItems = [];\n next = false;\n l = cap.length;\n i = 0;\n\n for (; i < l; i++) {\n item = cap[i];\n\n // Remove the list item's bullet\n // so it is seen as the next token.\n space = item.length;\n item = item.replace(/^ *([*+-]|\\d+\\.) */, '');\n\n // Outdent whatever the\n // list item contains. Hacky.\n if (~item.indexOf('\\n ')) {\n space -= item.length;\n item = !this.options.pedantic\n ? item.replace(new RegExp('^ {1,' + space + '}', 'gm'), '')\n : item.replace(/^ {1,4}/gm, '');\n }\n\n // Determine whether the next list item belongs here.\n // Backpedal if it does not belong in this list.\n if (i !== l - 1) {\n b = block.bullet.exec(cap[i + 1])[0];\n if (bull.length > 1 ? b.length === 1\n : (b.length > 1 || (this.options.smartLists && b !== bull))) {\n src = cap.slice(i + 1).join('\\n') + src;\n i = l - 1;\n }\n }\n\n // Determine whether item is loose or not.\n // Use: /(^|\\n)(?! )[^\\n]+\\n\\n(?!\\s*$)/\n // for discount behavior.\n loose = next || /\\n\\n(?!\\s*$)/.test(item);\n if (i !== l - 1) {\n next = item.charAt(item.length - 1) === '\\n';\n if (!loose) loose = next;\n }\n\n if (loose) {\n listStart.loose = true;\n }\n\n // Check for task list items\n istask = /^\\[[ xX]\\] /.test(item);\n ischecked = undefined;\n if (istask) {\n ischecked = item[1] !== ' ';\n item = item.replace(/^\\[[ xX]\\] +/, '');\n }\n\n t = {\n type: 'list_item_start',\n task: istask,\n checked: ischecked,\n loose: loose\n };\n\n listItems.push(t);\n this.tokens.push(t);\n\n // Recurse.\n this.token(item, false);\n\n this.tokens.push({\n type: 'list_item_end'\n });\n }\n\n if (listStart.loose) {\n l = listItems.length;\n i = 0;\n for (; i < l; i++) {\n listItems[i].loose = true;\n }\n }\n\n this.tokens.push({\n type: 'list_end'\n });\n\n continue;\n }\n\n // html\n if (cap = this.rules.html.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: this.options.sanitize\n ? 'paragraph'\n : 'html',\n pre: !this.options.sanitizer\n && (cap[1] === 'pre' || cap[1] === 'script' || cap[1] === 'style'),\n text: cap[0]\n });\n continue;\n }\n\n // def\n if (top && (cap = this.rules.def.exec(src))) {\n src = src.substring(cap[0].length);\n if (cap[3]) cap[3] = cap[3].substring(1, cap[3].length - 1);\n tag = cap[1].toLowerCase().replace(/\\s+/g, ' ');\n if (!this.tokens.links[tag]) {\n this.tokens.links[tag] = {\n href: cap[2],\n title: cap[3]\n };\n }\n continue;\n }\n\n // table (gfm)\n if (cap = this.rules.table.exec(src)) {\n item = {\n type: 'table',\n header: splitCells(cap[1].replace(/^ *| *\\| *$/g, '')),\n align: cap[2].replace(/^ *|\\| *$/g, '').split(/ *\\| */),\n cells: cap[3] ? cap[3].replace(/\\n$/, '').split('\\n') : []\n };\n\n if (item.header.length === item.align.length) {\n src = src.substring(cap[0].length);\n\n for (i = 0; i < item.align.length; i++) {\n if (/^ *-+: *$/.test(item.align[i])) {\n item.align[i] = 'right';\n } else if (/^ *:-+: *$/.test(item.align[i])) {\n item.align[i] = 'center';\n } else if (/^ *:-+ *$/.test(item.align[i])) {\n item.align[i] = 'left';\n } else {\n item.align[i] = null;\n }\n }\n\n for (i = 0; i < item.cells.length; i++) {\n item.cells[i] = splitCells(\n item.cells[i].replace(/^ *\\| *| *\\| *$/g, ''),\n item.header.length);\n }\n\n this.tokens.push(item);\n\n continue;\n }\n }\n\n // lheading\n if (cap = this.rules.lheading.exec(src)) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'heading',\n depth: cap[2] === '=' ? 1 : 2,\n text: cap[1]\n });\n continue;\n }\n\n // top-level paragraph\n if (top && (cap = this.rules.paragraph.exec(src))) {\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'paragraph',\n text: cap[1].charAt(cap[1].length - 1) === '\\n'\n ? cap[1].slice(0, -1)\n : cap[1]\n });\n continue;\n }\n\n // text\n if (cap = this.rules.text.exec(src)) {\n // Top-level should never reach here.\n src = src.substring(cap[0].length);\n this.tokens.push({\n type: 'text',\n text: cap[0]\n });\n continue;\n }\n\n if (src) {\n throw new Error('Infinite loop on byte: ' + src.charCodeAt(0));\n }\n }\n\n return this.tokens;\n};\n\n/**\n * Inline-Level Grammar\n */\n\nvar inline = {\n escape: /^\\\\([!\"#$%&'()*+,\\-./:;<=>?@\\[\\]\\\\^_`{|}~])/,\n autolink: /^<(scheme:[^\\s\\x00-\\x1f<>]*|email)>/,\n url: noop,\n tag: '^comment'\n + '|^</[a-zA-Z][\\\\w:-]*\\\\s*>' // self-closing tag\n + '|^<[a-zA-Z][\\\\w-]*(?:attribute)*?\\\\s*/?>' // open tag\n + '|^<\\\\?[\\\\s\\\\S]*?\\\\?>' // processing instruction, e.g. <?php ?>\n + '|^<![a-zA-Z]+\\\\s[\\\\s\\\\S]*?>' // declaration, e.g. <!DOCTYPE html>\n + '|^<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?\\\\]\\\\]>', // CDATA section\n link: /^!?\\[(label)\\]\\(href(?:\\s+(title))?\\s*\\)/,\n reflink: /^!?\\[(label)\\]\\[(?!\\s*\\])((?:\\\\[\\[\\]]?|[^\\[\\]\\\\])+)\\]/,\n nolink: /^!?\\[(?!\\s*\\])((?:\\[[^\\[\\]]*\\]|\\\\[\\[\\]]|[^\\[\\]])*)\\](?:\\[\\])?/,\n strong: /^__([^\\s_])__(?!_)|^\\*\\*([^\\s*])\\*\\*(?!\\*)|^__([^\\s][\\s\\S]*?[^\\s])__(?!_)|^\\*\\*([^\\s][\\s\\S]*?[^\\s])\\*\\*(?!\\*)/,\n em: /^_([^\\s_])_(?!_)|^\\*([^\\s*\"<\\[])\\*(?!\\*)|^_([^\\s][\\s\\S]*?[^\\s_])_(?!_|[^\\spunctuation])|^_([^\\s_][\\s\\S]*?[^\\s])_(?!_|[^\\spunctuation])|^\\*([^\\s\"<\\[][\\s\\S]*?[^\\s*])\\*(?!\\*)|^\\*([^\\s*\"<\\[][\\s\\S]*?[^\\s])\\*(?!\\*)/,\n code: /^(`+)([^`]|[^`][\\s\\S]*?[^`])\\1(?!`)/,\n br: /^( {2,}|\\\\)\\n(?!\\s*$)/,\n del: noop,\n text: /^(`+|[^`])(?:[\\s\\S]*?(?:(?=[\\\\<!\\[`*]|\\b_|$)|[^ ](?= {2,}\\n))|(?= {2,}\\n))/\n};\n\n// list of punctuation marks from common mark spec\n// without ` and ] to workaround Rule 17 (inline code blocks/links)\ninline._punctuation = '!\"#$%&\\'()*+,\\\\-./:;<=>?@\\\\[^_{|}~';\ninline.em = edit(inline.em).replace(/punctuation/g, inline._punctuation).getRegex();\n\ninline._escapes = /\\\\([!\"#$%&'()*+,\\-./:;<=>?@\\[\\]\\\\^_`{|}~])/g;\n\ninline._scheme = /[a-zA-Z][a-zA-Z0-9+.-]{1,31}/;\ninline._email = /[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/;\ninline.autolink = edit(inline.autolink)\n .replace('scheme', inline._scheme)\n .replace('email', inline._email)\n .getRegex();\n\ninline._attribute = /\\s+[a-zA-Z:_][\\w.:-]*(?:\\s*=\\s*\"[^\"]*\"|\\s*=\\s*'[^']*'|\\s*=\\s*[^\\s\"'=<>`]+)?/;\n\ninline.tag = edit(inline.tag)\n .replace('comment', block._comment)\n .replace('attribute', inline._attribute)\n .getRegex();\n\ninline._label = /(?:\\[[^\\[\\]]*\\]|\\\\[\\[\\]]?|`[^`]*`|`(?!`)|[^\\[\\]\\\\`])*?/;\ninline._href = /\\s*(<(?:\\\\[<>]?|[^\\s<>\\\\])*>|[^\\s\\x00-\\x1f]*)/;\ninline._title = /\"(?:\\\\\"?|[^\"\\\\])*\"|'(?:\\\\'?|[^'\\\\])*'|\\((?:\\\\\\)?|[^)\\\\])*\\)/;\n\ninline.link = edit(inline.link)\n .replace('label', inline._label)\n .replace('href', inline._href)\n .replace('title', inline._title)\n .getRegex();\n\ninline.reflink = edit(inline.reflink)\n .replace('label', inline._label)\n .getRegex();\n\n/**\n * Normal Inline Grammar\n */\n\ninline.normal = merge({}, inline);\n\n/**\n * Pedantic Inline Grammar\n */\n\ninline.pedantic = merge({}, inline.normal, {\n strong: /^__(?=\\S)([\\s\\S]*?\\S)__(?!_)|^\\*\\*(?=\\S)([\\s\\S]*?\\S)\\*\\*(?!\\*)/,\n em: /^_(?=\\S)([\\s\\S]*?\\S)_(?!_)|^\\*(?=\\S)([\\s\\S]*?\\S)\\*(?!\\*)/,\n link: edit(/^!?\\[(label)\\]\\((.*?)\\)/)\n .replace('label', inline._label)\n .getRegex(),\n reflink: edit(/^!?\\[(label)\\]\\s*\\[([^\\]]*)\\]/)\n .replace('label', inline._label)\n .getRegex()\n});\n\n/**\n * GFM Inline Grammar\n */\n\ninline.gfm = merge({}, inline.normal, {\n escape: edit(inline.escape).replace('])', '~|])').getRegex(),\n _extended_email: /[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/,\n url: /^((?:ftp|https?):\\/\\/|www\\.)(?:[a-zA-Z0-9\\-]+\\.?)+[^\\s<]*|^email/,\n _backpedal: /(?:[^?!.,:;*_~()&]+|\\([^)]*\\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_~)]+(?!$))+/,\n del: /^~+(?=\\S)([\\s\\S]*?\\S)~+/,\n text: /^(`+|[^`])(?:[\\s\\S]*?(?:(?=[\\\\<!\\[`*~]|\\b_|https?:\\/\\/|ftp:\\/\\/|www\\.|$)|[^ ](?= {2,}\\n)|[^a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-](?=[a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-]+@))|(?= {2,}\\n|[a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-]+@))/\n});\n\ninline.gfm.url = edit(inline.gfm.url, 'i')\n .replace('email', inline.gfm._extended_email)\n .getRegex();\n/**\n * GFM + Line Breaks Inline Grammar\n */\n\ninline.breaks = merge({}, inline.gfm, {\n br: edit(inline.br).replace('{2,}', '*').getRegex(),\n text: edit(inline.gfm.text).replace(/\\{2,\\}/g, '*').getRegex()\n});\n\n/**\n * Inline Lexer & Compiler\n */\n\nfunction InlineLexer(links, options) {\n this.options = options || marked.defaults;\n this.links = links;\n this.rules = inline.normal;\n this.renderer = this.options.renderer || new Renderer();\n this.renderer.options = this.options;\n\n if (!this.links) {\n throw new Error('Tokens array requires a `links` property.');\n }\n\n if (this.options.pedantic) {\n this.rules = inline.pedantic;\n } else if (this.options.gfm) {\n if (this.options.breaks) {\n this.rules = inline.breaks;\n } else {\n this.rules = inline.gfm;\n }\n }\n}\n\n/**\n * Expose Inline Rules\n */\n\nInlineLexer.rules = inline;\n\n/**\n * Static Lexing/Compiling Method\n */\n\nInlineLexer.output = function(src, links, options) {\n var inline = new InlineLexer(links, options);\n return inline.output(src);\n};\n\n/**\n * Lexing/Compiling\n */\n\nInlineLexer.prototype.output = function(src) {\n var out = '',\n link,\n text,\n href,\n title,\n cap,\n prevCapZero;\n\n while (src) {\n // escape\n if (cap = this.rules.escape.exec(src)) {\n src = src.substring(cap[0].length);\n out += escape(cap[1]);\n continue;\n }\n\n // tag\n if (cap = this.rules.tag.exec(src)) {\n if (!this.inLink && /^<a /i.test(cap[0])) {\n this.inLink = true;\n } else if (this.inLink && /^<\\/a>/i.test(cap[0])) {\n this.inLink = false;\n }\n if (!this.inRawBlock && /^<(pre|code|kbd|script)(\\s|>)/i.test(cap[0])) {\n this.inRawBlock = true;\n } else if (this.inRawBlock && /^<\\/(pre|code|kbd|script)(\\s|>)/i.test(cap[0])) {\n this.inRawBlock = false;\n }\n\n src = src.substring(cap[0].length);\n out += this.options.sanitize\n ? this.options.sanitizer\n ? this.options.sanitizer(cap[0])\n : escape(cap[0])\n : cap[0];\n continue;\n }\n\n // link\n if (cap = this.rules.link.exec(src)) {\n var lastParenIndex = findClosingBracket(cap[2], '()');\n if (lastParenIndex > -1) {\n var linkLen = cap[0].length - (cap[2].length - lastParenIndex) - (cap[3] || '').length;\n cap[2] = cap[2].substring(0, lastParenIndex);\n cap[0] = cap[0].substring(0, linkLen).trim();\n cap[3] = '';\n }\n src = src.substring(cap[0].length);\n this.inLink = true;\n href = cap[2];\n if (this.options.pedantic) {\n link = /^([^'\"]*[^\\s])\\s+(['\"])(.*)\\2/.exec(href);\n\n if (link) {\n href = link[1];\n title = link[3];\n } else {\n title = '';\n }\n } else {\n title = cap[3] ? cap[3].slice(1, -1) : '';\n }\n href = href.trim().replace(/^<([\\s\\S]*)>$/, '$1');\n out += this.outputLink(cap, {\n href: InlineLexer.escapes(href),\n title: InlineLexer.escapes(title)\n });\n this.inLink = false;\n continue;\n }\n\n // reflink, nolink\n if ((cap = this.rules.reflink.exec(src))\n || (cap = this.rules.nolink.exec(src))) {\n src = src.substring(cap[0].length);\n link = (cap[2] || cap[1]).replace(/\\s+/g, ' ');\n link = this.links[link.toLowerCase()];\n if (!link || !link.href) {\n out += cap[0].charAt(0);\n src = cap[0].substring(1) + src;\n continue;\n }\n this.inLink = true;\n out += this.outputLink(cap, link);\n this.inLink = false;\n continue;\n }\n\n // strong\n if (cap = this.rules.strong.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.strong(this.output(cap[4] || cap[3] || cap[2] || cap[1]));\n continue;\n }\n\n // em\n if (cap = this.rules.em.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.em(this.output(cap[6] || cap[5] || cap[4] || cap[3] || cap[2] || cap[1]));\n continue;\n }\n\n // code\n if (cap = this.rules.code.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.codespan(escape(cap[2].trim(), true));\n continue;\n }\n\n // br\n if (cap = this.rules.br.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.br();\n continue;\n }\n\n // del (gfm)\n if (cap = this.rules.del.exec(src)) {\n src = src.substring(cap[0].length);\n out += this.renderer.del(this.output(cap[1]));\n continue;\n }\n\n // autolink\n if (cap = this.rules.autolink.exec(src)) {\n src = src.substring(cap[0].length);\n if (cap[2] === '@') {\n text = escape(this.mangle(cap[1]));\n href = 'mailto:' + text;\n } else {\n text = escape(cap[1]);\n href = text;\n }\n out += this.renderer.link(href, null, text);\n continue;\n }\n\n // url (gfm)\n if (!this.inLink && (cap = this.rules.url.exec(src))) {\n if (cap[2] === '@') {\n text = escape(cap[0]);\n href = 'mailto:' + text;\n } else {\n // do extended autolink path validation\n do {\n prevCapZero = cap[0];\n cap[0] = this.rules._backpedal.exec(cap[0])[0];\n } while (prevCapZero !== cap[0]);\n text = escape(cap[0]);\n if (cap[1] === 'www.') {\n href = 'http://' + text;\n } else {\n href = text;\n }\n }\n src = src.substring(cap[0].length);\n out += this.renderer.link(href, null, text);\n continue;\n }\n\n // text\n if (cap = this.rules.text.exec(src)) {\n src = src.substring(cap[0].length);\n if (this.inRawBlock) {\n out += this.renderer.text(cap[0]);\n } else {\n out += this.renderer.text(escape(this.smartypants(cap[0])));\n }\n continue;\n }\n\n if (src) {\n throw new Error('Infinite loop on byte: ' + src.charCodeAt(0));\n }\n }\n\n return out;\n};\n\nInlineLexer.escapes = function(text) {\n return text ? text.replace(InlineLexer.rules._escapes, '$1') : text;\n};\n\n/**\n * Compile Link\n */\n\nInlineLexer.prototype.outputLink = function(cap, link) {\n var href = link.href,\n title = link.title ? escape(link.title) : null;\n\n return cap[0].charAt(0) !== '!'\n ? this.renderer.link(href, title, this.output(cap[1]))\n : this.renderer.image(href, title, escape(cap[1]));\n};\n\n/**\n * Smartypants Transformations\n */\n\nInlineLexer.prototype.smartypants = function(text) {\n if (!this.options.smartypants) return text;\n return text\n // em-dashes\n .replace(/---/g, '\\u2014')\n // en-dashes\n .replace(/--/g, '\\u2013')\n // opening singles\n .replace(/(^|[-\\u2014/(\\[{\"\\s])'/g, '$1\\u2018')\n // closing singles & apostrophes\n .replace(/'/g, '\\u2019')\n // opening doubles\n .replace(/(^|[-\\u2014/(\\[{\\u2018\\s])\"/g, '$1\\u201c')\n // closing doubles\n .replace(/\"/g, '\\u201d')\n // ellipses\n .replace(/\\.{3}/g, '\\u2026');\n};\n\n/**\n * Mangle Links\n */\n\nInlineLexer.prototype.mangle = function(text) {\n if (!this.options.mangle) return text;\n var out = '',\n l = text.length,\n i = 0,\n ch;\n\n for (; i < l; i++) {\n ch = text.charCodeAt(i);\n if (Math.random() > 0.5) {\n ch = 'x' + ch.toString(16);\n }\n out += '&#' + ch + ';';\n }\n\n return out;\n};\n\n/**\n * Renderer\n */\n\nfunction Renderer(options) {\n this.options = options || marked.defaults;\n}\n\nRenderer.prototype.code = function(code, infostring, escaped) {\n var lang = (infostring || '').match(/\\S*/)[0];\n if (this.options.highlight) {\n var out = this.options.highlight(code, lang);\n if (out != null && out !== code) {\n escaped = true;\n code = out;\n }\n }\n\n if (!lang) {\n return '<pre><code>'\n + (escaped ? code : escape(code, true))\n + '</code></pre>';\n }\n\n return '<pre><code class=\"'\n + this.options.langPrefix\n + escape(lang, true)\n + '\">'\n + (escaped ? code : escape(code, true))\n + '</code></pre>\\n';\n};\n\nRenderer.prototype.blockquote = function(quote) {\n return '<blockquote>\\n' + quote + '</blockquote>\\n';\n};\n\nRenderer.prototype.html = function(html) {\n return html;\n};\n\nRenderer.prototype.heading = function(text, level, raw, slugger) {\n if (this.options.headerIds) {\n return '<h'\n + level\n + ' id=\"'\n + this.options.headerPrefix\n + slugger.slug(raw)\n + '\">'\n + text\n + '</h'\n + level\n + '>\\n';\n }\n // ignore IDs\n return '<h' + level + '>' + text + '</h' + level + '>\\n';\n};\n\nRenderer.prototype.hr = function() {\n return this.options.xhtml ? '<hr/>\\n' : '<hr>\\n';\n};\n\nRenderer.prototype.list = function(body, ordered, start) {\n var type = ordered ? 'ol' : 'ul',\n startatt = (ordered && start !== 1) ? (' start=\"' + start + '\"') : '';\n return '<' + type + startatt + '>\\n' + body + '</' + type + '>\\n';\n};\n\nRenderer.prototype.listitem = function(text) {\n return '<li>' + text + '</li>\\n';\n};\n\nRenderer.prototype.checkbox = function(checked) {\n return '<input '\n + (checked ? 'checked=\"\" ' : '')\n + 'disabled=\"\" type=\"checkbox\"'\n + (this.options.xhtml ? ' /' : '')\n + '> ';\n};\n\nRenderer.prototype.paragraph = function(text) {\n return '<p>' + text + '</p>\\n';\n};\n\nRenderer.prototype.table = function(header, body) {\n if (body) body = '<tbody>' + body + '</tbody>';\n\n return '<table>\\n'\n + '<thead>\\n'\n + header\n + '</thead>\\n'\n + body\n + '</table>\\n';\n};\n\nRenderer.prototype.tablerow = function(content) {\n return '<tr>\\n' + content + '</tr>\\n';\n};\n\nRenderer.prototype.tablecell = function(content, flags) {\n var type = flags.header ? 'th' : 'td';\n var tag = flags.align\n ? '<' + type + ' align=\"' + flags.align + '\">'\n : '<' + type + '>';\n return tag + content + '</' + type + '>\\n';\n};\n\n// span level renderer\nRenderer.prototype.strong = function(text) {\n return '<strong>' + text + '</strong>';\n};\n\nRenderer.prototype.em = function(text) {\n return '<em>' + text + '</em>';\n};\n\nRenderer.prototype.codespan = function(text) {\n return '<code>' + text + '</code>';\n};\n\nRenderer.prototype.br = function() {\n return this.options.xhtml ? '<br/>' : '<br>';\n};\n\nRenderer.prototype.del = function(text) {\n return '<del>' + text + '</del>';\n};\n\nRenderer.prototype.link = function(href, title, text) {\n href = cleanUrl(this.options.sanitize, this.options.baseUrl, href);\n if (href === null) {\n return text;\n }\n var out = '<a href=\"' + escape(href) + '\"';\n if (title) {\n out += ' title=\"' + title + '\"';\n }\n out += '>' + text + '</a>';\n return out;\n};\n\nRenderer.prototype.image = function(href, title, text) {\n href = cleanUrl(this.options.sanitize, this.options.baseUrl, href);\n if (href === null) {\n return text;\n }\n\n var out = '<img src=\"' + href + '\" alt=\"' + text + '\"';\n if (title) {\n out += ' title=\"' + title + '\"';\n }\n out += this.options.xhtml ? '/>' : '>';\n return out;\n};\n\nRenderer.prototype.text = function(text) {\n return text;\n};\n\n/**\n * TextRenderer\n * returns only the textual part of the token\n */\n\nfunction TextRenderer() {}\n\n// no need for block level renderers\n\nTextRenderer.prototype.strong =\nTextRenderer.prototype.em =\nTextRenderer.prototype.codespan =\nTextRenderer.prototype.del =\nTextRenderer.prototype.text = function (text) {\n return text;\n};\n\nTextRenderer.prototype.link =\nTextRenderer.prototype.image = function(href, title, text) {\n return '' + text;\n};\n\nTextRenderer.prototype.br = function() {\n return '';\n};\n\n/**\n * Parsing & Compiling\n */\n\nfunction Parser(options) {\n this.tokens = [];\n this.token = null;\n this.options = options || marked.defaults;\n this.options.renderer = this.options.renderer || new Renderer();\n this.renderer = this.options.renderer;\n this.renderer.options = this.options;\n this.slugger = new Slugger();\n}\n\n/**\n * Static Parse Method\n */\n\nParser.parse = function(src, options) {\n var parser = new Parser(options);\n return parser.parse(src);\n};\n\n/**\n * Parse Loop\n */\n\nParser.prototype.parse = function(src) {\n this.inline = new InlineLexer(src.links, this.options);\n // use an InlineLexer with a TextRenderer to extract pure text\n this.inlineText = new InlineLexer(\n src.links,\n merge({}, this.options, {renderer: new TextRenderer()})\n );\n this.tokens = src.reverse();\n\n var out = '';\n while (this.next()) {\n out += this.tok();\n }\n\n return out;\n};\n\n/**\n * Next Token\n */\n\nParser.prototype.next = function() {\n return this.token = this.tokens.pop();\n};\n\n/**\n * Preview Next Token\n */\n\nParser.prototype.peek = function() {\n return this.tokens[this.tokens.length - 1] || 0;\n};\n\n/**\n * Parse Text Tokens\n */\n\nParser.prototype.parseText = function() {\n var body = this.token.text;\n\n while (this.peek().type === 'text') {\n body += '\\n' + this.next().text;\n }\n\n return this.inline.output(body);\n};\n\n/**\n * Parse Current Token\n */\n\nParser.prototype.tok = function() {\n switch (this.token.type) {\n case 'space': {\n return '';\n }\n case 'hr': {\n return this.renderer.hr();\n }\n case 'heading': {\n return this.renderer.heading(\n this.inline.output(this.token.text),\n this.token.depth,\n unescape(this.inlineText.output(this.token.text)),\n this.slugger);\n }\n case 'code': {\n return this.renderer.code(this.token.text,\n this.token.lang,\n this.token.escaped);\n }\n case 'table': {\n var header = '',\n body = '',\n i,\n row,\n cell,\n j;\n\n // header\n cell = '';\n for (i = 0; i < this.token.header.length; i++) {\n cell += this.renderer.tablecell(\n this.inline.output(this.token.header[i]),\n { header: true, align: this.token.align[i] }\n );\n }\n header += this.renderer.tablerow(cell);\n\n for (i = 0; i < this.token.cells.length; i++) {\n row = this.token.cells[i];\n\n cell = '';\n for (j = 0; j < row.length; j++) {\n cell += this.renderer.tablecell(\n this.inline.output(row[j]),\n { header: false, align: this.token.align[j] }\n );\n }\n\n body += this.renderer.tablerow(cell);\n }\n return this.renderer.table(header, body);\n }\n case 'blockquote_start': {\n body = '';\n\n while (this.next().type !== 'blockquote_end') {\n body += this.tok();\n }\n\n return this.renderer.blockquote(body);\n }\n case 'list_start': {\n body = '';\n var ordered = this.token.ordered,\n start = this.token.start;\n\n while (this.next().type !== 'list_end') {\n body += this.tok();\n }\n\n return this.renderer.list(body, ordered, start);\n }\n case 'list_item_start': {\n body = '';\n var loose = this.token.loose;\n var checked = this.token.checked;\n var task = this.token.task;\n\n if (this.token.task) {\n body += this.renderer.checkbox(checked);\n }\n\n while (this.next().type !== 'list_item_end') {\n body += !loose && this.token.type === 'text'\n ? this.parseText()\n : this.tok();\n }\n return this.renderer.listitem(body, task, checked);\n }\n case 'html': {\n // TODO parse inline content if parameter markdown=1\n return this.renderer.html(this.token.text);\n }\n case 'paragraph': {\n return this.renderer.paragraph(this.inline.output(this.token.text));\n }\n case 'text': {\n return this.renderer.paragraph(this.parseText());\n }\n default: {\n var errMsg = 'Token with \"' + this.token.type + '\" type was not found.';\n if (this.options.silent) {\n console.log(errMsg);\n } else {\n throw new Error(errMsg);\n }\n }\n }\n};\n\n/**\n * Slugger generates header id\n */\n\nfunction Slugger () {\n this.seen = {};\n}\n\n/**\n * Convert string to unique id\n */\n\nSlugger.prototype.slug = function (value) {\n var slug = value\n .toLowerCase()\n .trim()\n .replace(/[\\u2000-\\u206F\\u2E00-\\u2E7F\\\\'!\"#$%&()*+,./:;<=>?@[\\]^`{|}~]/g, '')\n .replace(/\\s/g, '-');\n\n if (this.seen.hasOwnProperty(slug)) {\n var originalSlug = slug;\n do {\n this.seen[originalSlug]++;\n slug = originalSlug + '-' + this.seen[originalSlug];\n } while (this.seen.hasOwnProperty(slug));\n }\n this.seen[slug] = 0;\n\n return slug;\n};\n\n/**\n * Helpers\n */\n\nfunction escape(html, encode) {\n if (encode) {\n if (escape.escapeTest.test(html)) {\n return html.replace(escape.escapeReplace, function (ch) { return escape.replacements[ch]; });\n }\n } else {\n if (escape.escapeTestNoEncode.test(html)) {\n return html.replace(escape.escapeReplaceNoEncode, function (ch) { return escape.replacements[ch]; });\n }\n }\n\n return html;\n}\n\nescape.escapeTest = /[&<>\"']/;\nescape.escapeReplace = /[&<>\"']/g;\nescape.replacements = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n};\n\nescape.escapeTestNoEncode = /[<>\"']|&(?!#?\\w+;)/;\nescape.escapeReplaceNoEncode = /[<>\"']|&(?!#?\\w+;)/g;\n\nfunction unescape(html) {\n // explicitly match decimal, hex, and named HTML entities\n return html.replace(/&(#(?:\\d+)|(?:#x[0-9A-Fa-f]+)|(?:\\w+));?/ig, function(_, n) {\n n = n.toLowerCase();\n if (n === 'colon') return ':';\n if (n.charAt(0) === '#') {\n return n.charAt(1) === 'x'\n ? String.fromCharCode(parseInt(n.substring(2), 16))\n : String.fromCharCode(+n.substring(1));\n }\n return '';\n });\n}\n\nfunction edit(regex, opt) {\n regex = regex.source || regex;\n opt = opt || '';\n return {\n replace: function(name, val) {\n val = val.source || val;\n val = val.replace(/(^|[^\\[])\\^/g, '$1');\n regex = regex.replace(name, val);\n return this;\n },\n getRegex: function() {\n return new RegExp(regex, opt);\n }\n };\n}\n\nfunction cleanUrl(sanitize, base, href) {\n if (sanitize) {\n try {\n var prot = decodeURIComponent(unescape(href))\n .replace(/[^\\w:]/g, '')\n .toLowerCase();\n } catch (e) {\n return null;\n }\n if (prot.indexOf('javascript:') === 0 || prot.indexOf('vbscript:') === 0 || prot.indexOf('data:') === 0) {\n return null;\n }\n }\n if (base && !originIndependentUrl.test(href)) {\n href = resolveUrl(base, href);\n }\n try {\n href = encodeURI(href).replace(/%25/g, '%');\n } catch (e) {\n return null;\n }\n return href;\n}\n\nfunction resolveUrl(base, href) {\n if (!baseUrls[' ' + base]) {\n // we can ignore everything in base after the last slash of its path component,\n // but we might need to add _that_\n // https://tools.ietf.org/html/rfc3986#section-3\n if (/^[^:]+:\\/*[^/]*$/.test(base)) {\n baseUrls[' ' + base] = base + '/';\n } else {\n baseUrls[' ' + base] = rtrim(base, '/', true);\n }\n }\n base = baseUrls[' ' + base];\n\n if (href.slice(0, 2) === '//') {\n return base.replace(/:[\\s\\S]*/, ':') + href;\n } else if (href.charAt(0) === '/') {\n return base.replace(/(:\\/*[^/]*)[\\s\\S]*/, '$1') + href;\n } else {\n return base + href;\n }\n}\nvar baseUrls = {};\nvar originIndependentUrl = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;\n\nfunction noop() {}\nnoop.exec = noop;\n\nfunction merge(obj) {\n var i = 1,\n target,\n key;\n\n for (; i < arguments.length; i++) {\n target = arguments[i];\n for (key in target) {\n if (Object.prototype.hasOwnProperty.call(target, key)) {\n obj[key] = target[key];\n }\n }\n }\n\n return obj;\n}\n\nfunction splitCells(tableRow, count) {\n // ensure that every cell-delimiting pipe has a space\n // before it to distinguish it from an escaped pipe\n var row = tableRow.replace(/\\|/g, function (match, offset, str) {\n var escaped = false,\n curr = offset;\n while (--curr >= 0 && str[curr] === '\\\\') escaped = !escaped;\n if (escaped) {\n // odd number of slashes means | is escaped\n // so we leave it alone\n return '|';\n } else {\n // add space before unescaped |\n return ' |';\n }\n }),\n cells = row.split(/ \\|/),\n i = 0;\n\n if (cells.length > count) {\n cells.splice(count);\n } else {\n while (cells.length < count) cells.push('');\n }\n\n for (; i < cells.length; i++) {\n // leading or trailing whitespace is ignored per the gfm spec\n cells[i] = cells[i].trim().replace(/\\\\\\|/g, '|');\n }\n return cells;\n}\n\n// Remove trailing 'c's. Equivalent to str.replace(/c*$/, '').\n// /c*$/ is vulnerable to REDOS.\n// invert: Remove suffix of non-c chars instead. Default falsey.\nfunction rtrim(str, c, invert) {\n if (str.length === 0) {\n return '';\n }\n\n // Length of suffix matching the invert condition.\n var suffLen = 0;\n\n // Step left until we fail to match the invert condition.\n while (suffLen < str.length) {\n var currChar = str.charAt(str.length - suffLen - 1);\n if (currChar === c && !invert) {\n suffLen++;\n } else if (currChar !== c && invert) {\n suffLen++;\n } else {\n break;\n }\n }\n\n return str.substr(0, str.length - suffLen);\n}\n\nfunction findClosingBracket(str, b) {\n if (str.indexOf(b[1]) === -1) {\n return -1;\n }\n var level = 0;\n for (var i = 0; i < str.length; i++) {\n if (str[i] === '\\\\') {\n i++;\n } else if (str[i] === b[0]) {\n level++;\n } else if (str[i] === b[1]) {\n level--;\n if (level < 0) {\n return i;\n }\n }\n }\n return -1;\n}\n\n/**\n * Marked\n */\n\nfunction marked(src, opt, callback) {\n // throw error in case of non string input\n if (typeof src === 'undefined' || src === null) {\n throw new Error('marked(): input parameter is undefined or null');\n }\n if (typeof src !== 'string') {\n throw new Error('marked(): input parameter is of type '\n + Object.prototype.toString.call(src) + ', string expected');\n }\n\n if (callback || typeof opt === 'function') {\n if (!callback) {\n callback = opt;\n opt = null;\n }\n\n opt = merge({}, marked.defaults, opt || {});\n\n var highlight = opt.highlight,\n tokens,\n pending,\n i = 0;\n\n try {\n tokens = Lexer.lex(src, opt);\n } catch (e) {\n return callback(e);\n }\n\n pending = tokens.length;\n\n var done = function(err) {\n if (err) {\n opt.highlight = highlight;\n return callback(err);\n }\n\n var out;\n\n try {\n out = Parser.parse(tokens, opt);\n } catch (e) {\n err = e;\n }\n\n opt.highlight = highlight;\n\n return err\n ? callback(err)\n : callback(null, out);\n };\n\n if (!highlight || highlight.length < 3) {\n return done();\n }\n\n delete opt.highlight;\n\n if (!pending) return done();\n\n for (; i < tokens.length; i++) {\n (function(token) {\n if (token.type !== 'code') {\n return --pending || done();\n }\n return highlight(token.text, token.lang, function(err, code) {\n if (err) return done(err);\n if (code == null || code === token.text) {\n return --pending || done();\n }\n token.text = code;\n token.escaped = true;\n --pending || done();\n });\n })(tokens[i]);\n }\n\n return;\n }\n try {\n if (opt) opt = merge({}, marked.defaults, opt);\n return Parser.parse(Lexer.lex(src, opt), opt);\n } catch (e) {\n e.message += '\\nPlease report this to https://github.com/markedjs/marked.';\n if ((opt || marked.defaults).silent) {\n return '<p>An error occurred:</p><pre>'\n + escape(e.message + '', true)\n + '</pre>';\n }\n throw e;\n }\n}\n\n/**\n * Options\n */\n\nmarked.options =\nmarked.setOptions = function(opt) {\n merge(marked.defaults, opt);\n return marked;\n};\n\nmarked.getDefaults = function () {\n return {\n baseUrl: null,\n breaks: false,\n gfm: true,\n headerIds: true,\n headerPrefix: '',\n highlight: null,\n langPrefix: 'language-',\n mangle: true,\n pedantic: false,\n renderer: new Renderer(),\n sanitize: false,\n sanitizer: null,\n silent: false,\n smartLists: false,\n smartypants: false,\n tables: true,\n xhtml: false\n };\n};\n\nmarked.defaults = marked.getDefaults();\n\n/**\n * Expose\n */\n\nmarked.Parser = Parser;\nmarked.parser = Parser.parse;\n\nmarked.Renderer = Renderer;\nmarked.TextRenderer = TextRenderer;\n\nmarked.Lexer = Lexer;\nmarked.lexer = Lexer.lex;\n\nmarked.InlineLexer = InlineLexer;\nmarked.inlineLexer = InlineLexer.output;\n\nmarked.Slugger = Slugger;\n\nmarked.parse = marked;\n\nif (typeof module !== 'undefined' && typeof exports === 'object') {\n module.exports = marked;\n} else if (typeof define === 'function' && define.amd) {\n define(function() { return marked; });\n} else {\n root.marked = marked;\n}\n})(this || (typeof window !== 'undefined' ? window : global));\n","(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n\ttypeof define === 'function' && define.amd ? define(factory) :\n\t(global.DOMPurify = factory());\n}(this, (function () { 'use strict';\n\nvar freeze$1 = Object.freeze || function (x) {\n return x;\n};\n\nvar html = freeze$1(['a', 'abbr', 'acronym', 'address', 'area', 'article', 'aside', 'audio', 'b', 'bdi', 'bdo', 'big', 'blink', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'center', 'cite', 'code', 'col', 'colgroup', 'content', 'data', 'datalist', 'dd', 'decorator', 'del', 'details', 'dfn', 'dir', 'div', 'dl', 'dt', 'element', 'em', 'fieldset', 'figcaption', 'figure', 'font', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'img', 'input', 'ins', 'kbd', 'label', 'legend', 'li', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meter', 'nav', 'nobr', 'ol', 'optgroup', 'option', 'output', 'p', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'section', 'select', 'shadow', 'small', 'source', 'spacer', 'span', 'strike', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'template', 'textarea', 'tfoot', 'th', 'thead', 'time', 'tr', 'track', 'tt', 'u', 'ul', 'var', 'video', 'wbr']);\n\n// SVG\nvar svg = freeze$1(['svg', 'a', 'altglyph', 'altglyphdef', 'altglyphitem', 'animatecolor', 'animatemotion', 'animatetransform', 'audio', 'canvas', 'circle', 'clippath', 'defs', 'desc', 'ellipse', 'filter', 'font', 'g', 'glyph', 'glyphref', 'hkern', 'image', 'line', 'lineargradient', 'marker', 'mask', 'metadata', 'mpath', 'path', 'pattern', 'polygon', 'polyline', 'radialgradient', 'rect', 'stop', 'style', 'switch', 'symbol', 'text', 'textpath', 'title', 'tref', 'tspan', 'video', 'view', 'vkern']);\n\nvar svgFilters = freeze$1(['feBlend', 'feColorMatrix', 'feComponentTransfer', 'feComposite', 'feConvolveMatrix', 'feDiffuseLighting', 'feDisplacementMap', 'feDistantLight', 'feFlood', 'feFuncA', 'feFuncB', 'feFuncG', 'feFuncR', 'feGaussianBlur', 'feMerge', 'feMergeNode', 'feMorphology', 'feOffset', 'fePointLight', 'feSpecularLighting', 'feSpotLight', 'feTile', 'feTurbulence']);\n\nvar mathMl = freeze$1(['math', 'menclose', 'merror', 'mfenced', 'mfrac', 'mglyph', 'mi', 'mlabeledtr', 'mmultiscripts', 'mn', 'mo', 'mover', 'mpadded', 'mphantom', 'mroot', 'mrow', 'ms', 'mspace', 'msqrt', 'mstyle', 'msub', 'msup', 'msubsup', 'mtable', 'mtd', 'mtext', 'mtr', 'munder', 'munderover']);\n\nvar text = freeze$1(['#text']);\n\nvar freeze$2 = Object.freeze || function (x) {\n return x;\n};\n\nvar html$1 = freeze$2(['accept', 'action', 'align', 'alt', 'autocomplete', 'background', 'bgcolor', 'border', 'cellpadding', 'cellspacing', 'checked', 'cite', 'class', 'clear', 'color', 'cols', 'colspan', 'controls', 'coords', 'crossorigin', 'datetime', 'default', 'dir', 'disabled', 'download', 'enctype', 'face', 'for', 'headers', 'height', 'hidden', 'high', 'href', 'hreflang', 'id', 'integrity', 'ismap', 'label', 'lang', 'list', 'loop', 'low', 'max', 'maxlength', 'media', 'method', 'min', 'multiple', 'name', 'noshade', 'novalidate', 'nowrap', 'open', 'optimum', 'pattern', 'placeholder', 'poster', 'preload', 'pubdate', 'radiogroup', 'readonly', 'rel', 'required', 'rev', 'reversed', 'role', 'rows', 'rowspan', 'spellcheck', 'scope', 'selected', 'shape', 'size', 'sizes', 'span', 'srclang', 'start', 'src', 'srcset', 'step', 'style', 'summary', 'tabindex', 'title', 'type', 'usemap', 'valign', 'value', 'width', 'xmlns']);\n\nvar svg$1 = freeze$2(['accent-height', 'accumulate', 'additive', 'alignment-baseline', 'ascent', 'attributename', 'attributetype', 'azimuth', 'basefrequency', 'baseline-shift', 'begin', 'bias', 'by', 'class', 'clip', 'clip-path', 'clip-rule', 'color', 'color-interpolation', 'color-interpolation-filters', 'color-profile', 'color-rendering', 'cx', 'cy', 'd', 'dx', 'dy', 'diffuseconstant', 'direction', 'display', 'divisor', 'dur', 'edgemode', 'elevation', 'end', 'fill', 'fill-opacity', 'fill-rule', 'filter', 'filterunits', 'flood-color', 'flood-opacity', 'font-family', 'font-size', 'font-size-adjust', 'font-stretch', 'font-style', 'font-variant', 'font-weight', 'fx', 'fy', 'g1', 'g2', 'glyph-name', 'glyphref', 'gradientunits', 'gradienttransform', 'height', 'href', 'id', 'image-rendering', 'in', 'in2', 'k', 'k1', 'k2', 'k3', 'k4', 'kerning', 'keypoints', 'keysplines', 'keytimes', 'lang', 'lengthadjust', 'letter-spacing', 'kernelmatrix', 'kernelunitlength', 'lighting-color', 'local', 'marker-end', 'marker-mid', 'marker-start', 'markerheight', 'markerunits', 'markerwidth', 'maskcontentunits', 'maskunits', 'max', 'mask', 'media', 'method', 'mode', 'min', 'name', 'numoctaves', 'offset', 'operator', 'opacity', 'order', 'orient', 'orientation', 'origin', 'overflow', 'paint-order', 'path', 'pathlength', 'patterncontentunits', 'patterntransform', 'patternunits', 'points', 'preservealpha', 'preserveaspectratio', 'primitiveunits', 'r', 'rx', 'ry', 'radius', 'refx', 'refy', 'repeatcount', 'repeatdur', 'restart', 'result', 'rotate', 'scale', 'seed', 'shape-rendering', 'specularconstant', 'specularexponent', 'spreadmethod', 'stddeviation', 'stitchtiles', 'stop-color', 'stop-opacity', 'stroke-dasharray', 'stroke-dashoffset', 'stroke-linecap', 'stroke-linejoin', 'stroke-miterlimit', 'stroke-opacity', 'stroke', 'stroke-width', 'style', 'surfacescale', 'tabindex', 'targetx', 'targety', 'transform', 'text-anchor', 'text-decoration', 'text-rendering', 'textlength', 'type', 'u1', 'u2', 'unicode', 'values', 'viewbox', 'visibility', 'version', 'vert-adv-y', 'vert-origin-x', 'vert-origin-y', 'width', 'word-spacing', 'wrap', 'writing-mode', 'xchannelselector', 'ychannelselector', 'x', 'x1', 'x2', 'xmlns', 'y', 'y1', 'y2', 'z', 'zoomandpan']);\n\nvar mathMl$1 = freeze$2(['accent', 'accentunder', 'align', 'bevelled', 'close', 'columnsalign', 'columnlines', 'columnspan', 'denomalign', 'depth', 'dir', 'display', 'displaystyle', 'fence', 'frame', 'height', 'href', 'id', 'largeop', 'length', 'linethickness', 'lspace', 'lquote', 'mathbackground', 'mathcolor', 'mathsize', 'mathvariant', 'maxsize', 'minsize', 'movablelimits', 'notation', 'numalign', 'open', 'rowalign', 'rowlines', 'rowspacing', 'rowspan', 'rspace', 'rquote', 'scriptlevel', 'scriptminsize', 'scriptsizemultiplier', 'selection', 'separator', 'separators', 'stretchy', 'subscriptshift', 'supscriptshift', 'symmetric', 'voffset', 'width', 'xmlns']);\n\nvar xml = freeze$2(['xlink:href', 'xml:id', 'xlink:title', 'xml:space', 'xmlns:xlink']);\n\nvar hasOwnProperty = Object.hasOwnProperty;\nvar setPrototypeOf = Object.setPrototypeOf;\n\nvar _ref$1 = typeof Reflect !== 'undefined' && Reflect;\nvar apply$1 = _ref$1.apply;\n\nif (!apply$1) {\n apply$1 = function apply(fun, thisValue, args) {\n return fun.apply(thisValue, args);\n };\n}\n\n/* Add properties to a lookup table */\nfunction addToSet(set, array) {\n if (setPrototypeOf) {\n // Make 'in' and truthy checks like Boolean(set.constructor)\n // independent of any properties defined on Object.prototype.\n // Prevent prototype setters from intercepting set as a this value.\n setPrototypeOf(set, null);\n }\n\n var l = array.length;\n while (l--) {\n var element = array[l];\n if (typeof element === 'string') {\n var lcElement = element.toLowerCase();\n if (lcElement !== element) {\n // Config presets (e.g. tags.js, attrs.js) are immutable.\n if (!Object.isFrozen(array)) {\n array[l] = lcElement;\n }\n\n element = lcElement;\n }\n }\n\n set[element] = true;\n }\n\n return set;\n}\n\n/* Shallow clone an object */\nfunction clone(object) {\n var newObject = {};\n\n var property = void 0;\n for (property in object) {\n if (apply$1(hasOwnProperty, object, [property])) {\n newObject[property] = object[property];\n }\n }\n\n return newObject;\n}\n\nvar seal = Object.seal || function (x) {\n return x;\n};\n\nvar MUSTACHE_EXPR = seal(/\\{\\{[\\s\\S]*|[\\s\\S]*\\}\\}/gm); // Specify template detection regex for SAFE_FOR_TEMPLATES mode\nvar ERB_EXPR = seal(/<%[\\s\\S]*|[\\s\\S]*%>/gm);\nvar DATA_ATTR = seal(/^data-[\\-\\w.\\u00B7-\\uFFFF]/); // eslint-disable-line no-useless-escape\nvar ARIA_ATTR = seal(/^aria-[\\-\\w]+$/); // eslint-disable-line no-useless-escape\nvar IS_ALLOWED_URI = seal(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp):|[^a-z]|[a-z+.\\-]+(?:[^a-z+.\\-:]|$))/i // eslint-disable-line no-useless-escape\n);\nvar IS_SCRIPT_OR_DATA = seal(/^(?:\\w+script|data):/i);\nvar ATTR_WHITESPACE = seal(/[\\u0000-\\u0020\\u00A0\\u1680\\u180E\\u2000-\\u2029\\u205f\\u3000]/g // eslint-disable-line no-control-regex\n);\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar _ref = typeof Reflect !== 'undefined' && Reflect;\nvar apply = _ref.apply;\n\nvar arraySlice = Array.prototype.slice;\nvar freeze = Object.freeze;\n\nvar getGlobal = function getGlobal() {\n return typeof window === 'undefined' ? null : window;\n};\n\nif (!apply) {\n apply = function apply(fun, thisValue, args) {\n return fun.apply(thisValue, args);\n };\n}\n\n/**\n * Creates a no-op policy for internal use only.\n * Don't export this function outside this module!\n * @param {?TrustedTypePolicyFactory} trustedTypes The policy factory.\n * @param {Document} document The document object (to determine policy name suffix)\n * @return {?TrustedTypePolicy} The policy created (or null, if Trusted Types\n * are not supported).\n */\nvar _createTrustedTypesPolicy = function _createTrustedTypesPolicy(trustedTypes, document) {\n if ((typeof trustedTypes === 'undefined' ? 'undefined' : _typeof(trustedTypes)) !== 'object' || typeof trustedTypes.createPolicy !== 'function') {\n return null;\n }\n\n // Allow the callers to control the unique policy name\n // by adding a data-tt-policy-suffix to the script element with the DOMPurify.\n // Policy creation with duplicate names throws in Trusted Types.\n var suffix = null;\n var ATTR_NAME = 'data-tt-policy-suffix';\n if (document.currentScript && document.currentScript.hasAttribute(ATTR_NAME)) {\n suffix = document.currentScript.getAttribute(ATTR_NAME);\n }\n\n var policyName = 'dompurify' + (suffix ? '#' + suffix : '');\n\n try {\n return trustedTypes.createPolicy(policyName, {\n createHTML: function createHTML(html$$1) {\n return html$$1;\n }\n });\n } catch (error) {\n // Policy creation failed (most likely another DOMPurify script has\n // already run). Skip creating the policy, as this will only cause errors\n // if TT are enforced.\n console.warn('TrustedTypes policy ' + policyName + ' could not be created.');\n return null;\n }\n};\n\nfunction createDOMPurify() {\n var window = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getGlobal();\n\n var DOMPurify = function DOMPurify(root) {\n return createDOMPurify(root);\n };\n\n /**\n * Version label, exposed for easier checks\n * if DOMPurify is up to date or not\n */\n DOMPurify.version = '1.0.11';\n\n /**\n * Array of elements that DOMPurify removed during sanitation.\n * Empty if nothing was removed.\n */\n DOMPurify.removed = [];\n\n if (!window || !window.document || window.document.nodeType !== 9) {\n // Not running in a browser, provide a factory function\n // so that you can pass your own Window\n DOMPurify.isSupported = false;\n\n return DOMPurify;\n }\n\n var originalDocument = window.document;\n var useDOMParser = false;\n var removeTitle = false;\n\n var document = window.document;\n var DocumentFragment = window.DocumentFragment,\n HTMLTemplateElement = window.HTMLTemplateElement,\n Node = window.Node,\n NodeFilter = window.NodeFilter,\n _window$NamedNodeMap = window.NamedNodeMap,\n NamedNodeMap = _window$NamedNodeMap === undefined ? window.NamedNodeMap || window.MozNamedAttrMap : _window$NamedNodeMap,\n Text = window.Text,\n Comment = window.Comment,\n DOMParser = window.DOMParser,\n TrustedTypes = window.TrustedTypes;\n\n // As per issue #47, the web-components registry is inherited by a\n // new document created via createHTMLDocument. As per the spec\n // (http://w3c.github.io/webcomponents/spec/custom/#creating-and-passing-registries)\n // a new empty registry is used when creating a template contents owner\n // document, so we use that as our parent document to ensure nothing\n // is inherited.\n\n if (typeof HTMLTemplateElement === 'function') {\n var template = document.createElement('template');\n if (template.content && template.content.ownerDocument) {\n document = template.content.ownerDocument;\n }\n }\n\n var trustedTypesPolicy = _createTrustedTypesPolicy(TrustedTypes, originalDocument);\n var emptyHTML = trustedTypesPolicy ? trustedTypesPolicy.createHTML('') : '';\n\n var _document = document,\n implementation = _document.implementation,\n createNodeIterator = _document.createNodeIterator,\n getElementsByTagName = _document.getElementsByTagName,\n createDocumentFragment = _document.createDocumentFragment;\n var importNode = originalDocument.importNode;\n\n\n var hooks = {};\n\n /**\n * Expose whether this browser supports running the full DOMPurify.\n */\n DOMPurify.isSupported = implementation && typeof implementation.createHTMLDocument !== 'undefined' && document.documentMode !== 9;\n\n var MUSTACHE_EXPR$$1 = MUSTACHE_EXPR,\n ERB_EXPR$$1 = ERB_EXPR,\n DATA_ATTR$$1 = DATA_ATTR,\n ARIA_ATTR$$1 = ARIA_ATTR,\n IS_SCRIPT_OR_DATA$$1 = IS_SCRIPT_OR_DATA,\n ATTR_WHITESPACE$$1 = ATTR_WHITESPACE;\n var IS_ALLOWED_URI$$1 = IS_ALLOWED_URI;\n /**\n * We consider the elements and attributes below to be safe. Ideally\n * don't add any new ones but feel free to remove unwanted ones.\n */\n\n /* allowed element names */\n\n var ALLOWED_TAGS = null;\n var DEFAULT_ALLOWED_TAGS = addToSet({}, [].concat(_toConsumableArray(html), _toConsumableArray(svg), _toConsumableArray(svgFilters), _toConsumableArray(mathMl), _toConsumableArray(text)));\n\n /* Allowed attribute names */\n var ALLOWED_ATTR = null;\n var DEFAULT_ALLOWED_ATTR = addToSet({}, [].concat(_toConsumableArray(html$1), _toConsumableArray(svg$1), _toConsumableArray(mathMl$1), _toConsumableArray(xml)));\n\n /* Explicitly forbidden tags (overrides ALLOWED_TAGS/ADD_TAGS) */\n var FORBID_TAGS = null;\n\n /* Explicitly forbidden attributes (overrides ALLOWED_ATTR/ADD_ATTR) */\n var FORBID_ATTR = null;\n\n /* Decide if ARIA attributes are okay */\n var ALLOW_ARIA_ATTR = true;\n\n /* Decide if custom data attributes are okay */\n var ALLOW_DATA_ATTR = true;\n\n /* Decide if unknown protocols are okay */\n var ALLOW_UNKNOWN_PROTOCOLS = false;\n\n /* Output should be safe for jQuery's $() factory? */\n var SAFE_FOR_JQUERY = false;\n\n /* Output should be safe for common template engines.\n * This means, DOMPurify removes data attributes, mustaches and ERB\n */\n var SAFE_FOR_TEMPLATES = false;\n\n /* Decide if document with <html>... should be returned */\n var WHOLE_DOCUMENT = false;\n\n /* Track whether config is already set on this instance of DOMPurify. */\n var SET_CONFIG = false;\n\n /* Decide if all elements (e.g. style, script) must be children of\n * document.body. By default, browsers might move them to document.head */\n var FORCE_BODY = false;\n\n /* Decide if a DOM `HTMLBodyElement` should be returned, instead of a html\n * string (or a TrustedHTML object if Trusted Types are supported).\n * If `WHOLE_DOCUMENT` is enabled a `HTMLHtmlElement` will be returned instead\n */\n var RETURN_DOM = false;\n\n /* Decide if a DOM `DocumentFragment` should be returned, instead of a html\n * string (or a TrustedHTML object if Trusted Types are supported) */\n var RETURN_DOM_FRAGMENT = false;\n\n /* If `RETURN_DOM` or `RETURN_DOM_FRAGMENT` is enabled, decide if the returned DOM\n * `Node` is imported into the current `Document`. If this flag is not enabled the\n * `Node` will belong (its ownerDocument) to a fresh `HTMLDocument`, created by\n * DOMPurify. */\n var RETURN_DOM_IMPORT = false;\n\n /* Output should be free from DOM clobbering attacks? */\n var SANITIZE_DOM = true;\n\n /* Keep element content when removing element? */\n var KEEP_CONTENT = true;\n\n /* If a `Node` is passed to sanitize(), then performs sanitization in-place instead\n * of importing it into a new Document and returning a sanitized copy */\n var IN_PLACE = false;\n\n /* Allow usage of profiles like html, svg and mathMl */\n var USE_PROFILES = {};\n\n /* Tags to ignore content of when KEEP_CONTENT is true */\n var FORBID_CONTENTS = addToSet({}, ['audio', 'head', 'math', 'script', 'style', 'template', 'svg', 'video']);\n\n /* Tags that are safe for data: URIs */\n var DATA_URI_TAGS = addToSet({}, ['audio', 'video', 'img', 'source', 'image']);\n\n /* Attributes safe for values like \"javascript:\" */\n var URI_SAFE_ATTRIBUTES = null;\n var DEFAULT_URI_SAFE_ATTRIBUTES = addToSet({}, ['alt', 'class', 'for', 'id', 'label', 'name', 'pattern', 'placeholder', 'summary', 'title', 'value', 'style', 'xmlns']);\n\n /* Keep a reference to config to pass to hooks */\n var CONFIG = null;\n\n /* Ideally, do not touch anything below this line */\n /* ______________________________________________ */\n\n var formElement = document.createElement('form');\n\n /**\n * _parseConfig\n *\n * @param {Object} cfg optional config literal\n */\n // eslint-disable-next-line complexity\n var _parseConfig = function _parseConfig(cfg) {\n if (CONFIG && CONFIG === cfg) {\n return;\n }\n\n /* Shield configuration object from tampering */\n if (!cfg || (typeof cfg === 'undefined' ? 'undefined' : _typeof(cfg)) !== 'object') {\n cfg = {};\n }\n\n /* Set configuration parameters */\n ALLOWED_TAGS = 'ALLOWED_TAGS' in cfg ? addToSet({}, cfg.ALLOWED_TAGS) : DEFAULT_ALLOWED_TAGS;\n ALLOWED_ATTR = 'ALLOWED_ATTR' in cfg ? addToSet({}, cfg.ALLOWED_ATTR) : DEFAULT_ALLOWED_ATTR;\n URI_SAFE_ATTRIBUTES = 'ADD_URI_SAFE_ATTR' in cfg ? addToSet({}, cfg.ADD_URI_SAFE_ATTR) : DEFAULT_URI_SAFE_ATTRIBUTES;\n FORBID_TAGS = 'FORBID_TAGS' in cfg ? addToSet({}, cfg.FORBID_TAGS) : {};\n FORBID_ATTR = 'FORBID_ATTR' in cfg ? addToSet({}, cfg.FORBID_ATTR) : {};\n USE_PROFILES = 'USE_PROFILES' in cfg ? cfg.USE_PROFILES : false;\n ALLOW_ARIA_ATTR = cfg.ALLOW_ARIA_ATTR !== false; // Default true\n ALLOW_DATA_ATTR = cfg.ALLOW_DATA_ATTR !== false; // Default true\n ALLOW_UNKNOWN_PROTOCOLS = cfg.ALLOW_UNKNOWN_PROTOCOLS || false; // Default false\n SAFE_FOR_JQUERY = cfg.SAFE_FOR_JQUERY || false; // Default false\n SAFE_FOR_TEMPLATES = cfg.SAFE_FOR_TEMPLATES || false; // Default false\n WHOLE_DOCUMENT = cfg.WHOLE_DOCUMENT || false; // Default false\n RETURN_DOM = cfg.RETURN_DOM || false; // Default false\n RETURN_DOM_FRAGMENT = cfg.RETURN_DOM_FRAGMENT || false; // Default false\n RETURN_DOM_IMPORT = cfg.RETURN_DOM_IMPORT || false; // Default false\n FORCE_BODY = cfg.FORCE_BODY || false; // Default false\n SANITIZE_DOM = cfg.SANITIZE_DOM !== false; // Default true\n KEEP_CONTENT = cfg.KEEP_CONTENT !== false; // Default true\n IN_PLACE = cfg.IN_PLACE || false; // Default false\n\n IS_ALLOWED_URI$$1 = cfg.ALLOWED_URI_REGEXP || IS_ALLOWED_URI$$1;\n\n if (SAFE_FOR_TEMPLATES) {\n ALLOW_DATA_ATTR = false;\n }\n\n if (RETURN_DOM_FRAGMENT) {\n RETURN_DOM = true;\n }\n\n /* Parse profile info */\n if (USE_PROFILES) {\n ALLOWED_TAGS = addToSet({}, [].concat(_toConsumableArray(text)));\n ALLOWED_ATTR = [];\n if (USE_PROFILES.html === true) {\n addToSet(ALLOWED_TAGS, html);\n addToSet(ALLOWED_ATTR, html$1);\n }\n\n if (USE_PROFILES.svg === true) {\n addToSet(ALLOWED_TAGS, svg);\n addToSet(ALLOWED_ATTR, svg$1);\n addToSet(ALLOWED_ATTR, xml);\n }\n\n if (USE_PROFILES.svgFilters === true) {\n addToSet(ALLOWED_TAGS, svgFilters);\n addToSet(ALLOWED_ATTR, svg$1);\n addToSet(ALLOWED_ATTR, xml);\n }\n\n if (USE_PROFILES.mathMl === true) {\n addToSet(ALLOWED_TAGS, mathMl);\n addToSet(ALLOWED_ATTR, mathMl$1);\n addToSet(ALLOWED_ATTR, xml);\n }\n }\n\n /* Merge configuration parameters */\n if (cfg.ADD_TAGS) {\n if (ALLOWED_TAGS === DEFAULT_ALLOWED_TAGS) {\n ALLOWED_TAGS = clone(ALLOWED_TAGS);\n }\n\n addToSet(ALLOWED_TAGS, cfg.ADD_TAGS);\n }\n\n if (cfg.ADD_ATTR) {\n if (ALLOWED_ATTR === DEFAULT_ALLOWED_ATTR) {\n ALLOWED_ATTR = clone(ALLOWED_ATTR);\n }\n\n addToSet(ALLOWED_ATTR, cfg.ADD_ATTR);\n }\n\n if (cfg.ADD_URI_SAFE_ATTR) {\n addToSet(URI_SAFE_ATTRIBUTES, cfg.ADD_URI_SAFE_ATTR);\n }\n\n /* Add #text in case KEEP_CONTENT is set to true */\n if (KEEP_CONTENT) {\n ALLOWED_TAGS['#text'] = true;\n }\n\n /* Add html, head and body to ALLOWED_TAGS in case WHOLE_DOCUMENT is true */\n if (WHOLE_DOCUMENT) {\n addToSet(ALLOWED_TAGS, ['html', 'head', 'body']);\n }\n\n /* Add tbody to ALLOWED_TAGS in case tables are permitted, see #286 */\n if (ALLOWED_TAGS.table) {\n addToSet(ALLOWED_TAGS, ['tbody']);\n }\n\n // Prevent further manipulation of configuration.\n // Not available in IE8, Safari 5, etc.\n if (freeze) {\n freeze(cfg);\n }\n\n CONFIG = cfg;\n };\n\n /**\n * _forceRemove\n *\n * @param {Node} node a DOM node\n */\n var _forceRemove = function _forceRemove(node) {\n DOMPurify.removed.push({ element: node });\n try {\n node.parentNode.removeChild(node);\n } catch (error) {\n node.outerHTML = emptyHTML;\n }\n };\n\n /**\n * _removeAttribute\n *\n * @param {String} name an Attribute name\n * @param {Node} node a DOM node\n */\n var _removeAttribute = function _removeAttribute(name, node) {\n try {\n DOMPurify.removed.push({\n attribute: node.getAttributeNode(name),\n from: node\n });\n } catch (error) {\n DOMPurify.removed.push({\n attribute: null,\n from: node\n });\n }\n\n node.removeAttribute(name);\n };\n\n /**\n * _initDocument\n *\n * @param {String} dirty a string of dirty markup\n * @return {Document} a DOM, filled with the dirty markup\n */\n var _initDocument = function _initDocument(dirty) {\n /* Create a HTML document */\n var doc = void 0;\n var leadingWhitespace = void 0;\n\n if (FORCE_BODY) {\n dirty = '<remove></remove>' + dirty;\n } else {\n /* If FORCE_BODY isn't used, leading whitespace needs to be preserved manually */\n var matches = dirty.match(/^[\\s]+/);\n leadingWhitespace = matches && matches[0];\n if (leadingWhitespace) {\n dirty = dirty.slice(leadingWhitespace.length);\n }\n }\n\n /* Use DOMParser to workaround Firefox bug (see comment below) */\n if (useDOMParser) {\n try {\n doc = new DOMParser().parseFromString(dirty, 'text/html');\n } catch (error) {}\n }\n\n /* Remove title to fix a mXSS bug in older MS Edge */\n if (removeTitle) {\n addToSet(FORBID_TAGS, ['title']);\n }\n\n /* Otherwise use createHTMLDocument, because DOMParser is unsafe in\n Safari (see comment below) */\n if (!doc || !doc.documentElement) {\n doc = implementation.createHTMLDocument('');\n var _doc = doc,\n body = _doc.body;\n\n body.parentNode.removeChild(body.parentNode.firstElementChild);\n body.outerHTML = trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty;\n }\n\n if (leadingWhitespace) {\n doc.body.insertBefore(document.createTextNode(leadingWhitespace), doc.body.childNodes[0] || null);\n }\n\n /* Work on whole document or just its body */\n return getElementsByTagName.call(doc, WHOLE_DOCUMENT ? 'html' : 'body')[0];\n };\n\n // Firefox uses a different parser for innerHTML rather than\n // DOMParser (see https://bugzilla.mozilla.org/show_bug.cgi?id=1205631)\n // which means that you *must* use DOMParser, otherwise the output may\n // not be safe if used in a document.write context later.\n //\n // So we feature detect the Firefox bug and use the DOMParser if necessary.\n //\n // MS Edge, in older versions, is affected by an mXSS behavior. The second\n // check tests for the behavior and fixes it if necessary.\n if (DOMPurify.isSupported) {\n (function () {\n try {\n var doc = _initDocument('<svg><p><style><img src=\"</style><img src=x onerror=1//\">');\n if (doc.querySelector('svg img')) {\n useDOMParser = true;\n }\n } catch (error) {}\n })();\n\n (function () {\n try {\n var doc = _initDocument('<x/><title></title><img>');\n if (doc.querySelector('title').innerHTML.match(/<\\/title/)) {\n removeTitle = true;\n }\n } catch (error) {}\n })();\n }\n\n /**\n * _createIterator\n *\n * @param {Document} root document/fragment to create iterator for\n * @return {Iterator} iterator instance\n */\n var _createIterator = function _createIterator(root) {\n return createNodeIterator.call(root.ownerDocument || root, root, NodeFilter.SHOW_ELEMENT | NodeFilter.SHOW_COMMENT | NodeFilter.SHOW_TEXT, function () {\n return NodeFilter.FILTER_ACCEPT;\n }, false);\n };\n\n /**\n * _isClobbered\n *\n * @param {Node} elm element to check for clobbering attacks\n * @return {Boolean} true if clobbered, false if safe\n */\n var _isClobbered = function _isClobbered(elm) {\n if (elm instanceof Text || elm instanceof Comment) {\n return false;\n }\n\n if (typeof elm.nodeName !== 'string' || typeof elm.textContent !== 'string' || typeof elm.removeChild !== 'function' || !(elm.attributes instanceof NamedNodeMap) || typeof elm.removeAttribute !== 'function' || typeof elm.setAttribute !== 'function') {\n return true;\n }\n\n return false;\n };\n\n /**\n * _isNode\n *\n * @param {Node} obj object to check whether it's a DOM node\n * @return {Boolean} true is object is a DOM node\n */\n var _isNode = function _isNode(obj) {\n return (typeof Node === 'undefined' ? 'undefined' : _typeof(Node)) === 'object' ? obj instanceof Node : obj && (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object' && typeof obj.nodeType === 'number' && typeof obj.nodeName === 'string';\n };\n\n /**\n * _executeHook\n * Execute user configurable hooks\n *\n * @param {String} entryPoint Name of the hook's entry point\n * @param {Node} currentNode node to work on with the hook\n * @param {Object} data additional hook parameters\n */\n var _executeHook = function _executeHook(entryPoint, currentNode, data) {\n if (!hooks[entryPoint]) {\n return;\n }\n\n hooks[entryPoint].forEach(function (hook) {\n hook.call(DOMPurify, currentNode, data, CONFIG);\n });\n };\n\n /**\n * _sanitizeElements\n *\n * @protect nodeName\n * @protect textContent\n * @protect removeChild\n *\n * @param {Node} currentNode to check for permission to exist\n * @return {Boolean} true if node was killed, false if left alive\n */\n // eslint-disable-next-line complexity\n var _sanitizeElements = function _sanitizeElements(currentNode) {\n var content = void 0;\n\n /* Execute a hook if present */\n _executeHook('beforeSanitizeElements', currentNode, null);\n\n /* Check if element is clobbered or can clobber */\n if (_isClobbered(currentNode)) {\n _forceRemove(currentNode);\n return true;\n }\n\n /* Now let's check the element's type and name */\n var tagName = currentNode.nodeName.toLowerCase();\n\n /* Execute a hook if present */\n _executeHook('uponSanitizeElement', currentNode, {\n tagName: tagName,\n allowedTags: ALLOWED_TAGS\n });\n\n /* Remove element if anything forbids its presence */\n if (!ALLOWED_TAGS[tagName] || FORBID_TAGS[tagName]) {\n /* Keep content except for black-listed elements */\n if (KEEP_CONTENT && !FORBID_CONTENTS[tagName] && typeof currentNode.insertAdjacentHTML === 'function') {\n try {\n var htmlToInsert = currentNode.innerHTML;\n currentNode.insertAdjacentHTML('AfterEnd', trustedTypesPolicy ? trustedTypesPolicy.createHTML(htmlToInsert) : htmlToInsert);\n } catch (error) {}\n }\n\n _forceRemove(currentNode);\n return true;\n }\n\n /* Remove in case a noscript/noembed XSS is suspected */\n if (tagName === 'noscript' && currentNode.innerHTML.match(/<\\/noscript/i)) {\n _forceRemove(currentNode);\n return true;\n }\n\n if (tagName === 'noembed' && currentNode.innerHTML.match(/<\\/noembed/i)) {\n _forceRemove(currentNode);\n return true;\n }\n\n /* Convert markup to cover jQuery behavior */\n if (SAFE_FOR_JQUERY && !currentNode.firstElementChild && (!currentNode.content || !currentNode.content.firstElementChild) && /</g.test(currentNode.textContent)) {\n DOMPurify.removed.push({ element: currentNode.cloneNode() });\n if (currentNode.innerHTML) {\n currentNode.innerHTML = currentNode.innerHTML.replace(/</g, '<');\n } else {\n currentNode.innerHTML = currentNode.textContent.replace(/</g, '<');\n }\n }\n\n /* Sanitize element content to be template-safe */\n if (SAFE_FOR_TEMPLATES && currentNode.nodeType === 3) {\n /* Get the element's text content */\n content = currentNode.textContent;\n content = content.replace(MUSTACHE_EXPR$$1, ' ');\n content = content.replace(ERB_EXPR$$1, ' ');\n if (currentNode.textContent !== content) {\n DOMPurify.removed.push({ element: currentNode.cloneNode() });\n currentNode.textContent = content;\n }\n }\n\n /* Execute a hook if present */\n _executeHook('afterSanitizeElements', currentNode, null);\n\n return false;\n };\n\n /**\n * _isValidAttribute\n *\n * @param {string} lcTag Lowercase tag name of containing element.\n * @param {string} lcName Lowercase attribute name.\n * @param {string} value Attribute value.\n * @return {Boolean} Returns true if `value` is valid, otherwise false.\n */\n // eslint-disable-next-line complexity\n var _isValidAttribute = function _isValidAttribute(lcTag, lcName, value) {\n /* Make sure attribute cannot clobber */\n if (SANITIZE_DOM && (lcName === 'id' || lcName === 'name') && (value in document || value in formElement)) {\n return false;\n }\n\n /* Allow valid data-* attributes: At least one character after \"-\"\n (https://html.spec.whatwg.org/multipage/dom.html#embedding-custom-non-visible-data-with-the-data-*-attributes)\n XML-compatible (https://html.spec.whatwg.org/multipage/infrastructure.html#xml-compatible and http://www.w3.org/TR/xml/#d0e804)\n We don't need to check the value; it's always URI safe. */\n if (ALLOW_DATA_ATTR && DATA_ATTR$$1.test(lcName)) {\n // This attribute is safe\n } else if (ALLOW_ARIA_ATTR && ARIA_ATTR$$1.test(lcName)) {\n // This attribute is safe\n /* Otherwise, check the name is permitted */\n } else if (!ALLOWED_ATTR[lcName] || FORBID_ATTR[lcName]) {\n return false;\n\n /* Check value is safe. First, is attr inert? If so, is safe */\n } else if (URI_SAFE_ATTRIBUTES[lcName]) {\n // This attribute is safe\n /* Check no script, data or unknown possibly unsafe URI\n unless we know URI values are safe for that attribute */\n } else if (IS_ALLOWED_URI$$1.test(value.replace(ATTR_WHITESPACE$$1, ''))) {\n // This attribute is safe\n /* Keep image data URIs alive if src/xlink:href is allowed */\n /* Further prevent gadget XSS for dynamically built script tags */\n } else if ((lcName === 'src' || lcName === 'xlink:href') && lcTag !== 'script' && value.indexOf('data:') === 0 && DATA_URI_TAGS[lcTag]) {\n // This attribute is safe\n /* Allow unknown protocols: This provides support for links that\n are handled by protocol handlers which may be unknown ahead of\n time, e.g. fb:, spotify: */\n } else if (ALLOW_UNKNOWN_PROTOCOLS && !IS_SCRIPT_OR_DATA$$1.test(value.replace(ATTR_WHITESPACE$$1, ''))) {\n // This attribute is safe\n /* Check for binary attributes */\n // eslint-disable-next-line no-negated-condition\n } else if (!value) {\n // Binary attributes are safe at this point\n /* Anything else, presume unsafe, do not add it back */\n } else {\n return false;\n }\n\n return true;\n };\n\n /**\n * _sanitizeAttributes\n *\n * @protect attributes\n * @protect nodeName\n * @protect removeAttribute\n * @protect setAttribute\n *\n * @param {Node} currentNode to sanitize\n */\n var _sanitizeAttributes = function _sanitizeAttributes(currentNode) {\n var attr = void 0;\n var value = void 0;\n var lcName = void 0;\n var idAttr = void 0;\n var l = void 0;\n /* Execute a hook if present */\n _executeHook('beforeSanitizeAttributes', currentNode, null);\n\n var attributes = currentNode.attributes;\n\n /* Check if we have attributes; if not we might have a text node */\n\n if (!attributes) {\n return;\n }\n\n var hookEvent = {\n attrName: '',\n attrValue: '',\n keepAttr: true,\n allowedAttributes: ALLOWED_ATTR\n };\n l = attributes.length;\n\n /* Go backwards over all attributes; safely remove bad ones */\n while (l--) {\n attr = attributes[l];\n var _attr = attr,\n name = _attr.name,\n namespaceURI = _attr.namespaceURI;\n\n value = attr.value.trim();\n lcName = name.toLowerCase();\n\n /* Execute a hook if present */\n hookEvent.attrName = lcName;\n hookEvent.attrValue = value;\n hookEvent.keepAttr = true;\n _executeHook('uponSanitizeAttribute', currentNode, hookEvent);\n value = hookEvent.attrValue;\n\n /* Remove attribute */\n // Safari (iOS + Mac), last tested v8.0.5, crashes if you try to\n // remove a \"name\" attribute from an <img> tag that has an \"id\"\n // attribute at the time.\n if (lcName === 'name' && currentNode.nodeName === 'IMG' && attributes.id) {\n idAttr = attributes.id;\n attributes = apply(arraySlice, attributes, []);\n _removeAttribute('id', currentNode);\n _removeAttribute(name, currentNode);\n if (attributes.indexOf(idAttr) > l) {\n currentNode.setAttribute('id', idAttr.value);\n }\n } else if (\n // This works around a bug in Safari, where input[type=file]\n // cannot be dynamically set after type has been removed\n currentNode.nodeName === 'INPUT' && lcName === 'type' && value === 'file' && hookEvent.keepAttr && (ALLOWED_ATTR[lcName] || !FORBID_ATTR[lcName])) {\n continue;\n } else {\n // This avoids a crash in Safari v9.0 with double-ids.\n // The trick is to first set the id to be empty and then to\n // remove the attribute\n if (name === 'id') {\n currentNode.setAttribute(name, '');\n }\n\n _removeAttribute(name, currentNode);\n }\n\n /* Did the hooks approve of the attribute? */\n if (!hookEvent.keepAttr) {\n continue;\n }\n\n /* Sanitize attribute content to be template-safe */\n if (SAFE_FOR_TEMPLATES) {\n value = value.replace(MUSTACHE_EXPR$$1, ' ');\n value = value.replace(ERB_EXPR$$1, ' ');\n }\n\n /* Is `value` valid for this attribute? */\n var lcTag = currentNode.nodeName.toLowerCase();\n if (!_isValidAttribute(lcTag, lcName, value)) {\n continue;\n }\n\n /* Handle invalid data-* attribute set by try-catching it */\n try {\n if (namespaceURI) {\n currentNode.setAttributeNS(namespaceURI, name, value);\n } else {\n /* Fallback to setAttribute() for browser-unrecognized namespaces e.g. \"x-schema\". */\n currentNode.setAttribute(name, value);\n }\n\n DOMPurify.removed.pop();\n } catch (error) {}\n }\n\n /* Execute a hook if present */\n _executeHook('afterSanitizeAttributes', currentNode, null);\n };\n\n /**\n * _sanitizeShadowDOM\n *\n * @param {DocumentFragment} fragment to iterate over recursively\n */\n var _sanitizeShadowDOM = function _sanitizeShadowDOM(fragment) {\n var shadowNode = void 0;\n var shadowIterator = _createIterator(fragment);\n\n /* Execute a hook if present */\n _executeHook('beforeSanitizeShadowDOM', fragment, null);\n\n while (shadowNode = shadowIterator.nextNode()) {\n /* Execute a hook if present */\n _executeHook('uponSanitizeShadowNode', shadowNode, null);\n\n /* Sanitize tags and elements */\n if (_sanitizeElements(shadowNode)) {\n continue;\n }\n\n /* Deep shadow DOM detected */\n if (shadowNode.content instanceof DocumentFragment) {\n _sanitizeShadowDOM(shadowNode.content);\n }\n\n /* Check attributes, sanitize if necessary */\n _sanitizeAttributes(shadowNode);\n }\n\n /* Execute a hook if present */\n _executeHook('afterSanitizeShadowDOM', fragment, null);\n };\n\n /**\n * Sanitize\n * Public method providing core sanitation functionality\n *\n * @param {String|Node} dirty string or DOM node\n * @param {Object} configuration object\n */\n // eslint-disable-next-line complexity\n DOMPurify.sanitize = function (dirty, cfg) {\n var body = void 0;\n var importedNode = void 0;\n var currentNode = void 0;\n var oldNode = void 0;\n var returnNode = void 0;\n /* Make sure we have a string to sanitize.\n DO NOT return early, as this will return the wrong type if\n the user has requested a DOM object rather than a string */\n if (!dirty) {\n dirty = '<!-->';\n }\n\n /* Stringify, in case dirty is an object */\n if (typeof dirty !== 'string' && !_isNode(dirty)) {\n // eslint-disable-next-line no-negated-condition\n if (typeof dirty.toString !== 'function') {\n throw new TypeError('toString is not a function');\n } else {\n dirty = dirty.toString();\n if (typeof dirty !== 'string') {\n throw new TypeError('dirty is not a string, aborting');\n }\n }\n }\n\n /* Check we can run. Otherwise fall back or ignore */\n if (!DOMPurify.isSupported) {\n if (_typeof(window.toStaticHTML) === 'object' || typeof window.toStaticHTML === 'function') {\n if (typeof dirty === 'string') {\n return window.toStaticHTML(dirty);\n }\n\n if (_isNode(dirty)) {\n return window.toStaticHTML(dirty.outerHTML);\n }\n }\n\n return dirty;\n }\n\n /* Assign config vars */\n if (!SET_CONFIG) {\n _parseConfig(cfg);\n }\n\n /* Clean up removed elements */\n DOMPurify.removed = [];\n\n if (IN_PLACE) {\n /* No special handling necessary for in-place sanitization */\n } else if (dirty instanceof Node) {\n /* If dirty is a DOM element, append to an empty document to avoid\n elements being stripped by the parser */\n body = _initDocument('<!-->');\n importedNode = body.ownerDocument.importNode(dirty, true);\n if (importedNode.nodeType === 1 && importedNode.nodeName === 'BODY') {\n /* Node is already a body, use as is */\n body = importedNode;\n } else if (importedNode.nodeName === 'HTML') {\n body = importedNode;\n } else {\n // eslint-disable-next-line unicorn/prefer-node-append\n body.appendChild(importedNode);\n }\n } else {\n /* Exit directly if we have nothing to do */\n if (!RETURN_DOM && !SAFE_FOR_TEMPLATES && !WHOLE_DOCUMENT && dirty.indexOf('<') === -1) {\n return trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty;\n }\n\n /* Initialize the document to work on */\n body = _initDocument(dirty);\n\n /* Check we have a DOM node from the data */\n if (!body) {\n return RETURN_DOM ? null : emptyHTML;\n }\n }\n\n /* Remove first element node (ours) if FORCE_BODY is set */\n if (body && FORCE_BODY) {\n _forceRemove(body.firstChild);\n }\n\n /* Get node iterator */\n var nodeIterator = _createIterator(IN_PLACE ? dirty : body);\n\n /* Now start iterating over the created document */\n while (currentNode = nodeIterator.nextNode()) {\n /* Fix IE's strange behavior with manipulated textNodes #89 */\n if (currentNode.nodeType === 3 && currentNode === oldNode) {\n continue;\n }\n\n /* Sanitize tags and elements */\n if (_sanitizeElements(currentNode)) {\n continue;\n }\n\n /* Shadow DOM detected, sanitize it */\n if (currentNode.content instanceof DocumentFragment) {\n _sanitizeShadowDOM(currentNode.content);\n }\n\n /* Check attributes, sanitize if necessary */\n _sanitizeAttributes(currentNode);\n\n oldNode = currentNode;\n }\n\n oldNode = null;\n\n /* If we sanitized `dirty` in-place, return it. */\n if (IN_PLACE) {\n return dirty;\n }\n\n /* Return sanitized string or DOM */\n if (RETURN_DOM) {\n if (RETURN_DOM_FRAGMENT) {\n returnNode = createDocumentFragment.call(body.ownerDocument);\n\n while (body.firstChild) {\n // eslint-disable-next-line unicorn/prefer-node-append\n returnNode.appendChild(body.firstChild);\n }\n } else {\n returnNode = body;\n }\n\n if (RETURN_DOM_IMPORT) {\n /* AdoptNode() is not used because internal state is not reset\n (e.g. the past names map of a HTMLFormElement), this is safe\n in theory but we would rather not risk another attack vector.\n The state that is cloned by importNode() is explicitly defined\n by the specs. */\n returnNode = importNode.call(originalDocument, returnNode, true);\n }\n\n return returnNode;\n }\n\n var serializedHTML = WHOLE_DOCUMENT ? body.outerHTML : body.innerHTML;\n\n /* Sanitize final string template-safe */\n if (SAFE_FOR_TEMPLATES) {\n serializedHTML = serializedHTML.replace(MUSTACHE_EXPR$$1, ' ');\n serializedHTML = serializedHTML.replace(ERB_EXPR$$1, ' ');\n }\n\n return trustedTypesPolicy ? trustedTypesPolicy.createHTML(serializedHTML) : serializedHTML;\n };\n\n /**\n * Public method to set the configuration once\n * setConfig\n *\n * @param {Object} cfg configuration object\n */\n DOMPurify.setConfig = function (cfg) {\n _parseConfig(cfg);\n SET_CONFIG = true;\n };\n\n /**\n * Public method to remove the configuration\n * clearConfig\n *\n */\n DOMPurify.clearConfig = function () {\n CONFIG = null;\n SET_CONFIG = false;\n };\n\n /**\n * Public method to check if an attribute value is valid.\n * Uses last set config, if any. Otherwise, uses config defaults.\n * isValidAttribute\n *\n * @param {string} tag Tag name of containing element.\n * @param {string} attr Attribute name.\n * @param {string} value Attribute value.\n * @return {Boolean} Returns true if `value` is valid. Otherwise, returns false.\n */\n DOMPurify.isValidAttribute = function (tag, attr, value) {\n /* Initialize shared config vars if necessary. */\n if (!CONFIG) {\n _parseConfig({});\n }\n\n var lcTag = tag.toLowerCase();\n var lcName = attr.toLowerCase();\n return _isValidAttribute(lcTag, lcName, value);\n };\n\n /**\n * AddHook\n * Public method to add DOMPurify hooks\n *\n * @param {String} entryPoint entry point for the hook to add\n * @param {Function} hookFunction function to execute\n */\n DOMPurify.addHook = function (entryPoint, hookFunction) {\n if (typeof hookFunction !== 'function') {\n return;\n }\n\n hooks[entryPoint] = hooks[entryPoint] || [];\n hooks[entryPoint].push(hookFunction);\n };\n\n /**\n * RemoveHook\n * Public method to remove a DOMPurify hook at a given entryPoint\n * (pops it from the stack of hooks if more are present)\n *\n * @param {String} entryPoint entry point for the hook to remove\n */\n DOMPurify.removeHook = function (entryPoint) {\n if (hooks[entryPoint]) {\n hooks[entryPoint].pop();\n }\n };\n\n /**\n * RemoveHooks\n * Public method to remove all DOMPurify hooks at a given entryPoint\n *\n * @param {String} entryPoint entry point for the hooks to remove\n */\n DOMPurify.removeHooks = function (entryPoint) {\n if (hooks[entryPoint]) {\n hooks[entryPoint] = [];\n }\n };\n\n /**\n * RemoveAllHooks\n * Public method to remove all DOMPurify hooks\n *\n */\n DOMPurify.removeAllHooks = function () {\n hooks = {};\n };\n\n return DOMPurify;\n}\n\nvar purify = createDOMPurify();\n\nreturn purify;\n\n})));\n//# sourceMappingURL=purify.js.map\n"],"sourceRoot":""}
\ No newline at end of file |