matrix-react-sdk
Version:
SDK for matrix.org using React
234 lines (195 loc) • 25.3 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var React = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _dispatcher = _interopRequireDefault(require("../../dispatcher/dispatcher"));
var _languageHandler = require("../../languageHandler");
var _AccessibleButton = _interopRequireDefault(require("../views/elements/AccessibleButton"));
var _actions = require("../../dispatcher/actions");
var _RoomListStore = _interopRequireDefault(require("../../stores/room-list/RoomListStore"));
var _NameFilterCondition = require("../../stores/room-list/filters/NameFilterCondition");
var _KeyBindingsManager = require("../../KeyBindingsManager");
var _replaceableComponent = require("../../utils/replaceableComponent");
var _SpaceStore = _interopRequireWildcard(require("../../stores/SpaceStore"));
var _dec, _class, _temp;
let RoomSearch = (_dec = (0, _replaceableComponent.replaceableComponent)("structures.RoomSearch"), _dec(_class = (_temp = class RoomSearch extends React.PureComponent
/*:: <IProps, IState>*/
{
constructor(props
/*: IProps*/
) {
super(props);
(0, _defineProperty2.default)(this, "dispatcherRef", void 0);
(0, _defineProperty2.default)(this, "inputRef", /*#__PURE__*/(0, React.createRef)());
(0, _defineProperty2.default)(this, "searchFilter", new _NameFilterCondition.NameFilterCondition());
(0, _defineProperty2.default)(this, "onSpaces", (spaces
/*: Room[]*/
) => {
this.setState({
inSpaces: spaces.length > 0
});
});
(0, _defineProperty2.default)(this, "onAction", (payload
/*: ActionPayload*/
) => {
if (payload.action === 'view_room' && payload.clear_search) {
this.clearInput();
} else if (payload.action === 'focus_room_filter' && this.inputRef.current) {
this.inputRef.current.focus();
}
});
(0, _defineProperty2.default)(this, "clearInput", () => {
if (!this.inputRef.current) return;
this.inputRef.current.value = "";
this.onChange();
});
(0, _defineProperty2.default)(this, "openSearch", () => {
_dispatcher.default.dispatch({
action: "show_left_panel"
});
_dispatcher.default.dispatch({
action: "focus_room_filter"
});
});
(0, _defineProperty2.default)(this, "onChange", () => {
if (!this.inputRef.current) return;
this.setState({
query: this.inputRef.current.value
});
});
(0, _defineProperty2.default)(this, "onFocus", (ev
/*: React.FocusEvent<HTMLInputElement>*/
) => {
this.setState({
focused: true
});
ev.target.select();
});
(0, _defineProperty2.default)(this, "onBlur", (ev
/*: React.FocusEvent<HTMLInputElement>*/
) => {
this.setState({
focused: false
});
});
(0, _defineProperty2.default)(this, "onKeyDown", (ev
/*: React.KeyboardEvent*/
) => {
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getRoomListAction(ev);
switch (action) {
case _KeyBindingsManager.RoomListAction.ClearSearch:
this.clearInput();
_dispatcher.default.fire(_actions.Action.FocusComposer);
break;
case _KeyBindingsManager.RoomListAction.NextRoom:
case _KeyBindingsManager.RoomListAction.PrevRoom:
// we don't handle these actions here put pass the event on to the interested party (LeftPanel)
this.props.onKeyDown(ev);
break;
case _KeyBindingsManager.RoomListAction.SelectRoom:
{
const shouldClear = this.props.onSelectRoom();
if (shouldClear) {
// wrap in set immediate to delay it so that we don't clear the filter & then change room
setImmediate(() => {
this.clearInput();
});
}
break;
}
}
});
this.state = {
query: "",
focused: false,
inSpaces: false
};
this.dispatcherRef = _dispatcher.default.register(this.onAction); // clear filter when changing spaces, in future we may wish to maintain a filter per-space
_SpaceStore.default.instance.on(_SpaceStore.UPDATE_SELECTED_SPACE, this.clearInput);
_SpaceStore.default.instance.on(_SpaceStore.UPDATE_TOP_LEVEL_SPACES, this.onSpaces);
}
componentDidUpdate(prevProps
/*: Readonly<IProps>*/
, prevState
/*: Readonly<IState>*/
)
/*: void*/
{
if (prevState.query !== this.state.query) {
const hadSearch = !!this.searchFilter.search.trim();
const haveSearch = !!this.state.query.trim();
this.searchFilter.search = this.state.query;
if (!hadSearch && haveSearch) {
// started a new filter - add the condition
_RoomListStore.default.instance.addFilter(this.searchFilter);
} else if (hadSearch && !haveSearch) {
// cleared a filter - remove the condition
_RoomListStore.default.instance.removeFilter(this.searchFilter);
} // else the filter hasn't changed enough for us to care here
}
}
componentWillUnmount() {
_dispatcher.default.unregister(this.dispatcherRef);
_SpaceStore.default.instance.off(_SpaceStore.UPDATE_SELECTED_SPACE, this.clearInput);
_SpaceStore.default.instance.off(_SpaceStore.UPDATE_TOP_LEVEL_SPACES, this.onSpaces);
}
render()
/*: React.ReactNode*/
{
const classes = (0, _classnames.default)({
'mx_RoomSearch': true,
'mx_RoomSearch_hasQuery': this.state.query,
'mx_RoomSearch_focused': this.state.focused,
'mx_RoomSearch_minimized': this.props.isMinimized
});
const inputClasses = (0, _classnames.default)({
'mx_RoomSearch_input': true,
'mx_RoomSearch_inputExpanded': this.state.query || this.state.focused
});
let placeholder = (0, _languageHandler._t)("Filter");
if (this.state.inSpaces) {
placeholder = (0, _languageHandler._t)("Filter all spaces");
}
let icon = /*#__PURE__*/React.createElement("div", {
className: "mx_RoomSearch_icon"
});
let input = /*#__PURE__*/React.createElement("input", {
type: "text",
ref: this.inputRef,
className: inputClasses,
value: this.state.query,
onFocus: this.onFocus,
onBlur: this.onBlur,
onChange: this.onChange,
onKeyDown: this.onKeyDown,
placeholder: placeholder,
autoComplete: "off"
});
let clearButton = /*#__PURE__*/React.createElement(_AccessibleButton.default, {
tabIndex: -1,
title: (0, _languageHandler._t)("Clear filter"),
className: "mx_RoomSearch_clearButton",
onClick: this.clearInput
});
if (this.props.isMinimized) {
icon = /*#__PURE__*/React.createElement(_AccessibleButton.default, {
title: (0, _languageHandler._t)("Filter rooms and people"),
className: "mx_RoomSearch_icon mx_RoomSearch_minimizedHandle",
onClick: this.openSearch
});
input = null;
clearButton = null;
}
return /*#__PURE__*/React.createElement("div", {
className: classes
}, icon, input, clearButton);
}
}, _temp)) || _class);
exports.default = RoomSearch;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/structures/RoomSearch.tsx"],"names":["RoomSearch","React","PureComponent","constructor","props","NameFilterCondition","spaces","setState","inSpaces","length","payload","action","clear_search","clearInput","inputRef","current","focus","value","onChange","defaultDispatcher","dispatch","query","ev","focused","target","select","getRoomListAction","RoomListAction","ClearSearch","fire","Action","FocusComposer","NextRoom","PrevRoom","onKeyDown","SelectRoom","shouldClear","onSelectRoom","setImmediate","state","dispatcherRef","register","onAction","SpaceStore","instance","on","UPDATE_SELECTED_SPACE","UPDATE_TOP_LEVEL_SPACES","onSpaces","componentDidUpdate","prevProps","prevState","hadSearch","searchFilter","search","trim","haveSearch","RoomListStore","addFilter","removeFilter","componentWillUnmount","unregister","off","render","classes","isMinimized","inputClasses","placeholder","icon","input","onFocus","onBlur","clearButton","openSearch"],"mappings":"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","sourcesContent":["/*\nCopyright 2020, 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as React from \"react\";\nimport { createRef } from \"react\";\nimport classNames from \"classnames\";\nimport { Room } from \"matrix-js-sdk/src/models/room\";\n\nimport defaultDispatcher from \"../../dispatcher/dispatcher\";\nimport { _t } from \"../../languageHandler\";\nimport { ActionPayload } from \"../../dispatcher/payloads\";\nimport AccessibleButton from \"../views/elements/AccessibleButton\";\nimport { Action } from \"../../dispatcher/actions\";\nimport RoomListStore from \"../../stores/room-list/RoomListStore\";\nimport { NameFilterCondition } from \"../../stores/room-list/filters/NameFilterCondition\";\nimport { getKeyBindingsManager, RoomListAction } from \"../../KeyBindingsManager\";\nimport { replaceableComponent } from \"../../utils/replaceableComponent\";\nimport SpaceStore, { UPDATE_SELECTED_SPACE, UPDATE_TOP_LEVEL_SPACES } from \"../../stores/SpaceStore\";\n\ninterface IProps {\n    isMinimized: boolean;\n    onKeyDown(ev: React.KeyboardEvent): void;\n    /**\n     * @returns true if a room has been selected and the search field should be cleared\n     */\n    onSelectRoom(): boolean;\n}\n\ninterface IState {\n    query: string;\n    focused: boolean;\n    inSpaces: boolean;\n}\n\n@replaceableComponent(\"structures.RoomSearch\")\nexport default class RoomSearch extends React.PureComponent<IProps, IState> {\n    private dispatcherRef: string;\n    private inputRef: React.RefObject<HTMLInputElement> = createRef();\n    private searchFilter: NameFilterCondition = new NameFilterCondition();\n\n    constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            query: \"\",\n            focused: false,\n            inSpaces: false,\n        };\n\n        this.dispatcherRef = defaultDispatcher.register(this.onAction);\n        // clear filter when changing spaces, in future we may wish to maintain a filter per-space\n        SpaceStore.instance.on(UPDATE_SELECTED_SPACE, this.clearInput);\n        SpaceStore.instance.on(UPDATE_TOP_LEVEL_SPACES, this.onSpaces);\n    }\n\n    public componentDidUpdate(prevProps: Readonly<IProps>, prevState: Readonly<IState>): void {\n        if (prevState.query !== this.state.query) {\n            const hadSearch = !!this.searchFilter.search.trim();\n            const haveSearch = !!this.state.query.trim();\n            this.searchFilter.search = this.state.query;\n            if (!hadSearch && haveSearch) {\n                // started a new filter - add the condition\n                RoomListStore.instance.addFilter(this.searchFilter);\n            } else if (hadSearch && !haveSearch) {\n                // cleared a filter - remove the condition\n                RoomListStore.instance.removeFilter(this.searchFilter);\n            } // else the filter hasn't changed enough for us to care here\n        }\n    }\n\n    public componentWillUnmount() {\n        defaultDispatcher.unregister(this.dispatcherRef);\n        SpaceStore.instance.off(UPDATE_SELECTED_SPACE, this.clearInput);\n        SpaceStore.instance.off(UPDATE_TOP_LEVEL_SPACES, this.onSpaces);\n    }\n\n    private onSpaces = (spaces: Room[]) => {\n        this.setState({\n            inSpaces: spaces.length > 0,\n        });\n    };\n\n    private onAction = (payload: ActionPayload) => {\n        if (payload.action === 'view_room' && payload.clear_search) {\n            this.clearInput();\n        } else if (payload.action === 'focus_room_filter' && this.inputRef.current) {\n            this.inputRef.current.focus();\n        }\n    };\n\n    private clearInput = () => {\n        if (!this.inputRef.current) return;\n        this.inputRef.current.value = \"\";\n        this.onChange();\n    };\n\n    private openSearch = () => {\n        defaultDispatcher.dispatch({action: \"show_left_panel\"});\n        defaultDispatcher.dispatch({action: \"focus_room_filter\"});\n    };\n\n    private onChange = () => {\n        if (!this.inputRef.current) return;\n        this.setState({query: this.inputRef.current.value});\n    };\n\n    private onFocus = (ev: React.FocusEvent<HTMLInputElement>) => {\n        this.setState({focused: true});\n        ev.target.select();\n    };\n\n    private onBlur = (ev: React.FocusEvent<HTMLInputElement>) => {\n        this.setState({focused: false});\n    };\n\n    private onKeyDown = (ev: React.KeyboardEvent) => {\n        const action = getKeyBindingsManager().getRoomListAction(ev);\n        switch (action) {\n            case RoomListAction.ClearSearch:\n                this.clearInput();\n                defaultDispatcher.fire(Action.FocusComposer);\n                break;\n            case RoomListAction.NextRoom:\n            case RoomListAction.PrevRoom:\n                // we don't handle these actions here put pass the event on to the interested party (LeftPanel)\n                this.props.onKeyDown(ev);\n                break;\n            case RoomListAction.SelectRoom: {\n                const shouldClear = this.props.onSelectRoom();\n                if (shouldClear) {\n                    // wrap in set immediate to delay it so that we don't clear the filter & then change room\n                    setImmediate(() => {\n                        this.clearInput();\n                    });\n                }\n                break;\n            }\n        }\n    };\n\n    public render(): React.ReactNode {\n        const classes = classNames({\n            'mx_RoomSearch': true,\n            'mx_RoomSearch_hasQuery': this.state.query,\n            'mx_RoomSearch_focused': this.state.focused,\n            'mx_RoomSearch_minimized': this.props.isMinimized,\n        });\n\n        const inputClasses = classNames({\n            'mx_RoomSearch_input': true,\n            'mx_RoomSearch_inputExpanded': this.state.query || this.state.focused,\n        });\n\n        let placeholder = _t(\"Filter\");\n        if (this.state.inSpaces) {\n            placeholder = _t(\"Filter all spaces\");\n        }\n\n        let icon = (\n            <div className='mx_RoomSearch_icon' />\n        );\n        let input = (\n            <input\n                type=\"text\"\n                ref={this.inputRef}\n                className={inputClasses}\n                value={this.state.query}\n                onFocus={this.onFocus}\n                onBlur={this.onBlur}\n                onChange={this.onChange}\n                onKeyDown={this.onKeyDown}\n                placeholder={placeholder}\n                autoComplete=\"off\"\n            />\n        );\n        let clearButton = (\n            <AccessibleButton\n                tabIndex={-1}\n                title={_t(\"Clear filter\")}\n                className=\"mx_RoomSearch_clearButton\"\n                onClick={this.clearInput}\n            />\n        );\n\n        if (this.props.isMinimized) {\n            icon = (\n                <AccessibleButton\n                    title={_t(\"Filter rooms and people\")}\n                    className=\"mx_RoomSearch_icon mx_RoomSearch_minimizedHandle\"\n                    onClick={this.openSearch}\n                />\n            );\n            input = null;\n            clearButton = null;\n        }\n\n        return (\n            <div className={classes}>\n                {icon}\n                {input}\n                {clearButton}\n            </div>\n        );\n    }\n}\n"]}