Skip to content

Commit

Permalink
fix remaining test by doing some upgrades
Browse files Browse the repository at this point in the history
  • Loading branch information
djahandarie committed Dec 13, 2024
1 parent 79527f6 commit 3753f95
Show file tree
Hide file tree
Showing 8 changed files with 357 additions and 436 deletions.
6 changes: 5 additions & 1 deletion .eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
"jsdoc/valid-types": "error",

"jsonc/indent": ["error", 4],
"jsonc/no-comments": "off",
"jsonc/array-bracket-newline": ["error", "consistent"],
"jsonc/array-bracket-spacing": ["error", "never"],
"jsonc/array-element-newline": ["error", "consistent"],
Expand Down Expand Up @@ -396,9 +397,12 @@
"@typescript-eslint/no-unsafe-return": "off",
"@typescript-eslint/require-await": "off",
"@typescript-eslint/restrict-template-expressions": "off",
"@typescript-eslint/prefer-promise-reject-errors": "off", // TODO: Enable this rule

"@typescript-eslint/ban-ts-comment": ["error", {"ts-expect-error": {"descriptionFormat": "^ - .+$"}}],
"@typescript-eslint/ban-types": ["error", {"types": {"object": true}, "extendDefaults": true}],
"@typescript-eslint/no-empty-object-type": "error",
"@typescript-eslint/no-unsafe-function-type": "error",
"@typescript-eslint/no-wrapper-object-types": "error",
"@typescript-eslint/no-explicit-any": "error",
"@typescript-eslint/no-shadow": ["error", {"builtinGlobals": false}],
"@typescript-eslint/no-this-alias": "error",
Expand Down
2 changes: 1 addition & 1 deletion ext/js/app/popup-factory.js
Original file line number Diff line number Diff line change
Expand Up @@ -188,7 +188,7 @@ export class PopupFactory {
promises.push(promise);
}

/** @type {undefined|unknown} */
/** @type {undefined|Error} */
let error = void 0;
/** @type {{popup: import('popup').PopupAny, token: string}[]} */
const results = [];
Expand Down
2 changes: 2 additions & 0 deletions ext/js/comm/anki-connect.js
Original file line number Diff line number Diff line change
Expand Up @@ -479,7 +479,9 @@ export class AnkiConnect {
if (typeof result === 'object' && result !== null && !Array.isArray(result)) {
const apiError = /** @type {import('core').SerializableObject} */ (result).error;
if (typeof apiError !== 'undefined') {
// eslint-disable-next-line @typescript-eslint/no-base-to-string
const error = new ExtensionError(`Anki error: ${apiError}`);
// eslint-disable-next-line @typescript-eslint/no-base-to-string
error.data = {action, params, status: response.status, apiError: typeof apiError === 'string' ? apiError : `${apiError}`};
throw error;
}
Expand Down
3 changes: 3 additions & 0 deletions ext/js/dom/text-source-generator.js
Original file line number Diff line number Diff line change
Expand Up @@ -406,6 +406,7 @@ export class TextSourceGenerator {
return document.caretRangeFromPoint(x, y);
}

// @ts-expect-error - caretPositionFromPoint is non-standard

Check failure on line 409 in ext/js/dom/text-source-generator.js

View workflow job for this annotation

GitHub Actions / Static Analysis

Unused '@ts-expect-error' directive.
if (typeof document.caretPositionFromPoint === 'function') {
// Firefox
return this._caretPositionFromPoint(x, y);
Expand All @@ -421,6 +422,7 @@ export class TextSourceGenerator {
* @returns {?Range}
*/
_caretPositionFromPoint(x, y) {
// @ts-expect-error - caretPositionFromPoint is non-standard

Check failure on line 425 in ext/js/dom/text-source-generator.js

View workflow job for this annotation

GitHub Actions / Static Analysis

Unused '@ts-expect-error' directive.
const position = /** @type {(x: number, y: number) => ?{offsetNode: Node, offset: number}} */ (document.caretPositionFromPoint)(x, y);
if (position === null) {
return null;
Expand Down Expand Up @@ -473,6 +475,7 @@ export class TextSourceGenerator {
nextElement.style.setProperty('user-select', 'text', 'important');
}

// @ts-expect-error - caretPositionFromPoint is non-standard

Check failure on line 478 in ext/js/dom/text-source-generator.js

View workflow job for this annotation

GitHub Actions / Static Analysis

Unused '@ts-expect-error' directive.
const position = /** @type {(x: number, y: number) => ?{offsetNode: Node, offset: number}} */ (document.caretPositionFromPoint)(x, y);
if (position === null) {
return null;
Expand Down
771 changes: 342 additions & 429 deletions package-lock.json

Large diffs are not rendered by default.

6 changes: 3 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,8 +73,8 @@
"@types/node": "20.11.5",
"@types/wanakana": "^5.3.0",
"@types/zip.js": "^2.0.33",
"@typescript-eslint/eslint-plugin": "^7.18.0",
"@typescript-eslint/parser": "^7.18.0",
"@typescript-eslint/eslint-plugin": "^8.18.0",
"@typescript-eslint/parser": "^8.18.0",
"@vitest/coverage-v8": "1.2.2",
"ajv": "^8.17.1",
"css": "^3.0.0",
Expand All @@ -89,7 +89,7 @@
"eslint-plugin-no-unsanitized": "^4.0.2",
"eslint-plugin-sonarjs": "^0.24.0",
"eslint-plugin-unicorn": "^51.0.1",
"eslint-plugin-unused-imports": "^3.2.0",
"eslint-plugin-unused-imports": "^4.1.4",
"eslint-plugin-vitest": "0.3.22",
"fake-indexeddb": "^5.0.2",
"handlebars": "^4.7.8",
Expand Down
2 changes: 1 addition & 1 deletion types/ext/core.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ export type TypeofResult = 'string' | 'number' | 'bigint' | 'boolean' | 'symbol'
export type SafeAny = any;

/** This type is used as an explicit way of permitting the `Function` type. */
// eslint-disable-next-line @typescript-eslint/ban-types
// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type
export type SafeFunction = Function;

/** This type is used as an explicit way of permitting the `any` type. */
Expand Down
1 change: 0 additions & 1 deletion types/ext/simple-dom-parser.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@ export type {
/**
* This type is used as a generic reference to an element object from a generic DOM API.
*/
// eslint-disable-next-line @typescript-eslint/ban-types
export type Element = object;

export type ISimpleDomParser = {
Expand Down

0 comments on commit 3753f95

Please sign in to comment.