UNPKG

@dnb/eufemia

Version:

DNB Eufemia Design System UI Library

31 lines 1.17 kB
import React, { useMemo } from 'react'; import StringField from "../String/index.js"; import useTranslation from "../../hooks/useTranslation.js"; const aText = `[A-Za-z0-9!#$%&'*+/=?^_\\x60{|}~\\u0080-\\uFFFF-]+`; export const pattern = `^${aText}(?:\\.${aText})*@` + `(?:` + `(?:` + `(?:xn--[A-Za-z0-9-]+|[A-Za-z0-9]+(?:-[A-Za-z0-9]+)*)\\.)+` + `(?:[A-Za-z]{2,}|xn--[A-Za-z0-9-]{2,})` + `|` + `(?:xn--[A-Za-z0-9-]{2,})` + `|` + `\\[(?:` + `\\d{1,3}(?:\\.\\d{1,3}){3}` + `|` + `IPv6:[0-9A-Fa-f:]+` + `)\\]` + `)$`; function Email(props) { const { label, errorRequired, errorPattern } = useTranslation().Email; const errorMessages = useMemo(() => ({ 'Field.errorRequired': errorRequired, 'Field.errorPattern': errorPattern, ...props.errorMessages }), [errorPattern, errorRequired, props.errorMessages]); const StringFieldProps = { label, autoComplete: 'email', inputMode: 'email', maxLength: 254, pattern, trim: true, ...props, errorMessages }; return React.createElement(StringField, StringFieldProps); } Email._supportsSpacingProps = true; export default Email; //# sourceMappingURL=Email.js.map