matrix-react-sdk
Version:
SDK for matrix.org using React
140 lines (136 loc) • 19.9 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _lodash = require("lodash");
var _classnames = _interopRequireDefault(require("classnames"));
var _AccessibleButton = _interopRequireDefault(require("../../components/views/elements/AccessibleButton"));
var _KeyBindingsManager = require("../../KeyBindingsManager");
var _KeyboardShortcuts = require("../../accessibility/KeyboardShortcuts");
const _excluded = ["onSearch", "onCleared", "onKeyDown", "onFocus", "onBlur", "className", "placeholder", "blurredPlaceholder", "autoFocus", "initialValue", "collapsed"];
/*
Copyright 2024 New Vector Ltd.
Copyright 2019 Michael Telatynski <7t3chguy@gmail.com>
Copyright 2015, 2016 OpenMarket 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; }
class SearchBox extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "search", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "onChange", () => {
if (!this.search.current) return;
this.setState({
searchTerm: this.search.current.value
});
this.onSearch();
});
(0, _defineProperty2.default)(this, "onSearch", (0, _lodash.throttle)(() => {
this.props.onSearch(this.search.current?.value ?? "");
}, 200, {
trailing: true,
leading: true
}));
(0, _defineProperty2.default)(this, "onKeyDown", ev => {
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(ev);
switch (action) {
case _KeyboardShortcuts.KeyBindingAction.Escape:
this.clearSearch("keyboard");
break;
}
if (this.props.onKeyDown) this.props.onKeyDown(ev);
});
(0, _defineProperty2.default)(this, "onFocus", ev => {
this.setState({
blurred: false
});
ev.target.select();
if (this.props.onFocus) {
this.props.onFocus(ev);
}
});
(0, _defineProperty2.default)(this, "onBlur", ev => {
this.setState({
blurred: true
});
if (this.props.onBlur) {
this.props.onBlur(ev);
}
});
this.state = {
searchTerm: props.initialValue || "",
blurred: true
};
}
clearSearch(source) {
if (this.search.current) this.search.current.value = "";
this.onChange();
this.props.onCleared?.(source);
}
render() {
/* eslint @typescript-eslint/no-unused-vars: ["error", { "ignoreRestSiblings": true }] */
const _this$props = this.props,
{
onSearch,
onCleared,
onKeyDown,
onFocus,
onBlur,
className = "",
placeholder,
blurredPlaceholder,
autoFocus,
initialValue,
collapsed
} = _this$props,
props = (0, _objectWithoutProperties2.default)(_this$props, _excluded);
// check for collapsed here and
// not at parent so we keep
// searchTerm in our state
// when collapsing and expanding
if (collapsed) {
return null;
}
const clearButton = !this.state.blurred || this.state.searchTerm ? /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
key: "button",
tabIndex: -1,
className: "mx_SearchBox_closeButton",
onClick: () => {
this.clearSearch("button");
}
}) : undefined;
// show a shorter placeholder when blurred, if requested
// this is used for the room filter field that has
// the explore button next to it when blurred
return /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)("mx_SearchBox", "mx_textinput", {
mx_SearchBox_blurred: this.state.blurred
})
}, /*#__PURE__*/_react.default.createElement("input", (0, _extends2.default)({}, props, {
key: "searchfield",
type: "text",
ref: this.search,
className: "mx_textinput_icon mx_textinput_search " + className,
value: this.state.searchTerm,
onFocus: this.onFocus,
onChange: this.onChange,
onKeyDown: this.onKeyDown,
onBlur: this.onBlur,
placeholder: this.state.blurred ? blurredPlaceholder || placeholder : placeholder,
autoComplete: "off",
autoFocus: this.props.autoFocus,
"data-testid": "searchbox-input"
})), clearButton);
}
}
exports.default = SearchBox;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_classnames","_interopRequireDefault","_AccessibleButton","_KeyBindingsManager","_KeyboardShortcuts","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","SearchBox","React","Component","constructor","props","_defineProperty2","createRef","search","current","setState","searchTerm","value","onSearch","throttle","trailing","leading","ev","action","getKeyBindingsManager","getAccessibilityAction","KeyBindingAction","Escape","clearSearch","onKeyDown","blurred","target","select","onFocus","onBlur","state","initialValue","source","onChange","onCleared","render","_this$props","className","placeholder","blurredPlaceholder","autoFocus","collapsed","_objectWithoutProperties2","clearButton","createElement","key","tabIndex","onClick","undefined","classNames","mx_SearchBox_blurred","_extends2","type","ref","autoComplete","exports"],"sources":["../../../src/components/structures/SearchBox.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019 Michael Telatynski <7t3chguy@gmail.com>\nCopyright 2015, 2016 OpenMarket 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, { createRef, HTMLProps } from \"react\";\nimport { throttle } from \"lodash\";\nimport classNames from \"classnames\";\n\nimport AccessibleButton from \"../../components/views/elements/AccessibleButton\";\nimport { getKeyBindingsManager } from \"../../KeyBindingsManager\";\nimport { KeyBindingAction } from \"../../accessibility/KeyboardShortcuts\";\n\ninterface IProps extends HTMLProps<HTMLInputElement> {\n    onSearch: (query: string) => void;\n    onCleared?: (source?: string) => void;\n    onKeyDown?: (ev: React.KeyboardEvent) => void;\n    onFocus?: (ev: React.FocusEvent) => void;\n    onBlur?: (ev: React.FocusEvent) => void;\n    className?: string;\n    placeholder: string;\n    blurredPlaceholder?: string;\n    autoFocus?: boolean;\n    initialValue?: string;\n    collapsed?: boolean;\n}\n\ninterface IState {\n    searchTerm: string;\n    blurred: boolean;\n}\n\nexport default class SearchBox extends React.Component<IProps, IState> {\n    private search = createRef<HTMLInputElement>();\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            searchTerm: props.initialValue || \"\",\n            blurred: true,\n        };\n    }\n\n    private onChange = (): void => {\n        if (!this.search.current) return;\n        this.setState({ searchTerm: this.search.current.value });\n        this.onSearch();\n    };\n\n    private onSearch = throttle(\n        (): void => {\n            this.props.onSearch(this.search.current?.value ?? \"\");\n        },\n        200,\n        { trailing: true, leading: true },\n    );\n\n    private onKeyDown = (ev: React.KeyboardEvent): void => {\n        const action = getKeyBindingsManager().getAccessibilityAction(ev);\n        switch (action) {\n            case KeyBindingAction.Escape:\n                this.clearSearch(\"keyboard\");\n                break;\n        }\n        if (this.props.onKeyDown) this.props.onKeyDown(ev);\n    };\n\n    private onFocus = (ev: React.FocusEvent): void => {\n        this.setState({ blurred: false });\n        (ev.target as HTMLInputElement).select();\n        if (this.props.onFocus) {\n            this.props.onFocus(ev);\n        }\n    };\n\n    private onBlur = (ev: React.FocusEvent): void => {\n        this.setState({ blurred: true });\n        if (this.props.onBlur) {\n            this.props.onBlur(ev);\n        }\n    };\n\n    private clearSearch(source?: string): void {\n        if (this.search.current) this.search.current.value = \"\";\n        this.onChange();\n        this.props.onCleared?.(source);\n    }\n\n    public render(): React.ReactNode {\n        /* eslint @typescript-eslint/no-unused-vars: [\"error\", { \"ignoreRestSiblings\": true }] */\n        const {\n            onSearch,\n            onCleared,\n            onKeyDown,\n            onFocus,\n            onBlur,\n            className = \"\",\n            placeholder,\n            blurredPlaceholder,\n            autoFocus,\n            initialValue,\n            collapsed,\n            ...props\n        } = this.props;\n\n        // check for collapsed here and\n        // not at parent so we keep\n        // searchTerm in our state\n        // when collapsing and expanding\n        if (collapsed) {\n            return null;\n        }\n        const clearButton =\n            !this.state.blurred || this.state.searchTerm ? (\n                <AccessibleButton\n                    key=\"button\"\n                    tabIndex={-1}\n                    className=\"mx_SearchBox_closeButton\"\n                    onClick={() => {\n                        this.clearSearch(\"button\");\n                    }}\n                />\n            ) : undefined;\n\n        // show a shorter placeholder when blurred, if requested\n        // this is used for the room filter field that has\n        // the explore button next to it when blurred\n        return (\n            <div className={classNames(\"mx_SearchBox\", \"mx_textinput\", { mx_SearchBox_blurred: this.state.blurred })}>\n                <input\n                    {...props}\n                    key=\"searchfield\"\n                    type=\"text\"\n                    ref={this.search}\n                    className={\"mx_textinput_icon mx_textinput_search \" + className}\n                    value={this.state.searchTerm}\n                    onFocus={this.onFocus}\n                    onChange={this.onChange}\n                    onKeyDown={this.onKeyDown}\n                    onBlur={this.onBlur}\n                    placeholder={this.state.blurred ? blurredPlaceholder || placeholder : placeholder}\n                    autoComplete=\"off\"\n                    autoFocus={this.props.autoFocus}\n                    data-testid=\"searchbox-input\"\n                />\n                {clearButton}\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}