Skip to content

Commit

Permalink
Remove obsolete ESLint comment directives
Browse files Browse the repository at this point in the history
  • Loading branch information
connor-baer committed Jun 24, 2024
1 parent bc57950 commit 98c4a14
Show file tree
Hide file tree
Showing 19 changed files with 33 additions and 52 deletions.
64 changes: 31 additions & 33 deletions MIGRATION.md
Original file line number Diff line number Diff line change
Expand Up @@ -136,12 +136,12 @@ This change might break tests that use `@testing-library/jest-dom`'s [`toBeDisab

```js
// jest.setup.js
import { toBeDisabled, toBeEnabled } from '@testing-library/jest-dom/matchers';
import { toBeDisabled, toBeEnabled } from "@testing-library/jest-dom/matchers";

function isAriaDisabled(element) {
return (
element.hasAttribute('aria-disabled') &&
element.getAttribute('aria-disabled') === 'true'
element.hasAttribute("aria-disabled") &&
element.getAttribute("aria-disabled") === "true"
);
}

Expand All @@ -152,17 +152,17 @@ expect.extend({
return {
pass: isDisabled,
message: () => {
const is = isDisabled ? 'is' : 'is not';
const is = isDisabled ? "is" : "is not";
return [
this.utils.matcherHint(
`${this.isNot ? '.not' : ''}.toBeDisabled`,
'element',
'',
`${this.isNot ? ".not" : ""}.toBeDisabled`,
"element",
""
),
'',
"",
`Received element ${is} disabled:`,
` ${this.utils.printReceived(element.cloneNode(false))}`,
].join('\n');
].join("\n");
},
};
},
Expand All @@ -173,17 +173,17 @@ expect.extend({
return {
pass: isEnabled,
message: () => {
const is = isEnabled ? 'is' : 'is not';
const is = isEnabled ? "is" : "is not";
return [
this.utils.matcherHint(
`${this.isNot ? '.not' : ''}.toBeEnabled`,
'element',
'',
`${this.isNot ? ".not" : ""}.toBeEnabled`,
"element",
""
),
'',
"",
`Received element ${is} enabled:`,
` ${this.utils.printReceived(element.cloneNode(false))}`,
].join('\n');
].join("\n");
},
};
},
Expand Down Expand Up @@ -331,7 +331,7 @@ For applications that don’t use Emotion.js, Circuit UI exports a new, smaller
<summary>Example</summary>

```tsx
import { clsx, utilClasses } from '@sumup/circuit-ui';
import { clsx, utilClasses } from "@sumup/circuit-ui";

function Component() {
return <div className={clsx(utilClasses.center, utilClasses.hideVisually)} />;
Expand Down Expand Up @@ -793,37 +793,35 @@ Previously, many apps would use `CreateStyled`:

```ts
// utils/styled.ts
import styled, { CreateStyled } from '@emotion/styled';
import { Theme } from '@sumup/design-tokens';
import styled, { CreateStyled } from "@emotion/styled";
import { Theme } from "@sumup/design-tokens";
// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
export default styled as CreateStyled<Theme>;
```
...and import the custom `styled` in their components:
```tsx
// components/RedCard.tsx
import { css } from '@emotion/core';
import { css } from "@emotion/core";
import styled from 'util/styled';
import styled from "util/styled";
const RedCard = styled(Card)(
({ theme }) => css`
background-color: red;
`,
`
);
```
Now, you can type the theme by adding it to `@emotion/react`'s declaration:
```ts
// types/emotion.d.ts (don't forget to include this file in tsconfig.json under `typeRoots`)
import { Theme as CircuitTheme } from '@sumup/design-tokens';
import {} from '@emotion/react/types/css-prop'; // See https://github.com/emotion-js/emotion/pull/1941
import { Theme as CircuitTheme } from "@sumup/design-tokens";
import {} from "@emotion/react/types/css-prop"; // See https://github.com/emotion-js/emotion/pull/1941
declare module '@emotion/react' {
// eslint-disable-next-line @typescript-eslint/no-empty-interface
declare module "@emotion/react" {
export interface Theme extends CircuitTheme {}
}
```
Expand All @@ -832,13 +830,13 @@ declare module '@emotion/react' {
```tsx
// components/RedCard.tsx
import { css } from '@emotion/core';
import styled from '@emotion/styled';
import { css } from "@emotion/core";
import styled from "@emotion/styled";
const RedCard = styled(Card)(
({ theme }) => css`
background-color: red;
`,
`
);
```
Expand All @@ -851,17 +849,17 @@ Make sure that references to Emotion packages inside Storybook are pointing to t
```js
// .storybook/main.js
const path = require('path');
const path = require("path");
const toPath = (_path) => path.join(process.cwd(), _path);
module.exports = {
webpackFinal: async (config) => {
// Add compatibility with Emotion 11
config.resolve.alias = {
...config.resolve.alias,
'@emotion/core': toPath('node_modules/@emotion/react'),
'@emotion/styled': toPath('node_modules/@emotion/styled'),
'emotion-theming': toPath('node_modules/@emotion/react'),
"@emotion/core": toPath("node_modules/@emotion/react"),
"@emotion/styled": toPath("node_modules/@emotion/styled"),
"emotion-theming": toPath("node_modules/@emotion/react"),
};
return config;
},
Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/components/Anchor/Anchor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,6 @@ export interface BaseProps extends BodyProps {
/**
* The ref to the HTML DOM element, it can be a button an anchor or a span, typed as any for now because of complex js manipulation with styled components
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
ref?: Ref<any>;
}
type LinkElProps = Omit<AnchorHTMLAttributes<HTMLAnchorElement>, 'onClick'>;
Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/components/BodyLarge/BodyLarge.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,6 @@ export interface BodyLargeProps extends HTMLAttributes<HTMLParagraphElement> {
/**
* The ref to the HTML DOM element.
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
ref?: Ref<any>;
}

Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/components/Button/Button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,6 @@ export type ButtonProps = SharedButtonProps & {
* to a different screen.
*/
export const Button: ForwardRefExoticComponent<
// eslint-disable-next-line @typescript-eslint/no-explicit-any
PropsWithoutRef<ButtonProps> & RefAttributes<any>
> = createButtonComponent<ButtonProps>(
'Button',
Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/components/Button/IconButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,6 @@ export type IconButtonProps = SharedButtonProps & {
* to a different screen.
*/
export const IconButton: ForwardRefExoticComponent<
// eslint-disable-next-line @typescript-eslint/no-explicit-any
PropsWithoutRef<IconButtonProps> & RefAttributes<any>
> = createButtonComponent<IconButtonProps>(
'IconButton',
Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/components/Button/base.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,6 @@ export function createButtonComponent<Props>(
// TODO: Refactor to `mapClassName` once the deprecations have been removed.
mapProps: (props: Props) => CreateButtonComponentProps,
) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const Button = forwardRef<any, Props>((props, ref) => {
const {
children,
Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/components/Carousel/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ export const ANIMATION_DURATION = 640;

export const SLIDE_DURATION = 5000;

// eslint-disable-next-line @typescript-eslint/naming-convention
export enum SLIDE_DIRECTIONS {
FORWARD = 'forward',
BACK = 'back',
Expand Down
2 changes: 1 addition & 1 deletion packages/circuit-ui/components/CloseButton/CloseButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ export type CloseButtonProps = Omit<IconButtonProps, 'icon'>;
/**
* A generic close button.
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any

export const CloseButton = forwardRef<any, CloseButtonProps>(
({ label = 'Close', children = label, ...props }, ref) => (
<IconButton
Expand Down
2 changes: 1 addition & 1 deletion packages/circuit-ui/components/Hamburger/Hamburger.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ export interface HamburgerProps
/**
* A hamburger button for menus. Morphs into a close icon when active.
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any

export const Hamburger = forwardRef<any, HamburgerProps>(
(
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@ describe('PhoneNumberInputService', () => {

it('should replace unsupported whitespace characters with single spaces in the subscriber number', () => {
const countryCode = '+1';
// eslint-disable-next-line no-tabs
const subscriberNumber = '234 567 8910';
const actual = normalizePhoneNumber(countryCode, subscriberNumber);
expect(actual).toBe('+1234 567 8910');
Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/components/Portal/Portal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,6 @@ export function Portal({
setContainer(getContainer());
// In order to prevent performance issues, this hook is only run once.
// This means that the container can't be changed after the initial render.
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);

return container && createPortal(children, container);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,6 @@ describe('PrimaryLink', () => {
it('should render with a suffix icon', () => {
renderPrimaryLink(render, {
...baseProps,
// eslint-disable-next-line react/display-name
suffix: (props) => <div {...props} data-testid="suffix" />,
});
expect(screen.getByTestId('suffix')).toBeVisible();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,5 @@ export function useClickOutside(
// The `refs` array is recreated on each render, but the ref objects inside
// don't necessarily change. Spreading the array allows React to compare the
// ref objects themselves.
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [...refs, callback, active]);
}
1 change: 0 additions & 1 deletion packages/circuit-ui/types/global.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ import type { Theme as CircuitTheme } from '@sumup/design-tokens';
import 'react';

declare module '@emotion/react' {
// eslint-disable-next-line @typescript-eslint/no-empty-interface
export interface Theme extends CircuitTheme {}
}

Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/types/return-type.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,4 @@

import type { ReactElement } from 'react';

// eslint-disable-next-line @typescript-eslint/no-explicit-any
export type ReturnType = ReactElement<any, any> | null;
2 changes: 0 additions & 2 deletions packages/circuit-ui/util/i18n.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,15 +31,13 @@ describe('i18n', () => {
let languageGetter: MockInstance;

beforeEach(() => {
// eslint-disable-next-line no-global-assign
window = originalWindow;
languagesGetter = vi.spyOn(window.navigator, 'languages', 'get');
languageGetter = vi.spyOn(window.navigator, 'language', 'get');
});

it('should return the default locale in server environments', () => {
// @ts-expect-error The window object is undefined in server environments
// eslint-disable-next-line no-global-assign
window = undefined;
const actual = getBrowserLocale();
expect(actual).toBe(DEFAULT_LOCALE);
Expand Down
1 change: 0 additions & 1 deletion packages/circuit-ui/util/refs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ export function applyMultipleRefs<T extends Element>(
if (typeof ref === 'function') {
ref(instance);
} else if (ref) {
// eslint-disable-next-line no-param-reassign
ref.current = instance;
}
});
Expand Down
1 change: 0 additions & 1 deletion scripts/.eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@
* limitations under the License.
*/

// eslint-disable-next-line import/no-extraneous-dependencies
module.exports = require('@sumup-oss/foundry/eslint')({
rules: {
'arrow-parens': 'off',
Expand Down
1 change: 0 additions & 1 deletion vite.config.mts
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@
import { defineConfig } from 'vite';
import GithubActionsReporter from 'vitest-github-actions-reporter';

// eslint-disable-next-line import/no-relative-packages
import { css } from './packages/circuit-ui/vite.config.js';

export default defineConfig({
Expand Down

0 comments on commit 98c4a14

Please sign in to comment.