# Contributing to L7

👍🎉 欢迎向 L7 贡献代码! 🎉👍

## 前置依赖安装

### 安装 Yarn

由于使用了 Yarn workspace,首先需要安装 Yarn:https://yarnpkg.com/en/docs/install#windows-stable

### Windows 环境配置

[L7 测试方案](https://github.com/antvis/L7/blob/master/dev-docs/%E8%87%AA%E5%8A%A8%E5%8C%96%E6%B5%8B%E8%AF%95%E6%96%B9%E6%A1%88.md)依赖 headless-gl,其中需要 node-gyp [编译本地依赖](https://github.com/nodejs/node-gyp#on-windows)。

1. 首先以管理员身份启动 PowerShell
2. 运行 `npm install --global --production windows-build-tools`,安装 Microsoft's windows-build-tools

安装过程中其他问题[详见](https://github.com/antvis/L7/issues/101)。

## 安装依赖

安装依赖并完成 Yarn workspace 初始化:
```bash
yarn install
```

### Windows

```bash
copy node_modules/gl/deps/windows/dll/x64/*.dll c:\windows\system32
```

## 运行 DEMO

启动各个 package 代码变更监听:
```bash
yarn watch
```

启动 Storybook,会自动打开 `http://localhost:6006/`:
```bash
yarn storybook
```

## 运行测试

运行单元测试:
```bash
yarn test
```

运行单元测试并查看代码覆盖率:
```bash
yarn coveralls
```

## 添加 Lerna package

添加一个新的 lerna package:
```bash
lerna create my-pack -y
```

将 ui-lib 作为 my-pack 的依赖:
```bash
yarn workspace my-pack add ui-lib/1.0.0
```

将 lodash 添加为所有 package 的依赖(不包含root)
```bash
yarn workspaces run add lodash
```

将 typescript 设置为 root 的开发依赖
```bash
yarn add -W -D typescript jest
```

## 提交代码

代替 `git commit` 提交:
```bash
yarn commit
```