{"version":3,"sources":["../node_modules/@ionic/core/dist/esm-es5/ion-button_2.entry.js","../node_modules/@ionic/core/dist/esm-es5/theme-5641d27f.js"],"names":["CACHED_MAP","getNamedUrl","iconName","url","window","Map","win","Ionicons","map","getIconMap","get","getAssetPath","getName","icon","mode","ios","md","toLower","isSrc","isStr","trim","replace","getSrc","src","str","length","test","val","toLowerCase","Button","hostRef","_this","this","registerInstance","ionFocus","createEvent","ionBlur","inItem","inListHeader","inToolbar","buttonType","disabled","routerDirection","strong","type","handleClick","ev","openURL","href","routerAnimation","hasShadowDom","el","form","closest","preventDefault","fakeButton","document","createElement","style","display","appendChild","click","remove","onFocus","emit","onBlur","prototype","componentWillLoad","Object","defineProperty","querySelector","enumerable","configurable","undefined","fill","hasIconOnly","render","_a","getIonMode$1","_b","rel","target","size","color","expand","shape","finalSize","TagType","attrs","download","h","Host","onClick","class","createColorClasses$1","hostContext","assign","part","name","rippleType","getElement","isValid","elm","nodeType","nodeName","i","attributes","value","indexOf","childNodes","ioniconContent","requests","getSvgContent","req","fetch","set","Promise","resolve","then","rsp","ok","text","svgContent","div","innerHTML","removeChild","svgElm","firstElementChild","svgClass","getAttribute","setAttribute","validateContent","Icon","isVisible","getIonMode","lazy","connectedCallback","waitUntilVisible","loadIcon","disconnectedCallback","io","disconnect","rootMargin","cb","IntersectionObserver","io_1","data","isIntersecting","observe","url_1","getUrl","has","ariaLabel","label","flipRtl","role","createColorClasses","ownerDocument","dir","documentElement","selector","cssClassMap","getClassMap","classes","Array","isArray","split","filter","c","getClassList","forEach","SCHEME","direction","animation","__awaiter","router","__generator","push"],"mappings":"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","file":"static/js/20.dac0d962.chunk.js","sourcesContent":["import { k as getAssetPath, r as registerInstance, e as createEvent, h, H as Host, i as getElement } from './index-92848855.js';\nimport { b as getIonMode$1 } from './ionic-global-23e7365a.js';\nimport { h as hasShadowDom } from './helpers-5c745fbd.js';\nimport { o as openURL, c as createColorClasses$1, h as hostContext } from './theme-5641d27f.js';\nvar CACHED_MAP;\nvar getIconMap = function () {\n if (typeof window === 'undefined') {\n return new Map();\n }\n else {\n if (!CACHED_MAP) {\n var win = window;\n win.Ionicons = win.Ionicons || {};\n CACHED_MAP = win.Ionicons.map = win.Ionicons.map || new Map();\n }\n return CACHED_MAP;\n }\n};\nvar getUrl = function (i) {\n var url = getSrc(i.src);\n if (url) {\n return url;\n }\n url = getName(i.name, i.icon, i.mode, i.ios, i.md);\n if (url) {\n return getNamedUrl(url);\n }\n if (i.icon) {\n url = getSrc(i.icon);\n if (url) {\n return url;\n }\n url = getSrc(i.icon[i.mode]);\n if (url) {\n return url;\n }\n }\n return null;\n};\nvar getNamedUrl = function (iconName) {\n var url = getIconMap().get(iconName);\n if (url) {\n return url;\n }\n return getAssetPath(\"svg/\" + iconName + \".svg\");\n};\nvar getName = function (iconName, icon, mode, ios, md) {\n // default to \"md\" if somehow the mode wasn't set\n mode = (mode && toLower(mode)) === 'ios' ? 'ios' : 'md';\n // if an icon was passed in using the ios or md attributes\n // set the iconName to whatever was passed in\n if (ios && mode === 'ios') {\n iconName = toLower(ios);\n }\n else if (md && mode === 'md') {\n iconName = toLower(md);\n }\n else {\n if (!iconName && icon && !isSrc(icon)) {\n iconName = icon;\n }\n if (isStr(iconName)) {\n iconName = toLower(iconName);\n }\n }\n if (!isStr(iconName) || iconName.trim() === '') {\n return null;\n }\n // only allow alpha characters and dash\n var invalidChars = iconName.replace(/[a-z]|-|\\d/gi, '');\n if (invalidChars !== '') {\n return null;\n }\n return iconName;\n};\nvar getSrc = function (src) {\n if (isStr(src)) {\n src = src.trim();\n if (isSrc(src)) {\n return src;\n }\n }\n return null;\n};\nvar isSrc = function (str) { return str.length > 0 && /(\\/|\\.)/.test(str); };\nvar isStr = function (val) { return typeof val === 'string'; };\nvar toLower = function (val) { return val.toLowerCase(); };\nvar buttonIosCss = \":host{--overflow:hidden;--ripple-color:currentColor;--border-width:initial;--border-color:initial;--border-style:initial;--color-activated:var(--color);--color-focused:var(--color);--color-hover:var(--color);--box-shadow:none;display:inline-block;width:auto;color:var(--color);font-family:var(--ion-font-family, inherit);text-align:center;text-decoration:none;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:top;vertical-align:-webkit-baseline-middle;pointer-events:auto;-webkit-font-kerning:none;font-kerning:none}:host(.button-disabled){cursor:default;opacity:0.5;pointer-events:none}:host(.button-solid){--background:var(--ion-color-primary, #3880ff);--color:var(--ion-color-primary-contrast, #fff)}:host(.button-outline){--border-color:var(--ion-color-primary, #3880ff);--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-clear){--border-width:0;--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-block){display:block}:host(.button-block) .button-native{margin-left:0;margin-right:0;display:block;width:100%;clear:both;contain:content}:host(.button-block) .button-native::after{clear:both}:host(.button-full){display:block}:host(.button-full) .button-native{margin-left:0;margin-right:0;display:block;width:100%;contain:content}:host(.button-full:not(.button-round)) .button-native{border-radius:0;border-right-width:0;border-left-width:0}.button-native{border-radius:var(--border-radius);-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;display:block;position:relative;width:100%;height:100%;-webkit-transition:var(--transition);transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:var(--background);line-height:1;-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);contain:layout style;cursor:pointer;opacity:var(--opacity);overflow:var(--overflow);z-index:0;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.button-native{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.button-native::-moz-focus-inner{border:0}.button-inner{display:-ms-flexbox;display:flex;position:relative;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%;z-index:1}::slotted(ion-icon){font-size:1.4em;pointer-events:none}::slotted(ion-icon[slot=start]){margin-left:-0.3em;margin-right:0.3em;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:-0.3em;margin-inline-start:-0.3em;-webkit-margin-end:0.3em;margin-inline-end:0.3em}}::slotted(ion-icon[slot=end]){margin-left:0.3em;margin-right:-0.2em;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:0.3em;margin-inline-start:0.3em;-webkit-margin-end:-0.2em;margin-inline-end:-0.2em}}::slotted(ion-icon[slot=icon-only]){font-size:1.8em}ion-ripple-effect{color:var(--ripple-color)}.button-native::after{left:0;right:0;top:0;bottom:0;position:absolute;content:\\\"\\\";opacity:0}:host(.ion-activated){color:var(--color-activated)}:host(.ion-activated) .button-native::after{background:var(--background-activated);opacity:var(--background-activated-opacity)}:host(.ion-focused){color:var(--color-focused)}:host(.ion-focused) .button-native::after{background:var(--background-focused);opacity:var(--background-focused-opacity)}@media (any-hover: hover){:host(:hover){color:var(--color-hover)}:host(:hover) .button-native::after{background:var(--background-hover);opacity:var(--background-hover-opacity)}}:host(.button-solid.ion-color) .button-native{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.button-outline.ion-color) .button-native{border-color:var(--ion-color-base);background:transparent;color:var(--ion-color-base)}:host(.button-clear.ion-color) .button-native{background:transparent;color:var(--ion-color-base)}:host(.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{color:var(--ion-toolbar-color, var(--color))}:host(.button-outline.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{border-color:var(--ion-toolbar-color, var(--color, var(--border-color)))}:host(.button-solid.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{background:var(--ion-toolbar-color, var(--background));color:var(--ion-toolbar-background, var(--color))}:host{--border-radius:10px;--padding-top:0;--padding-bottom:0;--padding-start:1em;--padding-end:1em;--transition:background-color, opacity 100ms linear;margin-left:2px;margin-right:2px;margin-top:4px;margin-bottom:4px;height:2.8em;font-size:16px;font-weight:500;letter-spacing:-0.03em}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host{margin-left:unset;margin-right:unset;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px}}:host(.button-solid){--background-activated:var(--ion-color-primary-shade, #3171e0);--background-focused:var(--ion-color-primary-shade, #3171e0);--background-hover:var(--ion-color-primary-tint, #4c8dff);--background-activated-opacity:1;--background-focused-opacity:1;--background-hover-opacity:1}:host(.button-outline){--border-radius:10px;--border-width:1px;--border-style:solid;--background-activated:var(--ion-color-primary, #3880ff);--background-focused:var(--ion-color-primary, #3880ff);--background-hover:transparent;--background-focused-opacity:.1;--color-activated:var(--ion-color-primary-contrast, #fff)}:host(.button-clear){--background-activated:transparent;--background-focused:var(--ion-color-primary, #3880ff);--background-hover:transparent;--background-focused-opacity:.1;font-size:17px;font-weight:normal;letter-spacing:0}:host(.button-large){--border-radius:12px;--padding-top:0;--padding-start:1em;--padding-end:1em;--padding-bottom:0;height:2.8em;font-size:20px}:host(.button-small){--border-radius:6px;--padding-top:0;--padding-start:0.9em;--padding-end:0.9em;--padding-bottom:0;height:2.1em;font-size:13px}:host(.button-round){--border-radius:64px;--padding-top:0;--padding-start:26px;--padding-end:26px;--padding-bottom:0}:host(.button-strong){font-weight:600}:host(.button-clear.ion-activated){opacity:0.4}:host(.button-outline.ion-activated.ion-color) .button-native{color:var(--ion-color-contrast)}:host(.button-outline.ion-activated.ion-color) .button-native::after{background:var(--ion-color-base)}:host(.button-solid.ion-color.ion-activated) .button-native::after{background:var(--ion-color-shade)}:host(.button-outline.ion-focused.ion-color) .button-native,:host(.button-clear.ion-focused.ion-color) .button-native{color:var(--ion-color-base)}:host(.button-outline.ion-focused.ion-color) .button-native::after,:host(.button-clear.ion-focused.ion-color) .button-native::after{background:var(--ion-color-base)}:host(.button-solid.ion-color.ion-focused) .button-native::after{background:var(--ion-color-shade)}@media (any-hover: hover){:host(.button-clear:hover),:host(.button-outline:hover){opacity:0.6}:host(.button-clear.ion-color:hover) .button-native,:host(.button-outline.ion-color:hover) .button-native{color:var(--ion-color-base)}:host(.button-clear.ion-color:hover) .button-native::after,:host(.button-outline.ion-color:hover) .button-native::after{background:transparent}:host(.button-solid.ion-color:hover) .button-native::after{background:var(--ion-color-tint)}:host(:hover.button-solid.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native::after{background:#fff;opacity:0.1}}\";\nvar buttonMdCss = \":host{--overflow:hidden;--ripple-color:currentColor;--border-width:initial;--border-color:initial;--border-style:initial;--color-activated:var(--color);--color-focused:var(--color);--color-hover:var(--color);--box-shadow:none;display:inline-block;width:auto;color:var(--color);font-family:var(--ion-font-family, inherit);text-align:center;text-decoration:none;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:top;vertical-align:-webkit-baseline-middle;pointer-events:auto;-webkit-font-kerning:none;font-kerning:none}:host(.button-disabled){cursor:default;opacity:0.5;pointer-events:none}:host(.button-solid){--background:var(--ion-color-primary, #3880ff);--color:var(--ion-color-primary-contrast, #fff)}:host(.button-outline){--border-color:var(--ion-color-primary, #3880ff);--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-clear){--border-width:0;--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-block){display:block}:host(.button-block) .button-native{margin-left:0;margin-right:0;display:block;width:100%;clear:both;contain:content}:host(.button-block) .button-native::after{clear:both}:host(.button-full){display:block}:host(.button-full) .button-native{margin-left:0;margin-right:0;display:block;width:100%;contain:content}:host(.button-full:not(.button-round)) .button-native{border-radius:0;border-right-width:0;border-left-width:0}.button-native{border-radius:var(--border-radius);-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;display:block;position:relative;width:100%;height:100%;-webkit-transition:var(--transition);transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:var(--background);line-height:1;-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);contain:layout style;cursor:pointer;opacity:var(--opacity);overflow:var(--overflow);z-index:0;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.button-native{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.button-native::-moz-focus-inner{border:0}.button-inner{display:-ms-flexbox;display:flex;position:relative;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%;z-index:1}::slotted(ion-icon){font-size:1.4em;pointer-events:none}::slotted(ion-icon[slot=start]){margin-left:-0.3em;margin-right:0.3em;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:-0.3em;margin-inline-start:-0.3em;-webkit-margin-end:0.3em;margin-inline-end:0.3em}}::slotted(ion-icon[slot=end]){margin-left:0.3em;margin-right:-0.2em;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:0.3em;margin-inline-start:0.3em;-webkit-margin-end:-0.2em;margin-inline-end:-0.2em}}::slotted(ion-icon[slot=icon-only]){font-size:1.8em}ion-ripple-effect{color:var(--ripple-color)}.button-native::after{left:0;right:0;top:0;bottom:0;position:absolute;content:\\\"\\\";opacity:0}:host(.ion-activated){color:var(--color-activated)}:host(.ion-activated) .button-native::after{background:var(--background-activated);opacity:var(--background-activated-opacity)}:host(.ion-focused){color:var(--color-focused)}:host(.ion-focused) .button-native::after{background:var(--background-focused);opacity:var(--background-focused-opacity)}@media (any-hover: hover){:host(:hover){color:var(--color-hover)}:host(:hover) .button-native::after{background:var(--background-hover);opacity:var(--background-hover-opacity)}}:host(.button-solid.ion-color) .button-native{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.button-outline.ion-color) .button-native{border-color:var(--ion-color-base);background:transparent;color:var(--ion-color-base)}:host(.button-clear.ion-color) .button-native{background:transparent;color:var(--ion-color-base)}:host(.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{color:var(--ion-toolbar-color, var(--color))}:host(.button-outline.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{border-color:var(--ion-toolbar-color, var(--color, var(--border-color)))}:host(.button-solid.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{background:var(--ion-toolbar-color, var(--background));color:var(--ion-toolbar-background, var(--color))}:host{--border-radius:4px;--padding-top:0;--padding-bottom:0;--padding-start:1.1em;--padding-end:1.1em;--transition:box-shadow 280ms cubic-bezier(.4, 0, .2, 1),\\n background-color 15ms linear,\\n color 15ms linear;margin-left:2px;margin-right:2px;margin-top:4px;margin-bottom:4px;height:36px;font-size:14px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host{margin-left:unset;margin-right:unset;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px}}:host(.button-solid){--background-activated:transparent;--background-hover:var(--ion-color-primary-contrast, #fff);--background-focused:var(--ion-color-primary-contrast, #fff);--background-activated-opacity:0;--background-focused-opacity:.24;--background-hover-opacity:.08;--box-shadow:0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12)}:host(.button-solid.ion-activated){--box-shadow:0 5px 5px -3px rgba(0, 0, 0, 0.2), 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12)}:host(.button-outline){--border-width:2px;--border-style:solid;--box-shadow:none;--background-activated:transparent;--background-focused:var(--ion-color-primary, #3880ff);--background-hover:var(--ion-color-primary, #3880ff);--background-activated-opacity:0;--background-focused-opacity:.12;--background-hover-opacity:.04}:host(.button-outline.ion-activated.ion-color) .button-native{background:transparent}:host(.button-clear){--background-activated:transparent;--background-focused:var(--ion-color-primary, #3880ff);--background-hover:var(--ion-color-primary, #3880ff);--background-activated-opacity:0;--background-focused-opacity:.12;--background-hover-opacity:.04}:host(.button-round){--border-radius:64px;--padding-top:0;--padding-start:26px;--padding-end:26px;--padding-bottom:0}:host(.button-large){--padding-top:0;--padding-start:1em;--padding-end:1em;--padding-bottom:0;height:2.8em;font-size:20px}:host(.button-small){--padding-top:0;--padding-start:0.9em;--padding-end:0.9em;--padding-bottom:0;height:2.1em;font-size:13px}:host(.button-strong){font-weight:bold}::slotted(ion-icon[slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host(.button-solid.ion-color.ion-focused) .button-native::after{background:var(--ion-color-contrast);opacity:0.24}:host(.button-clear.ion-color.ion-focused) .button-native::after,:host(.button-outline.ion-color.ion-focused) .button-native::after{background:var(--ion-color-base);opacity:0.12}@media (any-hover: hover){:host(.button-solid.ion-color:hover) .button-native::after{background:var(--ion-color-contrast);opacity:0.08}:host(.button-clear.ion-color:hover) .button-native::after,:host(.button-outline.ion-color:hover) .button-native::after{background:var(--ion-color-base);opacity:0.04}}\";\nvar Button = /** @class */ (function () {\n function Button(hostRef) {\n var _this = this;\n registerInstance(this, hostRef);\n this.ionFocus = createEvent(this, \"ionFocus\", 7);\n this.ionBlur = createEvent(this, \"ionBlur\", 7);\n this.inItem = false;\n this.inListHeader = false;\n this.inToolbar = false;\n /**\n * The type of button.\n */\n this.buttonType = 'button';\n /**\n * If `true`, the user cannot interact with the button.\n */\n this.disabled = false;\n /**\n * When using a router, it specifies the transition direction when navigating to\n * another page using `href`.\n */\n this.routerDirection = 'forward';\n /**\n * If `true`, activates a button with a heavier font weight.\n */\n this.strong = false;\n /**\n * The type of the button.\n */\n this.type = 'button';\n this.handleClick = function (ev) {\n if (_this.type === 'button') {\n openURL(_this.href, ev, _this.routerDirection, _this.routerAnimation);\n }\n else if (hasShadowDom(_this.el)) {\n // this button wants to specifically submit a form\n // climb up the dom to see if we're in a
\n // and if so, then use JS to submit it\n var form = _this.el.closest('form');\n if (form) {\n ev.preventDefault();\n var fakeButton = document.createElement('button');\n fakeButton.type = _this.type;\n fakeButton.style.display = 'none';\n form.appendChild(fakeButton);\n fakeButton.click();\n fakeButton.remove();\n }\n }\n };\n this.onFocus = function () {\n _this.ionFocus.emit();\n };\n this.onBlur = function () {\n _this.ionBlur.emit();\n };\n }\n Button.prototype.componentWillLoad = function () {\n this.inToolbar = !!this.el.closest('ion-buttons');\n this.inListHeader = !!this.el.closest('ion-list-header');\n this.inItem = !!this.el.closest('ion-item') || !!this.el.closest('ion-item-divider');\n };\n Object.defineProperty(Button.prototype, \"hasIconOnly\", {\n get: function () {\n return !!this.el.querySelector('[slot=\"icon-only\"]');\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(Button.prototype, \"rippleType\", {\n get: function () {\n var hasClearFill = this.fill === undefined || this.fill === 'clear';\n // If the button is in a toolbar, has a clear fill (which is the default)\n // and only has an icon we use the unbounded \"circular\" ripple effect\n if (hasClearFill && this.hasIconOnly && this.inToolbar) {\n return 'unbounded';\n }\n return 'bounded';\n },\n enumerable: false,\n configurable: true\n });\n Button.prototype.render = function () {\n var _a;\n var mode = getIonMode$1(this);\n var _b = this, buttonType = _b.buttonType, type = _b.type, disabled = _b.disabled, rel = _b.rel, target = _b.target, size = _b.size, href = _b.href, color = _b.color, expand = _b.expand, hasIconOnly = _b.hasIconOnly, shape = _b.shape, strong = _b.strong;\n var finalSize = size === undefined && this.inItem ? 'small' : size;\n var TagType = href === undefined ? 'button' : 'a';\n var attrs = (TagType === 'button')\n ? { type: type }\n : {\n download: this.download,\n href: href,\n rel: rel,\n target: target\n };\n var fill = this.fill;\n if (fill === undefined) {\n fill = this.inToolbar || this.inListHeader ? 'clear' : 'solid';\n }\n return (h(Host, { onClick: this.handleClick, \"aria-disabled\": disabled ? 'true' : null, class: createColorClasses$1(color, (_a = {},\n _a[mode] = true,\n _a[buttonType] = true,\n _a[buttonType + \"-\" + expand] = expand !== undefined,\n _a[buttonType + \"-\" + finalSize] = finalSize !== undefined,\n _a[buttonType + \"-\" + shape] = shape !== undefined,\n _a[buttonType + \"-\" + fill] = true,\n _a[buttonType + \"-strong\"] = strong,\n _a['in-toolbar'] = hostContext('ion-toolbar', this.el),\n _a['in-toolbar-color'] = hostContext('ion-toolbar[color]', this.el),\n _a['button-has-icon-only'] = hasIconOnly,\n _a['button-disabled'] = disabled,\n _a['ion-activatable'] = true,\n _a['ion-focusable'] = true,\n _a)) }, h(TagType, Object.assign({}, attrs, { class: \"button-native\", part: \"native\", disabled: disabled, onFocus: this.onFocus, onBlur: this.onBlur }), h(\"span\", { class: \"button-inner\" }, h(\"slot\", { name: \"icon-only\" }), h(\"slot\", { name: \"start\" }), h(\"slot\", null), h(\"slot\", { name: \"end\" })), mode === 'md' && h(\"ion-ripple-effect\", { type: this.rippleType }))));\n };\n Object.defineProperty(Button.prototype, \"el\", {\n get: function () { return getElement(this); },\n enumerable: false,\n configurable: true\n });\n return Button;\n}());\nButton.style = {\n ios: buttonIosCss,\n md: buttonMdCss\n};\nvar validateContent = function (svgContent) {\n if (svgContent && typeof document !== 'undefined') {\n var div = document.createElement('div');\n div.innerHTML = svgContent;\n // setup this way to ensure it works on our buddy IE\n for (var i = div.childNodes.length - 1; i >= 0; i--) {\n if (div.childNodes[i].nodeName.toLowerCase() !== 'svg') {\n div.removeChild(div.childNodes[i]);\n }\n }\n // must only have 1 root element\n var svgElm = div.firstElementChild;\n if (svgElm && svgElm.nodeName.toLowerCase() === 'svg') {\n var svgClass = svgElm.getAttribute('class') || '';\n svgElm.setAttribute('class', (svgClass + ' s-ion-icon').trim());\n // root element must be an svg\n // lets double check we've got valid elements\n // do not allow scripts\n if (isValid(svgElm)) {\n return div.innerHTML;\n }\n }\n }\n return '';\n};\nvar isValid = function (elm) {\n if (elm.nodeType === 1) {\n if (elm.nodeName.toLowerCase() === 'script') {\n return false;\n }\n for (var i = 0; i < elm.attributes.length; i++) {\n var val = elm.attributes[i].value;\n if (isStr(val) && val.toLowerCase().indexOf('on') === 0) {\n return false;\n }\n }\n for (var i = 0; i < elm.childNodes.length; i++) {\n if (!isValid(elm.childNodes[i])) {\n return false;\n }\n }\n }\n return true;\n};\nvar ioniconContent = new Map();\nvar requests = new Map();\nvar getSvgContent = function (url) {\n // see if we already have a request for this url\n var req = requests.get(url);\n if (!req) {\n if (typeof fetch !== 'undefined') {\n // we don't already have a request\n req = fetch(url).then(function (rsp) {\n if (rsp.ok) {\n return rsp.text().then(function (svgContent) {\n ioniconContent.set(url, validateContent(svgContent));\n });\n }\n ioniconContent.set(url, '');\n });\n // cache for the same requests\n requests.set(url, req);\n }\n else {\n // set to empty for ssr scenarios and resolve promise\n ioniconContent.set(url, '');\n return Promise.resolve();\n }\n }\n return req;\n};\nvar iconCss = \":host{display:inline-block;width:1em;height:1em;contain:strict;fill:currentColor;-webkit-box-sizing:content-box !important;box-sizing:content-box !important}:host .ionicon{stroke:currentColor}.ionicon-fill-none{fill:none}.ionicon-stroke-width{stroke-width:32px;stroke-width:var(--ionicon-stroke-width, 32px)}.icon-inner,.ionicon,svg{display:block;height:100%;width:100%}:host(.flip-rtl) .icon-inner{-webkit-transform:scaleX(-1);transform:scaleX(-1)}:host(.icon-small){font-size:18px !important}:host(.icon-large){font-size:32px !important}:host(.ion-color){color:var(--ion-color-base) !important}:host(.ion-color-primary){--ion-color-base:var(--ion-color-primary, #3880ff)}:host(.ion-color-secondary){--ion-color-base:var(--ion-color-secondary, #0cd1e8)}:host(.ion-color-tertiary){--ion-color-base:var(--ion-color-tertiary, #f4a942)}:host(.ion-color-success){--ion-color-base:var(--ion-color-success, #10dc60)}:host(.ion-color-warning){--ion-color-base:var(--ion-color-warning, #ffce00)}:host(.ion-color-danger){--ion-color-base:var(--ion-color-danger, #f14141)}:host(.ion-color-light){--ion-color-base:var(--ion-color-light, #f4f5f8)}:host(.ion-color-medium){--ion-color-base:var(--ion-color-medium, #989aa2)}:host(.ion-color-dark){--ion-color-base:var(--ion-color-dark, #222428)}\";\nvar Icon = /** @class */ (function () {\n function Icon(hostRef) {\n registerInstance(this, hostRef);\n this.isVisible = false;\n /**\n * The mode determines which platform styles to use.\n */\n this.mode = getIonMode();\n /**\n * If enabled, ion-icon will be loaded lazily when it's visible in the viewport.\n * Default, `false`.\n */\n this.lazy = false;\n }\n Icon.prototype.connectedCallback = function () {\n var _this = this;\n // purposely do not return the promise here because loading\n // the svg file should not hold up loading the app\n // only load the svg if it's visible\n this.waitUntilVisible(this.el, '50px', function () {\n _this.isVisible = true;\n _this.loadIcon();\n });\n };\n Icon.prototype.disconnectedCallback = function () {\n if (this.io) {\n this.io.disconnect();\n this.io = undefined;\n }\n };\n Icon.prototype.waitUntilVisible = function (el, rootMargin, cb) {\n var _this = this;\n if (this.lazy && typeof window !== 'undefined' && window.IntersectionObserver) {\n var io_1 = this.io = new window.IntersectionObserver(function (data) {\n if (data[0].isIntersecting) {\n io_1.disconnect();\n _this.io = undefined;\n cb();\n }\n }, { rootMargin: rootMargin });\n io_1.observe(el);\n }\n else {\n // browser doesn't support IntersectionObserver\n // so just fallback to always show it\n cb();\n }\n };\n Icon.prototype.loadIcon = function () {\n var _this = this;\n if (this.isVisible) {\n var url_1 = getUrl(this);\n if (url_1) {\n if (ioniconContent.has(url_1)) {\n // sync if it's already loaded\n this.svgContent = ioniconContent.get(url_1);\n }\n else {\n // async if it hasn't been loaded\n getSvgContent(url_1).then(function () { return _this.svgContent = ioniconContent.get(url_1); });\n }\n }\n }\n if (!this.ariaLabel) {\n var label = getName(this.name, this.icon, this.mode, this.ios, this.md);\n // user did not provide a label\n // come up with the label based on the icon name\n if (label) {\n this.ariaLabel = label.replace(/\\-/g, ' ');\n }\n }\n };\n Icon.prototype.render = function () {\n var _a, _b;\n var mode = this.mode || 'md';\n var flipRtl = this.flipRtl || (this.ariaLabel && (this.ariaLabel.indexOf('arrow') > -1 || this.ariaLabel.indexOf('chevron') > -1) && this.flipRtl !== false);\n return (h(Host, { role: \"img\", class: Object.assign(Object.assign((_a = {}, _a[mode] = true, _a), createColorClasses(this.color)), (_b = {}, _b[\"icon-\" + this.size] = !!this.size, _b['flip-rtl'] = !!flipRtl && this.el.ownerDocument.dir === 'rtl', _b)) }, ((this.svgContent)\n ? h(\"div\", { class: \"icon-inner\", innerHTML: this.svgContent })\n : h(\"div\", { class: \"icon-inner\" }))));\n };\n Object.defineProperty(Icon, \"assetsDirs\", {\n get: function () { return [\"svg\"]; },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(Icon.prototype, \"el\", {\n get: function () { return getElement(this); },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(Icon, \"watchers\", {\n get: function () {\n return {\n \"name\": [\"loadIcon\"],\n \"src\": [\"loadIcon\"],\n \"icon\": [\"loadIcon\"]\n };\n },\n enumerable: false,\n configurable: true\n });\n return Icon;\n}());\nvar getIonMode = function () { return (typeof document !== 'undefined' && document.documentElement.getAttribute('mode')) || 'md'; };\nvar createColorClasses = function (color) {\n var _a;\n return (color) ? (_a = {\n 'ion-color': true\n },\n _a[\"ion-color-\" + color] = true,\n _a) : null;\n};\nIcon.style = iconCss;\nexport { Button as ion_button, Icon as ion_icon };\n","import { __awaiter, __generator } from \"tslib\";\nvar hostContext = function (selector, el) {\n return el.closest(selector) !== null;\n};\n/**\n * Create the mode and color classes for the component based on the classes passed in\n */\nvar createColorClasses = function (color, cssClassMap) {\n var _a;\n return (typeof color === 'string' && color.length > 0) ? Object.assign((_a = { 'ion-color': true }, _a[\"ion-color-\" + color] = true, _a), cssClassMap) : cssClassMap;\n};\nvar getClassList = function (classes) {\n if (classes !== undefined) {\n var array = Array.isArray(classes) ? classes : classes.split(' ');\n return array\n .filter(function (c) { return c != null; })\n .map(function (c) { return c.trim(); })\n .filter(function (c) { return c !== ''; });\n }\n return [];\n};\nvar getClassMap = function (classes) {\n var map = {};\n getClassList(classes).forEach(function (c) { return map[c] = true; });\n return map;\n};\nvar SCHEME = /^[a-z][a-z0-9+\\-.]*:/;\nvar openURL = function (url, ev, direction, animation) { return __awaiter(void 0, void 0, void 0, function () {\n var router;\n return __generator(this, function (_a) {\n if (url != null && url[0] !== '#' && !SCHEME.test(url)) {\n router = document.querySelector('ion-router');\n if (router) {\n if (ev != null) {\n ev.preventDefault();\n }\n return [2 /*return*/, router.push(url, direction, animation)];\n }\n }\n return [2 /*return*/, false];\n });\n}); };\nexport { createColorClasses as c, getClassMap as g, hostContext as h, openURL as o };\n"],"sourceRoot":""}