@descope/web-components-ui 1.90.0 → 1.92.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.cjs.js +24 -1
- package/dist/cjs/index.cjs.js.map +1 -1
- package/dist/index.esm.js +24 -1
- package/dist/index.esm.js.map +1 -1
- package/dist/umd/DescopeDev.js +1 -1
- package/dist/umd/DescopeDev.js.map +1 -1
- package/dist/umd/descope-date-field-index-js.js +1 -1
- package/dist/umd/descope-date-field-index-js.js.map +1 -1
- package/dist/umd/descope-hybrid-field-index-js.js +3 -3
- package/dist/umd/descope-hybrid-field-index-js.js.map +1 -1
- package/package.json +1 -1
- package/src/components/descope-date-field/DateFieldClass.js +21 -1
- package/src/components/descope-hybrid-field/HybridFieldClass.js +3 -0
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"descope-hybrid-field-index-js.js","mappings":"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","sources":["webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/descope-phone-input-box-internal/PhoneFieldInternalInputBox.js","webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/PhoneFieldInputBoxClass.js","webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/index.js","webpack://@descope/web-components-ui/./src/components/descope-hybrid-field/helpers.js","webpack://@descope/web-components-ui/./src/components/descope-hybrid-field/HybridFieldClass.js","webpack://@descope/web-components-ui/./src/components/descope-hybrid-field/index.js","webpack://@descope/web-components-ui/../../../node_modules/@vaadin/email-field/theme/lumo/vaadin-email-field-styles.js","webpack://@descope/web-components-ui/../../../node_modules/@vaadin/email-field/src/vaadin-email-field-styles.js","webpack://@descope/web-components-ui/../../../node_modules/@vaadin/email-field/src/vaadin-email-field.js","webpack://@descope/web-components-ui/./src/components/descope-email-field/EmailFieldClass.js","webpack://@descope/web-components-ui/./src/components/descope-email-field/index.js","webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/descope-phone-input-box-internal/index.js","webpack://@descope/web-components-ui/./src/components/phone-fields/helpers.js"],"sourcesContent":["import { createBaseInputClass } from '../../../../baseClasses/createBaseInputClass';\nimport { getComponentName } from '../../../../helpers/componentHelpers';\nimport { getCountryByCodeId, matchingParenthesis } from '../../helpers';\nimport parsePhoneNumberFromString, { AsYouType } from 'libphonenumber-js/min';\n\nexport const componentName = getComponentName('phone-field-internal-input-box');\n\nconst observedAttributes = [\n 'disabled',\n 'size',\n 'readonly',\n 'phone-input-placeholder',\n 'name',\n 'maxlength',\n 'autocomplete',\n 'label-type',\n];\nconst mapAttrs = {\n 'phone-input-placeholder': 'placeholder',\n};\n\nconst BaseInputClass = createBaseInputClass({ componentName, baseSelector: 'div' });\n\nclass PhoneFieldInternal extends BaseInputClass {\n static get observedAttributes() {\n return [].concat(BaseInputClass.observedAttributes || [], observedAttributes);\n }\n\n #ayt;\n\n constructor() {\n super();\n\n this.innerHTML = `\n <div>\n <descope-text-field tabindex=\"1\" type=\"tel\" bordered=\"false\"></descope-text-field>\n </div>\n `;\n\n this.textField = this.querySelector('descope-text-field');\n }\n\n // notice: this function is exposed in parent component\n get phoneNumberInputEle() {\n return this.textField.shadowRoot.querySelector('input');\n }\n\n get defaultDialCode() {\n return getCountryByCodeId(this.getAttribute('default-code'));\n }\n\n get defaultCode() {\n return this.getAttribute('default-code');\n }\n\n get allowAlphanumericInput() {\n return this.getAttribute('allow-alphanumeric-input') === 'true';\n }\n\n get minLength() {\n return parseInt(this.getAttribute('minlength'), 10) || 0;\n }\n\n get maxLength() {\n return parseInt(this.getAttribute('maxlength'), 10) || 50;\n }\n\n get restrictCountries() {\n return this.getAttribute('restrict-countries')?.split(',').filter(Boolean) || [];\n }\n\n get isFormatValue() {\n return this.getAttribute('format-value') === 'true';\n }\n\n get isStrictValidation() {\n return this.getAttribute('strict-validation') === 'true';\n }\n\n get value() {\n if (!this.textField.value) return '';\n\n if (!this.isStrictValidation) {\n return this.#nonParsedValue();\n }\n\n const parsedVal = this.#parseWithCountryCode();\n\n if (parsedVal?.country && parsedVal?.countryCallingCode && parsedVal?.nationalNumber) {\n return `+${[parsedVal?.countryCallingCode, parsedVal?.nationalNumber].join('-')}`;\n }\n\n // if failed to parse or to find country code return text field value\n return this.textField.value;\n }\n\n set value(val) {\n this.textField.value = val;\n }\n\n init() {\n this.addEventListener('focus', (e) => {\n // We want to ignore focus events we are dispatching\n if (e.isTrusted) this.textField.focus();\n });\n\n super.init?.();\n\n this.textField.addEventListener('input', this.#onInput.bind(this));\n this.handleFocusEventsDispatching([this.textField]);\n }\n\n getValidity() {\n const validPhonePattern = /^\\+?\\d{1,4}-?(?:\\d-?){1,15}$/;\n const stripValue = this.#sanitizeVal(this.textField.value);\n\n if (this.isRequired && !this.textField.value) {\n return { valueMissing: true };\n }\n\n if (this.textField.value) {\n if (stripValue.length < this.minLength) {\n return { tooShort: true };\n }\n\n if (\n // has `strict-validation` and not properly parsed\n (this.isStrictValidation && this.textField.value && !this.#isValidParsedValue()) ||\n // if no `strict-validation` then conform with naive pattern\n (!this.isStrictValidation && this.textField.value && !validPhonePattern.test(this.value))\n ) {\n return { patternMismatch: true };\n }\n }\n\n return {};\n }\n\n setSelectionRange(...args) {\n this.textField.setSelectionRange(...args);\n }\n\n attributeChangedCallback(attrName, oldValue, newValue) {\n super.attributeChangedCallback(attrName, oldValue, newValue);\n\n if (oldValue !== newValue && observedAttributes.includes(attrName)) {\n const attr = mapAttrs[attrName] || attrName;\n this.textField.setAttribute(attr, newValue);\n }\n }\n\n #onInput(e) {\n let sanitizedInput = this.#sanitizeInput(e.target.value);\n\n if (this.isFormatValue && this.#canFormat(sanitizedInput)) {\n sanitizedInput = this.#formatPhoneNumber(sanitizedInput);\n }\n\n e.target.value = sanitizedInput;\n }\n\n #nonParsedValue() {\n if (!this.defaultDialCode) {\n return this.textField.value;\n }\n\n const nationalNumber = this.#trimDuplicateCountryCode(this.textField.value);\n const sanitizedVal = this.#sanitizeVal(nationalNumber);\n\n return [this.defaultDialCode, sanitizedVal].join('-');\n }\n\n #parseWithCountryCode() {\n if (this.defaultDialCode) {\n return parsePhoneNumberFromString(\n [this.defaultDialCode, this.#sanitizeVal(this.textField.value)].filter(Boolean).join('')\n );\n }\n\n // if default-code or not parsed - try to extract country code from value\n return parsePhoneNumberFromString(this.textField.value);\n }\n\n #sanitizeVal(val) {\n return val.replace(/\\D/g, '');\n }\n\n #trimDuplicateCountryCode(val) {\n if (this.textField.value?.[0] === '+') {\n const dialCodePrefixPattern = new RegExp(`^\\\\${this.defaultDialCode}`);\n const trimmed = val.replace(dialCodePrefixPattern, '');\n return trimmed;\n }\n return val;\n }\n\n #isValidParsedValue() {\n const parsed = parsePhoneNumberFromString(this.value);\n return (\n !!parsed && // parsed successfully (not undefined)\n !!parsed.isValid?.() && // Parsed object is valid\n !!parsed.country && // Parsed object with a country code\n !!this.#isAllowedCountry(parsed.country) && // Parsed with allowed country code\n (this.defaultCode ? this.defaultCode === parsed.country : true) // In case default country code is set validate parsed country matches it\n );\n }\n\n #isAllowedCountry(countryCode) {\n if (!this.restrictCountries.length) {\n return true;\n }\n\n return this.restrictCountries.includes(countryCode);\n }\n\n #sanitizeInput(val) {\n val = val\n .replace(/^-+/, '') // dash as first char\n .replace(/(?!^)\\+/g, '') // multiple plus symbols\n .replace('--', '-') // consecutive dashes\n .replace('+-', '+'); // dash following plus symbol\n\n if (!this.allowAlphanumericInput) {\n const telDigitsRegExp = /^[+\\d-\\(\\)]+$/;\n val = val\n .split('')\n .filter((char) => telDigitsRegExp.test(char))\n .join('');\n }\n\n return val;\n }\n\n #formatPhoneNumber(phoneNumber = '') {\n // Get country code from `default-code or` from phone number\n const countryCode = this.defaultCode || this.#getCountryCodeFromValue(phoneNumber);\n\n // Skip formatting if no country code is available\n if (!countryCode) {\n return phoneNumber;\n }\n\n // Update AsYouType country code if needed\n if (!this.#ayt || this.#ayt.country !== countryCode) {\n this.#ayt = new AsYouType(countryCode);\n }\n\n // We need to reset AsYouType instance before setting new input\n this.#ayt.reset();\n\n // Set AsYouType input\n const formattedVal = this.#ayt.input(phoneNumber) || phoneNumber;\n\n return formattedVal;\n }\n\n #getCountryCodeFromValue(val) {\n const parsed = parsePhoneNumberFromString(val);\n return parsed?.country || '';\n }\n\n #canFormat(val) {\n if (!matchingParenthesis(val)) return false;\n return true;\n }\n}\n\nexport default PhoneFieldInternal;\n","import { componentName as descopeInternalComponentName } from './descope-phone-input-box-internal/PhoneFieldInternalInputBox';\nimport { forwardAttrs, getComponentName } from '../../../helpers/componentHelpers';\nimport { compose } from '../../../helpers';\nimport {\n createProxy,\n createStyleMixin,\n draggableMixin,\n inputOverrideValidConstraintsMixin,\n proxyInputMixin,\n} from '../../../mixins';\nimport { TextFieldClass } from '../../descope-text-field/TextFieldClass';\nimport CountryCodes from '../CountryCodes';\nimport {\n resetInputLabelPosition,\n resetInputCursor,\n resetInputFieldDefaultWidth,\n resetInputFieldInvalidBackgroundColor,\n useHostExternalPadding,\n inputFloatingLabelStyle,\n} from '../../../helpers/themeHelpers/resetHelpers';\n\nconst textVars = TextFieldClass.cssVarList;\n\nexport const componentName = getComponentName('phone-input-box-field');\n\nconst customMixin = (superclass) =>\n class PhoneFieldInputBoxMixinClass extends superclass {\n static get CountryCodes() {\n return CountryCodes;\n }\n\n init() {\n super.init?.();\n\n const template = document.createElement('template');\n\n template.innerHTML = `\n\t\t\t\t<${descopeInternalComponentName}\n\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\tslot=\"input\"\n\t\t\t\t></${descopeInternalComponentName}>\n `;\n\n this.baseElement.appendChild(template.content.cloneNode(true));\n\n this.inputElement = this.shadowRoot.querySelector(descopeInternalComponentName);\n\n forwardAttrs(this.shadowRoot.host, this.inputElement, {\n includeAttrs: [\n 'size',\n 'minlength',\n 'maxlength',\n 'default-code',\n 'disabled',\n 'phone-input-placeholder',\n 'label',\n 'label-type',\n 'allow-alphanumeric-input',\n 'restrict-countries',\n 'format-value',\n 'strict-validation',\n 'data-errormessage-type-mismatch',\n ],\n });\n }\n\n get phoneNumberInputEle() {\n return this.inputElement?.phoneNumberInputEle;\n }\n };\n\nconst {\n host,\n label,\n inputElement,\n requiredIndicator,\n inputField,\n internalComponent,\n internalComponentAfter,\n phoneInput,\n errorMessage,\n helperText,\n} = {\n host: { selector: () => ':host' },\n label: { selector: '::part(label)' },\n placeholder: { selector: '> input:placeholder-shown' },\n inputElement: { selector: 'input' },\n requiredIndicator: { selector: '[required]::part(required-indicator)::after' },\n inputField: { selector: () => 'vaadin-text-field::part(input-field)' },\n internalComponent: {\n selector: 'descope-phone-field-internal-input-box',\n },\n internalComponentAfter: {\n selector: 'descope-phone-field-internal-input-box::after',\n },\n phoneInput: { selector: () => 'descope-text-field' },\n helperText: { selector: '::part(helper-text)' },\n errorMessage: { selector: '::part(error-message)' },\n};\n\nexport const PhoneFieldInputBoxClass = compose(\n createStyleMixin({\n mappings: {\n fontSize: [\n host,\n inputField,\n {\n selector: TextFieldClass.componentName,\n property: TextFieldClass.cssVarList.fontSize,\n },\n ],\n fontFamily: [label, errorMessage, helperText],\n hostWidth: { ...host, property: 'width' },\n hostMinWidth: { ...host, property: 'min-width' },\n hostDirection: { ...host, property: 'direction' },\n\n inputHorizontalPadding: [\n { ...phoneInput, property: 'padding-left' },\n { ...phoneInput, property: 'padding-right' },\n ],\n\n labelFontSize: { ...label, property: 'font-size' },\n labelFontWeight: { ...label, property: 'font-weight' },\n labelTextColor: [\n { ...label, property: 'color' },\n { ...requiredIndicator, property: 'color' },\n ],\n labelRequiredIndicator: { ...requiredIndicator, property: 'content' },\n errorMessageTextColor: { ...errorMessage, property: 'color' },\n\n errorMessageIcon: { ...errorMessage, property: 'background-image' },\n errorMessageIconSize: { ...errorMessage, property: 'background-size' },\n errorMessageIconPadding: { ...errorMessage, property: 'padding-inline-start' },\n errorMessageIconRepeat: { ...errorMessage, property: 'background-repeat' },\n errorMessageIconPosition: { ...errorMessage, property: 'background-position' },\n errorMessageFontSize: { ...errorMessage, property: 'font-size' },\n\n inputValueTextColor: { ...phoneInput, property: textVars.inputValueTextColor },\n\n inputPlaceholderTextColor: { ...phoneInput, property: textVars.inputPlaceholderColor },\n\n inputBorderStyle: { ...internalComponentAfter, property: 'border-style' },\n inputBorderWidth: { ...internalComponentAfter, property: 'border-width' },\n inputBorderColor: { ...internalComponentAfter, property: 'border-color' },\n inputBorderRadius: [\n { ...internalComponent, property: 'border-radius' },\n { ...internalComponentAfter, property: 'border-radius' },\n ],\n\n inputOutlineStyle: { ...internalComponent, property: 'outline-style' },\n inputOutlineColor: { ...internalComponent, property: 'outline-color' },\n inputOutlineWidth: { ...internalComponent, property: 'outline-width' },\n inputOutlineOffset: { ...internalComponent, property: 'outline-offset' },\n\n labelPosition: { ...label, property: 'position' },\n labelTopPosition: { ...label, property: 'top' },\n labelHorizontalPosition: [\n { ...label, property: 'left' },\n { ...label, property: 'right' },\n ],\n inputTransformY: { ...label, property: 'transform' },\n inputTransition: { ...label, property: 'transition' },\n marginInlineStart: { ...label, property: 'margin-inline-start' },\n valueInputHeight: { ...inputElement, property: 'height' },\n valueInputMarginBottom: {\n selector: TextFieldClass.componentName,\n property: textVars.valueInputMarginBottom,\n },\n },\n }),\n draggableMixin,\n inputOverrideValidConstraintsMixin,\n proxyInputMixin({ proxyProps: ['value', 'selectionStart'] }),\n customMixin\n)(\n createProxy({\n slots: [],\n wrappedEleName: 'vaadin-text-field',\n style: () => `\n :host {\n display: inline-flex;\n max-width: 100%;\n box-sizing: border-box;\n }\n ${useHostExternalPadding(PhoneFieldInputBoxClass.cssVarList)}\n ${resetInputCursor('vaadin-text-field')}\n ${resetInputFieldInvalidBackgroundColor('vaadin-text-field')}\n ${resetInputFieldDefaultWidth()}\n\n vaadin-text-field {\n width: 100%;\n box-sizing: border-box;\n padding: 0;\n }\n vaadin-text-field[focus-ring]::part(input-field) {\n box-shadow: none;\n }\n vaadin-text-field::before {\n height: 0;\n }\n vaadin-text-field::part(input-field) {\n padding: 0;\n background: transparent;\n -webkit-mask-image: none;\n }\n descope-phone-field-internal-input-box {\n -webkit-mask-image: none;\n padding: 0;\n width: 100%;\n }\n descope-phone-field-internal-input-box > div {\n width: 100%;\n }\n descope-phone-field-internal-input-box descope-text-field {\n ${textVars.inputOutlineWidth}: 0;\n ${textVars.inputOutlineOffset}: 0;\n }\n descope-phone-field-internal-input-box::after {\n content: '';\n position: absolute;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n box-sizing: border-box;\n pointer-events: none;\n }\n descope-text-field {\n flex-grow: 1;\n width: 100%;\n direction: ltr;\n }\n vaadin-text-field[readonly] > input:placeholder-shown {\n opacity: 1;\n }\n vaadin-text-field::part(input-field)::after {\n border: none;\n }\n\n vaadin-text-field[label-type=\"floating\"]:not([focused])[readonly] input:placeholder-shown {\n opacity: 0;\n }\n vaadin-text-field[label-type=\"floating\"]:not([focused])[disabled] input:placeholder-shown {\n opacity: 0;\n }\n\n ${resetInputLabelPosition('vaadin-text-field')}\n ${inputFloatingLabelStyle()}\n\t\t`,\n excludeAttrsSync: ['tabindex'],\n componentName,\n })\n);\n\nexport default PhoneFieldInputBoxClass;\n","import './descope-phone-input-box-internal';\nimport '../../descope-text-field';\n\nimport { componentName, PhoneFieldInputBoxClass } from './PhoneFieldInputBoxClass';\n\ncustomElements.define(componentName, PhoneFieldInputBoxClass);\n\nexport { PhoneFieldInputBoxClass, componentName };\n","const NUMERIC_RE = /^\\d+$/;\n\nexport const isNumericValue = (val) => NUMERIC_RE.test(val.replaceAll('+', '').replaceAll('-', ''));\n\nexport const sanitizeCountryCodePrefix = (val) => val.replace(/\\+\\d+-/, '');\n","import { createStyleMixin, draggableMixin, componentNameValidationMixin } from '../../mixins';\nimport { createBaseClass } from '../../baseClasses/createBaseClass';\nimport { compose } from '../../helpers';\nimport { forwardAttrs, getComponentName } from '../../helpers/componentHelpers';\nimport { isNumericValue, sanitizeCountryCodePrefix as sanitizeValue } from './helpers';\nimport { PhoneFieldClass } from '../phone-fields/descope-phone-field/PhoneFieldClass';\nimport { PhoneFieldInputBoxClass } from '../phone-fields/descope-phone-input-box-field/PhoneFieldInputBoxClass';\nimport { injectStyle } from '@descope-ui/common/components-helpers';\n\nexport const componentName = getComponentName('hybrid-field');\n\nconst attrs = {\n shared: [\n 'bordered',\n 'full-width',\n 'label-type',\n 'size',\n 'disabled',\n 'readonly',\n 'required',\n 'st-host-direction',\n 'st-error-message-icon',\n 'st-error-message-icon-size',\n 'st-error-message-icon-padding',\n ],\n email: [\n 'label',\n 'placeholder',\n 'data-errormessage-value-missing-email',\n 'data-errormessage-pattern-mismatch-email',\n 'external-input',\n ],\n phone: {\n countryCode: [\n 'phone-input-label',\n 'country-input-label',\n 'country-input-placeholder',\n 'restrict-countries',\n 'default-code',\n 'phone-minlength',\n 'phone-format-value',\n 'phone-strict-validation',\n 'data-errormessage-value-missing-phone',\n ],\n inputBox: [\n 'label',\n 'restrict-countries',\n 'default-code',\n 'phone-minlength',\n 'phone-format-value',\n 'phone-strict-validation',\n 'data-errormessage-value-missing-phone',\n ],\n },\n};\n\nconst attrMap = {\n email: {\n 'data-errormessage-value-missing-email': 'data-errormessage-value-missing',\n 'data-errormessage-pattern-mismatch-email': 'data-errormessage-pattern-mismatch',\n },\n phone: {\n 'phone-input-label': 'label',\n 'phone-minlength': 'minlength',\n 'phone-format-value': 'format-value',\n 'phone-strict-validation': 'strict-validation',\n 'data-errormessage-value-missing-phone': 'data-errormessage-value-missing',\n },\n};\n\nconst EMAIL_FIELD = 'descope-email-field';\nconst PHONE_FIELD = 'descope-phone-field';\nconst PHONE_INPUT_BOX_FIELD = 'descope-phone-input-box-field';\n\nconst BaseClass = createBaseClass({\n componentName,\n baseSelector: 'div',\n});\n\nclass RawHybridField extends BaseClass {\n #isReportedValidity = false;\n\n #selectionStart;\n\n constructor() {\n super();\n\n this.attachShadow({ mode: 'open' }).innerHTML = `\n <div class=\"wrapper\">\n <descope-email-field external-input=\"${this.isExternalInput}\"></descope-email-field>\n <descope-phone-field allow-alphanumeric-input=\"true\"></descope-phone-field>\n <descope-phone-input-box-field allow-alphanumeric-input=\"true\"></descope-phone-input-box-field>\n </div>\n\t\t`;\n\n injectStyle(\n `\n :host {\n display: inline-flex;\n box-sizing: border-box;\n padding: 0;\n gap: 0;\n }\n .wrapper {\n display: grid;\n width: 100%;\n }\n descope-email-field,\n descope-phone-field,\n descope-phone-input-box-field {\n grid-area: 1/1;\n width: 100%;\n height: 100%;\n }\n .hidden {\n visibility: hidden;\n }\n `,\n this\n );\n }\n\n get isExternalInput() {\n return this.getAttribute('external-input') === 'true';\n }\n\n get emailInputEle() {\n return this.isExternalInput ? this.emailInput.externalInput : this.emailInput.inputElement;\n }\n\n get phoneVariant() {\n const isInputBox = this.getAttribute('phone-variant') === 'inputBox';\n return isInputBox ? this.phoneInputBoxInput : this.phoneCountryCodeInput;\n }\n\n get defaultCode() {\n const firstItem = this.phoneCountryCodeInput.countryCodes?.[0] || '';\n return this.getAttribute('default-code') || firstItem;\n }\n\n get activeInputEle() {\n if (this.activeInput === this.emailInput) {\n return this.emailInputEle;\n }\n return this.phoneVariant.phoneNumberInputEle;\n }\n\n get value() {\n return this.activeInput?.value || '';\n }\n\n set value(val) {\n this.handleActiveInput(val);\n this.activeInput.value = val;\n }\n\n async init() {\n super.init?.();\n\n this.initInputs();\n this.updateAttrs();\n this.toggleInputVisibility();\n\n await this.waitForInputs();\n\n this.initInputEles();\n this.overrideEmailInputType();\n this.overrideEmailSetAttribute();\n }\n\n waitForInputs() {\n return new Promise((resolve) => {\n const check = setInterval(() => {\n if (this.emailInputEle) {\n clearInterval(check);\n resolve();\n }\n });\n });\n }\n\n initInputs() {\n this.emailInput = this.shadowRoot.querySelector(EMAIL_FIELD);\n this.phoneCountryCodeInput = this.shadowRoot.querySelector(PHONE_FIELD);\n this.phoneInputBoxInput = this.shadowRoot.querySelector(PHONE_INPUT_BOX_FIELD);\n\n this.inputs = [this.emailInput, this.phoneCountryCodeInput, this.phoneInputBoxInput];\n\n this.activeInput = this.emailInput;\n }\n\n // we need to listen on the inner `input` element itself, otherwise we don't always get an `input` event\n initInputEles() {\n const inputEles = [\n this.emailInputEle,\n this.phoneCountryCodeInput.phoneNumberInputEle,\n this.phoneInputBoxInput.phoneNumberInputEle,\n ];\n\n inputEles.forEach((ele) => {\n ele.addEventListener('input', this.onValueChange.bind(this));\n });\n }\n\n overrideEmailInputType() {\n this.emailInputEle.addEventListener('focus', () => {\n this.emailInputEle.setAttribute('type', 'text');\n });\n this.emailInputEle.addEventListener('blur', () => {\n setTimeout(() => {\n this.emailInputEle.setAttribute('type', 'email');\n });\n });\n }\n\n // We want to prevent Vaadin from changing the input type to `email`\n // otherwise, we cannot get the selectionStart from the input.\n overrideEmailSetAttribute() {\n const origEmailSetAttr = this.emailInput.setAttribute.bind(this.emailInputEle);\n this.emailInputEle.setAttribute = (name, value) => {\n if (name !== 'type' || value !== 'email' || !this.emailInput.hasAttribute('focused')) {\n return origEmailSetAttr(name, value);\n }\n return false;\n };\n }\n\n updateAttrs() {\n forwardAttrs(this, this.emailInput, { includeAttrs: attrs.email, mapAttrs: attrMap.email });\n\n forwardAttrs(this, this.phoneCountryCodeInput, {\n includeAttrs: attrs.phone.countryCode,\n mapAttrs: attrMap.phone,\n });\n\n forwardAttrs(this, this.phoneInputBoxInput, {\n includeAttrs: attrs.phone.inputBox,\n mapAttrs: attrMap.phone,\n });\n\n this.inputs.forEach((input) => forwardAttrs(this, input, { includeAttrs: attrs.shared }));\n\n setTimeout(() => this.phoneCountryCodeInput.setAttribute('default-code', this.defaultCode));\n }\n\n onValueChange() {\n this.#selectionStart = this.activeInputEle.selectionStart;\n this.handleActiveInput(this.activeInput.value);\n }\n\n handleActiveInput(val) {\n const expectedActiveInput = isNumericValue(val) ? this.phoneVariant : this.emailInput;\n\n if (this.activeInput !== expectedActiveInput) {\n this.setActiveInput(expectedActiveInput);\n }\n }\n\n setActiveInput(expectedActiveInput) {\n const val = this.activeInput.value;\n this.activeInput = expectedActiveInput;\n this.setActiveInputValue(val);\n if (this.#isReportedValidity) this.activeInput.reportValidity();\n this.setActiveInputSelectionStart();\n this.toggleInputVisibility();\n }\n\n setActiveInputSelectionStart() {\n setTimeout(() => {\n this.activeInputEle.focus();\n this.activeInputEle.setSelectionRange?.(this.#selectionStart, this.#selectionStart);\n });\n }\n\n setActiveInputValue(val) {\n const sanitizedVal = sanitizeValue(val);\n const isPhoneField = this.activeInput.localName === PHONE_FIELD;\n const value = isPhoneField\n ? `${this.phoneCountryCodeInput.countryCodeItems}-${sanitizedVal}`\n : sanitizedVal;\n this.activeInput.value = value;\n }\n\n toggleInputVisibility() {\n this.inputs.forEach((input) => {\n input !== this.activeInput ? input.classList.add('hidden') : input.classList.remove('hidden');\n });\n }\n\n reportValidity() {\n this.#isReportedValidity = true;\n\n const ele = this.activeInputEle;\n\n // On reportValidity we want to set the caret at the end of the input value.\n // Since checkValidity triggers `focus` on the input, it sets the caret at the start of the input,\n // regardless the existing value.\n setTimeout(() => {\n ele.setSelectionRange?.(ele.value.length, ele.value.length);\n });\n\n return this.activeInput.reportValidity();\n }\n\n checkValidity() {\n return this.activeInput.checkValidity();\n }\n}\n\nexport const HybridFieldClass = compose(\n createStyleMixin({ componentNameOverride: getComponentName('input-wrapper') }),\n createStyleMixin({\n mappings: {\n hostWidth: { selector: () => ':host', property: 'width' },\n hostDirection: [\n { selector: () => 'descope-email-field', property: 'direction' },\n { selector: () => 'descope-phone-field', property: 'direction' },\n { selector: () => 'descope-phone-input-box-field', property: 'direction' },\n ],\n errorMessageIcon: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIcon,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIcon,\n },\n ],\n errorMessageIconSize: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconSize,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconSize,\n },\n ],\n errorMessageIconPadding: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconPadding,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconPadding,\n },\n ],\n errorMessageIconRepeat: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconRepeat,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconRepeat,\n },\n ],\n errorMessageIconPosition: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconPosition,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconPosition,\n },\n ],\n errorMessageFontSize: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageFontSize,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageFontSize,\n },\n ],\n },\n }),\n draggableMixin,\n componentNameValidationMixin\n)(RawHybridField);\n","import '../descope-email-field';\nimport '../phone-fields/descope-phone-field';\nimport '../phone-fields/descope-phone-input-box-field';\n\nimport { componentName, HybridFieldClass } from './HybridFieldClass';\n\ncustomElements.define(componentName, HybridFieldClass);\n\nexport { HybridFieldClass, componentName };\n","/**\n * @license\n * Copyright (c) 2021 - 2023 Vaadin Ltd.\n * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/\n */\nimport { inputFieldShared } from '@vaadin/vaadin-lumo-styles/mixins/input-field-shared.js';\nimport { css, registerStyles } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js';\n\nconst emailField = css`\n :host([dir='rtl']) [part='input-field'] ::slotted(input) {\n --_lumo-text-field-overflow-mask-image: linear-gradient(to left, transparent, #000 1.25em);\n }\n\n :host([dir='rtl']) [part='input-field'] ::slotted(input:placeholder-shown) {\n --_lumo-text-field-overflow-mask-image: none;\n }\n`;\n\nregisterStyles('vaadin-email-field', [inputFieldShared, emailField], {\n moduleId: 'lumo-email-field',\n});\n","/**\n * @license\n * Copyright (c) 2021 - 2023 Vaadin Ltd.\n * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/\n */\nimport { css } from 'lit';\n\n// See https://github.com/vaadin/vaadin-text-field/issues/466\nexport const emailFieldStyles = css`\n :host([dir='rtl']) [part='input-field'] {\n direction: ltr;\n }\n\n :host([dir='rtl']) [part='input-field'] ::slotted(input)::placeholder {\n direction: rtl;\n text-align: left;\n }\n`;\n","/**\n * @license\n * Copyright (c) 2021 - 2023 Vaadin Ltd.\n * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/\n */\nimport { defineCustomElement } from '@vaadin/component-base/src/define.js';\nimport { TextField } from '@vaadin/text-field/src/vaadin-text-field.js';\nimport { registerStyles } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js';\nimport { emailFieldStyles } from './vaadin-email-field-styles.js';\n\nregisterStyles('vaadin-email-field', emailFieldStyles, { moduleId: 'vaadin-email-field-styles' });\n\n/**\n * `<vaadin-email-field>` is a Web Component for email field control in forms.\n *\n * ```html\n * <vaadin-email-field label=\"Email\"></vaadin-email-field>\n * ```\n *\n * ### Styling\n *\n * `<vaadin-email-field>` provides the same set of shadow DOM parts and state attributes as `<vaadin-text-field>`.\n * See [`<vaadin-text-field>`](#/elements/vaadin-text-field) for the styling documentation.\n *\n * See [Styling Components](https://vaadin.com/docs/latest/styling/styling-components) documentation.\n *\n * @fires {Event} input - Fired when the value is changed by the user: on every typing keystroke, and the value is cleared using the clear button.\n * @fires {Event} change - Fired when the user commits a value change.\n * @fires {CustomEvent} invalid-changed - Fired when the `invalid` property changes.\n * @fires {CustomEvent} value-changed - Fired when the `value` property changes.\n * @fires {CustomEvent} validated - Fired whenever the field is validated.\n *\n * @customElement\n * @extends TextField\n */\nexport class EmailField extends TextField {\n static get is() {\n return 'vaadin-email-field';\n }\n\n constructor() {\n super();\n this._setType('email');\n this.pattern = '^([a-zA-Z0-9_\\\\.\\\\-+])+@[a-zA-Z0-9\\\\-.]+\\\\.[a-zA-Z0-9\\\\-]{2,}$';\n }\n\n /** @protected */\n ready() {\n super.ready();\n\n if (this.inputElement) {\n this.inputElement.autocapitalize = 'off';\n }\n }\n}\n\ndefineCustomElement(EmailField);\n","import {\n createStyleMixin,\n draggableMixin,\n createProxy,\n proxyInputMixin,\n componentNameValidationMixin,\n externalInputMixin,\n} from '../../mixins';\nimport textFieldMappings from '../descope-text-field/textFieldMappings';\nimport { compose } from '../../helpers';\nimport { getComponentName } from '../../helpers/componentHelpers';\nimport {\n inputFloatingLabelStyle,\n resetInputLabelPosition,\n resetInputOverrides,\n useHostExternalPadding,\n} from '../../helpers/themeHelpers/resetHelpers';\n\nexport const componentName = getComponentName('email-field');\n\nconst defaultPattern = \"^[\\\\w\\\\.\\\\%\\\\+\\\\-']+@[\\\\w\\\\.\\\\-]+\\\\.[A-Za-z]{2,}$\";\nconst defaultAutocomplete = 'username';\n\nconst customMixin = (superclass) =>\n class EmailFieldMixinClass extends superclass {\n init() {\n super.init?.();\n\n // we need to set the pattern on the base element because vaadin-email-field is overriding it\n this.baseElement.setAttribute('pattern', defaultPattern);\n\n if (!this.getAttribute('autocomplete')) {\n this.setAttribute('autocomplete', defaultAutocomplete);\n }\n\n this.createExternalInput();\n }\n };\n\nexport const EmailFieldClass = compose(\n createStyleMixin({\n mappings: textFieldMappings,\n }),\n draggableMixin,\n externalInputMixin({\n inputType: 'email',\n inputName: 'email',\n autocompleteType: 'username',\n includeAttrs: ['disabled', 'readonly', 'pattern'],\n }),\n proxyInputMixin({ proxyProps: ['value', 'selectionStart'], useProxyTargets: true }),\n componentNameValidationMixin,\n customMixin\n)(\n createProxy({\n slots: ['', 'suffix'],\n wrappedEleName: 'vaadin-email-field',\n style: () => `\n\t\t\t:host {\n\t\t\t\tdisplay: inline-block;\n\t\t\t\tmax-width: 100%;\n\t\t\t\tpadding: calc(var(${EmailFieldClass.cssVarList.inputOutlineWidth}) + var(${\n EmailFieldClass.cssVarList.inputOutlineOffset\n }));\n box-sizing: border-box;\n\t\t\t}\n ${resetInputLabelPosition('vaadin-email-field')}\n\t\t\t${useHostExternalPadding(EmailFieldClass.cssVarList)}\n\t\t\t${resetInputOverrides('vaadin-email-field', EmailFieldClass.cssVarList)}\n ${inputFloatingLabelStyle()}\n\n vaadin-email-field[label-type=\"floating\"]:not([focused])[readonly] > input:placeholder-shown {\n opacity: 0;\n }\n vaadin-email-field[label-type=\"floating\"]:not([focused])[disabled] > input:placeholder-shown {\n opacity: 0;\n }\n\n :host ::slotted(*) {\n -webkit-mask-image: none;\n }\n\n vaadin-email-field[external-input=\"true\"] > input:not(:placeholder-shown) {\n opacity: 0;\n }\n\t\t`,\n excludeAttrsSync: ['tabindex'],\n componentName,\n })\n);\n","import '@vaadin/email-field';\nimport { componentName, EmailFieldClass } from './EmailFieldClass';\n\ncustomElements.define(componentName, EmailFieldClass);\n\nexport { EmailFieldClass, componentName };\n","import '../../../descope-text-field';\n\nimport PhoneFieldInternalInputBox, { componentName } from './PhoneFieldInternalInputBox';\n\ncustomElements.define(componentName, PhoneFieldInternalInputBox);\n","import parsePhoneNumberFromString from 'libphonenumber-js/min';\nimport CountryCodes from './CountryCodes';\n\nexport const getCountryByCodeId = (countryCode) => {\n return CountryCodes.find((c) => c.code === countryCode)?.dialCode;\n};\n\nexport const matchingParenthesis = (val) => {\n const openParenMatches = val.match(/\\(/g);\n const closeParenMatches = val.match(/\\)/g);\n return openParenMatches?.length === closeParenMatches?.length;\n};\n"],"names":["componentName","observedAttributes","mapAttrs","BaseInputClass","baseSelector","concat","constructor","super","this","innerHTML","textField","querySelector","phoneNumberInputEle","shadowRoot","defaultDialCode","getAttribute","defaultCode","allowAlphanumericInput","minLength","parseInt","maxLength","restrictCountries","split","filter","Boolean","isFormatValue","isStrictValidation","value","parsedVal","country","countryCallingCode","nationalNumber","join","val","init","addEventListener","e","isTrusted","focus","bind","handleFocusEventsDispatching","getValidity","validPhonePattern","stripValue","isRequired","valueMissing","length","tooShort","test","patternMismatch","setSelectionRange","args","attributeChangedCallback","attrName","oldValue","newValue","includes","attr","setAttribute","sanitizedInput","target","sanitizedVal","replace","dialCodePrefixPattern","RegExp","parsed","isValid","countryCode","telDigitsRegExp","char","phoneNumber","reset","input","textVars","cssVarList","host","label","inputElement","requiredIndicator","inputField","internalComponent","internalComponentAfter","phoneInput","errorMessage","helperText","selector","placeholder","PhoneFieldInputBoxClass","mappings","fontSize","property","fontFamily","hostWidth","hostMinWidth","hostDirection","inputHorizontalPadding","labelFontSize","labelFontWeight","labelTextColor","labelRequiredIndicator","errorMessageTextColor","errorMessageIcon","errorMessageIconSize","errorMessageIconPadding","errorMessageIconRepeat","errorMessageIconPosition","errorMessageFontSize","inputValueTextColor","inputPlaceholderTextColor","inputPlaceholderColor","inputBorderStyle","inputBorderWidth","inputBorderColor","inputBorderRadius","inputOutlineStyle","inputOutlineColor","inputOutlineWidth","inputOutlineOffset","labelPosition","labelTopPosition","labelHorizontalPosition","inputTransformY","inputTransition","marginInlineStart","valueInputHeight","valueInputMarginBottom","proxyProps","superclass","CountryCodes","template","document","createElement","baseElement","appendChild","content","cloneNode","includeAttrs","slots","wrappedEleName","style","excludeAttrsSync","customElements","define","NUMERIC_RE","attrs","shared","email","phone","inputBox","attrMap","PHONE_FIELD","BaseClass","createBaseClass","HybridFieldClass","componentNameOverride","PhoneFieldClass","attachShadow","mode","isExternalInput","emailInputEle","emailInput","externalInput","phoneVariant","phoneInputBoxInput","phoneCountryCodeInput","firstItem","countryCodes","activeInputEle","activeInput","handleActiveInput","initInputs","updateAttrs","toggleInputVisibility","waitForInputs","initInputEles","overrideEmailInputType","overrideEmailSetAttribute","Promise","resolve","check","setInterval","clearInterval","inputs","forEach","ele","onValueChange","setTimeout","origEmailSetAttr","name","hasAttribute","selectionStart","expectedActiveInput","replaceAll","isNumericValue","setActiveInput","setActiveInputValue","reportValidity","setActiveInputSelectionStart","localName","countryCodeItems","classList","add","remove","checkValidity","emailField","moduleId","emailFieldStyles","EmailField","is","_setType","pattern","ready","autocapitalize","EmailFieldClass","textFieldMappings","inputType","inputName","autocompleteType","useProxyTargets","createExternalInput","getCountryByCodeId","find","c","code","dialCode","matchingParenthesis","openParenMatches","match","closeParenMatches"],"sourceRoot":""}
|
1
|
+
{"version":3,"file":"descope-hybrid-field-index-js.js","mappings":"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","sources":["webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/descope-phone-input-box-internal/PhoneFieldInternalInputBox.js","webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/PhoneFieldInputBoxClass.js","webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/index.js","webpack://@descope/web-components-ui/./src/components/descope-hybrid-field/helpers.js","webpack://@descope/web-components-ui/./src/components/descope-hybrid-field/HybridFieldClass.js","webpack://@descope/web-components-ui/./src/components/descope-hybrid-field/index.js","webpack://@descope/web-components-ui/../../../node_modules/@vaadin/email-field/theme/lumo/vaadin-email-field-styles.js","webpack://@descope/web-components-ui/../../../node_modules/@vaadin/email-field/src/vaadin-email-field-styles.js","webpack://@descope/web-components-ui/../../../node_modules/@vaadin/email-field/src/vaadin-email-field.js","webpack://@descope/web-components-ui/./src/components/descope-email-field/EmailFieldClass.js","webpack://@descope/web-components-ui/./src/components/descope-email-field/index.js","webpack://@descope/web-components-ui/./src/components/phone-fields/descope-phone-input-box-field/descope-phone-input-box-internal/index.js","webpack://@descope/web-components-ui/./src/components/phone-fields/helpers.js"],"sourcesContent":["import { createBaseInputClass } from '../../../../baseClasses/createBaseInputClass';\nimport { getComponentName } from '../../../../helpers/componentHelpers';\nimport { getCountryByCodeId, matchingParenthesis } from '../../helpers';\nimport parsePhoneNumberFromString, { AsYouType } from 'libphonenumber-js/min';\n\nexport const componentName = getComponentName('phone-field-internal-input-box');\n\nconst observedAttributes = [\n 'disabled',\n 'size',\n 'readonly',\n 'phone-input-placeholder',\n 'name',\n 'maxlength',\n 'autocomplete',\n 'label-type',\n];\nconst mapAttrs = {\n 'phone-input-placeholder': 'placeholder',\n};\n\nconst BaseInputClass = createBaseInputClass({ componentName, baseSelector: 'div' });\n\nclass PhoneFieldInternal extends BaseInputClass {\n static get observedAttributes() {\n return [].concat(BaseInputClass.observedAttributes || [], observedAttributes);\n }\n\n #ayt;\n\n constructor() {\n super();\n\n this.innerHTML = `\n <div>\n <descope-text-field tabindex=\"1\" type=\"tel\" bordered=\"false\"></descope-text-field>\n </div>\n `;\n\n this.textField = this.querySelector('descope-text-field');\n }\n\n // notice: this function is exposed in parent component\n get phoneNumberInputEle() {\n return this.textField.shadowRoot.querySelector('input');\n }\n\n get defaultDialCode() {\n return getCountryByCodeId(this.getAttribute('default-code'));\n }\n\n get defaultCode() {\n return this.getAttribute('default-code');\n }\n\n get allowAlphanumericInput() {\n return this.getAttribute('allow-alphanumeric-input') === 'true';\n }\n\n get minLength() {\n return parseInt(this.getAttribute('minlength'), 10) || 0;\n }\n\n get maxLength() {\n return parseInt(this.getAttribute('maxlength'), 10) || 50;\n }\n\n get restrictCountries() {\n return this.getAttribute('restrict-countries')?.split(',').filter(Boolean) || [];\n }\n\n get isFormatValue() {\n return this.getAttribute('format-value') === 'true';\n }\n\n get isStrictValidation() {\n return this.getAttribute('strict-validation') === 'true';\n }\n\n get value() {\n if (!this.textField.value) return '';\n\n if (!this.isStrictValidation) {\n return this.#nonParsedValue();\n }\n\n const parsedVal = this.#parseWithCountryCode();\n\n if (parsedVal?.country && parsedVal?.countryCallingCode && parsedVal?.nationalNumber) {\n return `+${[parsedVal?.countryCallingCode, parsedVal?.nationalNumber].join('-')}`;\n }\n\n // if failed to parse or to find country code return text field value\n return this.textField.value;\n }\n\n set value(val) {\n this.textField.value = val;\n }\n\n init() {\n this.addEventListener('focus', (e) => {\n // We want to ignore focus events we are dispatching\n if (e.isTrusted) this.textField.focus();\n });\n\n super.init?.();\n\n this.textField.addEventListener('input', this.#onInput.bind(this));\n this.handleFocusEventsDispatching([this.textField]);\n }\n\n getValidity() {\n const validPhonePattern = /^\\+?\\d{1,4}-?(?:\\d-?){1,15}$/;\n const stripValue = this.#sanitizeVal(this.textField.value);\n\n if (this.isRequired && !this.textField.value) {\n return { valueMissing: true };\n }\n\n if (this.textField.value) {\n if (stripValue.length < this.minLength) {\n return { tooShort: true };\n }\n\n if (\n // has `strict-validation` and not properly parsed\n (this.isStrictValidation && this.textField.value && !this.#isValidParsedValue()) ||\n // if no `strict-validation` then conform with naive pattern\n (!this.isStrictValidation && this.textField.value && !validPhonePattern.test(this.value))\n ) {\n return { patternMismatch: true };\n }\n }\n\n return {};\n }\n\n setSelectionRange(...args) {\n this.textField.setSelectionRange(...args);\n }\n\n attributeChangedCallback(attrName, oldValue, newValue) {\n super.attributeChangedCallback(attrName, oldValue, newValue);\n\n if (oldValue !== newValue && observedAttributes.includes(attrName)) {\n const attr = mapAttrs[attrName] || attrName;\n this.textField.setAttribute(attr, newValue);\n }\n }\n\n #onInput(e) {\n let sanitizedInput = this.#sanitizeInput(e.target.value);\n\n if (this.isFormatValue && this.#canFormat(sanitizedInput)) {\n sanitizedInput = this.#formatPhoneNumber(sanitizedInput);\n }\n\n e.target.value = sanitizedInput;\n }\n\n #nonParsedValue() {\n if (!this.defaultDialCode) {\n return this.textField.value;\n }\n\n const nationalNumber = this.#trimDuplicateCountryCode(this.textField.value);\n const sanitizedVal = this.#sanitizeVal(nationalNumber);\n\n return [this.defaultDialCode, sanitizedVal].join('-');\n }\n\n #parseWithCountryCode() {\n if (this.defaultDialCode) {\n return parsePhoneNumberFromString(\n [this.defaultDialCode, this.#sanitizeVal(this.textField.value)].filter(Boolean).join('')\n );\n }\n\n // if default-code or not parsed - try to extract country code from value\n return parsePhoneNumberFromString(this.textField.value);\n }\n\n #sanitizeVal(val) {\n return val.replace(/\\D/g, '');\n }\n\n #trimDuplicateCountryCode(val) {\n if (this.textField.value?.[0] === '+') {\n const dialCodePrefixPattern = new RegExp(`^\\\\${this.defaultDialCode}`);\n const trimmed = val.replace(dialCodePrefixPattern, '');\n return trimmed;\n }\n return val;\n }\n\n #isValidParsedValue() {\n const parsed = parsePhoneNumberFromString(this.value);\n return (\n !!parsed && // parsed successfully (not undefined)\n !!parsed.isValid?.() && // Parsed object is valid\n !!parsed.country && // Parsed object with a country code\n !!this.#isAllowedCountry(parsed.country) && // Parsed with allowed country code\n (this.defaultCode ? this.defaultCode === parsed.country : true) // In case default country code is set validate parsed country matches it\n );\n }\n\n #isAllowedCountry(countryCode) {\n if (!this.restrictCountries.length) {\n return true;\n }\n\n return this.restrictCountries.includes(countryCode);\n }\n\n #sanitizeInput(val) {\n val = val\n .replace(/^-+/, '') // dash as first char\n .replace(/(?!^)\\+/g, '') // multiple plus symbols\n .replace('--', '-') // consecutive dashes\n .replace('+-', '+'); // dash following plus symbol\n\n if (!this.allowAlphanumericInput) {\n const telDigitsRegExp = /^[+\\d-\\(\\)]+$/;\n val = val\n .split('')\n .filter((char) => telDigitsRegExp.test(char))\n .join('');\n }\n\n return val;\n }\n\n #formatPhoneNumber(phoneNumber = '') {\n // Get country code from `default-code or` from phone number\n const countryCode = this.defaultCode || this.#getCountryCodeFromValue(phoneNumber);\n\n // Skip formatting if no country code is available\n if (!countryCode) {\n return phoneNumber;\n }\n\n // Update AsYouType country code if needed\n if (!this.#ayt || this.#ayt.country !== countryCode) {\n this.#ayt = new AsYouType(countryCode);\n }\n\n // We need to reset AsYouType instance before setting new input\n this.#ayt.reset();\n\n // Set AsYouType input\n const formattedVal = this.#ayt.input(phoneNumber) || phoneNumber;\n\n return formattedVal;\n }\n\n #getCountryCodeFromValue(val) {\n const parsed = parsePhoneNumberFromString(val);\n return parsed?.country || '';\n }\n\n #canFormat(val) {\n if (!matchingParenthesis(val)) return false;\n return true;\n }\n}\n\nexport default PhoneFieldInternal;\n","import { componentName as descopeInternalComponentName } from './descope-phone-input-box-internal/PhoneFieldInternalInputBox';\nimport { forwardAttrs, getComponentName } from '../../../helpers/componentHelpers';\nimport { compose } from '../../../helpers';\nimport {\n createProxy,\n createStyleMixin,\n draggableMixin,\n inputOverrideValidConstraintsMixin,\n proxyInputMixin,\n} from '../../../mixins';\nimport { TextFieldClass } from '../../descope-text-field/TextFieldClass';\nimport CountryCodes from '../CountryCodes';\nimport {\n resetInputLabelPosition,\n resetInputCursor,\n resetInputFieldDefaultWidth,\n resetInputFieldInvalidBackgroundColor,\n useHostExternalPadding,\n inputFloatingLabelStyle,\n} from '../../../helpers/themeHelpers/resetHelpers';\n\nconst textVars = TextFieldClass.cssVarList;\n\nexport const componentName = getComponentName('phone-input-box-field');\n\nconst customMixin = (superclass) =>\n class PhoneFieldInputBoxMixinClass extends superclass {\n static get CountryCodes() {\n return CountryCodes;\n }\n\n init() {\n super.init?.();\n\n const template = document.createElement('template');\n\n template.innerHTML = `\n\t\t\t\t<${descopeInternalComponentName}\n\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\tslot=\"input\"\n\t\t\t\t></${descopeInternalComponentName}>\n `;\n\n this.baseElement.appendChild(template.content.cloneNode(true));\n\n this.inputElement = this.shadowRoot.querySelector(descopeInternalComponentName);\n\n forwardAttrs(this.shadowRoot.host, this.inputElement, {\n includeAttrs: [\n 'size',\n 'minlength',\n 'maxlength',\n 'default-code',\n 'disabled',\n 'phone-input-placeholder',\n 'label',\n 'label-type',\n 'allow-alphanumeric-input',\n 'restrict-countries',\n 'format-value',\n 'strict-validation',\n 'data-errormessage-type-mismatch',\n ],\n });\n }\n\n get phoneNumberInputEle() {\n return this.inputElement?.phoneNumberInputEle;\n }\n };\n\nconst {\n host,\n label,\n inputElement,\n requiredIndicator,\n inputField,\n internalComponent,\n internalComponentAfter,\n phoneInput,\n errorMessage,\n helperText,\n} = {\n host: { selector: () => ':host' },\n label: { selector: '::part(label)' },\n placeholder: { selector: '> input:placeholder-shown' },\n inputElement: { selector: 'input' },\n requiredIndicator: { selector: '[required]::part(required-indicator)::after' },\n inputField: { selector: () => 'vaadin-text-field::part(input-field)' },\n internalComponent: {\n selector: 'descope-phone-field-internal-input-box',\n },\n internalComponentAfter: {\n selector: 'descope-phone-field-internal-input-box::after',\n },\n phoneInput: { selector: () => 'descope-text-field' },\n helperText: { selector: '::part(helper-text)' },\n errorMessage: { selector: '::part(error-message)' },\n};\n\nexport const PhoneFieldInputBoxClass = compose(\n createStyleMixin({\n mappings: {\n fontSize: [\n host,\n inputField,\n {\n selector: TextFieldClass.componentName,\n property: TextFieldClass.cssVarList.fontSize,\n },\n ],\n fontFamily: [label, errorMessage, helperText],\n hostWidth: { ...host, property: 'width' },\n hostMinWidth: { ...host, property: 'min-width' },\n hostDirection: { ...host, property: 'direction' },\n\n inputHorizontalPadding: [\n { ...phoneInput, property: 'padding-left' },\n { ...phoneInput, property: 'padding-right' },\n ],\n\n labelFontSize: { ...label, property: 'font-size' },\n labelFontWeight: { ...label, property: 'font-weight' },\n labelTextColor: [\n { ...label, property: 'color' },\n { ...requiredIndicator, property: 'color' },\n ],\n labelRequiredIndicator: { ...requiredIndicator, property: 'content' },\n errorMessageTextColor: { ...errorMessage, property: 'color' },\n\n errorMessageIcon: { ...errorMessage, property: 'background-image' },\n errorMessageIconSize: { ...errorMessage, property: 'background-size' },\n errorMessageIconPadding: { ...errorMessage, property: 'padding-inline-start' },\n errorMessageIconRepeat: { ...errorMessage, property: 'background-repeat' },\n errorMessageIconPosition: { ...errorMessage, property: 'background-position' },\n errorMessageFontSize: { ...errorMessage, property: 'font-size' },\n\n inputValueTextColor: { ...phoneInput, property: textVars.inputValueTextColor },\n\n inputPlaceholderTextColor: { ...phoneInput, property: textVars.inputPlaceholderColor },\n\n inputBorderStyle: { ...internalComponentAfter, property: 'border-style' },\n inputBorderWidth: { ...internalComponentAfter, property: 'border-width' },\n inputBorderColor: { ...internalComponentAfter, property: 'border-color' },\n inputBorderRadius: [\n { ...internalComponent, property: 'border-radius' },\n { ...internalComponentAfter, property: 'border-radius' },\n ],\n\n inputOutlineStyle: { ...internalComponent, property: 'outline-style' },\n inputOutlineColor: { ...internalComponent, property: 'outline-color' },\n inputOutlineWidth: { ...internalComponent, property: 'outline-width' },\n inputOutlineOffset: { ...internalComponent, property: 'outline-offset' },\n\n labelPosition: { ...label, property: 'position' },\n labelTopPosition: { ...label, property: 'top' },\n labelHorizontalPosition: [\n { ...label, property: 'left' },\n { ...label, property: 'right' },\n ],\n inputTransformY: { ...label, property: 'transform' },\n inputTransition: { ...label, property: 'transition' },\n marginInlineStart: { ...label, property: 'margin-inline-start' },\n valueInputHeight: { ...inputElement, property: 'height' },\n valueInputMarginBottom: {\n selector: TextFieldClass.componentName,\n property: textVars.valueInputMarginBottom,\n },\n },\n }),\n draggableMixin,\n inputOverrideValidConstraintsMixin,\n proxyInputMixin({ proxyProps: ['value', 'selectionStart'] }),\n customMixin\n)(\n createProxy({\n slots: [],\n wrappedEleName: 'vaadin-text-field',\n style: () => `\n :host {\n display: inline-flex;\n max-width: 100%;\n box-sizing: border-box;\n }\n ${useHostExternalPadding(PhoneFieldInputBoxClass.cssVarList)}\n ${resetInputCursor('vaadin-text-field')}\n ${resetInputFieldInvalidBackgroundColor('vaadin-text-field')}\n ${resetInputFieldDefaultWidth()}\n\n vaadin-text-field {\n width: 100%;\n box-sizing: border-box;\n padding: 0;\n }\n vaadin-text-field[focus-ring]::part(input-field) {\n box-shadow: none;\n }\n vaadin-text-field::before {\n height: 0;\n }\n vaadin-text-field::part(input-field) {\n padding: 0;\n background: transparent;\n -webkit-mask-image: none;\n }\n descope-phone-field-internal-input-box {\n -webkit-mask-image: none;\n padding: 0;\n width: 100%;\n }\n descope-phone-field-internal-input-box > div {\n width: 100%;\n }\n descope-phone-field-internal-input-box descope-text-field {\n ${textVars.inputOutlineWidth}: 0;\n ${textVars.inputOutlineOffset}: 0;\n }\n descope-phone-field-internal-input-box::after {\n content: '';\n position: absolute;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n box-sizing: border-box;\n pointer-events: none;\n }\n descope-text-field {\n flex-grow: 1;\n width: 100%;\n direction: ltr;\n }\n vaadin-text-field[readonly] > input:placeholder-shown {\n opacity: 1;\n }\n vaadin-text-field::part(input-field)::after {\n border: none;\n }\n\n vaadin-text-field[label-type=\"floating\"]:not([focused])[readonly] input:placeholder-shown {\n opacity: 0;\n }\n vaadin-text-field[label-type=\"floating\"]:not([focused])[disabled] input:placeholder-shown {\n opacity: 0;\n }\n\n ${resetInputLabelPosition('vaadin-text-field')}\n ${inputFloatingLabelStyle()}\n\t\t`,\n excludeAttrsSync: ['tabindex'],\n componentName,\n })\n);\n\nexport default PhoneFieldInputBoxClass;\n","import './descope-phone-input-box-internal';\nimport '../../descope-text-field';\n\nimport { componentName, PhoneFieldInputBoxClass } from './PhoneFieldInputBoxClass';\n\ncustomElements.define(componentName, PhoneFieldInputBoxClass);\n\nexport { PhoneFieldInputBoxClass, componentName };\n","const NUMERIC_RE = /^\\d+$/;\n\nexport const isNumericValue = (val) => NUMERIC_RE.test(val.replaceAll('+', '').replaceAll('-', ''));\n\nexport const sanitizeCountryCodePrefix = (val) => val.replace(/\\+\\d+-/, '');\n","import { createStyleMixin, draggableMixin, componentNameValidationMixin } from '../../mixins';\nimport { createBaseClass } from '../../baseClasses/createBaseClass';\nimport { compose } from '../../helpers';\nimport { forwardAttrs, getComponentName } from '../../helpers/componentHelpers';\nimport { isNumericValue, sanitizeCountryCodePrefix as sanitizeValue } from './helpers';\nimport { PhoneFieldClass } from '../phone-fields/descope-phone-field/PhoneFieldClass';\nimport { PhoneFieldInputBoxClass } from '../phone-fields/descope-phone-input-box-field/PhoneFieldInputBoxClass';\nimport { injectStyle } from '@descope-ui/common/components-helpers';\n\nexport const componentName = getComponentName('hybrid-field');\n\nconst attrs = {\n shared: [\n 'bordered',\n 'full-width',\n 'label-type',\n 'size',\n 'disabled',\n 'readonly',\n 'required',\n 'st-host-direction',\n 'st-error-message-icon',\n 'st-error-message-icon-size',\n 'st-error-message-icon-padding',\n ],\n email: [\n 'label',\n 'placeholder',\n 'data-errormessage-value-missing-email',\n 'data-errormessage-pattern-mismatch-email',\n 'external-input',\n ],\n phone: {\n countryCode: [\n 'phone-input-label',\n 'country-input-label',\n 'country-input-placeholder',\n 'restrict-countries',\n 'default-code',\n 'phone-minlength',\n 'phone-format-value',\n 'phone-strict-validation',\n 'data-errormessage-value-missing-phone',\n ],\n inputBox: [\n 'label',\n 'restrict-countries',\n 'default-code',\n 'phone-minlength',\n 'phone-format-value',\n 'phone-strict-validation',\n 'data-errormessage-value-missing-phone',\n ],\n },\n};\n\nconst attrMap = {\n email: {\n 'data-errormessage-value-missing-email': 'data-errormessage-value-missing',\n 'data-errormessage-pattern-mismatch-email': 'data-errormessage-pattern-mismatch',\n },\n phone: {\n 'phone-input-label': 'label',\n 'phone-minlength': 'minlength',\n 'phone-format-value': 'format-value',\n 'phone-strict-validation': 'strict-validation',\n 'data-errormessage-value-missing-phone': 'data-errormessage-value-missing',\n },\n};\n\nconst EMAIL_FIELD = 'descope-email-field';\nconst PHONE_FIELD = 'descope-phone-field';\nconst PHONE_INPUT_BOX_FIELD = 'descope-phone-input-box-field';\n\nconst BaseClass = createBaseClass({\n componentName,\n baseSelector: 'div',\n});\n\nclass RawHybridField extends BaseClass {\n #isReportedValidity = false;\n\n #selectionStart;\n\n constructor() {\n super();\n\n this.attachShadow({ mode: 'open' }).innerHTML = `\n <div class=\"wrapper\">\n <descope-email-field external-input=\"${this.isExternalInput}\"></descope-email-field>\n <descope-phone-field allow-alphanumeric-input=\"true\"></descope-phone-field>\n <descope-phone-input-box-field allow-alphanumeric-input=\"true\"></descope-phone-input-box-field>\n </div>\n\t\t`;\n\n injectStyle(\n `\n :host {\n display: inline-flex;\n box-sizing: border-box;\n padding: 0;\n gap: 0;\n }\n .wrapper {\n display: grid;\n width: 100%;\n }\n descope-email-field,\n descope-phone-field,\n descope-phone-input-box-field {\n grid-area: 1/1;\n width: 100%;\n height: 100%;\n }\n .hidden {\n visibility: hidden;\n }\n `,\n this\n );\n }\n\n get isExternalInput() {\n return this.getAttribute('external-input') === 'true';\n }\n\n get emailInputEle() {\n return this.isExternalInput ? this.emailInput.externalInput : this.emailInput.inputElement;\n }\n\n get phoneVariant() {\n const isInputBox = this.getAttribute('phone-variant') === 'inputBox';\n return isInputBox ? this.phoneInputBoxInput : this.phoneCountryCodeInput;\n }\n\n get defaultCode() {\n const firstItem = this.phoneCountryCodeInput.countryCodes?.[0] || '';\n return this.getAttribute('default-code') || firstItem;\n }\n\n get activeInputEle() {\n if (this.activeInput === this.emailInput) {\n return this.emailInputEle;\n }\n return this.phoneVariant.phoneNumberInputEle;\n }\n\n get value() {\n return this.activeInput?.value || '';\n }\n\n set value(val) {\n this.handleActiveInput(val);\n this.activeInput.value = val;\n }\n\n async init() {\n super.init?.();\n\n this.initInputs();\n this.updateAttrs();\n this.toggleInputVisibility();\n\n await this.waitForInputs();\n\n this.initInputEles();\n this.overrideEmailInputType();\n this.overrideEmailSetAttribute();\n }\n\n waitForInputs() {\n return new Promise((resolve) => {\n const check = setInterval(() => {\n if (this.emailInputEle) {\n clearInterval(check);\n resolve();\n }\n });\n });\n }\n\n initInputs() {\n this.emailInput = this.shadowRoot.querySelector(EMAIL_FIELD);\n this.phoneCountryCodeInput = this.shadowRoot.querySelector(PHONE_FIELD);\n this.phoneInputBoxInput = this.shadowRoot.querySelector(PHONE_INPUT_BOX_FIELD);\n\n this.inputs = [this.emailInput, this.phoneCountryCodeInput, this.phoneInputBoxInput];\n\n this.activeInput = this.emailInput;\n }\n\n // we need to listen on the inner `input` element itself, otherwise we don't always get an `input` event\n initInputEles() {\n const inputEles = [\n this.emailInputEle,\n this.phoneCountryCodeInput.phoneNumberInputEle,\n this.phoneInputBoxInput.phoneNumberInputEle,\n ];\n\n inputEles.forEach((ele) => {\n ele.addEventListener('input', this.onValueChange.bind(this));\n });\n }\n\n overrideEmailInputType() {\n this.emailInputEle.addEventListener('focus', () => {\n this.emailInputEle.setAttribute('type', 'text');\n });\n this.emailInputEle.addEventListener('blur', () => {\n setTimeout(() => {\n this.emailInputEle.setAttribute('type', 'email');\n });\n });\n }\n\n // We want to prevent Vaadin from changing the input type to `email`\n // otherwise, we cannot get the selectionStart from the input.\n overrideEmailSetAttribute() {\n const origEmailSetAttr = this.emailInput.setAttribute.bind(this.emailInputEle);\n this.emailInputEle.setAttribute = (name, value) => {\n if (name !== 'type' || value !== 'email' || !this.emailInput.hasAttribute('focused')) {\n return origEmailSetAttr(name, value);\n }\n return false;\n };\n }\n\n updateAttrs() {\n forwardAttrs(this, this.emailInput, { includeAttrs: attrs.email, mapAttrs: attrMap.email });\n\n forwardAttrs(this, this.phoneCountryCodeInput, {\n includeAttrs: attrs.phone.countryCode,\n mapAttrs: attrMap.phone,\n });\n\n forwardAttrs(this, this.phoneInputBoxInput, {\n includeAttrs: attrs.phone.inputBox,\n mapAttrs: attrMap.phone,\n });\n\n this.inputs.forEach((input) => forwardAttrs(this, input, { includeAttrs: attrs.shared }));\n\n setTimeout(() => this.phoneCountryCodeInput.setAttribute('default-code', this.defaultCode));\n }\n\n onValueChange() {\n this.#selectionStart = this.activeInputEle.selectionStart;\n this.handleActiveInput(this.activeInput.value);\n }\n\n handleActiveInput(val) {\n const expectedActiveInput = isNumericValue(val) ? this.phoneVariant : this.emailInput;\n\n if (this.activeInput !== expectedActiveInput) {\n this.setActiveInput(expectedActiveInput);\n }\n }\n\n setActiveInput(expectedActiveInput) {\n const val = this.activeInput.value;\n this.activeInput = expectedActiveInput;\n this.setActiveInputValue(val);\n if (this.#isReportedValidity) this.activeInput.reportValidity();\n this.setActiveInputSelectionStart();\n this.toggleInputVisibility();\n }\n\n setActiveInputSelectionStart() {\n setTimeout(() => {\n this.activeInputEle.focus();\n this.activeInputEle.setSelectionRange?.(this.#selectionStart, this.#selectionStart);\n });\n }\n\n setActiveInputValue(val) {\n const sanitizedVal = sanitizeValue(val);\n const isPhoneField = this.activeInput.localName === PHONE_FIELD;\n const value = isPhoneField\n ? `${this.phoneCountryCodeInput.countryCodeItems}-${sanitizedVal}`\n : sanitizedVal;\n this.activeInput.value = value;\n }\n\n toggleInputVisibility() {\n this.inputs.forEach((input) => {\n input !== this.activeInput ? input.classList.add('hidden') : input.classList.remove('hidden');\n });\n }\n\n reportValidity() {\n this.#isReportedValidity = true;\n\n const ele = this.activeInputEle;\n\n // On reportValidity we want to set the caret at the end of the input value.\n // Since checkValidity triggers `focus` on the input, it sets the caret at the start of the input,\n // regardless the existing value.\n const origInputType = ele.type;\n ele.setAttribute('type', 'text');\n setTimeout(() => {\n ele.setSelectionRange?.(ele.value.length, ele.value.length);\n ele.setAttribute('type', origInputType);\n });\n\n return this.activeInput.reportValidity();\n }\n\n checkValidity() {\n return this.activeInput.checkValidity();\n }\n}\n\nexport const HybridFieldClass = compose(\n createStyleMixin({ componentNameOverride: getComponentName('input-wrapper') }),\n createStyleMixin({\n mappings: {\n hostWidth: { selector: () => ':host', property: 'width' },\n hostDirection: [\n { selector: () => 'descope-email-field', property: 'direction' },\n { selector: () => 'descope-phone-field', property: 'direction' },\n { selector: () => 'descope-phone-input-box-field', property: 'direction' },\n ],\n errorMessageIcon: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIcon,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIcon,\n },\n ],\n errorMessageIconSize: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconSize,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconSize,\n },\n ],\n errorMessageIconPadding: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconPadding,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconPadding,\n },\n ],\n errorMessageIconRepeat: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconRepeat,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconRepeat,\n },\n ],\n errorMessageIconPosition: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageIconPosition,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageIconPosition,\n },\n ],\n errorMessageFontSize: [\n {\n selector: () => PhoneFieldClass.componentName,\n property: PhoneFieldClass.cssVarList.errorMessageFontSize,\n },\n {\n selector: () => PhoneFieldInputBoxClass.componentName,\n property: PhoneFieldInputBoxClass.cssVarList.errorMessageFontSize,\n },\n ],\n },\n }),\n draggableMixin,\n componentNameValidationMixin\n)(RawHybridField);\n","import '../descope-email-field';\nimport '../phone-fields/descope-phone-field';\nimport '../phone-fields/descope-phone-input-box-field';\n\nimport { componentName, HybridFieldClass } from './HybridFieldClass';\n\ncustomElements.define(componentName, HybridFieldClass);\n\nexport { HybridFieldClass, componentName };\n","/**\n * @license\n * Copyright (c) 2021 - 2023 Vaadin Ltd.\n * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/\n */\nimport { inputFieldShared } from '@vaadin/vaadin-lumo-styles/mixins/input-field-shared.js';\nimport { css, registerStyles } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js';\n\nconst emailField = css`\n :host([dir='rtl']) [part='input-field'] ::slotted(input) {\n --_lumo-text-field-overflow-mask-image: linear-gradient(to left, transparent, #000 1.25em);\n }\n\n :host([dir='rtl']) [part='input-field'] ::slotted(input:placeholder-shown) {\n --_lumo-text-field-overflow-mask-image: none;\n }\n`;\n\nregisterStyles('vaadin-email-field', [inputFieldShared, emailField], {\n moduleId: 'lumo-email-field',\n});\n","/**\n * @license\n * Copyright (c) 2021 - 2023 Vaadin Ltd.\n * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/\n */\nimport { css } from 'lit';\n\n// See https://github.com/vaadin/vaadin-text-field/issues/466\nexport const emailFieldStyles = css`\n :host([dir='rtl']) [part='input-field'] {\n direction: ltr;\n }\n\n :host([dir='rtl']) [part='input-field'] ::slotted(input)::placeholder {\n direction: rtl;\n text-align: left;\n }\n`;\n","/**\n * @license\n * Copyright (c) 2021 - 2023 Vaadin Ltd.\n * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/\n */\nimport { defineCustomElement } from '@vaadin/component-base/src/define.js';\nimport { TextField } from '@vaadin/text-field/src/vaadin-text-field.js';\nimport { registerStyles } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js';\nimport { emailFieldStyles } from './vaadin-email-field-styles.js';\n\nregisterStyles('vaadin-email-field', emailFieldStyles, { moduleId: 'vaadin-email-field-styles' });\n\n/**\n * `<vaadin-email-field>` is a Web Component for email field control in forms.\n *\n * ```html\n * <vaadin-email-field label=\"Email\"></vaadin-email-field>\n * ```\n *\n * ### Styling\n *\n * `<vaadin-email-field>` provides the same set of shadow DOM parts and state attributes as `<vaadin-text-field>`.\n * See [`<vaadin-text-field>`](#/elements/vaadin-text-field) for the styling documentation.\n *\n * See [Styling Components](https://vaadin.com/docs/latest/styling/styling-components) documentation.\n *\n * @fires {Event} input - Fired when the value is changed by the user: on every typing keystroke, and the value is cleared using the clear button.\n * @fires {Event} change - Fired when the user commits a value change.\n * @fires {CustomEvent} invalid-changed - Fired when the `invalid` property changes.\n * @fires {CustomEvent} value-changed - Fired when the `value` property changes.\n * @fires {CustomEvent} validated - Fired whenever the field is validated.\n *\n * @customElement\n * @extends TextField\n */\nexport class EmailField extends TextField {\n static get is() {\n return 'vaadin-email-field';\n }\n\n constructor() {\n super();\n this._setType('email');\n this.pattern = '^([a-zA-Z0-9_\\\\.\\\\-+])+@[a-zA-Z0-9\\\\-.]+\\\\.[a-zA-Z0-9\\\\-]{2,}$';\n }\n\n /** @protected */\n ready() {\n super.ready();\n\n if (this.inputElement) {\n this.inputElement.autocapitalize = 'off';\n }\n }\n}\n\ndefineCustomElement(EmailField);\n","import {\n createStyleMixin,\n draggableMixin,\n createProxy,\n proxyInputMixin,\n componentNameValidationMixin,\n externalInputMixin,\n} from '../../mixins';\nimport textFieldMappings from '../descope-text-field/textFieldMappings';\nimport { compose } from '../../helpers';\nimport { getComponentName } from '../../helpers/componentHelpers';\nimport {\n inputFloatingLabelStyle,\n resetInputLabelPosition,\n resetInputOverrides,\n useHostExternalPadding,\n} from '../../helpers/themeHelpers/resetHelpers';\n\nexport const componentName = getComponentName('email-field');\n\nconst defaultPattern = \"^[\\\\w\\\\.\\\\%\\\\+\\\\-']+@[\\\\w\\\\.\\\\-]+\\\\.[A-Za-z]{2,}$\";\nconst defaultAutocomplete = 'username';\n\nconst customMixin = (superclass) =>\n class EmailFieldMixinClass extends superclass {\n init() {\n super.init?.();\n\n // we need to set the pattern on the base element because vaadin-email-field is overriding it\n this.baseElement.setAttribute('pattern', defaultPattern);\n\n if (!this.getAttribute('autocomplete')) {\n this.setAttribute('autocomplete', defaultAutocomplete);\n }\n\n this.createExternalInput();\n }\n };\n\nexport const EmailFieldClass = compose(\n createStyleMixin({\n mappings: textFieldMappings,\n }),\n draggableMixin,\n externalInputMixin({\n inputType: 'email',\n inputName: 'email',\n autocompleteType: 'username',\n includeAttrs: ['disabled', 'readonly', 'pattern'],\n }),\n proxyInputMixin({ proxyProps: ['value', 'selectionStart'], useProxyTargets: true }),\n componentNameValidationMixin,\n customMixin\n)(\n createProxy({\n slots: ['', 'suffix'],\n wrappedEleName: 'vaadin-email-field',\n style: () => `\n\t\t\t:host {\n\t\t\t\tdisplay: inline-block;\n\t\t\t\tmax-width: 100%;\n\t\t\t\tpadding: calc(var(${EmailFieldClass.cssVarList.inputOutlineWidth}) + var(${\n EmailFieldClass.cssVarList.inputOutlineOffset\n }));\n box-sizing: border-box;\n\t\t\t}\n ${resetInputLabelPosition('vaadin-email-field')}\n\t\t\t${useHostExternalPadding(EmailFieldClass.cssVarList)}\n\t\t\t${resetInputOverrides('vaadin-email-field', EmailFieldClass.cssVarList)}\n ${inputFloatingLabelStyle()}\n\n vaadin-email-field[label-type=\"floating\"]:not([focused])[readonly] > input:placeholder-shown {\n opacity: 0;\n }\n vaadin-email-field[label-type=\"floating\"]:not([focused])[disabled] > input:placeholder-shown {\n opacity: 0;\n }\n\n :host ::slotted(*) {\n -webkit-mask-image: none;\n }\n\n vaadin-email-field[external-input=\"true\"] > input:not(:placeholder-shown) {\n opacity: 0;\n }\n\t\t`,\n excludeAttrsSync: ['tabindex'],\n componentName,\n })\n);\n","import '@vaadin/email-field';\nimport { componentName, EmailFieldClass } from './EmailFieldClass';\n\ncustomElements.define(componentName, EmailFieldClass);\n\nexport { EmailFieldClass, componentName };\n","import '../../../descope-text-field';\n\nimport PhoneFieldInternalInputBox, { componentName } from './PhoneFieldInternalInputBox';\n\ncustomElements.define(componentName, PhoneFieldInternalInputBox);\n","import parsePhoneNumberFromString from 'libphonenumber-js/min';\nimport CountryCodes from './CountryCodes';\n\nexport const getCountryByCodeId = (countryCode) => {\n return CountryCodes.find((c) => c.code === countryCode)?.dialCode;\n};\n\nexport const matchingParenthesis = (val) => {\n const openParenMatches = val.match(/\\(/g);\n const closeParenMatches = val.match(/\\)/g);\n return openParenMatches?.length === closeParenMatches?.length;\n};\n"],"names":["componentName","observedAttributes","mapAttrs","BaseInputClass","baseSelector","concat","constructor","super","this","innerHTML","textField","querySelector","phoneNumberInputEle","shadowRoot","defaultDialCode","getAttribute","defaultCode","allowAlphanumericInput","minLength","parseInt","maxLength","restrictCountries","split","filter","Boolean","isFormatValue","isStrictValidation","value","parsedVal","country","countryCallingCode","nationalNumber","join","val","init","addEventListener","e","isTrusted","focus","bind","handleFocusEventsDispatching","getValidity","validPhonePattern","stripValue","isRequired","valueMissing","length","tooShort","test","patternMismatch","setSelectionRange","args","attributeChangedCallback","attrName","oldValue","newValue","includes","attr","setAttribute","sanitizedInput","target","sanitizedVal","replace","dialCodePrefixPattern","RegExp","parsed","isValid","countryCode","telDigitsRegExp","char","phoneNumber","reset","input","textVars","cssVarList","host","label","inputElement","requiredIndicator","inputField","internalComponent","internalComponentAfter","phoneInput","errorMessage","helperText","selector","placeholder","PhoneFieldInputBoxClass","mappings","fontSize","property","fontFamily","hostWidth","hostMinWidth","hostDirection","inputHorizontalPadding","labelFontSize","labelFontWeight","labelTextColor","labelRequiredIndicator","errorMessageTextColor","errorMessageIcon","errorMessageIconSize","errorMessageIconPadding","errorMessageIconRepeat","errorMessageIconPosition","errorMessageFontSize","inputValueTextColor","inputPlaceholderTextColor","inputPlaceholderColor","inputBorderStyle","inputBorderWidth","inputBorderColor","inputBorderRadius","inputOutlineStyle","inputOutlineColor","inputOutlineWidth","inputOutlineOffset","labelPosition","labelTopPosition","labelHorizontalPosition","inputTransformY","inputTransition","marginInlineStart","valueInputHeight","valueInputMarginBottom","proxyProps","superclass","CountryCodes","template","document","createElement","baseElement","appendChild","content","cloneNode","includeAttrs","slots","wrappedEleName","style","excludeAttrsSync","customElements","define","NUMERIC_RE","attrs","shared","email","phone","inputBox","attrMap","PHONE_FIELD","BaseClass","createBaseClass","HybridFieldClass","componentNameOverride","PhoneFieldClass","attachShadow","mode","isExternalInput","emailInputEle","emailInput","externalInput","phoneVariant","phoneInputBoxInput","phoneCountryCodeInput","firstItem","countryCodes","activeInputEle","activeInput","handleActiveInput","initInputs","updateAttrs","toggleInputVisibility","waitForInputs","initInputEles","overrideEmailInputType","overrideEmailSetAttribute","Promise","resolve","check","setInterval","clearInterval","inputs","forEach","ele","onValueChange","setTimeout","origEmailSetAttr","name","hasAttribute","selectionStart","expectedActiveInput","replaceAll","isNumericValue","setActiveInput","setActiveInputValue","reportValidity","setActiveInputSelectionStart","localName","countryCodeItems","classList","add","remove","origInputType","type","checkValidity","emailField","moduleId","emailFieldStyles","EmailField","is","_setType","pattern","ready","autocapitalize","EmailFieldClass","textFieldMappings","inputType","inputName","autocompleteType","useProxyTargets","createExternalInput","getCountryByCodeId","find","c","code","dialCode","matchingParenthesis","openParenMatches","match","closeParenMatches"],"sourceRoot":""}
|
package/package.json
CHANGED
@@ -31,7 +31,7 @@ export const componentName = getComponentName('date-field');
|
|
31
31
|
const BASE_SELECTOR = 'vaadin-popover';
|
32
32
|
const BaseInputClass = createBaseInputClass({ componentName, baseSelector: BASE_SELECTOR });
|
33
33
|
|
34
|
-
const dateFieldAttrs = ['format', 'opened', 'initial-value', 'readonly'];
|
34
|
+
const dateFieldAttrs = ['format', 'opened', 'initial-value', 'readonly', 'disable-calendar'];
|
35
35
|
const calendarAttrs = ['years-range', 'calendar-months', 'calendar-weekdays'];
|
36
36
|
const observedAttrs = [...dateFieldAttrs, ...calendarAttrs];
|
37
37
|
|
@@ -121,6 +121,10 @@ class RawDateFieldClass extends BaseInputClass {
|
|
121
121
|
:host([readonly="true"]) .toggle-calendar {
|
122
122
|
pointer-events: none;
|
123
123
|
}
|
124
|
+
|
125
|
+
.hidden {
|
126
|
+
display: none;
|
127
|
+
}
|
124
128
|
`,
|
125
129
|
this
|
126
130
|
);
|
@@ -206,6 +210,10 @@ class RawDateFieldClass extends BaseInputClass {
|
|
206
210
|
return this.dateCounters.some((dc) => !dc.isInRange(dc.numberValue));
|
207
211
|
}
|
208
212
|
|
213
|
+
get disableCalendar() {
|
214
|
+
return this.getAttribute('disable-calendar') === 'true';
|
215
|
+
}
|
216
|
+
|
209
217
|
reportValidity() {
|
210
218
|
this.inputElement.reportValidity();
|
211
219
|
}
|
@@ -366,6 +374,7 @@ class RawDateFieldClass extends BaseInputClass {
|
|
366
374
|
}
|
367
375
|
|
368
376
|
openPopover() {
|
377
|
+
if (this.disableCalendar) return;
|
369
378
|
this.setAttribute('opened', 'true');
|
370
379
|
}
|
371
380
|
|
@@ -621,6 +630,14 @@ class RawDateFieldClass extends BaseInputClass {
|
|
621
630
|
}
|
622
631
|
}
|
623
632
|
|
633
|
+
togglePopoverAccess(visibility) {
|
634
|
+
if (visibility) {
|
635
|
+
this.popoverToggleButton.classList.remove('hidden');
|
636
|
+
} else {
|
637
|
+
this.popoverToggleButton.classList.add('hidden');
|
638
|
+
}
|
639
|
+
}
|
640
|
+
|
624
641
|
attributeChangedCallback(attrName, oldValue, newValue) {
|
625
642
|
super.attributeChangedCallback?.(attrName, oldValue, newValue);
|
626
643
|
|
@@ -628,6 +645,9 @@ class RawDateFieldClass extends BaseInputClass {
|
|
628
645
|
if (attrName === 'years-range') {
|
629
646
|
this.setYearRange(newValue);
|
630
647
|
}
|
648
|
+
if (attrName === 'disable-calendar') {
|
649
|
+
this.togglePopoverAccess(newValue !== 'true');
|
650
|
+
}
|
631
651
|
if (dateFieldAttrs.includes(attrName)) {
|
632
652
|
if (newValue && attrName === 'format') {
|
633
653
|
this.onFormatUpdate(newValue);
|
@@ -295,8 +295,11 @@ class RawHybridField extends BaseClass {
|
|
295
295
|
// On reportValidity we want to set the caret at the end of the input value.
|
296
296
|
// Since checkValidity triggers `focus` on the input, it sets the caret at the start of the input,
|
297
297
|
// regardless the existing value.
|
298
|
+
const origInputType = ele.type;
|
299
|
+
ele.setAttribute('type', 'text');
|
298
300
|
setTimeout(() => {
|
299
301
|
ele.setSelectionRange?.(ele.value.length, ele.value.length);
|
302
|
+
ele.setAttribute('type', origInputType);
|
300
303
|
});
|
301
304
|
|
302
305
|
return this.activeInput.reportValidity();
|