Browser push notifications (#133)
* fix type error fix is subscribed check - Persist subscription data locally - add / remove subscription during log in / out - Use store directly in hook Add toast error if subscription fails Revert removal of v2 hotfix linting issue Add custom notification handler - fix isSupported flag - make icon color compatible with light/dark theme - fix icon on notifications blocked banner wip: add push notification banner to notifications page. - ignore failed deletions via internal API - add ua parsing package - add more robust meta data to token save refactor naming + add push toggle to notification button shift some code around update css naming o proper BEM notation update notifications UI remove now unneeded util function Update push notification system to sue firebase sdk separate service worker webpack bundling update service worker to use firebase sdk Add firebase config Add firebase and remove filemanager Stub out the basics for browser push notifications. * fix safari * try smaller image for badge * add token validation with server, refactor code * remove param * add special icon for web notification badge * add translations * add missing trans for toast error * add pushRequest method that will not prompt users who have subscribed but since disabled notifications in the settings.
This commit is contained in:
parent
08adb805e9
commit
03f69eff86
27 changed files with 1318 additions and 85 deletions
|
@ -115,3 +115,13 @@ ENABLE_UI_NOTIFICATIONS=false
|
||||||
#MODELS_ENABLED=true
|
#MODELS_ENABLED=true
|
||||||
|
|
||||||
BRANDED_SITE=odysee
|
BRANDED_SITE=odysee
|
||||||
|
|
||||||
|
#FIREBASE
|
||||||
|
FIREBASE_API_KEY=AIzaSyAgc-4QORyglpYZ3qH9E5pDauEDOJXgM3A
|
||||||
|
FIREBASE_AUTH_DOMAIN=lbry-mobile.firebaseapp.com
|
||||||
|
FIREBASE_PROJECT_ID=lbry-mobile
|
||||||
|
FIREBASE_STORAGE_BUCKET=lbry-mobile.appspot.com
|
||||||
|
FIREBASE_MESSAGING_SENDER_ID=638894153788
|
||||||
|
FIREBASE_APP_ID=1:638894153788:web:35b295b15297201bd2e339
|
||||||
|
FIREBASE_MEASUREMENT_ID=G-2MPJGFEEXC
|
||||||
|
FIREBASE_VAPID_KEY=BFayEBpwMTU9GQQpXgitIJkfx-SD8-ltrFb3wLTZWgA27MfBhG4948pe0eERl432NzPrMKsbkXnA7ap_vLPgLYk
|
|
@ -35,6 +35,8 @@ module.name_mapper='^web\/effects\(.*\)$' -> '<PROJECT_ROOT>/web/effects\1'
|
||||||
module.name_mapper='^web\/page\(.*\)$' -> '<PROJECT_ROOT>/web/page\1'
|
module.name_mapper='^web\/page\(.*\)$' -> '<PROJECT_ROOT>/web/page\1'
|
||||||
module.name_mapper='^homepage\(.*\)$' -> '<PROJECT_ROOT>/ui/util/homepage\1'
|
module.name_mapper='^homepage\(.*\)$' -> '<PROJECT_ROOT>/ui/util/homepage\1'
|
||||||
module.name_mapper='^scss\/component\(.*\)$' -> '<PROJECT_ROOT>/ui/scss/component/\1'
|
module.name_mapper='^scss\/component\(.*\)$' -> '<PROJECT_ROOT>/ui/scss/component/\1'
|
||||||
|
module.name_mapper='^\$web\(.*\)$' -> '<PROJECT_ROOT>/web\1'
|
||||||
|
module.name_mapper='^\$ui\(.*\)$' -> '<PROJECT_ROOT>/ui\1'
|
||||||
|
|
||||||
esproposal.optional_chaining=enable
|
esproposal.optional_chaining=enable
|
||||||
|
|
||||||
|
|
11
config.js
11
config.js
|
@ -75,6 +75,17 @@ const config = {
|
||||||
SHOW_TAGS_INTRO: process.env.SHOW_TAGS_INTRO === 'true',
|
SHOW_TAGS_INTRO: process.env.SHOW_TAGS_INTRO === 'true',
|
||||||
LIGHTHOUSE_DEFAULT_TYPES: process.env.LIGHTHOUSE_DEFAULT_TYPES,
|
LIGHTHOUSE_DEFAULT_TYPES: process.env.LIGHTHOUSE_DEFAULT_TYPES,
|
||||||
BRANDED_SITE: process.env.BRANDED_SITE,
|
BRANDED_SITE: process.env.BRANDED_SITE,
|
||||||
|
|
||||||
|
// FIREBASE SDK
|
||||||
|
FIREBASE_API_KEY: process.env.FIREBASE_API_KEY,
|
||||||
|
FIREBASE_AUTH_DOMAIN: process.env.FIREBASE_AUTH_DOMAIN,
|
||||||
|
FIREBASE_PROJECT_ID: process.env.FIREBASE_PROJECT_ID,
|
||||||
|
FIREBASE_STORAGE_BUCKET: process.env.FIREBASE_STORAGE_BUCKET,
|
||||||
|
FIREBASE_MESSAGING_SENDER_ID: process.env.FIREBASE_MESSAGING_SENDER_ID,
|
||||||
|
FIREBASE_APP_ID: process.env.FIREBASE_APP_ID,
|
||||||
|
FIREBASE_MEASUREMENT_ID: process.env.FIREBASE_MEASUREMENT_ID,
|
||||||
|
FIREBASE_VAPID_KEY: process.env.FIREBASE_VAPID_KEY,
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
config.URL_DEV = `http://localhost:${config.WEBPACK_WEB_PORT}`;
|
config.URL_DEV = `http://localhost:${config.WEBPACK_WEB_PORT}`;
|
||||||
|
|
|
@ -2185,5 +2185,21 @@
|
||||||
"From comments": "From comments",
|
"From comments": "From comments",
|
||||||
"From search": "From search",
|
"From search": "From search",
|
||||||
"Manage tags": "Manage tags",
|
"Manage tags": "Manage tags",
|
||||||
|
"Notification Delivery": "Notification Delivery",
|
||||||
|
"Choose how you'd like to receive your Odysee notifications.": "Choose how you'd like to receive your Odysee notifications.",
|
||||||
|
"Desktop Notifications": "Desktop Notifications",
|
||||||
|
"Browser Notifications": "Browser Notifications",
|
||||||
|
"Receive push notifications in this browser, even when you're not on odysee.com": "Receive push notifications in this browser, even when you're not on odysee.com",
|
||||||
|
"Email Notification Topics": "Email Notification Topics",
|
||||||
|
"Choose which topics you’d like to be emailed about.": "Choose which topics you’d like to be emailed about.",
|
||||||
|
"Email Notifications": "Email Notifications",
|
||||||
|
"Receive notifications to the email address: %email%": "Receive notifications to the email address: %email%",
|
||||||
|
"Realtime push notifications straight to your browser.": "Realtime push notifications straight to your browser.",
|
||||||
|
"Don't miss another notification again.": "Don't miss another notification again.",
|
||||||
|
"Enable Push Notifications": "Enable Push Notifications",
|
||||||
|
"Dismiss": "Dismiss",
|
||||||
|
"Heads up: browser notifications are currently blocked in this browser.": "Heads up: browser notifications are currently blocked in this browser.",
|
||||||
|
"To enable push notifications please configure your browser to allow notifications on odysee.com.": "To enable push notifications please configure your browser to allow notifications on odysee.com.",
|
||||||
|
"There was an error enabling browser notifications. Please make sure your browser settings allow you to subscribe to notifications.": "There was an error enabling browser notifications. Please make sure your browser settings allow you to subscribe to notifications.",
|
||||||
"--end--": "--end--"
|
"--end--": "--end--"
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ import Button from 'component/button';
|
||||||
import useHover from 'effects/use-hover';
|
import useHover from 'effects/use-hover';
|
||||||
import { useIsMobile } from 'effects/use-screensize';
|
import { useIsMobile } from 'effects/use-screensize';
|
||||||
import { ENABLE_UI_NOTIFICATIONS } from 'config';
|
import { ENABLE_UI_NOTIFICATIONS } from 'config';
|
||||||
|
import useBrowserNotifications from '$web/component/browserNotificationSettings/use-browser-notifications';
|
||||||
|
|
||||||
type SubscriptionArgs = {
|
type SubscriptionArgs = {
|
||||||
channelName: string,
|
channelName: string,
|
||||||
|
@ -58,7 +59,10 @@ export default function SubscribeButton(props: Props) {
|
||||||
}
|
}
|
||||||
const claimName = channelName && '@' + channelName;
|
const claimName = channelName && '@' + channelName;
|
||||||
|
|
||||||
|
const { pushSupported, pushEnabled, pushRequest } = useBrowserNotifications();
|
||||||
|
|
||||||
const subscriptionHandler = isSubscribed ? doChannelUnsubscribe : doChannelSubscribe;
|
const subscriptionHandler = isSubscribed ? doChannelUnsubscribe : doChannelSubscribe;
|
||||||
|
|
||||||
const subscriptionLabel = isSubscribed
|
const subscriptionLabel = isSubscribed
|
||||||
? __('Following --[button label indicating a channel has been followed]--')
|
? __('Following --[button label indicating a channel has been followed]--')
|
||||||
: __('Follow');
|
: __('Follow');
|
||||||
|
@ -145,6 +149,10 @@ export default function SubscribeButton(props: Props) {
|
||||||
{ channel: claimName }
|
{ channel: claimName }
|
||||||
),
|
),
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (!newNotificationsDisabled && pushSupported && !pushEnabled) {
|
||||||
|
pushRequest();
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
|
|
@ -11,6 +11,7 @@ import Yrbl from 'component/yrbl';
|
||||||
import * as NOTIFICATIONS from 'constants/notifications';
|
import * as NOTIFICATIONS from 'constants/notifications';
|
||||||
import useFetched from 'effects/use-fetched';
|
import useFetched from 'effects/use-fetched';
|
||||||
import { RULE } from 'constants/notifications';
|
import { RULE } from 'constants/notifications';
|
||||||
|
import BrowserNotificationBanner from '$web/component/browserNotificationBanner';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
notifications: Array<Notification>,
|
notifications: Array<Notification>,
|
||||||
|
@ -108,6 +109,8 @@ export default function NotificationsPage(props: Props) {
|
||||||
|
|
||||||
const notificationListElement = (
|
const notificationListElement = (
|
||||||
<>
|
<>
|
||||||
|
<BrowserNotificationBanner />
|
||||||
|
|
||||||
<div className="claim-list__header">
|
<div className="claim-list__header">
|
||||||
<h1 className="card__title">{__('Notifications')}</h1>
|
<h1 className="card__title">{__('Notifications')}</h1>
|
||||||
<div className="claim-list__alt-controls--wrap">
|
<div className="claim-list__alt-controls--wrap">
|
||||||
|
@ -135,6 +138,7 @@ export default function NotificationsPage(props: Props) {
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{list && list.length > 0 && !(isFiltered && fetching) ? (
|
{list && list.length > 0 && !(isFiltered && fetching) ? (
|
||||||
<div className="card">
|
<div className="card">
|
||||||
<div className="notification_list">
|
<div className="notification_list">
|
||||||
|
|
|
@ -13,6 +13,7 @@ import { useHistory } from 'react-router';
|
||||||
import { Redirect } from 'react-router-dom';
|
import { Redirect } from 'react-router-dom';
|
||||||
import Yrbl from 'component/yrbl';
|
import Yrbl from 'component/yrbl';
|
||||||
import Button from 'component/button';
|
import Button from 'component/button';
|
||||||
|
import BrowserNotificationSettings from '$web/component/browserNotificationSettings';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
osNotificationsEnabled: boolean,
|
osNotificationsEnabled: boolean,
|
||||||
|
@ -123,45 +124,22 @@ export default function NotificationSettingsPage(props: Props) {
|
||||||
/>
|
/>
|
||||||
) : (
|
) : (
|
||||||
<div className="card-stack">
|
<div className="card-stack">
|
||||||
{/* @if TARGET='app' */}
|
|
||||||
<div>
|
<div>
|
||||||
<h2 className="card__title">{__('App notifications')}</h2>
|
<h2 className="card__title">{__('Notification Delivery')}</h2>
|
||||||
<div className="card__subtitle">{__('Notification settings for the desktop app.')}</div>
|
<div className="card__subtitle">{__("Choose how you'd like to receive your Odysee notifications.")}</div>
|
||||||
</div>
|
</div>
|
||||||
<Card
|
<Card
|
||||||
isBodyList
|
isBodyList
|
||||||
body={
|
body={
|
||||||
<SettingsRow
|
<>
|
||||||
title={__('Show Desktop Notifications')}
|
{enabledEmails && enabledEmails.length > 0 && (
|
||||||
subtitle={__('Get notified when an upload or channel is confirmed.')}
|
|
||||||
>
|
|
||||||
<FormField
|
|
||||||
type="checkbox"
|
|
||||||
name="desktopNotification"
|
|
||||||
onChange={() => setClientSetting(SETTINGS.OS_NOTIFICATIONS_ENABLED, !osNotificationsEnabled)}
|
|
||||||
checked={osNotificationsEnabled}
|
|
||||||
/>
|
|
||||||
</SettingsRow>
|
|
||||||
}
|
|
||||||
/>
|
|
||||||
{/* @endif */}
|
|
||||||
|
|
||||||
{enabledEmails && enabledEmails.length > 0 && (
|
|
||||||
<>
|
|
||||||
<div>
|
|
||||||
<h2 className="card__title">
|
|
||||||
{enabledEmails.length === 1 ? __('Your email') : __('Receiving addresses')}
|
|
||||||
</h2>
|
|
||||||
<div className="card__subtitle">
|
|
||||||
{__('Uncheck your email below if you want to stop receiving messages.')}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<Card
|
|
||||||
isBodyList
|
|
||||||
body={
|
|
||||||
<>
|
<>
|
||||||
{enabledEmails.map(({ email, isEnabled }) => (
|
{enabledEmails.map(({ email, isEnabled }) => (
|
||||||
<SettingsRow key={email} subtitle={__(email)}>
|
<SettingsRow
|
||||||
|
key={email}
|
||||||
|
title={__('Email Notifications')}
|
||||||
|
subtitle={__(`Receive notifications to the email address: %email%`, { email })}
|
||||||
|
>
|
||||||
<FormField
|
<FormField
|
||||||
type="checkbox"
|
type="checkbox"
|
||||||
name={`active-email:${email}`}
|
name={`active-email:${email}`}
|
||||||
|
@ -172,18 +150,34 @@ export default function NotificationSettingsPage(props: Props) {
|
||||||
</SettingsRow>
|
</SettingsRow>
|
||||||
))}
|
))}
|
||||||
</>
|
</>
|
||||||
}
|
)}
|
||||||
/>
|
|
||||||
</>
|
{/* @if TARGET='web' */}
|
||||||
)}
|
<BrowserNotificationSettings />
|
||||||
|
{/* @endif */}
|
||||||
|
|
||||||
|
{/* @if TARGET='app' */}
|
||||||
|
<SettingsRow
|
||||||
|
title={__('Desktop Notifications')}
|
||||||
|
subtitle={__('Get notified when an upload or channel is confirmed.')}
|
||||||
|
>
|
||||||
|
<FormField
|
||||||
|
type="checkbox"
|
||||||
|
name="desktopNotification"
|
||||||
|
onChange={() => setClientSetting(SETTINGS.OS_NOTIFICATIONS_ENABLED, !osNotificationsEnabled)}
|
||||||
|
checked={osNotificationsEnabled}
|
||||||
|
/>
|
||||||
|
</SettingsRow>
|
||||||
|
{/* @endif */}
|
||||||
|
</>
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
|
||||||
{tags && tags.length > 0 && (
|
{tags && tags.length > 0 && (
|
||||||
<>
|
<>
|
||||||
<div>
|
<div>
|
||||||
<h2 className="card__title">{__('Email preferences')}</h2>
|
<h2 className="card__title">{__('Email Notification Topics')}</h2>
|
||||||
<div className="card__subtitle">
|
<div className="card__subtitle">{__('Choose which topics you’d like to be emailed about.')}</div>
|
||||||
{__("Opt out of any topics you don't want to receive email about.")}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<Card
|
<Card
|
||||||
isBodyList
|
isBodyList
|
||||||
|
|
|
@ -19,6 +19,7 @@ import { doClearPublish } from 'redux/actions/publish';
|
||||||
import { Lbryio } from 'lbryinc';
|
import { Lbryio } from 'lbryinc';
|
||||||
import { selectFollowedTagsList } from 'redux/selectors/tags';
|
import { selectFollowedTagsList } from 'redux/selectors/tags';
|
||||||
import { doToast, doError, doNotificationList } from 'redux/actions/notifications';
|
import { doToast, doError, doNotificationList } from 'redux/actions/notifications';
|
||||||
|
import { pushReconnect, pushDisconnect, pushValidate } from '$web/src/push-notifications';
|
||||||
|
|
||||||
import Native from 'native';
|
import Native from 'native';
|
||||||
import {
|
import {
|
||||||
|
@ -535,6 +536,10 @@ export function doSignIn() {
|
||||||
return (dispatch, getState) => {
|
return (dispatch, getState) => {
|
||||||
const state = getState();
|
const state = getState();
|
||||||
const user = selectUser(state);
|
const user = selectUser(state);
|
||||||
|
|
||||||
|
pushReconnect(user.id);
|
||||||
|
pushValidate(user.id);
|
||||||
|
|
||||||
const notificationsEnabled = SIMPLE_SITE || user.experimental_ui;
|
const notificationsEnabled = SIMPLE_SITE || user.experimental_ui;
|
||||||
|
|
||||||
dispatch(doNotificationSocketConnect(notificationsEnabled));
|
dispatch(doNotificationSocketConnect(notificationsEnabled));
|
||||||
|
@ -553,20 +558,26 @@ export function doSignIn() {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function doSignOut() {
|
export function doSignOut() {
|
||||||
return () => {
|
return async (dispatch, getState) => {
|
||||||
Lbryio.call('user', 'signout')
|
const state = getState();
|
||||||
.then(doSignOutCleanup)
|
const user = selectUser(state);
|
||||||
.then(() => {
|
try {
|
||||||
// @if TARGET='web'
|
await pushDisconnect(user.id);
|
||||||
window.persistor.purge();
|
} finally {
|
||||||
// @endif
|
Lbryio.call('user', 'signout')
|
||||||
})
|
.then(doSignOutCleanup)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
setTimeout(() => {
|
// @if TARGET='web'
|
||||||
location.reload();
|
window.persistor.purge();
|
||||||
});
|
// @endif
|
||||||
})
|
})
|
||||||
.catch(() => location.reload());
|
.then(() => {
|
||||||
|
setTimeout(() => {
|
||||||
|
location.reload();
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.catch(() => location.reload());
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
41
ui/scss/component/notifications-banner.scss
Normal file
41
ui/scss/component/notifications-banner.scss
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
@import '../init/vars';
|
||||||
|
|
||||||
|
.browserNotificationsBanner {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
margin-bottom: var(--spacing-xl);
|
||||||
|
justify-content: space-between;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
@media (max-width: $breakpoint-small) {
|
||||||
|
flex-direction: column;
|
||||||
|
margin-bottom: var(--spacing-m);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.browserNotificationsBanner__actions {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
|
||||||
|
@media (max-width: $breakpoint-small) {
|
||||||
|
margin-top: var(--spacing-l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.browserNotificationsBanner__overview {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.browserNotificationsBanner__icon {
|
||||||
|
margin-right: var(--spacing-m);
|
||||||
|
flex-shrink: 0;
|
||||||
|
}
|
||||||
|
.browserNotificationsBanner__button {
|
||||||
|
margin-right: var(--spacing-m);
|
||||||
|
}
|
||||||
|
|
||||||
|
.notificationsBlocked__subText {
|
||||||
|
color: var(--color-text-subtitle);
|
||||||
|
font-size: var(--font-small);
|
||||||
|
}
|
17
ui/scss/component/notifications-blocked.scss
Normal file
17
ui/scss/component/notifications-blocked.scss
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
.notificationsBlocked {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
background-color: var(--color-placeholder-background);
|
||||||
|
padding: var(--spacing-m);
|
||||||
|
}
|
||||||
|
|
||||||
|
.notificationsBlocked__icon {
|
||||||
|
flex-shrink: 0;
|
||||||
|
margin-right: var(--spacing-m);
|
||||||
|
}
|
||||||
|
|
||||||
|
.notificationsBlocked__subText {
|
||||||
|
display: inline-block;
|
||||||
|
color: var(--color-text-subtitle);
|
||||||
|
font-size: var(--font-small);
|
||||||
|
}
|
4
web/component/browserNotificationBanner/index.js
Normal file
4
web/component/browserNotificationBanner/index.js
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
import { connect } from 'react-redux';
|
||||||
|
import BrowserNotificationBanner from './view';
|
||||||
|
|
||||||
|
export default connect()(BrowserNotificationBanner);
|
42
web/component/browserNotificationBanner/view.jsx
Normal file
42
web/component/browserNotificationBanner/view.jsx
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
// @flow
|
||||||
|
import React from 'react';
|
||||||
|
import * as ICONS from 'constants/icons';
|
||||||
|
import useBrowserNotifications from '$web/component/browserNotificationSettings/use-browser-notifications';
|
||||||
|
import 'scss/component/notifications-banner.scss';
|
||||||
|
import Icon from 'component/common/icon';
|
||||||
|
import Button from 'component/button';
|
||||||
|
import usePersistedState from 'effects/use-persisted-state';
|
||||||
|
|
||||||
|
export const BrowserNotificationBanner = () => {
|
||||||
|
const { pushSupported, pushEnabled, pushPermission, pushToggle } = useBrowserNotifications();
|
||||||
|
const [hasAcknowledgedPush, setHasAcknowledgedPush] = usePersistedState('push-nag', false);
|
||||||
|
|
||||||
|
if (!pushSupported || pushEnabled || pushPermission === 'denied' || hasAcknowledgedPush) return null;
|
||||||
|
|
||||||
|
const handleClose = () => setHasAcknowledgedPush(true);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className="browserNotificationsBanner notice-message">
|
||||||
|
<div className="browserNotificationsBanner__overview">
|
||||||
|
<Icon className="browserNotificationsBanner__icon" icon={ICONS.NOTIFICATION} size={32} />
|
||||||
|
<p>
|
||||||
|
<strong>{__('Realtime push notifications straight to your browser.')}</strong>
|
||||||
|
<br />
|
||||||
|
<span className="notificationsBlocked__subText">{__("Don't miss another notification again.")}</span>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div className="browserNotificationsBanner__actions">
|
||||||
|
<Button
|
||||||
|
className="browserNotificationsBanner__button"
|
||||||
|
button="primary"
|
||||||
|
title={__('Enable Push Notifications')}
|
||||||
|
label={__('Enable Push Notifications')}
|
||||||
|
onClick={pushToggle}
|
||||||
|
/>
|
||||||
|
<Button button="close" title={__('Dismiss')} icon={ICONS.REMOVE} onClick={handleClose} />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default BrowserNotificationBanner;
|
4
web/component/browserNotificationSettings/index.js
Normal file
4
web/component/browserNotificationSettings/index.js
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
import { connect } from 'react-redux';
|
||||||
|
import BrowserNotificationSettings from './view';
|
||||||
|
|
||||||
|
export default connect()(BrowserNotificationSettings);
|
|
@ -0,0 +1,67 @@
|
||||||
|
// @flow
|
||||||
|
import { useEffect, useState, useMemo } from 'react';
|
||||||
|
import { pushSubscribe, pushUnsubscribe, pushIsSubscribed } from '$web/src/push-notifications';
|
||||||
|
import { isSupported } from 'firebase/messaging';
|
||||||
|
|
||||||
|
// @todo: Once we are on Redux 7 we should have proper hooks we can use here for store access.
|
||||||
|
import { store } from '$ui/store';
|
||||||
|
import { selectUser } from 'redux/selectors/user';
|
||||||
|
import { doToast } from 'redux/actions/notifications';
|
||||||
|
|
||||||
|
export default () => {
|
||||||
|
const [pushPermission, setPushPermission] = useState(window.Notification?.permission);
|
||||||
|
const [subscribed, setSubscribed] = useState(false);
|
||||||
|
const [pushEnabled, setPushEnabled] = useState(false);
|
||||||
|
const [pushSupported, setPushSupported] = useState(false);
|
||||||
|
|
||||||
|
const [user] = useState(selectUser(store.getState()));
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
pushIsSubscribed(user.id).then((isSubscribed: boolean) => setSubscribed(isSubscribed));
|
||||||
|
isSupported().then((supported: boolean) => setPushSupported(supported));
|
||||||
|
}, [user]);
|
||||||
|
|
||||||
|
useMemo(() => setPushEnabled(pushPermission === 'granted' && subscribed), [pushPermission, subscribed]);
|
||||||
|
|
||||||
|
const subscribe = async () => {
|
||||||
|
if (await pushSubscribe(user.id)) {
|
||||||
|
setSubscribed(true);
|
||||||
|
setPushPermission(window.Notification?.permission);
|
||||||
|
} else {
|
||||||
|
showError();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const unsubscribe = async () => {
|
||||||
|
if (await pushUnsubscribe(user.id)) {
|
||||||
|
setSubscribed(false);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const pushToggle = async () => {
|
||||||
|
return !pushEnabled ? subscribe() : unsubscribe();
|
||||||
|
};
|
||||||
|
|
||||||
|
const pushRequest = async () => {
|
||||||
|
return window.Notification?.permission !== 'granted' ? subscribe() : null;
|
||||||
|
};
|
||||||
|
|
||||||
|
const showError = () => {
|
||||||
|
store.dispatch(
|
||||||
|
doToast({
|
||||||
|
isError: true,
|
||||||
|
message: __(
|
||||||
|
'There was an error enabling browser notifications. Please make sure your browser settings allow you to subscribe to notifications.'
|
||||||
|
),
|
||||||
|
})
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
pushSupported,
|
||||||
|
pushEnabled,
|
||||||
|
pushPermission,
|
||||||
|
pushToggle,
|
||||||
|
pushRequest,
|
||||||
|
};
|
||||||
|
};
|
40
web/component/browserNotificationSettings/view.jsx
Normal file
40
web/component/browserNotificationSettings/view.jsx
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
// @flow
|
||||||
|
import React from 'react';
|
||||||
|
import * as ICONS from 'constants/icons';
|
||||||
|
import SettingsRow from 'component/settingsRow';
|
||||||
|
import { FormField } from 'component/common/form';
|
||||||
|
import useBrowserNotifications from '$web/component/browserNotificationSettings/use-browser-notifications';
|
||||||
|
import 'scss/component/notifications-blocked.scss';
|
||||||
|
import Icon from 'component/common/icon';
|
||||||
|
|
||||||
|
const BrowserNotificationsBlocked = () => {
|
||||||
|
return (
|
||||||
|
<div className="notificationsBlocked">
|
||||||
|
<Icon className="notificationsBlocked__icon" color="#E50054" icon={ICONS.ALERT} size={32} />
|
||||||
|
<div>
|
||||||
|
<span>{__('Heads up: browser notifications are currently blocked in this browser.')}</span>
|
||||||
|
<span className={'notificationsBlocked__subText'}>
|
||||||
|
{__('To enable push notifications please configure your browser to allow notifications on odysee.com.')}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const BrowserNotificationSettings = () => {
|
||||||
|
const { pushSupported, pushEnabled, pushPermission, pushToggle } = useBrowserNotifications();
|
||||||
|
|
||||||
|
if (!pushSupported) return null;
|
||||||
|
if (pushPermission === 'denied') return <BrowserNotificationsBlocked />;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<SettingsRow
|
||||||
|
title={__('Browser Notifications')}
|
||||||
|
subtitle={__("Receive push notifications in this browser, even when you're not on odysee.com")}
|
||||||
|
>
|
||||||
|
<FormField type="checkbox" name="browserNotification" onChange={pushToggle} checked={pushEnabled} />
|
||||||
|
</SettingsRow>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default BrowserNotificationSettings;
|
|
@ -27,12 +27,14 @@
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@koa/router": "^8.0.2",
|
"@koa/router": "^8.0.2",
|
||||||
"cross-env": "^6.0.3",
|
"cross-env": "^6.0.3",
|
||||||
|
"firebase": "^9.1.1",
|
||||||
"koa": "^2.11.0",
|
"koa": "^2.11.0",
|
||||||
"koa-logger": "^3.2.1",
|
"koa-logger": "^3.2.1",
|
||||||
"koa-send": "^5.0.0",
|
"koa-send": "^5.0.0",
|
||||||
"koa-static": "^5.0.0",
|
"koa-static": "^5.0.0",
|
||||||
"mysql": "^2.17.1",
|
"mysql": "^2.17.1",
|
||||||
"node-fetch": "^2.6.1",
|
"node-fetch": "^2.6.1",
|
||||||
|
"ua-parser-js": "^0.7.28",
|
||||||
"uuid": "^8.3.0"
|
"uuid": "^8.3.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
|
27
web/src/fcm-management.js
Normal file
27
web/src/fcm-management.js
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
// @flow
|
||||||
|
/*
|
||||||
|
* This module is responsible for persisting information about push notification
|
||||||
|
* registrations to local storage.
|
||||||
|
*/
|
||||||
|
|
||||||
|
const registrations = (): Array<string> => {
|
||||||
|
return JSON.parse(localStorage.getItem('fcm') || '[]');
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateRegistrations = (data) => {
|
||||||
|
localStorage.setItem('fcm', JSON.stringify(data));
|
||||||
|
};
|
||||||
|
|
||||||
|
export const addRegistration = (userId: number) => {
|
||||||
|
const data = Array.from(new Set(registrations().concat(userId)));
|
||||||
|
updateRegistrations(data);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const removeRegistration = (userId: number) => {
|
||||||
|
const data = registrations().filter((id) => id !== userId);
|
||||||
|
updateRegistrations(data);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const hasRegistration = (userId: number): boolean => {
|
||||||
|
return registrations().includes(userId);
|
||||||
|
};
|
22
web/src/firebase-config.js
Normal file
22
web/src/firebase-config.js
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
import {
|
||||||
|
FIREBASE_API_KEY,
|
||||||
|
FIREBASE_AUTH_DOMAIN,
|
||||||
|
FIREBASE_PROJECT_ID,
|
||||||
|
FIREBASE_STORAGE_BUCKET,
|
||||||
|
FIREBASE_MESSAGING_SENDER_ID,
|
||||||
|
FIREBASE_APP_ID,
|
||||||
|
FIREBASE_MEASUREMENT_ID,
|
||||||
|
FIREBASE_VAPID_KEY,
|
||||||
|
} from 'config';
|
||||||
|
|
||||||
|
export const firebaseConfig = {
|
||||||
|
apiKey: FIREBASE_API_KEY,
|
||||||
|
authDomain: FIREBASE_AUTH_DOMAIN,
|
||||||
|
projectId: FIREBASE_PROJECT_ID,
|
||||||
|
storageBucket: FIREBASE_STORAGE_BUCKET,
|
||||||
|
messagingSenderId: FIREBASE_MESSAGING_SENDER_ID,
|
||||||
|
appId: FIREBASE_APP_ID,
|
||||||
|
measurementId: FIREBASE_MEASUREMENT_ID,
|
||||||
|
};
|
||||||
|
|
||||||
|
export const vapidKey = FIREBASE_VAPID_KEY;
|
|
@ -1,6 +1,6 @@
|
||||||
const {
|
const {
|
||||||
URL,
|
URL,
|
||||||
DOMAIN,
|
// DOMAIN,
|
||||||
SITE_TITLE,
|
SITE_TITLE,
|
||||||
SITE_CANONICAL_URL,
|
SITE_CANONICAL_URL,
|
||||||
OG_HOMEPAGE_TITLE,
|
OG_HOMEPAGE_TITLE,
|
||||||
|
@ -119,13 +119,15 @@ function buildOgMetadata(overrideOptions = {}) {
|
||||||
return head;
|
return head;
|
||||||
}
|
}
|
||||||
|
|
||||||
function conditionallyAddPWA() {
|
function addPWA() {
|
||||||
let head = '';
|
let head = '';
|
||||||
if (DOMAIN === 'odysee.com') {
|
head += '<link rel="manifest" href="/public/pwa/manifest.json"/>';
|
||||||
head += '<link rel="manifest" href="./public/pwa/manifest.json"/>';
|
head += '<link rel="apple-touch-icon" sizes="180x180" href="/public/pwa/icon-180.png">';
|
||||||
head += '<link rel="apple-touch-icon" sizes="180x180" href="./public/pwa/icon-180.png">';
|
head += `<script>
|
||||||
head += '<script src="./serviceWorker.js"></script>';
|
window.addEventListener('load', function() {
|
||||||
}
|
if("serviceWorker" in navigator){navigator.serviceWorker.register("/sw.js")}
|
||||||
|
});
|
||||||
|
</script>`;
|
||||||
return head;
|
return head;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -137,11 +139,7 @@ function addFavicon() {
|
||||||
|
|
||||||
function buildHead() {
|
function buildHead() {
|
||||||
const head =
|
const head =
|
||||||
'<!-- VARIABLE_HEAD_BEGIN -->' +
|
'<!-- VARIABLE_HEAD_BEGIN -->' + addFavicon() + addPWA() + buildOgMetadata() + '<!-- VARIABLE_HEAD_END -->';
|
||||||
addFavicon() +
|
|
||||||
conditionallyAddPWA() +
|
|
||||||
buildOgMetadata() +
|
|
||||||
'<!-- VARIABLE_HEAD_END -->';
|
|
||||||
return head;
|
return head;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
84
web/src/push-notifications.js
Normal file
84
web/src/push-notifications.js
Normal file
|
@ -0,0 +1,84 @@
|
||||||
|
// @flow
|
||||||
|
/*
|
||||||
|
* This module is responsible for managing browser push notification
|
||||||
|
* subscriptions via the firebase SDK.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { Lbryio } from 'lbryinc';
|
||||||
|
import { initializeApp } from 'firebase/app';
|
||||||
|
import { getMessaging, getToken, deleteToken } from 'firebase/messaging';
|
||||||
|
import { firebaseConfig, vapidKey } from '$web/src/firebase-config';
|
||||||
|
import { addRegistration, removeRegistration, hasRegistration } from '$web/src/fcm-management';
|
||||||
|
import { browserData } from '$web/src/ua';
|
||||||
|
|
||||||
|
const app = initializeApp(firebaseConfig);
|
||||||
|
const messaging = getMessaging(app);
|
||||||
|
|
||||||
|
const subscriptionMetaData = () => {
|
||||||
|
const isMobile = window.navigator.userAgentData?.mobile || false;
|
||||||
|
const browserName = browserData.browser?.name || 'unknown';
|
||||||
|
const osName = browserData.os?.name || 'unknown';
|
||||||
|
return { type: `web-${isMobile ? 'mobile' : 'desktop'}`, name: `${browserName}-${osName}` };
|
||||||
|
};
|
||||||
|
|
||||||
|
const getFcmToken = async (): Promise<string | void> => {
|
||||||
|
const swRegistration = await navigator.serviceWorker?.ready;
|
||||||
|
if (!swRegistration) return;
|
||||||
|
return getToken(messaging, { serviceWorkerRegistration: swRegistration, vapidKey });
|
||||||
|
};
|
||||||
|
|
||||||
|
export const pushSubscribe = async (userId: number, permanent: boolean = true): Promise<boolean> => {
|
||||||
|
try {
|
||||||
|
const fcmToken = await getFcmToken();
|
||||||
|
if (!fcmToken) return false;
|
||||||
|
await Lbryio.call('cfm', 'add', { token: fcmToken, ...subscriptionMetaData() });
|
||||||
|
if (permanent) addRegistration(userId);
|
||||||
|
return true;
|
||||||
|
} catch {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const pushUnsubscribe = async (userId: number, permanent: boolean = true): Promise<boolean> => {
|
||||||
|
try {
|
||||||
|
const fcmToken = await getFcmToken();
|
||||||
|
if (!fcmToken) return false;
|
||||||
|
await deleteToken(messaging);
|
||||||
|
await Lbryio.call('cfm', 'remove', { token: fcmToken });
|
||||||
|
if (permanent) removeRegistration(userId);
|
||||||
|
return true;
|
||||||
|
} catch {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const pushIsSubscribed = async (userId: number): Promise<boolean> => {
|
||||||
|
const swRegistration = await navigator.serviceWorker?.ready;
|
||||||
|
if (!swRegistration || !swRegistration.pushManager) return false;
|
||||||
|
const browserSubscriptionExists = (await swRegistration.pushManager.getSubscription()) !== null;
|
||||||
|
const userRecordExists = hasRegistration(userId);
|
||||||
|
return browserSubscriptionExists && userRecordExists;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const pushReconnect = async (userId: number): Promise<boolean> => {
|
||||||
|
if (hasRegistration(userId)) return pushSubscribe(userId, false);
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const pushDisconnect = async (userId: number): Promise<boolean> => {
|
||||||
|
if (hasRegistration(userId)) return pushUnsubscribe(userId, false);
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const pushValidate = async (userId: number) => {
|
||||||
|
if (!hasRegistration(userId)) return;
|
||||||
|
window.requestIdleCallback(async () => {
|
||||||
|
const serverTokens = await Lbryio.call('cfm', 'list');
|
||||||
|
const fcmToken = await getFcmToken();
|
||||||
|
if (!fcmToken) return;
|
||||||
|
const exists = serverTokens.find((item) => item.value === fcmToken);
|
||||||
|
if (!exists) {
|
||||||
|
await pushSubscribe(userId, false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
62
web/src/service-worker.js
Normal file
62
web/src/service-worker.js
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
import { initializeApp } from 'firebase/app';
|
||||||
|
import { getMessaging } from 'firebase/messaging/sw';
|
||||||
|
import { firebaseConfig } from '$web/src/firebase-config';
|
||||||
|
|
||||||
|
const app = initializeApp(firebaseConfig);
|
||||||
|
getMessaging(app);
|
||||||
|
|
||||||
|
const NOTIFICATION_ICON = '/public/pwa/icon-512.png';
|
||||||
|
const NOTIFICATION_BADGE = '/public/pwa/icon-96-alpha.png';
|
||||||
|
|
||||||
|
// used to fetch the manifest file.
|
||||||
|
self.addEventListener('fetch', () => {});
|
||||||
|
|
||||||
|
self.addEventListener('install', (event) => {
|
||||||
|
// Activate worker immediately.
|
||||||
|
event.waitUntil(self.skipWaiting());
|
||||||
|
});
|
||||||
|
|
||||||
|
self.addEventListener('activate', (event) => {
|
||||||
|
// Become available to all pages.
|
||||||
|
event.waitUntil(self.clients.claim());
|
||||||
|
});
|
||||||
|
|
||||||
|
self.addEventListener('push', (event) => {
|
||||||
|
event.waitUntil(
|
||||||
|
(async () => {
|
||||||
|
const { data } = event.data.json();
|
||||||
|
|
||||||
|
if (!data.title || !data.body || !data.link) return;
|
||||||
|
|
||||||
|
return self.registration.showNotification(data.title, {
|
||||||
|
body: data.body,
|
||||||
|
data: { url: data.link },
|
||||||
|
badge: NOTIFICATION_BADGE,
|
||||||
|
icon: NOTIFICATION_ICON,
|
||||||
|
});
|
||||||
|
})()
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
self.addEventListener('notificationclick', async (event) => {
|
||||||
|
event.notification.close();
|
||||||
|
event.waitUntil(
|
||||||
|
(async () => {
|
||||||
|
if (!event.notification.data || !event.notification.data.url) return;
|
||||||
|
await self.clients.claim();
|
||||||
|
let client = await getWindowClient();
|
||||||
|
|
||||||
|
if (!client) {
|
||||||
|
return await self.clients.openWindow(event.notification.data.url);
|
||||||
|
} else {
|
||||||
|
client = await client.focus();
|
||||||
|
return client.navigate(event.notification.data.url);
|
||||||
|
}
|
||||||
|
})()
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
const getWindowClient = async () => {
|
||||||
|
const clientList = await self.clients.matchAll({ includeUncontrolled: true, type: 'window' });
|
||||||
|
return Array.isArray(clientList) && clientList.length > 0 ? clientList[0] : null;
|
||||||
|
};
|
4
web/src/ua.js
Normal file
4
web/src/ua.js
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
import { UAParser } from 'ua-parser-js';
|
||||||
|
const parser = new UAParser();
|
||||||
|
|
||||||
|
export const browserData = parser.getResult();
|
BIN
web/static/pwa/icon-96-alpha.png
Normal file
BIN
web/static/pwa/icon-96-alpha.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.3 KiB |
|
@ -1,14 +0,0 @@
|
||||||
// register service worker
|
|
||||||
if ('serviceWorker' in navigator) {
|
|
||||||
navigator.serviceWorker
|
|
||||||
.register('./serviceWorker.js')
|
|
||||||
.then(function(reg) {
|
|
||||||
// reg.scope must be '/' to allow '/' as start url
|
|
||||||
})
|
|
||||||
.catch(function(err) {
|
|
||||||
// console.warn('Error whilst registering service worker', err);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// used to fetch the manifest file
|
|
||||||
self.addEventListener('fetch', () => {});
|
|
|
@ -3,6 +3,7 @@ const path = require('path');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const merge = require('webpack-merge');
|
const merge = require('webpack-merge');
|
||||||
const baseConfig = require('../webpack.base.config.js');
|
const baseConfig = require('../webpack.base.config.js');
|
||||||
|
const serviceWorkerConfig = require('./webpack.sw.config.js');
|
||||||
const CopyWebpackPlugin = require('copy-webpack-plugin');
|
const CopyWebpackPlugin = require('copy-webpack-plugin');
|
||||||
const WriteFilePlugin = require('write-file-webpack-plugin');
|
const WriteFilePlugin = require('write-file-webpack-plugin');
|
||||||
const { DefinePlugin, ProvidePlugin } = require('webpack');
|
const { DefinePlugin, ProvidePlugin } = require('webpack');
|
||||||
|
@ -67,10 +68,6 @@ const copyWebpackCommands = [
|
||||||
from: `${WEB_STATIC_ROOT}/pwa/`,
|
from: `${WEB_STATIC_ROOT}/pwa/`,
|
||||||
to: `${DIST_ROOT}/public/pwa/`,
|
to: `${DIST_ROOT}/public/pwa/`,
|
||||||
},
|
},
|
||||||
{
|
|
||||||
from: `${WEB_STATIC_ROOT}/pwa/serviceWorker.js`,
|
|
||||||
to: `${DIST_ROOT}/`,
|
|
||||||
},
|
|
||||||
];
|
];
|
||||||
|
|
||||||
const CUSTOM_OG_PATH = `${CUSTOM_ROOT}/v2-og.png`;
|
const CUSTOM_OG_PATH = `${CUSTOM_ROOT}/v2-og.png`;
|
||||||
|
@ -175,6 +172,8 @@ const webConfig = {
|
||||||
|
|
||||||
alias: {
|
alias: {
|
||||||
// lbryinc: '../extras/lbryinc',
|
// lbryinc: '../extras/lbryinc',
|
||||||
|
$web: WEB_PLATFORM_ROOT,
|
||||||
|
$ui: UI_ROOT,
|
||||||
electron: `${WEB_PLATFORM_ROOT}/stubs/electron.js`,
|
electron: `${WEB_PLATFORM_ROOT}/stubs/electron.js`,
|
||||||
fs: `${WEB_PLATFORM_ROOT}/stubs/fs.js`,
|
fs: `${WEB_PLATFORM_ROOT}/stubs/fs.js`,
|
||||||
},
|
},
|
||||||
|
@ -182,4 +181,4 @@ const webConfig = {
|
||||||
plugins,
|
plugins,
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports = merge(baseConfig, webConfig);
|
module.exports = [merge(baseConfig, webConfig), serviceWorkerConfig];
|
||||||
|
|
41
web/webpack.sw.config.js
Normal file
41
web/webpack.sw.config.js
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
const NODE_ENV = process.env.NODE_ENV || 'development';
|
||||||
|
|
||||||
|
const path = require('path');
|
||||||
|
const WriteFilePlugin = require('write-file-webpack-plugin');
|
||||||
|
const Dotenv = require('dotenv-webpack');
|
||||||
|
const { getIfUtils } = require('webpack-config-utils');
|
||||||
|
const { ifProduction } = getIfUtils(NODE_ENV);
|
||||||
|
const DIST_ROOT = path.resolve(__dirname, 'dist/');
|
||||||
|
const WEB_PLATFORM_ROOT = __dirname;
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
target: 'web',
|
||||||
|
mode: ifProduction('production', 'development'),
|
||||||
|
devtool: ifProduction('source-map', 'eval-cheap-module-source-map'),
|
||||||
|
|
||||||
|
entry: path.join(WEB_PLATFORM_ROOT, '/src/service-worker.js'),
|
||||||
|
|
||||||
|
output: {
|
||||||
|
filename: 'sw.js',
|
||||||
|
path: DIST_ROOT,
|
||||||
|
globalObject: 'this',
|
||||||
|
},
|
||||||
|
|
||||||
|
plugins: [
|
||||||
|
new WriteFilePlugin(),
|
||||||
|
new Dotenv({
|
||||||
|
allowEmptyValues: true, // allow empty variables (e.g. `FOO=`) (treat it as empty string, rather than missing)
|
||||||
|
systemvars: true, // load all the predefined 'process.env' variables which will trump anything local per dotenv specs.
|
||||||
|
silent: false, // hide any errors
|
||||||
|
defaults: true, // load '.env.defaults' as the default values if empty.
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
|
||||||
|
resolve: {
|
||||||
|
alias: {
|
||||||
|
$web: WEB_PLATFORM_ROOT,
|
||||||
|
config: path.resolve(__dirname, '../config.js'),
|
||||||
|
fs: `${WEB_PLATFORM_ROOT}/stubs/fs.js`,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
737
web/yarn.lock
737
web/yarn.lock
|
@ -805,6 +805,385 @@
|
||||||
lodash "^4.17.13"
|
lodash "^4.17.13"
|
||||||
to-fast-properties "^2.0.0"
|
to-fast-properties "^2.0.0"
|
||||||
|
|
||||||
|
"@firebase/analytics-compat@0.1.3":
|
||||||
|
version "0.1.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/analytics-compat/-/analytics-compat-0.1.3.tgz#20a67a9583cf9cc87a04a762e96d697c9ecc08d7"
|
||||||
|
integrity sha512-FpaJ4sbJnryCRBkKIE45L2wGt2oCmlRK+AZc4JQHw20vb8Mf1WG1qGO+FGNoFev3lJSAd21tyhoLdPvbCTnOZQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/analytics" "0.7.2"
|
||||||
|
"@firebase/analytics-types" "0.7.0"
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/analytics-types@0.7.0":
|
||||||
|
version "0.7.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/analytics-types/-/analytics-types-0.7.0.tgz#91960e7c87ce8bf18cf8dd9e55ccbf5dc3989b5d"
|
||||||
|
integrity sha512-DNE2Waiwy5+zZnCfintkDtBfaW6MjIG883474v6Z0K1XZIvl76cLND4iv0YUb48leyF+PJK1KO2XrgHb/KpmhQ==
|
||||||
|
|
||||||
|
"@firebase/analytics@0.7.2":
|
||||||
|
version "0.7.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/analytics/-/analytics-0.7.2.tgz#2e5e49101c8cf3455b738efcb1f3bef15331d74b"
|
||||||
|
integrity sha512-YxLsPojufkfe3FFg6imOMQdfdJwu5hig17jnldpdmqemj1gOIwE/peTBrksP4rxnIra26XhsBRppcPcVQyxMNQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/installations" "0.5.2"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/app-check-compat@0.1.3":
|
||||||
|
version "0.1.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/app-check-compat/-/app-check-compat-0.1.3.tgz#b10c34a44d4bfdd86911506367e86705fb2e3ff0"
|
||||||
|
integrity sha512-ka5ggmfucQDwEJTcFsXPJJ+ygPZz4Q44D5yb0sksfOAsUSpzAR83jDSxebOgTvvk+axNCFamxOsrZEV6KKDjEg==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/app-check" "0.4.2"
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/app-check-interop-types@0.1.0":
|
||||||
|
version "0.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/app-check-interop-types/-/app-check-interop-types-0.1.0.tgz#83afd9d41f99166c2bdb2d824e5032e9edd8fe53"
|
||||||
|
integrity sha512-uZfn9s4uuRsaX5Lwx+gFP3B6YsyOKUE+Rqa6z9ojT4VSRAsZFko9FRn6OxQUA1z5t5d08fY4pf+/+Dkd5wbdbA==
|
||||||
|
|
||||||
|
"@firebase/app-check@0.4.2":
|
||||||
|
version "0.4.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/app-check/-/app-check-0.4.2.tgz#33ca60f439d679ced9a593b392c8a4934d14d81f"
|
||||||
|
integrity sha512-DFYt22lUMvvncN3v6x9ZRE2/HHBQdRQyYtHwakAcZrRUALJiU16iDwl2CABuW4JKytTmMj+xXo0fjSIRWtwT/w==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/app-compat@0.1.5":
|
||||||
|
version "0.1.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/app-compat/-/app-compat-0.1.5.tgz#0cb75a04245a4830a5354fd43a0d15c65222c4f4"
|
||||||
|
integrity sha512-GJURp5Nn8dEm72/y13Z+XMvWmMomsYViNxw6VKYqVH9f9VKnJ46Q8zYtx2ePvOuj7pAqsfwNkvAdAFYcveTe9g==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/app" "0.7.4"
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/app-types@0.7.0":
|
||||||
|
version "0.7.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/app-types/-/app-types-0.7.0.tgz#c9e16d1b8bed1a991840b8d2a725fb58d0b5899f"
|
||||||
|
integrity sha512-6fbHQwDv2jp/v6bXhBw2eSRbNBpxHcd1NBF864UksSMVIqIyri9qpJB1Mn6sGZE+bnDsSQBC5j2TbMxYsJQkQg==
|
||||||
|
|
||||||
|
"@firebase/app@0.7.4":
|
||||||
|
version "0.7.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/app/-/app-0.7.4.tgz#2100e6379e7f6e4ed0912f8312ecfb722dc1d085"
|
||||||
|
integrity sha512-XBrZb60m7N1XqmRhSJWADDD3J/0j9wM2VhxC5KUEtFA9SWfTn9Z3EWGtRGz7ahrMkgPJsmo0fXpvUh6cY8pQvQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/auth-compat@0.1.6":
|
||||||
|
version "0.1.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/auth-compat/-/auth-compat-0.1.6.tgz#0b7595a8327e4a526ec1d7c8b23d1e6a28c43af7"
|
||||||
|
integrity sha512-+HNIsti29ZX4AgLH4KdI+DAesX9DOywcmHFbVJtOE6Ow8v2d8NFTi66fa4LEU7HLCvj9YpeiEpHHLs4NamJ1tw==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/auth" "0.18.3"
|
||||||
|
"@firebase/auth-types" "0.11.0"
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
node-fetch "2.6.5"
|
||||||
|
selenium-webdriver "^4.0.0-beta.2"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/auth-interop-types@0.1.6":
|
||||||
|
version "0.1.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/auth-interop-types/-/auth-interop-types-0.1.6.tgz#5ce13fc1c527ad36f1bb1322c4492680a6cf4964"
|
||||||
|
integrity sha512-etIi92fW3CctsmR9e3sYM3Uqnoq861M0Id9mdOPF6PWIg38BXL5k4upCNBggGUpLIS0H1grMOvy/wn1xymwe2g==
|
||||||
|
|
||||||
|
"@firebase/auth-types@0.11.0":
|
||||||
|
version "0.11.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/auth-types/-/auth-types-0.11.0.tgz#b9c73c60ca07945b3bbd7a097633e5f78fa9e886"
|
||||||
|
integrity sha512-q7Bt6cx+ySj9elQHTsKulwk3+qDezhzRBFC9zlQ1BjgMueUOnGMcvqmU0zuKlQ4RhLSH7MNAdBV2znVaoN3Vxw==
|
||||||
|
|
||||||
|
"@firebase/auth@0.18.3":
|
||||||
|
version "0.18.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/auth/-/auth-0.18.3.tgz#d4dcc4c437eed008b1db30d5b7f74e081a3ee233"
|
||||||
|
integrity sha512-uS67CzypGu52H94mkptJ/lpoc0xAtVDksb/4+4HdSRwekxMt5EtyEdLMy8MH73Vk3MwTQWyTEsHEbwrGgk42pQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
node-fetch "2.6.5"
|
||||||
|
selenium-webdriver "4.0.0-rc-1"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/component@0.5.7":
|
||||||
|
version "0.5.7"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/component/-/component-0.5.7.tgz#a50c5fbd14a2136a99ade6f59f53498729c0f174"
|
||||||
|
integrity sha512-CiAHUPXh2hn/lpzMShNmfAxHNQhKQwmQUJSYMPCjf2bCCt4Z2vLGpS+UWEuNFm9Zf8LNmkS+Z+U/s4Obi5carg==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/database-compat@0.1.2":
|
||||||
|
version "0.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/database-compat/-/database-compat-0.1.2.tgz#c65cd59e4e1b7ec6834de5a17238787249da1e19"
|
||||||
|
integrity sha512-sV32QIRSNIBj/6OYtpmPzA/SfQz1/NBZbhxg9dIhGaSt9e5HaMxXRuz2lImudX0Sd/v8DKdExrxa++K6rKrRtA==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/database" "0.12.2"
|
||||||
|
"@firebase/database-types" "0.9.1"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/database-types@0.9.1":
|
||||||
|
version "0.9.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/database-types/-/database-types-0.9.1.tgz#0cab989e8154d812b535d80f23c1578b1d391f5f"
|
||||||
|
integrity sha512-RUixK/YrbpxbfdE+nYP0wMcEsz1xPTnafP0q3UlSS/+fW744OITKtR1J0cMRaXbvY7EH0wUVTNVkrtgxYY8IgQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/app-types" "0.7.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
|
||||||
|
"@firebase/database@0.12.2":
|
||||||
|
version "0.12.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/database/-/database-0.12.2.tgz#8c24ff4d79abcbef5896c2cdeae02ccc382db44b"
|
||||||
|
integrity sha512-Y1LZR1LIQM8YKMkeUPpAq3/e53hcfcXO+JEZ6vCzBeD6xRawqmpw6B5/DzePdCNNvjcqheXzSaR7T39eRZo/wA==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/auth-interop-types" "0.1.6"
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
faye-websocket "0.11.4"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/firestore-compat@0.1.4":
|
||||||
|
version "0.1.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/firestore-compat/-/firestore-compat-0.1.4.tgz#c94cdec41d2588dd74ff8f7ecb0bee84544be8c6"
|
||||||
|
integrity sha512-NuV0cKXE1EAxNkZxRXYjFsBPiXljuq0W3NeKyQYZTmYsVVJ215KHdR/RHAUA+1ZOfrfT2NgoZpBmE7LpYeLwXA==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/firestore" "3.1.1"
|
||||||
|
"@firebase/firestore-types" "2.5.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/firestore-types@2.5.0":
|
||||||
|
version "2.5.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/firestore-types/-/firestore-types-2.5.0.tgz#16fca40b6980fdb000de86042d7a96635f2bcdd7"
|
||||||
|
integrity sha512-I6c2m1zUhZ5SH0cWPmINabDyH5w0PPFHk2UHsjBpKdZllzJZ2TwTkXbDtpHUZNmnc/zAa0WNMNMvcvbb/xJLKA==
|
||||||
|
|
||||||
|
"@firebase/firestore@3.1.1":
|
||||||
|
version "3.1.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/firestore/-/firestore-3.1.1.tgz#4b3c0d15f8ca38a83cc655ebfc2dffb8a6c984ab"
|
||||||
|
integrity sha512-hFl+Me6F+GhtEaMsmwruOVoaJfoYinjCKyhaXzQT/jUsoBzKUBCd6MKMjYD+D+y1deAmdkFJcRNxPV7CsgF2aw==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
"@firebase/webchannel-wrapper" "0.6.0"
|
||||||
|
"@grpc/grpc-js" "^1.3.2"
|
||||||
|
"@grpc/proto-loader" "^0.6.0"
|
||||||
|
node-fetch "2.6.5"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/functions-compat@0.1.4":
|
||||||
|
version "0.1.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/functions-compat/-/functions-compat-0.1.4.tgz#06cb51e79f87eba3852ca1d9fe15c59507e4b013"
|
||||||
|
integrity sha512-mC/z0uJbGk/RRskabvvDylpMHMsNNwNIxrjBJy3J8ADZUqpJTMuT4gq+pHlPemYqLBZuN8TffIZNVPajXxqc+Q==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/functions" "0.7.3"
|
||||||
|
"@firebase/functions-types" "0.5.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/functions-types@0.5.0":
|
||||||
|
version "0.5.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/functions-types/-/functions-types-0.5.0.tgz#b50ba95ccce9e96f7cda453228ffe1684645625b"
|
||||||
|
integrity sha512-qza0M5EwX+Ocrl1cYI14zoipUX4gI/Shwqv0C1nB864INAD42Dgv4v94BCyxGHBg2kzlWy8PNafdP7zPO8aJQA==
|
||||||
|
|
||||||
|
"@firebase/functions@0.7.3":
|
||||||
|
version "0.7.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/functions/-/functions-0.7.3.tgz#b8aba7c1e5b1665053b04e075faeb7bbf6b0bc49"
|
||||||
|
integrity sha512-LxLbR9UtULLKMWSs6vtlte2Ka5tBDPGeGwX8Mto2uAtaNdrkoWKdhiJ4OTQx1YTCRIbTQnTg3t50NO8afzTEcQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/app-check-interop-types" "0.1.0"
|
||||||
|
"@firebase/auth-interop-types" "0.1.6"
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/messaging-interop-types" "0.1.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
node-fetch "2.6.5"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/installations@0.5.2":
|
||||||
|
version "0.5.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/installations/-/installations-0.5.2.tgz#3da5f54c3e15d7ea47a04729caf667b28203d760"
|
||||||
|
integrity sha512-k43qItRUnjIhAcxFRhGrox2ZBY/CFJOizB30hej9HuWOFv4qXoMZOmLtKzyjskFhRn/HW8iBUVguNFAEf6iehw==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
idb "3.0.2"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/logger@0.3.0":
|
||||||
|
version "0.3.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/logger/-/logger-0.3.0.tgz#a3992e40f62c10276dbfcb8b4ab376b7e25d7fd9"
|
||||||
|
integrity sha512-7oQ+TctqekfgZImWkKuda50JZfkmAKMgh5qY4aR4pwRyqZXuJXN1H/BKkHvN1y0S4XWtF0f/wiCLKHhyi1ppPA==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/messaging-compat@0.1.2":
|
||||||
|
version "0.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/messaging-compat/-/messaging-compat-0.1.2.tgz#915841c0fbb89620da019e8626dc641a39cb603f"
|
||||||
|
integrity sha512-ORxqIlnstjRhTpQsX7A0K9ifBTrqI7MNdWwCRbhvTh7GkzmhMe7ht+YAALrdvHD3Qty49UFrHznaIbF7Gr+nwA==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/messaging" "0.9.2"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/messaging-interop-types@0.1.0":
|
||||||
|
version "0.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/messaging-interop-types/-/messaging-interop-types-0.1.0.tgz#bdac02dd31edd5cb9eec37b1db698ea5e2c1a631"
|
||||||
|
integrity sha512-DbvUl/rXAZpQeKBnwz0NYY5OCqr2nFA0Bj28Fmr3NXGqR4PAkfTOHuQlVtLO1Nudo3q0HxAYLa68ZDAcuv2uKQ==
|
||||||
|
|
||||||
|
"@firebase/messaging@0.9.2":
|
||||||
|
version "0.9.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/messaging/-/messaging-0.9.2.tgz#8dffa8b392bd6dec04e0be4b1f091ece42b825a5"
|
||||||
|
integrity sha512-v95cny/HsupEvFiewsobjEtQ8ItMCPsg+29VLP51SIS3Ix7Kg2TJLZ2tfHkESRFazIhf2+GNwR8hdXoajqz2og==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/installations" "0.5.2"
|
||||||
|
"@firebase/messaging-interop-types" "0.1.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
idb "3.0.2"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/performance-compat@0.1.2":
|
||||||
|
version "0.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/performance-compat/-/performance-compat-0.1.2.tgz#3266bfc2fc6392b1b5d0587d618a042055dff694"
|
||||||
|
integrity sha512-L9rt89eIPaucGsO/bwF199mS5+BV3kHTfK1Fr1vCmGL87kLpV8DKVccKc7Z0ZwQelfMvXOGy5jVqH/sHhiQAYg==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/performance" "0.5.2"
|
||||||
|
"@firebase/performance-types" "0.1.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/performance-types@0.1.0":
|
||||||
|
version "0.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/performance-types/-/performance-types-0.1.0.tgz#5e6efa9dc81860aee2cb7121b39ae8fa137e69fc"
|
||||||
|
integrity sha512-6p1HxrH0mpx+622Ql6fcxFxfkYSBpE3LSuwM7iTtYU2nw91Hj6THC8Bc8z4nboIq7WvgsT/kOTYVVZzCSlXl8w==
|
||||||
|
|
||||||
|
"@firebase/performance@0.5.2":
|
||||||
|
version "0.5.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/performance/-/performance-0.5.2.tgz#c4f1d906ef7645a9b632c686bad577fce361349e"
|
||||||
|
integrity sha512-xHrt/BNiln3OIW9hyqKwck0x4C7Km+XKYQsP8cPDBh8AWFh//DB0ta7DuMXw7JGIuyKpK2D3iq5aQNS0MzMvSw==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/installations" "0.5.2"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/polyfill@0.3.36":
|
||||||
|
version "0.3.36"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/polyfill/-/polyfill-0.3.36.tgz#c057cce6748170f36966b555749472b25efdb145"
|
||||||
|
integrity sha512-zMM9oSJgY6cT2jx3Ce9LYqb0eIpDE52meIzd/oe/y70F+v9u1LDqk5kUF5mf16zovGBWMNFmgzlsh6Wj0OsFtg==
|
||||||
|
dependencies:
|
||||||
|
core-js "3.6.5"
|
||||||
|
promise-polyfill "8.1.3"
|
||||||
|
whatwg-fetch "2.0.4"
|
||||||
|
|
||||||
|
"@firebase/remote-config-compat@0.1.2":
|
||||||
|
version "0.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/remote-config-compat/-/remote-config-compat-0.1.2.tgz#0b35eaa536396b8ea7cb4d69c5578bee6f409c7a"
|
||||||
|
integrity sha512-j+joqwZAOO1L3pTlK8aQ3M+781ZbbOtV/TNpU4Tulqq+Psfjlx5SOYVfuF8njbbWGPLhLReFwmEjyE3jnm9hrQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/remote-config" "0.3.1"
|
||||||
|
"@firebase/remote-config-types" "0.2.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/remote-config-types@0.2.0":
|
||||||
|
version "0.2.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/remote-config-types/-/remote-config-types-0.2.0.tgz#1e2759fc01f20b58c564db42196f075844c3d1fd"
|
||||||
|
integrity sha512-hqK5sCPeZvcHQ1D6VjJZdW6EexLTXNMJfPdTwbD8NrXUw6UjWC4KWhLK/TSlL0QPsQtcKRkaaoP+9QCgKfMFPw==
|
||||||
|
|
||||||
|
"@firebase/remote-config@0.3.1":
|
||||||
|
version "0.3.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/remote-config/-/remote-config-0.3.1.tgz#6d7aea2e98527a499a4ee924dac84ea10a90de4a"
|
||||||
|
integrity sha512-31nZ0NEcARw1wYKIpoAx63rA0ao28e9zYNrlSC08mBiouSOxu69lthiO0V1ZrFqR/iW9+7M2MqnOUhJ6/LYEwQ==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/installations" "0.5.2"
|
||||||
|
"@firebase/logger" "0.3.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/storage-compat@0.1.4":
|
||||||
|
version "0.1.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/storage-compat/-/storage-compat-0.1.4.tgz#975d48f87cb58e4698d111853adf5b75a3cecf66"
|
||||||
|
integrity sha512-EV14tdnjm5yewGBgsUarGPzRUgqQX26+NVHIW1AoT+bMoODlL5ypYGv2/QA9Phi7JBvo5cAcTe4stEsu3CTF0g==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/storage" "0.8.4"
|
||||||
|
"@firebase/storage-types" "0.6.0"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/storage-types@0.6.0":
|
||||||
|
version "0.6.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/storage-types/-/storage-types-0.6.0.tgz#0b1af64a2965af46fca138e5b70700e9b7e6312a"
|
||||||
|
integrity sha512-1LpWhcCb1ftpkP/akhzjzeFxgVefs6eMD2QeKiJJUGH1qOiows2w5o0sKCUSQrvrRQS1lz3SFGvNR1Ck/gqxeA==
|
||||||
|
|
||||||
|
"@firebase/storage@0.8.4":
|
||||||
|
version "0.8.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/storage/-/storage-0.8.4.tgz#67344879bce124ed3efea2c732e2ed25d6676bf0"
|
||||||
|
integrity sha512-Flv25G8J4hp9wa9qTy9UoaBRl2Vcsr+FGaK6RaRUAzoMw2PA46ZPt/DChJZWxKgpmOq/7HyRc8qNTwqqDJt7dA==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/component" "0.5.7"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
node-fetch "2.6.5"
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/util@1.4.0":
|
||||||
|
version "1.4.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/util/-/util-1.4.0.tgz#81e985adba44b4d1f21ec9f5af9628d505891de8"
|
||||||
|
integrity sha512-Qn58d+DVi1nGn0bA9RV89zkz0zcbt6aUcRdyiuub/SuEvjKYstWmHcHwh1C0qmE1wPf9a3a+AuaRtduaGaRT7A==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.1.0"
|
||||||
|
|
||||||
|
"@firebase/webchannel-wrapper@0.6.0":
|
||||||
|
version "0.6.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@firebase/webchannel-wrapper/-/webchannel-wrapper-0.6.0.tgz#e18ea901c84917f8dadd0185048a9d00573fe595"
|
||||||
|
integrity sha512-Pz4+7HPzKvOFI1ICQ6pyUv/VgStEWq9IGiVaaV1cQLi66NIA1mD5INnY4CDNoVAxlkuZvDEUZ+cVHLQ8iwA2hQ==
|
||||||
|
|
||||||
|
"@grpc/grpc-js@^1.3.2":
|
||||||
|
version "1.4.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@grpc/grpc-js/-/grpc-js-1.4.1.tgz#799063a4ff7395987d4fceb2aab133629b003840"
|
||||||
|
integrity sha512-/chkA48TdAvATHA7RXJPeHQLdfFhpu51974s8htjO/XTDHA41j5+SkR5Io+lr9XsLmkZD6HxLyRAFGmA9wjO2w==
|
||||||
|
dependencies:
|
||||||
|
"@grpc/proto-loader" "^0.6.4"
|
||||||
|
"@types/node" ">=12.12.47"
|
||||||
|
|
||||||
|
"@grpc/proto-loader@^0.6.0", "@grpc/proto-loader@^0.6.4":
|
||||||
|
version "0.6.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/@grpc/proto-loader/-/proto-loader-0.6.6.tgz#d8e51ea808ec5fa54d9defbecbf859336fb2da71"
|
||||||
|
integrity sha512-cdMaPZ8AiFz6ua6PUbP+LKbhwJbFXnrQ/mlnKGUyzDUZ3wp7vPLksnmLCBX6SHgSmjX7CbNVNLFYD5GmmjO4GQ==
|
||||||
|
dependencies:
|
||||||
|
"@types/long" "^4.0.1"
|
||||||
|
lodash.camelcase "^4.3.0"
|
||||||
|
long "^4.0.0"
|
||||||
|
protobufjs "^6.10.0"
|
||||||
|
yargs "^16.1.1"
|
||||||
|
|
||||||
"@koa/router@^8.0.2":
|
"@koa/router@^8.0.2":
|
||||||
version "8.0.2"
|
version "8.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/@koa/router/-/router-8.0.2.tgz#46a48d58cb0d76dc7a3735f14d1e66bbe2116575"
|
resolved "https://registry.yarnpkg.com/@koa/router/-/router-8.0.2.tgz#46a48d58cb0d76dc7a3735f14d1e66bbe2116575"
|
||||||
|
@ -817,6 +1196,59 @@
|
||||||
path-to-regexp "^1.1.1"
|
path-to-regexp "^1.1.1"
|
||||||
urijs "^1.19.0"
|
urijs "^1.19.0"
|
||||||
|
|
||||||
|
"@protobufjs/aspromise@^1.1.1", "@protobufjs/aspromise@^1.1.2":
|
||||||
|
version "1.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/aspromise/-/aspromise-1.1.2.tgz#9b8b0cc663d669a7d8f6f5d0893a14d348f30fbf"
|
||||||
|
integrity sha1-m4sMxmPWaafY9vXQiToU00jzD78=
|
||||||
|
|
||||||
|
"@protobufjs/base64@^1.1.2":
|
||||||
|
version "1.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/base64/-/base64-1.1.2.tgz#4c85730e59b9a1f1f349047dbf24296034bb2735"
|
||||||
|
integrity sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==
|
||||||
|
|
||||||
|
"@protobufjs/codegen@^2.0.4":
|
||||||
|
version "2.0.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/codegen/-/codegen-2.0.4.tgz#7ef37f0d010fb028ad1ad59722e506d9262815cb"
|
||||||
|
integrity sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==
|
||||||
|
|
||||||
|
"@protobufjs/eventemitter@^1.1.0":
|
||||||
|
version "1.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz#355cbc98bafad5978f9ed095f397621f1d066b70"
|
||||||
|
integrity sha1-NVy8mLr61ZePntCV85diHx0Ga3A=
|
||||||
|
|
||||||
|
"@protobufjs/fetch@^1.1.0":
|
||||||
|
version "1.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/fetch/-/fetch-1.1.0.tgz#ba99fb598614af65700c1619ff06d454b0d84c45"
|
||||||
|
integrity sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=
|
||||||
|
dependencies:
|
||||||
|
"@protobufjs/aspromise" "^1.1.1"
|
||||||
|
"@protobufjs/inquire" "^1.1.0"
|
||||||
|
|
||||||
|
"@protobufjs/float@^1.0.2":
|
||||||
|
version "1.0.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/float/-/float-1.0.2.tgz#5e9e1abdcb73fc0a7cb8b291df78c8cbd97b87d1"
|
||||||
|
integrity sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=
|
||||||
|
|
||||||
|
"@protobufjs/inquire@^1.1.0":
|
||||||
|
version "1.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/inquire/-/inquire-1.1.0.tgz#ff200e3e7cf2429e2dcafc1140828e8cc638f089"
|
||||||
|
integrity sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=
|
||||||
|
|
||||||
|
"@protobufjs/path@^1.1.2":
|
||||||
|
version "1.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/path/-/path-1.1.2.tgz#6cc2b20c5c9ad6ad0dccfd21ca7673d8d7fbf68d"
|
||||||
|
integrity sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=
|
||||||
|
|
||||||
|
"@protobufjs/pool@^1.1.0":
|
||||||
|
version "1.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/pool/-/pool-1.1.0.tgz#09fd15f2d6d3abfa9b65bc366506d6ad7846ff54"
|
||||||
|
integrity sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=
|
||||||
|
|
||||||
|
"@protobufjs/utf8@^1.1.0":
|
||||||
|
version "1.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@protobufjs/utf8/-/utf8-1.1.0.tgz#a777360b5b39a1a2e5106f8e858f2fd2d060c570"
|
||||||
|
integrity sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=
|
||||||
|
|
||||||
"@types/events@*":
|
"@types/events@*":
|
||||||
version "3.0.0"
|
version "3.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/@types/events/-/events-3.0.0.tgz#2862f3f58a9a7f7c3e78d79f130dd4d71c25c2a7"
|
resolved "https://registry.yarnpkg.com/@types/events/-/events-3.0.0.tgz#2862f3f58a9a7f7c3e78d79f130dd4d71c25c2a7"
|
||||||
|
@ -831,6 +1263,11 @@
|
||||||
"@types/minimatch" "*"
|
"@types/minimatch" "*"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
|
|
||||||
|
"@types/long@^4.0.1":
|
||||||
|
version "4.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@types/long/-/long-4.0.1.tgz#459c65fa1867dafe6a8f322c4c51695663cc55e9"
|
||||||
|
integrity sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==
|
||||||
|
|
||||||
"@types/minimatch@*":
|
"@types/minimatch@*":
|
||||||
version "3.0.3"
|
version "3.0.3"
|
||||||
resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.3.tgz#3dca0e3f33b200fc7d1139c0cd96c1268cadfd9d"
|
resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.3.tgz#3dca0e3f33b200fc7d1139c0cd96c1268cadfd9d"
|
||||||
|
@ -841,6 +1278,11 @@
|
||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-12.12.6.tgz#a47240c10d86a9a57bb0c633f0b2e0aea9ce9253"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-12.12.6.tgz#a47240c10d86a9a57bb0c633f0b2e0aea9ce9253"
|
||||||
integrity sha512-FjsYUPzEJdGXjwKqSpE0/9QEh6kzhTAeObA54rn6j3rR4C/mzpI9L0KNfoeASSPMMdxIsoJuCLDWcM/rVjIsSA==
|
integrity sha512-FjsYUPzEJdGXjwKqSpE0/9QEh6kzhTAeObA54rn6j3rR4C/mzpI9L0KNfoeASSPMMdxIsoJuCLDWcM/rVjIsSA==
|
||||||
|
|
||||||
|
"@types/node@>=12.12.47", "@types/node@>=13.7.0":
|
||||||
|
version "16.11.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-16.11.6.tgz#6bef7a2a0ad684cf6e90fcfe31cecabd9ce0a3ae"
|
||||||
|
integrity sha512-ua7PgUoeQFjmWPcoo9khiPum3Pd60k4/2ZGXt18sm2Slk0W0xZTqt5Y0Ny1NyBiN1EVQ/+FaF9NcY4Qe6rwk5w==
|
||||||
|
|
||||||
"@webassemblyjs/ast@1.8.5":
|
"@webassemblyjs/ast@1.8.5":
|
||||||
version "1.8.5"
|
version "1.8.5"
|
||||||
resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.8.5.tgz#51b1c5fe6576a34953bf4b253df9f0d490d9e359"
|
resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.8.5.tgz#51b1c5fe6576a34953bf4b253df9f0d490d9e359"
|
||||||
|
@ -1067,6 +1509,11 @@ ansi-regex@^3.0.0:
|
||||||
resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998"
|
resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998"
|
||||||
integrity sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=
|
integrity sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=
|
||||||
|
|
||||||
|
ansi-regex@^5.0.1:
|
||||||
|
version "5.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304"
|
||||||
|
integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==
|
||||||
|
|
||||||
ansi-styles@^3.2.1:
|
ansi-styles@^3.2.1:
|
||||||
version "3.2.1"
|
version "3.2.1"
|
||||||
resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d"
|
resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d"
|
||||||
|
@ -1074,6 +1521,13 @@ ansi-styles@^3.2.1:
|
||||||
dependencies:
|
dependencies:
|
||||||
color-convert "^1.9.0"
|
color-convert "^1.9.0"
|
||||||
|
|
||||||
|
ansi-styles@^4.0.0:
|
||||||
|
version "4.3.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937"
|
||||||
|
integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==
|
||||||
|
dependencies:
|
||||||
|
color-convert "^2.0.1"
|
||||||
|
|
||||||
any-promise@^1.0.0, any-promise@^1.1.0:
|
any-promise@^1.0.0, any-promise@^1.1.0:
|
||||||
version "1.3.0"
|
version "1.3.0"
|
||||||
resolved "https://registry.yarnpkg.com/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f"
|
resolved "https://registry.yarnpkg.com/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f"
|
||||||
|
@ -1596,6 +2050,15 @@ cliui@^4.0.0:
|
||||||
strip-ansi "^4.0.0"
|
strip-ansi "^4.0.0"
|
||||||
wrap-ansi "^2.0.0"
|
wrap-ansi "^2.0.0"
|
||||||
|
|
||||||
|
cliui@^7.0.2:
|
||||||
|
version "7.0.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/cliui/-/cliui-7.0.4.tgz#a0265ee655476fc807aea9df3df8df7783808b4f"
|
||||||
|
integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==
|
||||||
|
dependencies:
|
||||||
|
string-width "^4.2.0"
|
||||||
|
strip-ansi "^6.0.0"
|
||||||
|
wrap-ansi "^7.0.0"
|
||||||
|
|
||||||
co@^4.6.0:
|
co@^4.6.0:
|
||||||
version "4.6.0"
|
version "4.6.0"
|
||||||
resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184"
|
resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184"
|
||||||
|
@ -1621,11 +2084,23 @@ color-convert@^1.9.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
color-name "1.1.3"
|
color-name "1.1.3"
|
||||||
|
|
||||||
|
color-convert@^2.0.1:
|
||||||
|
version "2.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3"
|
||||||
|
integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==
|
||||||
|
dependencies:
|
||||||
|
color-name "~1.1.4"
|
||||||
|
|
||||||
color-name@1.1.3:
|
color-name@1.1.3:
|
||||||
version "1.1.3"
|
version "1.1.3"
|
||||||
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25"
|
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25"
|
||||||
integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=
|
integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=
|
||||||
|
|
||||||
|
color-name@~1.1.4:
|
||||||
|
version "1.1.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2"
|
||||||
|
integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==
|
||||||
|
|
||||||
commander@^2.18.0, commander@^2.20.0:
|
commander@^2.18.0, commander@^2.20.0:
|
||||||
version "2.20.3"
|
version "2.20.3"
|
||||||
resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz#fd485e84c03eb4881c20722ba48035e8531aeb33"
|
resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz#fd485e84c03eb4881c20722ba48035e8531aeb33"
|
||||||
|
@ -1770,6 +2245,11 @@ core-js-compat@^3.1.1:
|
||||||
browserslist "^4.7.2"
|
browserslist "^4.7.2"
|
||||||
semver "^6.3.0"
|
semver "^6.3.0"
|
||||||
|
|
||||||
|
core-js@3.6.5:
|
||||||
|
version "3.6.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.6.5.tgz#7395dc273af37fb2e50e9bd3d9fe841285231d1a"
|
||||||
|
integrity sha512-vZVEEwZoIsI+vPEuoF9Iqf5H7/M3eeQqWlQnYa8FSKKePuYTf5MWnxb5SDAzCa60b3JBRS5g9b+Dq7b1y/RCrA==
|
||||||
|
|
||||||
core-js@^2.6.5:
|
core-js@^2.6.5:
|
||||||
version "2.6.10"
|
version "2.6.10"
|
||||||
resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.6.10.tgz#8a5b8391f8cc7013da703411ce5b585706300d7f"
|
resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.6.10.tgz#8a5b8391f8cc7013da703411ce5b585706300d7f"
|
||||||
|
@ -2118,6 +2598,11 @@ elliptic@^6.0.0:
|
||||||
minimalistic-assert "^1.0.1"
|
minimalistic-assert "^1.0.1"
|
||||||
minimalistic-crypto-utils "^1.0.1"
|
minimalistic-crypto-utils "^1.0.1"
|
||||||
|
|
||||||
|
emoji-regex@^8.0.0:
|
||||||
|
version "8.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37"
|
||||||
|
integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==
|
||||||
|
|
||||||
emojis-list@^2.0.0:
|
emojis-list@^2.0.0:
|
||||||
version "2.1.0"
|
version "2.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-2.1.0.tgz#4daa4d9db00f9819880c79fa457ae5b09a1fd389"
|
resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-2.1.0.tgz#4daa4d9db00f9819880c79fa457ae5b09a1fd389"
|
||||||
|
@ -2156,6 +2641,11 @@ error-inject@^1.0.0:
|
||||||
resolved "https://registry.yarnpkg.com/error-inject/-/error-inject-1.0.0.tgz#e2b3d91b54aed672f309d950d154850fa11d4f37"
|
resolved "https://registry.yarnpkg.com/error-inject/-/error-inject-1.0.0.tgz#e2b3d91b54aed672f309d950d154850fa11d4f37"
|
||||||
integrity sha1-4rPZG1Su1nLzCdlQ0VSFD6EdTzc=
|
integrity sha1-4rPZG1Su1nLzCdlQ0VSFD6EdTzc=
|
||||||
|
|
||||||
|
escalade@^3.1.1:
|
||||||
|
version "3.1.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40"
|
||||||
|
integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==
|
||||||
|
|
||||||
escape-html@^1.0.3, escape-html@~1.0.3:
|
escape-html@^1.0.3, escape-html@~1.0.3:
|
||||||
version "1.0.3"
|
version "1.0.3"
|
||||||
resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988"
|
resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988"
|
||||||
|
@ -2335,6 +2825,13 @@ fast-json-stable-stringify@^2.0.0:
|
||||||
resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz#d5142c0caee6b1189f87d3a76111064f86c8bbf2"
|
resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz#d5142c0caee6b1189f87d3a76111064f86c8bbf2"
|
||||||
integrity sha1-1RQsDK7msRifh9OnYREGT4bIu/I=
|
integrity sha1-1RQsDK7msRifh9OnYREGT4bIu/I=
|
||||||
|
|
||||||
|
faye-websocket@0.11.4:
|
||||||
|
version "0.11.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.11.4.tgz#7f0d9275cfdd86a1c963dc8b65fcc451edcbb1da"
|
||||||
|
integrity sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==
|
||||||
|
dependencies:
|
||||||
|
websocket-driver ">=0.5.1"
|
||||||
|
|
||||||
faye-websocket@^0.10.0:
|
faye-websocket@^0.10.0:
|
||||||
version "0.10.0"
|
version "0.10.0"
|
||||||
resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.10.0.tgz#4e492f8d04dfb6f89003507f6edbf2d501e7c6f4"
|
resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.10.0.tgz#4e492f8d04dfb6f89003507f6edbf2d501e7c6f4"
|
||||||
|
@ -2415,6 +2912,38 @@ find-up@^4.0.0:
|
||||||
locate-path "^5.0.0"
|
locate-path "^5.0.0"
|
||||||
path-exists "^4.0.0"
|
path-exists "^4.0.0"
|
||||||
|
|
||||||
|
firebase@^9.1.1:
|
||||||
|
version "9.1.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/firebase/-/firebase-9.1.3.tgz#11557f812f53edab5053ed0bd4dd344f2ae7fb5f"
|
||||||
|
integrity sha512-OZA60idIzSE5c01qWUDH2plhe+s4VrwbPurAh1KxvPEhMdZSOVK3zrBFHbc7nczFYWRDQpWU6v7gTHAVSANHQg==
|
||||||
|
dependencies:
|
||||||
|
"@firebase/analytics" "0.7.2"
|
||||||
|
"@firebase/analytics-compat" "0.1.3"
|
||||||
|
"@firebase/app" "0.7.4"
|
||||||
|
"@firebase/app-check" "0.4.2"
|
||||||
|
"@firebase/app-check-compat" "0.1.3"
|
||||||
|
"@firebase/app-compat" "0.1.5"
|
||||||
|
"@firebase/app-types" "0.7.0"
|
||||||
|
"@firebase/auth" "0.18.3"
|
||||||
|
"@firebase/auth-compat" "0.1.6"
|
||||||
|
"@firebase/database" "0.12.2"
|
||||||
|
"@firebase/database-compat" "0.1.2"
|
||||||
|
"@firebase/firestore" "3.1.1"
|
||||||
|
"@firebase/firestore-compat" "0.1.4"
|
||||||
|
"@firebase/functions" "0.7.3"
|
||||||
|
"@firebase/functions-compat" "0.1.4"
|
||||||
|
"@firebase/installations" "0.5.2"
|
||||||
|
"@firebase/messaging" "0.9.2"
|
||||||
|
"@firebase/messaging-compat" "0.1.2"
|
||||||
|
"@firebase/performance" "0.5.2"
|
||||||
|
"@firebase/performance-compat" "0.1.2"
|
||||||
|
"@firebase/polyfill" "0.3.36"
|
||||||
|
"@firebase/remote-config" "0.3.1"
|
||||||
|
"@firebase/remote-config-compat" "0.1.2"
|
||||||
|
"@firebase/storage" "0.8.4"
|
||||||
|
"@firebase/storage-compat" "0.1.4"
|
||||||
|
"@firebase/util" "1.4.0"
|
||||||
|
|
||||||
flush-write-stream@^1.0.0:
|
flush-write-stream@^1.0.0:
|
||||||
version "1.1.1"
|
version "1.1.1"
|
||||||
resolved "https://registry.yarnpkg.com/flush-write-stream/-/flush-write-stream-1.1.1.tgz#8dd7d873a1babc207d94ead0c2e0e44276ebf2e8"
|
resolved "https://registry.yarnpkg.com/flush-write-stream/-/flush-write-stream-1.1.1.tgz#8dd7d873a1babc207d94ead0c2e0e44276ebf2e8"
|
||||||
|
@ -2512,6 +3041,11 @@ get-caller-file@^1.0.1:
|
||||||
resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.3.tgz#f978fa4c90d1dfe7ff2d6beda2a515e713bdcf4a"
|
resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.3.tgz#f978fa4c90d1dfe7ff2d6beda2a515e713bdcf4a"
|
||||||
integrity sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==
|
integrity sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==
|
||||||
|
|
||||||
|
get-caller-file@^2.0.5:
|
||||||
|
version "2.0.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e"
|
||||||
|
integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==
|
||||||
|
|
||||||
get-stream@^3.0.0:
|
get-stream@^3.0.0:
|
||||||
version "3.0.0"
|
version "3.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz#8e943d1358dc37555054ecbe2edb05aa174ede14"
|
resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz#8e943d1358dc37555054ecbe2edb05aa174ede14"
|
||||||
|
@ -2803,6 +3337,11 @@ iconv-lite@0.4.24, iconv-lite@^0.4.4:
|
||||||
dependencies:
|
dependencies:
|
||||||
safer-buffer ">= 2.1.2 < 3"
|
safer-buffer ">= 2.1.2 < 3"
|
||||||
|
|
||||||
|
idb@3.0.2:
|
||||||
|
version "3.0.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/idb/-/idb-3.0.2.tgz#c8e9122d5ddd40f13b60ae665e4862f8b13fa384"
|
||||||
|
integrity sha512-+FLa/0sTXqyux0o6C+i2lOR0VoS60LU/jzUo5xjfY6+7sEEgy4Gz1O7yFBXvjd7N0NyIGWIRg8DcQSLEG+VSPw==
|
||||||
|
|
||||||
ieee754@^1.1.4:
|
ieee754@^1.1.4:
|
||||||
version "1.1.13"
|
version "1.1.13"
|
||||||
resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.13.tgz#ec168558e95aa181fd87d37f55c32bbcb6708b84"
|
resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.13.tgz#ec168558e95aa181fd87d37f55c32bbcb6708b84"
|
||||||
|
@ -2825,6 +3364,11 @@ ignore-walk@^3.0.1:
|
||||||
dependencies:
|
dependencies:
|
||||||
minimatch "^3.0.4"
|
minimatch "^3.0.4"
|
||||||
|
|
||||||
|
immediate@~3.0.5:
|
||||||
|
version "3.0.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/immediate/-/immediate-3.0.6.tgz#9db1dbd0faf8de6fbe0f5dd5e56bb606280de69b"
|
||||||
|
integrity sha1-nbHb0Pr43m++D13V5Wu2BigN5ps=
|
||||||
|
|
||||||
import-lazy@^2.1.0:
|
import-lazy@^2.1.0:
|
||||||
version "2.1.0"
|
version "2.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-2.1.0.tgz#05698e3d45c88e8d7e9d92cb0584e77f096f3e43"
|
resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-2.1.0.tgz#05698e3d45c88e8d7e9d92cb0584e77f096f3e43"
|
||||||
|
@ -3025,6 +3569,11 @@ is-fullwidth-code-point@^2.0.0:
|
||||||
resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f"
|
resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f"
|
||||||
integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=
|
integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=
|
||||||
|
|
||||||
|
is-fullwidth-code-point@^3.0.0:
|
||||||
|
version "3.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d"
|
||||||
|
integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==
|
||||||
|
|
||||||
is-generator-function@^1.0.7:
|
is-generator-function@^1.0.7:
|
||||||
version "1.0.7"
|
version "1.0.7"
|
||||||
resolved "https://registry.yarnpkg.com/is-generator-function/-/is-generator-function-1.0.7.tgz#d2132e529bb0000a7f80794d4bdf5cd5e5813522"
|
resolved "https://registry.yarnpkg.com/is-generator-function/-/is-generator-function-1.0.7.tgz#d2132e529bb0000a7f80794d4bdf5cd5e5813522"
|
||||||
|
@ -3210,6 +3759,16 @@ json5@^2.1.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
minimist "^1.2.0"
|
minimist "^1.2.0"
|
||||||
|
|
||||||
|
jszip@^3.6.0:
|
||||||
|
version "3.7.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/jszip/-/jszip-3.7.1.tgz#bd63401221c15625a1228c556ca8a68da6fda3d9"
|
||||||
|
integrity sha512-ghL0tz1XG9ZEmRMcEN2vt7xabrDdqHHeykgARpmZ0BiIctWxM47Vt63ZO2dnp4QYt/xJVLLy5Zv1l/xRdh2byg==
|
||||||
|
dependencies:
|
||||||
|
lie "~3.3.0"
|
||||||
|
pako "~1.0.2"
|
||||||
|
readable-stream "~2.3.6"
|
||||||
|
set-immediate-shim "~1.0.1"
|
||||||
|
|
||||||
keygrip@~1.1.0:
|
keygrip@~1.1.0:
|
||||||
version "1.1.0"
|
version "1.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/keygrip/-/keygrip-1.1.0.tgz#871b1681d5e159c62a445b0c74b615e0917e7226"
|
resolved "https://registry.yarnpkg.com/keygrip/-/keygrip-1.1.0.tgz#871b1681d5e159c62a445b0c74b615e0917e7226"
|
||||||
|
@ -3338,6 +3897,13 @@ lcid@^2.0.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
invert-kv "^2.0.0"
|
invert-kv "^2.0.0"
|
||||||
|
|
||||||
|
lie@~3.3.0:
|
||||||
|
version "3.3.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/lie/-/lie-3.3.0.tgz#dcf82dee545f46074daf200c7c1c5a08e0f40f6a"
|
||||||
|
integrity sha512-UaiMJzeWRlEujzAuw5LokY1L5ecNQYZKfmyZ9L7wDHb/p5etKaxXhohBcrw0EYby+G/NA52vRSN4N39dxHAIwQ==
|
||||||
|
dependencies:
|
||||||
|
immediate "~3.0.5"
|
||||||
|
|
||||||
loader-runner@^2.4.0:
|
loader-runner@^2.4.0:
|
||||||
version "2.4.0"
|
version "2.4.0"
|
||||||
resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-2.4.0.tgz#ed47066bfe534d7e84c4c7b9998c2a75607d9357"
|
resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-2.4.0.tgz#ed47066bfe534d7e84c4c7b9998c2a75607d9357"
|
||||||
|
@ -3367,6 +3933,11 @@ locate-path@^5.0.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
p-locate "^4.1.0"
|
p-locate "^4.1.0"
|
||||||
|
|
||||||
|
lodash.camelcase@^4.3.0:
|
||||||
|
version "4.3.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6"
|
||||||
|
integrity sha1-soqmKIorn8ZRA1x3EfZathkDMaY=
|
||||||
|
|
||||||
lodash@^4.17.11, lodash@^4.17.13, lodash@^4.17.14, lodash@^4.17.15:
|
lodash@^4.17.11, lodash@^4.17.13, lodash@^4.17.14, lodash@^4.17.15:
|
||||||
version "4.17.21"
|
version "4.17.21"
|
||||||
resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c"
|
resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c"
|
||||||
|
@ -3377,6 +3948,11 @@ loglevel@^1.6.4:
|
||||||
resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.6.6.tgz#0ee6300cc058db6b3551fa1c4bf73b83bb771312"
|
resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.6.6.tgz#0ee6300cc058db6b3551fa1c4bf73b83bb771312"
|
||||||
integrity sha512-Sgr5lbboAUBo3eXCSPL4/KoVz3ROKquOjcctxmHIt+vol2DrqTQe3SwkKKuYhEiWB5kYa13YyopJ69deJ1irzQ==
|
integrity sha512-Sgr5lbboAUBo3eXCSPL4/KoVz3ROKquOjcctxmHIt+vol2DrqTQe3SwkKKuYhEiWB5kYa13YyopJ69deJ1irzQ==
|
||||||
|
|
||||||
|
long@^4.0.0:
|
||||||
|
version "4.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/long/-/long-4.0.0.tgz#9a7b71cfb7d361a194ea555241c92f7468d5bf28"
|
||||||
|
integrity sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==
|
||||||
|
|
||||||
loose-envify@^1.0.0:
|
loose-envify@^1.0.0:
|
||||||
version "1.4.0"
|
version "1.4.0"
|
||||||
resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf"
|
resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf"
|
||||||
|
@ -3736,6 +4312,13 @@ nice-try@^1.0.4:
|
||||||
resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366"
|
resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366"
|
||||||
integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==
|
integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==
|
||||||
|
|
||||||
|
node-fetch@2.6.5:
|
||||||
|
version "2.6.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.5.tgz#42735537d7f080a7e5f78b6c549b7146be1742fd"
|
||||||
|
integrity sha512-mmlIVHJEu5rnIxgEgez6b9GgWXbkZj5YZ7fx+2r94a2E+Uirsp6HsPTPlomfdHtpt/B0cdKviwkoaM6pyvUOpQ==
|
||||||
|
dependencies:
|
||||||
|
whatwg-url "^5.0.0"
|
||||||
|
|
||||||
node-fetch@^2.6.1:
|
node-fetch@^2.6.1:
|
||||||
version "2.6.1"
|
version "2.6.1"
|
||||||
resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.1.tgz#045bd323631f76ed2e2b55573394416b639a0052"
|
resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.1.tgz#045bd323631f76ed2e2b55573394416b639a0052"
|
||||||
|
@ -4072,6 +4655,11 @@ package-json@^4.0.0:
|
||||||
registry-url "^3.0.3"
|
registry-url "^3.0.3"
|
||||||
semver "^5.1.0"
|
semver "^5.1.0"
|
||||||
|
|
||||||
|
pako@~1.0.2:
|
||||||
|
version "1.0.11"
|
||||||
|
resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf"
|
||||||
|
integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==
|
||||||
|
|
||||||
pako@~1.0.5:
|
pako@~1.0.5:
|
||||||
version "1.0.10"
|
version "1.0.10"
|
||||||
resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.10.tgz#4328badb5086a426aa90f541977d4955da5c9732"
|
resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.10.tgz#4328badb5086a426aa90f541977d4955da5c9732"
|
||||||
|
@ -4268,6 +4856,30 @@ promise-inflight@^1.0.1:
|
||||||
resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3"
|
resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3"
|
||||||
integrity sha1-mEcocL8igTL8vdhoEputEsPAKeM=
|
integrity sha1-mEcocL8igTL8vdhoEputEsPAKeM=
|
||||||
|
|
||||||
|
promise-polyfill@8.1.3:
|
||||||
|
version "8.1.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/promise-polyfill/-/promise-polyfill-8.1.3.tgz#8c99b3cf53f3a91c68226ffde7bde81d7f904116"
|
||||||
|
integrity sha512-MG5r82wBzh7pSKDRa9y+vllNHz3e3d4CNj1PQE4BQYxLme0gKYYBm9YENq+UkEikyZ0XbiGWxYlVw3Rl9O/U8g==
|
||||||
|
|
||||||
|
protobufjs@^6.10.0:
|
||||||
|
version "6.11.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/protobufjs/-/protobufjs-6.11.2.tgz#de39fabd4ed32beaa08e9bb1e30d08544c1edf8b"
|
||||||
|
integrity sha512-4BQJoPooKJl2G9j3XftkIXjoC9C0Av2NOrWmbLWT1vH32GcSUHjM0Arra6UfTsVyfMAuFzaLucXn1sadxJydAw==
|
||||||
|
dependencies:
|
||||||
|
"@protobufjs/aspromise" "^1.1.2"
|
||||||
|
"@protobufjs/base64" "^1.1.2"
|
||||||
|
"@protobufjs/codegen" "^2.0.4"
|
||||||
|
"@protobufjs/eventemitter" "^1.1.0"
|
||||||
|
"@protobufjs/fetch" "^1.1.0"
|
||||||
|
"@protobufjs/float" "^1.0.2"
|
||||||
|
"@protobufjs/inquire" "^1.1.0"
|
||||||
|
"@protobufjs/path" "^1.1.2"
|
||||||
|
"@protobufjs/pool" "^1.1.0"
|
||||||
|
"@protobufjs/utf8" "^1.1.0"
|
||||||
|
"@types/long" "^4.0.1"
|
||||||
|
"@types/node" ">=13.7.0"
|
||||||
|
long "^4.0.0"
|
||||||
|
|
||||||
proxy-addr@~2.0.5:
|
proxy-addr@~2.0.5:
|
||||||
version "2.0.5"
|
version "2.0.5"
|
||||||
resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.5.tgz#34cbd64a2d81f4b1fd21e76f9f06c8a45299ee34"
|
resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.5.tgz#34cbd64a2d81f4b1fd21e76f9f06c8a45299ee34"
|
||||||
|
@ -4591,6 +5203,13 @@ rimraf@^2.5.4, rimraf@^2.6.1, rimraf@^2.6.3:
|
||||||
dependencies:
|
dependencies:
|
||||||
glob "^7.1.3"
|
glob "^7.1.3"
|
||||||
|
|
||||||
|
rimraf@^3.0.0, rimraf@^3.0.2:
|
||||||
|
version "3.0.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a"
|
||||||
|
integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==
|
||||||
|
dependencies:
|
||||||
|
glob "^7.1.3"
|
||||||
|
|
||||||
ripemd160@^2.0.0, ripemd160@^2.0.1:
|
ripemd160@^2.0.0, ripemd160@^2.0.1:
|
||||||
version "2.0.2"
|
version "2.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.2.tgz#a1c1a6f624751577ba5d07914cbc92850585890c"
|
resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.2.tgz#a1c1a6f624751577ba5d07914cbc92850585890c"
|
||||||
|
@ -4655,6 +5274,26 @@ select-hose@^2.0.0:
|
||||||
resolved "https://registry.yarnpkg.com/select-hose/-/select-hose-2.0.0.tgz#625d8658f865af43ec962bfc376a37359a4994ca"
|
resolved "https://registry.yarnpkg.com/select-hose/-/select-hose-2.0.0.tgz#625d8658f865af43ec962bfc376a37359a4994ca"
|
||||||
integrity sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo=
|
integrity sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo=
|
||||||
|
|
||||||
|
selenium-webdriver@4.0.0-rc-1:
|
||||||
|
version "4.0.0-rc-1"
|
||||||
|
resolved "https://registry.yarnpkg.com/selenium-webdriver/-/selenium-webdriver-4.0.0-rc-1.tgz#b1e7e5821298c8a071e988518dd6b759f0c41281"
|
||||||
|
integrity sha512-bcrwFPRax8fifRP60p7xkWDGSJJoMkPAzufMlk5K2NyLPht/YZzR2WcIk1+3gR8VOCLlst1P2PI+MXACaFzpIw==
|
||||||
|
dependencies:
|
||||||
|
jszip "^3.6.0"
|
||||||
|
rimraf "^3.0.2"
|
||||||
|
tmp "^0.2.1"
|
||||||
|
ws ">=7.4.6"
|
||||||
|
|
||||||
|
selenium-webdriver@^4.0.0-beta.2:
|
||||||
|
version "4.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/selenium-webdriver/-/selenium-webdriver-4.0.0.tgz#7dc8969facee3be634459e173f557b7e34308e73"
|
||||||
|
integrity sha512-tOlu6FnTjPq2FKpd153pl8o2cB7H40Rvl/ogiD2sapMv4IDjQqpIxbd+swDJe9UDLdszeh5CDis6lgy4e9UG1w==
|
||||||
|
dependencies:
|
||||||
|
jszip "^3.6.0"
|
||||||
|
rimraf "^3.0.2"
|
||||||
|
tmp "^0.2.1"
|
||||||
|
ws ">=7.4.6"
|
||||||
|
|
||||||
selfsigned@^1.10.7:
|
selfsigned@^1.10.7:
|
||||||
version "1.10.7"
|
version "1.10.7"
|
||||||
resolved "https://registry.yarnpkg.com/selfsigned/-/selfsigned-1.10.7.tgz#da5819fd049d5574f28e88a9bcc6dbc6e6f3906b"
|
resolved "https://registry.yarnpkg.com/selfsigned/-/selfsigned-1.10.7.tgz#da5819fd049d5574f28e88a9bcc6dbc6e6f3906b"
|
||||||
|
@ -4731,6 +5370,11 @@ set-blocking@^2.0.0, set-blocking@~2.0.0:
|
||||||
resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7"
|
resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7"
|
||||||
integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc=
|
integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc=
|
||||||
|
|
||||||
|
set-immediate-shim@~1.0.1:
|
||||||
|
version "1.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz#4b2b1b27eb808a9f8dcc481a58e5e56f599f3f61"
|
||||||
|
integrity sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=
|
||||||
|
|
||||||
set-value@^2.0.0, set-value@^2.0.1:
|
set-value@^2.0.0, set-value@^2.0.1:
|
||||||
version "2.0.1"
|
version "2.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz#a18d40530e6f07de4228c7defe4227af8cad005b"
|
resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz#a18d40530e6f07de4228c7defe4227af8cad005b"
|
||||||
|
@ -4993,6 +5637,15 @@ string-width@^1.0.1:
|
||||||
is-fullwidth-code-point "^2.0.0"
|
is-fullwidth-code-point "^2.0.0"
|
||||||
strip-ansi "^4.0.0"
|
strip-ansi "^4.0.0"
|
||||||
|
|
||||||
|
string-width@^4.1.0, string-width@^4.2.0:
|
||||||
|
version "4.2.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010"
|
||||||
|
integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==
|
||||||
|
dependencies:
|
||||||
|
emoji-regex "^8.0.0"
|
||||||
|
is-fullwidth-code-point "^3.0.0"
|
||||||
|
strip-ansi "^6.0.1"
|
||||||
|
|
||||||
string_decoder@^1.0.0, string_decoder@^1.1.1:
|
string_decoder@^1.0.0, string_decoder@^1.1.1:
|
||||||
version "1.3.0"
|
version "1.3.0"
|
||||||
resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e"
|
resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e"
|
||||||
|
@ -5021,6 +5674,13 @@ strip-ansi@^4.0.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
ansi-regex "^3.0.0"
|
ansi-regex "^3.0.0"
|
||||||
|
|
||||||
|
strip-ansi@^6.0.0, strip-ansi@^6.0.1:
|
||||||
|
version "6.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9"
|
||||||
|
integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==
|
||||||
|
dependencies:
|
||||||
|
ansi-regex "^5.0.1"
|
||||||
|
|
||||||
strip-eof@^1.0.0:
|
strip-eof@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf"
|
resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf"
|
||||||
|
@ -5133,6 +5793,13 @@ timers-browserify@^2.0.4:
|
||||||
dependencies:
|
dependencies:
|
||||||
setimmediate "^1.0.4"
|
setimmediate "^1.0.4"
|
||||||
|
|
||||||
|
tmp@^0.2.1:
|
||||||
|
version "0.2.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.2.1.tgz#8457fc3037dcf4719c251367a1af6500ee1ccf14"
|
||||||
|
integrity sha512-76SUhtfqR2Ijn+xllcI5P1oyannHNHByD80W1q447gU3mp9G9PSpGdWmjUOHRDPiHYacIk66W7ubDTuPF3BEtQ==
|
||||||
|
dependencies:
|
||||||
|
rimraf "^3.0.0"
|
||||||
|
|
||||||
to-arraybuffer@^1.0.0:
|
to-arraybuffer@^1.0.0:
|
||||||
version "1.0.1"
|
version "1.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz#7d229b1fcc637e466ca081180836a7aabff83f43"
|
resolved "https://registry.yarnpkg.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz#7d229b1fcc637e466ca081180836a7aabff83f43"
|
||||||
|
@ -5180,6 +5847,11 @@ touch@^3.1.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
nopt "~1.0.10"
|
nopt "~1.0.10"
|
||||||
|
|
||||||
|
tr46@~0.0.3:
|
||||||
|
version "0.0.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a"
|
||||||
|
integrity sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=
|
||||||
|
|
||||||
tryer@^1.0.1:
|
tryer@^1.0.1:
|
||||||
version "1.0.1"
|
version "1.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/tryer/-/tryer-1.0.1.tgz#f2c85406800b9b0f74c9f7465b81eaad241252f8"
|
resolved "https://registry.yarnpkg.com/tryer/-/tryer-1.0.1.tgz#f2c85406800b9b0f74c9f7465b81eaad241252f8"
|
||||||
|
@ -5190,6 +5862,11 @@ tslib@^1.9.0:
|
||||||
resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.10.0.tgz#c3c19f95973fb0a62973fb09d90d961ee43e5c8a"
|
resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.10.0.tgz#c3c19f95973fb0a62973fb09d90d961ee43e5c8a"
|
||||||
integrity sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==
|
integrity sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==
|
||||||
|
|
||||||
|
tslib@^2.1.0:
|
||||||
|
version "2.3.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.3.1.tgz#e8a335add5ceae51aa261d32a490158ef042ef01"
|
||||||
|
integrity sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==
|
||||||
|
|
||||||
tsscmp@1.0.6:
|
tsscmp@1.0.6:
|
||||||
version "1.0.6"
|
version "1.0.6"
|
||||||
resolved "https://registry.yarnpkg.com/tsscmp/-/tsscmp-1.0.6.tgz#85b99583ac3589ec4bfef825b5000aa911d605eb"
|
resolved "https://registry.yarnpkg.com/tsscmp/-/tsscmp-1.0.6.tgz#85b99583ac3589ec4bfef825b5000aa911d605eb"
|
||||||
|
@ -5213,6 +5890,11 @@ typedarray@^0.0.6:
|
||||||
resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777"
|
resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777"
|
||||||
integrity sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=
|
integrity sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=
|
||||||
|
|
||||||
|
ua-parser-js@^0.7.28:
|
||||||
|
version "0.7.28"
|
||||||
|
resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-0.7.28.tgz#8ba04e653f35ce210239c64661685bf9121dec31"
|
||||||
|
integrity sha512-6Gurc1n//gjp9eQNXjD9O3M/sMwVtN5S8Lv9bvOYBfKfDNiIIhqiyi01vMBO45u4zkDE420w/e0se7Vs+sIg+g==
|
||||||
|
|
||||||
undefsafe@^2.0.2:
|
undefsafe@^2.0.2:
|
||||||
version "2.0.2"
|
version "2.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/undefsafe/-/undefsafe-2.0.2.tgz#225f6b9e0337663e0d8e7cfd686fc2836ccace76"
|
resolved "https://registry.yarnpkg.com/undefsafe/-/undefsafe-2.0.2.tgz#225f6b9e0337663e0d8e7cfd686fc2836ccace76"
|
||||||
|
@ -5418,6 +6100,11 @@ wbuf@^1.1.0, wbuf@^1.7.3:
|
||||||
dependencies:
|
dependencies:
|
||||||
minimalistic-assert "^1.0.0"
|
minimalistic-assert "^1.0.0"
|
||||||
|
|
||||||
|
webidl-conversions@^3.0.0:
|
||||||
|
version "3.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871"
|
||||||
|
integrity sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE=
|
||||||
|
|
||||||
webpack-bundle-analyzer@^3.6.0:
|
webpack-bundle-analyzer@^3.6.0:
|
||||||
version "3.6.0"
|
version "3.6.0"
|
||||||
resolved "https://registry.yarnpkg.com/webpack-bundle-analyzer/-/webpack-bundle-analyzer-3.6.0.tgz#39b3a8f829ca044682bc6f9e011c95deb554aefd"
|
resolved "https://registry.yarnpkg.com/webpack-bundle-analyzer/-/webpack-bundle-analyzer-3.6.0.tgz#39b3a8f829ca044682bc6f9e011c95deb554aefd"
|
||||||
|
@ -5553,6 +6240,19 @@ websocket-extensions@>=0.1.1:
|
||||||
resolved "https://registry.yarnpkg.com/websocket-extensions/-/websocket-extensions-0.1.4.tgz#7f8473bc839dfd87608adb95d7eb075211578a42"
|
resolved "https://registry.yarnpkg.com/websocket-extensions/-/websocket-extensions-0.1.4.tgz#7f8473bc839dfd87608adb95d7eb075211578a42"
|
||||||
integrity sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==
|
integrity sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==
|
||||||
|
|
||||||
|
whatwg-fetch@2.0.4:
|
||||||
|
version "2.0.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-2.0.4.tgz#dde6a5df315f9d39991aa17621853d720b85566f"
|
||||||
|
integrity sha512-dcQ1GWpOD/eEQ97k66aiEVpNnapVj90/+R+SXTPYGHpYBBypfKJEQjLrvMZ7YXbKm21gXd4NcuxUTjiv1YtLng==
|
||||||
|
|
||||||
|
whatwg-url@^5.0.0:
|
||||||
|
version "5.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d"
|
||||||
|
integrity sha1-lmRU6HZUYuN2RNNib2dCzotwll0=
|
||||||
|
dependencies:
|
||||||
|
tr46 "~0.0.3"
|
||||||
|
webidl-conversions "^3.0.0"
|
||||||
|
|
||||||
which-module@^2.0.0:
|
which-module@^2.0.0:
|
||||||
version "2.0.0"
|
version "2.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a"
|
resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a"
|
||||||
|
@ -5601,6 +6301,15 @@ wrap-ansi@^2.0.0:
|
||||||
string-width "^1.0.1"
|
string-width "^1.0.1"
|
||||||
strip-ansi "^3.0.1"
|
strip-ansi "^3.0.1"
|
||||||
|
|
||||||
|
wrap-ansi@^7.0.0:
|
||||||
|
version "7.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43"
|
||||||
|
integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==
|
||||||
|
dependencies:
|
||||||
|
ansi-styles "^4.0.0"
|
||||||
|
string-width "^4.1.0"
|
||||||
|
strip-ansi "^6.0.0"
|
||||||
|
|
||||||
wrappy@1:
|
wrappy@1:
|
||||||
version "1.0.2"
|
version "1.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f"
|
resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f"
|
||||||
|
@ -5628,6 +6337,11 @@ write-file-webpack-plugin@^4.5.1:
|
||||||
moment "^2.22.1"
|
moment "^2.22.1"
|
||||||
write-file-atomic "^2.3.0"
|
write-file-atomic "^2.3.0"
|
||||||
|
|
||||||
|
ws@>=7.4.6:
|
||||||
|
version "8.2.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/ws/-/ws-8.2.3.tgz#63a56456db1b04367d0b721a0b80cae6d8becbba"
|
||||||
|
integrity sha512-wBuoj1BDpC6ZQ1B7DWQBYVLphPWkm8i9Y0/3YdHjHKHiohOJ1ws+3OccDWtH+PoC9DZD5WOTrJvNbWvjS6JWaA==
|
||||||
|
|
||||||
ws@^6.0.0, ws@^6.2.1:
|
ws@^6.0.0, ws@^6.2.1:
|
||||||
version "6.2.2"
|
version "6.2.2"
|
||||||
resolved "https://registry.yarnpkg.com/ws/-/ws-6.2.2.tgz#dd5cdbd57a9979916097652d78f1cc5faea0c32e"
|
resolved "https://registry.yarnpkg.com/ws/-/ws-6.2.2.tgz#dd5cdbd57a9979916097652d78f1cc5faea0c32e"
|
||||||
|
@ -5650,6 +6364,11 @@ xtend@^4.0.0, xtend@~4.0.1:
|
||||||
resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.0.tgz#95ef94f85ecc81d007c264e190a120f0a3c8566b"
|
resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.0.tgz#95ef94f85ecc81d007c264e190a120f0a3c8566b"
|
||||||
integrity sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==
|
integrity sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==
|
||||||
|
|
||||||
|
y18n@^5.0.5:
|
||||||
|
version "5.0.8"
|
||||||
|
resolved "https://registry.yarnpkg.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55"
|
||||||
|
integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==
|
||||||
|
|
||||||
yallist@^2.1.2:
|
yallist@^2.1.2:
|
||||||
version "2.1.2"
|
version "2.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52"
|
resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52"
|
||||||
|
@ -5668,6 +6387,11 @@ yargs-parser@^11.1.1:
|
||||||
camelcase "^5.0.0"
|
camelcase "^5.0.0"
|
||||||
decamelize "^1.2.0"
|
decamelize "^1.2.0"
|
||||||
|
|
||||||
|
yargs-parser@^20.2.2:
|
||||||
|
version "20.2.9"
|
||||||
|
resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.9.tgz#2eb7dc3b0289718fc295f362753845c41a0c94ee"
|
||||||
|
integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==
|
||||||
|
|
||||||
yargs@12.0.5:
|
yargs@12.0.5:
|
||||||
version "12.0.5"
|
version "12.0.5"
|
||||||
resolved "https://registry.yarnpkg.com/yargs/-/yargs-12.0.5.tgz#05f5997b609647b64f66b81e3b4b10a368e7ad13"
|
resolved "https://registry.yarnpkg.com/yargs/-/yargs-12.0.5.tgz#05f5997b609647b64f66b81e3b4b10a368e7ad13"
|
||||||
|
@ -5686,6 +6410,19 @@ yargs@12.0.5:
|
||||||
y18n "^3.2.1 || ^4.0.0"
|
y18n "^3.2.1 || ^4.0.0"
|
||||||
yargs-parser "^11.1.1"
|
yargs-parser "^11.1.1"
|
||||||
|
|
||||||
|
yargs@^16.1.1:
|
||||||
|
version "16.2.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/yargs/-/yargs-16.2.0.tgz#1c82bf0f6b6a66eafce7ef30e376f49a12477f66"
|
||||||
|
integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==
|
||||||
|
dependencies:
|
||||||
|
cliui "^7.0.2"
|
||||||
|
escalade "^3.1.1"
|
||||||
|
get-caller-file "^2.0.5"
|
||||||
|
require-directory "^2.1.1"
|
||||||
|
string-width "^4.2.0"
|
||||||
|
y18n "^5.0.5"
|
||||||
|
yargs-parser "^20.2.2"
|
||||||
|
|
||||||
ylru@^1.2.0:
|
ylru@^1.2.0:
|
||||||
version "1.2.1"
|
version "1.2.1"
|
||||||
resolved "https://registry.yarnpkg.com/ylru/-/ylru-1.2.1.tgz#f576b63341547989c1de7ba288760923b27fe84f"
|
resolved "https://registry.yarnpkg.com/ylru/-/ylru-1.2.1.tgz#f576b63341547989c1de7ba288760923b27fe84f"
|
||||||
|
|
Loading…
Reference in a new issue