Sha256: ba407676086cfc79d02cd1aee91b9f69b593e29bb191e46b531de057c0cd76cc
Contents?: true
Size: 1.23 KB
Versions: 2
Compression:
Stored size: 1.23 KB
Contents
import '@github/auto-check-element' import {controller, target} from '@github/catalyst' @controller class YatthoTextFieldElement extends HTMLElement { @target inputElement: HTMLInputElement @target validationElement: HTMLElement @target validationMessageElement: HTMLElement #abortController: AbortController | null connectedCallback(): void { this.#abortController?.abort() const {signal} = (this.#abortController = new AbortController()) this.inputElement.addEventListener( 'auto-check-success', () => { this.clearError() }, {signal} ) this.inputElement.addEventListener( 'auto-check-error', (event: any) => { event.detail.response.text().then( (error_message: string) => { this.setError(error_message) } ) }, {signal} ) } disconnectedCallback() { this.#abortController?.abort() } clearError(): void { this.inputElement.removeAttribute('invalid') this.validationElement.hidden = true this.validationMessageElement.innerText = '' } setError(message: string): void { this.validationMessageElement.innerText = message this.validationElement.hidden = false this.inputElement.setAttribute('invalid', 'true') } }
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
yattho_view_components-0.1.1 | lib/yattho/forms/yattho_text_field.ts |
yattho_view_components-0.0.1 | lib/yattho/forms/yattho_text_field.ts |