UNPKG

@huluvu424242/honey-slideshow

Version:

Text to Speech component wich is reading texts from DOM elements.

513 lines (512 loc) 25.5 kB
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __generator = (this && this.__generator) || function (thisArg, body) { var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function (v) { return step([n, v]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while (_) try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [op[0] & 2, t.value]; switch (op[0]) { case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [0]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } }; import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-a2883912.js'; import './config-804a0dce.js'; import { f as findItemLabel, a as renderHiddenInput } from './helpers-29d709d1.js'; import './hardware-back-button-b3b61715.js'; import { g as getIonMode } from './ionic-global-c170bb31.js'; import { f as popoverController, g as actionSheetController, h as alertController } from './overlays-d95d4a8d.js'; import { h as hostContext } from './theme-74c22054.js'; var watchForOptions = function (containerEl, tagName, onChange) { /* tslint:disable-next-line */ if (typeof MutationObserver === 'undefined') { return; } var mutation = new MutationObserver(function (mutationList) { onChange(getSelectedOption(mutationList, tagName)); }); mutation.observe(containerEl, { childList: true, subtree: true }); return mutation; }; var getSelectedOption = function (mutationList, tagName) { var newOption; mutationList.forEach(function (mut) { // tslint:disable-next-line: prefer-for-of for (var i = 0; i < mut.addedNodes.length; i++) { newOption = findCheckedOption(mut.addedNodes[i], tagName) || newOption; } }); return newOption; }; var findCheckedOption = function (el, tagName) { if (el.nodeType !== 1) { return undefined; } var options = (el.tagName === tagName.toUpperCase()) ? [el] : Array.from(el.querySelectorAll(tagName)); return options.find(function (o) { return o.value === el.value; }); }; var selectIosCss = ":host{--placeholder-color:currentColor;--placeholder-opacity:0.33;padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;font-family:var(--ion-font-family, inherit);overflow:hidden;z-index:2}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}:host(.in-item){position:static;max-width:45%}:host(.select-disabled){opacity:0.4;pointer-events:none}:host(.ion-focused) button{border:2px solid #5e9ed6}.select-placeholder{color:var(--placeholder-color);opacity:var(--placeholder-opacity)}button{left:0;top:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;position:absolute;width:100%;height:100%;border:0;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}[dir=rtl] button,:host-context([dir=rtl]) button{left:unset;right:unset;right:0}button::-moz-focus-inner{border:0}.select-icon{position:relative;opacity:0.33}.select-text{-ms-flex:1;flex:1;min-width:16px;font-size:inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.select-icon-inner{left:5px;top:50%;margin-top:-3px;position:absolute;width:0;height:0;border-top:5px solid;border-right:5px solid transparent;border-left:5px solid transparent;color:currentColor;pointer-events:none}[dir=rtl] .select-icon-inner,:host-context([dir=rtl]) .select-icon-inner{left:unset;right:unset;right:5px}:host{--padding-top:10px;--padding-end:10px;--padding-bottom:10px;--padding-start:20px}.select-icon{width:12px;height:18px}"; var selectMdCss = ":host{--placeholder-color:currentColor;--placeholder-opacity:0.33;padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;font-family:var(--ion-font-family, inherit);overflow:hidden;z-index:2}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}:host(.in-item){position:static;max-width:45%}:host(.select-disabled){opacity:0.4;pointer-events:none}:host(.ion-focused) button{border:2px solid #5e9ed6}.select-placeholder{color:var(--placeholder-color);opacity:var(--placeholder-opacity)}button{left:0;top:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;position:absolute;width:100%;height:100%;border:0;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}[dir=rtl] button,:host-context([dir=rtl]) button{left:unset;right:unset;right:0}button::-moz-focus-inner{border:0}.select-icon{position:relative;opacity:0.33}.select-text{-ms-flex:1;flex:1;min-width:16px;font-size:inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.select-icon-inner{left:5px;top:50%;margin-top:-3px;position:absolute;width:0;height:0;border-top:5px solid;border-right:5px solid transparent;border-left:5px solid transparent;color:currentColor;pointer-events:none}[dir=rtl] .select-icon-inner,:host-context([dir=rtl]) .select-icon-inner{left:unset;right:unset;right:5px}:host{--padding-top:10px;--padding-end:0;--padding-bottom:11px;--padding-start:16px}.select-icon{width:19px;height:19px}"; var Select = /** @class */ (function () { function class_1(hostRef) { var _this = this; registerInstance(this, hostRef); this.ionChange = createEvent(this, "ionChange", 7); this.ionCancel = createEvent(this, "ionCancel", 7); this.ionFocus = createEvent(this, "ionFocus", 7); this.ionBlur = createEvent(this, "ionBlur", 7); this.ionStyle = createEvent(this, "ionStyle", 7); this.inputId = "ion-sel-" + selectIds++; this.didInit = false; this.isExpanded = false; /** * If `true`, the user cannot interact with the select. */ this.disabled = false; /** * The text to display on the cancel button. */ this.cancelText = 'Cancel'; /** * The text to display on the ok button. */ this.okText = 'OK'; /** * The name of the control, which is submitted with the form data. */ this.name = this.inputId; /** * If `true`, the select can accept multiple values. */ this.multiple = false; /** * The interface the select should use: `action-sheet`, `popover` or `alert`. */ this.interface = 'alert'; /** * Any additional options that the `alert`, `action-sheet` or `popover` interface * can take. See the [ion-alert docs](../alert), the * [ion-action-sheet docs](../action-sheet) and the * [ion-popover docs](../popover) for the * create options for each interface. * * Note: `interfaceOptions` will not override `inputs` or `buttons` with the `alert` interface. */ this.interfaceOptions = {}; this.onClick = function (ev) { _this.setFocus(); _this.open(ev); }; this.onFocus = function () { _this.ionFocus.emit(); }; this.onBlur = function () { _this.ionBlur.emit(); }; } class_1.prototype.disabledChanged = function () { this.emitStyle(); }; class_1.prototype.valueChanged = function () { this.emitStyle(); if (this.didInit) { this.ionChange.emit({ value: this.value, }); } }; class_1.prototype.connectedCallback = function () { return __awaiter(this, void 0, void 0, function () { var _this = this; return __generator(this, function (_a) { this.updateOverlayOptions(); this.emitStyle(); this.mutationO = watchForOptions(this.el, 'ion-select-option', function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { this.updateOverlayOptions(); return [2 /*return*/]; }); }); }); return [2 /*return*/]; }); }); }; class_1.prototype.disconnectedCallback = function () { if (this.mutationO) { this.mutationO.disconnect(); this.mutationO = undefined; } }; class_1.prototype.componentDidLoad = function () { this.didInit = true; }; /** * Open the select overlay. The overlay is either an alert, action sheet, or popover, * depending on the `interface` property on the `ion-select`. * * @param event The user interface event that called the open. */ class_1.prototype.open = function (event) { return __awaiter(this, void 0, void 0, function () { var overlay, _a; var _this = this; return __generator(this, function (_b) { switch (_b.label) { case 0: if (this.disabled || this.isExpanded) { return [2 /*return*/, undefined]; } _a = this; return [4 /*yield*/, this.createOverlay(event)]; case 1: overlay = _a.overlay = _b.sent(); this.isExpanded = true; overlay.onDidDismiss().then(function () { _this.overlay = undefined; _this.isExpanded = false; _this.setFocus(); }); return [4 /*yield*/, overlay.present()]; case 2: _b.sent(); return [2 /*return*/, overlay]; } }); }); }; class_1.prototype.createOverlay = function (ev) { var selectInterface = this.interface; if ((selectInterface === 'action-sheet' || selectInterface === 'popover') && this.multiple) { console.warn("Select interface cannot be \"" + selectInterface + "\" with a multi-value select. Using the \"alert\" interface instead."); selectInterface = 'alert'; } if (selectInterface === 'popover' && !ev) { console.warn('Select interface cannot be a "popover" without passing an event. Using the "alert" interface instead.'); selectInterface = 'alert'; } if (selectInterface === 'popover') { return this.openPopover(ev); } if (selectInterface === 'action-sheet') { return this.openActionSheet(); } return this.openAlert(); }; class_1.prototype.updateOverlayOptions = function () { var overlay = this.overlay; if (!overlay) { return; } var childOpts = this.childOpts; var value = this.value; switch (this.interface) { case 'action-sheet': overlay.buttons = this.createActionSheetButtons(childOpts, value); break; case 'popover': var popover = overlay.querySelector('ion-select-popover'); if (popover) { popover.options = this.createPopoverOptions(childOpts, value); } break; case 'alert': var inputType = (this.multiple ? 'checkbox' : 'radio'); overlay.inputs = this.createAlertInputs(childOpts, inputType, value); break; } }; class_1.prototype.createActionSheetButtons = function (data, selectValue) { var _this = this; var actionSheetButtons = data.map(function (option) { var value = getOptionValue(option); return { role: (isOptionSelected(value, selectValue, _this.compareWith) ? 'selected' : ''), text: option.textContent, handler: function () { _this.value = value; } }; }); // Add "cancel" button actionSheetButtons.push({ text: this.cancelText, role: 'cancel', handler: function () { _this.ionCancel.emit(); } }); return actionSheetButtons; }; class_1.prototype.createAlertInputs = function (data, inputType, selectValue) { var _this = this; return data.map(function (o) { var value = getOptionValue(o); return { type: inputType, label: o.textContent || '', value: value, checked: isOptionSelected(value, selectValue, _this.compareWith), disabled: o.disabled }; }); }; class_1.prototype.createPopoverOptions = function (data, selectValue) { var _this = this; return data.map(function (o) { var value = getOptionValue(o); return { text: o.textContent || '', value: value, checked: isOptionSelected(value, selectValue, _this.compareWith), disabled: o.disabled, handler: function () { _this.value = value; _this.close(); } }; }); }; class_1.prototype.openPopover = function (ev) { return __awaiter(this, void 0, void 0, function () { var interfaceOptions, mode, value, popoverOpts; return __generator(this, function (_a) { interfaceOptions = this.interfaceOptions; mode = getIonMode(this); value = this.value; popoverOpts = Object.assign(Object.assign({ mode: mode }, interfaceOptions), { component: 'ion-select-popover', cssClass: ['select-popover', interfaceOptions.cssClass], event: ev, componentProps: { header: interfaceOptions.header, subHeader: interfaceOptions.subHeader, message: interfaceOptions.message, value: value, options: this.createPopoverOptions(this.childOpts, value) } }); return [2 /*return*/, popoverController.create(popoverOpts)]; }); }); }; class_1.prototype.openActionSheet = function () { return __awaiter(this, void 0, void 0, function () { var mode, interfaceOptions, actionSheetOpts; return __generator(this, function (_a) { mode = getIonMode(this); interfaceOptions = this.interfaceOptions; actionSheetOpts = Object.assign(Object.assign({ mode: mode }, interfaceOptions), { buttons: this.createActionSheetButtons(this.childOpts, this.value), cssClass: ['select-action-sheet', interfaceOptions.cssClass] }); return [2 /*return*/, actionSheetController.create(actionSheetOpts)]; }); }); }; class_1.prototype.openAlert = function () { return __awaiter(this, void 0, void 0, function () { var label, labelText, interfaceOptions, inputType, mode, alertOpts; var _this = this; return __generator(this, function (_a) { label = this.getLabel(); labelText = (label) ? label.textContent : null; interfaceOptions = this.interfaceOptions; inputType = (this.multiple ? 'checkbox' : 'radio'); mode = getIonMode(this); alertOpts = Object.assign(Object.assign({ mode: mode }, interfaceOptions), { header: interfaceOptions.header ? interfaceOptions.header : labelText, inputs: this.createAlertInputs(this.childOpts, inputType, this.value), buttons: [ { text: this.cancelText, role: 'cancel', handler: function () { _this.ionCancel.emit(); } }, { text: this.okText, handler: function (selectedValues) { _this.value = selectedValues; } } ], cssClass: ['select-alert', interfaceOptions.cssClass, (this.multiple ? 'multiple-select-alert' : 'single-select-alert')] }); return [2 /*return*/, alertController.create(alertOpts)]; }); }); }; /** * Close the select interface. */ class_1.prototype.close = function () { // TODO check !this.overlay || !this.isFocus() if (!this.overlay) { return Promise.resolve(false); } return this.overlay.dismiss(); }; class_1.prototype.getLabel = function () { return findItemLabel(this.el); }; class_1.prototype.hasValue = function () { return this.getText() !== ''; }; Object.defineProperty(class_1.prototype, "childOpts", { get: function () { return Array.from(this.el.querySelectorAll('ion-select-option')); }, enumerable: false, configurable: true }); class_1.prototype.getText = function () { var selectedText = this.selectedText; if (selectedText != null && selectedText !== '') { return selectedText; } return generateText(this.childOpts, this.value, this.compareWith); }; class_1.prototype.setFocus = function () { if (this.buttonEl) { this.buttonEl.focus(); } }; class_1.prototype.emitStyle = function () { this.ionStyle.emit({ 'interactive': true, 'select': true, 'has-placeholder': this.placeholder != null, 'has-value': this.hasValue(), 'interactive-disabled': this.disabled, 'select-disabled': this.disabled }); }; class_1.prototype.render = function () { var _a; var _this = this; var _b = this, placeholder = _b.placeholder, name = _b.name, disabled = _b.disabled, isExpanded = _b.isExpanded, value = _b.value, el = _b.el; var mode = getIonMode(this); var labelId = this.inputId + '-lbl'; var label = findItemLabel(el); if (label) { label.id = labelId; } var addPlaceholderClass = false; var selectText = this.getText(); if (selectText === '' && placeholder != null) { selectText = placeholder; addPlaceholderClass = true; } renderHiddenInput(true, el, name, parseValue(value), disabled); var selectTextClasses = { 'select-text': true, 'select-placeholder': addPlaceholderClass }; var textPart = addPlaceholderClass ? 'placeholder' : 'text'; return (h(Host, { onClick: this.onClick, role: "combobox", "aria-haspopup": "dialog", "aria-disabled": disabled ? 'true' : null, "aria-expanded": "" + isExpanded, "aria-labelledby": labelId, class: (_a = {}, _a[mode] = true, _a['in-item'] = hostContext('ion-item', el), _a['select-disabled'] = disabled, _a) }, h("div", { class: selectTextClasses, part: textPart }, selectText), h("div", { class: "select-icon", role: "presentation", part: "icon" }, h("div", { class: "select-icon-inner" })), h("button", { type: "button", onFocus: this.onFocus, onBlur: this.onBlur, disabled: disabled, ref: (function (btnEl) { return _this.buttonEl = btnEl; }) }))); }; Object.defineProperty(class_1.prototype, "el", { get: function () { return getElement(this); }, enumerable: false, configurable: true }); Object.defineProperty(class_1, "watchers", { get: function () { return { "disabled": ["disabledChanged"], "placeholder": ["disabledChanged"], "value": ["valueChanged"] }; }, enumerable: false, configurable: true }); return class_1; }()); var isOptionSelected = function (currentValue, compareValue, compareWith) { if (currentValue === undefined) { return false; } if (Array.isArray(currentValue)) { return currentValue.some(function (val) { return compareOptions(val, compareValue, compareWith); }); } else { return compareOptions(currentValue, compareValue, compareWith); } }; var getOptionValue = function (el) { var value = el.value; return (value === undefined) ? el.textContent || '' : value; }; var parseValue = function (value) { if (value == null) { return undefined; } if (Array.isArray(value)) { return value.join(','); } return value.toString(); }; var compareOptions = function (currentValue, compareValue, compareWith) { if (typeof compareWith === 'function') { return compareWith(currentValue, compareValue); } else if (typeof compareWith === 'string') { return currentValue[compareWith] === compareValue[compareWith]; } else { return Array.isArray(compareValue) ? compareValue.includes(currentValue) : currentValue === compareValue; } }; var generateText = function (opts, value, compareWith) { if (value === undefined) { return ''; } if (Array.isArray(value)) { return value .map(function (v) { return textForValue(opts, v, compareWith); }) .filter(function (opt) { return opt !== null; }) .join(', '); } else { return textForValue(opts, value, compareWith) || ''; } }; var textForValue = function (opts, value, compareWith) { var selectOpt = opts.find(function (opt) { return compareOptions(getOptionValue(opt), value, compareWith); }); return selectOpt ? selectOpt.textContent : null; }; var selectIds = 0; Select.style = { ios: selectIosCss, md: selectMdCss }; export { Select as ion_select };