mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-18 03:00:58 +08:00
38 lines
1.2 KiB
TypeScript
38 lines
1.2 KiB
TypeScript
import { NgZone } from '@angular/core';
|
|
import { setupConfig } from '@ionic/core';
|
|
import { applyPolyfills, defineCustomElements } from '@ionic/core/loader';
|
|
|
|
import { Config } from './providers/config';
|
|
import { IonicWindow } from './types/interfaces';
|
|
import { raf } from './util/util';
|
|
|
|
export const appInitialize = (config: Config, doc: Document, zone: NgZone) => {
|
|
return (): any => {
|
|
const win: IonicWindow | undefined = doc.defaultView as any;
|
|
if (win && typeof (window as any) !== 'undefined') {
|
|
setupConfig({
|
|
...config,
|
|
_zoneGate: (h: any) => zone.run(h),
|
|
});
|
|
|
|
const aelFn =
|
|
'__zone_symbol__addEventListener' in (doc.body as any) ? '__zone_symbol__addEventListener' : 'addEventListener';
|
|
|
|
return applyPolyfills().then(() => {
|
|
return defineCustomElements(win, {
|
|
exclude: ['ion-tabs', 'ion-tab'],
|
|
syncQueue: true,
|
|
raf,
|
|
jmp: (h: any) => zone.runOutsideAngular(h),
|
|
ael(elm, eventName, cb, opts) {
|
|
(elm as any)[aelFn](eventName, cb, opts);
|
|
},
|
|
rel(elm, eventName, cb, opts) {
|
|
elm.removeEventListener(eventName, cb, opts);
|
|
},
|
|
});
|
|
});
|
|
}
|
|
};
|
|
};
|