diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md index 5a1d462a2f..9e7dfe656c 100644 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -1,137 +1,7 @@ -_Note: Please transform `- [ ]` into `- (NA)` in the description when things are not applicable_ - -### Related issues - - - -### Description - - - -### Motivation & Context - - - -### Types of change - - - - -- Bug fix (non-breaking which fixes an issue) -- New feature (non-breaking change which adds functionality) -- Refactoring (non-breaking change) -- Breaking change (fix or feature that would change existing functionality) - -### Live previews - - - -- - -### Checklist - - - - -#### Contribution - -- [ ] I have read the [contributing guidelines](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/blob/main/.github/CONTRIBUTING.md) - -#### Accessibility - -- [ ] My change follows accessibility good practices; I have at least run axe - -#### Design - -- [ ] My change respects the design guidelines defined in [Orange Design System](https://oran.ge/dsweb) -- [ ] My change is compatible with a responsive display - -#### Development - -- [ ] My change follows the [developer guide](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/wiki/Developer-guide) -- [ ] I have added JavaScript unit tests to cover my changes -- [ ] I have added SCSS unit tests to cover my changes - -#### Documentation - -- [ ] My change introduces changes to the documentation and/or I have updated the documentation accordingly - -### Checklist (for Core Team only) - -- [ ] My change introduces changes to the migration guide -- [ ] My new component is well displayed in [Storybook](https://deploy-preview-{your_pr_number}--boosted.netlify.app/storybook) -- [ ] My new component is compatible with RTL -- [ ] Manually run [BrowserStack tests](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/actions/workflows/browserstack.yml) -- [ ] Manually test browser compatibility with BrowserStack (Chrome >= 60, Firefox >= 60 (+ ESR), Edge, Safari >= 12, iOS Safari, Chrome & Firefox on Android) -- [ ] Code review -- [ ] Design review -- [ ] A11y review - -#### After the merge - -- [ ] Manually launch [Percy tests](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/actions/workflows/percy.yml) - - - - - - - - +Click the `Preview` tab and select a PR template: +- **Boosted**: + - [Contribute to Boosted](?expand=1&template=boosted-contribution-template.md) + - [Release Boosted](?expand=1&template=boosted-release-template.md) (Core team only) +- **OUDS Web**: + - [Contribute to OUDS Web](?expand=1&template=ouds-contribution-template.md) + - [Release OUDS Web](?expand=1&template=ouds-release-template.md) (Core team only) diff --git a/.github/PULL_REQUEST_TEMPLATE/boosted-contribution-template.md b/.github/PULL_REQUEST_TEMPLATE/boosted-contribution-template.md new file mode 100644 index 0000000000..4d8be7be20 --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE/boosted-contribution-template.md @@ -0,0 +1,72 @@ +_Note: Please transform `- [ ]` into `- (NA)` in the description when things are not applicable_ + +### Related issues + + + +### Description + + + +### Motivation & Context + + + +### Types of change + + + + +- Bug fix (non-breaking which fixes an issue) +- New feature (non-breaking change which adds functionality) +- Refactoring (non-breaking change) +- Breaking change (fix or feature that would change existing functionality) + +### Live previews + + + +- + +### Checklist + + + + +#### Contribution + +- [ ] I have read the [contributing guidelines](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/blob/main/.github/CONTRIBUTING.md) + +#### Accessibility + +- [ ] My change follows accessibility good practices; I have at least run axe + +#### Design + +- [ ] My change respects the design guidelines defined in [Orange Design System](https://oran.ge/dsweb) +- [ ] My change is compatible with a responsive display + +#### Development + +- [ ] My change follows the [developer guide](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/wiki/Developer-guide) +- [ ] I have added JavaScript unit tests to cover my changes +- [ ] I have added SCSS unit tests to cover my changes + +#### Documentation + +- [ ] My change introduces changes to the documentation and/or I have updated the documentation accordingly + +### Checklist (for Core Team only) + +- [ ] My change introduces changes to the migration guide +- [ ] My new component is well displayed in [Storybook](https://deploy-preview-{your_pr_number}--boosted.netlify.app/storybook) +- [ ] My new component is compatible with RTL +- [ ] Manually run [BrowserStack tests](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/actions/workflows/browserstack.yml) +- [ ] Manually test browser compatibility with BrowserStack (Chrome >= 60, Firefox >= 60 (+ ESR), Edge, Safari >= 12, iOS Safari, Chrome & Firefox on Android) +- [ ] Code review +- [ ] Design review +- [ ] A11y review + +#### After the merge + +- [ ] Manually launch [Percy tests](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/actions/workflows/percy.yml) diff --git a/.github/PULL_REQUEST_TEMPLATE/boosted-release-template.md b/.github/PULL_REQUEST_TEMPLATE/boosted-release-template.md new file mode 100644 index 0000000000..cedbedc10c --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE/boosted-release-template.md @@ -0,0 +1,45 @@ +## Release v + +- [ ] [sync with Bootstrap](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/wiki/Syncing-with-Bootstrap)'s release and probably wait for it; +- [ ] `npm run release-version $current_version $next_version` to bump version number + - then, if bumping a minor or major version: + - [ ] Manually change `version_short` in `package.json` + - [ ] Add docs version to `site/data/docs-versions.yml` + - [ ] Manually change `docs_version` in `hugo.yml` and other references to the previous version + - [ ] Update redirects in docs frontmatter (`site/content/docs/_index.html`?) + - [ ] Move `site/content/docs/5.x` to `site/content/docs/5.x+1` + - [ ] Increment `site/static/docs/{version}` version + - [ ] (Major version) Manually update the version in `nuget/boosted.nuspec` and `nuget/boosted.sass.nuspec` + - check wrong matches in `CHANGELOG.md`, and maybe `site/content/docs//migration.md` + - :warning: check the `package-lock.json` and `package.json` content, only "boosted" should have its version changed! + - :warning: `site/content/docs/5.1/**/*.md` should not always be modified +- [ ] if the year changed recently, happy new year :tada: but please change © year in `.scss` main files (reboot, grid, utilities, and main file) as well as in `NOTICE.txt`. +- [ ] `npm run release` to compile dist, build Storybook, update SRI hashes in doc, and package the release +- [ ] Prepare changelog: + - install [Conventional Changelog](https://github.com/conventional-changelog/conventional-changelog) and `conventional-changelog-cli` globally + - run `conventional-changelog -p angular -i CHANGELOG.md -s` + - and probably maintain [a ship list (e.g. for v4.4.0)](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/issues/226) +- [ ] Commit and push `dist` with a `chore(release)` commit message +- [ ] Manually run BrowserStack test +- [ ] Manually run Percy test +- [ ] Merge (on `v4-dev` or `main`) +- [ ] Tag your version, and push your tag +- [ ] Pack and publish + - `npm pack` + - if you are already logged in to NPM (with a personal account, for example), [you'd better use a repository scoped `.npmrc` file](https://stackoverflow.com/questions/30114166/how-to-have-multiple-npm-users-set-up-locally) + - Publish: + - if you're releasing a pre-release, use `--tag`, e.g. for v5-alpha1 `npm publish boosted-5.0.0-alpha1.tgz --tag next` + - (v4 only) `npm publish --tag v4.x.y` (if you forgot and v4 becomes the latest version on NPM, you can run `npm dist-tag add boosted@5.x.y latest to fix it) + - (v5 only) `npm publish` +- [ ] check release on [NPM](https://www.npmjs.com/package/boosted), [Nuget](https://www.nuget.org/packages/boosted/), [Packagist](https://packagist.org/packages/orange-opensource/orange-boosted-bootstrap)… +- [ ] publish documentation on `gh-pages`: + - [ ] copy `../_site` to the `gh-pages` branch (don't forget to update Storybook as well) + - [ ] check every `index.html` used as redirections to redirect to the new release + - [ ] when bumping minor version: ensure `dist` URLs in examples' HTML has changed + - [ ] double-check everything before pushing, starting by searching for forgotten old version number occurrences +- [ ] make an announcement in [GitHub Discussions](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/discussions/categories/announcements) (+ pin the new GH Discussion) +- [ ] [create a GitHub release](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/releases/new): + - attach the zip file + - paste the CHANGELOG / Ship list in the release's description +- [ ] make an announcement on internal communication channels :tada: +- [ ] [publish on Nuget](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/wiki/Generate-NuGet-packages) diff --git a/.github/PULL_REQUEST_TEMPLATE/ouds-contribution-template.md b/.github/PULL_REQUEST_TEMPLATE/ouds-contribution-template.md new file mode 100644 index 0000000000..a9f81a9bed --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE/ouds-contribution-template.md @@ -0,0 +1,53 @@ +### Types of change + +- [ ] Non-breaking change +- [ ] Breaking change (fix or feature that would change existing functionality and usage) + +### Related issues + +Closes # + +### Context & Motivation + + + +### Description + + + +### Checklists + + + + +- [ ] I have read the [contributing guidelines](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/blob/ouds/main/.github/CONTRIBUTING.md) +- [ ] My change follows the [developer guide](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/wiki/Developer-guide) +- [ ] My change pass all tests +- [ ] My change is compatible with a responsive display +- [ ] I have added tests (Javascript unit test or visual) to cover my changes +- [ ] My change introduces changes to the documentation that I have updated accordingly + - [ ] Title and DOM structure is correct + - [ ] Links have been updated (title changes impact links) + - [ ] CSS for the documentation +- [ ] I have checked all states and combinations of the component with my change +- [ ] I have checked all the impacts for the other components and core behavior (grid, reboot, utilities) + +### Checklist (for Core Team only) + +- [ ] The changes need to be in the migration guide +- [ ] The changes are well displayed in [Storybook](https://deploy-preview-{your_pr_number}--boosted.netlify.app/storybook) (be careful if example order has changed for DSM) +- [ ] The changes are compatible with RTL +- [ ] Manually test browser compatibility with BrowserStack (Chrome 120, Firefox 121, Edge 120, Safari 15.6, iOS Safari, Chrome & Firefox on Android) + +### Progression (for Core Team only) + +- [ ] Code review +- [ ] Design review +- [ ] A11y review +- [ ] Commit on `ouds/main` following [conventional commit](https://www.conventionalcommits.org/en/v1.0.0/) + +### Live previews + + + +- diff --git a/.github/PULL_REQUEST_TEMPLATE/ouds-release-template.md b/.github/PULL_REQUEST_TEMPLATE/ouds-release-template.md new file mode 100644 index 0000000000..4e977d7bef --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE/ouds-release-template.md @@ -0,0 +1,51 @@ +## Release v + +- [ ] `npm run release-version $current_version $next_version` to bump version number + - then, if bumping a minor or major version: + - [ ] Manually search and replace `$current_version` in all files, meaning changes should happen in: + - [ ] The style sheet loaded in `.storybook/preview-head.html` + - [ ] Some download links in the `README.md` + - [ ] `docs_version` in `hugo.yml` and other references to the previous version + - [ ] `VERSION` in `js/src/base-component.js` + - [ ] `version` in `package.js` + - [ ] `version_short` in `package.json` + - [ ] `scss/mixins/_banner.scss` + - [ ] `scss/docs.scss` + - [ ] Several markdown files + - [ ] Add docs version to `site/data/docs-versions.yml` + - [ ] Update the home news for the next release + - [ ] Move `site/content/docs/x.y` to `site/content/docs/x.y+1` + - [ ] Move `site/static/docs/x.y` to `site/static/docs/x.y+1` + - [ ] (Major version) Manually update the version in `nuget/ouds-web.nuspec` and `nuget/ouds-web.sass.nuspec` + - check wrong matches in `CHANGELOG.md`, and maybe `site/content/docs//migration.md` + - :warning: check the `package-lock.json` and `package.json` content, only "@ouds/web" should have its version changed! +- [ ] if the year changed recently, happy new year :tada: but please change © year in `.scss` main files (reboot, grid, utilities, and main file) as well as in `NOTICE.txt`. +- [ ] `npm run release` to compile dist, build Storybook, update SRI hashes in doc, and package the release +- [ ] Prepare changelog: + - install [Conventional Changelog](https://github.com/conventional-changelog/conventional-changelog) and `conventional-changelog-cli` globally + - run `conventional-changelog -p angular -i CHANGELOG.md -s` +- [ ] Commit and push `dist` with a `chore(release): vx.y.z` commit message +- [ ] Merge on `ouds/main` +- [ ] Tag your version, and push your tag using `git tag vx.y.z-ouds-web` and `git push vx.y.z-ouds-web` +- [ ] Pack and publish + - `npm pack` + - if you are already logged in to NPM (with a personal account, for example), [you'd better use a repository scoped `.npmrc` file](https://stackoverflow.com/questions/30114166/how-to-have-multiple-npm-users-set-up-locally) + - Publish: + - if you're releasing a pre-release, use `--tag`, e.g. for v1-alpha1 `npm publish ouds-web-1.0.0-alpha1.tgz --tag next` + - `npm publish` + +- [ ] check release on [NPM](https://www.npmjs.com/package/@ouds/web), [Nuget](https://www.nuget.org/packages/@ouds/web/), [Packagist](https://packagist.org/packages/orange-opensource/orange-boosted-bootstrap)… +- [ ] publish documentation on `main` of the [ouds-web-doc](https://github.com/Orange-OpenSource/ouds-web-doc) repo: + - [ ] copy `../_site` to the `main` branch (don't forget to update Storybook as well) + - [ ] check every `index.html` used as redirections to redirect to the new release + - [ ] when bumping minor or major version: ensure `dist` URLs in examples' HTML has changed + - [ ] double-check everything before pushing, starting by searching for forgotten old version number occurrences + +- [ ] [create a GitHub release](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/releases/new): + - attach the 2 zip files + - paste the CHANGELOG / Ship list in the release's description + +- [ ] [publish on Nuget](https://github.com/Orange-OpenSource/Orange-Boosted-Bootstrap/wiki/Generate-NuGet-packages)