mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-18 03:00:58 +08:00
59 lines
1.4 KiB
TypeScript
59 lines
1.4 KiB
TypeScript
import { defineCustomElements } from '@ionic/core/loader';
|
|
import { Config } from './providers/config';
|
|
import { IonicWindow } from './types/interfaces';
|
|
|
|
// Webpack import for ionicons
|
|
// @ts-ignore
|
|
// tslint:disable-next-line:no-import-side-effect
|
|
import '@ionic/core/dist/ionic/svg';
|
|
|
|
export function appInitialize(config: Config) {
|
|
return () => {
|
|
const win: IonicWindow = window as any;
|
|
if (typeof win !== 'undefined') {
|
|
const Ionic = win.Ionic = win.Ionic || {};
|
|
|
|
Ionic.config = config;
|
|
Ionic.asyncQueue = false;
|
|
|
|
Ionic.ael = (elm, eventName, cb, opts) => {
|
|
if (elm.__zone_symbol__addEventListener && skipZone(eventName)) {
|
|
elm.__zone_symbol__addEventListener(eventName, cb, opts);
|
|
} else {
|
|
elm.addEventListener(eventName, cb, opts);
|
|
}
|
|
};
|
|
|
|
Ionic.rel = (elm, eventName, cb, opts) => {
|
|
if (elm.__zone_symbol__removeEventListener && skipZone(eventName)) {
|
|
elm.__zone_symbol__removeEventListener(eventName, cb, opts);
|
|
} else {
|
|
elm.removeEventListener(eventName, cb, opts);
|
|
}
|
|
};
|
|
|
|
// define all of Ionic's custom elements
|
|
defineCustomElements(win);
|
|
}
|
|
};
|
|
}
|
|
|
|
const SKIP_ZONE = [
|
|
'scroll',
|
|
'resize',
|
|
|
|
'touchstart',
|
|
'touchmove',
|
|
'touchend',
|
|
|
|
'mousedown',
|
|
'mousemove',
|
|
'mouseup',
|
|
|
|
'ionStyle',
|
|
];
|
|
|
|
function skipZone(eventName: string) {
|
|
return SKIP_ZONE.indexOf(eventName) >= 0;
|
|
}
|