UNPKG

matrix-react-sdk

Version:
243 lines (237 loc) 39.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _lodash = require("lodash"); var _Tooltip = _interopRequireWildcard(require("./Tooltip")); var _Keyboard = require("../../../Keyboard"); const _excluded = ["element", "inputRef", "prefixComponent", "postfixComponent", "className", "onValidate", "children", "tooltipContent", "forceValidity", "tooltipClassName", "validateOnBlur", "validateOnChange", "validateOnFocus", "usePlaceholderAsHint", "forceTooltipVisible", "tooltipAlignment"]; /* Copyright 2019-2024 New Vector Ltd. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } // Invoke validation from user input (when typing, etc.) at most once every N ms. const VALIDATION_THROTTLE_MS = 200; const BASE_ID = "mx_Field"; let count = 1; function getId() { return `${BASE_ID}_${count++}`; } class Field extends _react.default.PureComponent { constructor(props) { super(props); (0, _defineProperty2.default)(this, "id", void 0); (0, _defineProperty2.default)(this, "_inputRef", /*#__PURE__*/(0, _react.createRef)()); /* * This was changed from throttle to debounce: this is more traditional for * form validation since it means that the validation doesn't happen at all * until the user stops typing for a bit (debounce defaults to not running on * the leading edge). If we're doing an HTTP hit on each validation, we have more * incentive to prevent validating input that's very unlikely to be valid. * We may find that we actually want different behaviour for registration * fields, in which case we can add some options to control it. */ (0, _defineProperty2.default)(this, "validateOnChange", (0, _lodash.debounce)(() => { this.validate({ focused: true }); }, VALIDATION_THROTTLE_MS)); (0, _defineProperty2.default)(this, "onFocus", ev => { this.setState({ focused: true }); if (this.props.validateOnFocus) { this.validate({ focused: true }); } // Parent component may have supplied its own `onFocus` as well this.props.onFocus?.(ev); }); (0, _defineProperty2.default)(this, "onChange", ev => { if (this.props.validateOnChange) { this.validateOnChange(); } // Parent component may have supplied its own `onChange` as well this.props.onChange?.(ev); }); (0, _defineProperty2.default)(this, "onBlur", ev => { this.setState({ focused: false }); if (this.props.validateOnBlur) { this.validate({ focused: false }); } // Parent component may have supplied its own `onBlur` as well this.props.onBlur?.(ev); }); (0, _defineProperty2.default)(this, "onKeyDown", evt => { // If the tooltip is displayed to show a feedback and Escape is pressed // The tooltip is hided if (this.state.feedbackVisible && evt.key === _Keyboard.Key.ESCAPE) { evt.preventDefault(); evt.stopPropagation(); this.setState({ feedbackVisible: false }); } }); this.state = { feedbackVisible: false, focused: false }; this.id = this.props.id || getId(); } focus() { this.inputRef.current?.focus(); // programmatic does not fire onFocus handler this.setState({ focused: true }); } async validate({ focused, allowEmpty = true }) { if (!this.props.onValidate) { return; } const value = this.inputRef.current?.value ?? null; const { valid, feedback } = await this.props.onValidate({ value, focused: !!focused, allowEmpty }); // this method is async and so we may have been blurred since the method was called // if we have then hide the feedback as withValidation does if (this.state.focused && feedback) { this.setState({ valid, feedback, feedbackVisible: true }); } else { // When we receive null `feedback`, we want to hide the tooltip. // We leave the previous `feedback` content in state without updating it, // so that we can hide the tooltip containing the most recent feedback // via CSS animation. this.setState({ valid, feedbackVisible: false }); } return valid; } get inputRef() { return this.props.inputRef ?? this._inputRef; } render() { /* eslint @typescript-eslint/no-unused-vars: ["error", { "ignoreRestSiblings": true }] */ const _this$props = this.props, { element, inputRef, prefixComponent, postfixComponent, className, onValidate, children, tooltipContent, forceValidity, tooltipClassName, validateOnBlur, validateOnChange, validateOnFocus, usePlaceholderAsHint, forceTooltipVisible, tooltipAlignment } = _this$props, inputProps = (0, _objectWithoutProperties2.default)(_this$props, _excluded); // Handle displaying feedback on validity let fieldTooltip; if (tooltipContent || this.state.feedback) { const tooltipId = `${this.id}_tooltip`; const visible = this.state.focused && forceTooltipVisible || this.state.feedbackVisible; if (visible) { inputProps["aria-describedby"] = tooltipId; } let role; if (tooltipContent) { role = "tooltip"; } else { role = this.state.valid ? "status" : "alert"; } fieldTooltip = /*#__PURE__*/_react.default.createElement(_Tooltip.default, { id: tooltipId, tooltipClassName: (0, _classnames.default)("mx_Field_tooltip", "mx_Tooltip_noMargin", tooltipClassName), visible: visible, label: tooltipContent || this.state.feedback, alignment: tooltipAlignment || _Tooltip.Alignment.Right, role: role }); } inputProps.placeholder = inputProps.placeholder ?? inputProps.label; inputProps.id = this.id; // this overwrites the id from props inputProps.onFocus = this.onFocus; inputProps.onChange = this.onChange; inputProps.onBlur = this.onBlur; // Appease typescript's inference const inputProps_ = _objectSpread(_objectSpread({}, inputProps), {}, { ref: this.inputRef }); const fieldInput = /*#__PURE__*/_react.default.createElement(this.props.element, inputProps_, children); let prefixContainer; if (prefixComponent) { prefixContainer = /*#__PURE__*/_react.default.createElement("span", { className: "mx_Field_prefix" }, prefixComponent); } let postfixContainer; if (postfixComponent) { postfixContainer = /*#__PURE__*/_react.default.createElement("span", { className: "mx_Field_postfix" }, postfixComponent); } const hasValidationFlag = forceValidity !== null && forceValidity !== undefined; const fieldClasses = (0, _classnames.default)("mx_Field", `mx_Field_${this.props.element}`, className, { // If we have a prefix element, leave the label always at the top left and // don't animate it, as it looks a bit clunky and would add complexity to do // properly. mx_Field_labelAlwaysTopLeft: prefixComponent || usePlaceholderAsHint, mx_Field_placeholderIsHint: usePlaceholderAsHint, mx_Field_valid: hasValidationFlag ? forceValidity : onValidate && this.state.valid === true, mx_Field_invalid: hasValidationFlag ? !forceValidity : onValidate && this.state.valid === false }); return /*#__PURE__*/_react.default.createElement("div", { className: fieldClasses, onKeyDown: this.onKeyDown }, prefixContainer, fieldInput, /*#__PURE__*/_react.default.createElement("label", { htmlFor: this.id }, this.props.label), postfixContainer, fieldTooltip); } } exports.default = Field; (0, _defineProperty2.default)(Field, "defaultProps", { element: "input", type: "text", validateOnFocus: true, validateOnBlur: true, validateOnChange: true }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_lodash","_Tooltip","_Keyboard","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","VALIDATION_THROTTLE_MS","BASE_ID","count","getId","Field","React","PureComponent","constructor","props","createRef","debounce","validate","focused","ev","setState","validateOnFocus","onFocus","validateOnChange","onChange","validateOnBlur","onBlur","evt","state","feedbackVisible","key","Key","ESCAPE","preventDefault","stopPropagation","id","focus","inputRef","current","allowEmpty","onValidate","value","valid","feedback","_inputRef","render","_this$props","element","prefixComponent","postfixComponent","className","children","tooltipContent","forceValidity","tooltipClassName","usePlaceholderAsHint","forceTooltipVisible","tooltipAlignment","inputProps","_objectWithoutProperties2","fieldTooltip","tooltipId","visible","role","createElement","classNames","label","alignment","Alignment","Right","placeholder","inputProps_","ref","fieldInput","prefixContainer","postfixContainer","hasValidationFlag","undefined","fieldClasses","mx_Field_labelAlwaysTopLeft","mx_Field_placeholderIsHint","mx_Field_valid","mx_Field_invalid","onKeyDown","htmlFor","exports","type"],"sources":["../../../../src/components/views/elements/Field.tsx"],"sourcesContent":["/*\nCopyright 2019-2024 New Vector Ltd.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, {\n    InputHTMLAttributes,\n    SelectHTMLAttributes,\n    TextareaHTMLAttributes,\n    RefObject,\n    createRef,\n    KeyboardEvent,\n} from \"react\";\nimport classNames from \"classnames\";\nimport { debounce } from \"lodash\";\n\nimport { IFieldState, IValidationResult } from \"./Validation\";\nimport Tooltip, { Alignment } from \"./Tooltip\";\nimport { Key } from \"../../../Keyboard\";\n\n// Invoke validation from user input (when typing, etc.) at most once every N ms.\nconst VALIDATION_THROTTLE_MS = 200;\n\nconst BASE_ID = \"mx_Field\";\nlet count = 1;\nfunction getId(): string {\n    return `${BASE_ID}_${count++}`;\n}\n\nexport interface IValidateOpts {\n    focused?: boolean;\n    allowEmpty?: boolean;\n}\n\ninterface IProps {\n    // The field's ID, which binds the input and label together. Immutable.\n    id?: string;\n    // The field's label string.\n    label?: string;\n    // The field's placeholder string. Defaults to the label.\n    placeholder?: string;\n    // When true (default false), the placeholder will be shown instead of the label when\n    // the component is unfocused & empty.\n    usePlaceholderAsHint?: boolean;\n    // Optional component to include inside the field before the input.\n    prefixComponent?: React.ReactNode;\n    // Optional component to include inside the field after the input.\n    postfixComponent?: React.ReactNode;\n    // The callback called whenever the contents of the field\n    // changes.  Returns an object with `valid` boolean field\n    // and a `feedback` react component field to provide feedback\n    // to the user.\n    onValidate?: (input: IFieldState) => Promise<IValidationResult>;\n    // If specified, overrides the value returned by onValidate.\n    forceValidity?: boolean;\n    // If specified, contents will appear as a tooltip on the element and\n    // validation feedback tooltips will be suppressed.\n    tooltipContent?: React.ReactNode;\n    // If specified the tooltip will be shown regardless of feedback\n    forceTooltipVisible?: boolean;\n    // If specified, the tooltip with be aligned accorindly with the field, defaults to Right.\n    tooltipAlignment?: Alignment;\n    // If specified alongside tooltipContent, the class name to apply to the\n    // tooltip itself.\n    tooltipClassName?: string;\n    // If specified, an additional class name to apply to the field container\n    className?: string;\n    // On what events should validation occur; by default on all\n    validateOnFocus?: boolean;\n    validateOnBlur?: boolean;\n    validateOnChange?: boolean;\n    // All other props pass through to the <input>.\n}\n\nexport interface IInputProps extends IProps, InputHTMLAttributes<HTMLInputElement> {\n    // The ref pass through to the input\n    inputRef?: RefObject<HTMLInputElement>;\n    // The element to create. Defaults to \"input\".\n    element: \"input\";\n    // The input's value. This is a controlled component, so the value is required.\n    value: string;\n}\n\ninterface ISelectProps extends IProps, SelectHTMLAttributes<HTMLSelectElement> {\n    // The ref pass through to the select\n    inputRef?: RefObject<HTMLSelectElement>;\n    // To define options for a select, use <Field><option ... /></Field>\n    element: \"select\";\n    // The select's value. This is a controlled component, so the value is required.\n    value: string;\n}\n\ninterface ITextareaProps extends IProps, TextareaHTMLAttributes<HTMLTextAreaElement> {\n    // The ref pass through to the textarea\n    inputRef?: RefObject<HTMLTextAreaElement>;\n    element: \"textarea\";\n    // The textarea's value. This is a controlled component, so the value is required.\n    value: string;\n}\n\nexport interface INativeOnChangeInputProps extends IProps, InputHTMLAttributes<HTMLInputElement> {\n    // The ref pass through to the input\n    inputRef?: RefObject<HTMLInputElement>;\n    element: \"input\";\n    // The input's value. This is a controlled component, so the value is required.\n    value: string;\n}\n\ntype PropShapes = IInputProps | ISelectProps | ITextareaProps | INativeOnChangeInputProps;\n\ninterface IState {\n    valid?: boolean;\n    feedback?: React.ReactNode;\n    feedbackVisible: boolean;\n    focused: boolean;\n}\n\nexport default class Field extends React.PureComponent<PropShapes, IState> {\n    private readonly id: string;\n    private readonly _inputRef = createRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>();\n\n    public static readonly defaultProps = {\n        element: \"input\",\n        type: \"text\",\n        validateOnFocus: true,\n        validateOnBlur: true,\n        validateOnChange: true,\n    };\n\n    /*\n     * This was changed from throttle to debounce: this is more traditional for\n     * form validation since it means that the validation doesn't happen at all\n     * until the user stops typing for a bit (debounce defaults to not running on\n     * the leading edge). If we're doing an HTTP hit on each validation, we have more\n     * incentive to prevent validating input that's very unlikely to be valid.\n     * We may find that we actually want different behaviour for registration\n     * fields, in which case we can add some options to control it.\n     */\n    private validateOnChange = debounce(() => {\n        this.validate({\n            focused: true,\n        });\n    }, VALIDATION_THROTTLE_MS);\n\n    public constructor(props: PropShapes) {\n        super(props);\n        this.state = {\n            feedbackVisible: false,\n            focused: false,\n        };\n\n        this.id = this.props.id || getId();\n    }\n\n    public focus(): void {\n        this.inputRef.current?.focus();\n        // programmatic does not fire onFocus handler\n        this.setState({\n            focused: true,\n        });\n    }\n\n    private onFocus = (ev: React.FocusEvent<any>): void => {\n        this.setState({\n            focused: true,\n        });\n        if (this.props.validateOnFocus) {\n            this.validate({\n                focused: true,\n            });\n        }\n        // Parent component may have supplied its own `onFocus` as well\n        this.props.onFocus?.(ev);\n    };\n\n    private onChange = (ev: React.ChangeEvent<any>): void => {\n        if (this.props.validateOnChange) {\n            this.validateOnChange();\n        }\n        // Parent component may have supplied its own `onChange` as well\n        this.props.onChange?.(ev);\n    };\n\n    private onBlur = (ev: React.FocusEvent<any>): void => {\n        this.setState({\n            focused: false,\n        });\n        if (this.props.validateOnBlur) {\n            this.validate({\n                focused: false,\n            });\n        }\n        // Parent component may have supplied its own `onBlur` as well\n        this.props.onBlur?.(ev);\n    };\n\n    public async validate({ focused, allowEmpty = true }: IValidateOpts): Promise<boolean | undefined> {\n        if (!this.props.onValidate) {\n            return;\n        }\n        const value = this.inputRef.current?.value ?? null;\n        const { valid, feedback } = await this.props.onValidate({\n            value,\n            focused: !!focused,\n            allowEmpty,\n        });\n\n        // this method is async and so we may have been blurred since the method was called\n        // if we have then hide the feedback as withValidation does\n        if (this.state.focused && feedback) {\n            this.setState({\n                valid,\n                feedback,\n                feedbackVisible: true,\n            });\n        } else {\n            // When we receive null `feedback`, we want to hide the tooltip.\n            // We leave the previous `feedback` content in state without updating it,\n            // so that we can hide the tooltip containing the most recent feedback\n            // via CSS animation.\n            this.setState({\n                valid,\n                feedbackVisible: false,\n            });\n        }\n\n        return valid;\n    }\n\n    private get inputRef(): RefObject<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement> {\n        return this.props.inputRef ?? this._inputRef;\n    }\n\n    private onKeyDown = (evt: KeyboardEvent<HTMLDivElement>): void => {\n        // If the tooltip is displayed to show a feedback and Escape is pressed\n        // The tooltip is hided\n        if (this.state.feedbackVisible && evt.key === Key.ESCAPE) {\n            evt.preventDefault();\n            evt.stopPropagation();\n            this.setState({\n                feedbackVisible: false,\n            });\n        }\n    };\n\n    public render(): React.ReactNode {\n        /* eslint @typescript-eslint/no-unused-vars: [\"error\", { \"ignoreRestSiblings\": true }] */\n        const {\n            element,\n            inputRef,\n            prefixComponent,\n            postfixComponent,\n            className,\n            onValidate,\n            children,\n            tooltipContent,\n            forceValidity,\n            tooltipClassName,\n            validateOnBlur,\n            validateOnChange,\n            validateOnFocus,\n            usePlaceholderAsHint,\n            forceTooltipVisible,\n            tooltipAlignment,\n            ...inputProps\n        } = this.props;\n\n        // Handle displaying feedback on validity\n        let fieldTooltip: JSX.Element | undefined;\n        if (tooltipContent || this.state.feedback) {\n            const tooltipId = `${this.id}_tooltip`;\n            const visible = (this.state.focused && forceTooltipVisible) || this.state.feedbackVisible;\n            if (visible) {\n                inputProps[\"aria-describedby\"] = tooltipId;\n            }\n\n            let role: React.AriaRole;\n            if (tooltipContent) {\n                role = \"tooltip\";\n            } else {\n                role = this.state.valid ? \"status\" : \"alert\";\n            }\n\n            fieldTooltip = (\n                <Tooltip\n                    id={tooltipId}\n                    tooltipClassName={classNames(\"mx_Field_tooltip\", \"mx_Tooltip_noMargin\", tooltipClassName)}\n                    visible={visible}\n                    label={tooltipContent || this.state.feedback}\n                    alignment={tooltipAlignment || Alignment.Right}\n                    role={role}\n                />\n            );\n        }\n\n        inputProps.placeholder = inputProps.placeholder ?? inputProps.label;\n        inputProps.id = this.id; // this overwrites the id from props\n\n        inputProps.onFocus = this.onFocus;\n        inputProps.onChange = this.onChange;\n        inputProps.onBlur = this.onBlur;\n\n        // Appease typescript's inference\n        const inputProps_: React.HTMLAttributes<HTMLSelectElement | HTMLInputElement | HTMLTextAreaElement> &\n            React.ClassAttributes<HTMLSelectElement | HTMLInputElement | HTMLTextAreaElement> = {\n            ...inputProps,\n            ref: this.inputRef,\n        };\n\n        const fieldInput = React.createElement(this.props.element, inputProps_, children);\n\n        let prefixContainer: JSX.Element | undefined;\n        if (prefixComponent) {\n            prefixContainer = <span className=\"mx_Field_prefix\">{prefixComponent}</span>;\n        }\n        let postfixContainer: JSX.Element | undefined;\n        if (postfixComponent) {\n            postfixContainer = <span className=\"mx_Field_postfix\">{postfixComponent}</span>;\n        }\n\n        const hasValidationFlag = forceValidity !== null && forceValidity !== undefined;\n        const fieldClasses = classNames(\"mx_Field\", `mx_Field_${this.props.element}`, className, {\n            // If we have a prefix element, leave the label always at the top left and\n            // don't animate it, as it looks a bit clunky and would add complexity to do\n            // properly.\n            mx_Field_labelAlwaysTopLeft: prefixComponent || usePlaceholderAsHint,\n            mx_Field_placeholderIsHint: usePlaceholderAsHint,\n            mx_Field_valid: hasValidationFlag ? forceValidity : onValidate && this.state.valid === true,\n            mx_Field_invalid: hasValidationFlag ? !forceValidity : onValidate && this.state.valid === false,\n        });\n\n        return (\n            <div className={fieldClasses} onKeyDown={this.onKeyDown}>\n                {prefixContainer}\n                {fieldInput}\n                <label htmlFor={this.id}>{this.props.label}</label>\n                {postfixContainer}\n                {fieldTooltip}\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}