UNPKG

matrix-react-sdk

Version:
187 lines (183 loc) 29.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.AutocompleteInput = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _icons = require("@vector-im/compound-design-tokens/assets/web/icons"); var _Keyboard = require("../../Keyboard"); var _AccessibleButton = _interopRequireDefault(require("../../components/views/elements/AccessibleButton")); var _useFocus = _interopRequireDefault(require("../../hooks/useFocus")); 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; } /* Copyright 2024 New Vector Ltd. Copyright 2022 The Matrix.org Foundation C.I.C. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ const AutocompleteInput = ({ provider, renderSuggestion, renderSelection, maxSuggestions = 5, placeholder, onSelectionChange, selection, additionalFilter }) => { const [query, setQuery] = (0, _react.useState)(""); const [suggestions, setSuggestions] = (0, _react.useState)([]); const [isFocused, onFocusChangeHandlerFunctions] = (0, _useFocus.default)(); const editorContainerRef = (0, _react.useRef)(null); const editorRef = (0, _react.useRef)(null); const focusEditor = () => { editorRef?.current?.focus(); }; const onQueryChange = async e => { const value = e.target.value.trim(); setQuery(value); let matches = await provider.getCompletions(query, { start: query.length, end: query.length }, true, maxSuggestions); if (additionalFilter) { matches = matches.filter(additionalFilter); } setSuggestions(matches); }; const onClickInputArea = () => { focusEditor(); }; const onKeyDown = e => { const hasModifiers = e.ctrlKey || e.shiftKey || e.metaKey; // when the field is empty and the user hits backspace remove the right-most target if (!query && selection.length > 0 && e.key === _Keyboard.Key.BACKSPACE && !hasModifiers) { removeSelection(selection[selection.length - 1]); } }; const toggleSelection = completion => { const newSelection = [...selection]; const index = selection.findIndex(selection => selection.completionId === completion.completionId); if (index >= 0) { newSelection.splice(index, 1); } else { newSelection.push(completion); } onSelectionChange(newSelection); focusEditor(); setQuery(""); setSuggestions([]); }; const removeSelection = completion => { const newSelection = [...selection]; const index = selection.findIndex(selection => selection.completionId === completion.completionId); if (index >= 0) { newSelection.splice(index, 1); onSelectionChange(newSelection); } }; const hasPlaceholder = () => selection.length === 0 && query.length === 0; return /*#__PURE__*/_react.default.createElement("div", { className: "mx_AutocompleteInput" }, /*#__PURE__*/_react.default.createElement("div", { ref: editorContainerRef, className: (0, _classnames.default)({ "mx_AutocompleteInput_editor": true, "mx_AutocompleteInput_editor--focused": isFocused, "mx_AutocompleteInput_editor--has-suggestions": suggestions.length > 0 }), onClick: onClickInputArea, "data-testid": "autocomplete-editor" }, /*#__PURE__*/_react.default.createElement(_icons.SearchIcon, { className: "mx_AutocompleteInput_search_icon", width: "18px", height: "18px" }), selection.map(item => /*#__PURE__*/_react.default.createElement(SelectionItem, { key: item.completionId, item: item, onClick: removeSelection, render: renderSelection })), /*#__PURE__*/_react.default.createElement("input", (0, _extends2.default)({ ref: editorRef, type: "text", onKeyDown: onKeyDown, onChange: onQueryChange, value: query, autoComplete: "off", placeholder: hasPlaceholder() ? placeholder : undefined, "data-testid": "autocomplete-input" }, onFocusChangeHandlerFunctions))), isFocused && suggestions.length ? /*#__PURE__*/_react.default.createElement("div", { className: "mx_AutocompleteInput_matches", style: { top: editorContainerRef.current?.clientHeight }, "data-testid": "autocomplete-matches" }, suggestions.map(item => /*#__PURE__*/_react.default.createElement(SuggestionItem, { key: item.completionId, item: item, selection: selection, onClick: toggleSelection, render: renderSuggestion }))) : null); }; exports.AutocompleteInput = AutocompleteInput; const SelectionItem = ({ item, onClick, render }) => { const withContainer = children => /*#__PURE__*/_react.default.createElement("span", { className: "mx_AutocompleteInput_editor_selection", "data-testid": `autocomplete-selection-item-${item.completionId}` }, /*#__PURE__*/_react.default.createElement("span", { className: "mx_AutocompleteInput_editor_selection_pill" }, children), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_AutocompleteInput_editor_selection_remove_button", onClick: () => onClick(item), "data-testid": `autocomplete-selection-remove-button-${item.completionId}` }, /*#__PURE__*/_react.default.createElement(_icons.CloseIcon, { width: "16px", height: "16px" }))); if (render) { return withContainer(render(item)); } return withContainer( /*#__PURE__*/_react.default.createElement("span", { className: "mx_AutocompleteInput_editor_selection_text" }, item.completion)); }; const SuggestionItem = ({ item, selection, onClick, render }) => { const isSelected = selection.some(selection => selection.completionId === item.completionId); const classes = (0, _classnames.default)({ "mx_AutocompleteInput_suggestion": true, "mx_AutocompleteInput_suggestion--selected": isSelected }); const withContainer = children => /*#__PURE__*/_react.default.createElement("div", { className: classes // `onClick` cannot be used here as it would lead to focus loss and closing the suggestion list. , onMouseDown: event => { event.preventDefault(); onClick(item); }, "data-testid": `autocomplete-suggestion-item-${item.completionId}` }, children); if (render) { return withContainer(render(item)); } return withContainer( /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", { className: "mx_AutocompleteInput_suggestion_title" }, item.completion), /*#__PURE__*/_react.default.createElement("span", { className: "mx_AutocompleteInput_suggestion_description" }, item.completionId))); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_icons","_Keyboard","_AccessibleButton","_useFocus","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AutocompleteInput","provider","renderSuggestion","renderSelection","maxSuggestions","placeholder","onSelectionChange","selection","additionalFilter","query","setQuery","useState","suggestions","setSuggestions","isFocused","onFocusChangeHandlerFunctions","useFocus","editorContainerRef","useRef","editorRef","focusEditor","current","focus","onQueryChange","value","target","trim","matches","getCompletions","start","length","end","filter","onClickInputArea","onKeyDown","hasModifiers","ctrlKey","shiftKey","metaKey","key","Key","BACKSPACE","removeSelection","toggleSelection","completion","newSelection","index","findIndex","completionId","splice","push","hasPlaceholder","createElement","className","ref","classNames","onClick","SearchIcon","width","height","map","item","SelectionItem","render","_extends2","type","onChange","autoComplete","undefined","style","top","clientHeight","SuggestionItem","exports","withContainer","children","CloseIcon","isSelected","some","classes","onMouseDown","event","preventDefault","Fragment"],"sources":["../../../src/components/structures/AutocompleteInput.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 The Matrix.org Foundation C.I.C.\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, { useState, ReactNode, ChangeEvent, KeyboardEvent, useRef, ReactElement } from \"react\";\nimport classNames from \"classnames\";\nimport { SearchIcon, CloseIcon } from \"@vector-im/compound-design-tokens/assets/web/icons\";\n\nimport Autocompleter from \"../../autocomplete/AutocompleteProvider\";\nimport { Key } from \"../../Keyboard\";\nimport { ICompletion } from \"../../autocomplete/Autocompleter\";\nimport AccessibleButton from \"../../components/views/elements/AccessibleButton\";\nimport useFocus from \"../../hooks/useFocus\";\n\ninterface AutocompleteInputProps {\n    provider: Autocompleter;\n    placeholder: string;\n    selection: ICompletion[];\n    onSelectionChange: (selection: ICompletion[]) => void;\n    maxSuggestions?: number;\n    renderSuggestion?: (s: ICompletion) => ReactElement;\n    renderSelection?: (m: ICompletion) => ReactElement;\n    additionalFilter?: (suggestion: ICompletion) => boolean;\n}\n\nexport const AutocompleteInput: React.FC<AutocompleteInputProps> = ({\n    provider,\n    renderSuggestion,\n    renderSelection,\n    maxSuggestions = 5,\n    placeholder,\n    onSelectionChange,\n    selection,\n    additionalFilter,\n}) => {\n    const [query, setQuery] = useState<string>(\"\");\n    const [suggestions, setSuggestions] = useState<ICompletion[]>([]);\n    const [isFocused, onFocusChangeHandlerFunctions] = useFocus();\n    const editorContainerRef = useRef<HTMLDivElement>(null);\n    const editorRef = useRef<HTMLInputElement>(null);\n\n    const focusEditor = (): void => {\n        editorRef?.current?.focus();\n    };\n\n    const onQueryChange = async (e: ChangeEvent<HTMLInputElement>): Promise<void> => {\n        const value = e.target.value.trim();\n        setQuery(value);\n\n        let matches = await provider.getCompletions(\n            query,\n            { start: query.length, end: query.length },\n            true,\n            maxSuggestions,\n        );\n\n        if (additionalFilter) {\n            matches = matches.filter(additionalFilter);\n        }\n\n        setSuggestions(matches);\n    };\n\n    const onClickInputArea = (): void => {\n        focusEditor();\n    };\n\n    const onKeyDown = (e: KeyboardEvent): void => {\n        const hasModifiers = e.ctrlKey || e.shiftKey || e.metaKey;\n\n        // when the field is empty and the user hits backspace remove the right-most target\n        if (!query && selection.length > 0 && e.key === Key.BACKSPACE && !hasModifiers) {\n            removeSelection(selection[selection.length - 1]);\n        }\n    };\n\n    const toggleSelection = (completion: ICompletion): void => {\n        const newSelection = [...selection];\n        const index = selection.findIndex((selection) => selection.completionId === completion.completionId);\n\n        if (index >= 0) {\n            newSelection.splice(index, 1);\n        } else {\n            newSelection.push(completion);\n        }\n\n        onSelectionChange(newSelection);\n        focusEditor();\n        setQuery(\"\");\n        setSuggestions([]);\n    };\n\n    const removeSelection = (completion: ICompletion): void => {\n        const newSelection = [...selection];\n        const index = selection.findIndex((selection) => selection.completionId === completion.completionId);\n\n        if (index >= 0) {\n            newSelection.splice(index, 1);\n            onSelectionChange(newSelection);\n        }\n    };\n\n    const hasPlaceholder = (): boolean => selection.length === 0 && query.length === 0;\n\n    return (\n        <div className=\"mx_AutocompleteInput\">\n            <div\n                ref={editorContainerRef}\n                className={classNames({\n                    \"mx_AutocompleteInput_editor\": true,\n                    \"mx_AutocompleteInput_editor--focused\": isFocused,\n                    \"mx_AutocompleteInput_editor--has-suggestions\": suggestions.length > 0,\n                })}\n                onClick={onClickInputArea}\n                data-testid=\"autocomplete-editor\"\n            >\n                <SearchIcon className=\"mx_AutocompleteInput_search_icon\" width=\"18px\" height=\"18px\" />\n                {selection.map((item) => (\n                    <SelectionItem\n                        key={item.completionId}\n                        item={item}\n                        onClick={removeSelection}\n                        render={renderSelection}\n                    />\n                ))}\n                <input\n                    ref={editorRef}\n                    type=\"text\"\n                    onKeyDown={onKeyDown}\n                    onChange={onQueryChange}\n                    value={query}\n                    autoComplete=\"off\"\n                    placeholder={hasPlaceholder() ? placeholder : undefined}\n                    data-testid=\"autocomplete-input\"\n                    {...onFocusChangeHandlerFunctions}\n                />\n            </div>\n            {isFocused && suggestions.length ? (\n                <div\n                    className=\"mx_AutocompleteInput_matches\"\n                    style={{ top: editorContainerRef.current?.clientHeight }}\n                    data-testid=\"autocomplete-matches\"\n                >\n                    {suggestions.map((item) => (\n                        <SuggestionItem\n                            key={item.completionId}\n                            item={item}\n                            selection={selection}\n                            onClick={toggleSelection}\n                            render={renderSuggestion}\n                        />\n                    ))}\n                </div>\n            ) : null}\n        </div>\n    );\n};\n\ntype SelectionItemProps = {\n    item: ICompletion;\n    onClick: (completion: ICompletion) => void;\n    render?: (completion: ICompletion) => ReactElement;\n};\n\nconst SelectionItem: React.FC<SelectionItemProps> = ({ item, onClick, render }) => {\n    const withContainer = (children: ReactNode): ReactElement => (\n        <span\n            className=\"mx_AutocompleteInput_editor_selection\"\n            data-testid={`autocomplete-selection-item-${item.completionId}`}\n        >\n            <span className=\"mx_AutocompleteInput_editor_selection_pill\">{children}</span>\n            <AccessibleButton\n                className=\"mx_AutocompleteInput_editor_selection_remove_button\"\n                onClick={() => onClick(item)}\n                data-testid={`autocomplete-selection-remove-button-${item.completionId}`}\n            >\n                <CloseIcon width=\"16px\" height=\"16px\" />\n            </AccessibleButton>\n        </span>\n    );\n\n    if (render) {\n        return withContainer(render(item));\n    }\n\n    return withContainer(<span className=\"mx_AutocompleteInput_editor_selection_text\">{item.completion}</span>);\n};\n\ntype SuggestionItemProps = {\n    item: ICompletion;\n    selection: ICompletion[];\n    onClick: (completion: ICompletion) => void;\n    render?: (completion: ICompletion) => ReactElement;\n};\n\nconst SuggestionItem: React.FC<SuggestionItemProps> = ({ item, selection, onClick, render }) => {\n    const isSelected = selection.some((selection) => selection.completionId === item.completionId);\n    const classes = classNames({\n        \"mx_AutocompleteInput_suggestion\": true,\n        \"mx_AutocompleteInput_suggestion--selected\": isSelected,\n    });\n\n    const withContainer = (children: ReactNode): ReactElement => (\n        <div\n            className={classes}\n            // `onClick` cannot be used here as it would lead to focus loss and closing the suggestion list.\n            onMouseDown={(event) => {\n                event.preventDefault();\n                onClick(item);\n            }}\n            data-testid={`autocomplete-suggestion-item-${item.completionId}`}\n        >\n            {children}\n        </div>\n    );\n\n    if (render) {\n        return withContainer(render(item));\n    }\n\n    return withContainer(\n        <>\n            <span className=\"mx_AutocompleteInput_suggestion_title\">{item.completion}</span>\n            <span className=\"mx_AutocompleteInput_suggestion_description\">{item.completionId}</span>\n        </>,\n    );\n};\n"],"mappings":"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","ignoreList":[]}