From 3bd3ad45f9eb5fecb1eaf13f36843b4edfa6519c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Wed, 20 Jan 2021 10:52:44 +0100 Subject: [PATCH 01/13] =?UTF-8?q?=E2=9C=A8=20import=20dev=20extension?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- LICENSE-3rdparty.csv | 9 + package.json | 2 +- packages/developer-extension/.gitignore | 1 + packages/developer-extension/README.md | 35 + packages/developer-extension/icons/icon.png | Bin 0 -> 8252 bytes packages/developer-extension/manifest.json | 16 + packages/developer-extension/package.json | 22 + .../src/background/actions.ts | 5 + .../src/background/constants.ts | 3 + .../src/background/domain/endSession.ts | 8 + .../src/background/domain/flushEvents.ts | 13 + .../src/background/domain/logRequests.ts | 64 + .../src/background/domain/replaceBundles.ts | 51 + .../src/background/index.ts | 4 + .../src/background/store.ts | 30 + .../src/background/utils.ts | 21 + .../developer-extension/src/common/actions.ts | 43 + .../developer-extension/src/common/types.ts | 17 + .../developer-extension/src/popup/App.tsx | 31 + .../developer-extension/src/popup/Panel.tsx | 36 + .../developer-extension/src/popup/actions.ts | 5 + .../developer-extension/src/popup/index.tsx | 8 + .../developer-extension/src/popup/useStore.ts | 35 + packages/developer-extension/tsconfig.json | 14 + .../developer-extension/webpack.config.js | 62 + scripts/cli | 5 +- tsconfig.json | 3 +- yarn.lock | 1202 ++++++++++++++++- 28 files changed, 1727 insertions(+), 18 deletions(-) create mode 100644 packages/developer-extension/.gitignore create mode 100644 packages/developer-extension/README.md create mode 100644 packages/developer-extension/icons/icon.png create mode 100644 packages/developer-extension/manifest.json create mode 100644 packages/developer-extension/package.json create mode 100644 packages/developer-extension/src/background/actions.ts create mode 100644 packages/developer-extension/src/background/constants.ts create mode 100644 packages/developer-extension/src/background/domain/endSession.ts create mode 100644 packages/developer-extension/src/background/domain/flushEvents.ts create mode 100644 packages/developer-extension/src/background/domain/logRequests.ts create mode 100644 packages/developer-extension/src/background/domain/replaceBundles.ts create mode 100644 packages/developer-extension/src/background/index.ts create mode 100644 packages/developer-extension/src/background/store.ts create mode 100644 packages/developer-extension/src/background/utils.ts create mode 100644 packages/developer-extension/src/common/actions.ts create mode 100644 packages/developer-extension/src/common/types.ts create mode 100644 packages/developer-extension/src/popup/App.tsx create mode 100644 packages/developer-extension/src/popup/Panel.tsx create mode 100644 packages/developer-extension/src/popup/actions.ts create mode 100644 packages/developer-extension/src/popup/index.tsx create mode 100644 packages/developer-extension/src/popup/useStore.ts create mode 100644 packages/developer-extension/tsconfig.json create mode 100644 packages/developer-extension/webpack.config.js diff --git a/LICENSE-3rdparty.csv b/LICENSE-3rdparty.csv index 41626ecab9..d0d0c89b8d 100644 --- a/LICENSE-3rdparty.csv +++ b/LICENSE-3rdparty.csv @@ -3,11 +3,17 @@ require,tslib,Apache-2.0,Copyright Microsoft Corporation file,pako,MIT,(C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin file,rrweb,MIT,Copyright (c) 2018 Contributors (https://github.com/rrweb-io/rrweb/graphs/contributors) and SmartX Inc. file,tracekit,MIT,Copyright 2013 Onur Can Cakmak and all TraceKit contributors +prod,bumbag,MIT,Copyright (c) 2020 Bumbag Enterprises +prod,react,MIT,Copyright (c) Facebook, Inc. and its affiliates. +prod,react-dom,MIT,Copyright (c) Facebook, Inc. and its affiliates. prod,rrweb-snapshot,MIT,Copyright (c) 2018 Contributors (https://github.com/rrweb-io/rrweb-snapshot/graphs/contributors) and SmartX Inc. +dev,@types/chrome,MIT,Copyright Microsoft Corporation dev,@types/connect-busboy,MIT,Copyright Microsoft Corporation dev,@types/cors,MIT,Copyright Microsoft Corporation dev,@types/express,MIT,Copyright Microsoft Corporation dev,@types/jasmine,MIT,Copyright Microsoft Corporation +dev,@types/react,MIT,Copyright Microsoft Corporation +dev,@types/react-dom,MIT,Copyright Microsoft Corporation dev,@types/sinon,MIT,Copyright Microsoft Corporation dev,@wdio/browserstack-service,MIT,Copyright JS Foundation and other contributors dev,@wdio/cli,MIT,Copyright JS Foundation and other contributors @@ -21,9 +27,11 @@ dev,ajv,MIT,Copyright 2015-2017 Evgeny Poberezkin dev,browserstack-local,MIT,Copyright 2016 BrowserStack dev,codecov,MIT,Copyright 2014 Gregg Caines dev,connect-busboy,MIT,Copyright Brian White +dev,copy-webpack-plugin,MIT,Copyright JS Foundation and other contributors dev,cors,MIT,Copyright 2013 Troy Goode dev,emoji-name-map,MIT,Copyright 2016-19 Ionică Bizău (https://ionicabizau.net) dev,express,MIT,Copyright 2009-2014 TJ Holowaychuk 2013-2014 Roman Shtylman 2014-2015 Douglas Christopher Wilson +dev,html-webpack-plugin,MIT,Copyright JS Foundation and other contributors dev,istanbul-instrumenter-loader,MIT,Copyright JS Foundation and other contributors dev,jasmine-core,MIT,Copyright 2008-2017 Pivotal Labs dev,js-polyfills,Unlicense, @@ -56,3 +64,4 @@ dev,webdriverio,MIT,Copyright JS Foundation and other contributors dev,webpack,MIT,Copyright JS Foundation and other contributors dev,webpack-cli,MIT,Copyright JS Foundation and other contributors dev,webpack-dev-middleware,MIT,Copyright JS Foundation and other contributors +dev,webpack-webextension-plugin,MIT,Copyright 2018 Henrik Wenz (handtrix@gmail.com) diff --git a/package.json b/package.json index 161d81d27a..f968e7e917 100644 --- a/package.json +++ b/package.json @@ -11,7 +11,7 @@ "build:bundle": "lerna run build:bundle --stream", "format": "prettier --check .", "lint": "scripts/cli lint . && scripts/cli lint test/e2e", - "typecheck": "scripts/cli typecheck . && scripts/cli typecheck test/e2e", + "typecheck": "scripts/cli typecheck", "dev": "node scripts/dev-server.js", "release": "lerna version --exact", "version": "node ./scripts/generate-changelog.js", diff --git a/packages/developer-extension/.gitignore b/packages/developer-extension/.gitignore new file mode 100644 index 0000000000..178135c2b2 --- /dev/null +++ b/packages/developer-extension/.gitignore @@ -0,0 +1 @@ +/dist/ diff --git a/packages/developer-extension/README.md b/packages/developer-extension/README.md new file mode 100644 index 0000000000..7662a26ab1 --- /dev/null +++ b/packages/developer-extension/README.md @@ -0,0 +1,35 @@ +# Browser SDK developer extension + +Browser extension to investigate your Browser SDK integration. + +## Getting started + +The extension is not (yet?) published on addons store. You will need to clone this repository and +build the extension manually. + +``` +$ git clone https://github.com/DataDog/browser-sdk +$ cd browser-sdk +$ yarn +$ cd packages/developer-extension +$ yarn build +``` + +Then, in Google Chrome: + +- Open the _Extension Management_ page by navigating to [chrome://extensions](chrome://extensions). +- Enable _Developer Mode_ by clicking the toggle switch next to _Developer mode_. +- Click the _LOAD UNPACKED_ button and select the `browser-sdk/packages/developer-extension/dist` + directory. + +## Features + +- Log events sent by the SDK in the devtools console +- Flush buffered events +- End current session +- Load the SDK development bundles instead of production ones +- Switch between `datadog-rum.js` and `datadog-rum-recorder.js` bundles + +## Browser compatibility + +For now, only Google Chrome is supported. diff --git a/packages/developer-extension/icons/icon.png b/packages/developer-extension/icons/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..a3eb9907848a49705228374e3bb4fbbec110be38 GIT binary patch literal 8252 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 OfU<&`e3_g{(EkANfo{D3 literal 0 HcmV?d00001 diff --git a/packages/developer-extension/manifest.json b/packages/developer-extension/manifest.json new file mode 100644 index 0000000000..e803b19a7b --- /dev/null +++ b/packages/developer-extension/manifest.json @@ -0,0 +1,16 @@ +{ + "manifest_version": 2, + "name": "Datadog Browser SDK developer extension", + "permissions": ["", "tabs", "webRequest", "webRequestBlocking", "storage"], + "icons": { + "256": "icon.png" + }, + "background": { + "scripts": ["background.js"], + "persistent": true + }, + "browser_action": { + "default_title": "Browser SDK extension", + "default_popup": "popup.html" + } +} diff --git a/packages/developer-extension/package.json b/packages/developer-extension/package.json new file mode 100644 index 0000000000..e250ba879c --- /dev/null +++ b/packages/developer-extension/package.json @@ -0,0 +1,22 @@ +{ + "name": "@datadog/browser-sdk-developer-extension", + "version": "1.0.0", + "private": true, + "scripts": { + "build": "rm -rf dist && webpack --mode production", + "dev": "webpack --mode development --watch" + }, + "devDependencies": { + "@types/chrome": "0.0.125", + "@types/react": "16", + "@types/react-dom": "16", + "copy-webpack-plugin": "6", + "html-webpack-plugin": "4.5.1", + "webpack-webextension-plugin": "0.3.0" + }, + "dependencies": { + "bumbag": "1.6.12", + "react": "16", + "react-dom": "16" + } +} diff --git a/packages/developer-extension/src/background/actions.ts b/packages/developer-extension/src/background/actions.ts new file mode 100644 index 0000000000..4301d96908 --- /dev/null +++ b/packages/developer-extension/src/background/actions.ts @@ -0,0 +1,5 @@ +import { createListenAction, createSendAction } from '../common/actions' +import { BackgroundActions, PopupActions } from '../common/types' + +export const listenAction = createListenAction() +export const sendAction = createSendAction() diff --git a/packages/developer-extension/src/background/constants.ts b/packages/developer-extension/src/background/constants.ts new file mode 100644 index 0000000000..931939ea2c --- /dev/null +++ b/packages/developer-extension/src/background/constants.ts @@ -0,0 +1,3 @@ +export const DEV_LOGS_URL = 'http://localhost:8080/datadog-logs.js' +export const DEV_RUM_RECORDER_URL = 'http://localhost:8080/datadog-rum-recorder.js' +export const DEV_RUM_URL = 'http://localhost:8080/datadog-rum.js' diff --git a/packages/developer-extension/src/background/domain/endSession.ts b/packages/developer-extension/src/background/domain/endSession.ts new file mode 100644 index 0000000000..576e72cfe2 --- /dev/null +++ b/packages/developer-extension/src/background/domain/endSession.ts @@ -0,0 +1,8 @@ +import { listenAction } from '../actions' +import { evaluateCodeInActiveTab } from '../utils' + +listenAction('endSession', () => { + evaluateCodeInActiveTab(` + document.cookie = '_dd_s=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/' + `) +}) diff --git a/packages/developer-extension/src/background/domain/flushEvents.ts b/packages/developer-extension/src/background/domain/flushEvents.ts new file mode 100644 index 0000000000..8b20319752 --- /dev/null +++ b/packages/developer-extension/src/background/domain/flushEvents.ts @@ -0,0 +1,13 @@ +import { listenAction } from '../actions' +import { evaluateCodeInActiveTab } from '../utils' + +listenAction('flushEvents', () => + // Simulates a brief page visibility change (visible > hide > visible) + evaluateCodeInActiveTab(` + const descriptor = Object.getOwnPropertyDescriptor(Document.prototype, 'visibilityState') + Object.defineProperty(Document.prototype, 'visibilityState', { value: 'hidden' }) + document.dispatchEvent(new Event('visibilitychange', { bubbles: true })) + Object.defineProperty(Document.prototype, 'visibilityState', descriptor) + document.dispatchEvent(new Event('visibilitychange', { bubbles: true })) + `) +) diff --git a/packages/developer-extension/src/background/domain/logRequests.ts b/packages/developer-extension/src/background/domain/logRequests.ts new file mode 100644 index 0000000000..a5d8642da1 --- /dev/null +++ b/packages/developer-extension/src/background/domain/logRequests.ts @@ -0,0 +1,64 @@ +import { store } from '../store' + +const decoder = new TextDecoder('utf-8') +chrome.webRequest.onBeforeRequest.addListener( + (info) => { + if (!store.logEvents) { + return + } + if (info.tabId < 0) { + console.log('Some intake request was made in a non-tab context... (service worker maybe?)') + return + } + + const url = new URL(info.url) + + const intake = url.hostname.match(/^\w*/)?.[0] + if (!intake) { + return + } + if (!info.requestBody.raw) { + return + } + + for (const rawBody of info.requestBody.raw!) { + if (rawBody.bytes) { + const decodedBody = decoder.decode(rawBody.bytes) + for (const rawEvent of decodedBody.split('\n')) { + const event = sortProperties(JSON.parse(rawEvent)) + chrome.tabs.executeScript(info.tabId, { + code: `console.info("Browser-SDK:", ${JSON.stringify(intake)}, ${JSON.stringify(event)});`, + }) + } + } + } + }, + { + urls: [ + // TODO: implement a configuration page to add more URLs in this list. + 'https://*.logs.datadoghq.com/*', + 'https://*.browser-intake-datadoghq.com/*', + 'https://*.logs.datadoghq.eu/*', + 'https://*.browser-intake-datadoghq.eu/*', + ], + }, + ['requestBody'] +) + +function sortProperties(event: T): T { + if (Array.isArray(event)) { + return event.map(sortProperties) as T + } + + if (typeof event === 'object' && event !== null) { + const names = Object.getOwnPropertyNames(event) + names.sort() + const result: { [key: string]: unknown } = {} + names.forEach((name) => { + result[name] = sortProperties((event as { [key: string]: unknown })[name]) + }) + return result as T + } + + return event +} diff --git a/packages/developer-extension/src/background/domain/replaceBundles.ts b/packages/developer-extension/src/background/domain/replaceBundles.ts new file mode 100644 index 0000000000..9e3f05ed52 --- /dev/null +++ b/packages/developer-extension/src/background/domain/replaceBundles.ts @@ -0,0 +1,51 @@ +import { listenAction } from '../actions' +import { DEV_LOGS_URL, DEV_RUM_RECORDER_URL, DEV_RUM_URL } from '../constants' +import { setStore, store } from '../store' + +chrome.webRequest.onBeforeRequest.addListener( + (info) => { + if (store.useDevBundles) { + const url = new URL(info.url) + if (url.pathname.includes('logs')) { + return { redirectUrl: DEV_LOGS_URL } + } + if (url.pathname.includes('rum')) { + return { + redirectUrl: store.useRumRecorder ? DEV_RUM_RECORDER_URL : DEV_RUM_URL, + } + } + } else if (store.useRumRecorder && /\/datadog-rum(?!-recorder)\.js$/.test(info.url)) { + return { + redirectUrl: info.url.replace(/\.js$/, '-recorder.js'), + } + } + return + }, + { + types: ['script'], + urls: [ + // TODO: implement a configuration page to add more URLs in this list. + 'https://www.datadoghq-browser-agent.com/datadog-logs.js', + 'https://www.datadoghq-browser-agent.com/datadog-rum.js', + 'https://www.datadoghq-browser-agent.com/datadog-rum-recorder.js', + 'https://localhost:8443/static/datadog-rum-hotdog.js', + ], + }, + ['blocking'] +) + +listenAction('getStore', () => refreshDevServerStatus()) + +async function refreshDevServerStatus() { + const timeoutId = setTimeout(() => setStore({ devServerStatus: 'checking' }), 500) + let isAvailable = false + try { + const response = await fetch(DEV_LOGS_URL, { method: 'HEAD' }) + isAvailable = response.status === 200 + } catch { + // The request can fail if nothing is listening on the URL port. In this case, consider the dev + // server 'unavailable'. + } + clearTimeout(timeoutId) + setStore({ devServerStatus: isAvailable ? 'available' : 'unavailable' }) +} diff --git a/packages/developer-extension/src/background/index.ts b/packages/developer-extension/src/background/index.ts new file mode 100644 index 0000000000..22265e2268 --- /dev/null +++ b/packages/developer-extension/src/background/index.ts @@ -0,0 +1,4 @@ +import './domain/flushEvents' +import './domain/logRequests' +import './domain/endSession' +import './domain/replaceBundles' diff --git a/packages/developer-extension/src/background/store.ts b/packages/developer-extension/src/background/store.ts new file mode 100644 index 0000000000..e7fb890558 --- /dev/null +++ b/packages/developer-extension/src/background/store.ts @@ -0,0 +1,30 @@ +import { Store } from '../common/types' +import { listenAction, sendAction } from './actions' + +export const store: Store = { + devServerStatus: 'checking', + logEvents: true, + useDevBundles: false, + useRumRecorder: false, +} + +export function setStore(newStore: Partial) { + if (wouldModifyStore(newStore)) { + Object.assign(store, newStore) + sendAction('newStore', store) + chrome.storage.local.set({ store }) + } +} + +listenAction('getStore', () => sendAction('newStore', store)) +listenAction('setStore', (newStore) => setStore(newStore)) + +chrome.storage.local.get((storage) => { + if (storage.store) { + setStore(storage.store as Store) + } +}) + +function wouldModifyStore(newStore: Partial) { + return (Object.entries(newStore) as Array<[keyof Store, unknown]>).some(([key, value]) => store[key] !== value) +} diff --git a/packages/developer-extension/src/background/utils.ts b/packages/developer-extension/src/background/utils.ts new file mode 100644 index 0000000000..32b037d06e --- /dev/null +++ b/packages/developer-extension/src/background/utils.ts @@ -0,0 +1,21 @@ +export function evaluateCodeInActiveTab(code: string) { + chrome.tabs.query({ currentWindow: true, active: true }, (tabs) => { + for (const tab of tabs) { + if (tab.id) { + evaluateCodeInline(tab.id, code) + } + } + }) +} + +function evaluateCodeInline(tabId: number, code: string) { + chrome.tabs.executeScript(tabId, { + code: `{ + const script = document.createElement('script') + script.setAttribute("type", "module") + script.textContent = ${JSON.stringify(code)} + document.body.appendChild(script) + script.remove() + }`, + }) +} diff --git a/packages/developer-extension/src/common/actions.ts b/packages/developer-extension/src/common/actions.ts new file mode 100644 index 0000000000..6539ccfcd0 --- /dev/null +++ b/packages/developer-extension/src/common/actions.ts @@ -0,0 +1,43 @@ +type ValueOf = T[keyof T] + +type Message = ValueOf< + { + [K in keyof Actions]: { + action: K + payload: Actions[K] + } + } +> + +export function createListenAction() { + function listenAction(action: K, callback: (payload: Actions[K]) => void) { + const listener = (message: Message) => { + if (message.action === action) { + callback((message as Message>).payload) + } + } + chrome.runtime.onMessage.addListener(listener) + return () => { + chrome.runtime.onMessage.removeListener(listener) + } + } + + return listenAction +} + +export function createSendAction() { + function sendAction(action: K, payload: Actions[K]) { + return chrome.runtime.sendMessage({ action, payload }, () => { + const error = chrome.runtime.lastError + if ( + error && + error.message !== 'Could not establish connection. Receiving end does not exist.' && + error.message !== 'The message port closed before a response was received.' + ) { + console.error(`sendAction error: ${error.message}`) + } + }) + } + + return sendAction +} diff --git a/packages/developer-extension/src/common/types.ts b/packages/developer-extension/src/common/types.ts new file mode 100644 index 0000000000..47cc84a543 --- /dev/null +++ b/packages/developer-extension/src/common/types.ts @@ -0,0 +1,17 @@ +export interface BackgroundActions { + getStore: void + setStore: Partial + flushEvents: void + endSession: void +} + +export interface PopupActions { + newStore: Store +} + +export interface Store { + devServerStatus: 'unavailable' | 'checking' | 'available' + useDevBundles: boolean + useRumRecorder: boolean + logEvents: boolean +} diff --git a/packages/developer-extension/src/popup/App.tsx b/packages/developer-extension/src/popup/App.tsx new file mode 100644 index 0000000000..18e65ae281 --- /dev/null +++ b/packages/developer-extension/src/popup/App.tsx @@ -0,0 +1,31 @@ +import { Provider as BumbagProvider, css, Box } from 'bumbag' +import React, { Suspense } from 'react' + +import { Panel } from './Panel' + +const theme = { + global: { + fontSize: 14, + styles: { + base: css` + body { + width: 300px; + } + `, + }, + }, + modes: { + enableLocalStorage: false, + useSystemColorMode: true, + }, +} + +export function App() { + return ( + + }> + + + + ) +} diff --git a/packages/developer-extension/src/popup/Panel.tsx b/packages/developer-extension/src/popup/Panel.tsx new file mode 100644 index 0000000000..6e4bb98dd0 --- /dev/null +++ b/packages/developer-extension/src/popup/Panel.tsx @@ -0,0 +1,36 @@ +import { Checkbox, Stack, Button, Badge } from 'bumbag' +import React from 'react' +import { sendAction } from './actions' +import { useStore } from './useStore' + +export function Panel() { + const [{ useDevBundles, useRumRecorder, logEvents, devServerStatus: devStatus }, setStore] = useStore() + return ( + + + setStore({ useDevBundles: isChecked(e.target) })} + /> + + + + setStore({ useRumRecorder: isChecked(e.target) })} + /> + + setStore({ logEvents: isChecked(e.target) })} /> + + + + + + ) +} + +function isChecked(target: EventTarget) { + return target instanceof HTMLInputElement && target.checked +} diff --git a/packages/developer-extension/src/popup/actions.ts b/packages/developer-extension/src/popup/actions.ts new file mode 100644 index 0000000000..1674198415 --- /dev/null +++ b/packages/developer-extension/src/popup/actions.ts @@ -0,0 +1,5 @@ +import { createListenAction, createSendAction } from '../common/actions' +import { BackgroundActions, PopupActions } from '../common/types' + +export const sendAction = createSendAction() +export const listenAction = createListenAction() diff --git a/packages/developer-extension/src/popup/index.tsx b/packages/developer-extension/src/popup/index.tsx new file mode 100644 index 0000000000..a3fca003dd --- /dev/null +++ b/packages/developer-extension/src/popup/index.tsx @@ -0,0 +1,8 @@ +import { render } from 'react-dom' +import React from 'react' + +import { App } from './App' + +const main = document.createElement('main') +document.body.append(main) +render(, main) diff --git a/packages/developer-extension/src/popup/useStore.ts b/packages/developer-extension/src/popup/useStore.ts new file mode 100644 index 0000000000..3a7cffad2a --- /dev/null +++ b/packages/developer-extension/src/popup/useStore.ts @@ -0,0 +1,35 @@ +import { useEffect, useReducer } from 'react' +import { Store } from '../common/types' +import { listenAction, sendAction } from './actions' + +let store: Store | undefined +const storeListeners = new Set<() => void>() +const storeLoadingPromise = new Promise((resolve) => { + sendAction('getStore', undefined) + listenAction('newStore', (newStore) => { + store = newStore + storeListeners.forEach((listener) => listener()) + resolve() + }) +}) + +export function useStore(): [Store, (newState: Partial) => void] { + if (!store) { + throw storeLoadingPromise + } + + const forceUpdate = useReducer(() => ({}), {})[1] as () => void + + useEffect(() => { + storeListeners.add(forceUpdate) + return () => { + storeListeners.delete(forceUpdate) + } + }, []) + + return [store, setStore] +} + +function setStore(newStore: Partial) { + sendAction('setStore', newStore) +} diff --git a/packages/developer-extension/tsconfig.json b/packages/developer-extension/tsconfig.json new file mode 100644 index 0000000000..916a6390e8 --- /dev/null +++ b/packages/developer-extension/tsconfig.json @@ -0,0 +1,14 @@ +{ + "extends": "../../tsconfig.base.json", + + "compilerOptions": { + "baseUrl": ".", + "module": "ES6", + "jsx": "react", + + // See https://github.com/bumbag/bumbag-ui/issues/97 + "strictNullChecks": false + }, + + "include": ["src"] +} diff --git a/packages/developer-extension/webpack.config.js b/packages/developer-extension/webpack.config.js new file mode 100644 index 0000000000..dcb111c0ba --- /dev/null +++ b/packages/developer-extension/webpack.config.js @@ -0,0 +1,62 @@ +const HtmlWebpackPlugin = require('html-webpack-plugin') +const WebextensionPlugin = require('webpack-webextension-plugin') +const CopyPlugin = require('copy-webpack-plugin') + +module.exports = (env, argv) => { + return [ + baseConfig({ + entry: './src/background', + output: { + filename: 'background.js', + }, + plugins: [ + new WebextensionPlugin({ + manifestDefaults: { + version: require('./package.json').version, + }, + }), + new CopyPlugin({ + patterns: [{ from: './icons/' }], + }), + ], + }), + baseConfig({ + entry: './src/popup', + output: { + filename: 'popup.js', + }, + plugins: [ + new HtmlWebpackPlugin({ + filename: 'popup.html', + }), + ], + }), + ] + + function baseConfig({ entry, output, plugins }) { + return { + entry, + output, + devtool: argv.mode === 'development' ? 'inline-source-map' : 'false', + + module: { + rules: [ + { + test: /\.tsx?$/, + loader: 'ts-loader', + exclude: /node_modules/, + options: { + onlyCompileBundledFiles: true, + }, + }, + ], + }, + + resolve: { + extensions: ['.ts', '.tsx', '.js'], + }, + + plugins, + } + } +} diff --git a/scripts/cli b/scripts/cli index 5dd03b14fc..ae9a76d865 100755 --- a/scripts/cli +++ b/scripts/cli @@ -22,8 +22,9 @@ cmd_help () { } cmd_typecheck () { - local project_path="${1}" - tsc -p "$project_path" --noEmit true + tsc -p . --noEmit true + tsc -p test/e2e --noEmit true + tsc -p packages/developer-extension --noEmit true } cmd_lint () { diff --git a/tsconfig.json b/tsconfig.json index 207cd099d5..f2c0c96395 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,5 +1,6 @@ // This tsconfig is only used for tooling (ex: typecheck in code editors) { "extends": "./tsconfig.base.json", - "include": ["./packages/**/src/**/*.ts", "./packages/**/test/**/*.ts"] + "include": ["./packages/**/src", "./packages/**/test"], + "exclude": ["./packages/developer-extension"] } diff --git a/yarn.lock b/yarn.lock index 5c5522e3de..84ffc06734 100644 --- a/yarn.lock +++ b/yarn.lock @@ -52,6 +52,13 @@ dependencies: "@babel/types" "^7.0.0" +"@babel/helper-module-imports@^7.0.0": + version "7.12.5" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.12.5.tgz#1bfc0229f794988f76ed0a4d4e90860850b54dfb" + integrity sha512-SR713Ogqg6++uexFRORf/+nPXMmWIn80TALu0uaFb+iQIUoR7bOC7zBWyzBs5b3tBBJXuyD0cRu1F15GyzjOWA== + dependencies: + "@babel/types" "^7.12.5" + "@babel/helper-split-export-declaration@^7.4.4": version "7.4.4" resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.4.4.tgz#ff94894a340be78f53f06af038b205c49d993677" @@ -59,6 +66,11 @@ dependencies: "@babel/types" "^7.4.4" +"@babel/helper-validator-identifier@^7.12.11": + version "7.12.11" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz#c9a1f021917dcb5ccf0d4e453e399022981fc9ed" + integrity sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw== + "@babel/highlight@^7.0.0": version "7.5.0" resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.5.0.tgz#56d11312bd9248fa619591d02472be6e8cb32540" @@ -73,6 +85,13 @@ resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.5.5.tgz#02f077ac8817d3df4a832ef59de67565e71cca4b" integrity sha512-E5BN68cqR7dhKan1SfqgPGhQ178bkVKpXTPEXnFJBrEt8/DKRZlybmy+IgYLTeN7tp1R5Ccmbm2rBk17sHYU3g== +"@babel/runtime@^7.5.5", "@babel/runtime@^7.7.2": + version "7.12.5" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.12.5.tgz#410e7e487441e1b360c29be715d870d9b985882e" + integrity sha512-plcc+hbExy3McchJCEQG3knOsuh3HH+Prx1P6cLIkET/0dLuQDEnrT+s27Axgc9bqfsmNUNHfscgMUdBpC9xfg== + dependencies: + regenerator-runtime "^0.13.4" + "@babel/template@^7.1.0", "@babel/template@^7.4.0": version "7.4.4" resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.4.4.tgz#f4b88d1225689a08f5bc3a17483545be9e4ed237" @@ -106,6 +125,129 @@ lodash "^4.17.13" to-fast-properties "^2.0.0" +"@babel/types@^7.12.5": + version "7.12.12" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.12.12.tgz#4608a6ec313abbd87afa55004d373ad04a96c299" + integrity sha512-lnIX7piTxOH22xE7fDXDbSHg9MM1/6ORnafpJmov5rs0kX5g4BZxeXNJLXsMRiO0U5Rb8/FvMS6xlTnTHvxonQ== + dependencies: + "@babel/helper-validator-identifier" "^7.12.11" + lodash "^4.17.19" + to-fast-properties "^2.0.0" + +"@emotion/cache@^10.0.27": + version "10.0.29" + resolved "https://registry.yarnpkg.com/@emotion/cache/-/cache-10.0.29.tgz#87e7e64f412c060102d589fe7c6dc042e6f9d1e0" + integrity sha512-fU2VtSVlHiF27empSbxi1O2JFdNWZO+2NFHfwO0pxgTep6Xa3uGb+3pVKfLww2l/IBGLNEZl5Xf/++A4wAYDYQ== + dependencies: + "@emotion/sheet" "0.9.4" + "@emotion/stylis" "0.8.5" + "@emotion/utils" "0.11.3" + "@emotion/weak-memoize" "0.2.5" + +"@emotion/core@10.1.1": + version "10.1.1" + resolved "https://registry.yarnpkg.com/@emotion/core/-/core-10.1.1.tgz#c956c1365f2f2481960064bcb8c4732e5fb612c3" + integrity sha512-ZMLG6qpXR8x031NXD8HJqugy/AZSkAuMxxqB46pmAR7ze47MhNJ56cdoX243QPZdGctrdfo+s08yZTiwaUcRKA== + dependencies: + "@babel/runtime" "^7.5.5" + "@emotion/cache" "^10.0.27" + "@emotion/css" "^10.0.27" + "@emotion/serialize" "^0.11.15" + "@emotion/sheet" "0.9.4" + "@emotion/utils" "0.11.3" + +"@emotion/css@^10.0.27": + version "10.0.27" + resolved "https://registry.yarnpkg.com/@emotion/css/-/css-10.0.27.tgz#3a7458198fbbebb53b01b2b87f64e5e21241e14c" + integrity sha512-6wZjsvYeBhyZQYNrGoR5yPMYbMBNEnanDrqmsqS1mzDm1cOTu12shvl2j4QHNS36UaTE0USIJawCH9C8oW34Zw== + dependencies: + "@emotion/serialize" "^0.11.15" + "@emotion/utils" "0.11.3" + babel-plugin-emotion "^10.0.27" + +"@emotion/hash@0.8.0": + version "0.8.0" + resolved "https://registry.yarnpkg.com/@emotion/hash/-/hash-0.8.0.tgz#bbbff68978fefdbe68ccb533bc8cbe1d1afb5413" + integrity sha512-kBJtf7PH6aWwZ6fka3zQ0p6SBYzx4fl1LoZXE2RrnYST9Xljm7WfKJrU4g/Xr3Beg72MLrp1AWNUmuYJTL7Cow== + +"@emotion/is-prop-valid@0.8.2": + version "0.8.2" + resolved "https://registry.yarnpkg.com/@emotion/is-prop-valid/-/is-prop-valid-0.8.2.tgz#b9692080da79041683021fcc32f96b40c54c59dc" + integrity sha512-ZQIMAA2kLUWiUeMZNJDTeCwYRx1l8SQL0kHktze4COT22occKpDML1GDUXP5/sxhOMrZO8vZw773ni4H5Snrsg== + dependencies: + "@emotion/memoize" "0.7.2" + +"@emotion/is-prop-valid@0.8.8": + version "0.8.8" + resolved "https://registry.yarnpkg.com/@emotion/is-prop-valid/-/is-prop-valid-0.8.8.tgz#db28b1c4368a259b60a97311d6a952d4fd01ac1a" + integrity sha512-u5WtneEAr5IDG2Wv65yhunPSMLIpuKsbuOktRojfrEiEvRyC85LgPMZI63cr7NUqT8ZIGdSVg8ZKGxIug4lXcA== + dependencies: + "@emotion/memoize" "0.7.4" + +"@emotion/memoize@0.7.2": + version "0.7.2" + resolved "https://registry.yarnpkg.com/@emotion/memoize/-/memoize-0.7.2.tgz#7f4c71b7654068dfcccad29553520f984cc66b30" + integrity sha512-hnHhwQzvPCW1QjBWFyBtsETdllOM92BfrKWbUTmh9aeOlcVOiXvlPsK4104xH8NsaKfg86PTFsWkueQeUfMA/w== + +"@emotion/memoize@0.7.4": + version "0.7.4" + resolved "https://registry.yarnpkg.com/@emotion/memoize/-/memoize-0.7.4.tgz#19bf0f5af19149111c40d98bb0cf82119f5d9eeb" + integrity sha512-Ja/Vfqe3HpuzRsG1oBtWTHk2PGZ7GR+2Vz5iYGelAw8dx32K0y7PjVuxK6z1nMpZOqAFsRUPCkK1YjJ56qJlgw== + +"@emotion/serialize@^0.11.15", "@emotion/serialize@^0.11.16": + version "0.11.16" + resolved "https://registry.yarnpkg.com/@emotion/serialize/-/serialize-0.11.16.tgz#dee05f9e96ad2fb25a5206b6d759b2d1ed3379ad" + integrity sha512-G3J4o8by0VRrO+PFeSc3js2myYNOXVJ3Ya+RGVxnshRYgsvErfAOglKAiy1Eo1vhzxqtUvjCyS5gtewzkmvSSg== + dependencies: + "@emotion/hash" "0.8.0" + "@emotion/memoize" "0.7.4" + "@emotion/unitless" "0.7.5" + "@emotion/utils" "0.11.3" + csstype "^2.5.7" + +"@emotion/sheet@0.9.4": + version "0.9.4" + resolved "https://registry.yarnpkg.com/@emotion/sheet/-/sheet-0.9.4.tgz#894374bea39ec30f489bbfc3438192b9774d32e5" + integrity sha512-zM9PFmgVSqBw4zL101Q0HrBVTGmpAxFZH/pYx/cjJT5advXguvcgjHFTCaIO3enL/xr89vK2bh0Mfyj9aa0ANA== + +"@emotion/styled-base@^10.0.27": + version "10.0.31" + resolved "https://registry.yarnpkg.com/@emotion/styled-base/-/styled-base-10.0.31.tgz#940957ee0aa15c6974adc7d494ff19765a2f742a" + integrity sha512-wTOE1NcXmqMWlyrtwdkqg87Mu6Rj1MaukEoEmEkHirO5IoHDJ8LgCQL4MjJODgxWxXibGR3opGp1p7YvkNEdXQ== + dependencies: + "@babel/runtime" "^7.5.5" + "@emotion/is-prop-valid" "0.8.8" + "@emotion/serialize" "^0.11.15" + "@emotion/utils" "0.11.3" + +"@emotion/styled@10.0.27": + version "10.0.27" + resolved "https://registry.yarnpkg.com/@emotion/styled/-/styled-10.0.27.tgz#12cb67e91f7ad7431e1875b1d83a94b814133eaf" + integrity sha512-iK/8Sh7+NLJzyp9a5+vIQIXTYxfT4yB/OJbjzQanB2RZpvmzBQOHZWhpAMZWYEKRNNbsD6WfBw5sVWkb6WzS/Q== + dependencies: + "@emotion/styled-base" "^10.0.27" + babel-plugin-emotion "^10.0.27" + +"@emotion/stylis@0.8.5": + version "0.8.5" + resolved "https://registry.yarnpkg.com/@emotion/stylis/-/stylis-0.8.5.tgz#deacb389bd6ee77d1e7fcaccce9e16c5c7e78e04" + integrity sha512-h6KtPihKFn3T9fuIrwvXXUOwlx3rfUvfZIcP5a6rh8Y7zjE3O06hT5Ss4S/YI1AYhuZ1kjaE/5EaOOI2NqSylQ== + +"@emotion/unitless@0.7.5": + version "0.7.5" + resolved "https://registry.yarnpkg.com/@emotion/unitless/-/unitless-0.7.5.tgz#77211291c1900a700b8a78cfafda3160d76949ed" + integrity sha512-OWORNpfjMsSSUBVrRBVGECkhWcULOAJz9ZW8uK9qgxD+87M7jHRcvh/A96XXNhXTLmKcoYSQtBEX7lHMO7YRwg== + +"@emotion/utils@0.11.3": + version "0.11.3" + resolved "https://registry.yarnpkg.com/@emotion/utils/-/utils-0.11.3.tgz#a759863867befa7e583400d322652a3f44820924" + integrity sha512-0o4l6pZC+hI88+bzuaX/6BgOvQVhbt2PfmxauVaYOGgbsAw14wdKyvMCZXnsnsHys94iadcF+RG/wZyx6+ZZBw== + +"@emotion/weak-memoize@0.2.5": + version "0.2.5" + resolved "https://registry.yarnpkg.com/@emotion/weak-memoize/-/weak-memoize-0.2.5.tgz#8eed982e2ee6f7f4e44c253e12962980791efd46" + integrity sha512-6U71C2Wp7r5XtFtQzYrW5iKFT67OixrSxjI4MptCHzdSVlgabczzqLe0ZSgnub/5Kp4hSbpDB1tMytZY9pwxxA== + "@evocateur/libnpmaccess@^3.1.2": version "3.1.2" resolved "https://registry.yarnpkg.com/@evocateur/libnpmaccess/-/libnpmaccess-3.1.2.tgz#ecf7f6ce6b004e9f942b098d92200be4a4b1c845" @@ -199,6 +341,35 @@ reflect-metadata "^0.1.12" tslib "^1.8.1" +"@fortawesome/fontawesome-common-types@0.2.32": + version "0.2.32" + resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-0.2.32.tgz#3436795d5684f22742989bfa08f46f50f516f259" + integrity sha512-ux2EDjKMpcdHBVLi/eWZynnPxs0BtFVXJkgHIxXRl+9ZFaHPvYamAfCzeeQFqHRjuJtX90wVnMRaMQAAlctz3w== + +"@fortawesome/fontawesome-common-types@^0.2.32": + version "0.2.34" + resolved "https://registry.yarnpkg.com/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-0.2.34.tgz#0a8c348bb23b7b760030f5b1d912e582be4ec915" + integrity sha512-XcIn3iYbTEzGIxD0/dY5+4f019jIcEIWBiHc3KrmK/ROahwxmZ/s+tdj97p/5K0klz4zZUiMfUlYP0ajhSJjmA== + +"@fortawesome/free-solid-svg-icons@5.15.1": + version "5.15.1" + resolved "https://registry.yarnpkg.com/@fortawesome/free-solid-svg-icons/-/free-solid-svg-icons-5.15.1.tgz#e1432676ddd43108b41197fee9f86d910ad458ef" + integrity sha512-EFMuKtzRMNbvjab/SvJBaOOpaqJfdSap/Nl6hst7CgrJxwfORR1drdTV6q1Ib/JVzq4xObdTDcT6sqTaXMqfdg== + dependencies: + "@fortawesome/fontawesome-common-types" "^0.2.32" + +"@hapi/hoek@^9.0.0": + version "9.1.1" + resolved "https://registry.yarnpkg.com/@hapi/hoek/-/hoek-9.1.1.tgz#9daf5745156fd84b8e9889a2dc721f0c58e894aa" + integrity sha512-CAEbWH7OIur6jEOzaai83jq3FmKmv4PmX1JYfs9IrYcGEVI/lyL1EXJGCj7eFVJ0bg5QR8LMxBlEtA+xKiLpFw== + +"@hapi/topo@^5.0.0": + version "5.0.0" + resolved "https://registry.yarnpkg.com/@hapi/topo/-/topo-5.0.0.tgz#c19af8577fa393a06e9c77b60995af959be721e7" + integrity sha512-tFJlT47db0kMqVm3H4nQYgn6Pwg10GTZHb1pwmSiv1K4ks6drQOtfEF5ZnPjkvC+y4/bUPHK+bc87QvLcL+WMw== + dependencies: + "@hapi/hoek" "^9.0.0" + "@jest/types@^25.3.0": version "25.3.0" resolved "https://registry.yarnpkg.com/@jest/types/-/types-25.3.0.tgz#88f94b277a1d028fd7117bc1f74451e0fc2131e7" @@ -907,11 +1078,40 @@ call-me-maybe "^1.0.1" glob-to-regexp "^0.3.0" +"@nodelib/fs.scandir@2.1.4": + version "2.1.4" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz#d4b3549a5db5de2683e0c1071ab4f140904bbf69" + integrity sha512-33g3pMJk3bg5nXbL/+CY6I2eJDzZAni49PfJnL5fghPTggPvBd/pFNSgJsdAgWptuFu7qq/ERvOYFlhvsLTCKA== + dependencies: + "@nodelib/fs.stat" "2.0.4" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.4", "@nodelib/fs.stat@^2.0.2": + version "2.0.4" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.4.tgz#a3f2dd61bab43b8db8fa108a121cfffe4c676655" + integrity sha512-IYlHJA0clt2+Vg7bccq+TzRdJvv19c2INqBSsoOLp1je7xjtr7J26+WXR72MCdvU9q1qTzIWDfhMf+DRvQJK4Q== + "@nodelib/fs.stat@^1.1.2": version "1.1.3" resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz#2b5a3ab3f918cca48a8c754c08168e3f03eba61b" integrity sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw== +"@nodelib/fs.walk@^1.2.3": + version "1.2.6" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.6.tgz#cce9396b30aa5afe9e3756608f5831adcb53d063" + integrity sha512-8Broas6vTtW4GIXTAHDoE32hnN2M5ykgCpWGbuXHQ15vEMqr23pB76e/GZcYsZCHALv50ktd24qhEyKr6wBtow== + dependencies: + "@nodelib/fs.scandir" "2.1.4" + fastq "^1.6.0" + +"@npmcli/move-file@^1.0.1": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-1.1.0.tgz#4ef8a53d727b9e43facf35404caf55ebf92cfec8" + integrity sha512-Iv2iq0JuyYjKeFkSR4LPaCdDZwlGK9X2cP/01nJcp3yMJ1FjNd9vpiEYvLUgzBxKPg2SFmaOhizoQsPc0LWeOQ== + dependencies: + mkdirp "^1.0.4" + rimraf "^2.7.1" + "@octokit/endpoint@^5.1.0": version "5.4.1" resolved "https://registry.yarnpkg.com/@octokit/endpoint/-/endpoint-5.4.1.tgz#8f4c747d6cf8f352683d35a7fe8664db487cb730" @@ -964,6 +1164,28 @@ once "^1.4.0" universal-user-agent "^4.0.0" +"@popperjs/core@^2.4.4": + version "2.6.0" + resolved "https://registry.yarnpkg.com/@popperjs/core/-/core-2.6.0.tgz#f022195afdfc942e088ee2101285a1d31c7d727f" + integrity sha512-cPqjjzuFWNK3BSKLm0abspP0sp/IGOli4p5I5fKFAzdS8fvjdOwDCfZqAaIiXd9lPkOWi3SUUfZof3hEb7J/uw== + +"@sideway/address@^4.1.0": + version "4.1.0" + resolved "https://registry.yarnpkg.com/@sideway/address/-/address-4.1.0.tgz#0b301ada10ac4e0e3fa525c90615e0b61a72b78d" + integrity sha512-wAH/JYRXeIFQRsxerIuLjgUu2Xszam+O5xKeatJ4oudShOOirfmsQ1D6LL54XOU2tizpCYku+s1wmU0SYdpoSA== + dependencies: + "@hapi/hoek" "^9.0.0" + +"@sideway/formula@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@sideway/formula/-/formula-3.0.0.tgz#fe158aee32e6bd5de85044be615bc08478a0a13c" + integrity sha512-vHe7wZ4NOXVfkoRb8T5otiENVlT7a3IAiw7H5M2+GO+9CDgcVUUsX1zalAztCmwyOr2RUTGJdgB+ZvSVqmdHmg== + +"@sideway/pinpoint@^2.0.0": + version "2.0.0" + resolved "https://registry.yarnpkg.com/@sideway/pinpoint/-/pinpoint-2.0.0.tgz#cff8ffadc372ad29fd3f78277aeb29e632cc70df" + integrity sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ== + "@sindresorhus/is@^2.0.0", "@sindresorhus/is@^2.1.0": version "2.1.1" resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-2.1.1.tgz#ceff6a28a5b4867c2dd4a1ba513de278ccbe8bb1" @@ -1024,6 +1246,11 @@ resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.0.0.tgz#9c13c2574c92d4503b005feca8f2e16cc1611506" integrity sha512-KYyTT/T6ALPkIRd2Ge080X/BsXvy9O0hcWTtMWkPvwAwF99+vn6Dv4GzrFT/Nn1LePr+FFDbRXXlqmsy9lw2zA== +"@types/anymatch@*": + version "1.3.1" + resolved "https://registry.yarnpkg.com/@types/anymatch/-/anymatch-1.3.1.tgz#336badc1beecb9dacc38bea2cf32adf627a8421a" + integrity sha512-/+CRPXpBDpo2RK9C68N3b2cOvO0Cf5B9aPijHsoDQTHivnGSObdOF2BRQOYjojWTDy6nQvMjmqRXIxH55VjxxA== + "@types/body-parser@*": version "1.19.0" resolved "https://registry.yarnpkg.com/@types/body-parser/-/body-parser-1.19.0.tgz#0685b3c47eb3006ffed117cdd55164b61f80538f" @@ -1049,6 +1276,19 @@ "@types/node" "*" "@types/responselike" "*" +"@types/chrome@0.0.125": + version "0.0.125" + resolved "https://registry.yarnpkg.com/@types/chrome/-/chrome-0.0.125.tgz#a82c1ebcfff0912f98b8335bcdd4c0348ba66802" + integrity sha512-WBbihYza9NNaE/rlIpBiSE9o2MfLN1GMltDoW6rgaDDIZL+1z08ii2ZAsDbvnrkrG2ohVyQjLODG3IbzakEvGA== + dependencies: + "@types/filesystem" "*" + "@types/har-format" "*" + +"@types/classnames@2.2.11": + version "2.2.11" + resolved "https://registry.yarnpkg.com/@types/classnames/-/classnames-2.2.11.tgz#2521cc86f69d15c5b90664e4829d84566052c1cf" + integrity sha512-2koNhpWm3DgWRp5tpkiJ8JGc1xTn2q0l+jUNUE7oMKXUf5NpI9AIdC4kbjGNFBdHtcxBD18LAksoudAVhFKCjw== + "@types/color-name@^1.1.1": version "1.1.1" resolved "https://registry.yarnpkg.com/@types/color-name/-/color-name-1.1.1.tgz#1c1261bbeaa10a8055bbc5d8ab84b7b2afc846a0" @@ -1100,6 +1340,18 @@ "@types/qs" "*" "@types/serve-static" "*" +"@types/filesystem@*": + version "0.0.29" + resolved "https://registry.yarnpkg.com/@types/filesystem/-/filesystem-0.0.29.tgz#ee3748eb5be140dcf980c3bd35f11aec5f7a3748" + integrity sha512-85/1KfRedmfPGsbK8YzeaQUyV1FQAvMPMTuWFQ5EkLd2w7szhNO96bk3Rh/SKmOfd9co2rCLf0Voy4o7ECBOvw== + dependencies: + "@types/filewriter" "*" + +"@types/filewriter@*": + version "0.0.28" + resolved "https://registry.yarnpkg.com/@types/filewriter/-/filewriter-0.0.28.tgz#c054e8af4d9dd75db4e63abc76f885168714d4b3" + integrity sha1-wFTor02d11205jq8dviFFocU1LM= + "@types/glob@*": version "7.1.3" resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.1.3.tgz#e6ba80f36b7daad2c685acd9266382e68985c183" @@ -1117,6 +1369,16 @@ "@types/minimatch" "*" "@types/node" "*" +"@types/har-format@*": + version "1.2.5" + resolved "https://registry.yarnpkg.com/@types/har-format/-/har-format-1.2.5.tgz#4f6648814d0fdcb6a510e3364a9db439a753c4b1" + integrity sha512-IG8AE1m2pWtPqQ7wXhFhy6Q59bwwnLwO36v5Rit2FrbXCIp8Sk8E2PfUCreyrdo17STwFSKDAkitVuVYbpEHvQ== + +"@types/html-minifier-terser@^5.0.0": + version "5.1.1" + resolved "https://registry.yarnpkg.com/@types/html-minifier-terser/-/html-minifier-terser-5.1.1.tgz#3c9ee980f1a10d6021ae6632ca3e79ca2ec4fb50" + integrity sha512-giAlZwstKbmvMk1OO7WXSj4OZ0keXAcl2TQq4LWHiiPH2ByaH7WeUzng+Qej8UPxxv+8lRTuouo0iaNDBuzIBA== + "@types/http-cache-semantics@*": version "4.0.0" resolved "https://registry.yarnpkg.com/@types/http-cache-semantics/-/http-cache-semantics-4.0.0.tgz#9140779736aa2655635ee756e2467d787cfe8a2a" @@ -1194,6 +1456,16 @@ resolved "https://registry.yarnpkg.com/@types/normalize-package-data/-/normalize-package-data-2.4.0.tgz#e486d0d97396d79beedd0a6e33f4534ff6b4973e" integrity sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA== +"@types/parse-json@^4.0.0": + version "4.0.0" + resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" + integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== + +"@types/prop-types@*": + version "15.7.3" + resolved "https://registry.yarnpkg.com/@types/prop-types/-/prop-types-15.7.3.tgz#2ab0d5da2e5815f94b0b9d4b95d1e5f243ab2ca7" + integrity sha512-KfRL3PuHmqQLOG+2tGpRO26Ctg+Cq1E01D2DMriKEATHgWLfeNDmq9e29Q9WIky0dQ3NPkd1mzYH8Lm936Z9qw== + "@types/qs@*": version "6.9.5" resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.5.tgz#434711bdd49eb5ee69d90c1d67c354a9a8ecb18b" @@ -1204,6 +1476,21 @@ resolved "https://registry.yarnpkg.com/@types/range-parser/-/range-parser-1.2.3.tgz#7ee330ba7caafb98090bece86a5ee44115904c2c" integrity sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA== +"@types/react-dom@16": + version "16.9.10" + resolved "https://registry.yarnpkg.com/@types/react-dom/-/react-dom-16.9.10.tgz#4485b0bec3d41f856181b717f45fd7831101156f" + integrity sha512-ItatOrnXDMAYpv6G8UCk2VhbYVTjZT9aorLtA/OzDN9XJ2GKcfam68jutoAcILdRjsRUO8qb7AmyObF77Q8QFw== + dependencies: + "@types/react" "^16" + +"@types/react@16", "@types/react@^16": + version "16.14.2" + resolved "https://registry.yarnpkg.com/@types/react/-/react-16.14.2.tgz#85dcc0947d0645349923c04ccef6018a1ab7538c" + integrity sha512-BzzcAlyDxXl2nANlabtT4thtvbbnhee8hMmH/CcJrISDBVcJS1iOsP1f0OAgSdGE0MsY9tqcrb9YoZcOFv9dbQ== + dependencies: + "@types/prop-types" "*" + csstype "^3.0.2" + "@types/responselike@*", "@types/responselike@^1.0.0": version "1.0.0" resolved "https://registry.yarnpkg.com/@types/responselike/-/responselike-1.0.0.tgz#251f4fe7d154d2bad125abe1b429b23afd262e29" @@ -1238,11 +1525,49 @@ resolved "https://registry.yarnpkg.com/@types/sinonjs__fake-timers/-/sinonjs__fake-timers-6.0.2.tgz#3a84cf5ec3249439015e14049bd3161419bf9eae" integrity sha512-dIPoZ3g5gcx9zZEszaxLSVTvMReD3xxyyDnQUjA6IYDG9Ba2AV0otMPs+77sG9ojB4Qr2N2Vk5RnKeuA0X/0bg== +"@types/source-list-map@*": + version "0.1.2" + resolved "https://registry.yarnpkg.com/@types/source-list-map/-/source-list-map-0.1.2.tgz#0078836063ffaf17412349bba364087e0ac02ec9" + integrity sha512-K5K+yml8LTo9bWJI/rECfIPrGgxdpeNbj+d53lwN4QjW1MCwlkhUms+gtdzigTeUyBr09+u8BwOIY3MXvHdcsA== + "@types/stack-utils@^1.0.1": version "1.0.1" resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-1.0.1.tgz#0a851d3bd96498fa25c33ab7278ed3bd65f06c3e" integrity sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw== +"@types/tapable@*", "@types/tapable@^1.0.5": + version "1.0.6" + resolved "https://registry.yarnpkg.com/@types/tapable/-/tapable-1.0.6.tgz#a9ca4b70a18b270ccb2bc0aaafefd1d486b7ea74" + integrity sha512-W+bw9ds02rAQaMvaLYxAbJ6cvguW/iJXNT6lTssS1ps6QdrMKttqEAMEG/b5CR8TZl3/L7/lH0ZV5nNR1LXikA== + +"@types/uglify-js@*": + version "3.11.1" + resolved "https://registry.yarnpkg.com/@types/uglify-js/-/uglify-js-3.11.1.tgz#97ff30e61a0aa6876c270b5f538737e2d6ab8ceb" + integrity sha512-7npvPKV+jINLu1SpSYVWG8KvyJBhBa8tmzMMdDoVc2pWUYHN8KIXlPJhjJ4LT97c4dXJA2SHL/q6ADbDriZN+Q== + dependencies: + source-map "^0.6.1" + +"@types/webpack-sources@*": + version "2.1.0" + resolved "https://registry.yarnpkg.com/@types/webpack-sources/-/webpack-sources-2.1.0.tgz#8882b0bd62d1e0ce62f183d0d01b72e6e82e8c10" + integrity sha512-LXn/oYIpBeucgP1EIJbKQ2/4ZmpvRl+dlrFdX7+94SKRUV3Evy3FsfMZY318vGhkWUS5MPhtOM3w1/hCOAOXcg== + dependencies: + "@types/node" "*" + "@types/source-list-map" "*" + source-map "^0.7.3" + +"@types/webpack@^4.41.8": + version "4.41.26" + resolved "https://registry.yarnpkg.com/@types/webpack/-/webpack-4.41.26.tgz#27a30d7d531e16489f9c7607c747be6bc1a459ef" + integrity sha512-7ZyTfxjCRwexh+EJFwRUM+CDB2XvgHl4vfuqf1ZKrgGvcS5BrNvPQqJh3tsZ0P6h6Aa1qClVHaJZszLPzpqHeA== + dependencies: + "@types/anymatch" "*" + "@types/node" "*" + "@types/tapable" "*" + "@types/uglify-js" "*" + "@types/webpack-sources" "*" + source-map "^0.6.0" + "@types/yargs-parser@*": version "15.0.0" resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-15.0.0.tgz#cb3f9f741869e20cce330ffbeb9271590483882d" @@ -1646,6 +1971,14 @@ agentkeepalive@^3.4.1: dependencies: humanize-ms "^1.2.1" +aggregate-error@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" + integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== + dependencies: + clean-stack "^2.0.0" + indent-string "^4.0.0" + ajv-errors@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/ajv-errors/-/ajv-errors-1.0.1.tgz#f35986aceb91afadec4102fbd85014950cefa64d" @@ -1656,7 +1989,12 @@ ajv-keywords@^3.1.0, ajv-keywords@^3.4.1: resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-3.4.1.tgz#ef916e271c64ac12171fd8384eaae6b2345854da" integrity sha512-RO1ibKvd27e6FEShVFfPALuHI3WjSVNeK5FIsmme/LYRNxjKuNj+Dt7bucLa6NdSv3JcVTyMlm9kGR84z1XpaQ== -ajv@6.12.6: +ajv-keywords@^3.5.2: + version "3.5.2" + resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz#31f29da5ab6e00d1c2d329acf7b5929614d5014d" + integrity sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ== + +ajv@6.12.6, ajv@^6.12.5: version "6.12.6" resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== @@ -1886,6 +2224,11 @@ array-union@^1.0.2: dependencies: array-uniq "^1.0.1" +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + array-uniq@^1.0.1: version "1.0.3" resolved "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz#af6ac877a25cc7f74e058894753858dfdb24fdb6" @@ -2032,6 +2375,36 @@ babel-messages@^6.23.0: dependencies: babel-runtime "^6.22.0" +babel-plugin-emotion@^10.0.27: + version "10.0.33" + resolved "https://registry.yarnpkg.com/babel-plugin-emotion/-/babel-plugin-emotion-10.0.33.tgz#ce1155dcd1783bbb9286051efee53f4e2be63e03" + integrity sha512-bxZbTTGz0AJQDHm8k6Rf3RQJ8tX2scsfsRyKVgAbiUPUNIRtlK+7JxP+TAd1kRLABFxe0CFm2VdK4ePkoA9FxQ== + dependencies: + "@babel/helper-module-imports" "^7.0.0" + "@emotion/hash" "0.8.0" + "@emotion/memoize" "0.7.4" + "@emotion/serialize" "^0.11.16" + babel-plugin-macros "^2.0.0" + babel-plugin-syntax-jsx "^6.18.0" + convert-source-map "^1.5.0" + escape-string-regexp "^1.0.5" + find-root "^1.1.0" + source-map "^0.5.7" + +babel-plugin-macros@^2.0.0: + version "2.8.0" + resolved "https://registry.yarnpkg.com/babel-plugin-macros/-/babel-plugin-macros-2.8.0.tgz#0f958a7cc6556b1e65344465d99111a1e5e10138" + integrity sha512-SEP5kJpfGYqYKpBrj5XU3ahw5p5GOHJ0U5ssOSQ/WBVdwkD2Dzlce95exQTs3jOVWPPKLBN2rlEWkCK7dSmLvg== + dependencies: + "@babel/runtime" "^7.7.2" + cosmiconfig "^6.0.0" + resolve "^1.12.0" + +babel-plugin-syntax-jsx@^6.18.0: + version "6.18.0" + resolved "https://registry.yarnpkg.com/babel-plugin-syntax-jsx/-/babel-plugin-syntax-jsx-6.18.0.tgz#0af32a9a6e13ca7a3fd5069e62d7b0f58d0d8946" + integrity sha1-CvMqmm4Tyno/1QaeYtew9Y0NiUY= + babel-runtime@^6.22.0, babel-runtime@^6.26.0: version "6.26.0" resolved "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz#965c7058668e82b55d7bfe04ff2337bc8b5647fe" @@ -2214,6 +2587,16 @@ body-parser@1.19.0, body-parser@^1.16.1: raw-body "2.4.0" type-is "~1.6.17" +body-scroll-lock@^3.1.5: + version "3.1.5" + resolved "https://registry.yarnpkg.com/body-scroll-lock/-/body-scroll-lock-3.1.5.tgz#c1392d9217ed2c3e237fee1e910f6cdd80b7aaec" + integrity sha512-Yi1Xaml0EvNA0OYWxXiYNqY24AfWkbA6w5vxE7GWxtKfzIbZM+Qw+aSmkgsbWzbHiy/RCSkUZBplVxTA+E4jJg== + +boolbase@^1.0.0, boolbase@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" + integrity sha1-aN/1++YMUes3cl6p4+0xDcwed24= + brace-expansion@^1.1.7: version "1.1.11" resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" @@ -2404,6 +2787,30 @@ builtins@^1.0.3: resolved "https://registry.yarnpkg.com/builtins/-/builtins-1.0.3.tgz#cb94faeb61c8696451db36534e1422f94f0aee88" integrity sha1-y5T662HIaWRR2zZTThQi+U8K7og= +bumbag@1.6.12: + version "1.6.12" + resolved "https://registry.yarnpkg.com/bumbag/-/bumbag-1.6.12.tgz#601c96cd5815682c5a6852dbf9450e3a55999173" + integrity sha512-HPT9Ai+5KxpvKowSE9hEKfsA89nFoe/ANA5Aw9eVhN05MXS/4sqJIguyiVXDrvpSZzVEMkE5xoN8dEaws1Pebg== + dependencies: + "@emotion/core" "10.1.1" + "@emotion/is-prop-valid" "0.8.2" + "@emotion/styled" "10.0.27" + "@fortawesome/fontawesome-common-types" "0.2.32" + "@fortawesome/free-solid-svg-icons" "5.15.1" + "@types/classnames" "2.2.11" + capsize "1.1.0" + classnames "2.2.6" + conditional-wrap "1.0.0" + deepmerge "4.2.2" + emotion "10.0.27" + emotion-theming "10.0.27" + lodash "4.17.20" + react-input-mask "2.0.4" + react-loads-next "npm:react-loads@9.2.3" + reakit "1.3.0" + styled-tools "1.7.2" + tinycolor2 "1.4.2" + busboy@*: version "0.3.1" resolved "https://registry.yarnpkg.com/busboy/-/busboy-0.3.1.tgz#170899274c5bf38aae27d5c62b71268cd585fd1b" @@ -2460,6 +2867,29 @@ cacache@^12.0.0, cacache@^12.0.2, cacache@^12.0.3: unique-filename "^1.1.1" y18n "^4.0.0" +cacache@^15.0.5: + version "15.0.5" + resolved "https://registry.yarnpkg.com/cacache/-/cacache-15.0.5.tgz#69162833da29170d6732334643c60e005f5f17d0" + integrity sha512-lloiL22n7sOjEEXdL8NAjTgv9a1u43xICE9/203qonkZUCj5X1UEWIdf2/Y0d6QcCtMzbKQyhrcDbdvlZTs/+A== + dependencies: + "@npmcli/move-file" "^1.0.1" + chownr "^2.0.0" + fs-minipass "^2.0.0" + glob "^7.1.4" + infer-owner "^1.0.4" + lru-cache "^6.0.0" + minipass "^3.1.1" + minipass-collect "^1.0.2" + minipass-flush "^1.0.5" + minipass-pipeline "^1.2.2" + mkdirp "^1.0.3" + p-map "^4.0.0" + promise-inflight "^1.0.1" + rimraf "^3.0.2" + ssri "^8.0.0" + tar "^6.0.2" + unique-filename "^1.1.1" + cache-base@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2" @@ -2530,6 +2960,19 @@ callsites@^2.0.0: resolved "https://registry.yarnpkg.com/callsites/-/callsites-2.0.0.tgz#06eb84f00eea413da86affefacbffb36093b3c50" integrity sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA= +callsites@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" + integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== + +camel-case@^4.1.1: + version "4.1.2" + resolved "https://registry.yarnpkg.com/camel-case/-/camel-case-4.1.2.tgz#9728072a954f805228225a6deea6b38461e1bd5a" + integrity sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw== + dependencies: + pascal-case "^3.1.2" + tslib "^2.0.3" + camelcase-keys@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/camelcase-keys/-/camelcase-keys-2.1.0.tgz#308beeaffdf28119051efa1d932213c91b8f92e7" @@ -2584,6 +3027,13 @@ camelcase@^5.0.0, camelcase@^5.3.1: resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== +capsize@1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/capsize/-/capsize-1.1.0.tgz#d70f918b5ecadc2390b2a3b3b672ced639907ed6" + integrity sha512-tV0weOXxQ9hsbqewiWfGQBXsGzSN/i/w9IGuH+JVySzGOhscTAzeK3N9ZAM3Kf89bWgYot80Za5fSXKi6ZynvA== + dependencies: + round-to "^4.1.0" + caseless@~0.12.0: version "0.12.0" resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" @@ -2625,6 +3075,14 @@ chalk@^4.0.0: ansi-styles "^4.1.0" supports-color "^7.1.0" +chalk@~4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.0.tgz#4e14870a618d9e2edd97dd8345fd9d9dc315646a" + integrity sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + chardet@^0.7.0: version "0.7.0" resolved "https://registry.yarnpkg.com/chardet/-/chardet-0.7.0.tgz#90094849f0937f2eedc2425d0d28a9e5f0cbad9e" @@ -2674,6 +3132,11 @@ chownr@^1.1.2: resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.3.tgz#42d837d5239688d55f303003a508230fa6727142" integrity sha512-i70fVHhmV3DtTl6nqvZOnIjbY0Pe4kAUjwHj8z0zAdgBtYrJyYwLKCCuRBQ5ppkyL0AkN7HKRnETdmdp1zqNXw== +chownr@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" + integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== + chrome-launcher@^0.13.1: version "0.13.1" resolved "https://registry.yarnpkg.com/chrome-launcher/-/chrome-launcher-0.13.1.tgz#cd5ed4952b630b9fccf2037b211cba81e5aae044" @@ -2715,6 +3178,23 @@ class-utils@^0.3.5: isobject "^3.0.0" static-extend "^0.1.1" +classnames@2.2.6: + version "2.2.6" + resolved "https://registry.yarnpkg.com/classnames/-/classnames-2.2.6.tgz#43935bffdd291f326dad0a205309b38d00f650ce" + integrity sha512-JR/iSQOSt+LQIWwrwEzJ9uk0xfN3mTVYMwt1Ir5mUcSN6pU+V4zQFFaJsclJbPuAUQH+yfWef6tm7l1quW3C8Q== + +clean-css@^4.2.3: + version "4.2.3" + resolved "https://registry.yarnpkg.com/clean-css/-/clean-css-4.2.3.tgz#507b5de7d97b48ee53d84adb0160ff6216380f78" + integrity sha512-VcMWDN54ZN/DS+g58HYL5/n4Zrqe8vHJpGA8KdgUXFU4fuP/aHNw8eld9SyEIyabIMJX/0RaY/fplOo5hYLSFA== + dependencies: + source-map "~0.6.0" + +clean-stack@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" + integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== + cli-color@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/cli-color/-/cli-color-2.0.0.tgz#11ecfb58a79278cf6035a60c54e338f9d837897c" @@ -2868,6 +3348,11 @@ commander@^2.12.1, commander@^2.19.0, commander@^2.20.0: resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.0.tgz#d58bb2b5c1ee8f87b0d340027e9e94e222c5a422" integrity sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ== +commander@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/commander/-/commander-4.1.1.tgz#9fd602bd936294e9e9ef46a3f4d6964044b18068" + integrity sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA== + commondir@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b" @@ -2941,6 +3426,11 @@ concat-stream@^2.0.0: readable-stream "^3.0.2" typedarray "^0.0.6" +conditional-wrap@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/conditional-wrap/-/conditional-wrap-1.0.0.tgz#e97ea144b4f5b03819fe0e3c8be2f3d7f37d10ea" + integrity sha512-vjSB8ARvV+b4q5BbdO6aOpPRfjQdfnKEZZN0H5v8F1X+fQ+X1/LV+yWx3CSZaS+rLGiwFD3Xp086bB9qHu0aaw== + config-chain@^1.1.11: version "1.1.12" resolved "https://registry.yarnpkg.com/config-chain/-/config-chain-1.1.12.tgz#0fde8d091200eb5e808caf25fe618c02f48e4efa" @@ -3125,6 +3615,23 @@ copy-descriptor@^0.1.0: resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d" integrity sha1-Z29us8OZl8LuGsOpJP1hJHSPV40= +copy-webpack-plugin@6: + version "6.4.1" + resolved "https://registry.yarnpkg.com/copy-webpack-plugin/-/copy-webpack-plugin-6.4.1.tgz#138cd9b436dbca0a6d071720d5414848992ec47e" + integrity sha512-MXyPCjdPVx5iiWyl40Va3JGh27bKzOTNY3NjUTrosD2q7dR/cLD0013uqJ3BpFbUjyONINjb6qI7nDIJujrMbA== + dependencies: + cacache "^15.0.5" + fast-glob "^3.2.4" + find-cache-dir "^3.3.1" + glob-parent "^5.1.1" + globby "^11.0.1" + loader-utils "^2.0.0" + normalize-path "^3.0.0" + p-limit "^3.0.2" + schema-utils "^3.0.0" + serialize-javascript "^5.0.1" + webpack-sources "^1.4.3" + core-js@^2.4.0: version "2.6.9" resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.6.9.tgz#6b4b214620c834152e179323727fc19741b084f2" @@ -3153,6 +3660,17 @@ cosmiconfig@^5.1.0: js-yaml "^3.13.1" parse-json "^4.0.0" +cosmiconfig@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-6.0.0.tgz#da4fee853c52f6b1e6935f41c1a2fc50bd4a9982" + integrity sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg== + dependencies: + "@types/parse-json" "^4.0.0" + import-fresh "^3.1.0" + parse-json "^5.0.0" + path-type "^4.0.0" + yaml "^1.7.2" + crc32-stream@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/crc32-stream/-/crc32-stream-2.0.0.tgz#e3cdd3b4df3168dd74e3de3fbbcb7b297fe908f4" @@ -3176,6 +3694,16 @@ create-ecdh@^4.0.0: bn.js "^4.1.0" elliptic "^6.0.0" +create-emotion@^10.0.27: + version "10.0.27" + resolved "https://registry.yarnpkg.com/create-emotion/-/create-emotion-10.0.27.tgz#cb4fa2db750f6ca6f9a001a33fbf1f6c46789503" + integrity sha512-fIK73w82HPPn/RsAij7+Zt8eCE8SptcJ3WoRMfxMtjteYxud8GDTKKld7MYwAX2TVhrw29uR1N/bVGxeStHILg== + dependencies: + "@emotion/cache" "^10.0.27" + "@emotion/serialize" "^0.11.15" + "@emotion/sheet" "0.9.4" + "@emotion/utils" "0.11.3" + create-hash@^1.1.0, create-hash@^1.1.2: version "1.2.0" resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.2.0.tgz#889078af11a63756bcfb59bd221996be3a9ef196" @@ -3235,11 +3763,36 @@ crypto-browserify@^3.11.0: randombytes "^2.0.0" randomfill "^1.0.3" +css-select@^2.0.2: + version "2.1.0" + resolved "https://registry.yarnpkg.com/css-select/-/css-select-2.1.0.tgz#6a34653356635934a81baca68d0255432105dbef" + integrity sha512-Dqk7LQKpwLoH3VovzZnkzegqNSuAziQyNZUcrdDM401iY+R5NkGBXGmtO05/yaXQziALuPogeG0b7UAgjnTJTQ== + dependencies: + boolbase "^1.0.0" + css-what "^3.2.1" + domutils "^1.7.0" + nth-check "^1.0.2" + css-value@^0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/css-value/-/css-value-0.0.1.tgz#5efd6c2eea5ea1fd6b6ac57ec0427b18452424ea" integrity sha1-Xv1sLupeof1rasV+wEJ7GEUkJOo= +css-what@^3.2.1: + version "3.4.2" + resolved "https://registry.yarnpkg.com/css-what/-/css-what-3.4.2.tgz#ea7026fcb01777edbde52124e21f327e7ae950e4" + integrity sha512-ACUm3L0/jiZTqfzRM3Hi9Q8eZqd6IK37mMWPLz9PJxkLWllYeRf+EHUSHYEtFop2Eqytaq1FizFVh7XfBnXCDQ== + +csstype@^2.5.7: + version "2.6.14" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-2.6.14.tgz#004822a4050345b55ad4dcc00be1d9cf2f4296de" + integrity sha512-2mSc+VEpGPblzAxyeR+vZhJKgYg0Og0nnRi7pmRXFYYxSfnOnW8A5wwQb4n4cE2nIOzqKOAzLCaEX6aBmNEv8A== + +csstype@^3.0.2: + version "3.0.6" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.0.6.tgz#865d0b5833d7d8d40f4e5b8a6d76aea3de4725ef" + integrity sha512-+ZAmfyWMT7TiIlzdqJgjMb7S4f1beorDbWbsocyK4RaiqA5RTX3K14bnBWmmA9QEM0gRdsjyyrEmcyga8Zsxmw== + currently-unhandled@^0.4.1: version "0.4.1" resolved "https://registry.yarnpkg.com/currently-unhandled/-/currently-unhandled-0.4.1.tgz#988df33feab191ef799a61369dd76c17adf957ea" @@ -3367,6 +3920,11 @@ deep-extend@^0.6.0: resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== +deepmerge@4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.2.2.tgz#44d2ea3679b8f4d4ffba33f03d865fc1e7bf4955" + integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== + deepmerge@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.0.0.tgz#3e3110ca29205f120d7cb064960a39c3d2087c09" @@ -3545,6 +4103,13 @@ dir-glob@^2.2.2: dependencies: path-type "^3.0.0" +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + doctrine@0.7.2: version "0.7.2" resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-0.7.2.tgz#7cb860359ba3be90e040b26b729ce4bfa654c523" @@ -3553,6 +4118,13 @@ doctrine@0.7.2: esutils "^1.1.6" isarray "0.0.1" +dom-converter@^0.2: + version "0.2.0" + resolved "https://registry.yarnpkg.com/dom-converter/-/dom-converter-0.2.0.tgz#6721a9daee2e293682955b6afe416771627bb768" + integrity sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA== + dependencies: + utila "~0.4" + dom-serialize@^2.2.0: version "2.2.1" resolved "https://registry.yarnpkg.com/dom-serialize/-/dom-serialize-2.2.1.tgz#562ae8999f44be5ea3076f5419dcd59eb43ac95b" @@ -3563,11 +4135,52 @@ dom-serialize@^2.2.0: extend "^3.0.0" void-elements "^2.0.0" +dom-serializer@0: + version "0.2.2" + resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-0.2.2.tgz#1afb81f533717175d478655debc5e332d9f9bb51" + integrity sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g== + dependencies: + domelementtype "^2.0.1" + entities "^2.0.0" + domain-browser@^1.1.1: version "1.2.0" resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-1.2.0.tgz#3d31f50191a6749dd1375a7f522e823d42e54eda" integrity sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA== +domelementtype@1, domelementtype@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-1.3.1.tgz#d048c44b37b0d10a7f2a3d5fee3f4333d790481f" + integrity sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w== + +domelementtype@^2.0.1: + version "2.1.0" + resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.1.0.tgz#a851c080a6d1c3d94344aed151d99f669edf585e" + integrity sha512-LsTgx/L5VpD+Q8lmsXSHW2WpA+eBlZ9HPf3erD1IoPF00/3JKHZ3BknUVA2QGDNu69ZNmyFmCWBSO45XjYKC5w== + +domhandler@^2.3.0: + version "2.4.2" + resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-2.4.2.tgz#8805097e933d65e85546f726d60f5eb88b44f803" + integrity sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA== + dependencies: + domelementtype "1" + +domutils@^1.5.1, domutils@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/domutils/-/domutils-1.7.0.tgz#56ea341e834e06e6748af7a1cb25da67ea9f8c2a" + integrity sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg== + dependencies: + dom-serializer "0" + domelementtype "1" + +dot-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/dot-case/-/dot-case-3.0.4.tgz#9b2b670d00a431667a8a75ba29cd1b98809ce751" + integrity sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w== + dependencies: + no-case "^3.0.4" + tslib "^2.0.3" + dot-prop@^4.2.0: version "4.2.1" resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-4.2.1.tgz#45884194a71fc2cda71cbb4bceb3a4dd2f433ba4" @@ -3671,6 +4284,28 @@ emojis-list@^2.0.0: resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-2.1.0.tgz#4daa4d9db00f9819880c79fa457ae5b09a1fd389" integrity sha1-TapNnbAPmBmIDHn6RXrlsJof04k= +emojis-list@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-3.0.0.tgz#5570662046ad29e2e916e71aae260abdff4f6a78" + integrity sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q== + +emotion-theming@10.0.27: + version "10.0.27" + resolved "https://registry.yarnpkg.com/emotion-theming/-/emotion-theming-10.0.27.tgz#1887baaec15199862c89b1b984b79806f2b9ab10" + integrity sha512-MlF1yu/gYh8u+sLUqA0YuA9JX0P4Hb69WlKc/9OLo+WCXuX6sy/KoIa+qJimgmr2dWqnypYKYPX37esjDBbhdw== + dependencies: + "@babel/runtime" "^7.5.5" + "@emotion/weak-memoize" "0.2.5" + hoist-non-react-statics "^3.3.0" + +emotion@10.0.27: + version "10.0.27" + resolved "https://registry.yarnpkg.com/emotion/-/emotion-10.0.27.tgz#f9ca5df98630980a23c819a56262560562e5d75e" + integrity sha512-2xdDzdWWzue8R8lu4G76uWX5WhyQuzATon9LmNeCy/2BHVC6dsEpfhN1a0qhELgtDVdjyEA6J8Y/VlI5ZnaH0g== + dependencies: + babel-plugin-emotion "^10.0.27" + create-emotion "^10.0.27" + encodeurl@~1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" @@ -3744,6 +4379,16 @@ ent@~2.2.0: resolved "https://registry.yarnpkg.com/ent/-/ent-2.2.0.tgz#e964219325a21d05f44466a2f686ed6ce5f5dd1d" integrity sha1-6WQhkyWiHQX0RGai9obtbOX13R0= +entities@^1.1.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/entities/-/entities-1.1.2.tgz#bdfa735299664dfafd34529ed4f8522a275fea56" + integrity sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w== + +entities@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/entities/-/entities-2.1.0.tgz#992d3129cf7df6870b96c57858c249a120f8b8b5" + integrity sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w== + env-paths@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-1.0.0.tgz#4168133b42bb05c38a35b1ae4397c8298ab369e0" @@ -4143,11 +4788,30 @@ fast-glob@^2.2.6: merge2 "^1.2.3" micromatch "^3.1.10" +fast-glob@^3.1.1, fast-glob@^3.2.4: + version "3.2.5" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.5.tgz#7939af2a656de79a4f1901903ee8adcaa7cb9661" + integrity sha512-2DtFcgT68wiTTiwZ2hNdJfcHNke9XOfnwmBRWXhmeKM8rF0TGwmC/Qto3S7RoZKp5cilZbxzO5iTNTQsJ+EeDg== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.0" + merge2 "^1.3.0" + micromatch "^4.0.2" + picomatch "^2.2.1" + fast-json-stable-stringify@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz#d5142c0caee6b1189f87d3a76111064f86c8bbf2" integrity sha1-1RQsDK7msRifh9OnYREGT4bIu/I= +fastq@^1.6.0: + version "1.10.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.10.0.tgz#74dbefccade964932cdf500473ef302719c652bb" + integrity sha512-NL2Qc5L3iQEsyYzweq7qfgy5OtXCmGzGvhElGEd/SoFWEMOEczNh5s5ocaF01HDetxz+p8ecjNPA6cZxxIHmzA== + dependencies: + reusify "^1.0.4" + fd-slicer@~1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/fd-slicer/-/fd-slicer-1.1.0.tgz#25c7c89cb1f9077f8891bbe61d8f390eae256f1e" @@ -4228,6 +4892,20 @@ find-cache-dir@^2.1.0: make-dir "^2.0.0" pkg-dir "^3.0.0" +find-cache-dir@^3.3.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-3.3.1.tgz#89b33fad4a4670daa94f855f7fbe31d6d84fe880" + integrity sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ== + dependencies: + commondir "^1.0.1" + make-dir "^3.0.2" + pkg-dir "^4.1.0" + +find-root@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/find-root/-/find-root-1.1.0.tgz#abcfc8ba76f708c42a97b3d685b7e9450bfb9ce4" + integrity sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng== + find-up@^1.0.0: version "1.1.2" resolved "https://registry.yarnpkg.com/find-up/-/find-up-1.1.2.tgz#6b2e9822b1a2ce0a60ab64d610eccad53cb24d0f" @@ -4250,7 +4928,7 @@ find-up@^3.0.0: dependencies: locate-path "^3.0.0" -find-up@^4.1.0: +find-up@^4.0.0, find-up@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== @@ -4375,6 +5053,13 @@ fs-minipass@^1.2.5: dependencies: minipass "^2.2.1" +fs-minipass@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" + integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== + dependencies: + minipass "^3.0.0" + fs-write-stream-atomic@^1.0.8: version "1.0.10" resolved "https://registry.yarnpkg.com/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz#b47df53493ef911df75731e70a9ded0189db40c9" @@ -4555,6 +5240,13 @@ glob-parent@^5.0.0: dependencies: is-glob "^4.0.1" +glob-parent@^5.1.0, glob-parent@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.1.tgz#b6c1ef417c4e5663ea498f1c45afac6916bbc229" + integrity sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ== + dependencies: + is-glob "^4.0.1" + glob-promise@^3.4.0: version "3.4.0" resolved "https://registry.yarnpkg.com/glob-promise/-/glob-promise-3.4.0.tgz#b6b8f084504216f702dc2ce8c9bc9ac8866fdb20" @@ -4637,6 +5329,18 @@ globals@^9.18.0: resolved "https://registry.yarnpkg.com/globals/-/globals-9.18.0.tgz#aa3896b3e69b487f17e31ed2143d69a8e30c2d8a" integrity sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ== +globby@^11.0.1: + version "11.0.2" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.0.2.tgz#1af538b766a3b540ebfb58a32b2e2d5897321d83" + integrity sha512-2ZThXDvvV8fYFRVIxnrMQBipZQDr7MxKAmQK1vujaj9/7eF0efG7BPUKJ7jP7G5SLF37xKDXvO4S/KKLj/Z0og== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.1.1" + ignore "^5.1.4" + merge2 "^1.3.0" + slash "^3.0.0" + globby@^9.2.0: version "9.2.0" resolved "https://registry.yarnpkg.com/globby/-/globby-9.2.0.tgz#fd029a706c703d29bdd170f4b6db3a3f7a7cb63d" @@ -4832,6 +5536,11 @@ hash.js@^1.0.0, hash.js@^1.0.3: inherits "^2.0.3" minimalistic-assert "^1.0.1" +he@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" + integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== + hmac-drbg@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" @@ -4841,6 +5550,13 @@ hmac-drbg@^1.0.0: minimalistic-assert "^1.0.0" minimalistic-crypto-utils "^1.0.1" +hoist-non-react-statics@^3.3.0: + version "3.3.2" + resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" + integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw== + dependencies: + react-is "^16.7.0" + homedir-polyfill@^1.0.1: version "1.0.3" resolved "https://registry.yarnpkg.com/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz#743298cef4e5af3e194161fbadcc2151d3a058e8" @@ -4863,6 +5579,46 @@ html-escaper@^2.0.0: resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== +html-minifier-terser@^5.0.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/html-minifier-terser/-/html-minifier-terser-5.1.1.tgz#922e96f1f3bb60832c2634b79884096389b1f054" + integrity sha512-ZPr5MNObqnV/T9akshPKbVgyOqLmy+Bxo7juKCfTfnjNniTAMdy4hz21YQqoofMBJD2kdREaqPPdThoR78Tgxg== + dependencies: + camel-case "^4.1.1" + clean-css "^4.2.3" + commander "^4.1.1" + he "^1.2.0" + param-case "^3.0.3" + relateurl "^0.2.7" + terser "^4.6.3" + +html-webpack-plugin@4.5.1: + version "4.5.1" + resolved "https://registry.yarnpkg.com/html-webpack-plugin/-/html-webpack-plugin-4.5.1.tgz#40aaf1b5cb78f2f23a83333999625c20929cda65" + integrity sha512-yzK7RQZwv9xB+pcdHNTjcqbaaDZ+5L0zJHXfi89iWIZmb/FtzxhLk0635rmJihcQbs3ZUF27Xp4oWGx6EK56zg== + dependencies: + "@types/html-minifier-terser" "^5.0.0" + "@types/tapable" "^1.0.5" + "@types/webpack" "^4.41.8" + html-minifier-terser "^5.0.1" + loader-utils "^1.2.3" + lodash "^4.17.20" + pretty-error "^2.1.1" + tapable "^1.1.3" + util.promisify "1.0.0" + +htmlparser2@^3.10.1: + version "3.10.1" + resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-3.10.1.tgz#bd679dc3f59897b6a34bb10749c855bb53a9392f" + integrity sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ== + dependencies: + domelementtype "^1.3.1" + domhandler "^2.3.0" + domutils "^1.5.1" + entities "^1.1.1" + inherits "^2.0.1" + readable-stream "^3.1.1" + http-cache-semantics@^3.8.1: version "3.8.1" resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-3.8.1.tgz#39b0e16add9b605bf0a9ef3d9daaf4843b4cacd2" @@ -4995,6 +5751,11 @@ ignore@^4.0.3: resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== +ignore@^5.1.4: + version "5.1.8" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.1.8.tgz#f150a8b50a34289b33e22f5889abd4d8016f0e57" + integrity sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw== + import-fresh@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-2.0.0.tgz#d81355c15612d386c61f9ddd3922d4304822a546" @@ -5003,6 +5764,14 @@ import-fresh@^2.0.0: caller-path "^2.0.0" resolve-from "^3.0.0" +import-fresh@^3.1.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + import-local@2.0.0, import-local@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/import-local/-/import-local-2.0.0.tgz#55070be38a5993cf18ef6db7e961f5bee5c5a09d" @@ -5128,7 +5897,7 @@ interpret@1.2.0: resolved "https://registry.yarnpkg.com/interpret/-/interpret-1.2.0.tgz#d5061a6224be58e8083985f5014d844359576296" integrity sha512-mT34yGKMNceBQUoVn7iCDKDntA7SC6gycMAWzGx1z/CMCTV7b2AAtXlo3nRyHZ1FelRkQbQjprHSYGwzLtkVbw== -invariant@^2.2.2: +invariant@^2.2.2, invariant@^2.2.4: version "2.2.4" resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6" integrity sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA== @@ -5205,6 +5974,13 @@ is-ci@^2.0.0: dependencies: ci-info "^2.0.0" +is-core-module@^2.1.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.2.0.tgz#97037ef3d52224d85163f5597b2b63d9afed981a" + integrity sha512-XRAfAdyyY5F5cOXn7hYQDqh2Xmii+DEfIcQGxK/uNwMHhIkPWO0g8msXcbzLe+MpGoR951MlqM/2iIlU4vKDdQ== + dependencies: + has "^1.0.3" + is-data-descriptor@^0.1.4: version "0.1.4" resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56" @@ -5623,6 +6399,17 @@ jest-regex-util@^25.2.6: resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-25.2.6.tgz#d847d38ba15d2118d3b06390056028d0f2fd3964" integrity sha512-KQqf7a0NrtCkYmZZzodPftn7fL1cq3GQAFVMn5Hg8uKx/fIenLEobNanUxb7abQ1sjADHBseG/2FGpsv/wr+Qw== +joi@~17.3.0: + version "17.3.0" + resolved "https://registry.yarnpkg.com/joi/-/joi-17.3.0.tgz#f1be4a6ce29bc1716665819ac361dfa139fff5d2" + integrity sha512-Qh5gdU6niuYbUIUV5ejbsMiiFmBdw8Kcp8Buj2JntszCkCfxJ9Cz76OtHxOZMPXrt5810iDIXs+n1nNVoquHgg== + dependencies: + "@hapi/hoek" "^9.0.0" + "@hapi/topo" "^5.0.0" + "@sideway/address" "^4.1.0" + "@sideway/formula" "^3.0.0" + "@sideway/pinpoint" "^2.0.0" + js-polyfills@0.1.42: version "0.1.42" resolved "https://registry.yarnpkg.com/js-polyfills/-/js-polyfills-0.1.42.tgz#5d484902b361e3cf601fd23ad0f30bafcc93f148" @@ -5728,6 +6515,13 @@ json5@^1.0.1: dependencies: minimist "^1.2.0" +json5@^2.1.2: + version "2.1.3" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.1.3.tgz#c9b0f7fa9233bfe5807fe66fcf3a5617ed597d43" + integrity sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA== + dependencies: + minimist "^1.2.5" + jsonfile@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb" @@ -5997,6 +6791,15 @@ loader-utils@1.2.3, loader-utils@^1.0.2, loader-utils@^1.1.0, loader-utils@^1.2. emojis-list "^2.0.0" json5 "^1.0.1" +loader-utils@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-2.0.0.tgz#e4cace5b816d425a166b5f097e10cd12b36064b0" + integrity sha512-rP4F0h2RaWSvPEkD7BLDFQnvSf+nK+wr3ESUjNTyAGobqrijmW92zc+SO6d4p4B1wh7+B/Jg1mkQe5NYUEHtHQ== + dependencies: + big.js "^5.2.2" + emojis-list "^3.0.0" + json5 "^2.1.2" + locate-path@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" @@ -6130,16 +6933,16 @@ lodash.zip@^4.2.0: resolved "https://registry.yarnpkg.com/lodash.zip/-/lodash.zip-4.2.0.tgz#ec6662e4896408ed4ab6c542a3990b72cc080020" integrity sha1-7GZi5IlkCO1KtsVCo5kLcswIACA= +lodash@4.17.20, lodash@^4.17.19, lodash@^4.17.20: + version "4.17.20" + resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.20.tgz#b44a9b6297bcb698f1c51a3545a2b3b368d59c52" + integrity sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA== + lodash@^4.17.11, lodash@^4.17.12, lodash@^4.17.13, lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.4, lodash@^4.2.1, lodash@~4.17.10: version "4.17.19" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.19.tgz#e48ddedbe30b3321783c5b4301fbd353bc1e4a4b" integrity sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ== -lodash@^4.17.20: - version "4.17.20" - resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.20.tgz#b44a9b6297bcb698f1c51a3545a2b3b368d59c52" - integrity sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA== - log-update@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/log-update/-/log-update-4.0.0.tgz#589ecd352471f2a1c0c570287543a64dfd20e0a1" @@ -6171,7 +6974,7 @@ loglevel@^1.6.0: resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.6.3.tgz#77f2eb64be55a404c9fd04ad16d57c1d6d6b1280" integrity sha512-LoEDv5pgpvWgPF4kNYuIp0qqSJVWak/dML0RY74xlzMZiT9w77teNAwKYKWBTYjlokMirg+o3jBwp+vlLrcfAA== -loose-envify@^1.0.0: +loose-envify@^1.0.0, loose-envify@^1.1.0, loose-envify@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf" integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q== @@ -6186,6 +6989,13 @@ loud-rejection@^1.0.0: currently-unhandled "^0.4.1" signal-exit "^3.0.0" +lower-case@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-2.0.2.tgz#6fa237c63dbdc4a82ca0fd882e4722dc5e634e28" + integrity sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg== + dependencies: + tslib "^2.0.3" + lowercase-keys@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-2.0.0.tgz#2603e78b7b4b0006cbca2fbcc8a3202558ac9479" @@ -6206,6 +7016,13 @@ lru-cache@^5.1.1: dependencies: yallist "^3.0.2" +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + lru-queue@0.1: version "0.1.0" resolved "https://registry.yarnpkg.com/lru-queue/-/lru-queue-0.1.0.tgz#2738bd9f0d3cf4f84490c5736c48699ac632cda3" @@ -6233,6 +7050,13 @@ make-dir@^2.0.0, make-dir@^2.1.0: pify "^4.0.1" semver "^5.6.0" +make-dir@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" + integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== + dependencies: + semver "^6.0.0" + make-error@^1.1.1: version "1.3.5" resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.5.tgz#efe4e81f6db28cadd605c70f29c831b58ef776c8" @@ -6414,6 +7238,11 @@ merge2@^1.2.3: resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.3.0.tgz#5b366ee83b2f1582c48f87e47cf1a9352103ca81" integrity sha512-2j4DAdlBOkiSZIsaXk4mTE3sRS02yBHAtfy127xRV3bQUFqXkjHCHLW6Scv7DwNRbIWNHH8zpnz9zMaKXIdvYw== +merge2@^1.3.0: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + methods@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" @@ -6557,6 +7386,27 @@ minimist@^1.2.5: resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== +minipass-collect@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/minipass-collect/-/minipass-collect-1.0.2.tgz#22b813bf745dc6edba2576b940022ad6edc8c617" + integrity sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA== + dependencies: + minipass "^3.0.0" + +minipass-flush@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/minipass-flush/-/minipass-flush-1.0.5.tgz#82e7135d7e89a50ffe64610a787953c4c4cbb373" + integrity sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw== + dependencies: + minipass "^3.0.0" + +minipass-pipeline@^1.2.2: + version "1.2.4" + resolved "https://registry.yarnpkg.com/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz#68472f79711c084657c067c5c6ad93cddea8214c" + integrity sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A== + dependencies: + minipass "^3.0.0" + minipass@^2.2.1, minipass@^2.3.5: version "2.3.5" resolved "https://registry.yarnpkg.com/minipass/-/minipass-2.3.5.tgz#cacebe492022497f656b0f0f51e2682a9ed2d848" @@ -6573,6 +7423,13 @@ minipass@^2.8.6: safe-buffer "^5.1.2" yallist "^3.0.0" +minipass@^3.0.0, minipass@^3.1.1: + version "3.1.3" + resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.1.3.tgz#7d42ff1f39635482e15f9cdb53184deebd5815fd" + integrity sha512-Mgd2GdMVzY+x3IJ+oHnVM+KG3lA5c8tnabyJKmHSaG2kAGpudxuOf8ToDkhumF7UzME7DecbQE9uOZhNm7PuJg== + dependencies: + yallist "^4.0.0" + minizlib@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-1.2.1.tgz#dd27ea6136243c7c880684e8672bb3a45fd9b614" @@ -6580,6 +7437,14 @@ minizlib@^1.2.1: dependencies: minipass "^2.2.1" +minizlib@^2.1.1: + version "2.1.2" + resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" + integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== + dependencies: + minipass "^3.0.0" + yallist "^4.0.0" + mississippi@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/mississippi/-/mississippi-3.0.0.tgz#ea0a3291f97e0b5e8776b363d5f0a12d94c67022" @@ -6616,7 +7481,7 @@ mkdirp-promise@^5.0.1: dependencies: mkdirp "*" -mkdirp@*, mkdirp@^1.0.4: +mkdirp@*, mkdirp@^1.0.3, mkdirp@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== @@ -6771,6 +7636,14 @@ nise@^4.0.4: just-extend "^4.0.2" path-to-regexp "^1.7.0" +no-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" + integrity sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg== + dependencies: + lower-case "^2.0.2" + tslib "^2.0.3" + node-fetch-npm@^2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/node-fetch-npm/-/node-fetch-npm-2.0.2.tgz#7258c9046182dca345b4208eda918daf33697ff7" @@ -6980,6 +7853,13 @@ npm-run-path@^2.0.0: gauge "~2.7.3" set-blocking "~2.0.0" +nth-check@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-1.0.2.tgz#b2bd295c37e3dd58a3bf0700376663ba4d9cf05c" + integrity sha512-WeBOdju8SnzPN5vTUJYxYUxLeXpCaVP5i5e0LF8fg7WORF2Wd7wFX/pk0tYZk7s8T+J7VLy0Da6J1+wCT0AtHg== + dependencies: + boolbase "~1.0.0" + number-is-nan@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" @@ -7162,6 +8042,13 @@ p-limit@^2.2.0: dependencies: p-try "^2.0.0" +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + p-locate@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" @@ -7195,6 +8082,13 @@ p-map@^2.1.0: resolved "https://registry.yarnpkg.com/p-map/-/p-map-2.1.0.tgz#310928feef9c9ecc65b68b17693018a665cea175" integrity sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw== +p-map@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" + integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== + dependencies: + aggregate-error "^3.0.0" + p-pipe@^1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/p-pipe/-/p-pipe-1.2.0.tgz#4b1a11399a11520a67790ee5a0c1d5881d6befe9" @@ -7250,6 +8144,21 @@ parallel-transform@^1.1.0: inherits "^2.0.3" readable-stream "^2.1.5" +param-case@^3.0.3: + version "3.0.4" + resolved "https://registry.yarnpkg.com/param-case/-/param-case-3.0.4.tgz#7d17fe4aa12bde34d4a77d91acfb6219caad01c5" + integrity sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A== + dependencies: + dot-case "^3.0.4" + tslib "^2.0.3" + +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + parse-asn1@^5.0.0: version "5.1.4" resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.4.tgz#37f6628f823fbdeb2273b4d540434a22f3ef1fcc" @@ -7339,6 +8248,14 @@ parseurl@~1.3.3: resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== +pascal-case@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/pascal-case/-/pascal-case-3.1.2.tgz#b48e0ef2b98e205e7c1dae747d0b1508237660eb" + integrity sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g== + dependencies: + no-case "^3.0.4" + tslib "^2.0.3" + pascalcase@^0.1.1: version "0.1.1" resolved "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz#b363e55e8006ca6fe21784d2db22bd15d7917f14" @@ -7414,6 +8331,11 @@ path-type@^3.0.0: dependencies: pify "^3.0.0" +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + pause-stream@0.0.11: version "0.0.11" resolved "https://registry.yarnpkg.com/pause-stream/-/pause-stream-0.0.11.tgz#fe5a34b0cbce12b5aa6a2b403ee2e73b602f1445" @@ -7447,6 +8369,11 @@ picomatch@^2.0.4, picomatch@^2.0.5: resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.0.7.tgz#514169d8c7cd0bdbeecc8a2609e34a7163de69f6" integrity sha512-oLHIdio3tZ0qH76NybpeneBhYVj0QFTfXEFTc/B3zKQspYfYYkWYgFsmzo+4kvId/bQRcNkVeguI3y+CD22BtA== +picomatch@^2.2.1: + version "2.2.2" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" + integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== + pidtree@^0.3.0: version "0.3.0" resolved "https://registry.yarnpkg.com/pidtree/-/pidtree-0.3.0.tgz#f6fada10fccc9f99bf50e90d0b23d72c9ebc2e6b" @@ -7486,6 +8413,13 @@ pkg-dir@^3.0.0: dependencies: find-up "^3.0.0" +pkg-dir@^4.1.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" + integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== + dependencies: + find-up "^4.0.0" + posix-character-classes@^0.1.0: version "0.1.1" resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab" @@ -7496,6 +8430,14 @@ prettier@2.2.1, prettier@^2.2.0: resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.2.1.tgz#795a1a78dd52f073da0cd42b21f9c91381923ff5" integrity sha512-PqyhM2yCjg/oKkFPtTGUojv7gnZAoG80ttl45O6x2Ug/rMJw4wcc9k6aaf2hibP7BGVCCM33gZoGjyvt9mm16Q== +pretty-error@^2.1.1: + version "2.1.2" + resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-2.1.2.tgz#be89f82d81b1c86ec8fdfbc385045882727f93b6" + integrity sha512-EY5oDzmsX5wvuynAByrmY0P0hcp+QpnAKbJng2A2MPjVKXCxrDSUkzghVJ4ZGPIv+JC4gX8fPUWscC0RtjsWGw== + dependencies: + lodash "^4.17.20" + renderkid "^2.0.4" + pretty-format@^25.3.0: version "25.3.0" resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-25.3.0.tgz#d0a4f988ff4a6cd350342fdabbb809aeb4d49ad5" @@ -7548,6 +8490,15 @@ promzard@^0.3.0: dependencies: read "1" +prop-types@^15.6.2: + version "15.7.2" + resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.7.2.tgz#52c41e75b8c87e72b9d9360e0206b99dcbffa6c5" + integrity sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ== + dependencies: + loose-envify "^1.4.0" + object-assign "^4.1.1" + react-is "^16.8.1" + proto-list@~1.2.1: version "1.2.4" resolved "https://registry.yarnpkg.com/proto-list/-/proto-list-1.2.4.tgz#212d5bfe1318306a420f6402b8e26ff39647a849" @@ -7755,11 +8706,43 @@ rc@^1.2.7: minimist "^1.2.0" strip-json-comments "~2.0.1" -react-is@^16.12.0: +react-dom@16: + version "16.14.0" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-16.14.0.tgz#7ad838ec29a777fb3c75c3a190f661cf92ab8b89" + integrity sha512-1gCeQXDLoIqMgqD3IO2Ah9bnf0w9kzhwN5q4FGnHZ67hBm9yePzB5JJAIQCc8x3pFnNlwFq4RidZggNAAkzWWw== + dependencies: + loose-envify "^1.1.0" + object-assign "^4.1.1" + prop-types "^15.6.2" + scheduler "^0.19.1" + +react-input-mask@2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/react-input-mask/-/react-input-mask-2.0.4.tgz#9ade5cf8196f4a856dbf010820fe75a795f3eb14" + integrity sha512-1hwzMr/aO9tXfiroiVCx5EtKohKwLk/NT8QlJXHQ4N+yJJFyUuMT+zfTpLBwX/lK3PkuMlievIffncpMZ3HGRQ== + dependencies: + invariant "^2.2.4" + warning "^4.0.2" + +react-is@^16.12.0, react-is@^16.7.0, react-is@^16.8.1: version "16.13.1" resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== +"react-loads-next@npm:react-loads@9.2.3": + version "9.2.3" + resolved "https://registry.yarnpkg.com/react-loads/-/react-loads-9.2.3.tgz#141dd23cc94a7658c37cc65b798c03e93054a9ff" + integrity sha512-RbXHqMGlWRDRT4aYUg+CF6grveeREAWXb7ZBwkwq0na4CorxzcyP0V/nqPQzZ9BY98YNRd30QGDhvMjA9qG7zg== + +react@16: + version "16.14.0" + resolved "https://registry.yarnpkg.com/react/-/react-16.14.0.tgz#94d776ddd0aaa37da3eda8fc5b6b18a4c9a3114d" + integrity sha512-0X2CImDkJGApiAlcf0ODKIneSwBPhqJawOa5wCtKbu7ZECrmS26NvtSILynQ66cgkT/RJ4LidJOc3bUESwmU8g== + dependencies: + loose-envify "^1.1.0" + object-assign "^4.1.1" + prop-types "^15.6.2" + read-cmd-shim@^1.0.1: version "1.0.4" resolved "https://registry.yarnpkg.com/read-cmd-shim/-/read-cmd-shim-1.0.4.tgz#b4a53d43376211b45243f0072b6e603a8e37640d" @@ -7918,6 +8901,36 @@ readdirp@^3.1.1: dependencies: picomatch "^2.0.4" +reakit-system@^0.15.0: + version "0.15.1" + resolved "https://registry.yarnpkg.com/reakit-system/-/reakit-system-0.15.1.tgz#bf5cc7a03f60a817373bc9cbb4a689c1f4100547" + integrity sha512-PkqfAyEohtcEu/gUvKriCv42NywDtUgvocEN3147BI45dOFAB89nrT7wRIbIcKJiUT598F+JlPXAZZVLWhc1Kg== + dependencies: + reakit-utils "^0.15.1" + +reakit-utils@^0.15.0, reakit-utils@^0.15.1: + version "0.15.1" + resolved "https://registry.yarnpkg.com/reakit-utils/-/reakit-utils-0.15.1.tgz#797f0a43f6a1dbc22d161224d5d2272e287dbfe3" + integrity sha512-6cZgKGvOkAMQgkwU9jdYbHfkuIN1Pr+vwcB19plLvcTfVN0Or10JhIuj9X+JaPZyI7ydqTDFaKNdUcDP69o/+Q== + +reakit-warning@^0.6.0: + version "0.6.1" + resolved "https://registry.yarnpkg.com/reakit-warning/-/reakit-warning-0.6.1.tgz#dba33bb8866aebe30e67ac433ead707d16d38a36" + integrity sha512-poFUV0EyxB+CcV9uTNBAFmcgsnR2DzAbOTkld4Ul+QOKSeEHZB3b3+MoZQgcYHmbvG19Na1uWaM7ES+/Eyr8tQ== + dependencies: + reakit-utils "^0.15.1" + +reakit@1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/reakit/-/reakit-1.3.0.tgz#52ea989111504ae89584b7482b8a98c82c73523b" + integrity sha512-2hTq1VQ8F5hUksyNFgCWhLuBipMlpjOIFfqwbossWgNj36pQQMsvB0kb/+vcvQ0YgS6iXCLFq9lI2O5G4wAkgw== + dependencies: + "@popperjs/core" "^2.4.4" + body-scroll-lock "^3.1.5" + reakit-system "^0.15.0" + reakit-utils "^0.15.0" + reakit-warning "^0.6.0" + redent@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/redent/-/redent-1.0.0.tgz#cf916ab1fd5f1f16dfb20822dd6ec7f730c2afde" @@ -7952,6 +8965,11 @@ regenerator-runtime@^0.11.0: resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz#be05ad7f9bf7d22e056f9726cee5017fbf19e2e9" integrity sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg== +regenerator-runtime@^0.13.4: + version "0.13.7" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz#cac2dacc8a1ea675feaabaeb8ae833898ae46f55" + integrity sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew== + regex-not@^1.0.0, regex-not@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c" @@ -7960,11 +8978,27 @@ regex-not@^1.0.0, regex-not@^1.0.2: extend-shallow "^3.0.2" safe-regex "^1.1.0" +relateurl@^0.2.7: + version "0.2.7" + resolved "https://registry.yarnpkg.com/relateurl/-/relateurl-0.2.7.tgz#54dbf377e51440aca90a4cd274600d3ff2d888a9" + integrity sha1-VNvzd+UUQKypCkzSdGANP/LYiKk= + remove-trailing-separator@^1.0.1: version "1.1.0" resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef" integrity sha1-wkvOKig62tW8P1jg1IJJuSN52O8= +renderkid@^2.0.4: + version "2.0.5" + resolved "https://registry.yarnpkg.com/renderkid/-/renderkid-2.0.5.tgz#483b1ac59c6601ab30a7a596a5965cabccfdd0a5" + integrity sha512-ccqoLg+HLOHq1vdfYNm4TBeaCDIi1FLt3wGojTDSvdewUv65oTmI3cnT2E4hRjl1gzKZIPK+KZrXzlUYKnR+vQ== + dependencies: + css-select "^2.0.2" + dom-converter "^0.2" + htmlparser2 "^3.10.1" + lodash "^4.17.20" + strip-ansi "^3.0.0" + repeat-element@^1.1.2: version "1.1.3" resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.3.tgz#782e0d825c0c5a3bb39731f84efee6b742e6b1ce" @@ -8074,6 +9108,14 @@ resolve@^1.10.0, resolve@^1.3.2: dependencies: path-parse "^1.0.6" +resolve@^1.12.0: + version "1.19.0" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.19.0.tgz#1af5bf630409734a067cae29318aac7fa29a267c" + integrity sha512-rArEXAgsBG4UgRGcynxWIWKFvh/XZCcS8UJdHhwy91zwAvCZIbcs+vAbflgBnNjYMs/i/i+/Ux6IZhML1yPvxg== + dependencies: + is-core-module "^2.1.0" + path-parse "^1.0.6" + responselike@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/responselike/-/responselike-2.0.0.tgz#26391bcc3174f750f9a79eacc40a12a5c42d7723" @@ -8114,6 +9156,11 @@ retry@^0.10.0: resolved "https://registry.yarnpkg.com/retry/-/retry-0.10.1.tgz#e76388d217992c252750241d3d3956fed98d8ff4" integrity sha1-52OI0heZLCUnUCQdPTlW/tmNj/Q= +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + rfdc@^1.1.4: version "1.1.4" resolved "https://registry.yarnpkg.com/rfdc/-/rfdc-1.1.4.tgz#ba72cc1367a0ccd9cf81a870b3b58bd3ad07f8c2" @@ -8124,7 +9171,7 @@ rgb2hex@^0.1.0: resolved "https://registry.yarnpkg.com/rgb2hex/-/rgb2hex-0.1.9.tgz#5d3e0e14b0177b568e6f0d5b43e34fbfdb670346" integrity sha512-32iuQzhOjyT+cv9aAFRBJ19JgHwzQwbjUhH3Fj2sWW2EEGAW8fpFrDFP5ndoKDxJaLO06x1hE3kyuIFrUQtybQ== -rimraf@2, rimraf@^2.6.2: +rimraf@2, rimraf@^2.6.2, rimraf@^2.7.1: version "2.7.1" resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== @@ -8160,6 +9207,11 @@ ripemd160@^2.0.0, ripemd160@^2.0.1: hash-base "^3.0.0" inherits "^2.0.1" +round-to@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/round-to/-/round-to-4.1.0.tgz#148d768d18b2f127f78e6648cb8b0a5943c416bf" + integrity sha512-H/4z+4QdWS82iMZ23+5St302Mv2jJws0hUvEogrD6gC8NN6Z5TalDtbg51owCrVy4V/4c8ePvwVLNtlhEfPo5g== + rrweb-snapshot@1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/rrweb-snapshot/-/rrweb-snapshot-1.0.1.tgz#f3800f4deb434da02b6086533c5c38e23e7e796b" @@ -8172,6 +9224,11 @@ run-async@^2.2.0: dependencies: is-promise "^2.1.0" +run-parallel@^1.1.9: + version "1.1.10" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.1.10.tgz#60a51b2ae836636c81377df16cb107351bcd13ef" + integrity sha512-zb/1OuZ6flOlH6tQyMPUrE3x3Ulxjlo9WIVXR4yVYi4H9UXQaeIsPbLn2R3O3vQCnDKkAl2qHiuocKKX4Tz/Sw== + run-queue@^1.0.0, run-queue@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/run-queue/-/run-queue-1.0.3.tgz#e848396f057d223f24386924618e25694161ec47" @@ -8213,6 +9270,14 @@ sax@^1.2.4: resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== +scheduler@^0.19.1: + version "0.19.1" + resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.19.1.tgz#4f3e2ed2c1a7d65681f4c854fa8c5a1ccb40f196" + integrity sha512-n/zwRWRYSUj0/3g/otKDRPMh6qv2SYMWNq85IEa8iZyAv8od9zDYpGSnpBEjNgcMNq6Scbu5KfIPxNF72R/2EA== + dependencies: + loose-envify "^1.1.0" + object-assign "^4.1.1" + schema-utils@^0.3.0: version "0.3.0" resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-0.3.0.tgz#f5877222ce3e931edae039f17eb3716e7137f8cf" @@ -8229,6 +9294,15 @@ schema-utils@^1.0.0: ajv-errors "^1.0.0" ajv-keywords "^3.1.0" +schema-utils@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.0.0.tgz#67502f6aa2b66a2d4032b4279a2944978a0913ef" + integrity sha512-6D82/xSzO094ajanoOSbe4YvXWMfn2A//8Y1+MUqFAJul5Bs+yn36xbK9OtNDcRVSBJ9jjeoXftM6CfztsjOAA== + dependencies: + "@types/json-schema" "^7.0.6" + ajv "^6.12.5" + ajv-keywords "^3.5.2" + selenium-standalone@^6.15.1: version "6.16.0" resolved "https://registry.yarnpkg.com/selenium-standalone/-/selenium-standalone-6.16.0.tgz#ffcf02665c58ff7a7472427ae819ba79c15967ac" @@ -8306,6 +9380,13 @@ serialize-javascript@^4.0.0: dependencies: randombytes "^2.1.0" +serialize-javascript@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-5.0.1.tgz#7886ec848049a462467a97d3d918ebb2aaf934f4" + integrity sha512-SaaNal9imEO737H2c05Og0/8LUXG7EnsZyMa8MzkmuHoELfT6txuj0cMqRj6zfPKnmQ1yasR4PCJc8x+M4JSPA== + dependencies: + randombytes "^2.1.0" + serve-static@1.14.1: version "1.14.1" resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.14.1.tgz#666e636dc4f010f7ef29970a88a674320898b2f9" @@ -8558,7 +9639,7 @@ source-map@^0.5.0, source-map@^0.5.6, source-map@^0.5.7: resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" integrity sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w= -source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: +source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.0, source-map@~0.6.1: version "0.6.1" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== @@ -8649,6 +9730,13 @@ ssri@^6.0.0, ssri@^6.0.1: dependencies: figgy-pudding "^3.5.1" +ssri@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/ssri/-/ssri-8.0.0.tgz#79ca74e21f8ceaeddfcb4b90143c458b8d988808" + integrity sha512-aq/pz989nxVYwn16Tsbj1TqFpD5LLrQxHf5zaHuieFV+R0Bbr4y8qUsOA45hXT/N4/9UNXTarBjnjVmjSOVaAA== + dependencies: + minipass "^3.1.1" + stack-utils@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-1.0.2.tgz#33eba3897788558bebfc2db059dc158ec36cebb8" @@ -8904,6 +9992,11 @@ stubs@^3.0.0: resolved "https://registry.yarnpkg.com/stubs/-/stubs-3.0.0.tgz#e8d2ba1fa9c90570303c030b6900f7d5f89abe5b" integrity sha1-6NK6H6nJBXAwPAMLaQD31fiavls= +styled-tools@1.7.2: + version "1.7.2" + resolved "https://registry.yarnpkg.com/styled-tools/-/styled-tools-1.7.2.tgz#a8f71198535cf785d7db0927cc1c1b88337c4440" + integrity sha512-IjLxzM20RMwAsx8M1QoRlCG/Kmq8lKzCGyospjtSXt/BTIIcvgTonaxQAsKnBrsZNwhpHzO9ADx5te0h76ILVg== + suffix@^0.1.0: version "0.1.1" resolved "https://registry.yarnpkg.com/suffix/-/suffix-0.1.1.tgz#cc58231646a0ef1102f79478ef3a9248fd9c842f" @@ -9011,6 +10104,18 @@ tar@^4.4.10, tar@^4.4.12, tar@^4.4.8: safe-buffer "^5.1.2" yallist "^3.0.3" +tar@^6.0.2: + version "6.1.0" + resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.0.tgz#d1724e9bcc04b977b18d5c573b333a2207229a83" + integrity sha512-DUCttfhsnLCjwoDoFcI+B2iJgYa93vBnDUATYEeRx6sntCTdN01VnqsIuTlALXla/LWooNg0yEGeB+Y8WdFxGA== + dependencies: + chownr "^2.0.0" + fs-minipass "^2.0.0" + minipass "^3.0.0" + minizlib "^2.1.1" + mkdirp "^1.0.3" + yallist "^4.0.0" + teeny-request@6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/teeny-request/-/teeny-request-6.0.1.tgz#9b1f512cef152945827ba7e34f62523a4ce2c5b0" @@ -9070,6 +10175,15 @@ terser@^4.1.2: source-map "~0.6.1" source-map-support "~0.5.12" +terser@^4.6.3: + version "4.8.0" + resolved "https://registry.yarnpkg.com/terser/-/terser-4.8.0.tgz#63056343d7c70bb29f3af665865a46fe03a0df17" + integrity sha512-EAPipTNeWsb/3wLPeup1tVPaXfIaU68xMnVdPafIL1TV05OhASArYyIfFvnvJCNrR2NIOvDVNNTFRa+Re2MWyw== + dependencies: + commander "^2.20.0" + source-map "~0.6.1" + source-map-support "~0.5.12" + text-extensions@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/text-extensions/-/text-extensions-2.0.0.tgz#43eabd1b495482fae4a2bf65e5f56c29f69220f6" @@ -9129,6 +10243,11 @@ timers-ext@^0.1.5, timers-ext@^0.1.7: es5-ext "~0.10.46" next-tick "1" +tinycolor2@1.4.2: + version "1.4.2" + resolved "https://registry.yarnpkg.com/tinycolor2/-/tinycolor2-1.4.2.tgz#3f6a4d1071ad07676d7fa472e1fac40a719d8803" + integrity sha512-vJhccZPs965sV/L2sU4oRQVAos0pQXwsvTLkWYdqJ+a8Q5kPFzJTuOFwy7UniPli44NKQGAglksjvOcpo95aZA== + tmp@0.0.33, tmp@^0.0.33: version "0.0.33" resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.0.33.tgz#6d34335889768d21b2bcda0aa277ced3b1bfadf9" @@ -9294,6 +10413,11 @@ tslib@^1.10.0, tslib@^1.7.1, tslib@^1.8.0, tslib@^1.8.1, tslib@^1.9.0: resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.10.0.tgz#c3c19f95973fb0a62973fb09d90d961ee43e5c8a" integrity sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ== +tslib@^2.0.3: + version "2.1.0" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.1.0.tgz#da60860f1c2ecaa5703ab7d39bc05b6bf988b97a" + integrity sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A== + tslint-config-airbnb@5.11.1: version "5.11.1" resolved "https://registry.yarnpkg.com/tslint-config-airbnb/-/tslint-config-airbnb-5.11.1.tgz#51a27fbb8bf24c144d064a274a71da47e7ece617" @@ -9611,6 +10735,14 @@ util-promisify@^2.1.0: dependencies: object.getownpropertydescriptors "^2.0.3" +util.promisify@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/util.promisify/-/util.promisify-1.0.0.tgz#440f7165a459c9a16dc145eb8e72f35687097030" + integrity sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA== + dependencies: + define-properties "^1.1.2" + object.getownpropertydescriptors "^2.0.3" + util@0.10.3: version "0.10.3" resolved "https://registry.yarnpkg.com/util/-/util-0.10.3.tgz#7afb1afe50805246489e3db7fe0ed379336ac0f9" @@ -9625,6 +10757,11 @@ util@^0.11.0: dependencies: inherits "2.0.3" +utila@~0.4: + version "0.4.0" + resolved "https://registry.yarnpkg.com/utila/-/utila-0.4.0.tgz#8a16a05d445657a3aea5eecc5b12a4fa5379772c" + integrity sha1-ihagXURWV6Oupe7MWxKk+lN5dyw= + utils-merge@1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" @@ -9720,6 +10857,13 @@ vscode-uri@^1.0.6: resolved "https://registry.yarnpkg.com/vscode-uri/-/vscode-uri-1.0.8.tgz#9769aaececae4026fb6e22359cb38946580ded59" integrity sha512-obtSWTlbJ+a+TFRYGaUumtVwb+InIUVI0Lu0VBUAPmj2cU5JutEXg3xUE0c2J5Tcy7h2DEKVJBFi+Y9ZSFzzPQ== +warning@^4.0.2: + version "4.0.3" + resolved "https://registry.yarnpkg.com/warning/-/warning-4.0.3.tgz#16e9e077eb8a86d6af7d64aa1e05fd85b4678ca3" + integrity sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w== + dependencies: + loose-envify "^1.0.0" + watchpack@^1.6.0: version "1.6.0" resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-1.6.0.tgz#4bc12c2ebe8aa277a71f1d3f14d685c7b446cd00" @@ -9855,7 +10999,7 @@ webpack-log@^2.0.0: ansi-colors "^3.0.0" uuid "^3.3.2" -webpack-sources@^1.4.0, webpack-sources@^1.4.1: +webpack-sources@^1.4.0, webpack-sources@^1.4.1, webpack-sources@^1.4.3: version "1.4.3" resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-1.4.3.tgz#eedd8ec0b928fbf1cbfe994e22d2d890f330a933" integrity sha512-lgTS3Xhv1lCOKo7SA5TjKXMjpSM4sBjNV5+q2bqesbSPs5FjGmU6jjtBSkX9b4qW87vDIsCIlUPOEhbZrMdjeQ== @@ -9863,6 +11007,16 @@ webpack-sources@^1.4.0, webpack-sources@^1.4.1: source-list-map "^2.0.0" source-map "~0.6.1" +webpack-webextension-plugin@0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/webpack-webextension-plugin/-/webpack-webextension-plugin-0.3.0.tgz#a5ab82c3692f42adf2efcf56f63463c2ff10e609" + integrity sha512-WwilLIZ4LOnpZUAIRCqZKnJVTVMjKA7YVxBgTfPFjfaXJVtuCZmnw+OX3ZoNr9R9PpYoRsH+abs4W5PC0P3WWw== + dependencies: + chalk "~4.1.0" + joi "~17.3.0" + strip-ansi "^6.0.0" + ws "~7.4.0" + webpack@4.42.1: version "4.42.1" resolved "https://registry.yarnpkg.com/webpack/-/webpack-4.42.1.tgz#ae707baf091f5ca3ef9c38b884287cfe8f1983ef" @@ -10017,6 +11171,11 @@ ws@~3.3.1: safe-buffer "~5.1.0" ultron "~1.1.0" +ws@~7.4.0: + version "7.4.2" + resolved "https://registry.yarnpkg.com/ws/-/ws-7.4.2.tgz#782100048e54eb36fe9843363ab1c68672b261dd" + integrity sha512-T4tewALS3+qsrpGI/8dqNMLIVdq/g/85U98HPMa6F0m6xTbvhXU6RCQLqPH3+SlomNV/LdY6RXEbBpMH6EOJnA== + xmlbuilder@12.0.0: version "12.0.0" resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-12.0.0.tgz#e2ed675e06834a089ddfb84db96e2c2b03f78c1a" @@ -10052,6 +11211,16 @@ yallist@^3.0.0, yallist@^3.0.2, yallist@^3.0.3: resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.0.3.tgz#b4b049e314be545e3ce802236d6cd22cd91c3de9" integrity sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A== +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yaml@^1.7.2: + version "1.10.0" + resolved "https://registry.yarnpkg.com/yaml/-/yaml-1.10.0.tgz#3b593add944876077d4d683fee01081bd9fff31e" + integrity sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg== + yargs-parser@^13.1.0: version "13.1.2" resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-13.1.2.tgz#130f09702ebaeef2650d54ce6e3e5706f7a4fb38" @@ -10162,6 +11331,11 @@ yn@3.1.1: resolved "https://registry.yarnpkg.com/yn/-/yn-3.1.1.tgz#1e87401a09d767c1d5eab26a6e4c185182d2eb50" integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== + zip-stream@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/zip-stream/-/zip-stream-2.0.1.tgz#48a062488afe91dda42f823700fae589753ccd34" From fd6c04afc9abb1ce8f4b4055d9ca35476ee892de Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 17:51:02 +0100 Subject: [PATCH 02/13] adjust code for ESLint --- .eslintignore | 1 + .eslintrc.js | 7 ++++++- .../src/background/domain/logRequests.ts | 4 ++-- .../src/background/domain/replaceBundles.ts | 6 +++++- .../developer-extension/src/popup/{App.tsx => app.tsx} | 2 +- packages/developer-extension/src/popup/index.tsx | 2 +- .../developer-extension/src/popup/{Panel.tsx => panel.tsx} | 0 packages/developer-extension/tsconfig.json | 4 +--- 8 files changed, 17 insertions(+), 9 deletions(-) rename packages/developer-extension/src/popup/{App.tsx => app.tsx} (94%) rename packages/developer-extension/src/popup/{Panel.tsx => panel.tsx} (100%) diff --git a/.eslintignore b/.eslintignore index 71ac8ed945..7ca12e3c0a 100644 --- a/.eslintignore +++ b/.eslintignore @@ -1,6 +1,7 @@ bundle cjs esm +dist test/app/dist sandbox coverage diff --git a/.eslintrc.js b/.eslintrc.js index 40a86216bf..2decbf7ec5 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -10,7 +10,12 @@ module.exports = { ], parser: '@typescript-eslint/parser', parserOptions: { - project: ['./tsconfig.json', './test/app/tsconfig.json', './test/e2e/tsconfig.json'], + project: [ + './tsconfig.json', + './test/app/tsconfig.json', + './test/e2e/tsconfig.json', + './packages/developer-extension/tsconfig.json', + ], sourceType: 'module', }, plugins: [ diff --git a/packages/developer-extension/src/background/domain/logRequests.ts b/packages/developer-extension/src/background/domain/logRequests.ts index a5d8642da1..f5d0cfb47a 100644 --- a/packages/developer-extension/src/background/domain/logRequests.ts +++ b/packages/developer-extension/src/background/domain/logRequests.ts @@ -13,7 +13,7 @@ chrome.webRequest.onBeforeRequest.addListener( const url = new URL(info.url) - const intake = url.hostname.match(/^\w*/)?.[0] + const intake = /^\w*/.exec(url.hostname)?.[0] if (!intake) { return } @@ -21,7 +21,7 @@ chrome.webRequest.onBeforeRequest.addListener( return } - for (const rawBody of info.requestBody.raw!) { + for (const rawBody of info.requestBody.raw) { if (rawBody.bytes) { const decodedBody = decoder.decode(rawBody.bytes) for (const rawEvent of decodedBody.split('\n')) { diff --git a/packages/developer-extension/src/background/domain/replaceBundles.ts b/packages/developer-extension/src/background/domain/replaceBundles.ts index 9e3f05ed52..5fc9f9988a 100644 --- a/packages/developer-extension/src/background/domain/replaceBundles.ts +++ b/packages/developer-extension/src/background/domain/replaceBundles.ts @@ -34,7 +34,11 @@ chrome.webRequest.onBeforeRequest.addListener( ['blocking'] ) -listenAction('getStore', () => refreshDevServerStatus()) +listenAction('getStore', () => { + refreshDevServerStatus().catch((error) => + console.error('Unexpected error while refreshing dev server status:', error) + ) +}) async function refreshDevServerStatus() { const timeoutId = setTimeout(() => setStore({ devServerStatus: 'checking' }), 500) diff --git a/packages/developer-extension/src/popup/App.tsx b/packages/developer-extension/src/popup/app.tsx similarity index 94% rename from packages/developer-extension/src/popup/App.tsx rename to packages/developer-extension/src/popup/app.tsx index 18e65ae281..afd01e7b5e 100644 --- a/packages/developer-extension/src/popup/App.tsx +++ b/packages/developer-extension/src/popup/app.tsx @@ -1,7 +1,7 @@ import { Provider as BumbagProvider, css, Box } from 'bumbag' import React, { Suspense } from 'react' -import { Panel } from './Panel' +import { Panel } from './panel' const theme = { global: { diff --git a/packages/developer-extension/src/popup/index.tsx b/packages/developer-extension/src/popup/index.tsx index a3fca003dd..23abd5052d 100644 --- a/packages/developer-extension/src/popup/index.tsx +++ b/packages/developer-extension/src/popup/index.tsx @@ -1,7 +1,7 @@ import { render } from 'react-dom' import React from 'react' -import { App } from './App' +import { App } from './app' const main = document.createElement('main') document.body.append(main) diff --git a/packages/developer-extension/src/popup/Panel.tsx b/packages/developer-extension/src/popup/panel.tsx similarity index 100% rename from packages/developer-extension/src/popup/Panel.tsx rename to packages/developer-extension/src/popup/panel.tsx diff --git a/packages/developer-extension/tsconfig.json b/packages/developer-extension/tsconfig.json index 916a6390e8..d9b09af977 100644 --- a/packages/developer-extension/tsconfig.json +++ b/packages/developer-extension/tsconfig.json @@ -8,7 +8,5 @@ // See https://github.com/bumbag/bumbag-ui/issues/97 "strictNullChecks": false - }, - - "include": ["src"] + } } From 04bdf6ca101327e19f4a169e6ed021f5aaf1aab1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 18:09:31 +0100 Subject: [PATCH 03/13] =?UTF-8?q?=E2=8F=AA=20revert=20typecheck=20strategy?= =?UTF-8?q?=20changes=20and=20add=20extension=20package=20to=20script?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package.json | 2 +- scripts/cli | 5 ++--- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/package.json b/package.json index 86b24dc425..0a15a15a88 100644 --- a/package.json +++ b/package.json @@ -11,7 +11,7 @@ "build:bundle": "lerna run build:bundle --stream", "format": "prettier --check .", "lint": "scripts/cli lint .", - "typecheck": "scripts/cli typecheck", + "typecheck": "scripts/cli typecheck . && scripts/cli typecheck test/e2e && scripts/cli typecheck packages/developer-extension", "dev": "node scripts/dev-server.js", "release": "lerna version --exact", "version": "scripts/cli version", diff --git a/scripts/cli b/scripts/cli index 7ef24cbb23..76ba225dbc 100755 --- a/scripts/cli +++ b/scripts/cli @@ -22,9 +22,8 @@ cmd_help () { } cmd_typecheck () { - tsc -p . --noEmit true - tsc -p test/e2e --noEmit true - tsc -p packages/developer-extension --noEmit true + local project_path="${1}" + tsc -p "$project_path" --noEmit true } cmd_lint () { From d42b1a67c84b57792b99e68868b867fed709fd06 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 18:23:22 +0100 Subject: [PATCH 04/13] =?UTF-8?q?=F0=9F=9A=9A=20move=20extension=20outside?= =?UTF-8?q?=20'packages'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .eslintrc.js | 2 +- .../.gitignore | 0 .../README.md | 4 ++-- .../icons/icon.png | Bin .../manifest.json | 0 .../package.json | 0 .../src/background/actions.ts | 0 .../src/background/constants.ts | 0 .../src/background/domain/endSession.ts | 0 .../src/background/domain/flushEvents.ts | 0 .../src/background/domain/logRequests.ts | 0 .../src/background/domain/replaceBundles.ts | 0 .../src/background/index.ts | 0 .../src/background/store.ts | 0 .../src/background/utils.ts | 0 .../src/common/actions.ts | 0 .../src/common/types.ts | 0 .../src/popup/actions.ts | 0 .../src/popup/app.tsx | 0 .../src/popup/index.tsx | 0 .../src/popup/panel.tsx | 0 .../src/popup/useStore.ts | 0 .../tsconfig.json | 2 +- .../webpack.config.js | 0 package.json | 5 +++-- tsconfig.json | 2 +- 26 files changed, 8 insertions(+), 7 deletions(-) rename {packages/developer-extension => developer-extension}/.gitignore (100%) rename {packages/developer-extension => developer-extension}/README.md (86%) rename {packages/developer-extension => developer-extension}/icons/icon.png (100%) rename {packages/developer-extension => developer-extension}/manifest.json (100%) rename {packages/developer-extension => developer-extension}/package.json (100%) rename {packages/developer-extension => developer-extension}/src/background/actions.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/constants.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/domain/endSession.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/domain/flushEvents.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/domain/logRequests.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/domain/replaceBundles.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/index.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/store.ts (100%) rename {packages/developer-extension => developer-extension}/src/background/utils.ts (100%) rename {packages/developer-extension => developer-extension}/src/common/actions.ts (100%) rename {packages/developer-extension => developer-extension}/src/common/types.ts (100%) rename {packages/developer-extension => developer-extension}/src/popup/actions.ts (100%) rename {packages/developer-extension => developer-extension}/src/popup/app.tsx (100%) rename {packages/developer-extension => developer-extension}/src/popup/index.tsx (100%) rename {packages/developer-extension => developer-extension}/src/popup/panel.tsx (100%) rename {packages/developer-extension => developer-extension}/src/popup/useStore.ts (100%) rename {packages/developer-extension => developer-extension}/tsconfig.json (81%) rename {packages/developer-extension => developer-extension}/webpack.config.js (100%) diff --git a/.eslintrc.js b/.eslintrc.js index 2decbf7ec5..263a6daf02 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -14,7 +14,7 @@ module.exports = { './tsconfig.json', './test/app/tsconfig.json', './test/e2e/tsconfig.json', - './packages/developer-extension/tsconfig.json', + './developer-extension/tsconfig.json', ], sourceType: 'module', }, diff --git a/packages/developer-extension/.gitignore b/developer-extension/.gitignore similarity index 100% rename from packages/developer-extension/.gitignore rename to developer-extension/.gitignore diff --git a/packages/developer-extension/README.md b/developer-extension/README.md similarity index 86% rename from packages/developer-extension/README.md rename to developer-extension/README.md index 7662a26ab1..e1b51dec5c 100644 --- a/packages/developer-extension/README.md +++ b/developer-extension/README.md @@ -11,7 +11,7 @@ build the extension manually. $ git clone https://github.com/DataDog/browser-sdk $ cd browser-sdk $ yarn -$ cd packages/developer-extension +$ cd developer-extension $ yarn build ``` @@ -19,7 +19,7 @@ Then, in Google Chrome: - Open the _Extension Management_ page by navigating to [chrome://extensions](chrome://extensions). - Enable _Developer Mode_ by clicking the toggle switch next to _Developer mode_. -- Click the _LOAD UNPACKED_ button and select the `browser-sdk/packages/developer-extension/dist` +- Click the _LOAD UNPACKED_ button and select the `browser-sdk/developer-extension/dist` directory. ## Features diff --git a/packages/developer-extension/icons/icon.png b/developer-extension/icons/icon.png similarity index 100% rename from packages/developer-extension/icons/icon.png rename to developer-extension/icons/icon.png diff --git a/packages/developer-extension/manifest.json b/developer-extension/manifest.json similarity index 100% rename from packages/developer-extension/manifest.json rename to developer-extension/manifest.json diff --git a/packages/developer-extension/package.json b/developer-extension/package.json similarity index 100% rename from packages/developer-extension/package.json rename to developer-extension/package.json diff --git a/packages/developer-extension/src/background/actions.ts b/developer-extension/src/background/actions.ts similarity index 100% rename from packages/developer-extension/src/background/actions.ts rename to developer-extension/src/background/actions.ts diff --git a/packages/developer-extension/src/background/constants.ts b/developer-extension/src/background/constants.ts similarity index 100% rename from packages/developer-extension/src/background/constants.ts rename to developer-extension/src/background/constants.ts diff --git a/packages/developer-extension/src/background/domain/endSession.ts b/developer-extension/src/background/domain/endSession.ts similarity index 100% rename from packages/developer-extension/src/background/domain/endSession.ts rename to developer-extension/src/background/domain/endSession.ts diff --git a/packages/developer-extension/src/background/domain/flushEvents.ts b/developer-extension/src/background/domain/flushEvents.ts similarity index 100% rename from packages/developer-extension/src/background/domain/flushEvents.ts rename to developer-extension/src/background/domain/flushEvents.ts diff --git a/packages/developer-extension/src/background/domain/logRequests.ts b/developer-extension/src/background/domain/logRequests.ts similarity index 100% rename from packages/developer-extension/src/background/domain/logRequests.ts rename to developer-extension/src/background/domain/logRequests.ts diff --git a/packages/developer-extension/src/background/domain/replaceBundles.ts b/developer-extension/src/background/domain/replaceBundles.ts similarity index 100% rename from packages/developer-extension/src/background/domain/replaceBundles.ts rename to developer-extension/src/background/domain/replaceBundles.ts diff --git a/packages/developer-extension/src/background/index.ts b/developer-extension/src/background/index.ts similarity index 100% rename from packages/developer-extension/src/background/index.ts rename to developer-extension/src/background/index.ts diff --git a/packages/developer-extension/src/background/store.ts b/developer-extension/src/background/store.ts similarity index 100% rename from packages/developer-extension/src/background/store.ts rename to developer-extension/src/background/store.ts diff --git a/packages/developer-extension/src/background/utils.ts b/developer-extension/src/background/utils.ts similarity index 100% rename from packages/developer-extension/src/background/utils.ts rename to developer-extension/src/background/utils.ts diff --git a/packages/developer-extension/src/common/actions.ts b/developer-extension/src/common/actions.ts similarity index 100% rename from packages/developer-extension/src/common/actions.ts rename to developer-extension/src/common/actions.ts diff --git a/packages/developer-extension/src/common/types.ts b/developer-extension/src/common/types.ts similarity index 100% rename from packages/developer-extension/src/common/types.ts rename to developer-extension/src/common/types.ts diff --git a/packages/developer-extension/src/popup/actions.ts b/developer-extension/src/popup/actions.ts similarity index 100% rename from packages/developer-extension/src/popup/actions.ts rename to developer-extension/src/popup/actions.ts diff --git a/packages/developer-extension/src/popup/app.tsx b/developer-extension/src/popup/app.tsx similarity index 100% rename from packages/developer-extension/src/popup/app.tsx rename to developer-extension/src/popup/app.tsx diff --git a/packages/developer-extension/src/popup/index.tsx b/developer-extension/src/popup/index.tsx similarity index 100% rename from packages/developer-extension/src/popup/index.tsx rename to developer-extension/src/popup/index.tsx diff --git a/packages/developer-extension/src/popup/panel.tsx b/developer-extension/src/popup/panel.tsx similarity index 100% rename from packages/developer-extension/src/popup/panel.tsx rename to developer-extension/src/popup/panel.tsx diff --git a/packages/developer-extension/src/popup/useStore.ts b/developer-extension/src/popup/useStore.ts similarity index 100% rename from packages/developer-extension/src/popup/useStore.ts rename to developer-extension/src/popup/useStore.ts diff --git a/packages/developer-extension/tsconfig.json b/developer-extension/tsconfig.json similarity index 81% rename from packages/developer-extension/tsconfig.json rename to developer-extension/tsconfig.json index d9b09af977..b027e5de47 100644 --- a/packages/developer-extension/tsconfig.json +++ b/developer-extension/tsconfig.json @@ -1,5 +1,5 @@ { - "extends": "../../tsconfig.base.json", + "extends": "../tsconfig.base.json", "compilerOptions": { "baseUrl": ".", diff --git a/packages/developer-extension/webpack.config.js b/developer-extension/webpack.config.js similarity index 100% rename from packages/developer-extension/webpack.config.js rename to developer-extension/webpack.config.js diff --git a/package.json b/package.json index 0a15a15a88..3d43214a36 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,8 @@ "description": "browser SDK", "private": true, "workspaces": [ - "packages/*" + "packages/*", + "developer-extension" ], "scripts": { "postinstall": "scripts/cli update_submodule", @@ -11,7 +12,7 @@ "build:bundle": "lerna run build:bundle --stream", "format": "prettier --check .", "lint": "scripts/cli lint .", - "typecheck": "scripts/cli typecheck . && scripts/cli typecheck test/e2e && scripts/cli typecheck packages/developer-extension", + "typecheck": "scripts/cli typecheck . && scripts/cli typecheck test/e2e && scripts/cli typecheck developer-extension", "dev": "node scripts/dev-server.js", "release": "lerna version --exact", "version": "scripts/cli version", diff --git a/tsconfig.json b/tsconfig.json index 3487421864..23a8608a8d 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -2,5 +2,5 @@ { "extends": "./tsconfig.base.json", "include": [".", ".eslintrc.js"], - "exclude": ["./test/e2e", "./test/app", "./packages/developer-extension"] + "exclude": ["./test/e2e", "./test/app", "./developer-extension"] } From 213954aa7a032e66bca2e3d1d541697953f24799 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 18:42:33 +0100 Subject: [PATCH 05/13] =?UTF-8?q?=F0=9F=91=8C=20stringify=20functions=20in?= =?UTF-8?q?stead=20of=20passing=20strings=20for=20eval'd=20code?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- developer-extension/src/background/domain/endSession.ts | 5 +++-- developer-extension/src/background/domain/flushEvents.ts | 4 ++-- developer-extension/src/background/utils.ts | 6 +++--- 3 files changed, 8 insertions(+), 7 deletions(-) diff --git a/developer-extension/src/background/domain/endSession.ts b/developer-extension/src/background/domain/endSession.ts index 576e72cfe2..ca0a9261b8 100644 --- a/developer-extension/src/background/domain/endSession.ts +++ b/developer-extension/src/background/domain/endSession.ts @@ -2,7 +2,8 @@ import { listenAction } from '../actions' import { evaluateCodeInActiveTab } from '../utils' listenAction('endSession', () => { - evaluateCodeInActiveTab(` + evaluateCodeInActiveTab(() => { + console.log('plop') document.cookie = '_dd_s=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/' - `) + }) }) diff --git a/developer-extension/src/background/domain/flushEvents.ts b/developer-extension/src/background/domain/flushEvents.ts index 8b20319752..57478471f0 100644 --- a/developer-extension/src/background/domain/flushEvents.ts +++ b/developer-extension/src/background/domain/flushEvents.ts @@ -3,11 +3,11 @@ import { evaluateCodeInActiveTab } from '../utils' listenAction('flushEvents', () => // Simulates a brief page visibility change (visible > hide > visible) - evaluateCodeInActiveTab(` + evaluateCodeInActiveTab(() => { const descriptor = Object.getOwnPropertyDescriptor(Document.prototype, 'visibilityState') Object.defineProperty(Document.prototype, 'visibilityState', { value: 'hidden' }) document.dispatchEvent(new Event('visibilitychange', { bubbles: true })) Object.defineProperty(Document.prototype, 'visibilityState', descriptor) document.dispatchEvent(new Event('visibilitychange', { bubbles: true })) - `) + }) ) diff --git a/developer-extension/src/background/utils.ts b/developer-extension/src/background/utils.ts index 32b037d06e..ca1cd72156 100644 --- a/developer-extension/src/background/utils.ts +++ b/developer-extension/src/background/utils.ts @@ -1,4 +1,4 @@ -export function evaluateCodeInActiveTab(code: string) { +export function evaluateCodeInActiveTab(code: () => void) { chrome.tabs.query({ currentWindow: true, active: true }, (tabs) => { for (const tab of tabs) { if (tab.id) { @@ -8,12 +8,12 @@ export function evaluateCodeInActiveTab(code: string) { }) } -function evaluateCodeInline(tabId: number, code: string) { +function evaluateCodeInline(tabId: number, code: () => void) { chrome.tabs.executeScript(tabId, { code: `{ const script = document.createElement('script') script.setAttribute("type", "module") - script.textContent = ${JSON.stringify(code)} + script.textContent = ${JSON.stringify(`(${String(code)})()`)} document.body.appendChild(script) script.remove() }`, From 1b849dbfe876872aedd6cf0ba4e14268af683301 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 18:45:23 +0100 Subject: [PATCH 06/13] =?UTF-8?q?=F0=9F=91=8C=20use=20a=20local=20state=20?= =?UTF-8?q?for=20`useStore`?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Even if it's not necessary, it makes things a bit less obscure. --- developer-extension/src/popup/useStore.ts | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/developer-extension/src/popup/useStore.ts b/developer-extension/src/popup/useStore.ts index 3a7cffad2a..5d7a02beb3 100644 --- a/developer-extension/src/popup/useStore.ts +++ b/developer-extension/src/popup/useStore.ts @@ -1,14 +1,14 @@ -import { useEffect, useReducer } from 'react' +import { useEffect, useState } from 'react' import { Store } from '../common/types' import { listenAction, sendAction } from './actions' let store: Store | undefined -const storeListeners = new Set<() => void>() +const storeListeners = new Set<(store: Store) => void>() const storeLoadingPromise = new Promise((resolve) => { sendAction('getStore', undefined) listenAction('newStore', (newStore) => { store = newStore - storeListeners.forEach((listener) => listener()) + storeListeners.forEach((listener) => listener(store)) resolve() }) }) @@ -18,16 +18,16 @@ export function useStore(): [Store, (newState: Partial) => void] { throw storeLoadingPromise } - const forceUpdate = useReducer(() => ({}), {})[1] as () => void + const [localStore, setLocalStore] = useState(store) useEffect(() => { - storeListeners.add(forceUpdate) + storeListeners.add(setLocalStore) return () => { - storeListeners.delete(forceUpdate) + storeListeners.delete(setLocalStore) } }, []) - return [store, setStore] + return [localStore, setStore] } function setStore(newStore: Partial) { From e43c9ececf4520b24d05467700e8dc7285c55600 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 18:49:59 +0100 Subject: [PATCH 07/13] =?UTF-8?q?=F0=9F=91=8C=20rename=20logEvents=20and?= =?UTF-8?q?=20logRequests=20to=20logEventsFromRequests?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../{logRequests.ts => logEventsFromRequests.ts} | 2 +- developer-extension/src/background/index.ts | 2 +- developer-extension/src/background/store.ts | 2 +- developer-extension/src/common/types.ts | 2 +- developer-extension/src/popup/panel.tsx | 12 +++++++++--- 5 files changed, 13 insertions(+), 7 deletions(-) rename developer-extension/src/background/domain/{logRequests.ts => logEventsFromRequests.ts} (97%) diff --git a/developer-extension/src/background/domain/logRequests.ts b/developer-extension/src/background/domain/logEventsFromRequests.ts similarity index 97% rename from developer-extension/src/background/domain/logRequests.ts rename to developer-extension/src/background/domain/logEventsFromRequests.ts index f5d0cfb47a..af58b3fb34 100644 --- a/developer-extension/src/background/domain/logRequests.ts +++ b/developer-extension/src/background/domain/logEventsFromRequests.ts @@ -3,7 +3,7 @@ import { store } from '../store' const decoder = new TextDecoder('utf-8') chrome.webRequest.onBeforeRequest.addListener( (info) => { - if (!store.logEvents) { + if (!store.logEventsFromRequests) { return } if (info.tabId < 0) { diff --git a/developer-extension/src/background/index.ts b/developer-extension/src/background/index.ts index 22265e2268..90aa47e8bc 100644 --- a/developer-extension/src/background/index.ts +++ b/developer-extension/src/background/index.ts @@ -1,4 +1,4 @@ import './domain/flushEvents' -import './domain/logRequests' +import './domain/logEventsFromRequests' import './domain/endSession' import './domain/replaceBundles' diff --git a/developer-extension/src/background/store.ts b/developer-extension/src/background/store.ts index e7fb890558..7a0fafeb82 100644 --- a/developer-extension/src/background/store.ts +++ b/developer-extension/src/background/store.ts @@ -3,7 +3,7 @@ import { listenAction, sendAction } from './actions' export const store: Store = { devServerStatus: 'checking', - logEvents: true, + logEventsFromRequests: true, useDevBundles: false, useRumRecorder: false, } diff --git a/developer-extension/src/common/types.ts b/developer-extension/src/common/types.ts index 47cc84a543..3ffa5eb055 100644 --- a/developer-extension/src/common/types.ts +++ b/developer-extension/src/common/types.ts @@ -13,5 +13,5 @@ export interface Store { devServerStatus: 'unavailable' | 'checking' | 'available' useDevBundles: boolean useRumRecorder: boolean - logEvents: boolean + logEventsFromRequests: boolean } diff --git a/developer-extension/src/popup/panel.tsx b/developer-extension/src/popup/panel.tsx index 6e4bb98dd0..73e03659bd 100644 --- a/developer-extension/src/popup/panel.tsx +++ b/developer-extension/src/popup/panel.tsx @@ -4,7 +4,7 @@ import { sendAction } from './actions' import { useStore } from './useStore' export function Panel() { - const [{ useDevBundles, useRumRecorder, logEvents, devServerStatus: devStatus }, setStore] = useStore() + const [{ useDevBundles, useRumRecorder, logEventsFromRequests, devServerStatus }, setStore] = useStore() return ( @@ -13,7 +13,9 @@ export function Panel() { checked={useDevBundles} onChange={(e) => setStore({ useDevBundles: isChecked(e.target) })} /> - + setStore({ useRumRecorder: isChecked(e.target) })} /> - setStore({ logEvents: isChecked(e.target) })} /> + setStore({ logEventsFromRequests: isChecked(e.target) })} + /> From a85c49226930e6a720b7545a81c6bb46789e24d4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 18:58:03 +0100 Subject: [PATCH 08/13] =?UTF-8?q?=F0=9F=91=8C=20list=20more=20intake=20dom?= =?UTF-8?q?ains,=20and=20be=20more=20explicit=20for=20classic=20domains?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/background/domain/logEventsFromRequests.ts | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/developer-extension/src/background/domain/logEventsFromRequests.ts b/developer-extension/src/background/domain/logEventsFromRequests.ts index af58b3fb34..4a6c7ab166 100644 --- a/developer-extension/src/background/domain/logEventsFromRequests.ts +++ b/developer-extension/src/background/domain/logEventsFromRequests.ts @@ -36,15 +36,25 @@ chrome.webRequest.onBeforeRequest.addListener( { urls: [ // TODO: implement a configuration page to add more URLs in this list. - 'https://*.logs.datadoghq.com/*', 'https://*.browser-intake-datadoghq.com/*', - 'https://*.logs.datadoghq.eu/*', 'https://*.browser-intake-datadoghq.eu/*', + 'https://*.browser-intake-ddog-gov.com/*', + 'https://*.browser-intake-us3-datadoghq.com/*', + ...classicIntakesUrlsForSite('datadoghq.com'), + ...classicIntakesUrlsForSite('datadoghq.eu'), ], }, ['requestBody'] ) +function classicIntakesUrlsForSite(site: string) { + return [ + `https://public-trace-http-intake.logs.${site}/*`, + `https://rum-http-intake.logs.${site}/*`, + `https://browser-http-intake.logs.${site}/*`, + ] +} + function sortProperties(event: T): T { if (Array.isArray(event)) { return event.map(sortProperties) as T From 4ac9ff1b9bbc35a9cd6cf6da0487d2fd1ca9d7f1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 29 Jan 2021 19:12:11 +0100 Subject: [PATCH 09/13] =?UTF-8?q?=F0=9F=91=8C=20remove=20cache=20when=20re?= =?UTF-8?q?placing=20bundles?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- developer-extension/manifest.json | 2 +- developer-extension/src/background/domain/replaceBundles.ts | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/developer-extension/manifest.json b/developer-extension/manifest.json index e803b19a7b..1dd88cb250 100644 --- a/developer-extension/manifest.json +++ b/developer-extension/manifest.json @@ -1,7 +1,7 @@ { "manifest_version": 2, "name": "Datadog Browser SDK developer extension", - "permissions": ["", "tabs", "webRequest", "webRequestBlocking", "storage"], + "permissions": ["", "tabs", "webRequest", "webRequestBlocking", "storage", "browsingData"], "icons": { "256": "icon.png" }, diff --git a/developer-extension/src/background/domain/replaceBundles.ts b/developer-extension/src/background/domain/replaceBundles.ts index 5fc9f9988a..c24a6b89c7 100644 --- a/developer-extension/src/background/domain/replaceBundles.ts +++ b/developer-extension/src/background/domain/replaceBundles.ts @@ -40,6 +40,12 @@ listenAction('getStore', () => { ) }) +listenAction('setStore', (newStore) => { + if ('useDevBundles' in newStore || 'useRumRecorder' in newStore) { + chrome.browsingData.removeCache({}) + } +}) + async function refreshDevServerStatus() { const timeoutId = setTimeout(() => setStore({ devServerStatus: 'checking' }), 500) let isAvailable = false From 838b23b3736d65f40352074f7014f6af39ebf92d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Fri, 5 Feb 2021 18:06:39 +0100 Subject: [PATCH 10/13] =?UTF-8?q?=F0=9F=8F=B7=EF=B8=8F=20adjust=20TS=20con?= =?UTF-8?q?figuration?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- developer-extension/tsconfig.json | 2 ++ 1 file changed, 2 insertions(+) diff --git a/developer-extension/tsconfig.json b/developer-extension/tsconfig.json index b027e5de47..2574711b98 100644 --- a/developer-extension/tsconfig.json +++ b/developer-extension/tsconfig.json @@ -5,6 +5,8 @@ "baseUrl": ".", "module": "ES6", "jsx": "react", + "lib": ["ES2019", "DOM"], + "types": ["chrome", "react", "react-dom"], // See https://github.com/bumbag/bumbag-ui/issues/97 "strictNullChecks": false From fddf2a540861472bbf3b805014e58a383f41366e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Wed, 10 Feb 2021 12:03:20 +0100 Subject: [PATCH 11/13] fix 3rd party licenses --- LICENSE-3rdparty.csv | 1 - 1 file changed, 1 deletion(-) diff --git a/LICENSE-3rdparty.csv b/LICENSE-3rdparty.csv index ff79318a35..220787d1f4 100644 --- a/LICENSE-3rdparty.csv +++ b/LICENSE-3rdparty.csv @@ -7,7 +7,6 @@ file,tracekit,MIT,Copyright 2013 Onur Can Cakmak and all TraceKit contributors prod,bumbag,MIT,Copyright (c) 2020 Bumbag Enterprises prod,react,MIT,Copyright (c) Facebook, Inc. and its affiliates. prod,react-dom,MIT,Copyright (c) Facebook, Inc. and its affiliates. -prod,rrweb-snapshot,MIT,Copyright (c) 2018 Contributors (https://github.com/rrweb-io/rrweb-snapshot/graphs/contributors) and SmartX Inc. dev,@types/chrome,MIT,Copyright Microsoft Corporation dev,@types/connect-busboy,MIT,Copyright Microsoft Corporation dev,@types/cors,MIT,Copyright Microsoft Corporation From b00be549cdbb5095244b7f8feea6ec8cce6f17a2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Wed, 10 Feb 2021 12:04:32 +0100 Subject: [PATCH 12/13] fix lint --- developer-extension/webpack.config.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/developer-extension/webpack.config.js b/developer-extension/webpack.config.js index dcb111c0ba..1fcbef678d 100644 --- a/developer-extension/webpack.config.js +++ b/developer-extension/webpack.config.js @@ -2,7 +2,7 @@ const HtmlWebpackPlugin = require('html-webpack-plugin') const WebextensionPlugin = require('webpack-webextension-plugin') const CopyPlugin = require('copy-webpack-plugin') -module.exports = (env, argv) => { +module.exports = (_env, argv) => { return [ baseConfig({ entry: './src/background', From fa09cfc70a9c832c8b544fba772812daa616d5a1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Zugmeyer?= Date: Wed, 17 Feb 2021 10:26:13 +0100 Subject: [PATCH 13/13] =?UTF-8?q?=F0=9F=8F=B7=EF=B8=8F=20fix=20TS=20issue?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- developer-extension/src/popup/useStore.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/developer-extension/src/popup/useStore.ts b/developer-extension/src/popup/useStore.ts index 5d7a02beb3..adf02861d5 100644 --- a/developer-extension/src/popup/useStore.ts +++ b/developer-extension/src/popup/useStore.ts @@ -9,7 +9,7 @@ const storeLoadingPromise = new Promise((resolve) => { listenAction('newStore', (newStore) => { store = newStore storeListeners.forEach((listener) => listener(store)) - resolve() + resolve(undefined) }) })