Procházet zdrojové kódy

Secure routes

pull/134/head
unknown před 3 roky
rodič
revize
47656eac23

+ 23
- 0
src/assets/styles/components/_patterns.scss Zobrazit soubor

@@ -308,6 +308,21 @@
height: 12px;
}

.pattern-details-card-sub-card-message-pattern {
display: flex;
flex-direction: column;
height: 256px !important;
border: 2px solid#ccc !important;
background:rgb(224, 224, 224) !important;
border-radius: 6px;
padding: 1rem;
}

.pattern-details-card-sub-card-message-pattern ul {
list-style: disc;
padding: 1rem 2rem;
}

.pattern-details-card-sub-card-message-pattern textarea {
resize: none;
width: 100%;
@@ -397,6 +412,10 @@
margin-bottom: 9px;
}

.add-pattern-modal-form-control .tox {
height: 300px !important;
}

.add-pattern-modal-form-control label {
font-family: "Source Sans Pro";
font-style: normal;
@@ -497,6 +516,10 @@
margin-bottom: 9px;
}

.edit-pattern-modal-form-control .tox {
height: 300px !important;
}

.edit-pattern-modal-form-control label {
font-family: "Source Sans Pro";
font-style: normal;

+ 1
- 1
src/constants/pages.js Zobrazit soubor

@@ -12,7 +12,7 @@ export const CANDIDATES_DETAILS_PAGE = '/candidates/:id';
export const FORGOT_PASSWORD_CONFIRMATION_PAGE = '/forgot-password-confirmation';
export const RESET_PASSWORD_PAGE = '/reset-password';
export const SELECTION_PROCESS_PAGE = '/selectionFlow';
export const SELECTION_PROCESS_OF_APPLICANT_PAGE = '/selectionflow/:id';
export const SELECTION_PROCESS_OF_APPLICANT_PAGE = '/selectionFlow/:id';
export const PATTERNS_PAGE = '/patterns';
export const PATTERN_DETAILS_PAGE = '/patterns/:id';
export const SCHEDULE_PAGE = '/schedule'

+ 4
- 1
src/pages/PatternsPage/PatternDetailsPage.js Zobrazit soubor

@@ -16,6 +16,7 @@ import { setPatternApplicantsReq } from "../../store/actions/patternApplicants/p
import { selectPatternApplicants } from "../../store/selectors/patternApplicants";
import { PATTERNS_PAGE } from "../../constants/pages";
import { useHistory } from "react-router-dom";
import parse from "html-react-parser";

const PatternDetailsPage = () => {
const [emails, setEmails] = useState([]);
@@ -160,7 +161,9 @@ const PatternDetailsPage = () => {
<p>Teskt poruke</p>
</div>
<div className="pattern-details-card-sub-card-message-pattern">
<textarea disabled value={pattern.message}></textarea>
{/* <textarea disabled value={pattern.message}></textarea> */}
{console.log(pattern.message)}
{parse(pattern.message)}
</div>
</div>


+ 35
- 11
src/pages/PatternsPage/PatternsPage.js Zobrazit soubor

@@ -1,4 +1,4 @@
import React, { useState, useEffect } from "react";
import React, { useState, useEffect, useRef } from "react";
import PropTypes from "prop-types";
import FilterButton from "../../components/Button/FilterButton";
import { useTheme } from "@mui/system";
@@ -18,6 +18,7 @@ import { createPatternReq } from "../../store/actions/createPattern/createPatter
import { updatePatternReq } from "../../store/actions/updatePattern/updatePatternActions";
import PatternFilters from "../../components/Patterns/PatternFilters";
import IconButton from "../../components/IconButton/IconButton";
import { Editor } from "@tinymce/tinymce-react";

const PatternsPage = ({ history }) => {
const theme = useTheme();
@@ -29,11 +30,12 @@ const PatternsPage = ({ history }) => {
const [editPattern, setEditPattern] = useState(null);
const [addPatternTitle, setAddPatternTitle] = useState("");
const [addPatternCategory, setAddPatternCategory] = useState(1);
const [addPatternMessage, setAddPatternMessage] = useState("");
const [selectionLevelFilter, setSelectionLevelFilter] = useState([]);
const patterns = useSelector(selectPatterns);
const processes = useSelector(selectProcesses);
const dispatch = useDispatch();
const addPatternEditor = useRef();
const editPatternEditor = useRef();

useEffect(() => {
dispatch(setPatternsReq());
@@ -78,7 +80,10 @@ const PatternsPage = ({ history }) => {
const submitAddPatternHandler = (e) => {
e.preventDefault();

if (addPatternTitle.length === 0 || addPatternMessage.length === 0) {
if (
addPatternTitle.length === 0 ||
addPatternEditor.current.getContent().length === 0
) {
return;
}

@@ -86,24 +91,34 @@ const PatternsPage = ({ history }) => {
createPatternReq({
title: addPatternTitle,
selectionLevelId: addPatternCategory,
message: addPatternMessage,
message: addPatternEditor.current.getContent(),
})
);

setOpenAddPatternModal(false);
setAddPatternTitle("");
setAddPatternCategory(processes[0].id);
setAddPatternMessage("");
};

const submitEditPatternHandler = (e) => {
e.preventDefault();

if (editPattern.title.length === 0 || editPattern.message.length === 0) {
if (
editPattern.title.length === 0 ||
editPatternEditor.current.getContent() === 0
) {
return;
}

dispatch(updatePatternReq(editPattern));
dispatch(
updatePatternReq({
id: editPattern.id,
title: editPattern.title,
createdAt: editPattern.createdAt,
selectionLevelId: editPattern.selectionLevelId,
message: editPatternEditor.current.getContent(),
})
);

setOpenEditPatternModal(false);
};
@@ -241,7 +256,11 @@ const PatternsPage = ({ history }) => {
</div>
<div className="add-pattern-modal-form-control">
<label>Tekst poruke</label>
<textarea
<Editor
onInit={(evt, editor) => (addPatternEditor.current = editor)}
style={{ height: "100px !important" }}
/>
{/* <textarea
rows="11"
value={addPatternMessage}
onChange={(e) => {
@@ -251,7 +270,7 @@ const PatternsPage = ({ history }) => {
setAddPatternMessage(e.target.value);
}
}}
></textarea>
></textarea> */}
</div>
<div className="add-pattern-modal-form-control">
<input type="submit" value="DODAJ ŠABLON" />
@@ -319,7 +338,12 @@ const PatternsPage = ({ history }) => {
</div>
<div className="edit-pattern-modal-form-control">
<label>Tekst poruke</label>
<textarea
<Editor
initialValue={editPattern ? editPattern.message : ""}
onInit={(evt, editor) => (editPatternEditor.current = editor)}
style={{ height: "100px !important" }}
/>
{/* <textarea
rows="11"
onChange={(e) =>
setEditPattern((oldState) => ({
@@ -328,7 +352,7 @@ const PatternsPage = ({ history }) => {
}))
}
value={editPattern ? editPattern.message : ""}
></textarea>
></textarea> */}
</div>
<div className="edit-pattern-modal-form-control">
<input type="submit" value="UREDI ŠABLON" />

+ 1
- 1
src/pages/SelectionProcessPage/SelectionProcessOfApplicantPage.js Zobrazit soubor

@@ -200,7 +200,7 @@ const SelectionProcessOfApplicantPage = () => {
</div>
</div>
<div className="add-ad">
<Link className="ad-details-buttons-link" to="/selectionflow">
<Link className="ad-details-buttons-link" to="/selectionFlow">
Nazad na sve kandidate
</Link>
</div>

+ 25
- 10
src/store/saga/adsSaga.js Zobrazit soubor

@@ -28,9 +28,9 @@ import {
setCreateAd,
setCreateAdError,
} from "../actions/createAd/createAdActions";
// import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
// import { JWT_TOKEN } from "../../constants/localStorage";
// import { addHeaderToken } from "../../request";
import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
import { JWT_TOKEN } from "../../constants/localStorage";
import { addHeaderToken } from "../../request";
import { rejectErrorCodeHelper } from "../../util/helpers/rejectErrorCodeHelper";
import {
archiveActiveAd,
@@ -39,42 +39,56 @@ import {

export function* getAds() {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAllAds);
yield put(setAds(result.data));
} catch (error) {
yield put(setAdsError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setAdsError(errorMessage));
}
}

export function* getFilteredAds({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAllFilteredAds, payload);
yield put(setFilteredAds(result.data));
} catch (error) {
yield put(setFilteredAdsError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setFilteredAdsError(errorMessage));
}
}

export function* getAd({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAdDetailsById, payload.id);
yield put(setAd(result.data));
} catch (error) {
yield put(setAdError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setAdError(errorMessage));
}
}

export function* getArchiveAds() {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAllArchiveAds);
yield put(setArchiveAds(result.data));
} catch (error) {
yield put(setArchiveAdsError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setArchiveAdsError(errorMessage));
}
}

export function* createAd({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(createNewAd, payload);
const ad = result.data;
yield put(setCreateAd(ad));
@@ -86,14 +100,15 @@ export function* createAd({ payload }) {
yield call(payload.onSuccessAddAd);
}
} catch (error) {
yield put(setCreateAdError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setCreateAdError(errorMessage));
}
}

export function* archiveActiveAdSaga({ payload }) {
try {
// const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
// yield call(addHeaderToken, JwtToken);
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const { data } = yield call(archiveActiveAdRequest, payload);
yield put(archiveActiveAd(data));
const resultAds = yield call(getAllAds);

+ 5
- 5
src/store/saga/applicantsSaga.js Zobrazit soubor

@@ -1,8 +1,8 @@
import { all, call, put, takeEvery } from "redux-saga/effects";
// import { JWT_TOKEN } from "../../constants/localStorage";
// import { addHeaderToken } from "../../request";
import { JWT_TOKEN } from "../../constants/localStorage";
import { addHeaderToken } from "../../request";
import { applyForAdRequest } from "../../request/applicantRequest";
// import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
import { rejectErrorCodeHelper } from "../../util/helpers/rejectErrorCodeHelper";
import { APPLY_FOR_AD_REQ } from "../actions/applyForAd/applyForAdActionConstants";
import {
@@ -12,8 +12,8 @@ import {

export function* applyForAdSaga({ payload }) {
try {
// const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
// yield call(addHeaderToken, JwtToken);
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const formData = new FormData();
formData.append("adId", payload.adId);
formData.append("firstName", payload.firstName);

+ 6
- 1
src/store/saga/candidatesSaga.js Zobrazit soubor

@@ -106,8 +106,9 @@ export function* getAdsCandidates({ payload }) {
}

export function* deleteSingleCandidate({ payload }) {
// console.log(payload)
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
yield call(deleteCandidate, payload.id);
if (payload.handleApiResponseSuccess) {
yield call(payload.handleApiResponseSuccess);
@@ -123,6 +124,8 @@ export function* deleteSingleCandidate({ payload }) {

export function* getOptions() {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const { data } = yield call(getCandidateOptions);
yield put(fetchCandidateOptionsSuccess(data));
} catch (error) {
@@ -135,6 +138,8 @@ export function* getOptions() {

export function* initializeProcess({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
yield call(initializeProcessRequest, payload.model);
yield put(fetchInitProcessSuccess());
} catch (error) {

+ 25
- 13
src/store/saga/patternsSaga.js Zobrazit soubor

@@ -30,9 +30,9 @@ import {
updatePattern,
updatePatternError,
} from "../actions/updatePattern/updatePatternActions";
// import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
// import { JWT_TOKEN } from "../../constants/localStorage";
// import { addHeaderToken } from "../../request";
import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
import { JWT_TOKEN } from "../../constants/localStorage";
import { addHeaderToken } from "../../request";
import { rejectErrorCodeHelper } from "../../util/helpers/rejectErrorCodeHelper";
import { SCHEDULE_APPOINTMENT_REQ } from "../actions/scheduleAppointment/scheduleAppointmentActionConstants";
import { scheduleAppointment } from "../actions/scheduleAppointment/scheduleAppointmentActions";
@@ -41,26 +41,32 @@ import { setPatternApplicants } from "../actions/patternApplicants/patternApplic

export function* getPatterns() {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAllPatterns);
yield put(setPatterns(result.data));
} catch (error) {
yield put(setPatternsError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setPatternsError(errorMessage));
}
}

export function* getPattern({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getPatternById, payload.id);
yield put(setPattern(result.data));
} catch (error) {
yield put(setPatternError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setPatternError(errorMessage));
}
}

export function* getPatternApplicants({ payload }) {
try {
// const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
// yield call(addHeaderToken, JwtToken);
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getPatternApplicantsById, payload.id);
yield put(setPatternApplicants(result.data));
} catch (error) {
@@ -71,8 +77,8 @@ export function* getPatternApplicants({ payload }) {

export function* filterPatterns({ payload }) {
try {
// const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
// yield call(addHeaderToken, JwtToken);
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const { data } = yield call(getFilteredPatterns, payload);
yield put(setFilteredPatterns(data));
if (payload.handleApiResponseSuccess) {
@@ -86,30 +92,36 @@ export function* filterPatterns({ payload }) {

export function* createPatternSaga({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(createPatternRequest, payload);
yield put(createPattern(result.data));
const resultPatterns = yield call(getAllPatterns);
yield put(setPatterns(resultPatterns.data));
} catch (error) {
yield put(createPatternError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(createPatternError(errorMessage));
}
}

export function* updatePatternSaga({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(updatePatternRequest, payload);
yield put(updatePattern(result.data));
const resultPatterns = yield call(getAllPatterns);
yield put(setPatterns(resultPatterns.data));
} catch (error) {
yield put(updatePatternError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(updatePatternError(errorMessage));
}
}

export function* scheduleAppointmentSaga({ payload }) {
try {
// const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
// yield call(addHeaderToken, JwtToken);
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const { data } = yield call(scheduleAppointmentRequest, payload);
yield put(scheduleAppointment(data));
if (payload.handleApiResponseSuccess) {

+ 2
- 3
src/store/saga/processSaga.js Zobrazit soubor

@@ -52,9 +52,8 @@ export function* getProcesses() {

export function* getFilteredProcesses(payload) {
try {
// const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
// yield call(addHeaderToken, JwtToken);
// console.log(payload.payload)
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAllFilteredProcessesReq, payload.payload);
yield put(setProcesses(result.data));
} catch (error) {

+ 5
- 1
src/store/saga/scheduleSaga.js Zobrazit soubor

@@ -1,7 +1,9 @@
import { all, call, put, takeEvery } from "redux-saga/effects";
import { getSpecificSchedule } from "../../request/scheduleRequest";
import { rejectErrorCodeHelper } from "../../util/helpers/rejectErrorCodeHelper";
import { SCHEDULE_FETCH } from "../actions/schedule/scheduleActionConstants";
import { SCHEDULE_FETCH } from "../actions/schedule/scheduleActionConstants";import { addHeaderToken } from "../../request";
import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
import { JWT_TOKEN } from "../../constants/localStorage";
import {
fetchScheduleSuccess,
fetchScheduleError,
@@ -9,6 +11,8 @@ import {

export function* getSchedule({ payload }) {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getSpecificSchedule, {month:payload.month, year:payload.year});
yield put(fetchScheduleSuccess(result.data));
} catch (error) {

+ 9
- 1
src/store/saga/technologiesSaga.js Zobrazit soubor

@@ -7,10 +7,15 @@ import {
setTechnologies,
setTechnologiesError,
} from "../actions/technologies/technologiesActions";
import { JWT_TOKEN } from "../../constants/localStorage";
import { addHeaderToken } from "../../request";
import { authScopeStringGetHelper } from "../../util/helpers/authScopeHelpers";
import { rejectErrorCodeHelper } from "../../util/helpers/rejectErrorCodeHelper";

export function* getTechnologies() {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAllTechnologies);
const resultData = result.data.map((res) => ({ ...res, isChecked: false }));
yield put(setTechnologies(resultData));
@@ -24,11 +29,14 @@ export function* getTechnologies() {

export function* getTechnologiesAddAd() {
try {
const JwtToken = yield call(authScopeStringGetHelper, JWT_TOKEN);
yield call(addHeaderToken, JwtToken);
const result = yield call(getAllTechnologies);
const resultData = result.data.map((res) => ({ ...res, isChecked: false }));
yield put(setTechnologiesAddAd(resultData));
} catch (error) {
yield put(setTechnologiesError(error));
const errorMessage = yield call(rejectErrorCodeHelper, error);
yield put(setTechnologiesError(errorMessage));
}
}


+ 53
- 68
yarn.lock Zobrazit soubor

@@ -28,7 +28,7 @@
"resolved" "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.14.4.tgz"
"version" "7.14.4"

"@babel/core@^7.0.0", "@babel/core@^7.0.0-0", "@babel/core@^7.1.0", "@babel/core@^7.12.0", "@babel/core@^7.12.3", "@babel/core@^7.13.0", "@babel/core@^7.4.0-0", "@babel/core@^7.7.5", "@babel/core@^7.8.4", "@babel/core@7 || ^7.0.0-rc.2":
"@babel/core@^7.1.0", "@babel/core@^7.12.3", "@babel/core@^7.7.5", "@babel/core@^7.8.4":
"integrity" "sha512-jB5AmTKOCSJIZ72sd78ECEhuPiDMKlQdDI/4QRI6lzYATx5SSogS1oQA2AoPecRCknm30gHi2l+QVvNUu3wZAg=="
"resolved" "https://registry.npmjs.org/@babel/core/-/core-7.14.3.tgz"
"version" "7.14.3"
@@ -1346,7 +1346,7 @@
"resolved" "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.8.0.tgz"
"version" "0.8.0"

"@emotion/react@^11.0.0-rc.0", "@emotion/react@^11.1.1", "@emotion/react@^11.4.1", "@emotion/react@^11.5.0", "@emotion/react@^11.9.0":
"@emotion/react@^11.1.1", "@emotion/react@^11.5.0":
"integrity" "sha512-j0AkMpr6BL8gldJZ6XQsQ8DnS9TxEQu1R+OGmDZiWjBAJtCcbt0tS3I/YffoqHXxH6MjgI7KdMbYKw3MEiU9eA=="
"resolved" "https://registry.npmjs.org/@emotion/react/-/react-11.10.4.tgz"
"version" "11.10.4"
@@ -1376,7 +1376,7 @@
"resolved" "https://registry.npmjs.org/@emotion/sheet/-/sheet-1.2.0.tgz"
"version" "1.2.0"

"@emotion/styled@^11.3.0", "@emotion/styled@^11.8.1":
"@emotion/styled@^11.3.0":
"integrity" "sha512-pRl4R8Ez3UXvOPfc2bzIoV8u9P97UedgHS4FPX594ntwEuAMA114wlaHvOK24HB48uqfXiGlYIZYCxVJ1R1ttQ=="
"resolved" "https://registry.npmjs.org/@emotion/styled/-/styled-11.10.4.tgz"
"version" "11.10.4"
@@ -1682,7 +1682,7 @@
dependencies:
"@babel/runtime" "^7.19.0"

"@mui/material@^5.0.0", "@mui/material@^5.0.6", "@mui/material@^5.4.1":
"@mui/material@^5.0.6":
"integrity" "sha512-ioLvqY7VvcePz9dnEIRhpiVvtJmAFmvG6rtLXXzVdMmAVbSaelr5Io07mPz/mCyqE+Uv8/4EuJV276DWO7etzA=="
"resolved" "https://registry.npmjs.org/@mui/material/-/material-5.10.10.tgz"
"version" "5.10.10"
@@ -1719,7 +1719,7 @@
"csstype" "^3.1.1"
"prop-types" "^15.8.1"

"@mui/system@^5.10.10", "@mui/system@^5.4.1":
"@mui/system@^5.10.10":
"integrity" "sha512-TXwtKN0adKpBrZmO+eilQWoPf2veh050HLYrN78Kps9OhlvO70v/2Kya0+mORFhu9yhpAwjHXO8JII/R4a5ZLA=="
"resolved" "https://registry.npmjs.org/@mui/system/-/system-5.10.10.tgz"
"version" "5.10.10"
@@ -2043,7 +2043,7 @@
dependencies:
"defer-to-connect" "^1.0.1"

"@testing-library/dom@^8.0.0", "@testing-library/dom@>=7.21.4":
"@testing-library/dom@^8.0.0":
"integrity" "sha512-6YWYPPpxG3e/xOo6HIWwB/58HukkwIVTOaZ0VwdMVjhRUX/01E4FtQbck9GazOOj7MXHc5RBzMrU86iBJHbI+A=="
"resolved" "https://registry.npmjs.org/@testing-library/dom/-/dom-8.19.0.tgz"
"version" "8.19.0"
@@ -2292,7 +2292,7 @@
dependencies:
"@types/react" "*"

"@types/react@*", "@types/react@^17.0.0 || ^18.0.0":
"@types/react@*":
"integrity" "sha512-7QUCOxvFgnD5Jk8ZKlUAhVcRj7GuJRjnjjiY/IUBWKgOlnvDvTMLD4RTF7NPyVmbRhNrbomZiOepg7M/2Kj1mA=="
"resolved" "https://registry.npmjs.org/@types/react/-/react-18.0.21.tgz"
"version" "18.0.21"
@@ -2360,7 +2360,7 @@
"@types/source-list-map" "*"
"source-map" "^0.7.3"

"@types/webpack@^4.41.8", "@types/webpack@4.x":
"@types/webpack@^4.41.8":
"integrity" "sha512-6pLaORaVNZxiB3FSHbyBiWM7QdazAWda1zvAq4SbZObZqHSDbWLi62iFdblVea6SK9eyBIVp5yHhKt/yNQdR7Q=="
"resolved" "https://registry.npmjs.org/@types/webpack/-/webpack-4.41.29.tgz"
"version" "4.41.29"
@@ -2384,7 +2384,7 @@
dependencies:
"@types/yargs-parser" "*"

"@typescript-eslint/eslint-plugin@^4.0.0", "@typescript-eslint/eslint-plugin@^4.5.0", "@typescript-eslint/eslint-plugin@>= 4":
"@typescript-eslint/eslint-plugin@^4.5.0":
"integrity" "sha512-yA7IWp+5Qqf+TLbd8b35ySFOFzUfL7i+4If50EqvjT6w35X8Lv0eBHb6rATeWmucks37w+zV+tWnOXI9JlG6Eg=="
"resolved" "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-4.26.0.tgz"
"version" "4.26.0"
@@ -2421,7 +2421,7 @@
"eslint-scope" "^5.1.1"
"eslint-utils" "^3.0.0"

"@typescript-eslint/parser@^4.0.0", "@typescript-eslint/parser@^4.5.0":
"@typescript-eslint/parser@^4.5.0":
"integrity" "sha512-b4jekVJG9FfmjUfmM4VoOItQhPlnt6MPOBUL0AQbiTmm+SSpSdhHYlwayOm4IW9KLI/4/cRKtQCmDl1oE2OlPg=="
"resolved" "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-4.26.0.tgz"
"version" "4.26.0"
@@ -2677,16 +2677,16 @@
"resolved" "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz"
"version" "7.2.0"

"acorn@^6.0.0 || ^7.0.0 || ^8.0.0", "acorn@^7.1.0", "acorn@^7.1.1", "acorn@^7.4.0":
"integrity" "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A=="
"resolved" "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz"
"version" "7.4.1"

"acorn@^6.4.1":
"integrity" "sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ=="
"resolved" "https://registry.npmjs.org/acorn/-/acorn-6.4.2.tgz"
"version" "6.4.2"

"acorn@^7.1.0", "acorn@^7.1.1", "acorn@^7.4.0":
"integrity" "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A=="
"resolved" "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz"
"version" "7.4.1"

"acorn@^8.2.4":
"integrity" "sha512-tqPKHZ5CaBJw0Xmy0ZZvLs1qTV+BNFSyvn77ASXkpBNfIRk8ev26fKrD9iLGwGA9zedPao52GSHzq8lyZG0NUw=="
"resolved" "https://registry.npmjs.org/acorn/-/acorn-8.3.0.tgz"
@@ -2730,7 +2730,7 @@
"resolved" "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz"
"version" "3.5.2"

"ajv@^6.1.0", "ajv@^6.10.0", "ajv@^6.10.2", "ajv@^6.12.4", "ajv@^6.12.5", "ajv@^6.9.1", "ajv@>=5.0.0":
"ajv@^6.1.0", "ajv@^6.10.0", "ajv@^6.10.2", "ajv@^6.12.4", "ajv@^6.12.5":
"integrity" "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g=="
"resolved" "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz"
"version" "6.12.6"
@@ -3058,7 +3058,7 @@
"resolved" "https://registry.npmjs.org/axobject-query/-/axobject-query-2.2.0.tgz"
"version" "2.2.0"

"babel-eslint@^10.0.0", "babel-eslint@^10.1.0":
"babel-eslint@^10.1.0":
"integrity" "sha512-ifWaTHQ0ce+448CYop8AdrQiBsGrnC+bMgfyKFdi6EsPLTAWG+QfyDeM6OH+FmWnKvEq5NnBMLvlBUPKQZoDSg=="
"resolved" "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.1.0.tgz"
"version" "10.1.0"
@@ -3489,7 +3489,7 @@
dependencies:
"pako" "~1.0.5"

"browserslist@^4", "browserslist@^4.0.0", "browserslist@^4.12.0", "browserslist@^4.16.6", "browserslist@^4.6.2", "browserslist@^4.6.4":
"browserslist@^4.0.0", "browserslist@^4.12.0", "browserslist@^4.16.6", "browserslist@^4.6.2", "browserslist@^4.6.4":
"integrity" "sha512-Wspk/PqO+4W9qp5iUTJsa1B/QrYn1keNCcEP5OvP7WBwT4KaDly0uONYmC6Xa3Z5IqnUgS0KcgLYu1l74x0ZXQ=="
"resolved" "https://registry.npmjs.org/browserslist/-/browserslist-4.16.6.tgz"
"version" "4.16.6"
@@ -4546,7 +4546,7 @@
"whatwg-mimetype" "^2.3.0"
"whatwg-url" "^8.0.0"

"date-fns@^2.0.0", "date-fns@^2.25.0", "date-fns@^2.29.3":
"date-fns@^2.29.3":
"integrity" "sha512-dDCnyH2WnnKusqvZZ6+jA1O51Ibt8ZMRNkDZdyAyK4YfbDwa/cEmuztzG5pk6hqlp9aSBPYcjOlktquahGwGeA=="
"resolved" "https://registry.npmjs.org/date-fns/-/date-fns-2.29.3.tgz"
"version" "2.29.3"
@@ -5320,7 +5320,7 @@
"lodash" "^4.17.15"
"string-natural-compare" "^3.0.1"

"eslint-plugin-import@^2.22.0", "eslint-plugin-import@^2.22.1", "eslint-plugin-import@^2.23.4":
"eslint-plugin-import@^2.22.1", "eslint-plugin-import@^2.23.4":
"integrity" "sha512-6/wP8zZRsnQFiR3iaPFgh5ImVRM1WN5NUWfTIRqwOdeiGJlBcSk82o1FEVq8yXmy4lkIzTo7YhHCIxlU/2HyEQ=="
"resolved" "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.23.4.tgz"
"version" "2.23.4"
@@ -5341,7 +5341,7 @@
"resolve" "^1.20.0"
"tsconfig-paths" "^3.9.0"

"eslint-plugin-jest@^24.0.0", "eslint-plugin-jest@^24.1.0":
"eslint-plugin-jest@^24.1.0":
"integrity" "sha512-WOVH4TIaBLIeCX576rLcOgjNXqP+jNlCiEmRgFTfQtJ52DpwnIQKAVGlGPAN7CZ33bW6eNfHD6s8ZbEUTQubJg=="
"resolved" "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-24.3.6.tgz"
"version" "24.3.6"
@@ -5372,12 +5372,12 @@
dependencies:
"prettier-linter-helpers" "^1.0.0"

"eslint-plugin-react-hooks@^4 || ^3 || ^2.3.0 || ^1.7.0", "eslint-plugin-react-hooks@^4.0.8", "eslint-plugin-react-hooks@^4.2.0":
"eslint-plugin-react-hooks@^4.2.0":
"integrity" "sha512-623WEiZJqxR7VdxFCKLI6d6LLpwJkGPYKODnkH3D7WpOG5KM8yWueBd8TLsNAetEJNF5iJmolaAKO3F8yzyVBQ=="
"resolved" "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.2.0.tgz"
"version" "4.2.0"

"eslint-plugin-react@^7.20.3", "eslint-plugin-react@^7.21.5", "eslint-plugin-react@^7.24.0":
"eslint-plugin-react@^7.21.5", "eslint-plugin-react@^7.24.0":
"integrity" "sha512-KJJIx2SYx7PBx3ONe/mEeMz4YE0Lcr7feJTCMyyKb/341NcjuAgim3Acgan89GfPv7nxXK2+0slu0CWXYM4x+Q=="
"resolved" "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.24.0.tgz"
"version" "7.24.0"
@@ -5402,7 +5402,7 @@
dependencies:
"safe-regex" "^1.1.0"

"eslint-plugin-testing-library@^3.9.0", "eslint-plugin-testing-library@^3.9.2":
"eslint-plugin-testing-library@^3.9.2":
"integrity" "sha512-WAmOCt7EbF1XM8XfbCKAEzAPnShkNSwcIsAD2jHdsMUT9mZJPjLCG7pMzbcC8kK366NOuGip8HKLDC+Xk4yIdA=="
"resolved" "https://registry.npmjs.org/eslint-plugin-testing-library/-/eslint-plugin-testing-library-3.10.2.tgz"
"version" "3.10.2"
@@ -5478,7 +5478,7 @@
"normalize-path" "^3.0.0"
"schema-utils" "^3.0.0"

"eslint@*", "eslint@^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0", "eslint@^3 || ^4 || ^5 || ^6 || ^7", "eslint@^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0", "eslint@^5 || ^6 || ^7", "eslint@^5.0.0 || ^6.0.0 || ^7.0.0", "eslint@^5.16.0 || ^6.8.0 || ^7.2.0", "eslint@^7.0.0", "eslint@^7.1.0", "eslint@^7.11.0", "eslint@^7.28.0", "eslint@^7.5.0", "eslint@>= 4.12.1", "eslint@>=5", "eslint@>=5.0.0", "eslint@>=7.0.0":
"eslint@^7.11.0", "eslint@^7.28.0":
"integrity" "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA=="
"resolved" "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz"
"version" "7.32.0"
@@ -5825,7 +5825,7 @@
dependencies:
"flat-cache" "^3.0.4"

"file-loader@*", "file-loader@6.1.1":
"file-loader@6.1.1":
"integrity" "sha512-Klt8C4BjWSXYQAfhpYYkG4qHNTna4toMHEbWrI5IuVoxbU6uiDKeKAP99R8mmbJi3lvewn/jQBOgU4+NS3tDQw=="
"resolved" "https://registry.npmjs.org/file-loader/-/file-loader-6.1.1.tgz"
"version" "6.1.1"
@@ -6663,7 +6663,7 @@
"resolved" "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz"
"version" "1.1.1"

"i18next@^20.3.1", "i18next@>= 19.0.0":
"i18next@^20.3.1":
"integrity" "sha512-yCMYTMEJ9ihCwEQQ3phLo7I/Pwycf8uAx+sRHwwk5U9Aui/IZYgQRyMqXafQOw5QQ7DM1Z+WyEXWIqSuJHhG2A=="
"resolved" "https://registry.npmjs.org/i18next/-/i18next-20.6.1.tgz"
"version" "20.6.1"
@@ -7613,20 +7613,6 @@
"jest-regex-util" "^26.0.0"
"jest-snapshot" "^26.6.2"

"jest-resolve@*", "jest-resolve@26.6.0":
"integrity" "sha512-tRAz2bwraHufNp+CCmAD8ciyCpXCs1NQxB5EJAmtCFy6BN81loFEGWKzYu26Y62lAJJe4X4jg36Kf+NsQyiStQ=="
"resolved" "https://registry.npmjs.org/jest-resolve/-/jest-resolve-26.6.0.tgz"
"version" "26.6.0"
dependencies:
"@jest/types" "^26.6.0"
"chalk" "^4.0.0"
"graceful-fs" "^4.2.4"
"jest-pnp-resolver" "^1.2.2"
"jest-util" "^26.6.0"
"read-pkg-up" "^7.0.1"
"resolve" "^1.17.0"
"slash" "^3.0.0"

"jest-resolve@^26.6.2":
"integrity" "sha512-sOxsZOq25mT1wRsfHcbtkInS+Ek7Q8jCHUB0ZUTP0tc/c41QHriU/NunqMfCUWsL4H3MHpvQD4QR9kSYhS7UvQ=="
"resolved" "https://registry.npmjs.org/jest-resolve/-/jest-resolve-26.6.2.tgz"
@@ -7641,6 +7627,20 @@
"resolve" "^1.18.1"
"slash" "^3.0.0"

"jest-resolve@26.6.0":
"integrity" "sha512-tRAz2bwraHufNp+CCmAD8ciyCpXCs1NQxB5EJAmtCFy6BN81loFEGWKzYu26Y62lAJJe4X4jg36Kf+NsQyiStQ=="
"resolved" "https://registry.npmjs.org/jest-resolve/-/jest-resolve-26.6.0.tgz"
"version" "26.6.0"
dependencies:
"@jest/types" "^26.6.0"
"chalk" "^4.0.0"
"graceful-fs" "^4.2.4"
"jest-pnp-resolver" "^1.2.2"
"jest-util" "^26.6.0"
"read-pkg-up" "^7.0.1"
"resolve" "^1.17.0"
"slash" "^3.0.0"

"jest-runner@^26.6.0", "jest-runner@^26.6.3":
"integrity" "sha512-atgKpRHnaA2OvByG/HpGA4g6CSPS/1LK0jK3gATJAoptC1ojltpmVlYC3TYgdmGp+GLuhzpH30Gvs36szSL2JQ=="
"resolved" "https://registry.npmjs.org/jest-runner/-/jest-runner-26.6.3.tgz"
@@ -7797,7 +7797,7 @@
"merge-stream" "^2.0.0"
"supports-color" "^7.0.0"

"jest@^26.0.0", "jest@^26.6.0", "jest@26.6.0":
"jest@^26.6.0", "jest@26.6.0":
"integrity" "sha512-jxTmrvuecVISvKFFhOkjsWRZV7sFqdSUAd1ajOKY+/QE/aLBVstsJ/dX8GczLzwiT6ZEwwmZqtCUHLHHQVzcfA=="
"resolved" "https://registry.npmjs.org/jest/-/jest-26.6.0.tgz"
"version" "26.6.0"
@@ -7811,11 +7811,6 @@
"resolved" "https://registry.npmjs.org/jju/-/jju-1.4.0.tgz"
"version" "1.4.0"

"jquery@>=1.8.0":
"integrity" "sha512-/e7ulNIEEYk1Z/l4X0vpxGt+B/dNsV8ghOPAWZaJs8pkGvsSC0tm33aMGylXcj/U7y4IcvwtMXPMyBFZn/gK9A=="
"resolved" "https://registry.npmjs.org/jquery/-/jquery-3.6.2.tgz"
"version" "3.6.2"

"js-tokens@^3.0.0 || ^4.0.0", "js-tokens@^4.0.0":
"integrity" "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ=="
"resolved" "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz"
@@ -10305,7 +10300,7 @@
dependencies:
"fast-diff" "^1.1.2"

"prettier@>=1.13.0", "prettier@2.3.1":
"prettier@2.3.1":
"integrity" "sha512-p+vNbgpLjif/+D+DwAZAbndtRrR0md0MwfmOVN9N+2RgyACMT+7tfaRnT+WDPkqnuVwleyuBIG2XBxKDme3hPA=="
"resolved" "https://registry.npmjs.org/prettier/-/prettier-2.3.1.tgz"
"version" "2.3.1"
@@ -10600,7 +10595,7 @@
"strip-ansi" "6.0.0"
"text-table" "0.2.0"

"react-dom@^0.14.0 || ^15.0.1 || ^16.0.0 || ^17.0.0 || ^18.0.0", "react-dom@^16.6.0 || ^17.0.0 || ^18.0.0", "react-dom@^16.8.0 || ^17.0.0", "react-dom@^17.0.0 || ^18.0.0", "react-dom@^17.0.2", "react-dom@^17.0.2 || ^18.0.0", "react-dom@^18.0.0 || ^17.0.1 || ^16.7.0", "react-dom@<18.0.0", "react-dom@>=16.6.0", "react-dom@>=16.8.3":
"react-dom@^17.0.2":
"integrity" "sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA=="
"resolved" "https://registry.npmjs.org/react-dom/-/react-dom-17.0.2.tgz"
"version" "17.0.2"
@@ -10699,7 +10694,7 @@
"resolved" "https://registry.npmjs.org/react-property/-/react-property-2.0.0.tgz"
"version" "2.0.0"

"react-redux@^7.2.1 || ^8.0.2", "react-redux@^7.2.4":
"react-redux@^7.2.4":
"integrity" "sha512-Gx4L3uM182jEEayZfRbI/G11ZpYdNAnBs70lFVMNdHJI76XYtR+7m0MN+eAs7UHBPhWXcnFPaS+9owSCJQHNpQ=="
"resolved" "https://registry.npmjs.org/react-redux/-/react-redux-7.2.9.tgz"
"version" "7.2.9"
@@ -10711,7 +10706,7 @@
"prop-types" "^15.7.2"
"react-is" "^17.0.2"

"react-refresh@^0.8.3", "react-refresh@>=0.8.3 <0.10.0":
"react-refresh@^0.8.3":
"integrity" "sha512-X8jZHc7nCMjaCqoU+V2I0cOhNW+QMBwSUkeXnTi8IPe6zaRWfn60ZzvFDZqWPfmSJfjub7dDW1SP0jaHWLu/hg=="
"resolved" "https://registry.npmjs.org/react-refresh/-/react-refresh-0.8.3.tgz"
"version" "0.8.3"
@@ -10861,7 +10856,7 @@
"loose-envify" "^1.4.0"
"prop-types" "^15.6.2"

"react@^0.14.0 || ^15.0.1 || ^16.0.0 || ^17.0.0 || ^18.0.0", "react@^16.0.0", "react@^16.0.0 || ^17.0.0 || ^18.0.0", "react@^16.3.0 || ^17.0.0", "react@^16.6.0 || ^17.0.0 || ^18.0.0", "react@^16.8.0 || ^17.0.0", "react@^16.8.3 || ^17 || ^18", "react@^16.9.0 || ^17.0.0 || ^18", "react@^17.0.0 || ^18.0.0", "react@^17.0.2", "react@^17.0.2 || ^18.0.0", "react@^18.0.0 || ^17.0.1 || ^16.7.0", "react@^18.2.0", "react@<18.0.0", "react@>= 16", "react@>= 16.8 || 18.0.0", "react@>= 16.8.0", "react@>=15", "react@>=16.6.0", "react@>=16.8", "react@>=16.8.0", "react@>=16.8.3", "react@0.14 || 15 || 16 || 17 || 18", "react@17.0.2":
"react@^17.0.2":
"integrity" "sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA=="
"resolved" "https://registry.npmjs.org/react/-/react-17.0.2.tgz"
"version" "17.0.2"
@@ -11074,7 +11069,7 @@
"resolved" "https://registry.npmjs.org/redux-thunk/-/redux-thunk-2.4.1.tgz"
"version" "2.4.1"

"redux@^4", "redux@^4.0.0", "redux@^4.0.4", "redux@^4.1.0", "redux@^4.1.2":
"redux@^4.0.0", "redux@^4.0.4", "redux@^4.1.0", "redux@^4.1.2":
"integrity" "sha512-oSBmcKKIuIR4ME29/AeNUnl5L+hvBq7OaJWzaptTQJAntaPvxIJqfnjbaEiCzzaIz+XmVILfqAM3Ob0aXLPfjA=="
"resolved" "https://registry.npmjs.org/redux/-/redux-4.2.0.tgz"
"version" "4.2.0"
@@ -11429,7 +11424,7 @@
dependencies:
"estree-walker" "^0.6.1"

"rollup@^1.20.0 || ^2.0.0", "rollup@^1.20.0||^2.0.0", "rollup@^1.31.1", "rollup@>=0.60.0 <3", "rollup@>=0.66.0 <3":
"rollup@^1.31.1":
"integrity" "sha512-/2HA0Ec70TvQnXdzynFffkjA6XN+1e2pEv/uKS5Ulca40g2L7KuOE3riasHoNVHOsFD5KKZgDsMk1CP3Tw9s+A=="
"resolved" "https://registry.npmjs.org/rollup/-/rollup-1.32.1.tgz"
"version" "1.32.1"
@@ -11524,7 +11519,7 @@
"schema-utils" "^3.0.0"
"semver" "^7.3.2"

"sass@^1.3.0", "sass@^1.34.1":
"sass@^1.34.1":
"integrity" "sha512-Pk+PMy7OGLs9WaxZGJMn7S96dvlyVBwwtToX895WmCpAOr5YiJYEUJfiJidMuKb613z2xNWcXCHEuOvjZbqC6A=="
"resolved" "https://registry.npmjs.org/sass/-/sass-1.55.0.tgz"
"version" "1.55.0"
@@ -11893,7 +11888,7 @@
"source-map-resolve" "^0.5.0"
"use" "^3.1.0"

"sockjs-client@^1.4.0", "sockjs-client@^1.5.0":
"sockjs-client@^1.5.0":
"integrity" "sha512-VnVAb663fosipI/m6pqRXakEOw7nvd7TUgdr3PlR/8V2I95QIdwT8L4nMxhyU8SmDBHYXU1TOElaKOmKLfYzeQ=="
"resolved" "https://registry.npmjs.org/sockjs-client/-/sockjs-client-1.5.1.tgz"
"version" "1.5.1"
@@ -12753,11 +12748,6 @@
"resolved" "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz"
"version" "4.0.8"

"type-fest@^0.13.1":
"integrity" "sha512-34R7HTnG0XIJcBSn5XhDd7nNFPRcXYRZrBB2O2jdKqYODldSzBAqzsWoZYYvduky73toYS/ESqxPvkDf/F0XMg=="
"resolved" "https://registry.npmjs.org/type-fest/-/type-fest-0.13.1.tgz"
"version" "0.13.1"

"type-fest@^0.20.2":
"integrity" "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ=="
"resolved" "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz"
@@ -12832,11 +12822,6 @@
dependencies:
"typescript-compare" "^0.0.2"

"typescript@^3.2.1 || ^4", "typescript@>=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta":
"integrity" "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg=="
"resolved" "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz"
"version" "4.9.4"

"unbox-primitive@^1.0.2":
"integrity" "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw=="
"resolved" "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz"
@@ -13201,7 +13186,7 @@
"range-parser" "^1.2.1"
"webpack-log" "^2.0.0"

"webpack-dev-server@3.11.1", "webpack-dev-server@3.x":
"webpack-dev-server@3.11.1":
"integrity" "sha512-u4R3mRzZkbxQVa+MBWi2uVpB5W59H3ekZAJsQlKUTdl7Elcah2EhygTPLmeFXybQkf9i2+L0kn7ik9SnXa6ihQ=="
"resolved" "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-3.11.1.tgz"
"version" "3.11.1"
@@ -13266,7 +13251,7 @@
"source-list-map" "^2.0.0"
"source-map" "~0.6.1"

"webpack@^4.0.0", "webpack@^4.0.0 || ^5.0.0", "webpack@^4.27.0 || ^5.0.0", "webpack@^4.36.0 || ^5.0.0", "webpack@^4.4.0 || ^5.0.0", "webpack@>=2", "webpack@>=4.43.0 <6.0.0", "webpack@2 || 3 || 4", "webpack@4.44.2":
"webpack@4.44.2":
"integrity" "sha512-6KJVGlCxYdISyurpQ0IPTklv+DULv05rs2hseIXer6D7KrUicRDLFb4IUM1S6LUAKypPM/nSiVSuv8jHu1m3/Q=="
"resolved" "https://registry.npmjs.org/webpack/-/webpack-4.44.2.tgz"
"version" "4.44.2"

Načítá se…
Zrušit
Uložit