Skip to content

Latest commit

 

History

History
167 lines (117 loc) · 4.89 KB

CONTRIBUTING.md

File metadata and controls

167 lines (117 loc) · 4.89 KB

Contributing

Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Getting started

Prerequisites

Make sure you have at least Node.js v18:

node -v

v18.0.0

This repo runs with Yarn v1, please install make sure to install it, since all other steps will assume that you have this dependency installed.

npm install -g yarn@1

Setup the repo

Start by forking the repo. Then clone your fork and install dependencies.

git clone git@github.com:<your-user>/fluentui-contrib.git
cd fluentui-contrib
yarn

Add the main repo as a git remote so you can pull/rebase your fork with our latest updates:

git remote add upstream git@github.com:microsoft/fluentui-contrib.git

Creating a new package

Important

Every new package needs to go through 2 step PR process

  • 1st PR bootstraps package via generator
  • 2nd PR adds implementation logic

Important

Every package needs to have owner assigned within CODEOWNERS file. It's highly recommended to use Github Team as owner instead individual to mitigate unmaintained code risks.

You can create a new package by running the following commands.

<name> refers to the name of a folder within the packages/ folder. The final published package will have the form of @fluentui-contrib/<name> For example for react-chat 👇👇

packages/react-chat @fluentui-contrib/react-chat yarn nx build react-chat

# Scaffolds a new folder in the packages/ directory with autogenerated package files
yarn nx generate library <name>

# Configures storybook for the package
yarn nx generate configure-storybook <name>

# Configures playwright browser testing for the package
yarn nx generate playwright-component-configuration <name>

# Scaffolds a new component with sample implementation and example documentation
yarn nx generate component <name> <componentName>

# Starts the storybook for you new package and component
yarn nx storybook <name>

Contract

Contribution packages enable Fluent UI contributors and other Microsoft partners use Fluent UI to create rich experiences that build on the design system, without the requirements of the design system getting in the way. We give the initiative to contributors to ship their packages with an API and support structure that makes sense to them.

There are however a few housekeeping requirements that we impose on contribution packages:

  • README authoring - please author the README.md file for your package to be helpful to users
  • Documentation - each package should have documentation examples powered by Storybook
  • Issues - be a responsible maintainer and address user issues for your package

Other than the basic housekeeping requirements, the contribution package sandbox for developers to build on. The Fluent UI team is happy to work with contributors if they need help and guidance.

Common commands

<name> refers to the name of a folder within the packages/ folers. The final published package will have the form of @fluentui-contrib/<name> For example for react-chat 👇👇

packages/react-chat @fluentui-contrib/react-chat yarn nx build react-chat

This repository runs as a NX integrated monorepo. We have configured common commands across all packages that is the baseline to be able to:

  • develop
  • test
  • document
  • build
  • publish

all packages in the repo. All commands can be run from the root of the monorepo for any package. There should be no need to move around package folders to run commands.

storybook

Starts storybook for a package

yarn nx storybook <name>

test

Runs unit tests using jest

yarn nx test <name>

build

Builds source code with es6 and common-js formats in the dist/ folder in the monorepo root.

yarn nx build <name>

type-check

Checks typescript usage and generates type files in the dist/ folder in the monorepo root.

yarn nx type-check <name>

format

Formats the code with prettier

yarn nx format