Skip to content

Commit

Permalink
refactor: enable no-unsafe-call rule (@Miodec) (#5883)
Browse files Browse the repository at this point in the history
### Description

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

### Checks

- [ ] 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 or a theme?
- [ ] If is a language, did you edit `_list.json`, `_groups.json` and
add `languages.json`?
  - [ ] If is a theme, did you add the theme.css?
- Also please add a screenshot of the theme, it would be extra awesome
if you do so!
- [ ] Check if any open issues are related to this PR; if so, be sure to
tag them below.
- [ ] Make sure the PR title follows the Conventional Commits standard.
(https://www.conventionalcommits.org for more info)
- [ ] 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](#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! :) -->
  • Loading branch information
Miodec authored Sep 13, 2024
1 parent 84166ce commit ceedf8a
Show file tree
Hide file tree
Showing 17 changed files with 48 additions and 27 deletions.
2 changes: 1 addition & 1 deletion backend/src/api/controllers/dev.ts
Original file line number Diff line number Diff line change
Expand Up @@ -241,7 +241,7 @@ async function updateUser(uid: string): Promise<void> {
timestamp: best.timestamp,
} as PersonalBest;

personalBests[mode.mode][mode.mode2].push(entry);
(personalBests[mode.mode][mode.mode2] as PersonalBest[]).push(entry);

if (mode.mode === "time") {
if (lbPersonalBests[mode.mode][mode.mode2] === undefined)
Expand Down
4 changes: 2 additions & 2 deletions backend/src/dal/new-quotes.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { simpleGit } from "simple-git";
import { SimpleGit, simpleGit } from "simple-git";
import { Collection, ObjectId } from "mongodb";
import path from "path";
import { existsSync, writeFileSync } from "fs";
Expand All @@ -24,7 +24,7 @@ type QuoteData = {

const PATH_TO_REPO = "../../../../monkeytype-new-quotes";

let git;
let git: SimpleGit | undefined;
try {
git = simpleGit(path.join(__dirname, PATH_TO_REPO));
} catch (e) {
Expand Down
6 changes: 4 additions & 2 deletions backend/src/services/weekly-xp-leaderboard.ts
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,8 @@ export class WeeklyXpLeaderboard {
timeTypedSeconds + (currentEntryTimeTypedSeconds ?? 0);

const [rank] = await Promise.all([
// @ts-expect-error
// @ts-expect-error we are doing some weird file to function mapping, thats why its any
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
connection.addResultIncrement(
2,
weeklyXpLeaderboardScoresKey,
Expand Down Expand Up @@ -128,7 +129,8 @@ export class WeeklyXpLeaderboard {
const { weeklyXpLeaderboardScoresKey, weeklyXpLeaderboardResultsKey } =
this.getThisWeeksXpLeaderboardKeys();

// @ts-expect-error
// @ts-expect-error we are doing some weird file to function mapping, thats why its any
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
const [results, scores] = (await connection.getResults(
2, // How many of the arguments are redis keys (https://redis.io/docs/manual/programmability/lua-api/)
weeklyXpLeaderboardScoresKey,
Expand Down
9 changes: 6 additions & 3 deletions backend/src/utils/daily-leaderboards.ts
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,8 @@ export class DailyLeaderboard {

const resultScore = kogascore(entry.wpm, entry.acc, entry.timestamp);

// @ts-expect-error
// @ts-expect-error we are doing some weird file to function mapping, thats why its any
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
const rank = (await connection.addResult(
2,
leaderboardScoresKey,
Expand Down Expand Up @@ -120,7 +121,8 @@ export class DailyLeaderboard {
const { leaderboardScoresKey, leaderboardResultsKey } =
this.getTodaysLeaderboardKeys();

// @ts-expect-error
// @ts-expect-error we are doing some weird file to function mapping, thats why its any
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
const [results] = (await connection.getResults(
2,
leaderboardScoresKey,
Expand Down Expand Up @@ -213,7 +215,8 @@ export async function purgeUserFromDailyLeaderboards(
return;
}

// @ts-expect-error
// @ts-expect-error we are doing some weird file to function mapping, thats why its any
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
await connection.purgeResults(0, uid, dailyLeaderboardNamespace);
}

Expand Down
20 changes: 11 additions & 9 deletions backend/src/utils/pb.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ export function checkAndUpdatePb(
const didUpdate = updatePersonalBest(personalBestMatch, result);
isPb = didUpdate;
} else {
userPb[mode][mode2].push(buildPersonalBest(result));
(userPb[mode][mode2] as PersonalBest[]).push(buildPersonalBest(result));
}

if (!_.isNil(lbPersonalBests)) {
Expand Down Expand Up @@ -186,15 +186,17 @@ export function updateLeaderboardPersonalBests(
lbPb[mode] ??= {};
lbPb[mode][mode2] ??= {};
const bestForEveryLanguage = {};
userPersonalBests[mode][mode2].forEach((pb: PersonalBest) => {
const language = pb.language;
if (
bestForEveryLanguage[language] === undefined ||
bestForEveryLanguage[language].wpm < pb.wpm
) {
bestForEveryLanguage[language] = pb;
(userPersonalBests[mode][mode2] as PersonalBest[]).forEach(
(pb: PersonalBest) => {
const language = pb.language;
if (
bestForEveryLanguage[language] === undefined ||
bestForEveryLanguage[language].wpm < pb.wpm
) {
bestForEveryLanguage[language] = pb;
}
}
});
);
_.each(bestForEveryLanguage, (pb: PersonalBest, language: string) => {
const languageDoesNotExist = lbPb[mode][mode2][language] === undefined;
const languageIsEmpty = _.isEmpty(lbPb[mode][mode2][language]);
Expand Down
3 changes: 3 additions & 0 deletions frontend/src/ts/controllers/ad-controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,7 @@ export async function checkCookieblocker(): Promise<void> {
return;
}
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
window.__tcfapi("getTCData", 2, (tcData, success) => {
if (success as boolean) {
if (tcData.eventStatus === "cmpuishown") {
Expand Down Expand Up @@ -268,11 +269,13 @@ export function updateFooterAndVerticalAds(visible: boolean): void {
export function showConsentPopup(): void {
if (choice === "eg") {
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
window.__tcfapi("displayConsentUi", 2, function () {
//
});
} else {
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
ramp.showCmpModal();
}
}
Expand Down
5 changes: 3 additions & 2 deletions frontend/src/ts/controllers/captcha-controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ export function render(
}

//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call
const widgetId = grecaptcha.render(element, {
sitekey: siteKey,
callback,
Expand All @@ -28,6 +28,7 @@ export function reset(id: string): void {
}

//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
grecaptcha.reset(captchas[id]);
}

Expand All @@ -37,6 +38,6 @@ export function getResponse(id: string): string {
}

//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
// eslint-disable-next-line @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-call
return grecaptcha.getResponse(captchas[id]);
}
3 changes: 3 additions & 0 deletions frontend/src/ts/controllers/eg-ad-controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ export function init(): void {
export function renderResult(widerThanBreakpoint: boolean): void {
if (widerThanBreakpoint) {
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
window.egAps.render([
"ad-result",
"ad-vertical-left",
Expand All @@ -23,6 +24,7 @@ export function renderResult(widerThanBreakpoint: boolean): void {
]);
} else {
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
window.egAps.render([
"ad-result-small",
"ad-vertical-left",
Expand All @@ -35,6 +37,7 @@ export function renderResult(widerThanBreakpoint: boolean): void {
export function reinstate(): boolean {
try {
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
window.egAps.reinstate();
return true;
} catch (e) {
Expand Down
1 change: 1 addition & 0 deletions frontend/src/ts/controllers/pw-ad-controller.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
/* eslint-disable @typescript-eslint/no-unsafe-call */
//@ts-nocheck

import Config from "../config";
Expand Down
6 changes: 2 additions & 4 deletions frontend/src/ts/controllers/sound-controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -412,10 +412,8 @@ export async function previewError(val: string): Promise<void> {
const errorSoundIds = Object.keys(safeErrorSounds);
if (!errorSoundIds.includes(val)) return;

//@ts-expect-error
errorClickSounds[val][0].sounds[0].seek(0);
//@ts-expect-error
errorClickSounds[val][0].sounds[0].play();
errorSounds?.[val]?.[0]?.sounds[0]?.seek(0);
errorSounds?.[val]?.[0]?.sounds[0]?.play();
}

let currentCode = "KeyA";
Expand Down
4 changes: 4 additions & 0 deletions frontend/src/ts/elements/test-activity.ts
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,7 @@ export function initYearSelector(
const yearSelect = getYearSelector();
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
yearSelect.setData(years);
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
years.length > 1 ? yearSelect.enable() : yearSelect.disable();
}

Expand All @@ -108,11 +109,14 @@ function getYearSelector(): SlimSelect {
},
events: {
afterChange: async (newVal): Promise<void> => {
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
yearSelector?.disable();
const selected = newVal[0]?.value as string;
const activity = await getTestActivityCalendar(selected);
update(activity);
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
if ((yearSelector?.getData() ?? []).length > 1) {
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
yearSelector?.enable();
}
},
Expand Down
1 change: 1 addition & 0 deletions frontend/src/ts/pages/settings.ts
Original file line number Diff line number Diff line change
Expand Up @@ -426,6 +426,7 @@ function reset(): void {
$(".pageSettings .section[data-config-name='fontFamily'] .buttons").empty();
for (const select of document.querySelectorAll(".pageSettings select")) {
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
select?.slim?.destroy?.();
}
}
Expand Down
1 change: 1 addition & 0 deletions frontend/src/ts/popups/video-ad-popup.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ export async function show(): Promise<void> {
.removeClass("hidden")
.animate({ opacity: 1 }, 125, () => {
//@ts-expect-error
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
window.dataLayer.push({ event: "EG_Video" });
});
}
Expand Down
2 changes: 2 additions & 0 deletions frontend/src/ts/ready.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ $((): void => {
}
MonkeyPower.init();

// untyped, need to ignore
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
new Konami("https://keymash.io/");

if (Misc.isDevEnvironment()) {
Expand Down
4 changes: 2 additions & 2 deletions frontend/src/ts/test/british-english.ts
Original file line number Diff line number Diff line change
Expand Up @@ -46,8 +46,8 @@ export async function replace(
RegExp(`^(?:([\\W]*)(${replacement[0]})([\\W]*))$`, "gi"),
(_, $1, $2, $3) =>
$1 +
($2.charAt(0) === $2.charAt(0).toUpperCase()
? $2 === $2.toUpperCase()
(($2 as string).charAt(0) === ($2 as string).charAt(0).toUpperCase()
? $2 === ($2 as string).toUpperCase()
? replacement[1].toUpperCase()
: capitalizeFirstLetterOfEachWord(replacement[1])
: replacement[1]) +
Expand Down
2 changes: 1 addition & 1 deletion frontend/src/ts/test/english-punctuation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ export async function replace(word: string): Promise<string> {
RegExp(`^(?:([\\W]*)(${replacement[0]})([\\W]*))$`, "gi"),
(_, $1, $2, $3) =>
$1 +
($2.charAt(0) === $2.charAt(0).toUpperCase()
(($2 as string).charAt(0) === ($2 as string).charAt(0).toUpperCase()
? shouldWholeReplacementWordBeCapitalised($2 as string)
? randomReplacement.toUpperCase()
: capitalizeFirstLetterOfEachWord(randomReplacement)
Expand Down
2 changes: 1 addition & 1 deletion packages/eslint-config/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,10 +80,10 @@ module.exports = {
"@typescript-eslint/restrict-plus-operands": "off",

// TODO: enable at some point
"@typescript-eslint/no-unsafe-call": "off", //~76
"@typescript-eslint/no-unsafe-member-access": "off", //~105
//

"@typescript-eslint/no-unsafe-call": "error",
"@typescript-eslint/no-unsafe-argument": "error",
"@typescript-eslint/no-unsafe-assignment": "error",
"@typescript-eslint/no-unnecessary-type-assertion": "error",
Expand Down

0 comments on commit ceedf8a

Please sign in to comment.