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.
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.
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.
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
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
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
Use clarity-devtools to debug Clarity against any live website.
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"
}
]
}
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