| 
									
										
										
										
											2019-06-21 16:19:21 -05:00
										 |  |  | # Electron Documentation Style Guide
 | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | These are the guidelines for writing Electron documentation. | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | ## Headings
 | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:40:55 -07:00
										 |  |  | * Each page must have a single `#`-level title at the top. | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | * Chapters in the same page must have `##`-level headings. | 
					
						
							|  |  |  | * Sub-chapters need to increase the number of `#` in the heading according to | 
					
						
							| 
									
										
										
										
											2016-07-01 14:33:22 +09:00
										 |  |  |   their nesting depth. | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | * The page's title must follow [APA title case][title-case]. | 
					
						
							|  |  |  | * All chapters must follow [APA sentence case][sentence-case]. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | Using `Quick Start` as example: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```markdown | 
					
						
							|  |  |  | # Quick Start
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Main process
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Renderer process
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Run your app
 | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | ... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Run as a distribution
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Manually downloaded Electron binary
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For API references, there are exceptions to this rule. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Markdown rules
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | This repository uses the [`markdownlint`][markdownlint] package to enforce consistent | 
					
						
							|  |  |  | Markdown styling. For the exact rules, see the `.markdownlint.json` file in the root | 
					
						
							|  |  |  | folder. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | There are a few style guidelines that aren't covered by the linter rules: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <!--TODO(erickzhao): make sure this matches with the lint:markdownlint task--> | 
					
						
							| 
									
										
										
										
											2017-11-24 11:13:57 +01:00
										 |  |  | * Use `sh` instead of `cmd` in code blocks (due to the syntax highlighter). | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | * Keep line lengths between 80 and 100 characters if possible for readability | 
					
						
							|  |  |  |   purposes. | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | * No nesting lists more than 2 levels (due to the markdown renderer). | 
					
						
							| 
									
										
										
										
											2016-08-16 14:07:50 -07:00
										 |  |  | * All `js` and `javascript` code blocks are linted with | 
					
						
							| 
									
										
										
										
											2020-11-02 01:58:14 -08:00
										 |  |  | [standard-markdown](https://www.npmjs.com/package/standard-markdown). | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | * For unordered lists, use asterisks instead of dashes. | 
					
						
							| 
									
										
										
										
											2015-09-09 13:33:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | ## Picking words
 | 
					
						
							| 
									
										
										
										
											2015-09-09 13:33:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | * Use "will" over "would" when describing outcomes. | 
					
						
							|  |  |  | * Prefer "in the ___ process" over "on". | 
					
						
							| 
									
										
										
										
											2015-09-09 13:33:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | ## API references
 | 
					
						
							| 
									
										
										
										
											2015-09-09 13:33:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | The following rules only apply to the documentation of APIs. | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | ### Title and description
 | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | Each module's API doc must use the actual object name returned by `require('electron')` | 
					
						
							|  |  |  | as its title (such as `BrowserWindow`, `autoUpdater`, and `session`). | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | Directly under the page title, add a one-line description of the module | 
					
						
							|  |  |  | as a markdown quote (beginning with `>`). | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | Using the `session` module as an example: | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```markdown | 
					
						
							|  |  |  | # session
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | > Manage browser sessions, cookies, cache, proxy settings, etc.
 | 
					
						
							| 
									
										
										
										
											2016-06-17 12:26:08 -07:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | ### Module methods and events
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For modules that are not classes, their methods and events must be listed under | 
					
						
							| 
									
										
										
										
											2016-06-24 12:40:55 -07:00
										 |  |  | the `## Methods` and `## Events` chapters. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | Using `autoUpdater` as an example: | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```markdown | 
					
						
							|  |  |  | # autoUpdater
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Events
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Event: 'error'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Methods
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### `autoUpdater.setFeedURL(url[, requestHeaders])`
 | 
					
						
							| 
									
										
										
										
											2016-06-17 12:26:08 -07:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | ### Classes
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-01 14:30:55 +09:00
										 |  |  | * API classes or classes that are part of modules must be listed under a | 
					
						
							| 
									
										
										
										
											2016-06-24 12:40:55 -07:00
										 |  |  |   `## Class: TheClassName` chapter. | 
					
						
							| 
									
										
										
										
											2016-07-01 14:30:55 +09:00
										 |  |  | * One page can have multiple classes. | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | * Constructors must be listed with `###`-level headings. | 
					
						
							|  |  |  | * [Static Methods](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes/static) | 
					
						
							|  |  |  |   must be listed under a `### Static Methods` chapter. | 
					
						
							|  |  |  | * [Instance Methods](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes#Prototype_methods) | 
					
						
							|  |  |  |   must be listed under an `### Instance Methods` chapter. | 
					
						
							|  |  |  | * All methods that have a return value must start their description with | 
					
						
							| 
									
										
										
										
											2023-01-16 01:22:49 -08:00
										 |  |  |   "Returns `[TYPE]` - \[Return description]" | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  |   * If the method returns an `Object`, its structure can be specified using a colon | 
					
						
							|  |  |  |     followed by a newline then an unordered list of properties in the same style as | 
					
						
							|  |  |  |     function parameters. | 
					
						
							| 
									
										
										
										
											2016-07-12 22:00:28 -07:00
										 |  |  | * Instance Events must be listed under an `### Instance Events` chapter. | 
					
						
							|  |  |  | * Instance Properties must be listed under an `### Instance Properties` chapter. | 
					
						
							| 
									
										
										
										
											2023-01-16 01:22:49 -08:00
										 |  |  |   * Instance Properties must start with "A \[Property Type] ..." | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:40:55 -07:00
										 |  |  | Using the `Session` and `Cookies` classes as an example: | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```markdown | 
					
						
							|  |  |  | # session
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Methods
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### session.fromPartition(partition)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-15 10:15:32 -07:00
										 |  |  | ## Static Properties
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ### session.defaultSession
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Class: Session
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Instance Events
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Event: 'will-download'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Instance Methods
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-08 14:42:03 -08:00
										 |  |  | #### `ses.getCacheSize()`
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ### Instance Properties
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### `ses.cookies`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Class: Cookies
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Instance Methods
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### `cookies.get(filter, callback)`
 | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | ### Methods and their arguments
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | The methods chapter must be in the following form: | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```markdown | 
					
						
							|  |  |  | ### `objectName.methodName(required[, optional]))`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `required` string - A parameter description. | 
					
						
							| 
									
										
										
										
											2016-12-29 14:11:26 -08:00
										 |  |  | * `optional` Integer (optional) - Another parameter description. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | #### Heading level
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The heading can be `###` or `####`-levels depending on whether the method | 
					
						
							|  |  |  | belongs to a module or a class. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Function signature
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 15:59:30 -07:00
										 |  |  | For modules, the `objectName` is the module's name. For classes, it must be the | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | name of the instance of the class, and must not be the same as the module's | 
					
						
							|  |  |  | name. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | For example, the methods of the `Session` class under the `session` module must | 
					
						
							|  |  |  | use `ses` as the `objectName`. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | Optional arguments are notated by square brackets `[]` surrounding the optional | 
					
						
							|  |  |  | argument as well as the comma required if this optional argument follows another | 
					
						
							| 
									
										
										
										
											2016-06-24 15:59:30 -07:00
										 |  |  | argument: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | ```markdown | 
					
						
							| 
									
										
										
										
											2016-06-24 15:59:30 -07:00
										 |  |  | required[, optional] | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | #### Argument descriptions
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | More detailed information on each of the arguments is noted in an unordered list | 
					
						
							|  |  |  | below the method. The type of argument is notated by either JavaScript primitives | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | (e.g. `string`, `Promise`, or `Object`), a custom API structure like Electron's | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | [`Cookie`](api/structures/cookie.md), or the wildcard `any`. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If the argument is of type `Array`, use `[]` shorthand with the type of value | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | inside the array (for example,`any[]` or `string[]`). | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | If the argument is of type `Promise`, parametrize the type with what the promise | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | resolves to (for example, `Promise<void>` or `Promise<string>`). | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | If an argument can be of multiple types, separate the types with `|`. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The description for `Function` type arguments should make it clear how it may be | 
					
						
							|  |  |  | called and list the types of the parameters that will be passed to it. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Platform-specific functionality
 | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | If an argument or a method is unique to certain platforms, those platforms are | 
					
						
							|  |  |  | denoted using a space-delimited italicized list following the datatype. Values | 
					
						
							| 
									
										
										
										
											2018-05-12 18:12:28 +10:00
										 |  |  | can be `macOS`, `Windows` or `Linux`. | 
					
						
							| 
									
										
										
										
											2016-06-17 12:33:50 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | ```markdown | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `animate` boolean (optional) _macOS_ _Windows_ - Animate the thing. | 
					
						
							| 
									
										
										
										
											2016-06-17 12:33:50 -07:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | ### Events
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | The events chapter must be in following form: | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | ```markdown | 
					
						
							|  |  |  | ### Event: 'wake-up'
 | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Returns: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `time` string | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							| 
									
										
										
										
											2016-06-17 12:26:08 -07:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | The heading can be `###` or `####`-levels depending on whether the event | 
					
						
							|  |  |  | belongs to a module or a class. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:40:55 -07:00
										 |  |  | The arguments of an event follow the same rules as methods. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ### Properties
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 12:28:41 -07:00
										 |  |  | The properties chapter must be in following form: | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```markdown | 
					
						
							|  |  |  | ### session.defaultSession
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ... | 
					
						
							| 
									
										
										
										
											2015-08-22 14:07:45 +02:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | The heading can be `###` or `####`-levels depending on whether the property | 
					
						
							|  |  |  | belongs to a module or a class. | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-19 14:13:55 -07:00
										 |  |  | ## API History
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | An "API History" block is a YAML code block encapsulated by an HTML comment that | 
					
						
							|  |  |  | should be placed directly after the Markdown header for a class or method, like so: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | `````markdown | 
					
						
							|  |  |  | #### `win.setTrafficLightPosition(position)` _macOS_
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <!--
 | 
					
						
							|  |  |  | ```YAML history | 
					
						
							|  |  |  | added: | 
					
						
							|  |  |  |   - pr-url: https://github.com/electron/electron/pull/22533 | 
					
						
							|  |  |  | changes: | 
					
						
							|  |  |  |   - pr-url: https://github.com/electron/electron/pull/26789 | 
					
						
							|  |  |  |     description: "Made `trafficLightPosition` option work for `customButtonOnHover` window." | 
					
						
							|  |  |  | deprecated: | 
					
						
							|  |  |  |   - pr-url: https://github.com/electron/electron/pull/37094 | 
					
						
							|  |  |  |     breaking-changes-header: deprecated-browserwindowsettrafficlightpositionposition | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | --> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `position` [Point](structures/point.md) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Set a custom position for the traffic light buttons. Can only be used with `titleBarStyle` set to `hidden`. | 
					
						
							|  |  |  | ````` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | It should adhere to the API History [JSON Schema](https://json-schema.org/) | 
					
						
							|  |  |  | (`api-history.schema.json`) which you can find in the `docs` folder. | 
					
						
							|  |  |  | The [API History Schema RFC][api-history-schema-rfc] includes example usage and detailed | 
					
						
							|  |  |  | explanations for each aspect of the schema. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The purpose of the API History block is to describe when/where/how/why an API was: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * Added | 
					
						
							|  |  |  | * Changed (usually breaking changes) | 
					
						
							|  |  |  | * Deprecated | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Each API change listed in the block should include a link to the | 
					
						
							|  |  |  | PR where that change was made along with an optional short description of the | 
					
						
							|  |  |  | change. If applicable, include the [heading id](https://gist.github.com/asabaylus/3071099) | 
					
						
							|  |  |  | for that change from the [breaking changes documentation](./breaking-changes.md). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The [API History linting script][api-history-linting-script] (`lint:api-history`) | 
					
						
							|  |  |  | validates API History blocks in the Electron documentation against the schema and | 
					
						
							|  |  |  | performs some other checks. You can look at its [tests][api-history-tests] for more | 
					
						
							|  |  |  | details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | There are a few style guidelines that aren't covered by the linting script: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Format
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Always adhere to this format: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ```markdown | 
					
						
							|  |  |  |   API HEADER                  |  #### `win.flashFrame(flag)` | 
					
						
							|  |  |  |   BLANK LINE                  |  | 
					
						
							|  |  |  |   HTML COMMENT OPENING TAG    |  <!--
 | 
					
						
							|  |  |  |   API HISTORY OPENING TAG     |  ```YAML history | 
					
						
							|  |  |  |   API HISTORY                 |  added: | 
					
						
							|  |  |  |                               |    - pr-url: https://github.com/electron/electron/pull/22533 | 
					
						
							|  |  |  |   API HISTORY CLOSING TAG     |  ``` | 
					
						
							|  |  |  |   HTML COMMENT CLOSING TAG    |  --> | 
					
						
							|  |  |  |   BLANK LINE                  | | 
					
						
							|  |  |  |   ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### YAML
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * Use two spaces for indentation. | 
					
						
							|  |  |  | * Do not use comments. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Descriptions
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * Always wrap descriptions with double quotation marks (i.e. "example"). | 
					
						
							|  |  |  |   * [Certain special characters (e.g. `[`, `]`) can break YAML parsing](https:/stackoverflow.com/a/37015689/19020549). | 
					
						
							|  |  |  | * Describe the change in a way relevant to app developers and make it | 
					
						
							|  |  |  |   capitalized, punctuated, and past tense. | 
					
						
							|  |  |  |   * Refer to [Clerk](https://github.com/electron/clerk/blob/main/README.md#examples) | 
					
						
							|  |  |  |     for examples. | 
					
						
							|  |  |  | * Keep descriptions concise. | 
					
						
							|  |  |  |   * Ideally, a description will match its corresponding header in the | 
					
						
							|  |  |  |     breaking changes document. | 
					
						
							|  |  |  |   * Favor using the release notes from the associated PR whenever possible. | 
					
						
							|  |  |  |   * Developers can always view the breaking changes document or linked | 
					
						
							|  |  |  |     pull request for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Placement
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Generally, you should place the API History block directly after the Markdown header | 
					
						
							|  |  |  | for a class or method that was changed. However, there are some instances where this | 
					
						
							|  |  |  | is ambiguous: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Chromium bump
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * [chore: bump chromium to 122.0.6194.0 (main)](https://github.com/electron/electron/pull/40750) | 
					
						
							|  |  |  |   * [Behavior Changed: cross-origin iframes now use Permission Policy to access features][api-history-cross-origin] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Sometimes a breaking change doesn't relate to any of the existing APIs. In this | 
					
						
							|  |  |  | case, it is ok not to add API History anywhere. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Change affecting multiple APIs
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * [refactor: ensure IpcRenderer is not bridgable](https://github.com/electron/electron/pull/40330) | 
					
						
							|  |  |  |   * [Behavior Changed: ipcRenderer can no longer be sent over the contextBridge][api-history-ipc-renderer] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Sometimes a breaking change involves multiple APIs. In this case, place the | 
					
						
							|  |  |  | API History block under the top-level Markdown header for each of the | 
					
						
							|  |  |  | involved APIs. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | `````markdown | 
					
						
							|  |  |  | # contextBridge
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <!--
 | 
					
						
							|  |  |  | ```YAML history | 
					
						
							|  |  |  | changes: | 
					
						
							|  |  |  |   - pr-url: https://github.com/electron/electron/pull/40330 | 
					
						
							|  |  |  |     description: "`ipcRenderer` can no longer be sent over the `contextBridge`" | 
					
						
							|  |  |  |     breaking-changes-header: behavior-changed-ipcrenderer-can-no-longer-be-sent-over-the-contextbridge | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | --> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | > Create a safe, bi-directional, synchronous bridge across isolated contexts
 | 
					
						
							|  |  |  | ````` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | `````markdown | 
					
						
							|  |  |  | # ipcRenderer
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <!--
 | 
					
						
							|  |  |  | ```YAML history | 
					
						
							|  |  |  | changes: | 
					
						
							|  |  |  |   - pr-url: https://github.com/electron/electron/pull/40330 | 
					
						
							|  |  |  |     description: "`ipcRenderer` can no longer be sent over the `contextBridge`" | 
					
						
							|  |  |  |     breaking-changes-header: behavior-changed-ipcrenderer-can-no-longer-be-sent-over-the-contextbridge | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | --> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Process: [Renderer](../glossary.md#renderer-process) | 
					
						
							|  |  |  | ````` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Notice how an API History block wasn't added under: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `contextBridge.exposeInMainWorld(apiKey, api)` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | since that function wasn't changed, only how it may be used: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```patch | 
					
						
							|  |  |  |   contextBridge.exposeInMainWorld('app', { | 
					
						
							|  |  |  | -   ipcRenderer, | 
					
						
							|  |  |  | +   onEvent: (cb) => ipcRenderer.on('foo', (e, ...args) => cb(args)) | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | ## Documentation translations
 | 
					
						
							| 
									
										
										
										
											2016-06-24 10:45:37 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-02 12:05:49 -08:00
										 |  |  | See [electron/i18n](https://github.com/electron/i18n#readme) | 
					
						
							| 
									
										
										
										
											2021-05-18 19:55:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | [title-case]: https://apastyle.apa.org/style-grammar-guidelines/capitalization/title-case | 
					
						
							|  |  |  | [sentence-case]: https://apastyle.apa.org/style-grammar-guidelines/capitalization/sentence-case | 
					
						
							|  |  |  | [markdownlint]: https://github.com/DavidAnson/markdownlint | 
					
						
							| 
									
										
										
										
											2024-08-19 14:13:55 -07:00
										 |  |  | [api-history-schema-rfc]: https://github.com/electron/rfcs/blob/f36e0a8483e1ea844710890a8a7a1bd58ecbac05/text/0004-api-history-schema.md | 
					
						
							|  |  |  | [api-history-linting-script]: https://github.com/electron/lint-roller/blob/3030970136ec6b41028ef973f944d3e5cad68e1c/bin/lint-markdown-api-history.ts | 
					
						
							|  |  |  | [api-history-tests]: https://github.com/electron/lint-roller/blob/main/tests/lint-roller-markdown-api-history.spec.ts | 
					
						
							|  |  |  | [api-history-cross-origin]: https://github.com/electron/electron/blob/f508f6b6b570481a2b61d8c4f8c1951f492e4309/docs/breaking-changes.md#behavior-changed-cross-origin-iframes-now-use-permission-policy-to-access-features | 
					
						
							|  |  |  | [api-history-ipc-renderer]: https://github.com/electron/electron/blob/f508f6b6b570481a2b61d8c4f8c1951f492e4309/docs/breaking-changes.md#behavior-changed-ipcrenderer-can-no-longer-be-sent-over-the-contextbridge |