Skip to content

Commit

Permalink
chore: mark the Calendar component as stable. Update the eslint compo…
Browse files Browse the repository at this point in the history
…nent-lifecycle-imports rule
  • Loading branch information
sirineJ committed Oct 10, 2024
1 parent f8016eb commit 8e1fb76
Show file tree
Hide file tree
Showing 8 changed files with 63 additions and 8 deletions.
5 changes: 5 additions & 0 deletions .changeset/gold-worms-worry.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@sumup-oss/eslint-plugin-circuit-ui": minor
---

Updated the `component-lifecycle-imports` eslint rule to flag imports of stable entities from `@sumup-oss/circuit-ui/experimental`"
6 changes: 6 additions & 0 deletions .changeset/shiny-geckos-hang.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
"@sumup-oss/circuit-ui": minor
---

Marked the `Calendar` component as stable.

2 changes: 1 addition & 1 deletion packages/circuit-ui/components/Calendar/Calendar.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import * as Stories from './Calendar.stories';

# Calendar

<Status variant="experimental" />
<Status variant="stable" />

The Calendar component displays a monthly date grid. This is a low-level component for advanced use cases; you likely want to use the [DateInput](Forms/Input/DateInput/Base) component instead.

Expand Down
2 changes: 0 additions & 2 deletions packages/circuit-ui/experimental.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,5 @@ export {
Toggletip,
type ToggletipProps,
} from './components/Toggletip/index.js';
export { Calendar, type CalendarProps } from './components/Calendar/index.js';
export { type PlainDateRange } from './util/date.js';
export { PhoneNumberInput } from './components/PhoneNumberInput/index.js';
export type { PhoneNumberInputProps } from './components/PhoneNumberInput/index.js';
3 changes: 3 additions & 0 deletions packages/circuit-ui/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,9 @@ export { PercentageInput } from './components/PercentageInput/index.js';
export type { PercentageInputProps } from './components/PercentageInput/index.js';
export { ImageInput } from './components/ImageInput/index.js';
export type { ImageInputProps } from './components/ImageInput/index.js';
export { Calendar } from './components/Calendar/index.js';
export type { CalendarProps } from './components/Calendar/index.js';
export type { PlainDateRange } from './util/date.js';

// Actions
export { Button } from './components/Button/index.js';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,21 @@ Examples of **incorrect** code for this rule:
import { RangePicker } from '@sumup-oss/circuit-ui';
import type { RangePickerProps } from '@sumup-oss/circuit-ui';
```
```tsx
import { Calendar } from '@sumup-oss/circuit-ui/experimental';
import type { CalendarProps } from '@sumup-oss/circuit-ui/experimental';
```

Examples of **correct** code for this rule:

```tsx
import { RangePicker } from '@sumup-oss/circuit-ui/legacy';
import type { RangePickerProps } from '@sumup-oss/circuit-ui/legacy';
```
```tsx
import { Calendar } from '@sumup-oss/circuit-ui';
import type { CalendarProps } from '@sumup-oss/circuit-ui';
```

### Options

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ ruleTester.run('component-lifecycle-imports', componentLifecycleImports, {
],
invalid: [
{
name: 'single import with single match',
name: '[Legacy] single import with single match',
code: `
import { RangePicker } from '@sumup-oss/circuit-ui';
`,
Expand All @@ -70,7 +70,7 @@ ruleTester.run('component-lifecycle-imports', componentLifecycleImports, {
errors: [{ messageId: 'refactor' }],
},
{
name: 'single import with single match with local name',
name: '[Legacy] single import with single match with local name',
code: `
import { RangePicker as RangeInput } from '@sumup-oss/circuit-ui';
`,
Expand All @@ -80,7 +80,7 @@ ruleTester.run('component-lifecycle-imports', componentLifecycleImports, {
errors: [{ messageId: 'refactor' }],
},
{
name: 'multiple imports with single match',
name: '[Legacy] multiple imports with single match',
code: `
import { RangePicker, Button } from '@sumup-oss/circuit-ui';
`,
Expand All @@ -90,7 +90,7 @@ ruleTester.run('component-lifecycle-imports', componentLifecycleImports, {
errors: [{ messageId: 'refactor' }],
},
{
name: 'multiple imports with multiple matches',
name: '[Legacy] multiple imports with multiple matches',
code: `
import { RangePicker, RangePickerController } from '@sumup-oss/circuit-ui';
`,
Expand All @@ -101,7 +101,7 @@ ruleTester.run('component-lifecycle-imports', componentLifecycleImports, {
errors: [{ messageId: 'refactor' }, { messageId: 'refactor' }],
},
{
name: 'single type import with single match',
name: '[Legacy] single type import with single match',
code: `
import type { RangePickerProps } from '@sumup-oss/circuit-ui';
`,
Expand All @@ -110,5 +110,35 @@ ruleTester.run('component-lifecycle-imports', componentLifecycleImports, {
`,
errors: [{ messageId: 'refactor' }],
},
{
name: '[Experimental] single import with single match',
code: `
import { Calendar } from '@sumup/circuit-ui/experimental';
`,
output: `
import { Calendar } from '@sumup/circuit-ui';
`,
errors: [{ messageId: 'refactor' }],
},
{
name: '[Experimental] single import with single match with local name',
code: `
import { Calendar as CuiCalendar } from '@sumup/circuit-ui/experimental';
`,
output: `
import { Calendar as CuiCalendar } from '@sumup/circuit-ui';
`,
errors: [{ messageId: 'refactor' }],
},
{
name: '[Experimental] single type import with single match',
code: `
import type { CalendarProps } from '@sumup/circuit-ui/experimental';
`,
output: `
import type { CalendarProps } from '@sumup/circuit-ui';
`,
errors: [{ messageId: 'refactor' }],
},
],
});
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,11 @@ const mappings = [
'center',
],
},
{
from: '@sumup-oss/circuit-ui/experimental',
to: '@sumup-oss/circuit-ui',
specifiers: ['Calendar', 'CalendarProps', 'PlainDateRange'],
},
];

export const componentLifecycleImports = createRule({
Expand Down

0 comments on commit 8e1fb76

Please sign in to comment.