Summary: Bumps [typescript-eslint/parser](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/parser) from 5.13.0 to 5.14.0. <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/typescript-eslint/typescript-eslint/releases"><code>@typescript-eslint/parser</code>'s releases</a>.</em></p> <blockquote> <h2>v5.14.0</h2> <h1><a href="https://github.com/typescript-eslint/typescript-eslint/compare/v5.13.0...v5.14.0">5.14.0</a> (2022-03-07)</h1> <h3>Bug Fixes</h3> <ul> <li><strong>eslint-plugin:</strong> [naming-convention] cover case that requires quotes (<a href="https://github-redirect.dependabot.com/typescript-eslint/typescript-eslint/issues/4582">#4582</a>) (<a href="3ea09477de">3ea0947</a>)</li> <li><strong>eslint-plugin:</strong> [no-misused-promises] factor thenable returning function overload signatures (<a href="https://github-redirect.dependabot.com/typescript-eslint/typescript-eslint/issues/4620">#4620</a>) (<a href="56a09e98f1">56a09e9</a>)</li> <li><strong>eslint-plugin:</strong> [prefer-readonly-parameter-types] handle class sharp private field and member without throwing error (<a href="https://github-redirect.dependabot.com/typescript-eslint/typescript-eslint/issues/4343">#4343</a>) (<a href="a65713ae13">a65713a</a>)</li> <li><strong>eslint-plugin:</strong> [return-await] correct autofixer in binary expression (<a href="https://github-redirect.dependabot.com/typescript-eslint/typescript-eslint/issues/4401">#4401</a>) (<a href="5fa2fade38">5fa2fad</a>)</li> </ul> <h3>Features</h3> <ul> <li><strong>eslint-plugin:</strong> [no-misused-promises] add granular options within <code>checksVoidReturns</code> (<a href="https://github-redirect.dependabot.com/typescript-eslint/typescript-eslint/issues/4623">#4623</a>) (<a href="1085177269">1085177</a>)</li> <li>TypeScript 4.6 (<a href="https://github-redirect.dependabot.com/typescript-eslint/typescript-eslint/issues/4615">#4615</a>) (<a href="a02c63a264">a02c63a</a>)</li> </ul> </blockquote> </details> <details> <summary>Changelog</summary> <p><em>Sourced from <a href="https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/parser/CHANGELOG.md"><code>@typescript-eslint/parser</code>'s changelog</a>.</em></p> <blockquote> <h1><a href="https://github.com/typescript-eslint/typescript-eslint/compare/v5.13.0...v5.14.0">5.14.0</a> (2022-03-07)</h1> <p><strong>Note:</strong> Version bump only for package <code>@typescript-eslint/parser</code></p> </blockquote> </details> <details> <summary>Commits</summary> <ul> <li><a href="9752382d4c"><code>9752382</code></a> chore: publish v5.14.0</li> <li><a href="fa381f349c"><code>fa381f3</code></a> chore: use swc for tests instead of Babel (<a href="https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/parser/issues/4584">#4584</a>)</li> <li>See full diff in <a href="https://github.com/typescript-eslint/typescript-eslint/commits/v5.14.0/packages/parser">compare view</a></li> </ul> </details> <br /> [](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `dependabot rebase` will rebase this PR - `dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `dependabot merge` will merge this PR after your CI passes on it - `dependabot squash and merge` will squash and merge this PR after your CI passes on it - `dependabot cancel merge` will cancel a previously requested merge and block automerging - `dependabot reopen` will reopen this PR if it is closed - `dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) </details> Pull Request resolved: https://github.com/facebook/flipper/pull/3529 Reviewed By: mweststrate Differential Revision: D34867448 Pulled By: lblasa fbshipit-source-id: 7ff070bf68020b3aebeadfa0eee8d6da07883ba3
js-flipper
This package exposes JavaScript bindings to talk from web / Node.js directly to flipper.
Installation
yarn add js-flipper
Usage
How to build Flipper plugins is explained in the flipper documentation: Creating a Flipper plugin. Building a Flipper plugin involves building a plugin for the Desktop app, and a plugin that runs on a Device (web or Node.js). This package is only needed for the plugin that runs on the device (web / Node.js), and wants to use the WebSocket connection to communicate to Flipper.
This package exposes a flipperClient. It has:
addPluginmethod. It accepts apluginparameter, that registers a client plugin and will fire the relevant callbacks if the corresponding desktop plugin is selected in the Flipper Desktop. The full plugin API is documented here.startmethod. It starts the client. It has two arguments:appName- (required) the name dsplayed in Flipperoptionswhich conforms to the infterfaceinterface FlipperClientOptions { // Make the client connect to a different URL urlBase?: string; // Override WebSocket implementation (Node.js folks, it is for you!) websocketFactory?: (url: string) => FlipperWebSocket; // Override how errors are handled (it is simple `console.error` by default) onError?: (e: unknown) => void; // Timeout after which client tries to reconnect to Flipper reconnectTimeout?: number; }
Example (web)
An example plugin can be found in FlipperTicTacToe.js.
The corresponding Desktop plugin ships by default in Flipper, so importing the
above file and dropping the <FlipperTicTacToe /> component somewhere in your
application should work out of the box.
The sources of the corresponding Desktop plugin can be found here.
Node.js
Node.js does not have a built-in WebSocket implementation. You need to install any implmentation of WebSockets for Node.js that is compatible with the interface of the web version.
import flipperClient from 'js-flipper';
// Say, you decided to go with 'ws'
// https://github.com/websockets/ws
import WebSocket from 'ws';
// Start the client and pass some options
// You might ask yourself why there is the second argument `{ origin: 'localhost:' }`
// Flipper Desktop verifies the `Origin` header for every WS connection. You need to set it to one of the whitelisted values (see `VALID_WEB_SOCKET_REQUEST_ORIGIN_PREFIXES`).
flipperClient.start('My cool nodejs app', { websocketFactory: url => new WebSocket(url, {origin: 'localhost:'}) });
An example plugin should be somewhat similar to what we have for React. It is currently WIP (do not confuse with RIP!).