{"version":3,"mappings":"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","names":["CACHED_MAP","getName","iconName","icon","mode","ios","md","toLower","n","e","isSrc","isStr","trim","invalidChars","replace","getSrc","src","str","length","test","val","toLowerCase","Button","constructor","hostRef","registerInstance","this","ionFocus","createEvent","ionBlur","inItem","inListHeader","inToolbar","inheritedAttributes","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","componentWillLoad","inheritAttributes$1","hasIconOnly","querySelector","rippleType","undefined","fill","render","getIonMode$1","rel","target","size","color","expand","shape","finalSize","TagType","attrs","download","h","Host","onClick","class","createColorClasses$1","hostContext","Object","assign","part","name","getElement","isValid","elm","nodeType","nodeName","i","attributes","value","indexOf","childNodes","ioniconContent","Map","requests","Icon","isVisible","getIonMode","lazy","sanitize","hasAriaHidden","hasAttribute","getAttribute","attributeObject","forEach","attr","removeAttribute","inheritAttributes","connectedCallback","waitUntilVisible","loadIcon","disconnectedCallback","io","disconnect","rootMargin","cb","window","IntersectionObserver","data","isIntersecting","observe","url","win","Ionicons","map","getIconMap","get","getAssetPath","getNamedUrl","getUrl","has","svgContent","req","fetch","set","Promise","resolve","then","rsp","ok","text","div","innerHTML","removeChild","svgElm","firstElementChild","svgClass","setAttribute","validateContent","getSvgContent","label","ariaLabel","flipRtl","role","createColorClasses","ownerDocument","dir","assetsDirs","watchers","documentElement"],"sources":["./node_modules/@ionic/core/dist/esm/ion-button_2.entry.js"],"sourcesContent":["/*!\n * (C) Ionic http://ionicframework.com - MIT License\n */\nimport { k as getAssetPath, r as registerInstance, e as createEvent, h, H as Host, i as getElement } from './index-06cd27b1.js';\nimport { b as getIonMode$1 } from './ionic-global-a049bcbf.js';\nimport { l as hasShadowDom, i as inheritAttributes$1 } from './helpers-eed79a2b.js';\nimport { o as openURL, c as createColorClasses$1, h as hostContext } from './theme-a24ff1ad.js';\n\nlet CACHED_MAP;\nconst getIconMap = () => {\n if (typeof window === 'undefined') {\n return new Map();\n }\n else {\n if (!CACHED_MAP) {\n const 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};\nconst getUrl = (i) => {\n let 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};\nconst getNamedUrl = (iconName) => {\n const url = getIconMap().get(iconName);\n if (url) {\n return url;\n }\n return getAssetPath(`svg/${iconName}.svg`);\n};\nconst getName = (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 const invalidChars = iconName.replace(/[a-z]|-|\\d/gi, '');\n if (invalidChars !== '') {\n return null;\n }\n return iconName;\n};\nconst getSrc = (src) => {\n if (isStr(src)) {\n src = src.trim();\n if (isSrc(src)) {\n return src;\n }\n }\n return null;\n};\nconst isSrc = (str) => str.length > 0 && /(\\/|\\.)/.test(str);\nconst isStr = (val) => typeof val === 'string';\nconst toLower = (val) => val.toLowerCase();\n/**\n * Elements inside of web components sometimes need to inherit global attributes\n * set on the host. For example, the inner input in `ion-input` should inherit\n * the `title` attribute that developers set directly on `ion-input`. This\n * helper function should be called in componentWillLoad and assigned to a variable\n * that is later used in the render function.\n *\n * This does not need to be reactive as changing attributes on the host element\n * does not trigger a re-render.\n */\nconst inheritAttributes = (el, attributes = []) => {\n const attributeObject = {};\n attributes.forEach(attr => {\n if (el.hasAttribute(attr)) {\n const value = el.getAttribute(attr);\n if (value !== null) {\n attributeObject[attr] = el.getAttribute(attr);\n }\n el.removeAttribute(attr);\n }\n });\n return attributeObject;\n};\n\nconst 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;-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}}\";\n\nconst 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;-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)}: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)}@media (any-hover: hover){:host(.button-solid.ion-color:hover) .button-native::after{background:var(--ion-color-contrast)}:host(.button-clear.ion-color:hover) .button-native::after,:host(.button-outline.ion-color:hover) .button-native::after{background:var(--ion-color-base)}}\";\n\nlet Button = class {\n constructor(hostRef) {\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 this.inheritedAttributes = {};\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 = (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 const form = this.el.closest('form');\n if (form) {\n ev.preventDefault();\n const 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 = () => {\n this.ionFocus.emit();\n };\n this.onBlur = () => {\n this.ionBlur.emit();\n };\n }\n componentWillLoad() {\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 this.inheritedAttributes = inheritAttributes$1(this.el, ['aria-label']);\n }\n get hasIconOnly() {\n return !!this.el.querySelector('[slot=\"icon-only\"]');\n }\n get rippleType() {\n const 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 render() {\n const mode = getIonMode$1(this);\n const { buttonType, type, disabled, rel, target, size, href, color, expand, hasIconOnly, shape, strong, inheritedAttributes } = this;\n const finalSize = size === undefined && this.inItem ? 'small' : size;\n const TagType = href === undefined ? 'button' : 'a';\n const attrs = (TagType === 'button')\n ? { type }\n : {\n download: this.download,\n href,\n rel,\n target\n };\n let 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, {\n [mode]: true,\n [buttonType]: true,\n [`${buttonType}-${expand}`]: expand !== undefined,\n [`${buttonType}-${finalSize}`]: finalSize !== undefined,\n [`${buttonType}-${shape}`]: shape !== undefined,\n [`${buttonType}-${fill}`]: true,\n [`${buttonType}-strong`]: strong,\n 'in-toolbar': hostContext('ion-toolbar', this.el),\n 'in-toolbar-color': hostContext('ion-toolbar[color]', this.el),\n 'button-has-icon-only': hasIconOnly,\n 'button-disabled': disabled,\n 'ion-activatable': true,\n 'ion-focusable': true,\n }) }, h(TagType, Object.assign({}, attrs, { class: \"button-native\", part: \"native\", disabled: disabled, onFocus: this.onFocus, onBlur: this.onBlur }, inheritedAttributes), 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 get el() { return getElement(this); }\n};\nButton.style = {\n ios: buttonIosCss,\n md: buttonMdCss\n};\n\nconst validateContent = (svgContent) => {\n const div = document.createElement('div');\n div.innerHTML = svgContent;\n // setup this way to ensure it works on our buddy IE\n for (let 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 const svgElm = div.firstElementChild;\n if (svgElm && svgElm.nodeName.toLowerCase() === 'svg') {\n const 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 return '';\n};\nconst isValid = (elm) => {\n if (elm.nodeType === 1) {\n if (elm.nodeName.toLowerCase() === 'script') {\n return false;\n }\n for (let i = 0; i < elm.attributes.length; i++) {\n const val = elm.attributes[i].value;\n if (isStr(val) && val.toLowerCase().indexOf('on') === 0) {\n return false;\n }\n }\n for (let i = 0; i < elm.childNodes.length; i++) {\n if (!isValid(elm.childNodes[i])) {\n return false;\n }\n }\n }\n return true;\n};\n\nconst ioniconContent = new Map();\nconst requests = new Map();\nconst getSvgContent = (url, sanitize) => {\n // see if we already have a request for this url\n let req = requests.get(url);\n if (!req) {\n if (typeof fetch !== 'undefined' && typeof document !== 'undefined') {\n // we don't already have a request\n req = fetch(url).then((rsp) => {\n if (rsp.ok) {\n return rsp.text().then((svgContent) => {\n if (svgContent && sanitize !== false) {\n svgContent = validateContent(svgContent);\n }\n ioniconContent.set(url, 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};\n\nconst 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)}\";\n\nlet Icon = class {\n constructor(hostRef) {\n registerInstance(this, hostRef);\n this.iconName = null;\n this.inheritedAttributes = {};\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 * When set to `false`, SVG content that is HTTP fetched will not be checked\n * if the response SVG content has any `