diff --git a/docs/decisions/010-deprecations.md b/docs/decisions/010-deprecations.md index 6603e950fb..329ce08378 100644 --- a/docs/decisions/010-deprecations.md +++ b/docs/decisions/010-deprecations.md @@ -6,13 +6,12 @@ Status: proposed ## Context -Starting the development of our design system from scratch, we have been using version 0 for a long time. -As [SEMVER suggests][semver-zero-version], we want to communicate to our users that the design system is at an early stage and any feature is not considered stable. -However, from the time our users started to use the design system and test it, they wanted the components they would not change under the hands. -They want to API to be more stable and predictable. +Starting the development of our design system from scratch, we had been using version 0 for a long time. +As [SEMVER suggests][semver-zero-version], we wanted to communicate to our users that the design system was at an early stage and any feature was not considered stable. +However, from the time our users started to use the design system and tested it, they wanted the components that would not change under the hands. +They wanted the API to be more stable and predictable. -Starting the first production usage of the design system, we had to stabilize the API and find another way how to customize and further develop our components. -But without breaking the existing API. +Starting the first production usage of the design system, we had to stabilize the API and find another way how to further improve and develop our components, but without breaking the existing API. So, we began with the research on how other libraries are solving this problem. In various libraries like ESLint or [Twig][twig-deprecated] we have found the concept of deprecations. @@ -38,9 +37,9 @@ We will implement the following deprecation strategy: We will mark any feature that will be considered as a breaking change as deprecated. We will maintain DEPRECATIONS-v\*.md files for each major version documenting all deprecations. We will include a deprecation notice in the commit message as well as in the release notes. -We will provide [migration guides][migration-guides] for each deprecation. +We will provide a [migration guides][migration-guides] for each deprecation. There will be a "Deprecations" section in each package README.md file pointing to the deprecations list. -When there will be a deprecation notice in the component's README file it will be pointing to the related deprecation notice in deprecations list. +When there will be a deprecation notice in the component's README file it will be pointing to the related deprecation notice in the deprecations list mentioned above. Developers will have clear visibility of deprecated features during development. Production builds won't be impacted by deprecation warnings. Migration to new versions will be easier with clear upgrade paths. @@ -50,8 +49,8 @@ Additional maintenance effort is required to keep deprecation documentation up t ### Breaking Changes without Deprecation When delivering a new Major version, deprecating some features may not be possible or there will be a very short period to adapt. -In such cases, the breaking changes can be introduced without deprecation as a standard part of the Major version upgrade. -We consider there is a no less than 1 month period between the release of the deprecation notice and the release of the new Major version. +In such cases, the breaking changes can be introduced without deprecation as a standard part of the major version upgrade. +We consider there is a no less than 1 month period between the release of the deprecation notice and the release of the new major version. When the gap is longer, we should deprecate the feature first. [migration-guides]: https://github.com/lmc-eu/spirit-design-system/blob/main/docs/migrations/README.md diff --git a/packages/web-react/README.md b/packages/web-react/README.md index c12ef537ad..e3d9ca3c35 100644 --- a/packages/web-react/README.md +++ b/packages/web-react/README.md @@ -148,7 +148,7 @@ Check your browser console to see if you are using any of the deprecated functio ![Deprecations in the Browser's console](https://github.com/lmc-eu/spirit-design-system/blob/main/static/deprecations-browser-console.png?raw=true) -👉 [See a DEPRECATIONS file][all-deprecations] for a list of all deprecations. +👉 [See the DEPRECATIONS file][all-deprecations] for the list of all deprecations. ### Warnings in environments diff --git a/packages/web/README.md b/packages/web/README.md index f64b1b3a53..529ca13de6 100644 --- a/packages/web/README.md +++ b/packages/web/README.md @@ -245,6 +245,8 @@ Check your browser console to see if you are using any of the deprecated functio ![Deprecations in the Browser's console][deprecations] +👉 [See a DEPRECATIONS file][all-deprecations] for a list of all deprecations. + ## Feature Flags 👀 See [Feature Flags documentation][feature-flags-docs] for how to use them. @@ -257,11 +259,13 @@ Check your browser console to see if you are using any of the deprecated functio See the [LICENSE][license] file for information. +[all-deprecations]: https://github.com/lmc-eu/spirit-design-system/tree/main/packages/web/DEPRECATIONS.md +[configuring-load-path]: https://github.com/lmc-eu/spirit-design-system/tree/main/packages/design-tokens#configuring-load-path +[deprecations]: https://github.com/lmc-eu/spirit-design-system/blob/main/static/deprecations-browser-console.png?raw=true [design-tokens-usage]: https://github.com/lmc-eu/spirit-design-system/tree/main/packages/design-tokens#basic-usage [design-tokens-load-path]: https://github.com/lmc-eu/spirit-design-system/tree/main/packages/design-tokens#in-sass [design-tokens-color-tokens]: https://github.com/lmc-eu/spirit-design-system/blob/main/packages/design-tokens/src/scss/themes/_color-tokens.scss [design-tokens-rebranding]: https://github.com/lmc-eu/spirit-design-system/tree/main/packages/design-tokens#rebranding-spirit -[deprecations]: https://github.com/lmc-eu/spirit-design-system/blob/main/static/deprecations-browser-console.png?raw=true [examples]: https://spirit-design-system.netlify.app/packages/web/ [feature-flags-docs]: https://github.com/lmc-eu/spirit-design-system/blob/main/docs/contribution/feature-flags.md [license]: https://github.com/lmc-eu/spirit-design-system/blob/main/packages/web/LICENSE.md