Skip to content

Latest commit

 

History

History
132 lines (99 loc) · 4.22 KB

CONTRIBUTING.md

File metadata and controls

132 lines (99 loc) · 4.22 KB

Contributing to Clarity

The goal of this document is to provide easy instructions to setup a development environment and provide clear contribution guidelines to encourage participation from more developers.

This project welcomes contributions and suggestions. 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.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., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repositories 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 [email protected] with any additional questions or comments.

Workflow

Submitting Code Changes

Submit a pull-request with your changes. This involves creating a local feature branch, publishing it, and submitting a pull request, which will generate a code review. Once the review is approved, the code will automatically be merged.

Git

On Windows, grab an installer from here: https://git-scm.com/download/win and go with the default options (there will be a lot of option screens).

On Mac and Linux, it's pre-installed.

Node.js (18+)

On Windows, grab an installer from nodejs.org and go with the default options:

https://nodejs.org/en/download/

On Mac, setup Homebrew and then proceed to install node

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
brew install node

On Ubuntu, it's fairly straight forward except you've a few extra steps

sudo apt-get install nodejs
sudo apt-get install build-essential
sudo apt-get install libssl-dev
sudo apt-get install npm
sudo update-alternatives --install /usr/bin/node node /usr/bin/nodejs 10
  -- There's a naming conflict on Ubuntu for node vs. nodejs.
  -- If you happen to have node install, run: sudo apt-get --purge remove node

Cloning Clarity

1. Open command line prompt (Windows) / Terminal (Mac) / Shell (Ubuntu)
2. Go to a directory where you would like to pull Clarity code
3. git clone https://github.com/microsoft/clarity.git
4. When prompted, enter your github credentials

Starting Clarity

Install yarn package manager globally on your machine:

npm i -g yarn

Install yarn packages:

yarn install

To build:

yarn build

To test:

yarn test

On Ubuntu, if you run into errors, it may be because you are missing the libfontconfig package

sudo apt-get install libfontconfig

Debugging Clarity

Use clarity-devtools to debug Clarity against any live website.

Text Editor

Recommended text editor is Visual Studio Code, but if you prefer a different text editor, feel free to use it.

Download Visual Studio Code

https://code.visualstudio.com/download

Edit Clarity:

Go to 'File -> Open Folder' and select the 'clarity' folder that you just cloned.

Debug Tests

To debug tests from Visual Studio Code, create "launch.json" in your root project folder:

{
  "version": "0.2.0",
  "configurations": [
      {
          "name": "Clarity Tests",
          "type": "node",
          "request": "launch",
          "cwd": "${workspaceFolder}/packages/clarity-js",
          "runtimeExecutable": "${workspaceRoot}/node_modules/.bin/ts-mocha",
          "runtimeArgs": [
              "-p",
              "test/tsconfig.test.json",
              "${file}"
          ],
          "protocol": "inspector"
      }

  ]
}

Text Editor TSLint Plugin

TSLint plugin will read Clarity's TSLint configuration and highlight any TSLint errors immediately as you edit your code.

For Visual Studio Code, you can install the TSLint plugin from the Visual Studio Marketplace:

https://marketplace.visualstudio.com/items?itemName=ms-vscode.vscode-typescript-tslint-plugin