From 8d2f17e7a4a5dc5db7c4dc74286147b11940126c Mon Sep 17 00:00:00 2001 From: Whitney Date: Wed, 31 May 2023 13:47:50 -0700 Subject: [PATCH 01/14] Setup complete --- package.json | 2 + yarn.lock | 658 ++++++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 648 insertions(+), 12 deletions(-) diff --git a/package.json b/package.json index 35b7d9f6..b7f13726 100644 --- a/package.json +++ b/package.json @@ -27,6 +27,8 @@ "babel-core": "^7.0.0-bridge.0", "babel-jest": "^24.8.0", "babel-plugin-module-resolver": "^3.2.0", + "eslint": "^8.41.0", + "eslint-plugin-jest": "^27.2.1", "jest": "^24.8.0", "regenerator-runtime": "^0.12.1" }, diff --git a/yarn.lock b/yarn.lock index 01caa24c..93ea4066 100644 --- a/yarn.lock +++ b/yarn.lock @@ -943,6 +943,57 @@ exec-sh "^0.3.2" minimist "^1.2.0" +"@eslint-community/eslint-utils@^4.2.0": + version "4.4.0" + resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" + integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== + dependencies: + eslint-visitor-keys "^3.3.0" + +"@eslint-community/regexpp@^4.4.0": + version "4.5.1" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.5.1.tgz#cdd35dce4fa1a89a4fd42b1599eb35b3af408884" + integrity sha512-Z5ba73P98O1KUYCCJTUeVpja9RcGoMdncZ6T49FCUl2lN38JtCJ+3WgIDBv0AuY4WChU5PmtJmOCTlN6FZTFKQ== + +"@eslint/eslintrc@^2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.0.3.tgz#4910db5505f4d503f27774bf356e3704818a0331" + integrity sha512-+5gy6OQfk+xx3q0d6jGZZC3f3KzAkXc/IanVxd1is/VIIziRqqt3ongQz0FiTUXqTk0c7aDB3OaFuKnuSoJicQ== + 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" + +"@eslint/js@8.41.0": + version "8.41.0" + resolved "https://registry.yarnpkg.com/@eslint/js/-/js-8.41.0.tgz#080321c3b68253522f7646b55b577dd99d2950b3" + integrity sha512-LxcyMGxwmTh2lY9FwHPGWOHmYFCZvbrFCBZL4FzSSsxsRPuhrYUg/49/0KDfW8tnIEaEHtfmn6+NPN+1DqaNmA== + +"@humanwhocodes/config-array@^0.11.8": + version "0.11.8" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.8.tgz#03595ac2075a4dc0f191cc2131de14fbd7d410b9" + integrity sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g== + dependencies: + "@humanwhocodes/object-schema" "^1.2.1" + debug "^4.1.1" + minimatch "^3.0.5" + +"@humanwhocodes/module-importer@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c" + integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA== + +"@humanwhocodes/object-schema@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz#b520529ec21d8e5945a1851dfd1c32e94e39ff45" + integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA== + "@jest/console@^24.7.1", "@jest/console@^24.9.0": version "24.9.0" resolved "https://registry.yarnpkg.com/@jest/console/-/console-24.9.0.tgz#79b1bc06fb74a8cfb01cbdedf945584b1b9707f0" @@ -1136,6 +1187,27 @@ resolved "https://registry.yarnpkg.com/@nicolo-ribaudo/chokidar-2/-/chokidar-2-2.1.8-no-fsevents.3.tgz#323d72dd25103d0c4fbdce89dadf574a787b1f9b" integrity sha512-s88O1aVtXftvp5bCPB7WnmXc5IwOZZ7YPuwNPt+GtOOXpPvad1LfbmjYv+qII7zP6RU2QGnqve27dnLycEnyEQ== +"@nodelib/fs.scandir@2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== + dependencies: + "@nodelib/fs.stat" "2.0.5" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== + +"@nodelib/fs.walk@^1.2.3", "@nodelib/fs.walk@^1.2.8": + version "1.2.8" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== + dependencies: + "@nodelib/fs.scandir" "2.1.5" + fastq "^1.6.0" + "@types/babel__core@^7.1.0": version "7.1.19" resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.19.tgz#7b497495b7d1b4812bdb9d02804d0576f43ee460" @@ -1189,6 +1261,16 @@ "@types/istanbul-lib-coverage" "*" "@types/istanbul-lib-report" "*" +"@types/json-schema@^7.0.9": + version "7.0.12" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.12.tgz#d70faba7039d5fca54c83c7dbab41051d2b6f6cb" + integrity sha512-Hr5Jfhc9eYOQNPYO5WLDq/n4jqijdHNlDXjuAQkkt+mWdQR+XJToOHrsD4cPaMXpn6KO7y2+wM8AZEs8VpBLVA== + +"@types/semver@^7.3.12": + version "7.5.0" + resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.5.0.tgz#591c1ce3a702c45ee15f47a42ade72c2fd78978a" + integrity sha512-G8hZ6XJiHnuhQKR7ZmysCeJWE08o8T0AXtk5darsCaTVsYZhhgUrq53jizaR2FvsoeCwJhlmwTjkXBY5Pn/ZHw== + "@types/stack-utils@^1.0.1": version "1.0.1" resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-1.0.1.tgz#0a851d3bd96498fa25c33ab7278ed3bd65f06c3e" @@ -1206,6 +1288,54 @@ dependencies: "@types/yargs-parser" "*" +"@typescript-eslint/scope-manager@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.59.8.tgz#ff4ad4fec6433647b817c4a7d4b4165d18ea2fa8" + integrity sha512-/w08ndCYI8gxGf+9zKf1vtx/16y8MHrZs5/tnjHhMLNSixuNcJavSX4wAiPf4aS5x41Es9YPCn44MIe4cxIlig== + dependencies: + "@typescript-eslint/types" "5.59.8" + "@typescript-eslint/visitor-keys" "5.59.8" + +"@typescript-eslint/types@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.59.8.tgz#212e54414733618f5d0fd50b2da2717f630aebf8" + integrity sha512-+uWuOhBTj/L6awoWIg0BlWy0u9TyFpCHrAuQ5bNfxDaZ1Ppb3mx6tUigc74LHcbHpOHuOTOJrBoAnhdHdaea1w== + +"@typescript-eslint/typescript-estree@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.59.8.tgz#801a7b1766481629481b3b0878148bd7a1f345d7" + integrity sha512-Jy/lPSDJGNow14vYu6IrW790p7HIf/SOV1Bb6lZ7NUkLc2iB2Z9elESmsaUtLw8kVqogSbtLH9tut5GCX1RLDg== + dependencies: + "@typescript-eslint/types" "5.59.8" + "@typescript-eslint/visitor-keys" "5.59.8" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + semver "^7.3.7" + tsutils "^3.21.0" + +"@typescript-eslint/utils@^5.10.0": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.59.8.tgz#34d129f35a2134c67fdaf024941e8f96050dca2b" + integrity sha512-Tr65630KysnNn9f9G7ROF3w1b5/7f6QVCJ+WK9nhIocWmx9F+TmCAcglF26Vm7z8KCTwoKcNEBZrhlklla3CKg== + dependencies: + "@eslint-community/eslint-utils" "^4.2.0" + "@types/json-schema" "^7.0.9" + "@types/semver" "^7.3.12" + "@typescript-eslint/scope-manager" "5.59.8" + "@typescript-eslint/types" "5.59.8" + "@typescript-eslint/typescript-estree" "5.59.8" + eslint-scope "^5.1.1" + semver "^7.3.7" + +"@typescript-eslint/visitor-keys@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.59.8.tgz#aa6a7ef862add919401470c09e1609392ef3cc40" + integrity sha512-pJhi2ms0x0xgloT7xYabil3SGGlojNNKjK/q6dB3Ey0uJLMjK2UDGJvHieiyJVW/7C3KI+Z4Q3pEHkm4ejA+xQ== + dependencies: + "@typescript-eslint/types" "5.59.8" + eslint-visitor-keys "^3.3.0" + abab@^2.0.0: version "2.0.6" resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.6.tgz#41b80f2c871d19686216b82309231cfd3cb3d291" @@ -1219,6 +1349,11 @@ acorn-globals@^4.1.0: acorn "^6.0.1" acorn-walk "^6.0.1" +acorn-jsx@^5.3.2: + version "5.3.2" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" + integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== + acorn-walk@^6.0.1: version "6.2.0" resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-6.2.0.tgz#123cb8f3b84c2171f1f7fb252615b1c78a6b1a8c" @@ -1234,7 +1369,12 @@ acorn@^6.0.1: resolved "https://registry.yarnpkg.com/acorn/-/acorn-6.4.2.tgz#35866fd710528e92de10cf06016498e47e39e1e6" integrity sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ== -ajv@^6.12.3: +acorn@^8.8.0: + version "8.8.2" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.2.tgz#1b2f25db02af965399b9776b0c2c391276d37c4a" + integrity sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw== + +ajv@^6.10.0, ajv@^6.12.3, ajv@^6.12.4: version "6.12.6" resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== @@ -1269,6 +1409,11 @@ ansi-regex@^4.0.0, ansi-regex@^4.1.0: resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.1.tgz#164daac87ab2d6f6db3a29875e2d1766582dabed" integrity sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g== +ansi-regex@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" + integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== + ansi-styles@^2.2.1: version "2.2.1" resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz#b432dd3358b634cf75e1e4664368240533c1ddbe" @@ -1281,6 +1426,13 @@ ansi-styles@^3.2.0, ansi-styles@^3.2.1: dependencies: color-convert "^1.9.0" +ansi-styles@^4.1.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" + integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== + dependencies: + color-convert "^2.0.1" + anymatch@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-2.0.0.tgz#bcb24b4f37934d9aa7ac17b4adaf89e7c76ef2eb" @@ -1297,6 +1449,11 @@ anymatch@~3.1.2: normalize-path "^3.0.0" picomatch "^2.0.4" +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + arr-diff@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz#d6461074febfec71e7e15235761a329a5dc7c520" @@ -1317,6 +1474,11 @@ array-equal@^1.0.0: resolved "https://registry.yarnpkg.com/array-equal/-/array-equal-1.0.0.tgz#8c2a5ef2472fd9ea742b04c77a75093ba2757c93" integrity sha512-H3LU5RLiSsGXPhN+Nipar0iR0IofH+8r89G2y1tBKxQ/agagKyAjhkAFDRBfodP2caPrNKHpAWNIM/c9yeL7uA== +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + array-unique@^0.3.2: version "0.3.2" resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428" @@ -1543,7 +1705,7 @@ braces@^2.3.1: split-string "^3.0.2" to-regex "^3.0.1" -braces@~3.0.2: +braces@^3.0.2, braces@~3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== @@ -1655,6 +1817,14 @@ chalk@^2.0.0, chalk@^2.0.1, chalk@^2.4.2: escape-string-regexp "^1.0.5" supports-color "^5.3.0" +chalk@^4.0.0: + version "4.1.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + chokidar@^3.4.0: version "3.5.3" resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd" @@ -1740,11 +1910,23 @@ color-convert@^1.9.0: dependencies: color-name "1.1.3" +color-convert@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" + integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== + dependencies: + color-name "~1.1.4" + color-name@1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== +color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + combined-stream@^1.0.6, combined-stream@~1.0.6: version "1.0.8" resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" @@ -1818,6 +2000,15 @@ cross-spawn@^6.0.0: shebang-command "^1.2.0" which "^1.2.9" +cross-spawn@^7.0.2: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + cssom@0.3.x, "cssom@>= 0.3.2 < 0.4.0": version "0.3.8" resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a" @@ -1853,7 +2044,7 @@ debug@^2.2.0, debug@^2.3.3: dependencies: ms "2.0.0" -debug@^4.1.0, debug@^4.1.1: +debug@^4.1.0, debug@^4.1.1, debug@^4.3.2, debug@^4.3.4: version "4.3.4" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== @@ -1870,7 +2061,7 @@ decode-uri-component@^0.2.0: resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= -deep-is@~0.1.3: +deep-is@^0.1.3, deep-is@~0.1.3: version "0.1.4" resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== @@ -1920,6 +2111,20 @@ diff-sequences@^24.9.0: resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-24.9.0.tgz#5715d6244e2aa65f48bba0bc972db0b0b11e95b5" integrity sha512-Dj6Wk3tWyTE+Fo1rW8v0Xhwk80um6yFYKbuAxc9c3EZxIHFDYwbi34Uk42u1CdnIiVorvt4RmlSDjIPyzGC2ew== +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + +doctrine@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" + integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== + dependencies: + esutils "^2.0.2" + domexception@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/domexception/-/domexception-1.0.1.tgz#937442644ca6a31261ef36e3ec677fe805582c90" @@ -2017,6 +2222,11 @@ escape-string-regexp@^2.0.0: resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz#a30304e99daa32e23b2fd20f51babd07cffca344" integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w== +escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + escodegen@^1.9.1: version "1.14.3" resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-1.14.3.tgz#4e7b81fba61581dc97582ed78cab7f0e8d63f503" @@ -2029,16 +2239,117 @@ escodegen@^1.9.1: optionalDependencies: source-map "~0.6.1" +eslint-plugin-jest@^27.2.1: + version "27.2.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-jest/-/eslint-plugin-jest-27.2.1.tgz#b85b4adf41c682ea29f1f01c8b11ccc39b5c672c" + integrity sha512-l067Uxx7ZT8cO9NJuf+eJHvt6bqJyz2Z29wykyEdz/OtmcELQl2MQGQLX8J94O1cSJWAwUSEvCjwjA7KEK3Hmg== + dependencies: + "@typescript-eslint/utils" "^5.10.0" + +eslint-scope@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" + integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== + dependencies: + esrecurse "^4.3.0" + estraverse "^4.1.1" + +eslint-scope@^7.2.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.2.0.tgz#f21ebdafda02352f103634b96dd47d9f81ca117b" + integrity sha512-DYj5deGlHBfMt15J7rdtyKNq/Nqlv5KfU4iodrQ019XESsRnwXH9KAE0y3cwtUHDo2ob7CypAnCqefh6vioWRw== + dependencies: + esrecurse "^4.3.0" + estraverse "^5.2.0" + +eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.1: + version "3.4.1" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.1.tgz#c22c48f48942d08ca824cc526211ae400478a994" + integrity sha512-pZnmmLwYzf+kWaM/Qgrvpen51upAktaaiI01nsJD/Yr3lMOdNtq0cxkrrg16w64VtisN6okbs7Q8AfGqj4c9fA== + +eslint@^8.41.0: + version "8.41.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.41.0.tgz#3062ca73363b4714b16dbc1e60f035e6134b6f1c" + integrity sha512-WQDQpzGBOP5IrXPo4Hc0814r4/v2rrIsB0rhT7jtunIalgg6gYXWhRMOejVO8yH21T/FGaxjmFjBMNqcIlmH1Q== + dependencies: + "@eslint-community/eslint-utils" "^4.2.0" + "@eslint-community/regexpp" "^4.4.0" + "@eslint/eslintrc" "^2.0.3" + "@eslint/js" "8.41.0" + "@humanwhocodes/config-array" "^0.11.8" + "@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" + +espree@^9.5.2: + version "9.5.2" + resolved "https://registry.yarnpkg.com/espree/-/espree-9.5.2.tgz#e994e7dc33a082a7a82dceaf12883a829353215b" + integrity sha512-7OASN1Wma5fum5SrNhFMAMJxOUAbhyfQ8dQ//PJaJbNw0URTPWqIghHWt1MmAANKhHZIYOHruW4Kw4ruUWOdGw== + dependencies: + acorn "^8.8.0" + acorn-jsx "^5.3.2" + eslint-visitor-keys "^3.4.1" + esprima@^4.0.1: version "4.0.1" resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== -estraverse@^4.2.0: +esquery@^1.4.2: + version "1.5.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b" + integrity sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^4.1.1, estraverse@^4.2.0: version "4.3.0" resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== +estraverse@^5.1.0, estraverse@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + esutils@^2.0.2: version "2.0.3" resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" @@ -2141,21 +2452,39 @@ extsprintf@^1.2.0: resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.4.1.tgz#8d172c064867f235c0c84a596806d279bf4bcc07" integrity sha512-Wrk35e8ydCKDj/ArClo1VrPVmN8zph5V4AtHwIuHhvMXsKf73UT3BOD+azBIW+3wOJ4FhEH7zyaJCFvChjYvMA== -fast-deep-equal@^3.1.1: +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: version "3.1.3" resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== +fast-glob@^3.2.9: + version "3.2.12" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.12.tgz#7f39ec99c2e6ab030337142da9e0c18f37afae80" + integrity sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + fast-json-stable-stringify@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== -fast-levenshtein@~2.0.6: +fast-levenshtein@^2.0.6, fast-levenshtein@~2.0.6: version "2.0.6" resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc= +fastq@^1.6.0: + version "1.15.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a" + integrity sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw== + dependencies: + reusify "^1.0.4" + fb-watchman@^2.0.0: version "2.0.1" resolved "https://registry.yarnpkg.com/fb-watchman/-/fb-watchman-2.0.1.tgz#fc84fb39d2709cf3ff6d743706157bb5708a8a85" @@ -2171,6 +2500,13 @@ figures@^1.3.5: escape-string-regexp "^1.0.5" object-assign "^4.1.0" +file-entry-cache@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" + integrity sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg== + dependencies: + flat-cache "^3.0.4" + file-uri-to-path@1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" @@ -2224,6 +2560,27 @@ find-up@^3.0.0: dependencies: locate-path "^3.0.0" +find-up@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== + dependencies: + locate-path "^6.0.0" + path-exists "^4.0.0" + +flat-cache@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" + integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg== + dependencies: + flatted "^3.1.0" + rimraf "^3.0.2" + +flatted@^3.1.0: + version "3.2.7" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.2.7.tgz#609f39207cb614b89d0765b477cb2d437fbf9787" + integrity sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ== + for-each@^0.3.3: version "0.3.3" resolved "https://registry.yarnpkg.com/for-each/-/for-each-0.3.3.tgz#69b447e88a0a5d32c3e7084f3f1710034b21376e" @@ -2346,13 +2703,20 @@ getpass@^0.1.1: dependencies: assert-plus "^1.0.0" -glob-parent@~5.1.2: +glob-parent@^5.1.2, glob-parent@~5.1.2: version "5.1.2" resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== dependencies: is-glob "^4.0.1" +glob-parent@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + glob@^7.0.0, glob@^7.1.1, glob@^7.1.2, glob@^7.1.3: version "7.2.3" resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" @@ -2370,11 +2734,35 @@ globals@^11.1.0: resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== +globals@^13.19.0: + version "13.20.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.20.0.tgz#ea276a1e508ffd4f1612888f9d1bad1e2717bf82" + integrity sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ== + dependencies: + type-fest "^0.20.2" + +globby@^11.1.0: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" + slash "^3.0.0" + graceful-fs@^4.1.11, graceful-fs@^4.1.15, graceful-fs@^4.1.2: version "4.2.10" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== +graphemer@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/graphemer/-/graphemer-1.4.0.tgz#fb2f1d55e0e3a1849aeffc90c4fa0dd53a0e66c6" + integrity sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag== + growly@^1.3.0: version "1.3.0" resolved "https://registry.yarnpkg.com/growly/-/growly-1.3.0.tgz#f10748cbe76af964b7c96c93c6bcc28af120c081" @@ -2410,6 +2798,11 @@ has-flag@^3.0.0: resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + has-property-descriptors@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz#610708600606d36961ed04c196193b6a607fa861" @@ -2507,6 +2900,19 @@ iconv-lite@0.4.24: dependencies: safer-buffer ">= 2.1.2 < 3" +ignore@^5.2.0: + version "5.2.4" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.4.tgz#a291c0c6178ff1b960befe47fcdec301674a6324" + integrity sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ== + +import-fresh@^3.0.0, import-fresh@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + import-local@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/import-local/-/import-local-2.0.0.tgz#55070be38a5993cf18ef6db7e961f5bee5c5a09d" @@ -2710,7 +3116,7 @@ is-generator-fn@^2.0.0: resolved "https://registry.yarnpkg.com/is-generator-fn/-/is-generator-fn-2.1.0.tgz#7d140adc389aaf3011a8f2a2a4cfa6faadffb118" integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== -is-glob@^4.0.1, is-glob@~4.0.1: +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: version "4.0.3" resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== @@ -2741,6 +3147,11 @@ is-number@^7.0.0: resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== +is-path-inside@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" + integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== + is-plain-object@^2.0.3, is-plain-object@^2.0.4: version "2.0.4" resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" @@ -3235,6 +3646,13 @@ jest@^24.8.0: resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + jsbn@~0.1.0: version "0.1.1" resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" @@ -3297,6 +3715,11 @@ json-schema@0.4.0: resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.4.0.tgz#f7de4cf6efab838ebaeb3236474cbba5a1930ab5" integrity sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA== +json-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== + json-stringify-safe@~5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" @@ -3361,6 +3784,14 @@ leven@^3.1.0: resolved "https://registry.yarnpkg.com/leven/-/leven-3.1.0.tgz#77891de834064cccba82ae7842bb6b14a13ed7f2" integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + levn@~0.3.0: version "0.3.0" resolved "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee" @@ -3395,11 +3826,23 @@ locate-path@^3.0.0: p-locate "^3.0.0" path-exists "^3.0.0" +locate-path@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" + integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== + dependencies: + p-locate "^5.0.0" + lodash.debounce@^4.0.8: version "4.0.8" resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" integrity sha1-gteb/zCmfEAF/9XiUVMArZyk168= +lodash.merge@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" + integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== + lodash.sortby@^4.7.0: version "4.7.0" resolved "https://registry.yarnpkg.com/lodash.sortby/-/lodash.sortby-4.7.0.tgz#edd14c824e2cc9c1e0b0a1b42bb5210516a42438" @@ -3430,6 +3873,13 @@ loose-envify@^1.0.0: dependencies: js-tokens "^3.0.0 || ^4.0.0" +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + make-dir@^2.0.0, make-dir@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5" @@ -3462,6 +3912,11 @@ merge-stream@^2.0.0: resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== +merge2@^1.3.0, merge2@^1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + micromatch@^3.1.10, micromatch@^3.1.4: version "3.1.10" resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.10.tgz#70859bc95c9840952f359a068a3fc49f9ecfac23" @@ -3481,6 +3936,14 @@ micromatch@^3.1.10, micromatch@^3.1.4: snapdragon "^0.8.1" to-regex "^3.0.2" +micromatch@^4.0.4: + version "4.0.5" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" + integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== + dependencies: + braces "^3.0.2" + picomatch "^2.3.1" + mime-db@1.52.0: version "1.52.0" resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" @@ -3493,7 +3956,7 @@ mime-types@^2.1.12, mime-types@~2.1.19: dependencies: mime-db "1.52.0" -minimatch@^3.0.4, minimatch@^3.1.1: +minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== @@ -3727,6 +4190,18 @@ optionator@^0.8.1: type-check "~0.3.2" word-wrap "~1.2.3" +optionator@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" + integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== + 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" + p-each-series@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/p-each-series/-/p-each-series-1.0.0.tgz#930f3d12dd1f50e7434457a22cd6f04ac6ad7f71" @@ -3753,6 +4228,13 @@ p-limit@^2.0.0: dependencies: p-try "^2.0.0" +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + p-locate@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" @@ -3767,6 +4249,13 @@ p-locate@^3.0.0: dependencies: p-limit "^2.0.0" +p-locate@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" + integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== + dependencies: + p-limit "^3.0.2" + p-reduce@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/p-reduce/-/p-reduce-1.0.0.tgz#18c2b0dd936a4690a529f8231f58a0fdb6a47dfa" @@ -3782,6 +4271,13 @@ p-try@^2.0.0: resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + parse-json@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-4.0.0.tgz#be35f5425be1f7f6c747184f98a788cb99477ee0" @@ -3810,6 +4306,11 @@ path-exists@^3.0.0: resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" integrity sha1-zg6+ql94yxiSXqfYENe1mwEP1RU= +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + path-is-absolute@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" @@ -3820,6 +4321,11 @@ path-key@^2.0.0, path-key@^2.0.1: resolved "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz#411cadb574c5a140d3a4b1910d40d80cc9f40b40" integrity sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A= +path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + path-parse@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" @@ -3832,6 +4338,11 @@ path-type@^3.0.0: dependencies: pify "^3.0.0" +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + performance-now@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" @@ -3842,7 +4353,7 @@ picocolors@^1.0.0: resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== -picomatch@^2.0.4, picomatch@^2.2.1: +picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: version "2.3.1" resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== @@ -3886,6 +4397,11 @@ posix-character-classes@^0.1.0: resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab" integrity sha1-AerA/jta9xoqbAL+q7jB/vfgDqs= +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + prelude-ls@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54" @@ -3932,6 +4448,11 @@ qs@~6.5.2: resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.3.tgz#3aeeffc91967ef6e35c0e488ef46fb296ab76aad" integrity sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA== +queue-microtask@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + react-is@^16.8.4: version "16.13.1" resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" @@ -4141,6 +4662,11 @@ resolve-from@^3.0.0: resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-3.0.0.tgz#b22c7af7d9d6881bc8b6e653335eebcb0a188748" integrity sha1-six699nWiBvItuZTM17rywoYh0g= +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + resolve-url@^0.2.1: version "0.2.1" resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a" @@ -4173,6 +4699,11 @@ ret@~0.1.10: resolved "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz#b8a4825d5bdb1fc3f6f53c2bc33f81388681c7bc" integrity sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg== +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + rimraf@^2.5.4, rimraf@^2.6.3: version "2.7.1" resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" @@ -4180,6 +4711,13 @@ rimraf@^2.5.4, rimraf@^2.6.3: dependencies: glob "^7.1.3" +rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + rsvp@^4.8.4: version "4.8.5" resolved "https://registry.yarnpkg.com/rsvp/-/rsvp-4.8.5.tgz#c8f155311d167f68f21e168df71ec5b083113734" @@ -4192,6 +4730,13 @@ run-async@^0.1.0: dependencies: once "^1.3.0" +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + rx-lite@^3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/rx-lite/-/rx-lite-3.1.2.tgz#19ce502ca572665f3b647b10939f97fd1615f102" @@ -4254,6 +4799,13 @@ semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.2.0, semver@^6.3.0: resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== +semver@^7.3.7: + version "7.5.1" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.1.tgz#c90c4d631cf74720e46b21c1d37ea07edfab91ec" + integrity sha512-Wvss5ivl8TMRZXXESstBA4uR5iXgEN/VC5/sOcuXdVLzcdkz4HWetIoRfG5gb5X+ij/G9rw9YoGn3QoQ8OCSpw== + dependencies: + lru-cache "^6.0.0" + set-blocking@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" @@ -4283,11 +4835,23 @@ shebang-command@^1.2.0: dependencies: shebang-regex "^1.0.0" +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + shebang-regex@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3" integrity sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM= +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + shellwords@^0.1.1: version "0.1.1" resolved "https://registry.yarnpkg.com/shellwords/-/shellwords-0.1.1.tgz#d6b9181c1a48d397324c84871efbcfc73fc0654b" @@ -4317,6 +4881,11 @@ slash@^2.0.0: resolved "https://registry.yarnpkg.com/slash/-/slash-2.0.0.tgz#de552851a1759df3a8f206535442f5ec4ddeab44" integrity sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A== +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + snapdragon-node@^2.0.1: version "2.1.1" resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b" @@ -4514,6 +5083,13 @@ strip-ansi@^5.0.0, strip-ansi@^5.1.0, strip-ansi@^5.2.0: dependencies: ansi-regex "^4.1.0" +strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + strip-bom@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" @@ -4524,6 +5100,11 @@ strip-eof@^1.0.0: resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf" integrity sha1-u0P/VZim6wXYm1n80SnJgzE2Br8= +strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + supports-color@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz#535d045ce6b6363fa40117084629995e9df324c7" @@ -4543,6 +5124,13 @@ supports-color@^6.1.0: dependencies: has-flag "^3.0.0" +supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + supports-preserve-symlinks-flag@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" @@ -4563,6 +5151,11 @@ test-exclude@^5.2.3: read-pkg-up "^4.0.0" require-main-filename "^2.0.0" +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + throat@^4.0.0: version "4.1.0" resolved "https://registry.yarnpkg.com/throat/-/throat-4.1.0.tgz#89037cbc92c56ab18926e6ba4cbb200e15672a6a" @@ -4630,6 +5223,18 @@ tr46@^1.0.1: dependencies: punycode "^2.1.0" +tslib@^1.8.1: + version "1.14.1" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tsutils@^3.21.0: + version "3.21.0" + resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" + integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA== + dependencies: + tslib "^1.8.1" + tunnel-agent@^0.6.0: version "0.6.0" resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" @@ -4642,6 +5247,13 @@ tweetnacl@^0.14.3, tweetnacl@~0.14.0: resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" integrity sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q= +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + type-check@~0.3.2: version "0.3.2" resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz#5884cab512cf1d355e3fb784f30804b2b520db72" @@ -4649,6 +5261,11 @@ type-check@~0.3.2: dependencies: prelude-ls "~1.1.2" +type-fest@^0.20.2: + version "0.20.2" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" + integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== + unbox-primitive@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" @@ -4845,7 +5462,14 @@ which@^1.2.9, which@^1.3.0: dependencies: isexe "^2.0.0" -word-wrap@~1.2.3: +which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +word-wrap@^1.2.3, word-wrap@~1.2.3: version "1.2.3" resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== @@ -4898,6 +5522,11 @@ y18n@^4.0.0: resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.3.tgz#b5f259c82cd6e336921efd7bfd8bf560de9eeedf" integrity sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ== +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + yargs-parser@^13.1.2: version "13.1.2" resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-13.1.2.tgz#130f09702ebaeef2650d54ce6e3e5706f7a4fb38" @@ -4921,3 +5550,8 @@ yargs@^13.3.0: which-module "^2.0.0" y18n "^4.0.0" yargs-parser "^13.1.2" + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== From 2cd62a773a326e8c9ca3334fc3612d5fb5e744b5 Mon Sep 17 00:00:00 2001 From: Whitney Date: Sat, 3 Jun 2023 12:54:55 -0700 Subject: [PATCH 02/14] Wave 1 passing tests --- src/adagrams.js | 62 ++++++++++++++++++++++++++++++++++++++----- test/adagrams.test.js | 12 ++++----- 2 files changed, 61 insertions(+), 13 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index 7ec5afc7..9188364f 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -1,15 +1,63 @@ +const LETTER_POOL = { + A: 9, + B: 2, + C: 2, + D: 4, + E: 12, + F: 2, + G: 3, + H: 2, + I: 9, + J: 1, + K: 1, + L: 4, + M: 2, + N: 6, + O: 8, + P: 2, + Q: 1, + R: 6, + S: 4, + T: 6, + U: 4, + V: 2, + W: 2, + X: 1, + Y: 2, + Z: 1, +}; export const drawLetters = () => { - // Implement this method for wave 1 + let letterArray = Object.keys(LETTER_POOL) + let tempLetters = {} + let handSelection = [] + + while (handSelection.length < 10) { + let newNum = Math.floor(Math.random() * (26 + 1)); + let currentLetter = letterArray[newNum]; + if (!(currentLetter in tempLetters)) { + tempLetters[currentLetter] = 1; + } + if (currentLetter in tempLetters) { + if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { + tempLetters[currentLetter] += 1; + handSelection.push(currentLetter); + } + } + else { + continue; + } + } + return handSelection }; -export const usesAvailableLetters = (input, lettersInHand) => { +// export const usesAvailableLetters = (input, lettersInHand) => { // Implement this method for wave 2 -}; +// }; -export const scoreWord = (word) => { +// export const scoreWord = (word) => { // Implement this method for wave 3 -}; +// }; -export const highestScoreFrom = (words) => { +// export const highestScoreFrom = (words) => { // Implement this method for wave 4 -}; +// }; diff --git a/test/adagrams.test.js b/test/adagrams.test.js index 1a0dc94e..89de5727 100644 --- a/test/adagrams.test.js +++ b/test/adagrams.test.js @@ -3,7 +3,7 @@ import { usesAvailableLetters, scoreWord, highestScoreFrom, -} from "adagrams"; +} from 'adagrams'; const LETTER_POOL = { A: 9, @@ -34,15 +34,15 @@ const LETTER_POOL = { Z: 1, }; -describe("Adagrams", () => { - describe("drawLetters", () => { - it("draws ten letters from the letter pool", () => { +describe('Adagrams', () => { + describe('drawLetters', () => { + it('draws ten letters from the letter pool', () => { const drawn = drawLetters(); expect(drawn).toHaveLength(10); }); - it("returns an array, and each item is a single-letter string", () => { + it('returns an array, and each item is a single-letter string', () => { const drawn = drawLetters(); expect(Array.isArray(drawn)).toBe(true); @@ -51,7 +51,7 @@ describe("Adagrams", () => { }); }); - it("does not draw a letter too many times", () => { + it('does not draw a letter too many times', () => { for (let i = 0; i < 1000; i++) { const drawn = drawLetters(); const letter_freq = {}; From 6194fbb3f049b72de36fac11c5ce8b68cc1ea5c8 Mon Sep 17 00:00:00 2001 From: Whitney Date: Sat, 3 Jun 2023 13:41:43 -0700 Subject: [PATCH 03/14] Reworked some logic for wave 01, all tests passing --- src/adagrams.js | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index 9188364f..70384f57 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -34,10 +34,14 @@ export const drawLetters = () => { while (handSelection.length < 10) { let newNum = Math.floor(Math.random() * (26 + 1)); let currentLetter = letterArray[newNum]; - if (!(currentLetter in tempLetters)) { + if (currentLetter === undefined) { + continue; + } + else if (!(currentLetter in tempLetters)) { tempLetters[currentLetter] = 1; + handSelection.push(currentLetter); } - if (currentLetter in tempLetters) { + else if (currentLetter in tempLetters) { if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { tempLetters[currentLetter] += 1; handSelection.push(currentLetter); @@ -50,9 +54,8 @@ export const drawLetters = () => { return handSelection }; -// export const usesAvailableLetters = (input, lettersInHand) => { - // Implement this method for wave 2 -// }; +export const usesAvailableLetters = (input, lettersInHand) => { +}; // export const scoreWord = (word) => { // Implement this method for wave 3 From 884436462a966ccb5f7af12ced864a8e64cd0eb1 Mon Sep 17 00:00:00 2001 From: Whitney Date: Sat, 3 Jun 2023 13:43:41 -0700 Subject: [PATCH 04/14] Reworked Wave 01 logic, all tests passing --- src/adagrams.js | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index 9188364f..c6482853 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -34,10 +34,14 @@ export const drawLetters = () => { while (handSelection.length < 10) { let newNum = Math.floor(Math.random() * (26 + 1)); let currentLetter = letterArray[newNum]; - if (!(currentLetter in tempLetters)) { + if (currentLetter === undefined) { + continue; + } + else if (!(currentLetter in tempLetters)) { tempLetters[currentLetter] = 1; + handSelection.push(currentLetter); } - if (currentLetter in tempLetters) { + else if (currentLetter in tempLetters) { if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { tempLetters[currentLetter] += 1; handSelection.push(currentLetter); From 56e9a369c95939efa5631725d5a36a895a829ca1 Mon Sep 17 00:00:00 2001 From: Whitney Date: Sat, 3 Jun 2023 15:05:18 -0700 Subject: [PATCH 05/14] Refactor wave 01, tests passing --- src/adagrams.js | 41 +++++++++++++++++++++++++++++++++-------- 1 file changed, 33 insertions(+), 8 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index c6482853..d85fb8ee 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -29,9 +29,9 @@ const LETTER_POOL = { export const drawLetters = () => { let letterArray = Object.keys(LETTER_POOL) let tempLetters = {} - let handSelection = [] + let lettersInHand = [] - while (handSelection.length < 10) { + while (lettersInHand.length < 10) { let newNum = Math.floor(Math.random() * (26 + 1)); let currentLetter = letterArray[newNum]; if (currentLetter === undefined) { @@ -39,24 +39,49 @@ export const drawLetters = () => { } else if (!(currentLetter in tempLetters)) { tempLetters[currentLetter] = 1; - handSelection.push(currentLetter); + lettersInHand.push(currentLetter); } else if (currentLetter in tempLetters) { if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { tempLetters[currentLetter] += 1; - handSelection.push(currentLetter); + lettersInHand.push(currentLetter); } } else { continue; } } - return handSelection + return lettersInHand +}; + +export const usesAvailableLetters = (input, lettersInHand) => { + let tempLetters = {} + let capsInput = input.toUpperCase() + // let currentLetter = capsInput[0]; + for (let i = 0; i < capsInput.length; i++) { + let currentLetter = capsInput[i]; + if (!(currentLetter in lettersInHand)) { + return false; + } + else if (currentLetter in lettersInHand) { + if (!(currentLetter in tempLetters)) { + tempLetters[currentLetter] = 1; + // let currentLetter = capsInput[i]; + } + else if (currentLetter in tempLetters) { + tempLetters[currentLetter] += 1; + if (tempLetters[currentLetter] <= lettersInHand[currentLetter]) { + continue; + } + else { + return false; + } + } + } + return true; + } }; -// export const usesAvailableLetters = (input, lettersInHand) => { - // Implement this method for wave 2 -// }; // export const scoreWord = (word) => { // Implement this method for wave 3 From 8a82f87ef7f84b38535ead77bccd4a8af397d2ba Mon Sep 17 00:00:00 2001 From: Whitney Date: Sat, 3 Jun 2023 22:58:58 -0700 Subject: [PATCH 06/14] Forgot to switch branches, no changes, recommiting for safety --- src/adagrams.js | 65 ++++++++++++++++++++++++++++++++----------------- 1 file changed, 43 insertions(+), 22 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index d85fb8ee..a29ac3ca 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -55,31 +55,52 @@ export const drawLetters = () => { }; export const usesAvailableLetters = (input, lettersInHand) => { - let tempLetters = {} - let capsInput = input.toUpperCase() - // let currentLetter = capsInput[0]; - for (let i = 0; i < capsInput.length; i++) { - let currentLetter = capsInput[i]; - if (!(currentLetter in lettersInHand)) { - return false; - } - else if (currentLetter in lettersInHand) { - if (!(currentLetter in tempLetters)) { - tempLetters[currentLetter] = 1; - // let currentLetter = capsInput[i]; + let tempLetters = getLettersInHandObject(lettersInHand); + let inputObject = getInputObject(input); + for (let n = 0; n < input.length; n++) { + let currentLetter = input[n]; + if (currentLetter in tempLetters) { + if (inputObject[currentLetter] <= tempLetters[currentLetter]) { + continue; } - else if (currentLetter in tempLetters) { - tempLetters[currentLetter] += 1; - if (tempLetters[currentLetter] <= lettersInHand[currentLetter]) { - continue; - } - else { - return false; - } - } + else { + return false; } - return true; } + else { + return false; + } + } + return true; +}; + +const getLettersInHandObject = (lettersInHand) => { + let tempLetters = {}; + for (let i = 0; i < lettersInHand.length; i++) { + let letter = lettersInHand[i]; + if (!(letter in tempLetters)) { + tempLetters[letter] = 1; + } + else { + tempLetters[letter] += 1; + } + } + return tempLetters; +}; + +const getInputObject = (input) => { + let capsInput = input.toUpperCase(); + let inputObject = {} + for (let n = 0; n < capsInput.length; n++) { + let currentLetter = capsInput[n]; + if (!(currentLetter in inputObject)) { + inputObject[currentLetter] = 1; + } + else { + inputObject[currentLetter] += 1; + } + } + return inputObject }; From 6026de27b1377ec6c63cbd8a536a3471ed0c160b Mon Sep 17 00:00:00 2001 From: Whitney Date: Sat, 3 Jun 2023 23:37:56 -0700 Subject: [PATCH 07/14] Wave 03 complete, all tests passing --- src/adagrams.js | 47 ++++++++++++++++++++++++++++++++++++++++--- test/adagrams.test.js | 4 +++- 2 files changed, 47 insertions(+), 4 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index a29ac3ca..e875f4a0 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -26,6 +26,37 @@ const LETTER_POOL = { Y: 2, Z: 1, }; + +const SCORE_BOARD = { + A: 1, + B: 3, + C: 3, + D: 2, + E: 1, + F: 4, + G: 2, + H: 4, + I: 1, + J: 8, + K: 5, + L: 1, + M: 3, + N: 1, + O: 1, + P: 3, + Q: 10, + R: 1, + S: 1, + T: 1, + U: 1, + V: 4, + W: 4, + X: 8, + Y: 4, + Z: 10, +}; + + export const drawLetters = () => { let letterArray = Object.keys(LETTER_POOL) let tempLetters = {} @@ -104,9 +135,19 @@ const getInputObject = (input) => { }; -// export const scoreWord = (word) => { - // Implement this method for wave 3 -// }; +export const scoreWord = (word) => { + let score = 0; + let capsWord = word.toUpperCase(); + + for (let i = 0; i < word.length; i++) { + let currentLetter = capsWord[i]; + score += SCORE_BOARD[currentLetter]; + } + if (word.length >= 7) { + score += 8; + } + return score +}; // export const highestScoreFrom = (words) => { // Implement this method for wave 4 diff --git a/test/adagrams.test.js b/test/adagrams.test.js index 89de5727..3f4c754e 100644 --- a/test/adagrams.test.js +++ b/test/adagrams.test.js @@ -120,7 +120,9 @@ describe('Adagrams', () => { }); it("returns a score of 0 if given an empty input", () => { - throw "Complete test"; + expectScores({ + '': 0, + }); }); it("adds an extra 8 points if word is 7 or more characters long", () => { From 3850d05443ed7c9d3ac9a277d4ce65bb05ee0659 Mon Sep 17 00:00:00 2001 From: Whitney Date: Tue, 6 Jun 2023 00:54:07 -0700 Subject: [PATCH 08/14] All features working perfectly in Replit, not trasferring to VSCode --- src/adagrams.js | 86 ++++++++++++++++++++++++++++++++++++------- test/adagrams.test.js | 5 ++- 2 files changed, 76 insertions(+), 15 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index e875f4a0..12e98adc 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -105,6 +105,32 @@ export const usesAvailableLetters = (input, lettersInHand) => { return true; }; +export const scoreWord = (word) => { + let score = 0; + let capsWord = word.toUpperCase(); + + for (let i = 0; i < word.length; i++) { + let currentLetter = capsWord[i]; + score += SCORE_BOARD[currentLetter]; + } + if (word.length >= 7) { + score += 8; + } + return score +}; + +export const highestScoreFrom = (words) => { + let scoreArray = getScoreArray(words); + let highScore = getHighScore(scoreArray); + let potentialWinners = getHighValuePairs(words, scoreArray, highScore); + let lengthArray = getLengths(potentialWinners); + let tieBreaker = getTieBreaker(potentialWinners, lengthArray); + return {"word": tieBreaker, "score": highScore}; +}; + + + + const getLettersInHandObject = (lettersInHand) => { let tempLetters = {}; for (let i = 0; i < lettersInHand.length; i++) { @@ -134,21 +160,55 @@ const getInputObject = (input) => { return inputObject }; +const getScoreArray = (words) => { + let scoreArray = [] + for (let i = 0; i < words.length; i++) { + let currentWord = words[i]; + let currentScore = scoreWord(currentWord); + scoreArray.push(currentScore) + } + return scoreArray; +}; + +const getHighScore = (scoreArray) => { + let highScore = Math.max(...scoreArray) + return highScore; +}; -export const scoreWord = (word) => { - let score = 0; - let capsWord = word.toUpperCase(); - - for (let i = 0; i < word.length; i++) { - let currentLetter = capsWord[i]; - score += SCORE_BOARD[currentLetter]; +const getHighValuePairs = (words, scoreArray, highScore) => { + let potentialWinners = []; + for (let i = 0; i < scoreArray.length; i++) { + let winner = scoreArray[i]; + let winningWord = words[i]; + if (winner === highScore) { + potentialWinners.push(winningWord); + } } - if (word.length >= 7) { - score += 8; + return potentialWinners; +}; + + +const getLengths = (potentialWinners) => { + let lengthArray = [] + for (let i = 0; i < potentialWinners.length; i++) { + let currentWord = potentialWinners[i].length; + lengthArray.push(currentWord); } - return score + return lengthArray }; -// export const highestScoreFrom = (words) => { - // Implement this method for wave 4 -// }; +const getTieBreaker = (potentialWinners, lengthArray) => { + for (let i = 0; i < lengthArray.length; i++) { + let currentWord = potentialWinners[i]; + + let shortestLength = Math.min(...lengthArray); + if (currentWord.length === 10) { + return currentWord; + break; + } + else if (currentWord.length === shortestLength) { + return currentWord; + // break; + } + } +}; diff --git a/test/adagrams.test.js b/test/adagrams.test.js index 3f4c754e..e7683409 100644 --- a/test/adagrams.test.js +++ b/test/adagrams.test.js @@ -135,7 +135,7 @@ describe('Adagrams', () => { }); }); - describe.skip("highestScoreFrom", () => { + describe("highestScoreFrom", () => { it("returns a hash that contains the word and score of best word in an array", () => { const words = ["X", "XX", "XXX", "XXXX"]; const correct = { word: "XXXX", score: scoreWord("XXXX") }; @@ -147,7 +147,8 @@ describe('Adagrams', () => { const words = ["XXX", "XXXX", "X", "XX"]; const correct = { word: "XXXX", score: scoreWord("XXXX") }; - throw "Complete test by adding an assertion"; + // throw "Complete test by adding an assertion"; + expect(highestScoreFrom(words)).toEqual(correct); }); describe("in case of tied score", () => { From e3f10ec4622c7b74613b9d57a4b60f432829b007 Mon Sep 17 00:00:00 2001 From: Whitney Date: Tue, 6 Jun 2023 01:05:57 -0700 Subject: [PATCH 09/14] Wave 04 passing all tests, ready for refactor --- src/adagrams.js | 234 +++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 200 insertions(+), 34 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index 12e98adc..44a42eb4 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -56,7 +56,6 @@ const SCORE_BOARD = { Z: 10, }; - export const drawLetters = () => { let letterArray = Object.keys(LETTER_POOL) let tempLetters = {} @@ -85,6 +84,8 @@ export const drawLetters = () => { return lettersInHand }; + + export const usesAvailableLetters = (input, lettersInHand) => { let tempLetters = getLettersInHandObject(lettersInHand); let inputObject = getInputObject(input); @@ -105,32 +106,6 @@ export const usesAvailableLetters = (input, lettersInHand) => { return true; }; -export const scoreWord = (word) => { - let score = 0; - let capsWord = word.toUpperCase(); - - for (let i = 0; i < word.length; i++) { - let currentLetter = capsWord[i]; - score += SCORE_BOARD[currentLetter]; - } - if (word.length >= 7) { - score += 8; - } - return score -}; - -export const highestScoreFrom = (words) => { - let scoreArray = getScoreArray(words); - let highScore = getHighScore(scoreArray); - let potentialWinners = getHighValuePairs(words, scoreArray, highScore); - let lengthArray = getLengths(potentialWinners); - let tieBreaker = getTieBreaker(potentialWinners, lengthArray); - return {"word": tieBreaker, "score": highScore}; -}; - - - - const getLettersInHandObject = (lettersInHand) => { let tempLetters = {}; for (let i = 0; i < lettersInHand.length; i++) { @@ -160,6 +135,36 @@ const getInputObject = (input) => { return inputObject }; + +export const scoreWord = (word) => { + let score = 0; + let capsWord = word.toUpperCase(); + + for (let i = 0; i < word.length; i++) { + let currentLetter = capsWord[i]; + score += SCORE_BOARD[currentLetter]; + } + if (word.length >= 7) { + score += 8; + } + return score +}; + +export const highestScoreFrom = (words) => { + let scoreArray = getScoreArray(words); + let highScore = getHighScore(scoreArray); + let potentialWinners = getHighValuePairs(words, scoreArray, highScore); + let tenLetterWinner = checkForTen(potentialWinners); + if (tenLetterWinner) { + return {"word": tenLetterWinner, "score": highScore}; + } + else { + let lengthArray = getLengths(potentialWinners); + let tieBreaker = getTieBreaker(potentialWinners, lengthArray); + return {"word": tieBreaker, "score": highScore}; + } +}; + const getScoreArray = (words) => { let scoreArray = [] for (let i = 0; i < words.length; i++) { @@ -187,6 +192,14 @@ const getHighValuePairs = (words, scoreArray, highScore) => { return potentialWinners; }; +const checkForTen = (potentialWinners) => { + for (let i = 0; i < potentialWinners.length; i++) { + let currentWord = potentialWinners[i]; + if (currentWord.length === 10) { + return currentWord; + } + } +}; const getLengths = (potentialWinners) => { let lengthArray = [] @@ -197,18 +210,171 @@ const getLengths = (potentialWinners) => { return lengthArray }; + const getTieBreaker = (potentialWinners, lengthArray) => { for (let i = 0; i < lengthArray.length; i++) { let currentWord = potentialWinners[i]; - + // let currentLength = lengthArray[i]; let shortestLength = Math.min(...lengthArray); - if (currentWord.length === 10) { - return currentWord; - break; - } - else if (currentWord.length === shortestLength) { + if (currentWord.length === shortestLength) { return currentWord; - // break; } } }; + + +// export const drawLetters = () => { +// let letterArray = Object.keys(LETTER_POOL) +// let tempLetters = {} +// let lettersInHand = [] + +// while (lettersInHand.length < 10) { +// let newNum = Math.floor(Math.random() * (26 + 1)); +// let currentLetter = letterArray[newNum]; +// if (currentLetter === undefined) { +// continue; +// } +// else if (!(currentLetter in tempLetters)) { +// tempLetters[currentLetter] = 1; +// lettersInHand.push(currentLetter); +// } +// else if (currentLetter in tempLetters) { +// if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { +// tempLetters[currentLetter] += 1; +// lettersInHand.push(currentLetter); +// } +// } +// else { +// continue; +// } +// } +// return lettersInHand +// }; + +// export const usesAvailableLetters = (input, lettersInHand) => { +// let tempLetters = getLettersInHandObject(lettersInHand); +// let inputObject = getInputObject(input); +// for (let n = 0; n < input.length; n++) { +// let currentLetter = input[n]; +// if (currentLetter in tempLetters) { +// if (inputObject[currentLetter] <= tempLetters[currentLetter]) { +// continue; +// } +// else { +// return false; +// } +// } +// else { +// return false; +// } +// } +// return true; +// }; + +// export const scoreWord = (word) => { +// let score = 0; +// let capsWord = word.toUpperCase(); + +// for (let i = 0; i < word.length; i++) { +// let currentLetter = capsWord[i]; +// score += SCORE_BOARD[currentLetter]; +// } +// if (word.length >= 7) { +// score += 8; +// } +// return score +// }; + +// export const highestScoreFrom = (words) => { +// let scoreArray = getScoreArray(words); +// let highScore = getHighScore(scoreArray); +// let potentialWinners = getHighValuePairs(words, scoreArray, highScore); +// let lengthArray = getLengths(potentialWinners); +// let tieBreaker = getTieBreaker(potentialWinners, lengthArray); +// return {"word": tieBreaker, "score": highScore}; +// }; + + + + +// const getLettersInHandObject = (lettersInHand) => { +// let tempLetters = {}; +// for (let i = 0; i < lettersInHand.length; i++) { +// let letter = lettersInHand[i]; +// if (!(letter in tempLetters)) { +// tempLetters[letter] = 1; +// } +// else { +// tempLetters[letter] += 1; +// } +// } +// return tempLetters; +// }; + +// const getInputObject = (input) => { +// let capsInput = input.toUpperCase(); +// let inputObject = {} +// for (let n = 0; n < capsInput.length; n++) { +// let currentLetter = capsInput[n]; +// if (!(currentLetter in inputObject)) { +// inputObject[currentLetter] = 1; +// } +// else { +// inputObject[currentLetter] += 1; +// } +// } +// return inputObject +// }; + +// const getScoreArray = (words) => { +// let scoreArray = [] +// for (let i = 0; i < words.length; i++) { +// let currentWord = words[i]; +// let currentScore = scoreWord(currentWord); +// scoreArray.push(currentScore) +// } +// return scoreArray; +// }; + +// const getHighScore = (scoreArray) => { +// let highScore = Math.max(...scoreArray) +// return highScore; +// }; + +// const getHighValuePairs = (words, scoreArray, highScore) => { +// let potentialWinners = []; +// for (let i = 0; i < scoreArray.length; i++) { +// let winner = scoreArray[i]; +// let winningWord = words[i]; +// if (winner === highScore) { +// potentialWinners.push(winningWord); +// } +// } +// return potentialWinners; +// }; + + +// const getLengths = (potentialWinners) => { +// let lengthArray = [] +// for (let i = 0; i < potentialWinners.length; i++) { +// let currentWord = potentialWinners[i].length; +// lengthArray.push(currentWord); +// } +// return lengthArray +// }; + +// const getTieBreaker = (potentialWinners, lengthArray) => { +// for (let i = 0; i < lengthArray.length; i++) { +// let currentWord = potentialWinners[i]; + +// let shortestLength = Math.min(...lengthArray); +// if (currentWord.length === 10) { +// return currentWord; +// break; +// } +// else if (currentWord.length === shortestLength) { +// return currentWord; +// // break; +// } +// } +// }; From 46c6dc3a16eacd5cf44da6c0b3f73d7cc2bcaf22 Mon Sep 17 00:00:00 2001 From: Whitney Date: Tue, 6 Jun 2023 18:51:49 -0700 Subject: [PATCH 10/14] First pass at refactoring, all tests passing --- src/adagrams.js | 275 ++++++------------------------------------------ 1 file changed, 30 insertions(+), 245 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index 44a42eb4..72afc663 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -1,61 +1,20 @@ const LETTER_POOL = { - A: 9, - B: 2, - C: 2, - D: 4, - E: 12, - F: 2, - G: 3, - H: 2, - I: 9, - J: 1, - K: 1, - L: 4, - M: 2, - N: 6, - O: 8, - P: 2, - Q: 1, - R: 6, - S: 4, - T: 6, - U: 4, - V: 2, - W: 2, - X: 1, - Y: 2, - Z: 1, + A: 9, B: 2, C: 2, D: 4, E: 12, F: 2, + G: 3, H: 2, I: 9, J: 1, K: 1, L: 4, + M: 2, N: 6, O: 8, P: 2, Q: 1, R: 6, + S: 4, T: 6, U: 4, V: 2, W: 2, X: 1, + Y: 2, Z: 1, }; const SCORE_BOARD = { - A: 1, - B: 3, - C: 3, - D: 2, - E: 1, - F: 4, - G: 2, - H: 4, - I: 1, - J: 8, - K: 5, - L: 1, - M: 3, - N: 1, - O: 1, - P: 3, - Q: 10, - R: 1, - S: 1, - T: 1, - U: 1, - V: 4, - W: 4, - X: 8, - Y: 4, - Z: 10, + A: 1, B: 3, C: 3, D: 2, E: 1, F: 4, + G: 2, H: 4, I: 1, J: 8, K: 5, L: 1, + M: 3, N: 1, O: 1, P: 3, Q: 10, R: 1, + S: 1, T: 1, U: 1, V: 4, W: 4, X: 8, + Y: 4, Z: 10, }; + export const drawLetters = () => { let letterArray = Object.keys(LETTER_POOL) let tempLetters = {} @@ -84,13 +43,11 @@ export const drawLetters = () => { return lettersInHand }; - - export const usesAvailableLetters = (input, lettersInHand) => { - let tempLetters = getLettersInHandObject(lettersInHand); - let inputObject = getInputObject(input); - for (let n = 0; n < input.length; n++) { - let currentLetter = input[n]; + let tempLetters = getNewObject(lettersInHand); + let inputObject = getNewObject(input); + for (let i = 0; i < input.length; i++) { + let currentLetter = input[i]; if (currentLetter in tempLetters) { if (inputObject[currentLetter] <= tempLetters[currentLetter]) { continue; @@ -106,35 +63,19 @@ export const usesAvailableLetters = (input, lettersInHand) => { return true; }; -const getLettersInHandObject = (lettersInHand) => { - let tempLetters = {}; - for (let i = 0; i < lettersInHand.length; i++) { - let letter = lettersInHand[i]; - if (!(letter in tempLetters)) { - tempLetters[letter] = 1; +const getNewObject = (letters) => { + let newObject = {} + for (let i = 0; i < letters.length; i++) { + let currentLetter = letters[i]; + if (!(currentLetter in newObject)) { + newObject[currentLetter] = 1; } else { - tempLetters[letter] += 1; + newObject[currentLetter] += 1; } } - return tempLetters; -}; - -const getInputObject = (input) => { - let capsInput = input.toUpperCase(); - let inputObject = {} - for (let n = 0; n < capsInput.length; n++) { - let currentLetter = capsInput[n]; - if (!(currentLetter in inputObject)) { - inputObject[currentLetter] = 1; - } - else { - inputObject[currentLetter] += 1; - } - } - return inputObject -}; - + return newObject; +} export const scoreWord = (word) => { let score = 0; @@ -153,13 +94,13 @@ export const scoreWord = (word) => { export const highestScoreFrom = (words) => { let scoreArray = getScoreArray(words); let highScore = getHighScore(scoreArray); - let potentialWinners = getHighValuePairs(words, scoreArray, highScore); + let potentialWinners = getPotentialWinners(words, scoreArray, highScore); let tenLetterWinner = checkForTen(potentialWinners); if (tenLetterWinner) { return {"word": tenLetterWinner, "score": highScore}; } else { - let lengthArray = getLengths(potentialWinners); + let lengthArray = getLengthArray(potentialWinners); let tieBreaker = getTieBreaker(potentialWinners, lengthArray); return {"word": tieBreaker, "score": highScore}; } @@ -180,7 +121,7 @@ const getHighScore = (scoreArray) => { return highScore; }; -const getHighValuePairs = (words, scoreArray, highScore) => { +const getPotentialWinners = (words, scoreArray, highScore) => { let potentialWinners = []; for (let i = 0; i < scoreArray.length; i++) { let winner = scoreArray[i]; @@ -201,7 +142,7 @@ const checkForTen = (potentialWinners) => { } }; -const getLengths = (potentialWinners) => { +const getLengthArray = (potentialWinners) => { let lengthArray = [] for (let i = 0; i < potentialWinners.length; i++) { let currentWord = potentialWinners[i].length; @@ -210,11 +151,9 @@ const getLengths = (potentialWinners) => { return lengthArray }; - const getTieBreaker = (potentialWinners, lengthArray) => { for (let i = 0; i < lengthArray.length; i++) { let currentWord = potentialWinners[i]; - // let currentLength = lengthArray[i]; let shortestLength = Math.min(...lengthArray); if (currentWord.length === shortestLength) { return currentWord; @@ -222,159 +161,5 @@ const getTieBreaker = (potentialWinners, lengthArray) => { } }; - -// export const drawLetters = () => { -// let letterArray = Object.keys(LETTER_POOL) -// let tempLetters = {} -// let lettersInHand = [] - -// while (lettersInHand.length < 10) { -// let newNum = Math.floor(Math.random() * (26 + 1)); -// let currentLetter = letterArray[newNum]; -// if (currentLetter === undefined) { -// continue; -// } -// else if (!(currentLetter in tempLetters)) { -// tempLetters[currentLetter] = 1; -// lettersInHand.push(currentLetter); -// } -// else if (currentLetter in tempLetters) { -// if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { -// tempLetters[currentLetter] += 1; -// lettersInHand.push(currentLetter); -// } -// } -// else { -// continue; -// } -// } -// return lettersInHand -// }; - -// export const usesAvailableLetters = (input, lettersInHand) => { -// let tempLetters = getLettersInHandObject(lettersInHand); -// let inputObject = getInputObject(input); -// for (let n = 0; n < input.length; n++) { -// let currentLetter = input[n]; -// if (currentLetter in tempLetters) { -// if (inputObject[currentLetter] <= tempLetters[currentLetter]) { -// continue; -// } -// else { -// return false; -// } -// } -// else { -// return false; -// } -// } -// return true; -// }; - -// export const scoreWord = (word) => { -// let score = 0; -// let capsWord = word.toUpperCase(); - -// for (let i = 0; i < word.length; i++) { -// let currentLetter = capsWord[i]; -// score += SCORE_BOARD[currentLetter]; -// } -// if (word.length >= 7) { -// score += 8; -// } -// return score -// }; - -// export const highestScoreFrom = (words) => { -// let scoreArray = getScoreArray(words); -// let highScore = getHighScore(scoreArray); -// let potentialWinners = getHighValuePairs(words, scoreArray, highScore); -// let lengthArray = getLengths(potentialWinners); -// let tieBreaker = getTieBreaker(potentialWinners, lengthArray); -// return {"word": tieBreaker, "score": highScore}; -// }; - - - - -// const getLettersInHandObject = (lettersInHand) => { -// let tempLetters = {}; -// for (let i = 0; i < lettersInHand.length; i++) { -// let letter = lettersInHand[i]; -// if (!(letter in tempLetters)) { -// tempLetters[letter] = 1; -// } -// else { -// tempLetters[letter] += 1; -// } -// } -// return tempLetters; -// }; - -// const getInputObject = (input) => { -// let capsInput = input.toUpperCase(); -// let inputObject = {} -// for (let n = 0; n < capsInput.length; n++) { -// let currentLetter = capsInput[n]; -// if (!(currentLetter in inputObject)) { -// inputObject[currentLetter] = 1; -// } -// else { -// inputObject[currentLetter] += 1; -// } -// } -// return inputObject -// }; - -// const getScoreArray = (words) => { -// let scoreArray = [] -// for (let i = 0; i < words.length; i++) { -// let currentWord = words[i]; -// let currentScore = scoreWord(currentWord); -// scoreArray.push(currentScore) -// } -// return scoreArray; -// }; - -// const getHighScore = (scoreArray) => { -// let highScore = Math.max(...scoreArray) -// return highScore; -// }; - -// const getHighValuePairs = (words, scoreArray, highScore) => { -// let potentialWinners = []; -// for (let i = 0; i < scoreArray.length; i++) { -// let winner = scoreArray[i]; -// let winningWord = words[i]; -// if (winner === highScore) { -// potentialWinners.push(winningWord); -// } -// } -// return potentialWinners; -// }; - - -// const getLengths = (potentialWinners) => { -// let lengthArray = [] -// for (let i = 0; i < potentialWinners.length; i++) { -// let currentWord = potentialWinners[i].length; -// lengthArray.push(currentWord); -// } -// return lengthArray -// }; - -// const getTieBreaker = (potentialWinners, lengthArray) => { -// for (let i = 0; i < lengthArray.length; i++) { -// let currentWord = potentialWinners[i]; - -// let shortestLength = Math.min(...lengthArray); -// if (currentWord.length === 10) { -// return currentWord; -// break; -// } -// else if (currentWord.length === shortestLength) { -// return currentWord; -// // break; -// } -// } -// }; +// Rename functions and variables whose purpose has changed +// Let vs const usage \ No newline at end of file From 2c25eeca3f23c7fcc48aeb7997f66cabb3da3c0d Mon Sep 17 00:00:00 2001 From: Whitney Date: Tue, 6 Jun 2023 21:09:47 -0700 Subject: [PATCH 11/14] Final Push, Adagrams Completed --- src/adagrams.js | 21 +++++++++------------ 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/src/adagrams.js b/src/adagrams.js index 72afc663..b31b2a42 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -16,9 +16,9 @@ const SCORE_BOARD = { export const drawLetters = () => { - let letterArray = Object.keys(LETTER_POOL) - let tempLetters = {} - let lettersInHand = [] + let letterArray = Object.keys(LETTER_POOL); + let tempLetters = {}; + let lettersInHand = []; while (lettersInHand.length < 10) { let newNum = Math.floor(Math.random() * (26 + 1)); @@ -40,7 +40,7 @@ export const drawLetters = () => { continue; } } - return lettersInHand + return lettersInHand; }; export const usesAvailableLetters = (input, lettersInHand) => { @@ -75,7 +75,7 @@ const getNewObject = (letters) => { } } return newObject; -} +}; export const scoreWord = (word) => { let score = 0; @@ -88,7 +88,7 @@ export const scoreWord = (word) => { if (word.length >= 7) { score += 8; } - return score + return score; }; export const highestScoreFrom = (words) => { @@ -111,13 +111,13 @@ const getScoreArray = (words) => { for (let i = 0; i < words.length; i++) { let currentWord = words[i]; let currentScore = scoreWord(currentWord); - scoreArray.push(currentScore) + scoreArray.push(currentScore); } return scoreArray; }; const getHighScore = (scoreArray) => { - let highScore = Math.max(...scoreArray) + let highScore = Math.max(...scoreArray); return highScore; }; @@ -148,7 +148,7 @@ const getLengthArray = (potentialWinners) => { let currentWord = potentialWinners[i].length; lengthArray.push(currentWord); } - return lengthArray + return lengthArray; }; const getTieBreaker = (potentialWinners, lengthArray) => { @@ -160,6 +160,3 @@ const getTieBreaker = (potentialWinners, lengthArray) => { } } }; - -// Rename functions and variables whose purpose has changed -// Let vs const usage \ No newline at end of file From fb5ca8a0575949b90077e38b2d6b98255417ee87 Mon Sep 17 00:00:00 2001 From: Whitney Date: Tue, 6 Jun 2023 21:36:56 -0700 Subject: [PATCH 12/14] Fixed error found during submission --- src/adagrams.js | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/adagrams.js b/src/adagrams.js index b31b2a42..d1dd1046 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -82,6 +82,9 @@ export const scoreWord = (word) => { let capsWord = word.toUpperCase(); for (let i = 0; i < word.length; i++) { + if (word === "") { + return 0; + } let currentLetter = capsWord[i]; score += SCORE_BOARD[currentLetter]; } From 19d5721712b185898846cca7d3a4a1a46d1c732f Mon Sep 17 00:00:00 2001 From: Whitney Date: Tue, 6 Jun 2023 22:44:37 -0700 Subject: [PATCH 13/14] For real the final push, All tests and demo tests passing --- test/demo/model.test.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/demo/model.test.js b/test/demo/model.test.js index 49bf9599..52ae8d23 100644 --- a/test/demo/model.test.js +++ b/test/demo/model.test.js @@ -1,7 +1,7 @@ import Model from 'demo/model'; import Adagrams from 'demo/adagrams'; -describe.skip('Game Model', () => { +describe('Game Model', () => { const config = { players: [ 'Player A', From 8883a96444716e61174a1de49f48ca8394ec222b Mon Sep 17 00:00:00 2001 From: Whitney Date: Tue, 6 Jun 2023 23:02:17 -0700 Subject: [PATCH 14/14] Had issue merging, corrected --- src/adagrams.js | 168 +++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 167 insertions(+), 1 deletion(-) diff --git a/src/adagrams.js b/src/adagrams.js index 32902cf0..bff75379 100644 --- a/src/adagrams.js +++ b/src/adagrams.js @@ -28,7 +28,7 @@ export const drawLetters = () => { } else if (!(currentLetter in tempLetters)) { tempLetters[currentLetter] = 1; - handSelection.push(currentLetter); + lettersInHand.push(currentLetter); } else if (currentLetter in tempLetters) { if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { @@ -163,3 +163,169 @@ const getTieBreaker = (potentialWinners, lengthArray) => { } } }; + +// const LETTER_POOL = { +// A: 9, B: 2, C: 2, D: 4, E: 12, F: 2, +// G: 3, H: 2, I: 9, J: 1, K: 1, L: 4, +// M: 2, N: 6, O: 8, P: 2, Q: 1, R: 6, +// S: 4, T: 6, U: 4, V: 2, W: 2, X: 1, +// Y: 2, Z: 1, +// }; + +// const SCORE_BOARD = { +// A: 1, B: 3, C: 3, D: 2, E: 1, F: 4, +// G: 2, H: 4, I: 1, J: 8, K: 5, L: 1, +// M: 3, N: 1, O: 1, P: 3, Q: 10, R: 1, +// S: 1, T: 1, U: 1, V: 4, W: 4, X: 8, +// Y: 4, Z: 10, +// }; + + +// export const drawLetters = () => { +// let letterArray = Object.keys(LETTER_POOL); +// let tempLetters = {}; +// let lettersInHand = []; + +// while (lettersInHand.length < 10) { +// let newNum = Math.floor(Math.random() * (26 + 1)); +// let currentLetter = letterArray[newNum]; +// if (currentLetter === undefined) { +// continue; +// } +// else if (!(currentLetter in tempLetters)) { +// tempLetters[currentLetter] = 1; +// handSelection.push(currentLetter); +// } +// else if (currentLetter in tempLetters) { +// if (tempLetters[currentLetter] < LETTER_POOL[currentLetter]) { +// tempLetters[currentLetter] += 1; +// lettersInHand.push(currentLetter); +// } +// } +// else { +// continue; +// } +// } +// return lettersInHand; +// }; + +// export const usesAvailableLetters = (input, lettersInHand) => { +// let tempLetters = getNewObject(lettersInHand); +// let inputObject = getNewObject(input); +// for (let i = 0; i < input.length; i++) { +// let currentLetter = input[i]; +// if (currentLetter in tempLetters) { +// if (inputObject[currentLetter] <= tempLetters[currentLetter]) { +// continue; +// } +// else { +// return false; +// } +// } +// else { +// return false; +// } +// } +// return true; +// }; + +// const getNewObject = (letters) => { +// let newObject = {} +// for (let i = 0; i < letters.length; i++) { +// let currentLetter = letters[i]; +// if (!(currentLetter in newObject)) { +// newObject[currentLetter] = 1; +// } +// else { +// newObject[currentLetter] += 1; +// } +// } +// return newObject; +// }; + +// export const scoreWord = (word) => { +// let score = 0; +// let capsWord = word.toUpperCase(); + +// for (let i = 0; i < word.length; i++) { +// if (word === "") { +// return 0; +// } +// let currentLetter = capsWord[i]; +// score += SCORE_BOARD[currentLetter]; +// } +// if (word.length >= 7) { +// score += 8; +// } +// return score; +// }; + +// export const highestScoreFrom = (words) => { +// let scoreArray = getScoreArray(words); +// let highScore = getHighScore(scoreArray); +// let potentialWinners = getPotentialWinners(words, scoreArray, highScore); +// let tenLetterWinner = checkForTen(potentialWinners); +// if (tenLetterWinner) { +// return {"word": tenLetterWinner, "score": highScore}; +// } +// else { +// let lengthArray = getLengthArray(potentialWinners); +// let tieBreaker = getTieBreaker(potentialWinners, lengthArray); +// return {"word": tieBreaker, "score": highScore}; +// } +// }; + +// const getScoreArray = (words) => { +// let scoreArray = [] +// for (let i = 0; i < words.length; i++) { +// let currentWord = words[i]; +// let currentScore = scoreWord(currentWord); +// scoreArray.push(currentScore); +// } +// return scoreArray; +// }; + +// const getHighScore = (scoreArray) => { +// let highScore = Math.max(...scoreArray); +// return highScore; +// }; + +// const getPotentialWinners = (words, scoreArray, highScore) => { +// let potentialWinners = []; +// for (let i = 0; i < scoreArray.length; i++) { +// let winner = scoreArray[i]; +// let winningWord = words[i]; +// if (winner === highScore) { +// potentialWinners.push(winningWord); +// } +// } +// return potentialWinners; +// }; + +// const checkForTen = (potentialWinners) => { +// for (let i = 0; i < potentialWinners.length; i++) { +// let currentWord = potentialWinners[i]; +// if (currentWord.length === 10) { +// return currentWord; +// } +// } +// }; + +// const getLengthArray = (potentialWinners) => { +// let lengthArray = [] +// for (let i = 0; i < potentialWinners.length; i++) { +// let currentWord = potentialWinners[i].length; +// lengthArray.push(currentWord); +// } +// return lengthArray; +// }; + +// const getTieBreaker = (potentialWinners, lengthArray) => { +// for (let i = 0; i < lengthArray.length; i++) { +// let currentWord = potentialWinners[i]; +// let shortestLength = Math.min(...lengthArray); +// if (currentWord.length === shortestLength) { +// return currentWord; +// } +// } +// };