From fdbc6c37421afd4620d0eccf5fa33288edce80d7 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 27 Jun 2023 16:32:51 +0900
Subject: [PATCH 001/107] =?UTF-8?q?Chore:=20=EC=B4=88=EA=B8=B0=20=EC=84=B8?=
=?UTF-8?q?=ED=8C=85?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
vite, eslint, prettier, jest 적용
---
.babelrc | 3 +
.eslintrc | 13 +
.gitignore | 2 +
.prettierrc | 9 +
index.html | 9 +
package-lock.json | 7911 +++++++++++++++++++++++++++++++++++++++++++++
package.json | 20 +
src/index.js | 0
8 files changed, 7967 insertions(+)
create mode 100644 .babelrc
create mode 100644 .eslintrc
create mode 100644 .gitignore
create mode 100644 .prettierrc
create mode 100644 index.html
create mode 100644 package-lock.json
create mode 100644 package.json
create mode 100644 src/index.js
diff --git a/.babelrc b/.babelrc
new file mode 100644
index 00000000..8aa924d7
--- /dev/null
+++ b/.babelrc
@@ -0,0 +1,3 @@
+{
+ "presets": ["@babel/preset-env"]
+}
\ No newline at end of file
diff --git a/.eslintrc b/.eslintrc
new file mode 100644
index 00000000..495be454
--- /dev/null
+++ b/.eslintrc
@@ -0,0 +1,13 @@
+{
+ "extends": ["eslint:recommended", "plugin:jest/recommended"],
+ "plugins": ["jest"],
+ "parserOptions": {
+ "sourceType": "module",
+ "ecmaVersion": 2021
+ },
+ "env": {
+ "browser": true,
+ "es2021": true,
+ "jest/globals": true
+ }
+}
\ No newline at end of file
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 00000000..76add878
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,2 @@
+node_modules
+dist
\ No newline at end of file
diff --git a/.prettierrc b/.prettierrc
new file mode 100644
index 00000000..84d73a2b
--- /dev/null
+++ b/.prettierrc
@@ -0,0 +1,9 @@
+{
+ "semi": false,
+ "singleQuote": false,
+ "tabWidth": 2,
+ "trailingComma": "all",
+ "printWidth": 120,
+ "endOfLine": "auto",
+ "formatOnSave": true
+}
\ No newline at end of file
diff --git a/index.html b/index.html
new file mode 100644
index 00000000..eba584e4
--- /dev/null
+++ b/index.html
@@ -0,0 +1,9 @@
+
+
+ 효리의 노션 클로닝 사이트
+
+
+
+
+
+
\ No newline at end of file
diff --git a/package-lock.json b/package-lock.json
new file mode 100644
index 00000000..0f3dc982
--- /dev/null
+++ b/package-lock.json
@@ -0,0 +1,7911 @@
+{
+ "name": "fedc4-5_project_notion_vanillajs",
+ "version": "1.0.0",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "fedc4-5_project_notion_vanillajs",
+ "version": "1.0.0",
+ "devDependencies": {
+ "@babel/cli": "^7.22.5",
+ "@babel/core": "^7.22.5",
+ "@babel/preset-env": "^7.22.5",
+ "eslint": "^8.43.0",
+ "jest": "^29.5.0",
+ "prettier": "^2.8.8",
+ "vite": "^4.3.9"
+ }
+ },
+ "node_modules/@ampproject/remapping": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz",
+ "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/cli": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.22.5.tgz",
+ "integrity": "sha512-N5d7MjzwsQ2wppwjhrsicVDhJSqF9labEP/swYiHhio4Ca2XjEehpgPmerjnLQl7BPE59BLud0PTWGYwqFl/cQ==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/trace-mapping": "^0.3.17",
+ "commander": "^4.0.1",
+ "convert-source-map": "^1.1.0",
+ "fs-readdir-recursive": "^1.1.0",
+ "glob": "^7.2.0",
+ "make-dir": "^2.1.0",
+ "slash": "^2.0.0"
+ },
+ "bin": {
+ "babel": "bin/babel.js",
+ "babel-external-helpers": "bin/babel-external-helpers.js"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "optionalDependencies": {
+ "@nicolo-ribaudo/chokidar-2": "2.1.8-no-fsevents.3",
+ "chokidar": "^3.4.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.5.tgz",
+ "integrity": "sha512-Xmwn266vad+6DAqEB2A6V/CcZVp62BbwVmcOJc2RPuwih1kw02TjQvWVWlcKGbBPd+8/0V5DEkOcizRGYsspYQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/highlight": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/compat-data": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.5.tgz",
+ "integrity": "sha512-4Jc/YuIaYqKnDDz892kPIledykKg12Aw1PYX5i/TY28anJtacvM1Rrr8wbieB9GfEJwlzqT0hUEao0CxEebiDA==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/core": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.5.tgz",
+ "integrity": "sha512-SBuTAjg91A3eKOvD+bPEz3LlhHZRNu1nFOVts9lzDJTXshHTjII0BAtDS3Y2DAkdZdDKWVZGVwkDfc4Clxn1dg==",
+ "dev": true,
+ "dependencies": {
+ "@ampproject/remapping": "^2.2.0",
+ "@babel/code-frame": "^7.22.5",
+ "@babel/generator": "^7.22.5",
+ "@babel/helper-compilation-targets": "^7.22.5",
+ "@babel/helper-module-transforms": "^7.22.5",
+ "@babel/helpers": "^7.22.5",
+ "@babel/parser": "^7.22.5",
+ "@babel/template": "^7.22.5",
+ "@babel/traverse": "^7.22.5",
+ "@babel/types": "^7.22.5",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.2",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/babel"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.22.5.tgz",
+ "integrity": "sha512-+lcUbnTRhd0jOewtFSedLyiPsD5tswKkbgcezOqqWFUVNEwoUTlpPOBmvhG7OXWLR4jMdv0czPGH5XbflnD1EA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5",
+ "@jridgewell/gen-mapping": "^0.3.2",
+ "@jridgewell/trace-mapping": "^0.3.17",
+ "jsesc": "^2.5.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-annotate-as-pure": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.22.5.tgz",
+ "integrity": "sha512-LvBTxu8bQSQkcyKOU+a1btnNFQ1dMAd0R6PyW3arXes06F6QLWLIrd681bxRPIXlrMGR3XYnW9JyML7dP3qgxg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.22.5.tgz",
+ "integrity": "sha512-m1EP3lVOPptR+2DwD125gziZNcmoNSHGmJROKoy87loWUQyJaVXDgpmruWqDARZSmtYQ+Dl25okU8+qhVzuykw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.5.tgz",
+ "integrity": "sha512-Ji+ywpHeuqxB8WDxraCiqR0xfhYjiDE/e6k7FuIaANnoOFxAHskHChz4vA1mJC9Lbm01s1PVAGhQY4FUKSkGZw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.22.5",
+ "@babel/helper-validator-option": "^7.22.5",
+ "browserslist": "^4.21.3",
+ "lru-cache": "^5.1.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-create-class-features-plugin": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.22.5.tgz",
+ "integrity": "sha512-xkb58MyOYIslxu3gKmVXmjTtUPvBU4odYzbiIQbWwLKIHCsx6UGZGX6F1IznMFVnDdirseUZopzN+ZRt8Xb33Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.22.5",
+ "@babel/helper-environment-visitor": "^7.22.5",
+ "@babel/helper-function-name": "^7.22.5",
+ "@babel/helper-member-expression-to-functions": "^7.22.5",
+ "@babel/helper-optimise-call-expression": "^7.22.5",
+ "@babel/helper-replace-supers": "^7.22.5",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5",
+ "@babel/helper-split-export-declaration": "^7.22.5",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-create-regexp-features-plugin": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.22.5.tgz",
+ "integrity": "sha512-1VpEFOIbMRaXyDeUwUfmTIxExLwQ+zkW+Bh5zXpApA3oQedBx9v/updixWxnx/bZpKw7u8VxWjb/qWpIcmPq8A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.22.5",
+ "regexpu-core": "^5.3.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-define-polyfill-provider": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.4.0.tgz",
+ "integrity": "sha512-RnanLx5ETe6aybRi1cO/edaRH+bNYWaryCEmjDDYyNr4wnSzyOp8T0dWipmqVHKEY3AbVKUom50AKSlj1zmKbg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-compilation-targets": "^7.17.7",
+ "@babel/helper-plugin-utils": "^7.16.7",
+ "debug": "^4.1.1",
+ "lodash.debounce": "^4.0.8",
+ "resolve": "^1.14.2",
+ "semver": "^6.1.2"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.4.0-0"
+ }
+ },
+ "node_modules/@babel/helper-environment-visitor": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz",
+ "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-function-name": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.22.5.tgz",
+ "integrity": "sha512-wtHSq6jMRE3uF2otvfuD3DIvVhOsSNshQl0Qrd7qC9oQJzHvOL4qQXlQn2916+CXGywIjpGuIkoyZRRxHPiNQQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/template": "^7.22.5",
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-hoist-variables": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz",
+ "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-member-expression-to-functions": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.22.5.tgz",
+ "integrity": "sha512-aBiH1NKMG0H2cGZqspNvsaBe6wNGjbJjuLy29aU+eDZjSbbN53BaxlpB02xm9v34pLTZ1nIQPFYn2qMZoa5BQQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz",
+ "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-transforms": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.5.tgz",
+ "integrity": "sha512-+hGKDt/Ze8GFExiVHno/2dvG5IdstpzCq0y4Qc9OJ25D4q3pKfiIP/4Vp3/JvhDkLKsDK2api3q3fpIgiIF5bw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.22.5",
+ "@babel/helper-module-imports": "^7.22.5",
+ "@babel/helper-simple-access": "^7.22.5",
+ "@babel/helper-split-export-declaration": "^7.22.5",
+ "@babel/helper-validator-identifier": "^7.22.5",
+ "@babel/template": "^7.22.5",
+ "@babel/traverse": "^7.22.5",
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-optimise-call-expression": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.22.5.tgz",
+ "integrity": "sha512-HBwaojN0xFRx4yIvpwGqxiV2tUfl7401jlok564NgB9EHS1y6QT17FmKWm4ztqjeVdXLuC4fSvHc5ePpQjoTbw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-plugin-utils": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz",
+ "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-remap-async-to-generator": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.22.5.tgz",
+ "integrity": "sha512-cU0Sq1Rf4Z55fgz7haOakIyM7+x/uCFwXpLPaeRzfoUtAEAuUZjZvFPjL/rk5rW693dIgn2hng1W7xbT7lWT4g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.22.5",
+ "@babel/helper-environment-visitor": "^7.22.5",
+ "@babel/helper-wrap-function": "^7.22.5",
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-replace-supers": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.22.5.tgz",
+ "integrity": "sha512-aLdNM5I3kdI/V9xGNyKSF3X/gTyMUBohTZ+/3QdQKAA9vxIiy12E+8E2HoOP1/DjeqU+g6as35QHJNMDDYpuCg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.22.5",
+ "@babel/helper-member-expression-to-functions": "^7.22.5",
+ "@babel/helper-optimise-call-expression": "^7.22.5",
+ "@babel/template": "^7.22.5",
+ "@babel/traverse": "^7.22.5",
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-simple-access": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz",
+ "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-skip-transparent-expression-wrappers": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.22.5.tgz",
+ "integrity": "sha512-tK14r66JZKiC43p8Ki33yLBVJKlQDFoA8GYN67lWCDCqoL6EMMSuM9b+Iff2jHaM/RRFYl7K+iiru7hbRqNx8Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-split-export-declaration": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.5.tgz",
+ "integrity": "sha512-thqK5QFghPKWLhAV321lxF95yCg2K3Ob5yw+M3VHWfdia0IkPXUtoLH8x/6Fh486QUvzhb8YOWHChTVen2/PoQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz",
+ "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz",
+ "integrity": "sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-option": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz",
+ "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-wrap-function": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.22.5.tgz",
+ "integrity": "sha512-bYqLIBSEshYcYQyfks8ewYA8S30yaGSeRslcvKMvoUk6HHPySbxHq9YRi6ghhzEU+yhQv9bP/jXnygkStOcqZw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-function-name": "^7.22.5",
+ "@babel/template": "^7.22.5",
+ "@babel/traverse": "^7.22.5",
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helpers": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.5.tgz",
+ "integrity": "sha512-pSXRmfE1vzcUIDFQcSGA5Mr+GxBV9oiRKDuDxXvWQQBCh8HoIjs/2DlDB7H8smac1IVrB9/xdXj2N3Wol9Cr+Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/template": "^7.22.5",
+ "@babel/traverse": "^7.22.5",
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/highlight": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.5.tgz",
+ "integrity": "sha512-BSKlD1hgnedS5XRnGOljZawtag7H1yPfQp0tdNJCHoH6AZ+Pcm9VvkrK59/Yy593Ypg0zMxH2BxD1VPYUQ7UIw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.22.5",
+ "chalk": "^2.0.0",
+ "js-tokens": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.5.tgz",
+ "integrity": "sha512-DFZMC9LJUG9PLOclRC32G63UXwzqS2koQC8dkx+PLdmt1xSePYpbT/NbsrJy8Q/muXz7o/h/d4A7Fuyixm559Q==",
+ "dev": true,
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.22.5.tgz",
+ "integrity": "sha512-NP1M5Rf+u2Gw9qfSO4ihjcTGW5zXTi36ITLd4/EoAcEhIZ0yjMqmftDNl3QC19CX7olhrjpyU454g/2W7X0jvQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.22.5.tgz",
+ "integrity": "sha512-31Bb65aZaUwqCbWMnZPduIZxCBngHFlzyN6Dq6KAJjtx+lx6ohKHubc61OomYi7XwVD4Ol0XCVz4h+pYFR048g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5",
+ "@babel/plugin-transform-optional-chaining": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.13.0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-private-property-in-object": {
+ "version": "7.21.0-placeholder-for-preset-env.2",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.21.0-placeholder-for-preset-env.2.tgz",
+ "integrity": "sha512-SOSkfJDddaM7mak6cPEpswyTRnuRltl429hMraQEglW+OkovnCzsiszTmsrlY//qLFjCpQDFRvjdm2wA5pPm9w==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-unicode-property-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz",
+ "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-async-generators": {
+ "version": "7.8.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz",
+ "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-bigint": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz",
+ "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-class-properties": {
+ "version": "7.12.13",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz",
+ "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.12.13"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-class-static-block": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz",
+ "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-dynamic-import": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz",
+ "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-export-namespace-from": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz",
+ "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.3"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-import-assertions": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.22.5.tgz",
+ "integrity": "sha512-rdV97N7KqsRzeNGoWUOK6yUsWarLjE5Su/Snk9IYPU9CwkWHs4t+rTGOvffTR8XGkJMTAdLfO0xVnXm8wugIJg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-import-attributes": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.22.5.tgz",
+ "integrity": "sha512-KwvoWDeNKPETmozyFE0P2rOLqh39EoQHNjqizrI5B8Vt0ZNS7M56s7dAiAqbYfiAYOuIzIh96z3iR2ktgu3tEg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-import-meta": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz",
+ "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-json-strings": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz",
+ "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-jsx": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.22.5.tgz",
+ "integrity": "sha512-gvyP4hZrgrs/wWMaocvxZ44Hw0b3W8Pe+cMxc8V1ULQ07oh8VNbIRaoD1LRZVTvD+0nieDKjfgKg89sD7rrKrg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-logical-assignment-operators": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz",
+ "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz",
+ "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-numeric-separator": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz",
+ "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-object-rest-spread": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz",
+ "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-optional-catch-binding": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz",
+ "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-optional-chaining": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz",
+ "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-private-property-in-object": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz",
+ "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-top-level-await": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz",
+ "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-typescript": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.22.5.tgz",
+ "integrity": "sha512-1mS2o03i7t1c6VzH6fdQ3OA8tcEIxwG18zIPRp+UY1Ihv6W+XZzBCVxExF9upussPXJ0xE9XRHwMoNs1ep/nRQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-unicode-sets-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-unicode-sets-regex/-/plugin-syntax-unicode-sets-regex-7.18.6.tgz",
+ "integrity": "sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-arrow-functions": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.22.5.tgz",
+ "integrity": "sha512-26lTNXoVRdAnsaDXPpvCNUq+OVWEVC6bx7Vvz9rC53F2bagUWW4u4ii2+h8Fejfh7RYqPxn+libeFBBck9muEw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-async-generator-functions": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.22.5.tgz",
+ "integrity": "sha512-gGOEvFzm3fWoyD5uZq7vVTD57pPJ3PczPUD/xCFGjzBpUosnklmXyKnGQbbbGs1NPNPskFex0j93yKbHt0cHyg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-remap-async-to-generator": "^7.22.5",
+ "@babel/plugin-syntax-async-generators": "^7.8.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-async-to-generator": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.22.5.tgz",
+ "integrity": "sha512-b1A8D8ZzE/VhNDoV1MSJTnpKkCG5bJo+19R4o4oy03zM7ws8yEMK755j61Dc3EyvdysbqH5BOOTquJ7ZX9C6vQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-remap-async-to-generator": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-block-scoped-functions": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.22.5.tgz",
+ "integrity": "sha512-tdXZ2UdknEKQWKJP1KMNmuF5Lx3MymtMN/pvA+p/VEkhK8jVcQ1fzSy8KM9qRYhAf2/lV33hoMPKI/xaI9sADA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-block-scoping": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.22.5.tgz",
+ "integrity": "sha512-EcACl1i5fSQ6bt+YGuU/XGCeZKStLmyVGytWkpyhCLeQVA0eu6Wtiw92V+I1T/hnezUv7j74dA/Ro69gWcU+hg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-class-properties": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-properties/-/plugin-transform-class-properties-7.22.5.tgz",
+ "integrity": "sha512-nDkQ0NfkOhPTq8YCLiWNxp1+f9fCobEjCb0n8WdbNUBc4IB5V7P1QnX9IjpSoquKrXF5SKojHleVNs2vGeHCHQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-class-static-block": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.22.5.tgz",
+ "integrity": "sha512-SPToJ5eYZLxlnp1UzdARpOGeC2GbHvr9d/UV0EukuVx8atktg194oe+C5BqQ8jRTkgLRVOPYeXRSBg1IlMoVRA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.12.0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-classes": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.22.5.tgz",
+ "integrity": "sha512-2edQhLfibpWpsVBx2n/GKOz6JdGQvLruZQfGr9l1qes2KQaWswjBzhQF7UDUZMNaMMQeYnQzxwOMPsbYF7wqPQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.22.5",
+ "@babel/helper-compilation-targets": "^7.22.5",
+ "@babel/helper-environment-visitor": "^7.22.5",
+ "@babel/helper-function-name": "^7.22.5",
+ "@babel/helper-optimise-call-expression": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-replace-supers": "^7.22.5",
+ "@babel/helper-split-export-declaration": "^7.22.5",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-computed-properties": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.22.5.tgz",
+ "integrity": "sha512-4GHWBgRf0krxPX+AaPtgBAlTgTeZmqDynokHOX7aqqAB4tHs3U2Y02zH6ETFdLZGcg9UQSD1WCmkVrE9ErHeOg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/template": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-destructuring": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.22.5.tgz",
+ "integrity": "sha512-GfqcFuGW8vnEqTUBM7UtPd5A4q797LTvvwKxXTgRsFjoqaJiEg9deBG6kWeQYkVEL569NpnmpC0Pkr/8BLKGnQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-dotall-regex": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.22.5.tgz",
+ "integrity": "sha512-5/Yk9QxCQCl+sOIB1WelKnVRxTJDSAIxtJLL2/pqL14ZVlbH0fUQUZa/T5/UnQtBNgghR7mfB8ERBKyKPCi7Vw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-duplicate-keys": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.22.5.tgz",
+ "integrity": "sha512-dEnYD+9BBgld5VBXHnF/DbYGp3fqGMsyxKbtD1mDyIA7AkTSpKXFhCVuj/oQVOoALfBs77DudA0BE4d5mcpmqw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-dynamic-import": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.22.5.tgz",
+ "integrity": "sha512-0MC3ppTB1AMxd8fXjSrbPa7LT9hrImt+/fcj+Pg5YMD7UQyWp/02+JWpdnCymmsXwIx5Z+sYn1bwCn4ZJNvhqQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-exponentiation-operator": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.22.5.tgz",
+ "integrity": "sha512-vIpJFNM/FjZ4rh1myqIya9jXwrwwgFRHPjT3DkUA9ZLHuzox8jiXkOLvwm1H+PQIP3CqfC++WPKeuDi0Sjdj1g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-builder-binary-assignment-operator-visitor": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-export-namespace-from": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.22.5.tgz",
+ "integrity": "sha512-X4hhm7FRnPgd4nDA4b/5V280xCx6oL7Oob5+9qVS5C13Zq4bh1qq7LU0GgRU6b5dBWBvhGaXYVB4AcN6+ol6vg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-for-of": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.22.5.tgz",
+ "integrity": "sha512-3kxQjX1dU9uudwSshyLeEipvrLjBCVthCgeTp6CzE/9JYrlAIaeekVxRpCWsDDfYTfRZRoCeZatCQvwo+wvK8A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-function-name": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.22.5.tgz",
+ "integrity": "sha512-UIzQNMS0p0HHiQm3oelztj+ECwFnj+ZRV4KnguvlsD2of1whUeM6o7wGNj6oLwcDoAXQ8gEqfgC24D+VdIcevg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-compilation-targets": "^7.22.5",
+ "@babel/helper-function-name": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-json-strings": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.22.5.tgz",
+ "integrity": "sha512-DuCRB7fu8MyTLbEQd1ew3R85nx/88yMoqo2uPSjevMj3yoN7CDM8jkgrY0wmVxfJZyJ/B9fE1iq7EQppWQmR5A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-json-strings": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-literals": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.22.5.tgz",
+ "integrity": "sha512-fTLj4D79M+mepcw3dgFBTIDYpbcB9Sm0bpm4ppXPaO+U+PKFFyV9MGRvS0gvGw62sd10kT5lRMKXAADb9pWy8g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-logical-assignment-operators": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.22.5.tgz",
+ "integrity": "sha512-MQQOUW1KL8X0cDWfbwYP+TbVbZm16QmQXJQ+vndPtH/BoO0lOKpVoEDMI7+PskYxH+IiE0tS8xZye0qr1lGzSA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-member-expression-literals": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.22.5.tgz",
+ "integrity": "sha512-RZEdkNtzzYCFl9SE9ATaUMTj2hqMb4StarOJLrZRbqqU4HSBE7UlBw9WBWQiDzrJZJdUWiMTVDI6Gv/8DPvfew==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-amd": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.22.5.tgz",
+ "integrity": "sha512-R+PTfLTcYEmb1+kK7FNkhQ1gP4KgjpSO6HfH9+f8/yfp2Nt3ggBjiVpRwmwTlfqZLafYKJACy36yDXlEmI9HjQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-commonjs": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.22.5.tgz",
+ "integrity": "sha512-B4pzOXj+ONRmuaQTg05b3y/4DuFz3WcCNAXPLb2Q0GT0TrGKGxNKV4jwsXts+StaM0LQczZbOpj8o1DLPDJIiA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-simple-access": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-systemjs": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.22.5.tgz",
+ "integrity": "sha512-emtEpoaTMsOs6Tzz+nbmcePl6AKVtS1yC4YNAeMun9U8YCsgadPNxnOPQ8GhHFB2qdx+LZu9LgoC0Lthuu05DQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-hoist-variables": "^7.22.5",
+ "@babel/helper-module-transforms": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-validator-identifier": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-umd": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.22.5.tgz",
+ "integrity": "sha512-+S6kzefN/E1vkSsKx8kmQuqeQsvCKCd1fraCM7zXm4SFoggI099Tr4G8U81+5gtMdUeMQ4ipdQffbKLX0/7dBQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-named-capturing-groups-regex": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.22.5.tgz",
+ "integrity": "sha512-YgLLKmS3aUBhHaxp5hi1WJTgOUb/NCuDHzGT9z9WTt3YG+CPRhJs6nprbStx6DnWM4dh6gt7SU3sZodbZ08adQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-new-target": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.22.5.tgz",
+ "integrity": "sha512-AsF7K0Fx/cNKVyk3a+DW0JLo+Ua598/NxMRvxDnkpCIGFh43+h/v2xyhRUYf6oD8gE4QtL83C7zZVghMjHd+iw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-nullish-coalescing-operator": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.22.5.tgz",
+ "integrity": "sha512-6CF8g6z1dNYZ/VXok5uYkkBBICHZPiGEl7oDnAx2Mt1hlHVHOSIKWJaXHjQJA5VB43KZnXZDIexMchY4y2PGdA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-numeric-separator": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.22.5.tgz",
+ "integrity": "sha512-NbslED1/6M+sXiwwtcAB/nieypGw02Ejf4KtDeMkCEpP6gWFMX1wI9WKYua+4oBneCCEmulOkRpwywypVZzs/g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-object-rest-spread": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.22.5.tgz",
+ "integrity": "sha512-Kk3lyDmEslH9DnvCDA1s1kkd3YWQITiBOHngOtDL9Pt6BZjzqb6hiOlb8VfjiiQJ2unmegBqZu0rx5RxJb5vmQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.22.5",
+ "@babel/helper-compilation-targets": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-transform-parameters": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-object-super": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.22.5.tgz",
+ "integrity": "sha512-klXqyaT9trSjIUrcsYIfETAzmOEZL3cBYqOYLJxBHfMFFggmXOv+NYSX/Jbs9mzMVESw/WycLFPRx8ba/b2Ipw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-replace-supers": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-optional-catch-binding": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.22.5.tgz",
+ "integrity": "sha512-pH8orJahy+hzZje5b8e2QIlBWQvGpelS76C63Z+jhZKsmzfNaPQ+LaW6dcJ9bxTpo1mtXbgHwy765Ro3jftmUg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-optional-chaining": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.22.5.tgz",
+ "integrity": "sha512-AconbMKOMkyG+xCng2JogMCDcqW8wedQAqpVIL4cOSescZ7+iW8utC6YDZLMCSUIReEA733gzRSaOSXMAt/4WQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-parameters": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.22.5.tgz",
+ "integrity": "sha512-AVkFUBurORBREOmHRKo06FjHYgjrabpdqRSwq6+C7R5iTCZOsM4QbcB27St0a4U6fffyAOqh3s/qEfybAhfivg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-private-methods": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-methods/-/plugin-transform-private-methods-7.22.5.tgz",
+ "integrity": "sha512-PPjh4gyrQnGe97JTalgRGMuU4icsZFnWkzicB/fUtzlKUqvsWBKEpPPfr5a2JiyirZkHxnAqkQMO5Z5B2kK3fA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-private-property-in-object": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.22.5.tgz",
+ "integrity": "sha512-/9xnaTTJcVoBtSSmrVyhtSvO3kbqS2ODoh2juEU72c3aYonNF0OMGiaz2gjukyKM2wBBYJP38S4JiE0Wfb5VMQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.22.5",
+ "@babel/helper-create-class-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-property-literals": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.22.5.tgz",
+ "integrity": "sha512-TiOArgddK3mK/x1Qwf5hay2pxI6wCZnvQqrFSqbtg1GLl2JcNMitVH/YnqjP+M31pLUeTfzY1HAXFDnUBV30rQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-regenerator": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.22.5.tgz",
+ "integrity": "sha512-rR7KePOE7gfEtNTh9Qw+iO3Q/e4DEsoQ+hdvM6QUDH7JRJ5qxq5AA52ZzBWbI5i9lfNuvySgOGP8ZN7LAmaiPw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "regenerator-transform": "^0.15.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-reserved-words": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.22.5.tgz",
+ "integrity": "sha512-DTtGKFRQUDm8svigJzZHzb/2xatPc6TzNvAIJ5GqOKDsGFYgAskjRulbR/vGsPKq3OPqtexnz327qYpP57RFyA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-shorthand-properties": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.22.5.tgz",
+ "integrity": "sha512-vM4fq9IXHscXVKzDv5itkO1X52SmdFBFcMIBZ2FRn2nqVYqw6dBexUgMvAjHW+KXpPPViD/Yo3GrDEBaRC0QYA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-spread": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.22.5.tgz",
+ "integrity": "sha512-5ZzDQIGyvN4w8+dMmpohL6MBo+l2G7tfC/O2Dg7/hjpgeWvUx8FzfeOKxGog9IimPa4YekaQ9PlDqTLOljkcxg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-sticky-regex": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.22.5.tgz",
+ "integrity": "sha512-zf7LuNpHG0iEeiyCNwX4j3gDg1jgt1k3ZdXBKbZSoA3BbGQGvMiSvfbZRR3Dr3aeJe3ooWFZxOOG3IRStYp2Bw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-template-literals": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.22.5.tgz",
+ "integrity": "sha512-5ciOehRNf+EyUeewo8NkbQiUs4d6ZxiHo6BcBcnFlgiJfu16q0bQUw9Jvo0b0gBKFG1SMhDSjeKXSYuJLeFSMA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-typeof-symbol": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.22.5.tgz",
+ "integrity": "sha512-bYkI5lMzL4kPii4HHEEChkD0rkc+nvnlR6+o/qdqR6zrm0Sv/nodmyLhlq2DO0YKLUNd2VePmPRjJXSBh9OIdA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-escapes": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.22.5.tgz",
+ "integrity": "sha512-biEmVg1IYB/raUO5wT1tgfacCef15Fbzhkx493D3urBI++6hpJ+RFG4SrWMn0NEZLfvilqKf3QDrRVZHo08FYg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-property-regex": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-property-regex/-/plugin-transform-unicode-property-regex-7.22.5.tgz",
+ "integrity": "sha512-HCCIb+CbJIAE6sXn5CjFQXMwkCClcOfPCzTlilJ8cUatfzwHlWQkbtV0zD338u9dZskwvuOYTuuaMaA8J5EI5A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-regex": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.22.5.tgz",
+ "integrity": "sha512-028laaOKptN5vHJf9/Arr/HiJekMd41hOEZYvNsrsXqJ7YPYuX2bQxh31fkZzGmq3YqHRJzYFFAVYvKfMPKqyg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-sets-regex": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-sets-regex/-/plugin-transform-unicode-sets-regex-7.22.5.tgz",
+ "integrity": "sha512-lhMfi4FC15j13eKrh3DnYHjpGj6UKQHtNKTbtc1igvAhRy4+kLhV07OpLcsN0VgDEw/MjAvJO4BdMJsHwMhzCg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/preset-env": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.22.5.tgz",
+ "integrity": "sha512-fj06hw89dpiZzGZtxn+QybifF07nNiZjZ7sazs2aVDcysAZVGjW7+7iFYxg6GLNM47R/thYfLdrXc+2f11Vi9A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.22.5",
+ "@babel/helper-compilation-targets": "^7.22.5",
+ "@babel/helper-plugin-utils": "^7.22.5",
+ "@babel/helper-validator-option": "^7.22.5",
+ "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.22.5",
+ "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.22.5",
+ "@babel/plugin-proposal-private-property-in-object": "7.21.0-placeholder-for-preset-env.2",
+ "@babel/plugin-syntax-async-generators": "^7.8.4",
+ "@babel/plugin-syntax-class-properties": "^7.12.13",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3",
+ "@babel/plugin-syntax-import-assertions": "^7.22.5",
+ "@babel/plugin-syntax-import-attributes": "^7.22.5",
+ "@babel/plugin-syntax-import-meta": "^7.10.4",
+ "@babel/plugin-syntax-json-strings": "^7.8.3",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5",
+ "@babel/plugin-syntax-top-level-await": "^7.14.5",
+ "@babel/plugin-syntax-unicode-sets-regex": "^7.18.6",
+ "@babel/plugin-transform-arrow-functions": "^7.22.5",
+ "@babel/plugin-transform-async-generator-functions": "^7.22.5",
+ "@babel/plugin-transform-async-to-generator": "^7.22.5",
+ "@babel/plugin-transform-block-scoped-functions": "^7.22.5",
+ "@babel/plugin-transform-block-scoping": "^7.22.5",
+ "@babel/plugin-transform-class-properties": "^7.22.5",
+ "@babel/plugin-transform-class-static-block": "^7.22.5",
+ "@babel/plugin-transform-classes": "^7.22.5",
+ "@babel/plugin-transform-computed-properties": "^7.22.5",
+ "@babel/plugin-transform-destructuring": "^7.22.5",
+ "@babel/plugin-transform-dotall-regex": "^7.22.5",
+ "@babel/plugin-transform-duplicate-keys": "^7.22.5",
+ "@babel/plugin-transform-dynamic-import": "^7.22.5",
+ "@babel/plugin-transform-exponentiation-operator": "^7.22.5",
+ "@babel/plugin-transform-export-namespace-from": "^7.22.5",
+ "@babel/plugin-transform-for-of": "^7.22.5",
+ "@babel/plugin-transform-function-name": "^7.22.5",
+ "@babel/plugin-transform-json-strings": "^7.22.5",
+ "@babel/plugin-transform-literals": "^7.22.5",
+ "@babel/plugin-transform-logical-assignment-operators": "^7.22.5",
+ "@babel/plugin-transform-member-expression-literals": "^7.22.5",
+ "@babel/plugin-transform-modules-amd": "^7.22.5",
+ "@babel/plugin-transform-modules-commonjs": "^7.22.5",
+ "@babel/plugin-transform-modules-systemjs": "^7.22.5",
+ "@babel/plugin-transform-modules-umd": "^7.22.5",
+ "@babel/plugin-transform-named-capturing-groups-regex": "^7.22.5",
+ "@babel/plugin-transform-new-target": "^7.22.5",
+ "@babel/plugin-transform-nullish-coalescing-operator": "^7.22.5",
+ "@babel/plugin-transform-numeric-separator": "^7.22.5",
+ "@babel/plugin-transform-object-rest-spread": "^7.22.5",
+ "@babel/plugin-transform-object-super": "^7.22.5",
+ "@babel/plugin-transform-optional-catch-binding": "^7.22.5",
+ "@babel/plugin-transform-optional-chaining": "^7.22.5",
+ "@babel/plugin-transform-parameters": "^7.22.5",
+ "@babel/plugin-transform-private-methods": "^7.22.5",
+ "@babel/plugin-transform-private-property-in-object": "^7.22.5",
+ "@babel/plugin-transform-property-literals": "^7.22.5",
+ "@babel/plugin-transform-regenerator": "^7.22.5",
+ "@babel/plugin-transform-reserved-words": "^7.22.5",
+ "@babel/plugin-transform-shorthand-properties": "^7.22.5",
+ "@babel/plugin-transform-spread": "^7.22.5",
+ "@babel/plugin-transform-sticky-regex": "^7.22.5",
+ "@babel/plugin-transform-template-literals": "^7.22.5",
+ "@babel/plugin-transform-typeof-symbol": "^7.22.5",
+ "@babel/plugin-transform-unicode-escapes": "^7.22.5",
+ "@babel/plugin-transform-unicode-property-regex": "^7.22.5",
+ "@babel/plugin-transform-unicode-regex": "^7.22.5",
+ "@babel/plugin-transform-unicode-sets-regex": "^7.22.5",
+ "@babel/preset-modules": "^0.1.5",
+ "@babel/types": "^7.22.5",
+ "babel-plugin-polyfill-corejs2": "^0.4.3",
+ "babel-plugin-polyfill-corejs3": "^0.8.1",
+ "babel-plugin-polyfill-regenerator": "^0.5.0",
+ "core-js-compat": "^3.30.2",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/preset-modules": {
+ "version": "0.1.5",
+ "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz",
+ "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.4.4",
+ "@babel/plugin-transform-dotall-regex": "^7.4.4",
+ "@babel/types": "^7.4.4",
+ "esutils": "^2.0.2"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/regjsgen": {
+ "version": "0.8.0",
+ "resolved": "https://registry.npmjs.org/@babel/regjsgen/-/regjsgen-0.8.0.tgz",
+ "integrity": "sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==",
+ "dev": true
+ },
+ "node_modules/@babel/runtime": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.22.5.tgz",
+ "integrity": "sha512-ecjvYlnAaZ/KVneE/OdKYBYfgXV3Ptu6zQWmgEF7vwKhQnvVS6bjMD2XYgj+SNvQ1GfK/pjgokfPkC/2CO8CuA==",
+ "dev": true,
+ "dependencies": {
+ "regenerator-runtime": "^0.13.11"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.5.tgz",
+ "integrity": "sha512-X7yV7eiwAxdj9k94NEylvbVHLiVG1nvzCV2EAowhxLTwODV1jl9UzZ48leOC0sH7OnuHrIkllaBgneUykIcZaw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.22.5",
+ "@babel/parser": "^7.22.5",
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.5.tgz",
+ "integrity": "sha512-7DuIjPgERaNo6r+PZwItpjCZEa5vyw4eJGufeLxrPdBXBoLcCJCIasvK6pK/9DVNrLZTLFhUGqaC6X/PA007TQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.22.5",
+ "@babel/generator": "^7.22.5",
+ "@babel/helper-environment-visitor": "^7.22.5",
+ "@babel/helper-function-name": "^7.22.5",
+ "@babel/helper-hoist-variables": "^7.22.5",
+ "@babel/helper-split-export-declaration": "^7.22.5",
+ "@babel/parser": "^7.22.5",
+ "@babel/types": "^7.22.5",
+ "debug": "^4.1.0",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.5.tgz",
+ "integrity": "sha512-zo3MIHGOkPOfoRXitsgHLjEXmlDaD/5KU1Uzuc9GNiZPhSqVxVRtxuPaSBZDsYZ9qV88AjtMtWW7ww98loJ9KA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.22.5",
+ "@babel/helper-validator-identifier": "^7.22.5",
+ "to-fast-properties": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@bcoe/v8-coverage": {
+ "version": "0.2.3",
+ "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz",
+ "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==",
+ "dev": true
+ },
+ "node_modules/@esbuild/android-arm": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz",
+ "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-arm64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz",
+ "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz",
+ "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-arm64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz",
+ "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz",
+ "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-arm64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz",
+ "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz",
+ "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz",
+ "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz",
+ "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ia32": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz",
+ "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-loong64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz",
+ "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==",
+ "cpu": [
+ "loong64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-mips64el": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz",
+ "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==",
+ "cpu": [
+ "mips64el"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ppc64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz",
+ "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-riscv64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz",
+ "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==",
+ "cpu": [
+ "riscv64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-s390x": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz",
+ "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==",
+ "cpu": [
+ "s390x"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz",
+ "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/netbsd-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz",
+ "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "netbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/openbsd-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz",
+ "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "openbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/sunos-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz",
+ "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "sunos"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-arm64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz",
+ "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-ia32": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz",
+ "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-x64": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz",
+ "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@eslint-community/eslint-utils": {
+ "version": "4.4.0",
+ "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz",
+ "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==",
+ "dev": true,
+ "dependencies": {
+ "eslint-visitor-keys": "^3.3.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "peerDependencies": {
+ "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
+ }
+ },
+ "node_modules/@eslint-community/regexpp": {
+ "version": "4.5.1",
+ "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.5.1.tgz",
+ "integrity": "sha512-Z5ba73P98O1KUYCCJTUeVpja9RcGoMdncZ6T49FCUl2lN38JtCJ+3WgIDBv0AuY4WChU5PmtJmOCTlN6FZTFKQ==",
+ "dev": true,
+ "engines": {
+ "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@eslint/eslintrc": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.0.3.tgz",
+ "integrity": "sha512-+5gy6OQfk+xx3q0d6jGZZC3f3KzAkXc/IanVxd1is/VIIziRqqt3ongQz0FiTUXqTk0c7aDB3OaFuKnuSoJicQ==",
+ "dev": true,
+ "dependencies": {
+ "ajv": "^6.12.4",
+ "debug": "^4.3.2",
+ "espree": "^9.5.2",
+ "globals": "^13.19.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.2.1",
+ "js-yaml": "^4.1.0",
+ "minimatch": "^3.1.2",
+ "strip-json-comments": "^3.1.1"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/globals": {
+ "version": "13.20.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.20.0.tgz",
+ "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@eslint/js": {
+ "version": "8.43.0",
+ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.43.0.tgz",
+ "integrity": "sha512-s2UHCoiXfxMvmfzqoN+vrQ84ahUSYde9qNO1MdxmoEhyHWsfmwOpFlwYV+ePJEVc7gFnATGUi376WowX1N7tFg==",
+ "dev": true,
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@humanwhocodes/config-array": {
+ "version": "0.11.10",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.10.tgz",
+ "integrity": "sha512-KVVjQmNUepDVGXNuoRRdmmEjruj0KfiGSbS8LVc12LMsWDQzRXJ0qdhN8L8uUigKpfEHRhlaQFY0ib1tnUbNeQ==",
+ "dev": true,
+ "dependencies": {
+ "@humanwhocodes/object-schema": "^1.2.1",
+ "debug": "^4.1.1",
+ "minimatch": "^3.0.5"
+ },
+ "engines": {
+ "node": ">=10.10.0"
+ }
+ },
+ "node_modules/@humanwhocodes/module-importer": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
+ "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
+ "dev": true,
+ "engines": {
+ "node": ">=12.22"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/nzakas"
+ }
+ },
+ "node_modules/@humanwhocodes/object-schema": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz",
+ "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==",
+ "dev": true
+ },
+ "node_modules/@istanbuljs/load-nyc-config": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz",
+ "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==",
+ "dev": true,
+ "dependencies": {
+ "camelcase": "^5.3.1",
+ "find-up": "^4.1.0",
+ "get-package-type": "^0.1.0",
+ "js-yaml": "^3.13.1",
+ "resolve-from": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config/node_modules/argparse": {
+ "version": "1.0.10",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
+ "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
+ "dev": true,
+ "dependencies": {
+ "sprintf-js": "~1.0.2"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config/node_modules/find-up": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
+ "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
+ "dev": true,
+ "dependencies": {
+ "locate-path": "^5.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config/node_modules/js-yaml": {
+ "version": "3.14.1",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz",
+ "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==",
+ "dev": true,
+ "dependencies": {
+ "argparse": "^1.0.7",
+ "esprima": "^4.0.0"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config/node_modules/locate-path": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
+ "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
+ "dev": true,
+ "dependencies": {
+ "p-locate": "^4.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config/node_modules/p-limit": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
+ "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
+ "dev": true,
+ "dependencies": {
+ "p-try": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config/node_modules/p-locate": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
+ "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
+ "dev": true,
+ "dependencies": {
+ "p-limit": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config/node_modules/resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@istanbuljs/schema": {
+ "version": "0.1.3",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz",
+ "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/console": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.5.0.tgz",
+ "integrity": "sha512-NEpkObxPwyw/XxZVLPmAGKE89IQRp4puc6IQRPru6JKd1M3fW9v1xM1AnzIJE65hbCkzQAdnL8P47e9hzhiYLQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "chalk": "^4.0.0",
+ "jest-message-util": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "slash": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/console/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/@jest/console/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/@jest/console/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/@jest/console/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/@jest/console/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/console/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/console/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/core": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.5.0.tgz",
+ "integrity": "sha512-28UzQc7ulUrOQw1IsN/kv1QES3q2kkbl/wGslyhAclqZ/8cMdB5M68BffkIdSJgKBUt50d3hbwJ92XESlE7LiQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/console": "^29.5.0",
+ "@jest/reporters": "^29.5.0",
+ "@jest/test-result": "^29.5.0",
+ "@jest/transform": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "ansi-escapes": "^4.2.1",
+ "chalk": "^4.0.0",
+ "ci-info": "^3.2.0",
+ "exit": "^0.1.2",
+ "graceful-fs": "^4.2.9",
+ "jest-changed-files": "^29.5.0",
+ "jest-config": "^29.5.0",
+ "jest-haste-map": "^29.5.0",
+ "jest-message-util": "^29.5.0",
+ "jest-regex-util": "^29.4.3",
+ "jest-resolve": "^29.5.0",
+ "jest-resolve-dependencies": "^29.5.0",
+ "jest-runner": "^29.5.0",
+ "jest-runtime": "^29.5.0",
+ "jest-snapshot": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "jest-validate": "^29.5.0",
+ "jest-watcher": "^29.5.0",
+ "micromatch": "^4.0.4",
+ "pretty-format": "^29.5.0",
+ "slash": "^3.0.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "peerDependencies": {
+ "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
+ },
+ "peerDependenciesMeta": {
+ "node-notifier": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@jest/core/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/@jest/core/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/@jest/core/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/@jest/core/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/@jest/core/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/core/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/core/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/environment": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.5.0.tgz",
+ "integrity": "sha512-5FXw2+wD29YU1d4I2htpRX7jYnAyTRjP2CsXQdo9SAM8g3ifxWPSV0HnClSn71xwctr0U3oZIIH+dtbfmnbXVQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/fake-timers": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "jest-mock": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/expect": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.5.0.tgz",
+ "integrity": "sha512-PueDR2HGihN3ciUNGr4uelropW7rqUfTiOn+8u0leg/42UhblPxHkfoh0Ruu3I9Y1962P3u2DY4+h7GVTSVU6g==",
+ "dev": true,
+ "dependencies": {
+ "expect": "^29.5.0",
+ "jest-snapshot": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/expect-utils": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.5.0.tgz",
+ "integrity": "sha512-fmKzsidoXQT2KwnrwE0SQq3uj8Z763vzR8LnLBwC2qYWEFpjX8daRsk6rHUM1QvNlEW/UJXNXm59ztmJJWs2Mg==",
+ "dev": true,
+ "dependencies": {
+ "jest-get-type": "^29.4.3"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/fake-timers": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.5.0.tgz",
+ "integrity": "sha512-9ARvuAAQcBwDAqOnglWq2zwNIRUDtk/SCkp/ToGEhFv5r86K21l+VEs0qNTaXtyiY0lEePl3kylijSYJQqdbDg==",
+ "dev": true,
+ "dependencies": {
+ "@jest/types": "^29.5.0",
+ "@sinonjs/fake-timers": "^10.0.2",
+ "@types/node": "*",
+ "jest-message-util": "^29.5.0",
+ "jest-mock": "^29.5.0",
+ "jest-util": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/globals": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.5.0.tgz",
+ "integrity": "sha512-S02y0qMWGihdzNbUiqSAiKSpSozSuHX5UYc7QbnHP+D9Lyw8DgGGCinrN9uSuHPeKgSSzvPom2q1nAtBvUsvPQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/environment": "^29.5.0",
+ "@jest/expect": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "jest-mock": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/reporters": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.5.0.tgz",
+ "integrity": "sha512-D05STXqj/M8bP9hQNSICtPqz97u7ffGzZu+9XLucXhkOFBqKcXe04JLZOgIekOxdb73MAoBUFnqvf7MCpKk5OA==",
+ "dev": true,
+ "dependencies": {
+ "@bcoe/v8-coverage": "^0.2.3",
+ "@jest/console": "^29.5.0",
+ "@jest/test-result": "^29.5.0",
+ "@jest/transform": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@jridgewell/trace-mapping": "^0.3.15",
+ "@types/node": "*",
+ "chalk": "^4.0.0",
+ "collect-v8-coverage": "^1.0.0",
+ "exit": "^0.1.2",
+ "glob": "^7.1.3",
+ "graceful-fs": "^4.2.9",
+ "istanbul-lib-coverage": "^3.0.0",
+ "istanbul-lib-instrument": "^5.1.0",
+ "istanbul-lib-report": "^3.0.0",
+ "istanbul-lib-source-maps": "^4.0.0",
+ "istanbul-reports": "^3.1.3",
+ "jest-message-util": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "jest-worker": "^29.5.0",
+ "slash": "^3.0.0",
+ "string-length": "^4.0.1",
+ "strip-ansi": "^6.0.0",
+ "v8-to-istanbul": "^9.0.1"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "peerDependencies": {
+ "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
+ },
+ "peerDependenciesMeta": {
+ "node-notifier": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@jest/reporters/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/@jest/reporters/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/@jest/reporters/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/@jest/reporters/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/@jest/reporters/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/reporters/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/reporters/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/schemas": {
+ "version": "29.4.3",
+ "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.4.3.tgz",
+ "integrity": "sha512-VLYKXQmtmuEz6IxJsrZwzG9NvtkQsWNnWMsKxqWNu3+CnfzJQhp0WDDKWLVV9hLKr0l3SLLFRqcYHjhtyuDVxg==",
+ "dev": true,
+ "dependencies": {
+ "@sinclair/typebox": "^0.25.16"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/source-map": {
+ "version": "29.4.3",
+ "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.4.3.tgz",
+ "integrity": "sha512-qyt/mb6rLyd9j1jUts4EQncvS6Yy3PM9HghnNv86QBlV+zdL2inCdK1tuVlL+J+lpiw2BI67qXOrX3UurBqQ1w==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/trace-mapping": "^0.3.15",
+ "callsites": "^3.0.0",
+ "graceful-fs": "^4.2.9"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/test-result": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.5.0.tgz",
+ "integrity": "sha512-fGl4rfitnbfLsrfx1uUpDEESS7zM8JdgZgOCQuxQvL1Sn/I6ijeAVQWGfXI9zb1i9Mzo495cIpVZhA0yr60PkQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/console": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "collect-v8-coverage": "^1.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/test-sequencer": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.5.0.tgz",
+ "integrity": "sha512-yPafQEcKjkSfDXyvtgiV4pevSeyuA6MQr6ZIdVkWJly9vkqjnFfcfhRQqpD5whjoU8EORki752xQmjaqoFjzMQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/test-result": "^29.5.0",
+ "graceful-fs": "^4.2.9",
+ "jest-haste-map": "^29.5.0",
+ "slash": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/test-sequencer/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/transform": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.5.0.tgz",
+ "integrity": "sha512-8vbeZWqLJOvHaDfeMuoHITGKSz5qWc9u04lnWrQE3VyuSw604PzQM824ZeX9XSjUCeDiE3GuxZe5UKa8J61NQw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.11.6",
+ "@jest/types": "^29.5.0",
+ "@jridgewell/trace-mapping": "^0.3.15",
+ "babel-plugin-istanbul": "^6.1.1",
+ "chalk": "^4.0.0",
+ "convert-source-map": "^2.0.0",
+ "fast-json-stable-stringify": "^2.1.0",
+ "graceful-fs": "^4.2.9",
+ "jest-haste-map": "^29.5.0",
+ "jest-regex-util": "^29.4.3",
+ "jest-util": "^29.5.0",
+ "micromatch": "^4.0.4",
+ "pirates": "^4.0.4",
+ "slash": "^3.0.0",
+ "write-file-atomic": "^4.0.2"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/transform/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/@jest/transform/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/@jest/transform/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/@jest/transform/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/@jest/transform/node_modules/convert-source-map": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz",
+ "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==",
+ "dev": true
+ },
+ "node_modules/@jest/transform/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/transform/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/transform/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/types": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.5.0.tgz",
+ "integrity": "sha512-qbu7kN6czmVRc3xWFQcAN03RAUamgppVUdXrvl1Wr3jlNF93o9mJbGcDWrwGB6ht44u7efB1qCFgVQmca24Uog==",
+ "dev": true,
+ "dependencies": {
+ "@jest/schemas": "^29.4.3",
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^3.0.0",
+ "@types/node": "*",
+ "@types/yargs": "^17.0.8",
+ "chalk": "^4.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@jest/types/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/@jest/types/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/@jest/types/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/@jest/types/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/@jest/types/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jest/types/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz",
+ "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/resolve-uri": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz",
+ "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/set-array": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz",
+ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.4.15",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz",
+ "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==",
+ "dev": true
+ },
+ "node_modules/@jridgewell/trace-mapping": {
+ "version": "0.3.18",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz",
+ "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/resolve-uri": "3.1.0",
+ "@jridgewell/sourcemap-codec": "1.4.14"
+ }
+ },
+ "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.4.14",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz",
+ "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==",
+ "dev": true
+ },
+ "node_modules/@nicolo-ribaudo/chokidar-2": {
+ "version": "2.1.8-no-fsevents.3",
+ "resolved": "https://registry.npmjs.org/@nicolo-ribaudo/chokidar-2/-/chokidar-2-2.1.8-no-fsevents.3.tgz",
+ "integrity": "sha512-s88O1aVtXftvp5bCPB7WnmXc5IwOZZ7YPuwNPt+GtOOXpPvad1LfbmjYv+qII7zP6RU2QGnqve27dnLycEnyEQ==",
+ "dev": true,
+ "optional": true
+ },
+ "node_modules/@nodelib/fs.scandir": {
+ "version": "2.1.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
+ "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.stat": "2.0.5",
+ "run-parallel": "^1.1.9"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.stat": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
+ "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.walk": {
+ "version": "1.2.8",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
+ "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.scandir": "2.1.5",
+ "fastq": "^1.6.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@sinclair/typebox": {
+ "version": "0.25.24",
+ "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.25.24.tgz",
+ "integrity": "sha512-XJfwUVUKDHF5ugKwIcxEgc9k8b7HbznCp6eUfWgu710hMPNIO4aw4/zB5RogDQz8nd6gyCDpU9O/m6qYEWY6yQ==",
+ "dev": true
+ },
+ "node_modules/@sinonjs/commons": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.0.tgz",
+ "integrity": "sha512-jXBtWAF4vmdNmZgD5FoKsVLv3rPgDnLgPbU84LIJ3otV44vJlDRokVng5v8NFJdCf/da9legHcKaRuZs4L7faA==",
+ "dev": true,
+ "dependencies": {
+ "type-detect": "4.0.8"
+ }
+ },
+ "node_modules/@sinonjs/fake-timers": {
+ "version": "10.3.0",
+ "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.3.0.tgz",
+ "integrity": "sha512-V4BG07kuYSUkTCSBHG8G8TNhM+F19jXFWnQtzj+we8DrkpSBCee9Z3Ms8yiGer/dlmhe35/Xdgyo3/0rQKg7YA==",
+ "dev": true,
+ "dependencies": {
+ "@sinonjs/commons": "^3.0.0"
+ }
+ },
+ "node_modules/@types/babel__core": {
+ "version": "7.20.1",
+ "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.1.tgz",
+ "integrity": "sha512-aACu/U/omhdk15O4Nfb+fHgH/z3QsfQzpnvRZhYhThms83ZnAOZz7zZAWO7mn2yyNQaA4xTO8GLK3uqFU4bYYw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/parser": "^7.20.7",
+ "@babel/types": "^7.20.7",
+ "@types/babel__generator": "*",
+ "@types/babel__template": "*",
+ "@types/babel__traverse": "*"
+ }
+ },
+ "node_modules/@types/babel__generator": {
+ "version": "7.6.4",
+ "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz",
+ "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.0.0"
+ }
+ },
+ "node_modules/@types/babel__template": {
+ "version": "7.4.1",
+ "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz",
+ "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/parser": "^7.1.0",
+ "@babel/types": "^7.0.0"
+ }
+ },
+ "node_modules/@types/babel__traverse": {
+ "version": "7.20.1",
+ "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.1.tgz",
+ "integrity": "sha512-MitHFXnhtgwsGZWtT68URpOvLN4EREih1u3QtQiN4VdAxWKRVvGCSvw/Qth0M0Qq3pJpnGOu5JaM/ydK7OGbqg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.20.7"
+ }
+ },
+ "node_modules/@types/graceful-fs": {
+ "version": "4.1.6",
+ "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz",
+ "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/istanbul-lib-coverage": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz",
+ "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==",
+ "dev": true
+ },
+ "node_modules/@types/istanbul-lib-report": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz",
+ "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==",
+ "dev": true,
+ "dependencies": {
+ "@types/istanbul-lib-coverage": "*"
+ }
+ },
+ "node_modules/@types/istanbul-reports": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz",
+ "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==",
+ "dev": true,
+ "dependencies": {
+ "@types/istanbul-lib-report": "*"
+ }
+ },
+ "node_modules/@types/node": {
+ "version": "20.3.2",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-20.3.2.tgz",
+ "integrity": "sha512-vOBLVQeCQfIcF/2Y7eKFTqrMnizK5lRNQ7ykML/5RuwVXVWxYkgwS7xbt4B6fKCUPgbSL5FSsjHQpaGQP/dQmw==",
+ "dev": true
+ },
+ "node_modules/@types/prettier": {
+ "version": "2.7.3",
+ "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.3.tgz",
+ "integrity": "sha512-+68kP9yzs4LMp7VNh8gdzMSPZFL44MLGqiHWvttYJe+6qnuVr4Ek9wSBQoveqY/r+LwjCcU29kNVkidwim+kYA==",
+ "dev": true
+ },
+ "node_modules/@types/stack-utils": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz",
+ "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==",
+ "dev": true
+ },
+ "node_modules/@types/yargs": {
+ "version": "17.0.24",
+ "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.24.tgz",
+ "integrity": "sha512-6i0aC7jV6QzQB8ne1joVZ0eSFIstHsCrobmOtghM11yGlH0j43FKL2UhWdELkyps0zuf7qVTUVCCR+tgSlyLLw==",
+ "dev": true,
+ "dependencies": {
+ "@types/yargs-parser": "*"
+ }
+ },
+ "node_modules/@types/yargs-parser": {
+ "version": "21.0.0",
+ "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz",
+ "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==",
+ "dev": true
+ },
+ "node_modules/acorn": {
+ "version": "8.9.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.9.0.tgz",
+ "integrity": "sha512-jaVNAFBHNLXspO543WnNNPZFRtavh3skAkITqD0/2aeMkKZTN+254PyhwxFYrk3vQ1xfY+2wbesJMs/JC8/PwQ==",
+ "dev": true,
+ "bin": {
+ "acorn": "bin/acorn"
+ },
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/acorn-jsx": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
+ "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
+ "dev": true,
+ "peerDependencies": {
+ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/ansi-escapes": {
+ "version": "4.3.2",
+ "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz",
+ "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.21.3"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/ansi-escapes/node_modules/type-fest": {
+ "version": "0.21.3",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz",
+ "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/ansi-regex": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
+ "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^1.9.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/anymatch": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz",
+ "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
+ "dev": true,
+ "dependencies": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/argparse": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
+ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
+ "dev": true
+ },
+ "node_modules/babel-jest": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.5.0.tgz",
+ "integrity": "sha512-mA4eCDh5mSo2EcA9xQjVTpmbbNk32Zb3Q3QFQsNhaK56Q+yoXowzFodLux30HRgyOho5rsQ6B0P9QpMkvvnJ0Q==",
+ "dev": true,
+ "dependencies": {
+ "@jest/transform": "^29.5.0",
+ "@types/babel__core": "^7.1.14",
+ "babel-plugin-istanbul": "^6.1.1",
+ "babel-preset-jest": "^29.5.0",
+ "chalk": "^4.0.0",
+ "graceful-fs": "^4.2.9",
+ "slash": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.8.0"
+ }
+ },
+ "node_modules/babel-jest/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/babel-jest/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/babel-jest/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/babel-jest/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/babel-jest/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/babel-jest/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/babel-jest/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/babel-plugin-istanbul": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz",
+ "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@istanbuljs/load-nyc-config": "^1.0.0",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-instrument": "^5.0.4",
+ "test-exclude": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/babel-plugin-jest-hoist": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.5.0.tgz",
+ "integrity": "sha512-zSuuuAlTMT4mzLj2nPnUm6fsE6270vdOfnpbJ+RmruU75UhLFvL0N2NgI7xpeS7NaB6hGqmd5pVpGTDYvi4Q3w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/template": "^7.3.3",
+ "@babel/types": "^7.3.3",
+ "@types/babel__core": "^7.1.14",
+ "@types/babel__traverse": "^7.0.6"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-corejs2": {
+ "version": "0.4.3",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.3.tgz",
+ "integrity": "sha512-bM3gHc337Dta490gg+/AseNB9L4YLHxq1nGKZZSHbhXv4aTYU2MD2cjza1Ru4S6975YLTaL1K8uJf6ukJhhmtw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.17.7",
+ "@babel/helper-define-polyfill-provider": "^0.4.0",
+ "semver": "^6.1.1"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-corejs3": {
+ "version": "0.8.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.8.1.tgz",
+ "integrity": "sha512-ikFrZITKg1xH6pLND8zT14UPgjKHiGLqex7rGEZCH2EvhsneJaJPemmpQaIZV5AL03II+lXylw3UmddDK8RU5Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-define-polyfill-provider": "^0.4.0",
+ "core-js-compat": "^3.30.1"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-regenerator": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.5.0.tgz",
+ "integrity": "sha512-hDJtKjMLVa7Z+LwnTCxoDLQj6wdc+B8dun7ayF2fYieI6OzfuvcLMB32ihJZ4UhCBwNYGl5bg/x/P9cMdnkc2g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-define-polyfill-provider": "^0.4.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/babel-preset-current-node-syntax": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz",
+ "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/plugin-syntax-async-generators": "^7.8.4",
+ "@babel/plugin-syntax-bigint": "^7.8.3",
+ "@babel/plugin-syntax-class-properties": "^7.8.3",
+ "@babel/plugin-syntax-import-meta": "^7.8.3",
+ "@babel/plugin-syntax-json-strings": "^7.8.3",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
+ "@babel/plugin-syntax-numeric-separator": "^7.8.3",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3",
+ "@babel/plugin-syntax-top-level-await": "^7.8.3"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/babel-preset-jest": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.5.0.tgz",
+ "integrity": "sha512-JOMloxOqdiBSxMAzjRaH023/vvcaSaec49zvg+2LmNsktC7ei39LTJGw02J+9uUtTZUq6xbLyJ4dxe9sSmIuAg==",
+ "dev": true,
+ "dependencies": {
+ "babel-plugin-jest-hoist": "^29.5.0",
+ "babel-preset-current-node-syntax": "^1.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
+ "dev": true
+ },
+ "node_modules/binary-extensions": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
+ "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
+ "dev": true,
+ "optional": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "dev": true,
+ "dependencies": {
+ "fill-range": "^7.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/browserslist": {
+ "version": "4.21.9",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.9.tgz",
+ "integrity": "sha512-M0MFoZzbUrRU4KNfCrDLnvyE7gub+peetoTid3TBIqtunaDJyXlwhakT+/VkvSXcfIzFfK/nkCs4nmyTmxdNSg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "dependencies": {
+ "caniuse-lite": "^1.0.30001503",
+ "electron-to-chromium": "^1.4.431",
+ "node-releases": "^2.0.12",
+ "update-browserslist-db": "^1.0.11"
+ },
+ "bin": {
+ "browserslist": "cli.js"
+ },
+ "engines": {
+ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
+ }
+ },
+ "node_modules/bser": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz",
+ "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==",
+ "dev": true,
+ "dependencies": {
+ "node-int64": "^0.4.0"
+ }
+ },
+ "node_modules/buffer-from": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==",
+ "dev": true
+ },
+ "node_modules/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/camelcase": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
+ "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001508",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001508.tgz",
+ "integrity": "sha512-sdQZOJdmt3GJs1UMNpCCCyeuS2IEGLXnHyAo9yIO5JJDjbjoVRij4M1qep6P6gFpptD1PqIYgzM+gwJbOi92mw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ]
+ },
+ "node_modules/chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/char-regex": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz",
+ "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/chokidar": {
+ "version": "3.5.3",
+ "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
+ "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://paulmillr.com/funding/"
+ }
+ ],
+ "optional": true,
+ "dependencies": {
+ "anymatch": "~3.1.2",
+ "braces": "~3.0.2",
+ "glob-parent": "~5.1.2",
+ "is-binary-path": "~2.1.0",
+ "is-glob": "~4.0.1",
+ "normalize-path": "~3.0.0",
+ "readdirp": "~3.6.0"
+ },
+ "engines": {
+ "node": ">= 8.10.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/ci-info": {
+ "version": "3.8.0",
+ "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz",
+ "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/sibiraj-s"
+ }
+ ],
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/cjs-module-lexer": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.3.tgz",
+ "integrity": "sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ==",
+ "dev": true
+ },
+ "node_modules/cliui": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz",
+ "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==",
+ "dev": true,
+ "dependencies": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.1",
+ "wrap-ansi": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/co": {
+ "version": "4.6.0",
+ "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz",
+ "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==",
+ "dev": true,
+ "engines": {
+ "iojs": ">= 1.0.0",
+ "node": ">= 0.12.0"
+ }
+ },
+ "node_modules/collect-v8-coverage": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz",
+ "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==",
+ "dev": true
+ },
+ "node_modules/color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "1.1.3"
+ }
+ },
+ "node_modules/color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==",
+ "dev": true
+ },
+ "node_modules/commander": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz",
+ "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
+ "dev": true
+ },
+ "node_modules/convert-source-map": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz",
+ "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==",
+ "dev": true
+ },
+ "node_modules/core-js-compat": {
+ "version": "3.31.0",
+ "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.31.0.tgz",
+ "integrity": "sha512-hM7YCu1cU6Opx7MXNu0NuumM0ezNeAeRKadixyiQELWY3vT3De9S4J5ZBMraWV2vZnrE1Cirl0GtFtDtMUXzPw==",
+ "dev": true,
+ "dependencies": {
+ "browserslist": "^4.21.5"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/core-js"
+ }
+ },
+ "node_modules/cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "dependencies": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/debug": {
+ "version": "4.3.4",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
+ "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.1.2"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/dedent": {
+ "version": "0.7.0",
+ "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz",
+ "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==",
+ "dev": true
+ },
+ "node_modules/deep-is": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
+ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
+ "dev": true
+ },
+ "node_modules/deepmerge": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz",
+ "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/detect-newline": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz",
+ "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/diff-sequences": {
+ "version": "29.4.3",
+ "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.4.3.tgz",
+ "integrity": "sha512-ofrBgwpPhCD85kMKtE9RYFFq6OC1A89oW2vvgWZNCwxrUpRUILopY7lsYyMDSjc8g6U6aiO0Qubg6r4Wgt5ZnA==",
+ "dev": true,
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/doctrine": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
+ "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
+ "dev": true,
+ "dependencies": {
+ "esutils": "^2.0.2"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/electron-to-chromium": {
+ "version": "1.4.441",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.441.tgz",
+ "integrity": "sha512-LlCgQ8zgYZPymf5H4aE9itwiIWH4YlCiv1HFLmmcBeFYi5E+3eaIFnjHzYtcFQbaKfAW+CqZ9pgxo33DZuoqPg==",
+ "dev": true
+ },
+ "node_modules/emittery": {
+ "version": "0.13.1",
+ "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz",
+ "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sindresorhus/emittery?sponsor=1"
+ }
+ },
+ "node_modules/emoji-regex": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
+ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
+ "dev": true
+ },
+ "node_modules/error-ex": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
+ "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
+ "dev": true,
+ "dependencies": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "node_modules/esbuild": {
+ "version": "0.17.19",
+ "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz",
+ "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==",
+ "dev": true,
+ "hasInstallScript": true,
+ "bin": {
+ "esbuild": "bin/esbuild"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "optionalDependencies": {
+ "@esbuild/android-arm": "0.17.19",
+ "@esbuild/android-arm64": "0.17.19",
+ "@esbuild/android-x64": "0.17.19",
+ "@esbuild/darwin-arm64": "0.17.19",
+ "@esbuild/darwin-x64": "0.17.19",
+ "@esbuild/freebsd-arm64": "0.17.19",
+ "@esbuild/freebsd-x64": "0.17.19",
+ "@esbuild/linux-arm": "0.17.19",
+ "@esbuild/linux-arm64": "0.17.19",
+ "@esbuild/linux-ia32": "0.17.19",
+ "@esbuild/linux-loong64": "0.17.19",
+ "@esbuild/linux-mips64el": "0.17.19",
+ "@esbuild/linux-ppc64": "0.17.19",
+ "@esbuild/linux-riscv64": "0.17.19",
+ "@esbuild/linux-s390x": "0.17.19",
+ "@esbuild/linux-x64": "0.17.19",
+ "@esbuild/netbsd-x64": "0.17.19",
+ "@esbuild/openbsd-x64": "0.17.19",
+ "@esbuild/sunos-x64": "0.17.19",
+ "@esbuild/win32-arm64": "0.17.19",
+ "@esbuild/win32-ia32": "0.17.19",
+ "@esbuild/win32-x64": "0.17.19"
+ }
+ },
+ "node_modules/escalade": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
+ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/eslint": {
+ "version": "8.43.0",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.43.0.tgz",
+ "integrity": "sha512-aaCpf2JqqKesMFGgmRPessmVKjcGXqdlAYLLC3THM8t5nBRZRQ+st5WM/hoJXkdioEXLLbXgclUpM0TXo5HX5Q==",
+ "dev": true,
+ "dependencies": {
+ "@eslint-community/eslint-utils": "^4.2.0",
+ "@eslint-community/regexpp": "^4.4.0",
+ "@eslint/eslintrc": "^2.0.3",
+ "@eslint/js": "8.43.0",
+ "@humanwhocodes/config-array": "^0.11.10",
+ "@humanwhocodes/module-importer": "^1.0.1",
+ "@nodelib/fs.walk": "^1.2.8",
+ "ajv": "^6.10.0",
+ "chalk": "^4.0.0",
+ "cross-spawn": "^7.0.2",
+ "debug": "^4.3.2",
+ "doctrine": "^3.0.0",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^7.2.0",
+ "eslint-visitor-keys": "^3.4.1",
+ "espree": "^9.5.2",
+ "esquery": "^1.4.2",
+ "esutils": "^2.0.2",
+ "fast-deep-equal": "^3.1.3",
+ "file-entry-cache": "^6.0.1",
+ "find-up": "^5.0.0",
+ "glob-parent": "^6.0.2",
+ "globals": "^13.19.0",
+ "graphemer": "^1.4.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.0.0",
+ "imurmurhash": "^0.1.4",
+ "is-glob": "^4.0.0",
+ "is-path-inside": "^3.0.3",
+ "js-yaml": "^4.1.0",
+ "json-stable-stringify-without-jsonify": "^1.0.1",
+ "levn": "^0.4.1",
+ "lodash.merge": "^4.6.2",
+ "minimatch": "^3.1.2",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.1",
+ "strip-ansi": "^6.0.1",
+ "strip-json-comments": "^3.1.0",
+ "text-table": "^0.2.0"
+ },
+ "bin": {
+ "eslint": "bin/eslint.js"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.0.tgz",
+ "integrity": "sha512-DYj5deGlHBfMt15J7rdtyKNq/Nqlv5KfU4iodrQ019XESsRnwXH9KAE0y3cwtUHDo2ob7CypAnCqefh6vioWRw==",
+ "dev": true,
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-visitor-keys": {
+ "version": "3.4.1",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.1.tgz",
+ "integrity": "sha512-pZnmmLwYzf+kWaM/Qgrvpen51upAktaaiI01nsJD/Yr3lMOdNtq0cxkrrg16w64VtisN6okbs7Q8AfGqj4c9fA==",
+ "dev": true,
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/eslint/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/eslint/node_modules/escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint/node_modules/glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "dependencies": {
+ "is-glob": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/eslint/node_modules/globals": {
+ "version": "13.20.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.20.0.tgz",
+ "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/eslint/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/espree": {
+ "version": "9.5.2",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-9.5.2.tgz",
+ "integrity": "sha512-7OASN1Wma5fum5SrNhFMAMJxOUAbhyfQ8dQ//PJaJbNw0URTPWqIghHWt1MmAANKhHZIYOHruW4Kw4ruUWOdGw==",
+ "dev": true,
+ "dependencies": {
+ "acorn": "^8.8.0",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^3.4.1"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/esprima": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
+ "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
+ "dev": true,
+ "bin": {
+ "esparse": "bin/esparse.js",
+ "esvalidate": "bin/esvalidate.js"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/esquery": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz",
+ "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==",
+ "dev": true,
+ "dependencies": {
+ "estraverse": "^5.1.0"
+ },
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "dependencies": {
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/execa": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz",
+ "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==",
+ "dev": true,
+ "dependencies": {
+ "cross-spawn": "^7.0.3",
+ "get-stream": "^6.0.0",
+ "human-signals": "^2.1.0",
+ "is-stream": "^2.0.0",
+ "merge-stream": "^2.0.0",
+ "npm-run-path": "^4.0.1",
+ "onetime": "^5.1.2",
+ "signal-exit": "^3.0.3",
+ "strip-final-newline": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sindresorhus/execa?sponsor=1"
+ }
+ },
+ "node_modules/exit": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz",
+ "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/expect": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/expect/-/expect-29.5.0.tgz",
+ "integrity": "sha512-yM7xqUrCO2JdpFo4XpM82t+PJBFybdqoQuJLDGeDX2ij8NZzqRHyu3Hp188/JX7SWqud+7t4MUdvcgGBICMHZg==",
+ "dev": true,
+ "dependencies": {
+ "@jest/expect-utils": "^29.5.0",
+ "jest-get-type": "^29.4.3",
+ "jest-matcher-utils": "^29.5.0",
+ "jest-message-util": "^29.5.0",
+ "jest-util": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true
+ },
+ "node_modules/fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true
+ },
+ "node_modules/fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
+ "dev": true
+ },
+ "node_modules/fastq": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz",
+ "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==",
+ "dev": true,
+ "dependencies": {
+ "reusify": "^1.0.4"
+ }
+ },
+ "node_modules/fb-watchman": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz",
+ "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==",
+ "dev": true,
+ "dependencies": {
+ "bser": "2.1.1"
+ }
+ },
+ "node_modules/file-entry-cache": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
+ "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==",
+ "dev": true,
+ "dependencies": {
+ "flat-cache": "^3.0.4"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "dev": true,
+ "dependencies": {
+ "to-regex-range": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/find-up": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
+ "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
+ "dev": true,
+ "dependencies": {
+ "locate-path": "^6.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/flat-cache": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz",
+ "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==",
+ "dev": true,
+ "dependencies": {
+ "flatted": "^3.1.0",
+ "rimraf": "^3.0.2"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/flatted": {
+ "version": "3.2.7",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz",
+ "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==",
+ "dev": true
+ },
+ "node_modules/fs-readdir-recursive": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/fs-readdir-recursive/-/fs-readdir-recursive-1.1.0.tgz",
+ "integrity": "sha512-GNanXlVr2pf02+sPN40XN8HG+ePaNcvM0q5mZBd668Obwb0yD5GiUbZOFgwn8kGMY6I3mdyDJzieUy3PTYyTRA==",
+ "dev": true
+ },
+ "node_modules/fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==",
+ "dev": true
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
+ "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
+ "dev": true,
+ "hasInstallScript": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "node_modules/function-bind": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
+ "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
+ "dev": true
+ },
+ "node_modules/gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/get-caller-file": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
+ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
+ "dev": true,
+ "engines": {
+ "node": "6.* || 8.* || >= 10.*"
+ }
+ },
+ "node_modules/get-package-type": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz",
+ "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8.0.0"
+ }
+ },
+ "node_modules/get-stream": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz",
+ "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "is-glob": "^4.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/graceful-fs": {
+ "version": "4.2.11",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
+ "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
+ "dev": true
+ },
+ "node_modules/graphemer": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz",
+ "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==",
+ "dev": true
+ },
+ "node_modules/has": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
+ "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
+ "dev": true,
+ "dependencies": {
+ "function-bind": "^1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.4.0"
+ }
+ },
+ "node_modules/has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/html-escaper": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz",
+ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==",
+ "dev": true
+ },
+ "node_modules/human-signals": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz",
+ "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.17.0"
+ }
+ },
+ "node_modules/ignore": {
+ "version": "5.2.4",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz",
+ "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
+ "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
+ "dev": true,
+ "dependencies": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/import-local": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz",
+ "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==",
+ "dev": true,
+ "dependencies": {
+ "pkg-dir": "^4.2.0",
+ "resolve-cwd": "^3.0.0"
+ },
+ "bin": {
+ "import-local-fixture": "fixtures/cli.js"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.19"
+ }
+ },
+ "node_modules/inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
+ "dev": true,
+ "dependencies": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "node_modules/inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
+ "dev": true
+ },
+ "node_modules/is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "dev": true
+ },
+ "node_modules/is-binary-path": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "binary-extensions": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-core-module": {
+ "version": "2.12.1",
+ "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz",
+ "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==",
+ "dev": true,
+ "dependencies": {
+ "has": "^1.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-generator-fn": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz",
+ "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dev": true,
+ "dependencies": {
+ "is-extglob": "^2.1.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.12.0"
+ }
+ },
+ "node_modules/is-path-inside": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
+ "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-stream": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz",
+ "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true
+ },
+ "node_modules/istanbul-lib-coverage": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz",
+ "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-instrument": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz",
+ "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.12.3",
+ "@babel/parser": "^7.14.7",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-coverage": "^3.2.0",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-report": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz",
+ "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==",
+ "dev": true,
+ "dependencies": {
+ "istanbul-lib-coverage": "^3.0.0",
+ "make-dir": "^3.0.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-report/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-report/node_modules/make-dir": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
+ "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
+ "dev": true,
+ "dependencies": {
+ "semver": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/istanbul-lib-report/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-source-maps": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz",
+ "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==",
+ "dev": true,
+ "dependencies": {
+ "debug": "^4.1.1",
+ "istanbul-lib-coverage": "^3.0.0",
+ "source-map": "^0.6.1"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/istanbul-reports": {
+ "version": "3.1.5",
+ "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz",
+ "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==",
+ "dev": true,
+ "dependencies": {
+ "html-escaper": "^2.0.0",
+ "istanbul-lib-report": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest/-/jest-29.5.0.tgz",
+ "integrity": "sha512-juMg3he2uru1QoXX078zTa7pO85QyB9xajZc6bU+d9yEGwrKX6+vGmJQ3UdVZsvTEUARIdObzH68QItim6OSSQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/core": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "import-local": "^3.0.2",
+ "jest-cli": "^29.5.0"
+ },
+ "bin": {
+ "jest": "bin/jest.js"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "peerDependencies": {
+ "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
+ },
+ "peerDependenciesMeta": {
+ "node-notifier": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/jest-changed-files": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.5.0.tgz",
+ "integrity": "sha512-IFG34IUMUaNBIxjQXF/iu7g6EcdMrGRRxaUSw92I/2g2YC6vCdTltl4nHvt7Ci5nSJwXIkCu8Ka1DKF+X7Z1Ag==",
+ "dev": true,
+ "dependencies": {
+ "execa": "^5.0.0",
+ "p-limit": "^3.1.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-circus": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.5.0.tgz",
+ "integrity": "sha512-gq/ongqeQKAplVxqJmbeUOJJKkW3dDNPY8PjhJ5G0lBRvu0e3EWGxGy5cI4LAGA7gV2UHCtWBI4EMXK8c9nQKA==",
+ "dev": true,
+ "dependencies": {
+ "@jest/environment": "^29.5.0",
+ "@jest/expect": "^29.5.0",
+ "@jest/test-result": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "chalk": "^4.0.0",
+ "co": "^4.6.0",
+ "dedent": "^0.7.0",
+ "is-generator-fn": "^2.0.0",
+ "jest-each": "^29.5.0",
+ "jest-matcher-utils": "^29.5.0",
+ "jest-message-util": "^29.5.0",
+ "jest-runtime": "^29.5.0",
+ "jest-snapshot": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "p-limit": "^3.1.0",
+ "pretty-format": "^29.5.0",
+ "pure-rand": "^6.0.0",
+ "slash": "^3.0.0",
+ "stack-utils": "^2.0.3"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-circus/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-circus/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-circus/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-circus/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-circus/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-circus/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-circus/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-cli": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.5.0.tgz",
+ "integrity": "sha512-L1KcP1l4HtfwdxXNFCL5bmUbLQiKrakMUriBEcc1Vfz6gx31ORKdreuWvmQVBit+1ss9NNR3yxjwfwzZNdQXJw==",
+ "dev": true,
+ "dependencies": {
+ "@jest/core": "^29.5.0",
+ "@jest/test-result": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "chalk": "^4.0.0",
+ "exit": "^0.1.2",
+ "graceful-fs": "^4.2.9",
+ "import-local": "^3.0.2",
+ "jest-config": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "jest-validate": "^29.5.0",
+ "prompts": "^2.0.1",
+ "yargs": "^17.3.1"
+ },
+ "bin": {
+ "jest": "bin/jest.js"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "peerDependencies": {
+ "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
+ },
+ "peerDependenciesMeta": {
+ "node-notifier": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/jest-cli/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-cli/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-cli/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-cli/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-cli/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-cli/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-config": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.5.0.tgz",
+ "integrity": "sha512-kvDUKBnNJPNBmFFOhDbm59iu1Fii1Q6SxyhXfvylq3UTHbg6o7j/g8k2dZyXWLvfdKB1vAPxNZnMgtKJcmu3kA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.11.6",
+ "@jest/test-sequencer": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "babel-jest": "^29.5.0",
+ "chalk": "^4.0.0",
+ "ci-info": "^3.2.0",
+ "deepmerge": "^4.2.2",
+ "glob": "^7.1.3",
+ "graceful-fs": "^4.2.9",
+ "jest-circus": "^29.5.0",
+ "jest-environment-node": "^29.5.0",
+ "jest-get-type": "^29.4.3",
+ "jest-regex-util": "^29.4.3",
+ "jest-resolve": "^29.5.0",
+ "jest-runner": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "jest-validate": "^29.5.0",
+ "micromatch": "^4.0.4",
+ "parse-json": "^5.2.0",
+ "pretty-format": "^29.5.0",
+ "slash": "^3.0.0",
+ "strip-json-comments": "^3.1.1"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "peerDependencies": {
+ "@types/node": "*",
+ "ts-node": ">=9.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ },
+ "ts-node": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/jest-config/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-config/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-config/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-config/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-config/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-config/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-config/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-diff": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.5.0.tgz",
+ "integrity": "sha512-LtxijLLZBduXnHSniy0WMdaHjmQnt3g5sa16W4p0HqukYTTsyTW3GD1q41TyGl5YFXj/5B2U6dlh5FM1LIMgxw==",
+ "dev": true,
+ "dependencies": {
+ "chalk": "^4.0.0",
+ "diff-sequences": "^29.4.3",
+ "jest-get-type": "^29.4.3",
+ "pretty-format": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-diff/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-diff/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-diff/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-diff/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-diff/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-diff/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-docblock": {
+ "version": "29.4.3",
+ "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.4.3.tgz",
+ "integrity": "sha512-fzdTftThczeSD9nZ3fzA/4KkHtnmllawWrXO69vtI+L9WjEIuXWs4AmyME7lN5hU7dB0sHhuPfcKofRsUb/2Fg==",
+ "dev": true,
+ "dependencies": {
+ "detect-newline": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-each": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.5.0.tgz",
+ "integrity": "sha512-HM5kIJ1BTnVt+DQZ2ALp3rzXEl+g726csObrW/jpEGl+CDSSQpOJJX2KE/vEg8cxcMXdyEPu6U4QX5eruQv5hA==",
+ "dev": true,
+ "dependencies": {
+ "@jest/types": "^29.5.0",
+ "chalk": "^4.0.0",
+ "jest-get-type": "^29.4.3",
+ "jest-util": "^29.5.0",
+ "pretty-format": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-each/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-each/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-each/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-each/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-each/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-each/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-environment-node": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.5.0.tgz",
+ "integrity": "sha512-ExxuIK/+yQ+6PRGaHkKewYtg6hto2uGCgvKdb2nfJfKXgZ17DfXjvbZ+jA1Qt9A8EQSfPnt5FKIfnOO3u1h9qw==",
+ "dev": true,
+ "dependencies": {
+ "@jest/environment": "^29.5.0",
+ "@jest/fake-timers": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "jest-mock": "^29.5.0",
+ "jest-util": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-get-type": {
+ "version": "29.4.3",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.4.3.tgz",
+ "integrity": "sha512-J5Xez4nRRMjk8emnTpWrlkyb9pfRQQanDrvWHhsR1+VUfbwxi30eVcZFlcdGInRibU4G5LwHXpI7IRHU0CY+gg==",
+ "dev": true,
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-haste-map": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.5.0.tgz",
+ "integrity": "sha512-IspOPnnBro8YfVYSw6yDRKh/TiCdRngjxeacCps1cQ9cgVN6+10JUcuJ1EabrgYLOATsIAigxA0rLR9x/YlrSA==",
+ "dev": true,
+ "dependencies": {
+ "@jest/types": "^29.5.0",
+ "@types/graceful-fs": "^4.1.3",
+ "@types/node": "*",
+ "anymatch": "^3.0.3",
+ "fb-watchman": "^2.0.0",
+ "graceful-fs": "^4.2.9",
+ "jest-regex-util": "^29.4.3",
+ "jest-util": "^29.5.0",
+ "jest-worker": "^29.5.0",
+ "micromatch": "^4.0.4",
+ "walker": "^1.0.8"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "^2.3.2"
+ }
+ },
+ "node_modules/jest-leak-detector": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.5.0.tgz",
+ "integrity": "sha512-u9YdeeVnghBUtpN5mVxjID7KbkKE1QU4f6uUwuxiY0vYRi9BUCLKlPEZfDGR67ofdFmDz9oPAy2G92Ujrntmow==",
+ "dev": true,
+ "dependencies": {
+ "jest-get-type": "^29.4.3",
+ "pretty-format": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-matcher-utils": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.5.0.tgz",
+ "integrity": "sha512-lecRtgm/rjIK0CQ7LPQwzCs2VwW6WAahA55YBuI+xqmhm7LAaxokSB8C97yJeYyT+HvQkH741StzpU41wohhWw==",
+ "dev": true,
+ "dependencies": {
+ "chalk": "^4.0.0",
+ "jest-diff": "^29.5.0",
+ "jest-get-type": "^29.4.3",
+ "pretty-format": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-matcher-utils/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-matcher-utils/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-matcher-utils/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-matcher-utils/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-matcher-utils/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-matcher-utils/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-message-util": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.5.0.tgz",
+ "integrity": "sha512-Kijeg9Dag6CKtIDA7O21zNTACqD5MD/8HfIV8pdD94vFyFuer52SigdC3IQMhab3vACxXMiFk+yMHNdbqtyTGA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.12.13",
+ "@jest/types": "^29.5.0",
+ "@types/stack-utils": "^2.0.0",
+ "chalk": "^4.0.0",
+ "graceful-fs": "^4.2.9",
+ "micromatch": "^4.0.4",
+ "pretty-format": "^29.5.0",
+ "slash": "^3.0.0",
+ "stack-utils": "^2.0.3"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-message-util/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-message-util/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-message-util/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-message-util/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-message-util/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-message-util/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-message-util/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-mock": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.5.0.tgz",
+ "integrity": "sha512-GqOzvdWDE4fAV2bWQLQCkujxYWL7RxjCnj71b5VhDAGOevB3qj3Ovg26A5NI84ZpODxyzaozXLOh2NCgkbvyaw==",
+ "dev": true,
+ "dependencies": {
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "jest-util": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-pnp-resolver": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz",
+ "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ },
+ "peerDependencies": {
+ "jest-resolve": "*"
+ },
+ "peerDependenciesMeta": {
+ "jest-resolve": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/jest-regex-util": {
+ "version": "29.4.3",
+ "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.4.3.tgz",
+ "integrity": "sha512-O4FglZaMmWXbGHSQInfXewIsd1LMn9p3ZXB/6r4FOkyhX2/iP/soMG98jGvk/A3HAN78+5VWcBGO0BJAPRh4kg==",
+ "dev": true,
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-resolve": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.5.0.tgz",
+ "integrity": "sha512-1TzxJ37FQq7J10jPtQjcc+MkCkE3GBpBecsSUWJ0qZNJpmg6m0D9/7II03yJulm3H/fvVjgqLh/k2eYg+ui52w==",
+ "dev": true,
+ "dependencies": {
+ "chalk": "^4.0.0",
+ "graceful-fs": "^4.2.9",
+ "jest-haste-map": "^29.5.0",
+ "jest-pnp-resolver": "^1.2.2",
+ "jest-util": "^29.5.0",
+ "jest-validate": "^29.5.0",
+ "resolve": "^1.20.0",
+ "resolve.exports": "^2.0.0",
+ "slash": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-resolve-dependencies": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.5.0.tgz",
+ "integrity": "sha512-sjV3GFr0hDJMBpYeUuGduP+YeCRbd7S/ck6IvL3kQ9cpySYKqcqhdLLC2rFwrcL7tz5vYibomBrsFYWkIGGjOg==",
+ "dev": true,
+ "dependencies": {
+ "jest-regex-util": "^29.4.3",
+ "jest-snapshot": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-resolve/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-resolve/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-resolve/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-resolve/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-resolve/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-resolve/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-resolve/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-runner": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.5.0.tgz",
+ "integrity": "sha512-m7b6ypERhFghJsslMLhydaXBiLf7+jXy8FwGRHO3BGV1mcQpPbwiqiKUR2zU2NJuNeMenJmlFZCsIqzJCTeGLQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/console": "^29.5.0",
+ "@jest/environment": "^29.5.0",
+ "@jest/test-result": "^29.5.0",
+ "@jest/transform": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "chalk": "^4.0.0",
+ "emittery": "^0.13.1",
+ "graceful-fs": "^4.2.9",
+ "jest-docblock": "^29.4.3",
+ "jest-environment-node": "^29.5.0",
+ "jest-haste-map": "^29.5.0",
+ "jest-leak-detector": "^29.5.0",
+ "jest-message-util": "^29.5.0",
+ "jest-resolve": "^29.5.0",
+ "jest-runtime": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "jest-watcher": "^29.5.0",
+ "jest-worker": "^29.5.0",
+ "p-limit": "^3.1.0",
+ "source-map-support": "0.5.13"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-runner/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-runner/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-runner/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-runner/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-runner/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-runner/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-runtime": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.5.0.tgz",
+ "integrity": "sha512-1Hr6Hh7bAgXQP+pln3homOiEZtCDZFqwmle7Ew2j8OlbkIu6uE3Y/etJQG8MLQs3Zy90xrp2C0BRrtPHG4zryw==",
+ "dev": true,
+ "dependencies": {
+ "@jest/environment": "^29.5.0",
+ "@jest/fake-timers": "^29.5.0",
+ "@jest/globals": "^29.5.0",
+ "@jest/source-map": "^29.4.3",
+ "@jest/test-result": "^29.5.0",
+ "@jest/transform": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "chalk": "^4.0.0",
+ "cjs-module-lexer": "^1.0.0",
+ "collect-v8-coverage": "^1.0.0",
+ "glob": "^7.1.3",
+ "graceful-fs": "^4.2.9",
+ "jest-haste-map": "^29.5.0",
+ "jest-message-util": "^29.5.0",
+ "jest-mock": "^29.5.0",
+ "jest-regex-util": "^29.4.3",
+ "jest-resolve": "^29.5.0",
+ "jest-snapshot": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "slash": "^3.0.0",
+ "strip-bom": "^4.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-runtime/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-runtime/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-runtime/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-runtime/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-runtime/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-runtime/node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-runtime/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-snapshot": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.5.0.tgz",
+ "integrity": "sha512-x7Wolra5V0tt3wRs3/ts3S6ciSQVypgGQlJpz2rsdQYoUKxMxPNaoHMGJN6qAuPJqS+2iQ1ZUn5kl7HCyls84g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.11.6",
+ "@babel/generator": "^7.7.2",
+ "@babel/plugin-syntax-jsx": "^7.7.2",
+ "@babel/plugin-syntax-typescript": "^7.7.2",
+ "@babel/traverse": "^7.7.2",
+ "@babel/types": "^7.3.3",
+ "@jest/expect-utils": "^29.5.0",
+ "@jest/transform": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/babel__traverse": "^7.0.6",
+ "@types/prettier": "^2.1.5",
+ "babel-preset-current-node-syntax": "^1.0.0",
+ "chalk": "^4.0.0",
+ "expect": "^29.5.0",
+ "graceful-fs": "^4.2.9",
+ "jest-diff": "^29.5.0",
+ "jest-get-type": "^29.4.3",
+ "jest-matcher-utils": "^29.5.0",
+ "jest-message-util": "^29.5.0",
+ "jest-util": "^29.5.0",
+ "natural-compare": "^1.4.0",
+ "pretty-format": "^29.5.0",
+ "semver": "^7.3.5"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-snapshot/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/semver": {
+ "version": "7.5.3",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.3.tgz",
+ "integrity": "sha512-QBlUtyVk/5EeHbi7X0fw6liDZc7BBmEaSYn01fMU1OUYbf6GPsbTtd8WmnqbI20SeycoHSeiybkE/q1Q+qlThQ==",
+ "dev": true,
+ "dependencies": {
+ "lru-cache": "^6.0.0"
+ },
+ "bin": {
+ "semver": "bin/semver.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-snapshot/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/jest-util": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.5.0.tgz",
+ "integrity": "sha512-RYMgG/MTadOr5t8KdhejfvUU82MxsCu5MF6KuDUHl+NuwzUt+Sm6jJWxTJVrDR1j5M/gJVCPKQEpWXY+yIQ6lQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "chalk": "^4.0.0",
+ "ci-info": "^3.2.0",
+ "graceful-fs": "^4.2.9",
+ "picomatch": "^2.2.3"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-util/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-util/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-util/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-util/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-util/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-util/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-validate": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.5.0.tgz",
+ "integrity": "sha512-pC26etNIi+y3HV8A+tUGr/lph9B18GnzSRAkPaaZJIE1eFdiYm6/CewuiJQ8/RlfHd1u/8Ioi8/sJ+CmbA+zAQ==",
+ "dev": true,
+ "dependencies": {
+ "@jest/types": "^29.5.0",
+ "camelcase": "^6.2.0",
+ "chalk": "^4.0.0",
+ "jest-get-type": "^29.4.3",
+ "leven": "^3.1.0",
+ "pretty-format": "^29.5.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-validate/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-validate/node_modules/camelcase": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
+ "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/jest-validate/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-validate/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-validate/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-validate/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-validate/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-watcher": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.5.0.tgz",
+ "integrity": "sha512-KmTojKcapuqYrKDpRwfqcQ3zjMlwu27SYext9pt4GlF5FUgB+7XE1mcCnSm6a4uUpFyQIkb6ZhzZvHl+jiBCiA==",
+ "dev": true,
+ "dependencies": {
+ "@jest/test-result": "^29.5.0",
+ "@jest/types": "^29.5.0",
+ "@types/node": "*",
+ "ansi-escapes": "^4.2.1",
+ "chalk": "^4.0.0",
+ "emittery": "^0.13.1",
+ "jest-util": "^29.5.0",
+ "string-length": "^4.0.1"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-watcher/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jest-watcher/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jest-watcher/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jest-watcher/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jest-watcher/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-watcher/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-worker": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.5.0.tgz",
+ "integrity": "sha512-NcrQnevGoSp4b5kg+akIpthoAFHxPBcb5P6mYPY0fUNT+sSvmtu6jlkEle3anczUKIKEbMxFimk9oTP/tpIPgA==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*",
+ "jest-util": "^29.5.0",
+ "merge-stream": "^2.0.0",
+ "supports-color": "^8.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/jest-worker/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-worker/node_modules/supports-color": {
+ "version": "8.1.1",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz",
+ "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/supports-color?sponsor=1"
+ }
+ },
+ "node_modules/js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
+ "dev": true
+ },
+ "node_modules/js-yaml": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
+ "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
+ "dev": true,
+ "dependencies": {
+ "argparse": "^2.0.1"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "dev": true,
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/json-parse-even-better-errors": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
+ "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
+ "dev": true
+ },
+ "node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "node_modules/json-stable-stringify-without-jsonify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
+ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
+ "dev": true
+ },
+ "node_modules/json5": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
+ "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
+ "dev": true,
+ "bin": {
+ "json5": "lib/cli.js"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/kleur": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz",
+ "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/leven": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz",
+ "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/levn": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
+ "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
+ "dev": true,
+ "dependencies": {
+ "prelude-ls": "^1.2.1",
+ "type-check": "~0.4.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/lines-and-columns": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
+ "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
+ "dev": true
+ },
+ "node_modules/locate-path": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
+ "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
+ "dev": true,
+ "dependencies": {
+ "p-locate": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/lodash.debounce": {
+ "version": "4.0.8",
+ "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz",
+ "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==",
+ "dev": true
+ },
+ "node_modules/lodash.merge": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
+ "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
+ "dev": true
+ },
+ "node_modules/lru-cache": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
+ "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^3.0.2"
+ }
+ },
+ "node_modules/make-dir": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz",
+ "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==",
+ "dev": true,
+ "dependencies": {
+ "pify": "^4.0.1",
+ "semver": "^5.6.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/make-dir/node_modules/semver": {
+ "version": "5.7.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
+ "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver"
+ }
+ },
+ "node_modules/makeerror": {
+ "version": "1.0.12",
+ "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz",
+ "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==",
+ "dev": true,
+ "dependencies": {
+ "tmpl": "1.0.5"
+ }
+ },
+ "node_modules/merge-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
+ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
+ "dev": true
+ },
+ "node_modules/micromatch": {
+ "version": "4.0.5",
+ "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
+ "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
+ "dev": true,
+ "dependencies": {
+ "braces": "^3.0.2",
+ "picomatch": "^2.3.1"
+ },
+ "engines": {
+ "node": ">=8.6"
+ }
+ },
+ "node_modules/mimic-fn": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
+ "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
+ "dev": true
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz",
+ "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "bin": {
+ "nanoid": "bin/nanoid.cjs"
+ },
+ "engines": {
+ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
+ }
+ },
+ "node_modules/natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
+ "dev": true
+ },
+ "node_modules/node-int64": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz",
+ "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==",
+ "dev": true
+ },
+ "node_modules/node-releases": {
+ "version": "2.0.12",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.12.tgz",
+ "integrity": "sha512-QzsYKWhXTWx8h1kIvqfnC++o0pEmpRQA/aenALsL2F4pqNVr7YzcdMlDij5WBnwftRbJCNJL/O7zdKaxKPHqgQ==",
+ "dev": true
+ },
+ "node_modules/normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/npm-run-path": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz",
+ "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==",
+ "dev": true,
+ "dependencies": {
+ "path-key": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
+ "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
+ "dev": true,
+ "dependencies": {
+ "wrappy": "1"
+ }
+ },
+ "node_modules/onetime": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz",
+ "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==",
+ "dev": true,
+ "dependencies": {
+ "mimic-fn": "^2.1.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/optionator": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz",
+ "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==",
+ "dev": true,
+ "dependencies": {
+ "deep-is": "^0.1.3",
+ "fast-levenshtein": "^2.0.6",
+ "levn": "^0.4.1",
+ "prelude-ls": "^1.2.1",
+ "type-check": "^0.4.0",
+ "word-wrap": "^1.2.3"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/p-limit": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
+ "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
+ "dev": true,
+ "dependencies": {
+ "yocto-queue": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-locate": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
+ "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
+ "dev": true,
+ "dependencies": {
+ "p-limit": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-try": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
+ "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "dependencies": {
+ "callsites": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/parse-json": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
+ "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.0.0",
+ "error-ex": "^1.3.1",
+ "json-parse-even-better-errors": "^2.3.0",
+ "lines-and-columns": "^1.1.6"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-parse": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
+ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==",
+ "dev": true
+ },
+ "node_modules/picocolors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
+ "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
+ "dev": true
+ },
+ "node_modules/picomatch": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
+ "dev": true,
+ "engines": {
+ "node": ">=8.6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/jonschlinkert"
+ }
+ },
+ "node_modules/pify": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz",
+ "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/pirates": {
+ "version": "4.0.6",
+ "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz",
+ "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/pkg-dir": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz",
+ "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==",
+ "dev": true,
+ "dependencies": {
+ "find-up": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/pkg-dir/node_modules/find-up": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
+ "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
+ "dev": true,
+ "dependencies": {
+ "locate-path": "^5.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/pkg-dir/node_modules/locate-path": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
+ "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
+ "dev": true,
+ "dependencies": {
+ "p-locate": "^4.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/pkg-dir/node_modules/p-limit": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
+ "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
+ "dev": true,
+ "dependencies": {
+ "p-try": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/pkg-dir/node_modules/p-locate": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
+ "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
+ "dev": true,
+ "dependencies": {
+ "p-limit": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/postcss": {
+ "version": "8.4.24",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.24.tgz",
+ "integrity": "sha512-M0RzbcI0sO/XJNucsGjvWU9ERWxb/ytp1w6dKtxTKgixdtQDq4rmx/g8W1hnaheq9jgwL/oyEdH5Bc4WwJKMqg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/postcss"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "dependencies": {
+ "nanoid": "^3.3.6",
+ "picocolors": "^1.0.0",
+ "source-map-js": "^1.0.2"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ }
+ },
+ "node_modules/prelude-ls": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
+ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/prettier": {
+ "version": "2.8.8",
+ "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz",
+ "integrity": "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q==",
+ "dev": true,
+ "bin": {
+ "prettier": "bin-prettier.js"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ },
+ "funding": {
+ "url": "https://github.com/prettier/prettier?sponsor=1"
+ }
+ },
+ "node_modules/pretty-format": {
+ "version": "29.5.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.5.0.tgz",
+ "integrity": "sha512-V2mGkI31qdttvTFX7Mt4efOqHXqJWMu4/r66Xh3Z3BwZaPfPJgp6/gbwoujRpPUtfEF6AUUWx3Jim3GCw5g/Qw==",
+ "dev": true,
+ "dependencies": {
+ "@jest/schemas": "^29.4.3",
+ "ansi-styles": "^5.0.0",
+ "react-is": "^18.0.0"
+ },
+ "engines": {
+ "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
+ }
+ },
+ "node_modules/pretty-format/node_modules/ansi-styles": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz",
+ "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/prompts": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz",
+ "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==",
+ "dev": true,
+ "dependencies": {
+ "kleur": "^3.0.3",
+ "sisteransi": "^1.0.5"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/punycode": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz",
+ "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/pure-rand": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.2.tgz",
+ "integrity": "sha512-6Yg0ekpKICSjPswYOuC5sku/TSWaRYlA0qsXqJgM/d/4pLPHPuTxK7Nbf7jFKzAeedUhR8C7K9Uv63FBsSo8xQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://github.com/sponsors/dubzzz"
+ },
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/fast-check"
+ }
+ ]
+ },
+ "node_modules/queue-microtask": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
+ "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/react-is": {
+ "version": "18.2.0",
+ "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz",
+ "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==",
+ "dev": true
+ },
+ "node_modules/readdirp": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "picomatch": "^2.2.1"
+ },
+ "engines": {
+ "node": ">=8.10.0"
+ }
+ },
+ "node_modules/regenerate": {
+ "version": "1.4.2",
+ "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz",
+ "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==",
+ "dev": true
+ },
+ "node_modules/regenerate-unicode-properties": {
+ "version": "10.1.0",
+ "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz",
+ "integrity": "sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==",
+ "dev": true,
+ "dependencies": {
+ "regenerate": "^1.4.2"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/regenerator-runtime": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz",
+ "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==",
+ "dev": true
+ },
+ "node_modules/regenerator-transform": {
+ "version": "0.15.1",
+ "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.1.tgz",
+ "integrity": "sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/runtime": "^7.8.4"
+ }
+ },
+ "node_modules/regexpu-core": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.3.2.tgz",
+ "integrity": "sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/regjsgen": "^0.8.0",
+ "regenerate": "^1.4.2",
+ "regenerate-unicode-properties": "^10.1.0",
+ "regjsparser": "^0.9.1",
+ "unicode-match-property-ecmascript": "^2.0.0",
+ "unicode-match-property-value-ecmascript": "^2.1.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/regjsparser": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz",
+ "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==",
+ "dev": true,
+ "dependencies": {
+ "jsesc": "~0.5.0"
+ },
+ "bin": {
+ "regjsparser": "bin/parser"
+ }
+ },
+ "node_modules/regjsparser/node_modules/jsesc": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz",
+ "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==",
+ "dev": true,
+ "bin": {
+ "jsesc": "bin/jsesc"
+ }
+ },
+ "node_modules/require-directory": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
+ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/resolve": {
+ "version": "1.22.2",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz",
+ "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==",
+ "dev": true,
+ "dependencies": {
+ "is-core-module": "^2.11.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ },
+ "bin": {
+ "resolve": "bin/resolve"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/resolve-cwd": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz",
+ "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==",
+ "dev": true,
+ "dependencies": {
+ "resolve-from": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/resolve-cwd/node_modules/resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/resolve.exports": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz",
+ "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/reusify": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz",
+ "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
+ "dev": true,
+ "engines": {
+ "iojs": ">=1.0.0",
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "dependencies": {
+ "glob": "^7.1.3"
+ },
+ "bin": {
+ "rimraf": "bin.js"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/rollup": {
+ "version": "3.25.3",
+ "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.25.3.tgz",
+ "integrity": "sha512-ZT279hx8gszBj9uy5FfhoG4bZx8c+0A1sbqtr7Q3KNWIizpTdDEPZbV2xcbvHsnFp4MavCQYZyzApJ+virB8Yw==",
+ "dev": true,
+ "bin": {
+ "rollup": "dist/bin/rollup"
+ },
+ "engines": {
+ "node": ">=14.18.0",
+ "npm": ">=8.0.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/run-parallel": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
+ "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "dependencies": {
+ "queue-microtask": "^1.2.2"
+ }
+ },
+ "node_modules/semver": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
+ "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "dependencies": {
+ "shebang-regex": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/signal-exit": {
+ "version": "3.0.7",
+ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz",
+ "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==",
+ "dev": true
+ },
+ "node_modules/sisteransi": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz",
+ "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==",
+ "dev": true
+ },
+ "node_modules/slash": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz",
+ "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
+ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-support": {
+ "version": "0.5.13",
+ "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz",
+ "integrity": "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==",
+ "dev": true,
+ "dependencies": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ }
+ },
+ "node_modules/sprintf-js": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
+ "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==",
+ "dev": true
+ },
+ "node_modules/stack-utils": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz",
+ "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==",
+ "dev": true,
+ "dependencies": {
+ "escape-string-regexp": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/stack-utils/node_modules/escape-string-regexp": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz",
+ "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/string-length": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz",
+ "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==",
+ "dev": true,
+ "dependencies": {
+ "char-regex": "^1.0.2",
+ "strip-ansi": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/string-width": {
+ "version": "4.2.3",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
+ "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
+ "dev": true,
+ "dependencies": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-ansi": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "dependencies": {
+ "ansi-regex": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-bom": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz",
+ "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-final-newline": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz",
+ "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/strip-json-comments": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
+ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/supports-preserve-symlinks-flag": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
+ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/test-exclude": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz",
+ "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==",
+ "dev": true,
+ "dependencies": {
+ "@istanbuljs/schema": "^0.1.2",
+ "glob": "^7.1.4",
+ "minimatch": "^3.0.4"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/text-table": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
+ "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
+ "dev": true
+ },
+ "node_modules/tmpl": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz",
+ "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==",
+ "dev": true
+ },
+ "node_modules/to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "dev": true,
+ "dependencies": {
+ "is-number": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=8.0"
+ }
+ },
+ "node_modules/type-check": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
+ "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
+ "dev": true,
+ "dependencies": {
+ "prelude-ls": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/type-detect": {
+ "version": "4.0.8",
+ "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz",
+ "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/type-fest": {
+ "version": "0.20.2",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
+ "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/unicode-canonical-property-names-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-match-property-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==",
+ "dev": true,
+ "dependencies": {
+ "unicode-canonical-property-names-ecmascript": "^2.0.0",
+ "unicode-property-aliases-ecmascript": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-match-property-value-ecmascript": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz",
+ "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-property-aliases-ecmascript": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz",
+ "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/update-browserslist-db": {
+ "version": "1.0.11",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz",
+ "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "dependencies": {
+ "escalade": "^3.1.1",
+ "picocolors": "^1.0.0"
+ },
+ "bin": {
+ "update-browserslist-db": "cli.js"
+ },
+ "peerDependencies": {
+ "browserslist": ">= 4.21.0"
+ }
+ },
+ "node_modules/uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "dependencies": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "node_modules/v8-to-istanbul": {
+ "version": "9.1.0",
+ "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz",
+ "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/trace-mapping": "^0.3.12",
+ "@types/istanbul-lib-coverage": "^2.0.1",
+ "convert-source-map": "^1.6.0"
+ },
+ "engines": {
+ "node": ">=10.12.0"
+ }
+ },
+ "node_modules/vite": {
+ "version": "4.3.9",
+ "resolved": "https://registry.npmjs.org/vite/-/vite-4.3.9.tgz",
+ "integrity": "sha512-qsTNZjO9NoJNW7KnOrgYwczm0WctJ8m/yqYAMAK9Lxt4SoySUfS5S8ia9K7JHpa3KEeMfyF8LoJ3c5NeBJy6pg==",
+ "dev": true,
+ "dependencies": {
+ "esbuild": "^0.17.5",
+ "postcss": "^8.4.23",
+ "rollup": "^3.21.0"
+ },
+ "bin": {
+ "vite": "bin/vite.js"
+ },
+ "engines": {
+ "node": "^14.18.0 || >=16.0.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ },
+ "peerDependencies": {
+ "@types/node": ">= 14",
+ "less": "*",
+ "sass": "*",
+ "stylus": "*",
+ "sugarss": "*",
+ "terser": "^5.4.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ },
+ "less": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "sugarss": {
+ "optional": true
+ },
+ "terser": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/walker": {
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz",
+ "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==",
+ "dev": true,
+ "dependencies": {
+ "makeerror": "1.0.12"
+ }
+ },
+ "node_modules/which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/node-which"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/word-wrap": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
+ "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/wrap-ansi": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+ "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
+ "dev": true
+ },
+ "node_modules/write-file-atomic": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz",
+ "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==",
+ "dev": true,
+ "dependencies": {
+ "imurmurhash": "^0.1.4",
+ "signal-exit": "^3.0.7"
+ },
+ "engines": {
+ "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
+ }
+ },
+ "node_modules/y18n": {
+ "version": "5.0.8",
+ "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
+ "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/yallist": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
+ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
+ "dev": true
+ },
+ "node_modules/yargs": {
+ "version": "17.7.2",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz",
+ "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==",
+ "dev": true,
+ "dependencies": {
+ "cliui": "^8.0.1",
+ "escalade": "^3.1.1",
+ "get-caller-file": "^2.0.5",
+ "require-directory": "^2.1.1",
+ "string-width": "^4.2.3",
+ "y18n": "^5.0.5",
+ "yargs-parser": "^21.1.1"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/yargs-parser": {
+ "version": "21.1.1",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz",
+ "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/yocto-queue": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
+ "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ }
+ }
+}
diff --git a/package.json b/package.json
new file mode 100644
index 00000000..df0197a8
--- /dev/null
+++ b/package.json
@@ -0,0 +1,20 @@
+{
+ "name": "fedc4-5_project_notion_vanillajs",
+ "version": "1.0.0",
+ "description": "- 프로젝트 기한\r - 프로젝트 수행 기간 : 2023년 6월 27일(화) ~ 2023년 7월 6일(목)\r - 멘티 코드 리뷰 기간 : 2023년 7월 7일(금) ~ 2023년 7월 10일(월)\r - 멘토 코드 리뷰 기간 : 2023년 7월 7일(금) ~ 2023년 7월 13일(목)\r - 코드 리뷰 반영 기간 : 2023년 7월 14일(금) ~ 2023년 7월 17일(월)\r - 내용\r - [[Day 19] 노션 클로닝 요구사항](https://school.programmers.co.kr/app/courses/17516/curriculum/lessons/196456#part-46365)을 확인해 주세요.",
+ "main": "index.js",
+ "scripts": {
+ "dev": "npx vite",
+ "prod": "npx vite build && npx vite preview",
+ "test": "npx jest"
+ },
+ "devDependencies": {
+ "@babel/cli": "^7.22.5",
+ "@babel/core": "^7.22.5",
+ "@babel/preset-env": "^7.22.5",
+ "eslint": "^8.43.0",
+ "jest": "^29.5.0",
+ "prettier": "^2.8.8",
+ "vite": "^4.3.9"
+ }
+}
diff --git a/src/index.js b/src/index.js
new file mode 100644
index 00000000..e69de29b
From daba2d4b178ed53593a7c61c488da4f08b0f4f82 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 27 Jun 2023 18:30:53 +0900
Subject: [PATCH 002/107] =?UTF-8?q?Feat:=20api.js=20=ED=8C=8C=EC=9D=BC=20?=
=?UTF-8?q?=EC=83=9D=EC=84=B1=20=EB=B0=8F=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/api.js | 69 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 69 insertions(+)
create mode 100644 src/api/api.js
diff --git a/src/api/api.js b/src/api/api.js
new file mode 100644
index 00000000..be049f4c
--- /dev/null
+++ b/src/api/api.js
@@ -0,0 +1,69 @@
+const API_END_POINT = "https://kdt-frontend.programmers.co.kr/documents"
+
+const request = async (url = "", options = {}) => {
+ try {
+ const res = await fetch(`${API_END_POINT}${url}`, {
+ ...options
+ })
+
+ if (res.ok) {
+ return await res.json()
+ }
+
+ throw new Error("API 처리 중 에러가 발생했습니다.")
+ } catch (e) {
+ alert(e.message)
+ }
+}
+
+const fetchData = async (url, method = "GET", data = null) => {
+ const options = {
+ method,
+ headers: {
+ "Content-Type": "application/json",
+ "x-username": "hyoribogo"
+ },
+ body: data ? JSON.stringify(data) : null
+ }
+
+ const res = await request(url, options)
+ return res
+}
+
+// 전체 Document 목록 불러오기 GET
+const getRootDocument = async () => {
+ const res = await fetchData("")
+ return res
+}
+
+// 특정 Document 불러오기 GET
+const getSpecificDocument = async (url) => {
+ const res = await fetchData(url)
+ return res
+}
+
+// Document 생성하기 POST
+const createDocument = async (url, data) => {
+ const res = await fetchData(url, "POST", data)
+ return res
+}
+
+// 특정 Document 수정하기 PUT
+const editSpecificDocument = async (url, data) => {
+ const res = await fetchData(url, "PUT", data)
+ return res
+}
+
+// 특정 Document 삭제하기 DELETE
+const deleteSpecificDocument = async (url) => {
+ const res = await fetchData(url, "DELETE")
+ return res
+}
+
+export {
+ getRootDocument,
+ getSpecificDocument,
+ createDocument,
+ editSpecificDocument,
+ deleteSpecificDocument
+}
\ No newline at end of file
From fbbdb16191765d80b7c98f68d8dbc052ded68f29 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 27 Jun 2023 18:31:40 +0900
Subject: [PATCH 003/107] =?UTF-8?q?Docs:=20git=20=EB=A9=94=EC=8B=9C?=
=?UTF-8?q?=EC=A7=80=20=EC=BB=A8=EB=B2=A4=EC=85=98=20=ED=8C=8C=EC=9D=BC=20?=
=?UTF-8?q?=EC=B6=94=EA=B0=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.gitmessage.txt | 31 +++++++++++++++++++++++++++++++
1 file changed, 31 insertions(+)
create mode 100644 .gitmessage.txt
diff --git a/.gitmessage.txt b/.gitmessage.txt
new file mode 100644
index 00000000..f48adeef
--- /dev/null
+++ b/.gitmessage.txt
@@ -0,0 +1,31 @@
+#####################
+# hyoribogo's Commit Message Template
+#####################
+# type와 subject은 대문자로 시작합니다.
+# body과 footer는 선택 사항입니다.
+#####################
+# Feat: 새로운 기능 추가
+# Fix: 버그 수정
+# Docs: 문서 수정
+# Design: 사용자 UI 디자인 변경 (CSS 등)
+# Style: 코드 형식 수정 (세미콜론 누락 등, 코드 자체 변경 제외)
+# Refactor: 코드 리팩토링 (코드 구조 재조정)
+# Comment: 주석 추가 및 변경
+# Rename: 파일, 폴더 이름 변경
+# Remove: 파일, 폴더 삭제
+# Test: 테스트 코드, 리펙토링 테스트 코드 추가
+# Chore: 빌드 업무 수정, 패키지 매니저 수정
+#####################
+# type : subject
+
+#####################
+
+#####################
+# body
+
+#####################
+
+#####################
+# footer
+
+#####################
\ No newline at end of file
From 68b869a4b49e2478d1f5194965c6cddfdb1ce3b8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 27 Jun 2023 18:41:02 +0900
Subject: [PATCH 004/107] =?UTF-8?q?Feat:=20=EB=A1=9C=EC=BB=AC=20=EC=8A=A4?=
=?UTF-8?q?=ED=86=A0=EB=A6=AC=EC=A7=80=20=ED=8C=8C=EC=9D=BC=20=EA=B5=AC?=
=?UTF-8?q?=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/utils/storage.js | 16 ++++++++++++++++
1 file changed, 16 insertions(+)
create mode 100644 src/utils/storage.js
diff --git a/src/utils/storage.js b/src/utils/storage.js
new file mode 100644
index 00000000..af6bd933
--- /dev/null
+++ b/src/utils/storage.js
@@ -0,0 +1,16 @@
+const storage = window.localStorage
+
+const getItem = (key, defaultValue) => {
+ try {
+ const storedValue = storage.getItem(key)
+ return storedValue ? JSON.parse(storedValue) : defaultValue
+ } catch(e) {
+ return defaultValue
+ }
+}
+
+const setItem = (key, value) => {
+ storage.setItem(key, JSON.stringify(value))
+}
+
+export { getItem, setItem }
\ No newline at end of file
From f46aadf4bdec1eebfdc832c8a0bfc621a7aabffd Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 27 Jun 2023 18:41:44 +0900
Subject: [PATCH 005/107] =?UTF-8?q?Feat:=20=EB=B8=8C=EB=9D=BC=EC=9A=B0?=
=?UTF-8?q?=EC=A0=80=20=ED=83=80=EC=9D=B4=ED=8B=80=20=ED=95=9C=EA=B8=80=20?=
=?UTF-8?q?=EC=A0=81=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
index.html | 1 +
1 file changed, 1 insertion(+)
diff --git a/index.html b/index.html
index eba584e4..4a299996 100644
--- a/index.html
+++ b/index.html
@@ -1,5 +1,6 @@
+
효리의 노션 클로닝 사이트
From 5a1c8d3405b97843a80aa327d3b7d6e0c4315daa Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 01:23:29 +0900
Subject: [PATCH 006/107] =?UTF-8?q?Refactor:=20api=20=ED=95=A8=EC=88=98=20?=
=?UTF-8?q?=EB=A7=A4=EA=B0=9C=EB=B3=80=EC=88=98=20=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/api.js | 18 ++++++++++--------
1 file changed, 10 insertions(+), 8 deletions(-)
diff --git a/src/api/api.js b/src/api/api.js
index be049f4c..c61eef4a 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -17,6 +17,8 @@ const request = async (url = "", options = {}) => {
}
const fetchData = async (url, method = "GET", data = null) => {
+ if (typeof url !== 'string') url = url.toString()
+
const options = {
method,
headers: {
@@ -37,26 +39,26 @@ const getRootDocument = async () => {
}
// 특정 Document 불러오기 GET
-const getSpecificDocument = async (url) => {
- const res = await fetchData(url)
+const getSpecificDocument = async (id) => {
+ const res = await fetchData(id)
return res
}
// Document 생성하기 POST
-const createDocument = async (url, data) => {
- const res = await fetchData(url, "POST", data)
+const createDocument = async (data) => {
+ const res = await fetchData("", "POST", data)
return res
}
// 특정 Document 수정하기 PUT
-const editSpecificDocument = async (url, data) => {
- const res = await fetchData(url, "PUT", data)
+const editSpecificDocument = async (id, data) => {
+ const res = await fetchData(id, "PUT", data)
return res
}
// 특정 Document 삭제하기 DELETE
-const deleteSpecificDocument = async (url) => {
- const res = await fetchData(url, "DELETE")
+const deleteSpecificDocument = async (id) => {
+ const res = await fetchData(id, "DELETE")
return res
}
From 14d80632db59212f1a6e738dee4eefd7a3d81a08 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 01:24:22 +0900
Subject: [PATCH 007/107] =?UTF-8?q?Feat:=20=EC=A0=84=EC=B2=B4=20documents?=
=?UTF-8?q?=20=EC=B6=9C=EB=A0=A5=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/conponents/DocumentsList.js | 35 +++++++++++++++++++++++++++++
src/index.js | 11 +++++++++
src/pages/NotionPage.js | 40 +++++++++++++++++++++++++++++++++
3 files changed, 86 insertions(+)
create mode 100644 src/conponents/DocumentsList.js
create mode 100644 src/pages/NotionPage.js
diff --git a/src/conponents/DocumentsList.js b/src/conponents/DocumentsList.js
new file mode 100644
index 00000000..04b1e240
--- /dev/null
+++ b/src/conponents/DocumentsList.js
@@ -0,0 +1,35 @@
+export default function DocumentsList({ $target, initialState, onAdd }) {
+ const $documents = document.createElement('div')
+ $target.appendChild($documents)
+
+ this.state = initialState
+
+ this.setState = (nextState) => {
+ this.state = nextState
+ this.render()
+ }
+
+ const renderDocument = ({ documents, title, id }) => {
+ // 일단 id도 뜨게 구현
+ let html = `[${id}] ${title}`
+
+ if (documents.length) {
+ html += ""
+ documents.forEach((subdocument) => {
+ html += `${renderDocument(subdocument)}`
+ })
+ html += "
"
+ }
+
+ return html
+ }
+
+ this.render = () => {
+ this.state.forEach((document) => {
+ const documentHtml = renderDocument(document)
+ $documents.innerHTML += ``
+ })
+ }
+
+ this.render()
+}
\ No newline at end of file
diff --git a/src/index.js b/src/index.js
index e69de29b..cc030ec6 100644
--- a/src/index.js
+++ b/src/index.js
@@ -0,0 +1,11 @@
+import NotionPage from './pages/NotionPage'
+
+const $target = document.querySelector('#app')
+
+new NotionPage({
+ $target,
+ initialState: {
+ documents: [],
+ editorContent: null
+ }
+})
\ No newline at end of file
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
new file mode 100644
index 00000000..4e7c7aa8
--- /dev/null
+++ b/src/pages/NotionPage.js
@@ -0,0 +1,40 @@
+import { getRootDocument } from '../api/api'
+import DocumentsList from '../conponents/DocumentsList'
+
+export default function NotionPage({ $target, initialState }) {
+ const $notionPage = document.createElement('div')
+ $target.appendChild($notionPage)
+
+ // documents 리스트 state
+ this.documents = initialState.documents
+
+ this.setDocuments = (nextDocuments) => {
+ this.documents = nextDocuments
+ documentList.setState(nextDocuments)
+ }
+
+ // 편집기 state
+ this.editorContent = initialState.editorContent
+
+ this.setEditorContent = (nextContent) => {
+ this.editorContent = nextContent
+ }
+
+ const documentList = new DocumentsList({
+ $target: $notionPage,
+ initialState: this.documents,
+ onAdd: () => {
+ alert("추가 버튼 누름")
+ }
+ })
+
+ // 함수 파일 작성하기
+ const fetchDocumentsData = () => {
+ return getRootDocument()
+ .then((documents) => {
+ this.setDocuments(documents)
+ })
+ }
+
+ fetchDocumentsData()
+}
\ No newline at end of file
From 64b350df758c0f2a956a849513055c22f8b50c54 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 16:58:52 +0900
Subject: [PATCH 008/107] =?UTF-8?q?Feat:=20=ED=8A=B9=EC=A0=95=20Document?=
=?UTF-8?q?=EC=9D=98=20content=20=EC=A1=B0=ED=9A=8C=20=EA=B8=B0=EB=8A=A5?=
=?UTF-8?q?=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/api.js | 6 +++---
src/conponents/Content.js | 20 ++++++++++++++++++++
src/conponents/DocumentsList.js | 21 ++++++++++++++++-----
src/pages/NotionPage.js | 25 +++++++++++++++++++++----
4 files changed, 60 insertions(+), 12 deletions(-)
create mode 100644 src/conponents/Content.js
diff --git a/src/api/api.js b/src/api/api.js
index c61eef4a..72b3df66 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -17,7 +17,7 @@ const request = async (url = "", options = {}) => {
}
const fetchData = async (url, method = "GET", data = null) => {
- if (typeof url !== 'string') url = url.toString()
+ if (url.length && url !== null) url = `/${url}`
const options = {
method,
@@ -45,8 +45,8 @@ const getSpecificDocument = async (id) => {
}
// Document 생성하기 POST
-const createDocument = async (data) => {
- const res = await fetchData("", "POST", data)
+const createDocument = async (id) => {
+ const res = await fetchData(id, "POST")
return res
}
diff --git a/src/conponents/Content.js b/src/conponents/Content.js
new file mode 100644
index 00000000..01bb0ea9
--- /dev/null
+++ b/src/conponents/Content.js
@@ -0,0 +1,20 @@
+export default function Content({ $target, initialState }) {
+ const $content = document.createElement('div')
+ $target.appendChild($content)
+
+ this.state = initialState
+
+ this.setState = (nextState) => {
+ this.state = nextState
+ this.render()
+ }
+
+ this.render = () => {
+ const { title, content } = this.state
+
+ $content.innerHTML = `
+ ${title}
+
+ `
+ }
+}
\ No newline at end of file
diff --git a/src/conponents/DocumentsList.js b/src/conponents/DocumentsList.js
index 04b1e240..9f1e49f2 100644
--- a/src/conponents/DocumentsList.js
+++ b/src/conponents/DocumentsList.js
@@ -1,4 +1,4 @@
-export default function DocumentsList({ $target, initialState, onAdd }) {
+export default function DocumentsList({ $target, initialState, onAdd, onClick }) {
const $documents = document.createElement('div')
$target.appendChild($documents)
@@ -9,14 +9,14 @@ export default function DocumentsList({ $target, initialState, onAdd }) {
this.render()
}
- const renderDocument = ({ documents, title, id }) => {
+ const renderDocumentsTree = ({ documents, title, id }) => {
// 일단 id도 뜨게 구현
- let html = `[${id}] ${title}`
+ let html = `[${id}] ${title}`
if (documents.length) {
html += ""
documents.forEach((subdocument) => {
- html += `${renderDocument(subdocument)}`
+ html += `${renderDocumentsTree(subdocument)}`
})
html += "
"
}
@@ -26,9 +26,20 @@ export default function DocumentsList({ $target, initialState, onAdd }) {
this.render = () => {
this.state.forEach((document) => {
- const documentHtml = renderDocument(document)
+ const documentHtml = renderDocumentsTree(document)
$documents.innerHTML += ``
})
+
+ const $documentsList = $documents.querySelectorAll('li')
+
+ $documentsList.forEach(($document) => {
+ $document.addEventListener('click', ({ target }) => {
+ if (target.closest('li')) {
+ const { id } = target.dataset
+ onClick(id)
+ }
+ })
+ })
}
this.render()
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
index 4e7c7aa8..a9c2be47 100644
--- a/src/pages/NotionPage.js
+++ b/src/pages/NotionPage.js
@@ -1,4 +1,5 @@
-import { getRootDocument } from '../api/api'
+import { getRootDocument, getSpecificDocument } from '../api/api'
+import Content from '../conponents/Content'
import DocumentsList from '../conponents/DocumentsList'
export default function NotionPage({ $target, initialState }) {
@@ -10,7 +11,7 @@ export default function NotionPage({ $target, initialState }) {
this.setDocuments = (nextDocuments) => {
this.documents = nextDocuments
- documentList.setState(nextDocuments)
+ documentsList.setState(nextDocuments)
}
// 편집기 state
@@ -18,16 +19,25 @@ export default function NotionPage({ $target, initialState }) {
this.setEditorContent = (nextContent) => {
this.editorContent = nextContent
+ content.setState(nextContent)
}
- const documentList = new DocumentsList({
+ const documentsList = new DocumentsList({
$target: $notionPage,
initialState: this.documents,
- onAdd: () => {
+ onAdd: (id) => {
alert("추가 버튼 누름")
+ },
+ onClick: (id) => {
+ fetchContentData(id)
}
})
+ const content = new Content({
+ $target: $notionPage,
+ initialState: this.editorContent,
+ })
+
// 함수 파일 작성하기
const fetchDocumentsData = () => {
return getRootDocument()
@@ -36,5 +46,12 @@ export default function NotionPage({ $target, initialState }) {
})
}
+ const fetchContentData = (id) => {
+ return getSpecificDocument(id)
+ .then((content) => {
+ this.setEditorContent(content)
+ })
+ }
+
fetchDocumentsData()
}
\ No newline at end of file
From c36e1ad380f548b9ffb6fbfbd1d9a22496af5834 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 17:09:17 +0900
Subject: [PATCH 009/107] =?UTF-8?q?Feat:=20Documents=20=EB=A6=AC=EC=8A=A4?=
=?UTF-8?q?=ED=8A=B8=20=EC=9D=B4=EB=B2=A4=ED=8A=B8=20=EB=8F=99=EC=9E=91=20?=
=?UTF-8?q?=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/conponents/DocumentsList.js | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/src/conponents/DocumentsList.js b/src/conponents/DocumentsList.js
index 9f1e49f2..d648d8a3 100644
--- a/src/conponents/DocumentsList.js
+++ b/src/conponents/DocumentsList.js
@@ -11,7 +11,7 @@ export default function DocumentsList({ $target, initialState, onAdd, onClick })
const renderDocumentsTree = ({ documents, title, id }) => {
// 일단 id도 뜨게 구현
- let html = `[${id}] ${title}`
+ let html = `[${id}] ${title}`
if (documents.length) {
html += ""
@@ -34,8 +34,8 @@ export default function DocumentsList({ $target, initialState, onAdd, onClick })
$documentsList.forEach(($document) => {
$document.addEventListener('click', ({ target }) => {
- if (target.closest('li')) {
- const { id } = target.dataset
+ if (target.closest('span')) {
+ const { id } = $document.dataset
onClick(id)
}
})
From be8654325825a59547ea453ffd1efe4d7726714c Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 17:54:22 +0900
Subject: [PATCH 010/107] =?UTF-8?q?Feat:=20Document=20=EC=83=9D=EC=84=B1?=
=?UTF-8?q?=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/api.js | 6 +++---
src/conponents/DocumentsList.js | 30 ++++++++++++++++++++-------
src/pages/NotionPage.js | 36 +++++++++++++++++++--------------
3 files changed, 47 insertions(+), 25 deletions(-)
diff --git a/src/api/api.js b/src/api/api.js
index 72b3df66..e901a000 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -17,7 +17,7 @@ const request = async (url = "", options = {}) => {
}
const fetchData = async (url, method = "GET", data = null) => {
- if (url.length && url !== null) url = `/${url}`
+ if (url) url = `/${url}`
const options = {
method,
@@ -45,8 +45,8 @@ const getSpecificDocument = async (id) => {
}
// Document 생성하기 POST
-const createDocument = async (id) => {
- const res = await fetchData(id, "POST")
+const createDocument = async (data) => {
+ const res = await fetchData("", "POST", data)
return res
}
diff --git a/src/conponents/DocumentsList.js b/src/conponents/DocumentsList.js
index d648d8a3..9946d5a8 100644
--- a/src/conponents/DocumentsList.js
+++ b/src/conponents/DocumentsList.js
@@ -1,4 +1,9 @@
-export default function DocumentsList({ $target, initialState, onAdd, onClick }) {
+export default function DocumentsList({
+ $target,
+ initialState,
+ onClick,
+ onAdd,
+}) {
const $documents = document.createElement('div')
$target.appendChild($documents)
@@ -11,7 +16,10 @@ export default function DocumentsList({ $target, initialState, onAdd, onClick })
const renderDocumentsTree = ({ documents, title, id }) => {
// 일단 id도 뜨게 구현
- let html = `- [${id}] ${title}
`
+ let html = `-
+ [${id}] ${title}
+
+
`
if (documents.length) {
html += ""
@@ -25,19 +33,27 @@ export default function DocumentsList({ $target, initialState, onAdd, onClick })
}
this.render = () => {
- this.state.forEach((document) => {
- const documentHtml = renderDocumentsTree(document)
- $documents.innerHTML += ``
- })
+ $documents.innerHTML = `
+
+ ${this.state.map((document) =>
+ `${renderDocumentsTree(document)}`).join('')}
+
+
+ `
const $documentsList = $documents.querySelectorAll('li')
$documentsList.forEach(($document) => {
$document.addEventListener('click', ({ target }) => {
+ const { id } = $document.dataset
+
if (target.closest('span')) {
- const { id } = $document.dataset
onClick(id)
}
+
+ if (target.closest('button')) {
+ onAdd(id ? id : null)
+ }
})
})
}
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
index a9c2be47..a8e38df6 100644
--- a/src/pages/NotionPage.js
+++ b/src/pages/NotionPage.js
@@ -1,4 +1,4 @@
-import { getRootDocument, getSpecificDocument } from '../api/api'
+import { createDocument, getRootDocument, getSpecificDocument } from '../api/api'
import Content from '../conponents/Content'
import DocumentsList from '../conponents/DocumentsList'
@@ -25,12 +25,20 @@ export default function NotionPage({ $target, initialState }) {
const documentsList = new DocumentsList({
$target: $notionPage,
initialState: this.documents,
- onAdd: (id) => {
- alert("추가 버튼 누름")
- },
onClick: (id) => {
fetchContentData(id)
- }
+ },
+ onAdd: async (id) => {
+ const data = {
+ title: "제목 없음",
+ parent: id ? id : null
+ }
+
+ const newDocument = await createDocument(data)
+
+ fetchDocumentsData()
+ fetchContentData(newDocument.id)
+ },
})
const content = new Content({
@@ -39,18 +47,16 @@ export default function NotionPage({ $target, initialState }) {
})
// 함수 파일 작성하기
- const fetchDocumentsData = () => {
- return getRootDocument()
- .then((documents) => {
- this.setDocuments(documents)
- })
+ // 전체 documentsList 불러오기
+ const fetchDocumentsData = async () => {
+ const documents = await getRootDocument()
+ this.setDocuments(documents)
}
- const fetchContentData = (id) => {
- return getSpecificDocument(id)
- .then((content) => {
- this.setEditorContent(content)
- })
+ // 특정 document의 content 불러오기
+ const fetchContentData = async (id) => {
+ const content = await getSpecificDocument(id)
+ this.setEditorContent(content)
}
fetchDocumentsData()
From 9f873766e4fa8c8eefcd07f835b3bba4ab1eaa7c Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 18:15:25 +0900
Subject: [PATCH 011/107] =?UTF-8?q?Feat:=20content=20=ED=95=98=EB=8B=A8?=
=?UTF-8?q?=EC=97=90=20=ED=95=98=EC=9C=84=20Document=20=EB=A6=AC=EC=8A=A4?=
=?UTF-8?q?=ED=8A=B8=20=EC=B6=94=EA=B0=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/conponents/Content.js | 11 ++++++++++-
1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/src/conponents/Content.js b/src/conponents/Content.js
index 01bb0ea9..5c6e190f 100644
--- a/src/conponents/Content.js
+++ b/src/conponents/Content.js
@@ -10,11 +10,20 @@ export default function Content({ $target, initialState }) {
}
this.render = () => {
- const { title, content } = this.state
+ const { title, content, documents } = this.state
$content.innerHTML = `
${title}
+
+ ${documents.length ? `
+
+ ${documents.map((subdocument) =>
+ `- ${subdocument.title}
`
+ ).join('')}
+
+ ` : ''
+ }
`
}
}
\ No newline at end of file
From 8feda70ff6080086b914d950cfd9248a29eefb62 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 18:51:47 +0900
Subject: [PATCH 012/107] =?UTF-8?q?Feat:=20Document=20=EC=82=AD=EC=A0=9C?=
=?UTF-8?q?=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/conponents/Content.js | 18 +++++++++++++++---
src/pages/NotionPage.js | 19 ++++++++++++++-----
2 files changed, 29 insertions(+), 8 deletions(-)
diff --git a/src/conponents/Content.js b/src/conponents/Content.js
index 5c6e190f..74934149 100644
--- a/src/conponents/Content.js
+++ b/src/conponents/Content.js
@@ -1,4 +1,4 @@
-export default function Content({ $target, initialState }) {
+export default function Content({ $target, initialState, onDelete }) {
const $content = document.createElement('div')
$target.appendChild($content)
@@ -10,11 +10,17 @@ export default function Content({ $target, initialState }) {
}
this.render = () => {
- const { title, content, documents } = this.state
+ if (!this.state) {
+ $content.innerHTML = ''
+ return
+ }
+
+ const { id, title, content, documents } = this.state
$content.innerHTML = `
${title}
-
+
+
${documents.length ? `
@@ -25,5 +31,11 @@ export default function Content({ $target, initialState }) {
` : ''
}
`
+
+ const $deleteButton = $content.querySelector('button')
+
+ $deleteButton.addEventListener('click', () => {
+ onDelete(id)
+ })
}
}
\ No newline at end of file
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
index a8e38df6..f1191176 100644
--- a/src/pages/NotionPage.js
+++ b/src/pages/NotionPage.js
@@ -1,4 +1,4 @@
-import { createDocument, getRootDocument, getSpecificDocument } from '../api/api'
+import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
import Content from '../conponents/Content'
import DocumentsList from '../conponents/DocumentsList'
@@ -37,13 +37,18 @@ export default function NotionPage({ $target, initialState }) {
const newDocument = await createDocument(data)
fetchDocumentsData()
- fetchContentData(newDocument.id)
+ fetchDocumentsData(newDocument.id)
},
})
const content = new Content({
$target: $notionPage,
initialState: this.editorContent,
+ onDelete: async (id) => {
+ await deleteSpecificDocument(id)
+ fetchDocumentsData()
+ fetchContentData()
+ }
})
// 함수 파일 작성하기
@@ -54,9 +59,13 @@ export default function NotionPage({ $target, initialState }) {
}
// 특정 document의 content 불러오기
- const fetchContentData = async (id) => {
- const content = await getSpecificDocument(id)
- this.setEditorContent(content)
+ const fetchContentData = async (id = null) => {
+ if (id) {
+ const content = await getSpecificDocument(id)
+ this.setEditorContent(content)
+ } else {
+ this.setEditorContent(null)
+ }
}
fetchDocumentsData()
From 7502e32bc9c45c2b4b8f683ed0679f01cf08ccc4 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Fri, 30 Jun 2023 19:08:32 +0900
Subject: [PATCH 013/107] =?UTF-8?q?Refactor:=20=EC=B6=94=EA=B0=80=20?=
=?UTF-8?q?=EC=8B=9C=20=ED=95=B4=EB=8B=B9=20document=EC=9D=98=20content=20?=
=?UTF-8?q?=EB=9C=A8=EB=8F=84=EB=A1=9D=20=EC=88=98=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/conponents/Content.js | 2 +-
src/pages/NotionPage.js | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/conponents/Content.js b/src/conponents/Content.js
index 74934149..e0a47f0b 100644
--- a/src/conponents/Content.js
+++ b/src/conponents/Content.js
@@ -18,7 +18,7 @@ export default function Content({ $target, initialState, onDelete }) {
const { id, title, content, documents } = this.state
$content.innerHTML = `
- ${title}
+ [${id}] ${title}
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
index f1191176..5ae25f11 100644
--- a/src/pages/NotionPage.js
+++ b/src/pages/NotionPage.js
@@ -37,7 +37,7 @@ export default function NotionPage({ $target, initialState }) {
const newDocument = await createDocument(data)
fetchDocumentsData()
- fetchDocumentsData(newDocument.id)
+ fetchContentData(newDocument.id)
},
})
From b45446066429f2aa8422eaa913ed8e0d775d302d Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Sun, 2 Jul 2023 21:14:55 +0900
Subject: [PATCH 014/107] =?UTF-8?q?Rename:=20components=20=ED=8F=B4?=
=?UTF-8?q?=EB=8D=94=20=EC=9D=B4=EB=A6=84=20=EC=98=A4=ED=83=80=20=EC=88=98?=
=?UTF-8?q?=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/{conponents => components}/Content.js | 0
src/{conponents => components}/DocumentsList.js | 0
src/pages/NotionPage.js | 4 ++--
3 files changed, 2 insertions(+), 2 deletions(-)
rename src/{conponents => components}/Content.js (100%)
rename src/{conponents => components}/DocumentsList.js (100%)
diff --git a/src/conponents/Content.js b/src/components/Content.js
similarity index 100%
rename from src/conponents/Content.js
rename to src/components/Content.js
diff --git a/src/conponents/DocumentsList.js b/src/components/DocumentsList.js
similarity index 100%
rename from src/conponents/DocumentsList.js
rename to src/components/DocumentsList.js
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
index 5ae25f11..a50030b9 100644
--- a/src/pages/NotionPage.js
+++ b/src/pages/NotionPage.js
@@ -1,6 +1,6 @@
import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
-import Content from '../conponents/Content'
-import DocumentsList from '../conponents/DocumentsList'
+import Content from '../components/Content'
+import DocumentsList from '../components/DocumentsList'
export default function NotionPage({ $target, initialState }) {
const $notionPage = document.createElement('div')
From f5556a67ab32faec2a7d2794c01d1030274aed56 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Mon, 3 Jul 2023 19:30:42 +0900
Subject: [PATCH 015/107] =?UTF-8?q?Feat:=20App.js=20=EC=83=9D=EC=84=B1=20?=
=?UTF-8?q?=EB=B0=8F=20NotionPage=20=EC=BD=94=EB=93=9C=20=EB=B6=84?=
=?UTF-8?q?=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 49 ++++++++++++++++++++++++++++++++++++
src/index.js | 4 +--
src/pages/NotionPage.js | 55 +++++++++--------------------------------
3 files changed, 63 insertions(+), 45 deletions(-)
create mode 100644 src/components/App.js
diff --git a/src/components/App.js b/src/components/App.js
new file mode 100644
index 00000000..bb0d22ed
--- /dev/null
+++ b/src/components/App.js
@@ -0,0 +1,49 @@
+import { getRootDocument, getSpecificDocument } from '../api/api'
+import NotionPage from '../pages/NotionPage'
+
+export default function App({ $target, initialState }) {
+ const $app = document.createElement('div')
+ $target.appendChild($app)
+
+ // documents state
+ this.documents = initialState.documents
+
+ this.setDocuments = (nextDocuments) => {
+ this.documents = nextDocuments
+ notionPage.documentsList.setState(nextDocuments)
+ }
+
+ // document editor state
+ this.editorContent = initialState.editorContent
+
+ this.setEditorContent = (nextContent) => {
+ this.editorContent = nextContent
+ notionPage.content.setState(nextContent)
+ }
+
+ // 함수 파일 작성하기
+ // 전체 documentsList 불러오기
+ const fetchDocumentsData = async () => {
+ const documents = await getRootDocument()
+ this.setDocuments(documents)
+ }
+
+ // 특정 document의 content 불러오기
+ const fetchContentData = async (id = null) => {
+ if (id) {
+ const content = await getSpecificDocument(id)
+ this.setEditorContent(content)
+ } else {
+ this.setEditorContent(null)
+ }
+ }
+
+ const notionPage = new NotionPage({
+ $target,
+ initialState,
+ fetchContentData,
+ fetchDocumentsData,
+ })
+
+ fetchDocumentsData()
+}
\ No newline at end of file
diff --git a/src/index.js b/src/index.js
index cc030ec6..674c7b25 100644
--- a/src/index.js
+++ b/src/index.js
@@ -1,8 +1,8 @@
-import NotionPage from './pages/NotionPage'
+import App from './components/App'
const $target = document.querySelector('#app')
-new NotionPage({
+new App({
$target,
initialState: {
documents: [],
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
index a50030b9..1b5e09bd 100644
--- a/src/pages/NotionPage.js
+++ b/src/pages/NotionPage.js
@@ -1,30 +1,19 @@
-import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
+import { createDocument, deleteSpecificDocument } from '../api/api'
import Content from '../components/Content'
import DocumentsList from '../components/DocumentsList'
-export default function NotionPage({ $target, initialState }) {
+export default function NotionPage({
+ $target,
+ initialState,
+ fetchContentData,
+ fetchDocumentsData,
+}) {
const $notionPage = document.createElement('div')
$target.appendChild($notionPage)
- // documents 리스트 state
- this.documents = initialState.documents
-
- this.setDocuments = (nextDocuments) => {
- this.documents = nextDocuments
- documentsList.setState(nextDocuments)
- }
-
- // 편집기 state
- this.editorContent = initialState.editorContent
-
- this.setEditorContent = (nextContent) => {
- this.editorContent = nextContent
- content.setState(nextContent)
- }
-
- const documentsList = new DocumentsList({
+ this.documentsList = new DocumentsList({
$target: $notionPage,
- initialState: this.documents,
+ initialState: initialState.documents,
onClick: (id) => {
fetchContentData(id)
},
@@ -33,7 +22,6 @@ export default function NotionPage({ $target, initialState }) {
title: "제목 없음",
parent: id ? id : null
}
-
const newDocument = await createDocument(data)
fetchDocumentsData()
@@ -41,32 +29,13 @@ export default function NotionPage({ $target, initialState }) {
},
})
- const content = new Content({
+ this.content = new Content({
$target: $notionPage,
- initialState: this.editorContent,
+ initialState: initialState.editorContent,
onDelete: async (id) => {
await deleteSpecificDocument(id)
fetchDocumentsData()
fetchContentData()
- }
+ },
})
-
- // 함수 파일 작성하기
- // 전체 documentsList 불러오기
- const fetchDocumentsData = async () => {
- const documents = await getRootDocument()
- this.setDocuments(documents)
- }
-
- // 특정 document의 content 불러오기
- const fetchContentData = async (id = null) => {
- if (id) {
- const content = await getSpecificDocument(id)
- this.setEditorContent(content)
- } else {
- this.setEditorContent(null)
- }
- }
-
- fetchDocumentsData()
}
\ No newline at end of file
From 8dc28468602610aaba6ce8e355eb755ae91c03ce Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Mon, 3 Jul 2023 19:31:44 +0900
Subject: [PATCH 016/107] =?UTF-8?q?Rename:=20=ED=95=98=EC=9C=84=20?=
=?UTF-8?q?=EB=AC=B8=EC=84=9C=20=EC=B9=B4=EB=A9=9C=20=EC=BC=80=EC=9D=B4?=
=?UTF-8?q?=EC=8A=A4=EB=A1=9C=20=EC=9D=B4=EB=A6=84=20=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/Content.js | 4 ++--
src/components/DocumentsList.js | 14 ++++++++------
2 files changed, 10 insertions(+), 8 deletions(-)
diff --git a/src/components/Content.js b/src/components/Content.js
index e0a47f0b..61b583f2 100644
--- a/src/components/Content.js
+++ b/src/components/Content.js
@@ -24,8 +24,8 @@ export default function Content({ $target, initialState, onDelete }) {
${documents.length ? `
- ${documents.map((subdocument) =>
- `- ${subdocument.title}
`
+ ${documents.map((subDocument) =>
+ `- ${subDocument.title}
`
).join('')}
` : ''
diff --git a/src/components/DocumentsList.js b/src/components/DocumentsList.js
index 9946d5a8..cd6e1edd 100644
--- a/src/components/DocumentsList.js
+++ b/src/components/DocumentsList.js
@@ -16,15 +16,17 @@ export default function DocumentsList({
const renderDocumentsTree = ({ documents, title, id }) => {
// 일단 id도 뜨게 구현
- let html = `-
- [${id}] ${title}
-
-
`
+ let html = `
+ -
+ [${id}] ${title}
+
+
+ `
if (documents.length) {
html += ""
- documents.forEach((subdocument) => {
- html += `${renderDocumentsTree(subdocument)}`
+ documents.forEach((subDocument) => {
+ html += `${renderDocumentsTree(subDocument)}`
})
html += "
"
}
From 71f3d6446773c582e0b32d84271f1f5cba998a1b Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Mon, 3 Jul 2023 20:15:57 +0900
Subject: [PATCH 017/107] =?UTF-8?q?Refactor:=20NotionPage=20=ED=8C=8C?=
=?UTF-8?q?=EC=9D=BC=20=EC=82=AD=EC=A0=9C?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
메인 페이지가 notionPage이고, 다른 페이지가 존재하지 않으므로 App.js에 모두 구현하도록 변경
---
src/components/App.js | 51 ++++++++++++++++++++++++++++++-----------
src/pages/NotionPage.js | 41 ---------------------------------
2 files changed, 37 insertions(+), 55 deletions(-)
delete mode 100644 src/pages/NotionPage.js
diff --git a/src/components/App.js b/src/components/App.js
index bb0d22ed..514bf098 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,16 +1,17 @@
-import { getRootDocument, getSpecificDocument } from '../api/api'
-import NotionPage from '../pages/NotionPage'
+import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
+import Content from '../components/Content'
+import DocumentsList from '../components/DocumentsList'
export default function App({ $target, initialState }) {
- const $app = document.createElement('div')
- $target.appendChild($app)
+ const $notionPage = document.createElement('div')
+ $target.appendChild($notionPage)
- // documents state
+ // documents list state
this.documents = initialState.documents
this.setDocuments = (nextDocuments) => {
this.documents = nextDocuments
- notionPage.documentsList.setState(nextDocuments)
+ documentsList.setState(nextDocuments)
}
// document editor state
@@ -18,9 +19,38 @@ export default function App({ $target, initialState }) {
this.setEditorContent = (nextContent) => {
this.editorContent = nextContent
- notionPage.content.setState(nextContent)
+ content.setState(nextContent)
}
+ const documentsList = new DocumentsList({
+ $target: $notionPage,
+ initialState: this.documents,
+ onClick: (id) => {
+ fetchContentData(id)
+ },
+ onAdd: async (id) => {
+ const data = {
+ title: "제목 없음",
+ parent: id ? id : null
+ }
+
+ const newDocument = await createDocument(data)
+
+ fetchDocumentsData()
+ fetchContentData(newDocument.id)
+ },
+ })
+
+ const content = new Content({
+ $target: $notionPage,
+ initialState: this.editorContent,
+ onDelete: async (id) => {
+ await deleteSpecificDocument(id)
+ fetchDocumentsData()
+ fetchContentData()
+ }
+ })
+
// 함수 파일 작성하기
// 전체 documentsList 불러오기
const fetchDocumentsData = async () => {
@@ -38,12 +68,5 @@ export default function App({ $target, initialState }) {
}
}
- const notionPage = new NotionPage({
- $target,
- initialState,
- fetchContentData,
- fetchDocumentsData,
- })
-
fetchDocumentsData()
}
\ No newline at end of file
diff --git a/src/pages/NotionPage.js b/src/pages/NotionPage.js
deleted file mode 100644
index 1b5e09bd..00000000
--- a/src/pages/NotionPage.js
+++ /dev/null
@@ -1,41 +0,0 @@
-import { createDocument, deleteSpecificDocument } from '../api/api'
-import Content from '../components/Content'
-import DocumentsList from '../components/DocumentsList'
-
-export default function NotionPage({
- $target,
- initialState,
- fetchContentData,
- fetchDocumentsData,
-}) {
- const $notionPage = document.createElement('div')
- $target.appendChild($notionPage)
-
- this.documentsList = new DocumentsList({
- $target: $notionPage,
- initialState: initialState.documents,
- onClick: (id) => {
- fetchContentData(id)
- },
- onAdd: async (id) => {
- const data = {
- title: "제목 없음",
- parent: id ? id : null
- }
- const newDocument = await createDocument(data)
-
- fetchDocumentsData()
- fetchContentData(newDocument.id)
- },
- })
-
- this.content = new Content({
- $target: $notionPage,
- initialState: initialState.editorContent,
- onDelete: async (id) => {
- await deleteSpecificDocument(id)
- fetchDocumentsData()
- fetchContentData()
- },
- })
-}
\ No newline at end of file
From 39737bce83cba58c35925fc1a7d0a7c7a69f340f Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Mon, 3 Jul 2023 23:56:44 +0900
Subject: [PATCH 018/107] =?UTF-8?q?Refactor:=20=EC=BB=B4=ED=8F=AC=EB=84=8C?=
=?UTF-8?q?=ED=8A=B8=20=ED=8F=B4=EB=8D=94=20=EB=B6=84=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/{ => editor}/DocumentsList.js | 0
src/components/{ => sidebar}/Content.js | 0
2 files changed, 0 insertions(+), 0 deletions(-)
rename src/components/{ => editor}/DocumentsList.js (100%)
rename src/components/{ => sidebar}/Content.js (100%)
diff --git a/src/components/DocumentsList.js b/src/components/editor/DocumentsList.js
similarity index 100%
rename from src/components/DocumentsList.js
rename to src/components/editor/DocumentsList.js
diff --git a/src/components/Content.js b/src/components/sidebar/Content.js
similarity index 100%
rename from src/components/Content.js
rename to src/components/sidebar/Content.js
From 08351a15dd5d984496e7dffeb24bf75d1070ea9b Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Mon, 3 Jul 2023 23:56:55 +0900
Subject: [PATCH 019/107] =?UTF-8?q?Feat:=20=EB=9D=BC=EC=9A=B0=ED=8C=85=20?=
=?UTF-8?q?=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 52 ++++++++++++++++++++++++++++++-------------
1 file changed, 37 insertions(+), 15 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index 514bf098..1ac5c843 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,6 +1,6 @@
import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
-import Content from '../components/Content'
-import DocumentsList from '../components/DocumentsList'
+import Content from './sidebar/Content'
+import DocumentsList from './editor/DocumentsList'
export default function App({ $target, initialState }) {
const $notionPage = document.createElement('div')
@@ -26,7 +26,7 @@ export default function App({ $target, initialState }) {
$target: $notionPage,
initialState: this.documents,
onClick: (id) => {
- fetchContentData(id)
+ navigate(`/${id}`)
},
onAdd: async (id) => {
const data = {
@@ -35,9 +35,7 @@ export default function App({ $target, initialState }) {
}
const newDocument = await createDocument(data)
-
- fetchDocumentsData()
- fetchContentData(newDocument.id)
+ navigate(`/${newDocument.id}`)
},
})
@@ -46,12 +44,10 @@ export default function App({ $target, initialState }) {
initialState: this.editorContent,
onDelete: async (id) => {
await deleteSpecificDocument(id)
- fetchDocumentsData()
- fetchContentData()
+ navigate('/')
}
})
- // 함수 파일 작성하기
// 전체 documentsList 불러오기
const fetchDocumentsData = async () => {
const documents = await getRootDocument()
@@ -59,14 +55,40 @@ export default function App({ $target, initialState }) {
}
// 특정 document의 content 불러오기
- const fetchContentData = async (id = null) => {
- if (id) {
- const content = await getSpecificDocument(id)
- this.setEditorContent(content)
+ const fetchContentData = async () => {
+ const id = location.pathname.substring(1)
+ const content = id ? await getSpecificDocument(id) : null
+
+ this.setEditorContent(content)
+ }
+
+ // 라우팅 구현
+ const navigate = (path) => {
+ const { pathname } = location
+
+ if (pathname === path) {
+ window.history.replaceState(null, null, path)
} else {
- this.setEditorContent(null)
+ window.history.pushState(null, null, path)
+ }
+
+ this.route()
+ }
+
+ this.route = () => {
+ const { pathname } = location
+ if (pathname === '/404') {
+ // 404 페이지
+ return
}
+
+ fetchDocumentsData()
+ fetchContentData()
+ }
+
+ this.init = () => {
+ this.route()
}
- fetchDocumentsData()
+ this.init()
}
\ No newline at end of file
From 119c86a052ecf73308c51fdf97af5764a2ebe761 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Mon, 3 Jul 2023 23:57:54 +0900
Subject: [PATCH 020/107] =?UTF-8?q?Refactor:=20=EC=BB=B4=ED=8F=AC=EB=84=8C?=
=?UTF-8?q?=ED=8A=B8=20=ED=8C=8C=EC=9D=BC=20=EC=9E=AC=EB=B6=84=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 4 ++--
src/components/{sidebar => editor}/Content.js | 0
src/components/{editor => sidebar}/DocumentsList.js | 0
3 files changed, 2 insertions(+), 2 deletions(-)
rename src/components/{sidebar => editor}/Content.js (100%)
rename src/components/{editor => sidebar}/DocumentsList.js (100%)
diff --git a/src/components/App.js b/src/components/App.js
index 1ac5c843..89e1bb73 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,6 +1,6 @@
import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
-import Content from './sidebar/Content'
-import DocumentsList from './editor/DocumentsList'
+import Content from './editor/Content'
+import DocumentsList from './sidebar/DocumentsList'
export default function App({ $target, initialState }) {
const $notionPage = document.createElement('div')
diff --git a/src/components/sidebar/Content.js b/src/components/editor/Content.js
similarity index 100%
rename from src/components/sidebar/Content.js
rename to src/components/editor/Content.js
diff --git a/src/components/editor/DocumentsList.js b/src/components/sidebar/DocumentsList.js
similarity index 100%
rename from src/components/editor/DocumentsList.js
rename to src/components/sidebar/DocumentsList.js
From ec31f98f9cdeed780437eae43d07a2f4a006864d Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 03:30:02 +0900
Subject: [PATCH 021/107] =?UTF-8?q?Feat:=20Document=20=ED=86=A0=EA=B8=80?=
=?UTF-8?q?=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
index.html | 1 +
src/components/App.js | 17 ++++++++
src/components/sidebar/DocumentsList.js | 54 ++++++++++++++++---------
styles/style.css | 3 ++
4 files changed, 57 insertions(+), 18 deletions(-)
create mode 100644 styles/style.css
diff --git a/index.html b/index.html
index 4a299996..8b0e1ada 100644
--- a/index.html
+++ b/index.html
@@ -2,6 +2,7 @@
효리의 노션 클로닝 사이트
+
diff --git a/src/components/App.js b/src/components/App.js
index 89e1bb73..43d691ed 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,4 +1,5 @@
import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
+import { setItem } from '../utils/storage'
import Content from './editor/Content'
import DocumentsList from './sidebar/DocumentsList'
@@ -37,8 +38,24 @@ export default function App({ $target, initialState }) {
const newDocument = await createDocument(data)
navigate(`/${newDocument.id}`)
},
+ onToggle: async (target, id) => {
+ const $toggle = target.closest('.toggle')
+ const $nestedList = $toggle.closest('li').querySelector('.nested')
+ $nestedList.classList.toggle('hidden')
+
+ const isOpen = !$nestedList.classList.contains('hidden')
+ saveToggleState(id, isOpen)
+ fetchDocumentsData()
+ }
})
+ const toggleStateKey = (id) => `toggleState_${id}`
+
+ const saveToggleState = (id, isOpen) => {
+ const key = toggleStateKey(id)
+ setItem(key, isOpen)
+ }
+
const content = new Content({
$target: $notionPage,
initialState: this.editorContent,
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index cd6e1edd..172c5b1e 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -1,8 +1,11 @@
+import { getItem, setItem } from '../../utils/storage'
+
export default function DocumentsList({
$target,
initialState,
onClick,
onAdd,
+ onToggle,
}) {
const $documents = document.createElement('div')
$target.appendChild($documents)
@@ -13,24 +16,36 @@ export default function DocumentsList({
this.state = nextState
this.render()
}
+
+ const toggleStateKey = (id) => `toggleState_${id}`
+
+ const renderDocument = (document) => {
+ const { id, title, documents } = document
+ const toggleState = getItem(toggleStateKey(id), false)
+ const isHiddenClass = toggleState ? '' : 'hidden'
- const renderDocumentsTree = ({ documents, title, id }) => {
- // 일단 id도 뜨게 구현
let html = `
- -
+
-
+
[${id}] ${title}
-
-
- `
+
+ `
- if (documents.length) {
- html += ""
+ if (documents.length && toggleState) {
+ html += ``
documents.forEach((subDocument) => {
- html += `${renderDocumentsTree(subDocument)}`
+ html += `${renderDocument(subDocument)}`
})
- html += "
"
+ html += '
'
+ } else {
+ html += `
+ `
}
+ html += ''
+
return html
}
@@ -38,23 +53,26 @@ export default function DocumentsList({
$documents.innerHTML = `
${this.state.map((document) =>
- `${renderDocumentsTree(document)}`).join('')}
-
+ `${renderDocument(document)}`).join('')}
+
`
const $documentsList = $documents.querySelectorAll('li')
$documentsList.forEach(($document) => {
- $document.addEventListener('click', ({ target }) => {
+ $document.addEventListener('click', (e) => {
const { id } = $document.dataset
+ const { target } = e
+ e.stopPropagation()
- if (target.closest('span')) {
- onClick(id)
- }
-
- if (target.closest('button')) {
+ if (target.closest('.toggle')) {
+ onToggle(target, id)
+ this.render() // 낙관적 업데이트
+ } else if (target.closest('.add')) {
onAdd(id ? id : null)
+ } else if (target.closest('.document')) {
+ id && onClick(id)
}
})
})
diff --git a/styles/style.css b/styles/style.css
new file mode 100644
index 00000000..3d40c189
--- /dev/null
+++ b/styles/style.css
@@ -0,0 +1,3 @@
+.hidden {
+ display: none;
+}
\ No newline at end of file
From 1cd65b0da5a4ab4b0d6db342079d240acab09baf Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 03:33:52 +0900
Subject: [PATCH 022/107] =?UTF-8?q?Feat:=20Document=20=EB=A6=AC=EC=8A=A4?=
=?UTF-8?q?=ED=8A=B8=20=EC=82=AD=EC=A0=9C=20=EB=B2=84=ED=8A=BC=20=EC=B6=94?=
=?UTF-8?q?=EA=B0=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 10 ++++++++++
src/components/sidebar/DocumentsList.js | 4 ++++
2 files changed, 14 insertions(+)
diff --git a/src/components/App.js b/src/components/App.js
index 43d691ed..9e9fc5e0 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -46,6 +46,16 @@ export default function App({ $target, initialState }) {
const isOpen = !$nestedList.classList.contains('hidden')
saveToggleState(id, isOpen)
fetchDocumentsData()
+ },
+ onDelete: async (id) => {
+ const pathId = location.pathname.substring(1)
+
+ await deleteSpecificDocument(id)
+ if (pathId === id) {
+ navigate('/')
+ } else {
+ fetchDocumentsData()
+ }
}
})
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index 172c5b1e..554cf15b 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -6,6 +6,7 @@ export default function DocumentsList({
onClick,
onAdd,
onToggle,
+ onDelete,
}) {
const $documents = document.createElement('div')
$target.appendChild($documents)
@@ -28,6 +29,7 @@ export default function DocumentsList({
-
[${id}] ${title}
+
`
@@ -71,6 +73,8 @@ export default function DocumentsList({
this.render() // 낙관적 업데이트
} else if (target.closest('.add')) {
onAdd(id ? id : null)
+ } else if (target.closest('.delete')) {
+ onDelete(id)
} else if (target.closest('.document')) {
id && onClick(id)
}
From 35d3e1a079d526019cbbe428761617843813e081 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 04:48:03 +0900
Subject: [PATCH 023/107] =?UTF-8?q?Feat:=20document=20=EC=B6=94=EA=B0=80?=
=?UTF-8?q?=20=EC=8B=9C=20=ED=86=A0=EA=B8=80=20=EA=B8=B0=EB=8A=A5=20?=
=?UTF-8?q?=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 9 ++++++---
src/components/sidebar/DocumentsList.js | 8 +++++---
2 files changed, 11 insertions(+), 6 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index 9e9fc5e0..394e1a0f 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -34,14 +34,17 @@ export default function App({ $target, initialState }) {
title: "제목 없음",
parent: id ? id : null
}
-
+
const newDocument = await createDocument(data)
navigate(`/${newDocument.id}`)
+
+ return newDocument.id
},
- onToggle: async (target, id) => {
+ onToggle: async (target, id, event = '') => {
const $toggle = target.closest('.toggle')
const $nestedList = $toggle.closest('li').querySelector('.nested')
- $nestedList.classList.toggle('hidden')
+ if (event !== 'add' || $nestedList.classList.contains('hidden'))
+ $nestedList.classList.toggle('hidden')
const isOpen = !$nestedList.classList.contains('hidden')
saveToggleState(id, isOpen)
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index 554cf15b..b3191e25 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -41,7 +41,7 @@ export default function DocumentsList({
html += '
'
} else {
html += `
-
+ `
}
@@ -63,16 +63,18 @@ export default function DocumentsList({
const $documentsList = $documents.querySelectorAll('li')
$documentsList.forEach(($document) => {
- $document.addEventListener('click', (e) => {
+ $document.addEventListener('click', async (e) => {
const { id } = $document.dataset
const { target } = e
e.stopPropagation()
+ this.setState([...this.state])
+
if (target.closest('.toggle')) {
onToggle(target, id)
- this.render() // 낙관적 업데이트
} else if (target.closest('.add')) {
onAdd(id ? id : null)
+ onToggle($document.querySelector('.toggle'), id, target.className)
} else if (target.closest('.delete')) {
onDelete(id)
} else if (target.closest('.document')) {
From 86ec746dbac26b99c042998b37fb05c616673a83 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 04:54:48 +0900
Subject: [PATCH 024/107] =?UTF-8?q?Refactor:=20=ED=95=98=EB=8B=A8=20?=
=?UTF-8?q?=EC=B6=94=EA=B0=80=20=EB=B2=84=ED=8A=BC=20=ED=81=B4=EB=A6=AD=20?=
=?UTF-8?q?=EC=8B=9C=20Toggle=20=EC=9D=B4=EB=B2=A4=ED=8A=B8=20=EA=B5=AC?=
=?UTF-8?q?=ED=98=84=20=EB=B0=A9=EC=A7=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/sidebar/DocumentsList.js | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index b3191e25..f9c29a74 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -73,8 +73,12 @@ export default function DocumentsList({
if (target.closest('.toggle')) {
onToggle(target, id)
} else if (target.closest('.add')) {
- onAdd(id ? id : null)
- onToggle($document.querySelector('.toggle'), id, target.className)
+ if (id) {
+ onAdd(id)
+ onToggle($document.querySelector('.toggle'), id, target.className)
+ } else {
+ onAdd()
+ }
} else if (target.closest('.delete')) {
onDelete(id)
} else if (target.closest('.document')) {
From 417655a068e0ae54e2228c6bb217b0ae55bb70d7 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 05:25:12 +0900
Subject: [PATCH 025/107] =?UTF-8?q?Refactor:=20=EB=94=94=EB=A0=89=ED=86=A0?=
=?UTF-8?q?=EB=A6=AC=20=EA=B5=AC=EC=A1=B0=20=EC=A0=81=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
config/configuration.js | 0
src/components/editor/Editor.js | 0
src/components/editor/Title.js | 0
src/components/sidebar/Sidebar.js | 0
src/components/sidebar/SidebarHeader.js | 0
src/pages/MainPage.js | 0
src/pages/NotFoundPage.js | 0
src/routes/routes.js | 0
src/templates/templates.js | 0
src/utils/constants.js | 0
src/utils/domUtils.js | 0
src/utils/validation.js | 0
12 files changed, 0 insertions(+), 0 deletions(-)
create mode 100644 config/configuration.js
create mode 100644 src/components/editor/Editor.js
create mode 100644 src/components/editor/Title.js
create mode 100644 src/components/sidebar/Sidebar.js
create mode 100644 src/components/sidebar/SidebarHeader.js
create mode 100644 src/pages/MainPage.js
create mode 100644 src/pages/NotFoundPage.js
create mode 100644 src/routes/routes.js
create mode 100644 src/templates/templates.js
create mode 100644 src/utils/constants.js
create mode 100644 src/utils/domUtils.js
create mode 100644 src/utils/validation.js
diff --git a/config/configuration.js b/config/configuration.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/components/sidebar/Sidebar.js b/src/components/sidebar/Sidebar.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/components/sidebar/SidebarHeader.js b/src/components/sidebar/SidebarHeader.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/pages/NotFoundPage.js b/src/pages/NotFoundPage.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/routes/routes.js b/src/routes/routes.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/templates/templates.js b/src/templates/templates.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/utils/constants.js b/src/utils/constants.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/utils/domUtils.js b/src/utils/domUtils.js
new file mode 100644
index 00000000..e69de29b
diff --git a/src/utils/validation.js b/src/utils/validation.js
new file mode 100644
index 00000000..e69de29b
From 240df8065a29465aca8435118a524677f37c8cb8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 06:26:24 +0900
Subject: [PATCH 026/107] =?UTF-8?q?Refactor:=20Editor=20=EC=84=B8=EB=B6=80?=
=?UTF-8?q?=20=EC=BB=B4=ED=8F=AC=EB=84=8C=ED=8A=B8=20=EB=B6=84=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 14 ++++++-------
src/components/editor/Content.js | 34 ++++++++++++--------------------
src/components/editor/Editor.js | 26 ++++++++++++++++++++++++
src/components/editor/Title.js | 28 ++++++++++++++++++++++++++
src/index.js | 2 +-
5 files changed, 75 insertions(+), 29 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index 394e1a0f..6b285d50 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,11 +1,11 @@
import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
import { setItem } from '../utils/storage'
-import Content from './editor/Content'
+import Editor from './editor/Editor'
import DocumentsList from './sidebar/DocumentsList'
export default function App({ $target, initialState }) {
- const $notionPage = document.createElement('div')
- $target.appendChild($notionPage)
+ const $mainPage = document.createElement('div')
+ $target.appendChild($mainPage)
// documents list state
this.documents = initialState.documents
@@ -20,11 +20,11 @@ export default function App({ $target, initialState }) {
this.setEditorContent = (nextContent) => {
this.editorContent = nextContent
- content.setState(nextContent)
+ editor.setState(nextContent)
}
const documentsList = new DocumentsList({
- $target: $notionPage,
+ $target: $mainPage,
initialState: this.documents,
onClick: (id) => {
navigate(`/${id}`)
@@ -69,8 +69,8 @@ export default function App({ $target, initialState }) {
setItem(key, isOpen)
}
- const content = new Content({
- $target: $notionPage,
+ const editor = new Editor({
+ $target: $mainPage,
initialState: this.editorContent,
onDelete: async (id) => {
await deleteSpecificDocument(id)
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index 61b583f2..f451d813 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,6 +1,5 @@
-export default function Content({ $target, initialState, onDelete }) {
+export default function Content({ initialState }) {
const $content = document.createElement('div')
- $target.appendChild($content)
this.state = initialState
@@ -15,27 +14,20 @@ export default function Content({ $target, initialState, onDelete }) {
return
}
- const { id, title, content, documents } = this.state
+ const { content, documents } = this.state
- $content.innerHTML = `
- [${id}] ${title}
-
+ if (documents) {
+ $content.innerHTML = this.state ? `
+
+ ${documents.map((subDocument) =>
+ `- ${subDocument.title}
`
+ ).join('')}
+
` : ''
+ }
+ }
- ${documents.length ? `
-
- ${documents.map((subDocument) =>
- `- ${subDocument.title}
`
- ).join('')}
-
- ` : ''
- }
- `
-
- const $deleteButton = $content.querySelector('button')
+ this.render()
- $deleteButton.addEventListener('click', () => {
- onDelete(id)
- })
- }
+ return $content
}
\ No newline at end of file
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index e69de29b..1bcaf75a 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -0,0 +1,26 @@
+import Content from './Content.js'
+import Title from './Title.js'
+
+export default function Editor({ $target, initialState, onDelete }) {
+ const $editor = document.createElement('main')
+ $target.appendChild($editor)
+
+ this.state = initialState
+
+ this.setState = (nextState) => {
+ this.state = nextState
+ this.render()
+ }
+
+ this.render = () => {
+ $editor.innerHTML = ''
+
+ const titleComponent = new Title({ initialState: this.state })
+ const contentComponent = new Content({ initialState: this.state, onDelete })
+
+ $editor.appendChild(titleComponent)
+ $editor.appendChild(contentComponent)
+ }
+
+ this.render()
+}
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index e69de29b..71ee4a22 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -0,0 +1,28 @@
+export default function Title({ initialState = {} }) {
+ const $title = document.createElement('div')
+ $title.classList.add('title')
+
+ this.state = initialState
+
+ this.setState = (nextState) => {
+ this.state = nextState
+ this.render()
+ }
+
+ this.render = () => {
+ if (!this.state) {
+ $title.innerHTML = ''
+ return
+ }
+
+ const { title } = this.state
+
+ $title.innerHTML = `
+
+ `
+ }
+
+ this.render()
+
+ return $title
+}
\ No newline at end of file
diff --git a/src/index.js b/src/index.js
index 674c7b25..1bf91b92 100644
--- a/src/index.js
+++ b/src/index.js
@@ -6,6 +6,6 @@ new App({
$target,
initialState: {
documents: [],
- editorContent: null
+ editorContent: {}
}
})
\ No newline at end of file
From c48d7c0582fb1a4c536a8fcb4d19ebf9fd3858e8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 06:37:14 +0900
Subject: [PATCH 027/107] =?UTF-8?q?Refactor:=20Sidebar=20=EC=84=B8?=
=?UTF-8?q?=EB=B6=80=20=EC=BB=B4=ED=8F=AC=EB=84=8C=ED=8A=B8=20=EB=B6=84?=
=?UTF-8?q?=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 5 ++--
src/components/sidebar/DocumentsList.js | 14 ++++-----
src/components/sidebar/Sidebar.js | 38 +++++++++++++++++++++++++
src/components/sidebar/SidebarHeader.js | 15 ++++++++++
4 files changed, 63 insertions(+), 9 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index 6b285d50..2e1c05f3 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -2,6 +2,7 @@ import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDoc
import { setItem } from '../utils/storage'
import Editor from './editor/Editor'
import DocumentsList from './sidebar/DocumentsList'
+import Sidebar from './sidebar/Sidebar'
export default function App({ $target, initialState }) {
const $mainPage = document.createElement('div')
@@ -12,7 +13,7 @@ export default function App({ $target, initialState }) {
this.setDocuments = (nextDocuments) => {
this.documents = nextDocuments
- documentsList.setState(nextDocuments)
+ sidebar.setState(nextDocuments)
}
// document editor state
@@ -23,7 +24,7 @@ export default function App({ $target, initialState }) {
editor.setState(nextContent)
}
- const documentsList = new DocumentsList({
+ const sidebar = new Sidebar({
$target: $mainPage,
initialState: this.documents,
onClick: (id) => {
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index f9c29a74..a1dd8fa5 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -1,15 +1,13 @@
-import { getItem, setItem } from '../../utils/storage'
+import { getItem } from '../../utils/storage'
export default function DocumentsList({
- $target,
initialState,
onClick,
onAdd,
onToggle,
- onDelete,
+ onDelete
}) {
const $documents = document.createElement('div')
- $target.appendChild($documents)
this.state = initialState
@@ -17,7 +15,7 @@ export default function DocumentsList({
this.state = nextState
this.render()
}
-
+
const toggleStateKey = (id) => `toggleState_${id}`
const renderDocument = (document) => {
@@ -54,8 +52,8 @@ export default function DocumentsList({
this.render = () => {
$documents.innerHTML = `
- ${this.state.map((document) =>
- `${renderDocument(document)}`).join('')}
+ ${this.state.map((document) =>
+ `${renderDocument(document)}`).join('')}
`
@@ -89,4 +87,6 @@ export default function DocumentsList({
}
this.render()
+
+ return $documents
}
\ No newline at end of file
diff --git a/src/components/sidebar/Sidebar.js b/src/components/sidebar/Sidebar.js
index e69de29b..96717d4c 100644
--- a/src/components/sidebar/Sidebar.js
+++ b/src/components/sidebar/Sidebar.js
@@ -0,0 +1,38 @@
+import DocumentsList from './DocumentsList'
+import SidebarHeader from './SidebarHeader'
+
+export default function Sidebar({
+ $target,
+ initialState,
+ onClick,
+ onAdd,
+ onToggle,
+ onDelete, }) {
+ const $sidebar = document.createElement('div')
+ $target.appendChild($sidebar)
+
+ this.state = initialState
+
+ this.setState = (nextState) => {
+ this.state = nextState
+ this.render()
+ }
+
+ this.render = () => {
+ $sidebar.innerHTML = ''
+
+ const $header = new SidebarHeader({ initialState: this.state })
+ const $documents = new DocumentsList({
+ initialState: this.state,
+ onClick,
+ onAdd,
+ onToggle,
+ onDelete
+ })
+
+ $sidebar.appendChild($header)
+ $sidebar.appendChild($documents)
+ }
+
+ this.render()
+}
diff --git a/src/components/sidebar/SidebarHeader.js b/src/components/sidebar/SidebarHeader.js
index e69de29b..eb1b49b0 100644
--- a/src/components/sidebar/SidebarHeader.js
+++ b/src/components/sidebar/SidebarHeader.js
@@ -0,0 +1,15 @@
+export default function SidebarHeader({ initialState }) {
+ const $header = document.createElement('header')
+ $header.classList.add('header')
+
+ this.render = () => {
+ $header.innerHTML = `
+
+ 효리보고의 Notion
+ `
+ }
+
+ this.render()
+
+ return $header
+}
\ No newline at end of file
From 6a05ec0113fe5002a888d1c3a690074a8be4112f Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 06:37:45 +0900
Subject: [PATCH 028/107] =?UTF-8?q?Rename:=20=EC=BB=B4=ED=8F=AC=EB=84=8C?=
=?UTF-8?q?=ED=8A=B8=20=EB=B3=80=EC=88=98=EB=AA=85=20=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/editor/Editor.js | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index 1bcaf75a..46ecad78 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -15,11 +15,11 @@ export default function Editor({ $target, initialState, onDelete }) {
this.render = () => {
$editor.innerHTML = ''
- const titleComponent = new Title({ initialState: this.state })
- const contentComponent = new Content({ initialState: this.state, onDelete })
+ const $title = new Title({ initialState: this.state })
+ const $content = new Content({ initialState: this.state, onDelete })
- $editor.appendChild(titleComponent)
- $editor.appendChild(contentComponent)
+ $editor.appendChild($title)
+ $editor.appendChild($content)
}
this.render()
From 776f8894e502967ba73e339f447df3c37710d71b Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 07:25:12 +0900
Subject: [PATCH 029/107] =?UTF-8?q?Refactor:=20Router=20=ED=8C=8C=EC=9D=BC?=
=?UTF-8?q?=20=EB=B6=84=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/routes/Router.js | 33 +++++++++++++++++++++++++++++++++
src/routes/routes.js | 0
2 files changed, 33 insertions(+)
create mode 100644 src/routes/Router.js
delete mode 100644 src/routes/routes.js
diff --git a/src/routes/Router.js b/src/routes/Router.js
new file mode 100644
index 00000000..359895af
--- /dev/null
+++ b/src/routes/Router.js
@@ -0,0 +1,33 @@
+import MainPage from '../pages/MainPage'
+import NotFoundPage from '../pages/NotFoundPage'
+
+export default function Router({ $target }) {
+ this.routes = {
+ '': MainPage,
+ 'documents': MainPage,
+ '404': NotFoundPage
+ }
+
+ this.init = () => {
+ this.route()
+
+ window.addEventListener('popstate', () => {
+ this.route()
+ })
+ }
+
+ this.route = () => {
+ const { pathname } = location
+
+ let path = pathname.split('/')[1]
+
+ let PageComponent = this.routes[path]
+
+ if (!PageComponent) {
+ PageComponent = NotFoundPage
+ }
+
+ $target.innerHTML = ''
+ new PageComponent({ $target: $target })
+ }
+}
diff --git a/src/routes/routes.js b/src/routes/routes.js
deleted file mode 100644
index e69de29b..00000000
From 5198fffd2b55a61fa11cda44ba5bfec2e4b550e8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 07:25:23 +0900
Subject: [PATCH 030/107] =?UTF-8?q?Refactor:=20fetchData=20=ED=8C=8C?=
=?UTF-8?q?=EC=9D=BC=20=EB=B6=84=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/utils/fetchData.js | 25 +++++++++++++++++++++++++
1 file changed, 25 insertions(+)
create mode 100644 src/utils/fetchData.js
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
new file mode 100644
index 00000000..e8476f0f
--- /dev/null
+++ b/src/utils/fetchData.js
@@ -0,0 +1,25 @@
+import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
+
+export async function fetchRootDocument() {
+ const documents = await getRootDocument()
+ return documents
+}
+
+export async function fetchSpecificDocument(id) {
+ const content = await getSpecificDocument(id)
+ return content
+}
+
+export async function createNewDocument(parentId) {
+ const data = {
+ title: "제목 없음",
+ parent: parentId || null
+ }
+
+ const newDocument = await createDocument(data)
+ return newDocument
+}
+
+export async function deleteDocument(id) {
+ await deleteSpecificDocument(id)
+}
From cbe80058630038f713e5bba6211dcb59d05a1b36 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 07:25:49 +0900
Subject: [PATCH 031/107] =?UTF-8?q?Feat:=20404=20=ED=8E=98=EC=9D=B4?=
=?UTF-8?q?=EC=A7=80=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/pages/NotFoundPage.js | 14 ++++++++++++++
1 file changed, 14 insertions(+)
diff --git a/src/pages/NotFoundPage.js b/src/pages/NotFoundPage.js
index e69de29b..6d1fbfb4 100644
--- a/src/pages/NotFoundPage.js
+++ b/src/pages/NotFoundPage.js
@@ -0,0 +1,14 @@
+export default function NotFoundPage({ $target }) {
+ const $notFoundPage = document.createElement('div')
+ $target.appendChild($notFoundPage)
+
+ $notFoundPage.innerHTML = `
+
+ 이 콘텐츠는 존재하지 않습니다
+
+ `
+
+ $notFoundPage.addEventListener('click', () => {
+ // navigate('/')
+ })
+}
\ No newline at end of file
From 67e1da78f348e6c0d2bd084cd78de582c7cc26f1 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 07:26:43 +0900
Subject: [PATCH 032/107] =?UTF-8?q?Feat:=20404=20=EC=9D=91=EB=8B=B5=20?=
=?UTF-8?q?=EC=8B=9C=20404=20=ED=8E=98=EC=9D=B4=EC=A7=80=20=EB=A0=8C?=
=?UTF-8?q?=EB=8D=94=EB=A7=81=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/api.js | 13 ++++++++++++-
1 file changed, 12 insertions(+), 1 deletion(-)
diff --git a/src/api/api.js b/src/api/api.js
index e901a000..911f4076 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -1,3 +1,5 @@
+import NotFoundPage from '../pages/NotFoundPage'
+
const API_END_POINT = "https://kdt-frontend.programmers.co.kr/documents"
const request = async (url = "", options = {}) => {
@@ -10,9 +12,18 @@ const request = async (url = "", options = {}) => {
return await res.json()
}
+ if (res.status === 404) {
+ throw new Error("Not Found")
+ }
+
throw new Error("API 처리 중 에러가 발생했습니다.")
} catch (e) {
- alert(e.message)
+ console.log(e.message)
+ if (e.message === "Not Found") {
+ const $target = document.querySelector('#app')
+ $target.innerHTML = ''
+ new NotFoundPage({ $target })
+ }
}
}
From 43c880be8216d404b0e537cb0b3a28228465fc0e Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 07:27:12 +0900
Subject: [PATCH 033/107] =?UTF-8?q?Refactor:=20MainPage=20=EC=BB=B4?=
=?UTF-8?q?=ED=8F=AC=EB=84=8C=ED=8A=B8=20=EB=B6=84=EB=A6=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 122 ++----------------------------------------
src/pages/MainPage.js | 104 +++++++++++++++++++++++++++++++++++
2 files changed, 108 insertions(+), 118 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index 2e1c05f3..12d84f49 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,124 +1,10 @@
-import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
-import { setItem } from '../utils/storage'
-import Editor from './editor/Editor'
-import DocumentsList from './sidebar/DocumentsList'
-import Sidebar from './sidebar/Sidebar'
+import Router from '../routes/router'
-export default function App({ $target, initialState }) {
- const $mainPage = document.createElement('div')
- $target.appendChild($mainPage)
-
- // documents list state
- this.documents = initialState.documents
-
- this.setDocuments = (nextDocuments) => {
- this.documents = nextDocuments
- sidebar.setState(nextDocuments)
- }
-
- // document editor state
- this.editorContent = initialState.editorContent
-
- this.setEditorContent = (nextContent) => {
- this.editorContent = nextContent
- editor.setState(nextContent)
- }
-
- const sidebar = new Sidebar({
- $target: $mainPage,
- initialState: this.documents,
- onClick: (id) => {
- navigate(`/${id}`)
- },
- onAdd: async (id) => {
- const data = {
- title: "제목 없음",
- parent: id ? id : null
- }
-
- const newDocument = await createDocument(data)
- navigate(`/${newDocument.id}`)
-
- return newDocument.id
- },
- onToggle: async (target, id, event = '') => {
- const $toggle = target.closest('.toggle')
- const $nestedList = $toggle.closest('li').querySelector('.nested')
- if (event !== 'add' || $nestedList.classList.contains('hidden'))
- $nestedList.classList.toggle('hidden')
-
- const isOpen = !$nestedList.classList.contains('hidden')
- saveToggleState(id, isOpen)
- fetchDocumentsData()
- },
- onDelete: async (id) => {
- const pathId = location.pathname.substring(1)
-
- await deleteSpecificDocument(id)
- if (pathId === id) {
- navigate('/')
- } else {
- fetchDocumentsData()
- }
- }
- })
-
- const toggleStateKey = (id) => `toggleState_${id}`
-
- const saveToggleState = (id, isOpen) => {
- const key = toggleStateKey(id)
- setItem(key, isOpen)
- }
-
- const editor = new Editor({
- $target: $mainPage,
- initialState: this.editorContent,
- onDelete: async (id) => {
- await deleteSpecificDocument(id)
- navigate('/')
- }
- })
-
- // 전체 documentsList 불러오기
- const fetchDocumentsData = async () => {
- const documents = await getRootDocument()
- this.setDocuments(documents)
- }
-
- // 특정 document의 content 불러오기
- const fetchContentData = async () => {
- const id = location.pathname.substring(1)
- const content = id ? await getSpecificDocument(id) : null
-
- this.setEditorContent(content)
- }
-
- // 라우팅 구현
- const navigate = (path) => {
- const { pathname } = location
-
- if (pathname === path) {
- window.history.replaceState(null, null, path)
- } else {
- window.history.pushState(null, null, path)
- }
-
- this.route()
- }
-
- this.route = () => {
- const { pathname } = location
- if (pathname === '/404') {
- // 404 페이지
- return
- }
-
- fetchDocumentsData()
- fetchContentData()
- }
+export default function App({ $target }) {
+ const router = new Router({ $target })
this.init = () => {
- this.route()
+ router.init()
}
this.init()
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index e69de29b..0412e034 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -0,0 +1,104 @@
+import Sidebar from '../components/sidebar/Sidebar'
+import Editor from '../components/editor/Editor'
+import {
+ fetchRootDocument,
+ fetchSpecificDocument,
+ createNewDocument,
+ deleteDocument
+} from '../utils/fetchData'
+import { setItem } from '../utils/storage'
+
+export default function MainPage({ $target }) {
+ this.$mainPage = document.createElement('div')
+ $target.appendChild(this.$mainPage)
+
+ this.documents = []
+
+ this.setDocuments = (nextDocuments) => {
+ this.documents = nextDocuments
+ sidebar.setState(nextDocuments)
+ }
+
+ const sidebar = new Sidebar({
+ $target: this.$mainPage,
+ initialState: this.documents,
+ onClick: (id) => {
+ navigate(`/documents/${id}`)
+ },
+ onAdd: async (id) => {
+ const newDocument = await createNewDocument(id)
+ navigate(`/documents/${newDocument.id}`)
+ return newDocument.id
+ },
+ onToggle: async (target, id, event = '') => {
+ const $toggle = target.closest('.toggle')
+ const $nestedList = $toggle.closest('li').querySelector('.nested')
+ if (event !== 'add' || $nestedList.classList.contains('hidden'))
+ $nestedList.classList.toggle('hidden')
+
+ const isOpen = !$nestedList.classList.contains('hidden')
+ saveToggleState(id, isOpen)
+ fetchDocumentsData()
+ },
+ onDelete: async (id) => {
+ const pathId = location.pathname.split('/').at(-1)
+
+ await deleteDocument(id)
+ if (pathId === id) {
+ navigate('/')
+ } else {
+ fetchDocumentsData()
+ }
+ }
+ })
+
+ const toggleStateKey = (id) => `toggleState_${id}`
+
+ const saveToggleState = (id, isOpen) => {
+ const key = toggleStateKey(id)
+ setItem(key, isOpen)
+ }
+
+ const editor = new Editor({
+ $target: this.$mainPage,
+ onDelete: async (id) => {
+ await deleteDocument(id)
+ navigate('/')
+ }
+ })
+
+ const fetchDocumentsData = async () => {
+ const documents = await fetchRootDocument()
+ this.setDocuments(documents)
+ }
+
+ const fetchContentData = async () => {
+ const id = location.pathname.split('/').at(-1)
+ const content = id ? await fetchSpecificDocument(id) : null
+
+ editor.setState(content)
+ }
+
+ const navigate = (path) => {
+ const { pathname } = location
+
+ if (pathname === path) {
+ window.history.replaceState(null, null, path)
+ } else {
+ window.history.pushState(null, null, path)
+ }
+
+ this.route()
+ }
+
+ this.route = () => {
+ fetchDocumentsData()
+ fetchContentData()
+ }
+
+ this.init = () => {
+ this.route()
+ }
+
+ this.init()
+}
\ No newline at end of file
From fd241c56525018505c6924015265c128f7429bb8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 18:26:16 +0900
Subject: [PATCH 034/107] =?UTF-8?q?Refactor:=20title=20=EB=B9=88=20?=
=?UTF-8?q?=EA=B0=92=EC=9D=BC=20=EA=B2=BD=EC=9A=B0=20placeholder=EB=A1=9C?=
=?UTF-8?q?=20=EB=9C=A8=EB=8F=84=EB=A1=9D=20=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/editor/Content.js | 8 +++--
src/components/editor/Title.js | 52 +++++++++++++++++++-------------
src/utils/fetchData.js | 47 ++++++++++++++++++-----------
3 files changed, 66 insertions(+), 41 deletions(-)
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index f451d813..58c49127 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,7 +1,9 @@
export default function Content({ initialState }) {
const $content = document.createElement('div')
+ $content.classList.add('content')
this.state = initialState
+ this.input = this.state?.content
this.setState = (nextState) => {
this.state = nextState
@@ -17,13 +19,13 @@ export default function Content({ initialState }) {
const { content, documents } = this.state
if (documents) {
- $content.innerHTML = this.state ? `
+ $content.innerHTML = `
${documents.map((subDocument) =>
- `- ${subDocument.title}
`
+ `- ${subDocument.title.length ? subDocument.title : "제목 없음"}
`
).join('')}
-
` : ''
+
`
}
}
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index 71ee4a22..19aac617 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -1,28 +1,38 @@
-export default function Title({ initialState = {} }) {
- const $title = document.createElement('div')
- $title.classList.add('title')
+export default function Title({ initialState }) {
+ const $title = document.createElement('div')
+ $title.classList.add('title')
- this.state = initialState
+ this.state = initialState
- this.setState = (nextState) => {
- this.state = nextState
- this.render()
- }
+ this.setState = (nextState) => {
+ this.state = nextState
+ this.render()
+ }
- this.render = () => {
- if (!this.state) {
- $title.innerHTML = ''
- return
- }
+ this.render = () => {
+ if (!this.state) {
+ $title.innerHTML = ''
+ return
+ }
- const { title } = this.state
+ const { title } = this.state
- $title.innerHTML = `
-
- `
- }
+ if (title.length) {
+ $title.innerHTML = `
+
+ `
+ } else {
+ $title.innerHTML = `
+
+ `
+ }
- this.render()
+ // $title.addEventListener('keyup', e => {
+ // console.log(e.target.value)
+ // })
+ }
- return $title
-}
\ No newline at end of file
+ this.render()
+
+ return $title
+}
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
index e8476f0f..ed19ad0c 100644
--- a/src/utils/fetchData.js
+++ b/src/utils/fetchData.js
@@ -1,25 +1,38 @@
-import { createDocument, deleteSpecificDocument, getRootDocument, getSpecificDocument } from '../api/api'
+import {
+ createDocument,
+ deleteSpecificDocument,
+ getRootDocument,
+ getSpecificDocument,
+} from '../api/api'
-export async function fetchRootDocument() {
- const documents = await getRootDocument()
- return documents
+async function fetchRootDocument() {
+ const documents = await getRootDocument()
+ return documents
}
-export async function fetchSpecificDocument(id) {
- const content = await getSpecificDocument(id)
- return content
+async function fetchSpecificDocument(id) {
+ const content = await getSpecificDocument(id)
+ return content
}
-export async function createNewDocument(parentId) {
- const data = {
- title: "제목 없음",
- parent: parentId || null
- }
-
- const newDocument = await createDocument(data)
- return newDocument
+async function createNewDocument(parentId) {
+ const data = {
+ title: '',
+ parent: parentId || null,
+ }
+
+ const newDocument = await createDocument(data)
+ return newDocument
+}
+
+async function deleteDocument(id) {
+ await deleteSpecificDocument(id)
}
-export async function deleteDocument(id) {
- await deleteSpecificDocument(id)
+export {
+ fetchRootDocument,
+ fetchSpecificDocument,
+ createNewDocument,
+ createDocument,
+ deleteDocument,
}
From 0dd0c5a9d83f3c1f06616136e3fa702c0c458fdb Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 18:26:32 +0900
Subject: [PATCH 035/107] =?UTF-8?q?Refactor:=20Router=20=ED=95=A8=EC=88=98?=
=?UTF-8?q?=20=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/routes/Router.js | 17 ++++-------------
1 file changed, 4 insertions(+), 13 deletions(-)
diff --git a/src/routes/Router.js b/src/routes/Router.js
index 359895af..f8700d14 100644
--- a/src/routes/Router.js
+++ b/src/routes/Router.js
@@ -2,12 +2,6 @@ import MainPage from '../pages/MainPage'
import NotFoundPage from '../pages/NotFoundPage'
export default function Router({ $target }) {
- this.routes = {
- '': MainPage,
- 'documents': MainPage,
- '404': NotFoundPage
- }
-
this.init = () => {
this.route()
@@ -18,16 +12,13 @@ export default function Router({ $target }) {
this.route = () => {
const { pathname } = location
+ let PageComponent = NotFoundPage
- let path = pathname.split('/')[1]
-
- let PageComponent = this.routes[path]
-
- if (!PageComponent) {
- PageComponent = NotFoundPage
+ if (pathname === '/' || pathname.indexOf('/documents/') === 0) {
+ PageComponent = MainPage
}
$target.innerHTML = ''
- new PageComponent({ $target: $target })
+ new PageComponent({ $target })
}
}
From 6eba870229fc8d4a5a6f529d7683e27e23c20df8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 18:28:33 +0900
Subject: [PATCH 036/107] =?UTF-8?q?Feat:=20Content=20=EC=88=98=EC=A0=95=20?=
=?UTF-8?q?=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/editor/Editor.js | 33 +++++++++---
src/components/sidebar/DocumentsList.js | 15 +++---
src/pages/MainPage.js | 70 ++++++++++++++++++-------
3 files changed, 85 insertions(+), 33 deletions(-)
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index 46ecad78..a1e0f137 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -1,26 +1,47 @@
import Content from './Content.js'
import Title from './Title.js'
-export default function Editor({ $target, initialState, onDelete }) {
- const $editor = document.createElement('main')
+export default function Editor({ $target, onEdit }) {
+ const $editor = document.createElement('div')
$target.appendChild($editor)
- this.state = initialState
+ this.state = {}
this.setState = (nextState) => {
this.state = nextState
this.render()
}
+ let keyupListener = null
+
this.render = () => {
$editor.innerHTML = ''
const $title = new Title({ initialState: this.state })
- const $content = new Content({ initialState: this.state, onDelete })
+ const $content = new Content({ initialState: this.state })
$editor.appendChild($title)
$editor.appendChild($content)
- }
- this.render()
+ if (keyupListener) {
+ // 이전에 등록한 keyup 이벤트 리스너가 있을 경우 제거
+ $editor.removeEventListener('keyup', keyupListener)
+ }
+
+ keyupListener = ({ target }) => {
+ const name = target.closest('div').className
+
+ console.log(name)
+
+ const nextState = {
+ ...this.state,
+ [name]: target.value,
+ }
+ onEdit(nextState)
+
+ this.state = nextState // 낙관적 업데이트
+ }
+
+ $editor.addEventListener('keyup', keyupListener)
+ }
}
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index a1dd8fa5..29d1580f 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -5,7 +5,7 @@ export default function DocumentsList({
onClick,
onAdd,
onToggle,
- onDelete
+ onDelete,
}) {
const $documents = document.createElement('div')
@@ -16,17 +16,17 @@ export default function DocumentsList({
this.render()
}
- const toggleStateKey = (id) => `toggleState_${id}`
+ const TOGGLE_STATE_SAVE_KEY = 'toggle-state'
const renderDocument = (document) => {
const { id, title, documents } = document
- const toggleState = getItem(toggleStateKey(id), false)
- const isHiddenClass = toggleState ? '' : 'hidden'
+ const toggleState = getItem(TOGGLE_STATE_SAVE_KEY)
+ const isHiddenClass = toggleState?.[id] ? '' : 'hidden'
let html = `
-
- [${id}] ${title}
+ [${id}] ${title.length ? title : '제목 없음'}
`
@@ -52,8 +52,7 @@ export default function DocumentsList({
this.render = () => {
$documents.innerHTML = `
- ${this.state.map((document) =>
- `${renderDocument(document)}`).join('')}
+ ${this.state.map((document) => `${renderDocument(document)}`).join('')}
`
@@ -89,4 +88,4 @@ export default function DocumentsList({
this.render()
return $documents
-}
\ No newline at end of file
+}
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index 0412e034..7eeed4ce 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -4,13 +4,14 @@ import {
fetchRootDocument,
fetchSpecificDocument,
createNewDocument,
- deleteDocument
+ deleteDocument,
} from '../utils/fetchData'
-import { setItem } from '../utils/storage'
+import { getItem, setItem } from '../utils/storage'
+import { editSpecificDocument } from '../api/api'
export default function MainPage({ $target }) {
- this.$mainPage = document.createElement('div')
- $target.appendChild(this.$mainPage)
+ const $main = document.createElement('div')
+ $target.appendChild($main)
this.documents = []
@@ -19,8 +20,15 @@ export default function MainPage({ $target }) {
sidebar.setState(nextDocuments)
}
+ this.content = []
+
+ this.setContent = (nextDocuments) => {
+ this.content = nextDocuments
+ editor.setState(nextDocuments)
+ }
+
const sidebar = new Sidebar({
- $target: this.$mainPage,
+ $target: $main,
initialState: this.documents,
onClick: (id) => {
navigate(`/documents/${id}`)
@@ -49,22 +57,46 @@ export default function MainPage({ $target }) {
} else {
fetchDocumentsData()
}
- }
+ },
})
- const toggleStateKey = (id) => `toggleState_${id}`
+ const TEMP_POST_SAVE_KEY = 'temp-post'
+ const TOGGLE_STATE_SAVE_KEY = 'toggle-state'
+ let timer = null
const saveToggleState = (id, isOpen) => {
- const key = toggleStateKey(id)
- setItem(key, isOpen)
+ const currState = getItem(TOGGLE_STATE_SAVE_KEY)
+ const nextState = {
+ ...currState,
+ [id]: isOpen,
+ }
+ setItem(TOGGLE_STATE_SAVE_KEY, nextState)
}
const editor = new Editor({
- $target: this.$mainPage,
- onDelete: async (id) => {
- await deleteDocument(id)
- navigate('/')
- }
+ $target: $main,
+ onEdit: async (post) => {
+ if (timer) {
+ clearTimeout(timer)
+ }
+ // 디바운스
+ timer = setTimeout(async () => {
+ const currState = getItem(TEMP_POST_SAVE_KEY)
+ const { id, title, content } = post
+
+ const nextState = {
+ ...currState,
+ [id]: post,
+ }
+ setItem(TEMP_POST_SAVE_KEY, nextState)
+ const res = await editSpecificDocument(id, {
+ title,
+ content,
+ })
+
+ fetchDocumentsData()
+ }, 1000)
+ },
})
const fetchDocumentsData = async () => {
@@ -76,7 +108,7 @@ export default function MainPage({ $target }) {
const id = location.pathname.split('/').at(-1)
const content = id ? await fetchSpecificDocument(id) : null
- editor.setState(content)
+ this.setContent(content)
}
const navigate = (path) => {
@@ -88,17 +120,17 @@ export default function MainPage({ $target }) {
window.history.pushState(null, null, path)
}
- this.route()
+ this.fetchData()
}
- this.route = () => {
+ this.fetchData = () => {
fetchDocumentsData()
fetchContentData()
}
this.init = () => {
- this.route()
+ this.fetchData()
}
this.init()
-}
\ No newline at end of file
+}
From 78de8b0a1b77a423bc576d41aa9203b6274a17f8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 18:29:12 +0900
Subject: [PATCH 037/107] =?UTF-8?q?Chore:=20prettier=20=EC=84=A4=EC=A0=95?=
=?UTF-8?q?=20=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.prettierrc | 18 ++++++++++--------
1 file changed, 10 insertions(+), 8 deletions(-)
diff --git a/.prettierrc b/.prettierrc
index 84d73a2b..17b0ea60 100644
--- a/.prettierrc
+++ b/.prettierrc
@@ -1,9 +1,11 @@
{
- "semi": false,
- "singleQuote": false,
- "tabWidth": 2,
- "trailingComma": "all",
- "printWidth": 120,
- "endOfLine": "auto",
- "formatOnSave": true
-}
\ No newline at end of file
+ "semi": false,
+ "singleQuote": true,
+ "tabWidth": 2,
+ "trailingComma": "all",
+ "printWidth": 80,
+ "arrowParens": "always",
+ "bracketSpacing": true,
+ "bracketSameLine": false,
+ "formatOnSave": true
+}
From ffd60ce92aed1e976a4c71855b748a1a64a13ba4 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 18:31:03 +0900
Subject: [PATCH 038/107] =?UTF-8?q?Style:=20prettier=20=EB=B3=80=EA=B2=BD?=
=?UTF-8?q?=20=ED=8F=AC=EB=A7=B7=20=EC=A0=81=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.prettierrc | 18 +++++-----
src/api/api.js | 32 ++++++++---------
src/components/App.js | 2 +-
src/components/editor/Content.js | 13 ++++---
src/components/editor/Title.js | 48 ++++++++++++-------------
src/components/sidebar/Sidebar.js | 5 +--
src/components/sidebar/SidebarHeader.js | 2 +-
src/pages/NotFoundPage.js | 2 +-
src/utils/fetchData.js | 40 ++++++++++-----------
src/utils/storage.js | 4 +--
10 files changed, 86 insertions(+), 80 deletions(-)
diff --git a/.prettierrc b/.prettierrc
index 17b0ea60..be354a98 100644
--- a/.prettierrc
+++ b/.prettierrc
@@ -1,11 +1,11 @@
{
- "semi": false,
- "singleQuote": true,
- "tabWidth": 2,
- "trailingComma": "all",
- "printWidth": 80,
- "arrowParens": "always",
- "bracketSpacing": true,
- "bracketSameLine": false,
- "formatOnSave": true
+ "semi": false,
+ "singleQuote": true,
+ "tabWidth": 2,
+ "trailingComma": "all",
+ "printWidth": 80,
+ "arrowParens": "always",
+ "bracketSpacing": true,
+ "bracketSameLine": false,
+ "formatOnSave": true
}
diff --git a/src/api/api.js b/src/api/api.js
index 911f4076..0f17b65d 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -1,11 +1,11 @@
import NotFoundPage from '../pages/NotFoundPage'
-const API_END_POINT = "https://kdt-frontend.programmers.co.kr/documents"
+const API_END_POINT = 'https://kdt-frontend.programmers.co.kr/documents'
-const request = async (url = "", options = {}) => {
+const request = async (url = '', options = {}) => {
try {
const res = await fetch(`${API_END_POINT}${url}`, {
- ...options
+ ...options,
})
if (res.ok) {
@@ -13,13 +13,13 @@ const request = async (url = "", options = {}) => {
}
if (res.status === 404) {
- throw new Error("Not Found")
+ throw new Error('Not Found')
}
- throw new Error("API 처리 중 에러가 발생했습니다.")
+ throw new Error('API 처리 중 에러가 발생했습니다.')
} catch (e) {
console.log(e.message)
- if (e.message === "Not Found") {
+ if (e.message === 'Not Found') {
const $target = document.querySelector('#app')
$target.innerHTML = ''
new NotFoundPage({ $target })
@@ -27,16 +27,16 @@ const request = async (url = "", options = {}) => {
}
}
-const fetchData = async (url, method = "GET", data = null) => {
+const fetchData = async (url, method = 'GET', data = null) => {
if (url) url = `/${url}`
const options = {
method,
headers: {
- "Content-Type": "application/json",
- "x-username": "hyoribogo"
+ 'Content-Type': 'application/json',
+ 'x-username': 'hyoribogo',
},
- body: data ? JSON.stringify(data) : null
+ body: data ? JSON.stringify(data) : null,
}
const res = await request(url, options)
@@ -45,7 +45,7 @@ const fetchData = async (url, method = "GET", data = null) => {
// 전체 Document 목록 불러오기 GET
const getRootDocument = async () => {
- const res = await fetchData("")
+ const res = await fetchData('')
return res
}
@@ -57,19 +57,19 @@ const getSpecificDocument = async (id) => {
// Document 생성하기 POST
const createDocument = async (data) => {
- const res = await fetchData("", "POST", data)
+ const res = await fetchData('', 'POST', data)
return res
}
// 특정 Document 수정하기 PUT
const editSpecificDocument = async (id, data) => {
- const res = await fetchData(id, "PUT", data)
+ const res = await fetchData(id, 'PUT', data)
return res
}
// 특정 Document 삭제하기 DELETE
const deleteSpecificDocument = async (id) => {
- const res = await fetchData(id, "DELETE")
+ const res = await fetchData(id, 'DELETE')
return res
}
@@ -78,5 +78,5 @@ export {
getSpecificDocument,
createDocument,
editSpecificDocument,
- deleteSpecificDocument
-}
\ No newline at end of file
+ deleteSpecificDocument,
+}
diff --git a/src/components/App.js b/src/components/App.js
index 12d84f49..e2f8aa69 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -8,4 +8,4 @@ export default function App({ $target }) {
}
this.init()
-}
\ No newline at end of file
+}
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index 58c49127..8ee9c6d8 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -22,9 +22,14 @@ export default function Content({ initialState }) {
$content.innerHTML = `
- ${documents.map((subDocument) =>
- `- ${subDocument.title.length ? subDocument.title : "제목 없음"}
`
- ).join('')}
+ ${documents
+ .map(
+ (subDocument) =>
+ `- ${
+ subDocument.title.length ? subDocument.title : '제목 없음'
+ }
`,
+ )
+ .join('')}
`
}
}
@@ -32,4 +37,4 @@ export default function Content({ initialState }) {
this.render()
return $content
-}
\ No newline at end of file
+}
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index 19aac617..58bb4d15 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -1,38 +1,38 @@
export default function Title({ initialState }) {
- const $title = document.createElement('div')
- $title.classList.add('title')
+ const $title = document.createElement('div')
+ $title.classList.add('title')
- this.state = initialState
+ this.state = initialState
- this.setState = (nextState) => {
- this.state = nextState
- this.render()
- }
+ this.setState = (nextState) => {
+ this.state = nextState
+ this.render()
+ }
- this.render = () => {
- if (!this.state) {
- $title.innerHTML = ''
- return
- }
+ this.render = () => {
+ if (!this.state) {
+ $title.innerHTML = ''
+ return
+ }
- const { title } = this.state
+ const { title } = this.state
- if (title.length) {
- $title.innerHTML = `
+ if (title.length) {
+ $title.innerHTML = `
`
- } else {
- $title.innerHTML = `
+ } else {
+ $title.innerHTML = `
`
- }
+ }
- // $title.addEventListener('keyup', e => {
- // console.log(e.target.value)
- // })
- }
+ // $title.addEventListener('keyup', e => {
+ // console.log(e.target.value)
+ // })
+ }
- this.render()
+ this.render()
- return $title
+ return $title
}
diff --git a/src/components/sidebar/Sidebar.js b/src/components/sidebar/Sidebar.js
index 96717d4c..79309b51 100644
--- a/src/components/sidebar/Sidebar.js
+++ b/src/components/sidebar/Sidebar.js
@@ -7,7 +7,8 @@ export default function Sidebar({
onClick,
onAdd,
onToggle,
- onDelete, }) {
+ onDelete,
+}) {
const $sidebar = document.createElement('div')
$target.appendChild($sidebar)
@@ -27,7 +28,7 @@ export default function Sidebar({
onClick,
onAdd,
onToggle,
- onDelete
+ onDelete,
})
$sidebar.appendChild($header)
diff --git a/src/components/sidebar/SidebarHeader.js b/src/components/sidebar/SidebarHeader.js
index eb1b49b0..6bb247d4 100644
--- a/src/components/sidebar/SidebarHeader.js
+++ b/src/components/sidebar/SidebarHeader.js
@@ -12,4 +12,4 @@ export default function SidebarHeader({ initialState }) {
this.render()
return $header
-}
\ No newline at end of file
+}
diff --git a/src/pages/NotFoundPage.js b/src/pages/NotFoundPage.js
index 6d1fbfb4..75c63e85 100644
--- a/src/pages/NotFoundPage.js
+++ b/src/pages/NotFoundPage.js
@@ -11,4 +11,4 @@ export default function NotFoundPage({ $target }) {
$notFoundPage.addEventListener('click', () => {
// navigate('/')
})
-}
\ No newline at end of file
+}
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
index ed19ad0c..8f0dfa78 100644
--- a/src/utils/fetchData.js
+++ b/src/utils/fetchData.js
@@ -1,38 +1,38 @@
import {
- createDocument,
- deleteSpecificDocument,
- getRootDocument,
- getSpecificDocument,
+ createDocument,
+ deleteSpecificDocument,
+ getRootDocument,
+ getSpecificDocument,
} from '../api/api'
async function fetchRootDocument() {
- const documents = await getRootDocument()
- return documents
+ const documents = await getRootDocument()
+ return documents
}
async function fetchSpecificDocument(id) {
- const content = await getSpecificDocument(id)
- return content
+ const content = await getSpecificDocument(id)
+ return content
}
async function createNewDocument(parentId) {
- const data = {
- title: '',
- parent: parentId || null,
- }
+ const data = {
+ title: '',
+ parent: parentId || null,
+ }
- const newDocument = await createDocument(data)
- return newDocument
+ const newDocument = await createDocument(data)
+ return newDocument
}
async function deleteDocument(id) {
- await deleteSpecificDocument(id)
+ await deleteSpecificDocument(id)
}
export {
- fetchRootDocument,
- fetchSpecificDocument,
- createNewDocument,
- createDocument,
- deleteDocument,
+ fetchRootDocument,
+ fetchSpecificDocument,
+ createNewDocument,
+ createDocument,
+ deleteDocument,
}
diff --git a/src/utils/storage.js b/src/utils/storage.js
index af6bd933..e0684d6f 100644
--- a/src/utils/storage.js
+++ b/src/utils/storage.js
@@ -4,7 +4,7 @@ const getItem = (key, defaultValue) => {
try {
const storedValue = storage.getItem(key)
return storedValue ? JSON.parse(storedValue) : defaultValue
- } catch(e) {
+ } catch (e) {
return defaultValue
}
}
@@ -13,4 +13,4 @@ const setItem = (key, value) => {
storage.setItem(key, JSON.stringify(value))
}
-export { getItem, setItem }
\ No newline at end of file
+export { getItem, setItem }
From 08350c9f3bdde3f0bb4ae18a594c1b5631eab002 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Tue, 4 Jul 2023 19:17:04 +0900
Subject: [PATCH 039/107] =?UTF-8?q?Feat:=20Content=EC=9D=98=20=ED=95=98?=
=?UTF-8?q?=EC=9C=84=20=EB=AC=B8=EC=84=9C=20=ED=81=B4=EB=A6=AD=20=EC=8B=9C?=
=?UTF-8?q?=20=EC=9D=B4=EB=8F=99=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/editor/Content.js | 11 +++++++++--
src/components/editor/Editor.js | 4 ++--
src/components/editor/Title.js | 4 ----
src/pages/MainPage.js | 3 +++
4 files changed, 14 insertions(+), 8 deletions(-)
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index 8ee9c6d8..4f1bc5bb 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,4 +1,4 @@
-export default function Content({ initialState }) {
+export default function Content({ initialState, onClick, onToggle }) {
const $content = document.createElement('div')
$content.classList.add('content')
@@ -25,13 +25,20 @@ export default function Content({ initialState }) {
${documents
.map(
(subDocument) =>
- ` - ${
+ `
- ${
subDocument.title.length ? subDocument.title : '제목 없음'
}
`,
)
.join('')}
`
}
+
+ $content.addEventListener('click', ({ target }) => {
+ const subId = target.closest('li').dataset.id
+ onClick(subId)
+
+ // 현재 id 토글하기
+ })
}
this.render()
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index a1e0f137..6bc3f36f 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -1,7 +1,7 @@
import Content from './Content.js'
import Title from './Title.js'
-export default function Editor({ $target, onEdit }) {
+export default function Editor({ $target, onEdit, onClick }) {
const $editor = document.createElement('div')
$target.appendChild($editor)
@@ -18,7 +18,7 @@ export default function Editor({ $target, onEdit }) {
$editor.innerHTML = ''
const $title = new Title({ initialState: this.state })
- const $content = new Content({ initialState: this.state })
+ const $content = new Content({ initialState: this.state, onClick })
$editor.appendChild($title)
$editor.appendChild($content)
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index 58bb4d15..a39fd509 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -26,10 +26,6 @@ export default function Title({ initialState }) {
`
}
-
- // $title.addEventListener('keyup', e => {
- // console.log(e.target.value)
- // })
}
this.render()
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index 7eeed4ce..cef1d705 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -97,6 +97,9 @@ export default function MainPage({ $target }) {
fetchDocumentsData()
}, 1000)
},
+ onClick: (id) => {
+ navigate(`/documents/${id}`)
+ },
})
const fetchDocumentsData = async () => {
From 064d7b13d7a11aee86d1b4e74e293050132d4229 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 00:24:05 +0900
Subject: [PATCH 040/107] =?UTF-8?q?Rename:=20import=ED=95=9C=20=EB=9D=BC?=
=?UTF-8?q?=EC=9A=B0=ED=84=B0=20=ED=95=A8=EC=88=98=20=EC=98=A4=ED=83=80=20?=
=?UTF-8?q?=EC=88=98=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/components/App.js b/src/components/App.js
index e2f8aa69..cde176af 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,4 +1,4 @@
-import Router from '../routes/router'
+import Router from '../routes/Router'
export default function App({ $target }) {
const router = new Router({ $target })
From ad1f5d4848c220ddb7dd9e5639d03aabd62b6bf1 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 00:33:20 +0900
Subject: [PATCH 041/107] =?UTF-8?q?Rename:=20router=20=ED=95=A8=EC=88=98?=
=?UTF-8?q?=20=EC=9D=B4=EB=A6=84=20=EC=9E=AC=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 2 +-
src/routes/Router.js | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index cde176af..e2f8aa69 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,4 +1,4 @@
-import Router from '../routes/Router'
+import Router from '../routes/router'
export default function App({ $target }) {
const router = new Router({ $target })
diff --git a/src/routes/Router.js b/src/routes/Router.js
index f8700d14..802a4a1b 100644
--- a/src/routes/Router.js
+++ b/src/routes/Router.js
@@ -1,7 +1,7 @@
import MainPage from '../pages/MainPage'
import NotFoundPage from '../pages/NotFoundPage'
-export default function Router({ $target }) {
+export default function router({ $target }) {
this.init = () => {
this.route()
From 05001449cfe47930bf37dc2f14abaffb54771678 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 00:44:29 +0900
Subject: [PATCH 042/107] =?UTF-8?q?Chore:=20vercel=20spa=20=EB=9D=BC?=
=?UTF-8?q?=EC=9A=B0=ED=8A=B8=20=ED=99=98=EA=B2=BD=20=EC=84=A4=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
vercel.json | 3 +++
1 file changed, 3 insertions(+)
create mode 100644 vercel.json
diff --git a/vercel.json b/vercel.json
new file mode 100644
index 00000000..f15c54db
--- /dev/null
+++ b/vercel.json
@@ -0,0 +1,3 @@
+{
+ "routes": [{ "src": "/(.*)", "dest": "/index.html" }]
+}
From e66401817b7b42f315078a0403f7857cbaf337d5 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 00:47:34 +0900
Subject: [PATCH 043/107] =?UTF-8?q?Rename:=20router=20=ED=95=A8=EC=88=98?=
=?UTF-8?q?=20=EC=9D=B4=EB=A6=84=20=EC=9E=AC=EC=9E=AC=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/routes/Router.js | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/routes/Router.js b/src/routes/Router.js
index 802a4a1b..f8700d14 100644
--- a/src/routes/Router.js
+++ b/src/routes/Router.js
@@ -1,7 +1,7 @@
import MainPage from '../pages/MainPage'
import NotFoundPage from '../pages/NotFoundPage'
-export default function router({ $target }) {
+export default function Router({ $target }) {
this.init = () => {
this.route()
From f6af9954606715b5a8247d2bef6275fc127b3b4b Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 00:53:09 +0900
Subject: [PATCH 044/107] =?UTF-8?q?Chore:=20=EB=B0=B0=ED=8F=AC=20=EC=97=90?=
=?UTF-8?q?=EB=9F=AC=20=EB=9C=A8=EB=8A=94=20=ED=8C=8C=EC=9D=BC=EB=AA=85=20?=
=?UTF-8?q?=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 4 ++--
src/routes/{Router.js => PageRouter.js} | 2 +-
2 files changed, 3 insertions(+), 3 deletions(-)
rename src/routes/{Router.js => PageRouter.js} (90%)
diff --git a/src/components/App.js b/src/components/App.js
index e2f8aa69..dd0b7c5f 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,7 +1,7 @@
-import Router from '../routes/router'
+import PageRouter from '../routes/PageRouter'
export default function App({ $target }) {
- const router = new Router({ $target })
+ const router = new PageRouter({ $target })
this.init = () => {
router.init()
diff --git a/src/routes/Router.js b/src/routes/PageRouter.js
similarity index 90%
rename from src/routes/Router.js
rename to src/routes/PageRouter.js
index f8700d14..a78715db 100644
--- a/src/routes/Router.js
+++ b/src/routes/PageRouter.js
@@ -1,7 +1,7 @@
import MainPage from '../pages/MainPage'
import NotFoundPage from '../pages/NotFoundPage'
-export default function Router({ $target }) {
+export default function PageRouter({ $target }) {
this.init = () => {
this.route()
From 70912af1e9a04b92e5d6370292c701df31de0abe Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 01:07:56 +0900
Subject: [PATCH 045/107] =?UTF-8?q?Refactor:=20=ED=95=98=EC=9C=84=20?=
=?UTF-8?q?=EB=AC=B8=EC=84=9C=20=ED=81=B4=EB=A6=AD=ED=96=88=EC=9D=84=20?=
=?UTF-8?q?=EB=95=8C=EB=A7=8C=20=EC=9D=B4=EB=B2=A4=ED=8A=B8=20=EB=8F=99?=
=?UTF-8?q?=EC=9E=91=ED=95=98=EB=8F=84=EB=A1=9D=20=EB=B3=80=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
index.html | 6 +++---
src/components/editor/Content.js | 7 +++++--
src/components/editor/Editor.js | 2 --
3 files changed, 8 insertions(+), 7 deletions(-)
diff --git a/index.html b/index.html
index 8b0e1ada..46de59af 100644
--- a/index.html
+++ b/index.html
@@ -1,11 +1,11 @@
-
+
효리의 노션 클로닝 사이트
-
+
-
\ No newline at end of file
+
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index 4f1bc5bb..328e3c34 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -34,8 +34,11 @@ export default function Content({ initialState, onClick, onToggle }) {
}
$content.addEventListener('click', ({ target }) => {
- const subId = target.closest('li').dataset.id
- onClick(subId)
+ const $subDocument = target.closest('li')
+ if ($subDocument) {
+ const subId = $subDocument.dataset.id
+ onClick(subId)
+ }
// 현재 id 토글하기
})
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index 6bc3f36f..c3fc5a98 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -31,8 +31,6 @@ export default function Editor({ $target, onEdit, onClick }) {
keyupListener = ({ target }) => {
const name = target.closest('div').className
- console.log(name)
-
const nextState = {
...this.state,
[name]: target.value,
From a795f92e22dbe6ef76e44defe17548fad297d483 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 01:19:46 +0900
Subject: [PATCH 046/107] =?UTF-8?q?Chore:=20=EB=B0=B0=ED=8F=AC=20=EC=82=AC?=
=?UTF-8?q?=EC=9D=B4=ED=8A=B8=20=EB=A0=8C=EB=8D=94=EB=A7=81=20=EC=8B=9C=20?=
=?UTF-8?q?html=20=EC=97=90=EB=9F=AC=20=EC=88=98=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
vercel.json | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/vercel.json b/vercel.json
index f15c54db..0f32683a 100644
--- a/vercel.json
+++ b/vercel.json
@@ -1,3 +1,3 @@
{
- "routes": [{ "src": "/(.*)", "dest": "/index.html" }]
+ "rewrites": [{ "source": "/(.*)", "destination": "/index.html" }]
}
From d02c3bc6b7417ae88eeaf332df9cec4f527162eb Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 03:14:21 +0900
Subject: [PATCH 047/107] =?UTF-8?q?Chore:=20=ED=99=98=EA=B2=BD=20=EB=B3=80?=
=?UTF-8?q?=EC=88=98=20=EC=84=A4=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.gitignore | 3 ++-
src/api/api.js | 25 ++++++++-----------------
src/components/sidebar/DocumentsList.js | 5 ++---
src/pages/MainPage.js | 11 +++++------
src/utils/constants.js | 6 ++++++
5 files changed, 23 insertions(+), 27 deletions(-)
diff --git a/.gitignore b/.gitignore
index 76add878..a0d218e3 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,2 +1,3 @@
node_modules
-dist
\ No newline at end of file
+dist
+.env
\ No newline at end of file
diff --git a/src/api/api.js b/src/api/api.js
index 0f17b65d..7f4b6823 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -1,10 +1,9 @@
import NotFoundPage from '../pages/NotFoundPage'
-
-const API_END_POINT = 'https://kdt-frontend.programmers.co.kr/documents'
+import { ENV } from '../utils/constants'
const request = async (url = '', options = {}) => {
try {
- const res = await fetch(`${API_END_POINT}${url}`, {
+ const res = await fetch(`${ENV.API_END_POINT}${url}`, {
...options,
})
@@ -34,7 +33,7 @@ const fetchData = async (url, method = 'GET', data = null) => {
method,
headers: {
'Content-Type': 'application/json',
- 'x-username': 'hyoribogo',
+ 'x-username': ENV.USER_NAME,
},
body: data ? JSON.stringify(data) : null,
}
@@ -44,39 +43,31 @@ const fetchData = async (url, method = 'GET', data = null) => {
}
// 전체 Document 목록 불러오기 GET
-const getRootDocument = async () => {
+export const getRootDocument = async () => {
const res = await fetchData('')
return res
}
// 특정 Document 불러오기 GET
-const getSpecificDocument = async (id) => {
+export const getSpecificDocument = async (id) => {
const res = await fetchData(id)
return res
}
// Document 생성하기 POST
-const createDocument = async (data) => {
+export const createDocument = async (data) => {
const res = await fetchData('', 'POST', data)
return res
}
// 특정 Document 수정하기 PUT
-const editSpecificDocument = async (id, data) => {
+export const editSpecificDocument = async (id, data) => {
const res = await fetchData(id, 'PUT', data)
return res
}
// 특정 Document 삭제하기 DELETE
-const deleteSpecificDocument = async (id) => {
+export const deleteSpecificDocument = async (id) => {
const res = await fetchData(id, 'DELETE')
return res
}
-
-export {
- getRootDocument,
- getSpecificDocument,
- createDocument,
- editSpecificDocument,
- deleteSpecificDocument,
-}
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index 29d1580f..7057f95a 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -1,3 +1,4 @@
+import { ENV } from '../../utils/constants'
import { getItem } from '../../utils/storage'
export default function DocumentsList({
@@ -16,11 +17,9 @@ export default function DocumentsList({
this.render()
}
- const TOGGLE_STATE_SAVE_KEY = 'toggle-state'
-
const renderDocument = (document) => {
const { id, title, documents } = document
- const toggleState = getItem(TOGGLE_STATE_SAVE_KEY)
+ const toggleState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
const isHiddenClass = toggleState?.[id] ? '' : 'hidden'
let html = `
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index cef1d705..a9a3c664 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -8,6 +8,7 @@ import {
} from '../utils/fetchData'
import { getItem, setItem } from '../utils/storage'
import { editSpecificDocument } from '../api/api'
+import { ENV } from '../utils/constants'
export default function MainPage({ $target }) {
const $main = document.createElement('div')
@@ -60,17 +61,15 @@ export default function MainPage({ $target }) {
},
})
- const TEMP_POST_SAVE_KEY = 'temp-post'
- const TOGGLE_STATE_SAVE_KEY = 'toggle-state'
let timer = null
const saveToggleState = (id, isOpen) => {
- const currState = getItem(TOGGLE_STATE_SAVE_KEY)
+ const currState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
const nextState = {
...currState,
[id]: isOpen,
}
- setItem(TOGGLE_STATE_SAVE_KEY, nextState)
+ setItem(ENV.TOGGLE_STATE_SAVE_KEY, nextState)
}
const editor = new Editor({
@@ -81,14 +80,14 @@ export default function MainPage({ $target }) {
}
// 디바운스
timer = setTimeout(async () => {
- const currState = getItem(TEMP_POST_SAVE_KEY)
+ const currState = getItem(ENV.TEMP_POST_SAVE_KEY)
const { id, title, content } = post
const nextState = {
...currState,
[id]: post,
}
- setItem(TEMP_POST_SAVE_KEY, nextState)
+ setItem(ENV.TEMP_POST_SAVE_KEY, nextState)
const res = await editSpecificDocument(id, {
title,
content,
diff --git a/src/utils/constants.js b/src/utils/constants.js
index e69de29b..80e3bb86 100644
--- a/src/utils/constants.js
+++ b/src/utils/constants.js
@@ -0,0 +1,6 @@
+export const ENV = {
+ API_END_POINT: import.meta.env.VITE_API_END_POINT,
+ USER_NAME: import.meta.env.VITE_X_USER_NAME,
+ TEMP_POST_SAVE_KEY: import.meta.env.TEMP_POST_SAVE_KEY,
+ TOGGLE_STATE_SAVE_KEY: import.meta.env.TOGGLE_STATE_SAVE_KEY,
+}
From d80e8b1f189ef28ba0c0b0e6aeafd081ccd4dc93 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 18:55:06 +0900
Subject: [PATCH 048/107] =?UTF-8?q?Refactor:=20=EB=B6=88=ED=95=84=EC=9A=94?=
=?UTF-8?q?=ED=95=9C=20api=20=EC=9A=94=EC=B2=AD=20=EB=B0=A9=EC=A7=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 37 +++++++++++++++++++--
src/index.js | 8 +----
src/pages/MainPage.js | 69 +++++++++++-----------------------------
src/routes/PageRouter.js | 6 ++--
src/routes/URLRouter.js | 9 ++++++
src/utils/constants.js | 6 ++++
src/utils/fetchData.js | 33 ++++++++++---------
7 files changed, 88 insertions(+), 80 deletions(-)
create mode 100644 src/routes/URLRouter.js
diff --git a/src/components/App.js b/src/components/App.js
index dd0b7c5f..c35058a8 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,11 +1,44 @@
import PageRouter from '../routes/PageRouter'
+import { DATA } from '../utils/constants'
+import { fetchContent, fetchDocuments } from '../utils/fetchData'
export default function App({ $target }) {
const router = new PageRouter({ $target })
+ let PageComponent, main, notFound
- this.init = () => {
- router.init()
+ this.init = async () => {
+ PageComponent = router.init()
+ this.render()
+ updateState(DATA.DOCUMENT)
+ }
+
+ this.render = () => {
+ switch (PageComponent.name) {
+ case 'MainPage':
+ main = new PageComponent({ $target, updateState })
+ break
+ case 'NotFoundPage':
+ notFound = new PageComponent({ $target, updateState })
+ }
}
this.init()
+
+ async function updateState(targetState, id) {
+ switch (targetState) {
+ case DATA.DOCUMENT:
+ // 문서 데이터 받기
+ main.setDocuments(await fetchDocuments())
+ break
+ case DATA.CONTENT:
+ // 콘텐츠 데이터 받기
+ main.setContent(await fetchContent(id))
+ break
+ case DATA.ALL:
+ // 전부 받기
+ main.setDocuments(await fetchDocuments())
+ main.setContent(await fetchContent(id))
+ break
+ }
+ }
}
diff --git a/src/index.js b/src/index.js
index 1bf91b92..cfff2b5d 100644
--- a/src/index.js
+++ b/src/index.js
@@ -2,10 +2,4 @@ import App from './components/App'
const $target = document.querySelector('#app')
-new App({
- $target,
- initialState: {
- documents: [],
- editorContent: {}
- }
-})
\ No newline at end of file
+new App({ $target })
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index a9a3c664..edee53e8 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -1,16 +1,15 @@
import Sidebar from '../components/sidebar/Sidebar'
import Editor from '../components/editor/Editor'
import {
- fetchRootDocument,
- fetchSpecificDocument,
createNewDocument,
deleteDocument,
+ editDocument,
} from '../utils/fetchData'
import { getItem, setItem } from '../utils/storage'
-import { editSpecificDocument } from '../api/api'
-import { ENV } from '../utils/constants'
+import { DATA, ENV } from '../utils/constants'
+import { navigate } from '../routes/URLRouter'
-export default function MainPage({ $target }) {
+export default function MainPage({ $target, updateState }) {
const $main = document.createElement('div')
$target.appendChild($main)
@@ -33,30 +32,34 @@ export default function MainPage({ $target }) {
initialState: this.documents,
onClick: (id) => {
navigate(`/documents/${id}`)
+ updateState(DATA.CONTENT, id)
},
onAdd: async (id) => {
const newDocument = await createNewDocument(id)
navigate(`/documents/${newDocument.id}`)
- return newDocument.id
+ updateState(DATA.ALL, newDocument.id)
},
onToggle: async (target, id, event = '') => {
const $toggle = target.closest('.toggle')
const $nestedList = $toggle.closest('li').querySelector('.nested')
- if (event !== 'add' || $nestedList.classList.contains('hidden'))
+
+ if (event !== 'add' || $nestedList.classList.contains('hidden')) {
$nestedList.classList.toggle('hidden')
+ }
const isOpen = !$nestedList.classList.contains('hidden')
saveToggleState(id, isOpen)
- fetchDocumentsData()
+ this.setDocuments(this.documents)
},
onDelete: async (id) => {
const pathId = location.pathname.split('/').at(-1)
-
await deleteDocument(id)
+
if (pathId === id) {
navigate('/')
+ updateState(DATA.DOCUMENT)
} else {
- fetchDocumentsData()
+ updateState(DATA.DOCUMENT)
}
},
})
@@ -88,51 +91,15 @@ export default function MainPage({ $target }) {
[id]: post,
}
setItem(ENV.TEMP_POST_SAVE_KEY, nextState)
- const res = await editSpecificDocument(id, {
- title,
- content,
- })
-
- fetchDocumentsData()
+ await editDocument(id, title, content)
+ // 내용만 변경 시에는 content만 변하게 구현하기
+ // 토글 열리는 버그 수정하기
+ updateState(DATA.ALL, id)
}, 1000)
},
onClick: (id) => {
navigate(`/documents/${id}`)
+ updateState(DATA.CONTENT, id)
},
})
-
- const fetchDocumentsData = async () => {
- const documents = await fetchRootDocument()
- this.setDocuments(documents)
- }
-
- const fetchContentData = async () => {
- const id = location.pathname.split('/').at(-1)
- const content = id ? await fetchSpecificDocument(id) : null
-
- this.setContent(content)
- }
-
- const navigate = (path) => {
- const { pathname } = location
-
- if (pathname === path) {
- window.history.replaceState(null, null, path)
- } else {
- window.history.pushState(null, null, path)
- }
-
- this.fetchData()
- }
-
- this.fetchData = () => {
- fetchDocumentsData()
- fetchContentData()
- }
-
- this.init = () => {
- this.fetchData()
- }
-
- this.init()
}
diff --git a/src/routes/PageRouter.js b/src/routes/PageRouter.js
index a78715db..fc145875 100644
--- a/src/routes/PageRouter.js
+++ b/src/routes/PageRouter.js
@@ -3,11 +3,11 @@ import NotFoundPage from '../pages/NotFoundPage'
export default function PageRouter({ $target }) {
this.init = () => {
- this.route()
-
window.addEventListener('popstate', () => {
this.route()
})
+
+ return this.route()
}
this.route = () => {
@@ -19,6 +19,6 @@ export default function PageRouter({ $target }) {
}
$target.innerHTML = ''
- new PageComponent({ $target })
+ return PageComponent
}
}
diff --git a/src/routes/URLRouter.js b/src/routes/URLRouter.js
new file mode 100644
index 00000000..009e454b
--- /dev/null
+++ b/src/routes/URLRouter.js
@@ -0,0 +1,9 @@
+export function navigate(path) {
+ const { pathname } = location
+
+ if (pathname === path) {
+ window.history.replaceState(null, null, path)
+ } else {
+ window.history.pushState(null, null, path)
+ }
+}
diff --git a/src/utils/constants.js b/src/utils/constants.js
index 80e3bb86..c376f7ac 100644
--- a/src/utils/constants.js
+++ b/src/utils/constants.js
@@ -4,3 +4,9 @@ export const ENV = {
TEMP_POST_SAVE_KEY: import.meta.env.TEMP_POST_SAVE_KEY,
TOGGLE_STATE_SAVE_KEY: import.meta.env.TOGGLE_STATE_SAVE_KEY,
}
+
+export const DATA = {
+ DOCUMENT: 'documents',
+ CONTENT: 'content',
+ ALL: 'all',
+}
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
index 8f0dfa78..79570fd9 100644
--- a/src/utils/fetchData.js
+++ b/src/utils/fetchData.js
@@ -1,38 +1,37 @@
import {
createDocument,
deleteSpecificDocument,
+ editSpecificDocument,
getRootDocument,
getSpecificDocument,
} from '../api/api'
-async function fetchRootDocument() {
- const documents = await getRootDocument()
- return documents
+export async function fetchDocuments() {
+ return await getRootDocument()
}
-async function fetchSpecificDocument(id) {
- const content = await getSpecificDocument(id)
- return content
+export async function fetchContent(id) {
+ return await getSpecificDocument(id)
}
-async function createNewDocument(parentId) {
+export async function createNewDocument(parentId) {
const data = {
title: '',
parent: parentId || null,
}
- const newDocument = await createDocument(data)
- return newDocument
+ return await createDocument(data)
}
-async function deleteDocument(id) {
- await deleteSpecificDocument(id)
+export async function editDocument(id, title, content) {
+ const data = {
+ title,
+ content,
+ }
+
+ return await editSpecificDocument(id, data)
}
-export {
- fetchRootDocument,
- fetchSpecificDocument,
- createNewDocument,
- createDocument,
- deleteDocument,
+export async function deleteDocument(id) {
+ return await deleteSpecificDocument(id)
}
From 2a435d729912cc772940eee88fdaedd8a8bb3dbe Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 21:52:37 +0900
Subject: [PATCH 049/107] =?UTF-8?q?Refactor:=20=EB=B0=B0=ED=8F=AC=20?=
=?UTF-8?q?=EC=8B=9C=20=EC=98=A4=EB=B8=8C=EC=A0=9D=ED=8A=B8=20name=20?=
=?UTF-8?q?=EC=97=90=EB=9F=AC=20=EC=88=98=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 50 ++++++++++++++++------------------------
src/routes/PageRouter.js | 2 +-
src/utils/fetchData.js | 19 +++++++++++++++
3 files changed, 40 insertions(+), 31 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index c35058a8..82ccb433 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,44 +1,34 @@
-import PageRouter from '../routes/PageRouter'
+import MainPage from '../pages/MainPage'
+import NotFoundPage from '../pages/NotFoundPage'
import { DATA } from '../utils/constants'
-import { fetchContent, fetchDocuments } from '../utils/fetchData'
+import { fetchMainData } from '../utils/fetchData'
export default function App({ $target }) {
- const router = new PageRouter({ $target })
- let PageComponent, main, notFound
+ let main, notFound
- this.init = async () => {
- PageComponent = router.init()
- this.render()
+ this.init = () => {
+ window.addEventListener('popstate', () => {
+ this.route()
+ })
+
+ this.route()
updateState(DATA.DOCUMENT)
}
- this.render = () => {
- switch (PageComponent.name) {
- case 'MainPage':
- main = new PageComponent({ $target, updateState })
- break
- case 'NotFoundPage':
- notFound = new PageComponent({ $target, updateState })
+ this.route = () => {
+ const { pathname } = location
+ $target.innerHTML = ''
+
+ if (pathname === '/' || pathname.indexOf('/documents/') === 0) {
+ main = new MainPage({ $target, updateState })
+ } else {
+ notFound = new NotFoundPage({ $target, updateState })
}
}
this.init()
- async function updateState(targetState, id) {
- switch (targetState) {
- case DATA.DOCUMENT:
- // 문서 데이터 받기
- main.setDocuments(await fetchDocuments())
- break
- case DATA.CONTENT:
- // 콘텐츠 데이터 받기
- main.setContent(await fetchContent(id))
- break
- case DATA.ALL:
- // 전부 받기
- main.setDocuments(await fetchDocuments())
- main.setContent(await fetchContent(id))
- break
- }
+ function updateState(targetState, id) {
+ fetchMainData(main, targetState, id)
}
}
diff --git a/src/routes/PageRouter.js b/src/routes/PageRouter.js
index fc145875..e4ef4ad1 100644
--- a/src/routes/PageRouter.js
+++ b/src/routes/PageRouter.js
@@ -19,6 +19,6 @@ export default function PageRouter({ $target }) {
}
$target.innerHTML = ''
- return PageComponent
+ return [PageComponent, PageComponent.name]
}
}
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
index 79570fd9..6b54aeae 100644
--- a/src/utils/fetchData.js
+++ b/src/utils/fetchData.js
@@ -5,6 +5,7 @@ import {
getRootDocument,
getSpecificDocument,
} from '../api/api'
+import { DATA } from './constants'
export async function fetchDocuments() {
return await getRootDocument()
@@ -35,3 +36,21 @@ export async function editDocument(id, title, content) {
export async function deleteDocument(id) {
return await deleteSpecificDocument(id)
}
+
+export async function fetchMainData(page, targetState, id) {
+ switch (targetState) {
+ case DATA.DOCUMENT:
+ // documents 데이터 받기
+ page.setDocuments(await fetchDocuments())
+ break
+ case DATA.CONTENT:
+ // content 데이터 받기
+ page.setContent(await fetchContent(id))
+ break
+ case DATA.ALL:
+ // 전부 받기
+ page.setDocuments(await fetchDocuments())
+ page.setContent(await fetchContent(id))
+ break
+ }
+}
From 2529fe4ba7d707c79087ce5a68ddd622ef7a5a34 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 23:18:59 +0900
Subject: [PATCH 050/107] =?UTF-8?q?Refactor:=20popstate=20=EC=9D=B4?=
=?UTF-8?q?=EB=B2=A4=ED=8A=B8=20=EB=8F=99=EC=9E=91=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/api.js | 2 ++
src/components/App.js | 14 ++++++++------
src/components/editor/Content.js | 6 ++----
src/components/editor/Editor.js | 4 ++--
src/pages/MainPage.js | 3 ++-
src/routes/PageRouter.js | 2 +-
src/routes/URLRouter.js | 2 ++
src/utils/fetchData.js | 2 ++
8 files changed, 21 insertions(+), 14 deletions(-)
diff --git a/src/api/api.js b/src/api/api.js
index 7f4b6823..924b6c17 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -50,6 +50,8 @@ export const getRootDocument = async () => {
// 특정 Document 불러오기 GET
export const getSpecificDocument = async (id) => {
+ if (!id) return {}
+
const res = await fetchData(id)
return res
}
diff --git a/src/components/App.js b/src/components/App.js
index 82ccb433..1d3cf237 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,26 +1,28 @@
import MainPage from '../pages/MainPage'
import NotFoundPage from '../pages/NotFoundPage'
import { DATA } from '../utils/constants'
+import { eventHandler } from '../utils/domUtils'
import { fetchMainData } from '../utils/fetchData'
export default function App({ $target }) {
let main, notFound
this.init = () => {
- window.addEventListener('popstate', () => {
- this.route()
- })
-
+ eventHandler(window, 'popstate', this.route)
this.route()
- updateState(DATA.DOCUMENT)
}
this.route = () => {
const { pathname } = location
+ const isMain = pathname === '/'
+ const isEditor = pathname.indexOf('/documents/') === 0
+ const id = isEditor && pathname.split('/')[2]
$target.innerHTML = ''
- if (pathname === '/' || pathname.indexOf('/documents/') === 0) {
+ if (isMain || isEditor) {
main = new MainPage({ $target, updateState })
+ isMain && updateState(DATA.DOCUMENT)
+ isEditor && updateState(DATA.ALL, id)
} else {
notFound = new NotFoundPage({ $target, updateState })
}
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index 328e3c34..974fecb9 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,9 +1,9 @@
-export default function Content({ initialState, onClick, onToggle }) {
+export default function Content({ initialState, onClick }) {
const $content = document.createElement('div')
$content.classList.add('content')
this.state = initialState
- this.input = this.state?.content
+ this.input = this.state.content
this.setState = (nextState) => {
this.state = nextState
@@ -39,8 +39,6 @@ export default function Content({ initialState, onClick, onToggle }) {
const subId = $subDocument.dataset.id
onClick(subId)
}
-
- // 현재 id 토글하기
})
}
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index c3fc5a98..0432abc6 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -1,11 +1,11 @@
import Content from './Content.js'
import Title from './Title.js'
-export default function Editor({ $target, onEdit, onClick }) {
+export default function Editor({ $target, initialState, onEdit, onClick }) {
const $editor = document.createElement('div')
$target.appendChild($editor)
- this.state = {}
+ this.state = initialState
this.setState = (nextState) => {
this.state = nextState
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index edee53e8..291f1efa 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -20,7 +20,7 @@ export default function MainPage({ $target, updateState }) {
sidebar.setState(nextDocuments)
}
- this.content = []
+ this.content = {}
this.setContent = (nextDocuments) => {
this.content = nextDocuments
@@ -77,6 +77,7 @@ export default function MainPage({ $target, updateState }) {
const editor = new Editor({
$target: $main,
+ initialState: this.content,
onEdit: async (post) => {
if (timer) {
clearTimeout(timer)
diff --git a/src/routes/PageRouter.js b/src/routes/PageRouter.js
index e4ef4ad1..fc145875 100644
--- a/src/routes/PageRouter.js
+++ b/src/routes/PageRouter.js
@@ -19,6 +19,6 @@ export default function PageRouter({ $target }) {
}
$target.innerHTML = ''
- return [PageComponent, PageComponent.name]
+ return PageComponent
}
}
diff --git a/src/routes/URLRouter.js b/src/routes/URLRouter.js
index 009e454b..68eb8960 100644
--- a/src/routes/URLRouter.js
+++ b/src/routes/URLRouter.js
@@ -1,3 +1,5 @@
+import { DATA } from '../utils/constants'
+
export function navigate(path) {
const { pathname } = location
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
index 6b54aeae..b0382f3e 100644
--- a/src/utils/fetchData.js
+++ b/src/utils/fetchData.js
@@ -42,6 +42,7 @@ export async function fetchMainData(page, targetState, id) {
case DATA.DOCUMENT:
// documents 데이터 받기
page.setDocuments(await fetchDocuments())
+ page.setContent({})
break
case DATA.CONTENT:
// content 데이터 받기
@@ -52,5 +53,6 @@ export async function fetchMainData(page, targetState, id) {
page.setDocuments(await fetchDocuments())
page.setContent(await fetchContent(id))
break
+ default:
}
}
From 940f035161de55daccde1886a9579a8129d1928c Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 23:19:19 +0900
Subject: [PATCH 051/107] =?UTF-8?q?Refactor:=20dom=20=EA=B4=80=EB=A0=A8=20?=
=?UTF-8?q?util=20=ED=95=A8=EC=88=98=20=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/utils/domUtils.js | 15 +++++++++++++++
1 file changed, 15 insertions(+)
diff --git a/src/utils/domUtils.js b/src/utils/domUtils.js
index e69de29b..97f5c5aa 100644
--- a/src/utils/domUtils.js
+++ b/src/utils/domUtils.js
@@ -0,0 +1,15 @@
+export function createComponent(tagName, options = {}) {
+ const { className, text, attribute, event } = options
+ const element = document.createElement(tagName)
+
+ className && (element.className = className)
+ text && (element.textContent = textContent)
+ attribute && element.setAttribute(attrName, attrValue)
+ event && eventHandler(element, event.type, event.handler)
+
+ return element
+}
+
+export function eventHandler(element, eventType, handler) {
+ element.addEventListener(eventType, handler)
+}
From 931ea845c3f5f31ec8d7f46bbf84b5bcfa0fd7c8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Wed, 5 Jul 2023 23:29:33 +0900
Subject: [PATCH 052/107] =?UTF-8?q?Refactor:=20Content=20=EC=BB=B4?=
=?UTF-8?q?=ED=8F=AC=EB=84=8C=ED=8A=B8=20=EB=B9=84=ED=99=9C=EC=84=B1?=
=?UTF-8?q?=ED=99=94=20=EC=8B=9C=20null=20=EC=A0=84=EB=8B=AC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/api/api.js | 2 +-
src/components/editor/Content.js | 1 -
src/pages/MainPage.js | 2 +-
src/utils/fetchData.js | 2 +-
4 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/src/api/api.js b/src/api/api.js
index 924b6c17..cfde2a76 100644
--- a/src/api/api.js
+++ b/src/api/api.js
@@ -50,7 +50,7 @@ export const getRootDocument = async () => {
// 특정 Document 불러오기 GET
export const getSpecificDocument = async (id) => {
- if (!id) return {}
+ if (!id) return null
const res = await fetchData(id)
return res
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index 974fecb9..f7678b59 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -3,7 +3,6 @@ export default function Content({ initialState, onClick }) {
$content.classList.add('content')
this.state = initialState
- this.input = this.state.content
this.setState = (nextState) => {
this.state = nextState
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index 291f1efa..735c29fd 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -20,7 +20,7 @@ export default function MainPage({ $target, updateState }) {
sidebar.setState(nextDocuments)
}
- this.content = {}
+ this.content = null
this.setContent = (nextDocuments) => {
this.content = nextDocuments
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
index b0382f3e..4ef0c6c8 100644
--- a/src/utils/fetchData.js
+++ b/src/utils/fetchData.js
@@ -42,7 +42,7 @@ export async function fetchMainData(page, targetState, id) {
case DATA.DOCUMENT:
// documents 데이터 받기
page.setDocuments(await fetchDocuments())
- page.setContent({})
+ page.setContent(null)
break
case DATA.CONTENT:
// content 데이터 받기
From 91cc22dcb6359eb1882eac9bc643f4644541cef3 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 01:41:16 +0900
Subject: [PATCH 053/107] =?UTF-8?q?Refactor:=20=EC=BB=B4=ED=8F=AC=EB=84=8C?=
=?UTF-8?q?=ED=8A=B8=20=EC=83=9D=EC=84=B1=20=ED=95=A8=EC=88=98=20=EC=A0=81?=
=?UTF-8?q?=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/editor/Content.js | 5 +++--
src/components/editor/Editor.js | 3 ++-
src/components/editor/Title.js | 5 +++--
src/components/sidebar/DocumentsList.js | 3 ++-
src/components/sidebar/Sidebar.js | 5 +++--
src/components/sidebar/SidebarHeader.js | 7 ++++---
src/utils/domUtils.js | 9 ++-------
7 files changed, 19 insertions(+), 18 deletions(-)
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index f7678b59..48075ad3 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,6 +1,7 @@
+import { createComponent } from '../../utils/domUtils'
+
export default function Content({ initialState, onClick }) {
- const $content = document.createElement('div')
- $content.classList.add('content')
+ const $content = createComponent('div', 'content')
this.state = initialState
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index 0432abc6..2b24b7dc 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -1,8 +1,9 @@
+import { createComponent } from '../../utils/domUtils.js'
import Content from './Content.js'
import Title from './Title.js'
export default function Editor({ $target, initialState, onEdit, onClick }) {
- const $editor = document.createElement('div')
+ const $editor = createComponent('div', 'editor')
$target.appendChild($editor)
this.state = initialState
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index a39fd509..022e0f82 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -1,6 +1,7 @@
+import { createComponent } from '../../utils/domUtils'
+
export default function Title({ initialState }) {
- const $title = document.createElement('div')
- $title.classList.add('title')
+ const $title = createComponent('div', 'title')
this.state = initialState
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index 7057f95a..d2bd16bc 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -1,4 +1,5 @@
import { ENV } from '../../utils/constants'
+import { createComponent } from '../../utils/domUtils'
import { getItem } from '../../utils/storage'
export default function DocumentsList({
@@ -8,7 +9,7 @@ export default function DocumentsList({
onToggle,
onDelete,
}) {
- const $documents = document.createElement('div')
+ const $documents = createComponent('div', 'documents')
this.state = initialState
diff --git a/src/components/sidebar/Sidebar.js b/src/components/sidebar/Sidebar.js
index 79309b51..84d210b5 100644
--- a/src/components/sidebar/Sidebar.js
+++ b/src/components/sidebar/Sidebar.js
@@ -1,3 +1,4 @@
+import { createComponent } from '../../utils/domUtils'
import DocumentsList from './DocumentsList'
import SidebarHeader from './SidebarHeader'
@@ -9,7 +10,7 @@ export default function Sidebar({
onToggle,
onDelete,
}) {
- const $sidebar = document.createElement('div')
+ const $sidebar = createComponent('div', 'sidebar')
$target.appendChild($sidebar)
this.state = initialState
@@ -22,7 +23,7 @@ export default function Sidebar({
this.render = () => {
$sidebar.innerHTML = ''
- const $header = new SidebarHeader({ initialState: this.state })
+ const $header = new SidebarHeader()
const $documents = new DocumentsList({
initialState: this.state,
onClick,
diff --git a/src/components/sidebar/SidebarHeader.js b/src/components/sidebar/SidebarHeader.js
index 6bb247d4..bd541899 100644
--- a/src/components/sidebar/SidebarHeader.js
+++ b/src/components/sidebar/SidebarHeader.js
@@ -1,6 +1,7 @@
-export default function SidebarHeader({ initialState }) {
- const $header = document.createElement('header')
- $header.classList.add('header')
+import { createComponent } from '../../utils/domUtils'
+
+export default function SidebarHeader() {
+ const $header = createComponent('div', 'header')
this.render = () => {
$header.innerHTML = `
diff --git a/src/utils/domUtils.js b/src/utils/domUtils.js
index 97f5c5aa..b2948f15 100644
--- a/src/utils/domUtils.js
+++ b/src/utils/domUtils.js
@@ -1,11 +1,6 @@
-export function createComponent(tagName, options = {}) {
- const { className, text, attribute, event } = options
+export function createComponent(tagName, className) {
const element = document.createElement(tagName)
-
- className && (element.className = className)
- text && (element.textContent = textContent)
- attribute && element.setAttribute(attrName, attrValue)
- event && eventHandler(element, event.type, event.handler)
+ element.classList.add(className)
return element
}
From b8fef5bd0501b1bd7dab343d095e1ff93e8c63b1 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 02:24:17 +0900
Subject: [PATCH 054/107] =?UTF-8?q?Refactor:=20html=20=ED=85=9C=ED=94=8C?=
=?UTF-8?q?=EB=A6=BF=20=EB=B6=84=EB=A6=AC=20=EB=B0=8F=20=EC=A0=81=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/editor/Content.js | 18 ++--------
src/components/editor/Title.js | 13 ++-----
src/components/sidebar/DocumentsList.js | 42 ++--------------------
src/components/sidebar/SidebarHeader.js | 6 ++--
src/pages/MainPage.js | 3 +-
src/templates/SidebarTemplates.js | 48 +++++++++++++++++++++++++
src/templates/editorTemplates.js | 21 +++++++++++
7 files changed, 79 insertions(+), 72 deletions(-)
create mode 100644 src/templates/SidebarTemplates.js
create mode 100644 src/templates/editorTemplates.js
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index 48075ad3..e1f830ea 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,3 +1,4 @@
+import { contentTemplate } from '../../templates/editorTemplates'
import { createComponent } from '../../utils/domUtils'
export default function Content({ initialState, onClick }) {
@@ -16,22 +17,7 @@ export default function Content({ initialState, onClick }) {
return
}
- const { content, documents } = this.state
-
- if (documents) {
- $content.innerHTML = `
-
-
- ${documents
- .map(
- (subDocument) =>
- `- ${
- subDocument.title.length ? subDocument.title : '제목 없음'
- }
`,
- )
- .join('')}
-
`
- }
+ $content.innerHTML = contentTemplate(this.state)
$content.addEventListener('click', ({ target }) => {
const $subDocument = target.closest('li')
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index 022e0f82..0cc26fe7 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -1,3 +1,4 @@
+import { titleTemplate } from '../../templates/editorTemplates'
import { createComponent } from '../../utils/domUtils'
export default function Title({ initialState }) {
@@ -16,17 +17,7 @@ export default function Title({ initialState }) {
return
}
- const { title } = this.state
-
- if (title.length) {
- $title.innerHTML = `
-
- `
- } else {
- $title.innerHTML = `
-
- `
- }
+ $title.innerHTML = titleTemplate(this.state)
}
this.render()
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index d2bd16bc..8dab3eec 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -1,6 +1,5 @@
-import { ENV } from '../../utils/constants'
+import { documentsListTemplate } from '../../templates/SidebarTemplates'
import { createComponent } from '../../utils/domUtils'
-import { getItem } from '../../utils/storage'
export default function DocumentsList({
initialState,
@@ -18,45 +17,8 @@ export default function DocumentsList({
this.render()
}
- const renderDocument = (document) => {
- const { id, title, documents } = document
- const toggleState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
- const isHiddenClass = toggleState?.[id] ? '' : 'hidden'
-
- let html = `
- -
-
- [${id}] ${title.length ? title : '제목 없음'}
-
-
- `
-
- if (documents.length && toggleState) {
- html += `
`
- documents.forEach((subDocument) => {
- html += `${renderDocument(subDocument)}`
- })
- html += '
'
- } else {
- html += `
- `
- }
-
- html += ' '
-
- return html
- }
-
this.render = () => {
- $documents.innerHTML = `
-
- ${this.state.map((document) => `${renderDocument(document)}`).join('')}
-
-
- `
-
+ $documents.innerHTML = documentsListTemplate(this.state)
const $documentsList = $documents.querySelectorAll('li')
$documentsList.forEach(($document) => {
diff --git a/src/components/sidebar/SidebarHeader.js b/src/components/sidebar/SidebarHeader.js
index bd541899..f048c1b3 100644
--- a/src/components/sidebar/SidebarHeader.js
+++ b/src/components/sidebar/SidebarHeader.js
@@ -1,13 +1,11 @@
+import { sidebarHeaderTemplate } from '../../templates/SidebarTemplates'
import { createComponent } from '../../utils/domUtils'
export default function SidebarHeader() {
const $header = createComponent('div', 'header')
this.render = () => {
- $header.innerHTML = `
-
- 효리보고의 Notion
- `
+ $header.innerHTML = sidebarHeaderTemplate()
}
this.render()
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index 735c29fd..6abfdff4 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -8,9 +8,10 @@ import {
import { getItem, setItem } from '../utils/storage'
import { DATA, ENV } from '../utils/constants'
import { navigate } from '../routes/URLRouter'
+import { createComponent } from '../utils/domUtils'
export default function MainPage({ $target, updateState }) {
- const $main = document.createElement('div')
+ const $main = createComponent('div', 'main')
$target.appendChild($main)
this.documents = []
diff --git a/src/templates/SidebarTemplates.js b/src/templates/SidebarTemplates.js
new file mode 100644
index 00000000..261990be
--- /dev/null
+++ b/src/templates/SidebarTemplates.js
@@ -0,0 +1,48 @@
+import { ENV } from '../utils/constants'
+import { getItem } from '../utils/storage'
+
+function renderDocument({ id, title, documents }) {
+ const toggleState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
+ const isHiddenClass = toggleState?.[id] ? '' : 'hidden'
+
+ let html = `
+ -
+
+ [${id}] ${title.length ? title : '제목 없음'}
+
+
+ `
+
+ if (documents.length && toggleState) {
+ html += `
`
+ documents.forEach((subDocument) => {
+ html += `${renderDocument(subDocument)}`
+ })
+ html += '
'
+ } else {
+ html += `
+ `
+ }
+
+ html += ' '
+
+ return html
+}
+
+export function documentsListTemplate(documents) {
+ return `
+
+ ${documents.map((document) => `${renderDocument(document)}`).join('')}
+
+
+ `
+}
+
+export function sidebarHeaderTemplate() {
+ return `
+
+ 효리보고의 Notion
+ `
+}
diff --git a/src/templates/editorTemplates.js b/src/templates/editorTemplates.js
new file mode 100644
index 00000000..d1fc58f7
--- /dev/null
+++ b/src/templates/editorTemplates.js
@@ -0,0 +1,21 @@
+export function contentTemplate({ content, documents }) {
+ return `
+
+
+ ${documents
+ .map(
+ (subDocument) =>
+ `- ${
+ subDocument.title.length ? subDocument.title : '제목 없음'
+ }
`,
+ )
+ .join('')}
+
+ `
+}
+
+export function titleTemplate({ title }) {
+ return title.length
+ ? ``
+ : ``
+}
From 9e8c60877dbdfe4eb28e2aed6b558ef0ebbcf9fa Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 02:40:02 +0900
Subject: [PATCH 055/107] =?UTF-8?q?Refactor:=20=EB=A9=94=EC=9D=B8=ED=8E=98?=
=?UTF-8?q?=EC=9D=B4=EC=A7=80=20=ED=85=9C=ED=94=8C=EB=A6=BF=20=ED=8C=8C?=
=?UTF-8?q?=EC=9D=BC=20=ED=86=B5=ED=95=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 8 +--
src/components/editor/Content.js | 2 +-
src/components/editor/Title.js | 2 +-
src/components/sidebar/DocumentsList.js | 2 +-
src/components/sidebar/SidebarHeader.js | 2 +-
src/routes/URLRouter.js | 2 -
src/templates/editorTemplates.js | 21 -------
...debarTemplates.js => mainPageTemplates.js} | 56 +++++++++++++------
...{templates.js => notFoundPageTemplates.js} | 0
9 files changed, 48 insertions(+), 47 deletions(-)
delete mode 100644 src/templates/editorTemplates.js
rename src/templates/{SidebarTemplates.js => mainPageTemplates.js} (66%)
rename src/templates/{templates.js => notFoundPageTemplates.js} (100%)
diff --git a/src/components/App.js b/src/components/App.js
index 1d3cf237..4e5cd319 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -12,6 +12,10 @@ export default function App({ $target }) {
this.route()
}
+ const updateState = (targetState, id) => {
+ fetchMainData(main, targetState, id)
+ }
+
this.route = () => {
const { pathname } = location
const isMain = pathname === '/'
@@ -29,8 +33,4 @@ export default function App({ $target }) {
}
this.init()
-
- function updateState(targetState, id) {
- fetchMainData(main, targetState, id)
- }
}
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index e1f830ea..a22a53e8 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,4 +1,4 @@
-import { contentTemplate } from '../../templates/editorTemplates'
+import { contentTemplate } from '../../templates/mainPageTemplates'
import { createComponent } from '../../utils/domUtils'
export default function Content({ initialState, onClick }) {
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index 0cc26fe7..c3d54136 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -1,4 +1,4 @@
-import { titleTemplate } from '../../templates/editorTemplates'
+import { titleTemplate } from '../../templates/mainPageTemplates'
import { createComponent } from '../../utils/domUtils'
export default function Title({ initialState }) {
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index 8dab3eec..11a9f963 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -1,4 +1,4 @@
-import { documentsListTemplate } from '../../templates/SidebarTemplates'
+import { documentsListTemplate } from '../../templates/mainPageTemplates'
import { createComponent } from '../../utils/domUtils'
export default function DocumentsList({
diff --git a/src/components/sidebar/SidebarHeader.js b/src/components/sidebar/SidebarHeader.js
index f048c1b3..6bb0e834 100644
--- a/src/components/sidebar/SidebarHeader.js
+++ b/src/components/sidebar/SidebarHeader.js
@@ -1,4 +1,4 @@
-import { sidebarHeaderTemplate } from '../../templates/SidebarTemplates'
+import { sidebarHeaderTemplate } from '../../templates/mainPageTemplates'
import { createComponent } from '../../utils/domUtils'
export default function SidebarHeader() {
diff --git a/src/routes/URLRouter.js b/src/routes/URLRouter.js
index 68eb8960..009e454b 100644
--- a/src/routes/URLRouter.js
+++ b/src/routes/URLRouter.js
@@ -1,5 +1,3 @@
-import { DATA } from '../utils/constants'
-
export function navigate(path) {
const { pathname } = location
diff --git a/src/templates/editorTemplates.js b/src/templates/editorTemplates.js
deleted file mode 100644
index d1fc58f7..00000000
--- a/src/templates/editorTemplates.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export function contentTemplate({ content, documents }) {
- return `
-
-
- ${documents
- .map(
- (subDocument) =>
- `- ${
- subDocument.title.length ? subDocument.title : '제목 없음'
- }
`,
- )
- .join('')}
-
- `
-}
-
-export function titleTemplate({ title }) {
- return title.length
- ? ``
- : ``
-}
diff --git a/src/templates/SidebarTemplates.js b/src/templates/mainPageTemplates.js
similarity index 66%
rename from src/templates/SidebarTemplates.js
rename to src/templates/mainPageTemplates.js
index 261990be..4ca4b0d4 100644
--- a/src/templates/SidebarTemplates.js
+++ b/src/templates/mainPageTemplates.js
@@ -1,6 +1,46 @@
import { ENV } from '../utils/constants'
import { getItem } from '../utils/storage'
+// editor
+export function contentTemplate({ content, documents }) {
+ return `
+
+
+ ${documents
+ .map(
+ (subDocument) =>
+ `- ${
+ subDocument.title.length ? subDocument.title : '제목 없음'
+ }
`,
+ )
+ .join('')}
+
+ `
+}
+
+export function titleTemplate({ title }) {
+ return title.length
+ ? ``
+ : ``
+}
+
+// sidebar
+export function documentsListTemplate(documents) {
+ return `
+
+ ${documents.map((document) => `${renderDocument(document)}`).join('')}
+
+
+ `
+}
+
+export function sidebarHeaderTemplate() {
+ return `
+
+ 효리보고의 Notion
+ `
+}
+
function renderDocument({ id, title, documents }) {
const toggleState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
const isHiddenClass = toggleState?.[id] ? '' : 'hidden'
@@ -30,19 +70,3 @@ function renderDocument({ id, title, documents }) {
return html
}
-
-export function documentsListTemplate(documents) {
- return `
-
- ${documents.map((document) => `${renderDocument(document)}`).join('')}
-
-
- `
-}
-
-export function sidebarHeaderTemplate() {
- return `
-
- 효리보고의 Notion
- `
-}
diff --git a/src/templates/templates.js b/src/templates/notFoundPageTemplates.js
similarity index 100%
rename from src/templates/templates.js
rename to src/templates/notFoundPageTemplates.js
From b372f8567c750741d918e6ebd5ba9fde5dea0c6e Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 04:17:47 +0900
Subject: [PATCH 056/107] =?UTF-8?q?Refactor:=20404=20=ED=8E=98=EC=9D=B4?=
=?UTF-8?q?=EC=A7=80=20=ED=85=9C=ED=94=8C=EB=A6=BF=20=EC=A0=81=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/pages/NotFoundPage.js | 8 +++-----
src/templates/notFoundPageTemplates.js | 7 +++++++
2 files changed, 10 insertions(+), 5 deletions(-)
diff --git a/src/pages/NotFoundPage.js b/src/pages/NotFoundPage.js
index 75c63e85..78a885b7 100644
--- a/src/pages/NotFoundPage.js
+++ b/src/pages/NotFoundPage.js
@@ -1,12 +1,10 @@
+import { notFoundTemplate } from '../templates/notFoundPageTemplates'
+
export default function NotFoundPage({ $target }) {
const $notFoundPage = document.createElement('div')
$target.appendChild($notFoundPage)
- $notFoundPage.innerHTML = `
-
- 이 콘텐츠는 존재하지 않습니다
-
- `
+ $notFoundPage.innerHTML = notFoundTemplate()
$notFoundPage.addEventListener('click', () => {
// navigate('/')
diff --git a/src/templates/notFoundPageTemplates.js b/src/templates/notFoundPageTemplates.js
index e69de29b..96201ee6 100644
--- a/src/templates/notFoundPageTemplates.js
+++ b/src/templates/notFoundPageTemplates.js
@@ -0,0 +1,7 @@
+export function notFoundTemplate() {
+ return `
+
+ 이 콘텐츠는 존재하지 않습니다
+
+ `
+}
From 12f807afe31d9bc5487a2727d3e8081d931e7614 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 05:31:08 +0900
Subject: [PATCH 057/107] =?UTF-8?q?Refactor:=20=EC=9D=B4=EB=B2=A4=ED=8A=B8?=
=?UTF-8?q?=EB=A7=88=EB=8B=A4=20dom=20=EC=9C=A0=ED=8B=B8=20=ED=95=A8?=
=?UTF-8?q?=EC=88=98=20=EC=A0=81=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 4 +-
src/components/editor/Content.js | 30 ++++++-------
src/components/editor/Editor.js | 45 ++++++++++---------
src/components/editor/Title.js | 14 +++---
src/components/sidebar/DocumentsList.js | 56 +++++++++++------------
src/components/sidebar/Sidebar.js | 14 +++---
src/components/sidebar/SidebarHeader.js | 9 ++--
src/pages/MainPage.js | 21 +++++----
src/utils/constants.js | 4 +-
src/utils/domUtils.js | 59 +++++++++++++++++++++++--
10 files changed, 153 insertions(+), 103 deletions(-)
diff --git a/src/components/App.js b/src/components/App.js
index 4e5cd319..75db57ea 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -1,14 +1,14 @@
import MainPage from '../pages/MainPage'
import NotFoundPage from '../pages/NotFoundPage'
import { DATA } from '../utils/constants'
-import { eventHandler } from '../utils/domUtils'
+import { addEventHandler } from '../utils/domUtils'
import { fetchMainData } from '../utils/fetchData'
export default function App({ $target }) {
let main, notFound
this.init = () => {
- eventHandler(window, 'popstate', this.route)
+ addEventHandler(window, 'popstate', this.route)
this.route()
}
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index a22a53e8..bf34e544 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -1,8 +1,15 @@
import { contentTemplate } from '../../templates/mainPageTemplates'
-import { createComponent } from '../../utils/domUtils'
-
-export default function Content({ initialState, onClick }) {
- const $content = createComponent('div', 'content')
+import {
+ createComponent,
+ addEventHandler,
+ handleSubsClick,
+} from '../../utils/domUtils'
+
+export default function Content({ $target, initialState, onClick }) {
+ const $content = createComponent('div', {
+ className: 'content',
+ parentElement: $target,
+ })
this.state = initialState
@@ -12,23 +19,12 @@ export default function Content({ initialState, onClick }) {
}
this.render = () => {
- if (!this.state) {
- $content.innerHTML = ''
- return
- }
-
$content.innerHTML = contentTemplate(this.state)
- $content.addEventListener('click', ({ target }) => {
- const $subDocument = target.closest('li')
- if ($subDocument) {
- const subId = $subDocument.dataset.id
- onClick(subId)
- }
+ addEventHandler($content, 'click', ({ target }) => {
+ handleSubsClick(target, onClick)
})
}
this.render()
-
- return $content
}
diff --git a/src/components/editor/Editor.js b/src/components/editor/Editor.js
index 2b24b7dc..9b5c9e1f 100644
--- a/src/components/editor/Editor.js
+++ b/src/components/editor/Editor.js
@@ -1,14 +1,25 @@
-import { createComponent } from '../../utils/domUtils.js'
+import {
+ addEventHandler,
+ createComponent,
+ removeEventHandler,
+ handleKeyup,
+} from '../../utils/domUtils.js'
import Content from './Content.js'
import Title from './Title.js'
export default function Editor({ $target, initialState, onEdit, onClick }) {
- const $editor = createComponent('div', 'editor')
- $target.appendChild($editor)
+ const $editor = createComponent('div', {
+ className: 'editor',
+ })
this.state = initialState
this.setState = (nextState) => {
+ if (!nextState) {
+ $target.contains($editor) && $target.removeChild($editor)
+ return
+ }
+
this.state = nextState
this.render()
}
@@ -16,31 +27,23 @@ export default function Editor({ $target, initialState, onEdit, onClick }) {
let keyupListener = null
this.render = () => {
+ $target.appendChild($editor)
$editor.innerHTML = ''
- const $title = new Title({ initialState: this.state })
- const $content = new Content({ initialState: this.state, onClick })
-
- $editor.appendChild($title)
- $editor.appendChild($content)
+ new Title({ $target: $editor, initialState: this.state })
+ new Content({
+ $target: $editor,
+ initialState: this.state,
+ onClick,
+ })
if (keyupListener) {
- // 이전에 등록한 keyup 이벤트 리스너가 있을 경우 제거
- $editor.removeEventListener('keyup', keyupListener)
+ removeEventHandler($editor, 'keyup', keyupListener)
}
keyupListener = ({ target }) => {
- const name = target.closest('div').className
-
- const nextState = {
- ...this.state,
- [name]: target.value,
- }
- onEdit(nextState)
-
- this.state = nextState // 낙관적 업데이트
+ handleKeyup(target, onEdit, this.state)
}
-
- $editor.addEventListener('keyup', keyupListener)
+ addEventHandler($editor, 'keyup', keyupListener)
}
}
diff --git a/src/components/editor/Title.js b/src/components/editor/Title.js
index c3d54136..3df18d18 100644
--- a/src/components/editor/Title.js
+++ b/src/components/editor/Title.js
@@ -1,8 +1,11 @@
import { titleTemplate } from '../../templates/mainPageTemplates'
import { createComponent } from '../../utils/domUtils'
-export default function Title({ initialState }) {
- const $title = createComponent('div', 'title')
+export default function Title({ $target, initialState }) {
+ const $title = createComponent('div', {
+ className: 'title',
+ parentElement: $target,
+ })
this.state = initialState
@@ -12,15 +15,8 @@ export default function Title({ initialState }) {
}
this.render = () => {
- if (!this.state) {
- $title.innerHTML = ''
- return
- }
-
$title.innerHTML = titleTemplate(this.state)
}
this.render()
-
- return $title
}
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index 11a9f963..d6f22adb 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -1,14 +1,23 @@
import { documentsListTemplate } from '../../templates/mainPageTemplates'
-import { createComponent } from '../../utils/domUtils'
+import {
+ addEventHandler,
+ createComponent,
+ removeEventHandler,
+ handleSidebarClick,
+} from '../../utils/domUtils'
export default function DocumentsList({
+ $target,
initialState,
onClick,
onAdd,
onToggle,
onDelete,
}) {
- const $documents = createComponent('div', 'documents')
+ const $documents = createComponent('div', {
+ className: 'documents',
+ parentElement: $target,
+ })
this.state = initialState
@@ -17,37 +26,26 @@ export default function DocumentsList({
this.render()
}
+ let clickListener = null
+
this.render = () => {
$documents.innerHTML = documentsListTemplate(this.state)
- const $documentsList = $documents.querySelectorAll('li')
-
- $documentsList.forEach(($document) => {
- $document.addEventListener('click', async (e) => {
- const { id } = $document.dataset
- const { target } = e
- e.stopPropagation()
-
- this.setState([...this.state])
-
- if (target.closest('.toggle')) {
- onToggle(target, id)
- } else if (target.closest('.add')) {
- if (id) {
- onAdd(id)
- onToggle($document.querySelector('.toggle'), id, target.className)
- } else {
- onAdd()
- }
- } else if (target.closest('.delete')) {
- onDelete(id)
- } else if (target.closest('.document')) {
- id && onClick(id)
- }
+
+ if (clickListener) {
+ removeEventHandler($documents, 'click', clickListener)
+ }
+
+ clickListener = ({ target }) => {
+ handleSidebarClick(target, {
+ onClick,
+ onToggle,
+ onAdd,
+ onDelete,
})
- })
+ }
+
+ addEventHandler($documents, 'click', clickListener)
}
this.render()
-
- return $documents
}
diff --git a/src/components/sidebar/Sidebar.js b/src/components/sidebar/Sidebar.js
index 84d210b5..dc3b59f9 100644
--- a/src/components/sidebar/Sidebar.js
+++ b/src/components/sidebar/Sidebar.js
@@ -10,8 +10,10 @@ export default function Sidebar({
onToggle,
onDelete,
}) {
- const $sidebar = createComponent('div', 'sidebar')
- $target.appendChild($sidebar)
+ const $sidebar = createComponent('div', {
+ className: 'sidebar',
+ parentElement: $target,
+ })
this.state = initialState
@@ -23,17 +25,15 @@ export default function Sidebar({
this.render = () => {
$sidebar.innerHTML = ''
- const $header = new SidebarHeader()
- const $documents = new DocumentsList({
+ new SidebarHeader({ $target: $sidebar })
+ new DocumentsList({
+ $target: $sidebar,
initialState: this.state,
onClick,
onAdd,
onToggle,
onDelete,
})
-
- $sidebar.appendChild($header)
- $sidebar.appendChild($documents)
}
this.render()
diff --git a/src/components/sidebar/SidebarHeader.js b/src/components/sidebar/SidebarHeader.js
index 6bb0e834..074a097b 100644
--- a/src/components/sidebar/SidebarHeader.js
+++ b/src/components/sidebar/SidebarHeader.js
@@ -1,14 +1,15 @@
import { sidebarHeaderTemplate } from '../../templates/mainPageTemplates'
import { createComponent } from '../../utils/domUtils'
-export default function SidebarHeader() {
- const $header = createComponent('div', 'header')
+export default function SidebarHeader({ $target }) {
+ const $header = createComponent('div', {
+ className: 'header',
+ parentElement: $target,
+ })
this.render = () => {
$header.innerHTML = sidebarHeaderTemplate()
}
this.render()
-
- return $header
}
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index 6abfdff4..69abbe7a 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -11,8 +11,10 @@ import { navigate } from '../routes/URLRouter'
import { createComponent } from '../utils/domUtils'
export default function MainPage({ $target, updateState }) {
- const $main = createComponent('div', 'main')
- $target.appendChild($main)
+ const $main = createComponent('div', {
+ className: 'main',
+ parentElement: $target,
+ })
this.documents = []
@@ -23,9 +25,9 @@ export default function MainPage({ $target, updateState }) {
this.content = null
- this.setContent = (nextDocuments) => {
- this.content = nextDocuments
- editor.setState(nextDocuments)
+ this.setContent = (nextContent) => {
+ this.content = nextContent
+ editor.setState(nextContent)
}
const sidebar = new Sidebar({
@@ -59,6 +61,7 @@ export default function MainPage({ $target, updateState }) {
if (pathId === id) {
navigate('/')
updateState(DATA.DOCUMENT)
+ editor.setState(null)
} else {
updateState(DATA.DOCUMENT)
}
@@ -79,7 +82,7 @@ export default function MainPage({ $target, updateState }) {
const editor = new Editor({
$target: $main,
initialState: this.content,
- onEdit: async (post) => {
+ onEdit: async (post, name) => {
if (timer) {
clearTimeout(timer)
}
@@ -94,9 +97,9 @@ export default function MainPage({ $target, updateState }) {
}
setItem(ENV.TEMP_POST_SAVE_KEY, nextState)
await editDocument(id, title, content)
- // 내용만 변경 시에는 content만 변하게 구현하기
- // 토글 열리는 버그 수정하기
- updateState(DATA.ALL, id)
+
+ name === 'content' && updateState(DATA.CONTENT, id)
+ name === 'title' && updateState(DATA.ALL, id)
}, 1000)
},
onClick: (id) => {
diff --git a/src/utils/constants.js b/src/utils/constants.js
index c376f7ac..08965a94 100644
--- a/src/utils/constants.js
+++ b/src/utils/constants.js
@@ -1,8 +1,8 @@
export const ENV = {
API_END_POINT: import.meta.env.VITE_API_END_POINT,
USER_NAME: import.meta.env.VITE_X_USER_NAME,
- TEMP_POST_SAVE_KEY: import.meta.env.TEMP_POST_SAVE_KEY,
- TOGGLE_STATE_SAVE_KEY: import.meta.env.TOGGLE_STATE_SAVE_KEY,
+ TEMP_POST_SAVE_KEY: import.meta.env.VITE_TEMP_POST_SAVE_KEY,
+ TOGGLE_STATE_SAVE_KEY: import.meta.env.VITE_TOGGLE_STATE_SAVE_KEY,
}
export const DATA = {
diff --git a/src/utils/domUtils.js b/src/utils/domUtils.js
index b2948f15..c2d7fec7 100644
--- a/src/utils/domUtils.js
+++ b/src/utils/domUtils.js
@@ -1,10 +1,63 @@
-export function createComponent(tagName, className) {
+export function createComponent(tagName, options = {}) {
+ const { className, parentElement } = options
const element = document.createElement(tagName)
- element.classList.add(className)
+
+ className && element.classList.add(className)
+ parentElement && parentElement.appendChild(element)
return element
}
-export function eventHandler(element, eventType, handler) {
+export function addEventHandler(element, eventType, handler) {
element.addEventListener(eventType, handler)
}
+
+export function removeEventHandler(element, eventType, handler) {
+ element.removeEventListener(eventType, handler)
+}
+
+export function handleSubsClick(target, onClick) {
+ const $subDocument = target.closest('li')
+
+ if ($subDocument) {
+ const subId = $subDocument.dataset.id
+ onClick(subId)
+ }
+}
+
+export function handleKeyup(target, onEdit, state) {
+ const name = target.closest('div').className
+ const nextState = {
+ ...state,
+ [name]: target.value,
+ }
+ onEdit(nextState, name)
+}
+
+export function handleSidebarClick(target, events) {
+ const { onClick, onToggle, onAdd, onDelete } = events
+ const $li = target.closest('li')
+ const { id } = $li.dataset
+
+ if (target.closest('.toggle')) {
+ onToggle(target, id)
+ return
+ }
+
+ if (target.closest('.add')) {
+ id && onAdd(id)
+ id && onToggle($li.querySelector('.toggle'), id, target.className)
+
+ !id && onAdd()
+ return
+ }
+
+ if (target.closest('.delete')) {
+ onDelete(id)
+ return
+ }
+
+ if ($li) {
+ id && onClick(id)
+ }
+}
From 959e9b4954bf79fc1e9a7b1f0f32ed4a3f622cee Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 08:25:57 +0900
Subject: [PATCH 058/107] =?UTF-8?q?Refactor:=20=EC=9D=B4=EB=B2=A4=ED=8A=B8?=
=?UTF-8?q?=20=EC=A0=84=EB=8B=AC=20=ED=95=A8=EC=88=98=20=EA=B5=AC=ED=98=84?=
=?UTF-8?q?=20=EB=B0=8F=20=EC=A0=81=EC=9A=A9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/App.js | 2 +-
src/pages/MainPage.js | 89 ++++++++++----------------------------
src/routes/PageRouter.js | 24 ----------
src/utils/debounce.js | 7 +++
src/utils/dispatchEvent.js | 53 +++++++++++++++++++++++
src/utils/domUtils.js | 17 ++++++--
src/utils/fetchData.js | 1 -
src/utils/storage.js | 6 +--
8 files changed, 101 insertions(+), 98 deletions(-)
delete mode 100644 src/routes/PageRouter.js
create mode 100644 src/utils/debounce.js
create mode 100644 src/utils/dispatchEvent.js
diff --git a/src/components/App.js b/src/components/App.js
index 75db57ea..383f19ee 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -20,7 +20,7 @@ export default function App({ $target }) {
const { pathname } = location
const isMain = pathname === '/'
const isEditor = pathname.indexOf('/documents/') === 0
- const id = isEditor && pathname.split('/')[2]
+ const id = isEditor ? pathname.split('/')[2] : null
$target.innerHTML = ''
if (isMain || isEditor) {
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index 69abbe7a..a492e737 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -1,14 +1,14 @@
import Sidebar from '../components/sidebar/Sidebar'
import Editor from '../components/editor/Editor'
-import {
- createNewDocument,
- deleteDocument,
- editDocument,
-} from '../utils/fetchData'
-import { getItem, setItem } from '../utils/storage'
-import { DATA, ENV } from '../utils/constants'
-import { navigate } from '../routes/URLRouter'
import { createComponent } from '../utils/domUtils'
+import {
+ dispatchAddEvent,
+ dispatchClickEvent,
+ dispatchDeleteEvent,
+ dispatchEditEvent,
+ dispatchToggleEvent,
+} from '../utils/dispatchEvent'
+import { debounce } from '../utils/debounce'
export default function MainPage({ $target, updateState }) {
const $main = createComponent('div', {
@@ -34,77 +34,36 @@ export default function MainPage({ $target, updateState }) {
$target: $main,
initialState: this.documents,
onClick: (id) => {
- navigate(`/documents/${id}`)
- updateState(DATA.CONTENT, id)
+ dispatchClickEvent(id, updateState)
},
- onAdd: async (id) => {
- const newDocument = await createNewDocument(id)
- navigate(`/documents/${newDocument.id}`)
- updateState(DATA.ALL, newDocument.id)
+ onAdd: (id) => {
+ dispatchAddEvent(id, updateState)
},
- onToggle: async (target, id, event = '') => {
- const $toggle = target.closest('.toggle')
- const $nestedList = $toggle.closest('li').querySelector('.nested')
-
- if (event !== 'add' || $nestedList.classList.contains('hidden')) {
- $nestedList.classList.toggle('hidden')
- }
-
- const isOpen = !$nestedList.classList.contains('hidden')
- saveToggleState(id, isOpen)
- this.setDocuments(this.documents)
+ onToggle: (id, isOpen) => {
+ dispatchToggleEvent(id, isOpen)
},
onDelete: async (id) => {
- const pathId = location.pathname.split('/').at(-1)
- await deleteDocument(id)
-
- if (pathId === id) {
- navigate('/')
- updateState(DATA.DOCUMENT)
- editor.setState(null)
- } else {
- updateState(DATA.DOCUMENT)
- }
+ const isNavigated = dispatchDeleteEvent(id, updateState)
+ isNavigated && editor.setState(null)
},
})
let timer = null
- const saveToggleState = (id, isOpen) => {
- const currState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
- const nextState = {
- ...currState,
- [id]: isOpen,
- }
- setItem(ENV.TOGGLE_STATE_SAVE_KEY, nextState)
- }
-
const editor = new Editor({
$target: $main,
initialState: this.content,
- onEdit: async (post, name) => {
- if (timer) {
- clearTimeout(timer)
- }
- // 디바운스
- timer = setTimeout(async () => {
- const currState = getItem(ENV.TEMP_POST_SAVE_KEY)
- const { id, title, content } = post
-
- const nextState = {
- ...currState,
- [id]: post,
- }
- setItem(ENV.TEMP_POST_SAVE_KEY, nextState)
- await editDocument(id, title, content)
-
- name === 'content' && updateState(DATA.CONTENT, id)
- name === 'title' && updateState(DATA.ALL, id)
- }, 1000)
+ onEdit: (post, name) => {
+ timer = debounce(
+ timer,
+ () => {
+ dispatchEditEvent(post, name, updateState)
+ },
+ 1000,
+ )
},
onClick: (id) => {
- navigate(`/documents/${id}`)
- updateState(DATA.CONTENT, id)
+ dispatchClickEvent(id, updateState)
},
})
}
diff --git a/src/routes/PageRouter.js b/src/routes/PageRouter.js
deleted file mode 100644
index fc145875..00000000
--- a/src/routes/PageRouter.js
+++ /dev/null
@@ -1,24 +0,0 @@
-import MainPage from '../pages/MainPage'
-import NotFoundPage from '../pages/NotFoundPage'
-
-export default function PageRouter({ $target }) {
- this.init = () => {
- window.addEventListener('popstate', () => {
- this.route()
- })
-
- return this.route()
- }
-
- this.route = () => {
- const { pathname } = location
- let PageComponent = NotFoundPage
-
- if (pathname === '/' || pathname.indexOf('/documents/') === 0) {
- PageComponent = MainPage
- }
-
- $target.innerHTML = ''
- return PageComponent
- }
-}
diff --git a/src/utils/debounce.js b/src/utils/debounce.js
new file mode 100644
index 00000000..2311cfb8
--- /dev/null
+++ b/src/utils/debounce.js
@@ -0,0 +1,7 @@
+export function debounce(timer, callback, time) {
+ if (timer) {
+ clearTimeout(timer)
+ }
+
+ return setTimeout(callback, time)
+}
diff --git a/src/utils/dispatchEvent.js b/src/utils/dispatchEvent.js
new file mode 100644
index 00000000..7d614314
--- /dev/null
+++ b/src/utils/dispatchEvent.js
@@ -0,0 +1,53 @@
+import { navigate } from '../routes/URLRouter'
+import { DATA, ENV } from './constants'
+import { createNewDocument, deleteDocument, editDocument } from './fetchData'
+import { getItem, setItem } from './storage'
+
+export function dispatchClickEvent(id, update) {
+ navigate(`/documents/${id}`)
+ update(DATA.CONTENT, id)
+}
+
+export async function dispatchAddEvent(id, update) {
+ const newDocument = await createNewDocument(id)
+ navigate(`/documents/${newDocument.id}`)
+ update(DATA.ALL, newDocument.id)
+}
+
+export function dispatchToggleEvent(id, isOpen) {
+ const currState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
+ const nextState = {
+ ...currState,
+ [id]: isOpen,
+ }
+ setItem(ENV.TOGGLE_STATE_SAVE_KEY, nextState)
+}
+
+export async function dispatchDeleteEvent(id, update) {
+ const [, , pathId] = location.pathname.split('/')
+ await deleteDocument(id)
+
+ if (pathId === id) {
+ navigate('/')
+ update(DATA.DOCUMENT)
+ return true
+ }
+
+ update(DATA.DOCUMENT)
+ return false
+}
+
+export async function dispatchEditEvent(post, name, update) {
+ const currState = getItem(ENV.TEMP_POST_SAVE_KEY)
+ const { id, title, content } = post
+
+ const nextState = {
+ ...currState,
+ [id]: post,
+ }
+ setItem(ENV.TEMP_POST_SAVE_KEY, nextState)
+ await editDocument(id, title, content)
+
+ name === 'content' && update(DATA.CONTENT, id)
+ name === 'title' && update(DATA.ALL, id)
+}
diff --git a/src/utils/domUtils.js b/src/utils/domUtils.js
index c2d7fec7..8d6d6373 100644
--- a/src/utils/domUtils.js
+++ b/src/utils/domUtils.js
@@ -40,15 +40,16 @@ export function handleSidebarClick(target, events) {
const { id } = $li.dataset
if (target.closest('.toggle')) {
- onToggle(target, id)
+ handleToggle($li, id, onToggle)
return
}
if (target.closest('.add')) {
id && onAdd(id)
- id && onToggle($li.querySelector('.toggle'), id, target.className)
-
!id && onAdd()
+ $li.querySelector('.nested')?.classList.contains('hidden') &&
+ handleToggle($li, id, onToggle)
+
return
}
@@ -61,3 +62,13 @@ export function handleSidebarClick(target, events) {
id && onClick(id)
}
}
+
+function handleToggle($li, id, onToggle) {
+ const nestedList = $li.querySelector('.nested')
+
+ if (nestedList) {
+ nestedList.classList.toggle('hidden')
+ const isOpen = !nestedList.classList.contains('hidden')
+ onToggle(id, isOpen)
+ }
+}
diff --git a/src/utils/fetchData.js b/src/utils/fetchData.js
index 4ef0c6c8..e2f695b8 100644
--- a/src/utils/fetchData.js
+++ b/src/utils/fetchData.js
@@ -42,7 +42,6 @@ export async function fetchMainData(page, targetState, id) {
case DATA.DOCUMENT:
// documents 데이터 받기
page.setDocuments(await fetchDocuments())
- page.setContent(null)
break
case DATA.CONTENT:
// content 데이터 받기
diff --git a/src/utils/storage.js b/src/utils/storage.js
index e0684d6f..5bf410d5 100644
--- a/src/utils/storage.js
+++ b/src/utils/storage.js
@@ -1,6 +1,6 @@
const storage = window.localStorage
-const getItem = (key, defaultValue) => {
+export function getItem(key, defaultValue) {
try {
const storedValue = storage.getItem(key)
return storedValue ? JSON.parse(storedValue) : defaultValue
@@ -9,8 +9,6 @@ const getItem = (key, defaultValue) => {
}
}
-const setItem = (key, value) => {
+export function setItem(key, value) {
storage.setItem(key, JSON.stringify(value))
}
-
-export { getItem, setItem }
From 193c71e4bf9a0c28a54f4af872c7e2b83ed5af10 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 14:54:50 +0900
Subject: [PATCH 059/107] =?UTF-8?q?Refactor:=20=EB=B6=88=ED=95=84=EC=9A=94?=
=?UTF-8?q?=ED=95=9C=20dom=20=EB=A0=8C=EB=8D=94=EB=A7=81=20=EB=B0=A9?=
=?UTF-8?q?=EC=A7=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
config/configuration.js | 0
src/templates/mainPageTemplates.js | 33 +++++++++++++++++-------------
2 files changed, 19 insertions(+), 14 deletions(-)
delete mode 100644 config/configuration.js
diff --git a/config/configuration.js b/config/configuration.js
deleted file mode 100644
index e69de29b..00000000
diff --git a/src/templates/mainPageTemplates.js b/src/templates/mainPageTemplates.js
index 4ca4b0d4..8dd21c49 100644
--- a/src/templates/mainPageTemplates.js
+++ b/src/templates/mainPageTemplates.js
@@ -3,19 +3,24 @@ import { getItem } from '../utils/storage'
// editor
export function contentTemplate({ content, documents }) {
- return `
-
-
- ${documents
- .map(
- (subDocument) =>
- `- ${
- subDocument.title.length ? subDocument.title : '제목 없음'
- }
`,
- )
- .join('')}
-
- `
+ let html = ``
+
+ if (documents.length) {
+ html += `
+
+ ${documents
+ .map(
+ (subDocument) =>
+ `- ${
+ subDocument.title.length ? subDocument.title : '제목 없음'
+ }
`,
+ )
+ .join('')}
+
+ `
+ }
+
+ return html
}
export function titleTemplate({ title }) {
@@ -53,7 +58,7 @@ function renderDocument({ id, title, documents }) {
`
- if (documents.length && toggleState) {
+ if (documents.length) {
html += ``
documents.forEach((subDocument) => {
html += `${renderDocument(subDocument)}`
From a4851e0781b405fc6385c05c3770a0ed951f6979 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 18:25:05 +0900
Subject: [PATCH 060/107] =?UTF-8?q?Design:=20=EC=95=84=EC=9D=B4=EC=BD=98?=
=?UTF-8?q?=20=EC=B6=94=EA=B0=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
public/assets/images/add.svg | 3 +++
public/assets/images/delete.svg | 10 ++++++++++
public/assets/images/document.png | Bin 0 -> 422 bytes
public/assets/images/toggle_close.svg | 3 +++
public/assets/images/toggle_open.svg | 3 +++
5 files changed, 19 insertions(+)
create mode 100644 public/assets/images/add.svg
create mode 100644 public/assets/images/delete.svg
create mode 100644 public/assets/images/document.png
create mode 100644 public/assets/images/toggle_close.svg
create mode 100644 public/assets/images/toggle_open.svg
diff --git a/public/assets/images/add.svg b/public/assets/images/add.svg
new file mode 100644
index 00000000..532c5767
--- /dev/null
+++ b/public/assets/images/add.svg
@@ -0,0 +1,3 @@
+
diff --git a/public/assets/images/delete.svg b/public/assets/images/delete.svg
new file mode 100644
index 00000000..58a8ba56
--- /dev/null
+++ b/public/assets/images/delete.svg
@@ -0,0 +1,10 @@
+
diff --git a/public/assets/images/document.png b/public/assets/images/document.png
new file mode 100644
index 0000000000000000000000000000000000000000..a3f16312c0bb3ad13bb2c863261282a0315a383a
GIT binary patch
literal 422
zcmV;X0a^ZuP)F8P38V=w>WZE~kH8W11jR%xp~Z%UYs(3^0&6!GO|)8PKFb*B
zA1l1od^7Kt@4XBQ!}}``yFh~&!-{L@*|xLV-GzZqAdEp2mz-TN44WWb892p*!THVB
zKb_t&4n7o;Y+YlX6nKgvUqKvu)Ye-|u4%peXl@|S^Gtmo@FBm(kSbO}1gq0&oi+kO
z@K`&_dljV;fUKfJO^%}qy4yMOeM{)*SAZyrOp&F_I?OpAA(M;kyaR08PG*5Wt^=RB
z*(lAGNL){^0mH1sJ9Ac>NPhqo={tR?ZwRN8O9+}bMtTS)eJN#S!`pj0H;rPe0vItX
z2>h-9t-;y447A(ENtXWsF99(DBZmLQejk%8V+(bBoZTMdfSzBowd=ac4~QUula%d{
QRR91007*qoM6N<$f~!ZU6aWAK
literal 0
HcmV?d00001
diff --git a/public/assets/images/toggle_close.svg b/public/assets/images/toggle_close.svg
new file mode 100644
index 00000000..36537420
--- /dev/null
+++ b/public/assets/images/toggle_close.svg
@@ -0,0 +1,3 @@
+
diff --git a/public/assets/images/toggle_open.svg b/public/assets/images/toggle_open.svg
new file mode 100644
index 00000000..16f82d90
--- /dev/null
+++ b/public/assets/images/toggle_open.svg
@@ -0,0 +1,3 @@
+
From be3ea27ddf8e35b8c52c97179be569e64865c1e8 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 18:25:20 +0900
Subject: [PATCH 061/107] =?UTF-8?q?Design:=20minireset.css=20=EC=B6=94?=
=?UTF-8?q?=EA=B0=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
public/styles/minireset.css | 73 +++++++++++++++++++++++++++++++++++++
1 file changed, 73 insertions(+)
create mode 100644 public/styles/minireset.css
diff --git a/public/styles/minireset.css b/public/styles/minireset.css
new file mode 100644
index 00000000..454cde7f
--- /dev/null
+++ b/public/styles/minireset.css
@@ -0,0 +1,73 @@
+blockquote,
+body,
+dd,
+dl,
+dt,
+fieldset,
+figure,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+hr,
+html,
+iframe,
+legend,
+li,
+ol,
+p,
+pre,
+textarea,
+ul {
+ margin: 0;
+ padding: 0;
+}
+h1,
+h2,
+h3,
+h4,
+h5,
+h6 {
+ font-size: 100%;
+ font-weight: 400;
+}
+ul {
+ list-style: none;
+}
+button {
+ outline: 0;
+ border: 0;
+ background-color: transparent;
+}
+button,
+input,
+select {
+ margin: 0;
+ padding: 0;
+}
+html {
+ box-sizing: border-box;
+}
+*,
+:after,
+:before {
+ box-sizing: inherit;
+}
+img,
+video {
+ height: auto;
+ max-width: 100%;
+}
+iframe {
+ border: 0;
+}
+table {
+ border-collapse: collapse;
+ border-spacing: 0;
+}
+td,
+th {
+ padding: 0;
+}
From 467b647a253011c18a6c98e15c32232df2fb5fbd Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 18:25:54 +0900
Subject: [PATCH 062/107] =?UTF-8?q?Refactor:=20=ED=86=A0=EA=B8=80=20?=
=?UTF-8?q?=EC=8B=9C=20Documents=20=EC=9E=AC=EB=A0=8C=EB=8D=94=EB=A7=81=20?=
=?UTF-8?q?=EA=B5=AC=ED=98=84?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/pages/MainPage.js | 1 +
1 file changed, 1 insertion(+)
diff --git a/src/pages/MainPage.js b/src/pages/MainPage.js
index a492e737..2d116239 100644
--- a/src/pages/MainPage.js
+++ b/src/pages/MainPage.js
@@ -41,6 +41,7 @@ export default function MainPage({ $target, updateState }) {
},
onToggle: (id, isOpen) => {
dispatchToggleEvent(id, isOpen)
+ sidebar.render()
},
onDelete: async (id) => {
const isNavigated = dispatchDeleteEvent(id, updateState)
From c6e6d85557067182a0c100e039007de3aec1b68e Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 18:26:26 +0900
Subject: [PATCH 063/107] =?UTF-8?q?Refactor:=20Documents=20=EB=A6=AC?=
=?UTF-8?q?=EC=8A=A4=ED=8A=B8=20html=20=EA=B5=AC=EC=A1=B0=20=EB=B3=80?=
=?UTF-8?q?=EA=B2=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/templates/mainPageTemplates.js | 72 ++++++++++++++++++------------
src/utils/domUtils.js | 12 ++---
2 files changed, 46 insertions(+), 38 deletions(-)
diff --git a/src/templates/mainPageTemplates.js b/src/templates/mainPageTemplates.js
index 8dd21c49..836fc7cd 100644
--- a/src/templates/mainPageTemplates.js
+++ b/src/templates/mainPageTemplates.js
@@ -30,48 +30,62 @@ export function titleTemplate({ title }) {
}
// sidebar
-export function documentsListTemplate(documents) {
+export function sidebarHeaderTemplate() {
return `
-
- ${documents.map((document) => `${renderDocument(document)}`).join('')}
-
-
+
+ 효리보고의 Notion
`
}
-export function sidebarHeaderTemplate() {
+export function documentsListTemplate(documents) {
return `
-
- 효리보고의 Notion
+
+ ${documents.map((document) => `${renderDocument(document)}`).join('')}
+ -
+
+
+
`
}
function renderDocument({ id, title, documents }) {
const toggleState = getItem(ENV.TOGGLE_STATE_SAVE_KEY)
- const isHiddenClass = toggleState?.[id] ? '' : 'hidden'
+ const isToggled = toggleState?.[id] ? 'open' : ''
- let html = `
- -
-
- [${id}] ${title.length ? title : '제목 없음'}
-
-
- `
+ let html = documentTemplate(id, title, isToggled)
- if (documents.length) {
- html += `
`
- documents.forEach((subDocument) => {
- html += `${renderDocument(subDocument)}`
- })
- html += '
'
- } else {
- html += `
- `
- }
+ // 하위 documents 렌더링
+ if (isToggled === 'open') {
+ if (documents.length) {
+ html += ` `
+ documents.forEach((subDocument) => {
+ html += `${renderDocument(subDocument)}`
+ })
- html += '
'
+ html += `
`
+ } else {
+ html += `
+ -
+
+
+ `
+ }
+ }
return html
}
+
+function documentTemplate(id, title, isToggled) {
+ return `
+ -
+
+ [${id}] ${title.length ? title : '제목 없음'}
+
+
+
+ `
+}
diff --git a/src/utils/domUtils.js b/src/utils/domUtils.js
index 8d6d6373..ee109fcc 100644
--- a/src/utils/domUtils.js
+++ b/src/utils/domUtils.js
@@ -47,8 +47,7 @@ export function handleSidebarClick(target, events) {
if (target.closest('.add')) {
id && onAdd(id)
!id && onAdd()
- $li.querySelector('.nested')?.classList.contains('hidden') &&
- handleToggle($li, id, onToggle)
+ !$li.classList.contains('open') && handleToggle($li, id, onToggle)
return
}
@@ -64,11 +63,6 @@ export function handleSidebarClick(target, events) {
}
function handleToggle($li, id, onToggle) {
- const nestedList = $li.querySelector('.nested')
-
- if (nestedList) {
- nestedList.classList.toggle('hidden')
- const isOpen = !nestedList.classList.contains('hidden')
- onToggle(id, isOpen)
- }
+ const isOpen = !$li.classList.contains('open')
+ onToggle(id, isOpen)
}
From 4b229d91f6237538cad66e886da04155f8df4845 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 22:39:21 +0900
Subject: [PATCH 064/107] =?UTF-8?q?Design:=20=EC=95=84=EC=9D=B4=EC=BD=98?=
=?UTF-8?q?=20=ED=8C=8C=EC=9D=BC=20=EC=88=98=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
public/assets/images/delete.svg | 4 ++--
public/assets/images/doc.svg | 3 +++
public/assets/images/document.png | Bin 422 -> 0 bytes
3 files changed, 5 insertions(+), 2 deletions(-)
create mode 100644 public/assets/images/doc.svg
delete mode 100644 public/assets/images/document.png
diff --git a/public/assets/images/delete.svg b/public/assets/images/delete.svg
index 58a8ba56..e22eeb85 100644
--- a/public/assets/images/delete.svg
+++ b/public/assets/images/delete.svg
@@ -1,10 +1,10 @@
diff --git a/public/assets/images/doc.svg b/public/assets/images/doc.svg
new file mode 100644
index 00000000..91dd28c6
--- /dev/null
+++ b/public/assets/images/doc.svg
@@ -0,0 +1,3 @@
+
diff --git a/public/assets/images/document.png b/public/assets/images/document.png
deleted file mode 100644
index a3f16312c0bb3ad13bb2c863261282a0315a383a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001
literal 422
zcmV;X0a^ZuP)F8P38V=w>WZE~kH8W11jR%xp~Z%UYs(3^0&6!GO|)8PKFb*B
zA1l1od^7Kt@4XBQ!}}``yFh~&!-{L@*|xLV-GzZqAdEp2mz-TN44WWb892p*!THVB
zKb_t&4n7o;Y+YlX6nKgvUqKvu)Ye-|u4%peXl@|S^Gtmo@FBm(kSbO}1gq0&oi+kO
z@K`&_dljV;fUKfJO^%}qy4yMOeM{)*SAZyrOp&F_I?OpAA(M;kyaR08PG*5Wt^=RB
z*(lAGNL){^0mH1sJ9Ac>NPhqo={tR?ZwRN8O9+}bMtTS)eJN#S!`pj0H;rPe0vItX
z2>h-9t-;y447A(ENtXWsF99(DBZmLQejk%8V+(bBoZTMdfSzBowd=ac4~QUula%d{
QRR91007*qoM6N<$f~!ZU6aWAK
From f2119f23fb8eb608bf669da92d84164d6b95ec6c Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 22:39:37 +0900
Subject: [PATCH 065/107] =?UTF-8?q?Design:=20minireset.css=20=EC=88=98?=
=?UTF-8?q?=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
public/styles/minireset.css | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/public/styles/minireset.css b/public/styles/minireset.css
index 454cde7f..89425932 100644
--- a/public/styles/minireset.css
+++ b/public/styles/minireset.css
@@ -71,3 +71,13 @@ td,
th {
padding: 0;
}
+input,
+textarea {
+ border: none;
+ background: none;
+ outline: none;
+ box-shadow: none;
+}
+textarea {
+ resize: none;
+}
From a86f30ffd43174692bbde26795273ff4cd8e6e78 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 22:40:23 +0900
Subject: [PATCH 066/107] =?UTF-8?q?Refactor:=20content=20=EC=9E=91?=
=?UTF-8?q?=EC=84=B1=20=ED=9B=84=20focus=20=EC=9C=A0=EC=A7=80?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/editor/Content.js | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/src/components/editor/Content.js b/src/components/editor/Content.js
index bf34e544..4fb92273 100644
--- a/src/components/editor/Content.js
+++ b/src/components/editor/Content.js
@@ -24,6 +24,11 @@ export default function Content({ $target, initialState, onClick }) {
addEventHandler($content, 'click', ({ target }) => {
handleSubsClick(target, onClick)
})
+
+ const $textarea = $content.querySelector('textarea')
+
+ $textarea.focus()
+ $textarea.setSelectionRange($textarea.value.length, $textarea.value.length)
}
this.render()
From 96bf64bd1f6e8d00013de9c83b4013919c1350a6 Mon Sep 17 00:00:00 2001
From: hyoribogo <97094709+hyoribogo@users.noreply.github.com>
Date: Thu, 6 Jul 2023 22:41:03 +0900
Subject: [PATCH 067/107] =?UTF-8?q?Refactor:=20=ED=95=98=EC=9C=84=EB=AC=B8?=
=?UTF-8?q?=EC=84=9C=20depth=20=EC=84=A4=EC=A0=95?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/sidebar/DocumentsList.js | 2 ++
src/templates/mainPageTemplates.js | 47 +++++++++++++++----------
src/utils/domUtils.js | 10 ++++++
3 files changed, 40 insertions(+), 19 deletions(-)
diff --git a/src/components/sidebar/DocumentsList.js b/src/components/sidebar/DocumentsList.js
index d6f22adb..64689c58 100644
--- a/src/components/sidebar/DocumentsList.js
+++ b/src/components/sidebar/DocumentsList.js
@@ -4,6 +4,7 @@ import {
createComponent,
removeEventHandler,
handleSidebarClick,
+ handleTreesPadding,
} from '../../utils/domUtils'
export default function DocumentsList({
@@ -30,6 +31,7 @@ export default function DocumentsList({
this.render = () => {
$documents.innerHTML = documentsListTemplate(this.state)
+ handleTreesPadding($documents)
if (clickListener) {
removeEventHandler($documents, 'click', clickListener)
diff --git a/src/templates/mainPageTemplates.js b/src/templates/mainPageTemplates.js
index 836fc7cd..ab46f4d8 100644
--- a/src/templates/mainPageTemplates.js
+++ b/src/templates/mainPageTemplates.js
@@ -3,17 +3,24 @@ import { getItem } from '../utils/storage'
// editor
export function contentTemplate({ content, documents }) {
- let html = ``
+ let html = ``
if (documents.length) {
html += `
-