From c87ea672b05afb51dc2cb2c5b23b9d18df700625 Mon Sep 17 00:00:00 2001 From: Jonatan Heyman Date: Fri, 3 Jan 2025 15:43:17 +0100 Subject: [PATCH] Make language selector also search through the languages' filename suffixes (using the guesslang attribute) This makes the "cpp" string match C++, and "cs" match C#. --- src/components/LanguageSelector.vue | 8 +++++--- tests/language-selector.spec.js | 16 ++++++++++++++++ 2 files changed, 21 insertions(+), 3 deletions(-) create mode 100644 tests/language-selector.spec.js diff --git a/src/components/LanguageSelector.vue b/src/components/LanguageSelector.vue index b579ef2a..cc08107c 100644 --- a/src/components/LanguageSelector.vue +++ b/src/components/LanguageSelector.vue @@ -5,7 +5,8 @@ const items = LANGUAGES.map(l => { return { "token": l.token, - "name": l.name + "name": l.name, + "guesslang": l.guesslang, } }).sort((a, b) => { return a.name.localeCompare(b.name) @@ -35,12 +36,13 @@ return items } const searchResults = fuzzysort.go(this.filter, items, { - keys: ['name'], + keys: ['name', 'guesslang'], }) return searchResults.map(result => { + const highlight = result[0].highlight("", "") return { "token": result.obj.token, - "name": result[0].highlight("", "") + "name": highlight || result.obj.name, } }) }, diff --git a/tests/language-selector.spec.js b/tests/language-selector.spec.js new file mode 100644 index 00000000..96397a56 --- /dev/null +++ b/tests/language-selector.spec.js @@ -0,0 +1,16 @@ +import { test, expect } from "@playwright/test"; +import { HeynotePage } from "./test-utils.js"; + +let heynotePage + +test.beforeEach(async ({ page }) => { + heynotePage = new HeynotePage(page) + await heynotePage.goto() +}) + + +test("test language selector search by file ending", async ({ page }) => { + await page.locator("body").press(heynotePage.agnosticKey("Mod+L")) + await page.locator("body").pressSequentially("cpp") + await expect(page.locator("css=.language-selector .items > li.selected")).toHaveText("C++") +})