Commit graph

12526 commits

Author SHA1 Message Date
Francis Eugene Casibu
d6572cce41 refactor: remove jquery in modals/edit-result-tags 2025-12-25 21:25:14 +08:00
Francis Eugene Casibu
56a8e6b3b6 refactor: remove jquery in modals/edit-profile 2025-12-25 21:07:48 +08:00
Francis Eugene Casibu
966db65f67 refactor: remove jquery in modals/edit-preset 2025-12-25 20:20:04 +08:00
Francis Eugene Casibu
d0997c2bf5 refactor: remove jquery in modals/dev-options 2025-12-25 20:17:42 +08:00
Francis Eugene Casibu
fe272d1726 refactor: remove jquery in modals/custom-text 2025-12-25 20:17:42 +08:00
Francis Eugene Casibu
d31b39f135 feature: add setValue method in ElementsWithUtils 2025-12-25 17:50:44 +08:00
Francis Eugene Casibu
524c4a9c08 refactor: remove jquery in modals/custom-test-duration 2025-12-25 16:29:51 +08:00
Francis Eugene Casibu
491e6ffcad refactor: remove jquery in modals/custom-generator 2025-12-25 15:55:05 +08:00
Leonabcd123
5d169e933a
refactor: remove JQuery from pages directory (@Leonabcd123) (#7237)
- [x] 404
- [x] about
- [x] account-settings
- [x] account
- [x] friends
- [x] leaderboards
- [x] loading
- [x] login
- [x] page
- [x] profile-search
- [x] profile
- [x] settings
- [x] test

Before merging make sure to load every changed page to check for the qsa
notification.

---------

Co-authored-by: Christian Fehmer <fehmer@users.noreply.github.com>
2025-12-21 16:24:07 +01:00
Seif Soliman
fd177c9ed4
chore: TypeError when deleting in zen (@byseif21) (#7282)
* fix error from race condition `Cannot read properties of null (reading
'remove')` when deletion in zen mode, added null check.

The active word could already be removed when the debounced update runs,
which caused a null error

---------

Co-authored-by: Jack <jack@monkeytype.com>
2025-12-21 11:50:10 +01:00
Miodec
a1240d3d7e refactor: clean up zen mode element removal 2025-12-21 11:28:26 +01:00
Jack
16b4ec88af
impr: add reset function to promiseWithResolvers (@miodec) (#7280)
Actual AI slop but if it works ?????

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-12-21 10:56:50 +01:00
Christian Fehmer
ef5ef0c427
feat(commandline): add sign out (@fehmer) (#7283) 2025-12-21 10:54:24 +01:00
Miodec
d11bdaa710 refactor: result saving code flow 2025-12-20 18:09:49 +01:00
Miodec
58b6162b11 chore: missing setInvalid calls 2025-12-20 18:09:49 +01:00
Miodec
11c2bff300 chore: reorder 2025-12-20 18:09:49 +01:00
Miodec
4fae28c0f6 chore: move result code to result file 2025-12-20 18:09:49 +01:00
Miodec
5f50628110 chore: remove unnecessary code 2025-12-20 18:09:49 +01:00
Miodec
2cba7576bd chore: move ui code to result 2025-12-20 18:09:49 +01:00
Miodec
1f4e616d74 refactor: move code around 2025-12-20 18:09:49 +01:00
Miodec
10f4a13c1f chore: move ui code out of the test-logic file 2025-12-20 18:09:49 +01:00
Christian Fehmer
dd2ec8c6b9
fix: dom-utils onChild calling handler for elements outside the parent (@fehmer) (#7279) 2025-12-20 17:17:09 +01:00
Christian Fehmer
bd3cd75c94
refactor: add currentTarget back to regular listeners, add childTarget to onChild listeners (@fehmer) (#7273)
rework `onChild` to behave mostly like jQuery `.on` with selector.

- we remove `currentTarget` from the `onChild` event handler because
native events and jQuery events have different values for it
- the jQuery `currentTarget` is available with `childTarget` in our
events

---------

Co-authored-by: Miodec <jack@monkeytype.com>
2025-12-20 13:41:11 +01:00
Miodec
86ed9c2570 chore: ignore pnpm-lock 2025-12-20 11:05:27 +01:00
Arjun
1e2109bf60
impr(quotes): Add English quotes from XCOM: EU (@Zeden19) (#7264)
### Description

<!-- Please describe the change(s) made in your PR -->

### Checks

- [ ] Adding/modifying Typescript code?
  - [ ] I have used `qs`, `qsa` or `qsr` instead of JQuery selectors.
- [X] Adding quotes?
- [ ] Make sure to include translations for the quotes in the
description (or another comment) so we can verify their content.
- [ ] Adding a language?
- Make sure to follow the [languages
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/LANGUAGES.md)
  - [ ] Add language to `packages/schemas/src/languages.ts`
- [ ] Add language to exactly one group in
`frontend/src/ts/constants/languages.ts`
  - [ ] Add language json file to `frontend/static/languages` 
- [ ] Adding a theme?
- Make sure to follow the [themes
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/THEMES.md)
  - [ ] Add theme to `packages/schemas/src/themes.ts`
  - [ ] Add theme to `frontend/src/ts/constants/themes.ts`
  - [ ] Add theme css file to `frontend/static/themes`
- [ ] Add some screenshots of the theme, especially with different test
settings (colorful, flip colors) to your pull request
- [ ] Adding a layout?
- [ ] Make sure to follow the [layouts
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/LAYOUTS.md)
  - [ ] Add layout to `packages/schemas/src/layouts.ts`
  - [ ] Add layout json file to `frontend/static/layouts` 
- [ ] Adding a font?
- Make sure to follow the [themes
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/FONTS.md)
  - [ ] Add font file  to `frontend/static/webfonts`
  - [ ] Add font to `packages/schemas/src/fonts.ts`
  - [ ] Add font to `frontend/src/ts/constants/fonts.ts`
- [X] Check if any open issues are related to this PR; if so, be sure to
tag them below.
- [X] Make sure the PR title follows the Conventional Commits standard.
(https://www.conventionalcommits.org for more info)
- [X] Make sure to include your GitHub username prefixed with @ inside
parentheses at the end of the PR title.

<!-- label(optional scope): pull request title (@your_github_username)
-->

<!-- I know I know they seem boring but please do them, they help us and
you will find out it also helps you.-->

Closes #

<!-- the issue(s) your PR resolves if any (delete if that is not the
case) -->
<!-- please also reference any issues and or PRs related to your pull
request -->
<!-- Also remove it if you are not following any issues. -->

<!-- pro tip: you can mention an issue, PR, or discussion on GitHub by
referencing its hash number e.g:
[#1234](https://github.com/monkeytypegame/monkeytype/pull/1234) -->

<!-- pro tip: you can press . (dot or period) in the code tab of any
GitHub repo to get access to GitHub's VS Code web editor Enjoy! :) -->
2025-12-20 11:04:34 +01:00
Alex Rusbridge
5093dbe128
fix(british-english): adds british english spelling for english-medical.json (@AlexRusbridge) (#7278)
### Description

Adds British English spelling for words found in the english-medical
word list.

- Hematology terms (`hemo-`/`hema-` -> `haemo-`/`haema-`)
- Blood condition suffixes (`-emia` -> `-aemia`)
- White blood cell terms (`leuko-` -> `leuco-`)
- Respiratory terms (`-pnea` -> `-pnoea`)
- Other notable conversions (common patterns like `-ize` and other
cases)

### Checks

- [ ] ~Adding/modifying Typescript code?~
- [ ] ~Adding quotes?comment) so we can verify their content.~
- [ ] ~Adding a language?~
- [ ] ~Adding a theme?~
- [ ] ~Adding a layout?~
- [ ] ~Adding a font?~
- [x] Check if any open issues are related to this PR; if so, be sure to
tag them below.
- [x] Make sure the PR title follows the Conventional Commits standard.
(https://www.conventionalcommits.org for more info)
- [x] Make sure to include your GitHub username prefixed with @ inside
parentheses at the end of the PR title.

---------

Co-authored-by: Jack <jack@monkeytype.com>
2025-12-20 10:15:55 +01:00
Leonabcd123
8148b05dd6
fix(preset): Fix qsa warning on preset modal (@Leonabcd123) (#7277)
### Description

Use a more specific selector.
2025-12-19 23:40:48 +01:00
Jack
eb92e1af0d
impr: replace vite-plugin-checker with ~~vibe~~ (@miodec) (#7271)
vite plugin checker seems to happily spawn a new linting process per
file save, causing issues. This vibe coded solution kills the previously
running process. It also splits linting into two steps to get some fast
fail behavior.

I (AI) tried to merge it into one file but the overlay refused to show
that way.

!nuf
---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-12-19 22:29:56 +01:00
Leonabcd123
47712857f9
fix(blind-mode): make blind mode "on" text invisible (@Leonabcd123) (#7274)
### Description

Use `&ensp;` instead of the current, visible character.
2025-12-19 19:42:51 +01:00
Christian Fehmer
65e490c961
chore: use innerText on generate data modal (@fehmer) (#7276) 2025-12-19 19:42:34 +01:00
Leonabcd123
805c7ae7d9
fix(hide-extra-letters): extra letters with hideExtraLetters enabled causing caret problems (@Leonabcd123) (#7272)
### Description

Same solution as  #7254
2025-12-19 17:00:02 +01:00
Christian Fehmer
ca9dac17a7
refactor: remove currentTarget from dom-utils event handlers (@fehmer) (#7270) 2025-12-19 12:55:16 +01:00
Miodec
96e30b141e chore: bump oxc packages 2025-12-19 09:56:37 +01:00
Christian Fehmer
8a2a3e4d23
impr: add copy details to notification history (@fehmer) (#7262)
Add details to notifications.

If details are available show share icon on hover in the notification
history. On click the full content is copied to the clipboard. With this
is easier for an user to share the full details of an error on github or
discord.

<img width="377" height="107" alt="image"
src="https://github.com/user-attachments/assets/f22638a1-bafd-4708-8d8a-0ec48db10f1d"
/>

<img width="377" height="107" alt="image"
src="https://github.com/user-attachments/assets/d4a66860-f99f-4ac1-992c-81e31ab13eba"
/>



```json
{
    "title": "Error",
    "message": "Failed to save config",
    "details": {
        "status": 422,
        "validationErrors": [
            "Unrecognized key(s) in object: 'invalid'"
        ]
    }
}
```

---------

Co-authored-by: Jack <jack@monkeytype.com>
2025-12-18 19:27:24 +01:00
Miodec
484ab1bd5f chore: remove jquery from toggleSettingsGroup 2025-12-18 19:21:40 +01:00
Leonabcd123
9d709c7c7c
impr(quote search): add exact search quotes (@Leonabcd123) (#7261)
### Description

Make text wrapped in `""` required when searching for quotes (meaning
only quotes that contain this exact text will appear in the results).
This allows case insensitivity (so "hello" will match "Hello").
2025-12-18 17:22:44 +01:00
Miodec
8d1eefc5ba fix: account icon alignment when not using an avatar 2025-12-18 16:36:12 +01:00
Md Moushuf Alam
9e93af465f
refactor: replace jQuery with DOM utils for alt and shift key trackers (@MoushufAlam) (#7266)
### Description
Replaces jQuery usage with DOM utils for alt and shift key trackers.
Scope intentionally kept small per contributing guidelines.


### Checks

- [x] Adding/modifying Typescript code?
  - [x] I have used `qs`, `qsa` or `qsr` instead of JQuery selectors.
- [x] Check if any open issues are related to this PR; if so, be sure to
tag them below.
- [x] Make sure the PR title follows the Conventional Commits standard.
(https://www.conventionalcommits.org for more info)
- [x] Make sure to include your GitHub username prefixed with @ inside
parentheses at the end of the PR title.

<!-- label(optional scope): pull request title (@your_github_username)
-->

<!-- I know I know they seem boring but please do them, they help us and
you will find out it also helps you.-->

Related to #7186 

<!-- the issue(s) your PR resolves if any (delete if that is not the
case) -->
<!-- please also reference any issues and or PRs related to your pull
request -->
<!-- Also remove it if you are not following any issues. -->

<!-- pro tip: you can mention an issue, PR, or discussion on GitHub by
referencing its hash number e.g:
[#1234](https://github.com/monkeytypegame/monkeytype/pull/1234) -->

<!-- pro tip: you can press . (dot or period) in the code tab of any
GitHub repo to get access to GitHub's VS Code web editor Enjoy! :) -->
2025-12-18 11:43:47 +01:00
Md Moushuf Alam
d6a6dad552
refactor: replace jQuery with DOM utils in caps lock warning (@MoushufAlam) (#7265)
### Description

Replaces jQuery usage with DOM utils for the caps lock warning.
Scope intentionally kept small per contributing guidelines.

### Checks

- [x] Adding/modifying Typescript code?
  - [x] I have used `qs`, `qsa` or `qsr` instead of JQuery selectors.
- [x] Check if any open issues are related to this PR; if so, be sure to
tag them below.
- [x] Make sure the PR title follows the Conventional Commits standard.
(https://www.conventionalcommits.org for more info)
- [x] Make sure to include your GitHub username prefixed with @ inside
parentheses at the end of the PR title.

<!-- label(optional scope): pull request title (@your_github_username)
-->

<!-- I know I know they seem boring but please do them, they help us and
you will find out it also helps you.-->
Related to #7186 
<!-- the issue(s) your PR resolves if any (delete if that is not the
case) -->
<!-- please also reference any issues and or PRs related to your pull
request -->
<!-- Also remove it if you are not following any issues. -->

<!-- pro tip: you can mention an issue, PR, or discussion on GitHub by
referencing its hash number e.g:
[#1234](https://github.com/monkeytypegame/monkeytype/pull/1234) -->

<!-- pro tip: you can press . (dot or period) in the code tab of any
GitHub repo to get access to GitHub's VS Code web editor Enjoy! :) -->
2025-12-18 09:51:07 +01:00
Miodec
c222098a05 fix: previous commit nuking the timer 2025-12-17 20:53:40 +01:00
Seif Soliman
0e5dd85db2
fix(lazy-mode): respect manual toggle after unsupported language (@byseif21) (#7260)
### Description

* lazy mode status “stuck” after switching to a language that does not
support it then goes back to the one that supports it.


* to reproduce
After seeing the “This language does not support lazy mode” warning,
switch back to the one that was working with and manually toggling lazy
mode. It would not update to the selected option.
2025-12-17 20:41:55 +01:00
Miodec
bd9951931e fix: timer resetting to initial value when test finishes
closes #7263
2025-12-17 20:30:16 +01:00
100daysummer
74bafad7d5
impr(language): add bulgarian 1k (@100daysummer) (#7232)
### Description

This commit expands the two bulgarian wordlists - bulgarian.json and
bulgarian_latin.json

### Checks

- [ ] Adding/modifying Typescript code?
  - [ ] I have used `qs`,`qsa` or `qsr` instead of JQuery selectors.
- [ ] Adding quotes?
- [ ] Make sure to include translations for the quotes in the
description (or another comment) so we can verify their content.
- [x] Adding a language?
- Make sure to follow the [languages
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/LANGUAGES.md)
  - [x] Add language to `packages/schemas/src/languages.ts`
- [x] Add language to exactly one group in
`frontend/src/ts/constants/languages.ts`
  - [x] Add language json file to `frontend/static/languages` 
- [ ] Adding a theme?
- Make sure to follow the [themes
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/THEMES.md)
  - [ ] Add theme to `packages/schemas/src/themes.ts`
  - [ ] Add theme to `frontend/src/ts/constants/themes.ts`
  - [ ] Add theme css file to `frontend/static/themes`
- [ ] Add some screenshot of the theme, especially with different test
settings (colorful, flip colors) to your pull request
- [ ] Adding a layout?
- [ ] Make sure to follow the [layouts
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/LAYOUTS.md)
  - [ ] Add layout to `packages/schemas/src/layouts.ts`
  - [ ] Add layout json file to `frontend/static/layouts` 
- [ ] Adding a font?
- Make sure to follow the [themes
documentation](https://github.com/monkeytypegame/monkeytype/blob/master/docs/FONTS.md)
  - [ ] Add font file  to `frontend/static/webfonts`
  - [ ] Add font to `packages/schemas/src/fonts.ts`
  - [ ] Add font to `frontend/src/ts/constants/fonts.ts`
- [ ] Check if any open issues are related to this PR; if so, be sure to
tag them below.
- [x] Make sure the PR title follows the Conventional Commits standard.
(https://www.conventionalcommits.org for more info)
- [x] Make sure to include your GitHub username prefixed with @ inside
parentheses at the end of the PR title.

---------

Co-authored-by: Jack <jack@monkeytype.com>
2025-12-17 19:32:49 +01:00
Md Moushuf Alam
97b9085f7e
refactor: replace jquery with dom utils in scroll-to-top button (@MoushufAlam) (#7257)
### Description

Replaces jQuery usage with dom utils in the scroll-to-top button.
Scope intentionally kept small per contributing guidelines.

### Checks

- [x] Adding/modifying Typescript code?
  - [x] I have used `qs`, `qsa` or `qsr` instead of JQuery selectors.
- [x] Check if any open issues are related to this PR; if so, be sure to
tag them below.
- [x] Make sure the PR title follows the Conventional Commits standard.
(https://www.conventionalcommits.org for more info)
- [x] Make sure to include your GitHub username prefixed with @ inside
parentheses at the end of the PR title.

<!-- label(optional scope): pull request title (@your_github_username)
-->

<!-- I know I know they seem boring but please do them, they help us and
you will find out it also helps you.-->

Related to #7186

<!-- the issue(s) your PR resolves if any (delete if that is not the
case) -->
<!-- please also reference any issues and or PRs related to your pull
request -->
<!-- Also remove it if you are not following any issues. -->

<!-- pro tip: you can mention an issue, PR, or discussion on GitHub by
referencing its hash number e.g:
[#1234](https://github.com/monkeytypegame/monkeytype/pull/1234) -->

<!-- pro tip: you can press . (dot or period) in the code tab of any
GitHub repo to get access to GitHub's VS Code web editor Enjoy! :) -->
2025-12-17 19:19:43 +01:00
Seif Soliman
96169a149e
fix(caret): align caret correctly in RTL tape mode (@byseif21) (#7259)
* In RTL tests, enabling tape mode causes the main caret to be
misaligned from the start of the test and remain offset while typing.
The tape margin was always calculated from the left side, which is
correct for LTR but incorrect for RTL layouts.

fix

* we should have mirrored the margin from the right side.
2025-12-17 19:18:46 +01:00
Christian Fehmer
3f21023fc1
chore: update vitest/testcontainer versions, try to fix container teardown on macos (@fehmer) (#7248)
Co-authored-by: Miodec <jack@monkeytype.com>
2025-12-16 18:11:55 +01:00
Leonabcd123
71e78cd52d
docs: improve language in pull request template (@Leonabcd123) (#7252) 2025-12-16 17:55:27 +01:00
Miodec
d990b42c1e chore: update contributors list 2025-12-16 17:50:03 +01:00
Leonabcd123
b7c06d1ddc
fix(blind mode): Extra letters in blind mode causing caret problems (@Leonabcd123) (#7254)
### Description

- Enable blind mode
- Write extra letters
- Caret will jump to above the first letter in the word
2025-12-16 17:47:38 +01:00
Christian Fehmer
36b59ae8ee
impr: add multiple elements found warning in dom utils (@fehmer) (#7242)
Co-authored-by: Miodec <jack@monkeytype.com>
2025-12-16 12:30:25 +01:00