From 742522cf7915dde65969bd7ce5794c5916cf7048 Mon Sep 17 00:00:00 2001 From: Alexey Ivanov Date: Tue, 9 Nov 2021 14:53:56 +0300 Subject: [PATCH 1/8] [test] Workaround for imageUrl --- stories/TreeTableFormMktp.stories.tsx | 307 ++++++++++++++++++++++++++ 1 file changed, 307 insertions(+) diff --git a/stories/TreeTableFormMktp.stories.tsx b/stories/TreeTableFormMktp.stories.tsx index d5c3a18..ce49e6d 100644 --- a/stories/TreeTableFormMktp.stories.tsx +++ b/stories/TreeTableFormMktp.stories.tsx @@ -60,6 +60,313 @@ const Template: Story = (args: any) => { 'https://rdf4j.agentlab.ru/rdf4j-server', 'https://rdf4j.agentlab.ru/rdf4j-server/repositories/mktp-schema/namespaces', ); + //TODO: Workaround for imageUrl + const ProductCardShapeSchema = { + '@id': 'hs:ProductCardShape', + '@type': 'sh:NodeShape', + '@context': { + '@type': 'rdf:type', + brand: { + '@id': 'hs:brand', + '@type': 'hs:Brand', + }, + seller: { + '@id': 'hs:seller', + '@type': 'hs:Seller', + }, + firstParsedAt: { + '@id': 'hs:firstParsedAt', + '@type': 'xsd:dateTime', + }, + lastMonthParsedAt: { + '@id': 'hs:lastMonthParsedAt', + '@type': 'xsd:dateTime', + }, + parsedAt: { + '@id': 'hs:parsedAt', + '@type': 'xsd:dateTime', + }, + prevParsedAt: { + '@id': 'hs:prevParsedAt', + '@type': 'xsd:dateTime', + }, + categoryPopularity: { + '@id': 'hs:categoryPopularity', + '@type': 'xsd:double', + }, + commentsCount: { + '@id': 'hs:commentsCount', + '@type': 'xsd:int', + }, + lastMonthSalesAmount: { + '@id': 'hs:lastMonthSalesAmount', + '@type': 'xsd:int', + }, + lastMonthSalesValue: { + '@id': 'hs:lastMonthSalesValue', + '@type': 'xsd:int', + }, + perMonthSalesValue: { + '@id': 'hs:perMonthSalesValue', + '@type': 'xsd:int', + }, + photosCount: { + '@id': 'hs:photosCount', + '@type': 'xsd:int', + }, + prevMonthSalesAmount: { + '@id': 'hs:prevMonthSalesAmount', + '@type': 'xsd:int', + }, + prevMonthSalesValue: { + '@id': 'hs:prevMonthSalesValue', + '@type': 'xsd:int', + }, + price: { + '@id': 'hs:price', + '@type': 'xsd:int', + }, + questionsCount: { + '@id': 'hs:questionsCount', + '@type': 'xsd:int', + }, + saleValue: { + '@id': 'hs:saleValue', + '@type': 'xsd:int', + }, + salesAmountDiff: { + '@id': 'hs:salesAmountDiff', + '@type': 'xsd:int', + }, + starsValue: { + '@id': 'hs:starsValue', + '@type': 'xsd:int', + }, + stocksDiffOrders: { + '@id': 'hs:stocksDiffOrders', + '@type': 'xsd:int', + }, + stocksDiffReturns: { + '@id': 'hs:stocksDiffReturns', + '@type': 'xsd:int', + }, + stocks: { + '@id': 'hs:stocks', + '@type': 'xsd:int', + }, + totalSalesDiff: { + '@id': 'hs:totalSalesDiff', + '@type': 'xsd:int', + }, + totalSales: { + '@id': 'hs:totalSales', + '@type': 'xsd:int', + }, + rootId: { + '@id': 'hs:rootId', + '@type': 'xsd:long', + }, + country: { + '@id': 'hs:country', + '@type': 'xsd:string', + }, + name: { + '@id': 'hs:name', + '@type': 'xsd:string', + }, + CardInCatLink: { + '@id': 'hs:CardInCatLink', + '@type': 'hs:CategoryShape', + }, + CardInProdLink: { + '@id': 'mktp:CardInProdLink', + '@type': 'mktp:Product', + }, + //imageUrl: { + // '@id': 'hs:imageUrl', + // '@type': '@id', + //}, + identifier: { + '@id': 'hs:identifier', + '@type': '@id', + }, + }, + targetClass: 'hs:ProductCard', + $schema: 'http://json-schema.org/draft-07/schema#', + type: 'object', + title: 'Карточка товара', + properties: { + '@id': { + title: 'URI', + type: 'string', + format: 'iri', + }, + '@type': { + title: 'Тип', + type: 'string', + format: 'iri', + }, + brand: { + title: 'Бренд', + type: 'string', + format: 'iri', + }, + seller: { + title: 'Продавец', + type: 'string', + format: 'iri', + }, + firstParsedAt: { + title: 'Первый раз распарсено', + type: 'string', + format: 'date-time', + }, + lastMonthParsedAt: { + title: 'Распарсено в последнем месяце', + type: 'string', + format: 'date-time', + }, + parsedAt: { + title: 'Распарсено', + type: 'string', + format: 'date-time', + }, + prevParsedAt: { + title: 'Предыдущий парсинг', + type: 'string', + format: 'date-time', + }, + categoryPopularity: { + title: 'Популярность категории', + type: 'number', + }, + commentsCount: { + title: 'Кол-во комментариев', + type: 'integer', + }, + lastMonthSalesAmount: { + title: 'Продажи за последний месяц', + type: 'integer', + }, + lastMonthSalesValue: { + title: 'Выручка за последний месяц', + type: 'integer', + }, + perMonthSalesValue: { + title: 'Средняя выручка за месяц', + type: 'integer', + }, + photosCount: { + title: 'Кол-во фото', + type: 'integer', + }, + prevMonthSalesAmount: { + title: 'Средние продажи за прошлый месяц', + type: 'integer', + }, + prevMonthSalesValue: { + title: 'Средняя выручка за прошлый месяц', + type: 'integer', + }, + price: { + title: 'Цена', + type: 'integer', + }, + questionsCount: { + title: 'Кол-во вопросов', + type: 'integer', + }, + saleValue: { + title: 'Размер скидки', + type: 'integer', + }, + salesAmountDiff: { + title: 'Выручка, руб/день', + type: 'integer', + }, + starsValue: { + title: 'Кол-во звезд', + type: 'integer', + }, + stocksDiffOrders: { + title: 'Заказы в шт (изменение)', + type: 'integer', + }, + stocksDiffReturns: { + title: 'Поступления-Возвраты в шт (изменение)', + type: 'integer', + }, + stocks: { + title: 'Остатки в шт', + type: 'integer', + }, + totalSalesDiff: { + title: 'Объем продаж, шт/день', + type: 'integer', + }, + totalSales: { + title: 'Общий объем продаж, шт', + type: 'integer', + }, + rootId: { + title: 'Корневой ИД', + type: 'integer', + }, + country: { + title: 'Страна', + type: 'string', + }, + name: { + title: 'Название', + type: 'string', + }, + CardInCatLink: { + title: 'Родительские категории карточки', + type: 'string', + format: 'iri', + }, + CardInProdLink: { + title: 'Продуктовая разметка карточки', + type: 'string', + format: 'iri', + }, + //imageUrl: { + // title: 'Изображение товара', + // type: 'string', + // format: 'iri', + //}, + identifier: { + title: 'ИД HunterSales', + type: 'string', + format: 'iri', + }, + }, + required: [ + '@id', + '@type', + 'brand', + 'seller', + 'firstParsedAt', + 'lastMonthParsedAt', + 'parsedAt', + 'prevParsedAt', + 'commentsCount', + 'lastMonthSalesAmount', + 'lastMonthSalesValue', + 'perMonthSalesValue', + 'photosCount', + 'prevMonthSalesAmount', + 'prevMonthSalesValue', + 'starsValue', + 'totalSales', + 'rootId', + 'country', + 'name', + ], + }; + rootModelInitialState.schemas.json[ProductCardShapeSchema['@id']] = ProductCardShapeSchema; + rootModelInitialState.schemas.class2schema[ProductCardShapeSchema.targetClass] = ProductCardShapeSchema['@id']; + //End Workaround for imageUrl const rootStore = createUiModelFromState('mktp-fed', client, rootModelInitialState, args.additionalColls); const store: any = asReduxStore(rootStore); // eslint-disable-next-line @typescript-eslint/no-var-requires From c897f79a130804fb6d835a6c0df751b76153c93a Mon Sep 17 00:00:00 2001 From: Artkrygin <80037398+Artkrygin@users.noreply.github.com> Date: Tue, 9 Nov 2021 17:30:00 +0300 Subject: [PATCH 2/8] [FIX] loadingMore feature --- src/table/basetable/ReactBaseTable.tsx | 29 ++++++++------------------ src/util/ContextToProps.tsx | 8 ++++--- stories/TreeTableFormMktp.stories.tsx | 2 +- 3 files changed, 15 insertions(+), 24 deletions(-) diff --git a/src/table/basetable/ReactBaseTable.tsx b/src/table/basetable/ReactBaseTable.tsx index ba524e6..33ec52b 100644 --- a/src/table/basetable/ReactBaseTable.tsx +++ b/src/table/basetable/ReactBaseTable.tsx @@ -94,7 +94,6 @@ export const EditableTable: React.FC> = React.memo( parsedSchema, onChangeMenu, dataSource, - limit, loadMoreData, setColumnVisible, loadExpandedData, @@ -120,7 +119,6 @@ export const EditableTable: React.FC> = React.memo( const [expandedRowKeys, setExpandedRowKeys] = useState([]); const sortColumns = createSortColumnsObject(sortDir); const [loadingMore, setLoadingMore] = useState(false); - const [loadedAll, setLoadedAll] = useState(false); const [selection, setSelection] = useState([]); const i18n = { language: 'ru_RU' }; const systemCol = { @@ -305,20 +303,10 @@ export const EditableTable: React.FC> = React.memo( } setExpandedRowKeys(newExpandedRowKeys); }; - const loadMore = () => { - //if (!limit) { - setLoadedAll(true); - /*} else { - setLoadingMore(true); - loadMoreData(data.length).then((d: any) => { - if (d.length < limit) { - setLoadedAll(true); - } - const newData = [...data, ...d]; - setData(newData); - setLoadingMore(false); - }); - }*/ + const loadMore = async () => { + setLoadingMore(true); + await loadMoreData(); + setLoadingMore(false); }; const rowClassName = ({ rowData, rowIndex }: any): string => { @@ -335,7 +323,7 @@ export const EditableTable: React.FC> = React.memo( return null; }; const handleEndReached = (props: any) => { - if (loadingMore || loadedAll || data.length === 0) return; + if (loadingMore || data.length === 0) return; loadMore(); }; const handleSortEnd = ({ oldIndex, newIndex }: any) => { @@ -349,13 +337,14 @@ export const EditableTable: React.FC> = React.memo( setSelection([]); onSelect([]); const newData = checkChildren(dataSource); - if (newData.length < limit) { + /*if (newData.length < limit) { setLoadedAll(true); } else { setLoadedAll(false); - } + }*/ setData(newData); - }, [dataSource, limit]); + }, [dataSource]); + return ( {initTinyMCE} diff --git a/src/util/ContextToProps.tsx b/src/util/ContextToProps.tsx index 532fc7c..f935ec2 100644 --- a/src/util/ContextToProps.tsx +++ b/src/util/ContextToProps.tsx @@ -421,14 +421,17 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = targetData = targetColl?.data; } const coll = store.getColl(collIriOverride); + let data = coll?.data; if (!data) { return ; } data = getSnapshot(data); - const loadMoreData = async (offset: number) => { - return data; //store.loadDataByUri(scope, offset); + + const loadMoreData = async () => { + coll.loadMore(); }; + const withConnections = options.connections; const addDataToTarget = (data: any) => { if (targetData) { @@ -468,7 +471,6 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = viewDescrElement={viewDescrElement} addDataToTarget={addDataToTarget} schema={schema} - limit={10 /*store.queries[viewKindElement.resultsScope].limit*/} loadExpandedData={loadExpandedData} sortDir={{} /*store.queries[scope].orderBy*/} uri={id} diff --git a/stories/TreeTableFormMktp.stories.tsx b/stories/TreeTableFormMktp.stories.tsx index ce49e6d..90c2e78 100644 --- a/stories/TreeTableFormMktp.stories.tsx +++ b/stories/TreeTableFormMktp.stories.tsx @@ -443,7 +443,7 @@ const viewKinds = [ service: mktpSchemaRepoIri, }, ], - limit: 100, + limit: 10, }, { '@id': 'mktp:Cards_Coll', From 088e9e725827d7fd3a41b5c617f38d11478b92c7 Mon Sep 17 00:00:00 2001 From: Alexey Ivanov Date: Wed, 10 Nov 2021 20:29:01 +0300 Subject: [PATCH 3/8] [fix] ProdCards switch, memoidization during loadMore --- src/util/ContextToProps.tsx | 33 ++++++++++++++++++++++++++------ stories/TwoTablesBig.stories.tsx | 13 ++++++++----- 2 files changed, 35 insertions(+), 11 deletions(-) diff --git a/src/util/ContextToProps.tsx b/src/util/ContextToProps.tsx index f935ec2..ef5e187 100644 --- a/src/util/ContextToProps.tsx +++ b/src/util/ContextToProps.tsx @@ -9,7 +9,7 @@ ********************************************************************************/ import { cloneDeep, get, isArray, isEqual, omit } from 'lodash-es'; -import React, { useContext, useState } from 'react'; +import React, { useContext, useEffect, useState } from 'react'; import { Spin } from 'antd'; import { getSnapshot, applySnapshot } from 'mobx-state-tree'; import { observer } from 'mobx-react-lite'; @@ -395,6 +395,18 @@ export const withStoreToCollapseProps = (Component: React.FC): React.FC { + console.log('ChartSubRenderer'); + const [allState, setAllState] = useState(null); + useEffect(() => { + if (!props.dataIsLoading) { + //console.log('setDelayedConfig'); + setAllState(props); + } + }, [props]); + return ; +}; + export const withStoreToArrayProps = (Component: React.FC): React.FC => observer(({ ...props }: any) => { const { viewKind, viewDescr, schema } = props; @@ -421,12 +433,19 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = targetData = targetColl?.data; } const coll = store.getColl(collIriOverride); + let dataIsLoading = false; - let data = coll?.data; - if (!data) { - return ; + let data: any[] = []; + if (!coll.isLoading) { + data = coll?.data; + if (!data) { + data = []; + } else { + data = getSnapshot(data as any); + } + } else { + dataIsLoading = true; } - data = getSnapshot(data); const loadMoreData = async () => { coll.loadMore(); @@ -464,7 +483,9 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = return data; //store.getDataByQuery(newQuery); }; return ( - Date: Wed, 10 Nov 2021 22:43:40 +0300 Subject: [PATCH 4/8] [ADD] Test actions --- src/Form.tsx | 6 +- src/MstContext.tsx | 7 +- src/actions/baseActions.ts | 19 ++++++ src/actions/constants.ts | 1 + src/actions/index.ts | 10 +++ src/actions/types.ts | 8 +++ src/actions/utils.ts | 31 +++++++++ src/index.ts | 1 + src/table/BaseTableControl.tsx | 2 + src/table/basetable/BaseTableMenu.tsx | 92 ++++++-------------------- src/table/basetable/ReactBaseTable.tsx | 11 +-- src/util/ContextToProps.tsx | 14 ++-- stories/TableRemoteMktp.stories.tsx | 2 +- stories/TwoTables.stories.tsx | 35 +++++++++- 14 files changed, 150 insertions(+), 89 deletions(-) create mode 100644 src/actions/baseActions.ts create mode 100644 src/actions/constants.ts create mode 100644 src/actions/index.ts create mode 100644 src/actions/types.ts create mode 100644 src/actions/utils.ts diff --git a/src/Form.tsx b/src/Form.tsx index a0c7625..21468e7 100644 --- a/src/Form.tsx +++ b/src/Form.tsx @@ -20,6 +20,7 @@ import { JsonSchema7 } from './models/jsonSchema7'; //import ModalAntd from './antd/util/AntdModal'; import { MstContext } from './MstContext'; import { UnknownRenderer } from './UnknownRenderer'; +import { Actions } from './actions'; import { RankedTester } from './testers'; import { IViewDescr, IViewDescrElement, IViewKind, IViewKindElement } from './models/uischema'; @@ -59,7 +60,7 @@ export interface FormsDispatchProps { } export interface RenderProps extends FormsDispatchProps { viewDescrElement?: IViewDescrElement; - + actions?: Actions; id: string; schema: JsonSchema7; readOnly?: boolean; @@ -127,7 +128,7 @@ export const processViewKindOverride = ( }; export const FormsDispatch = observer((props) => { - const { store, renderers } = useContext(MstContext); + const { store, renderers, actions } = useContext(MstContext); const { viewKind, viewDescr, form, enabled } = props; const [id, collIri, collIriOverride, inCollPath, viewKindElement, viewDescrElement] = processViewKindOverride( @@ -166,6 +167,7 @@ export const FormsDispatch = observer((props) => { viewDescr={viewDescr} viewDescrElement={viewDescrElement} schema={schema} + actions={actions} enabled={enabled} form={form} /> diff --git a/src/MstContext.tsx b/src/MstContext.tsx index c5e3425..940b6a7 100644 --- a/src/MstContext.tsx +++ b/src/MstContext.tsx @@ -10,17 +10,20 @@ import React, { createContext, PropsWithChildren } from 'react'; import { CellRendererRegistryEntry, RendererRegistryEntry } from './renderers'; import { registerMstViewDescrSchema, registerMstViewKindSchema } from './models/MstViewDescr'; +import { Actions } from './actions'; export interface MstContextProps { store: any; renderers: RendererRegistryEntry[]; cells: CellRendererRegistryEntry[]; + actions: Actions; } export const MstContext = createContext({ store: {}, renderers: [], cells: [], + actions: {}, }); export const MstContextProvider = ({ @@ -28,10 +31,12 @@ export const MstContextProvider = ({ renderers, cells = [], children, + actions = {}, }: PropsWithChildren<{ store: any; renderers: RendererRegistryEntry[]; cells?: CellRendererRegistryEntry[]; + actions?: Actions; }>): JSX.Element => { renderers.forEach((r) => { const mstVkeType = (r as any).mstVkeType; @@ -53,5 +58,5 @@ export const MstContextProvider = ({ registerMstViewDescrSchema(mstVdeType, true); } }); - return {children}; + return {children}; }; diff --git a/src/actions/baseActions.ts b/src/actions/baseActions.ts new file mode 100644 index 0000000..671e576 --- /dev/null +++ b/src/actions/baseActions.ts @@ -0,0 +1,19 @@ +import { ActionFunctionProps } from './types'; +import { getSnapshot, applySnapshot } from 'mobx-state-tree'; + +export const addObjects = (props: ActionFunctionProps) => {}; + +export const deleteObjects = (props: ActionFunctionProps) => {}; + +export const addConectionToTarget = ({ root, coll, selection, options }: ActionFunctionProps) => { + const target = options?.target; + if (target) { + const targetColl = root.getColl(target); + const targetData = targetColl?.data; + if (targetData) { + const snapData = getSnapshot(targetData) as any; + const newData = [...snapData, ...selection]; + applySnapshot(targetData, newData); + } + } +}; diff --git a/src/actions/constants.ts b/src/actions/constants.ts new file mode 100644 index 0000000..df067bb --- /dev/null +++ b/src/actions/constants.ts @@ -0,0 +1 @@ +export const NoTitleProvided = 'No title provided'; diff --git a/src/actions/index.ts b/src/actions/index.ts new file mode 100644 index 0000000..a07a6b8 --- /dev/null +++ b/src/actions/index.ts @@ -0,0 +1,10 @@ +import { addObjects, deleteObjects, addConectionToTarget } from './baseActions'; +import { Actions } from './types'; +export * from './types'; +export * from './utils'; + +export const actions: Actions = { + 'ldkg:addObjects': addObjects, + 'ldkg:deleteObjects': deleteObjects, + 'ldkg:addConectionToTarget': addConectionToTarget, +}; diff --git a/src/actions/types.ts b/src/actions/types.ts new file mode 100644 index 0000000..20bf107 --- /dev/null +++ b/src/actions/types.ts @@ -0,0 +1,8 @@ +export type ActionFunctionProps = { + root: any; + coll: unknown; + selection: unknown[]; + options?: { [key: string]: unknown }; +}; + +export type Actions = Partial<{ [key: string]: (args: ActionFunctionProps) => Promise | void }>; diff --git a/src/actions/utils.ts b/src/actions/utils.ts new file mode 100644 index 0000000..f2d831d --- /dev/null +++ b/src/actions/utils.ts @@ -0,0 +1,31 @@ +import { Actions } from './types'; +import { NoTitleProvided } from './constants'; + +type MapViewKindPropsToActionsProps = { + actions: Actions; + viewKindActionProps?: { '@id': string; '@type': string; title?: string; options: { [key: string]: unknown } }[]; + coll: unknown; + root: any; +}; + +type ReturnShape = { + title: string; + action: (selection: unknown[]) => Promise | void; +}; +export const mapViewKindPropsToActions = ({ + actions, + viewKindActionProps, + coll, + root, +}: MapViewKindPropsToActionsProps): ReturnShape[] | undefined => + viewKindActionProps && + viewKindActionProps.reduce((acc: ReturnShape[], props): ReturnShape[] => { + const actionType = props['@type']; + if (actionType in actions) { + acc.push({ + title: props.title || NoTitleProvided, + action: (selection: unknown[]) => actions[actionType]?.({ coll, options: props.options, selection, root }), + }); + } + return acc; + }, [] as ReturnShape[]); diff --git a/src/index.ts b/src/index.ts index 6a82809..d82e75a 100644 --- a/src/index.ts +++ b/src/index.ts @@ -9,6 +9,7 @@ ********************************************************************************/ export * from './antd-controls'; export * from './cells'; +export * from './actions'; export * from './controls'; export * from './data-controls'; diff --git a/src/table/BaseTableControl.tsx b/src/table/BaseTableControl.tsx index 15fd2ed..450e5d1 100644 --- a/src/table/BaseTableControl.tsx +++ b/src/table/BaseTableControl.tsx @@ -55,6 +55,7 @@ export const BaseTableControl: React.FC = React.memo( onSelect = () => {}, onDeleteRows, onSort, + actionsMap, loadExpandedData, addDataToTarget, sortDir, @@ -89,6 +90,7 @@ export const BaseTableControl: React.FC = React.memo( schema={schema} options={options} sortDir={sortDir} + actionsMap={actionsMap} target={options?.target?.name} addDataToTarget={addDataToTarget} limit={limit} diff --git a/src/table/basetable/BaseTableMenu.tsx b/src/table/basetable/BaseTableMenu.tsx index 2867a56..27a01a8 100644 --- a/src/table/basetable/BaseTableMenu.tsx +++ b/src/table/basetable/BaseTableMenu.tsx @@ -8,29 +8,21 @@ * SPDX-License-Identifier: GPL-3.0-only ********************************************************************************/ import React from 'react'; -import { Divider } from 'antd'; -import { PlusOutlined, DeleteTwoTone, LinkOutlined } from '@ant-design/icons'; -import { JsObject, JsStrObj } from '@agentlab/sparql-jsld-client'; +import { JsObject } from '@agentlab/sparql-jsld-client'; import './BaseTableMenu.css'; -import { tt } from '../ForDelete'; - interface BaseTablrMenu { record: JsObject; selection: any[]; - target?: string; - addDataToTarget: (data: any) => void; visible: boolean; x: number | string; y: number | string; - onCreateArtifactBefore: (o: any) => void; - onCreateArtifactAfter: (o: any) => void; - onDeleteArtifacts: (o: any) => void; - onLinkArtifacts: (o: JsObject | any[]) => void; + actionsMap?: { title: string; action: (selection: unknown[]) => Promise | void }[]; + onClick: () => void; } -const labelsRu: JsStrObj = { +/*const labelsRu: JsStrObj = { 'table.menu.createArtifactBefore': 'Создать перед', 'table.menu.createArtifactBefore0': 'Создать перед {{ count }}', 'table.menu.createArtifactBefore1': 'Создать перед {{ count }}', @@ -47,67 +39,23 @@ const labelsRu: JsStrObj = { 'table.menu.linkArtifacts0': 'Слинковать {{ count }}', 'table.menu.linkArtifacts1': 'Слинковать {{ count }}', 'table.menu.linkArtifacts2': 'Слинковать {{ count }}', -}; +};*/ -export const BaseTableMenu: React.FC = ({ - record, - selection, - visible, - x, - y, - target, - addDataToTarget, - onCreateArtifactBefore, - onCreateArtifactAfter, - onDeleteArtifacts, - onLinkArtifacts, -}) => { - const t = (id: string, o?: JsObject) => tt(labelsRu, id, o); - if (visible) { - return ( +export const BaseTableMenu: React.FC = ({ record, selection, visible, x, y, actionsMap, onClick }) => { + return ( + (actionsMap && visible && (
    -
  • (selection.length === 0 ? onCreateArtifactBefore(record) : onCreateArtifactBefore(selection))}> - - {selection.length === 0 - ? t('table.menu.createArtifactBefore') - : t('table.menu.createArtifactBefore', { count: selection.length })} -
  • -
  • (selection.length === 0 ? onCreateArtifactAfter(record) : onCreateArtifactAfter(selection))}> - - {selection.length === 0 - ? t('table.menu.createArtifactAfter') - : t('table.menu.createArtifactAfter', { count: selection.length })} -
  • - -
  • - selection.length === 0 ? onDeleteArtifacts([record.identifier]) : onDeleteArtifacts(selection) - }> - - {selection.length === 0 - ? t('table.menu.deleteArtifacts') - : t('table.menu.deleteArtifacts', { count: selection.length })} -
  • - -
  • (selection.length === 0 ? onLinkArtifacts(record) : onLinkArtifacts(selection))}> - - {selection.length === 0 - ? t('table.menu.linkArtifacts') - : t('table.menu.linkArtifacts', { count: selection.length })} -
  • - {selection.length !== 0 && target ? ( - - -
  • addDataToTarget(selection)}> - - {`Добавить в ${target}`} -
  • -
    - ) : null} + {actionsMap.map(({ title, action }) => ( +
  • { + action(selection); + onClick(); + }}> + {title} +
  • + ))}
- ); - } else { - return null; - } + )) || + null + ); }; diff --git a/src/table/basetable/ReactBaseTable.tsx b/src/table/basetable/ReactBaseTable.tsx index 33ec52b..f00fcd2 100644 --- a/src/table/basetable/ReactBaseTable.tsx +++ b/src/table/basetable/ReactBaseTable.tsx @@ -99,6 +99,7 @@ export const EditableTable: React.FC> = React.memo( loadExpandedData, isMenu, sortDir, + actionsMap, schema, onDeleteRows, target, @@ -395,14 +396,8 @@ export const EditableTable: React.FC> = React.memo( record={popupRecord} selection={selection} visible={popupVisible} - onCreateArtifactBefore={() => {}} - target={target} - addDataToTarget={onAddDataToTarget} - onCreateArtifactAfter={() => {}} - onDeleteArtifacts={() => { - onDeleteRows(selection); - }} - onLinkArtifacts={() => {}} + actionsMap={actionsMap} + onClick={() => setSelection([])} />
); diff --git a/src/util/ContextToProps.tsx b/src/util/ContextToProps.tsx index ef5e187..e07ac6f 100644 --- a/src/util/ContextToProps.tsx +++ b/src/util/ContextToProps.tsx @@ -9,7 +9,7 @@ ********************************************************************************/ import { cloneDeep, get, isArray, isEqual, omit } from 'lodash-es'; -import React, { useContext, useEffect, useState } from 'react'; +import React, { useContext, useEffect, useState, useCallback, useMemo } from 'react'; import { Spin } from 'antd'; import { getSnapshot, applySnapshot } from 'mobx-state-tree'; import { observer } from 'mobx-react-lite'; @@ -22,6 +22,7 @@ import { compareByIri, ControlComponent, processViewKindOverride, RenderProps } import { validators } from '../validation'; import { MstContext } from '../MstContext'; import { FilterType } from '../controls/query/type'; +import { mapViewKindPropsToActions } from '../actions'; declare type Property = 'editable' | 'visible'; declare type JsObject = { [key: string]: any }; @@ -409,7 +410,7 @@ const ComponentCachingSubRenderer = (props: any) => { export const withStoreToArrayProps = (Component: React.FC): React.FC => observer(({ ...props }: any) => { - const { viewKind, viewDescr, schema } = props; + const { viewKind, viewDescr, schema, actions } = props; const { store } = useContext(MstContext); //if (viewKindElement.resultsScope && !store.saveLogicTree[viewKindElement.resultsScope]) { // store.setSaveLogic(viewKindElement.resultsScope); @@ -419,7 +420,7 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = props, store, ); - const options = viewKindElement.options || {}; + const options = useMemo(() => viewKindElement.options || {}, [viewKindElement]); let targetIri = options?.target?.iri; let targetData: any = null; if (targetIri) { @@ -435,6 +436,11 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = const coll = store.getColl(collIriOverride); let dataIsLoading = false; + const actionsMap = useMemo( + () => mapViewKindPropsToActions({ actions, viewKindActionProps: options.selectActions, coll, root: store }), + [coll, actions, options], + ); + let data: any[] = []; if (!coll.isLoading) { data = coll?.data; @@ -466,7 +472,6 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = } }; const onSelect = (data: any) => { - console.log('onChange', data); if (data && isArray(data)) { if (data.length === 1) { store.setSelectedData(collIriOverride, data[0]); @@ -493,6 +498,7 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = addDataToTarget={addDataToTarget} schema={schema} loadExpandedData={loadExpandedData} + actionsMap={actionsMap} sortDir={{} /*store.queries[scope].orderBy*/} uri={id} onDeleteRows={onDeleteRows} diff --git a/stories/TableRemoteMktp.stories.tsx b/stories/TableRemoteMktp.stories.tsx index 027897f..fde3ec3 100644 --- a/stories/TableRemoteMktp.stories.tsx +++ b/stories/TableRemoteMktp.stories.tsx @@ -80,7 +80,7 @@ const viewKinds = [ }, ], //orderBy: [{ expression: variable('identifier0'), descending: false }], - //limit: 50, + limit: 10, }, ], elements: [ diff --git a/stories/TwoTables.stories.tsx b/stories/TwoTables.stories.tsx index 848bd79..9f73fb6 100644 --- a/stories/TwoTables.stories.tsx +++ b/stories/TwoTables.stories.tsx @@ -27,6 +27,7 @@ import { RendererRegistryEntry, viewKindCollConstr, viewDescrCollConstr, + actions, } from '../src'; import { tableRenderers } from '../src'; @@ -54,7 +55,7 @@ const Template: Story = (args: any) => { return (
- +
@@ -215,6 +216,26 @@ const viewKinds = [ }, multiSelect: true, draggable: true, + selectActions: [ + { + '@id': 'action1', + '@type': 'ldkg:addObjects', + title: 'Добавить объекты', + }, + { + '@id': 'action2', + '@type': 'ldkg:deleteObjects', + title: 'Удалить объекты', + }, + { + '@id': 'action3', + '@type': 'ldkg:addConectionToTarget', + title: 'Добавить в правую таблицу', + options: { + target: 'mktp:ProductCards_in_Product_Coll', + }, + }, + ], resizeableHeader: true, style: { height: '100%' }, order: [ @@ -410,6 +431,18 @@ const viewKinds = [ '@type': 'aldkg:Array', resultsScope: 'mktp:ProductCards_in_Product_Coll', options: { + selectActions: [ + { + '@id': 'action1', + '@type': 'ldkg:addObjects', + title: 'Добавить объекты', + }, + { + '@id': 'action2', + '@type': 'ldkg:deleteObjects', + title: 'Удалить объекты', + }, + ], draggable: true, resizeableHeader: true, style: { height: '100%' }, From 5f1d36658f9e64b66a346cf67caf12076f6d9b31 Mon Sep 17 00:00:00 2001 From: Artkrygin <80037398+Artkrygin@users.noreply.github.com> Date: Thu, 11 Nov 2021 03:10:53 +0300 Subject: [PATCH 5/8] [ADD] Test tree actions --- src/actions/baseActions.ts | 17 +++++- src/actions/index.ts | 3 +- src/actions/types.ts | 2 +- src/components/ContextMenu/ContextMenu.tsx | 42 +++++++++++++ src/components/ContextMenu/index.css | 70 ++++++++++++++++++++++ src/components/ContextMenu/index.ts | 1 + src/components/index.ts | 1 + src/data-controls/DataControl.tsx | 2 + src/data-controls/TreeRenderer.tsx | 34 ++++++----- src/util/ContextToProps.tsx | 17 ++++-- stories/TwoTablesBig.stories.tsx | 41 +++++++++++-- 11 files changed, 201 insertions(+), 29 deletions(-) create mode 100644 src/components/ContextMenu/ContextMenu.tsx create mode 100644 src/components/ContextMenu/index.css create mode 100644 src/components/ContextMenu/index.ts create mode 100644 src/components/index.ts diff --git a/src/actions/baseActions.ts b/src/actions/baseActions.ts index 671e576..108433c 100644 --- a/src/actions/baseActions.ts +++ b/src/actions/baseActions.ts @@ -1,9 +1,22 @@ import { ActionFunctionProps } from './types'; import { getSnapshot, applySnapshot } from 'mobx-state-tree'; -export const addObjects = (props: ActionFunctionProps) => {}; +export const addObjects = ({ root, coll, selection, options }: ActionFunctionProps) => { + console.log('SELECTION', selection); + //coll.testOnAddObjs([selection]); +}; -export const deleteObjects = (props: ActionFunctionProps) => {}; +export const addTreeObj = ({ root, coll, selection, options }: ActionFunctionProps) => { + const node = selection[0] as any; + const newObj = { + [node.titlePropName]: 'New node', + [node.parentKey]: node['@id'], + }; + return coll.testOnAddObjs([newObj]); +}; +export const deleteObjects = ({ root, coll, selection, options }: ActionFunctionProps) => { + coll.testOnDeleteObjs(selection.map((obj: any) => obj['@id'])); +}; export const addConectionToTarget = ({ root, coll, selection, options }: ActionFunctionProps) => { const target = options?.target; diff --git a/src/actions/index.ts b/src/actions/index.ts index a07a6b8..645fb44 100644 --- a/src/actions/index.ts +++ b/src/actions/index.ts @@ -1,4 +1,4 @@ -import { addObjects, deleteObjects, addConectionToTarget } from './baseActions'; +import { addObjects, deleteObjects, addConectionToTarget, addTreeObj } from './baseActions'; import { Actions } from './types'; export * from './types'; export * from './utils'; @@ -7,4 +7,5 @@ export const actions: Actions = { 'ldkg:addObjects': addObjects, 'ldkg:deleteObjects': deleteObjects, 'ldkg:addConectionToTarget': addConectionToTarget, + 'ldkg:addTreeObj': addTreeObj, }; diff --git a/src/actions/types.ts b/src/actions/types.ts index 20bf107..65b30cd 100644 --- a/src/actions/types.ts +++ b/src/actions/types.ts @@ -1,6 +1,6 @@ export type ActionFunctionProps = { root: any; - coll: unknown; + coll: any; selection: unknown[]; options?: { [key: string]: unknown }; }; diff --git a/src/components/ContextMenu/ContextMenu.tsx b/src/components/ContextMenu/ContextMenu.tsx new file mode 100644 index 0000000..81dad2c --- /dev/null +++ b/src/components/ContextMenu/ContextMenu.tsx @@ -0,0 +1,42 @@ +/******************************************************************************** + * Copyright (c) 2021 Agentlab and others. + * + * This program and the accompanying materials are made available under the + * terms of the GNU General Public License v. 3.0 which is available at + * https://www.gnu.org/licenses/gpl-3.0.html. + * + * SPDX-License-Identifier: GPL-3.0-only + ********************************************************************************/ +import React from 'react'; +import { JsObject } from '@agentlab/sparql-jsld-client'; + +import './index.css'; + +interface ContextMenuProps { + record: JsObject; + selection: any[]; + visible: boolean; + x: number | string; + y: number | string; + actionsMap?: { title: string; action: (selection: unknown[]) => Promise | void }[]; + onClick: () => void; +} + +export const ContextMenu: React.FC = ({ record, selection, visible, x, y, actionsMap, onClick }) => { + return ( + (actionsMap && visible && ( +
    + {actionsMap.map(({ title, action }) => ( +
  • { + action(selection); + onClick(); + }}> + {title} +
  • + ))} +
+ )) || + null + ); +}; diff --git a/src/components/ContextMenu/index.css b/src/components/ContextMenu/index.css new file mode 100644 index 0000000..eabc5bf --- /dev/null +++ b/src/components/ContextMenu/index.css @@ -0,0 +1,70 @@ +/******************************************************************************** + * Copyright (c) 2021 Agentlab and others. + * + * This program and the accompanying materials are made available under the + * terms of the GNU General Public License v. 3.0 which is available at + * https://www.gnu.org/licenses/gpl-3.0.html. + * + * SPDX-License-Identifier: GPL-3.0-only + ********************************************************************************/ +@keyframes fadeIn { + 0% { + transform: translateY(-25%); + } + 50% { + transform: translateY(4%); + } + 65% { + transform: translateY(-2%); + } + 80% { + transform: translateY(2%); + } + 95% { + transform: translateY(-1%); + } + 100% { + transform: translateY(0%); + } +} + +.popup { + animation-name: fadeIn; + animation-duration: 0.4s; + background-clip: padding-box; + background-color: #fff; + border-radius: 4px; + box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15); + left: 0px; + list-style-type: none; + margin: 0; + outline: none; + padding: 0; + position: absolute; + text-align: left; + top: 0px; + overflow: hidden; + -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15); +} + +.popup li { + clear: both; + color: rgba(0, 0, 0, 0.65); + cursor: pointer; + font-size: 14px; + font-weight: normal; + line-height: 22px; + margin: 0; + padding: 5px 12px; + transition: all 0.3s; + white-space: nowrap; + -webkit-transition: all 0.3s; +} + +.popup li:hover { + background-color: #e6f7ff; +} + +.popup li > i { + margin-right: 8px; +} diff --git a/src/components/ContextMenu/index.ts b/src/components/ContextMenu/index.ts new file mode 100644 index 0000000..0839b04 --- /dev/null +++ b/src/components/ContextMenu/index.ts @@ -0,0 +1 @@ +export * from './ContextMenu'; diff --git a/src/components/index.ts b/src/components/index.ts new file mode 100644 index 0000000..0839b04 --- /dev/null +++ b/src/components/index.ts @@ -0,0 +1 @@ +export * from './ContextMenu'; diff --git a/src/data-controls/DataControl.tsx b/src/data-controls/DataControl.tsx index 23dea64..300a9b7 100644 --- a/src/data-controls/DataControl.tsx +++ b/src/data-controls/DataControl.tsx @@ -40,6 +40,7 @@ export const AntdDataLayout: React.FC = React.memo( onCreateFolder, onDeleteFolder, onRename, + actionsMap, } = props; const data = treeify(dataSource, '@id', viewKindElement?.options.treeNodeParentKey || 'parent', 'children', strcmp); const onSelect = (selected: { [key: string]: any }) => { @@ -55,6 +56,7 @@ export const AntdDataLayout: React.FC = React.memo( child={data} editing={editing} onDnD={onDnD} + actionsMap={actionsMap} viewKind={viewKind} viewKindElement={viewKindElement} viewDescr={viewDescr} diff --git a/src/data-controls/TreeRenderer.tsx b/src/data-controls/TreeRenderer.tsx index fa4499d..0ecfd70 100644 --- a/src/data-controls/TreeRenderer.tsx +++ b/src/data-controls/TreeRenderer.tsx @@ -14,6 +14,7 @@ import { Tree, Input } from 'antd'; import { SaveReqDialoglWithStore } from '../util/OnSaveDialog'; import { NodeRenderer } from './NodeRenderer'; import { TreeContextMenu } from './TreeContextMenu'; +import { ContextMenu } from '../components'; import './styles.css'; @@ -36,6 +37,7 @@ export const TreeRenderer: React.FC = (props) => { onCreateFolder, onDeleteFolder, onRename, + actionsMap, } = props; const [visible, setVisible] = useState(false); const [selected, setSelected] = useState(child[0]); @@ -239,17 +241,7 @@ export const TreeRenderer: React.FC = (props) => { }; const onCreateDirectory = (parentId: string) => { - onCreateFolder({ [titlePropName]: 'new', [viewKindElement?.options.treeNodeParentKey || 'parent']: parentId }).then( - (e: any) => { - const data = [...treeData]; - loop(data, parentId, (item: any) => { - const newNode = { ...e, ...{ edited: true, '@type': 'nav:folder', key: e['@id'] } }; - item.children = [...item.children, ...[newNode]]; - //item.children.unshift(newNode); - }); - setTreeData(data); - }, - ); + onCreateFolder({ [titlePropName]: 'new', [viewKindElement?.options.treeNodeParentKey || 'parent']: parentId }); }; const onDeleteDirectory = (id: string) => { onDeleteFolder(id).then((e: any) => { @@ -289,14 +281,24 @@ export const TreeRenderer: React.FC = (props) => { schemaUri={viewKindElement.resultsScope} onCancel={() => setVisible(false)} /> - null} />
); diff --git a/src/util/ContextToProps.tsx b/src/util/ContextToProps.tsx index e07ac6f..6a23431 100644 --- a/src/util/ContextToProps.tsx +++ b/src/util/ContextToProps.tsx @@ -243,7 +243,7 @@ export const withStoreToCellProps = (Component: React.FC): React.FC => export const withStoreToDataControlProps = (Component: React.FC): React.FC => observer(({ ...props }: any) => { - const { viewKind, viewDescr } = props; + const { viewKind, viewDescr, actions } = props; const { store } = useContext(MstContext); const [id, collIri, collIriOverride, inCollPath, viewKindElement, viewDescrElement] = processViewKindOverride( props, @@ -273,21 +273,30 @@ export const withStoreToDataControlProps = (Component: React.FC): React.FC< const onDnD = ({ childId, parentId }: any) => { store.updateObjectData({ parent: parentId }, collIriOverride, childId); }; + + const actionsMap = useMemo( + () => mapViewKindPropsToActions({ actions, viewKindActionProps: options.selectActions, coll, root: store }), + [coll, actions, options], + ); + const onCreateFolder = (data: any) => { - return store.onCreateObject(data, collIriOverride); + return coll.testOnAddObjs([data]); }; const onDeleteFolder = (id: any) => { if (id) { - return store.onDeleteObject(id, collIriOverride); + return coll.testOnDeleteObjs([id]); } }; + const onRename = (newTitle: string, id: any) => { - store.updateObjectData({ title: newTitle }, collIriOverride, id); + coll.testOnUpdateObj(id, { title: newTitle }); }; + return ( = (args) => { return (
- + @@ -204,6 +205,18 @@ const viewKinds = [ '@type': 'aldkg:DataControl', resultsScope: 'mktp:Categories_Coll', options: { + selectActions: [ + { + '@id': 'action1', + '@type': 'ldkg:addTreeObj', + title: 'Добавить папку', + }, + { + '@id': 'action2', + '@type': 'ldkg:deleteObjects', + title: 'Удалить папку', + }, + ], renderType: 'tree', title: 'Категории маркетплейса', treeNodeTitleKey: 'name', @@ -216,10 +229,16 @@ const viewKinds = [ '@type': 'aldkg:Array', resultsScope: 'mktp:ProductCards_in_Category_Coll', options: { - target: { - name: 'правую таблицу', - iri: 'mktp:ProductCards_in_Product_Coll', - }, + selectActions: [ + { + '@id': 'action3', + '@type': 'ldkg:addConectionToTarget', + title: 'Добавить в правую таблицу', + options: { + target: 'mktp:ProductCards_in_Product_Coll', + }, + }, + ], draggable: true, resizeableHeader: true, style: { height: '100%' }, @@ -584,6 +603,18 @@ const viewKinds = [ '@type': 'aldkg:DataControl', resultsScope: 'mktp:Products_Coll', options: { + selectActions: [ + { + '@id': 'action1', + '@type': 'ldkg:addTreeObj', + title: 'Добавить папку', + }, + { + '@id': 'action2', + '@type': 'ldkg:deleteObjects', + title: 'Удалить папку', + }, + ], renderType: 'tree', title: 'Продукты', treeNodeTitleKey: 'title', From dcbb75157ba7a658f4926df2bb9f300f85647ade Mon Sep 17 00:00:00 2001 From: Alexey Ivanov Date: Wed, 17 Nov 2021 20:58:04 +0300 Subject: [PATCH 6/8] [refactor] Delete workaround for imageUrl --- stories/TreeTableFormMktp.stories.tsx | 307 -------------------------- stories/TwoTablesBig.stories.tsx | 2 +- 2 files changed, 1 insertion(+), 308 deletions(-) diff --git a/stories/TreeTableFormMktp.stories.tsx b/stories/TreeTableFormMktp.stories.tsx index 90c2e78..a15eabd 100644 --- a/stories/TreeTableFormMktp.stories.tsx +++ b/stories/TreeTableFormMktp.stories.tsx @@ -60,313 +60,6 @@ const Template: Story = (args: any) => { 'https://rdf4j.agentlab.ru/rdf4j-server', 'https://rdf4j.agentlab.ru/rdf4j-server/repositories/mktp-schema/namespaces', ); - //TODO: Workaround for imageUrl - const ProductCardShapeSchema = { - '@id': 'hs:ProductCardShape', - '@type': 'sh:NodeShape', - '@context': { - '@type': 'rdf:type', - brand: { - '@id': 'hs:brand', - '@type': 'hs:Brand', - }, - seller: { - '@id': 'hs:seller', - '@type': 'hs:Seller', - }, - firstParsedAt: { - '@id': 'hs:firstParsedAt', - '@type': 'xsd:dateTime', - }, - lastMonthParsedAt: { - '@id': 'hs:lastMonthParsedAt', - '@type': 'xsd:dateTime', - }, - parsedAt: { - '@id': 'hs:parsedAt', - '@type': 'xsd:dateTime', - }, - prevParsedAt: { - '@id': 'hs:prevParsedAt', - '@type': 'xsd:dateTime', - }, - categoryPopularity: { - '@id': 'hs:categoryPopularity', - '@type': 'xsd:double', - }, - commentsCount: { - '@id': 'hs:commentsCount', - '@type': 'xsd:int', - }, - lastMonthSalesAmount: { - '@id': 'hs:lastMonthSalesAmount', - '@type': 'xsd:int', - }, - lastMonthSalesValue: { - '@id': 'hs:lastMonthSalesValue', - '@type': 'xsd:int', - }, - perMonthSalesValue: { - '@id': 'hs:perMonthSalesValue', - '@type': 'xsd:int', - }, - photosCount: { - '@id': 'hs:photosCount', - '@type': 'xsd:int', - }, - prevMonthSalesAmount: { - '@id': 'hs:prevMonthSalesAmount', - '@type': 'xsd:int', - }, - prevMonthSalesValue: { - '@id': 'hs:prevMonthSalesValue', - '@type': 'xsd:int', - }, - price: { - '@id': 'hs:price', - '@type': 'xsd:int', - }, - questionsCount: { - '@id': 'hs:questionsCount', - '@type': 'xsd:int', - }, - saleValue: { - '@id': 'hs:saleValue', - '@type': 'xsd:int', - }, - salesAmountDiff: { - '@id': 'hs:salesAmountDiff', - '@type': 'xsd:int', - }, - starsValue: { - '@id': 'hs:starsValue', - '@type': 'xsd:int', - }, - stocksDiffOrders: { - '@id': 'hs:stocksDiffOrders', - '@type': 'xsd:int', - }, - stocksDiffReturns: { - '@id': 'hs:stocksDiffReturns', - '@type': 'xsd:int', - }, - stocks: { - '@id': 'hs:stocks', - '@type': 'xsd:int', - }, - totalSalesDiff: { - '@id': 'hs:totalSalesDiff', - '@type': 'xsd:int', - }, - totalSales: { - '@id': 'hs:totalSales', - '@type': 'xsd:int', - }, - rootId: { - '@id': 'hs:rootId', - '@type': 'xsd:long', - }, - country: { - '@id': 'hs:country', - '@type': 'xsd:string', - }, - name: { - '@id': 'hs:name', - '@type': 'xsd:string', - }, - CardInCatLink: { - '@id': 'hs:CardInCatLink', - '@type': 'hs:CategoryShape', - }, - CardInProdLink: { - '@id': 'mktp:CardInProdLink', - '@type': 'mktp:Product', - }, - //imageUrl: { - // '@id': 'hs:imageUrl', - // '@type': '@id', - //}, - identifier: { - '@id': 'hs:identifier', - '@type': '@id', - }, - }, - targetClass: 'hs:ProductCard', - $schema: 'http://json-schema.org/draft-07/schema#', - type: 'object', - title: 'Карточка товара', - properties: { - '@id': { - title: 'URI', - type: 'string', - format: 'iri', - }, - '@type': { - title: 'Тип', - type: 'string', - format: 'iri', - }, - brand: { - title: 'Бренд', - type: 'string', - format: 'iri', - }, - seller: { - title: 'Продавец', - type: 'string', - format: 'iri', - }, - firstParsedAt: { - title: 'Первый раз распарсено', - type: 'string', - format: 'date-time', - }, - lastMonthParsedAt: { - title: 'Распарсено в последнем месяце', - type: 'string', - format: 'date-time', - }, - parsedAt: { - title: 'Распарсено', - type: 'string', - format: 'date-time', - }, - prevParsedAt: { - title: 'Предыдущий парсинг', - type: 'string', - format: 'date-time', - }, - categoryPopularity: { - title: 'Популярность категории', - type: 'number', - }, - commentsCount: { - title: 'Кол-во комментариев', - type: 'integer', - }, - lastMonthSalesAmount: { - title: 'Продажи за последний месяц', - type: 'integer', - }, - lastMonthSalesValue: { - title: 'Выручка за последний месяц', - type: 'integer', - }, - perMonthSalesValue: { - title: 'Средняя выручка за месяц', - type: 'integer', - }, - photosCount: { - title: 'Кол-во фото', - type: 'integer', - }, - prevMonthSalesAmount: { - title: 'Средние продажи за прошлый месяц', - type: 'integer', - }, - prevMonthSalesValue: { - title: 'Средняя выручка за прошлый месяц', - type: 'integer', - }, - price: { - title: 'Цена', - type: 'integer', - }, - questionsCount: { - title: 'Кол-во вопросов', - type: 'integer', - }, - saleValue: { - title: 'Размер скидки', - type: 'integer', - }, - salesAmountDiff: { - title: 'Выручка, руб/день', - type: 'integer', - }, - starsValue: { - title: 'Кол-во звезд', - type: 'integer', - }, - stocksDiffOrders: { - title: 'Заказы в шт (изменение)', - type: 'integer', - }, - stocksDiffReturns: { - title: 'Поступления-Возвраты в шт (изменение)', - type: 'integer', - }, - stocks: { - title: 'Остатки в шт', - type: 'integer', - }, - totalSalesDiff: { - title: 'Объем продаж, шт/день', - type: 'integer', - }, - totalSales: { - title: 'Общий объем продаж, шт', - type: 'integer', - }, - rootId: { - title: 'Корневой ИД', - type: 'integer', - }, - country: { - title: 'Страна', - type: 'string', - }, - name: { - title: 'Название', - type: 'string', - }, - CardInCatLink: { - title: 'Родительские категории карточки', - type: 'string', - format: 'iri', - }, - CardInProdLink: { - title: 'Продуктовая разметка карточки', - type: 'string', - format: 'iri', - }, - //imageUrl: { - // title: 'Изображение товара', - // type: 'string', - // format: 'iri', - //}, - identifier: { - title: 'ИД HunterSales', - type: 'string', - format: 'iri', - }, - }, - required: [ - '@id', - '@type', - 'brand', - 'seller', - 'firstParsedAt', - 'lastMonthParsedAt', - 'parsedAt', - 'prevParsedAt', - 'commentsCount', - 'lastMonthSalesAmount', - 'lastMonthSalesValue', - 'perMonthSalesValue', - 'photosCount', - 'prevMonthSalesAmount', - 'prevMonthSalesValue', - 'starsValue', - 'totalSales', - 'rootId', - 'country', - 'name', - ], - }; - rootModelInitialState.schemas.json[ProductCardShapeSchema['@id']] = ProductCardShapeSchema; - rootModelInitialState.schemas.class2schema[ProductCardShapeSchema.targetClass] = ProductCardShapeSchema['@id']; - //End Workaround for imageUrl const rootStore = createUiModelFromState('mktp-fed', client, rootModelInitialState, args.additionalColls); const store: any = asReduxStore(rootStore); // eslint-disable-next-line @typescript-eslint/no-var-requires diff --git a/stories/TwoTablesBig.stories.tsx b/stories/TwoTablesBig.stories.tsx index 372a8f4..640434b 100644 --- a/stories/TwoTablesBig.stories.tsx +++ b/stories/TwoTablesBig.stories.tsx @@ -115,9 +115,9 @@ const viewKinds = [ CardInCatLink: 'https://muying.1688.com/wanju', }, service: mktpSchemaRepoIri, + limit: 30, }, ], - limit: 30, }, //// Mktp Products { From 3ee318fa6bafcf8fe2b38174b326fc29cdf6d0de Mon Sep 17 00:00:00 2001 From: Alexey Ivanov Date: Wed, 17 Nov 2021 20:59:05 +0300 Subject: [PATCH 7/8] Hack for array schemas, disable loadMore --- src/DispatchCell.tsx | 1 + src/util/ContextToProps.tsx | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/DispatchCell.tsx b/src/DispatchCell.tsx index 3124bb0..49950ff 100644 --- a/src/DispatchCell.tsx +++ b/src/DispatchCell.tsx @@ -36,6 +36,7 @@ export const DispatchCell: React.FC = React.memo( ...rest }) => { const { cells } = useContext(MstContext); + if (schema && schema.items) schema = { ...schema, ...schema.items }; const renderer = maxBy(cells, (r) => r.tester(viewKindElement, schema)); if (renderer === undefined || renderer.tester(viewKindElement, schema) === -1) { return ( diff --git a/src/util/ContextToProps.tsx b/src/util/ContextToProps.tsx index 6a23431..1b3fc0a 100644 --- a/src/util/ContextToProps.tsx +++ b/src/util/ContextToProps.tsx @@ -463,7 +463,7 @@ export const withStoreToArrayProps = (Component: React.FC): React.FC = } const loadMoreData = async () => { - coll.loadMore(); + //coll.loadMore(); }; const withConnections = options.connections; From 54a84633a8f42971fd98a20ee5325c2d7546d3dd Mon Sep 17 00:00:00 2001 From: Alexey Ivanov Date: Wed, 17 Nov 2021 21:17:42 +0300 Subject: [PATCH 8/8] [deps] Update client, mobx, mst, router, dev --- .prettierrc.js | 2 +- package.json | 54 ++-- yarn.lock | 789 +++++++++++++++++++++++++++---------------------- 3 files changed, 461 insertions(+), 384 deletions(-) diff --git a/.prettierrc.js b/.prettierrc.js index 1026792..3c4d7c5 100644 --- a/.prettierrc.js +++ b/.prettierrc.js @@ -6,7 +6,7 @@ module.exports = { singleQuote: true, arrowParens: 'always', trailingComma: 'all', - jsxBracketSameLine: true, + bracketSameLine: true, jsxSingleQuote: true, endOfLine: 'lf', //quoteProps: 'consistent', diff --git a/package.json b/package.json index 603f1cd..e71d9e5 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@agentlab/ldkg-ui-react", - "version": "0.1.15", + "version": "0.1.16", "description": "LDKG Forms UI Components", "license": "GPL-3.0", "author": "Alexey Ivanov ", @@ -52,18 +52,18 @@ "lint-staged": "lint-staged" }, "peerDependencies": { - "@agentlab/sparql-jsld-client": ">=5.0.1", + "@agentlab/sparql-jsld-client": ">=5.0.3", "@ant-design/icons": ">=4.7.0", "@rdfjs/data-model": ">=1.3.4", "@tinymce/tinymce-react": ">=3.13.0", "antd": ">=4.16.13", "history": ">=5.1.0", "lodash-es": ">=4.17.21", - "mobx": ">=6.3.6", + "mobx": ">=6.3.7", "mobx-react-lite": ">=3.2.2", - "mobx-state-tree": ">=5.0.4", + "mobx-state-tree": ">=5.0.5", "moment": ">=2.29.1", - "rc-util": ">=5.14.0", + "rc-util": ">=5.15.0", "react": ">=17.0.2", "react-base-table": ">=1.13.0", "react-collapse-pane": ">=2.0.1", @@ -71,9 +71,9 @@ "react-dnd-html5-backend": ">=12.1.1", "react-dom": ">=17.0.2", "react-error-boundary": ">=3.1.4", - "react-horizontal-scrolling-menu": ">=2.5.1", - "react-router": ">=6.0.1", - "react-router-dom": ">=6.0.1", + "react-horizontal-scrolling-menu": ">=2.5.2", + "react-router": ">=6.0.2", + "react-router-dom": ">=6.0.2", "react-sortable-hoc": ">=2.0.0", "react-split-pane": ">=2.0.3", "react-virtualized": ">=9.22.3", @@ -83,20 +83,20 @@ "uuid62": ">=1.0.1" }, "dependencies": { - "@agentlab/sparql-jsld-client": "^5.0.1", + "@agentlab/sparql-jsld-client": "^5.0.3", "@ant-design/icons": "^4.7.0", "@tinymce/tinymce-react": "^3.13.0", - "@types/react": "^17.0.34", + "@types/react": "^17.0.35", "@types/react-dom": "^17.0.11", "@types/react-router": "^5.1.17", "@types/react-router-dom": "^5.3.2", - "@types/react-virtualized": "^9.21.14", + "@types/react-virtualized": "^9.21.15", "@types/styled-components": "^5.1.15", "@types/tinymce": "^4.6.4", "antd": "^4.16.13", "history": "^5.1.0", "mobx-react-lite": "^3.2.2", - "mst-middlewares": "^5.0.4", + "mst-middlewares": "^5.0.5", "react": "^17.0.2", "react-base-table": "^1.13.0", "react-collapse-pane": "^2.0.1", @@ -104,11 +104,11 @@ "react-dnd-html5-backend": "12.1.1", "react-dom": "^17.0.2", "react-error-boundary": "^3.1.4", - "react-horizontal-scrolling-menu": "^2.5.1", + "react-horizontal-scrolling-menu": "^2.5.2", "react-is": "^17.0.2", "react-redux": "^7.2.6", - "react-router": "^6.0.1", - "react-router-dom": "^6.0.1", + "react-router": "^6.0.2", + "react-router-dom": "^6.0.2", "react-sortable-hoc": "^2.0.0", "react-split-pane": "^2.0.3", "react-virtualized": "^9.22.3", @@ -135,34 +135,34 @@ "@testing-library/react": "^12.1.2", "@testing-library/user-event": "^13.5.0", "@types/jest": "^27.0.2", - "@typescript-eslint/eslint-plugin": "^5.3.0", - "@typescript-eslint/parser": "^5.3.0", + "@typescript-eslint/eslint-plugin": "^5.4.0", + "@typescript-eslint/parser": "^5.4.0", "autoprefixer": "^10.4.0", "babel-loader": "^8.2.3", "cross-env": "^7.0.3", - "cssnano": "^5.0.10", + "cssnano": "^5.0.11", "cypress": "^8.7.0", "cypress-storybook": "^0.5.1", - "eslint": "^7.32.0", + "eslint": "^8.2.0", "eslint-config-prettier": "^8.3.0", "eslint-config-react-app": "^6.0.0", "eslint-plugin-cypress": "^2.12.1", - "eslint-plugin-flowtype": "^6.1.1", - "eslint-plugin-import": "^2.25.2", + "eslint-plugin-flowtype": "^8.0.3", + "eslint-plugin-import": "^2.25.3", "eslint-plugin-jest": "^25.2.4", - "eslint-plugin-jsx-a11y": "^6.4.1", + "eslint-plugin-jsx-a11y": "^6.5.1", "eslint-plugin-prettier": "^4.0.0", - "eslint-plugin-react": "^7.26.1", - "eslint-plugin-react-hooks": "^4.2.0", + "eslint-plugin-react": "^7.27.0", + "eslint-plugin-react-hooks": "^4.3.0", "husky": "^7.0.4", "jest": "^27.3.1", "jest-watch-typeahead": "^1.0.0", - "lint-staged": "^11.2.6", + "lint-staged": "^12.0.2", "npm-run-all": "^4.1.5", "postcss": "^8.3.11", - "prettier": "2.3.2", + "prettier": "2.4.1", "rimraf": "^3.0.2", - "rollup": "^2.59.0", + "rollup": "^2.60.0", "rollup-plugin-babel": "^4.4.0", "rollup-plugin-peer-deps-external": "^2.2.4", "rollup-plugin-postcss": "^4.0.1", diff --git a/yarn.lock b/yarn.lock index cad935e..aee4196 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2,10 +2,10 @@ # yarn lockfile v1 -"@agentlab/sparql-jsld-client@^5.0.1": - version "5.0.1" - resolved "https://registry.yarnpkg.com/@agentlab/sparql-jsld-client/-/sparql-jsld-client-5.0.1.tgz#9a966ec5010a22dbe51d0c6d0fb4d09fa0f790f7" - integrity sha512-FDo3ZycWXzkPrwCPoHOAFHMjh/JZnH201KFf4BVFMYxaemAXPaSNVv86E0wComoYiS5AXv/0AAZmVuNXrZEODw== +"@agentlab/sparql-jsld-client@^5.0.3": + version "5.0.3" + resolved "https://registry.yarnpkg.com/@agentlab/sparql-jsld-client/-/sparql-jsld-client-5.0.3.tgz#89dffb7765930d9c7c43d6d913cfc964ca64c84c" + integrity sha512-TQ29BTiU4IRKqRtXCJ67nb1qNSPz8Xyg+JFgKAndGboCxlfJgQ+7M6XPCWeuW2hfnb1URSPgflNywK1kF+URWw== dependencies: "@rdfjs/data-model" "^1.3.4" "@types/json-schema" "^7.0.9" @@ -16,8 +16,8 @@ is-url "^1.2.4" jsonld "^5.2.0" lodash-es "^4.17.21" - mobx "^6.3.6" - mobx-state-tree "^5.0.4" + mobx "^6.3.7" + mobx-state-tree "^5.0.5" moment "^2.29.1" rdf-literal "^1.3.0" sparqljs "^3.5.1" @@ -81,13 +81,6 @@ dependencies: "@babel/highlight" "^7.10.4" -"@babel/code-frame@7.12.11": - version "7.12.11" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.12.11.tgz#f4ad435aa263db935b8f10f2c552d23fb716a63f" - integrity sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw== - dependencies: - "@babel/highlight" "^7.10.4" - "@babel/code-frame@^7.0.0", "@babel/code-frame@^7.10.4", "@babel/code-frame@^7.12.13", "@babel/code-frame@^7.14.5", "@babel/code-frame@^7.5.5", "@babel/code-frame@^7.8.3": version "7.14.5" resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.14.5.tgz#23b08d740e83f49c5e59945fbf1b43e80bbf4edb" @@ -1369,6 +1362,13 @@ dependencies: regenerator-runtime "^0.13.4" +"@babel/runtime@^7.16.3": + version "7.16.3" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.16.3.tgz#b86f0db02a04187a3c17caa77de69840165d42d5" + integrity sha512-WBwekcqacdY2e9AF/Q7WLFUWmdJGJTkbjqTjoMDgXkVZ3ZRUvOPsLb5KdwISoQVsbP+DQzVZW4Zhci0DvpbNTQ== + dependencies: + regenerator-runtime "^0.13.4" + "@babel/runtime@^7.2.0", "@babel/runtime@^7.4.4", "@babel/runtime@^7.8.3": version "7.15.4" resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.15.4.tgz#fd17d16bfdf878e6dd02d19753a39fa8a8d9c84a" @@ -1644,25 +1644,25 @@ resolved "https://registry.yarnpkg.com/@emotion/weak-memoize/-/weak-memoize-0.2.5.tgz#8eed982e2ee6f7f4e44c253e12962980791efd46" integrity sha512-6U71C2Wp7r5XtFtQzYrW5iKFT67OixrSxjI4MptCHzdSVlgabczzqLe0ZSgnub/5Kp4hSbpDB1tMytZY9pwxxA== -"@eslint/eslintrc@^0.4.3": - version "0.4.3" - resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.3.tgz#9e42981ef035beb3dd49add17acb96e8ff6f394c" - integrity sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw== +"@eslint/eslintrc@^1.0.4": + version "1.0.4" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-1.0.4.tgz#dfe0ff7ba270848d10c5add0715e04964c034b31" + integrity sha512-h8Vx6MdxwWI2WM8/zREHMoqdgLNXEL4QX3MWSVMdyNJGvXVOs+6lp+m2hc3FnuMHDc4poxFNI20vCk0OmI4G0Q== dependencies: ajv "^6.12.4" - debug "^4.1.1" - espree "^7.3.0" + debug "^4.3.2" + espree "^9.0.0" globals "^13.9.0" ignore "^4.0.6" import-fresh "^3.2.1" - js-yaml "^3.13.1" + js-yaml "^4.1.0" minimatch "^3.0.4" strip-json-comments "^3.1.1" -"@humanwhocodes/config-array@^0.5.0": - version "0.5.0" - resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.5.0.tgz#1407967d4c6eecd7388f83acf1eaf4d0c6e58ef9" - integrity sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg== +"@humanwhocodes/config-array@^0.6.0": + version "0.6.0" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.6.0.tgz#b5621fdb3b32309d2d16575456cbc277fa8f021a" + integrity sha512-JQlEKbcgEUjBFhLIF4iqM7u/9lwgHRBcpHrmUNCALK0Q3amXN6lxdoXLnF0sm11E9VqTmBALR87IlUg1bZ8A9A== dependencies: "@humanwhocodes/object-schema" "^1.2.0" debug "^4.1.1" @@ -3479,10 +3479,10 @@ dependencies: "@types/react" "*" -"@types/react-virtualized@^9.21.14": - version "9.21.14" - resolved "https://registry.yarnpkg.com/@types/react-virtualized/-/react-virtualized-9.21.14.tgz#8d465aa54386a7bebc7b61f71afc588bb800b868" - integrity sha512-wvZftXXYNpj3ELVm2v8pySnq/uxKD1UsFpRkNoBAbQFTnI4Bz4OcwjUhwvaqUq5dDoT6SCS2+PdCzysxMYfjdg== +"@types/react-virtualized@^9.21.15": + version "9.21.15" + resolved "https://registry.yarnpkg.com/@types/react-virtualized/-/react-virtualized-9.21.15.tgz#349a4f9774504e514ea4c8ebbbfe6cc8db17f045" + integrity sha512-R4ntUW+Y/a7RgRpfeYz3iRe+kaDWtXieMeQum4AoYjjZsR/QhpKqFu4muSBhzA7OHJHd6qA0KkeTzxj5ah5tmQ== dependencies: "@types/prop-types" "*" "@types/react" "*" @@ -3496,10 +3496,10 @@ "@types/scheduler" "*" csstype "^3.0.2" -"@types/react@^17.0.34": - version "17.0.34" - resolved "https://registry.yarnpkg.com/@types/react/-/react-17.0.34.tgz#797b66d359b692e3f19991b6b07e4b0c706c0102" - integrity sha512-46FEGrMjc2+8XhHXILr+3+/sTe3OfzSPU9YGKILLrUYbQ1CLQC9Daqo1KzENGXAWwrFwiY0l4ZbF20gRvgpWTg== +"@types/react@^17.0.35": + version "17.0.35" + resolved "https://registry.yarnpkg.com/@types/react/-/react-17.0.35.tgz#217164cf830267d56cd1aec09dcf25a541eedd4c" + integrity sha512-r3C8/TJuri/SLZiiwwxQoLAoavaczARfT9up9b4Jr65+ErAUX3MIkU0oMOQnrpfgHme8zIqZLX7O5nnjm5Wayw== dependencies: "@types/prop-types" "*" "@types/scheduler" "*" @@ -3636,13 +3636,13 @@ dependencies: "@types/node" "*" -"@typescript-eslint/eslint-plugin@^5.3.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.3.0.tgz#a55ae72d28ffeb6badd817fe4566c9cced1f5e29" - integrity sha512-ARUEJHJrq85aaiCqez7SANeahDsJTD3AEua34EoQN9pHS6S5Bq9emcIaGGySt/4X2zSi+vF5hAH52sEen7IO7g== +"@typescript-eslint/eslint-plugin@^5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.4.0.tgz#05e711a2e7b68342661fde61bccbd1531c19521a" + integrity sha512-9/yPSBlwzsetCsGEn9j24D8vGQgJkOTr4oMLas/w886ZtzKIs1iyoqFrwsX2fqYEeUwsdBpC21gcjRGo57u0eg== dependencies: - "@typescript-eslint/experimental-utils" "5.3.0" - "@typescript-eslint/scope-manager" "5.3.0" + "@typescript-eslint/experimental-utils" "5.4.0" + "@typescript-eslint/scope-manager" "5.4.0" debug "^4.3.2" functional-red-black-tree "^1.0.1" ignore "^5.1.8" @@ -3650,15 +3650,15 @@ semver "^7.3.5" tsutils "^3.21.0" -"@typescript-eslint/experimental-utils@5.3.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-5.3.0.tgz#ee56b4957547ed2b0fc7451205e41502e664f546" - integrity sha512-NFVxYTjKj69qB0FM+piah1x3G/63WB8vCBMnlnEHUsiLzXSTWb9FmFn36FD9Zb4APKBLY3xRArOGSMQkuzTF1w== +"@typescript-eslint/experimental-utils@5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-5.4.0.tgz#238a7418d2da3b24874ba35385eb21cc61d2a65e" + integrity sha512-Nz2JDIQUdmIGd6p33A+naQmwfkU5KVTLb/5lTk+tLVTDacZKoGQisj8UCxk7onJcrgjIvr8xWqkYI+DbI3TfXg== dependencies: "@types/json-schema" "^7.0.9" - "@typescript-eslint/scope-manager" "5.3.0" - "@typescript-eslint/types" "5.3.0" - "@typescript-eslint/typescript-estree" "5.3.0" + "@typescript-eslint/scope-manager" "5.4.0" + "@typescript-eslint/types" "5.4.0" + "@typescript-eslint/typescript-estree" "5.4.0" eslint-scope "^5.1.1" eslint-utils "^3.0.0" @@ -3674,14 +3674,14 @@ eslint-scope "^5.1.1" eslint-utils "^3.0.0" -"@typescript-eslint/parser@^5.3.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.3.0.tgz#7879f15e26d370ed3f653fb7dd06479531ed3ab9" - integrity sha512-rKu/yAReip7ovx8UwOAszJVO5MgBquo8WjIQcp1gx4pYQCwYzag+I5nVNHO4MqyMkAo0gWt2gWUi+36gWAVKcw== +"@typescript-eslint/parser@^5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.4.0.tgz#3aa83ce349d66e39b84151f6d5464928044ca9e3" + integrity sha512-JoB41EmxiYpaEsRwpZEYAJ9XQURPFer8hpkIW9GiaspVLX8oqbqNM8P4EP8HOZg96yaALiLEVWllA2E8vwsIKw== dependencies: - "@typescript-eslint/scope-manager" "5.3.0" - "@typescript-eslint/types" "5.3.0" - "@typescript-eslint/typescript-estree" "5.3.0" + "@typescript-eslint/scope-manager" "5.4.0" + "@typescript-eslint/types" "5.4.0" + "@typescript-eslint/typescript-estree" "5.4.0" debug "^4.3.2" "@typescript-eslint/scope-manager@5.0.0": @@ -3692,23 +3692,23 @@ "@typescript-eslint/types" "5.0.0" "@typescript-eslint/visitor-keys" "5.0.0" -"@typescript-eslint/scope-manager@5.3.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.3.0.tgz#97d0ccc7c9158e89e202d5e24ce6ba49052d432e" - integrity sha512-22Uic9oRlTsPppy5Tcwfj+QET5RWEnZ5414Prby465XxQrQFZ6nnm5KnXgnsAJefG4hEgMnaxTB3kNEyjdjj6A== +"@typescript-eslint/scope-manager@5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.4.0.tgz#aaab08415f4a9cf32b870c7750ae8ba4607126a1" + integrity sha512-pRxFjYwoi8R+n+sibjgF9iUiAELU9ihPBtHzocyW8v8D8G8KeQvXTsW7+CBYIyTYsmhtNk50QPGLE3vrvhM5KA== dependencies: - "@typescript-eslint/types" "5.3.0" - "@typescript-eslint/visitor-keys" "5.3.0" + "@typescript-eslint/types" "5.4.0" + "@typescript-eslint/visitor-keys" "5.4.0" "@typescript-eslint/types@5.0.0": version "5.0.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.0.0.tgz#25d93f6d269b2d25fdc51a0407eb81ccba60eb0f" integrity sha512-dU/pKBUpehdEqYuvkojmlv0FtHuZnLXFBn16zsDmlFF3LXkOpkAQ2vrKc3BidIIve9EMH2zfTlxqw9XM0fFN5w== -"@typescript-eslint/types@5.3.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.3.0.tgz#af29fd53867c2df0028c57c36a655bd7e9e05416" - integrity sha512-fce5pG41/w8O6ahQEhXmMV+xuh4+GayzqEogN24EK+vECA3I6pUwKuLi5QbXO721EMitpQne5VKXofPonYlAQg== +"@typescript-eslint/types@5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.4.0.tgz#b1c130f4b381b77bec19696c6e3366f9781ce8f2" + integrity sha512-GjXNpmn+n1LvnttarX+sPD6+S7giO+9LxDIGlRl4wK3a7qMWALOHYuVSZpPTfEIklYjaWuMtfKdeByx0AcaThA== "@typescript-eslint/typescript-estree@5.0.0": version "5.0.0" @@ -3723,13 +3723,13 @@ semver "^7.3.5" tsutils "^3.21.0" -"@typescript-eslint/typescript-estree@5.3.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.3.0.tgz#4f68ddd46dc2983182402d2ab21fb44ad94988cf" - integrity sha512-FJ0nqcaUOpn/6Z4Jwbtf+o0valjBLkqc3MWkMvrhA2TvzFXtcclIM8F4MBEmYa2kgcI8EZeSAzwoSrIC8JYkug== +"@typescript-eslint/typescript-estree@5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.4.0.tgz#fe524fb308973c68ebeb7428f3b64499a6ba5fc0" + integrity sha512-nhlNoBdhKuwiLMx6GrybPT3SFILm5Gij2YBdPEPFlYNFAXUJWX6QRgvi/lwVoadaQEFsizohs6aFRMqsXI2ewA== dependencies: - "@typescript-eslint/types" "5.3.0" - "@typescript-eslint/visitor-keys" "5.3.0" + "@typescript-eslint/types" "5.4.0" + "@typescript-eslint/visitor-keys" "5.4.0" debug "^4.3.2" globby "^11.0.4" is-glob "^4.0.3" @@ -3744,12 +3744,12 @@ "@typescript-eslint/types" "5.0.0" eslint-visitor-keys "^3.0.0" -"@typescript-eslint/visitor-keys@5.3.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.3.0.tgz#a6258790f3b7b2547f70ed8d4a1e0c3499994523" - integrity sha512-oVIAfIQuq0x2TFDNLVavUn548WL+7hdhxYn+9j3YdJJXB7mH9dAmZNJsPDa7Jc+B9WGqoiex7GUDbyMxV0a/aw== +"@typescript-eslint/visitor-keys@5.4.0": + version "5.4.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.4.0.tgz#09bc28efd3621f292fe88c86eef3bf4893364c8c" + integrity sha512-PVbax7MeE7tdLfW5SA0fs8NGVVr+buMPrcj+CWYWPXsZCH8qZ1THufDzbXm1xrZ2b2PA1iENJ0sRq5fuUtvsJg== dependencies: - "@typescript-eslint/types" "5.3.0" + "@typescript-eslint/types" "5.4.0" eslint-visitor-keys "^3.0.0" "@webassemblyjs/ast@1.9.0": @@ -3950,7 +3950,7 @@ acorn@^6.4.1: resolved "https://registry.yarnpkg.com/acorn/-/acorn-6.4.2.tgz#35866fd710528e92de10cf06016498e47e39e1e6" integrity sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ== -acorn@^7.1.1, acorn@^7.4.0, acorn@^7.4.1: +acorn@^7.1.1, acorn@^7.4.1: version "7.4.1" resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== @@ -3960,6 +3960,11 @@ acorn@^8.2.4: resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.4.1.tgz#56c36251fc7cabc7096adc18f05afe814321a28c" integrity sha512-asabaBSkEKosYKMITunzX177CXxQ4Q8BSSzMTKD+FefUhipQC70gfW5SiUDhYQ3vk8G+81HqQk7Fv9OXwwn9KA== +acorn@^8.5.0: + version "8.5.0" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.5.0.tgz#4512ccb99b3698c752591e9bb4472e38ad43cee2" + integrity sha512-yXbYeFy+jUuYd3/CDcg2NkIYE991XYX/bje7LmjJigUciaeO1JR4XxXgCIV1/Zc/dRuFEyw1L0pbA+qynJkW5Q== + address@1.1.2, address@^1.0.1: version "1.1.2" resolved "https://registry.yarnpkg.com/address/-/address-1.1.2.tgz#bf1116c9c758c51b7a933d296b72c221ed9428b6" @@ -4023,16 +4028,6 @@ ajv@^6.1.0, ajv@^6.10.0, ajv@^6.10.2, ajv@^6.12.2, ajv@^6.12.3, ajv@^6.12.4, ajv json-schema-traverse "^0.4.1" uri-js "^4.2.2" -ajv@^8.0.1: - version "8.6.0" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.6.0.tgz#60cc45d9c46a477d80d92c48076d972c342e5720" - integrity sha512-cnUG4NSBiM4YFBxgZIj/In3/6KX+rQ2l2YPRVcvAMQGWEPKuXoPIhxzwqh31jA3IPbI4qEOp/5ILI4ynioXsGQ== - dependencies: - fast-deep-equal "^3.1.1" - json-schema-traverse "^1.0.0" - require-from-string "^2.0.2" - uri-js "^4.2.2" - alphanum-sort@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/alphanum-sort/-/alphanum-sort-1.0.2.tgz#97a1119649b211ad33691d9f9f486a8ec9fbe0a3" @@ -4116,6 +4111,11 @@ ansi-styles@^5.0.0: resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-5.2.0.tgz#07449690ad45777d1924ac2abb2fc8895dba836b" integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== +ansi-styles@^6.0.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-6.1.0.tgz#87313c102b8118abd57371afab34618bf7350ed3" + integrity sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ== + ansi-to-html@^0.6.11: version "0.6.15" resolved "https://registry.yarnpkg.com/ansi-to-html/-/ansi-to-html-0.6.15.tgz#ac6ad4798a00f6aa045535d7f6a9cb9294eebea7" @@ -4216,6 +4216,11 @@ argparse@^1.0.7: dependencies: sprintf-js "~1.0.2" +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + aria-query@^4.2.2: version "4.2.2" resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-4.2.2.tgz#0d2ca6c9aceb56b8977e9fed6aed7e15bbd2f83b" @@ -4244,7 +4249,7 @@ array-flatten@1.1.1: resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= -array-includes@^3.0.3, array-includes@^3.1.1, array-includes@^3.1.2, array-includes@^3.1.3: +array-includes@^3.0.3, array-includes@^3.1.2, array-includes@^3.1.3: version "3.1.3" resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.3.tgz#c7f619b382ad2afaf5326cddfdc0afc61af7690a" integrity sha512-gcem1KlBU7c9rB+Rq8/3PPKsK2kjqeEBa3bD5kkQo4nYlOHQCJqIJFqBXDEfwaRuYTT4E+FxA9xez7Gf/e3Q7A== @@ -4311,7 +4316,7 @@ array.prototype.flat@^1.2.5: define-properties "^1.1.3" es-abstract "^1.19.0" -array.prototype.flatmap@^1.2.1, array.prototype.flatmap@^1.2.4: +array.prototype.flatmap@^1.2.1: version "1.2.4" resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.2.4.tgz#94cfd47cc1556ec0747d97f7c7738c58122004c9" integrity sha512-r9Z0zYoxqHz60vvQbWEdXIEtCwHF0yxaWfno9qzXeNHvfyl3BZqygmGzb84dsubyaXLH4husF+NFgMSdpZhk2Q== @@ -4321,6 +4326,15 @@ array.prototype.flatmap@^1.2.1, array.prototype.flatmap@^1.2.4: es-abstract "^1.18.0-next.1" function-bind "^1.1.1" +array.prototype.flatmap@^1.2.5: + version "1.2.5" + resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.2.5.tgz#908dc82d8a406930fdf38598d51e7411d18d4446" + integrity sha512-08u6rVyi1Lj7oqWbS9nUxliETrtIROT4XGTA4D/LWGten6E3ocm7cy9SIrmNHOL5XVbVuckUp3X6Xyg8/zpvHA== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + es-abstract "^1.19.0" + array.prototype.map@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/array.prototype.map/-/array.prototype.map-1.0.3.tgz#1609623618d3d84134a37d4a220030c2bd18420b" @@ -4464,10 +4478,10 @@ aws4@^1.8.0: resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.11.0.tgz#d61f46d83b2519250e2784daf5b09479a8b41c59" integrity sha512-xh1Rl34h6Fi1DC2WWKfxUTVqRsNnr6LsKz2+hfwDxQJWmrx8+c7ylaqBMcHfl1U1r2dsifOvKX3LQuLNZ+XSvA== -axe-core@^4.0.2: - version "4.2.3" - resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-4.2.3.tgz#2a3afc332f0031b42f602f4a3de03c211ca98f72" - integrity sha512-pXnVMfJKSIWU2Ml4JHP7pZEPIrgBO1Fd3WGx+fPBsS+KRGhE4vxooD8XBGWbQOIVSZsVK7pUDBBkCicNu80yzQ== +axe-core@^4.3.5: + version "4.3.5" + resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-4.3.5.tgz#78d6911ba317a8262bfee292aeafcc1e04b49cc5" + integrity sha512-WKTW1+xAzhMS5dJsxWkliixlO/PqC4VhmO9T4juNYcaTg9jzWiJsou6m5pxWYGfigWbwzJWeFY6z47a+4neRXA== axios@^0.24.0: version "0.24.0" @@ -5402,7 +5416,15 @@ cli-table3@0.6.0, cli-table3@~0.6.0: optionalDependencies: colors "^1.1.2" -cli-truncate@2.1.0, cli-truncate@^2.1.0: +cli-truncate@3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-3.1.0.tgz#3f23ab12535e3d73e839bb43e73c9de487db1389" + integrity sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA== + dependencies: + slice-ansi "^5.0.0" + string-width "^5.0.0" + +cli-truncate@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-2.1.0.tgz#c39e28bf05edcde5be3b98992a22deed5a2b93c7" integrity sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg== @@ -5433,6 +5455,11 @@ clone@2.1.1: resolved "https://registry.yarnpkg.com/clone/-/clone-2.1.1.tgz#d217d1e961118e3ac9a4b8bba3285553bf647cdb" integrity sha1-0hfR6WERjjrJpLi7oyhVU79kfNs= +clone@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/clone/-/clone-2.1.2.tgz#1b7f4b9f591f1e8f83670401600345a02887435f" + integrity sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18= + clsx@^1.0.4: version "1.1.1" resolved "https://registry.yarnpkg.com/clsx/-/clsx-1.1.1.tgz#98b3134f9abbdf23b2663491ace13c5c03a73188" @@ -5505,10 +5532,10 @@ colorette@^1.2.1, colorette@^1.2.2: resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.2.2.tgz#cbcc79d5e99caea2dbf10eb3a26fd8b3e6acfa94" integrity sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w== -colorette@^1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.4.0.tgz#5190fbb87276259a86ad700bff2c6d6faa3fca40" - integrity sha512-Y2oEozpomLn7Q3HFP7dpww7AtMJplbM9lGZP6RDfHqmbeRjiwRg4n6VM6j4KLmRke85uWEI7JqF17f3pqdRA0g== +colorette@^2.0.16: + version "2.0.16" + resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.16.tgz#713b9af84fdb000139f04546bd4a93f62a5085da" + integrity sha512-hUewv7oMjCp+wkBv5Rm0v87eJhq4woh5rSR+42YSQJKecCqgIqNkZ6lAlQms/BwHPJA5NKMRlpxPRv0n8HQW6g== colors@^1.1.2: version "1.4.0" @@ -5552,10 +5579,10 @@ commander@^7.1.0, commander@^7.2.0: resolved "https://registry.yarnpkg.com/commander/-/commander-7.2.0.tgz#a36cb57d0b501ce108e4d20559a150a391d97ab7" integrity sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw== -commander@^8.2.0: - version "8.2.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-8.2.0.tgz#37fe2bde301d87d47a53adeff8b5915db1381ca8" - integrity sha512-LLKxDvHeL91/8MIyTAD5BFMNtoIwztGPMiM/7Bl8rIPmHCZXRxmSWr91h57dpOpnQ6jIUqEWdXE/uBYMfiVZDA== +commander@^8.3.0: + version "8.3.0" + resolved "https://registry.yarnpkg.com/commander/-/commander-8.3.0.tgz#4837ea1b2da67b9c616a67afbb0fafee567bca66" + integrity sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww== common-tags@^1.8.0: version "1.8.0" @@ -6067,10 +6094,10 @@ cssnano-preset-default@^5.1.3: postcss-svgo "^5.0.2" postcss-unique-selectors "^5.0.1" -cssnano-preset-default@^5.1.6: - version "5.1.6" - resolved "https://registry.yarnpkg.com/cssnano-preset-default/-/cssnano-preset-default-5.1.6.tgz#1bdb83be6a6b1fee6dc5e9ec2e61286bcadcc7a6" - integrity sha512-X2nDeNGBXc0486oHjT2vSj+TdeyVsxRvJUxaOH50hOM6vSDLkKd0+59YXpSZRInJ4sNtBOykS4KsPfhdrU/35w== +cssnano-preset-default@^5.1.7: + version "5.1.7" + resolved "https://registry.yarnpkg.com/cssnano-preset-default/-/cssnano-preset-default-5.1.7.tgz#68c3ad1ec6a810482ec7d06b2d70fc34b6b0d70c" + integrity sha512-bWDjtTY+BOqrqBtsSQIbN0RLGD2Yr2CnecpP0ydHNafh9ZUEre8c8VYTaH9FEbyOt0eIfEUAYYk5zj92ioO8LA== dependencies: css-declaration-sorter "^6.0.3" cssnano-utils "^2.0.1" @@ -6081,11 +6108,11 @@ cssnano-preset-default@^5.1.6: postcss-discard-duplicates "^5.0.1" postcss-discard-empty "^5.0.1" postcss-discard-overridden "^5.0.1" - postcss-merge-longhand "^5.0.3" - postcss-merge-rules "^5.0.2" + postcss-merge-longhand "^5.0.4" + postcss-merge-rules "^5.0.3" postcss-minify-font-values "^5.0.1" postcss-minify-gradients "^5.0.3" - postcss-minify-params "^5.0.1" + postcss-minify-params "^5.0.2" postcss-minify-selectors "^5.1.0" postcss-normalize-charset "^5.0.1" postcss-normalize-display-values "^5.0.1" @@ -6094,13 +6121,13 @@ cssnano-preset-default@^5.1.6: postcss-normalize-string "^5.0.1" postcss-normalize-timing-functions "^5.0.1" postcss-normalize-unicode "^5.0.1" - postcss-normalize-url "^5.0.2" + postcss-normalize-url "^5.0.3" postcss-normalize-whitespace "^5.0.1" postcss-ordered-values "^5.0.2" postcss-reduce-initial "^5.0.1" postcss-reduce-transforms "^5.0.1" postcss-svgo "^5.0.3" - postcss-unique-selectors "^5.0.1" + postcss-unique-selectors "^5.0.2" cssnano-utils@^2.0.1: version "2.0.1" @@ -6117,12 +6144,12 @@ cssnano@^5.0.1: lilconfig "^2.0.3" yaml "^1.10.2" -cssnano@^5.0.10: - version "5.0.10" - resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-5.0.10.tgz#92207eb7c9c6dc08d318050726f9fad0adf7220b" - integrity sha512-YfNhVJJ04imffOpbPbXP2zjIoByf0m8E2c/s/HnvSvjXgzXMfgopVjAEGvxYOjkOpWuRQDg/OZFjO7WW94Ri8w== +cssnano@^5.0.11: + version "5.0.11" + resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-5.0.11.tgz#743397a05e04cb87e9df44b7659850adfafc3646" + integrity sha512-5SHM31NAAe29jvy0MJqK40zZ/8dGlnlzcfHKw00bWMVFp8LWqtuyPSFwbaoIoxvt71KWJOfg8HMRGrBR3PExCg== dependencies: - cssnano-preset-default "^5.1.6" + cssnano-preset-default "^5.1.7" is-resolvable "^1.1.0" lilconfig "^2.0.3" yaml "^1.10.2" @@ -6224,7 +6251,7 @@ cypress@^8.7.0: url "^0.11.0" yauzl "^2.10.0" -damerau-levenshtein@^1.0.6: +damerau-levenshtein@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.7.tgz#64368003512a1a6992593741a09a9d31a836f55d" integrity sha512-VvdQIPGdWP0SqFXghj79Wf/5LArmreyMsGLa6FG6iC4t3j7j5s71TrwWmT/4akbDQIqjfACkLZmjXhA7g2oUZw== @@ -6267,7 +6294,7 @@ debug@2.6.9, debug@^2.2.0, debug@^2.3.3, debug@^2.6.0, debug@^2.6.9: dependencies: ms "2.0.0" -debug@4, debug@^4.0.1, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1: +debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1: version "4.3.1" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.1.tgz#f0d229c505e0c6d8c49ac553d1b13dc183f6b2ee" integrity sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ== @@ -6668,7 +6695,7 @@ emoji-regex@^8.0.0: resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== -emoji-regex@^9.0.0: +emoji-regex@^9.2.2: version "9.2.2" resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-9.2.2.tgz#840c8803b0d8047f4ff0cf963176b32d4ef3ed72" integrity sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg== @@ -6784,30 +6811,6 @@ es-abstract@^1.17.0-next.0, es-abstract@^1.18.0-next.1, es-abstract@^1.18.0-next string.prototype.trimstart "^1.0.4" unbox-primitive "^1.0.1" -es-abstract@^1.18.1: - version "1.18.6" - resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.18.6.tgz#2c44e3ea7a6255039164d26559777a6d978cb456" - integrity sha512-kAeIT4cku5eNLNuUKhlmtuk1/TRZvQoYccn6TO0cSVdf1kzB0T7+dYuVK9MWM7l+/53W2Q8M7N2c6MQvhXFcUQ== - dependencies: - call-bind "^1.0.2" - es-to-primitive "^1.2.1" - function-bind "^1.1.1" - get-intrinsic "^1.1.1" - get-symbol-description "^1.0.0" - has "^1.0.3" - has-symbols "^1.0.2" - internal-slot "^1.0.3" - is-callable "^1.2.4" - is-negative-zero "^2.0.1" - is-regex "^1.1.4" - is-string "^1.0.7" - object-inspect "^1.11.0" - object-keys "^1.1.1" - object.assign "^4.1.2" - string.prototype.trimend "^1.0.4" - string.prototype.trimstart "^1.0.4" - unbox-primitive "^1.0.1" - es-abstract@^1.19.0, es-abstract@^1.19.1: version "1.19.1" resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.19.1.tgz#d4885796876916959de78edaa0df456627115ec3" @@ -6929,7 +6932,7 @@ eslint-import-resolver-node@^0.3.6: debug "^3.2.7" resolve "^1.20.0" -eslint-module-utils@^2.7.0: +eslint-module-utils@^2.7.1: version "2.7.1" resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.7.1.tgz#b435001c9f8dd4ab7f6d0efcae4b9696d4c24b7c" integrity sha512-fjoetBXQZq2tSTWZ9yWVl2KuFrTZZH3V+9iD1V1RfpDgxzJR+mPd/KZmMiA8gbPqdBzpNiEHOuT7IYEWxrH0zQ== @@ -6945,27 +6948,27 @@ eslint-plugin-cypress@^2.12.1: dependencies: globals "^11.12.0" -eslint-plugin-flowtype@^6.1.1: - version "6.1.1" - resolved "https://registry.yarnpkg.com/eslint-plugin-flowtype/-/eslint-plugin-flowtype-6.1.1.tgz#3358705e9285a53e4cc1b50ec7ab753d8ae07e3b" - integrity sha512-5RodSeZvKh1N0kppB9dSSO0ZqB8rHjdX9BUTVQUBnEzR3QU5aQVKEUlBJE7I7U7rhbJMxe3aHPmt/jD4+5Ya6g== +eslint-plugin-flowtype@^8.0.3: + version "8.0.3" + resolved "https://registry.yarnpkg.com/eslint-plugin-flowtype/-/eslint-plugin-flowtype-8.0.3.tgz#e1557e37118f24734aa3122e7536a038d34a4912" + integrity sha512-dX8l6qUL6O+fYPtpNRideCFSpmWOUVx5QcaGLVqe/vlDiBSe4vYljDWDETwnyFzpl7By/WVIu6rcrniCgH9BqQ== dependencies: lodash "^4.17.21" string-natural-compare "^3.0.1" -eslint-plugin-import@^2.25.2: - version "2.25.2" - resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.25.2.tgz#b3b9160efddb702fc1636659e71ba1d10adbe9e9" - integrity sha512-qCwQr9TYfoBHOFcVGKY9C9unq05uOxxdklmBXLVvcwo68y5Hta6/GzCZEMx2zQiu0woKNEER0LE7ZgaOfBU14g== +eslint-plugin-import@^2.25.3: + version "2.25.3" + resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.25.3.tgz#a554b5f66e08fb4f6dc99221866e57cfff824766" + integrity sha512-RzAVbby+72IB3iOEL8clzPLzL3wpDrlwjsTBAQXgyp5SeTqqY+0bFubwuo+y/HLhNZcXV4XqTBO4LGsfyHIDXg== dependencies: array-includes "^3.1.4" array.prototype.flat "^1.2.5" debug "^2.6.9" doctrine "^2.1.0" eslint-import-resolver-node "^0.3.6" - eslint-module-utils "^2.7.0" + eslint-module-utils "^2.7.1" has "^1.0.3" - is-core-module "^2.7.0" + is-core-module "^2.8.0" is-glob "^4.0.3" minimatch "^3.0.4" object.values "^1.1.5" @@ -6979,22 +6982,23 @@ eslint-plugin-jest@^25.2.4: dependencies: "@typescript-eslint/experimental-utils" "^5.0.0" -eslint-plugin-jsx-a11y@^6.4.1: - version "6.4.1" - resolved "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.4.1.tgz#a2d84caa49756942f42f1ffab9002436391718fd" - integrity sha512-0rGPJBbwHoGNPU73/QCLP/vveMlM1b1Z9PponxO87jfr6tuH5ligXbDT6nHSSzBC8ovX2Z+BQu7Bk5D/Xgq9zg== +eslint-plugin-jsx-a11y@^6.5.1: + version "6.5.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.5.1.tgz#cdbf2df901040ca140b6ec14715c988889c2a6d8" + integrity sha512-sVCFKX9fllURnXT2JwLN5Qgo24Ug5NF6dxhkmxsMEUZhXRcGg+X3e1JbJ84YePQKBl5E0ZjAH5Q4rkdcGY99+g== dependencies: - "@babel/runtime" "^7.11.2" + "@babel/runtime" "^7.16.3" aria-query "^4.2.2" - array-includes "^3.1.1" + array-includes "^3.1.4" ast-types-flow "^0.0.7" - axe-core "^4.0.2" + axe-core "^4.3.5" axobject-query "^2.2.0" - damerau-levenshtein "^1.0.6" - emoji-regex "^9.0.0" + damerau-levenshtein "^1.0.7" + emoji-regex "^9.2.2" has "^1.0.3" - jsx-ast-utils "^3.1.0" + jsx-ast-utils "^3.2.1" language-tags "^1.0.5" + minimatch "^3.0.4" eslint-plugin-prettier@^4.0.0: version "4.0.0" @@ -7003,30 +7007,30 @@ eslint-plugin-prettier@^4.0.0: dependencies: prettier-linter-helpers "^1.0.0" -eslint-plugin-react-hooks@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.2.0.tgz#8c229c268d468956334c943bb45fc860280f5556" - integrity sha512-623WEiZJqxR7VdxFCKLI6d6LLpwJkGPYKODnkH3D7WpOG5KM8yWueBd8TLsNAetEJNF5iJmolaAKO3F8yzyVBQ== +eslint-plugin-react-hooks@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.3.0.tgz#318dbf312e06fab1c835a4abef00121751ac1172" + integrity sha512-XslZy0LnMn+84NEG9jSGR6eGqaZB3133L8xewQo3fQagbQuGt7a63gf+P1NGKZavEYEC3UXaWEAA/AqDkuN6xA== -eslint-plugin-react@^7.26.1: - version "7.26.1" - resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.26.1.tgz#41bcfe3e39e6a5ac040971c1af94437c80daa40e" - integrity sha512-Lug0+NOFXeOE+ORZ5pbsh6mSKjBKXDXItUD2sQoT+5Yl0eoT82DqnXeTMfUare4QVCn9QwXbfzO/dBLjLXwVjQ== +eslint-plugin-react@^7.27.0: + version "7.27.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.27.0.tgz#f952c76517a3915b81c7788b220b2b4c96703124" + integrity sha512-0Ut+CkzpppgFtoIhdzi2LpdpxxBvgFf99eFqWxJnUrO7mMe0eOiNpou6rvNYeVVV6lWZvTah0BFne7k5xHjARg== dependencies: - array-includes "^3.1.3" - array.prototype.flatmap "^1.2.4" + array-includes "^3.1.4" + array.prototype.flatmap "^1.2.5" doctrine "^2.1.0" - estraverse "^5.2.0" + estraverse "^5.3.0" jsx-ast-utils "^2.4.1 || ^3.0.0" minimatch "^3.0.4" - object.entries "^1.1.4" - object.fromentries "^2.0.4" - object.hasown "^1.0.0" - object.values "^1.1.4" + object.entries "^1.1.5" + object.fromentries "^2.0.5" + object.hasown "^1.1.0" + object.values "^1.1.5" prop-types "^15.7.2" resolve "^2.0.0-next.3" semver "^6.3.0" - string.prototype.matchall "^4.0.5" + string.prototype.matchall "^4.0.6" eslint-scope@^4.0.3: version "4.0.3" @@ -7044,12 +7048,13 @@ eslint-scope@^5.1.1: esrecurse "^4.3.0" estraverse "^4.1.1" -eslint-utils@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-2.1.0.tgz#d2de5e03424e707dc10c74068ddedae708741b27" - integrity sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg== +eslint-scope@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-6.0.0.tgz#9cf45b13c5ac8f3d4c50f46a5121f61b3e318978" + integrity sha512-uRDL9MWmQCkaFus8RF5K9/L/2fn+80yoW3jkD53l4shjCh26fCtvJGasxjUqP5OT87SYTxCVA3BwTUzuELx9kA== dependencies: - eslint-visitor-keys "^1.1.0" + esrecurse "^4.3.0" + estraverse "^5.2.0" eslint-utils@^3.0.0: version "3.0.0" @@ -7058,11 +7063,6 @@ eslint-utils@^3.0.0: dependencies: eslint-visitor-keys "^2.0.0" -eslint-visitor-keys@^1.1.0, eslint-visitor-keys@^1.3.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz#30ebd1ef7c2fdff01c3a4f151044af25fab0523e" - integrity sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ== - eslint-visitor-keys@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz#f65328259305927392c938ed44eb0a5c9b2bd303" @@ -7073,37 +7073,36 @@ eslint-visitor-keys@^3.0.0: resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.0.0.tgz#e32e99c6cdc2eb063f204eda5db67bfe58bb4186" integrity sha512-mJOZa35trBTb3IyRmo8xmKBZlxf+N7OnUl4+ZhJHs/r+0770Wh/LEACE2pqMGMe27G/4y8P2bYGk4J70IC5k1Q== -eslint@^7.32.0: - version "7.32.0" - resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.32.0.tgz#c6d328a14be3fb08c8d1d21e12c02fdb7a2a812d" - integrity sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA== +eslint@^8.2.0: + version "8.2.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.2.0.tgz#44d3fb506d0f866a506d97a0fc0e90ee6d06a815" + integrity sha512-erw7XmM+CLxTOickrimJ1SiF55jiNlVSp2qqm0NuBWPtHYQCegD5ZMaW0c3i5ytPqL+SSLaCxdvQXFPLJn+ABw== dependencies: - "@babel/code-frame" "7.12.11" - "@eslint/eslintrc" "^0.4.3" - "@humanwhocodes/config-array" "^0.5.0" + "@eslint/eslintrc" "^1.0.4" + "@humanwhocodes/config-array" "^0.6.0" ajv "^6.10.0" chalk "^4.0.0" cross-spawn "^7.0.2" - debug "^4.0.1" + debug "^4.3.2" doctrine "^3.0.0" enquirer "^2.3.5" escape-string-regexp "^4.0.0" - eslint-scope "^5.1.1" - eslint-utils "^2.1.0" - eslint-visitor-keys "^2.0.0" - espree "^7.3.1" + eslint-scope "^6.0.0" + eslint-utils "^3.0.0" + eslint-visitor-keys "^3.0.0" + espree "^9.0.0" esquery "^1.4.0" esutils "^2.0.2" fast-deep-equal "^3.1.3" file-entry-cache "^6.0.1" functional-red-black-tree "^1.0.1" - glob-parent "^5.1.2" + glob-parent "^6.0.1" globals "^13.6.0" ignore "^4.0.6" import-fresh "^3.0.0" imurmurhash "^0.1.4" is-glob "^4.0.0" - js-yaml "^3.13.1" + js-yaml "^4.1.0" json-stable-stringify-without-jsonify "^1.0.1" levn "^0.4.1" lodash.merge "^4.6.2" @@ -7111,11 +7110,10 @@ eslint@^7.32.0: natural-compare "^1.4.0" optionator "^0.9.1" progress "^2.0.0" - regexpp "^3.1.0" + regexpp "^3.2.0" semver "^7.2.1" - strip-ansi "^6.0.0" + strip-ansi "^6.0.1" strip-json-comments "^3.1.0" - table "^6.0.9" text-table "^0.2.0" v8-compile-cache "^2.0.3" @@ -7124,14 +7122,14 @@ esm@^3.2.22: resolved "https://registry.yarnpkg.com/esm/-/esm-3.2.25.tgz#342c18c29d56157688ba5ce31f8431fbb795cc10" integrity sha512-U1suiZ2oDVWv4zPO56S0NcR5QriEahGtdN2OR6FiOG4WJvcjBVFB0qI4+eKoWFH483PKGuLuu6V8Z4T5g63UVA== -espree@^7.3.0, espree@^7.3.1: - version "7.3.1" - resolved "https://registry.yarnpkg.com/espree/-/espree-7.3.1.tgz#f2df330b752c6f55019f8bd89b7660039c1bbbb6" - integrity sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g== +espree@^9.0.0: + version "9.0.0" + resolved "https://registry.yarnpkg.com/espree/-/espree-9.0.0.tgz#e90a2965698228502e771c7a58489b1a9d107090" + integrity sha512-r5EQJcYZ2oaGbeR0jR0fFVijGOcwai07/690YRXLINuhmVeRY4UKSAsQPe/0BNuDgwP7Ophoc1PRsr2E3tkbdQ== dependencies: - acorn "^7.4.0" + acorn "^8.5.0" acorn-jsx "^5.3.1" - eslint-visitor-keys "^1.3.0" + eslint-visitor-keys "^3.0.0" esprima@^4.0.0, esprima@^4.0.1: version "4.0.1" @@ -7162,6 +7160,11 @@ estraverse@^5.1.0, estraverse@^5.2.0: resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.2.0.tgz#307df42547e6cc7324d3cf03c155d5cdb8c53880" integrity sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ== +estraverse@^5.3.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + estree-to-babel@^3.1.0: version "3.2.1" resolved "https://registry.yarnpkg.com/estree-to-babel/-/estree-to-babel-3.2.1.tgz#82e78315275c3ca74475fdc8ac1a5103c8a75bf5" @@ -7900,11 +7903,6 @@ get-intrinsic@^1.0.2, get-intrinsic@^1.1.0, get-intrinsic@^1.1.1: has "^1.0.3" has-symbols "^1.0.1" -get-own-enumerable-property-symbols@^3.0.0: - version "3.0.2" - resolved "https://registry.yarnpkg.com/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz#b5fde77f22cbe35f390b4e089922c50bce6ef664" - integrity sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g== - get-package-type@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" @@ -8018,6 +8016,13 @@ glob-parent@^5.1.2, glob-parent@~5.1.2: dependencies: is-glob "^4.0.1" +glob-parent@^6.0.1: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + glob-promise@^3.4.0: version "3.4.0" resolved "https://registry.yarnpkg.com/glob-promise/-/glob-promise-3.4.0.tgz#b6b8f084504216f702dc2ce8c9bc9ac8866fdb20" @@ -8181,6 +8186,11 @@ has-flag@^4.0.0: resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== +has-flag@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-5.0.1.tgz#5483db2ae02a472d1d0691462fc587d1843cd940" + integrity sha512-CsNUt5x9LUdx6hnk/E2SZLsDyvfqANZSUq4+D3D8RzDJ2M+HDTIkF60ibS1vHaK55vzgiZw1bEPFG9yH7l33wA== + has-glob@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/has-glob/-/has-glob-1.0.0.tgz#9aaa9eedbffb1ba3990a7b0010fb678ee0081207" @@ -8855,7 +8865,7 @@ is-core-module@^2.2.0: dependencies: has "^1.0.3" -is-core-module@^2.7.0: +is-core-module@^2.8.0: version "2.8.0" resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.8.0.tgz#0321336c3d0925e497fd97f5d95cb114a5ccd548" integrity sha512-vd15qHsaqrRL7dtH6QNuy0ndJmRDrS9HAM1CAiSifNUFv4x1a0CCVsj18hJ1mShxIG6T2i1sO78MkP56r0nYRw== @@ -8956,6 +8966,11 @@ is-fullwidth-code-point@^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-fullwidth-code-point@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz#fae3167c729e7463f8461ce512b080a49268aa88" + integrity sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ== + is-function@^1.0.1, is-function@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/is-function/-/is-function-1.0.2.tgz#4f097f30abf6efadac9833b17ca5dc03f8144e08" @@ -9044,11 +9059,6 @@ is-number@^7.0.0: resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== -is-obj@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz#3e4729ac1f5fde025cd7d83a896dab9f4f67db0f" - integrity sha1-PkcprB9f3gJc19g6iW2rn09n2w8= - is-object@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/is-object/-/is-object-1.0.2.tgz#a56552e1c665c9e950b4a025461da87e72f86fcf" @@ -9104,11 +9114,6 @@ is-regex@^1.1.4: call-bind "^1.0.2" has-tostringtag "^1.0.0" -is-regexp@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-regexp/-/is-regexp-1.0.0.tgz#fd2d883545c46bac5a633e7b9a09e87fa2cb5069" - integrity sha1-/S2INUXEa6xaYz57mgnof6LLUGk= - is-resolvable@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/is-resolvable/-/is-resolvable-1.1.0.tgz#fb18f87ce1feb925169c9a407c19318a3206ed88" @@ -9882,6 +9887,13 @@ js-yaml@^3.13.1: argparse "^1.0.7" esprima "^4.0.0" +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + jsan@^3.1.3: version "3.1.13" resolved "https://registry.yarnpkg.com/jsan/-/jsan-3.1.13.tgz#4de8c7bf8d1cfcd020c313d438f930cec4b91d86" @@ -9950,11 +9962,6 @@ json-schema-traverse@^0.4.1: resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== -json-schema-traverse@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" - integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== - json-schema@0.2.3: version "0.2.3" resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.2.3.tgz#b480c892e59a2f05954ce727bd3f2a4e882f9e13" @@ -10102,7 +10109,7 @@ jss@10.8.2, jss@^10.5.1: is-in-browser "^1.1.3" tiny-warning "^1.0.2" -"jsx-ast-utils@^2.4.1 || ^3.0.0", jsx-ast-utils@^3.1.0: +"jsx-ast-utils@^2.4.1 || ^3.0.0": version "3.2.0" resolved "https://registry.yarnpkg.com/jsx-ast-utils/-/jsx-ast-utils-3.2.0.tgz#41108d2cec408c3453c1bbe8a4aae9e1e2bd8f82" integrity sha512-EIsmt3O3ljsU6sot/J4E1zDRxfBNrhjyf/OKjlydwgEimQuznlM4Wv7U+ueONJMyEn1WRE0K8dhi3dVAXYT24Q== @@ -10110,6 +10117,14 @@ jss@10.8.2, jss@^10.5.1: array-includes "^3.1.2" object.assign "^4.1.2" +jsx-ast-utils@^3.2.1: + version "3.2.1" + resolved "https://registry.yarnpkg.com/jsx-ast-utils/-/jsx-ast-utils-3.2.1.tgz#720b97bfe7d901b927d87c3773637ae8ea48781b" + integrity sha512-uP5vu8xfy2F9A6LGC22KO7e2/vGTS1MhP+18f++ZNlf0Ohaxbc9nIEwHAsejlJKyzfZzU5UIhe5ItYkitcZnZA== + dependencies: + array-includes "^3.1.3" + object.assign "^4.1.2" + junk@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/junk/-/junk-3.1.0.tgz#31499098d902b7e98c5d9b9c80f43457a88abfa1" @@ -10259,36 +10274,35 @@ linked-list@0.1.0: resolved "https://registry.yarnpkg.com/linked-list/-/linked-list-0.1.0.tgz#798b0ff97d1b92a4fd08480f55aea4e9d49d37bf" integrity sha1-eYsP+X0bkqT9CEgPVa6k6dSdN78= -lint-staged@^11.2.6: - version "11.2.6" - resolved "https://registry.yarnpkg.com/lint-staged/-/lint-staged-11.2.6.tgz#f477b1af0294db054e5937f171679df63baa4c43" - integrity sha512-Vti55pUnpvPE0J9936lKl0ngVeTdSZpEdTNhASbkaWX7J5R9OEifo1INBGQuGW4zmy6OG+TcWPJ3m5yuy5Q8Tg== +lint-staged@^12.0.2: + version "12.0.2" + resolved "https://registry.yarnpkg.com/lint-staged/-/lint-staged-12.0.2.tgz#b0f96f2a57898658a5b59e087aeff975dad03fc1" + integrity sha512-tpCvACqc7bykziGJmXG0G8YG2RaCrWiDBwmrP9wU7i/3za9JMOvCECQmXjw/sO4ICC70ApVwyqixS1htQX9Haw== dependencies: - cli-truncate "2.1.0" - colorette "^1.4.0" - commander "^8.2.0" + cli-truncate "3.1.0" + colorette "^2.0.16" + commander "^8.3.0" cosmiconfig "^7.0.1" debug "^4.3.2" - enquirer "^2.3.6" execa "^5.1.1" - listr2 "^3.12.2" + listr2 "^3.13.3" micromatch "^4.0.4" normalize-path "^3.0.0" - please-upgrade-node "^3.2.0" + object-inspect "1.11.0" string-argv "0.3.1" - stringify-object "3.3.0" - supports-color "8.1.1" + supports-color "9.0.2" -listr2@^3.12.2: - version "3.12.2" - resolved "https://registry.yarnpkg.com/listr2/-/listr2-3.12.2.tgz#2d55cc627111603ad4768a9e87c9c7bb9b49997e" - integrity sha512-64xC2CJ/As/xgVI3wbhlPWVPx0wfTqbUAkpb7bjDi0thSWMqrf07UFhrfsGoo8YSXmF049Rp9C0cjLC8rZxK9A== +listr2@^3.13.3: + version "3.13.4" + resolved "https://registry.yarnpkg.com/listr2/-/listr2-3.13.4.tgz#34101fc0184545597e00d1e7915ccfbfb17332e6" + integrity sha512-lZ1Rut1DSIRwbxQbI8qaUBfOWJ1jEYRgltIM97j6kKOCI2pHVWMyxZvkU/JKmRBWcIYgDS2PK+yDgVqm7u3crw== dependencies: cli-truncate "^2.1.0" - colorette "^1.4.0" + clone "^2.1.2" + colorette "^2.0.16" log-update "^4.0.0" p-map "^4.0.0" - rxjs "^6.6.7" + rxjs "^7.4.0" through "^2.3.8" wrap-ansi "^7.0.0" @@ -10388,11 +10402,6 @@ lodash.camelcase@^4.3.0: resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6" integrity sha1-soqmKIorn8ZRA1x3EfZathkDMaY= -lodash.clonedeep@^4.5.0: - version "4.5.0" - resolved "https://registry.yarnpkg.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz#e23f3f9c4f8fbdde872529c1071857a086e5ccef" - integrity sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8= - lodash.debounce@^4.0.8: version "4.0.8" resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" @@ -10413,11 +10422,6 @@ lodash.once@^4.1.1: resolved "https://registry.yarnpkg.com/lodash.once/-/lodash.once-4.1.1.tgz#0dd3971213c7c56df880977d504c88fb471a97ac" integrity sha1-DdOXEhPHxW34gJd9UEyI+0cal6w= -lodash.truncate@^4.4.2: - version "4.4.2" - resolved "https://registry.yarnpkg.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz#5a350da0b1113b837ecfffd5812cbe58d6eae193" - integrity sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM= - lodash.uniq@4.5.0, lodash.uniq@^4.5.0: version "4.5.0" resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773" @@ -10863,15 +10867,15 @@ mobx-react-lite@^3.2.2: resolved "https://registry.yarnpkg.com/mobx-react-lite/-/mobx-react-lite-3.2.2.tgz#cee5f09e6b0e4d2705d87276baf1de74d997fa33" integrity sha512-FxJJMqmHcnQYOVVs2DdjNHioGlFsXF5/9VHztS9NAfIT3DYrxNZzVi119Zr/OmlWKkWNkAsssSNzPkqautfL4A== -mobx-state-tree@^5.0.4: - version "5.0.4" - resolved "https://registry.yarnpkg.com/mobx-state-tree/-/mobx-state-tree-5.0.4.tgz#b2628436915f5eba125cc9d2bc8bc3ad58b8762c" - integrity sha512-YJnjW4hy5+kcbZdRJAmqK2HrRYl2Xjh66dVRlNRBknJiNHzYvQ5qKFp096jXlP/0XWu5T3yn5JBgnLeGbGTVKA== +mobx-state-tree@^5.0.5: + version "5.0.5" + resolved "https://registry.yarnpkg.com/mobx-state-tree/-/mobx-state-tree-5.0.5.tgz#da990703c8aa30c33ead4977115e13448427b507" + integrity sha512-SM0CZ0Aj8qMYaLEkzOA7TOqSqdGQUqP8qT9+w4lvnvwB1EGmK22z3drullQzFq20RfkLOU20cn+Us0EOmK+9Sg== -mobx@^6.3.6: - version "6.3.6" - resolved "https://registry.yarnpkg.com/mobx/-/mobx-6.3.6.tgz#3192dea21ae8213d04a0df5c98a5ca164ed29ecd" - integrity sha512-TeCp8BTco5cmXKY7Zt5VSL5fHBEAHTSA6xs+KWmcxi3cFN1C+Xqs2m3giyGT/e6TSjtdDysVX5+cCZZhEyiJmA== +mobx@^6.3.7: + version "6.3.7" + resolved "https://registry.yarnpkg.com/mobx/-/mobx-6.3.7.tgz#9ed85561e86da45141134c8fa20cf5f9c7246c3d" + integrity sha512-X7yU7eOEyxIBk4gjIi2UIilwdw48gXh0kcZ5ex3Rc+COJsJmJ4SNpf42uYea3aUqb1hedTv5xzJrq5Q55p0P5g== moment@^2.24.0, moment@^2.25.3, moment@^2.29.1: version "2.29.1" @@ -10910,10 +10914,10 @@ ms@^2.1.1: resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== -mst-middlewares@^5.0.4: - version "5.0.4" - resolved "https://registry.yarnpkg.com/mst-middlewares/-/mst-middlewares-5.0.4.tgz#abe898095c2d95390266860e22bd60b565ea2380" - integrity sha512-kWsQYUR0HwcummeTG7ou3JeruucbOvqowU4MQ6fmqwDluXTmYBGlIqYEqpxIMZNdvPTJZ/nzonbuVgoMshsUbQ== +mst-middlewares@^5.0.5: + version "5.0.5" + resolved "https://registry.yarnpkg.com/mst-middlewares/-/mst-middlewares-5.0.5.tgz#b6e48fb5c3d40f8ac8b0e9aed8f2b8c84e8e0358" + integrity sha512-rZ9BVUaDHuTbI1NwCxq1oHVXvtawyUohjWdD2PYoqO1e01nBoEuxOU82IR90vgC2c1TAaaOE3IfKaYo5+/8hrw== nan@^2.12.1: version "2.14.2" @@ -11185,16 +11189,16 @@ object-copy@^0.1.0: define-property "^0.2.5" kind-of "^3.0.3" +object-inspect@1.11.0, object-inspect@^1.11.0: + version "1.11.0" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.11.0.tgz#9dceb146cedd4148a0d9e51ab88d34cf509922b1" + integrity sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg== + object-inspect@^1.10.3, object-inspect@^1.9.0: version "1.10.3" resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.10.3.tgz#c2aa7d2d09f50c99375704f7a0adf24c5782d369" integrity sha512-e5mCJlSH7poANfC8z8S9s9S2IN5/4Zb3aZ33f5s8YqoazCFzNLloLU8r5VCG+G7WoqLvAAZoVMcy3tp/3X0Plw== -object-inspect@^1.11.0: - version "1.11.0" - resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.11.0.tgz#9dceb146cedd4148a0d9e51ab88d34cf509922b1" - integrity sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg== - object-keys@^1.0.12, object-keys@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" @@ -11217,7 +11221,7 @@ object.assign@^4.1.0, object.assign@^4.1.2: has-symbols "^1.0.1" object-keys "^1.1.1" -object.entries@^1.1.0, object.entries@^1.1.4: +object.entries@^1.1.0: version "1.1.4" resolved "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.4.tgz#43ccf9a50bc5fd5b649d45ab1a579f24e088cafd" integrity sha512-h4LWKWE+wKQGhtMjZEBud7uLGhqyLwj8fpHOarZhD2uY3C9cRtk57VQ89ke3moByLXMedqs3XCHzyb4AmA2DjA== @@ -11226,7 +11230,16 @@ object.entries@^1.1.0, object.entries@^1.1.4: define-properties "^1.1.3" es-abstract "^1.18.2" -"object.fromentries@^2.0.0 || ^1.0.0", object.fromentries@^2.0.4: +object.entries@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.5.tgz#e1acdd17c4de2cd96d5a08487cfb9db84d881861" + integrity sha512-TyxmjUoZggd4OrrU1W66FMDG6CuqJxsFvymeyXI51+vQLN67zYfZseptRge703kKQdo4uccgAKebXFcRCzk4+g== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + +"object.fromentries@^2.0.0 || ^1.0.0": version "2.0.4" resolved "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.4.tgz#26e1ba5c4571c5c6f0890cef4473066456a120b8" integrity sha512-EsFBshs5RUUpQEY1D4q/m59kMfz4YJvxuNCJcv/jWwOJr34EaVnG11ZrZa0UHB3wnzV1wx8m58T4hQL8IuNXlQ== @@ -11236,6 +11249,15 @@ object.entries@^1.1.0, object.entries@^1.1.4: es-abstract "^1.18.0-next.2" has "^1.0.3" +object.fromentries@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.5.tgz#7b37b205109c21e741e605727fe8b0ad5fa08251" + integrity sha512-CAyG5mWQRRiBU57Re4FKoTBjXfDoNwdFVH2Y1tS9PqCsfUTymAohOkEMSG3aRNKmv4lV3O7p1et7c187q6bynw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + object.getownpropertydescriptors@^2.0.3, object.getownpropertydescriptors@^2.1.2: version "2.1.2" resolved "https://registry.yarnpkg.com/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.2.tgz#1bd63aeacf0d5d2d2f31b5e393b03a7c601a23f7" @@ -11245,13 +11267,13 @@ object.getownpropertydescriptors@^2.0.3, object.getownpropertydescriptors@^2.1.2 define-properties "^1.1.3" es-abstract "^1.18.0-next.2" -object.hasown@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/object.hasown/-/object.hasown-1.0.0.tgz#bdbade33cfacfb25d7f26ae2b6cb870bf99905c2" - integrity sha512-qYMF2CLIjxxLGleeM0jrcB4kiv3loGVAjKQKvH8pSU/i2VcRRvUNmxbD+nEMmrXRfORhuVJuH8OtSYCZoue3zA== +object.hasown@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/object.hasown/-/object.hasown-1.1.0.tgz#7232ed266f34d197d15cac5880232f7a4790afe5" + integrity sha512-MhjYRfj3GBlhSkDHo6QmvgjRLXQ2zndabdf3nX0yTyZK9rPfxb6uRpAac8HXNLy1GpqWtZ81Qh4v3uOls2sRAg== dependencies: define-properties "^1.1.3" - es-abstract "^1.18.1" + es-abstract "^1.19.1" object.pick@^1.3.0: version "1.3.0" @@ -11260,7 +11282,7 @@ object.pick@^1.3.0: dependencies: isobject "^3.0.1" -object.values@^1.1.0, object.values@^1.1.4: +object.values@^1.1.0: version "1.1.4" resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.1.4.tgz#0d273762833e816b693a637d30073e7051535b30" integrity sha512-TnGo7j4XSnKQoK3MfvkzqKCi0nVe/D9I9IjwTNYdb/fxYHpjrluHVOgw0AF6jrRFGMPHdfuidR09tIDiIvnaSg== @@ -11728,13 +11750,6 @@ pkg-up@3.1.0: dependencies: find-up "^3.0.0" -please-upgrade-node@^3.2.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz#aeddd3f994c933e4ad98b99d9a556efa0e2fe942" - integrity sha512-gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg== - dependencies: - semver-compare "^1.0.0" - pnp-webpack-plugin@1.6.4: version "1.6.4" resolved "https://registry.yarnpkg.com/pnp-webpack-plugin/-/pnp-webpack-plugin-1.6.4.tgz#c9711ac4dc48a685dabafc86f8b6dd9f8df84149" @@ -11884,12 +11899,11 @@ postcss-merge-longhand@^5.0.2: postcss-value-parser "^4.1.0" stylehacks "^5.0.1" -postcss-merge-longhand@^5.0.3: - version "5.0.3" - resolved "https://registry.yarnpkg.com/postcss-merge-longhand/-/postcss-merge-longhand-5.0.3.tgz#42194a5ffbaa5513edbf606ef79c44958564658b" - integrity sha512-kmB+1TjMTj/bPw6MCDUiqSA5e/x4fvLffiAdthra3a0m2/IjTrWsTmD3FdSskzUjEwkj5ZHBDEbv5dOcqD7CMQ== +postcss-merge-longhand@^5.0.4: + version "5.0.4" + resolved "https://registry.yarnpkg.com/postcss-merge-longhand/-/postcss-merge-longhand-5.0.4.tgz#41f4f3270282ea1a145ece078b7679f0cef21c32" + integrity sha512-2lZrOVD+d81aoYkZDpWu6+3dTAAGkCKbV5DoRhnIR7KOULVrI/R7bcMjhrH9KTRy6iiHKqmtG+n/MMj1WmqHFw== dependencies: - css-color-names "^1.0.1" postcss-value-parser "^4.1.0" stylehacks "^5.0.1" @@ -11904,6 +11918,16 @@ postcss-merge-rules@^5.0.2: postcss-selector-parser "^6.0.5" vendors "^1.0.3" +postcss-merge-rules@^5.0.3: + version "5.0.3" + resolved "https://registry.yarnpkg.com/postcss-merge-rules/-/postcss-merge-rules-5.0.3.tgz#b5cae31f53129812a77e3eb1eeee448f8cf1a1db" + integrity sha512-cEKTMEbWazVa5NXd8deLdCnXl+6cYG7m2am+1HzqH0EnTdy8fRysatkaXb2dEnR+fdaDxTvuZ5zoBdv6efF6hg== + dependencies: + browserslist "^4.16.6" + caniuse-api "^3.0.0" + cssnano-utils "^2.0.1" + postcss-selector-parser "^6.0.5" + postcss-minify-font-values@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/postcss-minify-font-values/-/postcss-minify-font-values-5.0.1.tgz#a90cefbfdaa075bd3dbaa1b33588bb4dc268addf" @@ -11940,6 +11964,16 @@ postcss-minify-params@^5.0.1: postcss-value-parser "^4.1.0" uniqs "^2.0.0" +postcss-minify-params@^5.0.2: + version "5.0.2" + resolved "https://registry.yarnpkg.com/postcss-minify-params/-/postcss-minify-params-5.0.2.tgz#1b644da903473fbbb18fbe07b8e239883684b85c" + integrity sha512-qJAPuBzxO1yhLad7h2Dzk/F7n1vPyfHfCCh5grjGfjhi1ttCnq4ZXGIW77GSrEbh9Hus9Lc/e/+tB4vh3/GpDg== + dependencies: + alphanum-sort "^1.0.2" + browserslist "^4.16.6" + cssnano-utils "^2.0.1" + postcss-value-parser "^4.1.0" + postcss-minify-selectors@^5.1.0: version "5.1.0" resolved "https://registry.yarnpkg.com/postcss-minify-selectors/-/postcss-minify-selectors-5.1.0.tgz#4385c845d3979ff160291774523ffa54eafd5a54" @@ -12083,6 +12117,15 @@ postcss-normalize-url@^5.0.2: normalize-url "^6.0.1" postcss-value-parser "^4.1.0" +postcss-normalize-url@^5.0.3: + version "5.0.3" + resolved "https://registry.yarnpkg.com/postcss-normalize-url/-/postcss-normalize-url-5.0.3.tgz#42eca6ede57fe69075fab0f88ac8e48916ef931c" + integrity sha512-qWiUMbvkRx3kc1Dp5opzUwc7MBWZcSDK2yofCmdvFBCpx+zFPkxBC1FASQ59Pt+flYfj/nTZSkmF56+XG5elSg== + dependencies: + is-absolute-url "^3.0.3" + normalize-url "^6.0.1" + postcss-value-parser "^4.1.0" + postcss-normalize-whitespace@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/postcss-normalize-whitespace/-/postcss-normalize-whitespace-5.0.1.tgz#b0b40b5bcac83585ff07ead2daf2dcfbeeef8e9a" @@ -12147,6 +12190,14 @@ postcss-unique-selectors@^5.0.1: postcss-selector-parser "^6.0.5" uniqs "^2.0.0" +postcss-unique-selectors@^5.0.2: + version "5.0.2" + resolved "https://registry.yarnpkg.com/postcss-unique-selectors/-/postcss-unique-selectors-5.0.2.tgz#5d6893daf534ae52626708e0d62250890108c0c1" + integrity sha512-w3zBVlrtZm7loQWRPVC0yjUwwpty7OM6DnEHkxcSQXO1bMS3RJ+JUS5LFMSDZHJcvGsRwhZinCWVqn8Kej4EDA== + dependencies: + alphanum-sort "^1.0.2" + postcss-selector-parser "^6.0.5" + postcss-value-parser@^3.3.0: version "3.3.1" resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz#9ff822547e2893213cf1c30efa51ac5fd1ba8281" @@ -12210,10 +12261,10 @@ prettier-linter-helpers@^1.0.0: dependencies: fast-diff "^1.1.2" -prettier@2.3.2: - version "2.3.2" - resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.3.2.tgz#ef280a05ec253712e486233db5c6f23441e7342d" - integrity sha512-lnJzDfJ66zkMy58OL5/NY5zp70S7Nz6KqcKkXYzn2tMVrNxvbqaBpg7H3qHaLxCJ5lNMsGuM8+ohS7cZrthdLQ== +prettier@2.4.1: + version "2.4.1" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.4.1.tgz#671e11c89c14a4cfc876ce564106c4a6726c9f5c" + integrity sha512-9fbDAXSBcc6Bs1mZrDYb3XKzDLm4EXXL9sC1LqKP5rZkT6KRr/rf9amVUcODVXgguK/isJz0d0hP72WeaKWsvA== prettier@~2.2.1: version "2.2.1" @@ -13063,10 +13114,10 @@ react-helmet-async@^1.0.7: react-fast-compare "^3.2.0" shallowequal "^1.1.0" -react-horizontal-scrolling-menu@^2.5.1: - version "2.5.1" - resolved "https://registry.yarnpkg.com/react-horizontal-scrolling-menu/-/react-horizontal-scrolling-menu-2.5.1.tgz#830fc3e8184d4db5518362344519fdc281d6cfb9" - integrity sha512-00FWMzamtsKG61RVs1WrO4yi0d+rjZrGIFM/wLCyYXkZUnTX5wQClwcYJ6BfG1hGU+L2qpM7y3tJjkDdmCBJig== +react-horizontal-scrolling-menu@^2.5.2: + version "2.5.2" + resolved "https://registry.yarnpkg.com/react-horizontal-scrolling-menu/-/react-horizontal-scrolling-menu-2.5.2.tgz#512466081b3ea6e0980bbb217402e146425c4ab3" + integrity sha512-/SowYoLgIqcx0mV/32KdM0eLVorvqBo4KQQgSXr3h5M2KF3lhI3d8BPyptgvj7hV9siyNX56kRkK+zSeIZInCQ== react-html-attributes@^1.4.2: version "1.4.6" @@ -13133,18 +13184,18 @@ react-refresh@^0.8.3: resolved "https://registry.yarnpkg.com/react-refresh/-/react-refresh-0.8.3.tgz#721d4657672d400c5e3c75d063c4a85fb2d5d68f" integrity sha512-X8jZHc7nCMjaCqoU+V2I0cOhNW+QMBwSUkeXnTi8IPe6zaRWfn60ZzvFDZqWPfmSJfjub7dDW1SP0jaHWLu/hg== -react-router-dom@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/react-router-dom/-/react-router-dom-6.0.1.tgz#958d5deac8932ce209001ba7a11d5ae605148856" - integrity sha512-fiE+PzFTrof5q8Z/+RHzuiin9/U/q5KY2adlHClwYexbY0DqJnHcC/0U9yv3Amz9em2/bcK7X8mk7+zxB+qhvg== +react-router-dom@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/react-router-dom/-/react-router-dom-6.0.2.tgz#860cefa697b9d4965eced3f91e82cdbc5995f3ad" + integrity sha512-cOpJ4B6raFutr0EG8O/M2fEoyQmwvZWomf1c6W2YXBZuFBx8oTk/zqjXghwScyhfrtnt0lANXV2182NQblRxFA== dependencies: history "^5.1.0" - react-router "6.0.1" + react-router "6.0.2" -react-router@6.0.1, react-router@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/react-router/-/react-router-6.0.1.tgz#3fe93ad11f91fb55e242a42628414cb47219e652" - integrity sha512-O3iab52icFnQaHWONZr50CcjRlf3gx8CCjPQ0YxN8xEuEklRJNgoZSeoYFYz0fLvA4cpnhc306Nd8BYgL4QZrQ== +react-router@6.0.2, react-router@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/react-router/-/react-router-6.0.2.tgz#bd2b0fa84fd1d152671e9f654d9c0b1f5a7c86da" + integrity sha512-8/Wm3Ed8t7TuedXjAvV39+c8j0vwrI5qVsYqjFr5WkJjsJpEvNSoLRUbtqSEYzqaTUj1IV+sbPJxvO+accvU0Q== dependencies: history "^5.1.0" @@ -13404,7 +13455,7 @@ regexp.prototype.flags@^1.3.1: call-bind "^1.0.2" define-properties "^1.1.3" -regexpp@^3.1.0, regexpp@^3.2.0: +regexpp@^3.2.0: version "3.2.0" resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.2.0.tgz#0425a2768d8f23bad70ca4b90461fa2f1213e1b2" integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg== @@ -13554,11 +13605,6 @@ require-directory@^2.1.1: resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" integrity sha1-jGStX9MNqxyXbiNE/+f3kqam30I= -require-from-string@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" - integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== - reserved-words@^0.1.2: version "0.1.2" resolved "https://registry.yarnpkg.com/reserved-words/-/reserved-words-0.1.2.tgz#00a0940f98cd501aeaaac316411d9adc52b31ab1" @@ -13716,10 +13762,10 @@ rollup-pluginutils@^2.8.1, rollup-pluginutils@^2.8.2: dependencies: estree-walker "^0.6.1" -rollup@^2.59.0: - version "2.59.0" - resolved "https://registry.yarnpkg.com/rollup/-/rollup-2.59.0.tgz#108c61b0fa0a37ebc8d1f164f281622056f0db59" - integrity sha512-l7s90JQhCQ6JyZjKgo7Lq1dKh2RxatOM+Jr6a9F7WbS9WgKbocyUSeLmZl8evAse7y96Ae98L2k1cBOwWD8nHw== +rollup@^2.60.0: + version "2.60.0" + resolved "https://registry.yarnpkg.com/rollup/-/rollup-2.60.0.tgz#4ee60ab7bdd0356763f87d7099f413e5460fc193" + integrity sha512-cHdv9GWd58v58rdseC8e8XIaPUo8a9cgZpnCMMDGZFDZKEODOiPPEQFXLriWr/TjXzhPPmG5bkAztPsOARIcGQ== optionalDependencies: fsevents "~2.3.2" @@ -13749,6 +13795,13 @@ rxjs@^6.6.7: dependencies: tslib "^1.9.0" +rxjs@^7.4.0: + version "7.4.0" + resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-7.4.0.tgz#a12a44d7eebf016f5ff2441b87f28c9a51cebc68" + integrity sha512-7SQDi7xeTMCJpqViXh8gL/lebcwlp3d831F05+9B44A4B0WfsEwUQHR64gsH1kvJ+Ep/J9K2+n1hVl1CsGN23w== + dependencies: + tslib "~2.1.0" + safe-buffer@5.1.1: version "5.1.1" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.1.tgz#893312af69b2123def71f57889001671eeb2c853" @@ -13909,11 +13962,6 @@ scroll-into-view-if-needed@^2.2.25: dependencies: compute-scroll-into-view "^1.0.17" -semver-compare@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/semver-compare/-/semver-compare-1.0.0.tgz#0dee216a1c941ab37e9efb1788f6afc5ff5537fc" - integrity sha1-De4hahyUGrN+nvsXiPavxf9VN/w= - "semver@2 || 3 || 4 || 5", semver@^5.4.1, semver@^5.5.0, semver@^5.6.0: version "5.7.1" resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" @@ -14116,6 +14164,14 @@ slice-ansi@^4.0.0: astral-regex "^2.0.0" is-fullwidth-code-point "^3.0.0" +slice-ansi@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-5.0.0.tgz#b73063c57aa96f9cd881654b15294d95d285c42a" + integrity sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ== + dependencies: + ansi-styles "^6.0.0" + is-fullwidth-code-point "^4.0.0" + snapdragon-node@^2.0.1: version "2.1.1" resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b" @@ -14462,7 +14518,16 @@ string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0: is-fullwidth-code-point "^3.0.0" strip-ansi "^6.0.0" -"string.prototype.matchall@^4.0.0 || ^3.0.1", string.prototype.matchall@^4.0.5: +string-width@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-5.0.1.tgz#0d8158335a6cfd8eb95da9b6b262ce314a036ffd" + integrity sha512-5ohWO/M4//8lErlUUtrFy3b11GtNOuMOU0ysKCDXFcfXuuvUXu95akgj/i8ofmaGdN0hCqyl6uu9i8dS/mQp5g== + dependencies: + emoji-regex "^9.2.2" + is-fullwidth-code-point "^4.0.0" + strip-ansi "^7.0.1" + +"string.prototype.matchall@^4.0.0 || ^3.0.1": version "4.0.5" resolved "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.5.tgz#59370644e1db7e4c0c045277690cf7b01203c4da" integrity sha512-Z5ZaXO0svs0M2xd/6By3qpeKpLKd9mO4v4q3oMEQrk8Ck4xOD5d5XeBOOjGrmVZZ/AHB1S0CgG4N5r1G9N3E2Q== @@ -14476,6 +14541,20 @@ string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0: regexp.prototype.flags "^1.3.1" side-channel "^1.0.4" +string.prototype.matchall@^4.0.6: + version "4.0.6" + resolved "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.6.tgz#5abb5dabc94c7b0ea2380f65ba610b3a544b15fa" + integrity sha512-6WgDX8HmQqvEd7J+G6VtAahhsQIssiZ8zl7zKh1VDMFyL3hRTJP4FTNA3RbIp2TOQ9AYNDcc7e3fH0Qbup+DBg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + get-intrinsic "^1.1.1" + has-symbols "^1.0.2" + internal-slot "^1.0.3" + regexp.prototype.flags "^1.3.1" + side-channel "^1.0.4" + string.prototype.padend@^3.0.0: version "3.1.2" resolved "https://registry.yarnpkg.com/string.prototype.padend/-/string.prototype.padend-3.1.2.tgz#6858ca4f35c5268ebd5e8615e1327d55f59ee311" @@ -14524,15 +14603,6 @@ string_decoder@~1.1.1: dependencies: safe-buffer "~5.1.0" -stringify-object@3.3.0: - version "3.3.0" - resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" - integrity sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw== - dependencies: - get-own-enumerable-property-symbols "^3.0.0" - is-obj "^1.0.1" - is-regexp "^1.0.0" - strip-ansi@6.0.0, strip-ansi@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" @@ -14561,6 +14631,13 @@ strip-ansi@^5.1.0: dependencies: ansi-regex "^4.1.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-ansi@^7.0.1: version "7.0.1" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-7.0.1.tgz#61740a08ce36b61e50e65653f07060d000975fb2" @@ -14685,12 +14762,12 @@ stylus@^0.54.8: semver "^6.3.0" source-map "^0.7.3" -supports-color@8.1.1, supports-color@^8.0.0, supports-color@^8.1.1: - version "8.1.1" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" - integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== +supports-color@9.0.2: + version "9.0.2" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-9.0.2.tgz#50f082888e4b0a4e2ccd2d0b4f9ef4efcd332485" + integrity sha512-ii6tc8ImGFrgMPYq7RVAMKkhPo9vk8uA+D3oKbJq/3Pk2YSMv1+9dUAesa9UxMbxBTvxwKTQffBahNVNxEvM8Q== dependencies: - has-flag "^4.0.0" + has-flag "^5.0.0" supports-color@^3.2.3: version "3.2.3" @@ -14720,6 +14797,13 @@ supports-color@^7.0.0, supports-color@^7.1.0: dependencies: has-flag "^4.0.0" +supports-color@^8.0.0, supports-color@^8.1.1: + version "8.1.1" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" + integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== + dependencies: + has-flag "^4.0.0" + supports-hyperlinks@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz#4f77b42488765891774b70c79babd87f9bd594bb" @@ -14774,18 +14858,6 @@ symbol.prototype.description@^1.0.0: has-symbols "^1.0.1" object.getownpropertydescriptors "^2.1.2" -table@^6.0.9: - version "6.7.1" - resolved "https://registry.yarnpkg.com/table/-/table-6.7.1.tgz#ee05592b7143831a8c94f3cee6aae4c1ccef33e2" - integrity sha512-ZGum47Yi6KOOFDE8m223td53ath2enHcYLgOCjGr5ngu8bdIARQk6mN/wRMv4yMRcHnCSnHbCEha4sobQx5yWg== - dependencies: - ajv "^8.0.1" - lodash.clonedeep "^4.5.0" - lodash.truncate "^4.4.2" - slice-ansi "^4.0.0" - string-width "^4.2.0" - strip-ansi "^6.0.0" - tapable@^1.0.0, tapable@^1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/tapable/-/tapable-1.1.3.tgz#a1fccc06b58db61fd7a45da2da44f5f3a3e67ba2" @@ -15114,6 +15186,11 @@ tslib@^2.3.1: resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.3.1.tgz#e8a335add5ceae51aa261d32a490158ef042ef01" integrity sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw== +tslib@~2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.1.0.tgz#da60860f1c2ecaa5703ab7d39bc05b6bf988b97a" + integrity sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A== + tsutils@^3.21.0: version "3.21.0" resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623"