UNPKG

@ionic/core

Version:
138 lines (132 loc) 5.76 kB
/*! * (C) Ionic http://ionicframework.com - MIT License */ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client'; import { d as inheritAttributes } from './helpers.js'; import { c as createColorClasses } from './theme.js'; import { b as getIonMode } from './ionic-global.js'; const pickerColumnOptionIosCss = "button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:100%;height:34px;border:0px;outline:none;background:transparent;color:inherit;font-family:var(--ion-font-family, inherit);font-size:inherit;line-height:34px;text-align:inherit;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;overflow:hidden}:host(.option-disabled){opacity:0.4}:host(.option-disabled) button{cursor:default}"; const pickerColumnOptionMdCss = "button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:100%;height:34px;border:0px;outline:none;background:transparent;color:inherit;font-family:var(--ion-font-family, inherit);font-size:inherit;line-height:34px;text-align:inherit;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;overflow:hidden}:host(.option-disabled){opacity:0.4}:host(.option-disabled) button{cursor:default}:host(.option-active){color:var(--ion-color-base)}"; const PickerColumnOption = /*@__PURE__*/ proxyCustomElement(class PickerColumnOption extends HTMLElement { constructor() { super(); this.__registerHost(); this.__attachShadow(); /** * We keep track of the parent picker column * so we can update the value of it when * clicking an enable option. */ this.pickerColumn = null; /** * The aria-label of the option. * * If the value changes, then it will trigger a * re-render of the picker since it's a @State variable. * Otherwise, the `aria-label` attribute cannot be updated * after the component is loaded. */ this.ariaLabel = null; /** * If `true`, the user cannot interact with the picker column option. */ this.disabled = false; /** * The color to use from your application's color palette. * Default options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`. * For more information on colors, see [theming](/docs/theming/basics). */ this.color = 'primary'; } /** * The aria-label of the option has changed after the * first render and needs to be updated within the component. * * @param ariaLbl The new aria-label value. */ onAriaLabelChange(ariaLbl) { this.ariaLabel = ariaLbl; } componentWillLoad() { const inheritedAttributes = inheritAttributes(this.el, ['aria-label']); /** * The initial value of `aria-label` needs to be set for * the first render. */ this.ariaLabel = inheritedAttributes['aria-label'] || null; } connectedCallback() { this.pickerColumn = this.el.closest('ion-picker-column'); } disconnectedCallback() { this.pickerColumn = null; } /** * The column options can load at any time * so the options needs to tell the * parent picker column when it is loaded * so the picker column can ensure it is * centered in the view. * * We intentionally run this for every * option. If we only ran this from * the selected option then if the newly * loaded options were not selected then * scrollActiveItemIntoView would not be called. */ componentDidLoad() { const { pickerColumn } = this; if (pickerColumn !== null) { pickerColumn.scrollActiveItemIntoView(); } } /** * When an option is clicked, update the * parent picker column value. This * component will handle centering the option * in the column view. */ onClick() { const { pickerColumn } = this; if (pickerColumn !== null) { pickerColumn.setValue(this.value); } } render() { const { color, disabled, ariaLabel } = this; const mode = getIonMode(this); return (h(Host, { key: 'f816729941aabcb31ddfdce3ffe2e2139030d715', class: createColorClasses(color, { [mode]: true, ['option-disabled']: disabled, }) }, h("button", { key: '48dff7833bb60fc8331cd353a0885e6affa683d1', tabindex: "-1", "aria-label": ariaLabel, disabled: disabled, onClick: () => this.onClick() }, h("slot", { key: 'f9224d0e7b7aa6c05b29abfdcfe0f30ad6ee3141' })))); } get el() { return this; } static get watchers() { return { "aria-label": ["onAriaLabelChange"] }; } static get style() { return { ios: pickerColumnOptionIosCss, md: pickerColumnOptionMdCss }; } }, [33, "ion-picker-column-option", { "disabled": [4], "value": [8], "color": [513], "ariaLabel": [32] }, undefined, { "aria-label": ["onAriaLabelChange"] }]); function defineCustomElement() { if (typeof customElements === "undefined") { return; } const components = ["ion-picker-column-option"]; components.forEach(tagName => { switch (tagName) { case "ion-picker-column-option": if (!customElements.get(tagName)) { customElements.define(tagName, PickerColumnOption); } break; } }); } export { PickerColumnOption as P, defineCustomElement as d };