From a13c4f72f550cd6f3eea8f2fbcad015ed8e8dd04 Mon Sep 17 00:00:00 2001 From: Carl Sverre Date: Wed, 6 Jan 2021 15:53:12 -0500 Subject: [PATCH] docs: adding PR guidelines for contributors (#2736) --- .prettierrc | 1 + CONTRIBUTING.md | 41 ++++++++++++++++- README.md | 20 ++------- src/locales/README.md | 6 +-- src/packages/excalidraw/README.md | 75 +++++++++++++++---------------- src/packages/utils/CHANGELOG.md | 4 +- src/packages/utils/README.md | 3 +- 7 files changed, 84 insertions(+), 66 deletions(-) diff --git a/.prettierrc b/.prettierrc index bf357fbb..32ad81f3 100644 --- a/.prettierrc +++ b/.prettierrc @@ -1,3 +1,4 @@ { + "proseWrap": "never", "trailingComma": "all" } diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index f85df1ad..e3998dcc 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -8,8 +8,7 @@ 1. Run `npm install` to install dependencies 1. Create a branch for your PR with `git checkout -b your-branch-name` -> To keep `master` branch pointing to remote repository and make -> pull requests from branches on your fork. To do this, run: +> To keep `master` branch pointing to remote repository and make pull requests from branches on your fork. To do this, run: > > ```sh > git remote add upstream https://github.com/excalidraw/excalidraw.git @@ -25,3 +24,41 @@ 1. Tap on `Fork Sandbox` 1. Write your code 1. Commit and PR automatically + +## Pull Request Guidelines + +Don't worry if you get any of the below wrong, or if you don't know how. We'll gladly help out. + +### Title + +Make sure the title starts with a semantic prefix: + +- **feat**: A new feature +- **fix**: A bug fix +- **improvement**: An improvement to a current feature +- **docs**: Documentation only changes +- **style**: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc) +- **refactor**: A code change that neither fixes a bug nor adds a feature +- **perf**: A code change that improves performance +- **test**: Adding missing tests or correcting existing tests +- **build**: Changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm) +- **ci**: Changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs) +- **chore**: Other changes that don't modify src or test files +- **revert**: Reverts a previous commit + +### Changelog + +Add a brief description of your pull request to the changelog located here: [`src/packages/excalidraw/CHANGELOG.md`](src/packages/excalidraw/CHANGELOG.md) + +Notes: + +- Make sure to prepend to the section corresponding with the semantic prefix you selected in the title +- Link to your pull request - this will require updating the CHANGELOG _after_ creating the pull request + +### Testing + +Once you submit your pull request it will automatically be tested. Be sure to check the results of the test and fix any issues that arise. + +It's also a good idea to consider if your change should include additional tests. This is highly recommended for new features or bug-fixes. For example, it's good practice to create a test for each bug you fix which ensures that we don't regress the code in the future. + +Finally - always manually test your changes using the convenient staging environment deployed for each pull request. As much as local development attempts to replicate production, there can still be subtle differences in behavior. For larger features consider testing your change in multiple browsers as well. diff --git a/README.md b/README.md index 7688c4ea..148812e7 100644 --- a/README.md +++ b/README.md @@ -99,11 +99,9 @@ And the main source of inspiration for starting the project is the awesome [Zwib ## Testimonials - - + - - + @@ -111,8 +109,7 @@ And the main source of inspiration for starting the project is the awesome [Zwib ### Code Contributors -This project exists thanks to all the people who contribute. [[Contribute](CONTRIBUTING.md)]. - +This project exists thanks to all the people who contribute. [[Contribute](CONTRIBUTING.md)]. ### Financial Contributors @@ -126,13 +123,4 @@ Become a financial contributor and help us sustain our community. [[Contribute]( Support this project with your organization. Your logo will show up here with a link to your website. [[Contribute](https://opencollective.com/excalidraw/contribute)] - - - - - - - - - - + diff --git a/src/locales/README.md b/src/locales/README.md index 6ed6bf32..a6113c1a 100644 --- a/src/locales/README.md +++ b/src/locales/README.md @@ -3,12 +3,10 @@ Please do not contribute changes directly to these files, as we manage them with Crowdin. Instead: - to request a new translation, [open an issue](https://github.com/excalidraw/excalidraw/issues/new/choose). -- to update existing translations, [edit them on Crowdin](https://crowdin.com/translate/excalidraw/10) - and we should have them included in the app soon! +- to update existing translations, [edit them on Crowdin](https://crowdin.com/translate/excalidraw/10) and we should have them included in the app soon! ## Completion of translation -[percentages.json](./percentages.json) holds a percentage of completion for each language. We generate these -automatically [on build time](./../../.github/workflows/locales-coverage.yml) when a new translation PR appears. +[percentages.json](./percentages.json) holds a percentage of completion for each language. We generate these automatically [on build time](./../../.github/workflows/locales-coverage.yml) when a new translation PR appears. We only make a language available on the app if it exceeds a certain threshold of completion. diff --git a/src/packages/excalidraw/README.md b/src/packages/excalidraw/README.md index 08245fd2..36c76f66 100644 --- a/src/packages/excalidraw/README.md +++ b/src/packages/excalidraw/README.md @@ -125,22 +125,22 @@ export default function App() { ### Props -| Name | Type | Default | Description | -| --------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------- | -| [`width`](#width) | Number | `window.innerWidth` | The width of Excalidraw component | -| [`height`](#height) | Number | `window.innerHeight` | The height of Excalidraw component | -| [`offsetLeft`](#offsetLeft) | Number | `0` | left position relative to which Excalidraw should be rendered | -| [`offsetTop`](#offsetTop) | Number | `0` | top position relative to which Excalidraw should render | -| [`onChange`](#onChange) | Function | | This callback is triggered whenever the component updates due to any change. This callback will receive the excalidraw elements and the current app state. | -| [`initialData`](#initialData) |
{elements?: ExcalidrawElement[], appState?: AppState } 
| null | The initial data with which app loads. | -| [`user`](#user) | `{ name?: string }` | | User details. The name refers to the name of the user to be shown | -| [`excalidrawRef`](#excalidrawRef) | [`createRef`](https://reactjs.org/docs/refs-and-the-dom.html#creating-refs) or [`callbackRef`](https://reactjs.org/docs/refs-and-the-dom.html#callback-refs) or
{ current: { readyPromise: resolvablePromise } }
| | Ref to be passed to Excalidraw | -| [`onCollabButtonClick`](#onCollabButtonClick) | Function | | Callback to be triggered when the collab button is clicked | -| [`isCollaborating`](#isCollaborating) | `boolean` | | This implies if the app is in collaboration mode | -| [`onPointerUpdate`](#onPointerUpdate) | Function | | Callback triggered when mouse pointer is updated. | -| [`onExportToBackend`](#onExportToBackend) | Function | | Callback triggered when link button is clicked on export dialog | -| [`langCode`](#langCode) | string | `en` | Language code string | -| [`renderFooter `](#renderFooter) | Function | | Function that renders custom UI footer | +| Name | Type | Default | Description | +| --- | --- | --- | --- | +| [`width`](#width) | Number | `window.innerWidth` | The width of Excalidraw component | +| [`height`](#height) | Number | `window.innerHeight` | The height of Excalidraw component | +| [`offsetLeft`](#offsetLeft) | Number | `0` | left position relative to which Excalidraw should be rendered | +| [`offsetTop`](#offsetTop) | Number | `0` | top position relative to which Excalidraw should render | +| [`onChange`](#onChange) | Function | | This callback is triggered whenever the component updates due to any change. This callback will receive the excalidraw elements and the current app state. | +| [`initialData`](#initialData) |
{elements?: ExcalidrawElement[], appState?: AppState } 
| null | The initial data with which app loads. | +| [`user`](#user) | `{ name?: string }` | | User details. The name refers to the name of the user to be shown | +| [`excalidrawRef`](#excalidrawRef) | [`createRef`](https://reactjs.org/docs/refs-and-the-dom.html#creating-refs) or [`callbackRef`](https://reactjs.org/docs/refs-and-the-dom.html#callback-refs) or
{ current: { readyPromise: resolvablePromise } }
| | Ref to be passed to Excalidraw | +| [`onCollabButtonClick`](#onCollabButtonClick) | Function | | Callback to be triggered when the collab button is clicked | +| [`isCollaborating`](#isCollaborating) | `boolean` | | This implies if the app is in collaboration mode | +| [`onPointerUpdate`](#onPointerUpdate) | Function | | Callback triggered when mouse pointer is updated. | +| [`onExportToBackend`](#onExportToBackend) | Function | | Callback triggered when link button is clicked on export dialog | +| [`langCode`](#langCode) | string | `en` | Language code string | +| [`renderFooter `](#renderFooter) | Function | | Function that renders custom UI footer | #### `width` @@ -174,13 +174,12 @@ Here you can try saving the data to your backend or local storage for example. #### `initialData` -This helps to load Excalidraw with `initialData`. -It must be an object or a [promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/Promise) which resolves to an object containing the below optional fields. +This helps to load Excalidraw with `initialData`. It must be an object or a [promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/Promise) which resolves to an object containing the below optional fields. -| name | type | -| -------- | ----------------------------------------------------------------------------------------------------- | +| name | type | +| --- | --- | | elements | [ExcalidrawElement []](https://github.com/excalidraw/excalidraw/blob/master/src/element/types.ts#L78) | -| appState | [AppState](https://github.com/excalidraw/excalidraw/blob/master/src/types.ts#L37) | +| appState | [AppState](https://github.com/excalidraw/excalidraw/blob/master/src/types.ts#L37) | ```json { @@ -219,19 +218,18 @@ This is the user name which shows during collaboration. Defaults to `{name: ''}` #### `excalidrawRef` -You can pass a `ref` when you want to access some excalidraw APIs. -We expose the below APIs: +You can pass a `ref` when you want to access some excalidraw APIs. We expose the below APIs: -| API | signature | Usage | -| -------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | -| ready | `boolean` | This is set to true once Excalidraw is rendered | -| readyPromise | [resolvablePromise](https://github.com/excalidraw/excalidraw/blob/master/src/utils.ts#L317) | This promise will be resolved with the api once excalidraw has rendered. This will be helpful when you want do some action on the host app once this promise resolves. For this to work you will have to pass ref as shown [here](#readyPromise) | -| updateScene |
(sceneData)) => void 
| updates the scene with the sceneData | -| resetScene | `({ resetLoadingState: boolean }) => void` | Resets the scene. If `resetLoadingState` is passed as true then it will also force set the loading state to false. | -| getSceneElementsIncludingDeleted |
 () => ExcalidrawElement []
| Returns all the elements including the deleted in the scene | -| getSceneElements |
 () => ExcalidrawElement []
| Returns all the elements excluding the deleted in the scene | -| history | `{ clear: () => void }` | This is the history API. `history.clear()` will clear the history | -| setScrollToCenter |
 (ExcalidrawElement[]) => void 
| sets the elements to center | +| API | signature | Usage | +| --- | --- | --- | +| ready | `boolean` | This is set to true once Excalidraw is rendered | +| readyPromise | [resolvablePromise](https://github.com/excalidraw/excalidraw/blob/master/src/utils.ts#L317) | This promise will be resolved with the api once excalidraw has rendered. This will be helpful when you want do some action on the host app once this promise resolves. For this to work you will have to pass ref as shown [here](#readyPromise) | +| updateScene |
(sceneData)) => void 
| updates the scene with the sceneData | +| resetScene | `({ resetLoadingState: boolean }) => void` | Resets the scene. If `resetLoadingState` is passed as true then it will also force set the loading state to false. | +| getSceneElementsIncludingDeleted |
 () => ExcalidrawElement []
| Returns all the elements including the deleted in the scene | +| getSceneElements |
 () => ExcalidrawElement []
| Returns all the elements excluding the deleted in the scene | +| history | `{ clear: () => void }` | This is the history API. `history.clear()` will clear the history | +| setScrollToCenter |
 (ExcalidrawElement[]) => void 
| sets the elements to center | #### `readyPromise` @@ -275,17 +273,16 @@ This callback is triggered when the shareable-link button is clicked in the expo #### `langCode` -Determines the language of the UI. It should be one of the [available language codes](https://github.com/excalidraw/excalidraw/blob/master/src/i18n.ts#L14). Defaults to `en` (English). -We also export default language and supported languages which you can import as shown below. +Determines the language of the UI. It should be one of the [available language codes](https://github.com/excalidraw/excalidraw/blob/master/src/i18n.ts#L14). Defaults to `en` (English). We also export default language and supported languages which you can import as shown below. ```js import { defaultLang, languages } from "@excalidraw/excalidraw"; ``` -| name | type | -| ----------- | ---------------------------------------------------------------------------------- | -| defaultLang | string | -| languages | [Language []](https://github.com/excalidraw/excalidraw/blob/master/src/i18n.ts#L8) | +| name | type | +| --- | --- | +| defaultLang | string | +| languages | [Language []](https://github.com/excalidraw/excalidraw/blob/master/src/i18n.ts#L8) | #### `renderFooter` diff --git a/src/packages/utils/CHANGELOG.md b/src/packages/utils/CHANGELOG.md index f706bf97..395b77e7 100644 --- a/src/packages/utils/CHANGELOG.md +++ b/src/packages/utils/CHANGELOG.md @@ -4,6 +4,4 @@ First release of `@excalidraw/utils` to provide utilities functions. -- Added `exportToBlob` and `exportToSvg` to export an Excalidraw diagram definition, respectively, - to a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) and - to a [SVGElement](https://developer.mozilla.org/en-US/docs/Web/API/SVGElement) ([#2246](https://github.com/excalidraw/excalidraw/pull/2246)) +- Added `exportToBlob` and `exportToSvg` to export an Excalidraw diagram definition, respectively, to a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) and to a [SVGElement](https://developer.mozilla.org/en-US/docs/Web/API/SVGElement) ([#2246](https://github.com/excalidraw/excalidraw/pull/2246)) diff --git a/src/packages/utils/README.md b/src/packages/utils/README.md index 204cab5d..15ef2e42 100644 --- a/src/packages/utils/README.md +++ b/src/packages/utils/README.md @@ -24,8 +24,7 @@ Export an Excalidraw diagram to a [SVGElement](https://developer.mozilla.org/en- ## Usage -Excalidraw utils is published as a UMD (Universal Module Definition). -If you are using a Web bundler (for instance, Webpack), you can import it as an ES6 module: +Excalidraw utils is published as a UMD (Universal Module Definition). If you are using a Web bundler (for instance, Webpack), you can import it as an ES6 module: ```js import { exportToSvg, exportToBlob } from "@excalidraw/utils";