diff --git a/.changeset/gold-worms-worry.md b/.changeset/gold-worms-worry.md new file mode 100644 index 0000000000..29eaf59e13 --- /dev/null +++ b/.changeset/gold-worms-worry.md @@ -0,0 +1,7 @@ +--- +"@sumup-oss/eslint-plugin-circuit-ui": minor +"@sumup-oss/circuit-ui": minor +--- + +Marked the `Calendar` component as stable. +Updated the `component-lifecycle-imports` eslint rule to flag relevant imports from @sumup-oss/circuit-ui/experimental" diff --git a/packages/circuit-ui/components/Calendar/Calendar.mdx b/packages/circuit-ui/components/Calendar/Calendar.mdx index 917b694f3d..854a0e4413 100644 --- a/packages/circuit-ui/components/Calendar/Calendar.mdx +++ b/packages/circuit-ui/components/Calendar/Calendar.mdx @@ -5,7 +5,7 @@ import * as Stories from './Calendar.stories'; # Calendar - + 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. diff --git a/packages/circuit-ui/experimental.ts b/packages/circuit-ui/experimental.ts index f14e515f7c..b6d69b2e3d 100644 --- a/packages/circuit-ui/experimental.ts +++ b/packages/circuit-ui/experimental.ts @@ -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'; diff --git a/packages/circuit-ui/index.ts b/packages/circuit-ui/index.ts index be4c7a7e41..d212b2b28c 100644 --- a/packages/circuit-ui/index.ts +++ b/packages/circuit-ui/index.ts @@ -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'; diff --git a/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.spec.ts b/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.spec.ts index 55b5f058e5..39ca1c900d 100644 --- a/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.spec.ts +++ b/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.spec.ts @@ -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'; `, @@ -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'; `, @@ -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'; `, @@ -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'; `, @@ -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'; `, @@ -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' }], + }, ], }); diff --git a/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.ts b/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.ts index 909f6f48e6..29aeb23dd3 100644 --- a/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.ts +++ b/packages/eslint-plugin-circuit-ui/component-lifecycle-imports/index.ts @@ -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({