-
Notifications
You must be signed in to change notification settings - Fork 0
/
12-es5.js.map
1 lines (1 loc) · 40.2 KB
/
12-es5.js.map
1
{"version":3,"sources":["webpack:///node_modules/@ionic/core/dist/esm/ion-button_2-ios.entry.js"],"names":["buttonIosCss","buttonMdCss","Button","hostRef","inItem","inListHeader","inToolbar","buttonType","disabled","routerDirection","strong","type","handleClick","ev","href","el","form","closest","preventDefault","fakeButton","document","createElement","style","display","appendChild","click","remove","onFocus","ionFocus","emit","onBlur","ionBlur","mode","rel","target","size","color","expand","hasIconOnly","shape","finalSize","undefined","TagType","attrs","download","fill","onClick","Object","assign","name","rippleType","querySelector","hasClearFill","ios","md","validateContent","svgContent","div","innerHTML","i","childNodes","length","nodeName","toLowerCase","removeChild","svgElm","firstElementChild","svgClass","getAttribute","setAttribute","trim","isValid","elm","nodeType","attributes","val","value","indexOf","ioniconContent","Map","requests","getSvgContent","url","req","get","fetch","then","rsp","ok","text","set","Promise","resolve","iconCss","Icon","isVisible","getIonMode","lazy","waitUntilVisible","loadIcon","io","disconnect","rootMargin","cb","window","IntersectionObserver","data","isIntersecting","observe","has","ariaLabel","label","icon","replace","flipRtl","role","createColorClasses","ownerDocument","dir","documentElement"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;;;AAAA;AAAA;AAAA;AAAA;;;AAAA;AAAA;AAAA;AAAA;;;AAAA;AAAA;AAAA;AAAA;;;AAAA;AAAA;AAAA;AAAA;;;AAAA;AAAA;AAAA;AAAA;;;AAAA;AAAA;AAAA;AAAA;;;AAAA;AAAA;AAAA;;AAMA,QAAMA,YAAY,GAAG,m+QAArB;AAEA,QAAMC,WAAW,GAAG,kxQAApB;;AAEA,QAAMC,MAAM;AACR,sBAAYC,OAAZ,EAAqB;AAAA;;AAAA;;AACjB,qEAAiB,IAAjB,EAAuBA,OAAvB;AACA,aAAKC,MAAL,GAAc,KAAd;AACA,aAAKC,YAAL,GAAoB,KAApB;AACA,aAAKC,SAAL,GAAiB,KAAjB;AACA;;;;AAGA,aAAKC,UAAL,GAAkB,QAAlB;AACA;;;;AAGA,aAAKC,QAAL,GAAgB,KAAhB;AACA;;;;;AAIA,aAAKC,eAAL,GAAuB,SAAvB;AACA;;;;AAGA,aAAKC,MAAL,GAAc,KAAd;AACA;;;;AAGA,aAAKC,IAAL,GAAY,QAAZ;;AACA,aAAKC,WAAL,GAAmB,UAACC,EAAD,EAAQ;AACvB,cAAI,KAAI,CAACF,IAAL,KAAc,QAAlB,EAA4B;AACxB,yEAAQ,KAAI,CAACG,IAAb,EAAmBD,EAAnB,EAAuB,KAAI,CAACJ,eAA5B;AACH,WAFD,MAGK,IAAI,+DAAa,KAAI,CAACM,EAAlB,CAAJ,EAA2B;AAC5B;AACA;AACA;AACA,gBAAMC,IAAI,GAAG,KAAI,CAACD,EAAL,CAAQE,OAAR,CAAgB,MAAhB,CAAb;;AACA,gBAAID,IAAJ,EAAU;AACNH,gBAAE,CAACK,cAAH;AACA,kBAAMC,UAAU,GAAGC,QAAQ,CAACC,aAAT,CAAuB,QAAvB,CAAnB;AACAF,wBAAU,CAACR,IAAX,GAAkB,KAAI,CAACA,IAAvB;AACAQ,wBAAU,CAACG,KAAX,CAAiBC,OAAjB,GAA2B,MAA3B;AACAP,kBAAI,CAACQ,WAAL,CAAiBL,UAAjB;AACAA,wBAAU,CAACM,KAAX;AACAN,wBAAU,CAACO,MAAX;AACH;AACJ;AACJ,SAnBD;;AAoBA,aAAKC,OAAL,GAAe,YAAM;AACjB,eAAI,CAACC,QAAL,CAAcC,IAAd;AACH,SAFD;;AAGA,aAAKC,MAAL,GAAc,YAAM;AAChB,eAAI,CAACC,OAAL,CAAaF,IAAb;AACH,SAFD;;AAGA,aAAKD,QAAL,GAAgB,6DAAY,IAAZ,EAAkB,UAAlB,EAA8B,CAA9B,CAAhB;AACA,aAAKG,OAAL,GAAe,6DAAY,IAAZ,EAAkB,SAAlB,EAA6B,CAA7B,CAAf;AACH;;AAvDO;AAAA;AAAA,4CAwDY;AAChB,eAAKzB,SAAL,GAAiB,CAAC,CAAC,KAAKS,EAAL,CAAQE,OAAR,CAAgB,aAAhB,CAAnB;AACA,eAAKZ,YAAL,GAAoB,CAAC,CAAC,KAAKU,EAAL,CAAQE,OAAR,CAAgB,iBAAhB,CAAtB;AACA,eAAKb,MAAL,GAAc,CAAC,CAAC,KAAKW,EAAL,CAAQE,OAAR,CAAgB,UAAhB,CAAF,IAAiC,CAAC,CAAC,KAAKF,EAAL,CAAQE,OAAR,CAAgB,kBAAhB,CAAjD;AACH;AA5DO;AAAA;AAAA,iCAyEC;AAAA;;AACL,cAAMe,IAAI,GAAG,oEAAa,IAAb,CAAb;AADK,cAEGzB,UAFH,GAEsG,IAFtG,CAEGA,UAFH;AAAA,cAEeI,IAFf,GAEsG,IAFtG,CAEeA,IAFf;AAAA,cAEqBH,QAFrB,GAEsG,IAFtG,CAEqBA,QAFrB;AAAA,cAE+ByB,GAF/B,GAEsG,IAFtG,CAE+BA,GAF/B;AAAA,cAEoCC,MAFpC,GAEsG,IAFtG,CAEoCA,MAFpC;AAAA,cAE4CC,IAF5C,GAEsG,IAFtG,CAE4CA,IAF5C;AAAA,cAEkDrB,IAFlD,GAEsG,IAFtG,CAEkDA,IAFlD;AAAA,cAEwDsB,KAFxD,GAEsG,IAFtG,CAEwDA,KAFxD;AAAA,cAE+DC,MAF/D,GAEsG,IAFtG,CAE+DA,MAF/D;AAAA,cAEuEC,WAFvE,GAEsG,IAFtG,CAEuEA,WAFvE;AAAA,cAEoFC,KAFpF,GAEsG,IAFtG,CAEoFA,KAFpF;AAAA,cAE2F7B,MAF3F,GAEsG,IAFtG,CAE2FA,MAF3F;AAGL,cAAM8B,SAAS,GAAGL,IAAI,KAAKM,SAAT,IAAsB,KAAKrC,MAA3B,GAAoC,OAApC,GAA8C+B,IAAhE;AACA,cAAMO,OAAO,GAAG5B,IAAI,KAAK2B,SAAT,GAAqB,QAArB,GAAgC,GAAhD;AACA,cAAME,KAAK,GAAID,OAAO,KAAK,QAAb,GACR;AAAE/B,gBAAI,EAAJA;AAAF,WADQ,GAER;AACEiC,oBAAQ,EAAE,KAAKA,QADjB;AAEE9B,gBAAI,EAAJA,IAFF;AAGEmB,eAAG,EAAHA,GAHF;AAIEC,kBAAM,EAANA;AAJF,WAFN;AAQA,cAAIW,IAAI,GAAG,KAAKA,IAAhB;;AACA,cAAIA,IAAI,KAAKJ,SAAb,EAAwB;AACpBI,gBAAI,GAAG,KAAKvC,SAAL,IAAkB,KAAKD,YAAvB,GAAsC,OAAtC,GAAgD,OAAvD;AACH;;AACD,iBAAQ,6DAAE,oDAAF,EAAQ;AAAEyC,mBAAO,EAAE,KAAKlC,WAAhB;AAA6B,6BAAiBJ,QAAQ,GAAG,MAAH,GAAY,IAAlE;AAAwE,qBAAOuC,MAAM,CAACC,MAAP,CAAcD,MAAM,CAACC,MAAP,CAAc,EAAd,EAAkB,6DAAqBZ,KAArB,CAAlB,CAAd,wDAAiEJ,IAAjE,EAAwE,IAAxE,mCAA+EzB,UAA/E,EAA4F,IAA5F,6CAAsGA,UAAtG,cAAoH8B,MAApH,GAA+HA,MAAM,KAAKI,SAA1I,6CAAyJlC,UAAzJ,cAAuKiC,SAAvK,GAAqLA,SAAS,KAAKC,SAAnM,6CAAkNlC,UAAlN,cAAgOgC,KAAhO,GAA0OA,KAAK,KAAKE,SAApP,6CAAmQlC,UAAnQ,cAAiRsC,IAAjR,GAA0R,IAA1R,6CAAoStC,UAApS,cAA0TG,MAA1T,mCAAkU,YAAlU,EAAgV,6DAAY,aAAZ,EAA2B,KAAKK,EAAhC,CAAhV,mCAAqX,kBAArX,EAAyY,6DAAY,oBAAZ,EAAkC,KAAKA,EAAvC,CAAzY,mCAAqb,sBAArb,EAA6cuB,WAA7c,mCAA0d,iBAA1d,EAA6e9B,QAA7e,mCAAuf,iBAAvf,EAA0gB,IAA1gB,mCAAghB,eAAhhB,EAAiiB,IAAjiB;AAA/E,WAAR,EAAmoB,6DAAEkC,OAAF,EAAWK,MAAM,CAACC,MAAP,CAAc,EAAd,EAAkBL,KAAlB,EAAyB;AAAE,qBAAO,eAAT;AAA0BnC,oBAAQ,EAAEA,QAApC;AAA8CmB,mBAAO,EAAE,KAAKA,OAA5D;AAAqEG,kBAAM,EAAE,KAAKA;AAAlF,WAAzB,CAAX,EAAiI,6DAAE,MAAF,EAAU;AAAE,qBAAO;AAAT,WAAV,EAAqC,6DAAE,MAAF,EAAU;AAAEmB,gBAAI,EAAE;AAAR,WAAV,CAArC,EAAuE,6DAAE,MAAF,EAAU;AAAEA,gBAAI,EAAE;AAAR,WAAV,CAAvE,EAAqG,6DAAE,MAAF,EAAU,IAAV,CAArG,EAAsH,6DAAE,MAAF,EAAU;AAAEA,gBAAI,EAAE;AAAR,WAAV,CAAtH,CAAjI,EAAoRjB,IAAI,KAAK,IAAT,IAAiB,6DAAE,mBAAF,EAAuB;AAAErB,gBAAI,EAAE,KAAKuC;AAAb,WAAvB,CAArS,CAAnoB,CAAR;AACH;AA3FO;AAAA;AAAA,4BA6DU;AACd,iBAAO,CAAC,CAAC,KAAKnC,EAAL,CAAQoC,aAAR,CAAsB,4BAAtB,CAAT;AACH;AA/DO;AAAA;AAAA,4BAgES;AACb,cAAMC,YAAY,GAAG,KAAKP,IAAL,KAAcJ,SAAd,IAA2B,KAAKI,IAAL,KAAc,OAA9D,CADa,CAEb;AACA;;AACA,cAAIO,YAAY,IAAI,KAAKd,WAArB,IAAoC,KAAKhC,SAA7C,EAAwD;AACpD,mBAAO,WAAP;AACH;;AACD,iBAAO,SAAP;AACH;AAxEO;AAAA;AAAA,4BA4FC;AAAE,iBAAO,6DAAW,IAAX,CAAP;AAA0B;AA5F7B;;AAAA;AAAA,OAAZ;;AA8FAJ,UAAM,CAACoB,KAAP,GAAe;AACX;AAAqB+B,SAAG,EAAErD,YADf;;AAEX;AAAoBsD,QAAE,EAAErD;AAFb,KAAf;;AAKA,QAAMsD,eAAe,GAAG,SAAlBA,eAAkB,CAACC,UAAD,EAAgB;AACpC,UAAIA,UAAU,IAAI,OAAOpC,QAAP,KAAoB,WAAtC,EAAmD;AAC/C,YAAMqC,GAAG,GAAGrC,QAAQ,CAACC,aAAT,CAAuB,KAAvB,CAAZ;AACAoC,WAAG,CAACC,SAAJ,GAAgBF,UAAhB,CAF+C,CAG/C;;AACA,aAAK,IAAIG,CAAC,GAAGF,GAAG,CAACG,UAAJ,CAAeC,MAAf,GAAwB,CAArC,EAAwCF,CAAC,IAAI,CAA7C,EAAgDA,CAAC,EAAjD,EAAqD;AACjD,cAAIF,GAAG,CAACG,UAAJ,CAAeD,CAAf,EAAkBG,QAAlB,CAA2BC,WAA3B,OAA6C,KAAjD,EAAwD;AACpDN,eAAG,CAACO,WAAJ,CAAgBP,GAAG,CAACG,UAAJ,CAAeD,CAAf,CAAhB;AACH;AACJ,SAR8C,CAS/C;;;AACA,YAAMM,MAAM,GAAGR,GAAG,CAACS,iBAAnB;;AACA,YAAID,MAAM,IAAIA,MAAM,CAACH,QAAP,CAAgBC,WAAhB,OAAkC,KAAhD,EAAuD;AACnD,cAAMI,QAAQ,GAAGF,MAAM,CAACG,YAAP,CAAoB,OAApB,KAAgC,EAAjD;AACAH,gBAAM,CAACI,YAAP,CAAoB,OAApB,EAA6B,CAACF,QAAQ,GAAG,aAAZ,EAA2BG,IAA3B,EAA7B,EAFmD,CAGnD;AACA;AACA;;AACA,cAAIC,OAAO,CAACN,MAAD,CAAX,EAAqB;AACjB,mBAAOR,GAAG,CAACC,SAAX;AACH;AACJ;AACJ;;AACD,aAAO,EAAP;AACH,KAxBD;;AAyBA,QAAMa,OAAO,GAAG,SAAVA,OAAU,CAACC,GAAD,EAAS;AACrB,UAAIA,GAAG,CAACC,QAAJ,KAAiB,CAArB,EAAwB;AACpB,YAAID,GAAG,CAACV,QAAJ,CAAaC,WAAb,OAA+B,QAAnC,EAA6C;AACzC,iBAAO,KAAP;AACH;;AACD,aAAK,IAAIJ,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGa,GAAG,CAACE,UAAJ,CAAeb,MAAnC,EAA2CF,CAAC,EAA5C,EAAgD;AAC5C,cAAMgB,GAAG,GAAGH,GAAG,CAACE,UAAJ,CAAef,CAAf,EAAkBiB,KAA9B;;AACA,cAAI,6DAAMD,GAAN,KAAcA,GAAG,CAACZ,WAAJ,GAAkBc,OAAlB,CAA0B,IAA1B,MAAoC,CAAtD,EAAyD;AACrD,mBAAO,KAAP;AACH;AACJ;;AACD,aAAK,IAAIlB,EAAC,GAAG,CAAb,EAAgBA,EAAC,GAAGa,GAAG,CAACZ,UAAJ,CAAeC,MAAnC,EAA2CF,EAAC,EAA5C,EAAgD;AAC5C,cAAI,CAACY,OAAO,CAACC,GAAG,CAACZ,UAAJ,CAAeD,EAAf,CAAD,CAAZ,EAAiC;AAC7B,mBAAO,KAAP;AACH;AACJ;AACJ;;AACD,aAAO,IAAP;AACH,KAlBD;;AAoBA,QAAMmB,cAAc,GAAG,IAAIC,GAAJ,EAAvB;AACA,QAAMC,QAAQ,GAAG,IAAID,GAAJ,EAAjB;;AACA,QAAME,aAAa,GAAG,SAAhBA,aAAgB,CAACC,GAAD,EAAS;AAC3B;AACA,UAAIC,GAAG,GAAGH,QAAQ,CAACI,GAAT,CAAaF,GAAb,CAAV;;AACA,UAAI,CAACC,GAAL,EAAU;AACN,YAAI,OAAOE,KAAP,KAAiB,WAArB,EAAkC;AAC9B;AACAF,aAAG,GAAGE,KAAK,CAACH,GAAD,CAAL,CAAWI,IAAX,CAAgB,UAAAC,GAAG,EAAI;AACzB,gBAAIA,GAAG,CAACC,EAAR,EAAY;AACR,qBAAOD,GAAG,CAACE,IAAJ,GAAWH,IAAX,CAAgB,UAAA9B,UAAU,EAAI;AACjCsB,8BAAc,CAACY,GAAf,CAAmBR,GAAnB,EAAwB3B,eAAe,CAACC,UAAD,CAAvC;AACH,eAFM,CAAP;AAGH;;AACDsB,0BAAc,CAACY,GAAf,CAAmBR,GAAnB,EAAwB,EAAxB;AACH,WAPK,CAAN,CAF8B,CAU9B;;AACAF,kBAAQ,CAACU,GAAT,CAAaR,GAAb,EAAkBC,GAAlB;AACH,SAZD,MAaK;AACD;AACAL,wBAAc,CAACY,GAAf,CAAmBR,GAAnB,EAAwB,EAAxB;AACA,iBAAOS,OAAO,CAACC,OAAR,EAAP;AACH;AACJ;;AACD,aAAOT,GAAP;AACH,KAxBD;;AA0BA,QAAMU,OAAO,GAAG,mwCAAhB;;AAEA,QAAMC,IAAI;AACN,oBAAY3F,OAAZ,EAAqB;AAAA;;AACjB,qEAAiB,IAAjB,EAAuBA,OAAvB;AACA,aAAK4F,SAAL,GAAiB,KAAjB;AACA;;;;AAGA,aAAK/D,IAAL,GAAYgE,UAAU,EAAtB;AACA;;;;;AAIA,aAAKC,IAAL,GAAY,KAAZ;AACH;;AAbK;AAAA;AAAA,4CAcc;AAAA;;AAChB;AACA;AACA;AACA,eAAKC,gBAAL,CAAsB,KAAKnF,EAA3B,EAA+B,MAA/B,EAAuC,YAAM;AACzC,kBAAI,CAACgF,SAAL,GAAiB,IAAjB;;AACA,kBAAI,CAACI,QAAL;AACH,WAHD;AAIH;AAtBK;AAAA;AAAA,+CAuBiB;AACnB,cAAI,KAAKC,EAAT,EAAa;AACT,iBAAKA,EAAL,CAAQC,UAAR;AACA,iBAAKD,EAAL,GAAU3D,SAAV;AACH;AACJ;AA5BK;AAAA;AAAA,yCA6BW1B,EA7BX,EA6BeuF,UA7Bf,EA6B2BC,EA7B3B,EA6B+B;AAAA;;AACjC,cAAK,KAAKN,IAAL,IAAa,OAAOO,MAAP,KAAkB,WAA/B,IAA8CA,MAAM,CAACC,oBAA1D,EAAgF;AAC5E,gBAAML,EAAE,GAAG,KAAKA,EAAL,GAAU,IAAII,MAAM,CAACC,oBAAX,CAAgC,UAACC,IAAD,EAAU;AAC3D,kBAAIA,IAAI,CAAC,CAAD,CAAJ,CAAQC,cAAZ,EAA4B;AACxBP,kBAAE,CAACC,UAAH;AACA,sBAAI,CAACD,EAAL,GAAU3D,SAAV;AACA8D,kBAAE;AACL;AACJ,aANoB,EAMlB;AAAED,wBAAU,EAAVA;AAAF,aANkB,CAArB;AAOAF,cAAE,CAACQ,OAAH,CAAW7F,EAAX;AACH,WATD,MAUK;AACD;AACA;AACAwF,cAAE;AACL;AACJ;AA7CK;AAAA;AAAA,mCA8CK;AAAA;;AACP,cAAK,KAAKR,SAAV,EAAqB;AACjB,gBAAMb,GAAG,GAAG,6DAAO,IAAP,CAAZ;;AACA,gBAAIA,GAAJ,EAAS;AACL,kBAAIJ,cAAc,CAAC+B,GAAf,CAAmB3B,GAAnB,CAAJ,EAA6B;AACzB;AACA,qBAAK1B,UAAL,GAAkBsB,cAAc,CAACM,GAAf,CAAmBF,GAAnB,CAAlB;AACH,eAHD,MAIK;AACD;AACAD,6BAAa,CAACC,GAAD,CAAb,CAAmBI,IAAnB,CAAwB;AAAA,yBAAM,MAAI,CAAC9B,UAAL,GAAkBsB,cAAc,CAACM,GAAf,CAAmBF,GAAnB,CAAxB;AAAA,iBAAxB;AACH;AACJ;AACJ;;AACD,cAAI,CAAC,KAAK4B,SAAV,EAAqB;AACjB,gBAAMC,KAAK,GAAG,6DAAQ,KAAK9D,IAAb,EAAmB,KAAK+D,IAAxB,EAA8B,KAAKhF,IAAnC,EAAyC,KAAKqB,GAA9C,EAAmD,KAAKC,EAAxD,CAAd,CADiB,CAEjB;AACA;;AACA,gBAAIyD,KAAJ,EAAW;AACP,mBAAKD,SAAL,GAAiBC,KAAK,CAACE,OAAN,CAAc,KAAd,EAAqB,GAArB,CAAjB;AACH;AACJ;AACJ;AApEK;AAAA;AAAA,iCAqEG;AAAA;;AACL,cAAMjF,IAAI,GAAG,KAAKA,IAAL,IAAa,IAA1B;AACA,cAAMkF,OAAO,GAAG,KAAKA,OAAL,IAAiB,KAAKJ,SAAL,KAAmB,KAAKA,SAAL,CAAejC,OAAf,CAAuB,OAAvB,IAAkC,CAAC,CAAnC,IAAwC,KAAKiC,SAAL,CAAejC,OAAf,CAAuB,SAAvB,IAAoC,CAAC,CAAhG,KAAsG,KAAKqC,OAAL,KAAiB,KAAxJ;AACA,iBAAQ,6DAAE,oDAAF,EAAQ;AAAEC,gBAAI,EAAE,KAAR;AAAe,qBAAOpE,MAAM,CAACC,MAAP,CAAcD,MAAM,CAACC,MAAP,qBAAiBhB,IAAjB,EAAwB,IAAxB,GAAgCoF,kBAAkB,CAAC,KAAKhF,KAAN,CAAlD,CAAd,yEAA0F,KAAKD,IAA/F,GAAwG,CAAC,CAAC,KAAKA,IAA/G,oCAAqH,UAArH,EAAiI,CAAC,CAAC+E,OAAF,IAAa,KAAKnG,EAAL,CAAQsG,aAAR,CAAsBC,GAAtB,KAA8B,KAA5K;AAAtB,WAAR,EAAyN,KAAK9D,UAAP,GACzN,6DAAE,KAAF,EAAS;AAAE,qBAAO,YAAT;AAAuBE,qBAAS,EAAE,KAAKF;AAAvC,WAAT,CADyN,GAEzN,6DAAE,KAAF,EAAS;AAAE,qBAAO;AAAT,WAAT,CAFE,CAAR;AAGH;AA3EK;AAAA;AAAA,4BA6EG;AAAE,iBAAO,6DAAW,IAAX,CAAP;AAA0B;AA7E/B;AAAA;AAAA,4BA4EkB;AAAE,iBAAO,CAAC,KAAD,CAAP;AAAiB;AA5ErC;AAAA;AAAA,4BA8EgB;AAAE,iBAAO;AAC3B,oBAAQ,CAAC,UAAD,CADmB;AAE3B,mBAAO,CAAC,UAAD,CAFoB;AAG3B,oBAAQ,CAAC,UAAD;AAHmB,WAAP;AAIpB;AAlFE;;AAAA;AAAA,OAAV;;AAoFA,QAAMwC,UAAU,GAAG,SAAbA,UAAa;AAAA,aAAQ,OAAO5E,QAAP,KAAoB,WAApB,IAAmCA,QAAQ,CAACmG,eAAT,CAAyBnD,YAAzB,CAAsC,MAAtC,CAArC,IAAuF,IAA7F;AAAA,KAAnB;;AACA,QAAMgD,kBAAkB,GAAG,SAArBA,kBAAqB,CAAChF,KAAD,EAAW;AAClC,aAAQA,KAAD;AACH,qBAAa;AADV,6BAEWA,KAFX,GAEqB,IAFrB,IAGH,IAHJ;AAIH,KALD;;AAMA0D,QAAI,CAACxE,KAAL,GAAauE,OAAb","file":"12-es5.js","sourcesContent":["import { r as registerInstance, d as createEvent, h, H as Host, e as getElement } from './index-26ec602c.js';\nimport { b as getIonMode$1 } from './ionic-global-1bf1fa84.js';\nimport { i as isStr, g as getUrl, a as getName } from './utils-6acbf959.js';\nimport { h as hasShadowDom } from './helpers-d8b49b57.js';\nimport { o as openURL, c as createColorClasses$1, h as hostContext } from './theme-c2dc54d9.js';\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;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}}\";\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;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}}\";\n\nconst Button = class {\n constructor(hostRef) {\n registerInstance(this, hostRef);\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 = (ev) => {\n if (this.type === 'button') {\n openURL(this.href, ev, this.routerDirection);\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 <form>\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 this.ionFocus = createEvent(this, \"ionFocus\", 7);\n this.ionBlur = createEvent(this, \"ionBlur\", 7);\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 }\n get hasIconOnly() {\n return !!this.el.querySelector('ion-icon[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 } = 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: Object.assign(Object.assign({}, createColorClasses$1(color)), { [mode]: true, [buttonType]: true, [`${buttonType}-${expand}`]: expand !== undefined, [`${buttonType}-${finalSize}`]: finalSize !== undefined, [`${buttonType}-${shape}`]: shape !== undefined, [`${buttonType}-${fill}`]: true, [`${buttonType}-strong`]: strong, 'in-toolbar': hostContext('ion-toolbar', this.el), 'in-toolbar-color': hostContext('ion-toolbar[color]', this.el), 'button-has-icon-only': hasIconOnly, 'button-disabled': disabled, 'ion-activatable': true, 'ion-focusable': true }) }, h(TagType, Object.assign({}, attrs, { class: \"button-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 get el() { return getElement(this); }\n};\nButton.style = {\n /*STENCIL:MODE:ios*/ ios: buttonIosCss,\n /*STENCIL:MODE:md*/ md: buttonMdCss\n};\n\nconst validateContent = (svgContent) => {\r\n if (svgContent && typeof document !== 'undefined') {\r\n const div = document.createElement('div');\r\n div.innerHTML = svgContent;\r\n // setup this way to ensure it works on our buddy IE\r\n for (let i = div.childNodes.length - 1; i >= 0; i--) {\r\n if (div.childNodes[i].nodeName.toLowerCase() !== 'svg') {\r\n div.removeChild(div.childNodes[i]);\r\n }\r\n }\r\n // must only have 1 root element\r\n const svgElm = div.firstElementChild;\r\n if (svgElm && svgElm.nodeName.toLowerCase() === 'svg') {\r\n const svgClass = svgElm.getAttribute('class') || '';\r\n svgElm.setAttribute('class', (svgClass + ' s-ion-icon').trim());\r\n // root element must be an svg\r\n // lets double check we've got valid elements\r\n // do not allow scripts\r\n if (isValid(svgElm)) {\r\n return div.innerHTML;\r\n }\r\n }\r\n }\r\n return '';\r\n};\r\nconst isValid = (elm) => {\r\n if (elm.nodeType === 1) {\r\n if (elm.nodeName.toLowerCase() === 'script') {\r\n return false;\r\n }\r\n for (let i = 0; i < elm.attributes.length; i++) {\r\n const val = elm.attributes[i].value;\r\n if (isStr(val) && val.toLowerCase().indexOf('on') === 0) {\r\n return false;\r\n }\r\n }\r\n for (let i = 0; i < elm.childNodes.length; i++) {\r\n if (!isValid(elm.childNodes[i])) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n};\n\nconst ioniconContent = new Map();\r\nconst requests = new Map();\r\nconst getSvgContent = (url) => {\r\n // see if we already have a request for this url\r\n let req = requests.get(url);\r\n if (!req) {\r\n if (typeof fetch !== 'undefined') {\r\n // we don't already have a request\r\n req = fetch(url).then(rsp => {\r\n if (rsp.ok) {\r\n return rsp.text().then(svgContent => {\r\n ioniconContent.set(url, validateContent(svgContent));\r\n });\r\n }\r\n ioniconContent.set(url, '');\r\n });\r\n // cache for the same requests\r\n requests.set(url, req);\r\n }\r\n else {\r\n // set to empty for ssr scenarios and resolve promise\r\n ioniconContent.set(url, '');\r\n return Promise.resolve();\r\n }\r\n }\r\n return req;\r\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\nconst Icon = class {\n constructor(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 connectedCallback() {\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', () => {\n this.isVisible = true;\n this.loadIcon();\n });\n }\n disconnectedCallback() {\n if (this.io) {\n this.io.disconnect();\n this.io = undefined;\n }\n }\n waitUntilVisible(el, rootMargin, cb) {\n if ( this.lazy && typeof window !== 'undefined' && window.IntersectionObserver) {\n const io = this.io = new window.IntersectionObserver((data) => {\n if (data[0].isIntersecting) {\n io.disconnect();\n this.io = undefined;\n cb();\n }\n }, { rootMargin });\n io.observe(el);\n }\n else {\n // browser doesn't support IntersectionObserver\n // so just fallback to always show it\n cb();\n }\n }\n loadIcon() {\n if ( this.isVisible) {\n const url = getUrl(this);\n if (url) {\n if (ioniconContent.has(url)) {\n // sync if it's already loaded\n this.svgContent = ioniconContent.get(url);\n }\n else {\n // async if it hasn't been loaded\n getSvgContent(url).then(() => this.svgContent = ioniconContent.get(url));\n }\n }\n }\n if (!this.ariaLabel) {\n const 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 render() {\n const mode = this.mode || 'md';\n const 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({ [mode]: true }, createColorClasses(this.color)), { [`icon-${this.size}`]: !!this.size, 'flip-rtl': !!flipRtl && this.el.ownerDocument.dir === 'rtl' }) }, (( this.svgContent)\n ? h(\"div\", { class: \"icon-inner\", innerHTML: this.svgContent })\n : h(\"div\", { class: \"icon-inner\" }))));\n }\n static get assetsDirs() { return [\"svg\"]; }\n get el() { return getElement(this); }\n static get watchers() { return {\n \"name\": [\"loadIcon\"],\n \"src\": [\"loadIcon\"],\n \"icon\": [\"loadIcon\"]\n }; }\n};\nconst getIonMode = () => ( typeof document !== 'undefined' && document.documentElement.getAttribute('mode')) || 'md';\nconst createColorClasses = (color) => {\n return (color) ? {\n 'ion-color': true,\n [`ion-color-${color}`]: true\n } : null;\n};\nIcon.style = iconCss;\n\nexport { Button as ion_button, Icon as ion_icon };\n"]}