357 lines
33 KiB
JavaScript
357 lines
33 KiB
JavaScript
|
(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[30],{
|
||
|
|
||
|
/***/ "./node_modules/@ionic/core/dist/esm/ion-searchbar.entry.js":
|
||
|
/*!******************************************************************!*\
|
||
|
!*** ./node_modules/@ionic/core/dist/esm/ion-searchbar.entry.js ***!
|
||
|
\******************************************************************/
|
||
|
/*! exports provided: ion_searchbar */
|
||
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
||
|
|
||
|
"use strict";
|
||
|
__webpack_require__.r(__webpack_exports__);
|
||
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ion_searchbar", function() { return Searchbar; });
|
||
|
/* 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 _theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./theme-5641d27f.js */ "./node_modules/@ionic/core/dist/esm/theme-5641d27f.js");
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
const searchbarIosCss = ".sc-ion-searchbar-ios-h{--placeholder-color:initial;--placeholder-font-style:initial;--placeholder-font-weight:initial;--placeholder-opacity:.5;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;width:100%;color:var(--color);font-family:var(--ion-font-family, inherit);-webkit-box-sizing:border-box;box-sizing:border-box}.ion-color.sc-ion-searchbar-ios-h{color:var(--ion-color-contrast)}.ion-color.sc-ion-searchbar-ios-h .searchbar-input.sc-ion-searchbar-ios{background:var(--ion-color-base)}.ion-color.sc-ion-searchbar-ios-h .searchbar-clear-button.sc-ion-searchbar-ios,.ion-color.sc-ion-searchbar-ios-h .searchbar-cancel-button.sc-ion-searchbar-ios,.ion-color.sc-ion-searchbar-ios-h .searchbar-search-icon.sc-ion-searchbar-ios{color:inherit}.searchbar-search-icon.sc-ion-searchbar-ios{color:var(--icon-color);pointer-events:none}.searchbar-input-container.sc-ion-searchbar-ios{display:block;position:relative;-ms-flex-negative:1;flex-shrink:1;width:100%}.searchbar-input.sc-ion-searchbar-ios{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;border-radius:var(--border-radius);display:block;width:100%;border:0;outline:none;background:var(--background);font-family:inherit;-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbar-input.sc-ion-searchbar-ios::-webkit-input-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-ios::-moz-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-ios:-ms-input-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-ios::-ms-input-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-ios::placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-ios::-webkit-search-cancel-button,.searchbar-input.sc-ion-searchbar-ios::-ms-clear{display:none}.searchbar-cancel-button.sc-ion-searchbar-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:none;height:100%;border:0;outline:none;color:var(--cancel-button-color);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbar-cancel-button.sc-ion-searchbar-ios>div.sc-ion-searchbar-ios{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.searchbar-clear-button.sc-ion-searchbar-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:none;min-height:0;outline:none;color:var(--clear-button-color);-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbar-has-value.searchbar-has-focus.sc-ion-searchbar-ios-h .searchbar-clear-button.sc-ion-searchbar-ios{display:block}.searchbar-disabled.sc-ion-searchbar-ios-h{cursor:default;opacity:0.4;pointer-events:none}.sc-ion-searchbar-ios-h{--background:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.07);--border-radius:10px;--box-shadow:none;--cancel-button-color:var(--ion-colo
|
||
|
|
||
|
const searchbarMdCss = ".sc-ion-searchbar-md-h{--placeholder-color:initial;--placeholder-font-style:initial;--placeholder-font-weight:initial;--placeholder-opacity:.5;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;width:100%;color:var(--color);font-family:var(--ion-font-family, inherit);-webkit-box-sizing:border-box;box-sizing:border-box}.ion-color.sc-ion-searchbar-md-h{color:var(--ion-color-contrast)}.ion-color.sc-ion-searchbar-md-h .searchbar-input.sc-ion-searchbar-md{background:var(--ion-color-base)}.ion-color.sc-ion-searchbar-md-h .searchbar-clear-button.sc-ion-searchbar-md,.ion-color.sc-ion-searchbar-md-h .searchbar-cancel-button.sc-ion-searchbar-md,.ion-color.sc-ion-searchbar-md-h .searchbar-search-icon.sc-ion-searchbar-md{color:inherit}.searchbar-search-icon.sc-ion-searchbar-md{color:var(--icon-color);pointer-events:none}.searchbar-input-container.sc-ion-searchbar-md{display:block;position:relative;-ms-flex-negative:1;flex-shrink:1;width:100%}.searchbar-input.sc-ion-searchbar-md{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;border-radius:var(--border-radius);display:block;width:100%;border:0;outline:none;background:var(--background);font-family:inherit;-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbar-input.sc-ion-searchbar-md::-webkit-input-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-md::-moz-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-md:-ms-input-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-md::-ms-input-placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-md::placeholder{color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.searchbar-input.sc-ion-searchbar-md::-webkit-search-cancel-button,.searchbar-input.sc-ion-searchbar-md::-ms-clear{display:none}.searchbar-cancel-button.sc-ion-searchbar-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:none;height:100%;border:0;outline:none;color:var(--cancel-button-color);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbar-cancel-button.sc-ion-searchbar-md>div.sc-ion-searchbar-md{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.searchbar-clear-button.sc-ion-searchbar-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:none;min-height:0;outline:none;color:var(--clear-button-color);-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbar-has-value.searchbar-has-focus.sc-ion-searchbar-md-h .searchbar-clear-button.sc-ion-searchbar-md{display:block}.searchbar-disabled.sc-ion-searchbar-md-h{cursor:default;opacity:0.4;pointer-events:none}.sc-ion-searchbar-md-h{--background:var(--ion-background-color, #fff);--border-radius:2px;--box-shadow:0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba
|
||
|
|
||
|
const Searchbar = class {
|
||
|
constructor(hostRef) {
|
||
|
Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["r"])(this, hostRef);
|
||
|
this.ionInput = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionInput", 7);
|
||
|
this.ionChange = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionChange", 7);
|
||
|
this.ionCancel = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionCancel", 7);
|
||
|
this.ionClear = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionClear", 7);
|
||
|
this.ionBlur = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionBlur", 7);
|
||
|
this.ionFocus = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionFocus", 7);
|
||
|
this.ionStyle = Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["e"])(this, "ionStyle", 7);
|
||
|
this.isCancelVisible = false;
|
||
|
this.shouldAlignLeft = true;
|
||
|
this.focused = false;
|
||
|
this.noAnimate = true;
|
||
|
/**
|
||
|
* If `true`, enable searchbar animation.
|
||
|
*/
|
||
|
this.animated = false;
|
||
|
/**
|
||
|
* Set the input's autocomplete property.
|
||
|
*/
|
||
|
this.autocomplete = 'off';
|
||
|
/**
|
||
|
* Set the input's autocorrect property.
|
||
|
*/
|
||
|
this.autocorrect = 'off';
|
||
|
/**
|
||
|
* Set the cancel button icon. Only applies to `md` mode.
|
||
|
* Defaults to `"arrow-back-sharp"`.
|
||
|
*/
|
||
|
this.cancelButtonIcon = _ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["c"].get('backButtonIcon', 'arrow-back-sharp');
|
||
|
/**
|
||
|
* Set the the cancel button text. Only applies to `ios` mode.
|
||
|
*/
|
||
|
this.cancelButtonText = 'Cancel';
|
||
|
/**
|
||
|
* Set the amount of time, in milliseconds, to wait to trigger the `ionChange` event after each keystroke.
|
||
|
*/
|
||
|
this.debounce = 250;
|
||
|
/**
|
||
|
* If `true`, the user cannot interact with the input.
|
||
|
*/
|
||
|
this.disabled = false;
|
||
|
/**
|
||
|
* Set the input's placeholder.
|
||
|
* `placeholder` can accept either plaintext or HTML as a string.
|
||
|
* To display characters normally reserved for HTML, they
|
||
|
* must be escaped. For example `<Ionic>` would become
|
||
|
* `<Ionic>`
|
||
|
*
|
||
|
* For more information: [Security Documentation](https://ionicframework.com/docs/faq/security)
|
||
|
*/
|
||
|
this.placeholder = 'Search';
|
||
|
/**
|
||
|
* Sets the behavior for the cancel button. Defaults to `"never"`.
|
||
|
* Setting to `"focus"` shows the cancel button on focus.
|
||
|
* Setting to `"never"` hides the cancel button.
|
||
|
* Setting to `"always"` shows the cancel button regardless
|
||
|
* of focus state.
|
||
|
*/
|
||
|
this.showCancelButton = 'never';
|
||
|
/**
|
||
|
* If `true`, enable spellcheck on the input.
|
||
|
*/
|
||
|
this.spellcheck = false;
|
||
|
/**
|
||
|
* Set the type of the input.
|
||
|
*/
|
||
|
this.type = 'search';
|
||
|
/**
|
||
|
* the value of the searchbar.
|
||
|
*/
|
||
|
this.value = '';
|
||
|
/**
|
||
|
* Clears the input field and triggers the control change.
|
||
|
*/
|
||
|
this.onClearInput = (ev) => {
|
||
|
this.ionClear.emit();
|
||
|
if (ev) {
|
||
|
ev.preventDefault();
|
||
|
ev.stopPropagation();
|
||
|
}
|
||
|
// setTimeout() fixes https://github.com/ionic-team/ionic/issues/7527
|
||
|
// wait for 4 frames
|
||
|
setTimeout(() => {
|
||
|
const value = this.getValue();
|
||
|
if (value !== '') {
|
||
|
this.value = '';
|
||
|
this.ionInput.emit();
|
||
|
}
|
||
|
}, 16 * 4);
|
||
|
};
|
||
|
/**
|
||
|
* Clears the input field and tells the input to blur since
|
||
|
* the clearInput function doesn't want the input to blur
|
||
|
* then calls the custom cancel function if the user passed one in.
|
||
|
*/
|
||
|
this.onCancelSearchbar = (ev) => {
|
||
|
if (ev) {
|
||
|
ev.preventDefault();
|
||
|
ev.stopPropagation();
|
||
|
}
|
||
|
this.ionCancel.emit();
|
||
|
this.onClearInput();
|
||
|
if (this.nativeInput) {
|
||
|
this.nativeInput.blur();
|
||
|
}
|
||
|
};
|
||
|
/**
|
||
|
* Update the Searchbar input value when the input changes
|
||
|
*/
|
||
|
this.onInput = (ev) => {
|
||
|
const input = ev.target;
|
||
|
if (input) {
|
||
|
this.value = input.value;
|
||
|
}
|
||
|
this.ionInput.emit(ev);
|
||
|
};
|
||
|
/**
|
||
|
* Sets the Searchbar to not focused and checks if it should align left
|
||
|
* based on whether there is a value in the searchbar or not.
|
||
|
*/
|
||
|
this.onBlur = () => {
|
||
|
this.focused = false;
|
||
|
this.ionBlur.emit();
|
||
|
this.positionElements();
|
||
|
};
|
||
|
/**
|
||
|
* Sets the Searchbar to focused and active on input focus.
|
||
|
*/
|
||
|
this.onFocus = () => {
|
||
|
this.focused = true;
|
||
|
this.ionFocus.emit();
|
||
|
this.positionElements();
|
||
|
};
|
||
|
}
|
||
|
debounceChanged() {
|
||
|
this.ionChange = Object(_helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_2__["d"])(this.ionChange, this.debounce);
|
||
|
}
|
||
|
valueChanged() {
|
||
|
const inputEl = this.nativeInput;
|
||
|
const value = this.getValue();
|
||
|
if (inputEl && inputEl.value !== value) {
|
||
|
inputEl.value = value;
|
||
|
}
|
||
|
this.ionChange.emit({ value });
|
||
|
}
|
||
|
showCancelButtonChanged() {
|
||
|
requestAnimationFrame(() => {
|
||
|
this.positionElements();
|
||
|
Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["j"])(this);
|
||
|
});
|
||
|
}
|
||
|
connectedCallback() {
|
||
|
this.emitStyle();
|
||
|
}
|
||
|
componentDidLoad() {
|
||
|
this.positionElements();
|
||
|
this.debounceChanged();
|
||
|
setTimeout(() => {
|
||
|
this.noAnimate = false;
|
||
|
}, 300);
|
||
|
}
|
||
|
emitStyle() {
|
||
|
this.ionStyle.emit({
|
||
|
'searchbar': true
|
||
|
});
|
||
|
}
|
||
|
/**
|
||
|
* Sets focus on the specified `ion-searchbar`. Use this method instead of the global
|
||
|
* `input.focus()`.
|
||
|
*/
|
||
|
async setFocus() {
|
||
|
if (this.nativeInput) {
|
||
|
this.nativeInput.focus();
|
||
|
}
|
||
|
}
|
||
|
/**
|
||
|
* Returns the native `<input>` element used under the hood.
|
||
|
*/
|
||
|
getInputElement() {
|
||
|
return Promise.resolve(this.nativeInput);
|
||
|
}
|
||
|
/**
|
||
|
* Positions the input search icon, placeholder, and the cancel button
|
||
|
* based on the input value and if it is focused. (ios only)
|
||
|
*/
|
||
|
positionElements() {
|
||
|
const value = this.getValue();
|
||
|
const prevAlignLeft = this.shouldAlignLeft;
|
||
|
const mode = Object(_ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["b"])(this);
|
||
|
const shouldAlignLeft = (!this.animated || value.trim() !== '' || !!this.focused);
|
||
|
this.shouldAlignLeft = shouldAlignLeft;
|
||
|
if (mode !== 'ios') {
|
||
|
return;
|
||
|
}
|
||
|
if (prevAlignLeft !== shouldAlignLeft) {
|
||
|
this.positionPlaceholder();
|
||
|
}
|
||
|
if (this.animated) {
|
||
|
this.positionCancelButton();
|
||
|
}
|
||
|
}
|
||
|
/**
|
||
|
* Positions the input placeholder
|
||
|
*/
|
||
|
positionPlaceholder() {
|
||
|
const inputEl = this.nativeInput;
|
||
|
if (!inputEl) {
|
||
|
return;
|
||
|
}
|
||
|
const isRTL = document.dir === 'rtl';
|
||
|
const iconEl = (this.el.shadowRoot || this.el).querySelector('.searchbar-search-icon');
|
||
|
if (this.shouldAlignLeft) {
|
||
|
inputEl.removeAttribute('style');
|
||
|
iconEl.removeAttribute('style');
|
||
|
}
|
||
|
else {
|
||
|
// Create a dummy span to get the placeholder width
|
||
|
const doc = document;
|
||
|
const tempSpan = doc.createElement('span');
|
||
|
tempSpan.innerText = this.placeholder || '';
|
||
|
doc.body.appendChild(tempSpan);
|
||
|
// Get the width of the span then remove it
|
||
|
Object(_helpers_5c745fbd_js__WEBPACK_IMPORTED_MODULE_2__["r"])(() => {
|
||
|
const textWidth = tempSpan.offsetWidth;
|
||
|
tempSpan.remove();
|
||
|
// Calculate the input padding
|
||
|
const inputLeft = 'calc(50% - ' + (textWidth / 2) + 'px)';
|
||
|
// Calculate the icon margin
|
||
|
const iconLeft = 'calc(50% - ' + ((textWidth / 2) + 30) + 'px)';
|
||
|
// Set the input padding start and icon margin start
|
||
|
if (isRTL) {
|
||
|
inputEl.style.paddingRight = inputLeft;
|
||
|
iconEl.style.marginRight = iconLeft;
|
||
|
}
|
||
|
else {
|
||
|
inputEl.style.paddingLeft = inputLeft;
|
||
|
iconEl.style.marginLeft = iconLeft;
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
/**
|
||
|
* Show the iOS Cancel button on focus, hide it offscreen otherwise
|
||
|
*/
|
||
|
positionCancelButton() {
|
||
|
const isRTL = document.dir === 'rtl';
|
||
|
const cancelButton = (this.el.shadowRoot || this.el).querySelector('.searchbar-cancel-button');
|
||
|
const shouldShowCancel = this.shouldShowCancelButton();
|
||
|
if (cancelButton && shouldShowCancel !== this.isCancelVisible) {
|
||
|
const cancelStyle = cancelButton.style;
|
||
|
this.isCancelVisible = shouldShowCancel;
|
||
|
if (shouldShowCancel) {
|
||
|
if (isRTL) {
|
||
|
cancelStyle.marginLeft = '0';
|
||
|
}
|
||
|
else {
|
||
|
cancelStyle.marginRight = '0';
|
||
|
}
|
||
|
}
|
||
|
else {
|
||
|
const offset = cancelButton.offsetWidth;
|
||
|
if (offset > 0) {
|
||
|
if (isRTL) {
|
||
|
cancelStyle.marginLeft = -offset + 'px';
|
||
|
}
|
||
|
else {
|
||
|
cancelStyle.marginRight = -offset + 'px';
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
getValue() {
|
||
|
return this.value || '';
|
||
|
}
|
||
|
hasValue() {
|
||
|
return this.getValue() !== '';
|
||
|
}
|
||
|
/**
|
||
|
* Determines whether or not the cancel button should be visible onscreen.
|
||
|
* Cancel button should be shown if one of two conditions applies:
|
||
|
* 1. `showCancelButton` is set to `always`.
|
||
|
* 2. `showCancelButton` is set to `focus`, and the searchbar has been focused.
|
||
|
*/
|
||
|
shouldShowCancelButton() {
|
||
|
if ((this.showCancelButton === 'never') || (this.showCancelButton === 'focus' && !this.focused)) {
|
||
|
return false;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
render() {
|
||
|
const { cancelButtonText } = this;
|
||
|
const animated = this.animated && _ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["c"].getBoolean('animated', true);
|
||
|
const mode = Object(_ionic_global_23e7365a_js__WEBPACK_IMPORTED_MODULE_1__["b"])(this);
|
||
|
const clearIcon = this.clearIcon || (mode === 'ios' ? 'close-circle' : 'close-sharp');
|
||
|
const searchIcon = this.searchIcon || (mode === 'ios' ? 'search-outline' : 'search-sharp');
|
||
|
const shouldShowCancelButton = this.shouldShowCancelButton();
|
||
|
const cancelButton = (this.showCancelButton !== 'never') && (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("button", { "aria-label": cancelButtonText, "aria-hidden": shouldShowCancelButton ? undefined : 'true', type: "button", tabIndex: mode === 'ios' && !shouldShowCancelButton ? -1 : undefined, onMouseDown: this.onCancelSearchbar, onTouchStart: this.onCancelSearchbar, class: "searchbar-cancel-button" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { "aria-hidden": "true" }, mode === 'md'
|
||
|
? Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("ion-icon", { "aria-hidden": "true", mode: mode, icon: this.cancelButtonIcon, lazy: false })
|
||
|
: cancelButtonText)));
|
||
|
return (Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["H"], { role: "search", "aria-disabled": this.disabled ? 'true' : null, class: Object(_theme_5641d27f_js__WEBPACK_IMPORTED_MODULE_3__["c"])(this.color, {
|
||
|
[mode]: true,
|
||
|
'searchbar-animated': animated,
|
||
|
'searchbar-disabled': this.disabled,
|
||
|
'searchbar-no-animate': animated && this.noAnimate,
|
||
|
'searchbar-has-value': this.hasValue(),
|
||
|
'searchbar-left-aligned': this.shouldAlignLeft,
|
||
|
'searchbar-has-focus': this.focused,
|
||
|
'searchbar-should-show-cancel': this.shouldShowCancelButton()
|
||
|
}) }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("div", { class: "searchbar-input-container" }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("input", { "aria-label": "search text", disabled: this.disabled, ref: el => this.nativeInput = el, class: "searchbar-input", inputMode: this.inputmode, enterKeyHint: this.enterkeyhint, onInput: this.onInput, onBlur: this.onBlur, onFocus: this.onFocus, placeholder: this.placeholder, type: this.type, value: this.getValue(), autoComplete: this.autocomplete, autoCorrect: this.autocorrect, spellcheck: this.spellcheck }), mode === 'md' && cancelButton, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("ion-icon", { "aria-hidden": "true", mode: mode, icon: searchIcon, lazy: false, class: "searchbar-search-icon" }), Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("button", { "aria-label": "reset", type: "button", "no-blur": true, class: "searchbar-clear-button", onMouseDown: this.onClearInput, onTouchStart: this.onClearInput }, Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["h"])("ion-icon", { "aria-hidden": "true", mode: mode, icon: clearIcon, lazy: false, class: "searchbar-clear-icon" }))), mode === 'ios' && cancelButton));
|
||
|
}
|
||
|
get el() { return Object(_index_92848855_js__WEBPACK_IMPORTED_MODULE_0__["i"])(this); }
|
||
|
static get watchers() { return {
|
||
|
"debounce": ["debounceChanged"],
|
||
|
"value": ["valueChanged"],
|
||
|
"showCancelButton": ["showCancelButtonChanged"]
|
||
|
}; }
|
||
|
};
|
||
|
Searchbar.style = {
|
||
|
ios: searchbarIosCss,
|
||
|
md: searchbarMdCss
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
/***/ })
|
||
|
|
||
|
}]);
|
||
|
//# sourceMappingURL=30-es2015.js.map
|