Lion Logo Lion Fundamentals Guides Components Blog Toggle darkmode

Input Tel Dropdown: API Table

class: LionInputTelDropdown, lion-input-tel-dropdown

Fields

NamePrivacyTypeDefaultDescriptionInherited From
refspublicobject{ /** @type {DropdownRef} */ dropdown: /** @type {DropdownRef} */ (createRef()), }
_templateDataDropdownprotectedTemplateDataForDropdownInputTelThis method provides a TemplateData object to be fed to pure template functions, a.k.a. Pure Templates™. The goal is to totally decouple presentation from logic here, so that Subclassers can override all content without having to loose private info contained within the template function that was overridden. Subclassers would need to make sure all the contents of the TemplateData object are implemented by making sure they are coupled to the right 'ref' ([data-ref=dropdown] in this example), with the help of lit's spread operator directive. To enhance this process, the TemplateData object is completely typed. Ideally, this would be enhanced by providing linters that make sure all of their required members are implemented by a Subclasser. When a Subclasser wants to add more data, this can be done via:
slotspublicAdds "._feedbackNode" as described belowLionField
preferredRegionspublicstring[][]Regions that will be shown on top of the dropdown
_allCountriesLabelprotectedstring''Group label for all countries, when preferredCountries are shown
_preferredCountriesLabelprotectedstring''Group label for preferred countries, when preferredCountries are shown
activeRegionpublicstringCurrently active region based on: 1. allowed regions: get the region from configured allowed regions (if one entry) 2. user input: try to derive active region from user input 3. locale: try to get the region from locale (`html[lang]` attribute)LionInputTel
activePhoneNumberTypepublicType of phone number, derived from textbox value. Enum with values: -'fixed-line' -'fixed-line-or-mobile' -'mobile' -'pager' -'personal-number' -'premium-rate' -'shared-cost' -'toll-free' -'uan' -'voip' -'unknown' See https://www.npmjs.com/package/awesome-phonenumberLionInputTel
_allowedOrAllRegionsprotectedRegionCode[]Used for rendering the region/country listLionInputTel
_phoneUtilLoadCompleteprotectedPromise<PhoneNumber>LionInputTel
fieldNamepublicstringSet a default name for this field, so that validation feedback will be always accessible and linguistically correctLionField
formatStrategypublicPhoneNumberFormat'international'Determines what the formatter output should look like. Formatting strategies as provided by google-libphonenumber See: https://www.npmjs.com/package/google-libphonenumberLionInputTel
formatCountryCodeStylepublicstring'default'Extra styling of the format strategy default | parenthesesLionInputTel
allowedRegionspublicRegionCode[][]The regions that should be considered when international phone numbers are detected. (when not configured, all regions worldwide will be considered)LionInputTel
_phoneUtilprotectedAwesomePhoneNumber|nullLionInputTel
_inputNodeprotectedHTMLInputElement | HTMLTextAreaElementThe interactive (form) element. Can be a native element like input/textarea/select or an element with tabindex > -1LionField
selectionStartpublicnumberNativeTextFieldMixin
selectionEndpublicnumberNativeTextFieldMixin
valuepublicThe view value. Will be delegated to `._inputNode.value` Note: Overrides the implementation from FormatMixinLionField
_focusableNodeprotectedHTMLElementThe focusable element: could be an input, textarea, select, button or any other element with tabindex > -1LionField
autocompletepublicstring | undefinedundefinedDelegates this property to input/textarea/select.NativeTextFieldMixin
formatOnprotectedstring'change'Event that will trigger formatting (more precise, visual update of the view, so the user sees the formatted value) Default: 'change'LionField
formatOptionspublic({ mode: 'auto' })Configuration object that will be available inside the formatter functionLionField
formattedValuepublicstring|undefinedundefinedThe view value is the result of the formatter function (when available). The result will be stored in the native _inputNode (usually an input[type=text]). Examples: - For a date input, this would be '20/01/1999' (dependent on locale). - For a number input, this could be '1,234.56' (a String representation of modelValue 1234.56)LionField
serializedValuepublicstring|undefinedundefinedThe serialized version of the model value. This value exists for maximal compatibility with the platform API. The serialized value can be an interface in context where data binding is not supported and a serialized string needs to be set. Examples: - For a date input, this would be the iso format of a date, e.g. '1999-01-20'. - For a number input this would be the String representation of a float ('1234.56' instead of 1234.56) When no parser is available, the value is usually the same as the formattedValue (being _inputNode.value)LionField
_isPastingprotectedbooleanfalseWhether the user is pasting content. Allows Subclassers to do this in their subclass:LionField
_isHandlingUserInputprotectedbooleanfalseFlag that will be set when user interaction takes place (for instance after an 'input' event). Will be added as meta info to the `model-value-changed` event. Depending on whether a user is interacting, formatting logic will be handled differently.LionField
focusedpublicbooleanfalseWhether the focusable element within (`._focusableNode`) is focused. Reflects to attribute '[focused]' as a styling hookLionField
focusedVisiblepublicbooleanfalseWhether the focusable element within (`._focusableNode`) matches ':focus-visible' Reflects to attribute '[focused-visible]' as a styling hook See: https://developer.mozilla.org/en-US/docs/Web/CSS/:focus-visibleLionField
autofocuspublicbooleanfalseLionField
labelpublicstring''The label text for the input node. When no value is defined, textContent of [slot=label] will be usedLionField
helpTextpublicstring''The helpt text for the input node. When no value is defined, textContent of [slot=help-text] will be usedLionField
_labelNodeprotectedElement where label will be rendered toLionField
_helpTextNodeprotectedElement where help text will be rendered toLionField
_feedbackNodeprotectedElement where validation feedback will be rendered toLionField
readOnlypublicbooleanfalseA Boolean attribute which, if present, indicates that the user should not be able to edit the value of the input. The difference between disabled and readonly is that read-only controls can still function, whereas disabled controls generally do not function as controls until they are enabled. (From: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#attr-readonly)LionField
labelSrOnlypublicbooleanfalseThe label will only be visible for srceen readers when trueLionField
_inputIdprotectedstringUnique id that can be used in all light domLionField
_ariaLabelledNodespublicHTMLElement[][]Contains all elements that should end up in aria-labelledby of `._inputNode`LionField
_ariaDescribedNodespublicHTMLElement[][]Contains all elements that should end up in aria-describedby of `._inputNode`LionField
_repropagationRolepublic'child'|'choice-group'|'fieldset''child'Based on the role, details of handling model-value-changed repropagation differ.LionField
_isRepropagationEndpointpublicbooleanfalseBy default, a field with _repropagationRole 'choice-group' will act as an 'endpoint'. This means it will be considered as an individual field: for a select, individual options will not be part of the formPath. They will. Similarly, components that (a11y wise) need to be fieldsets, but 'interaction wise' (from Application Developer perspective) need to be more like fields (think of an amount-input with a currency select box next to it), can set this to true to hide private internals in the formPath.LionField
modelValuepublicLionField
typepublicstring'text'LionInput
placeholderpublicstring''LionInput
namepublicstring''The name the element will be registered with to the .formElements collection of the parent. Also, it serves as the key of key/value pairs in modelValue/serializedValue objectsLionField
_parentFormGroupprotectedFormRegistrarHost | undefinedundefinedThe registrar this FormControl registers to, Usually a descendant of FormGroup or ChoiceGroupLionField
allowCrossRootRegistrationpublicbooleanfalseTo encourage accessibility best practices, `form-element-register` events do not pierce through shadow roots. This forces the developer to create form groups and fieldsets that automatically allow the creation of accessible relationships in the same dom tree. Use this option if you know what you're doing. It will then be possible to nest FormControls inside shadow dom. See https://lion.js.org/fundamentals/rationales/accessibility/#shadow-roots-and-accessibilityLionField
_requestedToBeDisabledprotectedbooleanfalseLionField
disabledpublicbooleanfalseLionField
_feedbackConditionMetaprotectedAllows Subclassers to add meta info for feedbackConditionLionField
touchedpublicbooleanfalseTrue when user has focused and left(blurred) the field.LionField
dirtypublicbooleanfalseTrue when user has changed the value of the field.LionField
prefilledpublicbooleanfalseTrue when user has left non-empty field or input is prefilled. The name must be seen from the point of view of the input field: once the user enters the input field, the value is non-empty.LionField
filledpublicbooleanfalseTrue when the modelValue is non-empty (see _isEmpty in FormControlMixin)LionField
_leaveEventprotectedstring'blur'The event that triggers the touched stateLionField
_valueChangedEventprotectedstring'model-value-changed'The event that triggers the dirty stateLionField
submittedpublicLionField
operationModepublicOperationModeTypes of input interaction of the FormControl (for instance 'enter'|'select'|'upload')LionField
_allValidatorsprotectedValidator[]Combination of validators provided by Application Developer and the default validatorsLionField
hasFeedbackForpublicValidationType[][]As soon as validation happens (after modelValue/validators/validator param change), this array is updated with the active ValidationTypes ('error'|'warning'|'success'|'info' etc.). Notice the difference with `.showsFeedbackFor`, which filters `.hasFeedbackFor` based on `.feedbackCondition()`. For styling purposes, will be reflected to [has-feedback-for="error warning"]. This can be useful for subtle visual feedback on keyup, like a red/green border around an input.LionField
showsFeedbackForpublicValidationType[][]Based on outcome of feedbackCondition, this array decides what ValidationTypes should be shown in validationFeedback, based on meta data like interaction states. For styling purposes, it reflects it `[shows-feedback-for="error warning"]`LionField
validationStatespublicValidationStates{}The outcome of a validation 'round'. Keyed by ValidationType and Validator nameLionField
isPendingpublicbooleanfalseFlag indicating whether async validation is pending. Creates attribute [is-pending] as a styling hookLionField
validatorspublicValidator[][]Used by Application Developers to add Validators to a FormControl.LionField
defaultValidatorspublicValidator[][]Used by Subclassers to add default Validators to a particular FormControl. A date input for instance, always needs the isDate validator.LionField
_visibleMessagesAmountprotectednumber1The amount of feedback messages that will visible in LionValidationFeedbackLionField
__SyncUpdatableNamespaceprotectedSyncUpdatableNamespace{}Namespace for this mixin that guarantees naming clashes will not occur...LionField

Methods

NamePrivacyDescriptionParametersReturnInherited From
_onPhoneNumberUtilReadyprotectedLionInputTel
_initModelValueBasedOnDropdownprotected
_isEmptyprotectedUsed for Required validation and computation of interaction states. We need to override this, because we prefill the input with the region code (like +31), but for proper UX, we don't consider this as having interaction state `prefilled`modelValue: stringbooleanLionField
_onDropdownValueChangeprotectedevent: OnDropdownChangeEvent
_repropagationConditionprotectedUsually, we don't use composition in regular LionFields (non choice-groups). Here we use a LionSelect(Rich) inside. We don't want to repropagate any children, since an Application Developer is not concerned with these internals (see repropate logic in FormControlMixin) Also, we don't want to give (wrong) info to InteractionStateMixin, that will set the wrong interaction states based on child info. TODO: Make "this._repropagationRole !== 'child'" the default for FormControlMixin (so that FormControls used within are never repropagated for LionFields)target: FormControlHostLionField
_setActiveRegionprotectedProtected setter for activeRegion, only meant for subclassersnewValue: RegionCode|undefinedLionInputTel
formatterpublicConverts modelValue to formattedValue (formattedValue will be synced with `._inputNode.value`) For instance, a Date object to a localized date.modelValue: stringstringLionField
parserpublicConverts viewValue to modelValue For instance, a localized date to a Date ObjectviewValue: stringstringLionField
preprocessorpublicPreprocessors could be considered 'live formatters'. Their result is shown to the user on keyup instead of after blurring the field. The biggest difference between preprocessors and formatters is their moment of execution: preprocessors are run before modelValue is computed (and work based on view value), whereas formatters are run after the parser (and are based on modelValue) Automatically formats code while typing. It depends on a preprocessro that smartly updates the viewValue and caret position for best UX.viewValue: string, { currentCaretIndex, prevViewValue }, options: @param {string} options.prevViewValue * @param {number} options.currentCaretIndex * { viewValue: string; caretIndex: number; } | undefinedLionField
_reflectBackOnprotectedDo not reflect back .formattedValue during typing (this normally wouldn't happen when FormatMixin calls _calculateValues based on user input, but for LionInputTel we need to call it on .activeRegion change)booleanLionField
_setValueAndPreserveCaretprotectedRestores the cursor to its original position after updating the value.newValue: stringNativeTextFieldMixin
_reflectBackFormattedValueToUserprotectedNote: Overrides the implementation from FormatMixinLionField
serializerpublicConverts `.modelValue` to `.serializedValue` For instance, a Date object to an iso formatted date stringv: ?stringLionField
deserializerpublicConverts `.serializedValue` to `.modelValue` For instance, an iso formatted date string to a Date objectv: ??LionField
_calculateValuesprotectedResponsible for storing all representations(modelValue, serializedValue, formattedValue and value) of the input value. Prevents infinite loops, so all value observers can be treated like they will only be called once, without indirectly calling other observers. (in fact, some are called twice, but the __preventRecursiveTrigger lock prevents the second call from having effect).{ source }, config: {source:'model'|'serialized'|'formatted'|null}LionField
_onModelValueChangedprotectedResponds to modelValue changes in the synchronous cycle (most subclassers should listen to the asynchronous cycle ('modelValue' in the .updated lifecycle))args: { modelValue: unknown; }[]LionField
_dispatchModelValueChangedEventprotectedThis is wrapped in a distinct method, so that parents can control when the changed event is fired. For objects, a deep comparison might be needed.args: { modelValue: unknown; }[]LionField
_syncValueUpwardsprotectedSynchronization from `._inputNode.value` to `LionField` (flow [2]) Downwards syncing should only happen for `LionField`.value changes from 'above'. This triggers _onModelValueChanged and connects user input to the parsing/formatting/serializing loop.LionField
_proxyInputEventprotectedThis can be called whenever the view value should be updated. Dependent on component type ("input" for <input> or "change" for <select>(mainly for IE)) a different event should be used as source for the "user-input-changed" event (which can be seen as an abstraction layer on top of other events (input, change, whatever))LionField
_onUserInputChangedprotectedLionField
__onCompositionEventprotected{ type }, event: EventLionField
focuspublicCalls `focus()` on focusable element withinLionField
blurpublicCalls `blur()` on focusable element withinLionField
_triggerInitialModelValueChangedEventprotectedLionField
_enhanceLightDomClassesprotectedLionField
_enhanceLightDomA11yprotectedLionField
_enhanceLightDomA11yForAdditionalSlotsprotectedEnhances additional slots(prefix, suffix, before, after) defined by developer. When boolean attribute data-label or data-description is found, the slot element will be connected to the input via aria-labelledby or aria-describedbyadditionalSlots: string[]LionField
__reflectAriaAttrprotectedWill handle help text, validation feedback and character counter, prefix/suffix/before/after (if they contain data-description flag attr). Also, contents of id references that will be put in the <lion-field>._ariaDescribedby property from an external context, will be read by a screen reader.attrName: string, nodes: Element[], reorder: boolean|undefinedLionField
_groupOneTemplateprotectedTemplateResultLionField
_groupTwoTemplateprotectedTemplateResultLionField
_labelTemplateprotectedTemplateResultLionField
_helpTextTemplateprotectedTemplateResultLionField
_inputGroupTemplateprotectedTemplateResultLionField
_inputGroupBeforeTemplateprotectedTemplateResultLionField
_inputGroupPrefixTemplateprotectedTemplateResult | nothingLionField
_inputGroupInputTemplateprotectedTemplateResultLionField
_inputGroupSuffixTemplateprotectedTemplateResult | nothingLionField
_inputGroupAfterTemplateprotectedTemplateResultLionField
_feedbackTemplateprotectedTemplateResultLionField
_getAriaDescriptionElementsprotectedThis function exposes descripion elements that a FormGroup should expose to its children. See FormGroupMixin.__getAllDescriptionElementsInParentChain()Array.<HTMLElement>LionField
addToAriaLabelledBypublicAllows to add extra element references to aria-labelledby attribute.element: HTMLElement, { idPrefix = '', reorder = true }, customConfig: {idPrefix?:string; reorder?: boolean}LionField
removeFromAriaLabelledBypublicAllows to remove element references from aria-labelledby attribute.element: HTMLElementLionField
addToAriaDescribedBypublicAllows to add element references to aria-describedby attribute.element: HTMLElement, { idPrefix = '', reorder = true }, customConfig: {idPrefix?:string; reorder?: boolean}LionField
removeFromAriaDescribedBypublicAllows to remove element references from aria-describedby attribute.element: HTMLElementLionField
__getDirectSlotChildprotectedslotName: stringHTMLElement | undefinedLionField
_dispatchInitialModelValueChangedEventprotectedLionField
_onBeforeRepropagateChildrenValuesprotectedHook for Subclassers to add logic before repropagationev: CustomEventLionField
__repropagateChildrenValuesprotectedev: CustomEventLionField
_onLabelClickprotectedLionField
makeRequestToBeDisabledpublicLionField
retractRequestToBeDisabledpublicLionField
clickpublicLionField
__rerenderSlotprotectedslotName: stringLionField
__appendNodesprotected`{ nodes, renderParent = this, slotName }, options: @param {Node[]} options.nodes * @param {Element} [options.renderParent] It's recommended to create a render target in light dom (like
), * which can be used as a render target for most * @param {string} options.slotName For the first render, it's best to use slotName
 ` |                                                           | LionField            |

| __initSlots | protected | Here we look what's inside our `get slots`. Rerenderable slots get scheduled and "one time slots" get rendered once on connected | slotNames: string[] | | LionField | | _connectSlotMixin | protected | | | | LionField | | _isPrivateSlot | protected | | slotName: string | boolean | LionField | | initInteractionState | public | Evaluations performed on connectedCallback. This method is public, so it can be called at a later moment (when we need to wait for registering children for instance) as well. Since this method will be called twice in last mentioned scenario, it must stay idempotent. | | | LionField | | _iStateOnLeave | protected | Sets touched value to true and reevaluates prefilled state. When false, on next interaction, user will start with a clean state. | | | LionField | | _iStateOnValueChange | protected | Sets dirty value and validates when already touched or invalid | | | LionField | | resetInteractionState | public | Resets touched and dirty, and recomputes prefilled | | | LionField | | _onTouchedChanged | protected | Dispatches event on touched state change | | | LionField | | _onDirtyChanged | protected | Dispatches event on touched state change | | | LionField | | _showFeedbackConditionFor | protected | Default feedbackCondition condition, used by Subclassers, that will be used when `feedbackCondition()` is not overridden by Application Developer. Show the validity feedback when returning true, don't show when false | type: string, meta: InteractionStates | | LionField | | updateSync | public | An abstraction that has the exact same api as `requestUpdate`, but taking into account: - [member order independence](https://github.com/webcomponents/gold-standard/wiki/Member-Order-Independence) - property effects start when all (light) dom has initialized (on firstUpdated) - property effects don't interrupt the first meaningful paint - compatible with propertyAccessor.`hasChanged`: no manual checks needed or accidentally run property effects / events when no change happened effects when values didn't change All code previously present in requestUpdate can be placed in this method. | name: string, oldValue: ? | | LionField | | validate | public | Triggered by: - modelValue change - change in the 'validators' array - change in the config of an individual Validator Three situations are handled: - a1) the FormControl is empty: further execution is halted. When the Required Validator (being mutually exclusive to the other Validators) is applied, it will end up in the validation result (as the only Validator, since further execution was halted). - a2) there are synchronous Validators: this is the most common flow. When modelValue hasn't changed since last async results were generated, 'sync results' are merged with the 'async results'. - a3) there are asynchronous Validators: for instance when server side evaluation is needed. Executions are scheduled and awaited and the 'async results' are merged with the 'sync results'. - b) there are MetaValidators. After steps a1, a2, or a3 are finished, the holistic MetaValidators (evaluating the total result of the 'regular' (a1, a2 and a3) validators) will be run... Situations a2 and a3 are not mutually exclusive and can be triggered within one `validate()` call. Situation b will occur after every call. | { clearCurrentResult = false }, opts: { clearCurrentResult?: boolean } | | LionField | | __executeValidators | protected | | | | LionField | | _onValidatorUpdated | protected | | e: Event\|CustomEvent | | LionField | | _updateFeedbackComponent | protected | Responsible for retrieving messages from Validators and (delegation of) rendering them. For `._feedbackNode` (extension of LionValidationFeedback): - retrieve messages from highest prio Validators - provide the result to custom feedback node and let the custom node decide on their renderings In both cases: - we compute the 'show' flag (like 'hasErrorVisible') for all types - we set the customValidity message of the highest prio Validator - we set aria-invalid="true" in case hasErrorVisible is true | | | LionField | | feedbackCondition | public | Allows the Application Developer to specify when a feedback message should be shown | type: string, meta: object, currentCondition: ((type: string, meta: object) => boolean) | boolean | LionField | | _hasFeedbackVisibleFor | protected | Used to translate `.hasFeedbackFor` and `.shouldShowFeedbackFor` to `.showsFeedbackFor` | type: string | | LionField | | _updateShouldShowFeedbackFor | protected | | | | LionField | | _prioritizeAndFilterFeedback | protected | Orders all active validators in this.__validationResult. Can also filter out occurrences (based on interaction states) | { validationResult }, opts: { validationResult: Validator[] } | Validator[] | LionField | | createScopedElement | public | | tagName | | LionField | | defineScopedElement | public | Defines a scoped element. | tagName: string, classToBeRegistered: typeof HTMLElement | | LionField | | attachShadow | public | | options: ShadowRootInit | ShadowRoot | LionField | | reset | public | Resets modelValue to initial value. Interaction states are cleared | | | LionField | | clear | public | Clears modelValue. Interaction states are not cleared (use resetInteractionState for this) | | | LionField | | _onChange | protected | Dispatches custom bubble event | ev: Event= | | LionField |

Events

NameTypeDescriptionInherited From
model-value-changedCustomEventLionField
user-input-changedEventLionField
focusEventLionField
blurEventLionField
focusinEventLionField
focusoutEventLionField
form-element-name-changedCustomEventLionField
form-element-registerCustomEventLionField
touched-changedEventLionField
dirty-changedEventLionField
showsFeedbackForChangedEventLionField
EventLionField
shouldShowFeedbackForChangedEventLionField
validate-performedEventprivate event that should be listened to by LionFieldSetLionField

Attributes

NameFieldInherited From
preferredRegionspreferredRegions
allowedRegionsallowedRegionsLionInputTel
format-strategyformatStrategyLionInputTel
format-country-code-styleformatCountryCodeStyleLionInputTel
activeRegionactiveRegionLionInputTel
_phoneUtil_phoneUtilLionInputTel
autocompleteautocompleteNativeTextFieldMixin
focusedfocusedLionField
focused-visiblefocusedVisibleLionField
autofocusautofocusLionField
readonlyreadOnlyLionField
labellabelLionField
label-sr-onlylabelSrOnlyLionField
help-texthelpTextLionField
typetypeLionInput
placeholderplaceholderLionInput
namenameLionField
allow-cross-root-registrationallowCrossRootRegistrationLionField
disableddisabledLionField
touchedtouchedLionField
dirtydirtyLionField
filledfilledLionField
shows-feedback-forshowsFeedbackForLionField
is-pendingisPendingLionField