488 lines
50 KiB
JavaScript
488 lines
50 KiB
JavaScript
|
(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[1],{
|
||
|
|
||
|
/***/ "./node_modules/@ionic/core/dist/esm/ion-alert.entry.js":
|
||
|
/*!**************************************************************!*\
|
||
|
!*** ./node_modules/@ionic/core/dist/esm/ion-alert.entry.js ***!
|
||
|
\**************************************************************/
|
||
|
/*! exports provided: ion_alert */
|
||
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
||
|
|
||
|
"use strict";
|
||
|
__webpack_require__.r(__webpack_exports__);
|
||
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ion_alert", function() { return Alert; });
|
||
|
/* harmony import */ var _index_92848855_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./index-92848855.js */ "./node_modules/@ionic/core/dist/esm/index-92848855.js");
|
||
|
/* harmony import */ var _ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ionic-global-23e7365a.js */ "./node_modules/@ionic/core/dist/esm/ionic-global-23e7365a.js");
|
||
|
/* harmony import */ var _helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./helpers-5c745fbd.js */ "./node_modules/@ionic/core/dist/esm/helpers-5c745fbd.js");
|
||
|
/* harmony import */ var _animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./animation-a635a2fc.js */ "./node_modules/@ionic/core/dist/esm/animation-a635a2fc.js");
|
||
|
/* harmony import */ var _gesture_controller_89173521_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./gesture-controller-89173521.js */ "./node_modules/@ionic/core/dist/esm/gesture-controller-89173521.js");
|
||
|
/* harmony import */ var _index_eea61379_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./index-eea61379.js */ "./node_modules/@ionic/core/dist/esm/index-eea61379.js");
|
||
|
/* harmony import */ var _index_79d74e0b_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./index-79d74e0b.js */ "./node_modules/@ionic/core/dist/esm/index-79d74e0b.js");
|
||
|
/* harmony import */ var _hardware_back_button_7b6ede21_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./hardware-back-button-7b6ede21.js */ "./node_modules/@ionic/core/dist/esm/hardware-back-button-7b6ede21.js");
|
||
|
/* harmony import */ var _overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./overlays-c5d9d644.js */ "./node_modules/@ionic/core/dist/esm/overlays-c5d9d644.js");
|
||
|
/* harmony import */ var _haptic_7b8ba70a_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./haptic-7b8ba70a.js */ "./node_modules/@ionic/core/dist/esm/haptic-7b8ba70a.js");
|
||
|
/* harmony import */ var _button_active_5da929d4_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./button-active-5da929d4.js */ "./node_modules/@ionic/core/dist/esm/button-active-5da929d4.js");
|
||
|
/* harmony import */ var _theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./theme-5641d27f.js */ "./node_modules/@ionic/core/dist/esm/theme-5641d27f.js");
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
/**
|
||
|
* iOS Alert Enter Animation
|
||
|
*/
|
||
|
const iosEnterAnimation = (baseEl) => {
|
||
|
const baseAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const backdropAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const wrapperAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
backdropAnimation
|
||
|
.addElement(baseEl.querySelector('ion-backdrop'))
|
||
|
.fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
|
||
|
.beforeStyles({
|
||
|
'pointer-events': 'none'
|
||
|
})
|
||
|
.afterClearStyles(['pointer-events']);
|
||
|
wrapperAnimation
|
||
|
.addElement(baseEl.querySelector('.alert-wrapper'))
|
||
|
.keyframes([
|
||
|
{ offset: 0, opacity: '0.01', transform: 'scale(1.1)' },
|
||
|
{ offset: 1, opacity: '1', transform: 'scale(1)' }
|
||
|
]);
|
||
|
return baseAnimation
|
||
|
.addElement(baseEl)
|
||
|
.easing('ease-in-out')
|
||
|
.duration(200)
|
||
|
.addAnimation([backdropAnimation, wrapperAnimation]);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* iOS Alert Leave Animation
|
||
|
*/
|
||
|
const iosLeaveAnimation = (baseEl) => {
|
||
|
const baseAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const backdropAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const wrapperAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
backdropAnimation
|
||
|
.addElement(baseEl.querySelector('ion-backdrop'))
|
||
|
.fromTo('opacity', 'var(--backdrop-opacity)', 0);
|
||
|
wrapperAnimation
|
||
|
.addElement(baseEl.querySelector('.alert-wrapper'))
|
||
|
.keyframes([
|
||
|
{ offset: 0, opacity: 0.99, transform: 'scale(1)' },
|
||
|
{ offset: 1, opacity: 0, transform: 'scale(0.9)' }
|
||
|
]);
|
||
|
return baseAnimation
|
||
|
.addElement(baseEl)
|
||
|
.easing('ease-in-out')
|
||
|
.duration(200)
|
||
|
.addAnimation([backdropAnimation, wrapperAnimation]);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Md Alert Enter Animation
|
||
|
*/
|
||
|
const mdEnterAnimation = (baseEl) => {
|
||
|
const baseAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const backdropAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const wrapperAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
backdropAnimation
|
||
|
.addElement(baseEl.querySelector('ion-backdrop'))
|
||
|
.fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
|
||
|
.beforeStyles({
|
||
|
'pointer-events': 'none'
|
||
|
})
|
||
|
.afterClearStyles(['pointer-events']);
|
||
|
wrapperAnimation
|
||
|
.addElement(baseEl.querySelector('.alert-wrapper'))
|
||
|
.keyframes([
|
||
|
{ offset: 0, opacity: '0.01', transform: 'scale(0.9)' },
|
||
|
{ offset: 1, opacity: '1', transform: 'scale(1)' }
|
||
|
]);
|
||
|
return baseAnimation
|
||
|
.addElement(baseEl)
|
||
|
.easing('ease-in-out')
|
||
|
.duration(150)
|
||
|
.addAnimation([backdropAnimation, wrapperAnimation]);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Md Alert Leave Animation
|
||
|
*/
|
||
|
const mdLeaveAnimation = (baseEl) => {
|
||
|
const baseAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const backdropAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
const wrapperAnimation = Object(_animation_a635a2fc_js__WEBPACK_IMPORTED_MODULE_3__["c"])();
|
||
|
backdropAnimation
|
||
|
.addElement(baseEl.querySelector('ion-backdrop'))
|
||
|
.fromTo('opacity', 'var(--backdrop-opacity)', 0);
|
||
|
wrapperAnimation
|
||
|
.addElement(baseEl.querySelector('.alert-wrapper'))
|
||
|
.fromTo('opacity', 0.99, 0);
|
||
|
return baseAnimation
|
||
|
.addElement(baseEl)
|
||
|
.easing('ease-in-out')
|
||
|
.duration(150)
|
||
|
.addAnimation([backdropAnimation, wrapperAnimation]);
|
||
|
};
|
||
|
|
||
|
const alertIosCss = ".sc-ion-alert-ios-h{--min-width:250px;--width:auto;--min-height:auto;--height:auto;--max-height:90%;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-ms-touch-action:none;touch-action:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}.overlay-hidden.sc-ion-alert-ios-h{display:none}.alert-top.sc-ion-alert-ios-h{padding-top:50px;-ms-flex-align:start;align-items:flex-start}.alert-wrapper.sc-ion-alert-ios{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);contain:content;opacity:0;z-index:10}.alert-title.sc-ion-alert-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}.alert-sub-title.sc-ion-alert-ios{margin-left:0;margin-right:0;margin-top:5px;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;font-weight:normal}.alert-message.sc-ion-alert-ios{-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-overflow-scrolling:touch;overflow-y:auto;overscroll-behavior-y:contain}.alert-checkbox-group.sc-ion-alert-ios::-webkit-scrollbar,.alert-radio-group.sc-ion-alert-ios::-webkit-scrollbar,.alert-message.sc-ion-alert-ios::-webkit-scrollbar{display:none}.alert-input.sc-ion-alert-ios{padding-left:0;padding-right:0;padding-top:10px;padding-bottom:10px;width:100%;border:0;background:inherit;font:inherit;-webkit-box-sizing:border-box;box-sizing:border-box}.alert-button-group.sc-ion-alert-ios{display:-ms-flexbox;display:flex;-ms-flex-direction:row;flex-direction:row;width:100%}.alert-button-group-vertical.sc-ion-alert-ios{-ms-flex-direction:column;flex-direction:column;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.alert-button.sc-ion-alert-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:block;border:0;font-size:14px;line-height:20px;z-index:0}.alert-button.ion-focused.sc-ion-alert-ios,.alert-tappable.ion-focused.sc-ion-alert-ios{background:var(--ion-color-step-100, #e6e6e6)}.alert-button-inner.sc-ion-alert-ios{display:-ms-flexbox;display:flex;-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%}.alert-input-disabled.sc-ion-alert-ios,.alert-checkbox-button-disabled.sc-ion-alert-ios .alert-button-inner.sc-ion-alert-ios,.alert-radio-button-disabled.sc-ion-alert-ios .alert-button-inner.sc-ion-alert-ios{cursor:default;opacity:0.5;pointer-events:none}.alert-tappable.sc-ion-alert-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;display:-ms-flexbox;display:flex;width:100%;border:0;background:transparent;font-size:inherit;line-height:initial;text-align:start;-webkit-appearance:none;-moz-appearance:none;appearance:none;contain:strict}.alert-button.sc-ion-alert-ios,.alert-checkbox.sc-ion-alert-ios,.alert-input.sc-ion-alert-ios,.alert-radio.sc-ion-alert-ios{outline:none}.alert-radio-icon.sc-ion-alert-ios,.alert-checkbox-icon.sc-ion-alert-ios,.alert-checkbox-inner.sc-ion-alert-ios{-webkit-box-sizing:border-box;box-sizing:border-box}textarea.alert-input.sc-ion-alert-ios{min-height:37px;resize:none}.sc-ion-alert-ios-h{--background:var(--ion-overlay-background-color, var(--ion-color-step-100, #f9f9f9));--max-width:270px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.3);font-size:14px}.alert-wrapper.sc-ion-alert-ios{border-radius:13px;-webkit-box-shadow:none;box-shadow:none;overflow:hidden}.alert-button.sc-ion-alert-ios .alert-button-inner.sc-ion-alert-ios{pointer-events:none}@supports ((-webkit-backdro
|
||
|
|
||
|
const alertMdCss = ".sc-ion-alert-md-h{--min-width:250px;--width:auto;--min-height:auto;--height:auto;--max-height:90%;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-ms-touch-action:none;touch-action:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}.overlay-hidden.sc-ion-alert-md-h{display:none}.alert-top.sc-ion-alert-md-h{padding-top:50px;-ms-flex-align:start;align-items:flex-start}.alert-wrapper.sc-ion-alert-md{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);contain:content;opacity:0;z-index:10}.alert-title.sc-ion-alert-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}.alert-sub-title.sc-ion-alert-md{margin-left:0;margin-right:0;margin-top:5px;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;font-weight:normal}.alert-message.sc-ion-alert-md{-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-overflow-scrolling:touch;overflow-y:auto;overscroll-behavior-y:contain}.alert-checkbox-group.sc-ion-alert-md::-webkit-scrollbar,.alert-radio-group.sc-ion-alert-md::-webkit-scrollbar,.alert-message.sc-ion-alert-md::-webkit-scrollbar{display:none}.alert-input.sc-ion-alert-md{padding-left:0;padding-right:0;padding-top:10px;padding-bottom:10px;width:100%;border:0;background:inherit;font:inherit;-webkit-box-sizing:border-box;box-sizing:border-box}.alert-button-group.sc-ion-alert-md{display:-ms-flexbox;display:flex;-ms-flex-direction:row;flex-direction:row;width:100%}.alert-button-group-vertical.sc-ion-alert-md{-ms-flex-direction:column;flex-direction:column;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.alert-button.sc-ion-alert-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:block;border:0;font-size:14px;line-height:20px;z-index:0}.alert-button.ion-focused.sc-ion-alert-md,.alert-tappable.ion-focused.sc-ion-alert-md{background:var(--ion-color-step-100, #e6e6e6)}.alert-button-inner.sc-ion-alert-md{display:-ms-flexbox;display:flex;-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%}.alert-input-disabled.sc-ion-alert-md,.alert-checkbox-button-disabled.sc-ion-alert-md .alert-button-inner.sc-ion-alert-md,.alert-radio-button-disabled.sc-ion-alert-md .alert-button-inner.sc-ion-alert-md{cursor:default;opacity:0.5;pointer-events:none}.alert-tappable.sc-ion-alert-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;display:-ms-flexbox;display:flex;width:100%;border:0;background:transparent;font-size:inherit;line-height:initial;text-align:start;-webkit-appearance:none;-moz-appearance:none;appearance:none;contain:strict}.alert-button.sc-ion-alert-md,.alert-checkbox.sc-ion-alert-md,.alert-input.sc-ion-alert-md,.alert-radio.sc-ion-alert-md{outline:none}.alert-radio-icon.sc-ion-alert-md,.alert-checkbox-icon.sc-ion-alert-md,.alert-checkbox-inner.sc-ion-alert-md{-webkit-box-sizing:border-box;box-sizing:border-box}textarea.alert-input.sc-ion-alert-md{min-height:37px;resize:none}.sc-ion-alert-md-h{--background:var(--ion-overlay-background-color, var(--ion-background-color, #fff));--max-width:280px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.32);font-size:14px}.alert-wrapper.sc-ion-alert-md{border-radius:4px;-webkit-box-shadow:0 11px 15px -7px rgba(0, 0, 0, 0.2), 0 24px 38px 3px rgba(0, 0, 0, 0.14), 0 9px 46px 8px rgba(0, 0, 0, 0.12);box-shadow:0 11px 15px -7px rgba(0, 0, 0, 0.2), 0 24px 38px 3px rgba(0, 0, 0,
|
||
|
|
||
|
const Alert = class {
|
||
|
constructor(hostRef) {
|
||
|
Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["r"])(this, hostRef);
|
||
|
this.didPresent = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionAlertDidPresent", 7);
|
||
|
this.willPresent = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionAlertWillPresent", 7);
|
||
|
this.willDismiss = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionAlertWillDismiss", 7);
|
||
|
this.didDismiss = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionAlertDidDismiss", 7);
|
||
|
this.processedInputs = [];
|
||
|
this.processedButtons = [];
|
||
|
this.presented = false;
|
||
|
/**
|
||
|
* If `true`, the keyboard will be automatically dismissed when the overlay is presented.
|
||
|
*/
|
||
|
this.keyboardClose = true;
|
||
|
/**
|
||
|
* Array of buttons to be added to the alert.
|
||
|
*/
|
||
|
this.buttons = [];
|
||
|
/**
|
||
|
* Array of input to show in the alert.
|
||
|
*/
|
||
|
this.inputs = [];
|
||
|
/**
|
||
|
* If `true`, the alert will be dismissed when the backdrop is clicked.
|
||
|
*/
|
||
|
this.backdropDismiss = true;
|
||
|
/**
|
||
|
* If `true`, the alert will be translucent.
|
||
|
* Only applies when the mode is `"ios"` and the device supports
|
||
|
* [`backdrop-filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter#Browser_compatibility).
|
||
|
*/
|
||
|
this.translucent = false;
|
||
|
/**
|
||
|
* If `true`, the alert will animate.
|
||
|
*/
|
||
|
this.animated = true;
|
||
|
this.onBackdropTap = () => {
|
||
|
this.dismiss(undefined, _overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["B"]);
|
||
|
};
|
||
|
this.dispatchCancelHandler = (ev) => {
|
||
|
const role = ev.detail.role;
|
||
|
if (Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["i"])(role)) {
|
||
|
const cancelButton = this.processedButtons.find(b => b.role === 'cancel');
|
||
|
this.callButtonHandler(cancelButton);
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
onKeydown(ev) {
|
||
|
const inputTypes = new Set(this.processedInputs.map(i => i.type));
|
||
|
// The only inputs we want to navigate between using arrow keys are the radios
|
||
|
// ignore the keydown event if it is not on a radio button
|
||
|
if (!inputTypes.has('radio')
|
||
|
|| (ev.target && !this.el.contains(ev.target))
|
||
|
|| ev.target.classList.contains('alert-button')) {
|
||
|
return;
|
||
|
}
|
||
|
// Get all radios inside of the radio group and then
|
||
|
// filter out disabled radios since we need to skip those
|
||
|
const query = this.el.querySelectorAll('.alert-radio');
|
||
|
const radios = Array.from(query).filter(radio => !radio.disabled);
|
||
|
// The focused radio is the one that shares the same id as
|
||
|
// the event target
|
||
|
const index = radios.findIndex(radio => radio.id === ev.target.id);
|
||
|
// We need to know what the next radio element should
|
||
|
// be in order to change the focus
|
||
|
let nextEl;
|
||
|
// If hitting arrow down or arrow right, move to the next radio
|
||
|
// If we're on the last radio, move to the first radio
|
||
|
if (['ArrowDown', 'ArrowRight'].includes(ev.key)) {
|
||
|
nextEl = (index === radios.length - 1)
|
||
|
? radios[0]
|
||
|
: radios[index + 1];
|
||
|
}
|
||
|
// If hitting arrow up or arrow left, move to the previous radio
|
||
|
// If we're on the first radio, move to the last radio
|
||
|
if (['ArrowUp', 'ArrowLeft'].includes(ev.key)) {
|
||
|
nextEl = (index === 0)
|
||
|
? radios[radios.length - 1]
|
||
|
: radios[index - 1];
|
||
|
}
|
||
|
if (nextEl && radios.includes(nextEl)) {
|
||
|
const nextProcessed = this.processedInputs.find(input => input.id === (nextEl === null || nextEl === void 0 ? void 0 : nextEl.id));
|
||
|
if (nextProcessed) {
|
||
|
this.rbClick(nextProcessed);
|
||
|
nextEl.focus();
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
buttonsChanged() {
|
||
|
const buttons = this.buttons;
|
||
|
this.processedButtons = buttons.map(btn => {
|
||
|
return (typeof btn === 'string')
|
||
|
? { text: btn, role: btn.toLowerCase() === 'cancel' ? 'cancel' : undefined }
|
||
|
: btn;
|
||
|
});
|
||
|
}
|
||
|
inputsChanged() {
|
||
|
const inputs = this.inputs;
|
||
|
// Get the first input that is not disabled and the checked one
|
||
|
// If an enabled checked input exists, set it to be the focusable input
|
||
|
// otherwise we default to focus the first input
|
||
|
// This will only be used when the input is type radio
|
||
|
const first = inputs.find(input => !input.disabled);
|
||
|
const checked = inputs.find(input => input.checked && !input.disabled);
|
||
|
const focusable = checked || first;
|
||
|
// An alert can be created with several different inputs. Radios,
|
||
|
// checkboxes and inputs are all accepted, but they cannot be mixed.
|
||
|
const inputTypes = new Set(inputs.map(i => i.type));
|
||
|
if (inputTypes.has('checkbox') && inputTypes.has('radio')) {
|
||
|
console.warn(`Alert cannot mix input types: ${(Array.from(inputTypes.values()).join('/'))}. Please see alert docs for more info.`);
|
||
|
}
|
||
|
this.inputType = inputTypes.values().next().value;
|
||
|
this.processedInputs = inputs.map((i, index) => ({
|
||
|
type: i.type || 'text',
|
||
|
name: i.name || `${index}`,
|
||
|
placeholder: i.placeholder || '',
|
||
|
value: i.value,
|
||
|
label: i.label,
|
||
|
checked: !!i.checked,
|
||
|
disabled: !!i.disabled,
|
||
|
id: i.id || `alert-input-${this.overlayIndex}-${index}`,
|
||
|
handler: i.handler,
|
||
|
min: i.min,
|
||
|
max: i.max,
|
||
|
cssClass: i.cssClass || '',
|
||
|
attributes: i.attributes || {},
|
||
|
tabindex: (i.type === 'radio' && i !== focusable) ? -1 : 0
|
||
|
}));
|
||
|
}
|
||
|
connectedCallback() {
|
||
|
Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["e"])(this.el);
|
||
|
}
|
||
|
componentWillLoad() {
|
||
|
this.inputsChanged();
|
||
|
this.buttonsChanged();
|
||
|
}
|
||
|
disconnectedCallback() {
|
||
|
if (this.gesture) {
|
||
|
this.gesture.destroy();
|
||
|
this.gesture = undefined;
|
||
|
}
|
||
|
}
|
||
|
componentDidLoad() {
|
||
|
/**
|
||
|
* Do not create gesture if:
|
||
|
* 1. A gesture already exists
|
||
|
* 2. App is running in MD mode
|
||
|
* 3. A wrapper ref does not exist
|
||
|
*/
|
||
|
if (this.gesture || Object(_ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["b"])(this) === 'md' || !this.wrapperEl) {
|
||
|
return;
|
||
|
}
|
||
|
this.gesture = Object(_button_active_5da929d4_js__WEBPACK_IMPORTED_MODULE_10__["c"])(this.wrapperEl, (refEl) => refEl.classList.contains('alert-button'));
|
||
|
this.gesture.enable(true);
|
||
|
}
|
||
|
/**
|
||
|
* Present the alert overlay after it has been created.
|
||
|
*/
|
||
|
present() {
|
||
|
return Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["d"])(this, 'alertEnter', iosEnterAnimation, mdEnterAnimation);
|
||
|
}
|
||
|
/**
|
||
|
* Dismiss the alert overlay after it has been presented.
|
||
|
*
|
||
|
* @param data Any data to emit in the dismiss events.
|
||
|
* @param role The role of the element that is dismissing the alert.
|
||
|
* This can be useful in a button handler for determining which button was
|
||
|
* clicked to dismiss the alert.
|
||
|
* Some examples include: ``"cancel"`, `"destructive"`, "selected"`, and `"backdrop"`.
|
||
|
*/
|
||
|
dismiss(data, role) {
|
||
|
return Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["f"])(this, data, role, 'alertLeave', iosLeaveAnimation, mdLeaveAnimation);
|
||
|
}
|
||
|
/**
|
||
|
* Returns a promise that resolves when the alert did dismiss.
|
||
|
*/
|
||
|
onDidDismiss() {
|
||
|
return Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["g"])(this.el, 'ionAlertDidDismiss');
|
||
|
}
|
||
|
/**
|
||
|
* Returns a promise that resolves when the alert will dismiss.
|
||
|
*/
|
||
|
onWillDismiss() {
|
||
|
return Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["g"])(this.el, 'ionAlertWillDismiss');
|
||
|
}
|
||
|
rbClick(selectedInput) {
|
||
|
for (const input of this.processedInputs) {
|
||
|
input.checked = input === selectedInput;
|
||
|
input.tabindex = input === selectedInput ? 0 : -1;
|
||
|
}
|
||
|
this.activeId = selectedInput.id;
|
||
|
Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["s"])(selectedInput.handler, selectedInput);
|
||
|
Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["j"])(this);
|
||
|
}
|
||
|
cbClick(selectedInput) {
|
||
|
selectedInput.checked = !selectedInput.checked;
|
||
|
Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["s"])(selectedInput.handler, selectedInput);
|
||
|
Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["j"])(this);
|
||
|
}
|
||
|
buttonClick(button) {
|
||
|
const role = button.role;
|
||
|
const values = this.getValues();
|
||
|
if (Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["i"])(role)) {
|
||
|
return this.dismiss({ values }, role);
|
||
|
}
|
||
|
const returnData = this.callButtonHandler(button, values);
|
||
|
if (returnData !== false) {
|
||
|
return this.dismiss(Object.assign({ values }, returnData), button.role);
|
||
|
}
|
||
|
return Promise.resolve(false);
|
||
|
}
|
||
|
callButtonHandler(button, data) {
|
||
|
if (button && button.handler) {
|
||
|
// a handler has been provided, execute it
|
||
|
// pass the handler the values from the inputs
|
||
|
const returnData = Object(_overlays_c5d9d644_js__WEBPACK_IMPORTED_MODULE_8__["s"])(button.handler, data);
|
||
|
if (returnData === false) {
|
||
|
// if the return value of the handler is false then do not dismiss
|
||
|
return false;
|
||
|
}
|
||
|
if (typeof returnData === 'object') {
|
||
|
return returnData;
|
||
|
}
|
||
|
}
|
||
|
return {};
|
||
|
}
|
||
|
getValues() {
|
||
|
if (this.processedInputs.length === 0) {
|
||
|
// this is an alert without any options/inputs at all
|
||
|
return undefined;
|
||
|
}
|
||
|
if (this.inputType === 'radio') {
|
||
|
// this is an alert with radio buttons (single value select)
|
||
|
// return the one value which is checked, otherwise undefined
|
||
|
const checkedInput = this.processedInputs.find(i => !!i.checked);
|
||
|
return checkedInput ? checkedInput.value : undefined;
|
||
|
}
|
||
|
if (this.inputType === 'checkbox') {
|
||
|
// this is an alert with checkboxes (multiple value select)
|
||
|
// return an array of all the checked values
|
||
|
return this.processedInputs.filter(i => i.checked).map(i => i.value);
|
||
|
}
|
||
|
// this is an alert with text inputs
|
||
|
// return an object of all the values with the input name as the key
|
||
|
const values = {};
|
||
|
this.processedInputs.forEach(i => {
|
||
|
values[i.name] = i.value || '';
|
||
|
});
|
||
|
return values;
|
||
|
}
|
||
|
renderAlertInputs(labelledBy) {
|
||
|
switch (this.inputType) {
|
||
|
case 'checkbox': return this.renderCheckbox(labelledBy);
|
||
|
case 'radio': return this.renderRadio(labelledBy);
|
||
|
default: return this.renderInput(labelledBy);
|
||
|
}
|
||
|
}
|
||
|
renderCheckbox(labelledby) {
|
||
|
const inputs = this.processedInputs;
|
||
|
const mode = Object(_ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["b"])(this);
|
||
|
if (inputs.length === 0) {
|
||
|
return null;
|
||
|
}
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-checkbox-group", "aria-labelledby": labelledby }, inputs.map(i => (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("button", { type: "button", onClick: () => this.cbClick(i), "aria-checked": `${i.checked}`, id: i.id, disabled: i.disabled, tabIndex: i.tabindex, role: "checkbox", class: Object.assign(Object.assign({}, Object(_theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_11__["g"])(i.cssClass)), { 'alert-tappable': true, 'alert-checkbox': true, 'alert-checkbox-button': true, 'ion-focusable': true, 'alert-checkbox-button-disabled': i.disabled || false }) }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-button-inner" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-checkbox-icon" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-checkbox-inner" })), Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-checkbox-label" }, i.label)), mode === 'md' && Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("ion-ripple-effect", null))))));
|
||
|
}
|
||
|
renderRadio(labelledby) {
|
||
|
const inputs = this.processedInputs;
|
||
|
if (inputs.length === 0) {
|
||
|
return null;
|
||
|
}
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-radio-group", role: "radiogroup", "aria-labelledby": labelledby, "aria-activedescendant": this.activeId }, inputs.map(i => (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("button", { type: "button", onClick: () => this.rbClick(i), "aria-checked": `${i.checked}`, disabled: i.disabled, id: i.id, tabIndex: i.tabindex, class: Object.assign(Object.assign({}, Object(_theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_11__["g"])(i.cssClass)), { 'alert-radio-button': true, 'alert-tappable': true, 'alert-radio': true, 'ion-focusable': true, 'alert-radio-button-disabled': i.disabled || false }), role: "radio" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-button-inner" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-radio-icon" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-radio-inner" })), Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-radio-label" }, i.label)))))));
|
||
|
}
|
||
|
renderInput(labelledby) {
|
||
|
const inputs = this.processedInputs;
|
||
|
if (inputs.length === 0) {
|
||
|
return null;
|
||
|
}
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-input-group", "aria-labelledby": labelledby }, inputs.map(i => {
|
||
|
var _a, _b, _c, _d;
|
||
|
if (i.type === 'textarea') {
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-input-wrapper" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("textarea", Object.assign({ placeholder: i.placeholder, value: i.value, id: i.id, tabIndex: i.tabindex }, i.attributes, { disabled: (_b = (_a = i.attributes) === null || _a === void 0 ? void 0 : _a.disabled) !== null && _b !== void 0 ? _b : i.disabled, class: inputClass(i), onInput: e => {
|
||
|
var _a;
|
||
|
i.value = e.target.value;
|
||
|
if ((_a = i.attributes) === null || _a === void 0 ? void 0 : _a.onInput) {
|
||
|
i.attributes.onInput(e);
|
||
|
}
|
||
|
} }))));
|
||
|
}
|
||
|
else {
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-input-wrapper" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("input", Object.assign({ placeholder: i.placeholder, type: i.type, min: i.min, max: i.max, value: i.value, id: i.id, tabIndex: i.tabindex }, i.attributes, { disabled: (_d = (_c = i.attributes) === null || _c === void 0 ? void 0 : _c.disabled) !== null && _d !== void 0 ? _d : i.disabled, class: inputClass(i), onInput: e => {
|
||
|
var _a;
|
||
|
i.value = e.target.value;
|
||
|
if ((_a = i.attributes) === null || _a === void 0 ? void 0 : _a.onInput) {
|
||
|
i.attributes.onInput(e);
|
||
|
}
|
||
|
} }))));
|
||
|
}
|
||
|
})));
|
||
|
}
|
||
|
renderAlertButtons() {
|
||
|
const buttons = this.processedButtons;
|
||
|
const mode = Object(_ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["b"])(this);
|
||
|
const alertButtonGroupClass = {
|
||
|
'alert-button-group': true,
|
||
|
'alert-button-group-vertical': buttons.length > 2
|
||
|
};
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: alertButtonGroupClass }, buttons.map(button => Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("button", { type: "button", class: buttonClass(button), tabIndex: 0, onClick: () => this.buttonClick(button) }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("span", { class: "alert-button-inner" }, button.text), mode === 'md' && Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("ion-ripple-effect", null)))));
|
||
|
}
|
||
|
render() {
|
||
|
const { overlayIndex, header, subHeader } = this;
|
||
|
const mode = Object(_ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["b"])(this);
|
||
|
const hdrId = `alert-${overlayIndex}-hdr`;
|
||
|
const subHdrId = `alert-${overlayIndex}-sub-hdr`;
|
||
|
const msgId = `alert-${overlayIndex}-msg`;
|
||
|
let labelledById;
|
||
|
if (header !== undefined) {
|
||
|
labelledById = hdrId;
|
||
|
}
|
||
|
else if (subHeader !== undefined) {
|
||
|
labelledById = subHdrId;
|
||
|
}
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["H"], { role: "dialog", "aria-modal": "true", tabindex: "-1", style: {
|
||
|
zIndex: `${20000 + overlayIndex}`,
|
||
|
}, class: Object.assign(Object.assign({}, Object(_theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_11__["g"])(this.cssClass)), { [mode]: true, 'alert-translucent': this.translucent }), onIonAlertWillDismiss: this.dispatchCancelHandler, onIonBackdropTap: this.onBackdropTap }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("ion-backdrop", { tappable: this.backdropDismiss }), Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { tabindex: "0" }), Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-wrapper ion-overlay-wrapper", ref: el => this.wrapperEl = el }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "alert-head" }, header && Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("h2", { id: hdrId, class: "alert-title" }, header), subHeader && Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("h2", { id: subHdrId, class: "alert-sub-title" }, subHeader)), Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { id: msgId, class: "alert-message", innerHTML: Object(_index_79d74e0b_js__WEBPACK_IMPORTED_MODULE_6__["s"])(this.message) }), this.renderAlertInputs(labelledById), this.renderAlertButtons()), Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { tabindex: "0" })));
|
||
|
}
|
||
|
get el() { return Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["i"])(this); }
|
||
|
static get watchers() { return {
|
||
|
"buttons": ["buttonsChanged"],
|
||
|
"inputs": ["inputsChanged"]
|
||
|
}; }
|
||
|
};
|
||
|
const inputClass = (input) => {
|
||
|
var _a, _b, _c;
|
||
|
return Object.assign(Object.assign({ 'alert-input': true, 'alert-input-disabled': ((_b = (_a = input.attributes) === null || _a === void 0 ? void 0 : _a.disabled) !== null && _b !== void 0 ? _b : input.disabled) || false }, Object(_theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_11__["g"])(input.cssClass)), Object(_theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_11__["g"])(input.attributes ? (_c = input.attributes.class) === null || _c === void 0 ? void 0 : _c.toString() : ''));
|
||
|
};
|
||
|
const buttonClass = (button) => {
|
||
|
return Object.assign({ 'alert-button': true, 'ion-focusable': true, 'ion-activatable': true, [`alert-button-role-${button.role}`]: button.role !== undefined }, Object(_theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_11__["g"])(button.cssClass));
|
||
|
};
|
||
|
Alert.style = {
|
||
|
ios: alertIosCss,
|
||
|
md: alertMdCss
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
/***/ })
|
||
|
|
||
|
}]);
|
||
|
//# sourceMappingURL=1-es2015.js.map
|