Use casual for mock data

This commit is contained in:
Josh Perez 2022-07-20 17:29:09 -04:00 committed by GitHub
parent f0bf3a075f
commit ea058371ed
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 195 additions and 457 deletions

View file

@ -264,6 +264,7 @@
"babel-core": "7.0.0-bridge.0", "babel-core": "7.0.0-bridge.0",
"babel-loader": "8.0.6", "babel-loader": "8.0.6",
"babel-plugin-lodash": "3.3.4", "babel-plugin-lodash": "3.3.4",
"casual": "1.6.2",
"chai": "4.3.4", "chai": "4.3.4",
"chai-as-promised": "7.1.1", "chai-as-promised": "7.1.1",
"core-js": "2.6.9", "core-js": "2.6.9",
@ -314,7 +315,7 @@
"fabric/jsdom": "https://registry.yarnpkg.com/nop/-/nop-1.0.0.tgz", "fabric/jsdom": "https://registry.yarnpkg.com/nop/-/nop-1.0.0.tgz",
"fast-glob/glob-parent": "5.1.2", "fast-glob/glob-parent": "5.1.2",
"read-last-lines/mz/thenify-all/thenify": "3.3.1", "read-last-lines/mz/thenify-all/thenify": "3.3.1",
"sharp/color/color-string": "1.7.4" "sharp/color/color-string": "1.9.0"
}, },
"engines": { "engines": {
"node": "16.13.2" "node": "16.13.2"

View file

@ -0,0 +1,21 @@
diff --git a/node_modules/casual/src/casual.js b/node_modules/casual/src/casual.js
index 9179af1..ed70b78 100644
--- a/node_modules/casual/src/casual.js
+++ b/node_modules/casual/src/casual.js
@@ -1,11 +1,11 @@
var helpers = require('./helpers');
-var exists = require('fs').existsSync;
var safe_require = function(filename) {
- if (exists(filename + '.js')) {
- return require(filename);
- }
- return {};
+ try {
+ return require(filename);
+ } catch (err) {
+ return {};
+ }
};
var build_casual = function() {

View file

@ -1,181 +1,175 @@
// Copyright 2021 Signal Messenger, LLC // Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only // SPDX-License-Identifier: AGPL-3.0-only
import type { Meta, Story } from '@storybook/react';
import React, { useState } from 'react'; import React, { useState } from 'react';
import casual from 'casual';
import { text, boolean, select } from '@storybook/addon-knobs';
import { action } from '@storybook/addon-actions';
import type { PropsType } from './ProfileEditor'; import type { PropsType } from './ProfileEditor';
import { ProfileEditor } from './ProfileEditor';
import { setupI18n } from '../util/setupI18n';
import enMessages from '../../_locales/en/messages.json'; import enMessages from '../../_locales/en/messages.json';
import { import { ProfileEditor } from './ProfileEditor';
getFirstName, import { UUID } from '../types/UUID';
getLastName,
} from '../test-both/helpers/getDefaultConversation';
import { getRandomColor } from '../test-both/helpers/getRandomColor';
import { UsernameSaveState } from '../state/ducks/conversationsEnums'; import { UsernameSaveState } from '../state/ducks/conversationsEnums';
import { getRandomColor } from '../test-both/helpers/getRandomColor';
import { setupI18n } from '../util/setupI18n';
const i18n = setupI18n('en', enMessages); const i18n = setupI18n('en', enMessages);
export default { export default {
component: ProfileEditor,
title: 'Components/ProfileEditor', title: 'Components/ProfileEditor',
}; argTypes: {
aboutEmoji: {
defaultValue: '',
},
aboutText: {
defaultValue: casual.sentence,
},
profileAvatarPath: {
defaultValue: undefined,
},
clearUsernameSave: { action: true },
conversationId: {
defaultValue: UUID.generate().toString(),
},
color: {
defaultValue: getRandomColor(),
},
deleteAvatarFromDisk: { action: true },
familyName: {
defaultValue: casual.last_name,
},
firstName: {
defaultValue: casual.first_name,
},
i18n: {
defaultValue: i18n,
},
isUsernameFlagEnabled: {
control: { type: 'checkbox' },
defaultValue: false,
},
onEditStateChanged: { action: true },
onProfileChanged: { action: true },
onSetSkinTone: { action: true },
recentEmojis: {
defaultValue: [],
},
replaceAvatar: { action: true },
saveAvatarToDisk: { action: true },
saveUsername: { action: true },
skinTone: {
defaultValue: 0,
},
userAvatarData: {
defaultValue: [],
},
username: {
defaultValue: casual.username,
},
usernameSaveState: {
control: { type: 'radio' },
defaultValue: UsernameSaveState.None,
options: {
None: UsernameSaveState.None,
Saving: UsernameSaveState.Saving,
UsernameTakenError: UsernameSaveState.UsernameTakenError,
UsernameMalformedError: UsernameSaveState.UsernameMalformedError,
GeneralError: UsernameSaveState.GeneralError,
DeleteFailed: UsernameSaveState.DeleteFailed,
Success: UsernameSaveState.Success,
},
},
},
} as Meta;
const createProps = (overrideProps: Partial<PropsType> = {}): PropsType => ({ const Template: Story<PropsType> = args => {
aboutEmoji: overrideProps.aboutEmoji,
aboutText: text('about', overrideProps.aboutText || ''),
profileAvatarPath: overrideProps.profileAvatarPath,
clearUsernameSave: action('clearUsernameSave'),
conversationId: '123',
color: overrideProps.color || getRandomColor(),
deleteAvatarFromDisk: action('deleteAvatarFromDisk'),
familyName: overrideProps.familyName,
firstName: text('firstName', overrideProps.firstName || getFirstName()),
i18n,
isUsernameFlagEnabled: boolean(
'isUsernameFlagEnabled',
overrideProps.isUsernameFlagEnabled !== undefined
? overrideProps.isUsernameFlagEnabled
: false
),
onEditStateChanged: action('onEditStateChanged'),
onProfileChanged: action('onProfileChanged'),
onSetSkinTone: overrideProps.onSetSkinTone || action('onSetSkinTone'),
recentEmojis: [],
replaceAvatar: action('replaceAvatar'),
saveAvatarToDisk: action('saveAvatarToDisk'),
saveUsername: action('saveUsername'),
skinTone: overrideProps.skinTone || 0,
userAvatarData: [],
username: overrideProps.username,
usernameSaveState: select(
'usernameSaveState',
Object.values(UsernameSaveState),
overrideProps.usernameSaveState || UsernameSaveState.None
),
});
export const FullSet = (): JSX.Element => {
const [skinTone, setSkinTone] = useState(0); const [skinTone, setSkinTone] = useState(0);
return ( return (
<ProfileEditor <ProfileEditor {...args} skinTone={skinTone} onSetSkinTone={setSkinTone} />
{...createProps({
aboutEmoji: '🙏',
aboutText: 'Live. Laugh. Love',
profileAvatarPath: '/fixtures/kitten-3-64-64.jpg',
onSetSkinTone: setSkinTone,
familyName: getLastName(),
skinTone,
})}
/>
); );
}; };
export const WithFullName = (): JSX.Element => ( export const FullSet = Template.bind({});
<ProfileEditor FullSet.args = {
{...createProps({ aboutEmoji: '🙏',
familyName: getLastName(), aboutText: 'Live. Laugh. Love',
})} familyName: casual.last_name,
/> firstName: casual.first_name,
); profileAvatarPath: '/fixtures/kitten-3-64-64.jpg',
};
export const WithFullName = Template.bind({});
WithFullName.args = {
familyName: casual.last_name,
};
WithFullName.story = { WithFullName.story = {
name: 'with Full Name', name: 'with Full Name',
}; };
export const WithCustomAbout = (): JSX.Element => ( export const WithCustomAbout = Template.bind({});
<ProfileEditor WithCustomAbout.args = {
{...createProps({ aboutEmoji: '🙏',
aboutEmoji: '🙏', aboutText: 'Live. Laugh. Love',
aboutText: 'Live. Laugh. Love', };
})}
/>
);
WithCustomAbout.story = { WithCustomAbout.story = {
name: 'with Custom About', name: 'with Custom About',
}; };
export const WithUsernameFlagEnabled = (): JSX.Element => ( export const WithUsernameFlagEnabled = Template.bind({});
<ProfileEditor WithUsernameFlagEnabled.args = {
{...createProps({ isUsernameFlagEnabled: true,
isUsernameFlagEnabled: true, };
})}
/>
);
WithUsernameFlagEnabled.story = { WithUsernameFlagEnabled.story = {
name: 'with Username flag enabled', name: 'with Username flag enabled',
}; };
export const WithUsernameFlagEnabledAndUsername = (): JSX.Element => ( export const WithUsernameFlagEnabledAndUsername = Template.bind({});
<ProfileEditor WithUsernameFlagEnabledAndUsername.args = {
{...createProps({ isUsernameFlagEnabled: true,
isUsernameFlagEnabled: true, username: casual.username,
username: 'unicorn55', };
})}
/>
);
WithUsernameFlagEnabledAndUsername.story = { WithUsernameFlagEnabledAndUsername.story = {
name: 'with Username flag enabled and username', name: 'with Username flag enabled and username',
}; };
export const UsernameEditingSaving = (): JSX.Element => ( export const UsernameEditingSaving = Template.bind({});
<ProfileEditor UsernameEditingSaving.args = {
{...createProps({ isUsernameFlagEnabled: true,
isUsernameFlagEnabled: true, usernameSaveState: UsernameSaveState.Saving,
usernameSaveState: UsernameSaveState.Saving, username: casual.username,
username: 'unicorn55', };
})}
/>
);
UsernameEditingSaving.story = { UsernameEditingSaving.story = {
name: 'Username editing, saving', name: 'Username editing, saving',
}; };
export const UsernameEditingUsernameTaken = (): JSX.Element => ( export const UsernameEditingUsernameTaken = Template.bind({});
<ProfileEditor UsernameEditingUsernameTaken.args = {
{...createProps({ isUsernameFlagEnabled: true,
isUsernameFlagEnabled: true, usernameSaveState: UsernameSaveState.UsernameTakenError,
usernameSaveState: UsernameSaveState.UsernameTakenError, username: casual.username,
username: 'unicorn55', };
})}
/>
);
UsernameEditingUsernameTaken.story = { UsernameEditingUsernameTaken.story = {
name: 'Username editing, username taken', name: 'Username editing, username taken',
}; };
export const UsernameEditingUsernameMalformed = (): JSX.Element => ( export const UsernameEditingUsernameMalformed = Template.bind({});
<ProfileEditor UsernameEditingUsernameMalformed.args = {
{...createProps({ isUsernameFlagEnabled: true,
isUsernameFlagEnabled: true, usernameSaveState: UsernameSaveState.UsernameMalformedError,
usernameSaveState: UsernameSaveState.UsernameMalformedError, username: casual.username,
username: 'unicorn55', };
})}
/>
);
UsernameEditingUsernameMalformed.story = { UsernameEditingUsernameMalformed.story = {
name: 'Username editing, username malformed', name: 'Username editing, username malformed',
}; };
export const UsernameEditingGeneralError = (): JSX.Element => ( export const UsernameEditingGeneralError = Template.bind({});
<ProfileEditor UsernameEditingGeneralError.args = {
{...createProps({ isUsernameFlagEnabled: true,
isUsernameFlagEnabled: true, usernameSaveState: UsernameSaveState.GeneralError,
usernameSaveState: UsernameSaveState.GeneralError, username: casual.username,
username: 'unicorn55', };
})}
/>
);
UsernameEditingGeneralError.story = { UsernameEditingGeneralError.story = {
name: 'Username editing, general error', name: 'Username editing, general error',
}; };

View file

@ -1,7 +1,7 @@
// Copyright 2020-2022 Signal Messenger, LLC // Copyright 2020-2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only // SPDX-License-Identifier: AGPL-3.0-only
import { v4 as generateUuid } from 'uuid'; import casual from 'casual';
import { sample } from 'lodash'; import { sample } from 'lodash';
import type { ConversationType } from '../../state/ducks/conversations'; import type { ConversationType } from '../../state/ducks/conversations';
import { UUID } from '../../types/UUID'; import { UUID } from '../../types/UUID';
@ -9,315 +9,6 @@ import type { UUIDStringType } from '../../types/UUID';
import { getRandomColor } from './getRandomColor'; import { getRandomColor } from './getRandomColor';
import { ConversationColors } from '../../types/Colors'; import { ConversationColors } from '../../types/Colors';
const FIRST_NAMES = [
'James',
'John',
'Robert',
'Michael',
'William',
'David',
'Richard',
'Joseph',
'Thomas',
'Charles',
'Christopher',
'Daniel',
'Matthew',
'Anthony',
'Donald',
'Mark',
'Paul',
'Steven',
'Andrew',
'Kenneth',
'Joshua',
'Kevin',
'Brian',
'George',
'Edward',
'Ronald',
'Timothy',
'Jason',
'Jeffrey',
'Ryan',
'Jacob',
'Gary',
'Nicholas',
'Eric',
'Jonathan',
'Stephen',
'Larry',
'Justin',
'Scott',
'Brandon',
'Benjamin',
'Samuel',
'Frank',
'Gregory',
'Raymond',
'Alexander',
'Patrick',
'Jack',
'Dennis',
'Jerry',
'Tyler',
'Aaron',
'Jose',
'Henry',
'Adam',
'Douglas',
'Nathan',
'Peter',
'Zachary',
'Kyle',
'Walter',
'Harold',
'Jeremy',
'Ethan',
'Carl',
'Keith',
'Roger',
'Gerald',
'Christian',
'Terry',
'Sean',
'Arthur',
'Austin',
'Noah',
'Lawrence',
'Jesse',
'Joe',
'Bryan',
'Billy',
'Jordan',
'Albert',
'Dylan',
'Bruce',
'Willie',
'Gabriel',
'Alan',
'Juan',
'Logan',
'Wayne',
'Ralph',
'Roy',
'Eugene',
'Randy',
'Vincent',
'Russell',
'Louis',
'Philip',
'Bobby',
'Johnny',
'Bradley',
'Mary',
'Patricia',
'Jennifer',
'Linda',
'Elizabeth',
'Barbara',
'Susan',
'Jessica',
'Sarah',
'Karen',
'Nancy',
'Lisa',
'Margaret',
'Betty',
'Sandra',
'Ashley',
'Dorothy',
'Kimberly',
'Emily',
'Donna',
'Michelle',
'Carol',
'Amanda',
'Melissa',
'Deborah',
'Stephanie',
'Rebecca',
'Laura',
'Sharon',
'Cynthia',
'Kathleen',
'Amy',
'Shirley',
'Angela',
'Helen',
'Anna',
'Brenda',
'Pamela',
'Nicole',
'Samantha',
'Katherine',
'Emma',
'Ruth',
'Christine',
'Catherine',
'Debra',
'Rachel',
'Carolyn',
'Janet',
'Virginia',
'Maria',
'Heather',
'Diane',
'Julie',
'Joyce',
'Victoria',
'Kelly',
'Christina',
'Lauren',
'Joan',
'Evelyn',
'Olivia',
'Judith',
'Megan',
'Cheryl',
'Martha',
'Andrea',
'Frances',
'Hannah',
'Jacqueline',
'Ann',
'Gloria',
'Jean',
'Kathryn',
'Alice',
'Teresa',
'Sara',
'Janice',
'Doris',
'Madison',
'Julia',
'Grace',
'Judy',
'Abigail',
'Marie',
'Denise',
'Beverly',
'Amber',
'Theresa',
'Marilyn',
'Danielle',
'Diana',
'Brittany',
'Natalie',
'Sophia',
'Rose',
'Isabella',
'Alexis',
'Kayla',
'Charlotte',
];
const LAST_NAMES = [
'Smith',
'Johnson',
'Williams',
'Brown',
'Jones',
'Garcia',
'Miller',
'Davis',
'Rodriguez',
'Martinez',
'Hernandez',
'Lopez',
'Gonzales',
'Wilson',
'Anderson',
'Thomas',
'Taylor',
'Moore',
'Jackson',
'Martin',
'Lee',
'Perez',
'Thompson',
'White',
'Harris',
'Sanchez',
'Clark',
'Ramirez',
'Lewis',
'Robinson',
'Walker',
'Young',
'Allen',
'King',
'Wright',
'Scott',
'Torres',
'Nguyen',
'Hill',
'Flores',
'Green',
'Adams',
'Nelson',
'Baker',
'Hall',
'Rivera',
'Campbell',
'Mitchell',
'Carter',
'Roberts',
'Gomez',
'Phillips',
'Evans',
'Turner',
'Diaz',
'Parker',
'Cruz',
'Edwards',
'Collins',
'Reyes',
'Stewart',
'Morris',
'Morales',
'Murphy',
'Cook',
'Rogers',
'Gutierrez',
'Ortiz',
'Morgan',
'Cooper',
'Peterson',
'Bailey',
'Reed',
'Kelly',
'Howard',
'Ramos',
'Kim',
'Cox',
'Ward',
'Richardson',
'Watson',
'Brooks',
'Chavez',
'Wood',
'James',
'Bennet',
'Gray',
'Mendoza',
'Ruiz',
'Hughes',
'Price',
'Alvarez',
'Castillo',
'Sanders',
'Patel',
'Myers',
'Long',
'Ross',
'Foster',
'Jimenez',
];
export const getFirstName = (): string => sample(FIRST_NAMES) || 'Test';
export const getLastName = (): string => sample(LAST_NAMES) || 'Test';
export const getAvatarPath = (): string => export const getAvatarPath = (): string =>
sample([ sample([
'/fixtures/kitten-1-64-64.jpg', '/fixtures/kitten-1-64-64.jpg',
@ -328,20 +19,20 @@ export const getAvatarPath = (): string =>
export function getDefaultConversation( export function getDefaultConversation(
overrideProps: Partial<ConversationType> = {} overrideProps: Partial<ConversationType> = {}
): ConversationType { ): ConversationType {
const firstName = getFirstName(); const firstName = casual.first_name;
const lastName = getLastName(); const lastName = casual.last_name;
return { return {
acceptedMessageRequest: true, acceptedMessageRequest: true,
avatarPath: getAvatarPath(), avatarPath: getAvatarPath(),
badges: [], badges: [],
e164: '+1300555000', e164: `+${casual.phone.replace(/-/g, '')}`,
conversationColor: ConversationColors[0], conversationColor: ConversationColors[0],
color: getRandomColor(), color: getRandomColor(),
firstName, firstName,
id: generateUuid(), id: UUID.generate().toString(),
isMe: false, isMe: false,
lastUpdated: Date.now(), lastUpdated: casual.unix_time,
markedUnread: Boolean(overrideProps.markedUnread), markedUnread: Boolean(overrideProps.markedUnread),
sharedGroupNames: [], sharedGroupNames: [],
title: `${firstName} ${lastName}`, title: `${firstName} ${lastName}`,

View file

@ -1,7 +1,7 @@
// Copyright 2022 Signal Messenger, LLC // Copyright 2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only // SPDX-License-Identifier: AGPL-3.0-only
import { v4 as uuid } from 'uuid'; import casual from 'casual';
import type { AttachmentType } from '../../types/Attachment'; import type { AttachmentType } from '../../types/Attachment';
import type { ConversationType } from '../../state/ducks/conversations'; import type { ConversationType } from '../../state/ducks/conversations';
@ -11,6 +11,7 @@ import type {
StoryViewType, StoryViewType,
} from '../../types/Stories'; } from '../../types/Stories';
import * as durations from '../../util/durations'; import * as durations from '../../util/durations';
import { UUID } from '../../types/UUID';
import { getDefaultConversation } from './getDefaultConversation'; import { getDefaultConversation } from './getDefaultConversation';
import { fakeAttachment, fakeThumbnail } from './fakeAttachment'; import { fakeAttachment, fakeThumbnail } from './fakeAttachment';
import { MY_STORIES_ID } from '../../types/Stories'; import { MY_STORIES_ID } from '../../types/Stories';
@ -23,16 +24,16 @@ function getAttachmentWithThumbnail(url: string): AttachmentType {
} }
export function getFakeMyStory(id?: string, name?: string): MyStoryType { export function getFakeMyStory(id?: string, name?: string): MyStoryType {
const storyCount = Math.ceil(Math.random() * 6 + 1); const storyCount = casual.integer(2, 6);
return { return {
distributionId: id || uuid(), distributionId: id || UUID.generate().toString(),
distributionName: distributionName:
name || id === MY_STORIES_ID ? 'My Stories' : 'Private Distribution List', name || id === MY_STORIES_ID ? 'My Stories' : casual.catch_phrase,
stories: Array.from(Array(storyCount), () => ({ stories: Array.from(Array(storyCount), () => ({
...getFakeStoryView(), ...getFakeStoryView(),
sendState: [], sendState: [],
views: Math.floor(Math.random() * 20), views: casual.integer(1, 20),
})), })),
}; };
} }
@ -47,9 +48,9 @@ export function getFakeStoryView(
attachment: getAttachmentWithThumbnail( attachment: getAttachmentWithThumbnail(
attachmentUrl || '/fixtures/tina-rolf-269345-unsplash.jpg' attachmentUrl || '/fixtures/tina-rolf-269345-unsplash.jpg'
), ),
hasReplies: Math.random() > 0.5, hasReplies: Boolean(casual.coin_flip),
isUnread: Math.random() > 0.5, isUnread: Boolean(casual.coin_flip),
messageId: uuid(), messageId: UUID.generate().toString(),
sender, sender,
timestamp: timestamp || Date.now() - 2 * durations.MINUTE, timestamp: timestamp || Date.now() - 2 * durations.MINUTE,
}; };

View file

@ -1752,6 +1752,18 @@
"reasonCategory": "falseMatch", "reasonCategory": "falseMatch",
"updated": "2018-09-19T18:13:29.628Z" "updated": "2018-09-19T18:13:29.628Z"
}, },
{
"rule": "jQuery-$(",
"path": "node_modules/casual/node_modules/moment/min/moment-with-locales.min.js",
"reasonCategory": "falseMatch",
"updated": "2022-07-07T22:51:10.163Z"
},
{
"rule": "jQuery-$(",
"path": "node_modules/casual/node_modules/moment/min/moment.min.js",
"reasonCategory": "falseMatch",
"updated": "2022-07-07T22:51:10.163Z"
},
{ {
"rule": "eval", "rule": "eval",
"path": "node_modules/config/lib/config.js", "path": "node_modules/config/lib/config.js",

View file

@ -5728,6 +5728,14 @@ case-sensitive-paths-webpack-plugin@^2.3.0:
resolved "https://registry.yarnpkg.com/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.4.0.tgz#db64066c6422eed2e08cc14b986ca43796dbc6d4" resolved "https://registry.yarnpkg.com/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.4.0.tgz#db64066c6422eed2e08cc14b986ca43796dbc6d4"
integrity sha512-roIFONhcxog0JSSWbvVAh3OocukmSgpqOH6YpMkCvav/ySIV3JKg4Dc8vYtQjYi/UxpNE36r/9v+VqTQqgkYmw== integrity sha512-roIFONhcxog0JSSWbvVAh3OocukmSgpqOH6YpMkCvav/ySIV3JKg4Dc8vYtQjYi/UxpNE36r/9v+VqTQqgkYmw==
casual@1.6.2:
version "1.6.2"
resolved "https://registry.yarnpkg.com/casual/-/casual-1.6.2.tgz#f56b87113ae99a6bba45e04bdfa068ca443f9e85"
integrity sha512-NQObL800rg32KZ9bBajHbyDjxLXxxuShChQg7A4tbSeG3n1t7VYGOSkzFSI9gkSgOHp+xilEJ7G0L5l6M30KYA==
dependencies:
mersenne-twister "^1.0.1"
moment "^2.15.2"
ccount@^1.0.0: ccount@^1.0.0:
version "1.1.0" version "1.1.0"
resolved "https://registry.yarnpkg.com/ccount/-/ccount-1.1.0.tgz#246687debb6014735131be8abab2d93898f8d043" resolved "https://registry.yarnpkg.com/ccount/-/ccount-1.1.0.tgz#246687debb6014735131be8abab2d93898f8d043"
@ -6055,10 +6063,10 @@ color-name@^1.0.0, color-name@~1.1.4:
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2"
integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==
color-string@1.7.4, color-string@^1.9.0: color-string@1.9.0, color-string@^1.9.0:
version "1.7.4" version "1.9.0"
resolved "https://registry.yarnpkg.com/color-string/-/color-string-1.7.4.tgz#79a7bf242610a8aa1b5e2681f3bf6bcfa666245f" resolved "https://registry.yarnpkg.com/color-string/-/color-string-1.9.0.tgz#63b6ebd1bec11999d1df3a79a7569451ac2be8aa"
integrity sha512-nVdUvPVgZMpRQad5dcsCMOSB5BXLljklTiaxS6ehhKxDsAI5sD7k5VmFuBt1y3Rlym8uulc/ANUN/bMWtBu6Sg== integrity sha512-9Mrz2AQLefkH1UvASKj6v6hj/7eWgjnT/cVsR8CumieLoT+g900exWeNogqtweI8dxloXN9BDQTYro1oWu/5CQ==
dependencies: dependencies:
color-name "^1.0.0" color-name "^1.0.0"
simple-swizzle "^0.2.2" simple-swizzle "^0.2.2"
@ -11443,6 +11451,11 @@ merge2@^1.4.1:
resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae"
integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==
mersenne-twister@^1.0.1:
version "1.1.0"
resolved "https://registry.yarnpkg.com/mersenne-twister/-/mersenne-twister-1.1.0.tgz#f916618ee43d7179efcf641bec4531eb9670978a"
integrity sha512-mUYWsMKNrm4lfygPkL3OfGzOPTR2DBlTkBNHM//F6hGp8cLThY897crAlk3/Jo17LEOOjQUrNAx6DvgO77QJkA==
methods@~1.1.2: methods@~1.1.2:
version "1.1.2" version "1.1.2"
resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee"
@ -11823,6 +11836,11 @@ moment@2.29.4:
resolved "https://registry.yarnpkg.com/moment/-/moment-2.29.4.tgz#3dbe052889fe7c1b2ed966fcb3a77328964ef108" resolved "https://registry.yarnpkg.com/moment/-/moment-2.29.4.tgz#3dbe052889fe7c1b2ed966fcb3a77328964ef108"
integrity sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w== integrity sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==
moment@^2.15.2:
version "2.29.4"
resolved "https://registry.yarnpkg.com/moment/-/moment-2.29.4.tgz#3dbe052889fe7c1b2ed966fcb3a77328964ef108"
integrity sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==
move-concurrently@^1.0.1: move-concurrently@^1.0.1:
version "1.0.1" version "1.0.1"
resolved "https://registry.yarnpkg.com/move-concurrently/-/move-concurrently-1.0.1.tgz#be2c005fda32e0b29af1f05d7c4b33214c701f92" resolved "https://registry.yarnpkg.com/move-concurrently/-/move-concurrently-1.0.1.tgz#be2c005fda32e0b29af1f05d7c4b33214c701f92"