Files
2018-03-13 19:45:36 +01:00

53 lines
1.3 KiB
TypeScript

import { Component, Listen, Method } from '@stencil/core';
import { PickerOptions } from '../../index';
import { OverlayController, createOverlay, dismissOverlay, getTopOverlay, removeLastOverlay } from '../../utils/overlays';
@Component({
tag: 'ion-picker-controller'
})
export class PickerController implements OverlayController {
private pickers = new Map<number, HTMLIonPickerElement>();
@Listen('body:ionPickerWillPresent')
protected pickerWillPresent(ev: any) {
this.pickers.set(ev.target.overlayId, ev.target);
}
@Listen('body:ionPickerWillDismiss')
@Listen('body:ionPickerDidUnload')
protected pickerWillDismiss(ev: any) {
this.pickers.delete(ev.target.overlayId);
}
@Listen('body:keyup.escape')
protected escapeKeyUp() {
removeLastOverlay(this.pickers);
}
/*
* Create a picker overlay with picker options.
*/
@Method()
create(opts?: PickerOptions): Promise<HTMLIonPickerElement> {
return createOverlay(document.createElement('ion-picker'), opts);
}
/*
* Dismiss the open picker overlay.
*/
@Method()
dismiss(data?: any, role?: string, pickerId = -1) {
return dismissOverlay(data, role, this.pickers, pickerId);
}
/*
* Get the most recently opened picker overlay.
*/
@Method()
getTop(): HTMLIonPickerElement {
return getTopOverlay(this.pickers);
}
}