Merge pull request #6230 from matrix-org/gsouquet/fix-17051
This commit is contained in:
commit
5b72423ea3
5 changed files with 156 additions and 104 deletions
|
@ -60,7 +60,7 @@ import ScrollPanel from "./ScrollPanel";
|
||||||
import TimelinePanel from "./TimelinePanel";
|
import TimelinePanel from "./TimelinePanel";
|
||||||
import ErrorBoundary from "../views/elements/ErrorBoundary";
|
import ErrorBoundary from "../views/elements/ErrorBoundary";
|
||||||
import RoomPreviewBar from "../views/rooms/RoomPreviewBar";
|
import RoomPreviewBar from "../views/rooms/RoomPreviewBar";
|
||||||
import SearchBar from "../views/rooms/SearchBar";
|
import SearchBar, { SearchScope } from "../views/rooms/SearchBar";
|
||||||
import RoomUpgradeWarningBar from "../views/rooms/RoomUpgradeWarningBar";
|
import RoomUpgradeWarningBar from "../views/rooms/RoomUpgradeWarningBar";
|
||||||
import AuxPanel from "../views/rooms/AuxPanel";
|
import AuxPanel from "../views/rooms/AuxPanel";
|
||||||
import RoomHeader from "../views/rooms/RoomHeader";
|
import RoomHeader from "../views/rooms/RoomHeader";
|
||||||
|
@ -139,7 +139,7 @@ export interface IState {
|
||||||
draggingFile: boolean;
|
draggingFile: boolean;
|
||||||
searching: boolean;
|
searching: boolean;
|
||||||
searchTerm?: string;
|
searchTerm?: string;
|
||||||
searchScope?: "All" | "Room";
|
searchScope?: SearchScope;
|
||||||
searchResults?: XOR<{}, {
|
searchResults?: XOR<{}, {
|
||||||
count: number;
|
count: number;
|
||||||
highlights: string[];
|
highlights: string[];
|
||||||
|
@ -1267,7 +1267,7 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private onSearch = (term: string, scope) => {
|
private onSearch = (term: string, scope: SearchScope) => {
|
||||||
this.setState({
|
this.setState({
|
||||||
searchTerm: term,
|
searchTerm: term,
|
||||||
searchScope: scope,
|
searchScope: scope,
|
||||||
|
@ -1288,7 +1288,7 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
this.searchId = new Date().getTime();
|
this.searchId = new Date().getTime();
|
||||||
|
|
||||||
let roomId;
|
let roomId;
|
||||||
if (scope === "Room") roomId = this.state.room.roomId;
|
if (scope === SearchScope.Room) roomId = this.state.room.roomId;
|
||||||
|
|
||||||
debuglog("sending search request");
|
debuglog("sending search request");
|
||||||
const searchPromise = eventSearch(term, roomId);
|
const searchPromise = eventSearch(term, roomId);
|
||||||
|
|
|
@ -14,10 +14,14 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import React from "react";
|
||||||
import EventIndexPeg from "../../../indexing/EventIndexPeg";
|
import EventIndexPeg from "../../../indexing/EventIndexPeg";
|
||||||
import { _t } from "../../../languageHandler";
|
import { _t } from "../../../languageHandler";
|
||||||
import SdkConfig from "../../../SdkConfig";
|
import SdkConfig from "../../../SdkConfig";
|
||||||
import React from "react";
|
import dis from "../../../dispatcher/dispatcher";
|
||||||
|
import { Action } from "../../../dispatcher/actions";
|
||||||
|
import { UserTab } from "../dialogs/UserSettingsDialog";
|
||||||
|
|
||||||
|
|
||||||
export enum WarningKind {
|
export enum WarningKind {
|
||||||
Files,
|
Files,
|
||||||
|
@ -33,6 +37,22 @@ export default function DesktopBuildsNotice({isRoomEncrypted, kind}: IProps) {
|
||||||
if (!isRoomEncrypted) return null;
|
if (!isRoomEncrypted) return null;
|
||||||
if (EventIndexPeg.get()) return null;
|
if (EventIndexPeg.get()) return null;
|
||||||
|
|
||||||
|
if (EventIndexPeg.error) {
|
||||||
|
return <>
|
||||||
|
{_t("Message search initialisation failed, check <a>your settings</a> for more information", {}, {
|
||||||
|
a: sub => (<a onClick={(evt) => {
|
||||||
|
evt.preventDefault();
|
||||||
|
dis.dispatch({
|
||||||
|
action: Action.ViewUserSettings,
|
||||||
|
initialTabId: UserTab.Security,
|
||||||
|
});
|
||||||
|
}}>
|
||||||
|
{sub}
|
||||||
|
</a>),
|
||||||
|
})}
|
||||||
|
</>;
|
||||||
|
}
|
||||||
|
|
||||||
const {desktopBuilds, brand} = SdkConfig.get();
|
const {desktopBuilds, brand} = SdkConfig.get();
|
||||||
|
|
||||||
let text = null;
|
let text = null;
|
||||||
|
|
|
@ -1,99 +0,0 @@
|
||||||
/*
|
|
||||||
Copyright 2015, 2016 OpenMarket Ltd
|
|
||||||
Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import React, {createRef} from 'react';
|
|
||||||
import AccessibleButton from "../elements/AccessibleButton";
|
|
||||||
import classNames from "classnames";
|
|
||||||
import { _t } from '../../../languageHandler';
|
|
||||||
import {Key} from "../../../Keyboard";
|
|
||||||
import DesktopBuildsNotice, {WarningKind} from "../elements/DesktopBuildsNotice";
|
|
||||||
import {replaceableComponent} from "../../../utils/replaceableComponent";
|
|
||||||
|
|
||||||
@replaceableComponent("views.rooms.SearchBar")
|
|
||||||
export default class SearchBar extends React.Component {
|
|
||||||
constructor(props) {
|
|
||||||
super(props);
|
|
||||||
|
|
||||||
this._search_term = createRef();
|
|
||||||
|
|
||||||
this.state = {
|
|
||||||
scope: 'Room',
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
onThisRoomClick = () => {
|
|
||||||
this.setState({ scope: 'Room' }, () => this._searchIfQuery());
|
|
||||||
};
|
|
||||||
|
|
||||||
onAllRoomsClick = () => {
|
|
||||||
this.setState({ scope: 'All' }, () => this._searchIfQuery());
|
|
||||||
};
|
|
||||||
|
|
||||||
onSearchChange = (e) => {
|
|
||||||
switch (e.key) {
|
|
||||||
case Key.ENTER:
|
|
||||||
this.onSearch();
|
|
||||||
break;
|
|
||||||
case Key.ESCAPE:
|
|
||||||
this.props.onCancelClick();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
_searchIfQuery() {
|
|
||||||
if (this._search_term.current.value) {
|
|
||||||
this.onSearch();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
onSearch = () => {
|
|
||||||
this.props.onSearch(this._search_term.current.value, this.state.scope);
|
|
||||||
};
|
|
||||||
|
|
||||||
render() {
|
|
||||||
const searchButtonClasses = classNames("mx_SearchBar_searchButton", {
|
|
||||||
mx_SearchBar_searching: this.props.searchInProgress,
|
|
||||||
});
|
|
||||||
const thisRoomClasses = classNames("mx_SearchBar_button", {
|
|
||||||
mx_SearchBar_unselected: this.state.scope !== 'Room',
|
|
||||||
});
|
|
||||||
const allRoomsClasses = classNames("mx_SearchBar_button", {
|
|
||||||
mx_SearchBar_unselected: this.state.scope !== 'All',
|
|
||||||
});
|
|
||||||
|
|
||||||
return (
|
|
||||||
<>
|
|
||||||
<div className="mx_SearchBar">
|
|
||||||
<div className="mx_SearchBar_buttons" role="radiogroup">
|
|
||||||
<AccessibleButton className={ thisRoomClasses } onClick={this.onThisRoomClick} aria-checked={this.state.scope === 'Room'} role="radio">
|
|
||||||
{_t("This Room")}
|
|
||||||
</AccessibleButton>
|
|
||||||
<AccessibleButton className={ allRoomsClasses } onClick={this.onAllRoomsClick} aria-checked={this.state.scope === 'All'} role="radio">
|
|
||||||
{_t("All Rooms")}
|
|
||||||
</AccessibleButton>
|
|
||||||
</div>
|
|
||||||
<div className="mx_SearchBar_input mx_textinput">
|
|
||||||
<input ref={this._search_term} type="text" autoFocus={true} placeholder={_t("Search…")} onKeyDown={this.onSearchChange} />
|
|
||||||
<AccessibleButton className={ searchButtonClasses } onClick={this.onSearch} />
|
|
||||||
</div>
|
|
||||||
<AccessibleButton className="mx_SearchBar_cancel" onClick={this.props.onCancelClick} />
|
|
||||||
</div>
|
|
||||||
<DesktopBuildsNotice isRoomEncrypted={this.props.isRoomEncrypted} kind={WarningKind.Search} />
|
|
||||||
</>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
130
src/components/views/rooms/SearchBar.tsx
Normal file
130
src/components/views/rooms/SearchBar.tsx
Normal file
|
@ -0,0 +1,130 @@
|
||||||
|
/*
|
||||||
|
Copyright 2015, 2016 OpenMarket Ltd
|
||||||
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import React, { createRef, RefObject } from 'react';
|
||||||
|
import AccessibleButton from "../elements/AccessibleButton";
|
||||||
|
import classNames from "classnames";
|
||||||
|
import { _t } from '../../../languageHandler';
|
||||||
|
import { Key } from "../../../Keyboard";
|
||||||
|
import DesktopBuildsNotice, { WarningKind } from "../elements/DesktopBuildsNotice";
|
||||||
|
import { replaceableComponent } from "../../../utils/replaceableComponent";
|
||||||
|
|
||||||
|
interface IProps {
|
||||||
|
onCancelClick: () => void;
|
||||||
|
onSearch: (query: string, scope: string) => void;
|
||||||
|
searchInProgress?: boolean;
|
||||||
|
isRoomEncrypted?: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface IState {
|
||||||
|
scope: SearchScope;
|
||||||
|
}
|
||||||
|
|
||||||
|
export enum SearchScope {
|
||||||
|
Room = "Room",
|
||||||
|
All = "All",
|
||||||
|
}
|
||||||
|
|
||||||
|
@replaceableComponent("views.rooms.SearchBar")
|
||||||
|
export default class SearchBar extends React.Component<IProps, IState> {
|
||||||
|
private searchTerm: RefObject<HTMLInputElement> = createRef();
|
||||||
|
|
||||||
|
constructor(props: IProps) {
|
||||||
|
super(props);
|
||||||
|
this.state = {
|
||||||
|
scope: SearchScope.Room,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
private onThisRoomClick = () => {
|
||||||
|
this.setState({ scope: SearchScope.Room }, () => this.searchIfQuery());
|
||||||
|
};
|
||||||
|
|
||||||
|
private onAllRoomsClick = () => {
|
||||||
|
this.setState({ scope: SearchScope.All }, () => this.searchIfQuery());
|
||||||
|
};
|
||||||
|
|
||||||
|
private onSearchChange = (e: React.KeyboardEvent) => {
|
||||||
|
switch (e.key) {
|
||||||
|
case Key.ENTER:
|
||||||
|
this.onSearch();
|
||||||
|
break;
|
||||||
|
case Key.ESCAPE:
|
||||||
|
this.props.onCancelClick();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private searchIfQuery(): void {
|
||||||
|
if (this.searchTerm.current.value) {
|
||||||
|
this.onSearch();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private onSearch = (): void => {
|
||||||
|
this.props.onSearch(this.searchTerm.current.value, this.state.scope);
|
||||||
|
};
|
||||||
|
|
||||||
|
public render() {
|
||||||
|
const searchButtonClasses = classNames("mx_SearchBar_searchButton", {
|
||||||
|
mx_SearchBar_searching: this.props.searchInProgress,
|
||||||
|
});
|
||||||
|
const thisRoomClasses = classNames("mx_SearchBar_button", {
|
||||||
|
mx_SearchBar_unselected: this.state.scope !== SearchScope.Room,
|
||||||
|
});
|
||||||
|
const allRoomsClasses = classNames("mx_SearchBar_button", {
|
||||||
|
mx_SearchBar_unselected: this.state.scope !== SearchScope.All,
|
||||||
|
});
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<div className="mx_SearchBar">
|
||||||
|
<div className="mx_SearchBar_buttons" role="radiogroup">
|
||||||
|
<AccessibleButton
|
||||||
|
className={thisRoomClasses}
|
||||||
|
onClick={this.onThisRoomClick}
|
||||||
|
aria-checked={this.state.scope === SearchScope.Room}
|
||||||
|
role="radio"
|
||||||
|
>
|
||||||
|
{_t("This Room")}
|
||||||
|
</AccessibleButton>
|
||||||
|
<AccessibleButton
|
||||||
|
className={allRoomsClasses}
|
||||||
|
onClick={this.onAllRoomsClick}
|
||||||
|
aria-checked={this.state.scope === SearchScope.All}
|
||||||
|
role="radio"
|
||||||
|
>
|
||||||
|
{_t("All Rooms")}
|
||||||
|
</AccessibleButton>
|
||||||
|
</div>
|
||||||
|
<div className="mx_SearchBar_input mx_textinput">
|
||||||
|
<input
|
||||||
|
ref={this.searchTerm}
|
||||||
|
type="text"
|
||||||
|
autoFocus={true}
|
||||||
|
placeholder={_t("Search…")}
|
||||||
|
onKeyDown={this.onSearchChange}
|
||||||
|
/>
|
||||||
|
<AccessibleButton className={ searchButtonClasses } onClick={this.onSearch} />
|
||||||
|
</div>
|
||||||
|
<AccessibleButton className="mx_SearchBar_cancel" onClick={this.props.onCancelClick} />
|
||||||
|
</div>
|
||||||
|
<DesktopBuildsNotice isRoomEncrypted={this.props.isRoomEncrypted} kind={WarningKind.Search} />
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1933,6 +1933,7 @@
|
||||||
"Error loading Widget": "Error loading Widget",
|
"Error loading Widget": "Error loading Widget",
|
||||||
"Error - Mixed content": "Error - Mixed content",
|
"Error - Mixed content": "Error - Mixed content",
|
||||||
"Popout widget": "Popout widget",
|
"Popout widget": "Popout widget",
|
||||||
|
"Message search initialisation failed, check <a>your settings</a> for more information": "Message search initialisation failed, check <a>your settings</a> for more information",
|
||||||
"Use the <a>Desktop app</a> to see all encrypted files": "Use the <a>Desktop app</a> to see all encrypted files",
|
"Use the <a>Desktop app</a> to see all encrypted files": "Use the <a>Desktop app</a> to see all encrypted files",
|
||||||
"Use the <a>Desktop app</a> to search encrypted messages": "Use the <a>Desktop app</a> to search encrypted messages",
|
"Use the <a>Desktop app</a> to search encrypted messages": "Use the <a>Desktop app</a> to search encrypted messages",
|
||||||
"This version of %(brand)s does not support viewing some encrypted files": "This version of %(brand)s does not support viewing some encrypted files",
|
"This version of %(brand)s does not support viewing some encrypted files": "This version of %(brand)s does not support viewing some encrypted files",
|
||||||
|
|
Loading…
Reference in a new issue