commit e9d53d43398c977c9cc1688158221a0db500cad5 Author: abdalmalik1996 Date: Tue Jul 9 12:47:31 2024 +0300 init diff --git a/.browserslistrc b/.browserslistrc new file mode 100644 index 0000000..dc3bc09 --- /dev/null +++ b/.browserslistrc @@ -0,0 +1,4 @@ +> 1% +last 2 versions +not dead +not ie 11 diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..7053c49 --- /dev/null +++ b/.editorconfig @@ -0,0 +1,5 @@ +[*.{js,jsx,ts,tsx,vue}] +indent_style = space +indent_size = 2 +trim_trailing_whitespace = true +insert_final_newline = true diff --git a/.env b/.env new file mode 100644 index 0000000..116f196 --- /dev/null +++ b/.env @@ -0,0 +1 @@ +VITE_APP_API_BASE_URL= "" diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 0000000..3fe71ff --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,13 @@ +module.exports = { + root: true, + env: { + node: true, + }, + extends: [ + 'plugin:vue/vue3-essential', + 'eslint:recommended', + ], + rules : [ + 'vue/multi-word-component-names' = off + ] +} diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..11f5d71 --- /dev/null +++ b/.gitignore @@ -0,0 +1,22 @@ +.DS_Store +node_modules +/dist + +# local env files +.env.local +.env.*.local + +# Log files +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* + +# Editor directories and files +.idea +.vscode +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? diff --git a/README.md b/README.md new file mode 100644 index 0000000..6d33a8a --- /dev/null +++ b/README.md @@ -0,0 +1,69 @@ +# essentials + +## Project setup + +``` +# yarn +yarn + +# npm +npm install + +# pnpm +pnpm install + +# bun +bun install +``` + +### Compiles and hot-reloads for development + +``` +# yarn +yarn dev + +# npm +npm run dev + +# pnpm +pnpm dev + +# bun +bun run dev +``` + +### Compiles and minifies for production + +``` +# yarn +yarn build + +# npm +npm run build + +# pnpm +pnpm build + +# bun +bun run build +``` + +### Lints and fixes files + +``` +# yarn +yarn lint + +# npm +npm run lint + +# pnpm +pnpm lint + +# bun +bun run lint +``` + +### Customize configuration + +See [Configuration Reference](https://vitejs.dev/config/). diff --git a/index.html b/index.html new file mode 100644 index 0000000..ea4547c --- /dev/null +++ b/index.html @@ -0,0 +1,14 @@ + + + + + + + MNS + + + +
+ + + diff --git a/jsconfig.json b/jsconfig.json new file mode 100644 index 0000000..4aafc5f --- /dev/null +++ b/jsconfig.json @@ -0,0 +1,19 @@ +{ + "compilerOptions": { + "target": "es5", + "module": "esnext", + "baseUrl": "./", + "moduleResolution": "node", + "paths": { + "@/*": [ + "src/*" + ] + }, + "lib": [ + "esnext", + "dom", + "dom.iterable", + "scripthost" + ] + } +} diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..3ecd90f --- /dev/null +++ b/package-lock.json @@ -0,0 +1,2710 @@ +{ + "name": "base", + "version": "0.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "base", + "version": "0.0.0", + "dependencies": { + "@mdi/font": "7.0.96", + "animate.css": "^4.1.1", + "axios": "^1.6.8", + "core-js": "^3.29.0", + "pinia": "^2.0.0", + "roboto-fontface": "*", + "swiper": "^11.1.3", + "vue": "^3.2.0", + "vue-i18n": "^9.13.1", + "vue-router": "^4.0.0", + "vue3-lottie": "^3.3.0", + "vuetify": "^3.0.0" + }, + "devDependencies": { + "@vitejs/plugin-vue": "^4.0.0", + "eslint": "^8.37.0", + "eslint-plugin-vue": "^9.3.0", + "sass": "^1.60.0", + "unplugin-fonts": "^1.0.3", + "vite": "^4.2.0", + "vite-plugin-vuetify": "^1.0.0" + } + }, + "node_modules/@babel/parser": { + "version": "7.24.5", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.5.tgz", + "integrity": "sha512-EOv5IK8arwh3LI47dz1b0tKUb/1uhHAnHJOrjgtQMIpu1uXd9mlFrJg9IUgGUgZ41Ch0K8REPTYpO7B76b4vJg==", + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@esbuild/android-arm": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.18.20.tgz", + "integrity": "sha512-fyi7TDI/ijKKNZTUJAQqiG5T7YjJXgnzkURqmGj13C6dCqckZBLdl4h7bkhHt/t0WP+zO9/zwroDvANaOqO5Sw==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.18.20.tgz", + "integrity": "sha512-Nz4rJcchGDtENV0eMKUNa6L12zz2zBDXuhj/Vjh18zGqB44Bi7MBMSXjgunJgjRhCmKOjnPuZp4Mb6OKqtMHLQ==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.18.20.tgz", + "integrity": "sha512-8GDdlePJA8D6zlZYJV/jnrRAi6rOiNaCC/JclcXpB+KIuvfBN4owLtgzY2bsxnx666XjJx2kDPUmnTtR8qKQUg==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-arm64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.18.20.tgz", + "integrity": "sha512-bxRHW5kHU38zS2lPTPOyuyTm+S+eobPUnTNkdJEfAddYgEcll4xkT8DB9d2008DtTbl7uJag2HuE5NZAZgnNEA==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.18.20.tgz", + "integrity": "sha512-pc5gxlMDxzm513qPGbCbDukOdsGtKhfxD1zJKXjCCcU7ju50O7MeAZ8c4krSJcOIJGFR+qx21yMMVYwiQvyTyQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-arm64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.20.tgz", + "integrity": "sha512-yqDQHy4QHevpMAaxhhIwYPMv1NECwOvIpGCZkECn8w2WFHXjEwrBn3CeNIYsibZ/iZEUemj++M26W3cNR5h+Tw==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.18.20.tgz", + "integrity": "sha512-tgWRPPuQsd3RmBZwarGVHZQvtzfEBOreNuxEMKFcd5DaDn2PbBxfwLcj4+aenoh7ctXcbXmOQIn8HI6mCSw5MQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.18.20.tgz", + "integrity": "sha512-/5bHkMWnq1EgKr1V+Ybz3s1hWXok7mDFUMQ4cG10AfW3wL02PSZi5kFpYKrptDsgb2WAJIvRcDm+qIvXf/apvg==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.18.20.tgz", + "integrity": "sha512-2YbscF+UL7SQAVIpnWvYwM+3LskyDmPhe31pE7/aoTMFKKzIc9lLbyGUpmmb8a8AixOL61sQ/mFh3jEjHYFvdA==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ia32": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.18.20.tgz", + "integrity": "sha512-P4etWwq6IsReT0E1KHU40bOnzMHoH73aXp96Fs8TIT6z9Hu8G6+0SHSw9i2isWrD2nbx2qo5yUqACgdfVGx7TA==", + "cpu": [ + "ia32" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-loong64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.18.20.tgz", + "integrity": "sha512-nXW8nqBTrOpDLPgPY9uV+/1DjxoQ7DoB2N8eocyq8I9XuqJ7BiAMDMf9n1xZM9TgW0J8zrquIb/A7s3BJv7rjg==", + "cpu": [ + "loong64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-mips64el": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.18.20.tgz", + "integrity": "sha512-d5NeaXZcHp8PzYy5VnXV3VSd2D328Zb+9dEq5HE6bw6+N86JVPExrA6O68OPwobntbNJ0pzCpUFZTo3w0GyetQ==", + "cpu": [ + "mips64el" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ppc64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.18.20.tgz", + "integrity": "sha512-WHPyeScRNcmANnLQkq6AfyXRFr5D6N2sKgkFo2FqguP44Nw2eyDlbTdZwd9GYk98DZG9QItIiTlFLHJHjxP3FA==", + "cpu": [ + "ppc64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-riscv64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.18.20.tgz", + "integrity": "sha512-WSxo6h5ecI5XH34KC7w5veNnKkju3zBRLEQNY7mv5mtBmrP/MjNBCAlsM2u5hDBlS3NGcTQpoBvRzqBcRtpq1A==", + "cpu": [ + "riscv64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-s390x": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.18.20.tgz", + "integrity": "sha512-+8231GMs3mAEth6Ja1iK0a1sQ3ohfcpzpRLH8uuc5/KVDFneH6jtAJLFGafpzpMRO6DzJ6AvXKze9LfFMrIHVQ==", + "cpu": [ + "s390x" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.18.20.tgz", + "integrity": "sha512-UYqiqemphJcNsFEskc73jQ7B9jgwjWrSayxawS6UVFZGWrAAtkzjxSqnoclCXxWtfwLdzU+vTpcNYhpn43uP1w==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/netbsd-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.18.20.tgz", + "integrity": "sha512-iO1c++VP6xUBUmltHZoMtCUdPlnPGdBom6IrO4gyKPFFVBKioIImVooR5I83nTew5UOYrk3gIJhbZh8X44y06A==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/openbsd-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.18.20.tgz", + "integrity": "sha512-e5e4YSsuQfX4cxcygw/UCPIEP6wbIL+se3sxPdCiMbFLBWu0eiZOJ7WoD+ptCLrmjZBK1Wk7I6D/I3NglUGOxg==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/sunos-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.18.20.tgz", + "integrity": "sha512-kDbFRFp0YpTQVVrqUd5FTYmWo45zGaXe0X8E1G/LKFC0v8x0vWrhOWSLITcCn63lmZIxfOMXtCfti/RxN/0wnQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-arm64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.18.20.tgz", + "integrity": "sha512-ddYFR6ItYgoaq4v4JmQQaAI5s7npztfV4Ag6NrhiaW0RrnOXqBkgwZLofVTlq1daVTQNhtI5oieTvkRPfZrePg==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-ia32": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.18.20.tgz", + "integrity": "sha512-Wv7QBi3ID/rROT08SABTS7eV4hX26sVduqDOTe1MvGMjNd3EjOz4b7zeexIR62GTIEKrfJXKL9LFxTYgkyeu7g==", + "cpu": [ + "ia32" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-x64": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.18.20.tgz", + "integrity": "sha512-kTdfRcSiDfQca/y9QIkng02avJ+NCaQvrMejlsB3RRv5sE9rRoeBPISaZpKxHELzRxZyLvNts1P27W3wV+8geQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@eslint-community/eslint-utils": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "dev": true, + "dependencies": { + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" + } + }, + "node_modules/@eslint-community/regexpp": { + "version": "4.10.0", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", + "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", + "dev": true, + "engines": { + "node": "^12.0.0 || ^14.0.0 || >=16.0.0" + } + }, + "node_modules/@eslint/eslintrc": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", + "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", + "dev": true, + "dependencies": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.6.0", + "globals": "^13.19.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint/js": { + "version": "8.57.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", + "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + } + }, + "node_modules/@humanwhocodes/config-array": { + "version": "0.11.14", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", + "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", + "dev": true, + "dependencies": { + "@humanwhocodes/object-schema": "^2.0.2", + "debug": "^4.3.1", + "minimatch": "^3.0.5" + }, + "engines": { + "node": ">=10.10.0" + } + }, + "node_modules/@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true, + "engines": { + "node": ">=12.22" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@humanwhocodes/object-schema": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", + "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", + "dev": true + }, + "node_modules/@intlify/core-base": { + "version": "9.13.1", + "resolved": "https://registry.npmjs.org/@intlify/core-base/-/core-base-9.13.1.tgz", + "integrity": "sha512-+bcQRkJO9pcX8d0gel9ZNfrzU22sZFSA0WVhfXrf5jdJOS24a+Bp8pozuS9sBI9Hk/tGz83pgKfmqcn/Ci7/8w==", + "dependencies": { + "@intlify/message-compiler": "9.13.1", + "@intlify/shared": "9.13.1" + }, + "engines": { + "node": ">= 16" + }, + "funding": { + "url": "https://github.com/sponsors/kazupon" + } + }, + "node_modules/@intlify/message-compiler": { + "version": "9.13.1", + "resolved": "https://registry.npmjs.org/@intlify/message-compiler/-/message-compiler-9.13.1.tgz", + "integrity": "sha512-SKsVa4ajYGBVm7sHMXd5qX70O2XXjm55zdZB3VeMFCvQyvLew/dLvq3MqnaIsTMF1VkkOb9Ttr6tHcMlyPDL9w==", + "dependencies": { + "@intlify/shared": "9.13.1", + "source-map-js": "^1.0.2" + }, + "engines": { + "node": ">= 16" + }, + "funding": { + "url": "https://github.com/sponsors/kazupon" + } + }, + "node_modules/@intlify/shared": { + "version": "9.13.1", + "resolved": "https://registry.npmjs.org/@intlify/shared/-/shared-9.13.1.tgz", + "integrity": "sha512-u3b6BKGhE6j/JeRU6C/RL2FgyJfy6LakbtfeVF8fJXURpZZTzfh3e05J0bu0XPw447Q6/WUp3C4ajv4TMS4YsQ==", + "engines": { + "node": ">= 16" + }, + "funding": { + "url": "https://github.com/sponsors/kazupon" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.4.15", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", + "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" + }, + "node_modules/@mdi/font": { + "version": "7.0.96", + "resolved": "https://registry.npmjs.org/@mdi/font/-/font-7.0.96.tgz", + "integrity": "sha512-rzlxTfR64hqY8yiBzDjmANfcd8rv+T5C0Yedv/TWk2QyAQYdc66e0kaN1ipmnYU3RukHRTRcBARHzzm+tIhL7w==" + }, + "node_modules/@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "dependencies": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "dependencies": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@ungap/structured-clone": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", + "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", + "dev": true + }, + "node_modules/@vitejs/plugin-vue": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/@vitejs/plugin-vue/-/plugin-vue-4.6.2.tgz", + "integrity": "sha512-kqf7SGFoG+80aZG6Pf+gsZIVvGSCKE98JbiWqcCV9cThtg91Jav0yvYFC9Zb+jKetNGF6ZKeoaxgZfND21fWKw==", + "dev": true, + "engines": { + "node": "^14.18.0 || >=16.0.0" + }, + "peerDependencies": { + "vite": "^4.0.0 || ^5.0.0", + "vue": "^3.2.25" + } + }, + "node_modules/@vue/compiler-core": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.4.27.tgz", + "integrity": "sha512-E+RyqY24KnyDXsCuQrI+mlcdW3ALND6U7Gqa/+bVwbcpcR3BRRIckFoz7Qyd4TTlnugtwuI7YgjbvsLmxb+yvg==", + "dependencies": { + "@babel/parser": "^7.24.4", + "@vue/shared": "3.4.27", + "entities": "^4.5.0", + "estree-walker": "^2.0.2", + "source-map-js": "^1.2.0" + } + }, + "node_modules/@vue/compiler-dom": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.4.27.tgz", + "integrity": "sha512-kUTvochG/oVgE1w5ViSr3KUBh9X7CWirebA3bezTbB5ZKBQZwR2Mwj9uoSKRMFcz4gSMzzLXBPD6KpCLb9nvWw==", + "dependencies": { + "@vue/compiler-core": "3.4.27", + "@vue/shared": "3.4.27" + } + }, + "node_modules/@vue/compiler-sfc": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-3.4.27.tgz", + "integrity": "sha512-nDwntUEADssW8e0rrmE0+OrONwmRlegDA1pD6QhVeXxjIytV03yDqTey9SBDiALsvAd5U4ZrEKbMyVXhX6mCGA==", + "dependencies": { + "@babel/parser": "^7.24.4", + "@vue/compiler-core": "3.4.27", + "@vue/compiler-dom": "3.4.27", + "@vue/compiler-ssr": "3.4.27", + "@vue/shared": "3.4.27", + "estree-walker": "^2.0.2", + "magic-string": "^0.30.10", + "postcss": "^8.4.38", + "source-map-js": "^1.2.0" + } + }, + "node_modules/@vue/compiler-ssr": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.4.27.tgz", + "integrity": "sha512-CVRzSJIltzMG5FcidsW0jKNQnNRYC8bT21VegyMMtHmhW3UOI7knmUehzswXLrExDLE6lQCZdrhD4ogI7c+vuw==", + "dependencies": { + "@vue/compiler-dom": "3.4.27", + "@vue/shared": "3.4.27" + } + }, + "node_modules/@vue/devtools-api": { + "version": "6.6.1", + "resolved": "https://registry.npmjs.org/@vue/devtools-api/-/devtools-api-6.6.1.tgz", + "integrity": "sha512-LgPscpE3Vs0x96PzSSB4IGVSZXZBZHpfxs+ZA1d+VEPwHdOXowy/Y2CsvCAIFrf+ssVU1pD1jidj505EpUnfbA==" + }, + "node_modules/@vue/reactivity": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/reactivity/-/reactivity-3.4.27.tgz", + "integrity": "sha512-kK0g4NknW6JX2yySLpsm2jlunZJl2/RJGZ0H9ddHdfBVHcNzxmQ0sS0b09ipmBoQpY8JM2KmUw+a6sO8Zo+zIA==", + "dependencies": { + "@vue/shared": "3.4.27" + } + }, + "node_modules/@vue/runtime-core": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/runtime-core/-/runtime-core-3.4.27.tgz", + "integrity": "sha512-7aYA9GEbOOdviqVvcuweTLe5Za4qBZkUY7SvET6vE8kyypxVgaT1ixHLg4urtOlrApdgcdgHoTZCUuTGap/5WA==", + "dependencies": { + "@vue/reactivity": "3.4.27", + "@vue/shared": "3.4.27" + } + }, + "node_modules/@vue/runtime-dom": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/runtime-dom/-/runtime-dom-3.4.27.tgz", + "integrity": "sha512-ScOmP70/3NPM+TW9hvVAz6VWWtZJqkbdf7w6ySsws+EsqtHvkhxaWLecrTorFxsawelM5Ys9FnDEMt6BPBDS0Q==", + "dependencies": { + "@vue/runtime-core": "3.4.27", + "@vue/shared": "3.4.27", + "csstype": "^3.1.3" + } + }, + "node_modules/@vue/server-renderer": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/server-renderer/-/server-renderer-3.4.27.tgz", + "integrity": "sha512-dlAMEuvmeA3rJsOMJ2J1kXU7o7pOxgsNHVr9K8hB3ImIkSuBrIdy0vF66h8gf8Tuinf1TK3mPAz2+2sqyf3KzA==", + "dependencies": { + "@vue/compiler-ssr": "3.4.27", + "@vue/shared": "3.4.27" + }, + "peerDependencies": { + "vue": "3.4.27" + } + }, + "node_modules/@vue/shared": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.4.27.tgz", + "integrity": "sha512-DL3NmY2OFlqmYYrzp39yi3LDkKxa5vZVwxWdQ3rG0ekuWscHraeIbnI8t+aZK7qhYqEqWKTUdijadunb9pnrgA==" + }, + "node_modules/@vuetify/loader-shared": { + "version": "1.7.1", + "resolved": "https://registry.npmjs.org/@vuetify/loader-shared/-/loader-shared-1.7.1.tgz", + "integrity": "sha512-kLUvuAed6RCvkeeTNJzuy14pqnkur8lTuner7v7pNE/kVhPR97TuyXwBSBMR1cJeiLiOfu6SF5XlCYbXByEx1g==", + "devOptional": true, + "dependencies": { + "find-cache-dir": "^3.3.2", + "upath": "^2.0.1" + }, + "peerDependencies": { + "vue": "^3.0.0", + "vuetify": "^3.0.0-beta.4" + } + }, + "node_modules/acorn": { + "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" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true, + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/animate.css": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/animate.css/-/animate.css-4.1.1.tgz", + "integrity": "sha512-+mRmCTv6SbCmtYJCN4faJMNFVNN5EuCTTprDTAo7YzIGji2KADmakjVA3+8mVDkZ2Bf09vayB35lSQIex2+QaQ==" + }, + "node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "devOptional": true, + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" + }, + "node_modules/axios": { + "version": "1.6.8", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.8.tgz", + "integrity": "sha512-v/ZHtJDU39mDpyBoFVkETcd/uNdxrWRrg3bKpOKzXFA6Bvqopts6ALSMU3y6ijYxbw2B+wPrIv46egTzJXCLGQ==", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "node_modules/binary-extensions": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", + "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", + "devOptional": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/boolbase": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", + "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", + "dev": true + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "devOptional": true, + "dependencies": { + "fill-range": "^7.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/chokidar": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", + "devOptional": true, + "dependencies": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + }, + "engines": { + "node": ">= 8.10.0" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/chokidar/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "devOptional": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", + "devOptional": true + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "node_modules/core-js": { + "version": "3.37.1", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.37.1.tgz", + "integrity": "sha512-Xn6qmxrQZyB0FFY8E3bgRXei3lWDJHhvI+u0q9TKIYM49G8pAr0FgnnrFRAmsbptZL1yxRADVXn+x5AGsbBfyw==", + "hasInstallScript": true, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/core-js" + } + }, + "node_modules/cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", + "dev": true, + "bin": { + "cssesc": "bin/cssesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/csstype": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==" + }, + "node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "devOptional": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/entities": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", + "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", + "engines": { + "node": ">=0.12" + }, + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, + "node_modules/esbuild": { + "version": "0.18.20", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.18.20.tgz", + "integrity": "sha512-ceqxoedUrcayh7Y7ZX6NdbbDzGROiyVBgC4PriJThBKSVPWnnFHZAkfI1lJT8QFkOwH4qOS2SJkS4wvpGl8BpA==", + "devOptional": true, + "hasInstallScript": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + }, + "optionalDependencies": { + "@esbuild/android-arm": "0.18.20", + "@esbuild/android-arm64": "0.18.20", + "@esbuild/android-x64": "0.18.20", + "@esbuild/darwin-arm64": "0.18.20", + "@esbuild/darwin-x64": "0.18.20", + "@esbuild/freebsd-arm64": "0.18.20", + "@esbuild/freebsd-x64": "0.18.20", + "@esbuild/linux-arm": "0.18.20", + "@esbuild/linux-arm64": "0.18.20", + "@esbuild/linux-ia32": "0.18.20", + "@esbuild/linux-loong64": "0.18.20", + "@esbuild/linux-mips64el": "0.18.20", + "@esbuild/linux-ppc64": "0.18.20", + "@esbuild/linux-riscv64": "0.18.20", + "@esbuild/linux-s390x": "0.18.20", + "@esbuild/linux-x64": "0.18.20", + "@esbuild/netbsd-x64": "0.18.20", + "@esbuild/openbsd-x64": "0.18.20", + "@esbuild/sunos-x64": "0.18.20", + "@esbuild/win32-arm64": "0.18.20", + "@esbuild/win32-ia32": "0.18.20", + "@esbuild/win32-x64": "0.18.20" + } + }, + "node_modules/escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint": { + "version": "8.57.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", + "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", + "dev": true, + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.4", + "@eslint/js": "8.57.0", + "@humanwhocodes/config-array": "^0.11.14", + "@humanwhocodes/module-importer": "^1.0.1", + "@nodelib/fs.walk": "^1.2.8", + "@ungap/structured-clone": "^1.2.0", + "ajv": "^6.12.4", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "doctrine": "^3.0.0", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^7.2.2", + "eslint-visitor-keys": "^3.4.3", + "espree": "^9.6.1", + "esquery": "^1.4.2", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "globals": "^13.19.0", + "graphemer": "^1.4.0", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "is-path-inside": "^3.0.3", + "js-yaml": "^4.1.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.3", + "strip-ansi": "^6.0.1", + "text-table": "^0.2.0" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-plugin-vue": { + "version": "9.26.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-vue/-/eslint-plugin-vue-9.26.0.tgz", + "integrity": "sha512-eTvlxXgd4ijE1cdur850G6KalZqk65k1JKoOI2d1kT3hr8sPD07j1q98FRFdNnpxBELGPWxZmInxeHGF/GxtqQ==", + "dev": true, + "dependencies": { + "@eslint-community/eslint-utils": "^4.4.0", + "globals": "^13.24.0", + "natural-compare": "^1.4.0", + "nth-check": "^2.1.1", + "postcss-selector-parser": "^6.0.15", + "semver": "^7.6.0", + "vue-eslint-parser": "^9.4.2", + "xml-name-validator": "^4.0.0" + }, + "engines": { + "node": "^14.17.0 || >=16.0.0" + }, + "peerDependencies": { + "eslint": "^6.2.0 || ^7.0.0 || ^8.0.0 || ^9.0.0" + } + }, + "node_modules/eslint-scope": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", + "dev": true, + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/espree": { + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", + "dev": true, + "dependencies": { + "acorn": "^8.9.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/esquery": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", + "dev": true, + "dependencies": { + "estraverse": "^5.1.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "dependencies": { + "estraverse": "^5.2.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estree-walker": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", + "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==" + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" + }, + "node_modules/fast-glob": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", + "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", + "dev": true, + "dependencies": { + "@nodelib/fs.stat": "^2.0.2", + "@nodelib/fs.walk": "^1.2.3", + "glob-parent": "^5.1.2", + "merge2": "^1.3.0", + "micromatch": "^4.0.4" + }, + "engines": { + "node": ">=8.6.0" + } + }, + "node_modules/fast-glob/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "node_modules/fastq": { + "version": "1.17.1", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", + "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", + "dev": true, + "dependencies": { + "reusify": "^1.0.4" + } + }, + "node_modules/file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "dependencies": { + "flat-cache": "^3.0.4" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "devOptional": true, + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/find-cache-dir": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz", + "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==", + "devOptional": true, + "dependencies": { + "commondir": "^1.0.1", + "make-dir": "^3.0.2", + "pkg-dir": "^4.1.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/avajs/find-cache-dir?sponsor=1" + } + }, + "node_modules/find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "dependencies": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/flat-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", + "dev": true, + "dependencies": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true + }, + "node_modules/follow-redirects": { + "version": "1.15.6", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz", + "integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/form-data": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", + "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true + }, + "node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "dependencies": { + "type-fest": "^0.20.2" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", + "dev": true + }, + "node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/ignore": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", + "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/immutable": { + "version": "4.3.6", + "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.3.6.tgz", + "integrity": "sha512-Ju0+lEMyzMVZarkTn/gqRpdqd5dOPaz1mCZ0SH3JV6iFw81PldE/PEB1hWVEA288HPt4WXW8O7AWxB10M+03QQ==", + "devOptional": true + }, + "node_modules/import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "dependencies": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true, + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "dev": true, + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "devOptional": true, + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "devOptional": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "devOptional": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "devOptional": true, + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true + }, + "node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "node_modules/json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, + "node_modules/keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "dependencies": { + "json-buffer": "3.0.1" + } + }, + "node_modules/klona": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/klona/-/klona-2.0.6.tgz", + "integrity": "sha512-dhG34DXATL5hSxJbIexCft8FChFXtmskoZYnoPWjXQuebWYCNkVeV3KkGegCK9CP1oswI/vQibS2GY7Em/sJJA==", + "engines": { + "node": ">= 8" + } + }, + "node_modules/levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, + "node_modules/lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "node_modules/lottie-web": { + "version": "5.12.2", + "resolved": "https://registry.npmjs.org/lottie-web/-/lottie-web-5.12.2.tgz", + "integrity": "sha512-uvhvYPC8kGPjXT3MyKMrL3JitEAmDMp30lVkuq/590Mw9ok6pWcFCwXJveo0t5uqYw1UREQHofD+jVpdjBv8wg==" + }, + "node_modules/magic-string": { + "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" + } + }, + "node_modules/make-dir": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", + "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", + "devOptional": true, + "dependencies": { + "semver": "^6.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/make-dir/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "devOptional": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/micromatch": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", + "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", + "dev": true, + "dependencies": { + "braces": "^3.0.2", + "picomatch": "^2.3.1" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "devOptional": true + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "devOptional": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/nth-check": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz", + "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==", + "dev": true, + "dependencies": { + "boolbase": "^1.0.0" + }, + "funding": { + "url": "https://github.com/fb55/nth-check?sponsor=1" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/optionator": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", + "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", + "dev": true, + "dependencies": { + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.5" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "dependencies": { + "yocto-queue": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "dependencies": { + "p-limit": "^3.0.2" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "devOptional": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "devOptional": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/picocolors": { + "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", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "devOptional": true, + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/pinia": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/pinia/-/pinia-2.1.7.tgz", + "integrity": "sha512-+C2AHFtcFqjPih0zpYuvof37SFxMQ7OEG2zV9jRI12i9BOy3YQVAHwdKtyyc8pDcDyIc33WCIsZaCFWU7WWxGQ==", + "dependencies": { + "@vue/devtools-api": "^6.5.0", + "vue-demi": ">=0.14.5" + }, + "funding": { + "url": "https://github.com/sponsors/posva" + }, + "peerDependencies": { + "@vue/composition-api": "^1.4.0", + "typescript": ">=4.4.4", + "vue": "^2.6.14 || ^3.3.0" + }, + "peerDependenciesMeta": { + "@vue/composition-api": { + "optional": true + }, + "typescript": { + "optional": true + } + } + }, + "node_modules/pinia/node_modules/vue-demi": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.14.7.tgz", + "integrity": "sha512-EOG8KXDQNwkJILkx/gPcoL/7vH+hORoBaKgGe+6W7VFMvCYJfmF2dGbvgDroVnI8LU7/kTu8mbjRZGBU1z9NTA==", + "hasInstallScript": true, + "bin": { + "vue-demi-fix": "bin/vue-demi-fix.js", + "vue-demi-switch": "bin/vue-demi-switch.js" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/antfu" + }, + "peerDependencies": { + "@vue/composition-api": "^1.0.0-rc.1", + "vue": "^3.0.0-0 || ^2.6.0" + }, + "peerDependenciesMeta": { + "@vue/composition-api": { + "optional": true + } + } + }, + "node_modules/pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", + "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "devOptional": true, + "dependencies": { + "find-up": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pkg-dir/node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "devOptional": true, + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pkg-dir/node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "devOptional": true, + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pkg-dir/node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "devOptional": true, + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/pkg-dir/node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "devOptional": true, + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "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" + } + }, + "node_modules/postcss-selector-parser": { + "version": "6.0.16", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.16.tgz", + "integrity": "sha512-A0RVJrX+IUkVZbW3ClroRWurercFhieevHB38sr2+l9eUClMqome3LmEmnhlNy+5Mr2EYN6B2Kaw9wYdd+VHiw==", + "dev": true, + "dependencies": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" + }, + "node_modules/punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "devOptional": true, + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "dev": true, + "engines": { + "iojs": ">=1.0.0", + "node": ">=0.10.0" + } + }, + "node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/roboto-fontface": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/roboto-fontface/-/roboto-fontface-0.10.0.tgz", + "integrity": "sha512-OlwfYEgA2RdboZohpldlvJ1xngOins5d7ejqnIBWr9KaMxsnBqotpptRXTyfNRLnFpqzX6sTDt+X+a+6udnU8g==" + }, + "node_modules/rollup": { + "version": "3.29.4", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.29.4.tgz", + "integrity": "sha512-oWzmBZwvYrU0iJHtDmhsm662rC15FRXmcjCk1xD771dFDx5jJ02ufAQQTn0etB2emNk4J9EZg/yWKpsn9BWGRw==", + "devOptional": true, + "bin": { + "rollup": "dist/bin/rollup" + }, + "engines": { + "node": ">=14.18.0", + "npm": ">=8.0.0" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "queue-microtask": "^1.2.2" + } + }, + "node_modules/sass": { + "version": "1.77.2", + "resolved": "https://registry.npmjs.org/sass/-/sass-1.77.2.tgz", + "integrity": "sha512-eb4GZt1C3avsX3heBNlrc7I09nyT00IUuo4eFhAbeXWU2fvA7oXI53SxODVAA+zgZCk9aunAZgO+losjR3fAwA==", + "devOptional": true, + "dependencies": { + "chokidar": ">=3.0.0 <4.0.0", + "immutable": "^4.0.0", + "source-map-js": ">=0.6.2 <2.0.0" + }, + "bin": { + "sass": "sass.js" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/semver": { + "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" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/source-map-js": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", + "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/swiper": { + "version": "11.1.3", + "resolved": "https://registry.npmjs.org/swiper/-/swiper-11.1.3.tgz", + "integrity": "sha512-80MSxonyTxrGcaWj9YgvvhD8OG0B9/9IVZP33vhIEvyWvmKjnQDBieO+29wKvMx285sAtvZyrWBdkxaw6+D3aw==", + "funding": [ + { + "type": "patreon", + "url": "https://www.patreon.com/swiperjs" + }, + { + "type": "open_collective", + "url": "http://opencollective.com/swiper" + } + ], + "engines": { + "node": ">= 4.7.0" + } + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "devOptional": true, + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/unplugin": { + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/unplugin/-/unplugin-1.10.1.tgz", + "integrity": "sha512-d6Mhq8RJeGA8UfKCu54Um4lFA0eSaRa3XxdAJg8tIdxbu1ubW0hBCZUL7yI2uGyYCRndvbK8FLHzqy2XKfeMsg==", + "dev": true, + "dependencies": { + "acorn": "^8.11.3", + "chokidar": "^3.6.0", + "webpack-sources": "^3.2.3", + "webpack-virtual-modules": "^0.6.1" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/unplugin-fonts": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unplugin-fonts/-/unplugin-fonts-1.1.1.tgz", + "integrity": "sha512-/Aw/rL9D2aslGGM0vi+2R2aG508RSwawLnnBuo+JDSqYc4cHJO1R1phllhN6GysEhBp/6a4B6+vSFPVapWyAAw==", + "dev": true, + "dependencies": { + "fast-glob": "^3.2.12", + "unplugin": "^1.3.1" + }, + "peerDependencies": { + "@nuxt/kit": "^3.0.0", + "vite": "^2.0.0 || ^3.0.0 || ^4.0.0 || ^5.0.0" + }, + "peerDependenciesMeta": { + "@nuxt/kit": { + "optional": true + } + } + }, + "node_modules/upath": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/upath/-/upath-2.0.1.tgz", + "integrity": "sha512-1uEe95xksV1O0CYKXo8vQvN1JEbtJp7lb7C5U9HMsIp6IVwntkH/oNUzyVNQSd4S1sYk2FpSSW44FqMc8qee5w==", + "devOptional": true, + "engines": { + "node": ">=4", + "yarn": "*" + } + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", + "dev": true + }, + "node_modules/vite": { + "version": "4.5.3", + "resolved": "https://registry.npmjs.org/vite/-/vite-4.5.3.tgz", + "integrity": "sha512-kQL23kMeX92v3ph7IauVkXkikdDRsYMGTVl5KY2E9OY4ONLvkHf04MDTbnfo6NKxZiDLWzVpP5oTa8hQD8U3dg==", + "devOptional": true, + "dependencies": { + "esbuild": "^0.18.10", + "postcss": "^8.4.27", + "rollup": "^3.27.1" + }, + "bin": { + "vite": "bin/vite.js" + }, + "engines": { + "node": "^14.18.0 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/vitejs/vite?sponsor=1" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + }, + "peerDependencies": { + "@types/node": ">= 14", + "less": "*", + "lightningcss": "^1.21.0", + "sass": "*", + "stylus": "*", + "sugarss": "*", + "terser": "^5.4.0" + }, + "peerDependenciesMeta": { + "@types/node": { + "optional": true + }, + "less": { + "optional": true + }, + "lightningcss": { + "optional": true + }, + "sass": { + "optional": true + }, + "stylus": { + "optional": true + }, + "sugarss": { + "optional": true + }, + "terser": { + "optional": true + } + } + }, + "node_modules/vite-plugin-vuetify": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/vite-plugin-vuetify/-/vite-plugin-vuetify-1.0.2.tgz", + "integrity": "sha512-MubIcKD33O8wtgQXlbEXE7ccTEpHZ8nPpe77y9Wy3my2MWw/PgehP9VqTp92BLqr0R1dSL970Lynvisx3UxBFw==", + "devOptional": true, + "dependencies": { + "@vuetify/loader-shared": "^1.7.1", + "debug": "^4.3.3", + "upath": "^2.0.1" + }, + "engines": { + "node": ">=12" + }, + "peerDependencies": { + "vite": "^2.7.0 || ^3.0.0 || ^4.0.0", + "vuetify": "^3.0.0-beta.4" + } + }, + "node_modules/vue": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/vue/-/vue-3.4.27.tgz", + "integrity": "sha512-8s/56uK6r01r1icG/aEOHqyMVxd1bkYcSe9j8HcKtr/xTOFWvnzIVTehNW+5Yt89f+DLBe4A569pnZLS5HzAMA==", + "dependencies": { + "@vue/compiler-dom": "3.4.27", + "@vue/compiler-sfc": "3.4.27", + "@vue/runtime-dom": "3.4.27", + "@vue/server-renderer": "3.4.27", + "@vue/shared": "3.4.27" + }, + "peerDependencies": { + "typescript": "*" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/vue-eslint-parser": { + "version": "9.4.2", + "resolved": "https://registry.npmjs.org/vue-eslint-parser/-/vue-eslint-parser-9.4.2.tgz", + "integrity": "sha512-Ry9oiGmCAK91HrKMtCrKFWmSFWvYkpGglCeFAIqDdr9zdXmMMpJOmUJS7WWsW7fX81h6mwHmUZCQQ1E0PkSwYQ==", + "dev": true, + "dependencies": { + "debug": "^4.3.4", + "eslint-scope": "^7.1.1", + "eslint-visitor-keys": "^3.3.0", + "espree": "^9.3.1", + "esquery": "^1.4.0", + "lodash": "^4.17.21", + "semver": "^7.3.6" + }, + "engines": { + "node": "^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/mysticatea" + }, + "peerDependencies": { + "eslint": ">=6.0.0" + } + }, + "node_modules/vue-i18n": { + "version": "9.13.1", + "resolved": "https://registry.npmjs.org/vue-i18n/-/vue-i18n-9.13.1.tgz", + "integrity": "sha512-mh0GIxx0wPtPlcB1q4k277y0iKgo25xmDPWioVVYanjPufDBpvu5ySTjP5wOrSvlYQ2m1xI+CFhGdauv/61uQg==", + "dependencies": { + "@intlify/core-base": "9.13.1", + "@intlify/shared": "9.13.1", + "@vue/devtools-api": "^6.5.0" + }, + "engines": { + "node": ">= 16" + }, + "funding": { + "url": "https://github.com/sponsors/kazupon" + }, + "peerDependencies": { + "vue": "^3.0.0" + } + }, + "node_modules/vue-router": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-4.3.2.tgz", + "integrity": "sha512-hKQJ1vDAZ5LVkKEnHhmm1f9pMiWIBNGF5AwU67PdH7TyXCj/a4hTccuUuYCAMgJK6rO/NVYtQIEN3yL8CECa7Q==", + "dependencies": { + "@vue/devtools-api": "^6.5.1" + }, + "funding": { + "url": "https://github.com/sponsors/posva" + }, + "peerDependencies": { + "vue": "^3.2.0" + } + }, + "node_modules/vue3-lottie": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/vue3-lottie/-/vue3-lottie-3.3.0.tgz", + "integrity": "sha512-Omv26YN3e78fh0QgQooeZcmPo8O2j5mJ5pacZh1mGdHH9ZTGayWlY1Yp6h+wAvfBKAvJ80JXrSgeBOKA4MRBYA==", + "dependencies": { + "fast-deep-equal": "^3.1.3", + "klona": "^2.0.6", + "lottie-web": "5.12.2" + }, + "engines": { + "node": ">=12" + }, + "peerDependencies": { + "vue": "^3.2" + } + }, + "node_modules/vuetify": { + "version": "3.6.6", + "resolved": "https://registry.npmjs.org/vuetify/-/vuetify-3.6.6.tgz", + "integrity": "sha512-7RkL0kuLsVUbc0YCwhPhVq54gSFKt5xv+SOrF01dxwJz7Ke3tAbvO616WhhQIfS78h1q/Ev952WJj5jpsdK58g==", + "engines": { + "node": "^12.20 || >=14.13" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/johnleider" + }, + "peerDependencies": { + "typescript": ">=4.7", + "vite-plugin-vuetify": ">=1.0.0", + "vue": "^3.3.0", + "vue-i18n": "^9.0.0", + "webpack-plugin-vuetify": ">=2.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + }, + "vite-plugin-vuetify": { + "optional": true + }, + "vue-i18n": { + "optional": true + }, + "webpack-plugin-vuetify": { + "optional": true + } + } + }, + "node_modules/webpack-sources": { + "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" + } + }, + "node_modules/webpack-virtual-modules": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/webpack-virtual-modules/-/webpack-virtual-modules-0.6.1.tgz", + "integrity": "sha512-poXpCylU7ExuvZK8z+On3kX+S8o/2dQ/SVYueKA0D4WEMXROXgY8Ez50/bQEUmvoSMMrWcrJqCHuhAbsiwg7Dg==", + "dev": true + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/word-wrap": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", + "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true + }, + "node_modules/xml-name-validator": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-4.0.0.tgz", + "integrity": "sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==", + "dev": true, + "engines": { + "node": ">=12" + } + }, + "node_modules/yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..557264c --- /dev/null +++ b/package.json @@ -0,0 +1,34 @@ +{ + "name": "base", + "version": "0.0.0", + "private": true, + "scripts": { + "dev": "vite", + "build": "vite build", + "preview": "vite preview", + "lint": "eslint . --fix --ignore-path .gitignore" + }, + "dependencies": { + "@mdi/font": "7.0.96", + "animate.css": "^4.1.1", + "axios": "^1.6.8", + "core-js": "^3.29.0", + "pinia": "^2.0.0", + "roboto-fontface": "*", + "swiper": "^11.1.3", + "vue": "^3.2.0", + "vue-i18n": "^9.13.1", + "vue-router": "^4.0.0", + "vue3-lottie": "^3.3.0", + "vuetify": "^3.0.0" + }, + "devDependencies": { + "@vitejs/plugin-vue": "^4.0.0", + "eslint": "^8.37.0", + "eslint-plugin-vue": "^9.3.0", + "sass": "^1.60.0", + "unplugin-fonts": "^1.0.3", + "vite": "^4.2.0", + "vite-plugin-vuetify": "^1.0.0" + } +} diff --git a/public/1.svg b/public/1.svg new file mode 100644 index 0000000..e5c4ffe --- /dev/null +++ b/public/1.svg @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/public/2.svg b/public/2.svg new file mode 100644 index 0000000..620300a --- /dev/null +++ b/public/2.svg @@ -0,0 +1,41 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/public/3.svg b/public/3.svg new file mode 100644 index 0000000..2095779 --- /dev/null +++ b/public/3.svg @@ -0,0 +1,37 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/public/4.svg b/public/4.svg new file mode 100644 index 0000000..b224cc3 --- /dev/null +++ b/public/4.svg @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/public/Home/avatar.png b/public/Home/avatar.png new file mode 100644 index 0000000..9a90629 Binary files /dev/null and b/public/Home/avatar.png differ diff --git a/public/Home/slider/1.png b/public/Home/slider/1.png new file mode 100644 index 0000000..ffe50ab Binary files /dev/null and b/public/Home/slider/1.png differ diff --git a/public/Home/slider/2.png b/public/Home/slider/2.png new file mode 100644 index 0000000..8550539 Binary files /dev/null and b/public/Home/slider/2.png differ diff --git a/public/Home/slider/3.png b/public/Home/slider/3.png new file mode 100644 index 0000000..ecec868 Binary files /dev/null and b/public/Home/slider/3.png differ diff --git a/public/Home/slider/4.png b/public/Home/slider/4.png new file mode 100644 index 0000000..9ba0ad2 Binary files /dev/null and b/public/Home/slider/4.png differ diff --git a/public/team/aTeamMember_1.jpg b/public/team/aTeamMember_1.jpg new file mode 100644 index 0000000..4f7bfb0 Binary files /dev/null and b/public/team/aTeamMember_1.jpg differ diff --git a/src/App.vue b/src/App.vue new file mode 100644 index 0000000..28179b4 --- /dev/null +++ b/src/App.vue @@ -0,0 +1,15 @@ + + + diff --git a/src/assets/about/about_1.png b/src/assets/about/about_1.png new file mode 100644 index 0000000..efbe721 Binary files /dev/null and b/src/assets/about/about_1.png differ diff --git a/src/assets/about/about_2.png b/src/assets/about/about_2.png new file mode 100644 index 0000000..a2d9329 Binary files /dev/null and b/src/assets/about/about_2.png differ diff --git a/src/assets/about/about_3.png b/src/assets/about/about_3.png new file mode 100644 index 0000000..7da9e6d Binary files /dev/null and b/src/assets/about/about_3.png differ diff --git a/src/assets/certificates.png b/src/assets/certificates.png new file mode 100644 index 0000000..e28e331 Binary files /dev/null and b/src/assets/certificates.png differ diff --git a/src/assets/decorations/decore_1.svg b/src/assets/decorations/decore_1.svg new file mode 100644 index 0000000..6c2e105 --- /dev/null +++ b/src/assets/decorations/decore_1.svg @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/assets/decorations/gear.svg b/src/assets/decorations/gear.svg new file mode 100644 index 0000000..3618fe9 --- /dev/null +++ b/src/assets/decorations/gear.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/src/assets/decorations/test_1.svg b/src/assets/decorations/test_1.svg new file mode 100644 index 0000000..2c699e9 --- /dev/null +++ b/src/assets/decorations/test_1.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/src/assets/logo.svg b/src/assets/logo.svg new file mode 100644 index 0000000..44f3903 --- /dev/null +++ b/src/assets/logo.svg @@ -0,0 +1,15 @@ + + + + + + + + + + + + + + + diff --git a/src/assets/products/end.png b/src/assets/products/end.png new file mode 100644 index 0000000..ffe50ab Binary files /dev/null and b/src/assets/products/end.png differ diff --git a/src/assets/products/lighting.png b/src/assets/products/lighting.png new file mode 100644 index 0000000..1d88f45 Binary files /dev/null and b/src/assets/products/lighting.png differ diff --git a/src/assets/products/measurement.png b/src/assets/products/measurement.png new file mode 100644 index 0000000..cfbdb5e Binary files /dev/null and b/src/assets/products/measurement.png differ diff --git a/src/core/base/GlobalBaseComponentsRegistration.js b/src/core/base/GlobalBaseComponentsRegistration.js new file mode 100644 index 0000000..f039c1b --- /dev/null +++ b/src/core/base/GlobalBaseComponentsRegistration.js @@ -0,0 +1,10 @@ +import app from '@/main'; + + +const requireComponent =import.meta.glob("./Base*.vue"); + +Object.keys(requireComponent).forEach(fileName => { + const componentConfig = requireComponent[fileName]; + const component = componentConfig.default || componentConfig; + app.component(component.name, component); +}); diff --git a/src/core/classes/base/BaseError.js b/src/core/classes/base/BaseError.js new file mode 100644 index 0000000..7663f37 --- /dev/null +++ b/src/core/classes/base/BaseError.js @@ -0,0 +1,15 @@ +import { useSnackbarStore } from '@/store/SnackbarStore'; + +export class BaseError { + data;//could be validation errors or any meta data of errors + message ="Unexpected Failure Please Check Your Internet Connection.";//the previewed message for user + + initData(error, data) { + this.error = error; + this.data = data; + return this; + } + dispatchError() { + useSnackbarStore().showSnackbar(`${this.message}`, { color: 'error' }) + } +} diff --git a/src/core/classes/base/BasePaginatedCollection.js b/src/core/classes/base/BasePaginatedCollection.js new file mode 100644 index 0000000..31e82b7 --- /dev/null +++ b/src/core/classes/base/BasePaginatedCollection.js @@ -0,0 +1,32 @@ +export default class BasePaginatedCollection { + collection = new Array(); + total; + perPage; + currentPage; + lastPage; + isLastPage; + + constructor( + paginationResponse //! this should be overridden in concretes (specific object collection init) + ) { + if (paginationResponse == undefined) { + //case of empty parameter constructor + this.currentPage = 1; + this.isLastPage = true; + } else { + this.total = paginationResponse.total; + this.perPage = paginationResponse.per_page; + this.currentPage = paginationResponse.current_page; + this.lastPage = paginationResponse.last_page; + this.isLastPage = this.currentPage == this.lastPage; + } + } + //! this should be overridden in concretes (specific object collection update) + updatePaginationPage(paginationResponse) { + this.total = paginationResponse.total; + this.perPage = paginationResponse.per_page; + this.currentPage = paginationResponse.current_page; + this.lastPage = paginationResponse.last_page; + this.isLastPage = this.currentPage == this.lastPage; + } +} diff --git a/src/core/classes/base/BaseService.js b/src/core/classes/base/BaseService.js new file mode 100644 index 0000000..1f4a8a1 --- /dev/null +++ b/src/core/classes/base/BaseService.js @@ -0,0 +1,185 @@ +import Mapper from "../mapper/Mapper"; +import { Notify } from "../notify/Notify"; + +export default class BaseService { + static data; + + static checkIfExists(item = null, callbackFn = null) { + try { + let checkIfElementExists = + item !== null && item !== undefined && item !== ""; + if (checkIfElementExists) { + return callbackFn !== null ? callbackFn(item) : checkIfElementExists; + } + } catch (e) { + Notify.showMessage("error", e); + } + } + + static resolveStatusResponse(status, res = {}) { + try { + return status < 300 ? Promise.resolve(res) : Promise.reject(res); + } catch (e) { + Notify.showMessage("error", e); + } + } + + static FormBuilder() { + try { + let formData = new FormData(); + Object.keys(this.data).forEach((item) => { + formData.append(item, this.data[item]); + }); + return formData; + } catch (e) { + Notify.showMessage("error", e); + } + } + static objectToFormDataWithoutArrayBrackets( + obj, + formData = new FormData(), + parentKey = "" + ) { + for (let key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key)) { + const nestedKey = parentKey ? `${parentKey}.${key}` : key; + const value = obj[key]; + + if (value === null || typeof value === "undefined") { + continue; // Skip null and undefined values + } + + if (Array.isArray(value)) { + if (value.length === 0) { + formData.append(nestedKey, ""); // Append an empty value to represent an empty array + } else { + value.forEach((item, index) => { + if (item instanceof File) { + formData.append(nestedKey, item); + } else { + BaseService.objectToFormData( + item, + formData, + `${nestedKey}[${index}]` + ); + } + }); + } + } else if (typeof value === "object") { + if (value instanceof File) { + formData.append(nestedKey, value); + } else { + BaseService.objectToFormData(value, formData, nestedKey); + } + } else { + formData.append(nestedKey, value); + } + } + } + + return formData; + } + + static toString(keys) { + try { + keys.forEach((key) => { + if (this.data[key]) { + this.data[key] = this.data[key].toString(); + } + }); + return this; + } catch (e) { + Notify.showMessage("error", e); + } + } + + static setData(data) { + try { + this.data = Mapper.camelToUnderscore(data); + return this; + } catch (e) { + Notify.showMessage("error", e); + } + } + + static filterForEmpty() { + try { + let newData = this.data; + Object.keys(this.data).forEach((item) => { + this.checkIfEmpty(this.data[item], function (value) { + delete newData[value]; + }); + }); + this.data = newData; + return this; + } catch (e) { + Notify.showMessage("error", e); + } + } + + static checkIfEmpty(item, callback) { + try { + if (item === "" || item == null || item == undefined) { + return callback(item); + } + } catch (e) { + Notify.showMessage("error", e); + } + } + + static unsetData(dataToUnset) { + try { + let newData = this.data; + dataToUnset.forEach((item) => { + delete newData[item]; + }); + this.data = newData; + return this; + } catch (e) { + Notify.showMessage("error", e); + } + } + + static getWithFormBuilder() { + try { + return this.FormBuilder(); + } catch (e) { + Notify.showMessage("error", e); + } + } + + static customizeData(obj) { + try { + Object.keys(obj).map((item) => (this.data[item] = this.data[obj[item]])); + return this; + } catch (e) { + Notify.showMessage("error", e); + } + } + + static get() { + try { + return this.data; + } catch (e) { + Notify.showMessage("error", e); + } + } + + static responseMapperToCamel(res) { + try { + if (res.data.response) { + if (!Array.isArray(res.data.response)) { + res.data.response = [res.data.response]; + } + res.data.response.map((item, index) => { + if (res.data.response[index]) { + res.data.response[index] = Mapper.underscoreToCamel(item); + } + }); + } + return res; + } catch (e) { + Notify.showMessage("error", e); + } + } +} diff --git a/src/core/classes/base/BaseStore.js b/src/core/classes/base/BaseStore.js new file mode 100644 index 0000000..84c94d5 --- /dev/null +++ b/src/core/classes/base/BaseStore.js @@ -0,0 +1,25 @@ +import BaseService from "./BaseService"; + +export default class BaseStore { + static promiseHandler(promise, onResolved, onRejected) { + return new Promise((resolve, reject) => { + promise() + .then((res) => { + let { data, status } = res; + return BaseService.resolveStatusResponse(status, res).then(() => { + if (onResolved) { + onResolved(data); + } + return resolve(res); + }); + }) + .catch((err) => { + if (onRejected) { + onRejected(err, reject); + } else { + reject(err); + } + }); + }); + } +} diff --git a/src/core/classes/client/Client.js b/src/core/classes/client/Client.js new file mode 100644 index 0000000..a270e81 --- /dev/null +++ b/src/core/classes/client/Client.js @@ -0,0 +1,146 @@ +import { Notify } from "../notify/Notify"; +import axios from "axios"; +import { useGlobalStore } from "../../../store/GlobalStore"; +import pinia from "@/store"; +import { ResponseErrorWrapper } from "../error/ResponseErrorWrapper"; + +const globalStore = useGlobalStore(pinia); + +export default class Client { + static initHttp(axios) { + axios.defaults.baseURL = import.meta.env.VITE_APP_API_BASE_URL; + axios.interceptors.request.use( + async (config) => { + config = this.prepareInterceptorsConfig(config); + globalStore.changeLoadingStatus(true); + return config; + }, + (error) => { + console.warn(error); + globalStore.changeLoadingStatus(false); + } + ); + axios.interceptors.response.use( + (response) => { + if (response?.status >= 200 && response?.status < 300) { + if (response?.data?.message) + Notify.showMessage("success", response?.data?.message); + } + globalStore.changeLoadingStatus(false); + return Promise.resolve(response); + }, + async (error) => { + try { + globalStore.changeLoadingStatus(false); + return new ResponseErrorWrapper(error); + } catch (e) { + console.warn(e); + globalStore.changeLoadingStatus(false); + return Promise.reject(e); + } + } + ); + return axios; + } + + static async get(url, queryParams = null) { + // get header + let headers = this.getHeaders(); + // check if there is any query params inserted + let config = { + params: queryParams !== null ? queryParams : "", + headers: headers, + }; + return await axios + .get(url, config) + .then((res) => { + return Promise.resolve(res); + }) + .catch(function (error) { + // show error if failed + Notify.showMessage("error", Notify.getMessage(error)); + }); + } + + static async post(url, data, options = {}) { + // get header + let headers = this.getHeaders(options); + return await axios + .post(url, data, { headers: headers }) + .then((res) => { + return Promise.resolve(res); + }) + .catch((error) => { + // show error if failed + Notify.showMessage("error", Notify.getMessage(error)); + }); + } + + static async patch(url, data, options = {}) { + // get header + let headers = this.getHeaders(options); + return await axios + .patch(url, data, { headers: headers }) + .then((res) => { + return Promise.resolve(res); + }) + .catch((error) => { + // show error if failed + Notify.showMessage("error", Notify.getMessage(error)); + }); + } + static async put(url, data, options = {}) { + // get header + let headers = this.getHeaders(options); + // add _method parameter + let config = { + params: { _method: "PUT" }, + headers: headers, + }; + return await axios + .post(url, data, config) + .then((res) => { + return Promise.resolve(res); + }) + .catch((error) => { + // show error if failed + Notify.showMessage("error", Notify.getMessage(error)); + }); + } + + static async delete(url, options = {}) { + // get header + let headers = this.getHeaders(options); + return await axios + .delete(url, { headers: headers }) + .then((res) => { + return Promise.resolve(res); + }) + .catch((error) => { + // show error if failed + Notify.showMessage("error", Notify.getMessage(error)); + }); + } + + static getHeaders(options = {}) { + let result = { + accept: "application/json", + "Access-Control-Allow-Origin": "*", + lang: localStorage.getItem("locale") || "ar", + "ngrok-skip-browser-warning": "69420", + }; + if (options.headers) { + for (const [key, value] of Object.entries(options.headers)) { + result[key] = value; + } + } + return result; + } + + static prepareInterceptorsConfig(config) { + config.params = { + ...config.params, + }; + return config; + } +} diff --git a/src/core/classes/error/BadRequestError.js b/src/core/classes/error/BadRequestError.js new file mode 100644 index 0000000..dc3ddb5 --- /dev/null +++ b/src/core/classes/error/BadRequestError.js @@ -0,0 +1,11 @@ +import { translate } from "@/plugins/i18n"; +import { BaseError } from "../base/BaseError"; +import { useSnackbarStore } from '@/store/SnackbarStore'; + + +export class BadRequestError extends BaseError { + message = translate('errorMessages.BadRequestError') ; + dispatchError() { + useSnackbarStore().showSnackbar(`${this.data.message}`, { color: 'error' }) + } +} diff --git a/src/core/classes/error/ErrorRegistration.js b/src/core/classes/error/ErrorRegistration.js new file mode 100644 index 0000000..6cd2cf1 --- /dev/null +++ b/src/core/classes/error/ErrorRegistration.js @@ -0,0 +1,23 @@ +import { RequestError } from "./RequestError"; +import { BadRequestError } from "./BadRequestError"; +import { UnAuthenticatedError } from "./UnAuthenticatedError"; +import { UnAuthorizedError } from "./UnAuthorizedError"; +import { NotFoundError } from "./NotFoundError"; +import { UnprocessableEntityError } from "./UnprocessableEntityError"; +import { ServerError } from "./ServerError"; + +export class ErrorRegistration { + statusCodeClasses = { + 301: new RequestError(), + 400: new BadRequestError(), + 401: new UnAuthenticatedError(), + 403: new UnAuthorizedError(), + 404: new NotFoundError(), + 422: new UnprocessableEntityError(), + 500: new ServerError(), + }; + + getClassFromStatusCode(code) { + return this.statusCodeClasses[code]; + } +} diff --git a/src/core/classes/error/FailedRequestError.js b/src/core/classes/error/FailedRequestError.js new file mode 100644 index 0000000..d6efe14 --- /dev/null +++ b/src/core/classes/error/FailedRequestError.js @@ -0,0 +1,6 @@ +import { translate } from "@/plugins/i18n"; +import { BaseError } from "../base/BaseError"; + +export class FailedRequestError extends BaseError { + message = translate('errorMessages.FailedRequestError') ; +} diff --git a/src/core/classes/error/NotFoundError.js b/src/core/classes/error/NotFoundError.js new file mode 100644 index 0000000..d843415 --- /dev/null +++ b/src/core/classes/error/NotFoundError.js @@ -0,0 +1,6 @@ +import { translate } from "@/plugins/i18n"; +import { BaseError } from "../base/BaseError"; + +export class NotFoundError extends BaseError { + message = translate("errorMessages.NotFoundError"); +} diff --git a/src/core/classes/error/RequestError.js b/src/core/classes/error/RequestError.js new file mode 100644 index 0000000..3803b14 --- /dev/null +++ b/src/core/classes/error/RequestError.js @@ -0,0 +1,6 @@ +import { translate } from "@/plugins/i18n"; +import { BaseError } from "../base/BaseError"; + +export class RequestError extends BaseError { + message = translate("errorMessages.RequestError"); +} diff --git a/src/core/classes/error/ResponseErrorWrapper.js b/src/core/classes/error/ResponseErrorWrapper.js new file mode 100644 index 0000000..08047a9 --- /dev/null +++ b/src/core/classes/error/ResponseErrorWrapper.js @@ -0,0 +1,26 @@ +import { ErrorRegistration } from "./ErrorRegistration"; +import { FailedRequestError } from "./FailedRequestError"; + + +export class ResponseErrorWrapper { + + constructor(error) { + this.error = error; + this.data = this.registerResponse(error); + return this.wrapError(); + } + + registerResponse(error) { + return error?.response?.data; + } + + wrapError() { + let errorClass = new ErrorRegistration().getClassFromStatusCode( + this?.error?.response?.status + ); + return errorClass != undefined + ? errorClass?.initData(this.error, this.data).dispatchError() + :new FailedRequestError().initData(this.error, this.data).dispatchError();//case no status for the error response + } + +} diff --git a/src/core/classes/error/ServerError.js b/src/core/classes/error/ServerError.js new file mode 100644 index 0000000..ec4a995 --- /dev/null +++ b/src/core/classes/error/ServerError.js @@ -0,0 +1,6 @@ +import { translate } from "@/plugins/i18n"; +import { BaseError } from "../base/BaseError"; + +export class ServerError extends BaseError { + message = translate("errorMessages.ServerError"); +} diff --git a/src/core/classes/error/UnAuthenticatedError.js b/src/core/classes/error/UnAuthenticatedError.js new file mode 100644 index 0000000..2e79fde --- /dev/null +++ b/src/core/classes/error/UnAuthenticatedError.js @@ -0,0 +1,22 @@ +import { Notify } from "../notify/Notify"; +import { BaseError } from "../base/BaseError"; +import { translate } from "@/plugins/i18n"; +// import { useAuthStore } from "@/modules/auth/store/AuthStore"; +// import pinia from "@/store"; + +// const authStore=useAuthStore(pinia); +export class UnAuthenticatedError extends BaseError { + message = translate("errorMessages.UnAuthenticatedError"); + sessionExpiredMessage = "Session Expired, Please Login Again"; + requiresAuthMessage = "Please Login To Your Account First."; + //TODO handle logout/storage clear cases + // dispatchError() { + // if (authStore.isAuthenticated) { + // //case the token lifetime has expired + // Notify.showMessage("warning", this.sessionExpiredMessage); + // } else {//case no token is stored + // Notify.showMessage("error", this.requiresAuthMessage); + // } + // authStore.localLogout(); + // } +} diff --git a/src/core/classes/error/UnAuthorizedError.js b/src/core/classes/error/UnAuthorizedError.js new file mode 100644 index 0000000..55cd85c --- /dev/null +++ b/src/core/classes/error/UnAuthorizedError.js @@ -0,0 +1,6 @@ +import { translate } from "@/plugins/i18n"; +import { BaseError } from "../base/BaseError"; + +export class UnAuthorizedError extends BaseError { + message = translate("errorMessages.UnAuthorizedError"); +} diff --git a/src/core/classes/error/UnprocessableEntityError.js b/src/core/classes/error/UnprocessableEntityError.js new file mode 100644 index 0000000..6a41c11 --- /dev/null +++ b/src/core/classes/error/UnprocessableEntityError.js @@ -0,0 +1,15 @@ +import { translate } from "@/plugins/i18n"; +import { BaseError } from "../base/BaseError"; +import { useSnackbarStore } from "@/store/SnackbarStore"; + +export class UnprocessableEntityError extends BaseError { + message = translate("errorMessages.UnprocessableEntityError"); + + dispatchError() { + Object.values(this.data.errors ?? []).forEach((error) => { + if (error) { + useSnackbarStore().showSnackbar(`${error}`, { color: "error" }); + } + }); + } +} diff --git a/src/core/classes/file/File.js b/src/core/classes/file/File.js new file mode 100644 index 0000000..c7527af --- /dev/null +++ b/src/core/classes/file/File.js @@ -0,0 +1,11 @@ +export default class File { + static resolveFile(file) { + if (file.$refs.input.files) { + return file.$refs.input.files[0]; + } + } + + static basicReturnFile(file) { + return file; + } +} diff --git a/src/core/classes/mapper/Mapper.js b/src/core/classes/mapper/Mapper.js new file mode 100644 index 0000000..e37e52c --- /dev/null +++ b/src/core/classes/mapper/Mapper.js @@ -0,0 +1,27 @@ +export default class Mapper { + /** + * @desc this function convert all obj content to camelCase words + * @author karam mustafa + * @return Object + * */ + static underscoreToCamel(obj) { + return JSON.parse( + JSON.stringify(obj).replace( + /(_\w)\w+":/g, + match => match[1].toUpperCase() + match.substring(2) + ) + ); + } + /** + * @desc this function return all keys from an object in camel case formatting and convert to under score words + * @author karam mustafa + * @return Object + * */ + static camelToUnderscore(obj) { + let newObj = {}; + for (let camel in obj) { + newObj[camel.replace(/([A-Z])/g, "_$1").toLowerCase()] = obj[camel]; + } + return newObj; + } +} diff --git a/src/core/classes/notify/Notify.js b/src/core/classes/notify/Notify.js new file mode 100644 index 0000000..8bc3d5f --- /dev/null +++ b/src/core/classes/notify/Notify.js @@ -0,0 +1,26 @@ +// import EventBus from "../../../main"; + +export class Notify { + static getMessage(code) { + let codeAvailable = { + 400: "خطأ في الطلب،الرجاء المحاولة مرة أخرى", + 401: "انتهت صلاحية جلستك، الرجاء تسجيل الدخول مرة أخرى", + 403: "لا يمكن إتمام الطلب لعدم امتلاك الصلاحيات اللازمة", + 301:"خطأ في الطلب،الرجاء المحاولة مرة أخرى", + 422: "الرجاء إدخال البيانات بالشكل الصحيح", + 500: "خطأ في الخادم،الرجاء المحاولة مرة أخرى", + }; + return codeAvailable[code] != null || undefined + ? codeAvailable[code] + : code; + } + + static showMessage(type, message) { + // EventBus.$notify({ + // group: "public", + // type: type, + // title: message, + // duration: 5000 + // }); + } +} diff --git a/src/core/components/NotFound.vue b/src/core/components/NotFound.vue new file mode 100644 index 0000000..c789c1d --- /dev/null +++ b/src/core/components/NotFound.vue @@ -0,0 +1,29 @@ + + + + diff --git a/src/core/components/breadcrumbs.vue b/src/core/components/breadcrumbs.vue new file mode 100644 index 0000000..f2c8f84 --- /dev/null +++ b/src/core/components/breadcrumbs.vue @@ -0,0 +1,34 @@ + + + + + diff --git a/src/core/components/decorations/gear.vue b/src/core/components/decorations/gear.vue new file mode 100644 index 0000000..2275cc5 --- /dev/null +++ b/src/core/components/decorations/gear.vue @@ -0,0 +1,38 @@ + + + + diff --git a/src/core/components/loader/LoadingProgress.vue b/src/core/components/loader/LoadingProgress.vue new file mode 100644 index 0000000..f5cf26a --- /dev/null +++ b/src/core/components/loader/LoadingProgress.vue @@ -0,0 +1,47 @@ + + + + + diff --git a/src/core/components/navs/SideNav.vue b/src/core/components/navs/SideNav.vue new file mode 100644 index 0000000..3b6f7a4 --- /dev/null +++ b/src/core/components/navs/SideNav.vue @@ -0,0 +1,234 @@ + + + + + diff --git a/src/core/components/navs/SideNavMain.vue b/src/core/components/navs/SideNavMain.vue new file mode 100644 index 0000000..9a90278 --- /dev/null +++ b/src/core/components/navs/SideNavMain.vue @@ -0,0 +1,48 @@ + + + + + diff --git a/src/core/components/navs/TabsList.js b/src/core/components/navs/TabsList.js new file mode 100644 index 0000000..2fcbb4e --- /dev/null +++ b/src/core/components/navs/TabsList.js @@ -0,0 +1,55 @@ +export const topNavTabs = [ + { + title: "awardAgenda", + routeName: "award_agenda", + icon: "mdi-calendar", + }, + { + title:"winners", + routeName: "winners", + icon: "mdi-trophy", + }, + { + title: "linkedAccounts", + routeName: "linked_accounts", + icon: "mdi-link-variant", + }, + { + title: "awardNews", + routeName: "award_news", + icon: "mdi-web", + }, + { + title:"contactUs", + routeName: "contact_us", + icon: "mdi-chat", + }, + { + title:"settings", + routeName: "settings", + icon: "mdi-cog-outline", + }, +]; + +export const bottomNavTabs = [ + { + title:"home", + routeName: "home", + }, + { + title:"aboutAward", + routeName: "about_award", + }, + { + title:"forms", + routeName: "forms", + }, + { + title:"eventsAndWorkshops", + routeName: "workshops", + }, + { + title:"achievementsFile", + routeName: "achievements", + }, +]; diff --git a/src/core/components/navs/TopNav.vue b/src/core/components/navs/TopNav.vue new file mode 100644 index 0000000..3b5db44 --- /dev/null +++ b/src/core/components/navs/TopNav.vue @@ -0,0 +1,175 @@ + + + + + diff --git a/src/core/components/navs/components/LocaleChanger.vue b/src/core/components/navs/components/LocaleChanger.vue new file mode 100644 index 0000000..7902a67 --- /dev/null +++ b/src/core/components/navs/components/LocaleChanger.vue @@ -0,0 +1,74 @@ + + + diff --git a/src/core/components/notifications/NotificationAlert.vue b/src/core/components/notifications/NotificationAlert.vue new file mode 100644 index 0000000..8e9c3d4 --- /dev/null +++ b/src/core/components/notifications/NotificationAlert.vue @@ -0,0 +1,32 @@ + + diff --git a/src/core/components/pagination/EmptyPaginationCollection.vue b/src/core/components/pagination/EmptyPaginationCollection.vue new file mode 100644 index 0000000..8c28ca8 --- /dev/null +++ b/src/core/components/pagination/EmptyPaginationCollection.vue @@ -0,0 +1,27 @@ + + + + + diff --git a/src/core/components/pagination/PaginationNextButton.vue b/src/core/components/pagination/PaginationNextButton.vue new file mode 100644 index 0000000..a5dee40 --- /dev/null +++ b/src/core/components/pagination/PaginationNextButton.vue @@ -0,0 +1,33 @@ + + + + + diff --git a/src/core/components/pagination/PaginationPreviousButton.vue b/src/core/components/pagination/PaginationPreviousButton.vue new file mode 100644 index 0000000..b94e8b1 --- /dev/null +++ b/src/core/components/pagination/PaginationPreviousButton.vue @@ -0,0 +1,33 @@ + + + + + diff --git a/src/core/composables/DateTime.js b/src/core/composables/DateTime.js new file mode 100644 index 0000000..30254c3 --- /dev/null +++ b/src/core/composables/DateTime.js @@ -0,0 +1,7 @@ +export function isTimestampBetween(timestamp, startTimestamp, endTimestamp) { + const startTime = new Date(startTimestamp).getTime(); + const endTime = new Date(endTimestamp).getTime(); + const targetTime = new Date(timestamp).getTime(); + + return targetTime >= startTime && targetTime <= endTime; +} diff --git a/src/core/composables/formatters.js b/src/core/composables/formatters.js new file mode 100644 index 0000000..5f42d79 --- /dev/null +++ b/src/core/composables/formatters.js @@ -0,0 +1,106 @@ +export const isToday = (date) => { + const today = new Date(); + + return ( + /* eslint-disable operator-linebreak */ + date.getDate() === today.getDate() && + date.getMonth() === today.getMonth() && + date.getFullYear() === today.getFullYear() + /* eslint-enable */ + ); +}; + +export const avatarText = (value) => { + if (!value) return ""; + const nameArray = value.split(" "); + + return nameArray.map((word) => word.charAt(0).toUpperCase()).join(""); +}; +// TODO: Try to implement this: https://twitter.com/fireship_dev/status/1565424801216311297 +export const kFormatter = (num) => { + const regex = /\B(?=(\d{3})+(?!\d))/g; + + return Math.abs(num) > 9999 + ? `${Math.sign(num) * +(Math.abs(num) / 1000).toFixed(1)}k` + : Math.abs(num).toFixed(0).replace(regex, ","); +}; + +/** + * Format and return date in Humanize format + * Intl docs: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/format + * Intl Constructor: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat + * @param {String} value date to format + * @param {Intl.DateTimeFormatOptions} formatting Intl object to format with + */ +export const formatDate = ( + value, + formatting = { month: "short", day: "numeric", year: "numeric" } +) => { + if (!value) return value; + + return new Intl.DateTimeFormat("en-US", formatting).format(new Date(value)); +}; + +/** + * Return short human friendly month representation of date + * Can also convert date to only time if date is of today (Better UX) + * @param {String} value date to format + * @param {Boolean} toTimeForCurrentDay Shall convert to time if day is today/current + */ +export const formatDateToMonthShort = (value, toTimeForCurrentDay = true) => { + const date = new Date(value); + let formatting = { month: "short", day: "numeric" }; + + if (toTimeForCurrentDay && isToday(date)) + formatting = { hour: "numeric", minute: "numeric" }; + + return new Intl.DateTimeFormat("en-US", formatting).format(new Date(value)); +}; +/** + * Return short human friendly Time in 12 Hour representation + * @param {String} value timestamp to format + */ +export const formatTimestampTo12HTime = (value) => { + const date = new Date(value); + + const timeFormatter = new Intl.DateTimeFormat("en-US", { + hour: "numeric", + minute: "numeric", + hour12: true, + }); + + const formattedTime = timeFormatter.format(date); + + return formattedTime; +}; + +export const formatDateTime = (value) => { + const datetime = new Date(value); // current datetime + + const options = { + year: "numeric", + month: "long", + day: "numeric", + hour: "numeric", + minute: "numeric", + hour12: true, + }; + return datetime.toLocaleString("en-US", options); +}; +export const formateToDate = (value) => { + const datetime = new Date(value); // current datetime + + const year = datetime.getFullYear(); + const month = String(datetime.getMonth() + 1).padStart(2, "0"); + const day = String(datetime.getDate()).padStart(2, "0"); + return `${year}-${month}-${day}`; +}; +export const formatToYearMonth = (value) => { + const datetime = new Date(value); // current datetime + + const options = { + year: "numeric", + month: "long", + }; + return datetime.toLocaleString("en-US", options); +}; diff --git a/src/core/composables/validators.js b/src/core/composables/validators.js new file mode 100644 index 0000000..50f7f8f --- /dev/null +++ b/src/core/composables/validators.js @@ -0,0 +1,137 @@ +import { translate } from '@/plugins/i18n' + +// 👉 IsEmpty +export const isEmpty = (value) => { + if (value === null || value === undefined || value === '') + return true + + return !!(Array.isArray(value) && value.length === 0) +} +// 👉 IsNullOrUndefined +export const isNullOrUndefined = (value) => { + return value === null || value === undefined +} + +// 👉 IsEmptyArray +export const isEmptyArray = (arr) => { + return Array.isArray(arr) && arr.length === 0 +} + +// 👉 Required Validator +export const requiredValidator = (value) => { + if (isNullOrUndefined(value) || isEmptyArray(value) || value === false) + return translate('validation.requiredField') + + return !!String(value).trim().length || translate('validation.requiredField') +} + +// 👉 Email Validator +export const emailValidator = (value) => { + if (isEmpty(value)) + return true + + const re = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/ + + if (Array.isArray(value)) + return value.every(val => re.test(String(val))) || translate('validation.emailField') + + return re.test(String(value)) || translate('validation.emailField') +} + +// 👉 Password Validator +export const passwordValidator = (password) => { + const regExp = /(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[!@#$%&*()]).{8,}/ + + const validPassword = regExp.test(password) + + return ( + // eslint-disable-next-line operator-linebreak + validPassword || + translate('validation.passwordField') + ) +} + +// 👉 Confirm Password Validator +export const confirmedValidator = (value, target) => + + value === target || translate('validation.confirmedField') + +// 👉 Between Validator +export const betweenValidator = (value, min, max) => { + const valueAsNumber = Number(value) + + return (Number(min) <= valueAsNumber && Number(max) >= valueAsNumber) + || translate('validation.betweenField', { min, max }) +} + +// 👉 Integer Validator +export const integerValidator = (value) => { + if (isEmpty(value)) + return true + + if (Array.isArray(value)) + return value.every(val => /^-?[0-9]+$/.test(String(val))) || translate('validation.integerField') + + return /^-?[0-9]+$/.test(String(value)) || translate('validation.integerField') +} + +// 👉 Regex Validator +export const regexValidator = (value, regex) => { + if (isEmpty(value)) + return true + + let regeX = regex + if (typeof regeX === 'string') + regeX = new RegExp(regeX) + + if (Array.isArray(value)) + return value.every(val => regexValidator(val, regeX)) + + return regeX.test(String(value)) || translate('validation.regexField') +} + +// 👉 Alpha Validator +export const alphaValidator = (value) => { + if (isEmpty(value)) + return true + + return /^[A-Z]*$/i.test(String(value)) || translate('validation.alphaField') +} + +// 👉 URL Validator +export const urlValidator = (value) => { + if (isEmpty(value)) + return true + + const re = /^(http[s]?:\/\/){0,1}(www\.){0,1}[a-zA-Z0-9\.\-]+\.[a-zA-Z]{2,5}[\.]{0,1}/ + + return re.test(String(value)) || translate('validation.urlField') +} + +// 👉 Time Validator +export const timeValidator = (value) => { + if (isEmpty(value)) + return true + + const re = /^(?:[01]\d|2[0-3]):[0-5]\d$/ + + return re.test(String(value)) || translate('validation.timeField') +} + +// 👉 Length Validator +export const lengthValidator = (value, length) => { + if (isEmpty(value)) + return true + + return String(value).length === length || translate('validation.lengthedField', { length }) +} + +// 👉 Alpha-dash Validator +export const alphaDashValidator = (value) => { + if (isEmpty(value)) + return true + + const valueAsString = String(value) + + return /^[0-9A-Z_-]*$/i.test(valueAsString) || translate('validation.alphaDashField') +} diff --git a/src/core/layouts/default/AppBar.vue b/src/core/layouts/default/AppBar.vue new file mode 100644 index 0000000..756e9e4 --- /dev/null +++ b/src/core/layouts/default/AppBar.vue @@ -0,0 +1,133 @@ + + + + + diff --git a/src/core/layouts/default/AppFooter.vue b/src/core/layouts/default/AppFooter.vue new file mode 100644 index 0000000..0b99abd --- /dev/null +++ b/src/core/layouts/default/AppFooter.vue @@ -0,0 +1,125 @@ + + + + + diff --git a/src/core/layouts/default/Default.vue b/src/core/layouts/default/Default.vue new file mode 100644 index 0000000..75850e6 --- /dev/null +++ b/src/core/layouts/default/Default.vue @@ -0,0 +1,19 @@ + + + diff --git a/src/core/layouts/default/View.vue b/src/core/layouts/default/View.vue new file mode 100644 index 0000000..e62d010 --- /dev/null +++ b/src/core/layouts/default/View.vue @@ -0,0 +1,9 @@ + + + diff --git a/src/core/layouts/default/systemBar.vue b/src/core/layouts/default/systemBar.vue new file mode 100644 index 0000000..3dfb73d --- /dev/null +++ b/src/core/layouts/default/systemBar.vue @@ -0,0 +1,40 @@ + + + + + diff --git a/src/main.js b/src/main.js new file mode 100644 index 0000000..daa1acf --- /dev/null +++ b/src/main.js @@ -0,0 +1,20 @@ +/** + * main.js + * + * Bootstraps Vuetify and other plugins then mounts the App` + */ + +// Components +import App from './App.vue' + +// Composables +import { createApp } from 'vue' + +// Plugins +import { registerPlugins } from '@/plugins' + +const app = createApp(App) + +registerPlugins(app) + +app.mount('#app') diff --git a/src/modules/About/components/Introduction.vue b/src/modules/About/components/Introduction.vue new file mode 100644 index 0000000..4f8a9f4 --- /dev/null +++ b/src/modules/About/components/Introduction.vue @@ -0,0 +1,224 @@ + + + + + diff --git a/src/modules/About/components/aTeamMember.vue b/src/modules/About/components/aTeamMember.vue new file mode 100644 index 0000000..1331066 --- /dev/null +++ b/src/modules/About/components/aTeamMember.vue @@ -0,0 +1,43 @@ + + + + + diff --git a/src/modules/About/components/ourTeam.vue b/src/modules/About/components/ourTeam.vue new file mode 100644 index 0000000..a1d7c61 --- /dev/null +++ b/src/modules/About/components/ourTeam.vue @@ -0,0 +1,28 @@ + + + + + diff --git a/src/modules/About/components/trustedBy.vue b/src/modules/About/components/trustedBy.vue new file mode 100644 index 0000000..7f61806 --- /dev/null +++ b/src/modules/About/components/trustedBy.vue @@ -0,0 +1,122 @@ + + + + + diff --git a/src/modules/About/pages/index.vue b/src/modules/About/pages/index.vue new file mode 100644 index 0000000..9d6e3d2 --- /dev/null +++ b/src/modules/About/pages/index.vue @@ -0,0 +1,33 @@ + + + + + diff --git a/src/modules/About/routes/index.routes.js b/src/modules/About/routes/index.routes.js new file mode 100644 index 0000000..a04940c --- /dev/null +++ b/src/modules/About/routes/index.routes.js @@ -0,0 +1,14 @@ +import DefaultLayout from "@/core/layouts/default/Default.vue"; +import About from "../pages/index.vue"; +export default { + path: "/About", + component: DefaultLayout, + children: [ + { + path: "", + name: "About", + component: About, + // meta: { title: translate("") }, + }, + ], +}; diff --git a/src/modules/About/services/index.api.js b/src/modules/About/services/index.api.js new file mode 100644 index 0000000..20a9a36 --- /dev/null +++ b/src/modules/About/services/index.api.js @@ -0,0 +1 @@ +export const api = `/`; diff --git a/src/modules/About/services/indexService.js b/src/modules/About/services/indexService.js new file mode 100644 index 0000000..f4d1756 --- /dev/null +++ b/src/modules/About/services/indexService.js @@ -0,0 +1,5 @@ +import BaseService from "@/core/classes/base/BaseService"; +import { api } from "./index.api"; +import Client from "@/core/classes/client/Client"; + +export default class CategoriesService extends BaseService {} diff --git a/src/modules/About/store/indexStore.js b/src/modules/About/store/indexStore.js new file mode 100644 index 0000000..9de3e87 --- /dev/null +++ b/src/modules/About/store/indexStore.js @@ -0,0 +1,11 @@ +import { defineStore } from "pinia"; +import BaseStore from "@/core/classes/base/BaseStore"; +import Service from "../services/indexService"; + +export const useHomeStore = defineStore("HomeStore", { + state: () => ({ + sliders: [], + }), + getters: {}, + actions: {}, +}); diff --git a/src/modules/Contact/components/contactUs.vue b/src/modules/Contact/components/contactUs.vue new file mode 100644 index 0000000..552b177 --- /dev/null +++ b/src/modules/Contact/components/contactUs.vue @@ -0,0 +1,70 @@ + + + + + diff --git a/src/modules/Contact/components/formContactUs.vue b/src/modules/Contact/components/formContactUs.vue new file mode 100644 index 0000000..b784c0d --- /dev/null +++ b/src/modules/Contact/components/formContactUs.vue @@ -0,0 +1,99 @@ + + + + + diff --git a/src/modules/Contact/pages/index.vue b/src/modules/Contact/pages/index.vue new file mode 100644 index 0000000..e670049 --- /dev/null +++ b/src/modules/Contact/pages/index.vue @@ -0,0 +1,25 @@ + + + + + diff --git a/src/modules/Contact/routes/index.routes.js b/src/modules/Contact/routes/index.routes.js new file mode 100644 index 0000000..20c0efb --- /dev/null +++ b/src/modules/Contact/routes/index.routes.js @@ -0,0 +1,14 @@ +import DefaultLayout from "@/core/layouts/default/Default.vue"; +import Contact from "../pages/index.vue"; +export default { + path: "/Contact", + component: DefaultLayout, + children: [ + { + path: "", + name: "Contact", + component: Contact, + // meta: { title: translate("") }, + }, + ], +}; diff --git a/src/modules/Contact/services/index.api.js b/src/modules/Contact/services/index.api.js new file mode 100644 index 0000000..20a9a36 --- /dev/null +++ b/src/modules/Contact/services/index.api.js @@ -0,0 +1 @@ +export const api = `/`; diff --git a/src/modules/Contact/services/indexService.js b/src/modules/Contact/services/indexService.js new file mode 100644 index 0000000..f4d1756 --- /dev/null +++ b/src/modules/Contact/services/indexService.js @@ -0,0 +1,5 @@ +import BaseService from "@/core/classes/base/BaseService"; +import { api } from "./index.api"; +import Client from "@/core/classes/client/Client"; + +export default class CategoriesService extends BaseService {} diff --git a/src/modules/Contact/store/indexStore.js b/src/modules/Contact/store/indexStore.js new file mode 100644 index 0000000..9de3e87 --- /dev/null +++ b/src/modules/Contact/store/indexStore.js @@ -0,0 +1,11 @@ +import { defineStore } from "pinia"; +import BaseStore from "@/core/classes/base/BaseStore"; +import Service from "../services/indexService"; + +export const useHomeStore = defineStore("HomeStore", { + state: () => ({ + sliders: [], + }), + getters: {}, + actions: {}, +}); diff --git a/src/modules/Distributors/components/showRoom.vue b/src/modules/Distributors/components/showRoom.vue new file mode 100644 index 0000000..8fa71e0 --- /dev/null +++ b/src/modules/Distributors/components/showRoom.vue @@ -0,0 +1,44 @@ + + + + + diff --git a/src/modules/Distributors/pages/index.vue b/src/modules/Distributors/pages/index.vue new file mode 100644 index 0000000..82a77d2 --- /dev/null +++ b/src/modules/Distributors/pages/index.vue @@ -0,0 +1,62 @@ + + + + + diff --git a/src/modules/Distributors/routes/index.routes.js b/src/modules/Distributors/routes/index.routes.js new file mode 100644 index 0000000..d0c5dc0 --- /dev/null +++ b/src/modules/Distributors/routes/index.routes.js @@ -0,0 +1,14 @@ +import DefaultLayout from "@/core/layouts/default/Default.vue"; +import Distributors from "../pages/index.vue"; +export default { + path: "/Distributors", + component: DefaultLayout, + children: [ + { + path: "", + name: "Distributors", + component: Distributors, + // meta: { title: translate("") }, + }, + ], +}; diff --git a/src/modules/Distributors/services/index.api.js b/src/modules/Distributors/services/index.api.js new file mode 100644 index 0000000..20a9a36 --- /dev/null +++ b/src/modules/Distributors/services/index.api.js @@ -0,0 +1 @@ +export const api = `/`; diff --git a/src/modules/Distributors/services/indexService.js b/src/modules/Distributors/services/indexService.js new file mode 100644 index 0000000..f4d1756 --- /dev/null +++ b/src/modules/Distributors/services/indexService.js @@ -0,0 +1,5 @@ +import BaseService from "@/core/classes/base/BaseService"; +import { api } from "./index.api"; +import Client from "@/core/classes/client/Client"; + +export default class CategoriesService extends BaseService {} diff --git a/src/modules/Distributors/store/indexStore.js b/src/modules/Distributors/store/indexStore.js new file mode 100644 index 0000000..9de3e87 --- /dev/null +++ b/src/modules/Distributors/store/indexStore.js @@ -0,0 +1,11 @@ +import { defineStore } from "pinia"; +import BaseStore from "@/core/classes/base/BaseStore"; +import Service from "../services/indexService"; + +export const useHomeStore = defineStore("HomeStore", { + state: () => ({ + sliders: [], + }), + getters: {}, + actions: {}, +}); diff --git a/src/modules/Home/components/Introduction.vue b/src/modules/Home/components/Introduction.vue new file mode 100644 index 0000000..b18fe80 --- /dev/null +++ b/src/modules/Home/components/Introduction.vue @@ -0,0 +1,114 @@ + + + + + diff --git a/src/modules/Home/pages/index.vue b/src/modules/Home/pages/index.vue new file mode 100644 index 0000000..a1b6c3f --- /dev/null +++ b/src/modules/Home/pages/index.vue @@ -0,0 +1,116 @@ + + + + + diff --git a/src/modules/Home/routes/index.routes.js b/src/modules/Home/routes/index.routes.js new file mode 100644 index 0000000..b9b2481 --- /dev/null +++ b/src/modules/Home/routes/index.routes.js @@ -0,0 +1,15 @@ +import { translate } from "@/plugins/i18n"; +import DefaultLayout from "@/core/layouts/default/Default.vue"; +import Home from "../pages/index.vue"; +export default { + path: "/", + component: DefaultLayout, + children: [ + { + path: "/", + name: "Home", + component: Home, + // meta: { title: translate("") }, + }, + ], +}; diff --git a/src/modules/Home/services/index.api.js b/src/modules/Home/services/index.api.js new file mode 100644 index 0000000..20a9a36 --- /dev/null +++ b/src/modules/Home/services/index.api.js @@ -0,0 +1 @@ +export const api = `/`; diff --git a/src/modules/Home/services/indexService.js b/src/modules/Home/services/indexService.js new file mode 100644 index 0000000..f4d1756 --- /dev/null +++ b/src/modules/Home/services/indexService.js @@ -0,0 +1,5 @@ +import BaseService from "@/core/classes/base/BaseService"; +import { api } from "./index.api"; +import Client from "@/core/classes/client/Client"; + +export default class CategoriesService extends BaseService {} diff --git a/src/modules/Home/store/indexStore.js b/src/modules/Home/store/indexStore.js new file mode 100644 index 0000000..9de3e87 --- /dev/null +++ b/src/modules/Home/store/indexStore.js @@ -0,0 +1,11 @@ +import { defineStore } from "pinia"; +import BaseStore from "@/core/classes/base/BaseStore"; +import Service from "../services/indexService"; + +export const useHomeStore = defineStore("HomeStore", { + state: () => ({ + sliders: [], + }), + getters: {}, + actions: {}, +}); diff --git a/src/modules/OurServices/components/showRoom.vue b/src/modules/OurServices/components/showRoom.vue new file mode 100644 index 0000000..32d08c5 --- /dev/null +++ b/src/modules/OurServices/components/showRoom.vue @@ -0,0 +1,155 @@ + + + + + diff --git a/src/modules/OurServices/pages/index.vue b/src/modules/OurServices/pages/index.vue new file mode 100644 index 0000000..94cb7fa --- /dev/null +++ b/src/modules/OurServices/pages/index.vue @@ -0,0 +1,25 @@ + + + + + diff --git a/src/modules/OurServices/routes/index.routes.js b/src/modules/OurServices/routes/index.routes.js new file mode 100644 index 0000000..29a59af --- /dev/null +++ b/src/modules/OurServices/routes/index.routes.js @@ -0,0 +1,14 @@ +import DefaultLayout from "@/core/layouts/default/Default.vue"; +import Services from "../pages/index.vue"; +export default { + path: "/Services", + component: DefaultLayout, + children: [ + { + path: "", + name: "Services", + component: Services, + // meta: { title: translate("") }, + }, + ], +}; diff --git a/src/modules/OurServices/services/index.api.js b/src/modules/OurServices/services/index.api.js new file mode 100644 index 0000000..20a9a36 --- /dev/null +++ b/src/modules/OurServices/services/index.api.js @@ -0,0 +1 @@ +export const api = `/`; diff --git a/src/modules/OurServices/services/indexService.js b/src/modules/OurServices/services/indexService.js new file mode 100644 index 0000000..f4d1756 --- /dev/null +++ b/src/modules/OurServices/services/indexService.js @@ -0,0 +1,5 @@ +import BaseService from "@/core/classes/base/BaseService"; +import { api } from "./index.api"; +import Client from "@/core/classes/client/Client"; + +export default class CategoriesService extends BaseService {} diff --git a/src/modules/OurServices/store/indexStore.js b/src/modules/OurServices/store/indexStore.js new file mode 100644 index 0000000..9de3e87 --- /dev/null +++ b/src/modules/OurServices/store/indexStore.js @@ -0,0 +1,11 @@ +import { defineStore } from "pinia"; +import BaseStore from "@/core/classes/base/BaseStore"; +import Service from "../services/indexService"; + +export const useHomeStore = defineStore("HomeStore", { + state: () => ({ + sliders: [], + }), + getters: {}, + actions: {}, +}); diff --git a/src/modules/Products/components/navigationDrawer.vue b/src/modules/Products/components/navigationDrawer.vue new file mode 100644 index 0000000..4037c5e --- /dev/null +++ b/src/modules/Products/components/navigationDrawer.vue @@ -0,0 +1,129 @@ + + + + + diff --git a/src/modules/Products/components/showRoom.vue b/src/modules/Products/components/showRoom.vue new file mode 100644 index 0000000..ddb4571 --- /dev/null +++ b/src/modules/Products/components/showRoom.vue @@ -0,0 +1,85 @@ + + + + + + diff --git a/src/modules/Products/components/showRoom_2.vue b/src/modules/Products/components/showRoom_2.vue new file mode 100644 index 0000000..61c47ce --- /dev/null +++ b/src/modules/Products/components/showRoom_2.vue @@ -0,0 +1,115 @@ + + + + + diff --git a/src/modules/Products/pages/index.vue b/src/modules/Products/pages/index.vue new file mode 100644 index 0000000..2cf96b7 --- /dev/null +++ b/src/modules/Products/pages/index.vue @@ -0,0 +1,14 @@ + + + + + diff --git a/src/modules/Products/routes/index.routes.js b/src/modules/Products/routes/index.routes.js new file mode 100644 index 0000000..9c38af8 --- /dev/null +++ b/src/modules/Products/routes/index.routes.js @@ -0,0 +1,15 @@ +import { translate } from "@/plugins/i18n"; +import DefaultLayout from "@/core/layouts/default/Default.vue"; +import Products from "../pages/index.vue"; +export default { + path: "/Products", + component: DefaultLayout, + children: [ + { + path: "", + name: "Products", + component: Products, + // meta: { title: translate("") }, + }, + ], +}; diff --git a/src/modules/Products/services/index.api.js b/src/modules/Products/services/index.api.js new file mode 100644 index 0000000..20a9a36 --- /dev/null +++ b/src/modules/Products/services/index.api.js @@ -0,0 +1 @@ +export const api = `/`; diff --git a/src/modules/Products/services/indexService.js b/src/modules/Products/services/indexService.js new file mode 100644 index 0000000..f4d1756 --- /dev/null +++ b/src/modules/Products/services/indexService.js @@ -0,0 +1,5 @@ +import BaseService from "@/core/classes/base/BaseService"; +import { api } from "./index.api"; +import Client from "@/core/classes/client/Client"; + +export default class CategoriesService extends BaseService {} diff --git a/src/modules/Products/store/indexStore.js b/src/modules/Products/store/indexStore.js new file mode 100644 index 0000000..9de3e87 --- /dev/null +++ b/src/modules/Products/store/indexStore.js @@ -0,0 +1,11 @@ +import { defineStore } from "pinia"; +import BaseStore from "@/core/classes/base/BaseStore"; +import Service from "../services/indexService"; + +export const useHomeStore = defineStore("HomeStore", { + state: () => ({ + sliders: [], + }), + getters: {}, + actions: {}, +}); diff --git a/src/modules/qualityCertificates/components/certificateCard.vue b/src/modules/qualityCertificates/components/certificateCard.vue new file mode 100644 index 0000000..13ca5ea --- /dev/null +++ b/src/modules/qualityCertificates/components/certificateCard.vue @@ -0,0 +1,17 @@ + + + + + diff --git a/src/modules/qualityCertificates/components/showHome.vue b/src/modules/qualityCertificates/components/showHome.vue new file mode 100644 index 0000000..4dbb101 --- /dev/null +++ b/src/modules/qualityCertificates/components/showHome.vue @@ -0,0 +1,74 @@ + + + + + diff --git a/src/modules/qualityCertificates/pages/index.vue b/src/modules/qualityCertificates/pages/index.vue new file mode 100644 index 0000000..addd18a --- /dev/null +++ b/src/modules/qualityCertificates/pages/index.vue @@ -0,0 +1,7 @@ + + + + + diff --git a/src/modules/qualityCertificates/routes/index.routes.js b/src/modules/qualityCertificates/routes/index.routes.js new file mode 100644 index 0000000..2d4aa2b --- /dev/null +++ b/src/modules/qualityCertificates/routes/index.routes.js @@ -0,0 +1,15 @@ +import { translate } from "@/plugins/i18n"; +import DefaultLayout from "@/core/layouts/default/Default.vue"; +import qualityCertificates from "../pages/index.vue"; +export default { + path: "/quality-certificates", + component: DefaultLayout, + children: [ + { + path: "", + name: "quality-certificates", + component: qualityCertificates, + // meta: { title: translate("") }, + }, + ], +}; diff --git a/src/modules/qualityCertificates/services/index.api.js b/src/modules/qualityCertificates/services/index.api.js new file mode 100644 index 0000000..20a9a36 --- /dev/null +++ b/src/modules/qualityCertificates/services/index.api.js @@ -0,0 +1 @@ +export const api = `/`; diff --git a/src/modules/qualityCertificates/services/indexService.js b/src/modules/qualityCertificates/services/indexService.js new file mode 100644 index 0000000..f4d1756 --- /dev/null +++ b/src/modules/qualityCertificates/services/indexService.js @@ -0,0 +1,5 @@ +import BaseService from "@/core/classes/base/BaseService"; +import { api } from "./index.api"; +import Client from "@/core/classes/client/Client"; + +export default class CategoriesService extends BaseService {} diff --git a/src/modules/qualityCertificates/store/indexStore.js b/src/modules/qualityCertificates/store/indexStore.js new file mode 100644 index 0000000..9de3e87 --- /dev/null +++ b/src/modules/qualityCertificates/store/indexStore.js @@ -0,0 +1,11 @@ +import { defineStore } from "pinia"; +import BaseStore from "@/core/classes/base/BaseStore"; +import Service from "../services/indexService"; + +export const useHomeStore = defineStore("HomeStore", { + state: () => ({ + sliders: [], + }), + getters: {}, + actions: {}, +}); diff --git a/src/plugins/README.md b/src/plugins/README.md new file mode 100644 index 0000000..62201c7 --- /dev/null +++ b/src/plugins/README.md @@ -0,0 +1,3 @@ +# Plugins + +Plugins are a way to extend the functionality of your Vue application. Use this folder for registering plugins that you want to use globally. diff --git a/src/plugins/axios.js b/src/plugins/axios.js new file mode 100644 index 0000000..61d2b38 --- /dev/null +++ b/src/plugins/axios.js @@ -0,0 +1,6 @@ +import axios from "axios"; +import Client from "@/core/classes/client/Client"; + + +//initializing http client with interceptors +window.axios = Client.initHttp(axios); diff --git a/src/plugins/i18n/index.js b/src/plugins/i18n/index.js new file mode 100644 index 0000000..eee0db2 --- /dev/null +++ b/src/plugins/i18n/index.js @@ -0,0 +1,37 @@ +import { createI18n } from "vue-i18n"; +import arTranslations from "./translations/ar"; +import enTranslations from "./translations/en"; +import { ar, en } from "vuetify/locale"; + +const i18n = createI18n({ + legacy: false, + locale: localStorage.getItem("locale") || "en", + fallbackLocale: "en", + messages: { + en: { + ...enTranslations, + $vuetify: { + ...en, + dataIterator: { + rowsPerPageText: "Items per page:", + pageText: "{0}-{1} of {2}", + }, + }, + }, + ar: { + ...arTranslations, + $vuetify: { + ...ar, + dataIterator: { + rowsPerPageText: "العناصر في الصفحة:", + pageText: "{0}-{1} من {2}", + }, + }, + }, + }, +}); + +export function translate(key, values = {}) { + return i18n.global.t(key, values); +} +export default i18n; diff --git a/src/plugins/i18n/translations/ar.js b/src/plugins/i18n/translations/ar.js new file mode 100644 index 0000000..ff8b4c5 --- /dev/null +++ b/src/plugins/i18n/translations/ar.js @@ -0,0 +1 @@ +export default {}; diff --git a/src/plugins/i18n/translations/en.js b/src/plugins/i18n/translations/en.js new file mode 100644 index 0000000..ff8b4c5 --- /dev/null +++ b/src/plugins/i18n/translations/en.js @@ -0,0 +1 @@ +export default {}; diff --git a/src/plugins/index.js b/src/plugins/index.js new file mode 100644 index 0000000..ba068e0 --- /dev/null +++ b/src/plugins/index.js @@ -0,0 +1,18 @@ +/** + * plugins/index.js + * + * Automatically included in `./src/main.js` + */ + +// Plugins +import vuetify from "./vuetify"; +import pinia from "@/store"; +import router from "@/router"; +import i18n from "./i18n"; +import vue3lottie from "vue3-lottie"; + +import "./axios"; + +export async function registerPlugins(app) { + app.use(pinia).use(vuetify).use(router).use(i18n).use(vue3lottie); +} diff --git a/src/plugins/vuetify.js b/src/plugins/vuetify.js new file mode 100644 index 0000000..cd90d40 --- /dev/null +++ b/src/plugins/vuetify.js @@ -0,0 +1,69 @@ +/** + * plugins/vuetify.js + * + * Framework documentation: https://vuetifyjs.com` + */ + +// Styles +import "@mdi/font/css/materialdesignicons.css"; +import "vuetify/styles"; +import { createVueI18nAdapter } from "vuetify/locale/adapters/vue-i18n"; +import { useI18n } from "vue-i18n"; +import i18n from "@/plugins/i18n"; +// Composables +import { createVuetify } from "vuetify"; +const myCustomLightTheme = { + dark: false, + colors: { + background: "##FFFFFF ", + surface: "#FFFFFF", + "surface-bright": "#FFFFFF", + "surface-light": "#EEEEEE", + "surface-variant": "#424242", + "on-surface-variant": "#EEEEEE", + primary: "#2D5284", + lightPrimary: "#3B6E85", + secondary: "#7c96ab", + darkSecondary: "#2E3947", + lightSecondary: "#c5cbcf", + accent: "#E8AD0B ", + lightAccent: "#9ad0c2", + lightNeutral: "#f8f4ed", + light: "#FAF8F6", + error: "#FF5252", + info: "#2196F3", + success: "#1FBD84", + warning: "#FFC107", + }, + variables: { + "border-color": "#000000", + "border-opacity": 0.12, + "high-emphasis-opacity": 0.87, + "medium-emphasis-opacity": 0.6, + "disabled-opacity": 0.38, + "idle-opacity": 0.04, + "hover-opacity": 0.04, + "focus-opacity": 0.12, + "selected-opacity": 0.08, + "activated-opacity": 0.12, + "pressed-opacity": 0.12, + "dragged-opacity": 0.08, + "theme-kbd": "#212529", + "theme-on-kbd": "#FFFFFF", + "theme-code": "#F5F5F5", + "theme-on-code": "#000000", + "theme-on-accent": "#FFFFFF", + }, +}; + +export default createVuetify({ + locale: { + adapter: createVueI18nAdapter({ i18n, useI18n }), + }, + theme: { + defaultTheme: "myCustomLightTheme", + themes: { + myCustomLightTheme, + }, + }, +}); diff --git a/src/router/index.js b/src/router/index.js new file mode 100644 index 0000000..6cb8339 --- /dev/null +++ b/src/router/index.js @@ -0,0 +1,56 @@ +import { createRouter, createWebHistory } from "vue-router"; +import { useGlobalStore } from "../store/GlobalStore"; +import pinia from "@/store"; +import NotFound from "@/core/components/NotFound.vue"; +import DefaultLayout from "@/core/layouts/default/Default.vue"; + +import importRoutes from "./routes"; + +const globalStore = useGlobalStore(pinia); + +const router = createRouter({ + history: createWebHistory(), + routes: [ + ...importRoutes(), + // Fallback route + { + path: "/:catchAll(.*)", + component: DefaultLayout, + children: [ + { + path: "", + name: "404", + component: NotFound, + meta: { title: "صفحة غير موجودة" }, + }, + ], + }, + ], + scrollBehavior(to) { + if (to.hash) { + return { + el: to.hash, + behavior: "smooth", + }; + } + }, +}); + +const originalPush = router.push; +router.push = function push(location) { + return originalPush.call(this, location).catch((err) => { + if (err.name !== "NavigationDuplicated") throw err; + }); +}; + +const DEFAULT_TITLE = "MNS"; +router.afterEach((to) => { + document.title = to.meta.title || DEFAULT_TITLE; +}); + +router.afterEach(() => { + window.scrollTo(0, 0); + globalStore.isDrawerVisible = false; +}); + +export default router; diff --git a/src/router/routes.js b/src/router/routes.js new file mode 100644 index 0000000..6903781 --- /dev/null +++ b/src/router/routes.js @@ -0,0 +1,14 @@ +function importRoutes() { + const routeFiles = import.meta.glob("/**/*.routes.js", { eager: true }); + const routes = []; + for (const path in routeFiles) { + if (Object.prototype.hasOwnProperty.call(routeFiles, path)) { + const routeModule = routeFiles[path]; + const routeConfig = routeModule.default || routeModule; + routes.push(routeConfig); + } + } + return routes; +} + +export default importRoutes; diff --git a/src/store/GlobalStore.js b/src/store/GlobalStore.js new file mode 100644 index 0000000..ed9e5db --- /dev/null +++ b/src/store/GlobalStore.js @@ -0,0 +1,26 @@ +import { defineStore } from "pinia"; + +export const useGlobalStore = defineStore("globalStore", { + state: () => ({ + isLoading: false, + isDrawerVisible: false, + locale: localStorage.getItem("locale") ?? "en", + }), + getters: { + getIsLoading: (state) => state.isLoading, + getIsDrawerVisible: (state) => state.isDrawerVisible, + getCurrentLocale: (state) => state.locale, + }, + actions: { + changeLoadingStatus(value) { + this.isLoading = value; + }, + changeDrawerVisibility() { + this.isDrawerVisible = !this.isDrawerVisible; + }, + changeCurrentLocale(newLocale) { + this.locale = newLocale; + localStorage.setItem("locale", newLocale); + }, + }, +}); diff --git a/src/store/SnackbarStore.js b/src/store/SnackbarStore.js new file mode 100644 index 0000000..21d83a4 --- /dev/null +++ b/src/store/SnackbarStore.js @@ -0,0 +1,19 @@ +import { defineStore } from 'pinia'; + +export const useSnackbarStore = defineStore('snackbarModule', { + state: () => ({ + isSnackbarVisible: false, + snackbarOptions: {}, + message: 'message', + icon: 'tabler:checkbox', + }), + actions: { + // 👉 index + async showSnackbar(message, options, icon) { + this.snackbarOptions = options + this.icon = icon || (options.color === 'error' ? 'tabler:xbox-x' : options.color === 'success' ? 'tabler:checkbox' : 'tabler:info-circle') + this.message = message + this.isSnackbarVisible = true + }, + }, +}) diff --git a/src/store/app.js b/src/store/app.js new file mode 100644 index 0000000..7429543 --- /dev/null +++ b/src/store/app.js @@ -0,0 +1,8 @@ +// Utilities +import { defineStore } from 'pinia' + +export const useAppStore = defineStore('app', { + state: () => ({ + // + }), +}) diff --git a/src/store/index.js b/src/store/index.js new file mode 100644 index 0000000..7b11dba --- /dev/null +++ b/src/store/index.js @@ -0,0 +1,4 @@ +// Utilities +import { createPinia } from "pinia"; + +export default createPinia(); diff --git a/src/styles/settings.scss b/src/styles/settings.scss new file mode 100644 index 0000000..c8c7015 --- /dev/null +++ b/src/styles/settings.scss @@ -0,0 +1,51 @@ +/** + * src/styles/settings.scss + * + * Configures SASS variables and Vuetify overwrites + */ + +// https://vuetifyjs.com/features/sass-variables/` +// @use 'vuetify/settings' with ( +// $color-pack: false +// ); +$font-family-custom: "Poppins", "Roboto"; + +@forward "vuetify/settings" with ( + $body-font-family: $font-family-custom !default, + $typography: ( + "h1": ( + "weight": 700, + "line-height": 6rem, + "text-transform": unset, + ), + "h2": ( + "weight": 600, + "font-size": 3.6rem, + "line-height": 4rem, + ), + "h3": ( + "weight": 700, + "letter-spacing": -0.0938rem, + "line-height": 74px, + + "text-transform": unset, + ), + "h4": ( + "weight": 600, + "letter-spacing": -0.0938rem, + "font-size": 2.45rem, + "line-height": 2.9rem, + "text-transform": unset, + ), + "h5": ( + "weight": 600, + "letter-spacing": -0.0938rem, + "line-height": 42px, + "text-transform": unset, + ), + "h6": ( + "text-transform": unset, + ), + ) + !default +); diff --git a/vite.config.js b/vite.config.js new file mode 100644 index 0000000..2425509 --- /dev/null +++ b/vite.config.js @@ -0,0 +1,48 @@ +// Plugins +import vue from "@vitejs/plugin-vue"; +import vuetify, { transformAssetUrls } from "vite-plugin-vuetify"; +import ViteFonts from "unplugin-fonts/vite"; + +// Utilities +import { defineConfig } from "vite"; +import { fileURLToPath, URL } from "node:url"; + +// https://vitejs.dev/config/ +export default defineConfig({ + plugins: [ + vue({ + template: { transformAssetUrls }, + }), + // https://github.com/vuetifyjs/vuetify-loader/tree/next/packages/vite-plugin + vuetify({ + autoImport: true, + styles: { + configFile: "src/styles/settings.scss", + }, + }), + ViteFonts({ + google: { + families: [ + { + name: "Roboto", + styles: "wght@100;300;400;500;700;900", + }, + { + name: "Poppins", + styles: "wght@100;300;400;500;600;700;900", + }, + ], + }, + }), + ], + define: { "process.env": {} }, + resolve: { + alias: { + "@": fileURLToPath(new URL("./src", import.meta.url)), + }, + extensions: [".js", ".json", ".jsx", ".mjs", ".ts", ".tsx", ".vue"], + }, + server: { + port: 3000, + }, +});