mirror of
https://github.com/vector-im/element-web.git
synced 2024-11-16 05:04:57 +08:00
739eec8555
* fix matrix search link * fix matrix search link Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search on new search feature Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * add review changes * Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> added review correction changed the transformSearchTerm function to use parsePermaLink removed extra spaces * add angle brackets to copyright email title * removed extra space Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * Update src/utils/SearchInput.ts Co-authored-by: Travis Ralston <travpc@gmail.com> * fixed spolight dialog search for room and user links * added tests for transformSearchTerm * removed transformSearchTerm from room search bar * replaces two test cases to one that should return the primaryEntityId if the search term was a permalink * corrected ts issues * changed type of transformSearchTerm to string * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * refactored transformSearchTerm and added a new test case * rewrote transformSearchTerm doc * changed mocked return values of test case - should return the original search term if the search term is a permalink and the primaryEntityId is null * lint corrections --------- Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> Co-authored-by: Boluwatife Omosowon <boluwatifeomosowon@Jesus-Loves-You.local> Co-authored-by: Travis Ralston <travpc@gmail.com>
61 lines
2.1 KiB
TypeScript
61 lines
2.1 KiB
TypeScript
/*
|
|
Copyright 2023 Boluwatife Omosowon <boluomosowon@gmail.com>
|
|
|
|
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 { mocked } from "jest-mock";
|
|
|
|
import { parsePermalink } from "../../src/utils/permalinks/Permalinks";
|
|
import { transformSearchTerm } from "../../src/utils/SearchInput";
|
|
|
|
jest.mock("../../src/utils/permalinks/Permalinks");
|
|
|
|
describe("transforming search term", () => {
|
|
it("should return the primaryEntityId if the search term was a permalink", () => {
|
|
const roomLink = "https://matrix.to/#/#element-dev:matrix.org";
|
|
const parsedPermalink = "#element-dev:matrix.org";
|
|
|
|
mocked(parsePermalink).mockReturnValue({
|
|
primaryEntityId: parsedPermalink,
|
|
roomIdOrAlias: parsedPermalink,
|
|
eventId: "",
|
|
userId: "",
|
|
viaServers: [],
|
|
sigil: "",
|
|
});
|
|
|
|
expect(transformSearchTerm(roomLink)).toBe(parsedPermalink);
|
|
});
|
|
|
|
it("should return the original search term if the search term is a permalink and the primaryEntityId is null", () => {
|
|
const searchTerm = "https://matrix.to/#/#random-link:matrix.org";
|
|
|
|
mocked(parsePermalink).mockReturnValue({
|
|
primaryEntityId: null,
|
|
roomIdOrAlias: null,
|
|
eventId: null,
|
|
userId: null,
|
|
viaServers: null,
|
|
sigil: "?",
|
|
});
|
|
|
|
expect(transformSearchTerm(searchTerm)).toBe(searchTerm);
|
|
});
|
|
|
|
it("should return the original search term if the search term was not a permalink", () => {
|
|
const searchTerm = "search term";
|
|
mocked(parsePermalink).mockReturnValue(null);
|
|
expect(transformSearchTerm(searchTerm)).toBe(searchTerm);
|
|
});
|
|
});
|