diff options
author | Surya V <suryav@ami.com> | 2024-07-11 12:49:46 +0300 |
---|---|---|
committer | Ed Tanous <ed@tanous.net> | 2024-10-03 21:34:06 +0300 |
commit | de23ea23d88451a2fa2774ec72053772603c23ae (patch) | |
tree | 8b9a8e7df2a8eebffd4306d8ba805867d5f65bce | |
parent | 883a0d597962dfd30d6c48319b8b33e2d0f98606 (diff) | |
download | webui-vue-de23ea23d88451a2fa2774ec72053772603c23ae.tar.xz |
Vuelidate, I18n, and filter are upgraded to vue3
While navigating to the pages i18n, vuelidate, and filters errors
occurred. i18n, and vuelidate code changes in each page adapted to
vue3. Filter global function for date and time format implemented
in the main.js file and those files which as called the filter
functions.
Change-Id: If1a2ee22d47750faef1c35ef2c263299067d9a20
Signed-off-by: Surya Venkatesan <suryav@ami.com>
102 files changed, 1623 insertions, 1741 deletions
diff --git a/package-lock.json b/package-lock.json index c87bb022..155ad16b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,7 +10,7 @@ "dependencies": { "@carbon/icons-vue": "10.49.1", "@novnc/novnc": "1.3.0", - "@vue/compat": "3.4.25", + "@vue/compat": "3.4.29", "@vue/vue3-jest": "27.0.0", "@vuelidate/core": "2.0.3", "@vuelidate/validators": "2.0.4", @@ -23,11 +23,11 @@ "date-fns-tz": "1.3.6", "js-cookie": "3.0.1", "lodash": "4.17.21", - "vue": "3.2.37", + "vue": "3.4.29", "vue-i18n": "9.13.1", "vue-loader": "17.4.2", - "vue-router": "3.5.1", - "vuex": "3.6.2", + "vue-router": "4.4.0", + "vuex": "4.1.0", "webpack-cli": "5.1.4", "xterm": "4.19.0", "xterm-addon-attach": "0.6.0", @@ -91,7 +91,6 @@ }, "node_modules/@ampproject/remapping": { "version": "2.2.1", - "dev": true, "license": "Apache-2.0", "dependencies": { "@jridgewell/gen-mapping": "^0.3.0", @@ -113,23 +112,16 @@ "node": ">=6.9.0" } }, - "node_modules/@babel/code-frame/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==" - }, "node_modules/@babel/compat-data": { "version": "7.24.7", "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.24.7.tgz", "integrity": "sha512-qJzAIcv03PyaWqxRgO4mSU3lihncDT296vnyuE2O8uA4w3UHWI4S3hgeZd1L8W1Bft40w9JxJ2b412iDUFFRhw==", - "dev": true, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/core": { "version": "7.23.9", - "dev": true, "license": "MIT", "dependencies": { "@ampproject/remapping": "^2.2.0", @@ -199,7 +191,6 @@ "version": "7.24.7", "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.24.7.tgz", "integrity": "sha512-ctSdRHBi20qWOfy27RUb4Fhp07KSJ3sXcuSvTrXrc4aG8NSYDo1ici3Vhg9bg69y5bj0Mr1lh0aeEgTvc12rMg==", - "dev": true, "dependencies": { "@babel/compat-data": "^7.24.7", "@babel/helper-validator-option": "^7.24.7", @@ -465,7 +456,6 @@ "version": "7.24.7", "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.7.tgz", "integrity": "sha512-yy1/KvjhV/ZCL+SM7hBrvnZJ3ZuT9OuZgIJAGpPEToANvc3iM6iDvBnRjtElWibHU6n8/LPR/EjX9EtIEYO3pw==", - "dev": true, "engines": { "node": ">=6.9.0" } @@ -487,7 +477,6 @@ }, "node_modules/@babel/helpers": { "version": "7.23.9", - "dev": true, "license": "MIT", "dependencies": { "@babel/template": "^7.23.9", @@ -512,11 +501,6 @@ "node": ">=6.9.0" } }, - "node_modules/@babel/highlight/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==" - }, "node_modules/@babel/parser": { "version": "7.24.7", "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.7.tgz", @@ -642,7 +626,6 @@ "version": "7.8.4", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.8.0" }, @@ -654,7 +637,6 @@ "version": "7.8.3", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.8.0" }, @@ -666,7 +648,6 @@ "version": "7.12.13", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.12.13" }, @@ -762,7 +743,6 @@ "version": "7.10.4", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.10.4" }, @@ -774,7 +754,6 @@ "version": "7.8.3", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.8.0" }, @@ -801,7 +780,6 @@ "version": "7.10.4", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.10.4" }, @@ -813,7 +791,6 @@ "version": "7.8.3", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.8.0" }, @@ -825,7 +802,6 @@ "version": "7.10.4", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.10.4" }, @@ -837,7 +813,6 @@ "version": "7.8.3", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.8.0" }, @@ -849,7 +824,6 @@ "version": "7.8.3", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.8.0" }, @@ -861,7 +835,6 @@ "version": "7.8.3", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.8.0" }, @@ -888,7 +861,6 @@ "version": "7.14.5", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.14.5" }, @@ -903,7 +875,6 @@ "version": "7.24.7", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.24.7.tgz", "integrity": "sha512-c/+fVeJBB0FeKsFvwytYiUD+LBvhHjGSI0g446PRGdSVGZLRNArBUno2PETbAly3tpiNAQR5XaZ+JslxkotsbA==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.24.7" }, @@ -1922,8 +1893,7 @@ "node_modules/@bcoe/v8-coverage": { "version": "0.2.3", "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", - "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", - "dev": true + "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==" }, "node_modules/@carbon/icon-helpers": { "version": "10.46.0", @@ -2240,7 +2210,6 @@ "version": "1.1.0", "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", - "dev": true, "dependencies": { "camelcase": "^5.3.1", "find-up": "^4.1.0", @@ -2256,7 +2225,6 @@ "version": "5.3.1", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true, "engines": { "node": ">=6" } @@ -2265,7 +2233,6 @@ "version": "0.1.3", "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", - "dev": true, "engines": { "node": ">=8" } @@ -2274,7 +2241,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/console/-/console-27.5.1.tgz", "integrity": "sha512-kZ/tNpS3NXn0mlXXXPNuDZnb4c0oZ20r4K5eemM2k30ZC3G0T02nXUvyhf5YdbXWHPEJLc9qGLxEZ216MdL+Zg==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "@types/node": "*", @@ -2291,7 +2257,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -2306,7 +2271,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -2322,7 +2286,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -2333,14 +2296,12 @@ "node_modules/@jest/console/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/@jest/console/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -2349,7 +2310,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -2361,7 +2321,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/core/-/core-27.5.1.tgz", "integrity": "sha512-AK6/UTrvQD0Cd24NSqmIA6rKsu0tKIxfiCducZvqxYdmMisOYAsdItspT+fQDQYARPf8XgjAFZi0ogW2agH5nQ==", - "dev": true, "dependencies": { "@jest/console": "^27.5.1", "@jest/reporters": "^27.5.1", @@ -2408,7 +2367,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -2423,7 +2381,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -2439,7 +2396,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -2450,14 +2406,12 @@ "node_modules/@jest/core/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/@jest/core/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -2466,7 +2420,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -2478,7 +2431,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-27.5.1.tgz", "integrity": "sha512-/WQjhPJe3/ghaol/4Bq480JKXV/Rfw8nQdN7f41fM8VDHLcxKXou6QyXAh3EFr9/bVG3x74z1NWDkP87EiY8gA==", - "dev": true, "dependencies": { "@jest/fake-timers": "^27.5.1", "@jest/types": "^27.5.1", @@ -2493,7 +2445,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-27.5.1.tgz", "integrity": "sha512-/aPowoolwa07k7/oM3aASneNeBGCmGQsc3ugN4u6s4C/+s5M64MFo/+djTdiwcbQlRfFElGuDXWzaWj6QgKObQ==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "@sinonjs/fake-timers": "^8.0.1", @@ -2510,7 +2461,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-27.5.1.tgz", "integrity": "sha512-ZEJNB41OBQQgGzgyInAv0UUfDDj3upmHydjieSxFvTRuZElrx7tXg/uVQ5hYVEwiXs3+aMsAeEc9X7xiSKCm4Q==", - "dev": true, "dependencies": { "@jest/environment": "^27.5.1", "@jest/types": "^27.5.1", @@ -2524,7 +2474,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-27.5.1.tgz", "integrity": "sha512-cPXh9hWIlVJMQkVk84aIvXuBB4uQQmFqZiacloFuGiP3ah1sbCxCosidXFDfqG8+6fO1oR2dTJTlsOy4VFmUfw==", - "dev": true, "dependencies": { "@bcoe/v8-coverage": "^0.2.3", "@jest/console": "^27.5.1", @@ -2568,7 +2517,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -2583,7 +2531,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -2599,7 +2546,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -2610,14 +2556,12 @@ "node_modules/@jest/reporters/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/@jest/reporters/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -2626,7 +2570,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -2650,7 +2593,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-27.5.1.tgz", "integrity": "sha512-y9NIHUYF3PJRlHk98NdC/N1gl88BL08aQQgu4k4ZopQkCw9t9cV8mtl3TV8b/YCB8XaVTFrmUTAJvjsntDireg==", - "dev": true, "dependencies": { "callsites": "^3.0.0", "graceful-fs": "^4.2.9", @@ -2664,7 +2606,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-27.5.1.tgz", "integrity": "sha512-EW35l2RYFUcUQxFJz5Cv5MTOxlJIQs4I7gxzi2zVU7PJhOwfYq1MdC5nhSmYjX1gmMmLPvB3sIaC+BkcHRBfag==", - "dev": true, "dependencies": { "@jest/console": "^27.5.1", "@jest/types": "^27.5.1", @@ -2679,7 +2620,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-27.5.1.tgz", "integrity": "sha512-LCheJF7WB2+9JuCS7VB/EmGIdQuhtqjRNI9A43idHv3E4KltCTsPsLxvdaubFHSYwY/fNjMWjl6vNRhDiN7vpQ==", - "dev": true, "dependencies": { "@jest/test-result": "^27.5.1", "graceful-fs": "^4.2.9", @@ -2694,7 +2634,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-27.5.1.tgz", "integrity": "sha512-ipON6WtYgl/1329g5AIJVbUuEh0wZVbdpGwC99Jw4LwuoBNS95MVphU6zOeD9pDkon+LLbFL7lOQRapbB8SCHw==", - "dev": true, "dependencies": { "@babel/core": "^7.1.0", "@jest/types": "^27.5.1", @@ -2720,7 +2659,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -2735,7 +2673,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -2751,7 +2688,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -2762,20 +2698,17 @@ "node_modules/@jest/transform/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/@jest/transform/node_modules/convert-source-map": { "version": "1.9.0", "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true + "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==" }, "node_modules/@jest/transform/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -2784,7 +2717,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -2796,7 +2728,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.1.tgz", "integrity": "sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw==", - "dev": true, "dependencies": { "@types/istanbul-lib-coverage": "^2.0.0", "@types/istanbul-reports": "^3.0.0", @@ -2812,7 +2743,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -2827,7 +2757,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -2843,7 +2772,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -2854,14 +2782,12 @@ "node_modules/@jest/types/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/@jest/types/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -2870,7 +2796,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -2910,7 +2835,6 @@ "version": "0.3.6", "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.6.tgz", "integrity": "sha512-1ZJTZebgqllO79ue2bm3rIGud/bOe0pP5BjSRCRxxYkEZS8STV7zN84UBbiYu7jy+eCKSnVIUgoWWE/tt+shMQ==", - "dev": true, "dependencies": { "@jridgewell/gen-mapping": "^0.3.5", "@jridgewell/trace-mapping": "^0.3.25" @@ -3152,7 +3076,6 @@ "version": "1.8.6", "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.6.tgz", "integrity": "sha512-Ky+XkAkqPZSm3NLBeUng77EBQl3cmeJhITaGHdYH8kjVB+aun3S4XBRti2zt17mtt0mIUDiNxYeoJm6drVvBJQ==", - "dev": true, "dependencies": { "type-detect": "4.0.8" } @@ -3161,7 +3084,6 @@ "version": "8.1.0", "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz", "integrity": "sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg==", - "dev": true, "dependencies": { "@sinonjs/commons": "^1.7.0" } @@ -3264,7 +3186,6 @@ "version": "1.1.2", "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", - "dev": true, "engines": { "node": ">= 6" } @@ -3282,7 +3203,6 @@ "version": "7.20.5", "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", - "dev": true, "dependencies": { "@babel/parser": "^7.20.7", "@babel/types": "^7.20.7", @@ -3295,7 +3215,6 @@ "version": "7.6.8", "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", - "dev": true, "dependencies": { "@babel/types": "^7.0.0" } @@ -3304,7 +3223,6 @@ "version": "7.4.4", "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", - "dev": true, "dependencies": { "@babel/parser": "^7.1.0", "@babel/types": "^7.0.0" @@ -3314,7 +3232,6 @@ "version": "7.20.6", "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.6.tgz", "integrity": "sha512-r1bzfrm0tomOI8g1SzvCaQHo6Lcv6zu0EA+W2kHrt8dyrHQxGzBBL4kdkzIS+jBMV+EYcMAEAqXqYaLJq5rOZg==", - "dev": true, "dependencies": { "@babel/types": "^7.20.7" } @@ -3359,7 +3276,6 @@ }, "node_modules/@types/eslint": { "version": "8.56.3", - "dev": true, "license": "MIT", "dependencies": { "@types/estree": "*", @@ -3368,7 +3284,6 @@ }, "node_modules/@types/eslint-scope": { "version": "3.7.7", - "dev": true, "license": "MIT", "dependencies": { "@types/eslint": "*", @@ -3377,7 +3292,6 @@ }, "node_modules/@types/estree": { "version": "1.0.5", - "dev": true, "license": "MIT" }, "node_modules/@types/express": { @@ -3418,7 +3332,6 @@ "version": "4.1.9", "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.9.tgz", "integrity": "sha512-olP3sd1qOEe5dXTSaFvQG+02VdRXcdytWLAZsAq1PecU8uqQAhkrnbli7DagjtXKW/Bl7YJbUsa8MPcuc8LHEQ==", - "dev": true, "dependencies": { "@types/node": "*" } @@ -3453,14 +3366,12 @@ "node_modules/@types/istanbul-lib-coverage": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", - "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==", - "dev": true + "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==" }, "node_modules/@types/istanbul-lib-report": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.3.tgz", "integrity": "sha512-NQn7AHQnk/RSLOxrBbGyJM/aVQ+pjj5HCgasFxc0K/KhoATfQ/47AyUl15I2yBUpihjmas+a+VJBOqecrFH+uA==", - "dev": true, "dependencies": { "@types/istanbul-lib-coverage": "*" } @@ -3469,7 +3380,6 @@ "version": "3.0.4", "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.4.tgz", "integrity": "sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==", - "dev": true, "dependencies": { "@types/istanbul-lib-report": "*" } @@ -3486,7 +3396,6 @@ }, "node_modules/@types/json-schema": { "version": "7.0.15", - "dev": true, "license": "MIT" }, "node_modules/@types/linkify-it": { @@ -3543,7 +3452,6 @@ }, "node_modules/@types/node": { "version": "20.11.20", - "dev": true, "license": "MIT", "dependencies": { "undici-types": "~5.26.4" @@ -3572,8 +3480,7 @@ "node_modules/@types/prettier": { "version": "2.7.3", "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.3.tgz", - "integrity": "sha512-+68kP9yzs4LMp7VNh8gdzMSPZFL44MLGqiHWvttYJe+6qnuVr4Ek9wSBQoveqY/r+LwjCcU29kNVkidwim+kYA==", - "dev": true + "integrity": "sha512-+68kP9yzs4LMp7VNh8gdzMSPZFL44MLGqiHWvttYJe+6qnuVr4Ek9wSBQoveqY/r+LwjCcU29kNVkidwim+kYA==" }, "node_modules/@types/q": { "version": "1.5.8", @@ -3646,8 +3553,7 @@ "node_modules/@types/stack-utils": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.3.tgz", - "integrity": "sha512-9aEbYZ3TbYMznPdcdr3SmIrLXwC/AKZXQeCf9Pgao5CKb8CyHuEX5jzWPTkvregvhRJHcpRO6BFoGW9ycaOkYw==", - "dev": true + "integrity": "sha512-9aEbYZ3TbYMznPdcdr3SmIrLXwC/AKZXQeCf9Pgao5CKb8CyHuEX5jzWPTkvregvhRJHcpRO6BFoGW9ycaOkYw==" }, "node_modules/@types/strip-bom": { "version": "3.0.0", @@ -3734,7 +3640,6 @@ "version": "16.0.9", "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.9.tgz", "integrity": "sha512-tHhzvkFXZQeTECenFoRljLBYPZJ7jAVxqqtEI0qTLOmuultnFp4I9yKE17vTuhf7BkhCu7I4XuemPgikDVuYqA==", - "dev": true, "dependencies": { "@types/yargs-parser": "*" } @@ -3742,8 +3647,7 @@ "node_modules/@types/yargs-parser": { "version": "21.0.3", "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz", - "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==", - "dev": true + "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==" }, "node_modules/@vue/babel-helper-vue-jsx-merge-props": { "version": "1.4.0", @@ -4289,40 +4193,6 @@ } } }, - "node_modules/@vue/cli-service/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", - "dev": true - }, - "node_modules/@vue/cli-service/node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "dependencies": { - "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } - }, "node_modules/@vue/cli-service/node_modules/postcss-loader": { "version": "6.2.1", "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-6.2.1.tgz", @@ -4478,16 +4348,16 @@ "dev": true }, "node_modules/@vue/compat": { - "version": "3.4.25", - "resolved": "https://registry.npmjs.org/@vue/compat/-/compat-3.4.25.tgz", - "integrity": "sha512-Gnl8h5LXzf0nVA82j2hBSi61aiMec/h0uduZmOWfTrBbREgHIPpbfpJrl3XRNbJQX6joMyEwkZr8uL0tClZS+w==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compat/-/compat-3.4.29.tgz", + "integrity": "sha512-AUHFAvHycdL23N9ntJUd28yCt0Mbcy8dFVdHv1mTJ61/AVa5iTnlBwHgFPs6DAirln/TMWTfEWHqzUtQWnjOKw==", "dependencies": { - "@babel/parser": "^7.24.4", + "@babel/parser": "^7.24.7", "estree-walker": "^2.0.2", "source-map-js": "^1.2.0" }, "peerDependencies": { - "vue": "3.4.25" + "vue": "3.4.29" } }, "node_modules/@vue/compiler-core": { @@ -4530,38 +4400,6 @@ "source-map-js": "^1.0.2" } }, - "node_modules/@vue/compiler-sfc/node_modules/picocolors": { - "version": "1.0.0", - "dev": true, - "license": "ISC" - }, - "node_modules/@vue/compiler-sfc/node_modules/postcss": { - "version": "8.4.35", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "license": "MIT", - "dependencies": { - "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.0.2" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } - }, "node_modules/@vue/compiler-ssr": { "version": "3.4.21", "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.4.21.tgz", @@ -4604,6 +4442,29 @@ "yallist": "^2.1.2" } }, + "node_modules/@vue/component-compiler-utils/node_modules/picocolors": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-0.2.1.tgz", + "integrity": "sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA==", + "dev": true + }, + "node_modules/@vue/component-compiler-utils/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/@vue/component-compiler-utils/node_modules/prettier": { "version": "2.8.8", "dev": true, @@ -4643,128 +4504,94 @@ } }, "node_modules/@vue/reactivity": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/reactivity/-/reactivity-3.2.37.tgz", - "integrity": "sha512-/7WRafBOshOc6m3F7plwzPeCu/RCVv9uMpOwa/5PiY1Zz+WLVRWiy0MYKwmg19KBdGtFWsmZ4cD+LOdVPcs52A==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/reactivity/-/reactivity-3.4.29.tgz", + "integrity": "sha512-w8+KV+mb1a8ornnGQitnMdLfE0kXmteaxLdccm2XwdFxXst4q/Z7SEboCV5SqJNpZbKFeaRBBJBhW24aJyGINg==", "dependencies": { - "@vue/shared": "3.2.37" - } - }, - "node_modules/@vue/reactivity-transform": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/reactivity-transform/-/reactivity-transform-3.2.37.tgz", - "integrity": "sha512-IWopkKEb+8qpu/1eMKVeXrK0NLw9HicGviJzhJDEyfxTR9e1WtpnnbYkJWurX6WwoFP0sz10xQg8yL8lgskAZg==", - "dependencies": { - "@babel/parser": "^7.16.4", - "@vue/compiler-core": "3.2.37", - "@vue/shared": "3.2.37", - "estree-walker": "^2.0.2", - "magic-string": "^0.25.7" - } - }, - "node_modules/@vue/reactivity-transform/node_modules/@vue/compiler-core": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.37.tgz", - "integrity": "sha512-81KhEjo7YAOh0vQJoSmAD68wLfYqJvoiD4ulyedzF+OEk/bk6/hx3fTNVfuzugIIaTrOx4PGx6pAiBRe5e9Zmg==", - "dependencies": { - "@babel/parser": "^7.16.4", - "@vue/shared": "3.2.37", - "estree-walker": "^2.0.2", - "source-map": "^0.6.1" - } - }, - "node_modules/@vue/reactivity-transform/node_modules/@vue/shared": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.37.tgz", - "integrity": "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" - }, - "node_modules/@vue/reactivity-transform/node_modules/magic-string": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", - "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", - "dependencies": { - "sourcemap-codec": "^1.4.8" + "@vue/shared": "3.4.29" } }, "node_modules/@vue/reactivity/node_modules/@vue/shared": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.37.tgz", - "integrity": "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.4.29.tgz", + "integrity": "sha512-hQ2gAQcBO/CDpC82DCrinJNgOHI2v+FA7BDW4lMSPeBpQ7sRe2OLHWe5cph1s7D8DUQAwRt18dBDfJJ220APEA==" }, "node_modules/@vue/runtime-core": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/runtime-core/-/runtime-core-3.2.37.tgz", - "integrity": "sha512-JPcd9kFyEdXLl/i0ClS7lwgcs0QpUAWj+SKX2ZC3ANKi1U4DOtiEr6cRqFXsPwY5u1L9fAjkinIdB8Rz3FoYNQ==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/runtime-core/-/runtime-core-3.4.29.tgz", + "integrity": "sha512-s8fmX3YVR/Rk5ig0ic0NuzTNjK2M7iLuVSZyMmCzN/+Mjuqqif1JasCtEtmtoJWF32pAtUjyuT2ljNKNLeOmnQ==", "dependencies": { - "@vue/reactivity": "3.2.37", - "@vue/shared": "3.2.37" + "@vue/reactivity": "3.4.29", + "@vue/shared": "3.4.29" } }, "node_modules/@vue/runtime-core/node_modules/@vue/shared": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.37.tgz", - "integrity": "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.4.29.tgz", + "integrity": "sha512-hQ2gAQcBO/CDpC82DCrinJNgOHI2v+FA7BDW4lMSPeBpQ7sRe2OLHWe5cph1s7D8DUQAwRt18dBDfJJ220APEA==" }, "node_modules/@vue/runtime-dom": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/runtime-dom/-/runtime-dom-3.2.37.tgz", - "integrity": "sha512-HimKdh9BepShW6YozwRKAYjYQWg9mQn63RGEiSswMbW+ssIht1MILYlVGkAGGQbkhSh31PCdoUcfiu4apXJoPw==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/runtime-dom/-/runtime-dom-3.4.29.tgz", + "integrity": "sha512-gI10atCrtOLf/2MPPMM+dpz3NGulo9ZZR9d1dWo4fYvm+xkfvRrw1ZmJ7mkWtiJVXSsdmPbcK1p5dZzOCKDN0g==", "dependencies": { - "@vue/runtime-core": "3.2.37", - "@vue/shared": "3.2.37", - "csstype": "^2.6.8" + "@vue/reactivity": "3.4.29", + "@vue/runtime-core": "3.4.29", + "@vue/shared": "3.4.29", + "csstype": "^3.1.3" } }, "node_modules/@vue/runtime-dom/node_modules/@vue/shared": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.37.tgz", - "integrity": "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.4.29.tgz", + "integrity": "sha512-hQ2gAQcBO/CDpC82DCrinJNgOHI2v+FA7BDW4lMSPeBpQ7sRe2OLHWe5cph1s7D8DUQAwRt18dBDfJJ220APEA==" }, "node_modules/@vue/server-renderer": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/server-renderer/-/server-renderer-3.2.37.tgz", - "integrity": "sha512-kLITEJvaYgZQ2h47hIzPh2K3jG8c1zCVbp/o/bzQOyvzaKiCquKS7AaioPI28GNxIsE/zSx+EwWYsNxDCX95MA==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/server-renderer/-/server-renderer-3.4.29.tgz", + "integrity": "sha512-HMLCmPI2j/k8PVkSBysrA2RxcxC5DgBiCdj7n7H2QtR8bQQPqKAe8qoaxLcInzouBmzwJ+J0x20ygN/B5mYBng==", "dependencies": { - "@vue/compiler-ssr": "3.2.37", - "@vue/shared": "3.2.37" + "@vue/compiler-ssr": "3.4.29", + "@vue/shared": "3.4.29" }, "peerDependencies": { - "vue": "3.2.37" + "vue": "3.4.29" } }, "node_modules/@vue/server-renderer/node_modules/@vue/compiler-core": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.37.tgz", - "integrity": "sha512-81KhEjo7YAOh0vQJoSmAD68wLfYqJvoiD4ulyedzF+OEk/bk6/hx3fTNVfuzugIIaTrOx4PGx6pAiBRe5e9Zmg==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.4.29.tgz", + "integrity": "sha512-TFKiRkKKsRCKvg/jTSSKK7mYLJEQdUiUfykbG49rubC9SfDyvT2JrzTReopWlz2MxqeLyxh9UZhvxEIBgAhtrg==", "dependencies": { - "@babel/parser": "^7.16.4", - "@vue/shared": "3.2.37", + "@babel/parser": "^7.24.7", + "@vue/shared": "3.4.29", + "entities": "^4.5.0", "estree-walker": "^2.0.2", - "source-map": "^0.6.1" + "source-map-js": "^1.2.0" } }, "node_modules/@vue/server-renderer/node_modules/@vue/compiler-dom": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.2.37.tgz", - "integrity": "sha512-yxJLH167fucHKxaqXpYk7x8z7mMEnXOw3G2q62FTkmsvNxu4FQSu5+3UMb+L7fjKa26DEzhrmCxAgFLLIzVfqQ==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.4.29.tgz", + "integrity": "sha512-A6+iZ2fKIEGnfPJejdB7b1FlJzgiD+Y/sxxKwJWg1EbJu6ZPgzaPQQ51ESGNv0CP6jm6Z7/pO6Ia8Ze6IKrX7w==", "dependencies": { - "@vue/compiler-core": "3.2.37", - "@vue/shared": "3.2.37" + "@vue/compiler-core": "3.4.29", + "@vue/shared": "3.4.29" } }, "node_modules/@vue/server-renderer/node_modules/@vue/compiler-ssr": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.2.37.tgz", - "integrity": "sha512-7mQJD7HdXxQjktmsWp/J67lThEIcxLemz1Vb5I6rYJHR5vI+lON3nPGOH3ubmbvYGt8xEUaAr1j7/tIFWiEOqw==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.4.29.tgz", + "integrity": "sha512-rFbwCmxJ16tDp3N8XCx5xSQzjhidYjXllvEcqX/lopkoznlNPz3jyy0WGJCyhAaVQK677WWFt3YO/WUEkMMUFQ==", "dependencies": { - "@vue/compiler-dom": "3.2.37", - "@vue/shared": "3.2.37" + "@vue/compiler-dom": "3.4.29", + "@vue/shared": "3.4.29" } }, "node_modules/@vue/server-renderer/node_modules/@vue/shared": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.37.tgz", - "integrity": "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.4.29.tgz", + "integrity": "sha512-hQ2gAQcBO/CDpC82DCrinJNgOHI2v+FA7BDW4lMSPeBpQ7sRe2OLHWe5cph1s7D8DUQAwRt18dBDfJJ220APEA==" }, "node_modules/@vue/shared": { "version": "3.4.21", @@ -5044,34 +4871,6 @@ "prettier": "^1.18.2 || ^2.0.0" } }, - "node_modules/@vuepress/core/node_modules/@vue/compiler-sfc/node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "dependencies": { - "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } - }, "node_modules/@vuepress/core/node_modules/@webassemblyjs/ast": { "version": "1.9.0", "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz", @@ -5438,11 +5237,22 @@ "webpack": "^4.0.0" } }, - "node_modules/@vuepress/core/node_modules/csstype": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", - "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", - "dev": true + "node_modules/@vuepress/core/node_modules/css-loader/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } }, "node_modules/@vuepress/core/node_modules/define-property": { "version": "2.0.2", @@ -5662,6 +5472,23 @@ "node": ">= 6" } }, + "node_modules/@vuepress/core/node_modules/icss-utils/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/@vuepress/core/node_modules/ignore": { "version": "3.3.10", "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", @@ -5981,9 +5808,9 @@ } }, "node_modules/@vuepress/core/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-0.2.1.tgz", + "integrity": "sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA==", "dev": true }, "node_modules/@vuepress/core/node_modules/pkg-dir": { @@ -6013,6 +5840,23 @@ "node": ">= 6" } }, + "node_modules/@vuepress/core/node_modules/postcss-loader/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/@vuepress/core/node_modules/postcss-modules-extract-imports": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-2.0.0.tgz", @@ -6025,6 +5869,23 @@ "node": ">= 6" } }, + "node_modules/@vuepress/core/node_modules/postcss-modules-extract-imports/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/@vuepress/core/node_modules/postcss-modules-local-by-default": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-2.0.6.tgz", @@ -6039,6 +5900,23 @@ "node": ">= 6" } }, + "node_modules/@vuepress/core/node_modules/postcss-modules-local-by-default/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/@vuepress/core/node_modules/postcss-modules-scope": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-2.2.0.tgz", @@ -6052,6 +5930,23 @@ "node": ">= 6" } }, + "node_modules/@vuepress/core/node_modules/postcss-modules-scope/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/@vuepress/core/node_modules/postcss-modules-values": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-2.0.0.tgz", @@ -6062,6 +5957,23 @@ "postcss": "^7.0.6" } }, + "node_modules/@vuepress/core/node_modules/postcss-modules-values/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/@vuepress/core/node_modules/postcss-value-parser": { "version": "3.3.1", "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", @@ -6380,6 +6292,12 @@ } } }, + "node_modules/@vuepress/core/node_modules/vue-router": { + "version": "3.6.5", + "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-3.6.5.tgz", + "integrity": "sha512-VYXZQLtjuvKxxcshuRAwjHnciqZVoXAjTjcqBTz4rKc8qih9g9pI3hbDjmqXaHdgL3v8pV6P8Z335XvHzESxLQ==", + "dev": true + }, "node_modules/@vuepress/core/node_modules/watchpack": { "version": "1.7.5", "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-1.7.5.tgz", @@ -7303,7 +7221,6 @@ "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.12.1.tgz", "integrity": "sha512-EKfMUOPRRUTy5UII4qJDGPpqfwjOmZ5jeGFwid9mnoqIFK+e0vqoi1qH56JpmZSzEL53jKnNzScdmftJyG5xWg==", - "dev": true, "dependencies": { "@webassemblyjs/helper-numbers": "1.11.6", "@webassemblyjs/helper-wasm-bytecode": "1.11.6" @@ -7312,20 +7229,17 @@ "node_modules/@webassemblyjs/floating-point-hex-parser": { "version": "1.11.6", "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.6.tgz", - "integrity": "sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==", - "dev": true + "integrity": "sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==" }, "node_modules/@webassemblyjs/helper-api-error": { "version": "1.11.6", "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.6.tgz", - "integrity": "sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==", - "dev": true + "integrity": "sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==" }, "node_modules/@webassemblyjs/helper-buffer": { "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.12.1.tgz", - "integrity": "sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw==", - "dev": true + "integrity": "sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw==" }, "node_modules/@webassemblyjs/helper-code-frame": { "version": "1.9.0", @@ -7400,7 +7314,6 @@ "version": "1.11.6", "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.6.tgz", "integrity": "sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==", - "dev": true, "dependencies": { "@webassemblyjs/floating-point-hex-parser": "1.11.6", "@webassemblyjs/helper-api-error": "1.11.6", @@ -7410,14 +7323,12 @@ "node_modules/@webassemblyjs/helper-wasm-bytecode": { "version": "1.11.6", "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.6.tgz", - "integrity": "sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==", - "dev": true + "integrity": "sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==" }, "node_modules/@webassemblyjs/helper-wasm-section": { "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.12.1.tgz", "integrity": "sha512-Jif4vfB6FJlUlSbgEMHUyk1j234GTNG9dBJ4XJdOySoj518Xj0oGsNi59cUQF4RRMS9ouBUxDDdyBVfPTypa5g==", - "dev": true, "dependencies": { "@webassemblyjs/ast": "1.12.1", "@webassemblyjs/helper-buffer": "1.12.1", @@ -7429,7 +7340,6 @@ "version": "1.11.6", "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.6.tgz", "integrity": "sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==", - "dev": true, "dependencies": { "@xtuc/ieee754": "^1.2.0" } @@ -7438,7 +7348,6 @@ "version": "1.11.6", "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.6.tgz", "integrity": "sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==", - "dev": true, "dependencies": { "@xtuc/long": "4.2.2" } @@ -7446,14 +7355,12 @@ "node_modules/@webassemblyjs/utf8": { "version": "1.11.6", "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.6.tgz", - "integrity": "sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==", - "dev": true + "integrity": "sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==" }, "node_modules/@webassemblyjs/wasm-edit": { "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.12.1.tgz", "integrity": "sha512-1DuwbVvADvS5mGnXbE+c9NfA8QRcZ6iKquqjjmR10k6o+zzsRVesil54DKexiowcFCPdr/Q0qaMgB01+SQ1u6g==", - "dev": true, "dependencies": { "@webassemblyjs/ast": "1.12.1", "@webassemblyjs/helper-buffer": "1.12.1", @@ -7469,7 +7376,6 @@ "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.12.1.tgz", "integrity": "sha512-TDq4Ojh9fcohAw6OIMXqiIcTq5KUXTGRkVxbSo1hQnSy6lAM5GSdfwWeSxpAo0YzgsgF182E/U0mDNhuA0tW7w==", - "dev": true, "dependencies": { "@webassemblyjs/ast": "1.12.1", "@webassemblyjs/helper-wasm-bytecode": "1.11.6", @@ -7482,7 +7388,6 @@ "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.12.1.tgz", "integrity": "sha512-Jg99j/2gG2iaz3hijw857AVYekZe2SAskcqlWIZXjji5WStnOpVoat3gQfT/Q5tb2djnCjBtMocY/Su1GfxPBg==", - "dev": true, "dependencies": { "@webassemblyjs/ast": "1.12.1", "@webassemblyjs/helper-buffer": "1.12.1", @@ -7494,7 +7399,6 @@ "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.12.1.tgz", "integrity": "sha512-xikIi7c2FHXysxXe3COrVUPSheuBtpcfhbpFj4gmu7KRLYOzANztwUU0IbsqvMqzuNK2+glRGWCEqZo1WCLyAQ==", - "dev": true, "dependencies": { "@webassemblyjs/ast": "1.12.1", "@webassemblyjs/helper-api-error": "1.11.6", @@ -7551,7 +7455,6 @@ "version": "1.12.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.12.1.tgz", "integrity": "sha512-+X4WAlOisVWQMikjbcvY2e0rwPsKQ9F688lksZhBcPycBBuii3O7m8FACbDMWDojpAqvjIncrG8J0XHKyQfVeA==", - "dev": true, "dependencies": { "@webassemblyjs/ast": "1.12.1", "@xtuc/long": "4.2.2" @@ -7601,21 +7504,18 @@ "node_modules/@xtuc/ieee754": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", - "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==", - "dev": true + "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==" }, "node_modules/@xtuc/long": { "version": "4.2.2", "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", - "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", - "dev": true + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==" }, "node_modules/abab": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==", - "deprecated": "Use your platform's native atob() and btoa() methods instead", - "dev": true + "deprecated": "Use your platform's native atob() and btoa() methods instead" }, "node_modules/abbrev": { "version": "2.0.0", @@ -7642,7 +7542,6 @@ "version": "8.11.3", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", - "dev": true, "bin": { "acorn": "bin/acorn" }, @@ -7654,7 +7553,6 @@ "version": "6.0.0", "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz", "integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==", - "dev": true, "dependencies": { "acorn": "^7.1.1", "acorn-walk": "^7.1.1" @@ -7664,7 +7562,6 @@ "version": "7.4.1", "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", - "dev": true, "bin": { "acorn": "bin/acorn" }, @@ -7676,7 +7573,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", - "dev": true, "engines": { "node": ">=0.4.0" } @@ -7685,7 +7581,6 @@ "version": "1.9.5", "resolved": "https://registry.npmjs.org/acorn-import-attributes/-/acorn-import-attributes-1.9.5.tgz", "integrity": "sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==", - "dev": true, "peerDependencies": { "acorn": "^8" } @@ -7722,7 +7617,6 @@ "version": "6.0.2", "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", - "dev": true, "dependencies": { "debug": "4" }, @@ -7754,7 +7648,6 @@ }, "node_modules/ajv": { "version": "6.12.6", - "dev": true, "license": "MIT", "dependencies": { "fast-deep-equal": "^3.1.1", @@ -7814,7 +7707,6 @@ }, "node_modules/ajv-keywords": { "version": "3.5.2", - "dev": true, "license": "MIT", "peerDependencies": { "ajv": "^6.9.1" @@ -7897,7 +7789,6 @@ "version": "4.3.2", "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", - "dev": true, "dependencies": { "type-fest": "^0.21.3" }, @@ -7924,7 +7815,6 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, "engines": { "node": ">=8" } @@ -7946,7 +7836,6 @@ }, "node_modules/anymatch": { "version": "3.1.3", - "dev": true, "license": "ISC", "dependencies": { "normalize-path": "^3.0.0", @@ -7983,7 +7872,6 @@ }, "node_modules/argparse": { "version": "1.0.10", - "dev": true, "license": "MIT", "dependencies": { "sprintf-js": "~1.0.2" @@ -8263,6 +8151,29 @@ "url": "https://tidelift.com/funding/github/npm/autoprefixer" } }, + "node_modules/autoprefixer/node_modules/picocolors": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-0.2.1.tgz", + "integrity": "sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA==", + "dev": true + }, + "node_modules/autoprefixer/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/available-typed-arrays": { "version": "1.0.7", "dev": true, @@ -8338,7 +8249,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-27.5.1.tgz", "integrity": "sha512-cdQ5dXjGRd0IBRATiQ4mZGlGlRE8kJpjPOixdNRdT+m3UcNqmYWN6rK6nvtXYfY3D76cb8s/O1Ss8ea24PIwcg==", - "dev": true, "dependencies": { "@jest/transform": "^27.5.1", "@jest/types": "^27.5.1", @@ -8360,7 +8270,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -8375,7 +8284,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -8391,7 +8299,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -8402,14 +8309,12 @@ "node_modules/babel-jest/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/babel-jest/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -8418,7 +8323,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -8457,7 +8361,6 @@ "version": "6.1.1", "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", - "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.0.0", "@istanbuljs/load-nyc-config": "^1.0.0", @@ -8473,7 +8376,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.5.1.tgz", "integrity": "sha512-50wCwD5EMNW4aRpOwtqzyZHIewTYNxLA4nhB+09d8BIssfNfzBRhkBIHiaPv1Si226TQSvp8gxAJm2iY2qs2hQ==", - "dev": true, "dependencies": { "@babel/template": "^7.3.3", "@babel/types": "^7.3.3", @@ -8535,7 +8437,6 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", - "dev": true, "dependencies": { "@babel/plugin-syntax-async-generators": "^7.8.4", "@babel/plugin-syntax-bigint": "^7.8.3", @@ -8558,7 +8459,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-27.5.1.tgz", "integrity": "sha512-Nptf2FzlPCWYuJg41HBqXVT8ym6bXOevuCTbhxlUpjwtysGaIWFvDEjp4y+G7fl13FgOdjs7P/DmErqH7da0Ag==", - "dev": true, "dependencies": { "babel-plugin-jest-hoist": "^27.5.1", "babel-preset-current-node-syntax": "^1.0.0" @@ -8572,7 +8472,6 @@ }, "node_modules/balanced-match": { "version": "1.0.2", - "dev": true, "license": "MIT" }, "node_modules/base": { @@ -8854,6 +8753,55 @@ "vue-functional-data-merge": "^3.1.0" } }, + "node_modules/bootstrap-vue/node_modules/@vue/compiler-sfc": { + "version": "2.7.16", + "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-2.7.16.tgz", + "integrity": "sha512-KWhJ9k5nXuNtygPU7+t1rX6baZeqOYLEforUPjgNDBnLicfHCoi48H87Q8XyLZOrNNsmhuwKqtpDQWjEFe6Ekg==", + "peer": true, + "dependencies": { + "@babel/parser": "^7.23.5", + "postcss": "^8.4.14", + "source-map": "^0.6.1" + }, + "optionalDependencies": { + "prettier": "^1.18.2 || ^2.0.0" + } + }, + "node_modules/bootstrap-vue/node_modules/portal-vue": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/portal-vue/-/portal-vue-2.1.7.tgz", + "integrity": "sha512-+yCno2oB3xA7irTt0EU5Ezw22L2J51uKAacE/6hMPMoO/mx3h4rXFkkBkT4GFsMDv/vEe8TNKC3ujJJ0PTwb6g==", + "peerDependencies": { + "vue": "^2.5.18" + } + }, + "node_modules/bootstrap-vue/node_modules/prettier": { + "version": "2.8.8", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", + "integrity": "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q==", + "optional": true, + "peer": true, + "bin": { + "prettier": "bin-prettier.js" + }, + "engines": { + "node": ">=10.13.0" + }, + "funding": { + "url": "https://github.com/prettier/prettier?sponsor=1" + } + }, + "node_modules/bootstrap-vue/node_modules/vue": { + "version": "2.7.16", + "resolved": "https://registry.npmjs.org/vue/-/vue-2.7.16.tgz", + "integrity": "sha512-4gCtFXaAA3zYZdTp5s4Hl2sozuySsgz4jy1EnpBHNfpMa9dK1ZCG7viqBPCwXtmgc8nHqUsAu3G4gtmXkkY3Sw==", + "deprecated": "Vue 2 has reached EOL and is no longer actively maintained. See https://v2.vuejs.org/eol/ for more details.", + "peer": true, + "dependencies": { + "@vue/compiler-sfc": "2.7.16", + "csstype": "^3.1.0" + } + }, "node_modules/boxen": { "version": "4.2.0", "dev": true, @@ -8954,7 +8902,6 @@ }, "node_modules/brace-expansion": { "version": "1.1.11", - "dev": true, "license": "MIT", "dependencies": { "balanced-match": "^1.0.0", @@ -8965,7 +8912,6 @@ "version": "3.0.3", "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", - "dev": true, "dependencies": { "fill-range": "^7.1.1" }, @@ -8982,8 +8928,7 @@ "node_modules/browser-process-hrtime": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", - "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==", - "dev": true + "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==" }, "node_modules/browserify-aes": { "version": "1.2.0", @@ -9106,7 +9051,6 @@ }, "node_modules/browserslist": { "version": "4.23.0", - "dev": true, "funding": [ { "type": "opencollective", @@ -9139,7 +9083,6 @@ "version": "2.1.1", "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", - "dev": true, "dependencies": { "node-int64": "^0.4.0" } @@ -9171,8 +9114,7 @@ "node_modules/buffer-from": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", - "dev": true + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" }, "node_modules/buffer-indexof": { "version": "1.1.1", @@ -9584,7 +9526,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", - "dev": true, "engines": { "node": ">=6" } @@ -9603,7 +9544,6 @@ "version": "6.3.0", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true, "engines": { "node": ">=10" }, @@ -9627,7 +9567,6 @@ "version": "1.0.30001600", "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001600.tgz", "integrity": "sha512-+2S9/2JFhYmYaDpZvo0lKkfvuKIglrx68MwOBqMGHhQsNkLjB5xtc/TGoEPs+MxjSyN/72qer2g97nzR641mOQ==", - "dev": true, "funding": [ { "type": "opencollective", @@ -9673,7 +9612,6 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", - "dev": true, "engines": { "node": ">=10" } @@ -9801,7 +9739,6 @@ }, "node_modules/chrome-trace-event": { "version": "1.0.3", - "dev": true, "license": "MIT", "engines": { "node": ">=6.0" @@ -9825,8 +9762,7 @@ "node_modules/cjs-module-lexer": { "version": "1.3.1", "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.3.1.tgz", - "integrity": "sha512-a3KdPAANPbNE4ZUv9h6LckSl9zLsYOP4MBmhIPkRaeyybt+r4UghLvq+xw/YwUcC1gqylCkL4rdVs3Lwupjm4Q==", - "dev": true + "integrity": "sha512-a3KdPAANPbNE4ZUv9h6LckSl9zLsYOP4MBmhIPkRaeyybt+r4UghLvq+xw/YwUcC1gqylCkL4rdVs3Lwupjm4Q==" }, "node_modules/class-utils": { "version": "0.3.6", @@ -10125,7 +10061,6 @@ "version": "7.0.4", "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dev": true, "dependencies": { "string-width": "^4.2.0", "strip-ansi": "^6.0.0", @@ -10169,7 +10104,6 @@ "version": "4.6.0", "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", - "dev": true, "engines": { "iojs": ">= 1.0.0", "node": ">= 0.12.0" @@ -10191,8 +10125,7 @@ "node_modules/collect-v8-coverage": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.2.tgz", - "integrity": "sha512-lHl4d5/ONEbLlJvaJNtsF/Lz+WvB07u2ycqTYbdrq7UypDXailES4valYb2eWiJFxZlVmpGekfqoxQhzyFdT4Q==", - "dev": true + "integrity": "sha512-lHl4d5/ONEbLlJvaJNtsF/Lz+WvB07u2ycqTYbdrq7UypDXailES4valYb2eWiJFxZlVmpGekfqoxQhzyFdT4Q==" }, "node_modules/collection-visit": { "version": "1.0.0", @@ -10419,7 +10352,6 @@ }, "node_modules/concat-map": { "version": "0.0.1", - "dev": true, "license": "MIT" }, "node_modules/concat-stream": { @@ -10581,7 +10513,6 @@ }, "node_modules/convert-source-map": { "version": "2.0.0", - "dev": true, "license": "MIT" }, "node_modules/cookie": { @@ -10904,40 +10835,6 @@ } } }, - "node_modules/css-loader/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", - "dev": true - }, - "node_modules/css-loader/node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "dependencies": { - "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } - }, "node_modules/css-loader/node_modules/semver": { "version": "7.6.2", "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", @@ -11022,40 +10919,6 @@ "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", "dev": true }, - "node_modules/css-minimizer-webpack-plugin/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", - "dev": true - }, - "node_modules/css-minimizer-webpack-plugin/node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "dependencies": { - "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } - }, "node_modules/css-minimizer-webpack-plugin/node_modules/schema-utils": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz", @@ -11234,6 +11097,29 @@ "node": ">=6.9.0" } }, + "node_modules/cssnano-util-raw-cache/node_modules/picocolors": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-0.2.1.tgz", + "integrity": "sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA==", + "dev": true + }, + "node_modules/cssnano-util-raw-cache/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/cssnano-util-same-parent": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/cssnano-util-same-parent/-/cssnano-util-same-parent-4.0.1.tgz", @@ -11286,14 +11172,12 @@ "node_modules/cssom": { "version": "0.4.4", "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", - "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", - "dev": true + "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==" }, "node_modules/cssstyle": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", - "dev": true, "dependencies": { "cssom": "~0.3.6" }, @@ -11304,13 +11188,12 @@ "node_modules/cssstyle/node_modules/cssom": { "version": "0.3.8", "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", - "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", - "dev": true + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==" }, "node_modules/csstype": { - "version": "2.6.21", - "resolved": "https://registry.npmjs.org/csstype/-/csstype-2.6.21.tgz", - "integrity": "sha512-Z1PhmomIfypOpoMjRQB70jfvy/wxT50qW08YXO5lMIJkrdq4yOTR+AW7FqutScmB9NkLwxo+jU+kZLbofZZq/w==" + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==" }, "node_modules/cyclist": { "version": "1.0.2", @@ -11334,7 +11217,6 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-2.0.0.tgz", "integrity": "sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==", - "dev": true, "dependencies": { "abab": "^2.0.3", "whatwg-mimetype": "^2.3.0", @@ -11403,8 +11285,7 @@ "node_modules/decimal.js": { "version": "10.4.3", "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.4.3.tgz", - "integrity": "sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==", - "dev": true + "integrity": "sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==" }, "node_modules/decode-uri-component": { "version": "0.2.2", @@ -11429,8 +11310,7 @@ "node_modules/dedent": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", - "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", - "dev": true + "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==" }, "node_modules/deep-equal": { "version": "1.1.2", @@ -11467,7 +11347,6 @@ }, "node_modules/deepmerge": { "version": "4.3.1", - "dev": true, "license": "MIT", "engines": { "node": ">=0.10.0" @@ -11740,7 +11619,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", - "dev": true, "engines": { "node": ">=8" } @@ -11755,7 +11633,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.1.tgz", "integrity": "sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ==", - "dev": true, "engines": { "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" } @@ -11928,7 +11805,6 @@ "resolved": "https://registry.npmjs.org/domexception/-/domexception-2.0.1.tgz", "integrity": "sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg==", "deprecated": "Use your platform's native DOMException instead", - "dev": true, "dependencies": { "webidl-conversions": "^5.0.0" }, @@ -11940,7 +11816,6 @@ "version": "5.0.0", "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz", "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==", - "dev": true, "engines": { "node": ">=8" } @@ -12204,7 +12079,6 @@ }, "node_modules/electron-to-chromium": { "version": "1.4.682", - "dev": true, "license": "ISC" }, "node_modules/elliptic": { @@ -12232,7 +12106,6 @@ "version": "0.8.1", "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.8.1.tgz", "integrity": "sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg==", - "dev": true, "engines": { "node": ">=10" }, @@ -12242,7 +12115,6 @@ }, "node_modules/emoji-regex": { "version": "8.0.0", - "dev": true, "license": "MIT" }, "node_modules/emojis-list": { @@ -12274,7 +12146,6 @@ "version": "5.17.0", "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.17.0.tgz", "integrity": "sha512-dwDPwZL0dmye8Txp2gzFmA6sxALaSvdRDjPH0viLcKrtlOL3tw62nWWweVD1SdILDTJrbrL6tdWVN58Wo6U3eA==", - "dev": true, "dependencies": { "graceful-fs": "^4.2.4", "tapable": "^2.2.0" @@ -12287,7 +12158,6 @@ "version": "4.5.0", "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", - "dev": true, "engines": { "node": ">=0.12" }, @@ -12341,7 +12211,6 @@ }, "node_modules/error-ex": { "version": "1.3.2", - "dev": true, "license": "MIT", "dependencies": { "is-arrayish": "^0.2.1" @@ -12435,7 +12304,6 @@ }, "node_modules/es-module-lexer": { "version": "1.4.1", - "dev": true, "license": "MIT" }, "node_modules/es-set-tostringtag": { @@ -12725,7 +12593,6 @@ }, "node_modules/escalade": { "version": "3.1.2", - "dev": true, "license": "MIT", "engines": { "node": ">=6" @@ -12756,7 +12623,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.1.0.tgz", "integrity": "sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w==", - "dev": true, "dependencies": { "esprima": "^4.0.1", "estraverse": "^5.2.0", @@ -13236,7 +13102,6 @@ }, "node_modules/esprima": { "version": "4.0.1", - "dev": true, "license": "BSD-2-Clause", "bin": { "esparse": "bin/esparse.js", @@ -13259,7 +13124,6 @@ }, "node_modules/esrecurse": { "version": "4.3.0", - "dev": true, "license": "BSD-2-Clause", "dependencies": { "estraverse": "^5.2.0" @@ -13272,7 +13136,6 @@ "version": "5.3.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", - "dev": true, "engines": { "node": ">=4.0" } @@ -13283,7 +13146,6 @@ }, "node_modules/esutils": { "version": "2.0.3", - "dev": true, "license": "BSD-2-Clause", "engines": { "node": ">=0.10.0" @@ -13423,7 +13285,6 @@ "version": "0.1.2", "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", - "dev": true, "engines": { "node": ">= 0.8.0" } @@ -13465,7 +13326,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.1.tgz", "integrity": "sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "jest-get-type": "^27.5.1", @@ -13621,7 +13481,6 @@ }, "node_modules/fast-deep-equal": { "version": "3.1.3", - "dev": true, "license": "MIT" }, "node_modules/fast-defer": { @@ -13664,7 +13523,6 @@ }, "node_modules/fast-json-stable-stringify": { "version": "2.1.0", - "dev": true, "license": "MIT" }, "node_modules/fast-levenshtein": { @@ -13705,7 +13563,6 @@ "version": "2.0.2", "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", - "dev": true, "dependencies": { "bser": "2.1.1" } @@ -13807,7 +13664,6 @@ "version": "7.1.1", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", - "dev": true, "dependencies": { "to-regex-range": "^5.0.1" }, @@ -14028,7 +13884,6 @@ "version": "3.0.1", "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", - "dev": true, "dependencies": { "asynckit": "^0.4.0", "combined-stream": "^1.0.8", @@ -14199,14 +14054,12 @@ }, "node_modules/fs.realpath": { "version": "1.0.0", - "dev": true, "license": "ISC" }, "node_modules/fsevents": { "version": "2.3.3", "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", - "dev": true, "hasInstallScript": true, "optional": true, "os": [ @@ -14256,7 +14109,6 @@ }, "node_modules/gensync": { "version": "1.0.0-beta.2", - "dev": true, "license": "MIT", "engines": { "node": ">=6.9.0" @@ -14264,7 +14116,6 @@ }, "node_modules/get-caller-file": { "version": "2.0.5", - "dev": true, "license": "ISC", "engines": { "node": "6.* || 8.* || >= 10.*" @@ -14292,7 +14143,6 @@ "version": "0.1.0", "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", - "dev": true, "engines": { "node": ">=8.0.0" } @@ -14344,7 +14194,6 @@ }, "node_modules/glob": { "version": "7.2.3", - "dev": true, "license": "ISC", "dependencies": { "fs.realpath": "^1.0.0", @@ -14869,7 +14718,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz", "integrity": "sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ==", - "dev": true, "dependencies": { "whatwg-encoding": "^1.0.5" }, @@ -14896,8 +14744,7 @@ "node_modules/html-escaper": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", - "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", - "dev": true + "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==" }, "node_modules/html-minifier": { "version": "3.5.21", @@ -15116,7 +14963,6 @@ "version": "4.0.1", "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", - "dev": true, "dependencies": { "@tootallnate/once": "1", "agent-base": "6", @@ -15167,7 +15013,6 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", - "dev": true, "dependencies": { "agent-base": "6", "debug": "4" @@ -15180,7 +15025,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", - "dev": true, "engines": { "node": ">=10.17.0" } @@ -15189,7 +15033,6 @@ "version": "0.4.24", "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dev": true, "dependencies": { "safer-buffer": ">= 2.1.2 < 3" }, @@ -15348,7 +15191,6 @@ }, "node_modules/imurmurhash": { "version": "0.1.4", - "dev": true, "license": "MIT", "engines": { "node": ">=0.8.19" @@ -15377,7 +15219,6 @@ }, "node_modules/inflight": { "version": "1.0.6", - "dev": true, "license": "ISC", "dependencies": { "once": "^1.3.0", @@ -15386,7 +15227,6 @@ }, "node_modules/inherits": { "version": "2.0.4", - "dev": true, "license": "ISC" }, "node_modules/ini": { @@ -15528,7 +15368,6 @@ }, "node_modules/is-arrayish": { "version": "0.2.1", - "dev": true, "license": "MIT" }, "node_modules/is-bigint": { @@ -15710,7 +15549,6 @@ }, "node_modules/is-fullwidth-code-point": { "version": "3.0.0", - "dev": true, "license": "MIT", "engines": { "node": ">=8" @@ -15720,7 +15558,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", - "dev": true, "engines": { "node": ">=6" } @@ -15783,7 +15620,6 @@ "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "dev": true, "engines": { "node": ">=0.12.0" } @@ -15869,8 +15705,7 @@ "node_modules/is-potential-custom-element-name": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz", - "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", - "dev": true + "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==" }, "node_modules/is-regex": { "version": "1.1.4", @@ -15959,7 +15794,6 @@ }, "node_modules/is-typedarray": { "version": "1.0.0", - "dev": true, "license": "MIT" }, "node_modules/is-unicode-supported": { @@ -16054,7 +15888,6 @@ "version": "3.2.2", "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", - "dev": true, "engines": { "node": ">=8" } @@ -16063,7 +15896,6 @@ "version": "5.2.1", "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", - "dev": true, "dependencies": { "@babel/core": "^7.12.3", "@babel/parser": "^7.14.7", @@ -16079,7 +15911,6 @@ "version": "3.0.1", "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", - "dev": true, "dependencies": { "istanbul-lib-coverage": "^3.0.0", "make-dir": "^4.0.0", @@ -16093,7 +15924,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -16102,7 +15932,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", - "dev": true, "dependencies": { "semver": "^7.5.3" }, @@ -16117,7 +15946,6 @@ "version": "7.6.2", "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", - "dev": true, "bin": { "semver": "bin/semver.js" }, @@ -16129,7 +15957,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -16141,7 +15968,6 @@ "version": "4.0.1", "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", - "dev": true, "dependencies": { "debug": "^4.1.1", "istanbul-lib-coverage": "^3.0.0", @@ -16155,7 +15981,6 @@ "version": "3.1.7", "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", - "dev": true, "dependencies": { "html-escaper": "^2.0.0", "istanbul-lib-report": "^3.0.0" @@ -16190,7 +16015,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest/-/jest-27.5.1.tgz", "integrity": "sha512-Yn0mADZB89zTtjkPJEXwrac3LHudkQMR+Paqa8uxJHCBr9agxztUifWCyiYrjhMPBoUVBjyny0I7XH6ozDr7QQ==", - "dev": true, "dependencies": { "@jest/core": "^27.5.1", "import-local": "^3.0.2", @@ -16215,7 +16039,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-27.5.1.tgz", "integrity": "sha512-buBLMiByfWGCoMsLLzGUUSpAmIAGnbR2KJoMN10ziLhOLvP4e0SlypHnAel8iqQXTrcbmfEY9sSqae5sgUsTvw==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "execa": "^5.0.0", @@ -16229,7 +16052,6 @@ "version": "5.1.1", "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", - "dev": true, "dependencies": { "cross-spawn": "^7.0.3", "get-stream": "^6.0.0", @@ -16252,7 +16074,6 @@ "version": "6.0.1", "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", - "dev": true, "engines": { "node": ">=10" }, @@ -16264,7 +16085,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", - "dev": true, "engines": { "node": ">=8" }, @@ -16276,7 +16096,6 @@ "version": "4.0.1", "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", - "dev": true, "dependencies": { "path-key": "^3.0.0" }, @@ -16288,7 +16107,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-27.5.1.tgz", "integrity": "sha512-D95R7x5UtlMA5iBYsOHFFbMD/GVA4R/Kdq15f7xYWUfWHBto9NYRsOvnSauTgdF+ogCpJ4tyKOXhUifxS65gdw==", - "dev": true, "dependencies": { "@jest/environment": "^27.5.1", "@jest/test-result": "^27.5.1", @@ -16318,7 +16136,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -16333,7 +16150,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -16349,7 +16165,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -16360,14 +16175,12 @@ "node_modules/jest-circus/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-circus/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -16376,7 +16189,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -16388,7 +16200,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-27.5.1.tgz", "integrity": "sha512-Hc6HOOwYq4/74/c62dEE3r5elx8wjYqxY0r0G/nFrLDPMFRu6RA/u8qINOIkvhxG7mMQ5EJsOGfRpI8L6eFUVw==", - "dev": true, "dependencies": { "@jest/core": "^27.5.1", "@jest/test-result": "^27.5.1", @@ -16422,7 +16233,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -16437,7 +16247,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -16453,7 +16262,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -16464,14 +16272,12 @@ "node_modules/jest-cli/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-cli/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -16480,7 +16286,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -16492,7 +16297,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-27.5.1.tgz", "integrity": "sha512-5sAsjm6tGdsVbW9ahcChPAFCk4IlkQUknH5AvKjuLTSlcO/wCZKyFdn7Rg0EkC+OGgWODEy2hDpWB1PgzH0JNA==", - "dev": true, "dependencies": { "@babel/core": "^7.8.0", "@jest/test-sequencer": "^27.5.1", @@ -16535,7 +16339,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -16550,7 +16353,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -16566,7 +16368,6 @@ "version": "3.9.0", "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.9.0.tgz", "integrity": "sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==", - "dev": true, "funding": [ { "type": "github", @@ -16581,7 +16382,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -16592,14 +16392,12 @@ "node_modules/jest-config/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-config/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -16608,7 +16406,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -16620,7 +16417,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.1.tgz", "integrity": "sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw==", - "dev": true, "dependencies": { "chalk": "^4.0.0", "diff-sequences": "^27.5.1", @@ -16635,7 +16431,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -16650,7 +16445,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -16666,7 +16460,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -16677,14 +16470,12 @@ "node_modules/jest-diff/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-diff/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -16693,7 +16484,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -16705,7 +16495,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-27.5.1.tgz", "integrity": "sha512-rl7hlABeTsRYxKiUfpHrQrG4e2obOiTQWfMEH3PxPjOtdsfLQO4ReWSZaQ7DETm4xu07rl4q/h4zcKXyU0/OzQ==", - "dev": true, "dependencies": { "detect-newline": "^3.0.0" }, @@ -16717,7 +16506,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-27.5.1.tgz", "integrity": "sha512-1Ff6p+FbhT/bXQnEouYy00bkNSY7OUpfIcmdl8vZ31A1UUaurOLPA8a8BbJOF2RDUElwJhmeaV7LnagI+5UwNQ==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "chalk": "^4.0.0", @@ -16733,7 +16521,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -16748,7 +16535,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -16764,7 +16550,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -16775,14 +16560,12 @@ "node_modules/jest-each/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-each/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -16791,7 +16574,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -16803,7 +16585,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-27.5.1.tgz", "integrity": "sha512-TFBvkTC1Hnnnrka/fUb56atfDtJ9VMZ94JkjTbggl1PEpwrYtUBKMezB3inLmWqQsXYLcMwNoDQwoBTAvFfsfw==", - "dev": true, "dependencies": { "@jest/environment": "^27.5.1", "@jest/fake-timers": "^27.5.1", @@ -16821,7 +16602,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-27.5.1.tgz", "integrity": "sha512-Jt4ZUnxdOsTGwSRAfKEnE6BcwsSPNOijjwifq5sDFSA2kesnXTvNqKHYgM0hDq3549Uf/KzdXNYn4wMZJPlFLw==", - "dev": true, "dependencies": { "@jest/environment": "^27.5.1", "@jest/fake-timers": "^27.5.1", @@ -16838,7 +16618,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.1.tgz", "integrity": "sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw==", - "dev": true, "engines": { "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" } @@ -16847,7 +16626,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-27.5.1.tgz", "integrity": "sha512-7GgkZ4Fw4NFbMSDSpZwXeBiIbx+t/46nJ2QitkOjvwPYyZmqttu2TDSimMHP1EkPOi4xUZAN1doE5Vd25H4Jng==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "@types/graceful-fs": "^4.1.2", @@ -16873,7 +16651,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-27.5.1.tgz", "integrity": "sha512-jtq7VVyG8SqAorDpApwiJJImd0V2wv1xzdheGHRGyuT7gZm6gG47QEskOlzsN1PG/6WNaCo5pmwMHDf3AkG2pQ==", - "dev": true, "dependencies": { "@jest/environment": "^27.5.1", "@jest/source-map": "^27.5.1", @@ -16901,7 +16678,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -16916,7 +16692,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -16932,7 +16707,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -16943,14 +16717,12 @@ "node_modules/jest-jasmine2/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-jasmine2/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -16959,7 +16731,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -16971,7 +16742,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-27.5.1.tgz", "integrity": "sha512-POXfWAMvfU6WMUXftV4HolnJfnPOGEu10fscNCA76KBpRRhcMN2c8d3iT2pxQS3HLbA+5X4sOUPzYO2NUyIlHQ==", - "dev": true, "dependencies": { "jest-get-type": "^27.5.1", "pretty-format": "^27.5.1" @@ -16984,7 +16754,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz", "integrity": "sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw==", - "dev": true, "dependencies": { "chalk": "^4.0.0", "jest-diff": "^27.5.1", @@ -16999,7 +16768,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17014,7 +16782,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17030,7 +16797,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17041,14 +16807,12 @@ "node_modules/jest-matcher-utils/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-matcher-utils/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17057,7 +16821,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -17069,7 +16832,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.1.tgz", "integrity": "sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g==", - "dev": true, "dependencies": { "@babel/code-frame": "^7.12.13", "@jest/types": "^27.5.1", @@ -17089,7 +16851,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17104,7 +16865,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17120,7 +16880,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17131,14 +16890,12 @@ "node_modules/jest-message-util/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-message-util/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17147,7 +16904,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -17159,7 +16915,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-27.5.1.tgz", "integrity": "sha512-K4jKbY1d4ENhbrG2zuPWaQBvDly+iZ2yAW+T1fATN78hc0sInwn7wZB8XtlNnvHug5RMwV897Xm4LqmPM4e2Og==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "@types/node": "*" @@ -17172,7 +16927,6 @@ "version": "1.2.3", "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", - "dev": true, "engines": { "node": ">=6" }, @@ -17189,7 +16943,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-27.5.1.tgz", "integrity": "sha512-4bfKq2zie+x16okqDXjXn9ql2B0dScQu+vcwe4TvFVhkVyuWLqpZrZtXxLLWoXYgn0E87I6r6GRYHF7wFZBUvg==", - "dev": true, "engines": { "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" } @@ -17198,7 +16951,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-27.5.1.tgz", "integrity": "sha512-FFDy8/9E6CV83IMbDpcjOhumAQPDyETnU2KZ1O98DwTnz8AOBsW/Xv3GySr1mOZdItLR+zDZ7I/UdTFbgSOVCw==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "chalk": "^4.0.0", @@ -17219,7 +16971,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-27.5.1.tgz", "integrity": "sha512-QQOOdY4PE39iawDn5rzbIePNigfe5B9Z91GDD1ae/xNDlu9kaat8QQ5EKnNmVWPV54hUdxCVwwj6YMgR2O7IOg==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "jest-regex-util": "^27.5.1", @@ -17233,7 +16984,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17248,7 +16998,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17264,7 +17013,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17275,14 +17023,12 @@ "node_modules/jest-resolve/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-resolve/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17291,7 +17037,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -17303,7 +17048,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-27.5.1.tgz", "integrity": "sha512-g4NPsM4mFCOwFKXO4p/H/kWGdJp9V8kURY2lX8Me2drgXqG7rrZAx5kv+5H7wtt/cdFIjhqYx1HrlqWHaOvDaQ==", - "dev": true, "dependencies": { "@jest/console": "^27.5.1", "@jest/environment": "^27.5.1", @@ -17335,7 +17079,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17350,7 +17093,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17366,7 +17108,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17377,14 +17118,12 @@ "node_modules/jest-runner/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-runner/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17393,7 +17132,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -17405,7 +17143,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-27.5.1.tgz", "integrity": "sha512-o7gxw3Gf+H2IGt8fv0RiyE1+r83FJBRruoA+FXrlHw6xEyBsU8ugA6IPfTdVyA0w8HClpbK+DGJxH59UrNMx8A==", - "dev": true, "dependencies": { "@jest/environment": "^27.5.1", "@jest/fake-timers": "^27.5.1", @@ -17438,7 +17175,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17453,7 +17189,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17469,7 +17204,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17480,14 +17214,12 @@ "node_modules/jest-runtime/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-runtime/node_modules/execa": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", - "dev": true, "dependencies": { "cross-spawn": "^7.0.3", "get-stream": "^6.0.0", @@ -17510,7 +17242,6 @@ "version": "6.0.1", "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", - "dev": true, "engines": { "node": ">=10" }, @@ -17522,7 +17253,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17531,7 +17261,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", - "dev": true, "engines": { "node": ">=8" }, @@ -17543,7 +17272,6 @@ "version": "4.0.1", "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", - "dev": true, "dependencies": { "path-key": "^3.0.0" }, @@ -17555,7 +17283,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -17567,7 +17294,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-27.5.1.tgz", "integrity": "sha512-jZCyo6iIxO1aqUxpuBlwTDMkzOAJS4a3eYz3YzgxxVQFwLeSA7Jfq5cbqCY+JLvTDrWirgusI/0KwxKMgrdf7w==", - "dev": true, "dependencies": { "@types/node": "*", "graceful-fs": "^4.2.9" @@ -17588,7 +17314,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-27.5.1.tgz", "integrity": "sha512-yYykXI5a0I31xX67mgeLw1DZ0bJB+gpq5IpSuCAoyDi0+BhgU/RIrL+RTzDmkNTchvDFWKP8lp+w/42Z3us5sA==", - "dev": true, "dependencies": { "@babel/core": "^7.7.2", "@babel/generator": "^7.7.2", @@ -17621,7 +17346,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17636,7 +17360,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17652,7 +17375,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17663,14 +17385,12 @@ "node_modules/jest-snapshot/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-snapshot/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17679,7 +17399,6 @@ "version": "7.6.2", "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", - "dev": true, "bin": { "semver": "bin/semver.js" }, @@ -17691,7 +17410,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -17708,7 +17426,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-27.5.1.tgz", "integrity": "sha512-Kv2o/8jNvX1MQ0KGtw480E/w4fBCDOnH6+6DmeKi6LZUIlKA5kwY0YNdlzaWTiVgxqAqik11QyxDOKk543aKXw==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "@types/node": "*", @@ -17725,7 +17442,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17740,7 +17456,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17756,7 +17471,6 @@ "version": "3.9.0", "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.9.0.tgz", "integrity": "sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==", - "dev": true, "funding": [ { "type": "github", @@ -17771,7 +17485,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17782,14 +17495,12 @@ "node_modules/jest-util/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-util/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17798,7 +17509,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -17810,7 +17520,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-27.5.1.tgz", "integrity": "sha512-thkNli0LYTmOI1tDB3FI1S1RTp/Bqyd9pTarJwL87OIBFuqEb5Apv5EaApEudYg4g86e3CT6kM0RowkhtEnCBQ==", - "dev": true, "dependencies": { "@jest/types": "^27.5.1", "camelcase": "^6.2.0", @@ -17827,7 +17536,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -17842,7 +17550,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17858,7 +17565,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -17869,14 +17575,12 @@ "node_modules/jest-validate/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-validate/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -17885,7 +17589,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -18278,7 +17981,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-27.5.1.tgz", "integrity": "sha512-z676SuD6Z8o8qbmEGhoEUFOM1+jfEiL3DXHK/xgEiG2EyNYfFG60jluWcupY6dATjfEsKQuibReS1djInQnoVw==", - "dev": true, "dependencies": { "@jest/test-result": "^27.5.1", "@jest/types": "^27.5.1", @@ -18296,7 +17998,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -18311,7 +18012,6 @@ "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -18327,7 +18027,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -18338,14 +18037,12 @@ "node_modules/jest-watcher/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/jest-watcher/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -18354,7 +18051,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -18366,7 +18062,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", - "dev": true, "dependencies": { "@types/node": "*", "merge-stream": "^2.0.0", @@ -18380,7 +18075,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -18389,7 +18083,6 @@ "version": "8.1.1", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -18434,6 +18127,12 @@ "@hapi/hoek": "^9.0.0" } }, + "node_modules/jquery": { + "version": "3.7.1", + "resolved": "https://registry.npmjs.org/jquery/-/jquery-3.7.1.tgz", + "integrity": "sha512-m4avr8yL8kmFN8psrbFFFmB/If14iN5o9nw/NgnnM+kybDJpRsAynV2BsfpTYrTRysYUdADVD7CkUUizgkpLfg==", + "peer": true + }, "node_modules/js-beautify": { "version": "1.15.1", "dev": true, @@ -18537,7 +18236,6 @@ }, "node_modules/js-yaml": { "version": "3.14.1", - "dev": true, "license": "MIT", "dependencies": { "argparse": "^1.0.7", @@ -18557,7 +18255,6 @@ "version": "16.7.0", "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-16.7.0.tgz", "integrity": "sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==", - "dev": true, "dependencies": { "abab": "^2.0.5", "acorn": "^8.2.4", @@ -18602,8 +18299,7 @@ "node_modules/jsdom/node_modules/parse5": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", - "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==", - "dev": true + "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==" }, "node_modules/jsesc": { "version": "2.5.2", @@ -18628,7 +18324,6 @@ }, "node_modules/json-parse-even-better-errors": { "version": "2.3.1", - "dev": true, "license": "MIT" }, "node_modules/json-schema": { @@ -18639,7 +18334,6 @@ }, "node_modules/json-schema-traverse": { "version": "0.4.1", - "dev": true, "license": "MIT" }, "node_modules/json-stable-stringify-without-jsonify": { @@ -18655,7 +18349,6 @@ }, "node_modules/json5": { "version": "2.2.3", - "dev": true, "license": "MIT", "bin": { "json5": "lib/cli.js" @@ -18783,7 +18476,6 @@ "version": "3.0.3", "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", - "dev": true, "engines": { "node": ">=6" } @@ -18835,16 +18527,10 @@ "launch-editor": "^2.6.1" } }, - "node_modules/launch-editor/node_modules/picocolors": { - "version": "1.0.0", - "dev": true, - "license": "ISC" - }, "node_modules/leven": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", - "dev": true, "engines": { "node": ">=6" } @@ -18872,7 +18558,6 @@ }, "node_modules/lines-and-columns": { "version": "1.2.4", - "dev": true, "license": "MIT" }, "node_modules/linkify-it": { @@ -19178,7 +18863,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz", "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==", - "dev": true, "engines": { "node": ">=6.11.5" } @@ -19481,21 +19165,17 @@ }, "node_modules/lru-cache": { "version": "5.1.1", - "dev": true, "license": "ISC", "dependencies": { "yallist": "^3.0.2" } }, "node_modules/magic-string": { - "version": "0.30.7", - "dev": true, - "license": "MIT", + "version": "0.30.10", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.10.tgz", + "integrity": "sha512-iIRwTIf0QKV3UAnYK4PU8uiEc4SRh5jX0mwpIwETPpHdhVM4f53RSwS/vXvN1JhGX+Cs7B8qIq3d6AH49O5fAQ==", "dependencies": { "@jridgewell/sourcemap-codec": "^1.4.15" - }, - "engines": { - "node": ">=12" } }, "node_modules/make-dir": { @@ -19516,7 +19196,6 @@ "version": "1.0.12", "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", - "dev": true, "dependencies": { "tmpl": "1.0.5" } @@ -19745,7 +19424,6 @@ }, "node_modules/merge-stream": { "version": "2.0.0", - "dev": true, "license": "MIT" }, "node_modules/merge2": { @@ -19769,7 +19447,6 @@ "version": "4.0.7", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", - "dev": true, "dependencies": { "braces": "^3.0.3", "picomatch": "^2.3.1" @@ -19830,7 +19507,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", - "dev": true, "engines": { "node": ">=6" } @@ -19939,7 +19615,6 @@ }, "node_modules/minimatch": { "version": "3.1.2", - "dev": true, "license": "ISC", "dependencies": { "brace-expansion": "^1.1.7" @@ -20203,7 +19878,6 @@ }, "node_modules/natural-compare": { "version": "1.4.0", - "dev": true, "license": "MIT" }, "node_modules/negotiator": { @@ -20217,7 +19891,6 @@ }, "node_modules/neo-async": { "version": "2.6.2", - "dev": true, "license": "MIT" }, "node_modules/nice-try": { @@ -20281,8 +19954,7 @@ "node_modules/node-int64": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", - "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", - "dev": true + "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==" }, "node_modules/node-libs-browser": { "version": "2.2.1", @@ -20379,7 +20051,6 @@ }, "node_modules/node-releases": { "version": "2.0.14", - "dev": true, "license": "MIT" }, "node_modules/nopt": { @@ -20417,7 +20088,6 @@ }, "node_modules/normalize-path": { "version": "3.0.0", - "dev": true, "license": "MIT", "engines": { "node": ">=0.10.0" @@ -20487,8 +20157,7 @@ "node_modules/nwsapi": { "version": "2.2.10", "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.10.tgz", - "integrity": "sha512-QK0sRs7MKv0tKe1+5uZIQk/C8XGza4DAnztJG8iD+TpJIORARrCxczA738awHrZoHeTjSSoHqao2teO0dC/gFQ==", - "dev": true + "integrity": "sha512-QK0sRs7MKv0tKe1+5uZIQk/C8XGza4DAnztJG8iD+TpJIORARrCxczA738awHrZoHeTjSSoHqao2teO0dC/gFQ==" }, "node_modules/oauth-sign": { "version": "0.9.0", @@ -20679,7 +20348,6 @@ }, "node_modules/once": { "version": "1.4.0", - "dev": true, "license": "ISC", "dependencies": { "wrappy": "1" @@ -20689,7 +20357,6 @@ "version": "5.1.2", "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", - "dev": true, "dependencies": { "mimic-fn": "^2.1.0" }, @@ -20896,6 +20563,29 @@ "node": ">=4" } }, + "node_modules/optimize-css-assets-webpack-plugin/node_modules/picocolors": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-0.2.1.tgz", + "integrity": "sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA==", + "dev": true + }, + "node_modules/optimize-css-assets-webpack-plugin/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/optimize-css-assets-webpack-plugin/node_modules/postcss-calc": { "version": "7.0.5", "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-7.0.5.tgz", @@ -21743,7 +21433,6 @@ "version": "5.2.0", "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", - "dev": true, "dependencies": { "@babel/code-frame": "^7.0.0", "error-ex": "^1.3.1", @@ -21825,7 +21514,6 @@ }, "node_modules/path-is-absolute": { "version": "1.0.1", - "dev": true, "license": "MIT", "engines": { "node": ">=0.10.0" @@ -21917,13 +21605,12 @@ "dev": true }, "node_modules/picocolors": { - "version": "0.2.1", - "dev": true, - "license": "ISC" + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", + "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==" }, "node_modules/picomatch": { "version": "2.3.1", - "dev": true, "license": "MIT", "engines": { "node": ">=8.6" @@ -21978,7 +21665,6 @@ "version": "4.0.6", "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", - "dev": true, "engines": { "node": ">= 6" } @@ -22001,13 +21687,6 @@ "url": "https://opencollective.com/popperjs" } }, - "node_modules/portal-vue": { - "version": "2.1.7", - "license": "MIT", - "peerDependencies": { - "vue": "^2.5.18" - } - }, "node_modules/portfinder": { "version": "1.0.32", "dev": true, @@ -22047,19 +21726,30 @@ } }, "node_modules/postcss": { - "version": "7.0.39", - "dev": true, - "license": "MIT", + "version": "8.4.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.39.tgz", + "integrity": "sha512-0vzE+lAiG7hZl1/9I8yzKLx3aR9Xbof3fBHKunvMfOCYAtMhrsnccJY2iTURb9EZd5+pLuiNV9/c/GZJOHsgIw==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], "dependencies": { - "picocolors": "^0.2.1", - "source-map": "^0.6.1" + "nanoid": "^3.3.7", + "picocolors": "^1.0.1", + "source-map-js": "^1.2.0" }, "engines": { - "node": ">=6.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" + "node": "^10 || ^12 || >=14" } }, "node_modules/postcss-calc": { @@ -22617,6 +22307,29 @@ "node": ">=6.0.0" } }, + "node_modules/postcss-safe-parser/node_modules/picocolors": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-0.2.1.tgz", + "integrity": "sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA==", + "dev": true + }, + "node_modules/postcss-safe-parser/node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, "node_modules/postcss-selector-parser": { "version": "6.0.15", "dev": true, @@ -22673,12 +22386,6 @@ "integrity": "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==", "dev": true }, - "node_modules/postcss-svgo/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", - "dev": true - }, "node_modules/postcss-svgo/node_modules/svgo": { "version": "2.8.0", "resolved": "https://registry.npmjs.org/svgo/-/svgo-2.8.0.tgz", @@ -22789,7 +22496,6 @@ "version": "27.5.1", "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", - "dev": true, "dependencies": { "ansi-regex": "^5.0.1", "ansi-styles": "^5.0.0", @@ -22803,7 +22509,6 @@ "version": "5.2.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true, "engines": { "node": ">=10" }, @@ -22996,7 +22701,6 @@ "version": "2.4.2", "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", - "dev": true, "dependencies": { "kleur": "^3.0.3", "sisteransi": "^1.0.5" @@ -23051,8 +22755,7 @@ "node_modules/psl": { "version": "1.9.0", "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", - "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", - "dev": true + "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==" }, "node_modules/public-encrypt": { "version": "4.0.3", @@ -23106,7 +22809,6 @@ }, "node_modules/punycode": { "version": "2.3.1", - "dev": true, "license": "MIT", "engines": { "node": ">=6" @@ -23167,8 +22869,7 @@ "node_modules/querystringify": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", - "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", - "dev": true + "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==" }, "node_modules/queue-microtask": { "version": "1.2.3", @@ -23191,7 +22892,6 @@ }, "node_modules/randombytes": { "version": "2.1.0", - "dev": true, "license": "MIT", "dependencies": { "safe-buffer": "^5.1.0" @@ -23265,8 +22965,7 @@ "node_modules/react-is": { "version": "17.0.2", "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", - "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", - "dev": true + "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==" }, "node_modules/read-pkg": { "version": "5.2.0", @@ -23631,7 +23330,6 @@ }, "node_modules/require-directory": { "version": "2.1.1", - "dev": true, "license": "MIT", "engines": { "node": ">=0.10.0" @@ -23654,8 +23352,7 @@ "node_modules/requires-port": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", - "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", - "dev": true + "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==" }, "node_modules/resolve": { "version": "1.22.8", @@ -23702,7 +23399,6 @@ "version": "1.1.1", "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.1.tgz", "integrity": "sha512-/NtpHNDN7jWhAaQ9BvBUYZ6YTXsRBgfqWFWP7BZBaoMJO/I3G5OFzvTuWNlZC3aPjins1F+TNrLKsGbH4rfsRQ==", - "dev": true, "engines": { "node": ">=10" } @@ -23776,7 +23472,6 @@ }, "node_modules/rimraf": { "version": "3.0.2", - "dev": true, "license": "ISC", "dependencies": { "glob": "^7.1.3" @@ -23857,7 +23552,6 @@ }, "node_modules/safe-buffer": { "version": "5.2.1", - "dev": true, "funding": [ { "type": "github", @@ -23902,8 +23596,7 @@ "node_modules/safer-buffer": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", - "dev": true + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" }, "node_modules/sass": { "version": "1.75.0", @@ -23972,7 +23665,6 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/saxes/-/saxes-5.0.1.tgz", "integrity": "sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==", - "dev": true, "dependencies": { "xmlchars": "^2.2.0" }, @@ -24031,7 +23723,6 @@ }, "node_modules/semver": { "version": "6.3.1", - "dev": true, "license": "ISC", "bin": { "semver": "bin/semver.js" @@ -24107,7 +23798,6 @@ }, "node_modules/serialize-javascript": { "version": "6.0.2", - "dev": true, "license": "BSD-3-Clause", "dependencies": { "randombytes": "^2.1.0" @@ -24338,7 +24028,6 @@ }, "node_modules/signal-exit": { "version": "3.0.7", - "dev": true, "license": "ISC" }, "node_modules/simple-swizzle": { @@ -24373,14 +24062,12 @@ "node_modules/sisteransi": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", - "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", - "dev": true + "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==" }, "node_modules/slash": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", - "dev": true, "engines": { "node": ">=8" } @@ -24645,7 +24332,6 @@ "version": "0.5.21", "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", - "dev": true, "dependencies": { "buffer-from": "^1.0.0", "source-map": "^0.6.0" @@ -24658,12 +24344,6 @@ "deprecated": "See https://github.com/lydell/source-map-url#deprecated", "dev": true }, - "node_modules/sourcemap-codec": { - "version": "1.4.8", - "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", - "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", - "deprecated": "Please use @jridgewell/sourcemap-codec instead" - }, "node_modules/spdx-correct": { "version": "3.2.0", "dev": true, @@ -24761,7 +24441,6 @@ }, "node_modules/sprintf-js": { "version": "1.0.3", - "dev": true, "license": "BSD-3-Clause" }, "node_modules/sshpk": { @@ -24809,7 +24488,6 @@ "version": "2.0.6", "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", - "dev": true, "dependencies": { "escape-string-regexp": "^2.0.0" }, @@ -24821,7 +24499,6 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", - "dev": true, "engines": { "node": ">=8" } @@ -25018,7 +24695,6 @@ "version": "4.0.2", "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", - "dev": true, "dependencies": { "char-regex": "^1.0.2", "strip-ansi": "^6.0.0" @@ -25029,7 +24705,6 @@ }, "node_modules/string-width": { "version": "4.2.3", - "dev": true, "license": "MIT", "dependencies": { "emoji-regex": "^8.0.0", @@ -25098,7 +24773,6 @@ }, "node_modules/strip-ansi": { "version": "6.0.1", - "dev": true, "license": "MIT", "dependencies": { "ansi-regex": "^5.0.1" @@ -25123,7 +24797,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", - "dev": true, "engines": { "node": ">=8" } @@ -25149,7 +24822,6 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", - "dev": true, "engines": { "node": ">=6" } @@ -25166,7 +24838,6 @@ "version": "3.1.1", "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", - "dev": true, "engines": { "node": ">=8" }, @@ -25302,7 +24973,6 @@ "version": "2.3.0", "resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.3.0.tgz", "integrity": "sha512-RpsAZlpWcDwOPQA22aCH4J0t7L8JmAvsCxfOSEwm7cQs3LshN36QaTkwd70DnBOXDWGssw2eUoc8CaRWT0XunA==", - "dev": true, "dependencies": { "has-flag": "^4.0.0", "supports-color": "^7.0.0" @@ -25315,7 +24985,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -25324,7 +24993,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -25438,8 +25106,7 @@ "node_modules/symbol-tree": { "version": "3.2.4", "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", - "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", - "dev": true + "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==" }, "node_modules/synckit": { "version": "0.8.8", @@ -25460,7 +25127,6 @@ "version": "2.2.1", "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", - "dev": true, "engines": { "node": ">=6" } @@ -25480,7 +25146,6 @@ "version": "2.1.1", "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz", "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==", - "dev": true, "dependencies": { "ansi-escapes": "^4.2.1", "supports-hyperlinks": "^2.0.0" @@ -25496,7 +25161,6 @@ "version": "5.31.1", "resolved": "https://registry.npmjs.org/terser/-/terser-5.31.1.tgz", "integrity": "sha512-37upzU1+viGvuFtBo9NPufCb9dwM0+l9hMxYyWfBA+fbwrPqNJAhbZ6W47bBFnZHKHTUBnMvi87434qq+qnxOg==", - "dev": true, "dependencies": { "@jridgewell/source-map": "^0.3.3", "acorn": "^8.8.2", @@ -25514,7 +25178,6 @@ "version": "5.3.10", "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz", "integrity": "sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==", - "dev": true, "dependencies": { "@jridgewell/trace-mapping": "^0.3.20", "jest-worker": "^27.4.5", @@ -25548,7 +25211,6 @@ "version": "3.3.0", "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", - "dev": true, "dependencies": { "@types/json-schema": "^7.0.8", "ajv": "^6.12.5", @@ -25565,14 +25227,12 @@ "node_modules/terser/node_modules/commander": { "version": "2.20.3", "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", - "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", - "dev": true + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" }, "node_modules/test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", - "dev": true, "dependencies": { "@istanbuljs/schema": "^0.1.2", "glob": "^7.1.4", @@ -25650,8 +25310,7 @@ "node_modules/throat": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/throat/-/throat-6.0.2.tgz", - "integrity": "sha512-WKexMoJj3vEuK0yFEapj8y64V0A6xcuPuK9Gt1d0R+dzCSJc0lHqQytAbSB4cDAK0dWh4T0E2ETkoLE2WZ41OQ==", - "dev": true + "integrity": "sha512-WKexMoJj3vEuK0yFEapj8y64V0A6xcuPuK9Gt1d0R+dzCSJc0lHqQytAbSB4cDAK0dWh4T0E2ETkoLE2WZ41OQ==" }, "node_modules/through": { "version": "2.3.8", @@ -25732,8 +25391,7 @@ "node_modules/tmpl": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", - "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", - "dev": true + "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==" }, "node_modules/to-arraybuffer": { "version": "1.0.1", @@ -25805,7 +25463,6 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dev": true, "dependencies": { "is-number": "^7.0.0" }, @@ -25898,7 +25555,6 @@ "version": "4.1.4", "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.4.tgz", "integrity": "sha512-Loo5UUvLD9ScZ6jh8beX1T6sO1w2/MpCRpEP7V280GKMVUQ0Jzar2U3UJPsrdbziLEMMhu3Ujnq//rhiFuIeag==", - "dev": true, "dependencies": { "psl": "^1.1.33", "punycode": "^2.1.1", @@ -25913,7 +25569,6 @@ "version": "0.2.0", "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", - "dev": true, "engines": { "node": ">= 4.0.0" } @@ -25922,7 +25577,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz", "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==", - "dev": true, "dependencies": { "punycode": "^2.1.1" }, @@ -26002,7 +25656,6 @@ "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", - "dev": true, "engines": { "node": ">=4" } @@ -26011,7 +25664,6 @@ "version": "0.21.3", "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", - "dev": true, "engines": { "node": ">=10" }, @@ -26109,7 +25761,6 @@ }, "node_modules/typedarray-to-buffer": { "version": "3.1.5", - "dev": true, "license": "MIT", "dependencies": { "is-typedarray": "^1.0.0" @@ -26159,7 +25810,6 @@ }, "node_modules/undici-types": { "version": "5.26.5", - "dev": true, "license": "MIT" }, "node_modules/unicode-canonical-property-names-ecmascript": { @@ -26347,7 +25997,6 @@ }, "node_modules/update-browserslist-db": { "version": "1.0.13", - "dev": true, "funding": [ { "type": "opencollective", @@ -26374,11 +26023,6 @@ "browserslist": ">= 4.21.0" } }, - "node_modules/update-browserslist-db/node_modules/picocolors": { - "version": "1.0.0", - "dev": true, - "license": "ISC" - }, "node_modules/update-notifier": { "version": "4.1.3", "dev": true, @@ -26474,7 +26118,6 @@ }, "node_modules/uri-js": { "version": "4.4.1", - "dev": true, "license": "BSD-2-Clause", "dependencies": { "punycode": "^2.1.0" @@ -26558,7 +26201,6 @@ "version": "1.5.10", "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", - "dev": true, "dependencies": { "querystringify": "^2.1.1", "requires-port": "^1.0.0" @@ -26669,7 +26311,6 @@ "version": "8.1.1", "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-8.1.1.tgz", "integrity": "sha512-FGtKtv3xIpR6BYhvgH8MI/y78oT7d8Au3ww4QIxymrCtZEh5b8gCw2siywE+puhEmuWKDtmfrvF5UlB298ut3w==", - "dev": true, "dependencies": { "@types/istanbul-lib-coverage": "^2.0.1", "convert-source-map": "^1.6.0", @@ -26682,14 +26323,12 @@ "node_modules/v8-to-istanbul/node_modules/convert-source-map": { "version": "1.9.0", "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true + "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==" }, "node_modules/v8-to-istanbul/node_modules/source-map": { "version": "0.7.4", "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", - "dev": true, "engines": { "node": ">= 8" } @@ -26743,15 +26382,23 @@ "dev": true }, "node_modules/vue": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/vue/-/vue-3.2.37.tgz", - "integrity": "sha512-bOKEZxrm8Eh+fveCqS1/NkG/n6aMidsI6hahas7pa0w/l7jkbssJVsRhVDs07IdDq7h9KHswZOgItnwJAgtVtQ==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/vue/-/vue-3.4.29.tgz", + "integrity": "sha512-8QUYfRcYzNlYuzKPfge1UWC6nF9ym0lx7mpGVPJYNhddxEf3DD0+kU07NTL0sXuiT2HuJuKr/iEO8WvXvT0RSQ==", "dependencies": { - "@vue/compiler-dom": "3.2.37", - "@vue/compiler-sfc": "3.2.37", - "@vue/runtime-dom": "3.2.37", - "@vue/server-renderer": "3.2.37", - "@vue/shared": "3.2.37" + "@vue/compiler-dom": "3.4.29", + "@vue/compiler-sfc": "3.4.29", + "@vue/runtime-dom": "3.4.29", + "@vue/server-renderer": "3.4.29", + "@vue/shared": "3.4.29" + }, + "peerDependencies": { + "typescript": "*" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } } }, "node_modules/vue-cli-plugin-i18n": { @@ -26787,12 +26434,6 @@ "prettier": "^1.18.2 || ^2.0.0" } }, - "node_modules/vue-cli-plugin-i18n/node_modules/csstype": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", - "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", - "dev": true - }, "node_modules/vue-cli-plugin-i18n/node_modules/dotenv": { "version": "8.6.0", "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.6.0.tgz", @@ -26802,40 +26443,6 @@ "node": ">=10" } }, - "node_modules/vue-cli-plugin-i18n/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", - "dev": true - }, - "node_modules/vue-cli-plugin-i18n/node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "dependencies": { - "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } - }, "node_modules/vue-cli-plugin-i18n/node_modules/prettier": { "version": "2.8.8", "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", @@ -27241,8 +26848,18 @@ } }, "node_modules/vue-router": { - "version": "3.5.1", - "license": "MIT" + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-4.4.0.tgz", + "integrity": "sha512-HB+t2p611aIZraV2aPSRNXf0Z/oLZFrlygJm+sZbdJaW6lcFqEDQwnzUBXn+DApw+/QzDU/I9TeWx9izEjTmsA==", + "dependencies": { + "@vue/devtools-api": "^6.5.1" + }, + "funding": { + "url": "https://github.com/sponsors/posva" + }, + "peerDependencies": { + "vue": "^3.2.0" + } }, "node_modules/vue-server-renderer": { "version": "2.7.16", @@ -27422,95 +27039,55 @@ "license": "MIT" }, "node_modules/vue/node_modules/@vue/compiler-core": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.37.tgz", - "integrity": "sha512-81KhEjo7YAOh0vQJoSmAD68wLfYqJvoiD4ulyedzF+OEk/bk6/hx3fTNVfuzugIIaTrOx4PGx6pAiBRe5e9Zmg==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.4.29.tgz", + "integrity": "sha512-TFKiRkKKsRCKvg/jTSSKK7mYLJEQdUiUfykbG49rubC9SfDyvT2JrzTReopWlz2MxqeLyxh9UZhvxEIBgAhtrg==", "dependencies": { - "@babel/parser": "^7.16.4", - "@vue/shared": "3.2.37", + "@babel/parser": "^7.24.7", + "@vue/shared": "3.4.29", + "entities": "^4.5.0", "estree-walker": "^2.0.2", - "source-map": "^0.6.1" + "source-map-js": "^1.2.0" } }, "node_modules/vue/node_modules/@vue/compiler-dom": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.2.37.tgz", - "integrity": "sha512-yxJLH167fucHKxaqXpYk7x8z7mMEnXOw3G2q62FTkmsvNxu4FQSu5+3UMb+L7fjKa26DEzhrmCxAgFLLIzVfqQ==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.4.29.tgz", + "integrity": "sha512-A6+iZ2fKIEGnfPJejdB7b1FlJzgiD+Y/sxxKwJWg1EbJu6ZPgzaPQQ51ESGNv0CP6jm6Z7/pO6Ia8Ze6IKrX7w==", "dependencies": { - "@vue/compiler-core": "3.2.37", - "@vue/shared": "3.2.37" + "@vue/compiler-core": "3.4.29", + "@vue/shared": "3.4.29" } }, "node_modules/vue/node_modules/@vue/compiler-sfc": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-3.2.37.tgz", - "integrity": "sha512-+7i/2+9LYlpqDv+KTtWhOZH+pa8/HnX/905MdVmAcI/mPQOBwkHHIzrsEsucyOIZQYMkXUiTkmZq5am/NyXKkg==", - "dependencies": { - "@babel/parser": "^7.16.4", - "@vue/compiler-core": "3.2.37", - "@vue/compiler-dom": "3.2.37", - "@vue/compiler-ssr": "3.2.37", - "@vue/reactivity-transform": "3.2.37", - "@vue/shared": "3.2.37", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-3.4.29.tgz", + "integrity": "sha512-zygDcEtn8ZimDlrEQyLUovoWgKQic6aEQqRXce2WXBvSeHbEbcAsXyCk9oG33ZkyWH4sl9D3tkYc1idoOkdqZQ==", + "dependencies": { + "@babel/parser": "^7.24.7", + "@vue/compiler-core": "3.4.29", + "@vue/compiler-dom": "3.4.29", + "@vue/compiler-ssr": "3.4.29", + "@vue/shared": "3.4.29", "estree-walker": "^2.0.2", - "magic-string": "^0.25.7", - "postcss": "^8.1.10", - "source-map": "^0.6.1" + "magic-string": "^0.30.10", + "postcss": "^8.4.38", + "source-map-js": "^1.2.0" } }, "node_modules/vue/node_modules/@vue/compiler-ssr": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.2.37.tgz", - "integrity": "sha512-7mQJD7HdXxQjktmsWp/J67lThEIcxLemz1Vb5I6rYJHR5vI+lON3nPGOH3ubmbvYGt8xEUaAr1j7/tIFWiEOqw==", + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.4.29.tgz", + "integrity": "sha512-rFbwCmxJ16tDp3N8XCx5xSQzjhidYjXllvEcqX/lopkoznlNPz3jyy0WGJCyhAaVQK677WWFt3YO/WUEkMMUFQ==", "dependencies": { - "@vue/compiler-dom": "3.2.37", - "@vue/shared": "3.2.37" + "@vue/compiler-dom": "3.4.29", + "@vue/shared": "3.4.29" } }, "node_modules/vue/node_modules/@vue/shared": { - "version": "3.2.37", - "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.37.tgz", - "integrity": "sha512-4rSJemR2NQIo9Klm1vabqWjD8rs/ZaJSzMxkMNeJS6lHiUjjUeYFbooN19NgFjztubEKh3WlZUeOLVdbbUWHsw==" - }, - "node_modules/vue/node_modules/magic-string": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", - "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", - "dependencies": { - "sourcemap-codec": "^1.4.8" - } - }, - "node_modules/vue/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==" - }, - "node_modules/vue/node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "dependencies": { - "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } + "version": "3.4.29", + "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.4.29.tgz", + "integrity": "sha512-hQ2gAQcBO/CDpC82DCrinJNgOHI2v+FA7BDW4lMSPeBpQ7sRe2OLHWe5cph1s7D8DUQAwRt18dBDfJJ220APEA==" }, "node_modules/vuepress": { "version": "1.9.7", @@ -27667,10 +27244,14 @@ } }, "node_modules/vuex": { - "version": "3.6.2", - "license": "MIT", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/vuex/-/vuex-4.1.0.tgz", + "integrity": "sha512-hmV6UerDrPcgbSy9ORAtNXDr9M4wlNP4pEFKye4ujJF8oqgFFuxDCdOLS3eNoRTtq5O3hoBDh9Doj1bQMYHRbQ==", + "dependencies": { + "@vue/devtools-api": "^6.0.0-beta.11" + }, "peerDependencies": { - "vue": "^2.0.0" + "vue": "^3.2.0" } }, "node_modules/w3c-hr-time": { @@ -27678,7 +27259,6 @@ "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz", "integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==", "deprecated": "Use your platform's native performance.now() and performance.timeOrigin.", - "dev": true, "dependencies": { "browser-process-hrtime": "^1.0.0" } @@ -27687,7 +27267,6 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz", "integrity": "sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA==", - "dev": true, "dependencies": { "xml-name-validator": "^3.0.0" }, @@ -27699,7 +27278,6 @@ "version": "1.0.8", "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", - "dev": true, "dependencies": { "makeerror": "1.0.12" } @@ -28075,7 +27653,6 @@ "version": "6.1.0", "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-6.1.0.tgz", "integrity": "sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w==", - "dev": true, "engines": { "node": ">=10.4" } @@ -28084,7 +27661,6 @@ "version": "5.92.0", "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.92.0.tgz", "integrity": "sha512-Bsw2X39MYIgxouNATyVpCNVWBCuUwDgWtN78g6lSdPJRLaQ/PUVm/oXcaRAyY/sMFoKFQrsPeqvTizWtq7QPCA==", - "dev": true, "dependencies": { "@types/eslint-scope": "^3.7.3", "@types/estree": "^1.0.5", @@ -28174,12 +27750,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/webpack-bundle-analyzer/node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", - "dev": true - }, "node_modules/webpack-chain": { "version": "6.5.1", "dev": true, @@ -28557,7 +28127,6 @@ "version": "5.1.1", "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", - "dev": true, "dependencies": { "esrecurse": "^4.3.0", "estraverse": "^4.1.1" @@ -28570,7 +28139,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", - "dev": true, "engines": { "node": ">=4.0" } @@ -28579,7 +28147,6 @@ "version": "3.3.0", "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", - "dev": true, "engines": { "node": ">=0.8.x" } @@ -28588,7 +28155,6 @@ "version": "3.3.0", "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", - "dev": true, "dependencies": { "@types/json-schema": "^7.0.8", "ajv": "^6.12.5", @@ -28606,7 +28172,6 @@ "version": "3.2.3", "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz", "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==", - "dev": true, "engines": { "node": ">=10.13.0" } @@ -28739,7 +28304,6 @@ "version": "1.0.5", "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", - "dev": true, "dependencies": { "iconv-lite": "0.4.24" } @@ -28753,14 +28317,12 @@ "node_modules/whatwg-mimetype": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", - "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==", - "dev": true + "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==" }, "node_modules/whatwg-url": { "version": "8.7.0", "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz", "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==", - "dev": true, "dependencies": { "lodash": "^4.7.0", "tr46": "^2.1.0", @@ -28857,7 +28419,6 @@ "version": "7.0.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, "dependencies": { "ansi-styles": "^4.0.0", "string-width": "^4.1.0", @@ -28921,7 +28482,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -28936,7 +28496,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -28947,19 +28506,16 @@ "node_modules/wrap-ansi/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/wrappy": { "version": "1.0.2", - "dev": true, "license": "ISC" }, "node_modules/write-file-atomic": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", - "dev": true, "dependencies": { "imurmurhash": "^0.1.4", "is-typedarray": "^1.0.0", @@ -28971,7 +28527,6 @@ "version": "7.5.10", "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.10.tgz", "integrity": "sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ==", - "dev": true, "engines": { "node": ">=8.3.0" }, @@ -28999,14 +28554,12 @@ "node_modules/xml-name-validator": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", - "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==", - "dev": true + "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==" }, "node_modules/xmlchars": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", - "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==", - "dev": true + "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==" }, "node_modules/xtend": { "version": "4.0.2", @@ -29039,7 +28592,6 @@ }, "node_modules/y18n": { "version": "5.0.8", - "dev": true, "license": "ISC", "engines": { "node": ">=10" @@ -29047,7 +28599,6 @@ }, "node_modules/yallist": { "version": "3.1.1", - "dev": true, "license": "ISC" }, "node_modules/yaml": { @@ -29081,7 +28632,6 @@ }, "node_modules/yargs": { "version": "16.2.0", - "dev": true, "license": "MIT", "dependencies": { "cliui": "^7.0.2", @@ -29117,7 +28667,6 @@ }, "node_modules/yargs/node_modules/yargs-parser": { "version": "20.2.9", - "dev": true, "license": "ISC", "engines": { "node": ">=10" diff --git a/src/components/AppHeader/AppHeader.vue b/src/components/AppHeader/AppHeader.vue index 6b19ac08..25c0f2b3 100644 --- a/src/components/AppHeader/AppHeader.vue +++ b/src/components/AppHeader/AppHeader.vue @@ -118,6 +118,7 @@ import StatusIcon from '@/components/Global/StatusIcon'; import LoadingBar from '@/components/Global/LoadingBar'; import { useI18n } from 'vue-i18n'; import { mapState } from 'vuex'; +import i18n from '@/i18n'; export default { name: 'AppHeader', @@ -204,8 +205,8 @@ export default { }, isAuthorized(value) { if (value === false) { - this.errorToast(this.$t('global.toast.unAuthDescription'), { - title: this.$t('global.toast.unAuthTitle'), + this.errorToast(i18n.global.t('global.toast.unAuthDescription'), { + title: i18n.global.t('global.toast.unAuthTitle'), }); } }, diff --git a/src/components/Global/FormFile.vue b/src/components/Global/FormFile.vue index 1eafa25f..ccdc038e 100644 --- a/src/components/Global/FormFile.vue +++ b/src/components/Global/FormFile.vue @@ -42,6 +42,7 @@ <script> import { BFormFile } from 'bootstrap-vue'; import IconClose from '@carbon/icons-vue/es/close/20'; +import { useI18n } from 'vue-i18n'; export default { name: 'FormFile', @@ -70,6 +71,7 @@ export default { }, data() { return { + $t: useI18n().t, file: null, }; }, diff --git a/src/components/Global/InfoTooltip.vue b/src/components/Global/InfoTooltip.vue index 0e5c3b5d..f5063e91 100644 --- a/src/components/Global/InfoTooltip.vue +++ b/src/components/Global/InfoTooltip.vue @@ -12,6 +12,7 @@ <script> import IconTooltip from '@carbon/icons-vue/es/information/16'; +import { useI18n } from 'vue-i18n'; export default { components: { IconTooltip }, @@ -21,6 +22,11 @@ export default { default: '', }, }, + data() { + return { + $t: useI18n().t, + }; + }, }; </script> diff --git a/src/components/Mixins/BVPaginationMixin.js b/src/components/Mixins/BVPaginationMixin.js index 0bdf3687..1aa20a5a 100644 --- a/src/components/Mixins/BVPaginationMixin.js +++ b/src/components/Mixins/BVPaginationMixin.js @@ -1,4 +1,4 @@ -//import i18n from '@/i18n'; +import i18n from '@/i18n'; export const currentPage = 1; export const perPage = 20; export const itemsPerPageOptions = [ @@ -20,8 +20,7 @@ export const itemsPerPageOptions = [ }, { value: 0, - //text: i18n.$t('global.table.viewAll'), - text: 'global.table.viewAll', + text: i18n.global.t('global.table.viewAll'), }, ]; const BVPaginationMixin = { diff --git a/src/components/Mixins/BVToastMixin.js b/src/components/Mixins/BVToastMixin.js index 4ee757fa..c8b58da1 100644 --- a/src/components/Mixins/BVToastMixin.js +++ b/src/components/Mixins/BVToastMixin.js @@ -1,4 +1,5 @@ import StatusIcon from '../Global/StatusIcon'; +import i18n from '@/i18n'; const BVToastMixin = { components: { @@ -26,7 +27,7 @@ const BVToastMixin = { } }, $_BVToastMixin_createTimestamp() { - const timestamp = this.$options.filters.formatTime(new Date()); + const timestamp = this.$filters.formatTime(new Date()); return this.$createElement('p', { class: 'mt-3 mb-0' }, timestamp); }, $_BVToastMixin_createRefreshAction() { @@ -40,7 +41,7 @@ const BVToastMixin = { }, }, }, - this.$t('global.action.refresh'), + i18n.global.t('global.action.refresh'), ); }, $_BVToastMixin_initToast(body, title, variant) { @@ -56,7 +57,7 @@ const BVToastMixin = { successToast( message, { - title: t = this.$t('global.status.success'), + title: t = i18n.global.t('global.status.success'), timestamp, refreshAction, } = {}, @@ -70,7 +71,7 @@ const BVToastMixin = { errorToast( message, { - title: t = this.$t('global.status.error'), + title: t = i18n.global.t('global.status.error'), timestamp, refreshAction, } = {}, @@ -84,7 +85,7 @@ const BVToastMixin = { warningToast( message, { - title: t = this.$t('global.status.warning'), + title: t = i18n.global.t('global.status.warning'), timestamp, refreshAction, } = {}, @@ -98,7 +99,7 @@ const BVToastMixin = { infoToast( message, { - title: t = this.$t('global.status.informational'), + title: t = i18n.global.t('global.status.informational'), timestamp, refreshAction, } = {}, diff --git a/src/components/Mixins/LocalTimezoneLabelMixin.js b/src/components/Mixins/LocalTimezoneLabelMixin.js index 6b4141c6..7bbd7059 100644 --- a/src/components/Mixins/LocalTimezoneLabelMixin.js +++ b/src/components/Mixins/LocalTimezoneLabelMixin.js @@ -4,7 +4,7 @@ const LocalTimezoneLabelMixin = { methods: { localOffset() { const timezone = Intl.DateTimeFormat().resolvedOptions().timeZone; - const shortTz = this.$options.filters.shortTimeZone(new Date()); + const shortTz = this.$filters.shortTimeZone(new Date()); const pattern = `'${shortTz}' O`; return format(new Date(), pattern, { timezone }).replace('GMT', 'UTC'); }, diff --git a/src/components/Mixins/TableRowExpandMixin.js b/src/components/Mixins/TableRowExpandMixin.js index 92b2448d..04508774 100644 --- a/src/components/Mixins/TableRowExpandMixin.js +++ b/src/components/Mixins/TableRowExpandMixin.js @@ -1,15 +1,15 @@ -//import i18n from '@/i18n'; -//export const expandRowLabel = i18n.$t('global.table.expandTableRow'); - -export const expandRowLabel = 'expand row label TODO'; +import i18n from '@/i18n'; +export const expandRowLabel = i18n.global.t('global.table.expandTableRow'); const TableRowExpandMixin = { methods: { toggleRowDetails(row) { row.toggleDetails(); row.detailsShowing - ? (this.expandRowLabel = this.$t('global.table.expandTableRow')) - : (this.expandRowLabel = this.$t('global.table.collapseTableRow')); + ? (this.expandRowLabel = i18n.global.t('global.table.expandTableRow')) + : (this.expandRowLabel = i18n.global.t( + 'global.table.collapseTableRow', + )); }, }, }; diff --git a/src/env/components/AppNavigation/ibm.js b/src/env/components/AppNavigation/ibm.js index ed84e17a..85fbdc15 100644 --- a/src/env/components/AppNavigation/ibm.js +++ b/src/env/components/AppNavigation/ibm.js @@ -6,6 +6,7 @@ import IconSettings from '@carbon/icons-vue/es/settings/16'; import IconSecurity from '@carbon/icons-vue/es/security/16'; import IconChevronUp from '@carbon/icons-vue/es/chevron--up/16'; import IconDataBase from '@carbon/icons-vue/es/data--base--alt/16'; +import i18n from '@/i18n'; const AppNavigationMixin = { components: { @@ -23,117 +24,117 @@ const AppNavigationMixin = { navigationItems: [ { id: 'overview', - label: this.$t('appNavigation.overview'), + label: i18n.global.t('appNavigation.overview'), route: '/', icon: 'iconOverview', }, { id: 'logs', - label: this.$t('appNavigation.logs'), + label: i18n.global.t('appNavigation.logs'), icon: 'iconLogs', children: [ { id: 'dumps', - label: this.$t('appNavigation.dumps'), + label: i18n.global.t('appNavigation.dumps'), route: '/logs/dumps', }, { id: 'event-logs', - label: this.$t('appNavigation.eventLogs'), + label: i18n.global.t('appNavigation.eventLogs'), route: '/logs/event-logs', }, { id: 'post-code-logs', - label: this.$t('appNavigation.postCodeLogs'), + label: i18n.global.t('appNavigation.postCodeLogs'), route: '/logs/post-code-logs', }, ], }, { id: 'hardware-status', - label: this.$t('appNavigation.hardwareStatus'), + label: i18n.global.t('appNavigation.hardwareStatus'), icon: 'iconHealth', children: [ { id: 'inventory', - label: this.$t('appNavigation.inventory'), + label: i18n.global.t('appNavigation.inventory'), route: '/hardware-status/inventory', }, { id: 'sensors', - label: this.$t('appNavigation.sensors'), + label: i18n.global.t('appNavigation.sensors'), route: '/hardware-status/sensors', }, ], }, { id: 'operations', - label: this.$t('appNavigation.operations'), + label: i18n.global.t('appNavigation.operations'), icon: 'iconControl', children: this.operationsNavigationItems(), }, { id: 'settings', - label: this.$t('appNavigation.settings'), + label: i18n.global.t('appNavigation.settings'), icon: 'iconSettings', children: [ { id: 'date-time', - label: this.$t('appNavigation.dateTime'), + label: i18n.global.t('appNavigation.dateTime'), route: '/settings/date-time', }, { id: 'network', - label: this.$t('appNavigation.network'), + label: i18n.global.t('appNavigation.network'), route: '/settings/network', }, { id: 'power-restore-policy', - label: this.$t('appNavigation.powerRestorePolicy'), + label: i18n.global.t('appNavigation.powerRestorePolicy'), route: '/settings/power-restore-policy', }, ], }, { id: 'security-and-access', - label: this.$t('appNavigation.securityAndAccess'), + label: i18n.global.t('appNavigation.securityAndAccess'), icon: 'iconSecurityAndAccess', children: [ { id: 'sessions', - label: this.$t('appNavigation.sessions'), + label: i18n.global.t('appNavigation.sessions'), route: '/security-and-access/sessions', }, { id: 'ldap', - label: this.$t('appNavigation.ldap'), + label: i18n.global.t('appNavigation.ldap'), route: '/security-and-access/ldap', }, { id: 'user-management', - label: this.$t('appNavigation.userManagement'), + label: i18n.global.t('appNavigation.userManagement'), route: '/security-and-access/user-management', }, { id: 'policies', - label: this.$t('appNavigation.policies'), + label: i18n.global.t('appNavigation.policies'), route: '/security-and-access/policies', }, { id: 'certificates', - label: this.$t('appNavigation.certificates'), + label: i18n.global.t('appNavigation.certificates'), route: '/security-and-access/certificates', }, ], }, { id: 'resource-management', - label: this.$t('appNavigation.resourceManagement'), + label: i18n.global.t('appNavigation.resourceManagement'), icon: 'iconResourceManagement', children: [ { id: 'power', - label: this.$t('appNavigation.power'), + label: i18n.global.t('appNavigation.power'), route: '/resource-management/power', }, ], @@ -147,33 +148,33 @@ const AppNavigationMixin = { let operationNavigationItems = [ { id: 'factory-reset', - label: this.$t('appNavigation.factoryReset'), + label: i18n.global.t('appNavigation.factoryReset'), route: '/operations/factory-reset', }, { id: 'firmware', - label: this.$t('appNavigation.firmware'), + label: i18n.global.t('appNavigation.firmware'), route: '/operations/firmware', }, { id: 'reboot-bmc', - label: this.$t('appNavigation.rebootBmc'), + label: i18n.global.t('appNavigation.rebootBmc'), route: '/operations/reboot-bmc', }, { id: 'serial-over-lan', - label: this.$t('appNavigation.serialOverLan'), + label: i18n.global.t('appNavigation.serialOverLan'), route: '/operations/serial-over-lan', }, { id: 'server-power-operations', - label: this.$t('appNavigation.serverPowerOperations'), + label: i18n.global.t('appNavigation.serverPowerOperations'), route: '/operations/server-power-operations', }, ]; let pageKeyClear = { id: 'key-clear', - label: this.$t('appNavigation.keyClear'), + label: i18n.global.t('appNavigation.keyClear'), route: '/operations/key-clear', }; if (username === 'service' || username === 'admin') { diff --git a/src/env/components/AppNavigation/intel.js b/src/env/components/AppNavigation/intel.js index 0688a05e..e20b0ef4 100644 --- a/src/env/components/AppNavigation/intel.js +++ b/src/env/components/AppNavigation/intel.js @@ -6,6 +6,7 @@ import IconSettings from '@carbon/icons-vue/es/settings/16'; import IconSecurity from '@carbon/icons-vue/es/security/16'; import IconChevronUp from '@carbon/icons-vue/es/chevron--up/16'; import IconDataBase from '@carbon/icons-vue/es/data--base--alt/16'; +import i18n from '@/i18n'; const roles = { administrator: 'Administrator', @@ -30,78 +31,78 @@ const AppNavigationMixin = { navigationItems: [ { id: 'overview', - label: this.$t('appNavigation.overview'), + label: i18n.global.t('appNavigation.overview'), route: '/', icon: 'iconOverview', }, { id: 'logs', - label: this.$t('appNavigation.logs'), + label: i18n.global.t('appNavigation.logs'), icon: 'iconLogs', children: [ { id: 'event-logs', - label: this.$t('appNavigation.eventLogs'), + label: i18n.global.t('appNavigation.eventLogs'), route: '/logs/event-logs', }, { id: 'post-code-logs', - label: this.$t('appNavigation.postCodeLogs'), + label: i18n.global.t('appNavigation.postCodeLogs'), route: '/logs/post-code-logs', }, ], }, { id: 'hardware-status', - label: this.$t('appNavigation.hardwareStatus'), + label: i18n.global.t('appNavigation.hardwareStatus'), icon: 'iconHealth', children: [ { id: 'inventory', - label: this.$t('appNavigation.inventory'), + label: i18n.global.t('appNavigation.inventory'), route: '/hardware-status/inventory', }, { id: 'sensors', - label: this.$t('appNavigation.sensors'), + label: i18n.global.t('appNavigation.sensors'), route: '/hardware-status/sensors', }, ], }, { id: 'operations', - label: this.$t('appNavigation.operations'), + label: i18n.global.t('appNavigation.operations'), icon: 'iconControl', children: [ { id: 'kvm', - label: this.$t('appNavigation.kvm'), + label: i18n.global.t('appNavigation.kvm'), route: '/operations/kvm', }, { id: 'firmware', - label: this.$t('appNavigation.firmware'), + label: i18n.global.t('appNavigation.firmware'), route: '/operations/firmware', }, { id: 'reboot-bmc', - label: this.$t('appNavigation.rebootBmc'), + label: i18n.global.t('appNavigation.rebootBmc'), route: '/operations/reboot-bmc', }, { id: 'serial-over-lan', - label: this.$t('appNavigation.serialOverLan'), + label: i18n.global.t('appNavigation.serialOverLan'), route: '/operations/serial-over-lan', exclusiveToRoles: [roles.administrator], }, { id: 'server-power-operations', - label: this.$t('appNavigation.serverPowerOperations'), + label: i18n.global.t('appNavigation.serverPowerOperations'), route: '/operations/server-power-operations', }, { id: 'virtual-media', - label: this.$t('appNavigation.virtualMedia'), + label: i18n.global.t('appNavigation.virtualMedia'), route: '/operations/virtual-media', exclusiveToRoles: [roles.administrator], }, @@ -109,56 +110,56 @@ const AppNavigationMixin = { }, { id: 'settings', - label: this.$t('appNavigation.settings'), + label: i18n.global.t('appNavigation.settings'), icon: 'iconSettings', children: [ { id: 'date-time', - label: this.$t('appNavigation.dateTime'), + label: i18n.global.t('appNavigation.dateTime'), route: '/settings/date-time', }, { id: 'network', - label: this.$t('appNavigation.network'), + label: i18n.global.t('appNavigation.network'), route: '/settings/network', }, ], }, { id: 'security-and-access', - label: this.$t('appNavigation.securityAndAccess'), + label: i18n.global.t('appNavigation.securityAndAccess'), icon: 'iconSecurityAndAccess', children: [ { id: 'sessions', - label: this.$t('appNavigation.sessions'), + label: i18n.global.t('appNavigation.sessions'), route: '/security-and-access/sessions', }, { id: 'user-management', - label: this.$t('appNavigation.userManagement'), + label: i18n.global.t('appNavigation.userManagement'), route: '/security-and-access/user-management', }, { id: 'policies', - label: this.$t('appNavigation.policies'), + label: i18n.global.t('appNavigation.policies'), route: '/security-and-access/policies', }, { id: 'certificates', - label: this.$t('appNavigation.certificates'), + label: i18n.global.t('appNavigation.certificates'), route: '/security-and-access/certificates', }, ], }, { id: 'resource-management', - label: this.$t('appNavigation.resourceManagement'), + label: i18n.global.t('appNavigation.resourceManagement'), icon: 'iconResourceManagement', children: [ { id: 'power', - label: this.$t('appNavigation.power'), + label: i18n.global.t('appNavigation.power'), route: '/resource-management/power', }, ], diff --git a/src/main.js b/src/main.js index 23bfb691..92c5c903 100644 --- a/src/main.js +++ b/src/main.js @@ -5,7 +5,7 @@ import i18n from './i18n'; import router from './router'; -//import { format } from 'date-fns-tz'; +import { format } from 'date-fns-tz'; //Do not change store import. //Exact match alias set to support @@ -52,49 +52,6 @@ import { TooltipPlugin, } from 'bootstrap-vue'; -// Filters -/* -Vue.filter('shortTimeZone', function (value) { - const longTZ = value - .toString() - .match(/\((.*)\)/) - .pop(); - const regexNotUpper = /[*a-z ]/g; - return longTZ.replace(regexNotUpper, ''); -}); - -Vue.filter('formatDate', function (value) { - const isUtcDisplay = store.getters['global/isUtcDisplay']; - - if (value instanceof Date) { - if (isUtcDisplay) { - return value.toISOString().substring(0, 10); - } - const pattern = `yyyy-MM-dd`; - const timezone = Intl.DateTimeFormat().resolvedOptions().timeZone; - return format(value, pattern, { timezone }); - } -}); - -Vue.filter('formatTime', function (value) { - const isUtcDisplay = store.getters['global/isUtcDisplay']; - - if (value instanceof Date) { - if (isUtcDisplay) { - let timeOptions = { - timeZone: 'UTC', - hourCycle: 'h23', - }; - return `${value.toLocaleTimeString('default', timeOptions)} UTC`; - } - const timezone = Intl.DateTimeFormat().resolvedOptions().timeZone; - const shortTz = Vue.filter('shortTimeZone')(value); - const pattern = `HH:mm:ss ('${shortTz}' O)`; - return format(value, pattern, { timezone }).replace('GMT', 'UTC'); - } -}); -*/ - const app = createApp({ router, store, @@ -154,3 +111,44 @@ app.use(TooltipPlugin); app.mount('#app'); app.prototype.$eventBus = eventBus; +//Filters +const filter = { + formatDate(value) { + const isUtcDisplay = store.getters['global/isUtcDisplay']; + + if (value instanceof Date) { + if (isUtcDisplay) { + return value.toISOString().substring(0, 10); + } + const pattern = `yyyy-MM-dd`; + const timezone = Intl.DateTimeFormat().resolvedOptions().timeZone; + return format(value, pattern, { timezone }); + } + }, + formatTime(value) { + const isUtcDisplay = store.getters['global/isUtcDisplay']; + + if (value instanceof Date) { + if (isUtcDisplay) { + let timeOptions = { + timeZone: 'UTC', + hourCycle: 'h23', + }; + return `${value.toLocaleTimeString('default', timeOptions)} UTC`; + } + const timezone = Intl.DateTimeFormat().resolvedOptions().timeZone; + const shortTz = this.shortTimeZone(value); + const pattern = `HH:mm:ss ('${shortTz}' O)`; + return format(value, pattern, { timezone }).replace('GMT', 'UTC'); + } + }, + shortTimeZone(value) { + const longTZ = value + .toString() + .match(/\((.*)\)/) + .pop(); + const regexNotUpper = /[*a-z ]/g; + return longTZ.replace(regexNotUpper, ''); + }, +}; +app.config.globalProperties.$filters = filter; diff --git a/src/store/modules/GlobalStore.js b/src/store/modules/GlobalStore.js index 10d50b1a..ed3e381a 100644 --- a/src/store/modules/GlobalStore.js +++ b/src/store/modules/GlobalStore.js @@ -81,7 +81,7 @@ const GlobalStore = { const serviceRoot = await api .get('/redfish/v1') .catch((error) => console.log(error)); - let bmcPath = serviceRoot.data?.ManagerProvidingService?.['@odata.id']; + let bmcPath = serviceRoot?.data?.ManagerProvidingService?.['@odata.id']; if (!bmcPath) { const managers = await api .get('/redfish/v1/Managers') @@ -94,7 +94,7 @@ const GlobalStore = { const systems = await api .get('/redfish/v1/Systems') .catch((error) => console.log(error)); - let systemPath = systems.data?.Members?.[0]?.['@odata.id']; + let systemPath = systems?.data?.Members?.[0]?.['@odata.id']; return systemPath; }, async getBmcTime({ commit }) { diff --git a/src/store/modules/HardwareStatus/AssemblyStore.js b/src/store/modules/HardwareStatus/AssemblyStore.js index 13cdbbc9..dfb7010c 100644 --- a/src/store/modules/HardwareStatus/AssemblyStore.js +++ b/src/store/modules/HardwareStatus/AssemblyStore.js @@ -58,9 +58,13 @@ const AssemblyStore = { .patch(uri, updatedIdentifyLedValue) .then(() => { if (led.identifyLed) { - return i18n.t('pageInventory.toast.successEnableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successEnableIdentifyLed', + ); } else { - return i18n.t('pageInventory.toast.successDisableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successDisableIdentifyLed', + ); } }) .catch((error) => { @@ -68,11 +72,11 @@ const AssemblyStore = { console.log('error', error); if (led.identifyLed) { throw new Error( - i18n.t('pageInventory.toast.errorEnableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorEnableIdentifyLed'), ); } else { throw new Error( - i18n.t('pageInventory.toast.errorDisableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorDisableIdentifyLed'), ); } }); diff --git a/src/store/modules/HardwareStatus/BmcStore.js b/src/store/modules/HardwareStatus/BmcStore.js index f0e4cf96..c6de412e 100644 --- a/src/store/modules/HardwareStatus/BmcStore.js +++ b/src/store/modules/HardwareStatus/BmcStore.js @@ -61,9 +61,13 @@ const BmcStore = { .then(() => { dispatch('getBmcInfo'); if (led.identifyLed) { - return i18n.t('pageInventory.toast.successEnableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successEnableIdentifyLed', + ); } else { - return i18n.t('pageInventory.toast.successDisableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successDisableIdentifyLed', + ); } }) .catch((error) => { @@ -71,11 +75,11 @@ const BmcStore = { console.log('error', error); if (led.identifyLed) { throw new Error( - i18n.t('pageInventory.toast.errorEnableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorEnableIdentifyLed'), ); } else { throw new Error( - i18n.t('pageInventory.toast.errorDisableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorDisableIdentifyLed'), ); } }); diff --git a/src/store/modules/HardwareStatus/ChassisStore.js b/src/store/modules/HardwareStatus/ChassisStore.js index 7e591ad2..3023a9c7 100644 --- a/src/store/modules/HardwareStatus/ChassisStore.js +++ b/src/store/modules/HardwareStatus/ChassisStore.js @@ -75,9 +75,13 @@ const ChassisStore = { .then(() => { dispatch('getChassisInfo'); if (led.identifyLed) { - return i18n.t('pageInventory.toast.successEnableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successEnableIdentifyLed', + ); } else { - return i18n.t('pageInventory.toast.successDisableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successDisableIdentifyLed', + ); } }) .catch((error) => { @@ -85,11 +89,11 @@ const ChassisStore = { console.log('error', error); if (led.identifyLed) { throw new Error( - i18n.t('pageInventory.toast.errorEnableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorEnableIdentifyLed'), ); } else { throw new Error( - i18n.t('pageInventory.toast.errorDisableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorDisableIdentifyLed'), ); } }); diff --git a/src/store/modules/HardwareStatus/MemoryStore.js b/src/store/modules/HardwareStatus/MemoryStore.js index d9a107d3..252823f2 100644 --- a/src/store/modules/HardwareStatus/MemoryStore.js +++ b/src/store/modules/HardwareStatus/MemoryStore.js @@ -77,9 +77,13 @@ const MemoryStore = { .patch(uri, updatedIdentifyLedValue) .then(() => { if (led.identifyLed) { - return i18n.t('pageInventory.toast.successEnableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successEnableIdentifyLed', + ); } else { - return i18n.t('pageInventory.toast.successDisableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successDisableIdentifyLed', + ); } }) .catch((error) => { @@ -87,11 +91,11 @@ const MemoryStore = { console.log('error', error); if (led.identifyLed) { throw new Error( - i18n.t('pageInventory.toast.errorEnableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorEnableIdentifyLed'), ); } else { throw new Error( - i18n.t('pageInventory.toast.errorDisableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorDisableIdentifyLed'), ); } }); diff --git a/src/store/modules/HardwareStatus/ProcessorStore.js b/src/store/modules/HardwareStatus/ProcessorStore.js index 446fdb9c..268a8972 100644 --- a/src/store/modules/HardwareStatus/ProcessorStore.js +++ b/src/store/modules/HardwareStatus/ProcessorStore.js @@ -85,9 +85,13 @@ const ProcessorStore = { .patch(uri, updatedIdentifyLedValue) .then(() => { if (led.identifyLed) { - return i18n.t('pageInventory.toast.successEnableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successEnableIdentifyLed', + ); } else { - return i18n.t('pageInventory.toast.successDisableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successDisableIdentifyLed', + ); } }) .catch((error) => { @@ -95,11 +99,11 @@ const ProcessorStore = { console.log('error', error); if (led.identifyLed) { throw new Error( - i18n.t('pageInventory.toast.errorEnableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorEnableIdentifyLed'), ); } else { throw new Error( - i18n.t('pageInventory.toast.errorDisableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorDisableIdentifyLed'), ); } }); diff --git a/src/store/modules/HardwareStatus/ServerLedStore.js b/src/store/modules/HardwareStatus/ServerLedStore.js index d4af0648..cb36e51b 100644 --- a/src/store/modules/HardwareStatus/ServerLedStore.js +++ b/src/store/modules/HardwareStatus/ServerLedStore.js @@ -37,11 +37,11 @@ const ServerLedStore = { commit('setIndicatorLedActiveState', !payload); if (payload) { throw new Error( - i18n.t('pageInventory.toast.errorEnableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorEnableIdentifyLed'), ); } else { throw new Error( - i18n.t('pageInventory.toast.errorDisableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorDisableIdentifyLed'), ); } }); diff --git a/src/store/modules/HardwareStatus/SystemStore.js b/src/store/modules/HardwareStatus/SystemStore.js index 87d2810b..50c8b6f7 100644 --- a/src/store/modules/HardwareStatus/SystemStore.js +++ b/src/store/modules/HardwareStatus/SystemStore.js @@ -48,9 +48,13 @@ const SystemStore = { }) .then(() => { if (ledState) { - return i18n.t('pageInventory.toast.successEnableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successEnableIdentifyLed', + ); } else { - return i18n.t('pageInventory.toast.successDisableIdentifyLed'); + return i18n.global.t( + 'pageInventory.toast.successDisableIdentifyLed', + ); } }) .catch((error) => { @@ -58,11 +62,11 @@ const SystemStore = { console.log('error', error); if (ledState) { throw new Error( - i18n.t('pageInventory.toast.errorEnableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorEnableIdentifyLed'), ); } else { throw new Error( - i18n.t('pageInventory.toast.errorDisableIdentifyLed'), + i18n.global.t('pageInventory.toast.errorDisableIdentifyLed'), ); } }); diff --git a/src/store/modules/Logs/DumpsStore.js b/src/store/modules/Logs/DumpsStore.js index 9391e571..100c4aa8 100644 --- a/src/store/modules/Logs/DumpsStore.js +++ b/src/store/modules/Logs/DumpsStore.js @@ -60,7 +60,7 @@ const DumpsStore = { ) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageDumps.toast.errorStartBmcDump')); + throw new Error(i18n.global.t('pageDumps.toast.errorStartBmcDump')); }); }, async createSystemDump() { @@ -74,7 +74,9 @@ const DumpsStore = { ) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageDumps.toast.errorStartSystemDump')); + throw new Error( + i18n.global.t('pageDumps.toast.errorStartSystemDump'), + ); }); }, async deleteDumps({ dispatch }, dumps) { @@ -96,7 +98,7 @@ const DumpsStore = { const toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageDumps.toast.successDeleteDump', successCount, ); @@ -104,7 +106,7 @@ const DumpsStore = { } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageDumps.toast.errorDeleteDump', errorCount, ); @@ -123,12 +125,15 @@ const DumpsStore = { ) .then(() => { commit('setAllDumps', []); - return i18n.tc('pageDumps.toast.successDeleteDump', totalDumpCount); + return i18n.global.t( + 'pageDumps.toast.successDeleteDump', + totalDumpCount, + ); }) .catch((error) => { console.log(error); throw new Error( - i18n.tc('pageDumps.toast.errorDeleteDump', totalDumpCount), + i18n.global.t('pageDumps.toast.errorDeleteDump', totalDumpCount), ); }); }, diff --git a/src/store/modules/Logs/EventLogStore.js b/src/store/modules/Logs/EventLogStore.js index 469aa26c..3de31aec 100644 --- a/src/store/modules/Logs/EventLogStore.js +++ b/src/store/modules/Logs/EventLogStore.js @@ -84,11 +84,13 @@ const EventLogStore = { `${await this.dispatch('global/getSystemPath')}/LogServices/EventLog/Actions/LogService.ClearLog`, ) .then(() => dispatch('getEventLogData')) - .then(() => i18n.tc('pageEventLogs.toast.successDelete', data.length)) + .then(() => + i18n.global.t('pageEventLogs.toast.successDelete', data.length), + ) .catch((error) => { console.log(error); throw new Error( - i18n.tc('pageEventLogs.toast.errorDelete', data.length), + i18n.global.t('pageEventLogs.toast.errorDelete', data.length), ); }); }, @@ -111,7 +113,7 @@ const EventLogStore = { const toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageEventLogs.toast.successDelete', successCount, ); @@ -119,7 +121,7 @@ const EventLogStore = { } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageEventLogs.toast.errorDelete', errorCount, ); @@ -148,14 +150,14 @@ const EventLogStore = { const { successCount, errorCount } = getResponseCount(responses); const toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageEventLogs.toast.successResolveLogs', successCount, ); toastMessages.push({ type: 'success', message }); } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageEventLogs.toast.errorResolveLogs', errorCount, ); @@ -183,14 +185,14 @@ const EventLogStore = { const { successCount, errorCount } = getResponseCount(responses); const toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageEventLogs.toast.successUnresolveLogs', successCount, ); toastMessages.push({ type: 'success', message }); } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageEventLogs.toast.errorUnresolveLogs', errorCount, ); @@ -210,14 +212,16 @@ const EventLogStore = { }) .then(() => { if (log.status) { - return i18n.tc('pageEventLogs.toast.successResolveLogs', 1); + return i18n.global.t('pageEventLogs.toast.successResolveLogs', 1); } else { - return i18n.tc('pageEventLogs.toast.successUnresolveLogs', 1); + return i18n.global.t('pageEventLogs.toast.successUnresolveLogs', 1); } }) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageEventLogs.toast.errorLogStatusUpdate')); + throw new Error( + i18n.global.t('pageEventLogs.toast.errorLogStatusUpdate'), + ); }); }, async downloadEntry(_, uri) { diff --git a/src/store/modules/Logs/PostCodeLogsStore.js b/src/store/modules/Logs/PostCodeLogsStore.js index 7bd1410f..9642ee42 100644 --- a/src/store/modules/Logs/PostCodeLogsStore.js +++ b/src/store/modules/Logs/PostCodeLogsStore.js @@ -43,12 +43,12 @@ const PostCodeLogsStore = { ) .then(() => dispatch('getPostCodesLogData')) .then(() => - i18n.tc('pagePostCodeLogs.toast.successDelete', data.length), + i18n.global.t('pagePostCodeLogs.toast.successDelete', data.length), ) .catch((error) => { console.log(error); throw new Error( - i18n.tc('pagePostCodeLogs.toast.errorDelete', data.length), + i18n.global.t('pagePostCodeLogs.toast.errorDelete', data.length), ); }); }, diff --git a/src/store/modules/Operations/BootSettingsStore.js b/src/store/modules/Operations/BootSettingsStore.js index 89598456..9740da7f 100644 --- a/src/store/modules/Operations/BootSettingsStore.js +++ b/src/store/modules/Operations/BootSettingsStore.js @@ -123,13 +123,15 @@ const BootSettingsStore = { return await api.all(promises).then( api.spread((...responses) => { - let message = i18n.t( + let message = i18n.global.t( 'pageServerPowerOperations.toast.successSaveSettings', ); responses.forEach((response) => { if (response instanceof Error) { throw new Error( - i18n.t('pageServerPowerOperations.toast.errorSaveSettings'), + i18n.global.t( + 'pageServerPowerOperations.toast.errorSaveSettings', + ), ); } }); diff --git a/src/store/modules/Operations/ControlStore.js b/src/store/modules/Operations/ControlStore.js index 320df6f9..82ab2499 100644 --- a/src/store/modules/Operations/ControlStore.js +++ b/src/store/modules/Operations/ControlStore.js @@ -78,10 +78,12 @@ const ControlStore = { `${await this.dispatch('global/getBmcPath')}/Actions/Manager.Reset`, data, ) - .then(() => i18n.t('pageRebootBmc.toast.successRebootStart')) + .then(() => i18n.global.t('pageRebootBmc.toast.successRebootStart')) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageRebootBmc.toast.errorRebootStart')); + throw new Error( + i18n.global.t('pageRebootBmc.toast.errorRebootStart'), + ); }); }, async serverPowerOn({ dispatch, commit }) { diff --git a/src/store/modules/Operations/FactoryResetStore.js b/src/store/modules/Operations/FactoryResetStore.js index 84a8f08a..ea8a8d08 100644 --- a/src/store/modules/Operations/FactoryResetStore.js +++ b/src/store/modules/Operations/FactoryResetStore.js @@ -12,11 +12,13 @@ const FactoryResetStore = { ResetType: 'ResetAll', }, ) - .then(() => i18n.t('pageFactoryReset.toast.resetToDefaultsSuccess')) + .then(() => + i18n.global.t('pageFactoryReset.toast.resetToDefaultsSuccess'), + ) .catch((error) => { console.log('Factory Reset: ', error); throw new Error( - i18n.t('pageFactoryReset.toast.resetToDefaultsError'), + i18n.global.t('pageFactoryReset.toast.resetToDefaultsError'), ); }); }, @@ -25,10 +27,12 @@ const FactoryResetStore = { .post( `${await this.dispatch('global/getSystemPath')}/Bios/Actions/Bios.ResetBios`, ) - .then(() => i18n.t('pageFactoryReset.toast.resetBiosSuccess')) + .then(() => i18n.global.t('pageFactoryReset.toast.resetBiosSuccess')) .catch((error) => { console.log('Factory Reset: ', error); - throw new Error(i18n.t('pageFactoryReset.toast.resetBiosError')); + throw new Error( + i18n.global.t('pageFactoryReset.toast.resetBiosError'), + ); }); }, }, diff --git a/src/store/modules/Operations/FirmwareStore.js b/src/store/modules/Operations/FirmwareStore.js index 64bd640f..78d3b912 100644 --- a/src/store/modules/Operations/FirmwareStore.js +++ b/src/store/modules/Operations/FirmwareStore.js @@ -134,7 +134,9 @@ const FirmwareStore = { }) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageFirmware.toast.errorUpdateFirmware')); + throw new Error( + i18n.global.t('pageFirmware.toast.errorUpdateFirmware'), + ); }); }, async uploadFirmwareMultipartHttpPush({ state }, { image, targets }) { @@ -155,7 +157,9 @@ const FirmwareStore = { }) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageFirmware.toast.errorUpdateFirmware')); + throw new Error( + i18n.global.t('pageFirmware.toast.errorUpdateFirmware'), + ); }); }, async switchBmcFirmwareAndReboot({ getters }) { @@ -171,7 +175,9 @@ const FirmwareStore = { .patch(`${await this.dispatch('global/getBmcPath')}`, data) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageFirmware.toast.errorSwitchImages')); + throw new Error( + i18n.global.t('pageFirmware.toast.errorSwitchImages'), + ); }); }, }, diff --git a/src/store/modules/Operations/KeyClearStore.js b/src/store/modules/Operations/KeyClearStore.js index 9e5e875e..e812ab23 100644 --- a/src/store/modules/Operations/KeyClearStore.js +++ b/src/store/modules/Operations/KeyClearStore.js @@ -13,10 +13,14 @@ const KeyClearStore = { `${await this.dispatch('global/getSystemPath')}/Bios/Settings`, selectedKeyForClearing, ) - .then(() => i18n.t('pageKeyClear.toast.selectedKeyClearedSuccess')) + .then(() => + i18n.global.t('pageKeyClear.toast.selectedKeyClearedSuccess'), + ) .catch((error) => { console.log('Key clear', error); - throw new Error(i18n.t('pageKeyClear.toast.selectedKeyClearedError')); + throw new Error( + i18n.global.t('pageKeyClear.toast.selectedKeyClearedError'), + ); }); }, }, diff --git a/src/store/modules/Operations/VirtualMediaStore.js b/src/store/modules/Operations/VirtualMediaStore.js index 9688d9c6..85612757 100644 --- a/src/store/modules/Operations/VirtualMediaStore.js +++ b/src/store/modules/Operations/VirtualMediaStore.js @@ -38,7 +38,7 @@ const VirtualMediaStore = { : false; if (!virtualMediaListEnabled) { const device = { - id: i18n.t('pageVirtualMedia.defaultDeviceName'), + id: i18n.global.t('pageVirtualMedia.defaultDeviceName'), websocket: '/vm/0/0', file: null, transferProtocolType: transferProtocolType.OEM, diff --git a/src/store/modules/ResourceManagement/PowerControlStore.js b/src/store/modules/ResourceManagement/PowerControlStore.js index f4629c96..7fd8a596 100644 --- a/src/store/modules/ResourceManagement/PowerControlStore.js +++ b/src/store/modules/ResourceManagement/PowerControlStore.js @@ -61,12 +61,12 @@ const PowerControlStore = { return await api .patch(state.powerCapUri, data) .then(() => - i18n.t('pageServerPowerOperations.toast.successSaveSettings'), + i18n.global.t('pageServerPowerOperations.toast.successSaveSettings'), ) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageServerPowerOperations.toast.errorSaveSettings'), + i18n.global.t('pageServerPowerOperations.toast.errorSaveSettings'), ); }); }, diff --git a/src/store/modules/SecurityAndAccess/CertificatesStore.js b/src/store/modules/SecurityAndAccess/CertificatesStore.js index 5c7c36d2..304c3706 100644 --- a/src/store/modules/SecurityAndAccess/CertificatesStore.js +++ b/src/store/modules/SecurityAndAccess/CertificatesStore.js @@ -39,12 +39,12 @@ const CertificatesStore = { location: `${await this.dispatch( 'global/getBmcPath', )}/NetworkProtocol/HTTPS/Certificates/`, - label: i18n.t('pageCertificates.httpsCertificate'), + label: i18n.global.t('pageCertificates.httpsCertificate'), }, { type: 'LDAP Certificate', location: '/redfish/v1/AccountService/LDAP/Certificates/', - label: i18n.t('pageCertificates.ldapCertificate'), + label: i18n.global.t('pageCertificates.ldapCertificate'), }, { type: 'TrustStore Certificate', @@ -54,7 +54,7 @@ const CertificatesStore = { // Web UI will show 'CA Certificate' instead of // 'TrustStore Certificate' after user testing revealed // the term 'TrustStore Certificate' wasn't recognized/was unfamilar - label: i18n.t('pageCertificates.caCertificate'), + label: i18n.global.t('pageCertificates.caCertificate'), }, ]; await commit('setCertificateTypes', certificateTypes); @@ -122,7 +122,7 @@ const CertificatesStore = { ) .then(() => dispatch('getCertificates')) .then(() => - i18n.t('pageCertificates.toast.successAddCertificate', { + i18n.global.t('pageCertificates.toast.successAddCertificate', { certificate: getCertificateProp( getters['certificateTypes'], type, @@ -132,7 +132,9 @@ const CertificatesStore = { ) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageCertificates.toast.errorAddCertificate')); + throw new Error( + i18n.global.t('pageCertificates.toast.errorAddCertificate'), + ); }); }, async replaceCertificate( @@ -151,7 +153,7 @@ const CertificatesStore = { ) .then(() => dispatch('getCertificates')) .then(() => - i18n.t('pageCertificates.toast.successReplaceCertificate', { + i18n.global.t('pageCertificates.toast.successReplaceCertificate', { certificate: getCertificateProp( getters['certificateTypes'], type, @@ -162,7 +164,7 @@ const CertificatesStore = { .catch((error) => { console.log(error); throw new Error( - i18n.t('pageCertificates.toast.errorReplaceCertificate'), + i18n.global.t('pageCertificates.toast.errorReplaceCertificate'), ); }); }, @@ -171,7 +173,7 @@ const CertificatesStore = { .delete(location) .then(() => dispatch('getCertificates')) .then(() => - i18n.t('pageCertificates.toast.successDeleteCertificate', { + i18n.global.t('pageCertificates.toast.successDeleteCertificate', { certificate: getCertificateProp( getters['certificateTypes'], type, @@ -182,7 +184,7 @@ const CertificatesStore = { .catch((error) => { console.log(error); throw new Error( - i18n.t('pageCertificates.toast.errorDeleteCertificate'), + i18n.global.t('pageCertificates.toast.errorDeleteCertificate'), ); }); }, diff --git a/src/store/modules/SecurityAndAccess/LdapStore.js b/src/store/modules/SecurityAndAccess/LdapStore.js index edb063c7..a8114f75 100644 --- a/src/store/modules/SecurityAndAccess/LdapStore.js +++ b/src/store/modules/SecurityAndAccess/LdapStore.js @@ -116,10 +116,12 @@ const LdapStore = { return await api .patch('/redfish/v1/AccountService', data) .then(() => dispatch('getAccountSettings')) - .then(() => i18n.t('pageLdap.toast.successSaveLdapSettings')) + .then(() => i18n.global.t('pageLdap.toast.successSaveLdapSettings')) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageLdap.toast.errorSaveLdapSettings')); + throw new Error( + i18n.global.t('pageLdap.toast.errorSaveLdapSettings'), + ); }); }, async saveActiveDirectorySettings({ state, dispatch }, properties) { @@ -133,11 +135,13 @@ const LdapStore = { return await api .patch('/redfish/v1/AccountService', data) .then(() => dispatch('getAccountSettings')) - .then(() => i18n.t('pageLdap.toast.successSaveActiveDirectorySettings')) + .then(() => + i18n.global.t('pageLdap.toast.successSaveActiveDirectorySettings'), + ) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageLdap.toast.errorSaveActiveDirectorySettings'), + i18n.global.t('pageLdap.toast.errorSaveActiveDirectorySettings'), ); }); }, @@ -201,13 +205,13 @@ const LdapStore = { .patch('/redfish/v1/AccountService', data) .then(() => dispatch('getAccountSettings')) .then(() => - i18n.t('pageLdap.toast.successAddRoleGroup', { + i18n.global.t('pageLdap.toast.successAddRoleGroup', { groupName, }), ) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageLdap.toast.errorAddRoleGroup')); + throw new Error(i18n.global.t('pageLdap.toast.errorAddRoleGroup')); }); }, async saveRoleGroup({ dispatch, getters }, { groupName, groupPrivilege }) { @@ -233,11 +237,11 @@ const LdapStore = { .patch('/redfish/v1/AccountService', data) .then(() => dispatch('getAccountSettings')) .then(() => - i18n.t('pageLdap.toast.successSaveRoleGroup', { groupName }), + i18n.global.t('pageLdap.toast.successSaveRoleGroup', { groupName }), ) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageLdap.toast.errorSaveRoleGroup')); + throw new Error(i18n.global.t('pageLdap.toast.errorSaveRoleGroup')); }); }, async deleteRoleGroup({ dispatch, getters }, { roleGroups = [] }) { @@ -260,12 +264,18 @@ const LdapStore = { .patch('/redfish/v1/AccountService', data) .then(() => dispatch('getAccountSettings')) .then(() => - i18n.tc('pageLdap.toast.successDeleteRoleGroup', roleGroups.length), + i18n.global.t( + 'pageLdap.toast.successDeleteRoleGroup', + roleGroups.length, + ), ) .catch((error) => { console.log(error); throw new Error( - i18n.tc('pageLdap.toast.errorDeleteRoleGroup', roleGroups.length), + i18n.global.t( + 'pageLdap.toast.errorDeleteRoleGroup', + roleGroups.length, + ), ); }); }, diff --git a/src/store/modules/SecurityAndAccess/PoliciesStore.js b/src/store/modules/SecurityAndAccess/PoliciesStore.js index f1e98b27..88ff151d 100644 --- a/src/store/modules/SecurityAndAccess/PoliciesStore.js +++ b/src/store/modules/SecurityAndAccess/PoliciesStore.js @@ -72,18 +72,22 @@ const PoliciesStore = { ) .then(() => { if (protocolEnabled) { - return i18n.t('pagePolicies.toast.successIpmiEnabled'); + return i18n.global.t('pagePolicies.toast.successIpmiEnabled'); } else { - return i18n.t('pagePolicies.toast.successIpmiDisabled'); + return i18n.global.t('pagePolicies.toast.successIpmiDisabled'); } }) .catch((error) => { console.log(error); commit('setIpmiProtocolEnabled', !protocolEnabled); if (protocolEnabled) { - throw new Error(i18n.t('pagePolicies.toast.errorIpmiEnabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorIpmiEnabled'), + ); } else { - throw new Error(i18n.t('pagePolicies.toast.errorIpmiDisabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorIpmiDisabled'), + ); } }); }, @@ -101,18 +105,22 @@ const PoliciesStore = { ) .then(() => { if (protocolEnabled) { - return i18n.t('pagePolicies.toast.successSshEnabled'); + return i18n.global.t('pagePolicies.toast.successSshEnabled'); } else { - return i18n.t('pagePolicies.toast.successSshDisabled'); + return i18n.global.t('pagePolicies.toast.successSshDisabled'); } }) .catch((error) => { console.log(error); commit('setSshProtocolEnabled', !protocolEnabled); if (protocolEnabled) { - throw new Error(i18n.t('pagePolicies.toast.errorSshEnabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorSshEnabled'), + ); } else { - throw new Error(i18n.t('pagePolicies.toast.errorSshDisabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorSshDisabled'), + ); } }); }, @@ -126,17 +134,21 @@ const PoliciesStore = { }) .then(() => { if (updatedRtad === 'Enabled') { - return i18n.t('pagePolicies.toast.successRtadEnabled'); + return i18n.global.t('pagePolicies.toast.successRtadEnabled'); } else { - return i18n.t('pagePolicies.toast.successRtadDisabled'); + return i18n.global.t('pagePolicies.toast.successRtadDisabled'); } }) .catch((error) => { console.log(error); if (updatedRtad === 'Enabled') { - throw new Error(i18n.t('pagePolicies.toast.errorRtadEnabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorRtadEnabled'), + ); } else { - throw new Error(i18n.t('pagePolicies.toast.errorRtadDisabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorRtadDisabled'), + ); } }); }, @@ -150,17 +162,21 @@ const PoliciesStore = { }) .then(() => { if (updatedVtpm === 'Enabled') { - return i18n.t('pagePolicies.toast.successVtpmEnabled'); + return i18n.global.t('pagePolicies.toast.successVtpmEnabled'); } else { - return i18n.t('pagePolicies.toast.successVtpmDisabled'); + return i18n.global.t('pagePolicies.toast.successVtpmDisabled'); } }) .catch((error) => { console.log(error); if (updatedVtpm === 'Enabled') { - throw new Error(i18n.t('pagePolicies.toast.errorVtpmEnabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorVtpmEnabled'), + ); } else { - throw new Error(i18n.t('pagePolicies.toast.errorVtpmDisabled')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorVtpmDisabled'), + ); } }); }, @@ -172,11 +188,13 @@ const PoliciesStore = { .patch('/redfish/v1/SessionService', sessionValue) .then(() => dispatch('getSessionTimeout')) .then(() => { - return i18n.t('pagePolicies.toast.successSessionTimeout'); + return i18n.global.t('pagePolicies.toast.successSessionTimeout'); }) .catch((error) => { console.log(error); - throw new Error(i18n.t('pagePolicies.toast.errorSessionTimeout')); + throw new Error( + i18n.global.t('pagePolicies.toast.errorSessionTimeout'), + ); }); }, }, diff --git a/src/store/modules/SecurityAndAccess/SessionsStore.js b/src/store/modules/SecurityAndAccess/SessionsStore.js index e567c524..98e876cc 100644 --- a/src/store/modules/SecurityAndAccess/SessionsStore.js +++ b/src/store/modules/SecurityAndAccess/SessionsStore.js @@ -60,7 +60,7 @@ const SessionsStore = { const toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageSessions.toast.successDelete', successCount, ); @@ -68,7 +68,7 @@ const SessionsStore = { } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageSessions.toast.errorDelete', errorCount, ); diff --git a/src/store/modules/SecurityAndAccess/UserManagementStore.js b/src/store/modules/SecurityAndAccess/UserManagementStore.js index 50361580..b1860d10 100644 --- a/src/store/modules/SecurityAndAccess/UserManagementStore.js +++ b/src/store/modules/SecurityAndAccess/UserManagementStore.js @@ -78,7 +78,9 @@ const UserManagementStore = { }) .catch((error) => { console.log(error); - const message = i18n.t('pageUserManagement.toast.errorLoadUsers'); + const message = i18n.global.t( + 'pageUserManagement.toast.errorLoadUsers', + ); throw new Error(message); }); }, @@ -93,7 +95,7 @@ const UserManagementStore = { }) .catch((error) => { console.log(error); - const message = i18n.t( + const message = i18n.global.t( 'pageUserManagement.toast.errorLoadAccountSettings', ); throw new Error(message); @@ -121,7 +123,7 @@ const UserManagementStore = { .post('/redfish/v1/AccountService/Accounts', data) .then(() => dispatch('getUsers')) .then(() => - i18n.t('pageUserManagement.toast.successCreateUser', { + i18n.global.t('pageUserManagement.toast.successCreateUser', { username, }), ) @@ -130,7 +132,7 @@ const UserManagementStore = { let message = serverMessages.length > 0 ? serverMessages.join(' ') - : i18n.t('pageUserManagement.toast.errorCreateUser', { + : i18n.global.t('pageUserManagement.toast.errorCreateUser', { username: username, }); throw new Error(message); @@ -150,7 +152,7 @@ const UserManagementStore = { .patch(`/redfish/v1/AccountService/Accounts/${originalUsername}`, data) .then(() => dispatch('getUsers')) .then(() => - i18n.t('pageUserManagement.toast.successUpdateUser', { + i18n.global.t('pageUserManagement.toast.successUpdateUser', { username: originalUsername, }), ) @@ -160,7 +162,7 @@ const UserManagementStore = { const message = serverMessages.length > 0 ? serverMessages.join(' ') - : i18n.t('pageUserManagement.toast.errorUpdateUser', { + : i18n.global.t('pageUserManagement.toast.errorUpdateUser', { username: originalUsername, }); throw new Error(message); @@ -171,15 +173,18 @@ const UserManagementStore = { .delete(`/redfish/v1/AccountService/Accounts/${username}`) .then(() => dispatch('getUsers')) .then(() => - i18n.t('pageUserManagement.toast.successDeleteUser', { + i18n.global.t('pageUserManagement.toast.successDeleteUser', { username, }), ) .catch((error) => { console.log(error); - const message = i18n.t('pageUserManagement.toast.errorDeleteUser', { - username, - }); + const message = i18n.global.t( + 'pageUserManagement.toast.errorDeleteUser', + { + username, + }, + ); throw new Error(message); }); }, @@ -204,7 +209,7 @@ const UserManagementStore = { let toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageUserManagement.toast.successBatchDelete', successCount, ); @@ -212,7 +217,7 @@ const UserManagementStore = { } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageUserManagement.toast.errorBatchDelete', errorCount, ); @@ -247,7 +252,7 @@ const UserManagementStore = { let toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageUserManagement.toast.successBatchEnable', successCount, ); @@ -255,7 +260,7 @@ const UserManagementStore = { } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageUserManagement.toast.errorBatchEnable', errorCount, ); @@ -290,7 +295,7 @@ const UserManagementStore = { let toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageUserManagement.toast.successBatchDisable', successCount, ); @@ -298,7 +303,7 @@ const UserManagementStore = { } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageUserManagement.toast.errorBatchDisable', errorCount, ); @@ -325,10 +330,14 @@ const UserManagementStore = { .patch('/redfish/v1/AccountService', data) //GET new settings to update view .then(() => dispatch('getAccountSettings')) - .then(() => i18n.t('pageUserManagement.toast.successSaveSettings')) + .then(() => + i18n.global.t('pageUserManagement.toast.successSaveSettings'), + ) .catch((error) => { console.log(error); - const message = i18n.t('pageUserManagement.toast.errorSaveSettings'); + const message = i18n.global.t( + 'pageUserManagement.toast.errorSaveSettings', + ); throw new Error(message); }); }, diff --git a/src/store/modules/Settings/DateTimeStore.js b/src/store/modules/Settings/DateTimeStore.js index 9d804a7e..94a1dfc0 100644 --- a/src/store/modules/Settings/DateTimeStore.js +++ b/src/store/modules/Settings/DateTimeStore.js @@ -74,11 +74,13 @@ const DateTimeStore = { } }) .then(() => { - return i18n.t('pageDateTime.toast.successSaveDateTime'); + return i18n.global.t('pageDateTime.toast.successSaveDateTime'); }) .catch((error) => { console.log(error); - throw new Error(i18n.t('pageDateTime.toast.errorSaveDateTime')); + throw new Error( + i18n.global.t('pageDateTime.toast.errorSaveDateTime'), + ); }); }, }, diff --git a/src/store/modules/Settings/NetworkStore.js b/src/store/modules/Settings/NetworkStore.js index a249d22b..9dc006e5 100644 --- a/src/store/modules/Settings/NetworkStore.js +++ b/src/store/modules/Settings/NetworkStore.js @@ -119,15 +119,15 @@ const NetworkStore = { ) .then(dispatch('getEthernetData')) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dhcp'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dhcp'), }); }) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dhcp'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dhcp'), }), ); }); @@ -183,8 +183,8 @@ const NetworkStore = { data, ) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.domainName'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.domainName'), }); }) .catch((error) => { @@ -193,8 +193,8 @@ const NetworkStore = { else if (ipVersion === 'IPv6') commit('setDomainNameStateIpv6', !domainState); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.domainName'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.domainName'), }), ); }); @@ -224,8 +224,8 @@ const NetworkStore = { data, ) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dns'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dns'), }); }) .catch((error) => { @@ -233,8 +233,8 @@ const NetworkStore = { if (ipVersion === 'IPv4') commit('setDnsState', !dnsState); else if (ipVersion === 'IPv6') commit('setDnsStateIpv6', !dnsState); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dns'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dns'), }), ); }); @@ -264,8 +264,8 @@ const NetworkStore = { data, ) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.ntp'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.ntp'), }); }) .catch((error) => { @@ -273,8 +273,8 @@ const NetworkStore = { if (ipVersion === 'IPv4') commit('setNtpState', !ntpState); else if (ipVersion === 'IPv6') commit('setNtpStateIpv6', !ntpState); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.ntp'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.ntp'), }), ); }); @@ -304,15 +304,15 @@ const NetworkStore = { ) .then(dispatch('getEthernetData')) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.ipv4'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.ipv4'), }); }) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.ipv4'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.ipv4'), }), ); }); @@ -356,15 +356,15 @@ const NetworkStore = { ) .then(dispatch('getEthernetData')) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.ipv4'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.ipv4'), }); }) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.ipv4'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.ipv4'), }), ); }); @@ -398,15 +398,15 @@ const NetworkStore = { ) .then(dispatch('getEthernetData')) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.network'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.network'), }); }) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.network'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.network'), }), ); }); @@ -423,15 +423,15 @@ const NetworkStore = { ) .then(dispatch('getEthernetData')) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dns'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dns'), }); }) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dns'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dns'), }), ); }); @@ -444,15 +444,15 @@ const NetworkStore = { ) .then(dispatch('getEthernetData')) .then(() => { - return i18n.t('pageNetwork.toast.successSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dns'), + return i18n.global.t('pageNetwork.toast.successSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dns'), }); }) .catch((error) => { console.log(error); throw new Error( - i18n.t('pageNetwork.toast.errorSaveNetworkSettings', { - setting: i18n.t('pageNetwork.dns'), + i18n.global.t('pageNetwork.toast.errorSaveNetworkSettings', { + setting: i18n.global.t('pageNetwork.dns'), }), ); }); diff --git a/src/store/modules/Settings/PowerPolicyStore.js b/src/store/modules/Settings/PowerPolicyStore.js index 0bdc0b5d..5ee36196 100644 --- a/src/store/modules/Settings/PowerPolicyStore.js +++ b/src/store/modules/Settings/PowerPolicyStore.js @@ -66,12 +66,14 @@ const PowerPolicyStore = { .patch(`${await this.dispatch('global/getSystemPath')}`, data) .then(() => { dispatch('getPowerRestoreCurrentPolicy'); - return i18n.t('pagePowerRestorePolicy.toast.successSaveSettings'); + return i18n.global.t( + 'pagePowerRestorePolicy.toast.successSaveSettings', + ); }) .catch((error) => { console.log(error); throw new Error( - i18n.t('pagePowerRestorePolicy.toast.errorSaveSettings'), + i18n.global.t('pagePowerRestorePolicy.toast.errorSaveSettings'), ); }); }, diff --git a/src/store/modules/Settings/SnmpAlertsStore.js b/src/store/modules/Settings/SnmpAlertsStore.js index 0871c8d8..0aabf4ee 100644 --- a/src/store/modules/Settings/SnmpAlertsStore.js +++ b/src/store/modules/Settings/SnmpAlertsStore.js @@ -39,7 +39,9 @@ const SnmpAlertsStore = { }) .catch((error) => { console.log(error); - const message = i18n.t('pageSnmpAlerts.toast.errorLoadSnmpDetails'); + const message = i18n.global.t( + 'pageSnmpAlerts.toast.errorLoadSnmpDetails', + ); throw new Error(message); }); }, @@ -49,13 +51,13 @@ const SnmpAlertsStore = { .delete(`${snmpAlertUrl}/${id}`) .then(() => dispatch('getSnmpDetails')) .then(() => - i18n.t('pageSnmpAlerts.toast.successDeleteDestination', { + i18n.global.t('pageSnmpAlerts.toast.successDeleteDestination', { id, }), ) .catch((error) => { console.log(error); - const message = i18n.t( + const message = i18n.global.t( 'pageSnmpAlerts.toast.errorDeleteDestination', { id, @@ -84,7 +86,7 @@ const SnmpAlertsStore = { let toastMessages = []; if (successCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageSnmpAlerts.toast.successBatchDelete', successCount, ); @@ -92,7 +94,7 @@ const SnmpAlertsStore = { } if (errorCount) { - const message = i18n.tc( + const message = i18n.global.t( 'pageSnmpAlerts.toast.errorBatchDelete', errorCount, ); @@ -108,10 +110,12 @@ const SnmpAlertsStore = { return await api .post(snmpAlertUrl, data) .then(() => dispatch('getSnmpDetails')) - .then(() => i18n.t('pageSnmpAlerts.toast.successAddDestination')) + .then(() => i18n.global.t('pageSnmpAlerts.toast.successAddDestination')) .catch((error) => { console.log(error); - const message = i18n.t('pageSnmpAlerts.toast.errorAddDestination'); + const message = i18n.global.t( + 'pageSnmpAlerts.toast.errorAddDestination', + ); throw new Error(message); }); }, diff --git a/src/views/ChangePassword/ChangePassword.vue b/src/views/ChangePassword/ChangePassword.vue index 002362a9..2680cc35 100644 --- a/src/views/ChangePassword/ChangePassword.vue +++ b/src/views/ChangePassword/ChangePassword.vue @@ -22,13 +22,13 @@ v-model="form.password" autofocus="autofocus" type="password" - :state="getValidationState($v.form.password)" + :state="getValidationState(v$.form.password)" class="form-control-with-button" - @change="$v.form.password.$touch()" + @change="v$.form.password.$touch()" > </b-form-input> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.password.required"> + <template v-if="!v$.form.password.required"> {{ $t('global.form.fieldRequired') }} </template> </b-form-invalid-feedback> @@ -43,16 +43,16 @@ id="password-confirm" v-model="form.passwordConfirm" type="password" - :state="getValidationState($v.form.passwordConfirm)" + :state="getValidationState(v$.form.passwordConfirm)" class="form-control-with-button" - @change="$v.form.passwordConfirm.$touch()" + @change="v$.form.passwordConfirm.$touch()" > </b-form-input> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.passwordConfirm.required"> + <template v-if="!v$.form.passwordConfirm.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-else-if="!$v.form.passwordConfirm.sameAsPassword"> + <template v-else-if="!v$.form.passwordConfirm.sameAsPassword"> {{ $t('global.form.passwordsDoNotMatch') }} </template> </b-form-invalid-feedback> @@ -78,6 +78,7 @@ import VuelidateMixin from '@/components/Mixins/VuelidateMixin'; import InputPasswordToggle from '@/components/Global/InputPasswordToggle'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import { useVuelidate } from '@vuelidate/core'; +import { useI18n } from 'vue-i18n'; export default { name: 'ChangePassword', @@ -90,6 +91,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { password: null, passwordConfirm: null, @@ -115,8 +117,8 @@ export default { this.$store.dispatch('authentication/logout'); }, changePassword() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; let data = { originalUsername: this.username, password: this.form.password, diff --git a/src/views/HardwareStatus/Inventory/Inventory.vue b/src/views/HardwareStatus/Inventory/Inventory.vue index d05e32e1..a3f4d23e 100644 --- a/src/views/HardwareStatus/Inventory/Inventory.vue +++ b/src/views/HardwareStatus/Inventory/Inventory.vue @@ -64,6 +64,8 @@ import PageSection from '@/components/Global/PageSection'; import JumpLink16 from '@carbon/icons-vue/es/jump-link/16'; import JumpLinkMixin from '@/components/Mixins/JumpLinkMixin'; import { chunk } from 'lodash'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { @@ -89,54 +91,55 @@ export default { }, data() { return { + $t: useI18n().t, links: [ { id: 'system', dataRef: 'system', href: '#system', - linkText: this.$t('pageInventory.system'), + linkText: i18n.global.t('pageInventory.system'), }, { id: 'bmc', dataRef: 'bmc', href: '#bmc', - linkText: this.$t('pageInventory.bmcManager'), + linkText: i18n.global.t('pageInventory.bmcManager'), }, { id: 'chassis', dataRef: 'chassis', href: '#chassis', - linkText: this.$t('pageInventory.chassis'), + linkText: i18n.global.t('pageInventory.chassis'), }, { id: 'dimms', dataRef: 'dimms', href: '#dimms', - linkText: this.$t('pageInventory.dimmSlot'), + linkText: i18n.global.t('pageInventory.dimmSlot'), }, { id: 'fans', dataRef: 'fans', href: '#fans', - linkText: this.$t('pageInventory.fans'), + linkText: i18n.global.t('pageInventory.fans'), }, { id: 'powerSupply', dataRef: 'powerSupply', href: '#powerSupply', - linkText: this.$t('pageInventory.powerSupplies'), + linkText: i18n.global.t('pageInventory.powerSupplies'), }, { id: 'processors', dataRef: 'processors', href: '#processors', - linkText: this.$t('pageInventory.processors'), + linkText: i18n.global.t('pageInventory.processors'), }, { id: 'assembly', dataRef: 'assembly', href: '#assembly', - linkText: this.$t('pageInventory.assemblies'), + linkText: i18n.global.t('pageInventory.assemblies'), }, ], }; diff --git a/src/views/HardwareStatus/Inventory/InventoryServiceIndicator.vue b/src/views/HardwareStatus/Inventory/InventoryServiceIndicator.vue index 0825ad7b..5b19b42a 100644 --- a/src/views/HardwareStatus/Inventory/InventoryServiceIndicator.vue +++ b/src/views/HardwareStatus/Inventory/InventoryServiceIndicator.vue @@ -40,10 +40,16 @@ <script> import PageSection from '@/components/Global/PageSection'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; +import { useI18n } from 'vue-i18n'; export default { components: { PageSection }, mixins: [BVToastMixin], + data() { + return { + $t: useI18n().t, + }; + }, computed: { systems() { let systemData = this.$store.getters['system/systems'][0]; diff --git a/src/views/HardwareStatus/Inventory/InventoryTableAssembly.vue b/src/views/HardwareStatus/Inventory/InventoryTableAssembly.vue index b9f59cc6..68bee056 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTableAssembly.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTableAssembly.vue @@ -76,12 +76,15 @@ import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; import DataFormatterMixin from '@/components/Mixins/DataFormatterMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection }, mixins: [BVToastMixin, TableRowExpandMixin, DataFormatterMixin], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -91,25 +94,25 @@ export default { }, { key: 'name', - label: this.$t('pageInventory.table.id'), + label: i18n.global.t('pageInventory.table.id'), formatter: this.dataFormatter, sortable: true, }, { key: 'partNumber', - label: this.$t('pageInventory.table.partNumber'), + label: i18n.global.t('pageInventory.table.partNumber'), formatter: this.dataFormatter, sortable: true, }, { key: 'locationNumber', - label: this.$t('pageInventory.table.locationNumber'), + label: i18n.global.t('pageInventory.table.locationNumber'), formatter: this.dataFormatter, sortable: true, }, { key: 'identifyLed', - label: this.$t('pageInventory.table.identifyLed'), + label: i18n.global.t('pageInventory.table.identifyLed'), formatter: this.dataFormatter, }, ], diff --git a/src/views/HardwareStatus/Inventory/InventoryTableBmcManager.vue b/src/views/HardwareStatus/Inventory/InventoryTableBmcManager.vue index 8c1e50d4..848322c0 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTableBmcManager.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTableBmcManager.vue @@ -88,14 +88,14 @@ <!-- BMC date and time --> <dt>{{ $t('pageInventory.table.bmcDateTime') }}:</dt> <dd> - {{ item.dateTime }} - {{ item.dateTime }} + {{ $filters.formatDate(item.dateTime) }} + {{ $filters.formatTime(item.dateTime) }} </dd> <!-- Reset date and time --> <dt>{{ $t('pageInventory.table.lastResetTime') }}:</dt> <dd> - {{ item.lastResetTime }} - {{ item.lastResetTime }} + {{ $filters.formatDate(item.lastResetTime) }} + {{ $filters.formatTime(item.lastResetTime) }} </dd> </dl> </b-col> @@ -170,12 +170,15 @@ import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; import DataFormatterMixin from '@/components/Mixins/DataFormatterMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection, StatusIcon }, mixins: [BVToastMixin, TableRowExpandMixin, DataFormatterMixin], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -185,22 +188,22 @@ export default { }, { key: 'id', - label: this.$t('pageInventory.table.id'), + label: i18n.global.t('pageInventory.table.id'), formatter: this.dataFormatter, }, { key: 'health', - label: this.$t('pageInventory.table.health'), + label: i18n.global.t('pageInventory.table.health'), formatter: this.dataFormatter, }, { key: 'locationNumber', - label: this.$t('pageInventory.table.locationNumber'), + label: i18n.global.t('pageInventory.table.locationNumber'), formatter: this.dataFormatter, }, { key: 'identifyLed', - label: this.$t('pageInventory.table.identifyLed'), + label: i18n.global.t('pageInventory.table.identifyLed'), formatter: this.dataFormatter, }, ], diff --git a/src/views/HardwareStatus/Inventory/InventoryTableChassis.vue b/src/views/HardwareStatus/Inventory/InventoryTableChassis.vue index 18ddfbaf..4458e33b 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTableChassis.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTableChassis.vue @@ -129,12 +129,15 @@ import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; import DataFormatterMixin from '@/components/Mixins/DataFormatterMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection, StatusIcon }, mixins: [BVToastMixin, TableRowExpandMixin, DataFormatterMixin], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -144,23 +147,23 @@ export default { }, { key: 'id', - label: this.$t('pageInventory.table.id'), + label: i18n.global.t('pageInventory.table.id'), formatter: this.dataFormatter, }, { key: 'health', - label: this.$t('pageInventory.table.health'), + label: i18n.global.t('pageInventory.table.health'), formatter: this.dataFormatter, tdClass: 'text-nowrap', }, { key: 'locationNumber', - label: this.$t('pageInventory.table.locationNumber'), + label: i18n.global.t('pageInventory.table.locationNumber'), formatter: this.dataFormatter, }, { key: 'identifyLed', - label: this.$t('pageInventory.table.identifyLed'), + label: i18n.global.t('pageInventory.table.identifyLed'), formatter: this.dataFormatter, }, ], diff --git a/src/views/HardwareStatus/Inventory/InventoryTableDimmSlot.vue b/src/views/HardwareStatus/Inventory/InventoryTableDimmSlot.vue index f3db133e..f4a850b0 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTableDimmSlot.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTableDimmSlot.vue @@ -203,6 +203,8 @@ import SearchFilterMixin, { import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection, StatusIcon, Search, TableCellCount }, @@ -215,6 +217,7 @@ export default { ], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -224,29 +227,29 @@ export default { }, { key: 'id', - label: this.$t('pageInventory.table.id'), + label: i18n.global.t('pageInventory.table.id'), formatter: this.dataFormatter, }, { key: 'health', - label: this.$t('pageInventory.table.health'), + label: i18n.global.t('pageInventory.table.health'), formatter: this.dataFormatter, tdClass: 'text-nowrap', }, { key: 'statusState', - label: this.$t('pageInventory.table.state'), + label: i18n.global.t('pageInventory.table.state'), formatter: this.dataFormatter, tdClass: 'text-nowrap', }, { key: 'locationNumber', - label: this.$t('pageInventory.table.locationNumber'), + label: i18n.global.t('pageInventory.table.locationNumber'), formatter: this.dataFormatter, }, { key: 'identifyLed', - label: this.$t('pageInventory.table.identifyLed'), + label: i18n.global.t('pageInventory.table.identifyLed'), formatter: this.dataFormatter, }, ], diff --git a/src/views/HardwareStatus/Inventory/InventoryTableFans.vue b/src/views/HardwareStatus/Inventory/InventoryTableFans.vue index af4b461e..373ecc8d 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTableFans.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTableFans.vue @@ -119,6 +119,8 @@ import SearchFilterMixin, { import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection, StatusIcon, Search, TableCellCount }, @@ -130,6 +132,7 @@ export default { ], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -140,13 +143,13 @@ export default { }, { key: 'name', - label: this.$t('pageInventory.table.name'), + label: i18n.global.t('pageInventory.table.name'), formatter: this.dataFormatter, sortable: true, }, { key: 'health', - label: this.$t('pageInventory.table.health'), + label: i18n.global.t('pageInventory.table.health'), formatter: this.dataFormatter, sortable: true, tdClass: 'text-nowrap', @@ -159,13 +162,13 @@ export default { }, { key: 'partNumber', - label: this.$t('pageInventory.table.partNumber'), + label: i18n.global.t('pageInventory.table.partNumber'), formatter: this.dataFormatter, sortable: true, }, { key: 'serialNumber', - label: this.$t('pageInventory.table.serialNumber'), + label: i18n.global.t('pageInventory.table.serialNumber'), formatter: this.dataFormatter, }, ], diff --git a/src/views/HardwareStatus/Inventory/InventoryTablePowerSupplies.vue b/src/views/HardwareStatus/Inventory/InventoryTablePowerSupplies.vue index 0ce8c823..78b2a960 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTablePowerSupplies.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTablePowerSupplies.vue @@ -140,6 +140,8 @@ import SearchFilterMixin, { import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection, StatusIcon, Search, TableCellCount }, @@ -151,6 +153,7 @@ export default { ], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -161,13 +164,13 @@ export default { }, { key: 'id', - label: this.$t('pageInventory.table.id'), + label: i18n.global.t('pageInventory.table.id'), formatter: this.dataFormatter, sortable: true, }, { key: 'health', - label: this.$t('pageInventory.table.health'), + label: i18n.global.t('pageInventory.table.health'), formatter: this.dataFormatter, sortable: true, tdClass: 'text-nowrap', @@ -180,13 +183,13 @@ export default { }, { key: 'locationNumber', - label: this.$t('pageInventory.table.locationNumber'), + label: i18n.global.t('pageInventory.table.locationNumber'), formatter: this.dataFormatter, sortable: true, }, { key: 'identifyLed', - label: this.$t('pageInventory.table.identifyLed'), + label: i18n.global.t('pageInventory.table.identifyLed'), formatter: this.dataFormatter, }, ], diff --git a/src/views/HardwareStatus/Inventory/InventoryTableProcessors.vue b/src/views/HardwareStatus/Inventory/InventoryTableProcessors.vue index 2887fc49..4bdff54b 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTableProcessors.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTableProcessors.vue @@ -172,6 +172,8 @@ import SearchFilterMixin, { import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection, StatusIcon, Search, TableCellCount }, @@ -184,6 +186,7 @@ export default { ], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -194,33 +197,33 @@ export default { }, { key: 'id', - label: this.$t('pageInventory.table.id'), + label: i18n.global.t('pageInventory.table.id'), formatter: this.dataFormatter, sortable: true, }, { key: 'health', - label: this.$t('pageInventory.table.health'), + label: i18n.global.t('pageInventory.table.health'), formatter: this.dataFormatter, sortable: true, tdClass: 'text-nowrap', }, { key: 'statusState', - label: this.$t('pageInventory.table.state'), + label: i18n.global.t('pageInventory.table.state'), formatter: this.dataFormatter, sortable: true, tdClass: 'text-nowrap', }, { key: 'locationNumber', - label: this.$t('pageInventory.table.locationNumber'), + label: i18n.global.t('pageInventory.table.locationNumber'), formatter: this.dataFormatter, sortable: true, }, { key: 'identifyLed', - label: this.$t('pageInventory.table.identifyLed'), + label: i18n.global.t('pageInventory.table.identifyLed'), formatter: this.dataFormatter, sortable: false, }, diff --git a/src/views/HardwareStatus/Inventory/InventoryTableSystem.vue b/src/views/HardwareStatus/Inventory/InventoryTableSystem.vue index 8ac1a259..2839c788 100644 --- a/src/views/HardwareStatus/Inventory/InventoryTableSystem.vue +++ b/src/views/HardwareStatus/Inventory/InventoryTableSystem.vue @@ -142,12 +142,15 @@ import TableRowExpandMixin, { expandRowLabel, } from '@/components/Mixins/TableRowExpandMixin'; import DataFormatterMixin from '@/components/Mixins/DataFormatterMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconChevron, PageSection, StatusIcon }, mixins: [BVToastMixin, TableRowExpandMixin, DataFormatterMixin], data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -157,29 +160,29 @@ export default { }, { key: 'id', - label: this.$t('pageInventory.table.id'), + label: i18n.global.t('pageInventory.table.id'), formatter: this.dataFormatter, }, { key: 'hardwareType', - label: this.$t('pageInventory.table.hardwareType'), + label: i18n.global.t('pageInventory.table.hardwareType'), formatter: this.dataFormatter, tdClass: 'text-nowrap', }, { key: 'health', - label: this.$t('pageInventory.table.health'), + label: i18n.global.t('pageInventory.table.health'), formatter: this.dataFormatter, tdClass: 'text-nowrap', }, { key: 'locationNumber', - label: this.$t('pageInventory.table.locationNumber'), + label: i18n.global.t('pageInventory.table.locationNumber'), formatter: this.dataFormatter, }, { key: 'locationIndicatorActive', - label: this.$t('pageInventory.table.identifyLed'), + label: i18n.global.t('pageInventory.table.identifyLed'), formatter: this.dataFormatter, }, ], diff --git a/src/views/HardwareStatus/Sensors/Sensors.vue b/src/views/HardwareStatus/Sensors/Sensors.vue index c4663a94..ac70e403 100644 --- a/src/views/HardwareStatus/Sensors/Sensors.vue +++ b/src/views/HardwareStatus/Sensors/Sensors.vue @@ -121,6 +121,8 @@ import TableSortMixin from '@/components/Mixins/TableSortMixin'; import SearchFilterMixin, { searchFilter, } from '@/components/Mixins/SearchFilterMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'Sensors', @@ -147,6 +149,7 @@ export default { }, data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -157,49 +160,49 @@ export default { { key: 'name', sortable: true, - label: this.$t('pageSensors.table.name'), + label: i18n.global.t('pageSensors.table.name'), }, { key: 'status', sortable: true, - label: this.$t('pageSensors.table.status'), + label: i18n.global.t('pageSensors.table.status'), tdClass: 'text-nowrap', }, { key: 'lowerCritical', formatter: this.dataFormatter, - label: this.$t('pageSensors.table.lowerCritical'), + label: i18n.global.t('pageSensors.table.lowerCritical'), }, { key: 'lowerCaution', formatter: this.dataFormatter, - label: this.$t('pageSensors.table.lowerWarning'), + label: i18n.global.t('pageSensors.table.lowerWarning'), }, { key: 'currentValue', formatter: this.dataFormatter, - label: this.$t('pageSensors.table.currentValue'), + label: i18n.global.t('pageSensors.table.currentValue'), }, { key: 'upperCaution', formatter: this.dataFormatter, - label: this.$t('pageSensors.table.upperWarning'), + label: i18n.global.t('pageSensors.table.upperWarning'), }, { key: 'upperCritical', formatter: this.dataFormatter, - label: this.$t('pageSensors.table.upperCritical'), + label: i18n.global.t('pageSensors.table.upperCritical'), }, ], tableFilters: [ { key: 'status', - label: this.$t('pageSensors.table.status'), + label: i18n.global.t('pageSensors.table.status'), values: [ - this.$t('global.action.ok'), - this.$t('global.action.warning'), - this.$t('global.action.critical'), + i18n.global.t('global.action.ok'), + i18n.global.t('global.action.warning'), + i18n.global.t('global.action.critical'), ], }, ], @@ -253,7 +256,7 @@ export default { date.toISOString().slice(0, 10) + '_' + date.toString().split(':').join('-').split(' ')[4]; - return this.$t('pageSensors.exportFilePrefix') + date; + return i18n.global.t('pageSensors.exportFilePrefix') + date; }, }, }; diff --git a/src/views/Logs/Dumps/Dumps.vue b/src/views/Logs/Dumps/Dumps.vue index 5a9869a4..04469118 100644 --- a/src/views/Logs/Dumps/Dumps.vue +++ b/src/views/Logs/Dumps/Dumps.vue @@ -84,8 +84,8 @@ <!-- Date and Time column --> <template #cell(dateTime)="{ value }"> - <p class="mb-0">{{ value }}</p> - <p class="mb-0">{{ value }}</p> + <p class="mb-0">{{ $filters.formatDate(value) }}</p> + <p class="mb-0">{{ $filters.formatTime(value) }}</p> </template> <!-- Size column --> @@ -171,6 +171,7 @@ import SearchFilterMixin, { } from '@/components/Mixins/SearchFilterMixin'; import TableFilter from '@/components/Global/TableFilter'; import TableFilterMixin from '@/components/Mixins/TableFilterMixin'; +import i18n from '@/i18n'; export default { components: { @@ -210,22 +211,22 @@ export default { }, { key: 'dateTime', - label: this.$t('pageDumps.table.dateAndTime'), + label: i18n.global.t('pageDumps.table.dateAndTime'), sortable: true, }, { key: 'dumpType', - label: this.$t('pageDumps.table.dumpType'), + label: i18n.global.t('pageDumps.table.dumpType'), sortable: true, }, { key: 'id', - label: this.$t('pageDumps.table.id'), + label: i18n.global.t('pageDumps.table.id'), sortable: true, }, { key: 'size', - label: this.$t('pageDumps.table.size'), + label: i18n.global.t('pageDumps.table.size'), sortable: true, }, { @@ -238,13 +239,13 @@ export default { batchActions: [ { value: 'delete', - label: this.$t('global.action.delete'), + label: i18n.global.t('global.action.delete'), }, ], tableFilters: [ { key: 'dumpType', - label: this.$t('pageDumps.table.dumpType'), + label: i18n.global.t('pageDumps.table.dumpType'), values: [ 'BMC Dump Entry', 'Hostboot Dump Entry', @@ -279,11 +280,11 @@ export default { actions: [ { value: 'download', - title: this.$t('global.action.download'), + title: i18n.global.t('global.action.download'), }, { value: 'delete', - title: this.$t('global.action.delete'), + title: i18n.global.t('global.action.delete'), }, ], }; @@ -328,12 +329,15 @@ export default { onTableRowAction(action, dump) { if (action === 'delete') { this.$bvModal - .msgBoxConfirm(this.$tc('pageDumps.modal.deleteDumpConfirmation'), { - title: this.$tc('pageDumps.modal.deleteDump'), - okTitle: this.$tc('pageDumps.modal.deleteDump'), - cancelTitle: this.$t('global.action.cancel'), - autoFocusButton: 'ok', - }) + .msgBoxConfirm( + i18n.global.t('pageDumps.modal.deleteDumpConfirmation'), + { + title: i18n.global.t('pageDumps.modal.deleteDump'), + okTitle: i18n.global.t('pageDumps.modal.deleteDump'), + cancelTitle: i18n.global.t('global.action.cancel'), + autoFocusButton: 'ok', + }, + ) .then((deleteConfrimed) => { if (deleteConfrimed) { this.$store @@ -355,20 +359,20 @@ export default { if (action === 'delete') { this.$bvModal .msgBoxConfirm( - this.$tc( + i18n.global.t( 'pageDumps.modal.deleteDumpConfirmation', this.selectedRows.length, ), { - title: this.$tc( + title: i18n.global.t( 'pageDumps.modal.deleteDump', this.selectedRows.length, ), - okTitle: this.$tc( + okTitle: i18n.global.t( 'pageDumps.modal.deleteDump', this.selectedRows.length, ), - cancelTitle: this.$t('global.action.cancel'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) diff --git a/src/views/Logs/Dumps/DumpsForm.vue b/src/views/Logs/Dumps/DumpsForm.vue index 40cea7e3..7da3084f 100644 --- a/src/views/Logs/Dumps/DumpsForm.vue +++ b/src/views/Logs/Dumps/DumpsForm.vue @@ -9,7 +9,7 @@ id="selectDumpType" v-model="selectedDumpType" :options="dumpTypeOptions" - :state="getValidationState($v.selectedDumpType)" + :state="getValidationState(v$.selectedDumpType)" > <template #first> <b-form-select-option :value="null" disabled> @@ -39,6 +39,7 @@ import ModalConfirmation from './DumpsModalConfirmation'; import Alert from '@/components/Global/Alert'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; +import i18n from '@/i18n'; export default { components: { Alert, ModalConfirmation }, @@ -52,8 +53,8 @@ export default { return { selectedDumpType: null, dumpTypeOptions: [ - { value: 'bmc', text: this.$t('pageDumps.form.bmcDump') }, - { value: 'system', text: this.$t('pageDumps.form.systemDump') }, + { value: 'bmc', text: i18n.global.t('pageDumps.form.bmcDump') }, + { value: 'system', text: i18n.global.t('pageDumps.form.systemDump') }, ], }; }, @@ -64,8 +65,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; // System dump initiation if (this.selectedDumpType === 'system') { @@ -76,10 +77,15 @@ export default { this.$store .dispatch('dumps/createBmcDump') .then(() => - this.infoToast(this.$t('pageDumps.toast.successStartBmcDump'), { - title: this.$t('pageDumps.toast.successStartBmcDumpTitle'), - timestamp: true, - }), + this.infoToast( + i18n.global.t('pageDumps.toast.successStartBmcDump'), + { + title: i18n.global.t( + 'pageDumps.toast.successStartBmcDumpTitle', + ), + timestamp: true, + }, + ), ) .catch(({ message }) => this.errorToast(message)); } @@ -91,10 +97,15 @@ export default { this.$store .dispatch('dumps/createSystemDump') .then(() => - this.infoToast(this.$t('pageDumps.toast.successStartSystemDump'), { - title: this.$t('pageDumps.toast.successStartSystemDumpTitle'), - timestamp: true, - }), + this.infoToast( + i18n.global.t('pageDumps.toast.successStartSystemDump'), + { + title: i18n.global.t( + 'pageDumps.toast.successStartSystemDumpTitle', + ), + timestamp: true, + }, + ), ) .catch(({ message }) => this.errorToast(message)); }, diff --git a/src/views/Logs/Dumps/DumpsModalConfirmation.vue b/src/views/Logs/Dumps/DumpsModalConfirmation.vue index 2a1e552f..4b68681b 100644 --- a/src/views/Logs/Dumps/DumpsModalConfirmation.vue +++ b/src/views/Logs/Dumps/DumpsModalConfirmation.vue @@ -17,11 +17,11 @@ <status-icon status="danger" /> {{ $t('pageDumps.modal.initiateSystemDumpMessage3') }} </p> - <b-form-checkbox v-model="confirmed" @input="$v.confirmed.$touch()"> + <b-form-checkbox v-model="confirmed" @input="v$.confirmed.$touch()"> {{ $t('pageDumps.modal.initiateSystemDumpMessage4') }} </b-form-checkbox> <b-form-invalid-feedback - :state="getValidationState($v.confirmed)" + :state="getValidationState(v$.confirmed)" role="alert" > {{ $t('global.form.required') }} @@ -67,14 +67,14 @@ export default { }); }, handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok'); this.closeModal(); }, resetForm() { this.confirmed = false; - this.$v.$reset(); + this.v$.$reset(); }, }, }; diff --git a/src/views/Logs/EventLogs/EventLogs.vue b/src/views/Logs/EventLogs/EventLogs.vue index 7aa5b1f7..392125c7 100644 --- a/src/views/Logs/EventLogs/EventLogs.vue +++ b/src/views/Logs/EventLogs/EventLogs.vue @@ -144,8 +144,8 @@ <!-- Modified date --> <dt>{{ $t('pageEventLogs.table.modifiedDate') }}:</dt> <dd v-if="item.modifiedDate"> - {{ item.modifiedDate }} - {{ item.modifiedDate }} + {{ $filters.formatDate(item.modifiedDate) }} + {{ $filters.formatTime(item.modifiedDate) }} </dd> <dd v-else>--</dd> </dl> @@ -166,8 +166,8 @@ </template> <!-- Date column --> <template #cell(date)="{ value }"> - <p class="mb-0">{{ value }}</p> - <p class="mb-0">{{ value }}</p> + <p class="mb-0">{{ $filters.formatDate(value) }}</p> + <p class="mb-0">{{ $filters.formatTime(value) }}</p> </template> <!-- Status column --> @@ -545,8 +545,8 @@ export default { onTableRowAction(action, { uri }) { if (action === 'delete') { this.$bvModal - .msgBoxConfirm(this.$tc('pageEventLogs.modal.deleteMessage'), { - title: this.$tc('pageEventLogs.modal.deleteTitle'), + .msgBoxConfirm(i18n.global.t('pageEventLogs.modal.deleteMessage'), { + title: i18n.global.t('pageEventLogs.modal.deleteTitle'), okTitle: i18n.global.t('global.action.delete'), cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', @@ -561,12 +561,12 @@ export default { const uris = this.selectedRows.map((row) => row.uri); this.$bvModal .msgBoxConfirm( - this.$tc( + i18n.global.t( 'pageEventLogs.modal.deleteMessage', this.selectedRows.length, ), { - title: this.$tc( + title: i18n.global.t( 'pageEventLogs.modal.deleteTitle', this.selectedRows.length, ), @@ -585,7 +585,7 @@ export default { ) .then(() => { this.successToast( - this.$tc( + i18n.global.t( 'pageEventLogs.toast.successDelete', uris.length, ), diff --git a/src/views/Logs/PostCodeLogs/PostCodeLogs.vue b/src/views/Logs/PostCodeLogs/PostCodeLogs.vue index ad62afce..6d8ff907 100644 --- a/src/views/Logs/PostCodeLogs/PostCodeLogs.vue +++ b/src/views/Logs/PostCodeLogs/PostCodeLogs.vue @@ -97,8 +97,8 @@ </template> <!-- Date column --> <template #cell(date)="{ value }"> - <p class="mb-0">{{ value }}</p> - <p class="mb-0">{{ value }}</p> + <p class="mb-0">{{ $filters.formatDate(value) }}</p> + <p class="mb-0">{{ $filters.formatTime(value) }}</p> </template> <!-- Actions column --> @@ -186,6 +186,8 @@ import TableRowExpandMixin, { import SearchFilterMixin, { searchFilter, } from '@/components/Mixins/SearchFilterMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { @@ -218,6 +220,7 @@ export default { }, data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -226,20 +229,20 @@ export default { }, { key: 'date', - label: this.$t('pagePostCodeLogs.table.created'), + label: i18n.global.t('pagePostCodeLogs.table.created'), sortable: true, }, { key: 'timeStampOffset', - label: this.$t('pagePostCodeLogs.table.timeStampOffset'), + label: i18n.global.t('pagePostCodeLogs.table.timeStampOffset'), }, { key: 'bootCount', - label: this.$t('pagePostCodeLogs.table.bootCount'), + label: i18n.global.t('pagePostCodeLogs.table.bootCount'), }, { key: 'postCode', - label: this.$t('pagePostCodeLogs.table.postCode'), + label: i18n.global.t('pagePostCodeLogs.table.postCode'), }, { key: 'actions', @@ -278,11 +281,11 @@ export default { actions: [ { value: 'export', - title: this.$t('pagePostCodeLogs.action.exportLogs'), + title: i18n.global.t('pagePostCodeLogs.action.exportLogs'), }, { value: 'download', - title: this.$t('pagePostCodeLogs.action.downloadDetails'), + title: i18n.global.t('pagePostCodeLogs.action.downloadDetails'), }, ], }; @@ -316,11 +319,11 @@ export default { methods: { deleteAllLogs() { this.$bvModal - .msgBoxConfirm(this.$t('pageEventLogs.modal.deleteAllMessage'), { - title: this.$t('pageEventLogs.modal.deleteAllTitle'), - okTitle: this.$t('global.action.delete'), + .msgBoxConfirm(i18n.global.t('pageEventLogs.modal.deleteAllMessage'), { + title: i18n.global.t('pageEventLogs.modal.deleteAllTitle'), + okTitle: i18n.global.t('global.action.delete'), okVariant: 'danger', - cancelTitle: this.$t('global.action.cancel'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'cancel', }) .then((deleteConfirmed) => { @@ -361,11 +364,11 @@ export default { date.toString().split(':').join('-').split(' ')[4]; let fileName; if (value === 'download') { - fileName = this.$t('pagePostCodeLogs.downloadFilePrefix'); + fileName = i18n.global.t('pagePostCodeLogs.downloadFilePrefix'); } else if (value === 'export') { - fileName = this.$t('pagePostCodeLogs.exportFilePrefix'); + fileName = i18n.global.t('pagePostCodeLogs.exportFilePrefix'); } else { - fileName = this.$t('pagePostCodeLogs.allExportFilePrefix'); + fileName = i18n.global.t('pagePostCodeLogs.allExportFilePrefix'); } return fileName + date; }, diff --git a/src/views/Operations/FactoryReset/FactoryReset.vue b/src/views/Operations/FactoryReset/FactoryReset.vue index 40330b12..f59b0a21 100644 --- a/src/views/Operations/FactoryReset/FactoryReset.vue +++ b/src/views/Operations/FactoryReset/FactoryReset.vue @@ -60,6 +60,7 @@ import PageTitle from '@/components/Global/PageTitle'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; import ModalReset from './FactoryResetModal'; +import { useI18n } from 'vue-i18n'; export default { name: 'FactoryReset', @@ -67,6 +68,7 @@ export default { mixins: [LoadingBarMixin, BVToastMixin], data() { return { + $t: useI18n().t, resetOption: 'resetBios', }; }, diff --git a/src/views/Operations/FactoryReset/FactoryResetModal.vue b/src/views/Operations/FactoryReset/FactoryResetModal.vue index 55ac1761..8784d4ae 100644 --- a/src/views/Operations/FactoryReset/FactoryResetModal.vue +++ b/src/views/Operations/FactoryReset/FactoryResetModal.vue @@ -32,13 +32,13 @@ <b-form-checkbox v-model="confirm" aria-describedby="reset-to-default-warning" - @input="$v.confirm.$touch()" + @input="v$.confirm.$touch()" > {{ $t(`pageFactoryReset.modal.resetWarningCheckLabel`) }} </b-form-checkbox> <b-form-invalid-feedback role="alert" - :state="getValidationState($v.confirm)" + :state="getValidationState(v$.confirm)" > {{ $t('global.form.fieldRequired') }} </b-form-invalid-feedback> @@ -66,6 +66,7 @@ <script> import StatusIcon from '@/components/Global/StatusIcon'; import VuelidateMixin from '@/components/Mixins/VuelidateMixin'; +import { useI18n } from 'vue-i18n'; export default { components: { StatusIcon }, @@ -78,6 +79,7 @@ export default { }, data() { return { + $t: useI18n().t, confirm: false, }; }, @@ -98,15 +100,15 @@ export default { }, methods: { handleConfirm() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('okConfirm'); this.$nextTick(() => this.$refs.modal.hide()); this.resetConfirm(); }, resetConfirm() { this.confirm = false; - this.$v.$reset(); + this.v$.$reset(); }, }, }; diff --git a/src/views/Operations/Firmware/Firmware.vue b/src/views/Operations/Firmware/Firmware.vue index 44a721ae..db1a4c7e 100644 --- a/src/views/Operations/Firmware/Firmware.vue +++ b/src/views/Operations/Firmware/Firmware.vue @@ -46,6 +46,7 @@ import PageSection from '@/components/Global/PageSection'; import PageTitle from '@/components/Global/PageTitle'; import LoadingBarMixin, { loading } from '@/components/Mixins/LoadingBarMixin'; +import { useI18n } from 'vue-i18n'; export default { name: 'FirmwareSingleImage', @@ -64,6 +65,7 @@ export default { }, data() { return { + $t: useI18n().t, loading, isServerPowerOffRequired: process.env.VUE_APP_SERVER_OFF_REQUIRED === 'true', diff --git a/src/views/Operations/Firmware/FirmwareAlertServerPower.vue b/src/views/Operations/Firmware/FirmwareAlertServerPower.vue index 08e4ae91..94cac578 100644 --- a/src/views/Operations/Firmware/FirmwareAlertServerPower.vue +++ b/src/views/Operations/Firmware/FirmwareAlertServerPower.vue @@ -32,6 +32,7 @@ <script> import Alert from '@/components/Global/Alert'; +import { useI18n } from 'vue-i18n'; export default { components: { Alert }, @@ -42,6 +43,11 @@ export default { default: true, }, }, + data() { + return { + $t: useI18n().t, + }; + }, computed: { isOperationInProgress() { return this.$store.getters['controls/isOperationInProgress']; diff --git a/src/views/Operations/Firmware/FirmwareCardsBmc.vue b/src/views/Operations/Firmware/FirmwareCardsBmc.vue index bfca14cf..2d18d5b8 100644 --- a/src/views/Operations/Firmware/FirmwareCardsBmc.vue +++ b/src/views/Operations/Firmware/FirmwareCardsBmc.vue @@ -58,6 +58,8 @@ import LoadingBarMixin, { loading } from '@/components/Mixins/LoadingBarMixin'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import ModalSwitchToRunning from './FirmwareModalSwitchToRunning'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { IconSwitch, ModalSwitchToRunning, PageSection }, @@ -76,6 +78,7 @@ export default { }, data() { return { + $t: useI18n().t, loading, switchToBackupImageDisabled: process.env.VUE_APP_SWITCH_TO_BACKUP_IMAGE_DISABLED === 'true', @@ -87,9 +90,9 @@ export default { }, sectionTitle() { if (this.isSingleFileUploadEnabled) { - return this.$t('pageFirmware.sectionTitleBmcCardsCombined'); + return i18n.global.t('pageFirmware.sectionTitleBmcCardsCombined'); } - return this.$t('pageFirmware.sectionTitleBmcCards'); + return i18n.global.t('pageFirmware.sectionTitleBmcCards'); }, running() { return this.$store.getters['firmware/activeBmcFirmware']; @@ -117,18 +120,24 @@ export default { this.startLoader(); const timerId = setTimeout(() => { this.endLoader(); - this.infoToast(this.$t('pageFirmware.toast.verifySwitchMessage'), { - title: this.$t('pageFirmware.toast.verifySwitch'), - refreshAction: true, - }); + this.infoToast( + i18n.global.t('pageFirmware.toast.verifySwitchMessage'), + { + title: i18n.global.t('pageFirmware.toast.verifySwitch'), + refreshAction: true, + }, + ); }, 60000); this.$store .dispatch('firmware/switchBmcFirmwareAndReboot') .then(() => - this.infoToast(this.$t('pageFirmware.toast.rebootStartedMessage'), { - title: this.$t('pageFirmware.toast.rebootStarted'), - }), + this.infoToast( + i18n.global.t('pageFirmware.toast.rebootStartedMessage'), + { + title: i18n.global.t('pageFirmware.toast.rebootStarted'), + }, + ), ) .catch(({ message }) => { this.errorToast(message); diff --git a/src/views/Operations/Firmware/FirmwareCardsHost.vue b/src/views/Operations/Firmware/FirmwareCardsHost.vue index 8fd0cac9..852e9fb1 100644 --- a/src/views/Operations/Firmware/FirmwareCardsHost.vue +++ b/src/views/Operations/Firmware/FirmwareCardsHost.vue @@ -38,9 +38,15 @@ <script> import PageSection from '@/components/Global/PageSection'; +import { useI18n } from 'vue-i18n'; export default { components: { PageSection }, + data() { + return { + $t: useI18n().t, + }; + }, computed: { running() { return this.$store.getters['firmware/activeHostFirmware']; diff --git a/src/views/Operations/Firmware/FirmwareFormUpdate.vue b/src/views/Operations/Firmware/FirmwareFormUpdate.vue index 3f114a93..dfb5c689 100644 --- a/src/views/Operations/Firmware/FirmwareFormUpdate.vue +++ b/src/views/Operations/Firmware/FirmwareFormUpdate.vue @@ -50,6 +50,8 @@ import { useVuelidate } from '@vuelidate/core'; import FormFile from '@/components/Global/FormFile'; import ModalUpdateFirmware from './FirmwareModalUpdateFirmware'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { FormFile, ModalUpdateFirmware }, @@ -67,11 +69,12 @@ export default { }, setup() { return { - v$: useVuelidate(), + $v: useVuelidate(), }; }, data() { return { + $t: useI18n().t, loading, file: null, isServerPowerOffRequired: @@ -93,13 +96,16 @@ export default { this.startLoader(); const timerId = setTimeout(() => { this.endLoader(); - this.infoToast(this.$t('pageFirmware.toast.verifyUpdateMessage'), { - title: this.$t('pageFirmware.toast.verifyUpdate'), - refreshAction: true, - }); + this.infoToast( + i18n.global.t('pageFirmware.toast.verifyUpdateMessage'), + { + title: i18n.global.t('pageFirmware.toast.verifyUpdate'), + refreshAction: true, + }, + ); }, 360000); - this.infoToast(this.$t('pageFirmware.toast.updateStartedMessage'), { - title: this.$t('pageFirmware.toast.updateStarted'), + this.infoToast(i18n.global.t('pageFirmware.toast.updateStartedMessage'), { + title: i18n.global.t('pageFirmware.toast.updateStarted'), timestamp: true, }); this.dispatchWorkstationUpload(timerId); diff --git a/src/views/Operations/Firmware/FirmwareModalSwitchToRunning.vue b/src/views/Operations/Firmware/FirmwareModalSwitchToRunning.vue index dc4a4973..9af8fb55 100644 --- a/src/views/Operations/Firmware/FirmwareModalSwitchToRunning.vue +++ b/src/views/Operations/Firmware/FirmwareModalSwitchToRunning.vue @@ -20,6 +20,7 @@ </template> <script> +import { useI18n } from 'vue-i18n'; export default { props: { backup: { @@ -27,5 +28,10 @@ export default { required: true, }, }, + data() { + return { + $t: useI18n().t, + }; + }, }; </script> diff --git a/src/views/Operations/Firmware/FirmwareModalUpdateFirmware.vue b/src/views/Operations/Firmware/FirmwareModalUpdateFirmware.vue index 18355217..183cab75 100644 --- a/src/views/Operations/Firmware/FirmwareModalUpdateFirmware.vue +++ b/src/views/Operations/Firmware/FirmwareModalUpdateFirmware.vue @@ -28,7 +28,13 @@ </template> <script> +import { useI18n } from 'vue-i18n'; export default { + data() { + return { + $t: useI18n().t, + }; + }, computed: { runningBmc() { return this.$store.getters['firmware/activeBmcFirmware']; diff --git a/src/views/Operations/KeyClear/KeyClear.vue b/src/views/Operations/KeyClear/KeyClear.vue index fbdf4c46..7baad344 100644 --- a/src/views/Operations/KeyClear/KeyClear.vue +++ b/src/views/Operations/KeyClear/KeyClear.vue @@ -69,6 +69,8 @@ import PageTitle from '@/components/Global/PageTitle'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; import Alert from '@/components/Global/Alert'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'KeyClear', @@ -76,6 +78,7 @@ export default { mixins: [LoadingBarMixin, BVToastMixin], data() { return { + $t: useI18n().t, keyOption: 'NONE', username: this.$store.getters['global/username'], }; @@ -86,11 +89,11 @@ export default { methods: { onKeyClearSubmit(valueSelected) { this.$bvModal - .msgBoxConfirm(this.$t('pageKeyClear.modal.clearAllMessage'), { - title: this.$t('pageKeyClear.modal.clearAllTitle'), - okTitle: this.$t('pageKeyClear.modal.clear'), + .msgBoxConfirm(i18n.global.t('pageKeyClear.modal.clearAllMessage'), { + title: i18n.global.t('pageKeyClear.modal.clearAllTitle'), + okTitle: i18n.global.t('pageKeyClear.modal.clear'), okVariant: 'danger', - cancelTitle: this.$t('global.action.cancel'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'cancel', }) .then((clearConfirmed) => { diff --git a/src/views/Operations/Kvm/KvmConsole.vue b/src/views/Operations/Kvm/KvmConsole.vue index cc623e44..6e2a4eac 100644 --- a/src/views/Operations/Kvm/KvmConsole.vue +++ b/src/views/Operations/Kvm/KvmConsole.vue @@ -46,6 +46,8 @@ import StatusIcon from '@/components/Global/StatusIcon'; import IconLaunch from '@carbon/icons-vue/es/launch/20'; import IconArrowDown from '@carbon/icons-vue/es/arrow--down/16'; import { throttle } from 'lodash'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; const Connecting = 0; const Connected = 1; @@ -62,6 +64,7 @@ export default { }, data() { return { + $t: useI18n().t, rfb: null, isConnected: false, terminalClass: this.isFullWindow ? 'full-window' : '', @@ -82,11 +85,11 @@ export default { }, serverStatus() { if (this.status === Connected) { - return this.$t('pageKvm.connected'); + return i18n.global.t('pageKvm.connected'); } else if (this.status === Disconnected) { - return this.$t('pageKvm.disconnected'); + return i18n.global.t('pageKvm.disconnected'); } - return this.$t('pageKvm.connecting'); + return i18n.global.t('pageKvm.connecting'); }, }, created() { diff --git a/src/views/Operations/RebootBmc/RebootBmc.vue b/src/views/Operations/RebootBmc/RebootBmc.vue index e56e968f..0865d77d 100644 --- a/src/views/Operations/RebootBmc/RebootBmc.vue +++ b/src/views/Operations/RebootBmc/RebootBmc.vue @@ -11,8 +11,8 @@ {{ $t('pageRebootBmc.lastReboot') }} </dt> <dd v-if="lastBmcRebootTime"> - {{ lastBmcRebootTime }} - {{ lastBmcRebootTime }} + {{ $filters.formatDate(lastBmcRebootTime) }} + {{ $filters.formatTime(lastBmcRebootTime) }} </dd> <dd v-else>--</dd> </dl> @@ -38,6 +38,8 @@ import PageTitle from '@/components/Global/PageTitle'; import PageSection from '@/components/Global/PageSection'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'RebootBmc', @@ -47,6 +49,11 @@ export default { this.hideLoader(); next(); }, + data() { + return { + $t: useI18n().t, + }; + }, computed: { lastBmcRebootTime() { return this.$store.getters['controls/lastBmcRebootTime']; @@ -61,10 +68,10 @@ export default { methods: { onClick() { this.$bvModal - .msgBoxConfirm(this.$t('pageRebootBmc.modal.confirmMessage'), { - title: this.$t('pageRebootBmc.modal.confirmTitle'), - okTitle: this.$t('global.action.confirm'), - cancelTitle: this.$t('global.action.cancel'), + .msgBoxConfirm(i18n.global.t('pageRebootBmc.modal.confirmMessage'), { + title: i18n.global.t('pageRebootBmc.modal.confirmTitle'), + okTitle: i18n.global.t('global.action.confirm'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }) .then((confirmed) => { diff --git a/src/views/Operations/SerialOverLan/SerialOverLan.vue b/src/views/Operations/SerialOverLan/SerialOverLan.vue index 48a68345..b9d3f2e6 100644 --- a/src/views/Operations/SerialOverLan/SerialOverLan.vue +++ b/src/views/Operations/SerialOverLan/SerialOverLan.vue @@ -12,6 +12,7 @@ import PageTitle from '@/components/Global/PageTitle'; import PageSection from '@/components/Global/PageSection'; import SerialOverLanConsole from './SerialOverLanConsole'; +import { useI18n } from 'vue-i18n'; export default { name: 'SerialOverLan', @@ -20,5 +21,10 @@ export default { PageTitle, SerialOverLanConsole, }, + data() { + return { + $t: useI18n().t, + }; + }, }; </script> diff --git a/src/views/Operations/SerialOverLan/SerialOverLanConsole.vue b/src/views/Operations/SerialOverLan/SerialOverLanConsole.vue index 8b4cd222..b711422f 100644 --- a/src/views/Operations/SerialOverLan/SerialOverLanConsole.vue +++ b/src/views/Operations/SerialOverLan/SerialOverLanConsole.vue @@ -50,6 +50,7 @@ import { Terminal } from 'xterm'; import { throttle } from 'lodash'; import IconLaunch from '@carbon/icons-vue/es/launch/20'; import StatusIcon from '@/components/Global/StatusIcon'; +import { useI18n } from 'vue-i18n'; export default { name: 'SerialOverLanConsole', @@ -66,6 +67,7 @@ export default { }, data() { return { + $t: useI18n().t, resizeConsoleWindow: null, }; }, diff --git a/src/views/Operations/ServerPowerOperations/BootSettings.vue b/src/views/Operations/ServerPowerOperations/BootSettings.vue index c74fd01f..a7bcfaa9 100644 --- a/src/views/Operations/ServerPowerOperations/BootSettings.vue +++ b/src/views/Operations/ServerPowerOperations/BootSettings.vue @@ -21,7 +21,7 @@ v-model="form.oneTimeBoot" class="mb-4" :disabled="form.bootOption === 'None'" - @change="$v.form.oneTimeBoot.$touch()" + @change="v$.form.oneTimeBoot.$touch()" > {{ $t('pageServerPowerOperations.bootSettings.enableOneTimeBoot') }} </b-form-checkbox> @@ -37,7 +37,7 @@ id="tpm-required-policy" v-model="form.tpmPolicyOn" aria-describedby="tpm-required-policy-help-block" - @change="$v.form.tpmPolicyOn.$touch()" + @change="v$.form.tpmPolicyOn.$touch()" > {{ $t('global.status.enabled') }} </b-form-checkbox> @@ -53,12 +53,14 @@ import { mapState } from 'vuex'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; +import { useI18n } from 'vue-i18n'; export default { name: 'BootSettings', mixins: [BVToastMixin, LoadingBarMixin], data() { return { + $t: useI18n().t, form: { bootOption: this.$store.getters['serverBootSettings/bootSource'], oneTimeBoot: this.$store.getters['serverBootSettings/overrideEnabled'], @@ -104,7 +106,7 @@ export default { methods: { handleSubmit() { this.startLoader(); - const tpmPolicyChanged = this.$v.form.tpmPolicyOn.$dirty; + const tpmPolicyChanged = this.v$.form.tpmPolicyOn.$dirty; let settings; let bootSource = this.form.bootOption; let overrideEnabled = this.form.oneTimeBoot; @@ -118,12 +120,12 @@ export default { .then((message) => this.successToast(message)) .catch(({ message }) => this.errorToast(message)) .finally(() => { - this.$v.form.$reset(); + this.v$.form.$reset(); this.endLoader(); }); }, onChangeSelect(selectedOption) { - this.$v.form.bootOption.$touch(); + this.v$.form.bootOption.$touch(); // Disable one time boot if selected boot option is 'None' if (selectedOption === 'None') this.form.oneTimeBoot = false; }, diff --git a/src/views/Operations/ServerPowerOperations/ServerPowerOperations.vue b/src/views/Operations/ServerPowerOperations/ServerPowerOperations.vue index 4e26ee10..caa608e8 100644 --- a/src/views/Operations/ServerPowerOperations/ServerPowerOperations.vue +++ b/src/views/Operations/ServerPowerOperations/ServerPowerOperations.vue @@ -44,8 +44,8 @@ v-if="lastPowerOperationTime" data-test-id="powerServerOps-text-lastPowerOp" > - {{ lastPowerOperationTime }} - {{ lastPowerOperationTime }} + {{ $filters.formatDate(lastPowerOperationTime) }} + {{ $filters.formatTime(lastPowerOperationTime) }} </dd> <dd v-else>--</dd> </dl> @@ -158,6 +158,8 @@ import BVToastMixin from '@/components/Mixins/BVToastMixin'; import BootSettings from './BootSettings'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; import Alert from '@/components/Global/Alert'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'ServerPowerOperations', @@ -169,6 +171,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { rebootOption: 'orderly', shutdownOption: 'orderly', @@ -212,13 +215,15 @@ export default { this.$store.dispatch('controls/serverPowerOn'); }, rebootServer() { - const modalMessage = this.$t( + const modalMessage = i18n.global.t( 'pageServerPowerOperations.modal.confirmRebootMessage', ); const modalOptions = { - title: this.$t('pageServerPowerOperations.modal.confirmRebootTitle'), - okTitle: this.$t('global.action.confirm'), - cancelTitle: this.$t('global.action.cancel'), + title: i18n.global.t( + 'pageServerPowerOperations.modal.confirmRebootTitle', + ), + okTitle: i18n.global.t('global.action.confirm'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }; @@ -237,13 +242,15 @@ export default { } }, shutdownServer() { - const modalMessage = this.$t( + const modalMessage = i18n.global.t( 'pageServerPowerOperations.modal.confirmShutdownMessage', ); const modalOptions = { - title: this.$t('pageServerPowerOperations.modal.confirmShutdownTitle'), - okTitle: this.$t('global.action.confirm'), - cancelTitle: this.$t('global.action.cancel'), + title: i18n.global.t( + 'pageServerPowerOperations.modal.confirmShutdownTitle', + ), + okTitle: i18n.global.t('global.action.confirm'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }; diff --git a/src/views/Operations/VirtualMedia/ModalConfigureConnection.vue b/src/views/Operations/VirtualMedia/ModalConfigureConnection.vue index 61e20507..f8d4af0c 100644 --- a/src/views/Operations/VirtualMedia/ModalConfigureConnection.vue +++ b/src/views/Operations/VirtualMedia/ModalConfigureConnection.vue @@ -18,12 +18,12 @@ id="serverUri" v-model="form.serverUri" type="text" - :state="getValidationState($v.form.serverUri)" + :state="getValidationState(v$.form.serverUri)" data-test-id="configureConnection-input-serverUri" - @input="$v.form.serverUri.$touch()" + @input="v$.form.serverUri.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.serverUri.required"> + <template v-if="!v$.form.serverUri.required"> {{ $t('global.form.fieldRequired') }} </template> </b-form-invalid-feedback> @@ -73,6 +73,7 @@ import { required } from '@vuelidate/validators'; import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; +import { useI18n } from 'vue-i18n'; export default { mixins: [VuelidateMixin], @@ -93,6 +94,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { serverUri: null, username: null, @@ -118,8 +120,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; let connectionData = {}; Object.assign(connectionData, this.form); this.$emit('ok', connectionData); @@ -140,7 +142,7 @@ export default { this.form.username = null; this.form.password = null; this.form.isRW = false; - this.$v.$reset(); + this.v$.$reset(); }, onOk(bvModalEvt) { bvModalEvt.preventDefault(); diff --git a/src/views/Operations/VirtualMedia/VirtualMedia.vue b/src/views/Operations/VirtualMedia/VirtualMedia.vue index 9ad1b1eb..e1580597 100644 --- a/src/views/Operations/VirtualMedia/VirtualMedia.vue +++ b/src/views/Operations/VirtualMedia/VirtualMedia.vue @@ -104,6 +104,8 @@ import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; import ModalConfigureConnection from './ModalConfigureConnection'; import NbdServer from '@/utilities/NBDServer'; import FormFile from '@/components/Global/FormFile'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'VirtualMedia', @@ -111,6 +113,7 @@ export default { mixins: [BVToastMixin, LoadingBarMixin], data() { return { + $t: useI18n().t, modalConfigureConnection: null, loadImageFromExternalServer: process.env.VUE_APP_VIRTUAL_MEDIA_LIST_ENABLED === 'true' @@ -144,17 +147,21 @@ export default { token, ); device.nbd.socketStarted = () => - this.successToast(this.$t('pageVirtualMedia.toast.serverRunning')); + this.successToast( + i18n.global.t('pageVirtualMedia.toast.serverRunning'), + ); device.nbd.errorReadingFile = () => - this.errorToast(this.$t('pageVirtualMedia.toast.errorReadingFile')); + this.errorToast( + i18n.global.t('pageVirtualMedia.toast.errorReadingFile'), + ); device.nbd.socketClosed = (code) => { if (code === 1000) this.successToast( - this.$t('pageVirtualMedia.toast.serverClosedSuccessfully'), + i18n.global.t('pageVirtualMedia.toast.serverClosedSuccessfully'), ); else this.errorToast( - this.$t('pageVirtualMedia.toast.serverClosedWithErrors'), + i18n.global.t('pageVirtualMedia.toast.serverClosedWithErrors'), ); device.file = null; device.isActive = false; @@ -180,12 +187,14 @@ export default { }) .then(() => { this.successToast( - this.$t('pageVirtualMedia.toast.serverConnectionEstablished'), + i18n.global.t('pageVirtualMedia.toast.serverConnectionEstablished'), ); connectionData.isActive = true; }) .catch(() => { - this.errorToast(this.$t('pageVirtualMedia.toast.errorMounting')); + this.errorToast( + i18n.global.t('pageVirtualMedia.toast.errorMounting'), + ); this.isActive = false; }) .finally(() => this.endLoader()); @@ -195,12 +204,14 @@ export default { .dispatch('virtualMedia/unmountImage', connectionData.id) .then(() => { this.successToast( - this.$t('pageVirtualMedia.toast.serverClosedSuccessfully'), + i18n.global.t('pageVirtualMedia.toast.serverClosedSuccessfully'), ); connectionData.isActive = false; }) .catch(() => - this.errorToast(this.$t('pageVirtualMedia.toast.errorUnmounting')), + this.errorToast( + i18n.global.t('pageVirtualMedia.toast.errorUnmounting'), + ), ) .finally(() => this.endLoader()); }, diff --git a/src/views/Overview/OverviewQuickLinks.vue b/src/views/Overview/OverviewQuickLinks.vue index ef9ab126..506de112 100644 --- a/src/views/Overview/OverviewQuickLinks.vue +++ b/src/views/Overview/OverviewQuickLinks.vue @@ -5,7 +5,8 @@ <dl> <dt>{{ $t('pageOverview.bmcTime') }}</dt> <dd v-if="bmcTime" data-test-id="overviewQuickLinks-text-bmcTime"> - {{ bmcTime }} {{ bmcTime }} + {{ $filters.formatDate(bmcTime) }} + {{ $filters.formatDate(bmcTime) }} </dd> <dd v-else>--</dd> </dl> diff --git a/src/views/PageNotFound/PageNotFound.vue b/src/views/PageNotFound/PageNotFound.vue index 91341dbb..77e596cd 100644 --- a/src/views/PageNotFound/PageNotFound.vue +++ b/src/views/PageNotFound/PageNotFound.vue @@ -5,8 +5,15 @@ </template> <script> import PageTitle from '@/components/Global/PageTitle'; +import { useI18n } from 'vue-i18n'; + export default { name: 'PageNotFound', components: { PageTitle }, + data() { + return { + $t: useI18n().t, + }; + }, }; </script> diff --git a/src/views/ProfileSettings/ProfileSettings.vue b/src/views/ProfileSettings/ProfileSettings.vue index aa325745..6fc9c1e7 100644 --- a/src/views/ProfileSettings/ProfileSettings.vue +++ b/src/views/ProfileSettings/ProfileSettings.vue @@ -57,16 +57,16 @@ v-model="form.newPassword" type="password" aria-describedby="password-help-block" - :state="getValidationState($v.form.newPassword)" + :state="getValidationState(v$.form.newPassword)" data-test-id="profileSettings-input-newPassword" class="form-control-with-button" - @input="$v.form.newPassword.$touch()" + @input="v$.form.newPassword.$touch()" /> <b-form-invalid-feedback role="alert"> <template v-if=" - !$v.form.newPassword.minLength || - !$v.form.newPassword.maxLength + !v$.form.newPassword.minLength || + !v$.form.newPassword.maxLength " > {{ @@ -89,13 +89,13 @@ id="password-confirmation" v-model="form.confirmPassword" type="password" - :state="getValidationState($v.form.confirmPassword)" + :state="getValidationState(v$.form.confirmPassword)" data-test-id="profileSettings-input-confirmPassword" class="form-control-with-button" - @input="$v.form.confirmPassword.$touch()" + @input="v$.form.confirmPassword.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.confirmPassword.sameAsPassword"> + <template v-if="!v$.form.confirmPassword.sameAsPassword"> {{ $t('pageProfileSettings.passwordsDoNotMatch') }} </template> </b-form-invalid-feedback> @@ -152,6 +152,8 @@ import PageTitle from '@/components/Global/PageTitle'; import PageSection from '@/components/Global/PageSection'; import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'ProfileSettings', @@ -169,6 +171,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { newPassword: '', confirmPassword: '', @@ -209,9 +212,9 @@ export default { }, methods: { saveNewPasswordInputData() { - this.$v.form.confirmPassword.$touch(); - this.$v.form.newPassword.$touch(); - if (this.$v.$invalid) return; + this.v$.form.confirmPassword.$touch(); + this.v$.form.newPassword.$touch(); + if (this.v$.$invalid) return; let userData = { originalUsername: this.username, password: this.form.newPassword, @@ -223,7 +226,7 @@ export default { (this.form.newPassword = ''), (this.form.confirmPassword = ''), (this.form.currentPassword = ''); - this.$v.$reset(); + this.v$.$reset(); this.successToast(message); this.$store.dispatch('authentication/logout'); }) @@ -233,7 +236,7 @@ export default { localStorage.setItem('storedUtcDisplay', this.form.isUtcDisplay); this.$store.commit('global/setUtcTime', this.form.isUtcDisplay); this.successToast( - this.$t('pageProfileSettings.toast.successUpdatingTimeZone'), + i18n.global.t('pageProfileSettings.toast.successUpdatingTimeZone'), ); }, submitForm() { @@ -251,8 +254,8 @@ export default { } }, confirmAuthenticate() { - this.$v.form.newPassword.$touch(); - if (this.$v.$invalid) return; + this.v$.form.newPassword.$touch(); + if (this.v$.$invalid) return; const username = this.username; const password = this.form.currentPassword; @@ -263,9 +266,9 @@ export default { this.saveNewPasswordInputData(); }) .catch(() => { - this.$v.$reset(); + this.v$.$reset(); this.errorToast( - this.$t('pageProfileSettings.toast.wrongCredentials'), + i18n.global.t('pageProfileSettings.toast.wrongCredentials'), ); }); }, diff --git a/src/views/ResourceManagement/Power.vue b/src/views/ResourceManagement/Power.vue index 8a9503fd..12e4868b 100644 --- a/src/views/ResourceManagement/Power.vue +++ b/src/views/ResourceManagement/Power.vue @@ -56,14 +56,14 @@ data-test-id="power-input-powerCapValue" type="number" aria-describedby="power-help-text" - :state="getValidationState($v.powerCapValue)" + :state="getValidationState(v$.powerCapValue)" ></b-form-input> <b-form-invalid-feedback id="input-live-feedback" role="alert"> - <template v-if="!$v.powerCapValue.required"> + <template v-if="!v$.powerCapValue.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-else-if="!$v.powerCapValue.between"> + <template v-else-if="!v$.powerCapValue.between"> {{ $t('global.form.invalidValue') }} </template> </b-form-invalid-feedback> @@ -92,6 +92,7 @@ import { useVuelidate } from '@vuelidate/core'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import { requiredIf, between } from '@vuelidate/validators'; import { mapGetters } from 'vuex'; +import { useI18n } from 'vue-i18n'; export default { name: 'Power', @@ -108,6 +109,7 @@ export default { }, data() { return { + $t: useI18n().t, loading, }; }, @@ -125,7 +127,7 @@ export default { return this.powerCapValue !== null; }, set(value) { - this.$v.$reset(); + this.v$.$reset(); let newValue = null; if (value) { if (this.powerCapValue) { @@ -142,7 +144,7 @@ export default { return this.$store.getters['powerControl/powerCapValue']; }, set(value) { - this.$v.$touch(); + this.v$.$touch(); this.$store.dispatch('powerControl/setPowerCapUpdatedValue', value); }, }, @@ -163,8 +165,8 @@ export default { }, methods: { submitForm() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.startLoader(); this.$store .dispatch('powerControl/setPowerControl', this.powerCapValue) diff --git a/src/views/SecurityAndAccess/Certificates/Certificates.vue b/src/views/SecurityAndAccess/Certificates/Certificates.vue index bceab5d2..a55b66cc 100644 --- a/src/views/SecurityAndAccess/Certificates/Certificates.vue +++ b/src/views/SecurityAndAccess/Certificates/Certificates.vue @@ -63,7 +63,7 @@ :empty-text="$t('global.table.emptyMessage')" > <template #cell(validFrom)="{ value }"> - {{ value }} + {{ $filters.formatDate(value) }} </template> <template #cell(validUntil)="{ value }"> @@ -71,7 +71,7 @@ v-if="getDaysUntilExpired(value) < 31" :status="getIconStatus(value)" /> - {{ value }} + {{ $filters.formatDate(value) }} </template> <template #cell(actions)="{ value, item }"> @@ -113,6 +113,8 @@ import Alert from '@/components/Global/Alert'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'Certificates', @@ -134,29 +136,30 @@ export default { }, data() { return { + $t: useI18n().t, isBusy: true, modalCertificate: null, fileTypeCorrect: undefined, fields: [ { key: 'certificate', - label: this.$t('pageCertificates.table.certificate'), + label: i18n.global.t('pageCertificates.table.certificate'), }, { key: 'issuedBy', - label: this.$t('pageCertificates.table.issuedBy'), + label: i18n.global.t('pageCertificates.table.issuedBy'), }, { key: 'issuedTo', - label: this.$t('pageCertificates.table.issuedTo'), + label: i18n.global.t('pageCertificates.table.issuedTo'), }, { key: 'validFrom', - label: this.$t('pageCertificates.table.validFrom'), + label: i18n.global.t('pageCertificates.table.validFrom'), }, { key: 'validUntil', - label: this.$t('pageCertificates.table.validUntil'), + label: i18n.global.t('pageCertificates.table.validUntil'), }, { key: 'actions', @@ -177,11 +180,11 @@ export default { actions: [ { value: 'replace', - title: this.$t('pageCertificates.replaceCertificate'), + title: i18n.global.t('pageCertificates.replaceCertificate'), }, { value: 'delete', - title: this.$t('pageCertificates.deleteCertificate'), + title: i18n.global.t('pageCertificates.deleteCertificate'), enabled: certificate.type === 'TrustStore Certificate' ? true : false, }, @@ -242,14 +245,14 @@ export default { initModalDeleteCertificate(certificate) { this.$bvModal .msgBoxConfirm( - this.$t('pageCertificates.modal.deleteConfirmMessage', { + i18n.global.t('pageCertificates.modal.deleteConfirmMessage', { issuedBy: certificate.issuedBy, certificate: certificate.certificate, }), { - title: this.$t('pageCertificates.deleteCertificate'), - okTitle: this.$t('global.action.delete'), - cancelTitle: this.$t('global.action.cancel'), + title: i18n.global.t('pageCertificates.deleteCertificate'), + okTitle: i18n.global.t('global.action.delete'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) @@ -265,9 +268,13 @@ export default { this.addNewCertificate(file, type); } else { this.errorToast( - this.$t('pageCertificates.alert.incorrectCertificateFileType'), + i18n.global.t( + 'pageCertificates.alert.incorrectCertificateFileType', + ), { - title: this.$t('pageCertificates.toast.errorAddCertificate'), + title: i18n.global.t( + 'pageCertificates.toast.errorAddCertificate', + ), }, ); } diff --git a/src/views/SecurityAndAccess/Certificates/ModalGenerateCsr.vue b/src/views/SecurityAndAccess/Certificates/ModalGenerateCsr.vue index 03ab8f4a..a74a1e46 100644 --- a/src/views/SecurityAndAccess/Certificates/ModalGenerateCsr.vue +++ b/src/views/SecurityAndAccess/Certificates/ModalGenerateCsr.vue @@ -8,7 +8,7 @@ :title="$t('pageCertificates.modal.generateACertificateSigningRequest')" @ok="onOkGenerateCsrModal" @cancel="resetForm" - @hidden="$v.$reset()" + @hidden="v$.$reset()" > <b-form id="generate-csr-form" novalidate> <b-container fluid> @@ -25,8 +25,8 @@ v-model="form.certificateType" data-test-id="modalGenerateCsr-select-certificateType" :options="certificateOptions" - :state="getValidationState($v.form.certificateType)" - @input="$v.form.certificateType.$touch()" + :state="getValidationState(v$.form.certificateType)" + @input="v$.form.certificateType.$touch()" > <template #first> <b-form-select-option :value="null" disabled> @@ -49,8 +49,8 @@ v-model="form.country" data-test-id="modalGenerateCsr-select-country" :options="countryOptions" - :state="getValidationState($v.form.country)" - @input="$v.form.country.$touch()" + :state="getValidationState(v$.form.country)" + @input="v$.form.country.$touch()" > <template #first> <b-form-select-option :value="null" disabled> @@ -75,7 +75,7 @@ v-model="form.state" type="text" data-test-id="modalGenerateCsr-input-state" - :state="getValidationState($v.form.state)" + :state="getValidationState(v$.form.state)" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -92,7 +92,7 @@ v-model="form.city" type="text" data-test-id="modalGenerateCsr-input-city" - :state="getValidationState($v.form.city)" + :state="getValidationState(v$.form.city)" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -111,7 +111,7 @@ v-model="form.companyName" type="text" data-test-id="modalGenerateCsr-input-companyName" - :state="getValidationState($v.form.companyName)" + :state="getValidationState(v$.form.companyName)" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -128,7 +128,7 @@ v-model="form.companyUnit" type="text" data-test-id="modalGenerateCsr-input-companyUnit" - :state="getValidationState($v.form.companyUnit)" + :state="getValidationState(v$.form.companyUnit)" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -147,7 +147,7 @@ v-model="form.commonName" type="text" data-test-id="modalGenerateCsr-input-commonName" - :state="getValidationState($v.form.commonName)" + :state="getValidationState(v$.form.commonName)" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -240,8 +240,8 @@ v-model="form.keyPairAlgorithm" data-test-id="modalGenerateCsr-select-keyPairAlgorithm" :options="keyPairAlgorithmOptions" - :state="getValidationState($v.form.keyPairAlgorithm)" - @input="$v.form.keyPairAlgorithm.$touch()" + :state="getValidationState(v$.form.keyPairAlgorithm)" + @input="v$.form.keyPairAlgorithm.$touch()" > <template #first> <b-form-select-option :value="null" disabled> @@ -257,7 +257,7 @@ </b-row> <b-row> <b-col lg="12"> - <template v-if="$v.form.keyPairAlgorithm.$model === 'EC'"> + <template v-if="v$.form.keyPairAlgorithm.$model === 'EC'"> <b-form-group :label="$t('pageCertificates.modal.keyCurveId')" label-for="key-curve-id" @@ -267,8 +267,8 @@ v-model="form.keyCurveId" data-test-id="modalGenerateCsr-select-keyCurveId" :options="keyCurveIdOptions" - :state="getValidationState($v.form.keyCurveId)" - @input="$v.form.keyCurveId.$touch()" + :state="getValidationState(v$.form.keyCurveId)" + @input="v$.form.keyCurveId.$touch()" > <template #first> <b-form-select-option :value="null" disabled> @@ -281,7 +281,7 @@ </b-form-invalid-feedback> </b-form-group> </template> - <template v-if="$v.form.keyPairAlgorithm.$model === 'RSA'"> + <template v-if="v$.form.keyPairAlgorithm.$model === 'RSA'"> <b-form-group :label="$t('pageCertificates.modal.keyBitLength')" label-for="key-bit-length" @@ -291,8 +291,8 @@ v-model="form.keyBitLength" data-test-id="modalGenerateCsr-select-keyBitLength" :options="keyBitLengthOptions" - :state="getValidationState($v.form.keyBitLength)" - @input="$v.form.keyBitLength.$touch()" + :state="getValidationState(v$.form.keyBitLength)" + @input="v$.form.keyBitLength.$touch()" > <template #first> <b-form-select-option :value="null" disabled> @@ -369,6 +369,7 @@ import { COUNTRY_LIST } from './CsrCountryCodes'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; +import { useI18n } from 'vue-i18n'; export default { name: 'ModalGenerateCsr', @@ -381,6 +382,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { certificateType: null, country: null, @@ -449,14 +451,14 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$store .dispatch('certificates/generateCsr', this.form) .then(({ data: { CSRString } }) => { this.csrString = CSRString; this.$bvModal.show('csr-string'); - this.$v.$reset(); + this.v$.$reset(); }); }, resetForm() { diff --git a/src/views/SecurityAndAccess/Certificates/ModalUploadCertificate.vue b/src/views/SecurityAndAccess/Certificates/ModalUploadCertificate.vue index 60170f1b..3a8cd3f0 100644 --- a/src/views/SecurityAndAccess/Certificates/ModalUploadCertificate.vue +++ b/src/views/SecurityAndAccess/Certificates/ModalUploadCertificate.vue @@ -27,12 +27,12 @@ id="certificate-type" v-model="form.certificateType" :options="certificateOptions" - :state="getValidationState($v.form.certificateType)" - @input="$v.form.certificateType.$touch()" + :state="getValidationState(v$.form.certificateType)" + @input="v$.form.certificateType.$touch()" > </b-form-select> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.certificateType.required"> + <template v-if="!v$.form.certificateType.required"> {{ $t('global.form.fieldRequired') }} </template> </b-form-invalid-feedback> @@ -44,7 +44,7 @@ id="certificate-file" v-model="form.file" accept=".pem" - :state="getValidationState($v.form.file)" + :state="getValidationState(v$.form.file)" > <template #invalid> <b-form-invalid-feedback role="alert"> @@ -74,6 +74,7 @@ import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; import FormFile from '@/components/Global/FormFile'; +import { useI18n } from 'vue-i18n'; export default { components: { FormFile }, @@ -98,6 +99,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { certificateType: null, file: null, @@ -140,8 +142,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok', { addNew: !this.certificate, file: this.form.file, @@ -162,7 +164,7 @@ export default { ? this.certificateOptions[0].value : null; this.form.file = null; - this.$v.$reset(); + this.v$.$reset(); }, onOk(bvModalEvt) { // prevent modal close diff --git a/src/views/SecurityAndAccess/Ldap/Ldap.vue b/src/views/SecurityAndAccess/Ldap/Ldap.vue index 28d2b1cb..eab2737f 100644 --- a/src/views/SecurityAndAccess/Ldap/Ldap.vue +++ b/src/views/SecurityAndAccess/Ldap/Ldap.vue @@ -44,7 +44,7 @@ :disabled=" !caCertificateExpiration || !ldapCertificateExpiration " - @change="$v.form.secureLdapEnabled.$touch()" + @change="v$.form.secureLdapEnabled.$touch()" > {{ $t('global.action.enable') }} </b-form-checkbox> @@ -52,12 +52,12 @@ <dl> <dt>{{ $t('pageLdap.form.caCertificateValidUntil') }}</dt> <dd v-if="caCertificateExpiration"> - {{ caCertificateExpiration }} + {{ $filters.formatDate(caCertificateExpiration) }} </dd> <dd v-else>--</dd> <dt>{{ $t('pageLdap.form.ldapCertificateValidUntil') }}</dt> <dd v-if="ldapCertificateExpiration"> - {{ ldapCertificateExpiration }} + {{ $filters.formatDate(ldapCertificateExpiration) }} </dd> <dd v-else>--</dd> </dl> @@ -105,8 +105,8 @@ id="server-uri" v-model="form.serverUri" data-test-id="ldap-input-serverUri" - :state="getValidationState($v.form.serverUri)" - @change="$v.form.serverUri.$touch()" + :state="getValidationState(v$.form.serverUri)" + @change="v$.form.serverUri.$touch()" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -123,8 +123,8 @@ id="bind-dn" v-model="form.bindDn" data-test-id="ldap-input-bindDn" - :state="getValidationState($v.form.bindDn)" - @change="$v.form.bindDn.$touch()" + :state="getValidationState(v$.form.bindDn)" + @change="v$.form.bindDn.$touch()" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -143,9 +143,9 @@ id="bind-password" v-model="form.bindPassword" type="password" - :state="getValidationState($v.form.bindPassword)" + :state="getValidationState(v$.form.bindPassword)" class="form-control-with-button" - @change="$v.form.bindPassword.$touch()" + @change="v$.form.bindPassword.$touch()" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -162,8 +162,8 @@ id="base-dn" v-model="form.baseDn" data-test-id="ldap-input-baseDn" - :state="getValidationState($v.form.baseDn)" - @change="$v.form.baseDn.$touch()" + :state="getValidationState(v$.form.baseDn)" + @change="v$.form.baseDn.$touch()" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -182,7 +182,7 @@ id="user-id-attribute" v-model="form.userIdAttribute" data-test-id="ldap-input-userIdAttribute" - @change="$v.form.userIdAttribute.$touch()" + @change="v$.form.userIdAttribute.$touch()" /> </b-form-group> </b-col> @@ -198,7 +198,7 @@ id="group-id-attribute" v-model="form.groupIdAttribute" data-test-id="ldap-input-groupIdAttribute" - @change="$v.form.groupIdAttribute.$touch()" + @change="v$.form.groupIdAttribute.$touch()" /> </b-form-group> </b-col> @@ -243,6 +243,7 @@ import PageTitle from '@/components/Global/PageTitle'; import PageSection from '@/components/Global/PageSection'; import InfoTooltip from '@/components/Global/InfoTooltip'; import TableRoleGroups from './TableRoleGroups'; +import { useI18n } from 'vue-i18n'; export default { name: 'Ldap', @@ -265,6 +266,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { ldapAuthenticationEnabled: this.$store.getters['ldap/isServiceEnabled'], secureLdapEnabled: false, @@ -388,8 +390,8 @@ export default { this.form.groupIdAttribute = groupsAttribute; }, handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; const data = { serviceEnabled: this.form.ldapAuthenticationEnabled, activeDirectoryEnabled: this.form.activeDirectoryEnabled, @@ -411,12 +413,12 @@ export default { }) .finally(() => { this.form.bindPassword = ''; - this.$v.form.$reset(); + this.v$.form.$reset(); this.endLoader(); }); }, onChangeServiceType(isActiveDirectoryEnabled) { - this.$v.form.activeDirectoryEnabled.$touch(); + this.v$.form.activeDirectoryEnabled.$touch(); const serviceType = isActiveDirectoryEnabled ? this.activeDirectory : this.ldap; @@ -425,7 +427,7 @@ export default { this.setFormValues(serviceType); }, onChangeldapAuthenticationEnabled(isServiceEnabled) { - this.$v.form.ldapAuthenticationEnabled.$touch(); + this.v$.form.ldapAuthenticationEnabled.$touch(); if (!isServiceEnabled) { // Request will fail if sent with empty values. // The frontend only checks for required fields diff --git a/src/views/SecurityAndAccess/Ldap/ModalAddRoleGroup.vue b/src/views/SecurityAndAccess/Ldap/ModalAddRoleGroup.vue index 9b50abdc..d22aa6a6 100644 --- a/src/views/SecurityAndAccess/Ldap/ModalAddRoleGroup.vue +++ b/src/views/SecurityAndAccess/Ldap/ModalAddRoleGroup.vue @@ -29,8 +29,8 @@ <b-form-input id="role-group-name" v-model="form.groupName" - :state="getValidationState($v.form.groupName)" - @input="$v.form.groupName.$touch()" + :state="getValidationState(v$.form.groupName)" + @input="v$.form.groupName.$touch()" /> <b-form-invalid-feedback role="alert"> {{ $t('global.form.fieldRequired') }} @@ -46,8 +46,8 @@ id="privilege" v-model="form.groupPrivilege" :options="accountRoles" - :state="getValidationState($v.form.groupPrivilege)" - @input="$v.form.groupPrivilege.$touch()" + :state="getValidationState(v$.form.groupPrivilege)" + @input="v$.form.groupPrivilege.$touch()" > <template v-if="!roleGroup" #first> <b-form-select-option :value="null" disabled> @@ -83,6 +83,7 @@ import { required, requiredIf } from '@vuelidate/validators'; import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; +import { useI18n } from 'vue-i18n'; export default { mixins: [VuelidateMixin], @@ -106,6 +107,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { groupName: null, groupPrivilege: null, @@ -140,8 +142,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok', { addNew: !this.roleGroup, groupName: this.form.groupName, @@ -157,7 +159,7 @@ export default { resetForm() { this.form.groupName = null; this.form.groupPrivilege = null; - this.$v.$reset(); + this.v$.$reset(); this.$emit('hidden'); }, onOk(bvModalEvt) { diff --git a/src/views/SecurityAndAccess/Ldap/TableRoleGroups.vue b/src/views/SecurityAndAccess/Ldap/TableRoleGroups.vue index eeebfb9b..f73d9276 100644 --- a/src/views/SecurityAndAccess/Ldap/TableRoleGroups.vue +++ b/src/views/SecurityAndAccess/Ldap/TableRoleGroups.vue @@ -108,6 +108,8 @@ import BVTableSelectableMixin, { import BVToastMixin from '@/components/Mixins/BVToastMixin'; import ModalAddRoleGroup from './ModalAddRoleGroup'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { @@ -122,6 +124,7 @@ export default { mixins: [BVTableSelectableMixin, BVToastMixin, LoadingBarMixin], data() { return { + $t: useI18n().t, isBusy: true, activeRoleGroup: null, fields: [ @@ -132,12 +135,12 @@ export default { { key: 'groupName', sortable: true, - label: this.$t('pageLdap.tableRoleGroups.groupName'), + label: i18n.global.t('pageLdap.tableRoleGroups.groupName'), }, { key: 'groupPrivilege', sortable: true, - label: this.$t('pageLdap.tableRoleGroups.groupPrivilege'), + label: i18n.global.t('pageLdap.tableRoleGroups.groupPrivilege'), }, { key: 'actions', @@ -149,7 +152,7 @@ export default { batchActions: [ { value: 'delete', - label: this.$t('global.action.delete'), + label: i18n.global.t('global.action.delete'), }, ], selectedRows: selectedRows, @@ -167,12 +170,12 @@ export default { actions: [ { value: 'edit', - title: this.$t('global.action.edit'), + title: i18n.global.t('global.action.edit'), enabled: this.isServiceEnabled, }, { value: 'delete', - title: this.$t('global.action.delete'), + title: i18n.global.t('global.action.delete'), enabled: this.isServiceEnabled, }, ], @@ -189,14 +192,14 @@ export default { onBatchAction() { this.$bvModal .msgBoxConfirm( - this.$tc( + i18n.global.t( 'pageLdap.modal.deleteRoleGroupBatchConfirmMessage', this.selectedRows.length, ), { - title: this.$t('pageLdap.modal.deleteRoleGroup'), - okTitle: this.$t('global.action.delete'), - cancelTitle: this.$t('global.action.cancel'), + title: i18n.global.t('pageLdap.modal.deleteRoleGroup'), + okTitle: i18n.global.t('global.action.delete'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) @@ -221,13 +224,13 @@ export default { case 'delete': this.$bvModal .msgBoxConfirm( - this.$t('pageLdap.modal.deleteRoleGroupConfirmMessage', { + i18n.global.t('pageLdap.modal.deleteRoleGroupConfirmMessage', { groupName: row.groupName, }), { - title: this.$t('pageLdap.modal.deleteRoleGroup'), - okTitle: this.$t('global.action.delete'), - cancelTitle: this.$t('global.action.cancel'), + title: i18n.global.t('pageLdap.modal.deleteRoleGroup'), + okTitle: i18n.global.t('global.action.delete'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) diff --git a/src/views/SecurityAndAccess/Policies/Policies.vue b/src/views/SecurityAndAccess/Policies/Policies.vue index fb521750..6cba8832 100644 --- a/src/views/SecurityAndAccess/Policies/Policies.vue +++ b/src/views/SecurityAndAccess/Policies/Policies.vue @@ -137,6 +137,8 @@ import PageTitle from '@/components/Global/PageTitle'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'Policies', @@ -148,15 +150,16 @@ export default { }, data() { return { + $t: useI18n().t, modifySSHPolicyDisabled: process.env.VUE_APP_MODIFY_SSH_POLICY_DISABLED === 'true', sessionTimeOutOptions: [ - { value: 1800, text: this.$t('pagePolicies.options.30minutes') }, - { value: 3600, text: this.$t('pagePolicies.options.1hour') }, - { value: 7200, text: this.$t('pagePolicies.options.2hours') }, - { value: 14400, text: this.$t('pagePolicies.options.4hours') }, - { value: 28800, text: this.$t('pagePolicies.options.8hours') }, - { value: 86400, text: this.$t('pagePolicies.options.1day') }, + { value: 1800, text: i18n.global.t('pagePolicies.options.30minutes') }, + { value: 3600, text: i18n.global.t('pagePolicies.options.1hour') }, + { value: 7200, text: i18n.global.t('pagePolicies.options.2hours') }, + { value: 14400, text: i18n.global.t('pagePolicies.options.4hours') }, + { value: 28800, text: i18n.global.t('pagePolicies.options.8hours') }, + { value: 86400, text: i18n.global.t('pagePolicies.options.1day') }, ], }; }, diff --git a/src/views/SecurityAndAccess/Sessions/Sessions.vue b/src/views/SecurityAndAccess/Sessions/Sessions.vue index 636aafe0..74dcf744 100644 --- a/src/views/SecurityAndAccess/Sessions/Sessions.vue +++ b/src/views/SecurityAndAccess/Sessions/Sessions.vue @@ -135,6 +135,8 @@ import BVToastMixin from '@/components/Mixins/BVToastMixin'; import SearchFilterMixin, { searchFilter, } from '@/components/Mixins/SearchFilterMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { components: { @@ -159,6 +161,7 @@ export default { }, data() { return { + $t: useI18n().t, isBusy: true, fields: [ { @@ -167,22 +170,22 @@ export default { }, { key: 'sessionID', - label: this.$t('pageSessions.table.sessionID'), + label: i18n.global.t('pageSessions.table.sessionID'), class: 'text-center', }, { key: 'context', - label: this.$t('pageSessions.table.context'), + label: i18n.global.t('pageSessions.table.context'), class: 'text-center', }, { key: 'username', - label: this.$t('pageSessions.table.username'), + label: i18n.global.t('pageSessions.table.username'), class: 'text-center', }, { key: 'ipAddress', - label: this.$t('pageSessions.table.ipAddress'), + label: i18n.global.t('pageSessions.table.ipAddress'), class: 'text-center', }, { @@ -194,7 +197,7 @@ export default { batchActions: [ { value: 'disconnect', - label: this.$t('pageSessions.action.disconnect'), + label: i18n.global.t('pageSessions.action.disconnect'), }, ], currentPage: currentPage, @@ -220,7 +223,7 @@ export default { actions: [ { value: 'disconnect', - title: this.$t('pageSessions.action.disconnect'), + title: i18n.global.t('pageSessions.action.disconnect'), }, ], }; @@ -257,12 +260,15 @@ export default { onTableRowAction(action, { uri }) { if (action === 'disconnect') { this.$bvModal - .msgBoxConfirm(this.$tc('pageSessions.modal.disconnectMessage'), { - title: this.$tc('pageSessions.modal.disconnectTitle'), - okTitle: this.$t('pageSessions.action.disconnect'), - cancelTitle: this.$t('global.action.cancel'), - autoFocusButton: 'ok', - }) + .msgBoxConfirm( + i18n.global.t('pageSessions.modal.disconnectMessage'), + { + title: i18n.global.t('pageSessions.modal.disconnectTitle'), + okTitle: i18n.global.t('pageSessions.action.disconnect'), + cancelTitle: i18n.global.t('global.action.cancel'), + autoFocusButton: 'ok', + }, + ) .then((deleteConfirmed) => { if (deleteConfirmed) this.disconnectSessions([uri]); }); @@ -273,17 +279,17 @@ export default { const uris = this.selectedRows.map((row) => row.uri); this.$bvModal .msgBoxConfirm( - this.$tc( + i18n.global.t( 'pageSessions.modal.disconnectMessage', this.selectedRows.length, ), { - title: this.$tc( + title: i18n.global.t( 'pageSessions.modal.disconnectTitle', this.selectedRows.length, ), - okTitle: this.$t('pageSessions.action.disconnect'), - cancelTitle: this.$t('global.action.cancel'), + okTitle: i18n.global.t('pageSessions.action.disconnect'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) diff --git a/src/views/SecurityAndAccess/UserManagement/ModalSettings.vue b/src/views/SecurityAndAccess/UserManagement/ModalSettings.vue index 8932eb56..91db8258 100644 --- a/src/views/SecurityAndAccess/UserManagement/ModalSettings.vue +++ b/src/views/SecurityAndAccess/UserManagement/ModalSettings.vue @@ -27,17 +27,17 @@ type="number" aria-describedby="lockout-threshold-help-block" data-test-id="userManagement-input-lockoutThreshold" - :state="getValidationState($v.form.lockoutThreshold)" - @input="$v.form.lockoutThreshold.$touch()" + :state="getValidationState(v$.form.lockoutThreshold)" + @input="v$.form.lockoutThreshold.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.lockoutThreshold.required"> + <template v-if="!v$.form.lockoutThreshold.required"> {{ $t('global.form.fieldRequired') }} </template> <template v-if=" - !$v.form.lockoutThreshold.minLength || - !$v.form.lockoutThreshold.maxLength + !v$.form.lockoutThreshold.minLength || + !v$.form.lockoutThreshold.maxLength " > {{ @@ -60,7 +60,7 @@ class="mb-2" :value="0" data-test-id="userManagement-radio-manualUnlock" - @input="$v.form.unlockMethod.$touch()" + @input="v$.form.unlockMethod.$touch()" > {{ $t('pageUserManagement.modal.manual') }} </b-form-radio> @@ -69,7 +69,7 @@ name="unlock-method" :value="1" data-test-id="userManagement-radio-automaticUnlock" - @input="$v.form.unlockMethod.$touch()" + @input="v$.form.unlockMethod.$touch()" > {{ $t('pageUserManagement.modal.automaticAfterTimeout') }} </b-form-radio> @@ -82,15 +82,15 @@ aria-describedby="lockout-duration-help-block" type="number" data-test-id="userManagement-input-lockoutDuration" - :state="getValidationState($v.form.lockoutDuration)" - :readonly="$v.form.unlockMethod.$model === 0" - @input="$v.form.lockoutDuration.$touch()" + :state="getValidationState(v$.form.lockoutDuration)" + :readonly="v$.form.unlockMethod.$model === 0" + @input="v$.form.lockoutDuration.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.lockoutDuration.required"> + <template v-if="!v$.form.lockoutDuration.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-else-if="!$v.form.lockoutDuration.minvalue"> + <template v-else-if="!v$.form.lockoutDuration.minvalue"> {{ $t('global.form.mustBeAtLeast', { value: 1 }) }} </template> </b-form-invalid-feedback> @@ -124,6 +124,7 @@ <script> import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; +import { useI18n } from 'vue-i18n'; import { required, @@ -147,6 +148,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { lockoutThreshold: 0, unlockMethod: 0, @@ -181,15 +183,15 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; let lockoutThreshold; let lockoutDuration; - if (this.$v.form.lockoutThreshold.$dirty) { + if (this.v$.form.lockoutThreshold.$dirty) { lockoutThreshold = this.form.lockoutThreshold; } - if (this.$v.form.unlockMethod.$dirty) { + if (this.v$.form.unlockMethod.$dirty) { lockoutDuration = this.form.unlockMethod ? this.form.lockoutDuration : 0; @@ -215,7 +217,7 @@ export default { this.form.lockoutDuration = this.settings.lockoutDuration ? this.settings.lockoutDuration : null; - this.$v.$reset(); // clear validations + this.v$.$reset(); // clear validations }, }, }; diff --git a/src/views/SecurityAndAccess/UserManagement/ModalUser.vue b/src/views/SecurityAndAccess/UserManagement/ModalUser.vue index dca97363..44ab516d 100644 --- a/src/views/SecurityAndAccess/UserManagement/ModalUser.vue +++ b/src/views/SecurityAndAccess/UserManagement/ModalUser.vue @@ -14,7 +14,7 @@ <b-row v-if="!newUser && manualUnlockPolicy && user.Locked"> <b-col sm="9"> <alert :show="true" variant="warning" small> - <template v-if="!$v.form.manualUnlock.$dirty"> + <template v-if="!v$.form.manualUnlock.$dirty"> {{ $t('pageUserManagement.modal.accountLocked') }} </template> <template v-else> @@ -30,9 +30,9 @@ /> <b-button variant="primary" - :disabled="$v.form.manualUnlock.$dirty" + :disabled="v$.form.manualUnlock.$dirty" data-test-id="userManagement-button-manualUnlock" - @click="$v.form.manualUnlock.$touch()" + @click="v$.form.manualUnlock.$touch()" > {{ $t('pageUserManagement.modal.unlock') }} </b-button> @@ -46,7 +46,7 @@ name="user-status" :value="true" data-test-id="userManagement-radioButton-statusEnabled" - @input="$v.form.status.$touch()" + @input="v$.form.status.$touch()" > {{ $t('global.status.enabled') }} </b-form-radio> @@ -56,7 +56,7 @@ data-test-id="userManagement-radioButton-statusDisabled" :value="false" :disabled="!newUser && originalUsername === disabled" - @input="$v.form.status.$touch()" + @input="v$.form.status.$touch()" > {{ $t('global.status.disabled') }} </b-form-radio> @@ -80,20 +80,20 @@ type="text" aria-describedby="username-help-block" data-test-id="userManagement-input-username" - :state="getValidationState($v.form.username)" + :state="getValidationState(v$.form.username)" :disabled="!newUser && originalUsername === disabled" - @input="$v.form.username.$touch()" + @input="v$.form.username.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.username.required"> + <template v-if="!v$.form.username.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-else-if="!$v.form.username.maxLength"> + <template v-else-if="!v$.form.username.maxLength"> {{ $t('global.form.lengthMustBeBetween', { min: 1, max: 16 }) }} </template> - <template v-else-if="!$v.form.username.pattern"> + <template v-else-if="!v$.form.username.pattern"> {{ $t('global.form.invalidFormat') }} </template> </b-form-invalid-feedback> @@ -107,9 +107,9 @@ v-model="form.privilege" :options="privilegeTypes" data-test-id="userManagement-select-privilege" - :state="getValidationState($v.form.privilege)" + :state="getValidationState(v$.form.privilege)" :disabled="!newUser && originalUsername === 'root'" - @input="$v.form.privilege.$touch()" + @input="v$.form.privilege.$touch()" > <template #first> <b-form-select-option :value="null" disabled> @@ -118,7 +118,7 @@ </template> </b-form-select> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.privilege.required"> + <template v-if="!v$.form.privilege.required"> {{ $t('global.form.fieldRequired') }} </template> </b-form-invalid-feedback> @@ -144,17 +144,17 @@ type="password" data-test-id="userManagement-input-password" aria-describedby="password-help-block" - :state="getValidationState($v.form.password)" + :state="getValidationState(v$.form.password)" class="form-control-with-button" - @input="$v.form.password.$touch()" + @input="v$.form.password.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.password.required"> + <template v-if="!v$.form.password.required"> {{ $t('global.form.fieldRequired') }} </template> <template v-if=" - !$v.form.password.minLength || !$v.form.password.maxLength + !v$.form.password.minLength || !v$.form.password.maxLength " > {{ @@ -177,16 +177,16 @@ v-model="form.passwordConfirmation" data-test-id="userManagement-input-passwordConfirmation" type="password" - :state="getValidationState($v.form.passwordConfirmation)" + :state="getValidationState(v$.form.passwordConfirmation)" class="form-control-with-button" - @input="$v.form.passwordConfirmation.$touch()" + @input="v$.form.passwordConfirmation.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.passwordConfirmation.required"> + <template v-if="!v$.form.passwordConfirmation.required"> {{ $t('global.form.fieldRequired') }} </template> <template - v-else-if="!$v.form.passwordConfirmation.sameAsPassword" + v-else-if="!v$.form.passwordConfirmation.sameAsPassword" > {{ $t('pageUserManagement.modal.passwordsDoNotMatch') }} </template> @@ -237,6 +237,7 @@ import { useVuelidate } from '@vuelidate/core'; import InputPasswordToggle from '@/components/Global/InputPasswordToggle'; import Alert from '@/components/Global/Alert'; +import { useI18n } from 'vue-i18n'; export default { components: { Alert, InputPasswordToggle }, @@ -258,6 +259,7 @@ export default { }, data() { return { + $t: useI18n().t, originalUsername: '', form: { status: true, @@ -329,28 +331,28 @@ export default { let userData = {}; if (this.newUser) { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; userData.username = this.form.username; userData.status = this.form.status; userData.privilege = this.form.privilege; userData.password = this.form.password; } else { - if (this.$v.$invalid) return; + if (this.v$.$invalid) return; userData.originalUsername = this.originalUsername; - if (this.$v.form.status.$dirty) { + if (this.v$.form.status.$dirty) { userData.status = this.form.status; } - if (this.$v.form.username.$dirty) { + if (this.v$.form.username.$dirty) { userData.username = this.form.username; } - if (this.$v.form.privilege.$dirty) { + if (this.v$.form.privilege.$dirty) { userData.privilege = this.form.privilege; } - if (this.$v.form.password.$dirty) { + if (this.v$.form.password.$dirty) { userData.password = this.form.password; } - if (this.$v.form.manualUnlock.$dirty) { + if (this.v$.form.manualUnlock.$dirty) { // If form manualUnlock control $dirty then // set user Locked property to false userData.locked = false; @@ -376,13 +378,13 @@ export default { this.form.privilege = null; this.form.password = ''; this.form.passwordConfirmation = ''; - this.$v.$reset(); + this.v$.$reset(); this.$emit('hidden'); }, requirePassword() { if (this.newUser) return true; - if (this.$v.form.password.$dirty) return true; - if (this.$v.form.passwordConfirmation.$dirty) return true; + if (this.v$.form.password.$dirty) return true; + if (this.v$.form.passwordConfirmation.$dirty) return true; return false; }, onOk(bvModalEvt) { diff --git a/src/views/SecurityAndAccess/UserManagement/TableRoles.vue b/src/views/SecurityAndAccess/UserManagement/TableRoles.vue index 9fb8013d..5d928569 100644 --- a/src/views/SecurityAndAccess/UserManagement/TableRoles.vue +++ b/src/views/SecurityAndAccess/UserManagement/TableRoles.vue @@ -25,6 +25,7 @@ <script> import Checkmark20 from '@carbon/icons-vue/es/checkmark/20'; +import i18n from '@/i18n'; export default { components: { @@ -34,7 +35,7 @@ export default { return { items: [ { - description: this.$t( + description: i18n.global.t( 'pageUserManagement.tableRoles.configureComponentsManagedByThisService', ), administrator: true, @@ -43,7 +44,7 @@ export default { noaccess: false, }, { - description: this.$t( + description: i18n.global.t( 'pageUserManagement.tableRoles.configureManagerResources', ), administrator: true, @@ -52,7 +53,7 @@ export default { noaccess: false, }, { - description: this.$t( + description: i18n.global.t( 'pageUserManagement.tableRoles.updatePasswordForCurrentUserAccount', ), administrator: true, @@ -61,7 +62,7 @@ export default { noaccess: false, }, { - description: this.$t( + description: i18n.global.t( 'pageUserManagement.tableRoles.configureUsersAndTheirAccounts', ), administrator: true, @@ -70,7 +71,7 @@ export default { noaccess: false, }, { - description: this.$t( + description: i18n.global.t( 'pageUserManagement.tableRoles.logInToTheServiceAndReadResources', ), administrator: true, @@ -82,26 +83,26 @@ export default { fields: [ { key: 'description', - label: this.$t('pageUserManagement.tableRoles.privilege'), + label: i18n.global.t('pageUserManagement.tableRoles.privilege'), }, { key: 'administrator', - label: this.$t('pageUserManagement.tableRoles.administrator'), + label: i18n.global.t('pageUserManagement.tableRoles.administrator'), class: 'text-center', }, { key: 'operator', - label: this.$t('pageUserManagement.tableRoles.operator'), + label: i18n.global.t('pageUserManagement.tableRoles.operator'), class: 'text-center', }, { key: 'readonly', - label: this.$t('pageUserManagement.tableRoles.readOnly'), + label: i18n.global.t('pageUserManagement.tableRoles.readOnly'), class: 'text-center', }, { key: 'noaccess', - label: this.$t('pageUserManagement.tableRoles.noAccess'), + label: i18n.global.t('pageUserManagement.tableRoles.noAccess'), class: 'text-center', }, ], diff --git a/src/views/SecurityAndAccess/UserManagement/UserManagement.vue b/src/views/SecurityAndAccess/UserManagement/UserManagement.vue index 43f3a404..99c344b1 100644 --- a/src/views/SecurityAndAccess/UserManagement/UserManagement.vue +++ b/src/views/SecurityAndAccess/UserManagement/UserManagement.vue @@ -133,6 +133,8 @@ import BVTableSelectableMixin, { } from '@/components/Mixins/BVTableSelectableMixin'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'UserManagement', @@ -156,6 +158,7 @@ export default { }, data() { return { + $t: useI18n().t, isBusy: true, activeUser: null, setting: {}, @@ -165,15 +168,15 @@ export default { }, { key: 'username', - label: this.$t('pageUserManagement.table.username'), + label: i18n.global.t('pageUserManagement.table.username'), }, { key: 'privilege', - label: this.$t('pageUserManagement.table.privilege'), + label: i18n.global.t('pageUserManagement.table.privilege'), }, { key: 'status', - label: this.$t('pageUserManagement.table.status'), + label: i18n.global.t('pageUserManagement.table.status'), }, { key: 'actions', @@ -184,15 +187,15 @@ export default { tableToolbarActions: [ { value: 'delete', - label: this.$t('global.action.delete'), + label: i18n.global.t('global.action.delete'), }, { value: 'enable', - label: this.$t('global.action.enable'), + label: i18n.global.t('global.action.enable'), }, { value: 'disable', - label: this.$t('global.action.disable'), + label: i18n.global.t('global.action.disable'), }, ], selectedRows: selectedRows, @@ -219,7 +222,7 @@ export default { { value: 'edit', enabled: this.editEnable(user), - title: this.$t('pageUserManagement.editUser'), + title: i18n.global.t('pageUserManagement.editUser'), }, { value: 'delete', @@ -229,7 +232,7 @@ export default { : true && user.UserName === 'root' ? false : true, - title: this.$tc('pageUserManagement.deleteUser'), + title: i18n.global.t('pageUserManagement.deleteUser'), }, ], ...user, @@ -267,13 +270,13 @@ export default { initModalDelete(user) { this.$bvModal .msgBoxConfirm( - this.$t('pageUserManagement.modal.deleteConfirmMessage', { + i18n.global.t('pageUserManagement.modal.deleteConfirmMessage', { user: user.username, }), { - title: this.$tc('pageUserManagement.deleteUser'), - okTitle: this.$tc('pageUserManagement.deleteUser'), - cancelTitle: this.$t('global.action.cancel'), + title: i18n.global.t('pageUserManagement.deleteUser'), + okTitle: i18n.global.t('pageUserManagement.deleteUser'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) @@ -316,20 +319,20 @@ export default { case 'delete': this.$bvModal .msgBoxConfirm( - this.$tc( + i18n.global.t( 'pageUserManagement.modal.batchDeleteConfirmMessage', this.selectedRows.length, ), { - title: this.$tc( + title: i18n.global.t( 'pageUserManagement.deleteUser', this.selectedRows.length, ), - okTitle: this.$tc( + okTitle: i18n.global.t( 'pageUserManagement.deleteUser', this.selectedRows.length, ), - cancelTitle: this.$t('global.action.cancel'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) diff --git a/src/views/Settings/DateTime/DateTime.vue b/src/views/Settings/DateTime/DateTime.vue index 00d7b45a..b86ebd22 100644 --- a/src/views/Settings/DateTime/DateTime.vue +++ b/src/views/Settings/DateTime/DateTime.vue @@ -18,14 +18,14 @@ <b-col lg="3"> <dl> <dt>{{ $t('pageDateTime.form.date') }}</dt> - <dd v-if="bmcTime">{{ bmcTime }}</dd> + <dd v-if="bmcTime">{{ $filters.formatDate(bmcTime) }}</dd> <dd v-else>--</dd> </dl> </b-col> <b-col lg="3"> <dl> <dt>{{ $t('pageDateTime.form.time.label') }}</dt> - <dd v-if="bmcTime">{{ bmcTime }}</dd> + <dd v-if="bmcTime">{{ $filters.formatTime(bmcTime) }}</dd> <dd v-else>--</dd> </dl> </b-col> @@ -56,17 +56,17 @@ <b-form-input id="input-manual-date" v-model="form.manual.date" - :state="getValidationState($v.form.manual.date)" + :state="getValidationState(v$.form.manual.date)" :disabled="ntpOptionSelected" data-test-id="dateTime-input-manualDate" class="form-control-with-button" - @blur="$v.form.manual.date.$touch()" + @blur="v$.form.manual.date.$touch()" /> <b-form-invalid-feedback role="alert"> - <div v-if="!$v.form.manual.date.pattern"> + <div v-if="!v$.form.manual.date.pattern"> {{ $t('global.form.invalidFormat') }} </div> - <div v-if="!$v.form.manual.date.required"> + <div v-if="!v$.form.manual.date.required"> {{ $t('global.form.fieldRequired') }} </div> </b-form-invalid-feedback> @@ -105,16 +105,16 @@ <b-form-input id="input-manual-time" v-model="form.manual.time" - :state="getValidationState($v.form.manual.time)" + :state="getValidationState(v$.form.manual.time)" :disabled="ntpOptionSelected" data-test-id="dateTime-input-manualTime" - @blur="$v.form.manual.time.$touch()" + @blur="v$.form.manual.time.$touch()" /> <b-form-invalid-feedback role="alert"> - <div v-if="!$v.form.manual.time.pattern"> + <div v-if="!v$.form.manual.time.pattern"> {{ $t('global.form.invalidFormat') }} </div> - <div v-if="!$v.form.manual.time.required"> + <div v-if="!v$.form.manual.time.required"> {{ $t('global.form.fieldRequired') }} </div> </b-form-invalid-feedback> @@ -139,13 +139,13 @@ <b-form-input id="input-ntp-1" v-model="form.ntp.firstAddress" - :state="getValidationState($v.form.ntp.firstAddress)" + :state="getValidationState(v$.form.ntp.firstAddress)" :disabled="manualOptionSelected" data-test-id="dateTime-input-ntpServer1" - @blur="$v.form.ntp.firstAddress.$touch()" + @blur="v$.form.ntp.firstAddress.$touch()" /> <b-form-invalid-feedback role="alert"> - <div v-if="!$v.form.ntp.firstAddress.required"> + <div v-if="!v$.form.ntp.firstAddress.required"> {{ $t('global.form.fieldRequired') }} </div> </b-form-invalid-feedback> @@ -210,6 +210,7 @@ import { useVuelidate } from '@vuelidate/core'; import { mapState } from 'vuex'; import { requiredIf, helpers } from '@vuelidate/validators'; +import { useI18n } from 'vue-i18n'; const isoDateRegex = /([12]\d{3}-(0[1-9]|1[0-2])-(0[1-9]|[12]\d|3[01]))/; const isoTimeRegex = /^(0[0-9]|1[0-9]|2[0-3]):[0-5][0-9]$/; @@ -234,6 +235,7 @@ export default { }, data() { return { + $t: useI18n().t, locale: this.$store.getters['global/languagePreference'], form: { configurationSelected: 'manual', @@ -302,10 +304,10 @@ export default { this.emitChange(); }, bmcTime() { - this.form.manual.date = this.$options.filters.formatDate( + this.form.manual.date = this.$filters.formatDate( this.$store.getters['global/bmcTime'], ); - this.form.manual.time = this.$options.filters + this.form.manual.time = this.$filters .formatTime(this.$store.getters['global/bmcTime']) .slice(0, 5); }, @@ -320,8 +322,8 @@ export default { }, methods: { emitChange() { - if (this.$v.$invalid) return; - this.$v.$reset(); //reset to re-validate on blur + if (this.v$.$invalid) return; + this.v$.$reset(); //reset to re-validate on blur this.$emit('change', { manualDate: this.manualDate ? new Date(this.manualDate) : null, }); @@ -337,8 +339,8 @@ export default { ] = [this.ntpServers[0], this.ntpServers[1], this.ntpServers[2]]; }, submitForm() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.startLoader(); let dateTimeForm = {}; @@ -398,7 +400,7 @@ export default { }) .catch(({ message }) => this.errorToast(message)) .finally(() => { - this.$v.form.$reset(); + this.v$.form.$reset(); this.endLoader(); }); }, diff --git a/src/views/Settings/Network/ModalDns.vue b/src/views/Settings/Network/ModalDns.vue index 8fe371ee..0e1bd881 100644 --- a/src/views/Settings/Network/ModalDns.vue +++ b/src/views/Settings/Network/ModalDns.vue @@ -16,14 +16,14 @@ id="staticDns" v-model="form.staticDns" type="text" - :state="getValidationState($v.form.staticDns)" - @input="$v.form.staticDns.$touch()" + :state="getValidationState(v$.form.staticDns)" + @input="v$.form.staticDns.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.staticDns.required"> + <template v-if="!v$.form.staticDns.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-if="!$v.form.staticDns.ipAddress"> + <template v-if="!v$.form.staticDns.ipAddress"> {{ $t('global.form.invalidFormat') }} </template> </b-form-invalid-feedback> @@ -47,6 +47,7 @@ import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; import { ipAddress, required } from '@vuelidate/validators'; +import { useI18n } from 'vue-i18n'; export default { mixins: [VuelidateMixin], @@ -57,6 +58,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { staticDns: null, }, @@ -74,8 +76,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok', [this.form.staticDns]); this.closeModal(); }, @@ -86,7 +88,7 @@ export default { }, resetForm() { this.form.staticDns = null; - this.$v.$reset(); + this.v$.$reset(); this.$emit('hidden'); }, onOk(bvModalEvt) { diff --git a/src/views/Settings/Network/ModalHostname.vue b/src/views/Settings/Network/ModalHostname.vue index 1b3bab1d..b2155b7a 100644 --- a/src/views/Settings/Network/ModalHostname.vue +++ b/src/views/Settings/Network/ModalHostname.vue @@ -16,14 +16,14 @@ id="hostname" v-model="form.hostname" type="text" - :state="getValidationState($v.form.hostname)" - @input="$v.form.hostname.$touch()" + :state="getValidationState(v$.form.hostname)" + @input="v$.form.hostname.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.hostname.required"> + <template v-if="!v$.form.hostname.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-if="!$v.form.hostname.validateHostname"> + <template v-if="!v$.form.hostname.validateHostname"> {{ $t('global.form.lengthMustBeBetween', { min: 1, max: 64 }) }} </template> </b-form-invalid-feedback> @@ -52,6 +52,7 @@ import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; import { required, helpers } from '@vuelidate/validators'; +import { useI18n } from 'vue-i18n'; const validateHostname = helpers.regex('validateHostname', /^\S{0,64}$/); @@ -70,6 +71,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { hostname: '', }, @@ -92,8 +94,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok', { HostName: this.form.hostname }); this.closeModal(); }, @@ -104,7 +106,7 @@ export default { }, resetForm() { this.form.hostname = this.hostname; - this.$v.$reset(); + this.v$.$reset(); this.$emit('hidden'); }, onOk(bvModalEvt) { diff --git a/src/views/Settings/Network/ModalIpv4.vue b/src/views/Settings/Network/ModalIpv4.vue index 2c3d9e88..a3b54826 100644 --- a/src/views/Settings/Network/ModalIpv4.vue +++ b/src/views/Settings/Network/ModalIpv4.vue @@ -16,14 +16,14 @@ id="ipAddress" v-model="form.ipAddress" type="text" - :state="getValidationState($v.form.ipAddress)" - @input="$v.form.ipAddress.$touch()" + :state="getValidationState(v$.form.ipAddress)" + @input="v$.form.ipAddress.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.ipAddress.required"> + <template v-if="!v$.form.ipAddress.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-if="!$v.form.ipAddress.ipAddress"> + <template v-if="!v$.form.ipAddress.ipAddress"> {{ $t('global.form.invalidFormat') }} </template> </b-form-invalid-feedback> @@ -38,14 +38,14 @@ id="gateway" v-model="form.gateway" type="text" - :state="getValidationState($v.form.gateway)" - @input="$v.form.gateway.$touch()" + :state="getValidationState(v$.form.gateway)" + @input="v$.form.gateway.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.gateway.required"> + <template v-if="!v$.form.gateway.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-if="!$v.form.gateway.ipAddress"> + <template v-if="!v$.form.gateway.ipAddress"> {{ $t('global.form.invalidFormat') }} </template> </b-form-invalid-feedback> @@ -62,14 +62,14 @@ id="subnetMask" v-model="form.subnetMask" type="text" - :state="getValidationState($v.form.subnetMask)" - @input="$v.form.subnetMask.$touch()" + :state="getValidationState(v$.form.subnetMask)" + @input="v$.form.subnetMask.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.subnetMask.required"> + <template v-if="!v$.form.subnetMask.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-if="!$v.form.subnetMask.ipAddress"> + <template v-if="!v$.form.subnetMask.ipAddress"> {{ $t('global.form.invalidFormat') }} </template> </b-form-invalid-feedback> @@ -93,6 +93,7 @@ import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; import { ipAddress, required } from '@vuelidate/validators'; +import { useI18n } from 'vue-i18n'; export default { mixins: [VuelidateMixin], @@ -109,6 +110,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { ipAddress: '', gateway: '', @@ -141,8 +143,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok', { Address: this.form.ipAddress, Gateway: this.form.gateway, @@ -159,7 +161,7 @@ export default { this.form.ipAddress = null; this.form.gateway = this.defaultGateway; this.form.subnetMask = null; - this.$v.$reset(); + this.v$.$reset(); this.$emit('hidden'); }, onOk(bvModalEvt) { diff --git a/src/views/Settings/Network/ModalMacAddress.vue b/src/views/Settings/Network/ModalMacAddress.vue index 307eb8df..f3fcc02e 100644 --- a/src/views/Settings/Network/ModalMacAddress.vue +++ b/src/views/Settings/Network/ModalMacAddress.vue @@ -17,14 +17,14 @@ v-model.trim="form.macAddress" data-test-id="network-input-macAddress" type="text" - :state="getValidationState($v.form.macAddress)" - @change="$v.form.macAddress.$touch()" + :state="getValidationState(v$.form.macAddress)" + @change="v$.form.macAddress.$touch()" /> <b-form-invalid-feedback role="alert"> - <div v-if="!$v.form.macAddress.required"> + <div v-if="!v$.form.macAddress.required"> {{ $t('global.form.fieldRequired') }} </div> - <div v-if="!$v.form.macAddress.macAddress"> + <div v-if="!v$.form.macAddress.macAddress"> {{ $t('global.form.invalidFormat') }} </div> </b-form-invalid-feedback> @@ -53,6 +53,7 @@ import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; import { macAddress, required } from '@vuelidate/validators'; +import { useI18n } from 'vue-i18n'; export default { mixins: [VuelidateMixin], @@ -69,6 +70,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { macAddress: '', }, @@ -91,8 +93,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok', { MACAddress: this.form.macAddress }); this.closeModal(); }, @@ -103,7 +105,7 @@ export default { }, resetForm() { this.form.macAddress = this.macAddress; - this.$v.$reset(); + this.v$.$reset(); this.$emit('hidden'); }, onOk(bvModalEvt) { diff --git a/src/views/Settings/Network/Network.vue b/src/views/Settings/Network/Network.vue index 0279cbe6..7a2e014c 100644 --- a/src/views/Settings/Network/Network.vue +++ b/src/views/Settings/Network/Network.vue @@ -64,6 +64,7 @@ import TableIpv4 from './TableIpv4.vue'; import TableIpv6 from './TableIpv6.vue'; import TableDns from './TableDns.vue'; import { mapState } from 'vuex'; +import { useI18n } from 'vue-i18n'; export default { name: 'Network', @@ -89,6 +90,7 @@ export default { }, data() { return { + $t: useI18n().t, currentHostname: '', currentMacAddress: '', defaultGateway: '', diff --git a/src/views/Settings/Network/NetworkGlobalSettings.vue b/src/views/Settings/Network/NetworkGlobalSettings.vue index 0c062ea2..23ce6cac 100644 --- a/src/views/Settings/Network/NetworkGlobalSettings.vue +++ b/src/views/Settings/Network/NetworkGlobalSettings.vue @@ -133,6 +133,7 @@ import IconEdit from '@carbon/icons-vue/es/edit/16'; import DataFormatterMixin from '@/components/Mixins/DataFormatterMixin'; import PageSection from '@/components/Global/PageSection'; import { mapState } from 'vuex'; +import { useI18n } from 'vue-i18n'; export default { name: 'GlobalNetworkSettings', @@ -141,6 +142,7 @@ export default { data() { return { + $t: useI18n().t, hostname: '', }; }, diff --git a/src/views/Settings/Network/NetworkInterfaceSettings.vue b/src/views/Settings/Network/NetworkInterfaceSettings.vue index 023d29bc..ea837574 100644 --- a/src/views/Settings/Network/NetworkInterfaceSettings.vue +++ b/src/views/Settings/Network/NetworkInterfaceSettings.vue @@ -62,6 +62,7 @@ import IconEdit from '@carbon/icons-vue/es/edit/16'; import PageSection from '@/components/Global/PageSection'; import DataFormatterMixin from '@/components/Mixins/DataFormatterMixin'; import { mapState } from 'vuex'; +import { useI18n } from 'vue-i18n'; export default { name: 'Ipv4Table', @@ -78,6 +79,7 @@ export default { }, data() { return { + $t: useI18n().t, selectedInterface: '', linkStatus: '', linkSpeed: '', diff --git a/src/views/Settings/Network/TableDns.vue b/src/views/Settings/Network/TableDns.vue index 569109f1..0de1dcab 100644 --- a/src/views/Settings/Network/TableDns.vue +++ b/src/views/Settings/Network/TableDns.vue @@ -46,6 +46,7 @@ import IconTrashcan from '@carbon/icons-vue/es/trash-can/20'; import PageSection from '@/components/Global/PageSection'; import TableRowAction from '@/components/Global/TableRowAction'; import { mapState } from 'vuex'; +import { useI18n } from 'vue-i18n'; export default { name: 'DNSTable', @@ -65,23 +66,24 @@ export default { }, data() { return { + $t: useI18n().t, form: { dnsStaticTableItems: [], }, actions: [ { value: 'edit', - title: this.$t('global.action.edit'), + title: 'global.action.edit', }, { value: 'delete', - title: this.$t('global.action.delete'), + title: 'global.action.delete', }, ], dnsTableFields: [ { key: 'address', - label: this.$t('pageNetwork.table.ipAddress'), + label: 'pageNetwork.table.ipAddress', }, { key: 'actions', label: '', tdClass: 'text-right' }, ], @@ -116,7 +118,7 @@ export default { actions: [ { value: 'delete', - title: this.$t('pageNetwork.table.deleteDns'), + title: 'pageNetwork.table.deleteDns', }, ], }; diff --git a/src/views/Settings/Network/TableIpv4.vue b/src/views/Settings/Network/TableIpv4.vue index 0a06e0e4..b95e7d39 100644 --- a/src/views/Settings/Network/TableIpv4.vue +++ b/src/views/Settings/Network/TableIpv4.vue @@ -71,6 +71,8 @@ import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; import PageSection from '@/components/Global/PageSection'; import TableRowAction from '@/components/Global/TableRowAction'; import { mapState } from 'vuex'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'Ipv4Table', @@ -90,35 +92,36 @@ export default { }, data() { return { + $t: useI18n().t, form: { ipv4TableItems: [], }, actions: [ { value: 'edit', - title: this.$t('global.action.edit'), + title: i18n.global.t('global.action.edit'), }, { value: 'delete', - title: this.$t('global.action.delete'), + title: i18n.global.t('global.action.delete'), }, ], ipv4TableFields: [ { key: 'Address', - label: this.$t('pageNetwork.table.ipAddress'), + label: i18n.global.t('pageNetwork.table.ipAddress'), }, { key: 'Gateway', - label: this.$t('pageNetwork.table.gateway'), + label: i18n.global.t('pageNetwork.table.gateway'), }, { key: 'SubnetMask', - label: this.$t('pageNetwork.table.subnet'), + label: i18n.global.t('pageNetwork.table.subnet'), }, { key: 'AddressOrigin', - label: this.$t('pageNetwork.table.addressOrigin'), + label: i18n.global.t('pageNetwork.table.addressOrigin'), }, { key: 'actions', label: '', tdClass: 'text-right' }, ], @@ -178,7 +181,7 @@ export default { actions: [ { value: 'delete', - title: this.$t('pageNetwork.table.deleteIpv4'), + title: i18n.global.t('pageNetwork.table.deleteIpv4'), }, ], }; @@ -211,19 +214,19 @@ export default { this.$bvModal .msgBoxConfirm( state - ? this.$t('pageNetwork.modal.confirmEnableDhcp') - : this.$t('pageNetwork.modal.confirmDisableDhcp'), + ? i18n.global.t('pageNetwork.modal.confirmEnableDhcp') + : i18n.global.t('pageNetwork.modal.confirmDisableDhcp'), { - title: this.$t('pageNetwork.modal.dhcpConfirmTitle', { + title: i18n.global.t('pageNetwork.modal.dhcpConfirmTitle', { dhcpState: state - ? this.$t('global.action.enable') - : this.$t('global.action.disable'), + ? i18n.global.t('global.action.enable') + : i18n.global.t('global.action.disable'), }), okTitle: state - ? this.$t('global.action.enable') - : this.$t('global.action.disable'), + ? i18n.global.t('global.action.enable') + : i18n.global.t('global.action.disable'), okVariant: 'danger', - cancelTitle: this.$t('global.action.cancel'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'cancel', }, ) diff --git a/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue b/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue index dfa4865d..348540a2 100644 --- a/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue +++ b/src/views/Settings/PowerRestorePolicy/PowerRestorePolicy.vue @@ -28,6 +28,8 @@ import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; import BVToastMixin from '@/components/Mixins/BVToastMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; export default { name: 'PowerRestorePolicy', @@ -44,6 +46,7 @@ export default { }, data() { return { + $t: useI18n().t, policyValue: null, options: [], }; @@ -74,7 +77,9 @@ export default { this.options.length = 0; this.powerRestorePolicies.map((item) => { this.options.push({ - text: this.$t(`pagePowerRestorePolicy.policiesDesc.${item.state}`), + text: i18n.global.t( + `pagePowerRestorePolicy.policiesDesc.${item.state}`, + ), value: `${item.state}`, }); }); diff --git a/src/views/Settings/SnmpAlerts/ModalAddDestination.vue b/src/views/Settings/SnmpAlerts/ModalAddDestination.vue index f52acd72..91ef34f0 100644 --- a/src/views/Settings/SnmpAlerts/ModalAddDestination.vue +++ b/src/views/Settings/SnmpAlerts/ModalAddDestination.vue @@ -15,17 +15,17 @@ <b-form-input id="ip-Address" v-model="form.ipAddress" - :state="getValidationState($v.form.ipAddress)" + :state="getValidationState(v$.form.ipAddress)" data-test-id="snmpAlerts-input-ipAddress" type="text" - @blur="$v.form.ipAddress.$touch()" + @blur="v$.form.ipAddress.$touch()" /> <b-form-invalid-feedback role="alert"> - <template v-if="!$v.form.ipAddress.required"> + <template v-if="!v$.form.ipAddress.required"> {{ $t('global.form.fieldRequired') }} </template> - <template v-if="!$v.form.ipAddress.ipAddress"> + <template v-if="!v$.form.ipAddress.ipAddress"> {{ $t('global.form.invalidFormat') }} </template> </b-form-invalid-feedback> @@ -43,13 +43,13 @@ id="port" v-model="form.port" type="text" - :state="getValidationState($v.form.port)" + :state="getValidationState(v$.form.port)" data-test-id="snmpAlerts-input-port" - @blur="$v.form.port.$touch()" + @blur="v$.form.port.$touch()" /> <b-form-invalid-feedback role="alert"> <template - v-if="!$v.form.port.minLength || !$v.form.port.maxLength" + v-if="!v$.form.port.minLength || !v$.form.port.maxLength" > {{ $t('global.form.valueMustBeBetween', { @@ -85,6 +85,7 @@ import { required, ipAddress, minValue, maxValue } from '@vuelidate/validators'; import VuelidateMixin from '@/components/Mixins/VuelidateMixin.js'; import { useVuelidate } from '@vuelidate/core'; +import { useI18n } from 'vue-i18n'; export default { mixins: [VuelidateMixin], @@ -95,6 +96,7 @@ export default { }, data() { return { + $t: useI18n().t, form: { ipaddress: null, port: null, @@ -117,8 +119,8 @@ export default { }, methods: { handleSubmit() { - this.$v.$touch(); - if (this.$v.$invalid) return; + this.v$.$touch(); + if (this.v$.$invalid) return; this.$emit('ok', { ipAddress: this.form.ipAddress, port: this.form.port, @@ -133,7 +135,7 @@ export default { resetForm() { this.form.ipAddress = ''; this.form.port = ''; - this.$v.$reset(); + this.v$.$reset(); this.$emit('hidden'); }, onOk(bvModalEvt) { diff --git a/src/views/Settings/SnmpAlerts/SnmpAlerts.vue b/src/views/Settings/SnmpAlerts/SnmpAlerts.vue index dba181f2..d18ea753 100644 --- a/src/views/Settings/SnmpAlerts/SnmpAlerts.vue +++ b/src/views/Settings/SnmpAlerts/SnmpAlerts.vue @@ -90,6 +90,9 @@ import BVTableSelectableMixin, { tableHeaderCheckboxModel, tableHeaderCheckboxIndeterminate, } from '@/components/Mixins/BVTableSelectableMixin'; +import { useI18n } from 'vue-i18n'; +import i18n from '@/i18n'; + export default { name: 'SnmpAlerts', components: { @@ -107,17 +110,18 @@ export default { }, data() { return { + $t: useI18n().t, fields: [ { key: 'checkbox', }, { key: 'IP', - label: this.$t('pageSnmpAlerts.table.ipaddress'), + label: i18n.global.t('pageSnmpAlerts.table.ipaddress'), }, { key: 'Port', - label: this.$t('pageSnmpAlerts.table.port'), + label: i18n.global.t('pageSnmpAlerts.table.port'), }, { key: 'actions', @@ -128,7 +132,7 @@ export default { tableToolbarActions: [ { value: 'delete', - label: this.$t('global.action.delete'), + label: i18n.global.t('global.action.delete'), }, ], selectedRows: selectedRows, @@ -164,7 +168,7 @@ export default { { value: 'delete', enabled: true, - title: this.$tc('pageSnmpAlerts.deleteDestination'), + title: i18n.global.t('pageSnmpAlerts.deleteDestination'), }, ], ...subscriptions, @@ -202,13 +206,15 @@ export default { initModalDeleteDestination(destination) { this.$bvModal .msgBoxConfirm( - this.$t('pageSnmpAlerts.modal.deleteConfirmMessage', { + i18n.global.t('pageSnmpAlerts.modal.deleteConfirmMessage', { destination: destination.id, }), { - title: this.$tc('pageSnmpAlerts.modal.deleteSnmpDestinationTitle'), - okTitle: this.$tc('pageSnmpAlerts.deleteDestination'), - cancelTitle: this.$t('global.action.cancel'), + title: i18n.global.t( + 'pageSnmpAlerts.modal.deleteSnmpDestinationTitle', + ), + okTitle: i18n.global.t('pageSnmpAlerts.deleteDestination'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) @@ -230,20 +236,20 @@ export default { if (action === 'delete') { this.$bvModal .msgBoxConfirm( - this.$tc( + i18n.global.t( 'pageSnmpAlerts.modal.batchDeleteConfirmMessage', this.selectedRows.length, ), { - title: this.$tc( + title: i18n.global.t( 'pageSnmpAlerts.modal.deleteSnmpDestinationTitle', this.selectedRows.length, ), - okTitle: this.$tc( + okTitle: i18n.global.t( 'pageSnmpAlerts.deleteDestination', this.selectedRows.length, ), - cancelTitle: this.$t('global.action.cancel'), + cancelTitle: i18n.global.t('global.action.cancel'), autoFocusButton: 'ok', }, ) |